Very Popular
import { optimize } from "../deps/svgo.ts";import { merge } from "../core/utils.ts";
import type { DeepPartial, Page, Site } from "../core.ts";import type { Config } from "../deps/svgo.ts";
export interface Options { /** The list of extensions this plugin applies to */ extensions: string[];
/** Options passed to SVGO. See https://github.com/svg/svgo#configuration */ options: Config;}
// Default optionsexport const defaults: Options = { extensions: [".svg"], options: {},};
/** A plugin to load all SVG files and minify them using SVGO */export default function (userOptions?: DeepPartial<Options>) { const options = merge(defaults, userOptions);
return (site: Site) => { site.loadAssets(options.extensions); site.process(options.extensions, svg);
function svg(page: Page) { const path = site.src(page.outputPath!); const result = optimize(page.content as string, { path, ...options.options, }) as { data: string };
page.content = result.data; } };}