Sha256: a8809f575788283378141d98acb7c55c0c7ee6ed5a9a84f31ffc35e9c4075400
Contents?: true
Size: 1.68 KB
Versions: 1
Compression:
Stored size: 1.68 KB
Contents
namespace :javascript do desc "Install JavaScript dependencies" task :install do command = install_command unless system(command) raise "jsbundling-rails: Command install failed, ensure #{command.split.first} is installed" end end desc "Build your JavaScript bundle" build_task = task :build do command = build_command unless system(command) raise "jsbundling-rails: Command build failed, ensure `#{command}` runs without errors" end end build_task.prereqs << :install unless ENV["SKIP_YARN_INSTALL"] || ENV["SKIP_BUN_INSTALL"] end def install_command return "bun install" if File.exist?('bun.lockb') || (tool_exists?('bun') && !File.exist?('yarn.lock')) return "yarn install" if File.exist?('yarn.lock') || tool_exists?('yarn') raise "jsbundling-rails: No suitable tool found for installing JavaScript dependencies" end def build_command return "bun run build" if File.exist?('bun.lockb') || (tool_exists?('bun') && !File.exist?('yarn.lock')) return "yarn build" if File.exist?('yarn.lock') || tool_exists?('yarn') raise "jsbundling-rails: No suitable tool found for building JavaScript" end def tool_exists?(tool) system "command -v #{tool} > /dev/null" end unless ENV["SKIP_JS_BUILD"] if Rake::Task.task_defined?("assets:precompile") Rake::Task["assets:precompile"].enhance(["javascript:build"]) end if Rake::Task.task_defined?("test:prepare") Rake::Task["test:prepare"].enhance(["javascript:build"]) elsif Rake::Task.task_defined?("spec:prepare") Rake::Task["spec:prepare"].enhance(["javascript:build"]) elsif Rake::Task.task_defined?("db:test:prepare") Rake::Task["db:test:prepare"].enhance(["javascript:build"]) end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
jsbundling-rails-1.2.0 | lib/tasks/jsbundling/build.rake |