Fred fixes part 2

This commit is contained in:
Fred K. Schott 2021-09-20 19:29:16 +00:00 committed by Drew Powers
parent 75fc9f2c7a
commit 34e016aeb3
10 changed files with 1032 additions and 1250 deletions

View file

@ -40,9 +40,7 @@
"npm": "7.11.2",
"yarn": "1.22.10"
},
"dependencies": {
"camel-case": "^4.1.2"
},
"dependencies": {},
"devDependencies": {
"@changesets/cli": "^2.16.0",
"@types/jest": "^27.0.1",

View file

@ -59,18 +59,11 @@
"@web/rollup-plugin-html": "^1.9.1",
"acorn": "^7.4.0",
"astring": "^1.7.5",
"autoprefixer": "^10.2.5",
"babel-plugin-module-resolver": "^4.1.0",
"camel-case": "^4.1.2",
"chokidar": "^3.5.2",
"ci-info": "^3.2.0",
"connect": "^3.7.0",
"deepmerge": "^4.2.2",
"del": "^6.0.0",
"es-module-lexer": "^0.7.1",
"esbuild": "^0.12.23",
"estree-util-value-to-estree": "^1.2.0",
"etag": "^1.8.1",
"fast-xml-parser": "^3.19.0",
"fdir": "^5.1.0",
"get-port": "^5.1.1",
@ -81,6 +74,7 @@
"node-fetch": "^2.6.1",
"path-to-regexp": "^6.2.0",
"picomatch": "^2.3.0",
"rimraf": "^3.0.2",
"sass": "^1.38.1",
"semver": "^7.3.5",
"send": "^0.17.1",
@ -88,7 +82,6 @@
"shorthash": "^0.0.2",
"slash": "^4.0.0",
"source-map": "^0.7.3",
"srcset-parse": "^1.1.0",
"string-width": "^5.0.0",
"strip-ansi": "^7.0.1",
"supports-esm": "^1.0.0",
@ -100,9 +93,9 @@
"@astrojs/parser": "^0.20.2",
"@types/babel__core": "^7.1.15",
"@types/connect": "^3.4.35",
"@types/etag": "^1.8.1",
"@types/mime": "^2.0.3",
"@types/node-fetch": "^2.5.12",
"@types/rimraf": "^3.0.2",
"@types/send": "^0.17.1",
"@types/yargs-parser": "^20.2.1",
"sqlite": "^4.0.23",

View file

@ -100,7 +100,6 @@ export interface AstroUserConfig {
// @types/config.ts file, consider replacing it with the following lines:
//
// export interface AstroUserConfig extends z.input<typeof AstroConfigSchema> {
// markdownOptions?: Partial<AstroMarkdownOptions>;
// }
export type AstroConfig = z.output<typeof AstroConfigSchema>;

View file

@ -1,6 +1,5 @@
import type { LogOptions } from '../logger';
import del from 'del';
import rimraf from 'rimraf';
import { fileURLToPath } from 'url';
import { defaultLogDestination, defaultLogLevel, info } from '../logger.js';
@ -13,7 +12,7 @@ export async function reload(cwd: string) {
try {
info(logging, 'reload', `Clearing the cache...`);
const viteCache = new URL('node_modules/.vite/', `file://${cwd}/`);
await del(fileURLToPath(viteCache));
rimraf.sync(fileURLToPath(viteCache));
return 0;
} catch {
return 1;

View file

@ -4,16 +4,12 @@ import type { AstroConfig, ManifestData, RouteCache, RouteData, SSRError } from
import type { LogOptions } from '../logger';
import type { HmrContext, ModuleNode } from 'vite';
import chokidar from 'chokidar';
import { fileURLToPath } from 'url';
import connect from 'connect';
import mime from 'mime';
import getEtag from 'etag';
import { performance } from 'perf_hooks';
import { fileURLToPath } from 'url';
import { createRequire } from 'module';
import stripAnsi from 'strip-ansi';
import path from 'path';
import { promises as fs } from 'fs';
import vite from 'vite';
import { defaultLogOptions, error, info } from '../logger.js';
import { createRouteManifest, matchRoute } from '../runtime/routing.js';
@ -65,7 +61,6 @@ export class AstroDevServer {
private origin: string;
private routeCache: RouteCache = {};
private viteServer: vite.ViteDevServer | undefined;
private watcher: chokidar.FSWatcher;
private mostRecentRoute?: RouteData;
constructor(config: AstroConfig, options: DevOptions) {
@ -76,20 +71,6 @@ export class AstroDevServer {
this.port = config.devOptions.port;
this.origin = config.buildOptions.site ? new URL(config.buildOptions.site).origin : `http://localhost:${this.port}`;
this.manifest = createRouteManifest({ config });
// rebuild manifest on change (watch all events, but only rebuild if .astro or .md files are touched)
this.watcher = chokidar.watch(fileURLToPath(config.pages), { ignored: ['!**/*.astro', '!**/*.md', '**'] }); // ignore everything but .astro & .md
this.watcher.on('add', () => {
this.routeCache = {};
this.manifest = createRouteManifest({ config: this.config });
});
this.watcher.on('unlink', () => {
this.routeCache = {};
this.manifest = createRouteManifest({ config: this.config });
});
this.watcher.on('change', () => {
this.routeCache = {}; // note: manifests dont need to be rebuilt on file content changes
});
}
/** Start dev server */
@ -98,6 +79,7 @@ export class AstroDevServer {
const devStart = performance.now();
// 2. create Vite instance
const pagesDirectory = fileURLToPath(this.config.pages);
const viteConfig = await loadViteConfig(
{
mode: 'development',
@ -109,6 +91,28 @@ export class AstroDevServer {
{ astroConfig: this.config, logging: this.logging, devServer: this }
);
this.viteServer = await vite.createServer(viteConfig);
this.viteServer.watcher.on('add', (file) => {
// Only rebuild routes if new file is a page.
if (!file.startsWith(pagesDirectory)) {
return;
}
this.routeCache = {};
this.manifest = createRouteManifest({ config: this.config });
});
this.viteServer.watcher.on('unlink', (file) => {
// Only rebuild routes if deleted file is a page.
if (!file.startsWith(pagesDirectory)) {
return;
}
this.routeCache = {};
this.manifest = createRouteManifest({ config: this.config });
});
this.viteServer.watcher.on('change', () => {
// No need to rebuild routes on file content changes.
// However, we DO want to clear the cache in case
// the change caused a getStaticPaths() return to change.
this.routeCache = {};
});
// 3. add middlewares
this.app.use((req, res, next) => this.handleRequest(req, res, next));
@ -136,7 +140,6 @@ export class AstroDevServer {
if (this.httpServer) this.httpServer.close(); // close HTTP server
await Promise.all([
...(this.viteServer ? [this.viteServer.close()] : []), // close Vite server
this.watcher.close(), // close chokidar
]);
}

View file

@ -1,6 +1,6 @@
import type { AstroComponentMetadata } from '../@types/astro';
import { valueToEstree, Value } from 'estree-util-value-to-estree';
import { valueToEstree } from 'estree-util-value-to-estree';
import * as astring from 'astring';
import shorthash from 'shorthash';
import { renderToString, renderAstroComponent } from '../runtime/astro.js';
@ -21,7 +21,7 @@ const customGenerator: astring.Generator = {
}
},
};
const serialize = (value: Value) =>
const serialize = (value: any) =>
generate(valueToEstree(value), {
generator: customGenerator,
});
@ -47,9 +47,10 @@ async function _render(child: any): Promise<any> {
}
export class AstroComponent {
private htmlParts: string[];
private expressions: TemplateStringsArray;
constructor(htmlParts: string[], expressions: TemplateStringsArray) {
private htmlParts: TemplateStringsArray;
private expressions: any[];
constructor(htmlParts: TemplateStringsArray, expressions: any[]) {
this.htmlParts = htmlParts;
this.expressions = expressions;
}
@ -67,7 +68,7 @@ export class AstroComponent {
}
}
export function render(htmlParts: string[], ...expressions: TemplateStringsArray) {
export async function render(htmlParts: TemplateStringsArray, ...expressions: any[]) {
return new AstroComponent(htmlParts, expressions);
}
@ -162,11 +163,10 @@ export const renderComponent = async (result: any, displayName: string, Componen
const { hydrationDirective, props } = extractHydrationDirectives(_props);
let html = '';
if (!hydrationDirective) {
return '<pre>Not implemented</pre>';
if (hydrationDirective) {
metadata.hydrate = hydrationDirective[0] as AstroComponentMetadata['hydrate'];
metadata.hydrateArgs = hydrationDirective[1];
}
metadata.hydrate = hydrationDirective[0] as AstroComponentMetadata['hydrate'];
metadata.hydrateArgs = hydrationDirective[1];
for (const [url, exported] of Object.entries(result._metadata.importedModules)) {
for (const [key, value] of Object.entries(exported as any)) {
@ -186,6 +186,11 @@ export const renderComponent = async (result: any, displayName: string, Componen
}
({ html } = await renderer.ssr.renderToStaticMarkup(Component, props, null));
if (!hydrationDirective) {
return html;
}
const astroId = shorthash.unique(html);
result.scripts.add(await generateHydrateScript({ renderer, astroId, props }, metadata as Required<AstroComponentMetadata>));

View file

@ -21,6 +21,6 @@ export async function renderToString(result: any, componentFactory: AstroCompone
export async function renderPage(result: any, Component: AstroComponentFactory, props: any, children: any) {
const template = await renderToString(result, Component, props, children);
const styles = Array.from(result.styles).map((style) => `<style>${style}</style>`);
const scripts = Array.from(result.scripts).map((script) => `<script type="module">${script}</script>`);
const scripts = Array.from(result.scripts);
return template.replace('</head>', styles.join('\n') + scripts.join('\n') + '</head>');
}

View file

@ -3,7 +3,7 @@ import { map } from 'unist-util-map';
const MDX_ELEMENTS = new Set(['mdxJsxFlowElement', 'mdxJsxTextElement']);
export default function rehypeJsx(): any {
return function (node: any): any {
return map(node, (child) => {
return map(node, (child: any) => {
if (child.type === 'element') {
return { ...child, tagName: `${child.tagName}` }
}
@ -12,7 +12,7 @@ export default function rehypeJsx(): any {
...child,
type: 'element',
tagName: `${child.name}`,
properties: child.attributes.reduce((acc, entry) => {
properties: child.attributes.reduce((acc: any[], entry: any) => {
let attr = entry.value;
if (attr && typeof attr === 'object') {
attr = `{${attr.value}}`

View file

@ -1,5 +1,5 @@
{
"extends": "../../tsconfig.base.json",
"extends": "../../../tsconfig.base.json",
"include": ["src"],
"compilerOptions": {
"allowJs": true,

2183
yarn.lock

File diff suppressed because it is too large Load diff