summaryrefslogtreecommitdiff
path: root/docs/markdown.md
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 /docs/markdown.md
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 'docs/markdown.md')
-rw-r--r--docs/markdown.md120
1 files changed, 120 insertions, 0 deletions
diff --git a/docs/markdown.md b/docs/markdown.md
new file mode 100644
index 000000000..ceeb0b515
--- /dev/null
+++ b/docs/markdown.md
@@ -0,0 +1,120 @@
+## ✍️ Markdown
+
+Astro comes with out-of-the-box Markdown support powered by the expansive [**remark**](https://github.com/remarkjs/remark) ecosystem.
+
+## Remark Plugins
+
+**This is the first draft of Markdown support!** While we plan to support user-provided `remark` plugins soon, our hope is that you won't need `remark` plugins at all!
+
+In addition to [custom components inside the `<Markdown>` component](#markdown-component), Astro comes with [GitHub-flavored Markdown](https://github.github.com/gfm/) support, [Footnotes](https://github.com/remarkjs/remark-footnotes) syntax, [Smartypants](https://github.com/silvenon/remark-smartypants), and syntax highlighting via [Prism](https://prismjs.com/) pre-enabled. These features are likely to be configurable in the future.
+
+### Markdown Pages
+
+Astro treats any `.md` files inside of the `/src/pages` directory as pages. These pages are processed as plain Markdown files and do not support components. If you're looking to embed rich components in your Markdown, take a look at the [Markdown Component](#markdown-component) section.
+
+#### `layout`
+
+The only special Frontmatter key is `layout`, which defines the relative path to a `.astro` component which should wrap your Markdown content.
+
+`src/pages/index.md`
+```md
+---
+layout: ../layouts/main.astro
+---
+
+# Hello world!
+```
+
+Layout files are normal `.astro` components. Any Frontmatter defined in your `.md` page will be exposed to the Layout component as the `content` prop. `content` also has an `astro` key which holds special metadata about your file, like the complete Markdown `source` and a `headings` object.
+
+The rendered Markdown content is placed into the default `<slot />` element.
+
+`src/layouts/main.astro`
+```jsx
+---
+export let content;
+---
+
+<html>
+ <head>
+ <title>{content.title}</title>
+ </head>
+
+ <body>
+ <slot/>
+ </body>
+</html>
+```
+
+### Markdown Component
+
+Similar to tools like [MDX](https://mdxjs.com/) or [MDsveX](https://github.com/pngwn/MDsveX), Astro makes it straightforward to embed rich, interactive components inside of your Markdown content. The `<Markdown>` component is statically rendered, so it does not add any runtime overhead.
+
+Astro exposes a special `Markdown` component for `.astro` files which enables markdown syntax for its children **recursively**. Within the `Markdown` component you may also use plain HTML or any other type of component that is supported by Astro.
+
+```jsx
+---
+// For now, this import _must_ be named "Markdown" and _must not_ be wrapped with a custom component
+// We're working on easing these restrictions!
+import Markdown from 'astro/components/Markdown.astro';
+import Layout from '../layouts/main.astro';
+import MyFancyCodePreview from '../components/MyFancyCodePreview.tsx';
+
+const expressions = 'Lorem ipsum';
+---
+
+<Layout>
+ <Markdown>
+ # Hello world!
+
+ **Everything** supported in a `.md` file is also supported here!
+
+ There is _zero_ runtime overhead.
+
+ In addition, Astro supports:
+ - Astro {expressions}
+ - Automatic indentation normalization
+ - Automatic escaping of expressions inside code blocks
+
+ ```jsx
+ // This content is not transformed!
+ const object = { someOtherValue };
+ ```
+
+ - Rich component support like any `.astro` file!
+ - Recursive Markdown support (Component children are also processed as Markdown)
+
+ <MyFancyCodePreview:visible>
+ ```jsx
+ const object = { someOtherValue };
+ ```
+ </MyFancyCodePreview:visible>
+ </Markdown>
+</Layout>
+```
+
+### Remote Markdown
+
+If you have Markdown in a remote source, you may pass it directly to the Markdown component. For example, the example below fetches the README from Snowpack's GitHub repository and renders it as HTML.
+
+```jsx
+---
+import Markdown from 'astro/components/Markdown.astro';
+
+const content = await fetch('https://raw.githubusercontent.com/snowpackjs/snowpack/main/README.md').then(res => res.text());
+---
+
+<Layout>
+ <Markdown>{content}</Markdown>
+</Layout>
+```
+
+### Security FAQs
+
+**Aren't there security concerns to rendering remote markdown directly to HTML?**
+
+Yes! Just like with regular HTML, improper use the `<Markdown>` component can open you up to a [cross-site scripting (XSS)](https://en.wikipedia.org/wiki/Cross-site_scripting) attack. If you are rendering untrusted content, be sure to _santize your content **before** rendering it_.
+
+**Why not use a prop like React's `dangerouslySetInnerHTML={{ __html: content }}`?**
+
+Rendering a string of HTML (or Markdown) is an extremely common use case when rendering a static site and you probably don't need the extra hoops to jump through. Rendering untrusted content is always dangerous! Be sure to _santize your content **before** rendering it_.