-
Notifications
You must be signed in to change notification settings - Fork 46
/
Copy pathconfig.rb
112 lines (86 loc) · 2.92 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
# Set markdown engine so we can get TOC
set :markdown_engine, :redcarpet
set :markdown, with_toc_data: true, :fenced_code_blocks => true, :no_intraemphasis => true
###
# Compass
###
# Change Compass configuration
compass_config do |config|
config.output_style = :compact
sourcemap = true
end
# Proxy pages (https://middlemanapp.com/advanced/dynamic_pages/)
# proxy "/this-page-has-no-template.html", "/template-file.html", :locals => {
# :which_fake_page => "Rendering a fake page with a local variable" }
###
# Helpers
###
# Automatic image dimensions on image_tag helper
# activate :automatic_image_sizes
configure :development do
activate :livereload
set :sass, :sourcemap => :inline
end
configure :build do
compass_config do |config|
config.line_comments = false
# config.output_style = :compact did not seem to work for me but config.sass_options = {} did
config.sass_options = {
:style => :compact
}
end
end
activate :deploy do |deploy|
deploy.build_before = true # default: false
end
# Methods defined in the helpers block are available in templates
helpers do
def nav_active(path)
current_page.path == path ? {:class => "is-active"} : {}
end
def code_example(input, type="")
source = input
formatter = Rouge::Formatters::HTML.new(css_class: 'highlight')
lexer = Rouge::Lexers::Shell.new
output = formatter.format(lexer.lex(source))
type = type ? 'sc-demo--' + type : ""
"<div class='sc-demo #{type}'><div class='sc-demo__output'>#{input.to_s}</div><div class='sc-demo__input'>#{output}</div></div>"
end
def gh_link(path)
"<a class='ext-link sc-u-font-meta' href='https://github.com/dropbox/scooter/tree/master/scss/#{path}'>View on GitHub</a>"
end
end
set :source, "docs/source"
set :build_dir, "docs/build"
set :css_dir, 'assets/css'
set :js_dir, 'assets/js'
set :images_dir, 'assets/images'
# Relative links for assets that actually work no gh-pages
activate :relative_assets
set :relative_links, true
# Syntax highlighting
activate :syntax
# Prefix stuff, yo
activate :autoprefixer
# 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 :asset_hash
# Use relative URLs
# activate :relative_assets
# Or use a different image path
# set :http_prefix, "/Content/images/"
end
# Deployment to gh-pages
activate :deploy do |deploy|
deploy.method = :git
# Optional Settings
# deploy.remote = 'custom-remote' # remote name or git url, default: origin
# deploy.branch = 'custom-branch' # default: gh-pages
# deploy.strategy = :submodule # commit strategy: can be :force_push or :submodule, default: :force_push
# deploy.commit_message = 'custom-message' # commit message (can be empty), default: Automated commit at `timestamp` by middleman-deploy `version`
end