jekyll-bookshop 2.5.0 → 3.0.0.pre.beta.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: cf5eb896ec22cacd3714267136ecdc7eb77ba5896e3ad01c00640344b52bffd4
4
- data.tar.gz: '078ea4cd2d5b822d41cf3fb4c41a7069f48c27d2191c8740b93133859403f309'
3
+ metadata.gz: 6af0c6eab01547be4a41a281bc00781a9f4af5481a28981b97f70c57aae5e97b
4
+ data.tar.gz: 653ebc7a173421f2a2ca7a3ed6881cd8117b6e58e6a07d6d2ba8320c6e43332e
5
5
  SHA512:
6
- metadata.gz: 18204d893a7ef896105aa32c187632df4e3dc5156b3330b23bdc238e6dfdeb6abcacb4263111f64bff2f1d0e11d90db5b600af0dc63e9a8292bbf95df5f147c3
7
- data.tar.gz: 6a504a634faa0ca8680de0d3fe016deac9852aeb589cf6c27aec41c09ebcf24cc3fbbcd9948a8e0e4244a8aec3d531e76c5b16ce7b06b9323e1cd769a52792c2
6
+ metadata.gz: a2169a27a8d94e94cc6ec98ca41a7283ca4bf54118184ddc2dc3ed4d8aa8f733deb3005636911661caa84d1905c62a82b5cd1d85ba11440acf7b9b5ba5af6d32
7
+ data.tar.gz: a28f61c1a4d730bdd8cc5af758341094da4953c65ab1b34466c28c8e99a05e21b2af8d969229c759582f59a8593026b3d55b1f73dc6f511144837f6a3b750c67
@@ -37,12 +37,17 @@ module JekyllBookshop
37
37
  loop_context = "#{name}[#{index}]"
38
38
  end
39
39
 
40
+ # If this component is not a subcomponent,
41
+ # we also drop in some site metadata here so that it can be used in the render.
42
+ meta_comment = context["__bookshop__nested"] ? "" : "<!--bookshop-live meta(version=\"#{JekyllBookshop::VERSION.gsub(".pre.", "-")}\" baseurl=\"#{site.baseurl}\" title=\"#{site.config["title"]&.gsub('"', '\"') || ""}\") -->\n"
43
+
40
44
  context.stack do
41
45
  context["include"] = parse_params(context) if @params
46
+ context["__bookshop__nested"] = true
42
47
  begin
43
- "<!--bookshop-live name(#{file}) params(#{@params}) context(#{loop_context.gsub(/-/, '=').gsub(/=include\./, '=')}) -->
44
- #{partial.render!(context)}
45
- <!--bookshop-live end-->"
48
+ "#{meta_comment}<!--bookshop-live name(#{file}) params(#{@params}) context(#{loop_context.gsub(/-/, '=').gsub(/=include\./, '=')}) -->
49
+ #{partial.render!(context)}
50
+ <!--bookshop-live end-->"
46
51
  rescue Liquid::Error => e
47
52
  e.template_name = path
48
53
  e.markup_context = "included " if e.markup_context.nil?
@@ -30,17 +30,11 @@ module JekyllBookshop
30
30
  site = context.registers[:site]
31
31
  page = context.registers[:page]
32
32
 
33
- site.data["_bookshop_data_pages"] ||= []
34
- unless site.data["_bookshop_data_pages"].include?(page["url"])
35
- site.data["_bookshop_data_pages"].push(page["url"])
36
- end
37
-
38
33
  "<div data-bookshop-browser></div>
39
- <script>window.bookshop_browser_site_data = null;</script>
40
34
  <script src=\"#{host}\"></script>
41
35
  <script>
42
36
  window.bookshopBrowser = new window.BookshopBrowser({
43
- globals: [window.bookshop_browser_site_data]
37
+ globals: []
44
38
  });
45
39
  window.bookshopBrowser.render();
46
40
  </script>"
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module JekyllBookshop
4
- VERSION = "2.5.0"
4
+ VERSION = "3.0.0.pre.beta.0"
5
5
  end
