diff options
author | 2021-06-04 14:19:01 -0400 | |
---|---|---|
committer | 2021-06-04 14:19:01 -0400 | |
commit | 50e6f491ad2258689ba8735a3f98a0d99e4ba336 (patch) | |
tree | cc2c1284b3632d6447d3c9bab3b5c1aa461c35cf /packages/markdown-support/src/remark-scoped-styles.ts | |
parent | a2594ef572c41ce05dd01ef095e8595ffcd35842 (diff) | |
download | astro-50e6f491ad2258689ba8735a3f98a0d99e4ba336.tar.gz astro-50e6f491ad2258689ba8735a3f98a0d99e4ba336.tar.zst astro-50e6f491ad2258689ba8735a3f98a0d99e4ba336.zip |
Use npm package names to load internal deps (#294)
* Use npm package names to load internal deps
This is necessary so that published Astro components work. These components will be built by esinstall and therefore they cannot rely on `_astro_internal`. The fix is to use npm specifiers everywhere.
* Move most of frontend to internal
* Mark astro/internal/markdown.js as external
* Move markdown stuff to its own package
This moves the markdown stuff to its own package so that we can externalize it in the markdown component.
* Add the changeset
Diffstat (limited to 'packages/markdown-support/src/remark-scoped-styles.ts')
-rw-r--r-- | packages/markdown-support/src/remark-scoped-styles.ts | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/packages/markdown-support/src/remark-scoped-styles.ts b/packages/markdown-support/src/remark-scoped-styles.ts new file mode 100644 index 000000000..9ca70c029 --- /dev/null +++ b/packages/markdown-support/src/remark-scoped-styles.ts @@ -0,0 +1,18 @@ +import { visit } from 'unist-util-visit'; +const noVisit = new Set(['root', 'html', 'text']); + +/** */ +export default function scopedStyles(className: string) { + const visitor = (node: any) => { + if (noVisit.has(node.type)) return; + + const { data } = node; + let currentClassName = data?.hProperties?.class ?? ''; + node.data = node.data || {}; + node.data.hProperties = node.data.hProperties || {}; + node.data.hProperties.class = `${className} ${currentClassName}`.trim(); + + return node; + }; + return () => (tree: any) => visit(tree, visitor); +} |