-
Notifications
You must be signed in to change notification settings - Fork 232
/
Copy path.eleventy.js
130 lines (113 loc) · 5.64 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
122
123
124
125
126
127
128
129
130
// Imports
const pluginEleventyNavigation = require("@11ty/eleventy-navigation");
const pluginMinifier = require("@sherby/eleventy-plugin-files-minifier");
const pluginSitemap = require("@quasibit/eleventy-plugin-sitemap");
// Configs
const configCss = require("./src/config/css");
const configJs = require("./src/config/javascript");
const configSitemap = require("./src/config/sitemap");
const configServer = require("./src/config/server");
// Other
const filterPostDate = require("./src/config/postDate");
const isProduction = configServer.isProduction;
module.exports = function (eleventyConfig) {
/**=====================================================================
EXTENSIONS - Recognising non-default languages as templates
=======================================================================*/
/** https://www.11ty.dev/docs/languages/custom/ */
/**
* CSS EXTENSION
* Setting up CSS files to be recognised as aN eleventy template language. This allows our minifier to read CSS files and minify them
*/
eleventyConfig.addTemplateFormats("css");
eleventyConfig.addExtension("css", configCss);
/**
* JS EXTENSION
* Sets up JS files as an eleventy template language, which are compiled by esbuild. Allows bundling and minification of JS
*/
eleventyConfig.addTemplateFormats("js");
eleventyConfig.addExtension("js", configJs);
/**=====================================================================
END EXTENSIONS
=======================================================================*/
/**=====================================================================
PLUGINS - Adds additional eleventy functionality
=======================================================================*/
/** https://www.11ty.dev/docs/plugins/ */
/**
* ELEVENTY NAVIGATION
* Sets up the eleventy navigation plugin for a scalable navigation as used in _includes/components/header.html
* /~https://github.com/11ty/eleventy-navigation
*/
eleventyConfig.addPlugin(pluginEleventyNavigation);
/**
* AUTOMATIC SITEMAP GENERATION
* Automatically generate a sitemap, using the domain in _data/client.json
* https://www.npmjs.com/package/@quasibit/eleventy-plugin-sitemap
*/
eleventyConfig.addPlugin(pluginSitemap, configSitemap);
/**
* MINIFIER
* When in production ("npm run build" is ran), minify all HTML, CSS, JSON, XML, XSL and webmanifest files.
* /~https://github.com/benjaminrancourt/eleventy-plugin-files-minifier
*/
if (isProduction) {
eleventyConfig.addPlugin(pluginMinifier);
}
/**=====================================================================
END PLUGINS
=======================================================================*/
/**======================================================================
PASSTHROUGHS - Copy source files to /public with no 11ty processing
========================================================================*/
/** https://www.11ty.dev/docs/copy/ */
eleventyConfig.addPassthroughCopy("./src/assets", {
filter: ["**/*", "!**/*.js"],
});
eleventyConfig.addPassthroughCopy("./src/admin");
eleventyConfig.addPassthroughCopy("./src/_redirects");
/**=====================================================================
END PASSTHROUGHS
=======================================================================*/
/**======================================================================
FILTERS - Modify data in template files at build time
========================================================================*/
/** https://www.11ty.dev/docs/filters/ */
/**
* Converts dates from JSDate format (Fri Dec 02 18:00:00 GMT-0600) to a locale format.
* Use - {{ "DATE GOES HERE" | postDate }}
* https://moment.github.io/luxon/api-docs/index.html#datetime
*/
eleventyConfig.addFilter("postDate", filterPostDate);
/**=====================================================================
END FILTERS
=======================================================================*/
/**======================================================================
SHORTCODES - Output data using JS at build time
========================================================================*/
/** https://www.11ty.dev/docs/shortcodes/ */
/**
* Gets the current year, which can be outputted with {% year %}. Used for the footer copyright. Updates with every build.
* Use - {% year %}
*/
eleventyConfig.addShortcode("year", () => `${new Date().getFullYear()}`);
/**=====================================================================
END SHORTCODES
=======================================================================*/
/**=====================================================================
SERVER SETTINGS
=======================================================================*/
eleventyConfig.setServerOptions(configServer);
/**=====================================================================
END SERVER SETTINGS
=======================================================================*/
return {
dir: {
input: "src",
output: "public",
includes: "_includes",
data: "_data",
},
htmlTemplateEngine: "njk",
};
};