nereare_grimoire 1.13.13 → 1.21.0

Sign up to get free protection for your applications and to get access to all the features.
data/assets/search.js ADDED
@@ -0,0 +1,58 @@
1
+ $(document).ready(function() {
2
+ console.log("App ready!");
3
+
4
+ // Get search parameter
5
+ let searchParams = new URLSearchParams(window.location.search)
6
+ let search = searchParams.get("text");
7
+
8
+ // Get searchable fields
9
+ let fields = null;
10
+ let results = [];
11
+ let unique_results = [];
12
+ $.getJSON("/search.json")
13
+ .done(function(json) {
14
+ console.log("Got searchable fields.");
15
+ fields = json;
16
+ })
17
+ .fail(function() {
18
+ console.log("There was a problem retrieving searchable fields.");
19
+ })
20
+ .always(function() {
21
+ console.log("Begining search...");
22
+ // Parse it there is any results
23
+ $.each(fields, function(index, value) {
24
+ if ( value["title"].toLowerCase().includes( search ) ||
25
+ value["date"].toLowerCase().includes( search ) ||
26
+ value["content"].toLowerCase().includes( search ) ) {
27
+ results.push( index );
28
+ }
29
+ });
30
+ // Remove duplicate results
31
+ unique_results = results.filter( onlyUnique );
32
+ // Check if there are any results
33
+ if ( unique_results.length > 0 ) {
34
+ $.each(unique_results, function(index, value) {
35
+ let link = $("<a>");
36
+ link.html( fields[value]["title"] );
37
+ link.attr("href", fields[value]["url"]);
38
+ let strong = $("<strong>");
39
+ strong.append( link );
40
+ let span = $("<span>");
41
+ let date = new Date( fields[value]["date"] );
42
+ let options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' };
43
+ span.html( " (" + date.toLocaleDateString("en-US", options) + ")" );
44
+ let result = $("<li>");
45
+ result.append( strong );
46
+ result.append( span );
47
+ $("#results").append( result );
48
+ });
49
+ } else {
50
+ let meh = $("<li>").html("No results were found...");
51
+ $("#results").append( meh );
52
+ }
53
+ });
54
+ });
55
+
56
+ function onlyUnique(value, index, self) {
57
+ return self.indexOf(value) === index;
58
+ }
@@ -0,0 +1,15 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: chapters = site.chapters | join: '' %}
6
+ {% if chapters != '' %}
7
+ <div class="collection">
8
+ <h1>Chapters</h1>
9
+ <ul>
10
+ {% for chapter in site.chapters %}
11
+ <li><strong><a href="{{ chapter.url }}">{{ chapter.title }}</a>:</strong> chapter {{ chapter.chapter.number }} from {{ chapter.chapter.book }}.</li>
12
+ {% endfor %}
13
+ </ul>
14
+ </div>
15
+ {% endif %}
data/docs/404.html ADDED
@@ -0,0 +1,25 @@
1
+ ---
2
+ permalink: /404.html
3
+ layout: default
4
+ ---
5
+
6
+ <style type="text/css" media="screen">
7
+ .container {
8
+ margin: 10px auto;
9
+ max-width: 600px;
10
+ text-align: center;
11
+ }
12
+ h1 {
13
+ margin: 30px 0;
14
+ font-size: 4em;
15
+ line-height: 1;
16
+ letter-spacing: -1px;
17
+ }
18
+ </style>
19
+
20
+ <div class="container">
21
+ <h1>404</h1>
22
+
23
+ <p><strong>Page not found :(</strong></p>
24
+ <p>The requested page could not be found.</p>
25
+ </div>
@@ -0,0 +1,15 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: items = site.items | join: '' %}
6
+ {% if items != '' %}
7
+ <div class="collection">
8
+ <h1>Items</h1>
9
+ <ul>
10
+ {% for item in site.items %}
11
+ <li><strong><a href="{{ item.url }}">{{ item.title }}</a></li>
12
+ {% endfor %}
13
+ </ul>
14
+ </div>
15
+ {% endif %}
@@ -0,0 +1,16 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: monsters = site.monsters | join: '' %}
6
+ {% if monsters != '' %}
7
+ <div class="collection">
8
+ <h1>Monsters</h1>
9
+ <ul>
10
+ {% for monster in site.monsters %}
11
+ {% if monster.monster.e5.cr %}{% assign: cr = monster.monster.e5.cr %}{% else %}{% assign: cr = monster.monster.e35.cr %}{% endif %}
12
+ <li><strong><a href="{{ monster.url }}">{{ monster.monster.name }}</a>:</strong> {{ monster.monster.size | articulate }} {{ monster.monster.type }}, CR {{ cr }}.</li>
13
+ {% endfor %}
14
+ </ul>
15
+ </div>
16
+ {% endif %}
@@ -0,0 +1,15 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: plants = site.plants | join: '' %}
6
+ {% if plants != '' %}
7
+ <div class="collection">
8
+ <h1>Plants</h1>
9
+ <ul>
10
+ {% for plant in site.plants %}
11
+ <li><strong><a href="{{ plant.url }}">{{ plant.title }}</a> (<em>{{ plant.plant.species }}</em>)</li>
12
+ {% endfor %}
13
+ </ul>
14
+ </div>
15
+ {% endif %}
@@ -0,0 +1,47 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: posts = site.posts | join: '' %}
6
+ {% if posts != '' %}
7
+ <h1>Posts</h1>
8
+ <nav class="posts">
9
+ <ul class="columns">
10
+ <li class="four columns"><button class="u-full-width button-primary" id="go-alphabetical">Alphabetical</button></li>
11
+ <li class="four columns"><button class="u-full-width" id="go-tags">Tags</button></li>
12
+ <li class="four columns"><button class="u-full-width" id="go-categories">Categories</button></li>
13
+ </ul>
14
+ </nav>
15
+ <div class="collection" id="alphabetical">
16
+ <ul>
17
+ {% for post in site.posts %}
18
+ <li><strong><a href="{{ post.url }}">{{ post.title }}</a>:</strong> {{ post.excerpt | strip_html | truncatewords: 50 }}</li>
19
+ {% endfor %}
20
+ </ul>
21
+ </div>
22
+ <div class="collection" id="tags">
23
+ <h2>Tags</h2>
24
+ {% for tag in site.tags %}
25
+ <h3>{{ tag[0] }}</h3>
26
+ <ul>
27
+ {% for post in tag[1] %}
28
+ <li><strong><a href="{{ post.url }}">{{ post.title }}</a>:</strong> {{ post.excerpt | strip_html | truncatewords: 50 }}</li>
29
+ {% endfor %}
30
+ </ul>
31
+ {% endfor %}
32
+ </div>
33
+ <div class="collection" id="categories">
34
+ <h2>Categories</h2>
35
+ {% for cat in site.categories %}
36
+ <h3>{{ cat[0] }}</h3>
37
+ <ul>
38
+ {% for post in cat[1] %}
39
+ <li><strong><a href="{{ post.url }}">{{ post.title }}</a>:</strong> {{ post.excerpt | strip_html | truncatewords: 50 }}</li>
40
+ {% endfor %}
41
+ </ul>
42
+ {% endfor %}
43
+ </div>
44
+ {% endif %}
45
+
46
+ <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script>
47
+ <script type="text/javascript" src="/assets/posts_collection.js"></script>
data/search.html ADDED
@@ -0,0 +1,12 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ <h1>Results</h1>
6
+
7
+ <div class="collection">
8
+ <ul id="results"></ul>
9
+ </div>
10
+
11
+ <script type="text/javascript" src="https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js"></script>
12
+ <script type="text/javascript" src="/assets/search.js"></script>
data/search.json ADDED
@@ -0,0 +1,22 @@
1
+ ---
2
+ layout: none
3
+ ---
4
+ {% assign: searchables = site.adventures | concat: site.ages %}
5
+ {% assign: searchables = searchables | concat: site.animals %}
6
+ {% assign: searchables = searchables | concat: site.chapters %}
7
+ {% assign: searchables = searchables | concat: site.items %}
8
+ {% assign: searchables = searchables | concat: site.monsters %}
9
+ {% assign: searchables = searchables | concat: site.plants %}
10
+ {% assign: searchables = searchables | concat: site.posts %}
11
+ {% assign: searchables = searchables | concat: site.settlements %}
12
+ {% assign: searchables = searchables | concat: site.spells %}
13
+ [
14
+ {% for item in searchables %}
15
+ {
16
+ "title" : "{{ item.title | escape }}",
17
+ "url" : "{{ site.baseurl }}{{ item.url }}",
18
+ "date" : "{{ item.date }}",
19
+ "content" : "{{ item.content | strip_html | escape | strip }}"
20
+ }{% unless forloop.last %},{% endunless %}
21
+ {% endfor %}
22
+ ]
@@ -0,0 +1,15 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: settlements = site.settlements | join: '' %}
6
+ {% if settlements != '' %}
7
+ <div class="collection">
8
+ <h1>Settlements</h1>
9
+ <ul>
10
+ {% for settlement in site.settlements %}
11
+ <li><strong><a href="{{ settlement.url }}">{{ settlement.settlement.name }}</a>:</strong> {{ settlement.settlement.type | articulate }} with {{ settlement.settlement.population | pretty_number }} souls.</li>
12
+ {% endfor %}
13
+ </ul>
14
+ </div>
15
+ {% endif %}
@@ -0,0 +1,15 @@
1
+ ---
2
+ layout: default
3
+ ---
4
+
5
+ {% assign: spells = site.spells | join: '' %}
6
+ {% if spells != '' %}
7
+ <div class="collection">
8
+ <h1>Spells</h1>
9
+ <ul>
10
+ {% for spell in site.spells %}
11
+ <li><strong><a href="{{ spell.url }}">{{ spell.spell.name }}</a>:</strong> {% if spell.spell.e5.level %}{{ spell.spell.e5.level | ordinal }}-level {% endif %}{{ spell.spell.school }}{% if spell.spell.subschool %} ({{ spell.spell.subschool }}){% endif %}{% assign: descs = spell.spell.descriptor | join: '' %}{% if descs != '' %} [{{ spell.spell.descriptor | join: ', ' }}]{% endif %}{% if spell.spell.e35.level %} for {{ spell.spell.e35.level | join: ', ' }}{% endif %}.</li>
12
+ {% endfor %}
13
+ </ul>
14
+ </div>
15
+ {% endif %}
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: nereare_grimoire
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.13.13
4
+ version: 1.21.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Igor Padoim
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-09-18 00:00:00.000000000 Z
11
+ date: 2022-08-27 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: html-proofer
@@ -16,93 +16,128 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: 3.15.1
19
+ version: '4.3'
20
+ - - ">="
21
+ - !ruby/object:Gem::Version
22
+ version: 4.3.1
20
23
  type: :development
