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

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.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.2",
3
+ "version": "3.0.0-alpha.5",
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.2";
10
+ const version = "3.0.0-alpha.5";
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"));
50
- const addUserFileWithUndefinedFallback = (filename, path, extensions = ["js", "ts"]) => {
51
- const resolvedFilename = `prismic/${filename}.ts`;
49
+ nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@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
55
  logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, "~").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
  [
@@ -108,9 +109,9 @@ const module = defineNuxtModule({
108
109
  });
109
110
  }
110
111
  const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint) ? getRepositoryName(mergedOptions.endpoint) : mergedOptions.endpoint;
111
- (_b = nuxt.options).meta || (_b.meta = {});
112
- (_c = nuxt.options.meta).script || (_c.script = []);
113
- nuxt.options.meta.script.push({
112
+ (_b = nuxt.options).head || (_b.head = {});
113
+ (_c = nuxt.options.head).script || (_c.script = []);
114
+ nuxt.options.head.script.push({
114
115
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
115
116
  });
116
117
  }
@@ -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,
@@ -4,7 +4,7 @@
4
4
  <img
5
5
  src=""
6
6
  alt="Prismic"
7
- >
7
+ />
8
8
  <figcaption>Loading preview...</figcaption>
9
9
  </figure>
10
10
  </section>
@@ -13,7 +13,7 @@
13
13
  <script setup>
14
14
  import { onMounted } from 'vue'
15
15
 
16
- useMeta({
16
+ useHead({
17
17
  title: 'Prismic Preview - Loading'
18
18
  })
19
19
 
@@ -37,14 +37,15 @@ onMounted(async () => {
37
37
  position: fixed;
38
38
  top: 0;
39
39
  left: 0;
40
- display: flex;
40
+ display: flex;
41
41
  justify-content: center;
42
42
  align-items: center;
43
43
  background: #ffffff;
44
- color: #666666;
45
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
46
- font-size: 1rem;
47
- text-align: center;
44
+ color: #666666;
45
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
46
+ Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
47
+ font-size: 1rem;
48
+ text-align: center;
48
49
  }
49
50
 
50
51
  img {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nuxtjs/prismic",
3
- "version": "3.0.0-alpha.2",
3
+ "version": "3.0.0-alpha.5",
4
4
  "description": "Easily connect your Nuxt 3 application to your content hosted on Prismic",
5
5
  "keywords": [
6
6
  "nuxt",
@@ -45,19 +45,19 @@
45
45
  "unit": "echo \"TODO: vitest & nuxt-test-utils\""
46
46
  },
47
47
  "dependencies": {
48
- "@nuxt/kit": "npm:@nuxt/kit-edge@latest",
49
- "@prismicio/client": "^6.4.2",
48
+ "@nuxt/kit": "^3.0.0-rc",
49
+ "@prismicio/client": "^6.4.3",
50
50
  "@prismicio/vue": "^3.0.0-beta",
51
51
  "consola": "^2.15.3",
52
- "ufo": "^0.8.1"
52
+ "ufo": "^0.8.3"
53
53
  },
54
54
  "devDependencies": {
55
55
  "@nuxt/module-builder": "latest",
56
56
  "@nuxtjs/eslint-config-typescript": "latest",
57
- "eslint": "^8.11.0",
58
- "nuxt3": "latest",
57
+ "eslint": "^8.13.0",
58
+ "nuxt": "^3.0.0-rc",
59
59
  "standard-version": "^9.3.2",
60
- "typescript": "^4.6.2"
60
+ "typescript": "^4.6.3"
61
61
  },
62
62
  "engines": {
63
63
  "node": ">=12.7.0"
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'))
53
+ nuxt.options.build.transpile.push(resolver.resolve('runtime'), '@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
+ // If user file exists, proxy it with vfs
64
65
  logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').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'))
@@ -138,9 +141,9 @@ export default defineNuxtModule<PrismicModuleOptions>({
138
141
  const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint)
139
142
  ? getRepositoryName(mergedOptions.endpoint)
140
143
  : mergedOptions.endpoint
141
- nuxt.options.meta ||= {}
142
- nuxt.options.meta.script ||= []
143
- nuxt.options.meta.script.push({
144
+ nuxt.options.head ||= {}
145
+ nuxt.options.head.script ||= []
146
+ nuxt.options.head.script.push({
144
147
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
145
148
  })
146
149
  }
@@ -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,
@@ -4,7 +4,7 @@
4
4
  <img
5
5
  src=""
6
6
  alt="Prismic"
7
- >
7
+ />
8
8
  <figcaption>Loading preview...</figcaption>
9
9
  </figure>
10
10
  </section>
@@ -13,7 +13,7 @@
13
13
  <script setup>
14
14
  import { onMounted } from 'vue'
15
15
 
16
- useMeta({
16
+ useHead({
17
17
  title: 'Prismic Preview - Loading'
18
18
  })
19
19
 
@@ -37,14 +37,15 @@ onMounted(async () => {
37
37
  position: fixed;
38
38
  top: 0;
39
39
  left: 0;
40
- display: flex;
40
+ display: flex;
41
41
  justify-content: center;
42
42
  align-items: center;
43
43
  background: #ffffff;
44
- color: #666666;
45
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
46
- font-size: 1rem;
47
- text-align: center;
44
+ color: #666666;
45
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
46
+ Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
47
+ font-size: 1rem;
48
+ text-align: center;
48
49
  }
49
50
 
50
51
  img {
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
  };