nuxt-og-image 1.4.9 → 1.4.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -34,6 +34,7 @@ Enlightened OG Image generation for Nuxt 3.
34
34
  ## Demos
35
35
 
36
36
  - [Vercel Edge Demo](https://nuxt-og-image-playground.vercel.app/)
37
+ - [StackBlitz - Minimal Example](https://stackblitz.com/edit/nuxt-starter-pxs3wk?file=pages/index.vue)
37
38
  - [StackBlitz - Alpine Theme](https://stackblitz.com/edit/github-hgunsf?file=package.json) (visit `/__og_image__`)
38
39
 
39
40
  ## Features
package/dist/module.json CHANGED
@@ -5,5 +5,5 @@
5
5
  "bridge": false
6
6
  },
7
7
  "configKey": "ogImage",
8
- "version": "1.4.9"
8
+ "version": "1.4.10"
9
9
  }
@@ -10,6 +10,12 @@ import { fonts, satoriOptions } from "#nuxt-og-image/config";
10
10
  import loadSvg2png from "#nuxt-og-image/svg2png";
11
11
  import loadSatori from "#nuxt-og-image/satori";
12
12
  const satoriFonts = [];
13
+ let fontLoadPromise = null;
14
+ function loadFonts(fonts2) {
15
+ if (fontLoadPromise)
16
+ return fontLoadPromise;
17
+ return fontLoadPromise = Promise.all(fonts2.map((font) => loadFont(font)));
18
+ }
13
19
  export default {
14
20
  name: "satori",
15
21
  createPng: async function createPng(baseUrl, options) {
@@ -39,10 +45,8 @@ export default {
39
45
  },
40
46
  createSvg: async function createSvg(baseUrl, options) {
41
47
  const vnodes = await this.createVNode(baseUrl, options);
42
- if (!satoriFonts.length) {
43
- for (const font of fonts)
44
- satoriFonts.push(await loadFont(new URL(baseUrl), font));
45
- }
48
+ if (!satoriFonts.length)
49
+ satoriFonts.push(...await loadFonts(fonts));
46
50
  const satori = await loadSatori();
47
51
  return await satori(vnodes, {
48
52
  ...satoriOptions,
@@ -1,5 +1,5 @@
1
1
  import type { ParsedURL } from 'ufo';
2
2
  import type { SatoriTransformer, VNode } from '../../../../types';
3
- export declare function loadFont(url: URL, font: string): Promise<any>;
3
+ export declare function loadFont(font: string): Promise<any>;
4
4
  export declare function walkSatoriTree(url: ParsedURL, node: VNode, plugins: SatoriTransformer[]): Promise<void>;
5
5
  export declare function defineSatoriTransformer(transformer: (url: ParsedURL) => SatoriTransformer): (url: ParsedURL) => SatoriTransformer;
@@ -1,7 +1,7 @@
1
1
  import { base64ToArrayBuffer, readPublicAsset } from "../../utils.mjs";
2
2
  import { useStorage } from "#internal/nitro";
3
3
  const cachedFonts = {};
4
- export async function loadFont(url, font) {
4
+ export async function loadFont(font) {
5
5
  if (cachedFonts[font])
6
6
  return cachedFonts[font];
7
7
  let data;
@@ -14,7 +14,7 @@ export async function loadFont(url, font) {
14
14
  if (name === "Inter" && ["400", "700"].includes(weight)) {
15
15
  const data2 = await readPublicAsset(`/inter-latin-ext-${weight}-normal.woff`);
16
16
  if (data2)
17
- return cachedFonts[font] = { name: font, data: data2, style: "normal" };
17
+ return cachedFonts[font] = { name, weight: Number(weight), data: data2, style: "normal" };
18
18
  }
19
19
  if (!data) {
20
20
  const fontUrl = await globalThis.$fetch("/api/og-image-font", {
@@ -25,7 +25,7 @@ export async function loadFont(url, font) {
25
25
  });
26
26
  }
27
27
  await useStorage().setItem(storageKey, Buffer.from(data).toString("base64"));
28
- return cachedFonts[font] = { name, weight, data, style: "normal" };
28
+ return cachedFonts[font] = { name, weight: Number(weight), data, style: "normal" };
29
29
  }
30
30
  export async function walkSatoriTree(url, node, plugins) {
31
31
  if (!node.props?.children)
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "nuxt-og-image",
3
3
  "type": "module",
4
- "version": "1.4.9",
4
+ "version": "1.4.10",
5
5
  "packageManager": "pnpm@7.8.0",
6
6
  "license": "MIT",
7
7
  "funding": "https://github.com/sponsors/harlan-zw",