21
24
  prerelease: false
22
25
  version_requirements: !ruby/object:Gem::Requirement
23
26
  requirements:
24
27
  - - "~>"
25
28
  - !ruby/object:Gem::Version
26
- version: 3.15.1
29
+ version: '4.3'
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: 4.3.1
27
33
  - !ruby/object:Gem::Dependency
28
34
  name: nokogiri
29
35
  requirement: !ruby/object:Gem::Requirement
30
36
  requirements:
31
37
  - - "~>"
32
38
  - !ruby/object:Gem::Version
33
- version: 1.10.8
39
+ version: '1.12'
40
+ - - ">="
41
+ - !ruby/object:Gem::Version
42
+ version: 1.12.5
34
43
  type: :development
35
44
  prerelease: false
36
45
  version_requirements: !ruby/object:Gem::Requirement
37
46
  requirements:
38
47
  - - "~>"
39
48
  - !ruby/object:Gem::Version
40
- version: 1.10.8
49
+ version: '1.12'
50
+ - - ">="
51
+ - !ruby/object:Gem::Version
52
+ version: 1.12.5
53
+ - !ruby/object:Gem::Dependency
54
+ name: webrick
55
+ requirement: !ruby/object:Gem::Requirement
56
+ requirements:
57
+ - - "~>"
58
+ - !ruby/object:Gem::Version
59
+ version: '1.7'
60
+ - - ">="
61
+ - !ruby/object:Gem::Version
62
+ version: 1.7.0
63
+ type: :development
64
+ prerelease: false
65
+ version_requirements: !ruby/object:Gem::Requirement
66
+ requirements:
67
+ - - "~>"
68
+ - !ruby/object:Gem::Version
69
+ version: '1.7'
70
+ - - ">="
71
+ - !ruby/object:Gem::Version
72
+ version: 1.7.0
41
73
  - !ruby/object:Gem::Dependency
