-
Notifications
You must be signed in to change notification settings - Fork 38
/
config.rb
164 lines (131 loc) · 3.87 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
###
# Blog settings
###
Time.zone = "Beijing"
activate :blog do |blog|
# blog.prefix = "blog"
# blog.permalink = ":year/:month/:day/:title.html"
# blog.sources = ":year-:month-:day-:title.html"
# blog.taglink = "tags/:tag.html"
blog.layout = "layouts/podcast"
# 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.tag_template = "tag.html"
# blog.calendar_template = "calendar.html"
# blog.paginate = true
# blog.per_page = 10
# blog.page_link = "page/:num"
end
page "/feed.xml", :layout => false
page "/sitemap.xml", :layout => false
###
# Compass
###
# Susy grids in Compass
# First: gem install susy --pre
# require 'susy'
require 'sassy-buttons'
require 'rgbapng'
# 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
###
activate :sprockets
# 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
#activate :syntax
# Methods defined in the helpers block are available in templates
helpers do
def disqus_identifier(podcast)
podcast.data["disqus_identifier"] || podcast.title.parameterize
end
def author_tag(ident)
author = author(ident)
%Q!<a href="#{author.link}" target="_blank"><img src="/images/#{author.avatar}"/></a>!
end
def author(ident)
data.author[ident]
end
def prev_nav(article)
if article
%Q!<a href="#{article.url}" class="prev"><i class="icon-angle-left"></i></a>!
else
%Q!<a href="#" class="prev disabled"><i class="icon-angle-left"></i></a>!
end
end
def next_nav(article)
if article
%Q!<a href="#{article.url}" class="next"><i class="icon-angle-right"></i></a>!
else
%Q!<a href="#" class="next disabled"><i class="icon-angle-right"></i></a>!
end
end
end
# Assets PATH
set :css_dir, 'stylesheets'
set :js_dir, 'javascripts'
set :images_dir, 'images'
set :markdown_engine, :kramdown
#set :markdown, fenced_code_blocks: true, autolink: true, smartypants: true
# Livereload
# use: https://github.com/middleman/middleman-livereload
activate :livereload
# Build-specific configuration
configure :build do
# Or use a different image path
# set :http_path, "/Content/images/"
# Make favicons
# use: https://github.com/follmann/middleman-favicon-maker
activate :favicon_maker
# Minify
# see: https://github.com/middleman/middleman-guides/blob/master/source/advanced/file-size-optimization.html.markdown#compressing-images
activate :minify_css
activate :minify_javascript
# Enable cache buster
# see: https://github.com/middleman/middleman-guides/blob/master/source/advanced/improving-cacheability.html.markdown#cache-buster-in-query-string
activate :cache_buster
# Use relative URLs
# activate :relative_assets
# Compress PNGs after build
# use: https://github.com/middleman/middleman-smusher
# activate :smusher
# Gzip HTML, CSS, and JavaScript
# see: https://github.com/middleman/middleman-guides/blob/master/source/advanced/file-size-optimization.html.markdown#gzip-text-files
activate :gzip
end
activate :deploy do |deploy|
deploy.deploy_method = :git
deploy.branch = "gh-pages"
end