-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathplugins.ts
More file actions
45 lines (40 loc) · 1.26 KB
/
plugins.ts
File metadata and controls
45 lines (40 loc) · 1.26 KB
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
import lightningcss from "lume/plugins/lightningcss.ts";
import tailwindcss from "lume/plugins/tailwindcss.ts";
import inline from "lume/plugins/inline.ts";
import icons from "lume/plugins/icons.ts";
import typography from "npm:@tailwindcss/typography";
import postcss from "lume/plugins/postcss.ts";
import basePath from "lume/plugins/base_path.ts";
import metas from "lume/plugins/metas.ts";
import { Options as SitemapOptions, sitemap } from "lume/plugins/sitemap.ts";
import { favicon, Options as FaviconOptions } from "lume/plugins/favicon.ts";
import { merge } from "lume/core/utils/object.ts";
import "lume/types.ts";
export interface Options {
sitemap?: Partial<SitemapOptions>;
favicon?: Partial<FaviconOptions>;
}
export const defaults: Options = {
favicon: {
input: "favicon.svg",
},
};
/** Configure the site */
export default function (userOptions?: Options) {
const options = merge(defaults, userOptions);
return (site: Lume.Site) => {
site.use(lightningcss())
.use(basePath())
.use(metas())
.use(icons())
.use(inline())
.use(sitemap(options.sitemap))
.use(favicon(options.favicon))
.use(tailwindcss({
options: {
plugins: [typography],
},
}))
.use(postcss());
};
}