42
74
  name: jekyll-feed
43
75
  requirement: !ruby/object:Gem::Requirement
44
76
  requirements:
77
+ - - "~>"
78
+ - !ruby/object:Gem::Version
79
+ version: '0.12'
45
80
  - - ">="
46
81
  - !ruby/object:Gem::Version
47
82
  version: 0.12.1
48
- - - "<"
49
- - !ruby/object:Gem::Version
50
- version: 0.16.0
51
83
  type: :runtime
52
84
  prerelease: false
53
85
  version_requirements: !ruby/object:Gem::Requirement
54
86
  requirements:
87
+ - - "~>"
88
+ - !ruby/object:Gem::Version
89
+ version: '0.12'
55
90
  - - ">="
56
91
  - !ruby/object:Gem::Version
57
92
  version: 0.12.1
58
- - - "<"
59
- - !ruby/object:Gem::Version
60
- version: 0.16.0
61
93
  - !ruby/object:Gem::Dependency
62
94
  name: jekyll
63
95
  requirement: !ruby/object:Gem::Requirement
64
96
  requirements:
65
- - - ">="
97
+ - - "~>"
66
98
  - !ruby/object:Gem::Version
67
99
  version: '4.0'
68
- - - "<"
100
+ - - ">="
69
101
  - !ruby/object:Gem::Version
