@nuxtjs/prismic 3.0.0-alpha.5 → 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.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.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.5";
10
+ const version = "3.0.0-alpha.6";
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}'`
@@ -94,10 +94,15 @@ const module = defineNuxtModule({
94
94
  };
95
95
  });
96
96
  addAutoImport(composableAutoImports);
97
+ addAutoImport({
98
+ name: "usePrismicPreview",
99
+ as: "usePrismicPreview",
100
+ from: resolver.resolve("runtime/usePrismicPreview")
101
+ });
97
102
  if (mergedOptions.preview) {
98
103
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ["js", "ts", "vue"]);
99
104
  if (maybeUserPreviewPage) {
100
- 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}\``);
101
106
  } else {
102
107
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``);
103
108
  extendPages((pages) => {
@@ -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.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",
@@ -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,
@@ -117,13 +117,18 @@ export default defineNuxtModule<PrismicModuleOptions>({
117
117
  }
118
118
  })
119
119
  addAutoImport(composableAutoImports)
120
+ addAutoImport({
121
+ name: 'usePrismicPreview',
122
+ as: 'usePrismicPreview',
123
+ from: resolver.resolve('runtime/usePrismicPreview')
124
+ })
120
125
 
121
126
  // Add preview route
122
127
  if (mergedOptions.preview) {
123
128
  const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
124
129
 
125
130
  if (maybeUserPreviewPage) {
126
- 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, '/')
127
132
  }\`, available at \`${mergedOptions.preview}\``)
128
133
  } else {
129
134
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
@@ -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
+ }