@nuxtjs/prismic 3.0.0-alpha.1 → 3.0.0-alpha.10
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.d.ts +6 -2
- package/dist/module.json +1 -1
- package/dist/module.mjs +59 -31
- package/dist/runtime/plugin.client.d.ts +2 -0
- package/dist/runtime/plugin.client.mjs +11 -0
- package/dist/runtime/plugin.mjs +34 -6
- package/dist/runtime/preview.vue +13 -21
- package/dist/runtime/usePrismicPreview.d.ts +6 -0
- package/dist/runtime/usePrismicPreview.mjs +13 -0
- package/dist/types.d.ts +5 -1
- package/package.json +12 -14
- package/src/module.ts +73 -34
- package/src/runtime/plugin.client.ts +22 -0
- package/src/runtime/plugin.ts +58 -6
- package/src/runtime/preview.vue +13 -21
- package/src/runtime/usePrismicPreview.ts +21 -0
- package/src/types.ts +6 -2
- package/src/utils.ts +14 -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.d.ts
CHANGED
|
@@ -1,10 +1,14 @@
|
|
|
1
1
|
import * as _nuxt_schema from '@nuxt/schema';
|
|
2
2
|
import { PrismicPluginOptions } from '@prismicio/vue';
|
|
3
3
|
|
|
4
|
-
declare type PrismicModuleOptions = PrismicPluginOptions & {
|
|
4
|
+
declare type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver' | 'htmlSerializer'> & {
|
|
5
|
+
endpoint: string;
|
|
6
|
+
client?: string;
|
|
7
|
+
linkResolver?: string;
|
|
8
|
+
htmlSerializer?: string;
|
|
5
9
|
preview?: string | false;
|
|
6
10
|
};
|
|
7
11
|
|
|
8
12
|
declare const _default: _nuxt_schema.NuxtModule<PrismicModuleOptions>;
|
|
9
13
|
|
|
10
|
-
export { _default as default };
|
|
14
|
+
export { PrismicModuleOptions as ModuleOptions, PrismicModuleOptions, _default as default };
|
package/dist/module.json
CHANGED
package/dist/module.mjs
CHANGED
|
@@ -1,11 +1,23 @@
|
|
|
1
1
|
import { join } from 'path';
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
2
|
+
import { defineNuxtModule, createResolver, addPlugin, addComponent, addAutoImport, extendPages, addTemplate } from '@nuxt/kit';
|
|
3
|
+
import { cleanDoubleSlashes } from 'ufo';
|
|
4
|
+
import { isRepositoryEndpoint, getRepositoryName } from '@prismicio/client';
|
|
4
5
|
import * as prismicVue from '@prismicio/vue';
|
|
6
|
+
import { existsSync } from 'fs';
|
|
5
7
|
import consola from 'consola';
|
|
6
8
|
|
|
7
9
|
const name = "@nuxtjs/prismic";
|
|
8
|
-
const version = "3.0.0-alpha.
|
|
10
|
+
const version = "3.0.0-alpha.10";
|
|
11
|
+
|
|
12
|
+
const fileExists = (path, extensions = ["js", "ts"]) => {
|
|
13
|
+
if (!path) {
|
|
14
|
+
return null;
|
|
15
|
+
} else if (existsSync(path)) {
|
|
16
|
+
return path;
|
|
17
|
+
}
|
|
18
|
+
const extension = extensions.find((extension2) => existsSync(`${path}.${extension2}`));
|
|
19
|
+
return extension ? `${path}.${extension}` : null;
|
|
20
|
+
};
|
|
9
21
|
|
|
10
22
|
const logger = consola.withScope("nuxt:prismic");
|
|
11
23
|
|
|
@@ -16,29 +28,49 @@ const module = defineNuxtModule({
|
|
|
16
28
|
configKey: "prismic",
|
|
17
29
|
compatibility: { nuxt: "^3.0.0" }
|
|
18
30
|
},
|
|
19
|
-
defaults: {
|
|
31
|
+
defaults: (nuxt) => ({
|
|
20
32
|
endpoint: "",
|
|
21
33
|
clientConfig: {},
|
|
22
|
-
|
|
23
|
-
|
|
34
|
+
client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
|
|
35
|
+
linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
|
|
36
|
+
htmlSerializer: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/htmlSerializer`),
|
|
24
37
|
injectComponents: true,
|
|
25
|
-
components: {
|
|
26
|
-
linkInternalComponent: "nuxt-link"
|
|
27
|
-
},
|
|
38
|
+
components: {},
|
|
28
39
|
preview: "/preview"
|
|
29
|
-
},
|
|
40
|
+
}),
|
|
30
41
|
hooks: {},
|
|
31
42
|
setup(mergedOptions, nuxt) {
|
|
32
43
|
var _a, _b, _c;
|
|
33
|
-
if (!mergedOptions.
|
|
34
|
-
logger.warn("Options `endpoint`
|
|
44
|
+
if (!mergedOptions.endpoint) {
|
|
45
|
+
logger.warn("Options `endpoint` is required, disabling module...");
|
|
35
46
|
return;
|
|
36
47
|
}
|
|
37
48
|
const resolver = createResolver(import.meta.url);
|
|
38
|
-
nuxt.options.build.transpile.push(resolver.resolve("runtime"));
|
|
39
|
-
|
|
40
|
-
|
|
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
|
+
const resolvedPath = path ? path.replace(/^(~~|@@)/, nuxt.options.rootDir).replace(/^(~|@)/, nuxt.options.srcDir) : void 0;
|
|
53
|
+
const maybeUserFile = fileExists(resolvedPath, extensions);
|
|
54
|
+
if (maybeUserFile) {
|
|
55
|
+
logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, "~").replace(nuxt.options.rootDir, "~~").replace(/\\/g, "/")}\``);
|
|
56
|
+
addTemplate({
|
|
57
|
+
filename: resolvedFilename,
|
|
58
|
+
getContents: () => `export { default } from '${path}'`
|
|
59
|
+
});
|
|
60
|
+
} else {
|
|
61
|
+
addTemplate({
|
|
62
|
+
filename: resolvedFilename,
|
|
63
|
+
getContents: () => "export default undefined"
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
};
|
|
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;
|
|
41
72
|
addPlugin(resolver.resolve("runtime/plugin"));
|
|
73
|
+
addPlugin(resolver.resolve("runtime/plugin.client"));
|
|
42
74
|
if (mergedOptions.injectComponents) {
|
|
43
75
|
[
|
|
44
76
|
"PrismicEmbed",
|
|
@@ -63,10 +95,15 @@ const module = defineNuxtModule({
|
|
|
63
95
|
};
|
|
64
96
|
});
|
|
65
97
|
addAutoImport(composableAutoImports);
|
|
98
|
+
addAutoImport({
|
|
99
|
+
name: "usePrismicPreview",
|
|
100
|
+
as: "usePrismicPreview",
|
|
101
|
+
from: resolver.resolve("runtime/usePrismicPreview")
|
|
102
|
+
});
|
|
66
103
|
if (mergedOptions.preview) {
|
|
67
|
-
const
|
|
68
|
-
if (
|
|
69
|
-
logger.info(`Using user-defined preview page at \`${
|
|
104
|
+
const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ["js", "ts", "vue"]);
|
|
105
|
+
if (maybeUserPreviewPage) {
|
|
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}\``);
|
|
70
107
|
} else {
|
|
71
108
|
logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``);
|
|
72
109
|
extendPages((pages) => {
|
|
@@ -77,19 +114,10 @@ const module = defineNuxtModule({
|
|
|
77
114
|
});
|
|
78
115
|
});
|
|
79
116
|
}
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
try {
|
|
85
|
-
repositoryName = new URL(mergedOptions.endpoint).host.split(".")[0];
|
|
86
|
-
} catch (error) {
|
|
87
|
-
repositoryName = mergedOptions.endpoint;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
(_b = nuxt.options).meta || (_b.meta = {});
|
|
91
|
-
(_c = nuxt.options.meta).script || (_c.script = []);
|
|
92
|
-
nuxt.options.meta.script.push({
|
|
117
|
+
const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint) ? getRepositoryName(mergedOptions.endpoint) : mergedOptions.endpoint;
|
|
118
|
+
(_b = nuxt.options.app).head || (_b.head = {});
|
|
119
|
+
(_c = nuxt.options.app.head).script || (_c.script = []);
|
|
120
|
+
nuxt.options.app.head.script.push({
|
|
93
121
|
src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
|
|
94
122
|
});
|
|
95
123
|
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { defineNuxtPlugin, refreshNuxtData } 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
|
+
event.preventDefault();
|
|
8
|
+
refreshNuxtData();
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
});
|
package/dist/runtime/plugin.mjs
CHANGED
|
@@ -1,10 +1,38 @@
|
|
|
1
|
-
import { defineNuxtPlugin } from "#app";
|
|
1
|
+
import { defineNuxtPlugin, useCookie, useRequestEvent, refreshNuxtData } from "#app";
|
|
2
|
+
import NuxtLink from "#app/components/nuxt-link";
|
|
2
3
|
import { createPrismic } from "@prismicio/vue";
|
|
3
|
-
import
|
|
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";
|
|
4
8
|
export default defineNuxtPlugin((nuxtApp) => {
|
|
5
|
-
const mergedOptions = nuxtApp.payload.config[pkgName];
|
|
6
|
-
|
|
9
|
+
const mergedOptions = nuxtApp.payload.config[pkgName] ?? nuxtApp.payload.config.public[pkgName] ?? {};
|
|
10
|
+
const prismicPlugin = createPrismic({
|
|
7
11
|
...mergedOptions,
|
|
8
|
-
|
|
9
|
-
|
|
12
|
+
client,
|
|
13
|
+
linkResolver,
|
|
14
|
+
htmlSerializer,
|
|
15
|
+
injectComponents: false,
|
|
16
|
+
components: {
|
|
17
|
+
linkInternalComponent: NuxtLink,
|
|
18
|
+
linkExternalComponent: NuxtLink,
|
|
19
|
+
...mergedOptions.components
|
|
20
|
+
}
|
|
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
|
+
}
|
|
10
38
|
});
|
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>
|
|
@@ -37,14 +28,15 @@ onMounted(async () => {
|
|
|
37
28
|
position: fixed;
|
|
38
29
|
top: 0;
|
|
39
30
|
left: 0;
|
|
40
|
-
|
|
31
|
+
display: flex;
|
|
41
32
|
justify-content: center;
|
|
42
33
|
align-items: center;
|
|
43
34
|
background: #ffffff;
|
|
44
|
-
|
|
45
|
-
font-family: -apple-system, BlinkMacSystemFont,
|
|
46
|
-
|
|
47
|
-
|
|
35
|
+
color: #666666;
|
|
36
|
+
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
|
|
37
|
+
Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
|
|
38
|
+
font-size: 1rem;
|
|
39
|
+
text-align: center;
|
|
48
40
|
}
|
|
49
41
|
|
|
50
42
|
img {
|
|
@@ -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/dist/types.d.ts
CHANGED
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
|
|
2
|
-
import {
|
|
2
|
+
import { ModuleOptions } from './module'
|
|
3
3
|
|
|
4
|
+
declare module '@nuxt/schema' {
|
|
5
|
+
interface NuxtConfig { ['prismic']?: Partial<ModuleOptions> }
|
|
6
|
+
interface NuxtOptions { ['prismic']?: ModuleOptions }
|
|
7
|
+
}
|
|
4
8
|
|
|
5
9
|
|
|
6
10
|
export { default } from './module'
|
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.10",
|
|
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",
|
|
@@ -36,34 +37,31 @@
|
|
|
36
37
|
"dev": "nuxi dev playground",
|
|
37
38
|
"dev:build": "nuxi build playground",
|
|
38
39
|
"lint": "eslint --ext .js,.ts .",
|
|
39
|
-
"playground:build": "nuxi build playground",
|
|
40
|
-
"playground:dev": "nuxi dev playground",
|
|
41
40
|
"prepare": "nuxi prepare playground && npm run build",
|
|
42
41
|
"release": "npm run build && npm run test && standard-version && git push --follow-tags && npm run build && npm publish",
|
|
43
42
|
"release:alpha": "npm run build && npm run test && standard-version --release-as major --prerelease alpha && git push --follow-tags && npm run build && npm publish --tag alpha",
|
|
44
43
|
"release:alpha:dry": "standard-version --release-as major --prerelease alpha --dry-run",
|
|
45
44
|
"release:dry": "standard-version --dry-run",
|
|
46
45
|
"test": "npm run lint && npm run unit",
|
|
47
|
-
"unit": "
|
|
46
|
+
"unit": "echo \"TODO: vitest & nuxt-test-utils\""
|
|
48
47
|
},
|
|
49
48
|
"dependencies": {
|
|
50
|
-
"@nuxt/kit": "
|
|
49
|
+
"@nuxt/kit": "^3.0.0-rc",
|
|
50
|
+
"@prismicio/client": "^6.6.1",
|
|
51
51
|
"@prismicio/vue": "^3.0.0-beta",
|
|
52
|
-
"consola": "^2.15.3"
|
|
52
|
+
"consola": "^2.15.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
|
-
"
|
|
58
|
-
"
|
|
59
|
-
"
|
|
60
|
-
"
|
|
61
|
-
"standard-version": "^9.3.2",
|
|
62
|
-
"ts-eager": "^2.0.2",
|
|
63
|
-
"typescript": "^4.5.5"
|
|
58
|
+
"eslint": "^8.18.0",
|
|
59
|
+
"nuxt": "^3.0.0-rc",
|
|
60
|
+
"standard-version": "^9.5.0",
|
|
61
|
+
"typescript": "^4.7.4"
|
|
64
62
|
},
|
|
65
63
|
"engines": {
|
|
66
|
-
"node": ">=
|
|
64
|
+
"node": ">=14.15.0"
|
|
67
65
|
},
|
|
68
66
|
"publishConfig": {
|
|
69
67
|
"access": "public"
|
package/src/module.ts
CHANGED
|
@@ -1,13 +1,29 @@
|
|
|
1
1
|
import { join } from 'path'
|
|
2
|
-
import { existsSync } from 'fs'
|
|
3
|
-
import { defineNuxtModule, createResolver, addPlugin, addAutoImport, addComponent, extendPages } from '@nuxt/kit'
|
|
4
2
|
|
|
3
|
+
import {
|
|
4
|
+
defineNuxtModule,
|
|
5
|
+
createResolver,
|
|
6
|
+
addTemplate,
|
|
7
|
+
addPlugin,
|
|
8
|
+
addAutoImport,
|
|
9
|
+
addComponent,
|
|
10
|
+
extendPages
|
|
11
|
+
} from '@nuxt/kit'
|
|
12
|
+
import { cleanDoubleSlashes } from 'ufo'
|
|
13
|
+
|
|
14
|
+
import { isRepositoryEndpoint, getRepositoryName } from '@prismicio/client'
|
|
5
15
|
import * as prismicVue from '@prismicio/vue'
|
|
6
16
|
|
|
7
17
|
import { name as pkgName, version as pkgVersion } from '../package.json'
|
|
8
|
-
import { PrismicModuleOptions } from './types'
|
|
18
|
+
import type { PrismicModuleOptions } from './types'
|
|
19
|
+
import { fileExists } from './utils'
|
|
9
20
|
import { logger } from './logger'
|
|
10
21
|
|
|
22
|
+
// Options export
|
|
23
|
+
export type { PrismicModuleOptions } from './types'
|
|
24
|
+
export type { PrismicModuleOptions as ModuleOptions } from './types'
|
|
25
|
+
|
|
26
|
+
// Module export
|
|
11
27
|
export default defineNuxtModule<PrismicModuleOptions>({
|
|
12
28
|
meta: {
|
|
13
29
|
name: pkgName,
|
|
@@ -15,34 +31,62 @@ export default defineNuxtModule<PrismicModuleOptions>({
|
|
|
15
31
|
configKey: 'prismic',
|
|
16
32
|
compatibility: { nuxt: '^3.0.0' }
|
|
17
33
|
},
|
|
18
|
-
defaults: {
|
|
34
|
+
defaults: nuxt => ({
|
|
19
35
|
endpoint: '',
|
|
20
36
|
clientConfig: {},
|
|
21
|
-
|
|
22
|
-
|
|
37
|
+
client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
|
|
38
|
+
linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
|
|
39
|
+
htmlSerializer: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/htmlSerializer`),
|
|
23
40
|
injectComponents: true,
|
|
24
|
-
components: {
|
|
25
|
-
linkInternalComponent: 'nuxt-link'
|
|
26
|
-
},
|
|
41
|
+
components: {},
|
|
27
42
|
preview: '/preview'
|
|
28
|
-
},
|
|
43
|
+
}),
|
|
29
44
|
hooks: {},
|
|
30
45
|
setup (mergedOptions, nuxt) {
|
|
31
|
-
if (!mergedOptions.
|
|
32
|
-
logger.warn('Options `endpoint`
|
|
46
|
+
if (!mergedOptions.endpoint) {
|
|
47
|
+
logger.warn('Options `endpoint` is required, disabling module...')
|
|
33
48
|
return
|
|
34
49
|
}
|
|
35
50
|
|
|
36
51
|
// Runtime dir boilerplate
|
|
37
52
|
const resolver = createResolver(import.meta.url)
|
|
38
|
-
nuxt.options.build.transpile.push(resolver.resolve('runtime'))
|
|
53
|
+
nuxt.options.build.transpile.push(resolver.resolve('runtime'), '@nuxtjs/prismic', '@prismicio/vue')
|
|
54
|
+
|
|
55
|
+
// Add runtime user code
|
|
56
|
+
const proxyUserFileWithUndefinedFallback = (filename: string, path?: string, extensions = ['js', 'mjs', 'ts']) => {
|
|
57
|
+
const resolvedFilename = `prismic/proxy/${filename}.ts`
|
|
58
|
+
const resolvedPath = path
|
|
59
|
+
? path.replace(/^(~~|@@)/, nuxt.options.rootDir).replace(/^(~|@)/, nuxt.options.srcDir)
|
|
60
|
+
: undefined
|
|
61
|
+
const maybeUserFile = fileExists(resolvedPath, extensions)
|
|
62
|
+
|
|
63
|
+
if (maybeUserFile) {
|
|
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, '/')}\``)
|
|
66
|
+
|
|
67
|
+
addTemplate({
|
|
68
|
+
filename: resolvedFilename,
|
|
69
|
+
getContents: () => `export { default } from '${path}'`
|
|
70
|
+
})
|
|
71
|
+
} else {
|
|
72
|
+
// Else provide `undefined` fallback
|
|
73
|
+
addTemplate({
|
|
74
|
+
filename: resolvedFilename,
|
|
75
|
+
getContents: () => 'export default undefined'
|
|
76
|
+
})
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
proxyUserFileWithUndefinedFallback('client', mergedOptions.client)
|
|
80
|
+
proxyUserFileWithUndefinedFallback('linkResolver', mergedOptions.linkResolver)
|
|
81
|
+
proxyUserFileWithUndefinedFallback('htmlSerializer', mergedOptions.htmlSerializer)
|
|
39
82
|
|
|
40
83
|
// Expose options through public runtime config
|
|
41
|
-
nuxt.options.
|
|
42
|
-
nuxt.options.
|
|
84
|
+
nuxt.options.runtimeConfig.public ||= {} as typeof nuxt.options.runtimeConfig.public
|
|
85
|
+
nuxt.options.runtimeConfig.public[pkgName] = mergedOptions
|
|
43
86
|
|
|
44
87
|
// Add plugin
|
|
45
88
|
addPlugin(resolver.resolve('runtime/plugin'))
|
|
89
|
+
addPlugin(resolver.resolve('runtime/plugin.client'))
|
|
46
90
|
|
|
47
91
|
// Add components auto import
|
|
48
92
|
if (mergedOptions.injectComponents) {
|
|
@@ -74,14 +118,18 @@ export default defineNuxtModule<PrismicModuleOptions>({
|
|
|
74
118
|
}
|
|
75
119
|
})
|
|
76
120
|
addAutoImport(composableAutoImports)
|
|
121
|
+
addAutoImport({
|
|
122
|
+
name: 'usePrismicPreview',
|
|
123
|
+
as: 'usePrismicPreview',
|
|
124
|
+
from: resolver.resolve('runtime/usePrismicPreview')
|
|
125
|
+
})
|
|
77
126
|
|
|
78
127
|
// Add preview route
|
|
79
128
|
if (mergedOptions.preview) {
|
|
80
|
-
const
|
|
129
|
+
const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
|
|
81
130
|
|
|
82
|
-
if (
|
|
83
|
-
logger.info(`Using user-defined preview page at \`${
|
|
84
|
-
userPreviewPagePath.replace(join(nuxt.options.rootDir), '~~').replace(/\\/g, '/')
|
|
131
|
+
if (maybeUserPreviewPage) {
|
|
132
|
+
logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(nuxt.options.rootDir, '~~').replace(/\\/g, '/')
|
|
85
133
|
}\`, available at \`${mergedOptions.preview}\``)
|
|
86
134
|
} else {
|
|
87
135
|
logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
|
|
@@ -95,22 +143,13 @@ export default defineNuxtModule<PrismicModuleOptions>({
|
|
|
95
143
|
})
|
|
96
144
|
}
|
|
97
145
|
|
|
98
|
-
// TODO: Refactor with new client helpers
|
|
99
|
-
let repositoryName = ''
|
|
100
|
-
if (mergedOptions.client) {
|
|
101
|
-
repositoryName = new URL(mergedOptions.client.endpoint).host.split('.')[0]
|
|
102
|
-
} else {
|
|
103
|
-
try {
|
|
104
|
-
repositoryName = new URL(mergedOptions.endpoint).host.split('.')[0]
|
|
105
|
-
} catch (error) {
|
|
106
|
-
repositoryName = mergedOptions.endpoint
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
|
|
110
146
|
// Add toolbar
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
147
|
+
const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint)
|
|
148
|
+
? getRepositoryName(mergedOptions.endpoint)
|
|
149
|
+
: mergedOptions.endpoint
|
|
150
|
+
nuxt.options.app.head ||= {}
|
|
151
|
+
nuxt.options.app.head.script ||= []
|
|
152
|
+
nuxt.options.app.head.script.push({
|
|
114
153
|
src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
|
|
115
154
|
})
|
|
116
155
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { defineNuxtPlugin, refreshNuxtData } 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
|
+
event.preventDefault()
|
|
19
|
+
refreshNuxtData()
|
|
20
|
+
})
|
|
21
|
+
}
|
|
22
|
+
})
|
package/src/runtime/plugin.ts
CHANGED
|
@@ -1,14 +1,66 @@
|
|
|
1
|
-
import { defineNuxtPlugin } from '#app'
|
|
1
|
+
import { defineNuxtPlugin, useCookie, useRequestEvent, refreshNuxtData } from '#app'
|
|
2
|
+
import NuxtLink from '#app/components/nuxt-link'
|
|
3
|
+
|
|
2
4
|
import { createPrismic } from '@prismicio/vue'
|
|
3
5
|
|
|
4
|
-
import { name as pkgName } from '../../package.json'
|
|
6
|
+
// import { name as pkgName } from '../../package.json'
|
|
5
7
|
import { PrismicModuleOptions } from '../types'
|
|
6
8
|
|
|
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'
|
|
18
|
+
|
|
7
19
|
export default defineNuxtPlugin((nuxtApp) => {
|
|
8
|
-
const mergedOptions: PrismicModuleOptions =
|
|
20
|
+
const mergedOptions: PrismicModuleOptions =
|
|
21
|
+
nuxtApp.payload.config[pkgName] ??
|
|
22
|
+
nuxtApp.payload.config.public[pkgName] ??
|
|
23
|
+
{}
|
|
9
24
|
|
|
10
|
-
|
|
25
|
+
const prismicPlugin = createPrismic({
|
|
11
26
|
...mergedOptions,
|
|
12
|
-
|
|
13
|
-
|
|
27
|
+
client,
|
|
28
|
+
linkResolver,
|
|
29
|
+
htmlSerializer,
|
|
30
|
+
injectComponents: false, // Handled at module level
|
|
31
|
+
components: {
|
|
32
|
+
linkInternalComponent: NuxtLink,
|
|
33
|
+
linkExternalComponent: NuxtLink,
|
|
34
|
+
...mergedOptions.components
|
|
35
|
+
}
|
|
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
|
+
}
|
|
14
66
|
})
|
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>
|
|
@@ -37,14 +28,15 @@ onMounted(async () => {
|
|
|
37
28
|
position: fixed;
|
|
38
29
|
top: 0;
|
|
39
30
|
left: 0;
|
|
40
|
-
|
|
31
|
+
display: flex;
|
|
41
32
|
justify-content: center;
|
|
42
33
|
align-items: center;
|
|
43
34
|
background: #ffffff;
|
|
44
|
-
|
|
45
|
-
font-family: -apple-system, BlinkMacSystemFont,
|
|
46
|
-
|
|
47
|
-
|
|
35
|
+
color: #666666;
|
|
36
|
+
font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
|
|
37
|
+
Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
|
|
38
|
+
font-size: 1rem;
|
|
39
|
+
text-align: center;
|
|
48
40
|
}
|
|
49
41
|
|
|
50
42
|
img {
|
|
@@ -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,5 +1,9 @@
|
|
|
1
1
|
import { PrismicPluginOptions } from '@prismicio/vue'
|
|
2
2
|
|
|
3
|
-
export type PrismicModuleOptions = PrismicPluginOptions & {
|
|
4
|
-
|
|
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;
|
|
5
9
|
};
|
package/src/utils.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { existsSync } from 'fs'
|
|
2
|
+
|
|
3
|
+
export const fileExists = (path?: string, extensions = ['js', 'ts']): string | null => {
|
|
4
|
+
if (!path) {
|
|
5
|
+
return null
|
|
6
|
+
} else if (existsSync(path)) {
|
|
7
|
+
// If path already contains/forces the extension
|
|
8
|
+
return path
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const extension = extensions.find(extension => existsSync(`${path}.${extension}`))
|
|
12
|
+
|
|
13
|
+
return extension ? `${path}.${extension}` : null
|
|
14
|
+
}
|