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