| | |
| | | import { PluggableList } from "unified" |
| | | import { StaticResources } from "../resources" |
| | | import { StaticResources } from "../util/resources" |
| | | import { ProcessedContent } from "./vfile" |
| | | import { GlobalConfiguration } from "../cfg" |
| | | |
| | | export abstract class QuartzTransformerPlugin { |
| | | abstract name: string |
| | | abstract markdownPlugins(): PluggableList |
| | | abstract htmlPlugins(): PluggableList |
| | | externalResources?: Partial<StaticResources> |
| | | } |
| | | |
| | | export abstract class QuartzFilterPlugin { |
| | | abstract name: string |
| | | abstract shouldPublish(content: ProcessedContent): boolean |
| | | } |
| | | |
| | | export interface EmitOptions { |
| | | slug: string |
| | | ext: `.${string}` |
| | | content: string |
| | | } |
| | | |
| | | export type EmitCallback = (data: EmitOptions) => Promise<string> |
| | | export abstract class QuartzEmitterPlugin { |
| | | abstract name: string |
| | | abstract emit(cfg: GlobalConfiguration, content: ProcessedContent[], resources: StaticResources, emitCallback: EmitCallback): Promise<string[]> |
| | | } |
| | | import { QuartzComponent } from "../components/types" |
| | | import { FilePath } from "../util/path" |
| | | import { BuildCtx } from "../util/ctx" |
| | | import DepGraph from "../depgraph" |
| | | |
| | | export interface PluginTypes { |
| | | transformers: QuartzTransformerPlugin[], |
| | | filters: QuartzFilterPlugin[], |
| | | emitters: QuartzEmitterPlugin[], |
| | | transformers: QuartzTransformerPluginInstance[] |
| | | filters: QuartzFilterPluginInstance[] |
| | | emitters: QuartzEmitterPluginInstance[] |
| | | } |
| | | |
| | | type OptionType = object | undefined |
| | | type ExternalResourcesFn = (ctx: BuildCtx) => Partial<StaticResources> | undefined |
| | | export type QuartzTransformerPlugin<Options extends OptionType = undefined> = ( |
| | | opts?: Options, |
| | | ) => QuartzTransformerPluginInstance |
| | | export type QuartzTransformerPluginInstance = { |
| | | name: string |
| | | textTransform?: (ctx: BuildCtx, src: string) => string |
| | | markdownPlugins?: (ctx: BuildCtx) => PluggableList |
| | | htmlPlugins?: (ctx: BuildCtx) => PluggableList |
| | | externalResources?: ExternalResourcesFn |
| | | } |
| | | |
| | | export type QuartzFilterPlugin<Options extends OptionType = undefined> = ( |
| | | opts?: Options, |
| | | ) => QuartzFilterPluginInstance |
| | | export type QuartzFilterPluginInstance = { |
| | | name: string |
| | | shouldPublish(ctx: BuildCtx, content: ProcessedContent): boolean |
| | | } |
| | | |
| | | export type QuartzEmitterPlugin<Options extends OptionType = undefined> = ( |
| | | opts?: Options, |
| | | ) => QuartzEmitterPluginInstance |
| | | export type QuartzEmitterPluginInstance = { |
| | | name: string |
| | | emit( |
| | | ctx: BuildCtx, |
| | | content: ProcessedContent[], |
| | | resources: StaticResources, |
| | | ): Promise<FilePath[]> | AsyncGenerator<FilePath> |
| | | /** |
| | | * Returns the components (if any) that are used in rendering the page. |
| | | * This helps Quartz optimize the page by only including necessary resources |
| | | * for components that are actually used. |
| | | */ |
| | | getQuartzComponents?: (ctx: BuildCtx) => QuartzComponent[] |
| | | getDependencyGraph?( |
| | | ctx: BuildCtx, |
| | | content: ProcessedContent[], |
| | | resources: StaticResources, |
| | | ): Promise<DepGraph<FilePath>> |
| | | externalResources?: ExternalResourcesFn |
| | | } |