@nuxtjs/prismic 3.0.0-alpha.3 → 3.0.0-alpha.6

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
@@ -32,7 +32,7 @@ npm install --save-dev @nuxtjs/prismic@alpha # or yarn add --dev @nuxtjs/prismic
32
32
  Then, add `@nuxtjs/prismic` to the `modules` section of your Nuxt config and configure your Prismic API endpoint:
33
33
 
34
34
  ```javascript
35
- import { defineNuxtConfig } from 'nuxt3'
35
+ import { defineNuxtConfig } from 'nuxt'
36
36
 
37
37
  export default defineNuxtConfig({
38
38
  modules: ['@nuxtjs/prismic'],
package/dist/module.d.ts CHANGED
@@ -1,10 +1,11 @@
1
1
  import * as _nuxt_schema from '@nuxt/schema';
2
2
  import { PrismicPluginOptions } from '@prismicio/vue';
3
3
 
4
- declare type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver'> & {
4
+ declare type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver' | 'htmlSerializer'> & {
5
5
  endpoint: string;
6
6
  client?: string;
7
7
  linkResolver?: string;
8
+ htmlSerializer?: string;
8
9
  preview?: string | false;
9
10
  };
10
11
 
package/dist/module.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nuxtjs/prismic",
3
- "version": "3.0.0-alpha.3",
3
+ "version": "3.0.0-alpha.6",
4
4
  "configKey": "prismic",
5
5
  "compatibility": {
6
6
  "nuxt": "^3.0.0"
package/dist/module.mjs CHANGED
@@ -7,7 +7,7 @@ import { existsSync } from 'fs';
7
7
  import consola from 'consola';
8
8
 
9
9
  const name = "@nuxtjs/prismic";
10
- const version = "3.0.0-alpha.3";
10
+ const version = "3.0.0-alpha.6";
11
11
 
12
12
  const fileExists = (path, extensions = ["js", "ts"]) => {
13
13
  if (!path) {
@@ -33,7 +33,7 @@ const module = defineNuxtModule({
33
33
  clientConfig: {},
34
34
  client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
35
35
  linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
36
- htmlSerializer: void 0,
36
+ htmlSerializer: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/htmlSerializer`),
37
37
  injectComponents: true,
38
38
  components: {},
39
39
  preview: "/preview"
@@ -46,16 +46,16 @@ const module = defineNuxtModule({
46
46
  return;
47
47
  }
48
48
  const resolver = createResolver(import.meta.url);
49
- nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@prismicio/vue");
50
- const addUserFileWithUndefinedFallback = (filename, path, extensions = ["js", "ts"]) => {
51
- const resolvedFilename = `prismic/${filename}.ts`;
49
+ nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@nuxtjs/prismic", "@prismicio/vue");
50
+ const proxyUserFileWithUndefinedFallback = (filename, path, extensions = ["js", "mjs", "ts"]) => {
51
+ const resolvedFilename = `prismic/proxy/${filename}.ts`;
52
52
  const resolvedPath = path ? path.replace(/^(~~|@@)/, nuxt.options.rootDir).replace(/^(~|@)/, nuxt.options.srcDir) : void 0;
53
53
  const maybeUserFile = fileExists(resolvedPath, extensions);
54
54
  if (maybeUserFile) {
55
- logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, "~").replace(/\\/g, "/")}\``);
55
+ logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, "~").replace(nuxt.options.rootDir, "~~").replace(/\\/g, "/")}\``);
56
56
  addTemplate({
57
57
  filename: resolvedFilename,
58
- src: maybeUserFile
58
+ getContents: () => `export { default } from '${path}'`
59
59
  });
