@nuxtjs/prismic 3.0.0-alpha.4 → 3.0.0-alpha.7
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 +1 -1
- package/dist/module.json +1 -1
- package/dist/module.mjs +18 -13
- package/dist/runtime/plugin.mjs +4 -4
- package/dist/runtime/preview.vue +6 -15
- package/dist/runtime/usePrismicPreview.d.ts +6 -0
- package/dist/runtime/usePrismicPreview.mjs +13 -0
- package/package.json +10 -9
- package/src/module.ts +19 -12
- package/src/runtime/plugin.ts +10 -4
- package/src/runtime/preview.vue +6 -15
- package/src/runtime/usePrismicPreview.ts +21 -0
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 '
|
|
35
|
+
import { defineNuxtConfig } from 'nuxt'
|
|
36
36
|
|
|
37
37
|
export default defineNuxtConfig({
|
|
38
38
|
modules: ['@nuxtjs/prismic'],
|
package/dist/module.json
CHANGED
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.
|
|
10
|
+
const version = "3.0.0-alpha.7";
|
|
11
11
|
|
|
12
12
|
const fileExists = (path, extensions = ["js", "ts"]) => {
|
|
13
13
|
if (!path) {
|
|
@@ -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
|
|
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
|
-
|
|
58
|
+
getContents: () => `export { default } from '${path}'`
|
|
59
59
|
});
|
|
60
60
|
} else {
|
|
61
61
|
addTemplate({
|
|
@@ -64,9 +64,9 @@ const module = defineNuxtModule({
|
|
|
64
64
|
});
|
|
65
65
|
}
|
|
66
66
|
};
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
67
|
+
proxyUserFileWithUndefinedFallback("client", mergedOptions.client);
|
|
68
|
+
proxyUserFileWithUndefinedFallback("linkResolver", mergedOptions.linkResolver);
|
|
69
|
+
proxyUserFileWithUndefinedFallback("htmlSerializer", mergedOptions.htmlSerializer);
|
|
70
70
|
(_a = nuxt.options.runtimeConfig).public || (_a.public = {});
|
|
71
71
|
nuxt.options.runtimeConfig.public[name] = mergedOptions;
|
|
72
72
|
addPlugin(resolver.resolve("runtime/plugin"));
|
|
@@ -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) => {
|
|
@@ -109,9 +114,9 @@ const module = defineNuxtModule({
|
|
|
109
114
|
});
|
|
110
115
|
}
|
|
111
116
|
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({
|
|
117
|
+
(_b = nuxt.options.app).head || (_b.head = {});
|
|
118
|
+
(_c = nuxt.options.app.head).script || (_c.script = []);
|
|
119
|
+
nuxt.options.app.head.script.push({
|
|
115
120
|
src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
|
|
116
121
|
});
|
|
117
122
|
}
|
package/dist/runtime/plugin.mjs
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { defineNuxtPlugin } from "#app";
|
|
2
2
|
import NuxtLink from "#app/components/nuxt-link";
|
|
3
3
|
import { createPrismic } from "@prismicio/vue";
|
|
4
|
-
import
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
|
|
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";
|
|
8
8
|
export default defineNuxtPlugin((nuxtApp) => {
|
|
9
9
|
const mergedOptions = nuxtApp.payload.config[pkgName] ?? nuxtApp.payload.config.public[pkgName] ?? {};
|
|
10
10
|
nuxtApp.vueApp.use(createPrismic({
|
package/dist/runtime/preview.vue
CHANGED
|
@@ -3,31 +3,22 @@
|
|
|
3
3
|
<figure>
|
|
4
4
|
<img
|
|
5
5
|
src=""
|
|
6
|
-
alt="Prismic"
|
|
7
|
-
|
|
8
|
-
|
|
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 {
|
|
15
|
+
import { useHead, usePrismicPreview } from '#imports'
|
|
15
16
|
|
|
16
17
|
useHead({
|
|
17
18
|
title: 'Prismic Preview - Loading'
|
|
18
19
|
})
|
|
19
20
|
|
|
20
|
-
|
|
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,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
|
+
"version": "3.0.0-alpha.7",
|
|
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": "
|
|
49
|
-
"@prismicio/client": "^6.
|
|
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.
|
|
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.
|
|
58
|
-
"
|
|
59
|
-
"standard-version": "^9.
|
|
60
|
-
"typescript": "^4.
|
|
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": ">=
|
|
64
|
+
"node": ">=14.15.0"
|
|
64
65
|
},
|
|
65
66
|
"publishConfig": {
|
|
66
67
|
"access": "public"
|
package/src/module.ts
CHANGED
|
@@ -50,33 +50,35 @@ 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
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
78
|
-
|
|
79
|
-
|
|
79
|
+
proxyUserFileWithUndefinedFallback('client', mergedOptions.client)
|
|
80
|
+
proxyUserFileWithUndefinedFallback('linkResolver', mergedOptions.linkResolver)
|
|
81
|
+
proxyUserFileWithUndefinedFallback('htmlSerializer', mergedOptions.htmlSerializer)
|
|
80
82
|
|
|
81
83
|
// Expose options through public runtime config
|
|
82
84
|
nuxt.options.runtimeConfig.public ||= {} as typeof nuxt.options.runtimeConfig.public
|
|
@@ -115,13 +117,18 @@ export default defineNuxtModule<PrismicModuleOptions>({
|
|
|
115
117
|
}
|
|
116
118
|
})
|
|
117
119
|
addAutoImport(composableAutoImports)
|
|
120
|
+
addAutoImport({
|
|
121
|
+
name: 'usePrismicPreview',
|
|
122
|
+
as: 'usePrismicPreview',
|
|
123
|
+
from: resolver.resolve('runtime/usePrismicPreview')
|
|
124
|
+
})
|
|
118
125
|
|
|
119
126
|
// Add preview route
|
|
120
127
|
if (mergedOptions.preview) {
|
|
121
128
|
const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
|
|
122
129
|
|
|
123
130
|
if (maybeUserPreviewPage) {
|
|
124
|
-
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, '/')
|
|
125
132
|
}\`, available at \`${mergedOptions.preview}\``)
|
|
126
133
|
} else {
|
|
127
134
|
logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
|
|
@@ -139,9 +146,9 @@ export default defineNuxtModule<PrismicModuleOptions>({
|
|
|
139
146
|
const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint)
|
|
140
147
|
? getRepositoryName(mergedOptions.endpoint)
|
|
141
148
|
: mergedOptions.endpoint
|
|
142
|
-
nuxt.options.head ||= {}
|
|
143
|
-
nuxt.options.head.script ||= []
|
|
144
|
-
nuxt.options.head.script.push({
|
|
149
|
+
nuxt.options.app.head ||= {}
|
|
150
|
+
nuxt.options.app.head.script ||= []
|
|
151
|
+
nuxt.options.app.head.script.push({
|
|
145
152
|
src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
|
|
146
153
|
})
|
|
147
154
|
}
|
package/src/runtime/plugin.ts
CHANGED
|
@@ -3,12 +3,18 @@ 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
|
-
|
|
10
|
-
import
|
|
11
|
-
|
|
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'
|
|
12
18
|
|
|
13
19
|
export default defineNuxtPlugin((nuxtApp) => {
|
|
14
20
|
const mergedOptions: PrismicModuleOptions =
|
package/src/runtime/preview.vue
CHANGED
|
@@ -3,31 +3,22 @@
|
|
|
3
3
|
<figure>
|
|
4
4
|
<img
|
|
5
5
|
src=""
|
|
6
|
-
alt="Prismic"
|
|
7
|
-
|
|
8
|
-
|
|
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 {
|
|
15
|
+
import { useHead, usePrismicPreview } from '#imports'
|
|
15
16
|
|
|
16
17
|
useHead({
|
|
17
18
|
title: 'Prismic Preview - Loading'
|
|
18
19
|
})
|
|
19
20
|
|
|
20
|
-
|
|
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
|
+
}
|