@nuxtjs/prismic 4.0.1 → 4.1.0-pr.235.3e7479b
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/LICENSE +1 -1
- package/README.md +18 -32
- package/dist/module.d.mts +48 -75
- package/dist/module.json +3 -3
- package/dist/module.mjs +193 -242
- package/dist/runtime/PrismicPreview.d.vue.ts +3 -0
- package/dist/runtime/PrismicPreview.vue +8 -14
- package/dist/runtime/PrismicPreview.vue.d.ts +3 -0
- package/dist/runtime/plugin.client.js +13 -7
- package/dist/runtime/plugin.js +89 -72
- package/dist/runtime/usePrismicPreview.d.ts +1 -5
- package/dist/runtime/usePrismicPreview.js +3 -3
- package/dist/types.d.mts +3 -1
- package/package.json +41 -45
- package/src/module.ts +352 -185
- package/src/runtime/PrismicPreview.vue +12 -16
- package/src/runtime/plugin.client.ts +16 -12
- package/src/runtime/plugin.ts +114 -103
- package/src/runtime/usePrismicPreview.ts +7 -11
- package/dist/client/200.html +0 -1
- package/dist/client/404.html +0 -1
- package/dist/client/_nuxt/BMD6bpEv.js +0 -1
- package/dist/client/_nuxt/BQB6UGbx.js +0 -25
- package/dist/client/_nuxt/CkG7IjgS.js +0 -1
- package/dist/client/_nuxt/DlAUqK2U.js +0 -1
- package/dist/client/_nuxt/H1okkFcd.js +0 -1
- package/dist/client/_nuxt/RYS3n4u0.js +0 -1
- package/dist/client/_nuxt/V_weDLQm.js +0 -1
- package/dist/client/_nuxt/builds/latest.json +0 -1
- package/dist/client/_nuxt/builds/meta/f4865457-86fc-49e4-8a56-18ed8a000da8.json +0 -1
- package/dist/client/_nuxt/entry.BC9BDAld.css +0 -1
- package/dist/client/_nuxt/error-404.smTsHvdw.css +0 -1
- package/dist/client/_nuxt/error-500.Bo-s0s94.css +0 -1
- package/dist/client/_nuxt/index.C4BggqQh.css +0 -1
- package/dist/client/index.html +0 -1
- package/dist/module.cjs +0 -5
- package/dist/module.d.ts +0 -136
- package/dist/types.d.ts +0 -1
- package/src/devtools/index.ts +0 -127
- package/src/devtools/types.ts +0 -22
- package/src/lib/fileExists.ts +0 -15
- package/src/lib/index.ts +0 -2
- package/src/lib/logger.ts +0 -3
- package/src/types.ts +0 -137
package/dist/module.mjs
CHANGED
|
@@ -1,289 +1,240 @@
|
|
|
1
|
-
import { join } from 'node:path';
|
|
2
|
-
import { readFile } from 'node:fs/promises';
|
|
3
1
|
import { existsSync } from 'node:fs';
|
|
2
|
+
import { readFile } from 'node:fs/promises';
|
|
3
|
+
import { join } from 'node:path';
|
|
4
|
+
import { defineNuxtModule, createResolver, useLogger, addPlugin, addComponent, addImports, extendPages, getNuxtVersion, addTemplate } from '@nuxt/kit';
|
|
4
5
|
import { defu } from 'defu';
|
|
5
|
-
import { useLogger, defineNuxtModule, getNuxtVersion, createResolver, addPlugin, addComponent, addImports, extendPages, addTemplate } from '@nuxt/kit';
|
|
6
|
-
import * as prismicVue from '@prismicio/vue';
|
|
7
|
-
import { onDevToolsInitialized, extendServerRpc, startSubprocess } from '@nuxt/devtools-kit';
|
|
8
|
-
import { resolve } from 'pathe';
|
|
9
|
-
import terminate from 'terminate';
|
|
10
|
-
|
|
11
|
-
const RPC_NAMESPACE = "prismic-slicemachine-rpc";
|
|
12
|
-
var SliceMachineStatus = /* @__PURE__ */ ((SliceMachineStatus2) => {
|
|
13
|
-
SliceMachineStatus2[SliceMachineStatus2["STARTED"] = 0] = "STARTED";
|
|
14
|
-
SliceMachineStatus2[SliceMachineStatus2["STOPPED"] = 1] = "STOPPED";
|
|
15
|
-
return SliceMachineStatus2;
|
|
16
|
-
})(SliceMachineStatus || {});
|
|
17
|
-
|
|
18
|
-
const DEVTOOLS_UI_ROUTE = "/__prismic-client";
|
|
19
|
-
const DEVTOOLS_UI_LOCAL_PORT = 5173;
|
|
20
|
-
let subProcess = null;
|
|
21
|
-
const stopSubprocess = () => {
|
|
22
|
-
if (subProcess) {
|
|
23
|
-
const pid = subProcess.getProcess().pid;
|
|
24
|
-
if (pid) {
|
|
25
|
-
terminate(pid);
|
|
26
|
-
}
|
|
27
|
-
subProcess.terminate();
|
|
28
|
-
subProcess = null;
|
|
29
|
-
}
|
|
30
|
-
};
|
|
31
|
-
const setupDevToolsUI = (nuxt, resolver) => {
|
|
32
|
-
const clientPath = resolver.resolve("./client");
|
|
33
|
-
const isProductionBuild = existsSync(clientPath);
|
|
34
|
-
if (isProductionBuild) {
|
|
35
|
-
nuxt.hook("vite:serverCreated", async (server) => {
|
|
36
|
-
const sirv = await import('sirv').then((r) => r.default || r);
|
|
37
|
-
server.middlewares.use(
|
|
38
|
-
DEVTOOLS_UI_ROUTE,
|
|
39
|
-
sirv(clientPath, { dev: true, single: true })
|
|
40
|
-
);
|
|
41
|
-
});
|
|
42
|
-
} else {
|
|
43
|
-
nuxt.hook("vite:extendConfig", (config) => {
|
|
44
|
-
config.server = config.server || {};
|
|
45
|
-
config.server.proxy = config.server.proxy || {};
|
|
46
|
-
config.server.proxy[DEVTOOLS_UI_ROUTE] = {
|
|
47
|
-
target: `http://localhost:${DEVTOOLS_UI_LOCAL_PORT}${DEVTOOLS_UI_ROUTE}`,
|
|
48
|
-
changeOrigin: true,
|
|
49
|
-
followRedirects: true,
|
|
50
|
-
ws: true,
|
|
51
|
-
rewrite: (path) => path.replace(DEVTOOLS_UI_ROUTE, "")
|
|
52
|
-
};
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
nuxt.hooks.hook("close", () => {
|
|
56
|
-
stopSubprocess();
|
|
57
|
-
});
|
|
58
|
-
process.on("exit", () => {
|
|
59
|
-
stopSubprocess();
|
|
60
|
-
});
|
|
61
|
-
onDevToolsInitialized(() => {
|
|
62
|
-
const rpc = extendServerRpc(
|
|
63
|
-
RPC_NAMESPACE,
|
|
64
|
-
{
|
|
65
|
-
async getSlicemachineConfig() {
|
|
66
|
-
const configPath = resolve(nuxt.options.rootDir, "slicemachine.config.json");
|
|
67
|
-
if (existsSync(configPath)) {
|
|
68
|
-
return JSON.parse(await readFile(configPath, "utf-8"));
|
|
69
|
-
}
|
|
70
|
-
return null;
|
|
71
|
-
},
|
|
72
|
-
isSliceMachineStarted() {
|
|
73
|
-
return subProcess !== null;
|
|
74
|
-
},
|
|
75
|
-
startSliceMachine() {
|
|
76
|
-
stopSubprocess();
|
|
77
|
-
subProcess = startSubprocess({
|
|
78
|
-
command: "npx",
|
|
79
|
-
args: ["start-slicemachine"],
|
|
80
|
-
cwd: nuxt.options.rootDir
|
|
81
|
-
}, {
|
|
82
|
-
id: "slicemachine",
|
|
83
|
-
name: "SliceMachine",
|
|
84
|
-
icon: "i-simple-icons-prismic"
|
|
85
|
-
}, nuxt);
|
|
86
|
-
rpc.broadcast.updateStatus(SliceMachineStatus.STARTED);
|
|
87
|
-
return SliceMachineStatus.STARTED;
|
|
88
|
-
},
|
|
89
|
-
stopSliceMachine() {
|
|
90
|
-
stopSubprocess();
|
|
91
|
-
rpc.broadcast.updateStatus(SliceMachineStatus.STOPPED);
|
|
92
|
-
return SliceMachineStatus.STOPPED;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
);
|
|
96
|
-
});
|
|
97
|
-
nuxt.hook("devtools:customTabs", (tabs) => {
|
|
98
|
-
tabs.push({
|
|
99
|
-
// unique identifier
|
|
100
|
-
name: "prismic",
|
|
101
|
-
// title to display in the tab
|
|
102
|
-
title: "Prismic",
|
|
103
|
-
// any icon from Iconify, or a URL to an image
|
|
104
|
-
icon: "i-simple-icons-prismic",
|
|
105
|
-
// iframe view
|
|
106
|
-
view: {
|
|
107
|
-
type: "iframe",
|
|
108
|
-
src: DEVTOOLS_UI_ROUTE
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
};
|
|
113
|
-
|
|
114
|
-
const logger = useLogger("nuxt:prismic");
|
|
115
6
|
|
|
116
|
-
const
|
|
117
|
-
if (!path) {
|
|
118
|
-
return null;
|
|
119
|
-
} else if (existsSync(path)) {
|
|
120
|
-
return path;
|
|
121
|
-
}
|
|
122
|
-
const extension = extensions.find((extension2) => existsSync(`${path}.${extension2}`));
|
|
123
|
-
return extension ? `${path}.${extension}` : null;
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
const module = defineNuxtModule({
|
|
7
|
+
const module$1 = defineNuxtModule({
|
|
127
8
|
meta: {
|
|
128
9
|
name: "@nuxtjs/prismic",
|
|
129
10
|
configKey: "prismic",
|
|
130
11
|
compatibility: { nuxt: ">=3.7.0" }
|
|
131
12
|
},
|
|
132
13
|
defaults: (nuxt) => {
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
linkResolver: "~/prismic/linkResolver",
|
|
147
|
-
richTextSerializer: "~/prismic/richTextSerializer"
|
|
148
|
-
};
|
|
149
|
-
prismicComponentsFiles = {
|
|
150
|
-
linkRel: "~/prismic/linkRel",
|
|
151
|
-
richTextComponents: "~/prismic/richTextComponents",
|
|
152
|
-
sliceZoneDefaultComponent: "~/prismic/sliceZoneDefaultComponent"
|
|
14
|
+
const nuxt3flavor = getNuxtVersion(nuxt).startsWith("3") && !nuxt.options?.future?.compatibilityVersion;
|
|
15
|
+
if (nuxt3flavor) {
|
|
16
|
+
return {
|
|
17
|
+
endpoint: "u",
|
|
18
|
+
environment: "",
|
|
19
|
+
clientConfig: {},
|
|
20
|
+
client: "~/app/prismic/client",
|
|
21
|
+
preview: "/preview",
|
|
22
|
+
toolbar: true,
|
|
23
|
+
componentsConfig: {
|
|
24
|
+
linkResolver: "~/app/prismic/linkResolver",
|
|
25
|
+
defaultComponents: "~/app/prismic/defaultComponents"
|
|
26
|
+
}
|
|
153
27
|
};
|
|
154
28
|
}
|
|
155
29
|
return {
|
|
156
30
|
endpoint: "",
|
|
157
31
|
environment: "",
|
|
32
|
+
client: "~/prismic/client",
|
|
158
33
|
clientConfig: {},
|
|
159
|
-
...prismicFiles,
|
|
160
|
-
injectComponents: true,
|
|
161
|
-
components: prismicComponentsFiles,
|
|
162
34
|
preview: "/preview",
|
|
163
35
|
toolbar: true,
|
|
164
|
-
|
|
36
|
+
componentsConfig: {
|
|
37
|
+
linkResolver: "~/prismic/linkResolver",
|
|
38
|
+
defaultComponents: "~/prismic/defaultComponents"
|
|
39
|
+
}
|
|
165
40
|
};
|
|
166
41
|
},
|
|
167
|
-
hooks: {},
|
|
168
42
|
setup(options, nuxt) {
|
|
169
|
-
nuxt.options.runtimeConfig.public ||= {};
|
|
170
|
-
const moduleOptions = defu(nuxt.options.runtimeConfig.public.prismic, options);
|
|
171
|
-
nuxt.options.runtimeConfig.public.prismic = moduleOptions;
|
|
172
43
|
const resolver = createResolver(import.meta.url);
|
|
173
|
-
|
|
174
|
-
|
|
44
|
+
const logger = useLogger("nuxt:prismic");
|
|
45
|
+
const moduleOptions = defu(
|
|
46
|
+
nuxt.options.runtimeConfig.public?.prismic,
|
|
47
|
+
options
|
|
48
|
+
);
|
|
49
|
+
exposeRuntimeConfig();
|
|
50
|
+
transpileDependencies();
|
|
51
|
+
const ok = proxyUserFiles();
|
|
52
|
+
if (!ok) return;
|
|
53
|
+
addRuntimePlugins();
|
|
54
|
+
addAutoImports();
|
|
55
|
+
addPreviewRoute();
|
|
56
|
+
extendESLintConfig();
|
|
57
|
+
function exposeRuntimeConfig() {
|
|
58
|
+
nuxt.options.runtimeConfig.public ||= {};
|
|
59
|
+
nuxt.options.runtimeConfig.public.prismic = moduleOptions;
|
|
60
|
+
}
|
|
61
|
+
function transpileDependencies() {
|
|
62
|
+
nuxt.options.build.transpile.push(
|
|
63
|
+
resolver.resolve("runtime"),
|
|
64
|
+
"@nuxtjs/prismic",
|
|
65
|
+
"@prismicio/vue"
|
|
66
|
+
);
|
|
67
|
+
nuxt.options.vite.optimizeDeps ||= {};
|
|
68
|
+
nuxt.options.vite.optimizeDeps.exclude ||= [];
|
|
69
|
+
nuxt.options.vite.optimizeDeps.exclude.push("@prismicio/vue");
|
|
175
70
|
}
|
|
176
|
-
|
|
177
|
-
const
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
71
|
+
function proxyUserFiles() {
|
|
72
|
+
const proxyUserFileWithUndefinedFallback = (filename, path) => {
|
|
73
|
+
const resolvedFilename = `prismic/proxy/${filename}.ts`;
|
|
74
|
+
const resolvedPath = path.replace(/^(~~|@@)/, nuxt.options.rootDir).replace(/^(~|@)/, nuxt.options.srcDir);
|
|
75
|
+
const maybeUserFile = fileExists(resolvedPath, [
|
|
76
|
+
"js",
|
|
77
|
+
"mjs",
|
|
78
|
+
"ts",
|
|
79
|
+
"vue"
|
|
80
|
+
]);
|
|
81
|
+
if (maybeUserFile) {
|
|
82
|
+
logger.info(
|
|
83
|
+
`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, "~").replace(nuxt.options.rootDir, "~~").replace(/\\/g, "/")}\``
|
|
84
|
+
);
|
|
85
|
+
addTemplate({
|
|
86
|
+
filename: resolvedFilename,
|
|
87
|
+
getContents: () => `export { default } from '${path}'`
|
|
88
|
+
});
|
|
89
|
+
return true;
|
|
90
|
+
} else {
|
|
91
|
+
addTemplate({
|
|
92
|
+
filename: resolvedFilename,
|
|
93
|
+
getContents: () => "export default undefined"
|
|
94
|
+
});
|
|
95
|
+
return false;
|
|
184
96
|
}
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
});
|
|
97
|
+
};
|
|
98
|
+
const proxiedUserClient = proxyUserFileWithUndefinedFallback(
|
|
99
|
+
"client",
|
|
100
|
+
moduleOptions.client
|
|
101
|
+
);
|
|
102
|
+
if (!moduleOptions.endpoint && !proxiedUserClient && !process.env.NUXT_PUBLIC_PRISMIC_ENDPOINT) {
|
|
103
|
+
logger.warn(
|
|
104
|
+
`\`endpoint\` option is missing and \`${moduleOptions.client}\` was not found. At least one of them is required for the module to run. Disabling module...`
|
|
105
|
+
);
|
|
195
106
|
return false;
|
|
196
107
|
}
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
108
|
+
proxyUserFileWithUndefinedFallback(
|
|
109
|
+
"linkResolver",
|
|
110
|
+
moduleOptions.componentsConfig.linkResolver
|
|
111
|
+
);
|
|
112
|
+
proxyUserFileWithUndefinedFallback(
|
|
113
|
+
"defaultComponents",
|
|
114
|
+
moduleOptions.componentsConfig.defaultComponents
|
|
115
|
+
);
|
|
116
|
+
return true;
|
|
202
117
|
}
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@nuxtjs/prismic", "@prismicio/vue");
|
|
209
|
-
nuxt.options.vite.optimizeDeps ||= {};
|
|
210
|
-
nuxt.options.vite.optimizeDeps.exclude ||= [];
|
|
211
|
-
nuxt.options.vite.optimizeDeps.exclude.push("@prismicio/vue");
|
|
212
|
-
addPlugin(resolver.resolve("runtime/plugin"));
|
|
213
|
-
addPlugin(resolver.resolve("runtime/plugin.client"));
|
|
214
|
-
if (moduleOptions.injectComponents) {
|
|
118
|
+
function addRuntimePlugins() {
|
|
119
|
+
addPlugin(resolver.resolve("runtime/plugin"));
|
|
120
|
+
addPlugin(resolver.resolve("runtime/plugin.client"));
|
|
121
|
+
}
|
|
122
|
+
function addAutoImports() {
|
|
215
123
|
[
|
|
216
|
-
"PrismicEmbed",
|
|
217
124
|
"PrismicImage",
|
|
218
125
|
"PrismicLink",
|
|
219
126
|
"PrismicText",
|
|
220
127
|
"PrismicRichText",
|
|
128
|
+
"PrismicTable",
|
|
221
129
|
"SliceZone"
|
|
222
|
-
].forEach((
|
|
130
|
+
].forEach((entry) => {
|
|
223
131
|
addComponent({
|
|
224
|
-
name:
|
|
225
|
-
export:
|
|
132
|
+
name: entry,
|
|
133
|
+
export: entry,
|
|
226
134
|
filePath: "@prismicio/vue"
|
|
227
135
|
});
|
|
228
136
|
});
|
|
137
|
+
addImports(
|
|
138
|
+
[
|
|
139
|
+
"usePrismic",
|
|
140
|
+
"getSliceComponentProps",
|
|
141
|
+
"defineSliceZoneComponents",
|
|
142
|
+
"getRichTextComponentProps",
|
|
143
|
+
"getTableComponentProps"
|
|
144
|
+
].map((entry) => ({ name: entry, as: entry, from: "@prismicio/vue" }))
|
|
145
|
+
);
|
|
146
|
+
addImports({
|
|
147
|
+
name: "usePrismicPreview",
|
|
148
|
+
as: "usePrismicPreview",
|
|
149
|
+
from: resolver.resolve("runtime/usePrismicPreview")
|
|
150
|
+
});
|
|
229
151
|
}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
152
|
+
function addPreviewRoute() {
|
|
153
|
+
if (moduleOptions.preview) {
|
|
154
|
+
const maybeUserPreviewPage = fileExists(
|
|
155
|
+
join(
|
|
156
|
+
nuxt.options.srcDir,
|
|
157
|
+
nuxt.options.dir.pages,
|
|
158
|
+
moduleOptions.preview
|
|
159
|
+
),
|
|
160
|
+
["js", "ts", "vue"]
|
|
161
|
+
);
|
|
162
|
+
if (maybeUserPreviewPage) {
|
|
163
|
+
logger.info(
|
|
164
|
+
`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(nuxt.options.rootDir, "~~").replace(
|
|
165
|
+
/\\/g,
|
|
166
|
+
"/"
|
|
167
|
+
)}\`, available at \`${moduleOptions.preview}\``
|
|
168
|
+
);
|
|
169
|
+
} else {
|
|
170
|
+
logger.info(
|
|
171
|
+
`Using default preview page, available at \`${moduleOptions.preview}\``
|
|
172
|
+
);
|
|
173
|
+
extendPages((pages) => {
|
|
174
|
+
pages.unshift({
|
|
175
|
+
name: "prismic-preview",
|
|
176
|
+
path: moduleOptions.preview,
|
|
177
|
+
// Checked before
|
|
178
|
+
file: resolver.resolve("runtime/PrismicPreview.vue")
|
|
179
|
+
});
|
|
255
180
|
});
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
181
|
+
}
|
|
182
|
+
if (!moduleOptions.toolbar) {
|
|
183
|
+
logger.warn(
|
|
184
|
+
"`toolbar` option is disabled but `preview` is enabled. Previews won't work unless you manually load the toolbar."
|
|
185
|
+
);
|
|
186
|
+
}
|
|
260
187
|
}
|
|
261
188
|
}
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
const
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
189
|
+
function extendESLintConfig() {
|
|
190
|
+
nuxt.hook(
|
|
191
|
+
// @ts-expect-error 3rd party hook
|
|
192
|
+
"eslint:config:addons",
|
|
193
|
+
(addons) => {
|
|
194
|
+
addons.push({
|
|
195
|
+
name: "@nuxtjs/prismic",
|
|
196
|
+
async getConfigs() {
|
|
197
|
+
const configPath = resolver.resolve(
|
|
198
|
+
nuxt.options.rootDir,
|
|
199
|
+
"slicemachine.config.json"
|
|
200
|
+
);
|
|
201
|
+
const configs = [];
|
|
202
|
+
try {
|
|
203
|
+
if (existsSync(configPath)) {
|
|
204
|
+
const config = JSON.parse(await readFile(configPath, "utf-8"));
|
|
205
|
+
if (config && "libraries" in config && Array.isArray(config.libraries)) {
|
|
206
|
+
configs.push(
|
|
207
|
+
JSON.stringify({
|
|
208
|
+
files: config.libraries.map(
|
|
209
|
+
(library) => `${library.replace("./", "")}/**/index.vue`
|
|
210
|
+
),
|
|
211
|
+
rules: {
|
|
212
|
+
"vue/multi-word-component-names": "off"
|
|
213
|
+
}
|
|
214
|
+
})
|
|
215
|
+
);
|
|
276
216
|
}
|
|
277
|
-
}
|
|
217
|
+
}
|
|
218
|
+
} catch {
|
|
278
219
|
}
|
|
220
|
+
return { configs };
|
|
279
221
|
}
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
return { configs };
|
|
222
|
+
});
|
|
283
223
|
}
|
|
284
|
-
|
|
285
|
-
}
|
|
224
|
+
);
|
|
225
|
+
}
|
|
286
226
|
}
|
|
287
227
|
});
|
|
228
|
+
function fileExists(path, extensions = ["js", "ts"]) {
|
|
229
|
+
if (!path) {
|
|
230
|
+
return null;
|
|
231
|
+
} else if (existsSync(path)) {
|
|
232
|
+
return path;
|
|
233
|
+
}
|
|
234
|
+
const extension = extensions.find(
|
|
235
|
+
(extension2) => existsSync(`${path}.${extension2}`)
|
|
236
|
+
);
|
|
237
|
+
return extension ? `${path}.${extension}` : null;
|
|
238
|
+
}
|
|
288
239
|
|
|
289
|
-
export { module as default };
|
|
240
|
+
export { module$1 as default };
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
declare const _default: typeof __VLS_export;
|
|
2
|
+
export default _default;
|
|
3
|
+
declare const __VLS_export: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
@@ -1,27 +1,21 @@
|
|
|
1
|
+
<script setup>
|
|
2
|
+
import { usePrismicPreview, useSeoMeta } from "#imports";
|
|
3
|
+
useSeoMeta({ title: "Prismic Preview - Loading" });
|
|
4
|
+
usePrismicPreview();
|
|
5
|
+
</script>
|
|
6
|
+
|
|
1
7
|
<template>
|
|
2
8
|
<section class="prismic-preview">
|
|
3
9
|
<figure>
|
|
4
10
|
<img
|
|
5
11
|
src=""
|
|
6
12
|
alt="Prismic"
|
|
7
|
-
|
|
8
|
-
<figcaption>
|
|
9
|
-
Loading preview...
|
|
10
|
-
</figcaption>
|
|
13
|
+
/>
|
|
14
|
+
<figcaption>Loading preview...</figcaption>
|
|
11
15
|
</figure>
|
|
12
16
|
</section>
|
|
13
17
|
</template>
|
|
14
18
|
|
|
15
|
-
<script setup>
|
|
16
|
-
import { useHead, usePrismicPreview } from '#imports'
|
|
17
|
-
|
|
18
|
-
useHead({
|
|
19
|
-
title: 'Prismic Preview - Loading',
|
|
20
|
-
})
|
|
21
|
-
|
|
22
|
-
usePrismicPreview()
|
|
23
|
-
</script>
|
|
24
|
-
|
|
25
19
|
<style scoped>
|
|
26
20
|
.prismic-preview{align-items:center;background:#fff;color:#666;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;font-size:1rem;height:100vh;justify-content:center;left:0;position:fixed;text-align:center;top:0;width:100%}img{margin-bottom:1.25rem}
|
|
27
21
|
</style>
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
declare const _default: typeof __VLS_export;
|
|
2
|
+
export default _default;
|
|
3
|
+
declare const __VLS_export: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
import { defineNuxtPlugin } from "#app";
|
|
2
2
|
import { refreshNuxtData, useRuntimeConfig } from "#imports";
|
|
3
|
-
export default defineNuxtPlugin(
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
3
|
+
export default defineNuxtPlugin({
|
|
4
|
+
name: "prismic:plugin:client",
|
|
5
|
+
parallel: true,
|
|
6
|
+
setup() {
|
|
7
|
+
hotReloadPrismicPreview();
|
|
8
|
+
function hotReloadPrismicPreview() {
|
|
9
|
+
if (useRuntimeConfig().public.prismic?.preview) {
|
|
10
|
+
window.addEventListener("prismicPreviewUpdate", (event) => {
|
|
11
|
+
event.preventDefault();
|
|
12
|
+
refreshNuxtData();
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
}
|
|
10
16
|
}
|
|
11
17
|
});
|