jekyll-open-sdg-plugins 1.0.0.rc11 → 1.0.0.rc12

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: 3668b012dcfdd9957e10f37855cc46b01ca36fa7da976f45797c15272ebb4086
4
- data.tar.gz: 3a87d3869abbe9286df6cf1656c1b0d7f2ab7d6aac033c959216a151fc741e9f
3
+ metadata.gz: f3ddcd012812807b48b5b94dbbedfe47d4c3187f60383439fa0eb26c1f28e90f
4
+ data.tar.gz: 64a473bdd4e7f3c64f2d9cf2e1c1e1b7659b2273f96b4089e0f4c74f0a8a09fb
5
5
  SHA512:
6
- metadata.gz: a589b05b8c085a70ece51a29ba5435b00757ccd91b87f75b3e56c6f3fd9b22f3c3cb868a6a13b73472fee32f2ed6a4e0943ecdc5579eaf7396070db058964616
7
- data.tar.gz: a330617aee360e7ad4ccbd0795bfcca9b5ae1943f79eca35814b34e963e2614ed74cb1d5bbf461377a4651a60f6d159ed6121e513c9df4bdfbd229cbf87bc581
6
+ metadata.gz: 3bc05be3e1b50b49560c235df08893590ba67ace6b59056c77d049f7bb650ce955cc1ec1257145a7a02835f5245f4d8e84816eda4cf616e31a9549dac519b96f
7
+ data.tar.gz: 994312f102ed250a8978d812aacc7d598767d062b5c9b065c420012311199345514cd0765b4af19bdd483bd684d9f83b405c3427c14ce54e9fcc93c7112650cb
@@ -5,6 +5,7 @@ require_relative "jekyll-open-sdg-plugins/create_indicators"
5
5
  require_relative "jekyll-open-sdg-plugins/create_goals"
6
6
  require_relative "jekyll-open-sdg-plugins/create_pages"
7
7
  require_relative "jekyll-open-sdg-plugins/sdg_variables"
8
+ require_relative "jekyll-open-sdg-plugins/search_index"
8
9
 
9
10
  module JekyllOpenSdgPlugins
10
11
  end
@@ -0,0 +1,75 @@
1
+ require "jekyll"
2
+ require_relative "helpers"
3
+
4
+ module JekyllOpenSdgPlugins
5
+ class SearchIndex < Jekyll::Generator
6
+ safe true
7
+ priority :lowest
8
+ # NOTE: This must be executed **after** the sdg_variables.rb file, since it
9
+ # relies heavily on the variables created there.
10
+
11
+ def generate(site)
12
+
13
+ # Generate a hash of items to include in the search index.
14
+ search_items = {}
15
+
16
+ site.collections.keys.each do |collection|
17
+ site.collections[collection].docs.each do |doc|
18
+ # We segregate the search items by language.
19
+ language = doc.data['language']
20
+ if !search_items.has_key? language
21
+ search_items[language] = {}
22
+ end
23
+ # We'll be adding properties to this basic hash.
24
+ item = {
25
+ # The 'type' can be used on the front-end to describe a search result.
26
+ # It is assumed that all the collection names are translated in the
27
+ # "general" translation group. Eg: general.indicators, general.goals
28
+ 'type' => opensdg_translate_key('general.' + collection, site.data['translations'], language)
29
+ }
30
+ if collection == 'indicators'
31
+ # For indicators, we assign the following properties for each item.
32
+ # The URL of the page.
33
+ item['url'] = doc.data['indicator']['url']
34
+ # For the title, use the indicator name.
35
+ item['title'] = doc.data['indicator']['name']
36
+ # For the content, use the 'page_content' field.
37
+ item['content'] = doc.data['indicator']['page_content']
38
+ # For the hidden field, use the ID number.
39
+ item['hidden'] = doc.data['indicator']['number']
40
+ # Also index any additional metadata fields.
41
+ if site.config['search_index_extra_fields']
42
+ site.config['search_index_extra_fields'].each do |field|
43
+ if doc.data['indicator'].has_key? field
44
+ item['hidden'] += ' ' + doc.data['indicator'][field]
45
+ end
46
+ end
47
+ end
48
+ elsif collection == 'goals'
49
+ # For goals, we assign the following properties for each item.
50
+ # The URL of the page.
51
+ item['url'] = doc.data['goal']['url']
52
+ # For the title we use the goal name.
53
+ item['title'] = doc.data['goal']['name']
54
+ # For the content, currently nothing here.
55
+ item['content'] = ''
56
+ # For the hidden field, use the ID number.
57
+ item['hidden'] = doc.data['goal']['number']
58
+ else
59
+ # Otherwise assume it is a normal Jekyll document.
60
+ item['url'] = doc.url
61
+ item['title'] = doc.data['title']
62
+ item['content'] = doc.content
63
+ item['hidden'] = ''
64
+ end
65
+
66
+ # Save this item in the language-specific search index.
67
+ search_items[language][item['url']] = item
68
+ end
69
+ end
70
+
71
+ # Stow the data for later use in Jekyll templates.
72
+ site.data['search_items'] = search_items
73
+ end
74
+ end
75
+ end
@@ -1,3 +1,3 @@
1
1
  module JekyllOpenSdgPlugins
2
- VERSION = "1.0.0.rc11".freeze
2
+ VERSION = "1.0.0.rc12".freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: jekyll-open-sdg-plugins
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.0.rc11
4
+ version: 1.0.0.rc12
5
5
  platform: ruby
6
6
  authors:
7
7
  - Brock Fanning
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-01-10 00:00:00.000000000 Z
11
+ date: 2020-01-11 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: jekyll
@@ -57,6 +57,7 @@ files:
57
57
  - lib/jekyll-open-sdg-plugins/fetch_remote_data.rb
58
58
  - lib/jekyll-open-sdg-plugins/helpers.rb
59
59
  - lib/jekyll-open-sdg-plugins/sdg_variables.rb
60
+ - lib/jekyll-open-sdg-plugins/search_index.rb
60
61
  - lib/jekyll-open-sdg-plugins/translate_key.rb
61
62
  - lib/jekyll-open-sdg-plugins/version.rb
62
63
  homepage: https://github.com/open-sdg/jekyll-open-sdg-plugins