@nuxtjs/prismic 3.0.0-alpha.5 → 3.0.0-alpha.8

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.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nuxtjs/prismic",
3
- "version": "3.0.0-alpha.5",
3
+ "version": "3.0.0-alpha.8",
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.5";
10
+ const version = "3.0.0-alpha.8";
11
11
 
12
12
  const fileExists = (path, extensions = ["js", "ts"]) => {
13
13
  if (!path) {
@@ -46,13 +46,13 @@ 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");
49
+ nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@nuxtjs/prismic", "@prismicio/vue");
50
50
  const proxyUserFileWithUndefinedFallback = (filename, path, extensions = ["js", "mjs", "ts"]) => {
51
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
58
  getContents: () => `export { default } from '${path}'`
@@ -70,6 +70,7 @@ const module = defineNuxtModule({
70
70
  (_a = nuxt.options.runtimeConfig).public || (_a.public = {});
71
71
  nuxt.options.runtimeConfig.public[name] = mergedOptions;
72
72
  addPlugin(resolver.resolve("runtime/plugin"));
73
+ addPlugin(resolver.resolve("runtime/plugin.client"));
73
74
  if (mergedOptions.injectComponents) {
74
75
  [
75
76
  "PrismicEmbed",
@@ -94,10 +95,15 @@ const module = defineNuxtModule({
94
95
  };
95
96
  });
96
97
  addAutoImport(composableAutoImports);
98
+ addAutoImport({
99
+ name: "usePrismicPreview",
100
+ as: "usePrismicPreview",
101
+ from: resolver.resolve("runtime/usePrismicPreview")
102
+ });
97
103
  if (mergedOptions.preview) {
98
104
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ["js", "ts", "vue"]);
99
105
  if (maybeUserPreviewPage) {
100
- logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
106
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(nuxt.options.rootDir, "~~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
101
107
  } else {
102
108
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``);
103
109
  extendPages((pages) => {
@@ -109,9 +115,9 @@ const module = defineNuxtModule({
109
115
  });
110
116
  }
111
117
  const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint) ? getRepositoryName(mergedOptions.endpoint) : mergedOptions.endpoint;
112
- (_b = nuxt.options).head || (_b.head = {});
113
- (_c = nuxt.options.head).script || (_c.script = []);
114
- nuxt.options.head.script.push({
118
+ (_b = nuxt.options.app).head || (_b.head = {});
119
+ (_c = nuxt.options.app.head).script || (_c.script = []);
120
+ nuxt.options.app.head.script.push({
115
121
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
116
122
  });
117
123
  }
@@ -0,0 +1,2 @@
1
+ declare const _default: any;
2
+ export default _default;
@@ -0,0 +1,13 @@
1
+ import { defineNuxtPlugin } from "#app";
2
+ const pkgName = "@nuxtjs/prismic";
3
+ export default defineNuxtPlugin((nuxtApp) => {
4
+ const mergedOptions = nuxtApp.payload.config[pkgName] ?? nuxtApp.payload.config.public[pkgName] ?? {};
5
+ if (mergedOptions.preview) {
6
+ window.addEventListener("prismicPreviewUpdate", (event) => {
7
+ if (refreshNuxtData) {
8
+ event.preventDefault();
9
+ refreshNuxtData();
10
+ }
11
+ });
12
+ }
13
+ });
@@ -7,7 +7,7 @@ import htmlSerializer from "#build/prismic/proxy/htmlSerializer";
7
7
  const pkgName = "@nuxtjs/prismic";
8
8
  export default defineNuxtPlugin((nuxtApp) => {
9
9
  const mergedOptions = nuxtApp.payload.config[pkgName] ?? nuxtApp.payload.config.public[pkgName] ?? {};
10
- nuxtApp.vueApp.use(createPrismic({
10
+ const prismicPlugin = createPrismic({
11
11
  ...mergedOptions,
12
12
  client,
13
13
  linkResolver,
@@ -18,5 +18,21 @@ export default defineNuxtPlugin((nuxtApp) => {
18
18
  linkExternalComponent: NuxtLink,
19
19
  ...mergedOptions.components
20
20
  }
21
- }));
21
+ });
22
+ nuxtApp.vueApp.use(prismicPlugin);
23
+ if (mergedOptions.preview) {
24
+ const previewCookie = useCookie("io.prismic.preview").value;
25
+ if (process.server) {
26
+ prismicPlugin.client.enableAutoPreviewsFromReq(useRequestEvent()?.req);
27
+ }
28
+ if (previewCookie) {
29
+ try {
30
+ const session = typeof previewCookie === "string" ? JSON.parse(decodeURIComponent(previewCookie)) : previewCookie;
31
+ if (Object.keys(session).some((key) => key in session && typeof session[key] === "object" && session[key] !== null && "preview" in session[key] && session[key].preview)) {
32
+ refreshNuxtData();
33
+ }
34
+ } catch (error) {
35
+ }
36
+ }
37
+ }
22
38
  });
@@ -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.5",
3
+ "version": "3.0.0-alpha.8",
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",
@@ -46,21 +47,21 @@
46
47
  },
47
48
  "dependencies": {
48
49
  "@nuxt/kit": "^3.0.0-rc",
49
- "@prismicio/client": "^6.4.3",
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.13.0",
58
+ "eslint": "^8.18.0",
58
59
  "nuxt": "^3.0.0-rc",
59
- "standard-version": "^9.3.2",
60
- "typescript": "^4.6.3"
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
@@ -50,7 +50,7 @@ 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
56
  const proxyUserFileWithUndefinedFallback = (filename: string, path?: string, extensions = ['js', 'mjs', 'ts']) => {
@@ -62,7 +62,7 @@ export default defineNuxtModule<PrismicModuleOptions>({
62
62
 
63
63
  if (maybeUserFile) {
64
64
  // If user file exists, proxy it with vfs
65
- logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').replace(/\\/g, '/')}\``)
65
+ logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').replace(nuxt.options.rootDir, '~~').replace(/\\/g, '/')}\``)
66
66
 
67
67
  addTemplate({
68
68
  filename: resolvedFilename,
@@ -86,6 +86,7 @@ export default defineNuxtModule<PrismicModuleOptions>({
86
86
 
87
87
  // Add plugin
88
88
  addPlugin(resolver.resolve('runtime/plugin'))
89
+ addPlugin(resolver.resolve('runtime/plugin.client'))
89
90
 
90
91
  // Add components auto import
91
92
  if (mergedOptions.injectComponents) {
@@ -117,13 +118,18 @@ export default defineNuxtModule<PrismicModuleOptions>({
117
118
  }
118
119
  })
119
120
  addAutoImport(composableAutoImports)
121
+ addAutoImport({
122
+ name: 'usePrismicPreview',
123
+ as: 'usePrismicPreview',
124
+ from: resolver.resolve('runtime/usePrismicPreview')
125
+ })
120
126
 
121
127
  // Add preview route
122
128
  if (mergedOptions.preview) {
123
129
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
124
130
 
125
131
  if (maybeUserPreviewPage) {
126
- logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(/\\/g, '/')
132
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(nuxt.options.rootDir, '~~').replace(/\\/g, '/')
127
133
  }\`, available at \`${mergedOptions.preview}\``)
128
134
  } else {
129
135
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
@@ -141,9 +147,9 @@ export default defineNuxtModule<PrismicModuleOptions>({
141
147
  const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint)
142
148
  ? getRepositoryName(mergedOptions.endpoint)
143
149
  : mergedOptions.endpoint
144
- nuxt.options.head ||= {}
145
- nuxt.options.head.script ||= []
146
- nuxt.options.head.script.push({
150
+ nuxt.options.app.head ||= {}
151
+ nuxt.options.app.head.script ||= []
152
+ nuxt.options.app.head.script.push({
147
153
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
148
154
  })
149
155
  }
@@ -0,0 +1,24 @@
1
+ import { defineNuxtPlugin } from '#app'
2
+
3
+ // import { name as pkgName } from '../../package.json'
4
+ import { PrismicModuleOptions } from '../types'
5
+
6
+ // TODO: Revert when fixed
7
+ const pkgName = '@nuxtjs/prismic'
8
+
9
+ export default defineNuxtPlugin((nuxtApp) => {
10
+ const mergedOptions: PrismicModuleOptions =
11
+ nuxtApp.payload.config[pkgName] ??
12
+ nuxtApp.payload.config.public[pkgName] ??
13
+ {}
14
+
15
+ // Hot reload preview updates
16
+ if (mergedOptions.preview) {
17
+ window.addEventListener('prismicPreviewUpdate', (event) => {
18
+ if (refreshNuxtData) {
19
+ event.preventDefault()
20
+ refreshNuxtData()
21
+ }
22
+ })
23
+ }
24
+ })
@@ -22,7 +22,7 @@ export default defineNuxtPlugin((nuxtApp) => {
22
22
  nuxtApp.payload.config.public[pkgName] ??
23
23
  {}
24
24
 
25
- nuxtApp.vueApp.use(createPrismic({
25
+ const prismicPlugin = createPrismic({
26
26
  ...mergedOptions,
27
27
  client,
28
28
  linkResolver,
@@ -33,5 +33,34 @@ export default defineNuxtPlugin((nuxtApp) => {
33
33
  linkExternalComponent: NuxtLink,
34
34
  ...mergedOptions.components
35
35
  }
36
- }))
36
+ })
37
+
38
+ nuxtApp.vueApp.use(prismicPlugin)
39
+
40
+ if (mergedOptions.preview) {
41
+ const previewCookie = useCookie('io.prismic.preview').value
42
+
43
+ // Update client with req when running server side
44
+ if (process.server) {
45
+ prismicPlugin.client.enableAutoPreviewsFromReq(useRequestEvent()?.req)
46
+ }
47
+
48
+ if (previewCookie) {
49
+ try {
50
+ const session = typeof previewCookie === 'string' ? JSON.parse(decodeURIComponent(previewCookie)) : previewCookie
51
+
52
+ if (Object.keys(session).some(key =>
53
+ key in session &&
54
+ typeof session[key] === 'object' &&
55
+ session[key] !== null &&
56
+ 'preview' in session[key] &&
57
+ session[key].preview)
58
+ ) {
59
+ refreshNuxtData()
60
+ }
61
+ } catch (error) {
62
+ // noop
63
+ }
64
+ }
65
+ }
37
66
  })
@@ -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
+ }