summaryrefslogtreecommitdiff
path: root/packages/astro-parser/src/interfaces.ts
diff options
context:
space:
mode:
authorGravatar Nate Moore <natemoo-re@users.noreply.github.com> 2021-05-17 09:29:16 -0500
committerGravatar GitHub <noreply@github.com> 2021-05-17 09:29:16 -0500
commitb3886c206f550b53227facd0480a94500ab2515d (patch)
treeb3a1af99f6fa62adeb6996db1c4d47f4015c32d4 /packages/astro-parser/src/interfaces.ts
parentfe5cf78e8e5760f814aa7f5af4c68f51b2ce457c (diff)
downloadastro-b3886c206f550b53227facd0480a94500ab2515d.tar.gz
astro-b3886c206f550b53227facd0480a94500ab2515d.tar.zst
astro-b3886c206f550b53227facd0480a94500ab2515d.zip
Fix markdown issues (#208)
* Init fix/markdown * Astro Markdown (#207) * Add Astro Markdown to VSCode Extension * Add Astro Markdown to Astro * refactor: update astro-markdown example * feat: remove embedded components from `.md` files * fix: resolve `.md.astro` files at runtime * chore: update markdown tests * feat: add <Markdown> component * chore: bump examples * chore: update example * fix: improve Markdown child handling * feat: harden markdown support, add code fence support, add automatic dedenting * chore: add weird markdown edge cases * chore: update remote-markdown examples * chore: add comment to Markdown.astro * feat: improve markdown support (codefences, nested inside HTML) * refactor: extract import specifier types to set * refactor: conditionally import markdown renderer * refactor: revert special-cased "astro/components" * refactor: revert special-cased "astro/components" * refactor: use astro/components/Markdown.astro * refactor: remove `.md.astro` support in favor of Markdown component * refactor: use regular .astro files * refactor: remove unused code * refactor: move Markdown inside Layout * wip: markdown scoped styles * feat: improve scoped styles in Markdown * feat: micromark => remark ecosystem * fix: markdown build * fix: markdown build * chore: add todo * fix: collect headers text * docs: add Markdown doc * chore: add changeset * docs: improve Markdown highlighting * refactor: prefer Set * refactor: exclude large unified deps * docs: update markdown docs Co-authored-by: Jonathan Neal <jonathantneal@hotmail.com> * chore: remove extra markdown deps * perf: optimize markdown * fix: unified/rehype deps * temp: fix markdown test * test: add TODO comment * fix: do not namespace frontmatter, just astro metadata * test: fix astro-markdown test * test: add realworld markdown example * fix: prism language bug * docs: update markdown docs * chore: bump dependencies * fix: escape codespan * fix: unterminated string literal * fix(vscode): inline dependencies * fix(vscode): dependencies * feat(vscode): embedded markdown * feat: add Markdown syntax highlighting * chore: improve markdown example * fix: markdown example * feat: highlighting improvements * chore: add changeset * fix: CodeBlock => CodeSpan * chore: get astro-markdown example running Co-authored-by: Jonathan Neal <jonathantneal@hotmail.com>
Diffstat (limited to 'packages/astro-parser/src/interfaces.ts')
-rw-r--r--packages/astro-parser/src/interfaces.ts16
1 files changed, 15 insertions, 1 deletions
diff --git a/packages/astro-parser/src/interfaces.ts b/packages/astro-parser/src/interfaces.ts
index efe971941..40eeb04f5 100644
--- a/packages/astro-parser/src/interfaces.ts
+++ b/packages/astro-parser/src/interfaces.ts
@@ -20,6 +20,20 @@ export interface Text extends BaseNode {
raw: string;
}
+export interface CodeFence extends BaseNode {
+ type: 'CodeFence';
+ metadata: string;
+ data: string;
+ raw: string;
+}
+
+export interface CodeSpan extends BaseNode {
+ type: 'CodeFence';
+ metadata: string;
+ data: string;
+ raw: string;
+}
+
export interface Attribute extends BaseNode {
type: 'Attribute';
name: string;
@@ -48,7 +62,7 @@ export interface Transition extends BaseDirective {
export type Directive = BaseDirective | Transition;
-export type TemplateNode = Text | MustacheTag | BaseNode | Directive | Transition;
+export type TemplateNode = Text | CodeSpan | CodeFence | MustacheTag | BaseNode | Directive | Transition;
export interface Expression {
type: 'Expression';