'use strict'; const path = require('path'); const { EleventyRenderPlugin } = require('@11ty/eleventy'); const syntaxHighlight = require('@11ty/eleventy-plugin-syntaxhighlight'); const formatDistanceToNow = require('date-fns/formatDistanceToNow'); const yaml = require('js-yaml'); const { LoremIpsum } = require('lorem-ipsum'); const markdown = require('markdown-it'); const markdownItAttrs = require('markdown-it-attrs'); const markdownDefList = require('markdown-it-deflist'); const typogrify = require('typogr'); const { Liquid } = require('liquidjs'); const { getImplStatus, canSplit, generateCodeExample, } = require('./source/helpers/sass_helpers.ts'); /** @param {import('@11ty/eleventy').UserConfig} eleventyConfig */ module.exports = (eleventyConfig) => { eleventyConfig.addPassthroughCopy('source/assets/dist'); eleventyConfig.addPassthroughCopy('source/assets/img'); eleventyConfig.addPassthroughCopy('source/favicon.ico'); const liquidEngine = new Liquid({ root: [ path.resolve(__dirname, 'source/_includes/'), path.resolve(__dirname, 'source/'), ], extname: '.liquid', strictFilters: true, jsTruthy: true, }); eleventyConfig.setLibrary('liquid', liquidEngine); eleventyConfig.setUseGitIgnore(false); eleventyConfig.watchIgnores.add('source/_data/versionCache.json'); const mdown = markdown({ html: true, typographer: true, }) .use(markdownDefList) .use(markdownItAttrs); eleventyConfig.setLibrary('md', mdown); eleventyConfig.addDataExtension('yml, yaml', (contents) => yaml.load(contents), ); // Shortcodes... const lorem = new LoremIpsum(); eleventyConfig.addLiquidShortcode('lorem', (type, number = 1) => { switch (type) { case 'sentence': case 'sentences': return lorem.generateSentences(number); case 'paragraph': case 'paragraphs': return lorem.generateParagraphs(number); case 'word': case 'words': return lorem.generateWords(number); } return ''; }); // Paired shortcodes... eleventyConfig.addPairedLiquidShortcode( 'compatibility', async (details, dart = null, libsass = null, ruby = null, feature = null) => liquidEngine.renderFile('compatibility', { details, dart, libsass, ruby, feature, }), ); eleventyConfig.addPairedLiquidShortcode( 'codeExample', async (contents, exampleName, autogenCSS = true, syntax = null) => { const code = generateCodeExample(contents, autogenCSS); return await liquidEngine.renderFile('code_example', { code, exampleName, }); }, ); eleventyConfig.addPairedLiquidShortcode('funFact', async (contents) => liquidEngine.renderFile('fun_fact', { contents, }), ); eleventyConfig.addPairedLiquidShortcode('markdown', (content) => mdown.render(content), ); eleventyConfig.addPairedLiquidShortcode('markdownInline', (content) => mdown.renderInline(content), ); eleventyConfig.addPairedLiquidShortcode('typogr', (content) => typogrify.typogrify(content), ); // Filters... eleventyConfig.addLiquidFilter('formatDistanceToNow', (date) => { return formatDistanceToNow(new Date(date)); }); eleventyConfig.addLiquidFilter('markdown', (content) => mdown.render(content), ); eleventyConfig.addLiquidFilter('markdownInline', (content) => mdown.renderInline(content), ); eleventyConfig.addLiquidFilter('typogr', (content) => typogrify.typogrify(content), ); eleventyConfig.addLiquidFilter('isTypedoc', (page) => page.url.startsWith('/documentation/js-api/'), ); eleventyConfig.addLiquidFilter('implStatus', (status) => getImplStatus(status), ); eleventyConfig.addPlugin(EleventyRenderPlugin); eleventyConfig.addPlugin(syntaxHighlight); // settings return { dir: { input: 'source', includes: '_includes', layouts: '_layouts', }, }; };