[ci] yarn format
This commit is contained in:
parent
34e03cf912
commit
a5c6f922fa
26 changed files with 101 additions and 104 deletions
|
@ -13,4 +13,4 @@ description: Just a Hello World Post!
|
|||
|
||||
This is so cool!
|
||||
|
||||
Do variables work {frontmatter.value * 2}?
|
||||
Do variables work {frontmatter.value \* 2}?
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import { KNOWN_LANGUAGES } from './config';
|
||||
|
||||
export { KNOWN_LANGUAGES }
|
||||
export { KNOWN_LANGUAGES };
|
||||
export const KNOWN_LANGUAGE_CODES = Object.values(KNOWN_LANGUAGES);
|
||||
export const langPathRegex = /\/([a-z]{2}-?[A-Z]{0,2})\//;
|
||||
|
||||
|
|
|
@ -11,13 +11,16 @@ import astroRemark from '@astrojs/markdown-remark';
|
|||
export default /** @type {import('astro').AstroUserConfig} */ ({
|
||||
// Enable Custom Markdown options, plugins, etc.
|
||||
markdownOptions: {
|
||||
render: [astroRemark, {
|
||||
render: [
|
||||
astroRemark,
|
||||
{
|
||||
remarkPlugins: ['remark-code-titles', 'remark-slug'],
|
||||
rehypePlugins: [
|
||||
['rehype-autolink-headings', { behavior: 'prepend' }],
|
||||
['rehype-toc', { headings: ['h2', 'h3'] }],
|
||||
['rehype-add-classes', { 'h1,h2,h3': 'title' }],
|
||||
]
|
||||
}]
|
||||
],
|
||||
},
|
||||
],
|
||||
},
|
||||
});
|
||||
|
|
|
@ -66,7 +66,7 @@ export function codeFrame(src: string, loc: ErrorPayload['err']['loc']): string
|
|||
|
||||
export function resolveDependency(dep: string, astroConfig: AstroConfig) {
|
||||
const resolved = resolve.sync(dep, {
|
||||
basedir: fileURLToPath(astroConfig.projectRoot)
|
||||
basedir: fileURLToPath(astroConfig.projectRoot),
|
||||
});
|
||||
// For Windows compat, we need a fully resolved `file://` URL string
|
||||
return pathToFileURL(resolved).toString();
|
||||
|
|
|
@ -365,13 +365,17 @@ export async function renderToString(result: SSRResult, componentFactory: AstroC
|
|||
const uniqueElements = (item: any, index: number, all: any[]) => {
|
||||
const props = JSON.stringify(item.props);
|
||||
const children = item.children;
|
||||
return index === all.findIndex(i => JSON.stringify(i.props) === props && i.children == children)
|
||||
}
|
||||
return index === all.findIndex((i) => JSON.stringify(i.props) === props && i.children == children);
|
||||
};
|
||||
|
||||
export async function renderPage(result: SSRResult, Component: AstroComponentFactory, props: any, children: any) {
|
||||
const template = await renderToString(result, Component, props, children);
|
||||
const styles = Array.from(result.styles).filter(uniqueElements).map((style) => renderElement('style', style));
|
||||
const scripts = Array.from(result.scripts).filter(uniqueElements).map((script) => renderElement('script', script));
|
||||
const styles = Array.from(result.styles)
|
||||
.filter(uniqueElements)
|
||||
.map((style) => renderElement('style', style));
|
||||
const scripts = Array.from(result.scripts)
|
||||
.filter(uniqueElements)
|
||||
.map((script) => renderElement('script', script));
|
||||
return template.replace('</head>', styles.join('\n') + scripts.join('\n') + '</head>');
|
||||
}
|
||||
|
||||
|
|
|
@ -13,8 +13,8 @@ describe('Dynamic components', () => {
|
|||
it('Loads packages that only run code in client', async () => {
|
||||
const html = await fixture.readFile('/index.html');
|
||||
|
||||
const $ = cheerio.load(html)
|
||||
expect($('script').length).to.eq(2)
|
||||
const $ = cheerio.load(html);
|
||||
expect($('script').length).to.eq(2);
|
||||
});
|
||||
|
||||
it('Loads pages using client:media hydrator', async () => {
|
||||
|
|
|
@ -3,7 +3,6 @@ import cheerio from 'cheerio';
|
|||
import { loadFixture } from './test-utils.js';
|
||||
import markdownRemark from '@astrojs/markdown-remark';
|
||||
|
||||
|
||||
describe('Astro Markdown plugins', () => {
|
||||
let fixture;
|
||||
|
||||
|
@ -12,13 +11,16 @@ describe('Astro Markdown plugins', () => {
|
|||
projectRoot: './fixtures/astro-markdown-plugins/',
|
||||
renderers: ['@astrojs/renderer-preact'],
|
||||
markdownOptions: {
|
||||
render: [markdownRemark, {
|
||||
render: [
|
||||
markdownRemark,
|
||||
{
|
||||
remarkPlugins: ['remark-code-titles', 'remark-slug', ['rehype-autolink-headings', { behavior: 'prepend' }]],
|
||||
rehypePlugins: [
|
||||
['rehype-toc', { headings: ['h2', 'h3'] }],
|
||||
['rehype-add-classes', { 'h1,h2,h3': 'title' }],
|
||||
],
|
||||
}],
|
||||
},
|
||||
],
|
||||
},
|
||||
buildOptions: {
|
||||
sitemap: false,
|
||||
|
|
|
@ -59,7 +59,7 @@ describe('Astro Markdown', () => {
|
|||
|
||||
// test 1: <pre> tag has scopedStyle class passed down
|
||||
expect($('pre').is('[class]')).to.equal(true);
|
||||
expect($('pre').attr('class').split(' ').length).to.equal(2)
|
||||
expect($('pre').attr('class').split(' ').length).to.equal(2);
|
||||
|
||||
// test 2: <pre> tag has correct language
|
||||
expect($('pre').hasClass('language-js')).to.equal(true);
|
||||
|
@ -117,7 +117,7 @@ describe('Astro Markdown', () => {
|
|||
expect($('code:nth-child(2)').text()).to.equal('{...props}');
|
||||
|
||||
// test 4: Rendered curly braces markdown content
|
||||
expect($('code:last-child').text()).to.equal('{/* JavaScript *\/}');
|
||||
expect($('code:last-child').text()).to.equal('{/* JavaScript */}');
|
||||
});
|
||||
|
||||
it('Does not close parent early when using content attribute (#494)', async () => {
|
||||
|
|
|
@ -32,17 +32,17 @@ export const DEFAULT_REMARK_PLUGINS = [
|
|||
'remark-footnotes',
|
||||
// TODO: reenable smartypants!
|
||||
// '@silvenon/remark-smartypants'
|
||||
]
|
||||
];
|
||||
|
||||
export const DEFAULT_REHYPE_PLUGINS = [
|
||||
// empty
|
||||
]
|
||||
];
|
||||
|
||||
/** Shared utility for rendering markdown */
|
||||
export async function renderMarkdown(content: string, opts?: MarkdownRenderingOptions | null) {
|
||||
const { remarkPlugins = DEFAULT_REMARK_PLUGINS, rehypePlugins = DEFAULT_REHYPE_PLUGINS } = opts ?? {};
|
||||
const scopedClassName = opts?.$?.scopedClassName;
|
||||
const mode = opts?.mode ?? "mdx";
|
||||
const mode = opts?.mode ?? 'mdx';
|
||||
const isMDX = mode === 'mdx';
|
||||
const { headers, rehypeCollectHeaders } = createCollectHeaders();
|
||||
|
||||
|
@ -52,7 +52,7 @@ export async function renderMarkdown(content: string, opts?: MarkdownRenderingOp
|
|||
.use(markdown)
|
||||
.use(isMDX ? [remarkJsx] : [])
|
||||
.use(isMDX ? [remarkExpressions] : [])
|
||||
.use([remarkUnwrap])
|
||||
.use([remarkUnwrap]);
|
||||
|
||||
const loadedRemarkPlugins = await Promise.all(loadPlugins(remarkPlugins));
|
||||
const loadedRehypePlugins = await Promise.all(loadPlugins(rehypePlugins));
|
||||
|
@ -66,7 +66,7 @@ export async function renderMarkdown(content: string, opts?: MarkdownRenderingOp
|
|||
}
|
||||
|
||||
parser.use([remarkPrism(scopedClassName)]);
|
||||
parser.use([[markdownToHtml as any, { allowDangerousHtml: true, passThrough: ['raw', 'mdxTextExpression', 'mdxJsxTextElement', 'mdxJsxFlowElement']}]]);
|
||||
parser.use([[markdownToHtml as any, { allowDangerousHtml: true, passThrough: ['raw', 'mdxTextExpression', 'mdxJsxTextElement', 'mdxJsxFlowElement'] }]]);
|
||||
|
||||
loadedRehypePlugins.forEach(([plugin, opts]) => {
|
||||
parser.use([[plugin, opts]]);
|
||||
|
@ -76,14 +76,11 @@ export async function renderMarkdown(content: string, opts?: MarkdownRenderingOp
|
|||
.use(isMDX ? [rehypeJsx] : [])
|
||||
.use(isMDX ? [rehypeExpressions] : [])
|
||||
.use(isMDX ? [] : [rehypeRaw])
|
||||
.use(rehypeIslands)
|
||||
.use(rehypeIslands);
|
||||
|
||||
let result: string;
|
||||
try {
|
||||
const vfile = await parser
|
||||
.use([rehypeCollectHeaders])
|
||||
.use(rehypeStringify, { allowDangerousHtml: true })
|
||||
.process(content);
|
||||
const vfile = await parser.use([rehypeCollectHeaders]).use(rehypeStringify, { allowDangerousHtml: true }).process(content);
|
||||
result = vfile.toString();
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import {SKIP, visit} from 'unist-util-visit';
|
||||
import { SKIP, visit } from 'unist-util-visit';
|
||||
|
||||
// This fixes some confusing bugs coming from somewhere inside of our Markdown pipeline.
|
||||
// `unist`/`remark`/`rehype` (not sure) often generate malformed HTML inside of <astro-root>
|
||||
|
@ -14,8 +14,8 @@ export default function rehypeIslands(): any {
|
|||
// Sometimes comments can be trapped as text, which causes them to be escaped
|
||||
// This casts them back to real HTML comments
|
||||
if (parent && child.value.indexOf('<!--') > -1 && index != null) {
|
||||
parent.children.splice(index, 1, { ...child, type: 'comment', value: child.value.replace('<!--', '').replace('-->', '').trim()});
|
||||
return [SKIP, index]
|
||||
parent.children.splice(index, 1, { ...child, type: 'comment', value: child.value.replace('<!--', '').replace('-->', '').trim() });
|
||||
return [SKIP, index];
|
||||
}
|
||||
// For some reason `rehype` likes to inject extra linebreaks,
|
||||
// but React and Vue throw hydration errors when they see these!
|
||||
|
@ -24,7 +24,7 @@ export default function rehypeIslands(): any {
|
|||
child.value = child.value.replace(/\n+/g, '');
|
||||
return child;
|
||||
}
|
||||
})
|
||||
});
|
||||
}
|
||||
});
|
||||
};
|
||||
|
|
|
@ -5,7 +5,7 @@ export default function rehypeJsx(): any {
|
|||
return function (node: any): any {
|
||||
return map(node, (child: any) => {
|
||||
if (child.type === 'element') {
|
||||
return { ...child, tagName: `${child.tagName}` }
|
||||
return { ...child, tagName: `${child.tagName}` };
|
||||
}
|
||||
if (MDX_ELEMENTS.has(child.type)) {
|
||||
return {
|
||||
|
@ -15,12 +15,12 @@ export default function rehypeJsx(): any {
|
|||
properties: child.attributes.reduce((acc: any[], entry: any) => {
|
||||
let attr = entry.value;
|
||||
if (attr && typeof attr === 'object') {
|
||||
attr = `{${attr.value}}`
|
||||
attr = `{${attr.value}}`;
|
||||
} else if (attr === null) {
|
||||
attr = `{true}`
|
||||
attr = `{true}`;
|
||||
}
|
||||
return Object.assign(acc, { [entry.name]: attr });
|
||||
}, {})
|
||||
}, {}),
|
||||
};
|
||||
}
|
||||
return child;
|
||||
|
|
|
@ -4,26 +4,24 @@ import { addAstro } from '@astrojs/prism';
|
|||
import loadLanguages from 'prismjs/components/index.js';
|
||||
const noVisit = new Set(['root', 'html', 'text']);
|
||||
|
||||
const languageMap = new Map([
|
||||
['ts', 'typescript']
|
||||
]);
|
||||
const languageMap = new Map([['ts', 'typescript']]);
|
||||
|
||||
function runHighlighter(lang: string, code: string) {
|
||||
let classLanguage = `language-${lang}`
|
||||
let classLanguage = `language-${lang}`;
|
||||
|
||||
if (lang == null) {
|
||||
lang = 'plaintext';
|
||||
}
|
||||
|
||||
const ensureLoaded = (lang: string) => {
|
||||
if(lang && !Prism.languages[lang]) {
|
||||
if (lang && !Prism.languages[lang]) {
|
||||
loadLanguages([lang]);
|
||||
}
|
||||
};
|
||||
|
||||
if(languageMap.has(lang)) {
|
||||
if (languageMap.has(lang)) {
|
||||
ensureLoaded(languageMap.get(lang)!);
|
||||
} else if(lang === 'astro') {
|
||||
} else if (lang === 'astro') {
|
||||
ensureLoaded('typescript');
|
||||
addAstro(Prism);
|
||||
} else {
|
||||
|
@ -31,7 +29,7 @@ function runHighlighter(lang: string, code: string) {
|
|||
ensureLoaded(lang);
|
||||
}
|
||||
|
||||
if(lang && !Prism.languages[lang]) {
|
||||
if (lang && !Prism.languages[lang]) {
|
||||
console.warn(`Unable to load the language: ${lang}`);
|
||||
}
|
||||
|
||||
|
@ -48,24 +46,23 @@ type MaybeString = string | null | undefined;
|
|||
|
||||
/** */
|
||||
function transformer(className: MaybeString) {
|
||||
return function(tree: any) {
|
||||
return function (tree: any) {
|
||||
const visitor = (node: any) => {
|
||||
let {lang, value} = node;
|
||||
let { lang, value } = node;
|
||||
node.type = 'html';
|
||||
|
||||
let { html, classLanguage } = runHighlighter(lang, value);
|
||||
let classes = [classLanguage];
|
||||
if(className) {
|
||||
if (className) {
|
||||
classes.push(className);
|
||||
}
|
||||
node.value = `<pre class="${classes.join(' ')}"><code data-astro-raw class="${classLanguage}">${html}</code></pre>`;
|
||||
return node;
|
||||
};
|
||||
return visit(tree, 'code', visitor)
|
||||
}
|
||||
return visit(tree, 'code', visitor);
|
||||
};
|
||||
}
|
||||
|
||||
|
||||
function plugin(className: MaybeString) {
|
||||
return transformer.bind(null, className);
|
||||
}
|
||||
|
|
|
@ -3,11 +3,11 @@
|
|||
* @typedef {import('hast').Properties} Properties
|
||||
*/
|
||||
|
||||
import {toString} from 'mdast-util-to-string'
|
||||
import {visit} from 'unist-util-visit'
|
||||
import BananaSlug from 'github-slugger'
|
||||
import { toString } from 'mdast-util-to-string';
|
||||
import { visit } from 'unist-util-visit';
|
||||
import BananaSlug from 'github-slugger';
|
||||
|
||||
const slugs = new BananaSlug()
|
||||
const slugs = new BananaSlug();
|
||||
|
||||
/**
|
||||
* Plugin to add anchors headings using GitHub’s algorithm.
|
||||
|
@ -16,19 +16,17 @@ const slugs = new BananaSlug()
|
|||
*/
|
||||
export default function remarkSlug() {
|
||||
return (tree: any) => {
|
||||
slugs.reset()
|
||||
slugs.reset();
|
||||
visit(tree, (node) => {
|
||||
console.log(node);
|
||||
});
|
||||
visit(tree, 'heading', (node) => {
|
||||
const data = node.data || (node.data = {})
|
||||
const props = /** @type {Properties} */ (
|
||||
data.hProperties || (data.hProperties = {})
|
||||
)
|
||||
let id = props.id
|
||||
id = id ? slugs.slug(String(id), true) : slugs.slug(toString(node))
|
||||
const data = node.data || (node.data = {});
|
||||
const props = /** @type {Properties} */ data.hProperties || (data.hProperties = {});
|
||||
let id = props.id;
|
||||
id = id ? slugs.slug(String(id), true) : slugs.slug(toString(node));
|
||||
data.id = id;
|
||||
props.id = id;
|
||||
})
|
||||
}
|
||||
});
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import {visit, SKIP} from 'unist-util-visit'
|
||||
import { visit, SKIP } from 'unist-util-visit';
|
||||
|
||||
// Remove the wrapping paragraph for <astro-root> islands
|
||||
export default function remarkUnwrap() {
|
||||
|
@ -18,21 +18,17 @@ export default function remarkUnwrap() {
|
|||
insideAstroRoot = false;
|
||||
}
|
||||
astroRootNodes.add(node);
|
||||
})
|
||||
});
|
||||
|
||||
visit(tree, 'paragraph', (node, index, parent) => {
|
||||
if (
|
||||
parent &&
|
||||
typeof index === 'number' &&
|
||||
containsAstroRootNode(node)
|
||||
) {
|
||||
parent.children.splice(index, 1, ...node.children)
|
||||
return [SKIP, index]
|
||||
}
|
||||
})
|
||||
if (parent && typeof index === 'number' && containsAstroRootNode(node)) {
|
||||
parent.children.splice(index, 1, ...node.children);
|
||||
return [SKIP, index];
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
function containsAstroRootNode(node: any) {
|
||||
return node.children.map((child: any) => astroRootNodes.has(child)).reduce((all: boolean, v: boolean) => all ? all : v, false)
|
||||
return node.children.map((child: any) => astroRootNodes.has(child)).reduce((all: boolean, v: boolean) => (all ? all : v), false);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -4,7 +4,7 @@ export type UnifiedPluginImport = Promise<{ default: unified.Plugin }>;
|
|||
export type Plugin = string | [string, any] | UnifiedPluginImport | [UnifiedPluginImport, any];
|
||||
|
||||
export interface AstroMarkdownOptions {
|
||||
mode?: 'md'|'mdx';
|
||||
mode?: 'md' | 'mdx';
|
||||
remarkPlugins?: Plugin[];
|
||||
rehypePlugins?: Plugin[];
|
||||
}
|
||||
|
|
|
@ -20,7 +20,7 @@ export default {
|
|||
'@webcomponents/template-shadowroot/template-shadowroot.js',
|
||||
'lit/experimental-hydrate-support.js',
|
||||
],
|
||||
exclude: ['@astrojs/renderer-lit/server.js']
|
||||
exclude: ['@astrojs/renderer-lit/server.js'],
|
||||
},
|
||||
ssr: {
|
||||
external: [
|
||||
|
|
|
@ -15,7 +15,7 @@ export default {
|
|||
return {
|
||||
alias: {
|
||||
react: 'preact/compat',
|
||||
'react-dom': 'preact/compat'
|
||||
'react-dom': 'preact/compat',
|
||||
},
|
||||
resolve: {
|
||||
dedupe: ['react', 'react-dom'],
|
||||
|
|
Loading…
Reference in a new issue