You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
164 lines
4.9 KiB
164 lines
4.9 KiB
# The DocPad Configuration File
|
|
# It is simply a CoffeeScript Object which is parsed by CSON
|
|
docpadConfig = {
|
|
|
|
outPath: '../docs'
|
|
|
|
enabledPlugins:
|
|
handlebars: false
|
|
html2coffee: false
|
|
jade: false
|
|
marked: false
|
|
paged: false
|
|
|
|
plugins:
|
|
handlebars:
|
|
helpers:
|
|
# Expose docpads 'getBlock' function to handlebars
|
|
getBlock: (type, additional...) ->
|
|
additional.pop() # remove the hash object
|
|
@getBlock(type).add(additional).toHTML()
|
|
|
|
# Check Version
|
|
# Whether or not to check for newer versions of DocPad
|
|
checkVersion: true # default
|
|
|
|
# =================================
|
|
# Template Data
|
|
# These are variables that will be accessible via our templates
|
|
# To access one of these within our templates, refer to the FAQ: https://github.com/bevry/docpad/wiki/FAQ
|
|
|
|
templateData:
|
|
|
|
# Specify some site properties
|
|
site:
|
|
# The production url of our website
|
|
url: "http://www.semantic-ui.com"
|
|
|
|
# Here are some old site urls that you would like to redirect from
|
|
oldUrls: [
|
|
'learnsemantic.com'
|
|
]
|
|
|
|
# The default title of our website
|
|
title: "Semantic UI"
|
|
|
|
# The website description (for SEO)
|
|
description: """
|
|
Semantic empowers designers and developers by creating a shared vocabulary for UI.
|
|
"""
|
|
|
|
# The website keywords (for SEO) separated by commas
|
|
keywords: """
|
|
html5, ui, library, framework, javascript
|
|
"""
|
|
|
|
|
|
# -----------------------------
|
|
# Helper Functions
|
|
|
|
# Get the prepared site/document title
|
|
# Often we would like to specify particular formatting to our page's title
|
|
# we can apply that formatting here
|
|
getPreparedTitle: ->
|
|
# if we have a document title, then we should use that and suffix the site's title onto it
|
|
if @document.title
|
|
"#{@document.title} | #{@site.title}"
|
|
# if our document does not have it's own title, then we should just use the site's title
|
|
else
|
|
@site.title
|
|
|
|
getPage: (collection, id) ->
|
|
for item, index in collection
|
|
selectedIndex = (index + 1) if item.id is id
|
|
selectedIndex
|
|
|
|
pageCount: (collection) ->
|
|
for item, index in collection
|
|
itemCount = index + 1
|
|
itemCount
|
|
|
|
getPageCollection: (collection, id, delta = 2) ->
|
|
for item, index in collection
|
|
selectedIndex = index if item.id is id
|
|
lastIndex = index
|
|
|
|
# determine page count before and after
|
|
bottomCount = if (selectedIndex - delta >= 0) then delta else (selectedIndex)
|
|
topCount = if (selectedIndex + delta <= lastIndex) then delta else (lastIndex - selectedIndex)
|
|
|
|
bottomDelta = (delta * 2 - topCount)
|
|
topDelta = (delta * 2 - bottomCount)
|
|
|
|
bottomIndex = if (selectedIndex - bottomDelta >= 0) then (selectedIndex - bottomDelta) else 0
|
|
topIndex = if (selectedIndex + topDelta <= lastIndex) then (selectedIndex + topDelta) else lastIndex
|
|
result = collection[bottomIndex..topIndex]
|
|
result
|
|
|
|
# Get the prepared site/document description
|
|
getPreparedDescription: ->
|
|
# if we have a document description, then we should use that, otherwise use the site's description
|
|
@document.description or @site.description
|
|
|
|
# Get the prepared site/document keywords
|
|
getPreparedKeywords: ->
|
|
# Merge the document keywords with the site keywords
|
|
@site.keywords.concat(@document.keywords or []).join(', ')
|
|
getGruntedStyles: ->
|
|
_ = require 'underscore'
|
|
styles = []
|
|
gruntConfig = require('./grunt-config.json')
|
|
_.each gruntConfig, (value, key) ->
|
|
styles = styles.concat _.flatten _.pluck value, 'dest'
|
|
styles = _.filter styles, (value) ->
|
|
return value.indexOf('.min.css') > -1
|
|
_.map styles, (value) ->
|
|
return value.replace 'out', ''
|
|
|
|
getGruntedScripts: ->
|
|
_ = require 'underscore'
|
|
scripts = []
|
|
gruntConfig = require('./grunt-config.json')
|
|
_.each gruntConfig, (value, key) ->
|
|
scripts = scripts.concat _.flatten _.pluck value, 'dest'
|
|
scripts = _.filter scripts, (value) ->
|
|
return value.indexOf('.min.js') > -1
|
|
_.map scripts, (value) ->
|
|
return value.replace 'out', ''
|
|
|
|
|
|
# =================================
|
|
# DocPad Events
|
|
|
|
# Here we can define handlers for events that DocPad fires
|
|
# You can find a full listing of events on the DocPad Wiki
|
|
events:
|
|
|
|
# Server Extend
|
|
# Used to add our own custom routes to the server before the docpad routes are added
|
|
serverExtend: (opts) ->
|
|
# Extract the server from the options
|
|
{server} = opts
|
|
docpad = @docpad
|
|
|
|
# As we are now running in an event,
|
|
# ensure we are using the latest copy of the docpad configuraiton
|
|
# and fetch our urls from it
|
|
latestConfig = docpad.getConfig()
|
|
oldUrls = latestConfig.templateData.site.oldUrls or []
|
|
newUrl = latestConfig.templateData.site.url
|
|
|
|
# Redirect any requests accessing one of our sites oldUrls to the new site url
|
|
server.use (req,res,next) ->
|
|
if req.headers.host in oldUrls
|
|
res.redirect(newUrl+req.url, 301)
|
|
else
|
|
next()
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
# Export our DocPad Configuration
|
|
module.exports = docpadConfig
|