[ci] format

This commit is contained in:
matthewp 2022-06-15 12:52:13 +00:00 committed by github-actions[bot]
parent fc52321a88
commit f1f207839a
7 changed files with 92 additions and 98 deletions

View file

@ -772,9 +772,7 @@ export interface MarkdownInstance<T extends Record<string, any>> {
}>; }>;
} }
export type GetHydrateCallback = () => Promise< export type GetHydrateCallback = () => Promise<() => void | Promise<void>>;
() => void | Promise<void>
>;
/** /**
* getStaticPaths() options * getStaticPaths() options

View file

@ -8,77 +8,79 @@
} }
const propTypes: PropTypeSelector = { const propTypes: PropTypeSelector = {
0: value => value, 0: (value) => value,
1: value => JSON.parse(value, reviver), 1: (value) => JSON.parse(value, reviver),
2: value => new RegExp(value), 2: (value) => new RegExp(value),
3: value => new Date(value), 3: (value) => new Date(value),
4: value => new Map(JSON.parse(value, reviver)), 4: (value) => new Map(JSON.parse(value, reviver)),
5: value => new Set(JSON.parse(value, reviver)), 5: (value) => new Set(JSON.parse(value, reviver)),
6: value => BigInt(value), 6: (value) => BigInt(value),
7: value => new URL(value), 7: (value) => new URL(value),
}; };
const reviver = (propKey: string, raw: string): any => { const reviver = (propKey: string, raw: string): any => {
if(propKey === '' || !Array.isArray(raw)) return raw; if (propKey === '' || !Array.isArray(raw)) return raw;
const [type, value] = raw; const [type, value] = raw;
return (type in propTypes) ? propTypes[type](value) : undefined; return type in propTypes ? propTypes[type](value) : undefined;
}; };
if(!customElements.get('astro-island')) { if (!customElements.get('astro-island')) {
customElements.define('astro-island', class extends HTMLElement { customElements.define(
public Component: any; 'astro-island',
public hydrator: any; class extends HTMLElement {
static observedAttributes = ['props']; public Component: any;
async connectedCallback(){ public hydrator: any;
const [ { default: setup } ] = await Promise.all([ static observedAttributes = ['props'];
import(this.getAttribute('directive-url')!), async connectedCallback() {
import(this.getAttribute('before-hydration-url')!) const [{ default: setup }] = await Promise.all([
]); import(this.getAttribute('directive-url')!),
window.addEventListener('astro:hydrate', this.hydrate); import(this.getAttribute('before-hydration-url')!),
const opts = JSON.parse(this.getAttribute('opts')!);
setup(this, opts, async () => {
const rendererUrl = this.getAttribute('renderer-url');
const [
componentModule,
{ default: hydrator }
] = await Promise.all([
import(this.getAttribute('component-url')!),
rendererUrl ? import(rendererUrl) : () => () => {}
]); ]);
this.Component = componentModule[this.getAttribute('component-export') || 'default']; window.addEventListener('astro:hydrate', this.hydrate);
this.hydrator = hydrator;
return this.hydrate; const opts = JSON.parse(this.getAttribute('opts')!);
}); setup(this, opts, async () => {
} const rendererUrl = this.getAttribute('renderer-url');
hydrate = () => { const [componentModule, { default: hydrator }] = await Promise.all([
if(!this.hydrator || this.parentElement?.closest('astro-island[ssr]')) { import(this.getAttribute('component-url')!),
return; rendererUrl ? import(rendererUrl) : () => () => {},
]);
this.Component = componentModule[this.getAttribute('component-export') || 'default'];
this.hydrator = hydrator;
return this.hydrate;
});
} }
let innerHTML: string | null = null; hydrate = () => {
let fragment = this.querySelector('astro-fragment'); if (!this.hydrator || this.parentElement?.closest('astro-island[ssr]')) {
if (fragment == null && this.hasAttribute('tmpl')) { return;
// If there is no child fragment, check to see if there is a template.
// This happens if children were passed but the client component did not render any.
let template = this.querySelector('template[data-astro-template]');
if (template) {
innerHTML = template.innerHTML;
template.remove();
} }
} else if (fragment) { let innerHTML: string | null = null;
innerHTML = fragment.innerHTML; let fragment = this.querySelector('astro-fragment');
if (fragment == null && this.hasAttribute('tmpl')) {
// If there is no child fragment, check to see if there is a template.
// This happens if children were passed but the client component did not render any.
let template = this.querySelector('template[data-astro-template]');
if (template) {
innerHTML = template.innerHTML;
template.remove();
}
} else if (fragment) {
innerHTML = fragment.innerHTML;
}
const props = this.hasAttribute('props')
? JSON.parse(this.getAttribute('props')!, reviver)
: {};
this.hydrator(this)(this.Component, props, innerHTML, {
client: this.getAttribute('client'),
});
this.removeAttribute('ssr');
window.removeEventListener('astro:hydrate', this.hydrate);
window.dispatchEvent(new CustomEvent('astro:hydrate'));
};
attributeChangedCallback() {
if (this.hydrator) this.hydrate();
} }
const props = this.hasAttribute('props') ? JSON.parse(this.getAttribute('props')!, reviver) : {};
this.hydrator(this)(this.Component, props, innerHTML, {
client: this.getAttribute('client')
});
this.removeAttribute('ssr');
window.removeEventListener('astro:hydrate', this.hydrate);
window.dispatchEvent(new CustomEvent('astro:hydrate'));
} }
attributeChangedCallback() { );
if(this.hydrator) this.hydrate();
}
});
} }
} }

View file

@ -5,8 +5,8 @@ import type {
SSRResult, SSRResult,
} from '../../@types/astro'; } from '../../@types/astro';
import { escapeHTML } from './escape.js'; import { escapeHTML } from './escape.js';
import { hydrationSpecifier, serializeListValue } from './util.js';
import { serializeProps } from './serialize.js'; import { serializeProps } from './serialize.js';
import { hydrationSpecifier, serializeListValue } from './util.js';
const HydrationDirectives = ['load', 'idle', 'media', 'visible', 'only']; const HydrationDirectives = ['load', 'idle', 'media', 'visible', 'only'];
@ -95,11 +95,6 @@ interface HydrateScriptOptions {
props: Record<string | number, any>; props: Record<string | number, any>;
} }
/** For hydrated components, generate a <script type="module"> to load the component */ /** For hydrated components, generate a <script type="module"> to load the component */
export async function generateHydrateScript( export async function generateHydrateScript(
scriptOptions: HydrateScriptOptions, scriptOptions: HydrateScriptOptions,
@ -118,15 +113,15 @@ export async function generateHydrateScript(
children: '', children: '',
props: { props: {
// This is for HMR, probably can avoid it in prod // This is for HMR, probably can avoid it in prod
uid: astroId uid: astroId,
} },
}; };
// Add component url // Add component url
island.props['component-url'] = await result.resolve(componentUrl); island.props['component-url'] = await result.resolve(componentUrl);
// Add renderer url // Add renderer url
if(renderer.clientEntrypoint) { if (renderer.clientEntrypoint) {
island.props['component-export'] = componentExport.value; island.props['component-export'] = componentExport.value;
island.props['renderer-url'] = await result.resolve(renderer.clientEntrypoint); island.props['renderer-url'] = await result.resolve(renderer.clientEntrypoint);
island.props['props'] = escapeHTML(serializeProps(props)); island.props['props'] = escapeHTML(serializeProps(props));
@ -136,10 +131,12 @@ export async function generateHydrateScript(
island.props['client'] = hydrate; island.props['client'] = hydrate;
island.props['directive-url'] = await result.resolve(hydrationSpecifier(hydrate)); island.props['directive-url'] = await result.resolve(hydrationSpecifier(hydrate));
island.props['before-hydration-url'] = await result.resolve('astro:scripts/before-hydration.js'); island.props['before-hydration-url'] = await result.resolve('astro:scripts/before-hydration.js');
island.props['opts'] = escapeHTML(JSON.stringify({ island.props['opts'] = escapeHTML(
name: metadata.displayName, JSON.stringify({
value: metadata.hydrateArgs || '' name: metadata.displayName,
})) value: metadata.hydrateArgs || '',
})
);
return island; return island;
} }

View file

@ -8,12 +8,12 @@ import type {
SSRLoadedRenderer, SSRLoadedRenderer,
SSRResult, SSRResult,
} from '../../@types/astro'; } from '../../@types/astro';
import islandScript from './astro-island.prebuilt.js';
import { escapeHTML, HTMLString, markHTMLString } from './escape.js'; import { escapeHTML, HTMLString, markHTMLString } from './escape.js';
import { extractDirectives, generateHydrateScript } from './hydration.js'; import { extractDirectives, generateHydrateScript } from './hydration.js';
import { serializeProps } from './serialize.js';
import { shorthash } from './shorthash.js'; import { shorthash } from './shorthash.js';
import { serializeListValue } from './util.js'; import { serializeListValue } from './util.js';
import islandScript from './astro-island.prebuilt.js';
import { serializeProps } from './serialize.js';
export { markHTMLString, markHTMLString as unescapeHTML } from './escape.js'; export { markHTMLString, markHTMLString as unescapeHTML } from './escape.js';
export type { Metadata } from './metadata'; export type { Metadata } from './metadata';
@ -33,7 +33,7 @@ const svgEnumAttributes = /^(autoReverse|externalResourcesRequired|focusable|pre
const resultsWithHydrationScript = new WeakSet<SSRResult>(); const resultsWithHydrationScript = new WeakSet<SSRResult>();
function determineIfNeedsHydrationScript(result: SSRResult): boolean { function determineIfNeedsHydrationScript(result: SSRResult): boolean {
if(resultsWithHydrationScript.has(result)) { if (resultsWithHydrationScript.has(result)) {
return false; return false;
} }
resultsWithHydrationScript.add(result); resultsWithHydrationScript.add(result);
@ -342,19 +342,17 @@ If you're still stuck, please open an issue on GitHub or join us at https://astr
const needsAstroTemplate = children && !/<\/?astro-fragment\>/.test(html); const needsAstroTemplate = children && !/<\/?astro-fragment\>/.test(html);
const template = needsAstroTemplate ? `<template data-astro-template>${children}</template>` : ''; const template = needsAstroTemplate ? `<template data-astro-template>${children}</template>` : '';
if(needsAstroTemplate) { if (needsAstroTemplate) {
island.props.tmpl = ''; island.props.tmpl = '';
} }
island.children = `${ island.children = `${html ?? ''}${template}`;
html ?? ''
}${template}`;
// Add the astro-island definition only once. Since the SSRResult object // Add the astro-island definition only once. Since the SSRResult object
// is scoped to a page renderer we can use it as a key to know if the script // is scoped to a page renderer we can use it as a key to know if the script
// has been rendered or not. // has been rendered or not.
let script = ''; let script = '';
if(needsHydrationScript) { if (needsHydrationScript) {
// Note that this is a class script, not a module script. // Note that this is a class script, not a module script.
// This is so that it executes immediate, and when the browser encounters // This is so that it executes immediate, and when the browser encounters
// an astro-island element the callbacks will fire immediately, causing the JS // an astro-island element the callbacks will fire immediately, causing the JS
@ -362,10 +360,7 @@ If you're still stuck, please open an issue on GitHub or join us at https://astr
script = `<script>${islandScript}</script>`; script = `<script>${islandScript}</script>`;
} }
return markHTMLString( return markHTMLString(script + renderElement('astro-island', island, false));
script +
renderElement('astro-island', island, false)
);
} }
/** Create the Astro.fetchContent() runtime function. */ /** Create the Astro.fetchContent() runtime function. */

View file

@ -16,14 +16,16 @@ function serializeArray(value: any[]): any[] {
} }
function serializeObject(value: Record<any, any>): Record<any, any> { function serializeObject(value: Record<any, any>): Record<any, any> {
return Object.fromEntries(Object.entries(value).map(([k, v]) => { return Object.fromEntries(
return [k, convertToSerializedForm(v)]; Object.entries(value).map(([k, v]) => {
})); return [k, convertToSerializedForm(v)];
})
);
} }
function convertToSerializedForm(value: any): [ValueOf<typeof PROP_TYPE>, any] { function convertToSerializedForm(value: any): [ValueOf<typeof PROP_TYPE>, any] {
const tag = Object.prototype.toString.call(value); const tag = Object.prototype.toString.call(value);
switch(tag) { switch (tag) {
case '[object Date]': { case '[object Date]': {
return [PROP_TYPE.Date, (value as Date).toISOString()]; return [PROP_TYPE.Date, (value as Date).toISOString()];
} }
@ -46,7 +48,7 @@ function convertToSerializedForm(value: any): [ValueOf<typeof PROP_TYPE>, any] {
return [PROP_TYPE.JSON, JSON.stringify(serializeArray(value))]; return [PROP_TYPE.JSON, JSON.stringify(serializeArray(value))];
} }
default: { default: {
if(typeof value === 'object') { if (typeof value === 'object') {
return [PROP_TYPE.Value, serializeObject(value)]; return [PROP_TYPE.Value, serializeObject(value)];
} else { } else {
return [PROP_TYPE.Value, value]; return [PROP_TYPE.Value, value];

View file

@ -7,7 +7,7 @@ import { pathToFileURL, fileURLToPath } from 'url';
export default async function prebuild(...args) { export default async function prebuild(...args) {
let buildToString = args.indexOf('--to-string'); let buildToString = args.indexOf('--to-string');
if(buildToString !== -1) { if (buildToString !== -1) {
args.splice(buildToString, 1); args.splice(buildToString, 1);
buildToString = true; buildToString = true;
} }
@ -33,10 +33,10 @@ export default async function prebuild(...args) {
const tscode = await fs.promises.readFile(filepath, 'utf-8'); const tscode = await fs.promises.readFile(filepath, 'utf-8');
const esbuildresult = await esbuild.transform(tscode, { const esbuildresult = await esbuild.transform(tscode, {
loader: 'ts', loader: 'ts',
minify: true minify: true,
}); });
const rootURL = new URL('../../', import.meta.url); const rootURL = new URL('../../', import.meta.url);
const rel = path.relative(fileURLToPath(rootURL), filepath) const rel = path.relative(fileURLToPath(rootURL), filepath);
const mod = `/** const mod = `/**
* This file is prebuilt from ${rel} * This file is prebuilt from ${rel}
* Do not edit this directly, but instead edit that file and rerun the prebuild * Do not edit this directly, but instead edit that file and rerun the prebuild