@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 +1 -1
- package/dist/module.json +1 -1
- package/dist/module.mjs +13 -7
- package/dist/runtime/plugin.client.d.ts +2 -0
- package/dist/runtime/plugin.client.mjs +13 -0
- package/dist/runtime/plugin.mjs +18 -2
- 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 +8 -7
- package/src/module.ts +12 -6
- package/src/runtime/plugin.client.ts +24 -0
- package/src/runtime/plugin.ts +31 -2
- 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.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,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
|
+
});
|
package/dist/runtime/plugin.mjs
CHANGED
|
@@ -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
|
-
|
|
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
|
});
|
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.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.
|
|
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
|
+
"eslint": "^8.18.0",
|
|
58
59
|
"nuxt": "^3.0.0-rc",
|
|
59
|
-
"standard-version": "^9.
|
|
60
|
-
"typescript": "^4.
|
|
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,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
|
+
})
|
package/src/runtime/plugin.ts
CHANGED
|
@@ -22,7 +22,7 @@ export default defineNuxtPlugin((nuxtApp) => {
|
|
|
22
22
|
nuxtApp.payload.config.public[pkgName] ??
|
|
23
23
|
{}
|
|
24
24
|
|
|
25
|
-
|
|
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
|
})
|
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
|
+
}
|