izi_lightup 0.0.0.1 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 130b95a322e27bff9b2b60080ca086f90d9a1a391d7cace27e479f78b9291585
4
- data.tar.gz: b090a0d62203d7f4338c53eda32db9c64191686e0871d2bd59b14d075681d167
3
+ metadata.gz: f8f79dcdf158759fc11c0b29c8b8a97b54c250c42ba80df355a82a605df2740a
4
+ data.tar.gz: 523adf5e981759cef50da8418dcc167c8cf6cee7beb11f62cf1c3eab82a05468
5
5
  SHA512:
6
- metadata.gz: 46424c06388df9af3110d69e781e4453713bb6d85dc3326e80fe8cab868152da360a0cd75c44088a12163040a7400677b96190f0f5879b8ce2797439bbd77f04
7
- data.tar.gz: bc4da804bc238a6a158003362814c4aff7e2249b8c9ba2e0dfbcb967d5d6b064c63aa0cf8c8153873ff3d59aab955c5ea33d533e282d2dc57b1e389cd3969129
6
+ metadata.gz: 5e1d85ee87b1af74d7e8d580950271585126bcfde37f381a912d220130fa9f0ae7d98ac1b41e102115f0674b0672dede6d88db363c83d574766a0f8787cbea35
7
+ data.tar.gz: e6cd686fc83af4063aed999def9fcddcab442f0954f784f03ad3ec26c88b7b9f5cf0a52297c66c32e7c17a1900b141323ff2b2b6cf7fe0df1dab56284171388b
@@ -0,0 +1,2 @@
1
+ //= require cssrelpreload.js
2
+ //= require loadCSS.js
@@ -1,10 +1,13 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module CriticalHelper
4
- def css_preload(name)
5
- link = content_tag :link, '', rel: 'preload', href: stylesheet_path(name), as: 'style', onload: 'this.rel="stylesheet"'
4
+ def css_preload(names)
5
+ return '' if names.blank?
6
+ names = Array.wrap(names)
7
+
8
+ link = stylesheet_link_tag(*names, rel: 'preload', as: 'style', onload: 'this.rel="stylesheet"')
6
9
  noscript = content_tag :noscript do
7
- content_tag :link, '', rel: 'stylesheet', href: stylesheet_path(name)
10
+ stylesheet_link_tag(*names)
8
11
  end
9
12
 
10
13
  link + noscript
@@ -24,20 +27,28 @@ module CriticalHelper
24
27
  inline_js('crit-utils/bundle.js').presence || '<!-- CRIT JS NOT FOUND! -->'.html_safe
25
28
  end
26
29
 
27
- def critical_css
30
+ def critical_css(params = {})
28
31
  name = find_scoped_css('critical')
29
- return '<!-- CRIT CSS NOT FOUND! -->'.html_safe if name.blank?
32
+ stylesheets = Array.wrap(params.fetch(:stylesheets, []))
33
+ data = StringIO.new
30
34
 
31
- return inline_css(name) if Rails.env.production?
35
+ if name.blank?
36
+ # insert stylesheets directly if not crit css
37
+ data << '<!-- CRIT CSS NOT FOUND! -->'
38
+ data << stylesheet_link_tag(*stylesheets) if stylesheets.present?
39
+ else
40
+ data << inline_css(name)
41
+ data << css_preload(stylesheets) if stylesheets.present?
42
+ data << inline_js('crit-utils/measure.js') if Rails.env.development?
43
+ end
32
44
 
33
- # inject measure js for development
34
- inline_css(name) + inline_js('utils/measure.js')
45
+ data.string.html_safe
35
46
  end
36
47
 
37
- def smart_picture(object, fields = %i[picture], versions = [], params = {})
48
+ def smart_picture(object, *args, **xargs, &block)
38
49
  return '' if object.blank?
39
50
 
40
- IziLightup::SmartPicture.render(object, fields, versions, params)
51
+ IziLightup::SmartPicture.render(object, *args, **xargs, &block)
41
52
  end
42
53
 
43
54
  private
@@ -12,6 +12,7 @@ module IziLightup
12
12
 
13
13
  loadCSS.js
14
14
  cssrelpreload.js
15
+ crit-utils/async-css.js
15
16
  ]
16
17
  end
17
18
  end
@@ -33,12 +33,22 @@ module IziLightup
33
33
  end
34
34
 
35
35
  def raw_source(asset_path)
36
+ return find_sources_fallback(asset_path) if old_manifest?
37
+
36
38
  manifest.find_sources(asset_path).first&.html_safe
37
39
  end
38
40
 
41
+ def old_manifest?
42
+ !manifest.respond_to?(:find_sources)
43
+ end
44
+
39
45
  def manifest
40
46
  @manifest ||= Rails.application.assets_manifest
41
47
  end
48
+
49
+ def find_sources_fallback(asset_path)
50
+ Rails.application.assets.find_asset(asset_path)&.source&.html_safe
51
+ end
42
52
  end
43
53
  end
44
54
  end
@@ -2,9 +2,9 @@
2
2
 
3
3
  module IziLightup
4
4
  module SmartPicture
5
- include ActionView::Helpers::AssetTagHelper
6
-
7
5
  class << self
6
+ include ActionView::Helpers::AssetTagHelper
7
+
8
8
  def render(object, fields = %i[picture], versions = [], params = {})
9
9
  return '' if object.blank?
10
10
 
@@ -19,7 +19,7 @@ module IziLightup
19
19
  next unless version_name == :default || item.data.respond_to?(version_name)
20
20
 
21
21
  version = version_name == :default ? item.data : item.data.public_send(version_name)
22
- next if version&.url&.blank?
22
+ next unless version&.file&.exists? && version&.url&.present?
23
23
 
24
24
  url = version.url
25
25
  params.merge!(%i[width height].zip(version.dimensions).to_h)
@@ -32,6 +32,14 @@ module IziLightup
32
32
 
33
33
  ''
34
34
  end
35
+
36
+ private
37
+
38
+ def fetch_items(object, fields)
39
+ Array.wrap(fields).map do |name|
40
+ object.respond_to?(name) ? object.public_send(name) : nil
41
+ end.compact
42
+ end
35
43
  end
36
44
  end
37
45
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module IziLightup
4
- VERSION = '0.0.0.1'
4
+ VERSION = '1.0.4'
5
5
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: izi_lightup
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.0.1
4
+ version: 1.0.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - IzikAJ
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-08-31 00:00:00.000000000 Z
11
+ date: 2020-10-05 00:00:00.000000000 Z
12
12
  dependencies: []
13
13
  description: |-
14
14
  Utils to speed up page load by using critical css &
@@ -20,6 +20,7 @@ extra_rdoc_files: []
20
20
  files:
21
21
  - README.rdoc
22
22
  - app/assets/javascripts/crit-utils/active_emit.js.coffee
23
+ - app/assets/javascripts/crit-utils/async-css.js
23
24
  - app/assets/javascripts/crit-utils/bundle.js
24
25
  - app/assets/javascripts/crit-utils/measure.js
25
26
  - app/assets/javascripts/crit-utils/measure/cls.js.coffee
@@ -35,7 +36,8 @@ files:
35
36
  - vendor/assets/javascripts/cssrelpreload.js
36
37
  - vendor/assets/javascripts/loadCSS.js
37
38
  homepage: https://bitbucket.org/netfixllc/izi_lightup
38
- licenses: []
39
+ licenses:
40
+ - MIT
39
41
  metadata: {}
40
42
  post_install_message:
41
43
  rdoc_options: []