feat: restart server on markdoc config change (#7467)
* deps: vite-plugin-restart * feat: restart on markdoc config change * chore: changeset * chore: roll our own restarter! * deps: remove vite-plugin-restart * refactor: use good enough option
This commit is contained in:
parent
2726098bc8
commit
f6feff7a29
3 changed files with 20 additions and 19 deletions
5
.changeset/wet-apples-smoke.md
Normal file
5
.changeset/wet-apples-smoke.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'@astrojs/markdoc': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Restart the dev server whenever your markdoc config changes.
|
|
@ -4,7 +4,7 @@ import Markdoc from '@markdoc/markdoc';
|
||||||
import type { AstroConfig, AstroIntegration, ContentEntryType, HookParameters } from 'astro';
|
import type { AstroConfig, AstroIntegration, ContentEntryType, HookParameters } from 'astro';
|
||||||
import crypto from 'node:crypto';
|
import crypto from 'node:crypto';
|
||||||
import fs from 'node:fs';
|
import fs from 'node:fs';
|
||||||
import { fileURLToPath, pathToFileURL } from 'node:url';
|
import { fileURLToPath } from 'node:url';
|
||||||
import {
|
import {
|
||||||
hasContentFlag,
|
hasContentFlag,
|
||||||
isValidUrl,
|
isValidUrl,
|
||||||
|
@ -15,11 +15,15 @@ import {
|
||||||
} from './utils.js';
|
} from './utils.js';
|
||||||
// @ts-expect-error Cannot find module 'astro/assets' or its corresponding type declarations.
|
// @ts-expect-error Cannot find module 'astro/assets' or its corresponding type declarations.
|
||||||
import { emitESMImage } from 'astro/assets';
|
import { emitESMImage } from 'astro/assets';
|
||||||
import { bold, red, yellow } from 'kleur/colors';
|
import { bold, red } from 'kleur/colors';
|
||||||
import path from 'node:path';
|
import path from 'node:path';
|
||||||
import type * as rollup from 'rollup';
|
import type * as rollup from 'rollup';
|
||||||
import { normalizePath } from 'vite';
|
import { normalizePath } from 'vite';
|
||||||
import { loadMarkdocConfig, type MarkdocConfigResult } from './load-config.js';
|
import {
|
||||||
|
loadMarkdocConfig,
|
||||||
|
SUPPORTED_MARKDOC_CONFIG_FILES,
|
||||||
|
type MarkdocConfigResult,
|
||||||
|
} from './load-config.js';
|
||||||
import { setupConfig } from './runtime.js';
|
import { setupConfig } from './runtime.js';
|
||||||
|
|
||||||
type SetupHookParams = HookParameters<'astro:config:setup'> & {
|
type SetupHookParams = HookParameters<'astro:config:setup'> & {
|
||||||
|
@ -45,15 +49,13 @@ export default function markdocIntegration(legacyConfig?: any): AstroIntegration
|
||||||
}
|
}
|
||||||
let markdocConfigResult: MarkdocConfigResult | undefined;
|
let markdocConfigResult: MarkdocConfigResult | undefined;
|
||||||
let markdocConfigResultId = '';
|
let markdocConfigResultId = '';
|
||||||
|
let astroConfig: AstroConfig;
|
||||||
return {
|
return {
|
||||||
name: '@astrojs/markdoc',
|
name: '@astrojs/markdoc',
|
||||||
hooks: {
|
hooks: {
|
||||||
'astro:config:setup': async (params) => {
|
'astro:config:setup': async (params) => {
|
||||||
const {
|
const { updateConfig, addContentEntryType } = params as SetupHookParams;
|
||||||
config: astroConfig,
|
astroConfig = params.config;
|
||||||
updateConfig,
|
|
||||||
addContentEntryType,
|
|
||||||
} = params as SetupHookParams;
|
|
||||||
|
|
||||||
markdocConfigResult = await loadMarkdocConfig(astroConfig);
|
markdocConfigResult = await loadMarkdocConfig(astroConfig);
|
||||||
if (markdocConfigResult) {
|
if (markdocConfigResult) {
|
||||||
|
@ -204,10 +206,8 @@ export const Content = createComponent({
|
||||||
|
|
||||||
updateConfig({
|
updateConfig({
|
||||||
vite: {
|
vite: {
|
||||||
vite: {
|
ssr: {
|
||||||
ssr: {
|
external: ['@astrojs/markdoc/prism', '@astrojs/markdoc/shiki'],
|
||||||
external: ['@astrojs/markdoc/prism', '@astrojs/markdoc/shiki'],
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
build: {
|
build: {
|
||||||
rollupOptions,
|
rollupOptions,
|
||||||
|
@ -233,12 +233,8 @@ export const Content = createComponent({
|
||||||
},
|
},
|
||||||
'astro:server:setup': async ({ server }) => {
|
'astro:server:setup': async ({ server }) => {
|
||||||
server.watcher.on('all', (event, entry) => {
|
server.watcher.on('all', (event, entry) => {
|
||||||
if (prependForwardSlash(pathToFileURL(entry).pathname) === markdocConfigResultId) {
|
if (SUPPORTED_MARKDOC_CONFIG_FILES.some((f) => entry.endsWith(f))) {
|
||||||
console.log(
|
server.restart();
|
||||||
yellow(
|
|
||||||
`${bold('[Markdoc]')} Restart the dev server for config changes to take effect.`
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
|
@ -4,7 +4,7 @@ import * as fs from 'node:fs';
|
||||||
import { fileURLToPath } from 'node:url';
|
import { fileURLToPath } from 'node:url';
|
||||||
import type { AstroMarkdocConfig } from './config.js';
|
import type { AstroMarkdocConfig } from './config.js';
|
||||||
|
|
||||||
const SUPPORTED_MARKDOC_CONFIG_FILES = [
|
export const SUPPORTED_MARKDOC_CONFIG_FILES = [
|
||||||
'markdoc.config.js',
|
'markdoc.config.js',
|
||||||
'markdoc.config.mjs',
|
'markdoc.config.mjs',
|
||||||
'markdoc.config.mts',
|
'markdoc.config.mts',
|
||||||
|
|
Loading…
Reference in a new issue