[ci] format
This commit is contained in:
parent
7250e4e86d
commit
4819e7b071
9 changed files with 44 additions and 41 deletions
6
packages/astro/env.d.ts
vendored
6
packages/astro/env.d.ts
vendored
|
@ -27,7 +27,7 @@ declare module '*.md' {
|
||||||
export default load;
|
export default load;
|
||||||
}
|
}
|
||||||
|
|
||||||
declare module "*.html" {
|
declare module '*.html' {
|
||||||
const Component: { render(opts: { slots: Record<string, string> }): string };
|
const Component: { render(opts: { slots: Record<string, string> }): string };
|
||||||
export default Component;
|
export default Component;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,9 +9,9 @@ import astroViteServerPlugin from '../vite-plugin-astro-server/index.js';
|
||||||
import astroVitePlugin from '../vite-plugin-astro/index.js';
|
import astroVitePlugin from '../vite-plugin-astro/index.js';
|
||||||
import configAliasVitePlugin from '../vite-plugin-config-alias/index.js';
|
import configAliasVitePlugin from '../vite-plugin-config-alias/index.js';
|
||||||
import envVitePlugin from '../vite-plugin-env/index.js';
|
import envVitePlugin from '../vite-plugin-env/index.js';
|
||||||
|
import htmlVitePlugin from '../vite-plugin-html/index.js';
|
||||||
import astroIntegrationsContainerPlugin from '../vite-plugin-integrations-container/index.js';
|
import astroIntegrationsContainerPlugin from '../vite-plugin-integrations-container/index.js';
|
||||||
import jsxVitePlugin from '../vite-plugin-jsx/index.js';
|
import jsxVitePlugin from '../vite-plugin-jsx/index.js';
|
||||||
import htmlVitePlugin from '../vite-plugin-html/index.js';
|
|
||||||
import markdownVitePlugin from '../vite-plugin-markdown/index.js';
|
import markdownVitePlugin from '../vite-plugin-markdown/index.js';
|
||||||
import astroScriptsPlugin from '../vite-plugin-scripts/index.js';
|
import astroScriptsPlugin from '../vite-plugin-scripts/index.js';
|
||||||
import { createCustomViteLogger } from './errors.js';
|
import { createCustomViteLogger } from './errors.js';
|
||||||
|
|
|
@ -9,6 +9,6 @@ export default function html() {
|
||||||
async transform(source: string, id: string) {
|
async transform(source: string, id: string) {
|
||||||
if (!id.endsWith('.html')) return;
|
if (!id.endsWith('.html')) return;
|
||||||
return await transform(source, id);
|
return await transform(source, id);
|
||||||
}
|
},
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import type { Plugin } from 'unified';
|
|
||||||
import type { Root, RootContent } from 'hast';
|
import type { Root, RootContent } from 'hast';
|
||||||
import type MagicString from 'magic-string';
|
import type MagicString from 'magic-string';
|
||||||
|
import type { Plugin } from 'unified';
|
||||||
import { visit } from 'unist-util-visit';
|
import { visit } from 'unist-util-visit';
|
||||||
|
|
||||||
import { replaceAttribute, needsEscape, escape } from './utils.js';
|
import { escape, needsEscape, replaceAttribute } from './utils.js';
|
||||||
|
|
||||||
const rehypeEscape: Plugin<[{ s: MagicString }], Root> = ({ s }) => {
|
const rehypeEscape: Plugin<[{ s: MagicString }], Root> = ({ s }) => {
|
||||||
return (tree, file) => {
|
return (tree, file) => {
|
||||||
|
@ -17,7 +17,7 @@ const rehypeEscape: Plugin<[{ s: MagicString }], Root> = ({ s }) => {
|
||||||
const newKey = needsEscape(key) ? escape(key) : key;
|
const newKey = needsEscape(key) ? escape(key) : key;
|
||||||
const newValue = needsEscape(value) ? escape(value) : value;
|
const newValue = needsEscape(value) ? escape(value) : value;
|
||||||
if (newKey === key && newValue === value) continue;
|
if (newKey === key && newValue === value) continue;
|
||||||
replaceAttribute(s, node, key, (value === '') ? newKey : `${newKey}="${newValue}"`);
|
replaceAttribute(s, node, key, value === '' ? newKey : `${newKey}="${newValue}"`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
|
@ -7,26 +7,25 @@ import slots, { SLOT_PREFIX } from './slots.js';
|
||||||
export async function transform(code: string, id: string) {
|
export async function transform(code: string, id: string) {
|
||||||
const s = new MagicString(code, { filename: id });
|
const s = new MagicString(code, { filename: id });
|
||||||
const imports = new Map();
|
const imports = new Map();
|
||||||
const parser = rehype()
|
const parser = rehype().data('settings', { fragment: true }).use(escape, { s }).use(slots, { s });
|
||||||
.data('settings', { fragment: true })
|
|
||||||
.use(escape, { s })
|
|
||||||
.use(slots, { s });
|
|
||||||
|
|
||||||
const vfile = new VFile({ value: code, path: id })
|
const vfile = new VFile({ value: code, path: id });
|
||||||
await parser.process(vfile)
|
await parser.process(vfile);
|
||||||
s.prepend(`export default {\n\t"astro:html": true,\n\trender({ slots: ${SLOT_PREFIX} }) {\n\t\treturn \``);
|
s.prepend(
|
||||||
|
`export default {\n\t"astro:html": true,\n\trender({ slots: ${SLOT_PREFIX} }) {\n\t\treturn \``
|
||||||
|
);
|
||||||
s.append('`\n\t}\n}');
|
s.append('`\n\t}\n}');
|
||||||
|
|
||||||
if (imports.size > 0) {
|
if (imports.size > 0) {
|
||||||
let importText = ''
|
let importText = '';
|
||||||
for (const [path, importName] of imports.entries()) {
|
for (const [path, importName] of imports.entries()) {
|
||||||
importText += `import ${importName} from "${path}";\n`
|
importText += `import ${importName} from "${path}";\n`;
|
||||||
}
|
}
|
||||||
s.prepend(importText);
|
s.prepend(importText);
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
code: s.toString(),
|
code: s.toString(),
|
||||||
map: s.generateMap()
|
map: s.generateMap(),
|
||||||
}
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,26 +1,28 @@
|
||||||
import type { Plugin } from 'unified';
|
|
||||||
import type { Root, RootContent } from 'hast';
|
import type { Root, RootContent } from 'hast';
|
||||||
|
import type { Plugin } from 'unified';
|
||||||
|
|
||||||
import { visit } from 'unist-util-visit';
|
|
||||||
import MagicString from 'magic-string';
|
import MagicString from 'magic-string';
|
||||||
|
import { visit } from 'unist-util-visit';
|
||||||
import { escape } from './utils.js';
|
import { escape } from './utils.js';
|
||||||
|
|
||||||
const rehypeSlots: Plugin<[{ s: MagicString }], Root> = ({ s }) => {
|
const rehypeSlots: Plugin<[{ s: MagicString }], Root> = ({ s }) => {
|
||||||
return (tree, file) => {
|
return (tree, file) => {
|
||||||
visit(tree, (node: Root | RootContent, index, parent) => {
|
visit(tree, (node: Root | RootContent, index, parent) => {
|
||||||
if (node.type === 'element' && node.tagName === 'slot') {
|
if (node.type === 'element' && node.tagName === 'slot') {
|
||||||
if (typeof node.properties?.['is:inline'] !== 'undefined') return;
|
if (typeof node.properties?.['is:inline'] !== 'undefined') return;
|
||||||
const name = node.properties?.['name'] ?? 'default';
|
const name = node.properties?.['name'] ?? 'default';
|
||||||
const start = node.position?.start.offset ?? 0;
|
const start = node.position?.start.offset ?? 0;
|
||||||
const end = node.position?.end.offset ?? 0;
|
const end = node.position?.end.offset ?? 0;
|
||||||
const first = node.children.at(0) ?? node;
|
const first = node.children.at(0) ?? node;
|
||||||
const last = node.children.at(-1) ?? node;
|
const last = node.children.at(-1) ?? node;
|
||||||
const text = file.value.slice(first.position?.start.offset ?? 0, last.position?.end.offset ?? 0).toString();
|
const text = file.value
|
||||||
s.overwrite(start, end, `\${${SLOT_PREFIX}["${name}"] ?? \`${escape(text).trim()}\`}`)
|
.slice(first.position?.start.offset ?? 0, last.position?.end.offset ?? 0)
|
||||||
}
|
.toString();
|
||||||
});
|
s.overwrite(start, end, `\${${SLOT_PREFIX}["${name}"] ?? \`${escape(text).trim()}\`}`);
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
export default rehypeSlots;
|
export default rehypeSlots;
|
||||||
|
|
||||||
|
|
|
@ -5,18 +5,20 @@ const splitAttrsTokenizer = /([\$\{\}\@a-z0-9_\:\-]*)\s*?=\s*?(['"]?)(.*?)\2\s+/
|
||||||
|
|
||||||
export function replaceAttribute(s: MagicString, node: Element, key: string, newValue: string) {
|
export function replaceAttribute(s: MagicString, node: Element, key: string, newValue: string) {
|
||||||
splitAttrsTokenizer.lastIndex = 0;
|
splitAttrsTokenizer.lastIndex = 0;
|
||||||
const text = s.original.slice(node.position?.start.offset ?? 0, node.position?.end.offset ?? 0).toString();
|
const text = s.original
|
||||||
|
.slice(node.position?.start.offset ?? 0, node.position?.end.offset ?? 0)
|
||||||
|
.toString();
|
||||||
const offset = text.indexOf(key);
|
const offset = text.indexOf(key);
|
||||||
if (offset === -1) return;
|
if (offset === -1) return;
|
||||||
const start = node.position!.start.offset! + offset;
|
const start = node.position!.start.offset! + offset;
|
||||||
const tokens = text.slice(offset).split(splitAttrsTokenizer);
|
const tokens = text.slice(offset).split(splitAttrsTokenizer);
|
||||||
const token = tokens[0].replace(/([^>])(\>[\s\S]*$)/gmi, '$1');
|
const token = tokens[0].replace(/([^>])(\>[\s\S]*$)/gim, '$1');
|
||||||
if (token.trim() === key) {
|
if (token.trim() === key) {
|
||||||
const end = start + key.length;
|
const end = start + key.length;
|
||||||
s.overwrite(start, end, newValue)
|
s.overwrite(start, end, newValue);
|
||||||
} else {
|
} else {
|
||||||
const end = start + `${key}=${tokens[2]}${tokens[3]}${tokens[2]}`.length;
|
const end = start + `${key}=${tokens[2]}${tokens[3]}${tokens[2]}`.length;
|
||||||
s.overwrite(start, end, newValue)
|
s.overwrite(start, end, newValue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
export function needsEscape(value: any): value is string {
|
export function needsEscape(value: any): value is string {
|
||||||
|
|
|
@ -24,10 +24,10 @@ describe('HTML Escape', () => {
|
||||||
expect(div.text()).to.equal('${foo}');
|
expect(div.text()).to.equal('${foo}');
|
||||||
|
|
||||||
const span = $('span');
|
const span = $('span');
|
||||||
expect(span.attr('${attr}')).to.equal("");
|
expect(span.attr('${attr}')).to.equal('');
|
||||||
|
|
||||||
const ce = $('custom-element');
|
const ce = $('custom-element');
|
||||||
expect(ce.attr('x-data')).to.equal("`${test}`");
|
expect(ce.attr('x-data')).to.equal('`${test}`');
|
||||||
|
|
||||||
const script = $('script');
|
const script = $('script');
|
||||||
expect(script.text()).to.equal('console.log(`hello ${"world"}!`)');
|
expect(script.text()).to.equal('console.log(`hello ${"world"}!`)');
|
||||||
|
@ -57,10 +57,10 @@ describe('HTML Escape', () => {
|
||||||
expect(div.text()).to.equal('${foo}');
|
expect(div.text()).to.equal('${foo}');
|
||||||
|
|
||||||
const span = $('span');
|
const span = $('span');
|
||||||
expect(span.attr('${attr}')).to.equal("");
|
expect(span.attr('${attr}')).to.equal('');
|
||||||
|
|
||||||
const ce = $('custom-element');
|
const ce = $('custom-element');
|
||||||
expect(ce.attr('x-data')).to.equal("`${test}`");
|
expect(ce.attr('x-data')).to.equal('`${test}`');
|
||||||
|
|
||||||
const script = $('script');
|
const script = $('script');
|
||||||
expect(script.text()).to.equal('console.log(`hello ${"world"}!`)');
|
expect(script.text()).to.equal('console.log(`hello ${"world"}!`)');
|
||||||
|
|
|
@ -18,7 +18,7 @@ describe('HTML Page', () => {
|
||||||
|
|
||||||
it('works', async () => {
|
it('works', async () => {
|
||||||
const html = await fixture.readFile('/index.html');
|
const html = await fixture.readFile('/index.html');
|
||||||
const $ = cheerio.load(html)
|
const $ = cheerio.load(html);
|
||||||
|
|
||||||
const h1 = $('h1');
|
const h1 = $('h1');
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ describe('HTML Page', () => {
|
||||||
expect(res.status).to.equal(200);
|
expect(res.status).to.equal(200);
|
||||||
|
|
||||||
const html = await res.text();
|
const html = await res.text();
|
||||||
const $ = cheerio.load(html)
|
const $ = cheerio.load(html);
|
||||||
|
|
||||||
const h1 = $('h1');
|
const h1 = $('h1');
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue