Module: ReactOnRails::PackerUtils

Defined in:
lib/react_on_rails/packer_utils.rb

Class Method Summary collapse

Class Method Details

.asset_uri_from_packer(asset_name) ⇒ Object

The function doesn’t ensure that the asset exists.

  • It just returns url to the asset if dev server is running

  • Otherwise it returns file path to the asset



87
88
89
90
91
92
93
# File 'lib/react_on_rails/packer_utils.rb', line 87

def self.asset_uri_from_packer(asset_name)
  if dev_server_running?
    "#{dev_server_url}/#{public_output_uri_path}#{asset_name}"
  else
    File.join(packer_public_output_path, asset_name).to_s
  end
end

.bundle_js_uri_from_packer(bundle_name) ⇒ Object

This returns either a URL for the webpack-dev-server, non-server bundle or the hashed server bundle if using the same bundle for the client. Otherwise returns a file path.



62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
# File 'lib/react_on_rails/packer_utils.rb', line 62

def self.bundle_js_uri_from_packer(bundle_name)
  hashed_bundle_name = packer.manifest.lookup!(bundle_name)

  # Support for hashing the server-bundle and having that built
  # the webpack-dev-server is provided by the config value
  # "same_bundle_for_client_and_server" where a value of true
  # would mean that the bundle is created by the webpack-dev-server
  is_bundle_running_on_server = (bundle_name == ReactOnRails.configuration.server_bundle_js_file) ||
                                (bundle_name == ReactOnRails.configuration.rsc_bundle_js_file)

  if packer.dev_server.running? && (!is_bundle_running_on_server ||
    ReactOnRails.configuration.same_bundle_for_client_and_server)
    "#{dev_server_url}#{hashed_bundle_name}"
  else
    File.expand_path(File.join("public", hashed_bundle_name)).to_s
  end
end

.check_manifest_not_cachedObject



125
126
127
128
129
130
131
132
133
134
135
# File 'lib/react_on_rails/packer_utils.rb', line 125

def self.check_manifest_not_cached
  return unless using_packer? && packer.config.cache_manifest?

  msg = <<-MSG.strip_heredoc
      ERROR: you have enabled cache_manifest in the #{Rails.env} env when using the
      ReactOnRails::TestHelper.configure_rspec_to_compile_assets helper
      To fix this: edit your config/#{packer_type}.yml file and set cache_manifest to false for test.
  MSG
  puts wrap_message(msg)
  exit!
end

.dev_server_running?Boolean

Returns:

  • (Boolean)


29
30
31
32
33
# File 'lib/react_on_rails/packer_utils.rb', line 29

def self.dev_server_running?
  return false unless using_packer?

  packer.dev_server.running?
end

.dev_server_urlObject



35
36
37
# File 'lib/react_on_rails/packer_utils.rb', line 35

def self.dev_server_url
  "#{packer.dev_server.protocol}://#{packer.dev_server.host_with_port}"
end

.manifest_exists?Boolean

Returns:

  • (Boolean)


117
118
119
# File 'lib/react_on_rails/packer_utils.rb', line 117

def self.manifest_exists?
  packer.config.public_manifest_path.exist?
end

.nested_entries?Boolean

Returns:

  • (Boolean)


109
110
111
# File 'lib/react_on_rails/packer_utils.rb', line 109

def self.nested_entries?
  packer.config.nested_entries?
end

.packerObject



22
23
24
25
26
27
# File 'lib/react_on_rails/packer_utils.rb', line 22

def self.packer
  return nil unless using_packer?

  require "shakapacker"
  ::Shakapacker
end

.packer_public_output_pathObject



113
114
115
# File 'lib/react_on_rails/packer_utils.rb', line 113

def self.packer_public_output_path
  packer.config.public_output_path.to_s
end

.packer_source_entry_pathObject



105
106
107
# File 'lib/react_on_rails/packer_utils.rb', line 105

def self.packer_source_entry_path
  packer.config.source_entry_path
end

.packer_source_pathObject



101
102
103
# File 'lib/react_on_rails/packer_utils.rb', line 101

def self.packer_source_path
  packer.config.source_path
end

.packer_source_path_explicit?Boolean

Returns:

  • (Boolean)


121
122
123
# File 'lib/react_on_rails/packer_utils.rb', line 121

def self.packer_source_path_explicit?
  packer.config.send(:data)[:source_path].present?
end

.packer_typeObject



16
17
18
19
20
# File 'lib/react_on_rails/packer_utils.rb', line 16

def self.packer_type
  return "shakapacker" if using_shakapacker_const?

  nil
end

.precompile?Boolean

Returns:

  • (Boolean)


95
96
97
98
99
# File 'lib/react_on_rails/packer_utils.rb', line 95