70
- version: '4.2'
102
+ version: 4.0.0
71
103
  type: :runtime
72
104
  prerelease: false
73
105
  version_requirements: !ruby/object:Gem::Requirement
74
106
  requirements:
75
- - - ">="
107
+ - - "~>"
76
108
  - !ruby/object:Gem::Version
77
109
  version: '4.0'
78
- - - "<"
110
+ - - ">="
79
111
  - !ruby/object:Gem::Version
80
- version: '4.2'
112
+ version: 4.0.0
81
113
  - !ruby/object:Gem::Dependency
82
114
  name: jekyll-redirect-from
83
115
  requirement: !ruby/object:Gem::Requirement
84
116
  requirements:
85
- - - ">="
117
+ - - "~>"
86
118
  - !ruby/object:Gem::Version
87
119
  version: '0.15'
88
- - - "<"
120
+ - - ">="
89
121
  - !ruby/object:Gem::Version
90
- version: '0.17'
122
+ version: 0.15.0
91
123
  type: :runtime
92
124
  prerelease: false
93
125
  version_requirements: !ruby/object:Gem::Requirement
94
126
  requirements:
95
- - - ">="
127
+ - - "~>"
96
128
  - !ruby/object:Gem::Version
97
129
  version: '0.15'
98
- - - "<"
130
+ - - ">="
99
131
  - !ruby/object:Gem::Version
100
- version: '0.17'
132
+ version: 0.15.0
101
133
  - !ruby/object:Gem::Dependency
102
134
  name: jekyll-seo-tag
103
135
  requirement: !ruby/object:Gem::Requirement
104
136
  requirements:
105
137
  - - "~>"
138
+ - !ruby/object:Gem::Version
139
+ version: '2.6'
140
+ - - ">="
106
141
  - !ruby/object:Gem::Version
107
142
  version: 2.6.1
108
143
  type: :runtime
@@ -110,49 +145,52 @@ dependencies:
110
145
  version_requirements: !ruby/object:Gem::Requirement
111
146
  requirements:
112
147
  - - "~>"
148
+ - !ruby/object:Gem::Version
149
+ version: '2.6'
150
+ - - ">="
113
151
  - !ruby/object:Gem::Version
114
152
  version: 2.6.1
115
153
  - !ruby/object:Gem::Dependency
116
154
  name: jekyll-sitemap
117
155
  requirement: !ruby/object:Gem::Requirement
118
156
  requirements:
157
+ - - "~>"
158
+ - !ruby/object:Gem::Version
159
+ version: '1.3'
119
160
  - - ">="
120
161
  - !ruby/object:Gem::Version
121
162
  version: 1.3.1
122
- - - "<"
123
- - !ruby/object:Gem::Version
124
- version: 1.5.0
125
163
  type: :runtime
126
164
  prerelease: false
127
165
  version_requirements: !ruby/object:Gem::Requirement
128
166
  requirements:
167
+ - - "~>"
168
+ - !ruby/object:Gem::Version
169
+ version: '1.3'
129
170
  - - ">="
