mirror of
https://github.com/danog/sass-site.git
synced 2024-12-11 17:09:52 +01:00
47 lines
1.2 KiB
TypeScript
47 lines
1.2 KiB
TypeScript
import slugify from '@sindresorhus/slugify';
|
|
import {Liquid} from 'liquidjs';
|
|
import markdown from 'markdown-it';
|
|
import markdownAnchor from 'markdown-it-anchor';
|
|
import markdownItAttrs from 'markdown-it-attrs';
|
|
import markdownDefList from 'markdown-it-deflist';
|
|
import markdownItFootnote from 'markdown-it-footnote';
|
|
import path from 'path';
|
|
|
|
import {renderPermalink} from './components/anchors';
|
|
|
|
/**
|
|
* Returns Markdown engine with custom configuration and plugins.
|
|
*
|
|
* @see https://github.com/markdown-it/markdown-it
|
|
* @see https://github.com/markdown-it/markdown-it-deflist
|
|
* @see https://github.com/arve0/markdown-it-attrs
|
|
* @see https://github.com/valeriangalliat/markdown-it-anchor
|
|
*/
|
|
export const markdownEngine = markdown({
|
|
html: true,
|
|
typographer: true,
|
|
})
|
|
.use(markdownDefList)
|
|
.use(markdownItAttrs)
|
|
.use(markdownItFootnote)
|
|
.use(markdownAnchor, {
|
|
level: 2,
|
|
permalink: renderPermalink,
|
|
slugify: s => slugify(s),
|
|
});
|
|
|
|
/**
|
|
* Returns LiquidJS engine with custom configuration.
|
|
*
|
|
* @see https://liquidjs.com/
|
|
*/
|
|
export const liquidEngine = new Liquid({
|
|
root: [
|
|
path.resolve(__dirname, '../_includes/'),
|
|
path.resolve(__dirname, '../'),
|
|
],
|
|
extname: '.liquid',
|
|
strictFilters: true,
|
|
jsTruthy: true,
|
|
});
|