summaryrefslogtreecommitdiff
path: root/packages/markdown-support/src/remark-scoped-styles.ts
diff options
context:
space:
mode:
authorGravatar Matthew Phillips <matthew@matthewphillips.info> 2021-06-04 14:19:01 -0400
committerGravatar GitHub <noreply@github.com> 2021-06-04 14:19:01 -0400
commit50e6f491ad2258689ba8735a3f98a0d99e4ba336 (patch)
treecc2c1284b3632d6447d3c9bab3b5c1aa461c35cf /packages/markdown-support/src/remark-scoped-styles.ts
parenta2594ef572c41ce05dd01ef095e8595ffcd35842 (diff)
downloadastro-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.ts18
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);
+}