middleman-toc 0.0.6 → 0.0.7
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 +4 -4
- data/lib/middleman_toc.rb +17 -1
- data/lib/middleman_toc/helpers.rb +4 -0
- data/lib/middleman_toc/toc.rb +4 -4
- data/lib/middleman_toc/version.rb +1 -1
- metadata +3 -2
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA1:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 81a938c2b695ff26c83afd107e7dab18f74dbaee
|
|
4
|
+
data.tar.gz: 2dddefda32ce8d129b5035b568d7bbb4a86bdd01
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 5461a4abc400c78908ac2a72124ba56490a67804e215bace364c8be73c6c207af297f8c8f3396bcf8349ae1fe89655576e0e740784f2b5c2124926b427d381b4
|
|
7
|
+
data.tar.gz: 09e3d09ce1c6951c60243a0f16040d1fe12360f00042928f917822711bec287952a1d30d4d9c763da8f41d7a35aa7b2ebd1d8b0acfdc5e833e3548ca43646789
|
data/lib/middleman_toc.rb
CHANGED
|
@@ -5,6 +5,12 @@ require 'middleman_toc/toc'
|
|
|
5
5
|
require 'middleman_toc/validator'
|
|
6
6
|
|
|
7
7
|
module MiddlemanToc
|
|
8
|
+
class Page < Struct.new(:resource, :title)
|
|
9
|
+
def render
|
|
10
|
+
resource.render(layout: false)
|
|
11
|
+
end
|
|
12
|
+
end
|
|
13
|
+
|
|
8
14
|
class << self
|
|
9
15
|
def instance(sitemap)
|
|
10
16
|
@instance ||= Toc.new(pages(sitemap)).tap do |toc|
|
|
@@ -16,6 +22,16 @@ module MiddlemanToc
|
|
|
16
22
|
rendering { instance(sitemap).toc(path) } # .tap { |html| puts html }
|
|
17
23
|
end
|
|
18
24
|
|
|
25
|
+
def all_pages(sitemap)
|
|
26
|
+
rendering do
|
|
27
|
+
instance(sitemap).nodes.inject([]) do |result, node|
|
|
28
|
+
page = pages(sitemap)[node.path]
|
|
29
|
+
result << Page.new(page, node.title) if page
|
|
30
|
+
result
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
|
|
19
35
|
def prev_page(sitemap, path)
|
|
20
36
|
rendering { instance(sitemap).prev_page(path) }
|
|
21
37
|
end
|
|
@@ -25,7 +41,7 @@ module MiddlemanToc
|
|
|
25
41
|
end
|
|
26
42
|
|
|
27
43
|
def pages(sitemap)
|
|
28
|
-
sitemap.resources.inject({}) do |pages, page|
|
|
44
|
+
@pages ||= sitemap.resources.inject({}) do |pages, page|
|
|
29
45
|
pages.merge(page.path.gsub(%r((^|\/)[\d]+\-), '').sub('.html', '\1') => page)
|
|
30
46
|
end
|
|
31
47
|
end
|
data/lib/middleman_toc/toc.rb
CHANGED
|
@@ -14,6 +14,10 @@ module MiddlemanToc
|
|
|
14
14
|
root.render
|
|
15
15
|
end
|
|
16
16
|
|
|
17
|
+
def nodes
|
|
18
|
+
@nodes ||= root.flatten
|
|
19
|
+
end
|
|
20
|
+
|
|
17
21
|
def prev_page(path)
|
|
18
22
|
node = prev_node(path)
|
|
19
23
|
Tag.new(:a, 'Previous', class: 'prev', href: "/#{node.path}.html").render if node && node.path
|
|
@@ -35,10 +39,6 @@ module MiddlemanToc
|
|
|
35
39
|
normalize_nodes(YAML.load_file('data/toc.yml'))
|
|
36
40
|
end
|
|
37
41
|
|
|
38
|
-
def nodes
|
|
39
|
-
@nodes ||= root.flatten
|
|
40
|
-
end
|
|
41
|
-
|
|
42
42
|
def find(path)
|
|
43
43
|
nodes.detect { |node| node.path == path }
|
|
44
44
|
end
|
metadata
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: middleman-toc
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 0.0.
|
|
4
|
+
version: 0.0.7
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Sven Fuchs
|
|
8
8
|
autorequire:
|
|
9
9
|
bindir: bin
|
|
10
10
|
cert_chain: []
|
|
11
|
-
date: 2015-
|
|
11
|
+
date: 2015-08-18 00:00:00.000000000 Z
|
|
12
12
|
dependencies:
|
|
13
13
|
- !ruby/object:Gem::Dependency
|
|
14
14
|
name: titleize
|
|
@@ -70,3 +70,4 @@ signing_key:
|
|
|
70
70
|
specification_version: 4
|
|
71
71
|
summary: Middleman Table of Contents
|
|
72
72
|
test_files: []
|
|
73
|
+
has_rdoc:
|