-
Notifications
You must be signed in to change notification settings - Fork 4
/
config.rb
193 lines (160 loc) · 5.94 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
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
###
# Blog settings
###
Time.zone = "Tokyo"
activate :blog do |blog|
blog.name = "chapters"
# blog.prefix = "docs"
blog.sources = "chapters/:title.html"
blog.permalink = "chapters/:title"
# blog.sources = ":year-:month-:day-:title.html"
# blog.taglink = "tags/:tag.html"
blog.layout = "chapter_layout"
# blog.summary_separator = /(READMORE)/
# blog.summary_length = 250
# blog.year_link = ":year.html"
# blog.month_link = ":year/:month.html"
# blog.day_link = ":year/:month/:day.html"
# blog.default_extension = ".markdown"
blog.paginate = true
# blog.per_page = 10
# blog.page_link = "page/:num"
end
# activate :drafts do |drafts|
# drafts.build = true if ENV["SHOW_DRAFTS"]
# end
page "/print.html", :layout => :print_layout
###
# Compass
###
# Susy grids in Compass
# First: gem install susy
# require 'susy'
# Change Compass configuration
# compass_config do |config|
# config.output_style = :compact
# end
###
# Page options, layouts, aliases and proxies
###
# Per-page layout changes:
#
# With no layout
# page "/path/to/file.html", :layout => false
#
# With alternative layout
# page "/path/to/file.html", :layout => :otherlayout
#
# A path which all have the same layout
# with_layout :admin do
# page "/admin/*"
# end
# Proxy (fake) files
# page "/this-page-has-no-template.html", :proxy => "/template-file.html" do
# @which_fake_page = "Rendering a fake page with a variable"
# end
###
# Helpers
###
# Automatic image dimensions on image_tag helper
# activate :automatic_image_sizes
# Methods defined in the helpers block are available in templates
# helpers do
# def some_helper
# "Helping"
# end
# end
set :css_dir, 'stylesheets'
set :js_dir, 'javascripts'
set :images_dir, 'images'
set :fonts_dir, 'fonts'
set :build_dir, 'tmp'
# Build-specific configuration
configure :build do
# For example, change the Compass output style for deployment
# activate :minify_css
# Minify Javascript on build
# activate :minify_javascript
# Enable cache buster
# activate :cache_buster
# Use relative URLs
# activate :relative_assets
# Compress PNGs after build
# First: gem install middleman-smusher
# require "middleman-smusher"
# activate :smusher
# Or use a different image path
# set :http_path, "/Content/images/"
end
activate :livereload
activate :directory_indexes
activate :syntax#,:linenos => 'table'
activate :autoprefixer
set :markdown_engine, :redcarpet
set :markdown, :fenced_code_blocks => true, :smartypants => true
helpers do
def div(css_class, content)
%Q{<div class="#{css_class}">#{content}</div>}
end
def caption(content)
%Q{<div class="caption">#{content}</div>}
end
def image(src, css_class)
%Q{<img class="#{css_class}" src="/images/#{src}"/>}
end
def figure(src, caption="", css_class="", link="")
prefix = ''
if src[0..3] != 'http'
prefix = '/images/book/'
end
if link != ""
%Q{<figure class="#{css_class}"><a href="#{link}" target="_blank"><img src="#{prefix}#{src}"/></a><figcaption>#{caption}</figcaption></figure>}
else
%Q{<figure class="#{css_class}"><img src="#{prefix}#{src}"/><figcaption>#{caption}</figcaption></figure>}
end
end
def diagram(name, caption, css_class="")
%Q{<figure class="diagram #{css_class}"><img src="/images/diagrams/#{name}@2x.png" alt="#{caption}"/><figcaption>#{caption}</figcaption></figure>}
end
def screenshot(name, caption, css_class="")
%Q{<figure class="screenshot #{css_class}"><img src="/images/screenshots/#{name}.png" alt="#{caption}"/><figcaption>#{caption}</figcaption></figure>}
end
def commit(name, caption)
caption = truncate(caption, :length => 60)
%Q{<div class="commit"><img src="/images/code.svg"/><div class="message"><h4>Commit #{name}</h4><p>#{caption}</p></div><div class="actions"><a class="commit-link" href="https://github.com/DiscoverMeteor/Microscope/commit/chapter#{name}" target="_blank">View on GitHub</a><a class="instance-link" href="http://meteor-book-chapter#{name}.meteor.com" target="_blank" class="live-instance">Launch Instance</a></div></div>}
end
def scommit(name, caption)
caption = truncate(caption, :length => 60)
%Q{<div class="commit"><img src="/images/code.svg"/><div class="message"><h4>Commit #{name}</h4><p>#{caption}</p></div><div class="actions"><a class="commit-link" href="https://github.com/DiscoverMeteor/Microscope/commit/sidebar#{name}" target="_blank">View on GitHub</a><a class="instance-link" href="http://meteor-book-sidebar#{name}.meteor.com" target="_blank" class="live-instance">Launch Instance</a></div></div>}
end
def tweet(content)
%Q{<div class="tweet">#{content}</div>}
end
def pullquote(content, css_class="left")
%Q{<blockquote class="pull pull-#{css_class}">#{content}</blockquote>}
end
def note(&block)
markdown = Redcarpet::Markdown.new(Redcarpet::Render::HTML, :fenced_code_blocks => true)
content = markdown.render(capture(&block))
concat %Q{<div class="note">#{content}</div>}
end
def quote(&block)
markdown = Redcarpet::Markdown.new(Redcarpet::Render::HTML, :fenced_code_blocks => true)
content = markdown.render(capture(&block))
concat %Q{<div class="quote"><div class="inner">#{content}</div></div>}
end
def q(quote, name)
contributor = data.contributors.select{|c| c.name == name}.first
%Q{<div class="quote"><div class="inner">#{quote}</div><h4><span>#{name}</span>, <a href="#{contributor.link}">#{contributor.community}</a></h4></div>}
end
def homework(&block)
markdown = Redcarpet::Markdown.new(Redcarpet::Render::HTML, :fenced_code_blocks => true)
content = markdown.render(capture(&block))
concat %Q{<div class="homework"><h4>Homework</h4>#{content}</div>}
end
def chapter(&block)
markdown = Redcarpet::Markdown.new(Redcarpet::Render::HTML, :fenced_code_blocks => true)
content = markdown.render(capture(&block))
concat %Q{<div class="note chapter"><h3>In this chapter, you will:</h3>#{content}</div>}
end
end