60
60
  } else {
61
61
  addTemplate({
@@ -64,10 +64,11 @@ const module = defineNuxtModule({
64
64
  });
65
65
  }
66
66
  };
67
- addUserFileWithUndefinedFallback("client", mergedOptions.client);
68
- addUserFileWithUndefinedFallback("linkResolver", mergedOptions.linkResolver);
69
- (_a = nuxt.options).publicRuntimeConfig || (_a.publicRuntimeConfig = {});
70
- nuxt.options.publicRuntimeConfig[name] = mergedOptions;
67
+ proxyUserFileWithUndefinedFallback("client", mergedOptions.client);
68
+ proxyUserFileWithUndefinedFallback("linkResolver", mergedOptions.linkResolver);
69
+ proxyUserFileWithUndefinedFallback("htmlSerializer", mergedOptions.htmlSerializer);
70
+ (_a = nuxt.options.runtimeConfig).public || (_a.public = {});
71
+ nuxt.options.runtimeConfig.public[name] = mergedOptions;
71
72
  addPlugin(resolver.resolve("runtime/plugin"));
72
73
  if (mergedOptions.injectComponents) {
73
74
  [
@@ -93,10 +94,15 @@ const module = defineNuxtModule({
93
94
  };
94
95
  });
95
96
  addAutoImport(composableAutoImports);
97
+ addAutoImport({
98
+ name: "usePrismicPreview",
99
+ as: "usePrismicPreview",
100
+ from: resolver.resolve("runtime/usePrismicPreview")
101
+ });
96
102
  if (mergedOptions.preview) {
97
103
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ["js", "ts", "vue"]);
98
104
  if (maybeUserPreviewPage) {
99
- logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
105
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(nuxt.options.rootDir, "~~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
100
106
  } else {
101
107
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``);
102
108
  extendPages((pages) => {
@@ -1,15 +1,17 @@
1
1
  import { defineNuxtPlugin } from "#app";
2
2
  import NuxtLink from "#app/components/nuxt-link";
3
3
  import { createPrismic } from "@prismicio/vue";
4
- import { name as pkgName } from "../../package.json";
5
- import linkResolver from "#build/prismic/linkResolver";
6
- import client from "#build/prismic/client";
4
+ import client from "#build/prismic/proxy/client";
5
+ import linkResolver from "#build/prismic/proxy/linkResolver";
6
+ import htmlSerializer from "#build/prismic/proxy/htmlSerializer";
7
+ const pkgName = "@nuxtjs/prismic";
7
8
  export default defineNuxtPlugin((nuxtApp) => {
8
- const mergedOptions = nuxtApp.payload.config[pkgName];
9
+ const mergedOptions = nuxtApp.payload.config[pkgName] ?? nuxtApp.payload.config.public[pkgName] ?? {};
9
10
  nuxtApp.vueApp.use(createPrismic({
10
11
  ...mergedOptions,
11
12
  client,
12
13
  linkResolver,
14
+ htmlSerializer,
13
15
  injectComponents: false,
14
16
  components: {
15
17
  linkInternalComponent: NuxtLink,
@@ -3,31 +3,22 @@
3
3
  <figure>
4
4
  <img
5
5
  src=""
6
- alt="Prismic"
7
- />
8
- <figcaption>Loading preview...</figcaption>
6
+ alt="Prismic">
7
+ <figcaption>
8
+ Loading preview...
9
+ </figcaption>
9
10
  </figure>
10
11
  </section>
11
12
  </template>
12
13
 
13
14
  <script setup>
14
- import { onMounted } from 'vue'
15
+ import { useHead, usePrismicPreview } from '#imports'
15
16
 
16
17
  useHead({
17
18
  title: 'Prismic Preview - Loading'
18
19
  })
19
20
 
20
- // TODO: refactor into simple hook
21
- const { client, options: { linkResolver } } = usePrismic()
22
- const { push } = useRouter()
23
- onMounted(async () => {
24
- const redirectURL = await client.resolvePreviewURL({
25
- linkResolver,
26
- defaultURL: '/'
27
- })
28
-
29
- push(redirectURL ?? '/')
30
- })
21
+ usePrismicPreview()
31
22
  </script>
32
23
 
33
24
  <style scoped>
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Resolves Prismic previews on the preview entry page (`/preview`)
3
+ *
4
+ * @param defaultURL - The default URL to redirect to if the previewed document doesn't map to one.
5
+ */
6
+ export declare const usePrismicPreview: (defaultURL?: string) => void;
@@ -0,0 +1,13 @@
1
+ import { onMounted } from "vue";
2
+ import { useRouter, usePrismic } from "#imports";
3
+ export const usePrismicPreview = (defaultURL = "/") => {
4
+ const { client, options: { linkResolver } } = usePrismic();
5
+ const { push } = useRouter();
6
+ onMounted(async () => {
7
+ const redirectURL = await client.resolvePreviewURL({
8
+ linkResolver,
9
+ defaultURL
10
+ });
11
+ push(redirectURL);
12
+ });
13
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nuxtjs/prismic",
3
- "version": "3.0.0-alpha.3",
3
+ "version": "3.0.0-alpha.6",
4
4
  "description": "Easily connect your Nuxt 3 application to your content hosted on Prismic",
5
5
  "keywords": [
6
6
  "nuxt",
@@ -22,6 +22,7 @@
22
22
  "require": "./dist/module.cjs",
23
23
  "import": "./dist/module.mjs"
24
24
  },
25
+ "./runtime/*": "./dist/runtime/*",
25
26
  "./package.json": "./package.json"
26
27
  },
27
28
  "main": "dist/module.cjs",
@@ -45,22 +46,22 @@
45
46
  "unit": "echo \"TODO: vitest & nuxt-test-utils\""
46
47
  },
47
48
  "dependencies": {
48
- "@nuxt/kit": "npm:@nuxt/kit-edge@latest",
49
- "@prismicio/client": "^6.4.2",
49
+ "@nuxt/kit": "^3.0.0-rc",
50
+ "@prismicio/client": "^6.6.1",
50
51
  "@prismicio/vue": "^3.0.0-beta",
51
52
  "consola": "^2.15.3",
52
- "ufo": "^0.8.3"
53
+ "ufo": "^0.8.4"
53
54
  },
54
55
  "devDependencies": {
55
56
  "@nuxt/module-builder": "latest",
56
57
  "@nuxtjs/eslint-config-typescript": "latest",
57
- "eslint": "^8.12.0",
58
- "nuxt3": "latest",
59
- "standard-version": "^9.3.2",
60
- "typescript": "^4.6.3"
58
+ "eslint": "^8.18.0",
59
+ "nuxt": "^3.0.0-rc",
60
+ "standard-version": "^9.5.0",
61
+ "typescript": "^4.7.4"
61
62
  },
62
63
  "engines": {
63
- "node": ">=12.7.0"
64
+ "node": ">=14.15.0"
64
65
  },
65
66
  "publishConfig": {
66
67
  "access": "public"
package/src/module.ts CHANGED
@@ -36,7 +36,7 @@ export default defineNuxtModule<PrismicModuleOptions>({
36
36
  clientConfig: {},
37
37
  client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
38
38
  linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
39
- htmlSerializer: undefined,
39
+ htmlSerializer: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/htmlSerializer`),
40
40
  injectComponents: true,
41
41
  components: {},
42
42
  preview: '/preview'
@@ -50,36 +50,39 @@ export default defineNuxtModule<PrismicModuleOptions>({
50
50
 
51
51
  // Runtime dir boilerplate
52
52
  const resolver = createResolver(import.meta.url)
53
- nuxt.options.build.transpile.push(resolver.resolve('runtime'), '@prismicio/vue')
53
+ nuxt.options.build.transpile.push(resolver.resolve('runtime'), '@nuxtjs/prismic', '@prismicio/vue')
54
54
 
55
55
  // Add runtime user code
56
- const addUserFileWithUndefinedFallback = (filename: string, path?: string, extensions = ['js', 'ts']) => {
57
- const resolvedFilename = `prismic/${filename}.ts`
56
+ const proxyUserFileWithUndefinedFallback = (filename: string, path?: string, extensions = ['js', 'mjs', 'ts']) => {
57
+ const resolvedFilename = `prismic/proxy/${filename}.ts`
58
58
  const resolvedPath = path
59
59
  ? path.replace(/^(~~|@@)/, nuxt.options.rootDir).replace(/^(~|@)/, nuxt.options.srcDir)
60
60
  : undefined
61
61
  const maybeUserFile = fileExists(resolvedPath, extensions)
62
62
 
63
63
  if (maybeUserFile) {
64
- logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').replace(/\\/g, '/')}\``)
64
+ // If user file exists, proxy it with vfs
65
+ logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').replace(nuxt.options.rootDir, '~~').replace(/\\/g, '/')}\``)
65
66
 
66
67
  addTemplate({
67
68
  filename: resolvedFilename,
68
- src: maybeUserFile
69
+ getContents: () => `export { default } from '${path}'`
69
70
  })
70
71
  } else {
72
+ // Else provide `undefined` fallback
71
73
  addTemplate({
72
74
  filename: resolvedFilename,
73
75
  getContents: () => 'export default undefined'
74
76
  })
75
77
  }
76
78
  }
77
- addUserFileWithUndefinedFallback('client', mergedOptions.client)
78
- addUserFileWithUndefinedFallback('linkResolver', mergedOptions.linkResolver)
79
+ proxyUserFileWithUndefinedFallback('client', mergedOptions.client)
80
+ proxyUserFileWithUndefinedFallback('linkResolver', mergedOptions.linkResolver)
81
+ proxyUserFileWithUndefinedFallback('htmlSerializer', mergedOptions.htmlSerializer)
79
82
 
80
83
  // Expose options through public runtime config
81
- nuxt.options.publicRuntimeConfig ||= {} as typeof nuxt.options.publicRuntimeConfig
82
- nuxt.options.publicRuntimeConfig[pkgName] = mergedOptions
84
+ nuxt.options.runtimeConfig.public ||= {} as typeof nuxt.options.runtimeConfig.public
85
+ nuxt.options.runtimeConfig.public[pkgName] = mergedOptions
83
86
 
84
87
  // Add plugin
85
88
  addPlugin(resolver.resolve('runtime/plugin'))
@@ -114,13 +117,18 @@ export default defineNuxtModule<PrismicModuleOptions>({
114
117
  }
115
118
  })
116
119
  addAutoImport(composableAutoImports)
120
+ addAutoImport({
121
+ name: 'usePrismicPreview',
122
+ as: 'usePrismicPreview',
123
+ from: resolver.resolve('runtime/usePrismicPreview')
124
+ })
117
125
 
118
126
  // Add preview route
119
127
  if (mergedOptions.preview) {
120
128
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
121
129
 
122
130
  if (maybeUserPreviewPage) {
123
- logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(/\\/g, '/')
131
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(nuxt.options.rootDir, '~~').replace(/\\/g, '/')
124
132
  }\`, available at \`${mergedOptions.preview}\``)
125
133
  } else {
126
134
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
@@ -3,19 +3,30 @@ import NuxtLink from '#app/components/nuxt-link'
3
3
 
4
4
  import { createPrismic } from '@prismicio/vue'
5
5
 
6
- import { name as pkgName } from '../../package.json'
6
+ // import { name as pkgName } from '../../package.json'
7
7
  import { PrismicModuleOptions } from '../types'
8
8
 
9
- import linkResolver from '#build/prismic/linkResolver'
10
- import client from '#build/prismic/client'
9
+ // @ts-expect-error vfs cannot be resolved here
10
+ import client from '#build/prismic/proxy/client'
11
+ // @ts-expect-error vfs cannot be resolved here
12
+ import linkResolver from '#build/prismic/proxy/linkResolver'
13
+ // @ts-expect-error vfs cannot be resolved here
14
+ import htmlSerializer from '#build/prismic/proxy/htmlSerializer'
15
+
16
+ // TODO: Revert when fixed
17
+ const pkgName = '@nuxtjs/prismic'
11
18
 
12
19
  export default defineNuxtPlugin((nuxtApp) => {
13
- const mergedOptions: PrismicModuleOptions = nuxtApp.payload.config[pkgName]
20
+ const mergedOptions: PrismicModuleOptions =
21
+ nuxtApp.payload.config[pkgName] ??
22
+ nuxtApp.payload.config.public[pkgName] ??
23
+ {}
14
24
 
15
25
  nuxtApp.vueApp.use(createPrismic({
16
26
  ...mergedOptions,
17
27
  client,
18
28
  linkResolver,
29
+ htmlSerializer,
19
30
  injectComponents: false, // Handled at module level
20
31
  components: {
21
32
  linkInternalComponent: NuxtLink,
@@ -3,31 +3,22 @@
3
3
  <figure>
4
4
  <img
5
5
  src=""
6
- alt="Prismic"
7
- />
8
- <figcaption>Loading preview...</figcaption>
6
+ alt="Prismic">
7
+ <figcaption>
8
+ Loading preview...
9
+ </figcaption>
9
10
  </figure>
10
11
  </section>
11
12
  </template>
12
13
 
13
14
  <script setup>
14
- import { onMounted } from 'vue'
15
+ import { useHead, usePrismicPreview } from '#imports'
15
16
 
16
17
  useHead({
17
18
  title: 'Prismic Preview - Loading'
18
19
  })
19
20
 
20
- // TODO: refactor into simple hook
21
- const { client, options: { linkResolver } } = usePrismic()
22
- const { push } = useRouter()
23
- onMounted(async () => {
24
- const redirectURL = await client.resolvePreviewURL({
25
- linkResolver,
26
- defaultURL: '/'
27
- })
28
-
29
- push(redirectURL ?? '/')
30
- })
21
+ usePrismicPreview()
31
22
  </script>
32
23
 
33
24
  <style scoped>
@@ -0,0 +1,21 @@
1
+ import { onMounted } from 'vue'
2
+
3
+ import { useRouter, usePrismic } from '#imports'
4
+
5
+ /**
6
+ * Resolves Prismic previews on the preview entry page (`/preview`)
7
+ *
8
+ * @param defaultURL - The default URL to redirect to if the previewed document doesn't map to one.
9
+ */
10
+ export const usePrismicPreview = (defaultURL = '/'): void => {
11
+ const { client, options: { linkResolver } } = usePrismic()
12
+ const { push } = useRouter()
13
+ onMounted(async () => {
14
+ const redirectURL = await client.resolvePreviewURL({
15
+ linkResolver,
16
+ defaultURL
17
+ })
18
+
19
+ push(redirectURL)
20
+ })
21
+ }
package/src/types.ts CHANGED
@@ -1,8 +1,9 @@
1
1
  import { PrismicPluginOptions } from '@prismicio/vue'
2
2
 
3
- export type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver'> & {
4
- endpoint: string,
5
- client?: string,
6
- linkResolver?: string,
7
- preview?: string | false,
3
+ export type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver' | 'htmlSerializer'> & {
4
+ endpoint: string;
5
+ client?: string;
6
+ linkResolver?: string;
7
+ htmlSerializer?: string;
8
+ preview?: string | false;
8
9
  };