130
171
  - !ruby/object:Gem::Version
131
172
  version: 1.3.1
132
- - - "<"
133
- - !ruby/object:Gem::Version
134
- version: 1.5.0
135
173
  - !ruby/object:Gem::Dependency
136
174
  name: jemoji
137
175
  requirement: !ruby/object:Gem::Requirement
138
176
  requirements:
177
+ - - "~>"
178
+ - !ruby/object:Gem::Version
179
+ version: '0.11'
139
180
  - - ">="
140
181
  - !ruby/object:Gem::Version
141
182
  version: 0.11.1
142
- - - "<"
143
- - !ruby/object:Gem::Version
144
- version: 0.13.0
145
183
  type: :runtime
146
184
  prerelease: false
147
185
  version_requirements: !ruby/object:Gem::Requirement
148
186
  requirements:
187
+ - - "~>"
188
+ - !ruby/object:Gem::Version
189
+ version: '0.11'
149
190
  - - ">="
150
191
  - !ruby/object:Gem::Version
151
192
  version: 0.11.1
152
- - - "<"
153
- - !ruby/object:Gem::Version
154
- version: 0.13.0
155
- description:
193
+ description:
156
194
  email:
157
195
  - igorpadoim@gmail.com
158
196
  executables: []
@@ -160,7 +198,9 @@ extensions: []
160
198
  extra_rdoc_files: []
161
199
  files:
162
200
  - 404.html
201
+ - CHANGELOG.md
163
202
  - LICENSE.md
203
+ - OGL.md
164
204
  - README.md
165
205
  - _layouts/adventure.html
166
206
  - _layouts/age.html
@@ -181,10 +221,14 @@ files:
181
221
  - _plugins/add-sign.rb
182
222
  - _plugins/animal-metadata.rb
183
223
  - _plugins/articulate.rb
224
+ - _plugins/cr-format.rb
184
225
  - _plugins/number.rb
185
226
  - _plugins/ordinal.rb
186
227
  - _plugins/plant-metadata.rb
187
228
  - _plugins/pluralize.rb
229
+ - adventures_collection.html
230
+ - ages_collection.html
231
+ - animals_collection.html
188
232
  - assets/404.png
189
233
  - assets/background.jpg
190
234
  - assets/css/boxes.scss
@@ -208,14 +252,28 @@ files:
208
252
  - assets/favicon/site.webmanifest
209
253
  - assets/header.png
210
254
  - assets/note-border.png
255
+ - assets/posts_collection.js
256
+ - assets/search.js
257
+ - chapters_collection.html
258
+ - docs/404.html
259
+ - items_collection.html
260
+ - monsters_collection.html
261
+ - plants_collection.html
262
+ - posts_collection.html
263
+ - search.html
264
+ - search.json
265
+ - settlements_collection.html
266
+ - spells_collection.html
211
267
  homepage: https://github.com/Nereare/Grimoire
212
268
  licenses:
213
- - Hippocratic
269
+ - Nonstandard
214
270
  metadata:
215
271
  source_code_uri: https://github.com/Nereare/Grimoire
216
272
  changelog_uri: https://github.com/Nereare/Grimoire/blob/master/CHANGELOG.md
273
+ documentation_uri: https://nereare.github.io/Grimoire
274
+ bug_tracker_uri: https://github.com/Nereare/Grimoire/issues
217
275
  github_repo: https://github.com/Nereare/Grimoire.git
218
- post_install_message:
276
+ post_install_message:
219
277
  rdoc_options: []
220
278
  require_paths:
221
279
  - lib
@@ -223,15 +281,15 @@ required_ruby_version: !ruby/object:Gem::Requirement
223
281
  requirements:
224
282
  - - ">="
225
283
  - !ruby/object:Gem::Version
226
- version: 2.5.0
284
+ version: 3.0.0
227
285
  required_rubygems_version: !ruby/object:Gem::Requirement
228
286
  requirements:
229
287
  - - ">="
230
288
  - !ruby/object:Gem::Version
231
289
  version: '0'
232
290
  requirements: []
233
- rubygems_version: 3.0.6
234
- signing_key:
291
+ rubygems_version: 3.3.16
292
+ signing_key:
235
293
  specification_version: 4
236
294
  summary: A jekyll quasi-wiki for RPG-oriented worldbuilding.
237
295
  test_files: []