Yufan Sheng
901cd8219c
* style: better reply button. * feat: add astro badge. * chore: drop useless styles. * feat: use new options.ts for global configuration. * fix: the invalid import.meta.env.PROD in astro build. * feat: move og to new assert prefix. * chore: add better og description. * chore: make sure all the images link could be correctly replaced. * feat: add upyun uploader.
54 lines
1.7 KiB
TypeScript
54 lines
1.7 KiB
TypeScript
import type { Literal, Node, Parent } from 'unist';
|
|
import { visit } from 'unist-util-visit';
|
|
import { imageMetadata } from '../src/helpers/images';
|
|
|
|
export type ImageNode = Parent & {
|
|
url: string;
|
|
alt: string;
|
|
name: string;
|
|
width?: number;
|
|
height?: number;
|
|
attributes: (Literal & { name: string })[];
|
|
};
|
|
|
|
export const astroImage = () => {
|
|
return async (tree: Node) => {
|
|
const images: ImageNode[] = [];
|
|
|
|
// Find all the local image node.
|
|
visit(tree, 'image', (node: Node, _, __: Parent) => {
|
|
const imageNode = node as ImageNode;
|
|
// Skip remote images.
|
|
if (imageNode.url.startsWith('http')) {
|
|
return;
|
|
}
|
|
|
|
images.push(imageNode);
|
|
});
|
|
|
|
// Process images.
|
|
await Promise.all(images.map(transformAstroImage));
|
|
return tree;
|
|
};
|
|
};
|
|
|
|
const transformAstroImage = async (imageNode: ImageNode) => {
|
|
const metadata = await imageMetadata(imageNode.url);
|
|
if (metadata == null) {
|
|
throw new Error(`Failed to get image metadata: ${imageNode.url}`);
|
|
}
|
|
|
|
// Convert original node to next/image
|
|
imageNode.type = 'mdxJsxFlowElement';
|
|
imageNode.name = 'Image';
|
|
imageNode.attributes = [
|
|
{ type: 'mdxJsxAttribute', name: 'alt', value: imageNode.alt },
|
|
{ type: 'mdxJsxAttribute', name: 'src', value: metadata.src },
|
|
{ type: 'mdxJsxAttribute', name: 'width', value: imageNode.width ?? metadata.width },
|
|
{ type: 'mdxJsxAttribute', name: 'height', value: imageNode.height ?? metadata.height },
|
|
{ type: 'mdxJsxAttribute', name: 'blurDataURL', value: metadata.blurDataURL },
|
|
{ type: 'mdxJsxAttribute', name: 'blurWidth', value: metadata.blurWidth },
|
|
{ type: 'mdxJsxAttribute', name: 'blurHeight', value: metadata.blurHeight },
|
|
];
|
|
};
|