forked from jchris/eleventy-netlify-boilerplate
-
Notifications
You must be signed in to change notification settings - Fork 0
/
.eleventy.js
121 lines (104 loc) · 3.8 KB
/
.eleventy.js
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
const { DateTime } = require('luxon')
const CleanCSS = require('clean-css')
const UglifyJS = require('uglify-js')
const htmlmin = require('html-minifier')
const eleventyNavigationPlugin = require('@11ty/eleventy-navigation')
module.exports = function (eleventyConfig) {
// Eleventy Navigation https://www.11ty.dev/docs/plugins/navigation/
eleventyConfig.addPlugin(eleventyNavigationPlugin)
// Configuration API: use eleventyConfig.addLayoutAlias(from, to) to add
// layout aliases! Say you have a bunch of existing content using
// layout: post. If you don’t want to rewrite all of those values, just map
// post to a new file like this:
// eleventyConfig.addLayoutAlias("post", "layouts/my_new_post_layout.njk");
// Merge data instead of overriding
// https://www.11ty.dev/docs/data-deep-merge/
eleventyConfig.setDataDeepMerge(true)
// Add support for maintenance-free post authors
// Adds an authors collection using the author key in our post frontmatter
// Thanks to @pdehaan: https://github.com/pdehaan
eleventyConfig.addCollection('authors', (collection) => {
const blogs = collection.getFilteredByGlob('posts/*.md')
return blogs.reduce((coll, post) => {
const author = post.data.author
if (!author) {
return coll
}
if (!coll.hasOwnProperty(author)) {
coll[author] = []
}
coll[author].push(post.data)
return coll
}, {})
})
// Date formatting (human readable)
eleventyConfig.addFilter('readableDate', (dateObj) => {
return DateTime.fromJSDate(dateObj).toFormat('dd LLL yyyy')
})
// Date formatting (machine readable)
eleventyConfig.addFilter('machineDate', (dateObj) => {
return DateTime.fromJSDate(dateObj).toFormat('yyyy-MM-dd')
})
// Minify CSS
eleventyConfig.addFilter('cssmin', function (code) {
return new CleanCSS({}).minify(code).styles
})
// Minify JS
eleventyConfig.addFilter('jsmin', function (code) {
let minified = UglifyJS.minify(code)
if (minified.error) {
console.log('UglifyJS error: ', minified.error)
return code
}
return minified.code
})
// Minify HTML output
eleventyConfig.addTransform('htmlmin', function (content, outputPath) {
if (outputPath.indexOf('.html') > -1) {
let minified = htmlmin.minify(content, {
useShortDoctype: true,
removeComments: true,
collapseWhitespace: true
})
return minified
}
return content
})
// Don't process folders with static assets e.g. images
eleventyConfig.addPassthroughCopy('favicon.ico')
eleventyConfig.addPassthroughCopy('static/img')
eleventyConfig.addPassthroughCopy('docs')
eleventyConfig.addPassthroughCopy('demo')
eleventyConfig.addPassthroughCopy('admin/')
eleventyConfig.addPassthroughCopy({ tlas: '/' })
// We additionally output a copy of our CSS for use in Netlify CMS previews
eleventyConfig.addPassthroughCopy('_includes/assets/css/inline.css')
/* Markdown Plugins */
let markdownIt = require('markdown-it')
let markdownItAnchor = require('markdown-it-anchor')
let options = {
breaks: true,
linkify: true
}
let opts = {
permalink: false
}
eleventyConfig.setLibrary('md', markdownIt(options).use(markdownItAnchor, opts))
return {
templateFormats: ['md', 'njk', 'liquid'],
// If your site lives in a different subdirectory, change this.
// Leading or trailing slashes are all normalized away, so don’t worry about it.
// If you don’t have a subdirectory, use "" or "/" (they do the same thing)
// This is only used for URLs (it does not affect your file structure)
pathPrefix: '/',
markdownTemplateEngine: 'liquid',
htmlTemplateEngine: 'njk',
dataTemplateEngine: 'njk',
dir: {
input: '.',
includes: '_includes',
data: '_data',
output: '_site'
}
}
}