wip: play with separate markdoc config
This commit is contained in:
parent
570b83d525
commit
2bb0c5d98f
5 changed files with 66 additions and 54 deletions
7
examples/with-markdoc/src/components/Marquee.astro
Normal file
7
examples/with-markdoc/src/components/Marquee.astro
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
<marquee {...Astro.props}><slot /></marquee>
|
||||||
|
|
||||||
|
<style>
|
||||||
|
marquee {
|
||||||
|
color: red;
|
||||||
|
}
|
||||||
|
</style>
|
|
@ -1,6 +1,6 @@
|
||||||
# Hey there
|
# Hey there
|
||||||
|
|
||||||
This is a test file?
|
Look at this table! Built-in to Markdoc, neat.
|
||||||
|
|
||||||
{% table %}
|
{% table %}
|
||||||
* Heading 1
|
* Heading 1
|
||||||
|
@ -15,14 +15,12 @@ This is a test file?
|
||||||
|
|
||||||
{% if $shouldMarquee %}
|
{% if $shouldMarquee %}
|
||||||
{% mq direction="right" %}
|
{% mq direction="right" %}
|
||||||
Testing!
|
Im a marquee!
|
||||||
{% /mq %}
|
{% /mq %}
|
||||||
{% /if %}
|
{% /if %}
|
||||||
|
|
||||||
{% link href=$href %}Link{% /link %}
|
{% link href=$href %}Link{% /link %}
|
||||||
|
|
||||||
Some `inline code` should help
|
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const testing = true;
|
const testing = true;
|
||||||
function further() {
|
function further() {
|
||||||
|
|
30
examples/with-markdoc/src/markdoc.config.ts
Normal file
30
examples/with-markdoc/src/markdoc.config.ts
Normal file
|
@ -0,0 +1,30 @@
|
||||||
|
export default {
|
||||||
|
transform: {
|
||||||
|
variables: {
|
||||||
|
shouldMarquee: true,
|
||||||
|
href: 'https://astro.build',
|
||||||
|
},
|
||||||
|
tags: {
|
||||||
|
mq: {
|
||||||
|
render: 'marquee',
|
||||||
|
attributes: {
|
||||||
|
direction: {
|
||||||
|
type: String,
|
||||||
|
default: 'left',
|
||||||
|
matches: ['left', 'right', 'up', 'down'],
|
||||||
|
errorLevel: 'critical',
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
link: {
|
||||||
|
render: 'a',
|
||||||
|
attributes: {
|
||||||
|
href: {
|
||||||
|
type: String,
|
||||||
|
required: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
|
@ -1,52 +1,10 @@
|
||||||
---
|
---
|
||||||
import { body } from '../components/test.mdoc';
|
|
||||||
import { Markdoc } from '@astrojs/markdoc';
|
import { Markdoc } from '@astrojs/markdoc';
|
||||||
import RenderMarkdoc from '../renderer/RenderMarkdoc.astro';
|
import RenderMarkdoc from '../renderer/RenderMarkdoc.astro';
|
||||||
import RedP from '../components/RedP.astro';
|
|
||||||
|
import { getTransformed } from '../components/test.mdoc';
|
||||||
import { Code } from 'astro/components';
|
import { Code } from 'astro/components';
|
||||||
import { Tag } from '@markdoc/markdoc';
|
import Marquee from '../components/Marquee.astro';
|
||||||
import { ComponentRenderer } from '../renderer/astroNode';
|
|
||||||
|
|
||||||
const parsed = Markdoc.parse(body);
|
|
||||||
const content = Markdoc.transform(parsed, {
|
|
||||||
variables: {
|
|
||||||
shouldMarquee: true,
|
|
||||||
href: 'https://astro.build',
|
|
||||||
},
|
|
||||||
tags: {
|
|
||||||
mq: {
|
|
||||||
render: 'marquee',
|
|
||||||
attributes: {
|
|
||||||
direction: {
|
|
||||||
type: String,
|
|
||||||
default: 'left',
|
|
||||||
matches: ['left', 'right', 'up', 'down'],
|
|
||||||
errorLevel: 'critical',
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
link: {
|
|
||||||
render: 'a',
|
|
||||||
attributes: {
|
|
||||||
href: {
|
|
||||||
type: String,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
});
|
|
||||||
|
|
||||||
const code: ComponentRenderer = {
|
|
||||||
component: Code,
|
|
||||||
props({ attributes, getTreeNode }) {
|
|
||||||
return {
|
|
||||||
...attributes,
|
|
||||||
lang: attributes.lang ?? attributes['data-language'],
|
|
||||||
code: attributes.code ?? Markdoc.renderers.html(getTreeNode().children),
|
|
||||||
};
|
|
||||||
},
|
|
||||||
};
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
|
@ -61,11 +19,19 @@ const code: ComponentRenderer = {
|
||||||
<h1>Astro</h1>
|
<h1>Astro</h1>
|
||||||
<article>
|
<article>
|
||||||
<RenderMarkdoc
|
<RenderMarkdoc
|
||||||
content={content}
|
content={await getTransformed()}
|
||||||
components={{
|
components={{
|
||||||
p: RedP,
|
marquee: Marquee,
|
||||||
code,
|
pre: {
|
||||||
pre: code,
|
component: Code,
|
||||||
|
props({ attributes, getTreeNode }) {
|
||||||
|
return {
|
||||||
|
...attributes,
|
||||||
|
lang: attributes.lang ?? attributes['data-language'],
|
||||||
|
code: attributes.code ?? Markdoc.renderers.html(getTreeNode().children),
|
||||||
|
};
|
||||||
|
},
|
||||||
|
},
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
</article>
|
</article>
|
||||||
|
|
|
@ -9,6 +9,7 @@ export default function markdoc(partialOptions: {} = {}): AstroIntegration {
|
||||||
'astro:config:setup': async ({ updateConfig, config, addPageExtension, command }: any) => {
|
'astro:config:setup': async ({ updateConfig, config, addPageExtension, command }: any) => {
|
||||||
addPageExtension('.mdoc');
|
addPageExtension('.mdoc');
|
||||||
console.log('Markdoc working!');
|
console.log('Markdoc working!');
|
||||||
|
const markdocConfigUrl = new URL('./markdoc.config.ts', config.srcDir);
|
||||||
|
|
||||||
const viteConfig: InlineConfig = {
|
const viteConfig: InlineConfig = {
|
||||||
plugins: [
|
plugins: [
|
||||||
|
@ -16,7 +17,17 @@ export default function markdoc(partialOptions: {} = {}): AstroIntegration {
|
||||||
name: '@astrojs/markdoc',
|
name: '@astrojs/markdoc',
|
||||||
async transform(code, id) {
|
async transform(code, id) {
|
||||||
if (!id.endsWith('.mdoc')) return;
|
if (!id.endsWith('.mdoc')) return;
|
||||||
return `export const body = ${JSON.stringify(code)}`;
|
return `import { Markdoc } from '@astrojs/markdoc';\nexport const body = ${JSON.stringify(
|
||||||
|
code
|
||||||
|
)};\nexport function getParsed() { return Markdoc.parse(body); }\nexport async function getTransformed(inlineConfig) {
|
||||||
|
let config = inlineConfig;
|
||||||
|
if (!config) {
|
||||||
|
try {
|
||||||
|
const importedConfig = await import(${JSON.stringify(markdocConfigUrl.pathname)});
|
||||||
|
config = importedConfig.default.transform;
|
||||||
|
} catch {}
|
||||||
|
}
|
||||||
|
return Markdoc.transform(getParsed(), config) }`;
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
|
|
Loading…
Reference in a new issue