@@ -10,7 +10,6 @@ require_relative "jekyll-bookshop/tags/bookshop-tag"
10
10
  require_relative "jekyll-bookshop/tags/browser-tag"
11
11
  require_relative "jekyll-bookshop/tags/style-tag"
12
12
  require_relative "jekyll-bookshop/opener"
13
- require_relative "jekyll-bookshop/site-data"
14
13
 
15
14
  Liquid::Template.register_tag("bookshop", JekyllBookshop::Tag)
16
15
  Liquid::Template.register_tag("bookshop_include", JekyllBookshop::IncludeTag)
@@ -20,7 +19,3 @@ Liquid::Template.register_tag("bookshop_browser", JekyllBookshop::BrowserTag)
20
19
  Jekyll::Hooks.register :site, :after_init do |site|
21
20
  JekyllBookshop::Opener.open_bookshop(site)
22
21
  end
23
-
24
- Jekyll::Hooks.register :site, :post_render do |site|
25
- JekyllBookshop::SiteData.extract(site)
26
- end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: jekyll-bookshop
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.5.0
4
+ version: 3.0.0.pre.beta.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - CloudCannon
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2022-02-22 00:00:00.000000000 Z
11
+ date: 2022-03-28 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: jekyll
@@ -87,7 +87,6 @@ extra_rdoc_files: []
87
87
  files:
88
88
  - lib/jekyll-bookshop.rb
89
89
  - lib/jekyll-bookshop/opener.rb
90
- - lib/jekyll-bookshop/site-data.rb
91
90
  - lib/jekyll-bookshop/tags/bookshop-common-tag.rb
92
91
  - lib/jekyll-bookshop/tags/bookshop-include-tag.rb
93
92
  - lib/jekyll-bookshop/tags/bookshop-tag.rb
@@ -109,9 +108,9 @@ required_ruby_version: !ruby/object:Gem::Requirement
109
108
  version: '0'
110
109
  required_rubygems_version: !ruby/object:Gem::Requirement
111
110
  requirements:
112
- - - ">="
111
+ - - ">"
113
112
  - !ruby/object:Gem::Version
114
- version: '0'
113
+ version: 1.3.1
115
114
  requirements: []
116
115
  rubygems_version: 3.0.3
117
116
  signing_key:
@@ -1,58 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- module JekyllBookshop
4
- class SiteData
5
- def self.extract(site)
6
- @site = site
7
-
8
- payload = {}
9
- @site.collections.each_pair do |collection, items|
10
- payload[collection] = items.docs.map do |doc|
11
- doc.data.merge(hydrate_document_fields(doc))
12
- end
13
- end
14
-
15
- payload["data"] = {}
16
- @site.data.each_pair do |key, value|
17
- next if key.to_s.start_with?("_bookshop")
18
-
19
- payload["data"][key] = value
20
- end
21
-
22
- payload["baseurl"] = @site.baseurl
23
- payload["title"] = @site.config["title"]
24
-
25
- @site.data["_bookshop_site_data"] = { "site" => payload }
26
-
27
- update_browser_pages
28
-
29
- Jekyll.logger.info "Bookshop:",
30
- "Bookshop site data generated"
31
- end
32
-
33
- def self.hydrate_document_fields(document)
34
- keys = %w(content url date relative_path permalink)
35
- hydrated_doc = {}
36
- keys.each { |key| hydrated_doc[key] = document.send(key) }
37
- hydrate_document_excerpt(document, hydrated_doc)
38
- end
39
-
40
- def self.hydrate_document_excerpt(document, hydrated_doc)
41
- hydrated_doc.merge!({
42
- "excerpt" => document.data["excerpt"].output,
43
- })
44
- end
45
-
46
- def self.update_browser_pages
47
- @site.pages.each do |page|
48
- next unless @site.data["_bookshop_data_pages"]&.include?(page.url)
49
-
50
- page.output = page.output.gsub(
51
- %r!bookshop_browser_site_data = null!,
52
- "bookshop_browser_site_data = #{@site.data["_bookshop_site_data"].to_json.gsub(%r!</script!i, "<\\/script")}"
53
- )
54
- end
55
- @site.data["_bookshop_data_pages"] = nil
56
- end
57
- end
58
- end