2023-02-06 16:13:57 +00:00
import type { AstroIntegration } from 'astro' ;
2023-02-06 16:21:17 +00:00
import type { InlineConfig } from 'vite' ;
2023-02-06 21:11:01 +00:00
import _Markdoc from '@markdoc/markdoc' ;
2023-02-07 21:01:34 +00:00
import { parseFrontmatter } from './utils.js' ;
import { fileURLToPath } from 'node:url' ;
2023-02-10 14:00:53 +00:00
import fs from 'node:fs' ;
2023-02-07 21:01:34 +00:00
const contentEntryType = {
extensions : [ '.mdoc' ] ,
2023-02-09 17:16:02 +00:00
async getEntryInfo ( { fileUrl , contents } : { fileUrl : URL ; contents : string } ) {
const parsed = parseFrontmatter ( contents , fileURLToPath ( fileUrl ) ) ;
2023-02-07 21:01:34 +00:00
return {
data : parsed.data ,
body : parsed.content ,
slug : parsed.data.slug ,
rawData : parsed.matter ,
} ;
} ,
} ;
2023-02-06 16:13:57 +00:00
export default function markdoc ( partialOptions : { } = { } ) : AstroIntegration {
return {
name : '@astrojs/markdoc' ,
hooks : {
2023-02-07 21:01:34 +00:00
'astro:config:setup' : async ( { updateConfig , config , addContentEntryType , command } : any ) = > {
addContentEntryType ( contentEntryType ) ;
2023-02-10 14:10:06 +00:00
2023-02-09 17:26:21 +00:00
const markdocConfigUrl = new URL ( './markdoc.config' , config . srcDir ) ;
2023-02-10 14:00:53 +00:00
const configFileLoad = ` if (!config) {
try {
const importedConfig = await import ( $ { JSON . stringify ( markdocConfigUrl . pathname ) } ) ;
console . log ( { importedConfig } )
config = importedConfig . default . transform ;
} catch {
config = { } ;
}
} ` ;
2023-02-06 16:21:17 +00:00
const viteConfig : InlineConfig = {
plugins : [
{
name : '@astrojs/markdoc' ,
async transform ( code , id ) {
if ( ! id . endsWith ( '.mdoc' ) ) return ;
2023-02-08 14:53:35 +00:00
return ` import { jsx as h } from 'astro/jsx-runtime'; \ nimport { Markdoc } from '@astrojs/markdoc'; \ nimport { Renderer } from '@astrojs/markdoc/components'; \ nexport const body = ${ JSON . stringify (
2023-02-06 23:09:23 +00:00
code
) } ; \ nexport function getParsed() { return Markdoc . parse ( body ) ; } \ nexport async function getTransformed ( inlineConfig ) {
2023-02-10 14:00:53 +00:00
let config = inlineConfig ; \ n $ {
fs . existsSync ( markdocConfigUrl ) ? configFileLoad : ''
} \ nreturn Markdoc . transform ( getParsed ( ) , config ) } \ nexport async function Content ( { config , components } ) { return h ( Renderer , { content : await getTransformed ( config ) , components } ) ; } \ nContent [ Symbol . for ( 'astro.needsHeadRendering' ) ] = true ; ` ;
2023-02-06 16:21:17 +00:00
} ,
} ,
] ,
} ;
updateConfig ( { vite : viteConfig } ) ;
2023-02-06 16:13:57 +00:00
} ,
} ,
} ;
}
2023-02-06 21:11:01 +00:00
export const Markdoc = _Markdoc ;