def self.precompile?
  return ::Shakapacker.config.shakapacker_precompile? if using_shakapacker_const?

  false
end

.public_output_uri_pathObject



80
81
82
# File 'lib/react_on_rails/packer_utils.rb', line 80

def self.public_output_uri_path
  "#{packer.config.public_output_path.relative_path_from(packer.config.public_path)}/"
end

.raise_nested_entries_disabledObject



149
150
151
152
153
154
155
156
157
# File 'lib/react_on_rails/packer_utils.rb', line 149

def self.raise_nested_entries_disabled
  msg = <<~MSG
    **ERROR** ReactOnRails: `nested_entries` is configured to be disabled in shakapacker. Please update \
    config/#{packer_type}.yml to enable nested entries. for more information read
    https://www.shakacode.com/react-on-rails/docs/guides/file-system-based-automated-bundle-generation.md#enable-nested_entries-for-shakapacker
  MSG

  raise ReactOnRails::Error, msg
end

.raise_shakapacker_not_installedObject



169
170
171
172
173
174
175
176
177
# File 'lib/react_on_rails/packer_utils.rb', line 169

def self.raise_shakapacker_not_installed
  msg = <<~MSG
    **ERROR** ReactOnRails: Missing Shakapacker gem. Please upgrade to use Shakapacker \
    #{ReactOnRails::PacksGenerator::MINIMUM_SHAKAPACKER_VERSION} or above to use the \
    automated bundle generation feature.
  MSG

  raise ReactOnRails::Error, msg
end

.raise_shakapacker_version_incompatible_for_autobundlingObject



159
160
161
162
163
164
165
166
167
# File 'lib/react_on_rails/packer_utils.rb', line 159

def self.raise_shakapacker_version_incompatible_for_autobundling
  msg = <<~MSG
    **ERROR** ReactOnRails: Please upgrade Shakapacker to version #{ReactOnRails::PacksGenerator::MINIMUM_SHAKAPACKER_VERSION} or \
    above to use the automated bundle generation feature. The currently installed version is \
    #{ReactOnRails::PackerUtils.shakapacker_version}.
  MSG

  raise ReactOnRails::Error, msg
end

.shakapacker_versionObject



39
40
41
42
43
44
# File 'lib/react_on_rails/packer_utils.rb', line 39

def self.shakapacker_version
  return @shakapacker_version if defined?(@shakapacker_version)
  return nil unless ReactOnRails::Utils.gem_available?("shakapacker")

  @shakapacker_version = Gem.loaded_specs["shakapacker"].version.to_s
end

.shakapacker_version_as_arrayObject



46
47
48
49
50
51
52
53
# File 'lib/react_on_rails/packer_utils.rb', line 46

def self.shakapacker_version_as_array
  return @shakapacker_version_as_array if defined?(@shakapacker_version_as_array)

  match = shakapacker_version.match(ReactOnRails::VersionChecker::VERSION_PARTS_REGEX)

  # match[4] is the pre-release version, not normally a number but something like "beta.1" or `nil`
  @shakapacker_version_as_array = [match[1].to_i, match[2].to_i, match[3].to_i, match[4]].compact
end

.shakapacker_version_requirement_met?(required_version) ⇒ Boolean

Returns:

  • (Boolean)


55
56
57
# File 'lib/react_on_rails/packer_utils.rb', line 55

def self.shakapacker_version_requirement_met?(required_version)
  Gem::Version.new(shakapacker_version) >= Gem::Version.new(required_version)
end

.using_packer?Boolean

Returns:

  • (Boolean)


5
6
7
# File 'lib/react_on_rails/packer_utils.rb', line 5

def self.using_packer?
  using_shakapacker_const?
end

.using_shakapacker_const?Boolean

Returns:

  • (Boolean)


9
10
11
12
13
14
# File 'lib/react_on_rails/packer_utils.rb', line 9

def self.using_shakapacker_const?
  return @using_shakapacker_const if defined?(@using_shakapacker_const)

  @using_shakapacker_const = ReactOnRails::Utils.gem_available?("shakapacker") &&
                             shakapacker_version_requirement_met?("8.2.0")
end

.webpack_assets_status_checkerObject



137
138
139
140
141
142
143
144
145
146
147
# File 'lib/react_on_rails/packer_utils.rb', line 137

def self.webpack_assets_status_checker
  source_path = ReactOnRails::Utils.source_path
  generated_assets_full_path = ReactOnRails::Utils.generated_assets_full_path
  webpack_generated_files = ReactOnRails.configuration.webpack_generated_files

  @webpack_assets_status_checker ||= ReactOnRails::TestHelper::WebpackAssetsStatusChecker.new(
    source_path: source_path,
    generated_assets_full_path: generated_assets_full_path,
    webpack_generated_files: webpack_generated_files
  )
end