Module: Manifester::Helper
- Defined in:
- lib/manifester/helper.rb
Instance Method Summary collapse
-
#asset_manifest_path(name, **options) ⇒ Object
Computes the relative path for a given Manifester asset.
-
#asset_manifest_url(name, **options) ⇒ Object
Computes the absolute path for a given Manifester asset.
- #current_manifester_instance ⇒ Object
-
#favicon_manifest_tag(name, **options) ⇒ Object
Creates a link tag for a favicon that references the named pack file.
-
#image_manifest_path(name, **options) ⇒ Object
Computes the relative path for a given Manifester image with the same automated processing as image_manifest_tag.
-
#image_manifest_tag(name, **options) ⇒ Object
Creates an image tag that references the named pack file.
-
#image_manifest_url(name, **options) ⇒ Object
Computes the absolute path for a given Manifester image with the same automated processing as image_manifest_tag.
-
#javascript_manifest_tag(*names, **options) ⇒ Object
Creates script tags that reference the js chunks from entrypoints when using split chunks API, as compiled by webpack per the entries list in package/environments/base.js.
-
#preload_manifest_asset(name, **options) ⇒ Object
Creates a link tag, for preloading, that references a given Manifester asset.
-
#stylesheet_manifest_tag(*names, **options) ⇒ Object
Creates link tags that reference the css chunks from entrypoints when using split chunks API, as compiled by webpack per the entries list in package/environments/base.js.
Instance Method Details
#asset_manifest_path(name, **options) ⇒ Object
Computes the relative path for a given Manifester asset. Returns the relative path using manifest.json and passes it to path_to_asset helper. This will use path_to_asset internally, so most of their behaviors will be the same.
Example:
<%= asset_manifest_path 'calendar.css' %> # => "/packs/calendar-1016838bab065ae1e122.css"
14 15 16 17 18 |
# File 'lib/manifester/helper.rb', line 14 def asset_manifest_path(name, **) return asset_pack_path(name, **) if fallback_to_webpacker? path_to_asset(current_manifester_instance.manifest.lookup!(name), ) end |
#asset_manifest_url(name, **options) ⇒ Object
Computes the absolute path for a given Manifester asset. Returns the absolute path using manifest.json and passes it to url_to_asset helper. This will use url_to_asset internally, so most of their behaviors will be the same.
Example:
<%= asset_manifest_url 'calendar.css' %> # => "http://example.com/packs/calendar-1016838bab065ae1e122.css"
27 28 29 30 31 |
# File 'lib/manifester/helper.rb', line 27 def asset_manifest_url(name, **) return asset_pack_url(name, **) if fallback_to_webpacker? url_to_asset(current_manifester_instance.manifest.lookup!(name), ) end |
#current_manifester_instance ⇒ Object
3 4 5 |
# File 'lib/manifester/helper.rb', line 3 def current_manifester_instance Manifester.instance end |
#favicon_manifest_tag(name, **options) ⇒ Object
Creates a link tag for a favicon that references the named pack file.
Example:
<%= favicon_manifest_tag 'mb-icon.png', rel: 'apple-touch-icon', type: 'image/png' %>
<link href="/packs/mb-icon-k344a6d59eef8632c9d1.png" rel="apple-touch-icon" type="image/png" />
79 80 81 82 83 |
# File 'lib/manifester/helper.rb', line 79 def favicon_manifest_tag(name, **) return favicon_pack_tag(name, **) if fallback_to_webpacker? favicon_link_tag(resolve_path_to_image(name), ) end |
#image_manifest_path(name, **options) ⇒ Object
Computes the relative path for a given Manifester image with the same automated processing as image_manifest_tag. Returns the relative path using manifest.json and passes it to path_to_asset helper. This will use path_to_asset internally, so most of their behaviors will be the same.
36 37 38 39 40 |
# File 'lib/manifester/helper.rb', line 36 def image_manifest_path(name, **) return image_pack_path(name, **) if fallback_to_webpacker? resolve_path_to_image(name, **) end |
#image_manifest_tag(name, **options) ⇒ Object
Creates an image tag that references the named pack file.
Example:
<%= image_manifest_tag 'application.png', size: '16x10', alt: 'Edit Entry' %>
<img alt='Edit Entry' src='/packs/application-k344a6d59eef8632c9d1.png' width='16' height='10' />
<%= image_manifest_tag 'picture.png', srcset: { 'picture-2x.png' => '2x' } %>
<img srcset= "/packs/picture-2x-7cca48e6cae66ec07b8e.png 2x" src="/packs/picture-c38deda30895059837cf.png" >
61 62 63 64 65 66 67 68 69 70 71 |
# File 'lib/manifester/helper.rb', line 61 def image_manifest_tag(name, **) return image_pack_tag(name, **) if fallback_to_webpacker? if [:srcset] && ![:srcset].is_a?(String) [:srcset] = [:srcset].map do |src_name, size| "#{resolve_path_to_image(src_name)} #{size}" end.join(", ") end image_tag(resolve_path_to_image(name), ) end |
#image_manifest_url(name, **options) ⇒ Object
Computes the absolute path for a given Manifester image with the same automated processing as image_manifest_tag. Returns the relative path using manifest.json and passes it to path_to_asset helper. This will use path_to_asset internally, so most of their behaviors will be the same.
46 47 48 49 50 |
# File 'lib/manifester/helper.rb', line 46 def image_manifest_url(name, **) return image_pack_url(name, **) if fallback_to_webpacker? resolve_path_to_image(name, **.merge(protocol: :request)) end |
#javascript_manifest_tag(*names, **options) ⇒ Object
Creates script tags that reference the js chunks from entrypoints when using split chunks API, as compiled by webpack per the entries list in package/environments/base.js. By default, this list is auto-generated to match everything in app/packs/entrypoints/*.js and all the dependent chunks. In production mode, the digested reference is automatically looked up. See: webpack.js.org/plugins/split-chunks-plugin/
Example:
<%= javascript_manifest_tag 'calendar', 'map', 'data-turbolinks-track': 'reload' %> # =>
<script src="/packs/vendor-16838bab065ae1e314.chunk.js" data-turbolinks-track="reload"></script>
<script src="/packs/calendar~runtime-16838bab065ae1e314.chunk.js" data-turbolinks-track="reload"></script>
<script src="/packs/calendar-1016838bab065ae1e314.chunk.js" data-turbolinks-track="reload"></script>
<script src="/packs/map~runtime-16838bab065ae1e314.chunk.js" data-turbolinks-track="reload"></script>
<script src="/packs/map-16838bab065ae1e314.chunk.js" data-turbolinks-track="reload"></script>
DO:
<%= javascript_manifest_tag 'calendar', 'map' %>
DON’T:
<%= javascript_manifest_tag 'calendar' %>
<%= javascript_manifest_tag 'map' %>
108 109 110 111 112 |
# File 'lib/manifester/helper.rb', line 108 def javascript_manifest_tag(*names, **) return javascript_pack_tag(*names, **) if fallback_to_webpacker? javascript_include_tag(*manifester_sources_from_manifest_entrypoints(names, type: :javascript), **) end |
#preload_manifest_asset(name, **options) ⇒ Object
Creates a link tag, for preloading, that references a given Manifester asset. In production mode, the digested reference is automatically looked up. See: developer.mozilla.org/en-US/docs/Web/HTML/Preloading_content
Example:
<%= preload_manifest_asset 'fonts/fa-regular-400.woff2' %> # =>
<link rel="preload" href="/packs/fonts/fa-regular-400-944fb546bd7018b07190a32244f67dc9.woff2" as="font" type="font/woff2" crossorigin="anonymous">
122 123 124 125 126 127 128 129 130 |
# File 'lib/manifester/helper.rb', line 122 def preload_manifest_asset(name, **) return preload_pack_asset(name, **) if fallback_to_webpacker? if self.class.method_defined?(:preload_link_tag) preload_link_tag(current_manifester_instance.manifest.lookup!(name), ) else raise "You need Rails >= 5.2 to use this tag." end end |
#stylesheet_manifest_tag(*names, **options) ⇒ Object
Creates link tags that reference the css chunks from entrypoints when using split chunks API, as compiled by webpack per the entries list in package/environments/base.js. By default, this list is auto-generated to match everything in app/packs/entrypoints/*.js and all the dependent chunks. In production mode, the digested reference is automatically looked up. See: webpack.js.org/plugins/split-chunks-plugin/
Examples:
<%= stylesheet_manifest_tag 'calendar', 'map' %> # =>
<link rel="stylesheet" media="screen" href="/packs/3-8c7ce31a.chunk.css" />
<link rel="stylesheet" media="screen" href="/packs/calendar-8c7ce31a.chunk.css" />
<link rel="stylesheet" media="screen" href="/packs/map-8c7ce31a.chunk.css" />
DO:
<%= stylesheet_manifest_tag 'calendar', 'map' %>
DON’T:
<%= stylesheet_manifest_tag 'calendar' %>
<%= stylesheet_manifest_tag 'map' %>
153 154 155 156 157 |
# File 'lib/manifester/helper.rb', line 153 def stylesheet_manifest_tag(*names, **) return stylesheet_pack_tag(*names, **) if fallback_to_webpacker? stylesheet_link_tag(*manifester_sources_from_manifest_entrypoints(names, type: :stylesheet), **) end |