-
Notifications
You must be signed in to change notification settings - Fork 22
/
topic.rb
114 lines (93 loc) · 2.75 KB
/
topic.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
require 'rdiscount'
require './models'
class Topic
def text_only
@body = @body.gsub(/\<[^\<]+\>/,'')
self
end
def self.load(topic, source)
topic = new(topic, source)
topic.parse
return topic
end
def self.all_topics
dirs = AppConfig['dirs'] || {}
paths = dirs.values.map! { |path| path += "*.md" }
# puts paths
paths <<'docs/en/**/**/*.md'
FileList[paths]
end
attr_reader :topic, :title, :content, :toc, :toc_sub, :intro, :body
def initialize(name, source)
@topic = name
@source = source
end
def parse
@topic = topic
@content = markdown(source)
@title, @content = _title(@content)
@toc, @content = _toc(@content)
@toc_sub, @content = _tocSub(@content)
if @toc.any?
@intro, @body = @content.split('<h2>', 2)
@body = "<h2>#{@body}"
else
@intro, @body = '', @content
end
end
protected
def source
@source
end
def notes(source)
# source.gsub(
# /NOTE: (.*?)\n\n/m,
# "<table class='note'>\n<td class='icon'></td><td class='content'>\\1</td>\n</table>\n\n"
# )
source.gsub(
/NOTE: (.*?)$/m,
"<div class='alert alert-warning'><table>\n<td ><i class='icon-warning-sign icon-2x'></i></td><td >\\1</td>\n</table></div>\n\n"
)
end
def markdown(source)
source = source.gsub(/Motorola Solutions/,'Zebra Technologies')
source = source.gsub(/Motorola Webkit/,'Zebra Webkit')
source = source.gsub(/Motorola /,'Zebra ')
# source = source.gsub(/Motorola/,'Zebra')
html = RDiscount.new(notes(source), :smart).to_html
# parse custom {lang} definitions to support syntax highlighting
html.gsub(/<pre><code>\{(\w+)\}/, '<pre><code class="brush: \1;">')
end
def _title(content)
title = content.match(/<h1>(.*)<\/h1>/)[1]
content_minus_title = content.gsub(/<h1>.*<\/h1>/, '')
return title, content_minus_title
end
def slugify(title)
title.downcase.gsub(/[^a-z0-9 -]/, '').gsub(/ /, '-')
end
def _toc(content)
toc = content.scan(/<h2>([^<]+)<\/h2>/m).to_a.map { |m| m.first }
content_with_anchors = content.gsub(/(<h2>[^<]+<\/h2>)/m) do |m|
"<a name=\"#{slugify(m.gsub(/<[^>]+>/, ''))}\"></a>#{m}"
end
return toc, content_with_anchors
end
def _tocSub(content)
toc = []
content.scan(/<h3 data-h2="([^<]+)">([^<]+)<\/h3>/m).each {|m|
hash = { "h2" => m[0], "h3" => m[1] }
toc.push(hash)
} #.to_a #.map #{ |m| m.first }
# puts toc
content_with_anchors = content.gsub(/(<h3 data-h2="([^<]+)">[^<]+<\/h3>)/m) do |m|
"<a name=\"#{slugify(m.gsub(/<[^>]+>/, ''))}\"></a>#{m}"
end
return toc, content_with_anchors
end
def self.model(topicfile)
model = nil
model = Models.docmodel(topicfile)
return model
end
end