mirror of
https://github.com/withastro/astro.git
synced 2025-01-20 22:12:38 -05:00
397d8f3d84
* Upgrade @astrojs/markdown-support deps and update types * Add changeset * Update changeset * Switch astro-markdown-plugins example to use rehype-autolink-headings Usage of remark-autolink-headings is discouraged in favor of the rehype counterpart: https://github.com/remarkjs/remark-autolink-headings\#remark-autolink-headings * Add stricter types for unified plugins This includes a few suggestions from a code review: - use vfile.toString instead of vfile.value.toString - refactor plugins to follow unified best practices instead of returning functions that return a plugin - use any instead of any[] for plugin options types * Narrow down types to more specific hast or mdast typings
27 lines
753 B
TypeScript
27 lines
753 B
TypeScript
import unified from 'unified';
|
|
import type { Plugin, UnifiedPluginImport } from './types';
|
|
|
|
async function importPlugin(p: string | UnifiedPluginImport): UnifiedPluginImport {
|
|
if (typeof p === 'string') {
|
|
return await import(p);
|
|
}
|
|
|
|
return await p;
|
|
}
|
|
|
|
export function loadPlugins(items: Plugin[]): Promise<[unified.Plugin] | [unified.Plugin, any]>[] {
|
|
return items.map((p) => {
|
|
return new Promise((resolve, reject) => {
|
|
if (Array.isArray(p)) {
|
|
const [plugin, opts] = p;
|
|
return importPlugin(plugin)
|
|
.then((m) => resolve([m.default, opts]))
|
|
.catch((e) => reject(e));
|
|
}
|
|
|
|
return importPlugin(p)
|
|
.then((m) => resolve([m.default]))
|
|
.catch((e) => reject(e));
|
|
});
|
|
});
|
|
}
|