nuxt-og-image 2.0.0-beta.13 → 2.0.0-beta.15

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/dist/module.json CHANGED
@@ -5,5 +5,5 @@
5
5
  "bridge": false
6
6
  },
7
7
  "configKey": "ogImage",
8
- "version": "2.0.0-beta.13"
8
+ "version": "2.0.0-beta.15"
9
9
  }
package/dist/module.mjs CHANGED
@@ -1,5 +1,5 @@
1
1
  import { readFile, writeFile } from 'node:fs/promises';
2
- import { defineNuxtModule, createResolver, addTemplate, addServerHandler, addImports, addComponent } from '@nuxt/kit';
2
+ import { defineNuxtModule, createResolver, addTemplate, addServerHandler, addImports, addComponent, addServerPlugin } from '@nuxt/kit';
3
3
  import { execa } from 'execa';
4
4
  import chalk from 'chalk';
5
5
  import defu from 'defu';
@@ -330,6 +330,7 @@ export {}
330
330
  });
331
331
  const runtimeDir = resolve("./runtime");
332
332
  nuxt.options.build.transpile.push(runtimeDir);
333
+ addServerPlugin(resolve("./runtime/nitro/plugins/prerender"));
333
334
  const moduleAssetDir = resolve("./runtime/public-assets");
334
335
  const assetDirs = [
335
336
  resolve(nuxt.options.rootDir, nuxt.options.dir.public),
@@ -32,12 +32,10 @@ export function defineOgImageStatic(options = {}) {
32
32
  }
33
33
  export function defineOgImage(options = {}) {
34
34
  if (process.server) {
35
- const { forcePrerender, defaults, siteUrl } = useRuntimeConfig()["nuxt-og-image"];
35
+ const { defaults, siteUrl } = useRuntimeConfig()["nuxt-og-image"];
36
36
  const router = useRouter();
37
37
  const route = router?.currentRoute?.value?.path || "";
38
38
  const e = useRequestEvent();
39
- if ((forcePrerender || options.static) && options.provider === "satori")
40
- e.res.setHeader("x-nitro-prerender", `${route === "/" ? "" : route}/__og_image__/og.png`);
41
39
  const baseUrl = process.env.prerender ? siteUrl : useHostname(e);
42
40
  const meta = [
43
41
  {
@@ -0,0 +1,3 @@
1
+ import type { NitroAppPlugin } from 'nitropack';
2
+ declare const OgImagePrenderNitroPlugin: NitroAppPlugin;
3
+ export default OgImagePrenderNitroPlugin;
@@ -0,0 +1,20 @@
1
+ import { appendHeader } from "h3";
2
+ import { joinURL } from "ufo";
3
+ import { extractOgImageOptions } from "../utils-pure.mjs";
4
+ import { useRuntimeConfig } from "#imports";
5
+ const OgImagePrenderNitroPlugin = (nitroApp) => {
6
+ if (!process.env.prerender)
7
+ return;
8
+ const { forcePrerender } = useRuntimeConfig()["nuxt-og-image"];
9
+ nitroApp.hooks.hook("render:html", async (ctx, { event }) => {
10
+ const url = event.node.req.url;
11
+ if (url.includes(".") || url.startsWith("/__nuxt_island/"))
12
+ return;
13
+ const options = extractOgImageOptions(ctx.head.join("\n"));
14
+ if (!options)
15
+ return;
16
+ if ((forcePrerender || options.static) && options.provider === "satori")
17
+ appendHeader(event, "x-nitro-prerender", joinURL(url, "/__og_image__/og.png"));
18
+ });
19
+ };
20
+ export default OgImagePrenderNitroPlugin;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "nuxt-og-image",
3
3
  "type": "module",
4
- "version": "2.0.0-beta.13",
4
+ "version": "2.0.0-beta.15",
5
5
  "packageManager": "pnpm@8.1.0",
6
6
  "license": "MIT",
7
7
  "funding": "https://github.com/sponsors/harlan-zw",