This repository has been archived by the owner on Oct 31, 2019. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 12
/
config.rb
104 lines (85 loc) · 2.47 KB
/
config.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
###
# Page options, layouts, aliases and proxies
###
# Per-page layout changes:
#
# With no layout
page '/*.xml', layout: false
page '/*.json', layout: false
page '/*.txt', layout: false
activate :sprockets
set :markdown_engine, :redcarpet
set :markdown,
fenced_code_blocks: true,
smartypants: true,
with_toc_data: true,
tables: true,
xhtml: true
# With alternative layout
# page "/path/to/file.html", layout: :otherlayout
# Proxy pages (https://middlemanapp.com/basics/dynamic-pages/)
# proxy "/this-page-has-no-template.html", "/template-file.html", locals: {
# which_fake_page: "Rendering a fake page with a local variable" }
# General configuration
# Reload the browser automatically whenever files change
configure :development do
activate :livereload
end
activate :blog do |blog|
blog.name = "docs"
blog.prefix = "docs"
blog.sources = "{title}.html"
blog.permalink = "{title}.html"
blog.layout = "documentation"
end
activate :blog do |blog|
blog.name = "reference"
blog.prefix = "reference"
blog.sources = "{title}.html"
blog.permalink = "{title}.html"
blog.layout = "documentation"
end
activate :directory_indexes
###
# Helpers
###
# Methods defined in the helpers block are available in templates
helpers do
def sorted_docs(doc_prefix)
blog(doc_prefix).articles.sort {|a,b| a.data.order <=> b.data.order }
end
def nav_active(path)
current_page.url == path ? "active" : ""
end
def is_docs()
current_page.url.include? "docs/" or current_page.url.include? "reference/"
end
def is_docs_but_not_overview()
is_docs() and !current_page.url.end_with? "docs/"
end
def docs_nav_active()
is_lib = current_page.url.include? "library"
(is_docs() || is_lib) ? "active" : ""
end
def table_of_contents(page)
if config.markdown_engine == :redcarpet && config.markdown[:with_toc_data]
renderer = Redcarpet::Markdown.new(Redcarpet::Render::HTML_TOC,
fenced_code_blocks: true,
xhtml: true)
file = ::File.read(page.source_file)
tocpre = '<nav>'
tocpost = '</nav>'
# ignore YAML frontmatter
file = file.gsub(/^(---\s*\n.*?\n?)^(---\s*$\n?)/m, '')
file = file.gsub(' & ', ' & ')
renderer.render(file)
end
end
end
# Build-specific configuration
configure :build do
# Minify CSS on build
activate :minify_css
# Minify Javascript on build
activate :minify_javascript
end