page-toc-filter 0.0.1 → 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +4 -0
- data/lib/page-toc-filter.rb +31 -5
- data/page-toc-filter.gemspec +1 -1
- metadata +3 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 45b7f9c69ba970ee849f37ba30d5662db658f14e
|
4
|
+
data.tar.gz: 2aad334c79bcf252995ff8812e883a80a179eb80
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: cb85a7bf92d8685f888665064538183ff073273894cc4e46110825e596209a0e98f8df14af89d5b6544fda0bdece7b7f3f775b9ffa0ef1ac204f17b8820e38e1
|
7
|
+
data.tar.gz: '092d37bfcdad2bd1de98db1dcdec337dce79fc05bf26068e549c754a6365f2c64b1fcbc67cdea015ee511db227b7d819a5c93bda72da5254d3c981d0d88e68a1'
|
data/README.md
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
# PageTocFilter
|
2
2
|
|
3
|
+
Inserts a table of contents on a page via the [`HTML::Pipeline`](https://github.com/jch/html-pipeline).
|
4
|
+
|
3
5
|
## Installation
|
4
6
|
|
5
7
|
Add this line to your application's Gemfile:
|
@@ -34,6 +36,8 @@ pipeline = HTML::Pipeline.new([
|
|
34
36
|
])
|
35
37
|
```
|
36
38
|
|
39
|
+
Then, on your page, enter the text `{:toc}` to have it replaced by a table of contents.
|
40
|
+
|
37
41
|
By default, only `h2` headings will be converted into a table of contents. You can change this with the optional `toc_levels` setting, which should be a comma-separated string of heading levels. For example:
|
38
42
|
|
39
43
|
``` ruby
|
data/lib/page-toc-filter.rb
CHANGED
@@ -14,15 +14,41 @@ class PageTocFilter < HTML::Pipeline::Filter
|
|
14
14
|
end
|
15
15
|
|
16
16
|
def page_toc_filter(doc)
|
17
|
-
|
18
|
-
|
17
|
+
levels = doc.search(context[:toc_levels] || 'h2')
|
18
|
+
return '' if levels.empty?
|
19
|
+
|
20
|
+
toc = %(<ul id="markdown-toc">\n)
|
21
|
+
last_level = nil
|
22
|
+
depth = 1
|
23
|
+
|
24
|
+
levels.each do |node|
|
25
|
+
current_level = node.name.match(/h(\d)/)[1]
|
19
26
|
|
20
|
-
doc.search(levels).each do |node|
|
21
27
|
text = node.text
|
22
28
|
id = node.child['id']
|
23
|
-
|
29
|
+
|
30
|
+
link = %(<a href="##{id}" id="markdown-toc-#{id}">#{text}</a>)
|
31
|
+
|
32
|
+
if last_level.nil?
|
33
|
+
toc << %(<li>#{link})
|
34
|
+
elsif current_level == last_level
|
35
|
+
toc << %(</li>\n<li>#{link})
|
36
|
+
elsif current_level > last_level
|
37
|
+
depth += 1
|
38
|
+
toc << %(\n<ul><li>#{link})
|
39
|
+
elsif current_level < last_level
|
40
|
+
depth -= 1
|
41
|
+
toc << %(</li></ul>\n<li>#{link})
|
42
|
+
end
|
43
|
+
|
44
|
+
last_level = current_level
|
45
|
+
end
|
46
|
+
|
47
|
+
if depth < 0
|
48
|
+
raise ArgumentError, 'Your headings are not in sequential order. It seems that a lower heading level (like an h4) is being defined before a higher heading level (like an h1).'
|
24
49
|
end
|
25
|
-
|
50
|
+
|
51
|
+
toc << %(</li>\n</ul>) * depth
|
26
52
|
toc
|
27
53
|
end
|
28
54
|
end
|
data/page-toc-filter.gemspec
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: page-toc-filter
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
4
|
+
version: 0.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Garen Torikian
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2017-04-16 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: html-pipeline
|
@@ -115,7 +115,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
115
115
|
version: '0'
|
116
116
|
requirements: []
|
117
117
|
rubyforge_project:
|
118
|
-
rubygems_version: 2.
|
118
|
+
rubygems_version: 2.6.8
|
119
119
|
signing_key:
|
120
120
|
specification_version: 4
|
121
121
|
summary: Generates a table of contents for a single page, via HTML::Pipeline.
|