@nuxtjs/prismic 3.0.0-alpha.0 → 3.0.0-alpha.3

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
@@ -29,13 +29,13 @@ Easily connect your Nuxt.js application to your content hosted on [Prismic][pris
29
29
  npm install --save-dev @nuxtjs/prismic@alpha # or yarn add --dev @nuxtjs/prismic@alpha
30
30
  ```
31
31
 
32
- Then, add `@nuxtjs/prismic` to the `buildModules` section of your Nuxt config and configure your Prismic API endpoint:
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
35
  import { defineNuxtConfig } from 'nuxt3'
36
36
 
37
37
  export default defineNuxtConfig({
38
- buildModules: ['@nuxtjs/prismic'],
38
+ modules: ['@nuxtjs/prismic'],
39
39
  prismic: {
40
40
  endpoint: 'my-repository'
41
41
  },
package/dist/module.d.ts CHANGED
@@ -1,10 +1,13 @@
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'> & {
5
+ endpoint: string;
6
+ client?: string;
7
+ linkResolver?: string;
5
8
  preview?: string | false;
6
9
  };
7
10
 
8
11
  declare const _default: _nuxt_schema.NuxtModule<PrismicModuleOptions>;
9
12
 
10
- export { _default as default };
13
+ export { PrismicModuleOptions as ModuleOptions, PrismicModuleOptions, _default as default };
package/dist/module.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nuxtjs/prismic",
3
- "version": "3.0.0-alpha.0",
3
+ "version": "3.0.0-alpha.3",
4
4
  "configKey": "prismic",
5
5
  "compatibility": {
6
6
  "nuxt": "^3.0.0"
package/dist/module.mjs CHANGED
@@ -1,11 +1,23 @@
1
1
  import { join } from 'path';
2
- import { existsSync } from 'fs';
3
- import { defineNuxtModule, createResolver, addPlugin, addAutoImport, extendPages } from '@nuxt/kit';
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.0";
10
+ const version = "3.0.0-alpha.3";
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,63 @@ 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
- linkResolver: void 0,
34
+ client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
35
+ linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
23
36
  htmlSerializer: void 0,
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.client && !mergedOptions.endpoint) {
34
- logger.warn("Options `endpoint` or `client` are required, disabling module...");
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"));
49
+ nuxt.options.build.transpile.push(resolver.resolve("runtime"), "@prismicio/vue");
50
+ const addUserFileWithUndefinedFallback = (filename, path, extensions = ["js", "ts"]) => {
51
+ const resolvedFilename = `prismic/${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(/\\/g, "/")}\``);
56
+ addTemplate({
57
+ filename: resolvedFilename,
58
+ src: maybeUserFile
59
+ });
60
+ } else {
61
+ addTemplate({
62
+ filename: resolvedFilename,
63
+ getContents: () => "export default undefined"
64
+ });
65
+ }
66
+ };
67
+ addUserFileWithUndefinedFallback("client", mergedOptions.client);
68
+ addUserFileWithUndefinedFallback("linkResolver", mergedOptions.linkResolver);
39
69
  (_a = nuxt.options).publicRuntimeConfig || (_a.publicRuntimeConfig = {});
40
70
  nuxt.options.publicRuntimeConfig[name] = mergedOptions;
41
71
  addPlugin(resolver.resolve("runtime/plugin"));
72
+ if (mergedOptions.injectComponents) {
73
+ [
74
+ "PrismicEmbed",
75
+ "PrismicImage",
76
+ "PrismicLink",
77
+ "PrismicText",
78
+ "PrismicRichText",
79
+ "SliceZone"
80
+ ].forEach((component) => {
81
+ addComponent({
82
+ name: component,
83
+ export: component,
84
+ filePath: "@prismicio/vue"
85
+ });
86
+ });
87
+ }
42
88
  const composableAutoImports = Object.keys(prismicVue).filter((key) => key.startsWith("use")).map((key) => {
43
89
  return {
44
90
  name: key,
@@ -48,9 +94,9 @@ const module = defineNuxtModule({
48
94
  });
49
95
  addAutoImport(composableAutoImports);
50
96
  if (mergedOptions.preview) {
51
- const userPreviewPagePath = join(nuxt.options.srcDir, nuxt.options.dir.pages, `${mergedOptions.preview}.vue`);
52
- if (existsSync(userPreviewPagePath)) {
53
- logger.info(`Using user-defined preview page at \`${userPreviewPagePath.replace(join(nuxt.options.rootDir), "~~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
97
+ const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ["js", "ts", "vue"]);
98
+ if (maybeUserPreviewPage) {
99
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), "~").replace(/\\/g, "/")}\`, available at \`${mergedOptions.preview}\``);
54
100
  } else {
55
101
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``);
56
102
  extendPages((pages) => {
@@ -61,19 +107,10 @@ const module = defineNuxtModule({
61
107
  });
62
108
  });
63
109
  }
64
- let repositoryName = "";
65
- if (mergedOptions.client) {
66
- repositoryName = new URL(mergedOptions.client.endpoint).host.split(".")[0];
67
- } else {
68
- try {
69
- repositoryName = new URL(mergedOptions.endpoint).host.split(".")[0];
70
- } catch (error) {
71
- repositoryName = mergedOptions.endpoint;
72
- }
73
- }
74
- (_b = nuxt.options).meta || (_b.meta = {});
75
- (_c = nuxt.options.meta).script || (_c.script = []);
76
- nuxt.options.meta.script.push({
110
+ const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint) ? getRepositoryName(mergedOptions.endpoint) : mergedOptions.endpoint;
111
+ (_b = nuxt.options).head || (_b.head = {});
112
+ (_c = nuxt.options.head).script || (_c.script = []);
113
+ nuxt.options.head.script.push({
77
114
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
78
115
  });
79
116
  }
@@ -1,7 +1,20 @@
1
1
  import { defineNuxtPlugin } from "#app";
2
+ import NuxtLink from "#app/components/nuxt-link";
2
3
  import { createPrismic } from "@prismicio/vue";
3
4
  import { name as pkgName } from "../../package.json";
5
+ import linkResolver from "#build/prismic/linkResolver";
6
+ import client from "#build/prismic/client";
4
7
  export default defineNuxtPlugin((nuxtApp) => {
5
8
  const mergedOptions = nuxtApp.payload.config[pkgName];
6
- nuxtApp.vueApp.use(createPrismic(mergedOptions));
9
+ nuxtApp.vueApp.use(createPrismic({
10
+ ...mergedOptions,
11
+ client,
12
+ linkResolver,
13
+ injectComponents: false,
14
+ components: {
15
+ linkInternalComponent: NuxtLink,
16
+ linkExternalComponent: NuxtLink,
17
+ ...mergedOptions.components
18
+ }
19
+ }));
7
20
  });
@@ -4,7 +4,7 @@
4
4
  <img
5
5
  src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="140" height="36">
  <path fill="#212735" fill-rule="evenodd" d="M35.538 18.74l-2.655-2.66a1.126 1.126 0 0 1-.329-.796v-3.256c0-3.009-.313-4.1-.9-5.2a6.127 6.127 0 0 0-2.546-2.551c-1.097-.589-2.186-.902-5.188-.902h-4.295a.225.225 0 0 1-.158-.384L22.122.33c.21-.211.496-.33.794-.33h1.493c4.003 0 5.455.418 6.919 1.202a8.169 8.169 0 0 1 3.394 3.402c.783 1.467 1.2 2.922 1.2 6.933v7.045a.225.225 0 0 1-.384.159zM17.222 35.617l2.655-2.661c.21-.211.496-.33.794-.33h3.249c3.002 0 4.09-.313 5.188-.902a6.127 6.127 0 0 0 2.546-2.551c.587-1.1.9-2.191.9-5.2v-4.304a.225.225 0 0 1 .383-.159l2.656 2.661c.21.211.329.498.329.796v1.497c0 4.011-.417 5.466-1.2 6.933a8.169 8.169 0 0 1-3.394 3.402C29.864 35.582 28.412 36 24.409 36H17.38a.225.225 0 0 1-.158-.384zM.383 17.259L3.04 19.92c.21.211.329.498.329.796v3.256c0 3.009.312 4.1.9 5.2a6.127 6.127 0 0 0 2.545 2.551c1.098.589 2.187.902 5.189.902h4.294a.225.225 0 0 1 .16.384l-2.657 2.661c-.21.211-.496.33-.793.33h-1.494c-4.003 0-5.454-.418-6.918-1.202A8.169 8.169 0 0 1 1.2 31.396C.417 29.929 0 28.474 0 24.463v-7.045a.225.225 0 0 1 .383-.159zM16.045 3.045c-.211.211-.496.33-.794.33h-3.249c-3.002 0-4.091.313-5.189.902a6.127 6.127 0 0 0-2.546 2.551c-.587 1.1-.9 2.191-.9 5.2v4.304a.225.225 0 0 1-.383.159L.33 13.83A1.126 1.126 0 0 1 0 13.034v-1.497c0-4.011.417-5.466 1.2-6.933a8.169 8.169 0 0 1 3.394-3.402C6.058.418 7.51 0 11.512 0h7.03a.225.225 0 0 1 .158.384l-2.655 2.661zm13.884 10.091l-3.62-3.468c-.24-.24-.52-.414-.819-.523A2.236 2.236 0 0 0 24.696 9H14.01a.225.225 0 0 1-.159-.384l2.659-2.662c.21-.21.495-.329.793-.329h8.516c2.48 0 4.49 2.015 4.49 4.5v2.849a.225.225 0 0 1-.38.162zm-7.115 16.861l3.46-3.629c.24-.24.414-.52.523-.82a2.25 2.25 0 0 0 .144-.795v-10.71a.225.225 0 0 1 .384-.159l2.656 2.664c.21.211.328.497.328.796v8.534c0 2.485-2.01 4.5-4.49 4.5h-2.843a.225.225 0 0 1-.162-.38zM5.992 22.864l3.622 3.468c.239.24.52.414.818.523.246.094.514.145.794.145h10.686a.225.225 0 0 1 .158.384l-2.658 2.662c-.21.21-.496.329-.793.329h-8.516a4.495 4.495 0 0 1-4.49-4.5v-2.849a.225.225 0 0 1 .38-.162zm7.116-16.859l-3.461 3.63c-.24.24-.413.52-.522.82a2.25 2.25 0 0 0-.145.795v10.71a.225.225 0 0 1-.383.158l-2.656-2.664a1.126 1.126 0 0 1-.328-.795v-8.534c0-2.485 2.01-4.5 4.49-4.5h2.843a.225.225 0 0 1 .162.38zm33.105 4.379h.868c.593 0 1.074.48 1.074 1.074v1.016c0 .032.026.057.057.057.495-.875 1.16-1.51 1.998-1.909a6.236 6.236 0 0 1 2.71-.596c1.047 0 1.989.194 2.826.582.837.387 1.55.92 2.14 1.595a6.896 6.896 0 0 1 1.34 2.386c.305.915.457 1.9.457 2.953a8.795 8.795 0 0 1-.485 2.953 7.418 7.418 0 0 1-1.355 2.386 6.269 6.269 0 0 1-2.097 1.595 6.182 6.182 0 0 1-2.683.582c-.647 0-1.217-.07-1.712-.209a5.751 5.751 0 0 1-1.312-.537 5.252 5.252 0 0 1-.97-.7 5.012 5.012 0 0 1-.657-.731.086.086 0 0 0-.086.085v7.224a1.31 1.31 0 0 1-1.31 1.31h-.803a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm10.046 7.158c0-.557-.09-1.094-.27-1.61a4.078 4.078 0 0 0-.8-1.373 3.99 3.99 0 0 0-1.27-.954c-.494-.239-1.055-.358-1.683-.358-.628 0-1.19.12-1.684.358a3.99 3.99 0 0 0-1.27.954 4.078 4.078 0 0 0-.799 1.372 4.845 4.845 0 0 0-.27 1.61c0 .558.09 1.094.27 1.611.181.517.447.975.8 1.372a3.99 3.99 0 0 0 1.27.955c.494.238 1.055.358 1.683.358.628 0 1.189-.12 1.683-.358a3.99 3.99 0 0 0 1.27-.955c.352-.397.618-.855.8-1.372.18-.517.27-1.053.27-1.61zm8.359-7.158h.98c.626 0 1.134.507 1.134 1.133v1.077c0 .031.025.057.057.057.38-.836.922-1.482 1.626-1.939.704-.457 1.513-.686 2.426-.686.209 0 .414.02.613.06a.762.762 0 0 1 .614.747v1.964a.715.715 0 0 1-.842.704 4.58 4.58 0 0 0-.813-.075c-.8 0-1.441.154-1.926.462-.485.309-.856.661-1.113 1.06a3.6 3.6 0 0 0-.514 1.192c-.086.398-.128.696-.128.895v6.355a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm11.585 0h.804c.723 0 1.31.587 1.31 1.31V23.39a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm-1.795-4.862c0-.576.204-1.078.613-1.506.41-.427.928-.641 1.555-.641.628 0 1.156.204 1.584.611.428.408.642.92.642 1.536 0 .617-.214 1.129-.642 1.536-.428.408-.956.612-1.584.612-.627 0-1.146-.214-1.555-.641a2.108 2.108 0 0 1-.613-1.507zm14.753 8.133c-.695-.51-1.314-.766-1.855-.766-.457 0-.904.12-1.342.358-.437.239-.656.626-.656 1.163 0 .438.18.756.542.955.362.198.818.368 1.37.507.552.139 1.146.283 1.783.432.638.15 1.232.378 1.784.686.552.308 1.008.73 1.37 1.268.361.537.542 1.272.542 2.207 0 .855-.176 1.575-.528 2.162a4.241 4.241 0 0 1-1.37 1.417 5.927 5.927 0 0 1-1.897.775 9.553 9.553 0 0 1-2.112.239c-1.065 0-2.045-.16-2.94-.477-.35-.125-.77-.375-1.26-.751a1.31 1.31 0 0 1-.119-1.976l.355-.348a1.31 1.31 0 0 1 1.783-.048c.208.183.388.324.54.423.504.329 1.118.493 1.84.493.248 0 .505-.03.771-.09.267-.06.514-.159.742-.298.228-.14.414-.313.557-.522.142-.209.214-.452.214-.73 0-.498-.181-.866-.543-1.104-.361-.239-.818-.433-1.37-.582a28.746 28.746 0 0 0-1.783-.417 6.707 6.707 0 0 1-1.783-.627 3.795 3.795 0 0 1-1.37-1.208c-.361-.517-.542-1.233-.542-2.147 0-.795.157-1.486.47-2.073a4.265 4.265 0 0 1 1.242-1.446 5.256 5.256 0 0 1 1.77-.836 7.773 7.773 0 0 1 2.025-.268c.913 0 1.817.164 2.711.492.324.119.685.339 1.084.66a1.31 1.31 0 0 1 .075 1.975l-.426.401a1.31 1.31 0 0 1-1.674.101zm7.787-3.271h.633c.723 0 1.31.587 1.31 1.31v.927a5.602 5.602 0 0 1 1.527-1.805c.675-.527 1.583-.79 2.725-.79 2.15 0 3.576.885 4.28 2.654.495-.914 1.113-1.585 1.855-2.013.742-.427 1.626-.641 2.654-.641.913 0 1.683.159 2.311.477a4.084 4.084 0 0 1 1.527 1.312c.39.557.67 1.208.841 1.954.172.746.257 1.546.257 2.4v7.22a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31v-6.802c0-.437-.038-.86-.114-1.267a3.111 3.111 0 0 0-.4-1.074 2.062 2.062 0 0 0-.77-.73c-.324-.18-.742-.269-1.256-.269-.532 0-.984.104-1.355.313a2.686 2.686 0 0 0-.913.835 3.508 3.508 0 0 0-.514 1.193 5.94 5.94 0 0 0-.157 1.357v6.445a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31v-7.22c0-.895-.18-1.606-.542-2.133-.362-.526-.96-.79-1.798-.79-.57 0-1.051.1-1.441.298-.39.2-.713.468-.97.806a3.26 3.26 0 0 0-.557 1.163 5.413 5.413 0 0 0-.17 1.372v6.504a1.31 1.31 0 0 1-1.311 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.587-1.31 1.31-1.31zm25.454 0h.803c.724 0 1.31.587 1.31 1.31V23.39a1.31 1.31 0 0 1-1.31 1.31h-.803a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm-1.796-4.862c0-.576.205-1.078.614-1.506.409-.427.927-.641 1.555-.641.628 0 1.156.204 1.584.611.428.408.642.92.642 1.536 0 .617-.214 1.129-.642 1.536-.428.408-.956.612-1.584.612-.628 0-1.146-.214-1.555-.641a2.108 2.108 0 0 1-.614-1.507zm16.751 8.373a3.564 3.564 0 0 0-.371-.26 2.607 2.607 0 0 0-1.342-.388c-.627 0-1.189.12-1.683.358a3.99 3.99 0 0 0-1.27.954 4.078 4.078 0 0 0-.799 1.372 4.845 4.845 0 0 0-.271 1.61c0 .558.09 1.094.271 1.611.18.517.447.975.8 1.372a3.99 3.99 0 0 0 1.269.955c.494.238 1.056.358 1.683.358.533 0 1.028-.115 1.484-.343.093-.047.193-.11.3-.189a1.31 1.31 0 0 1 1.756.185l.52.584a1.248 1.248 0 0 1-.307 1.91 7.98 7.98 0 0 1-2.668.97c-.419.069-.78.104-1.085.104a7.904 7.904 0 0 1-2.91-.537A6.938 6.938 0 0 1 130.365 23a7.23 7.23 0 0 1-1.583-2.371c-.39-.925-.585-1.954-.585-3.087 0-1.133.195-2.162.585-3.087a7.23 7.23 0 0 1 1.583-2.371 6.938 6.938 0 0 1 2.369-1.521 7.904 7.904 0 0 1 2.91-.537c.876 0 1.755.174 2.64.522.337.133.735.37 1.193.711a1.31 1.31 0 0 1 .164 1.957l-.53.553a1.31 1.31 0 0 1-1.754.126z"/>
</svg>"
6
6
  alt="Prismic"
7
- >
7
+ />
8
8
  <figcaption>Loading preview...</figcaption>
9
9
  </figure>
10
10
  </section>
@@ -13,7 +13,7 @@
13
13
  <script setup>
14
14
  import { onMounted } from 'vue'
15
15
 
16
- useMeta({
16
+ useHead({
17
17
  title: 'Prismic Preview - Loading'
18
18
  })
19
19
 
@@ -37,14 +37,15 @@ onMounted(async () => {
37
37
  position: fixed;
38
38
  top: 0;
39
39
  left: 0;
40
- display: flex;
40
+ display: flex;
41
41
  justify-content: center;
42
42
  align-items: center;
43
43
  background: #ffffff;
44
- color: #666666;
45
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
46
- font-size: 1rem;
47
- text-align: center;
44
+ color: #666666;
45
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
46
+ Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
47
+ font-size: 1rem;
48
+ text-align: center;
48
49
  }
49
50
 
50
51
  img {
package/dist/types.d.ts CHANGED
@@ -1,6 +1,10 @@
1
1
 
2
- import { } from './module'
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.0",
3
+ "version": "3.0.0-alpha.3",
4
4
  "description": "Easily connect your Nuxt 3 application to your content hosted on Prismic",
5
5
  "keywords": [
6
6
  "nuxt",
@@ -36,31 +36,28 @@
36
36
  "dev": "nuxi dev playground",
37
37
  "dev:build": "nuxi build playground",
38
38
  "lint": "eslint --ext .js,.ts .",
39
- "playground:build": "nuxi build playground",
40
- "playground:dev": "nuxi dev playground",
41
- "prepare": "npm run build",
39
+ "prepare": "nuxi prepare playground && npm run build",
42
40
  "release": "npm run build && npm run test && standard-version && git push --follow-tags && npm run build && npm publish",
43
41
  "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
42
  "release:alpha:dry": "standard-version --release-as major --prerelease alpha --dry-run",
45
43
  "release:dry": "standard-version --dry-run",
46
44
  "test": "npm run lint && npm run unit",
47
- "unit": "nyc --reporter=lcovonly --reporter=text --exclude-after-remap=false ava"
45
+ "unit": "echo \"TODO: vitest & nuxt-test-utils\""
48
46
  },
49
47
  "dependencies": {
50
48
  "@nuxt/kit": "npm:@nuxt/kit-edge@latest",
49
+ "@prismicio/client": "^6.4.2",
51
50
  "@prismicio/vue": "^3.0.0-beta",
52
- "consola": "^2.15.3"
51
+ "consola": "^2.15.3",
52
+ "ufo": "^0.8.3"
53
53
  },
54
54
  "devDependencies": {
55
55
  "@nuxt/module-builder": "latest",
56
56
  "@nuxtjs/eslint-config-typescript": "latest",
57
- "ava": "^3.15.0",
58
- "eslint": "^8.9.0",
57
+ "eslint": "^8.12.0",
59
58
  "nuxt3": "latest",
60
- "nyc": "^15.1.0",
61
59
  "standard-version": "^9.3.2",
62
- "ts-eager": "^2.0.2",
63
- "typescript": "^4.5.5"
60
+ "typescript": "^4.6.3"
64
61
  },
65
62
  "engines": {
66
63
  "node": ">=12.7.0"
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, 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,35 +31,77 @@ 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
- linkResolver: undefined,
37
+ client: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/client`),
38
+ linkResolver: cleanDoubleSlashes(`~/${nuxt.options.dir.app}/prismic/linkResolver`),
22
39
  htmlSerializer: undefined,
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.client && !mergedOptions.endpoint) {
32
- logger.warn('Options `endpoint` or `client` are required, disabling module...')
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'), '@prismicio/vue')
54
+
55
+ // Add runtime user code
56
+ const addUserFileWithUndefinedFallback = (filename: string, path?: string, extensions = ['js', 'ts']) => {
57
+ const resolvedFilename = `prismic/${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
+ logger.info(`Using user-defined \`${filename}\` at \`${maybeUserFile.replace(nuxt.options.srcDir, '~').replace(/\\/g, '/')}\``)
65
+
66
+ addTemplate({
67
+ filename: resolvedFilename,
68
+ src: maybeUserFile
69
+ })
70
+ } else {
71
+ addTemplate({
72
+ filename: resolvedFilename,
73
+ getContents: () => 'export default undefined'
74
+ })
75
+ }
76
+ }
77
+ addUserFileWithUndefinedFallback('client', mergedOptions.client)
78
+ addUserFileWithUndefinedFallback('linkResolver', mergedOptions.linkResolver)
39
79
 
40
80
  // Expose options through public runtime config
41
- nuxt.options.publicRuntimeConfig ||= {}
81
+ nuxt.options.publicRuntimeConfig ||= {} as typeof nuxt.options.publicRuntimeConfig
42
82
  nuxt.options.publicRuntimeConfig[pkgName] = mergedOptions
43
83
 
44
84
  // Add plugin
45
85
  addPlugin(resolver.resolve('runtime/plugin'))
46
86
 
87
+ // Add components auto import
88
+ if (mergedOptions.injectComponents) {
89
+ [
90
+ 'PrismicEmbed',
91
+ 'PrismicImage',
92
+ 'PrismicLink',
93
+ 'PrismicText',
94
+ 'PrismicRichText',
95
+ 'SliceZone'
96
+ ].forEach((component) => {
97
+ addComponent({
98
+ name: component,
99
+ export: component,
100
+ filePath: '@prismicio/vue'
101
+ })
102
+ })
103
+ }
104
+
47
105
  // Add composable auto import
48
106
  const composableAutoImports = Object
49
107
  .keys(prismicVue)
@@ -59,11 +117,10 @@ export default defineNuxtModule<PrismicModuleOptions>({
59
117
 
60
118
  // Add preview route
61
119
  if (mergedOptions.preview) {
62
- const userPreviewPagePath = join(nuxt.options.srcDir, nuxt.options.dir.pages, `${mergedOptions.preview}.vue`)
120
+ const maybeUserPreviewPage = fileExists(join(nuxt.options.srcDir, nuxt.options.dir.pages, mergedOptions.preview), ['js', 'ts', 'vue'])
63
121
 
64
- if (existsSync(userPreviewPagePath)) {
65
- logger.info(`Using user-defined preview page at \`${
66
- userPreviewPagePath.replace(join(nuxt.options.rootDir), '~~').replace(/\\/g, '/')
122
+ if (maybeUserPreviewPage) {
123
+ logger.info(`Using user-defined preview page at \`${maybeUserPreviewPage.replace(join(nuxt.options.srcDir), '~').replace(/\\/g, '/')
67
124
  }\`, available at \`${mergedOptions.preview}\``)
68
125
  } else {
69
126
  logger.info(`Using default preview page, available at \`${mergedOptions.preview}\``)
@@ -77,22 +134,13 @@ export default defineNuxtModule<PrismicModuleOptions>({
77
134
  })
78
135
  }
79
136
 
80
- // TODO: Refactor with new client helpers
81
- let repositoryName = ''
82
- if (mergedOptions.client) {
83
- repositoryName = new URL(mergedOptions.client.endpoint).host.split('.')[0]
84
- } else {
85
- try {
86
- repositoryName = new URL(mergedOptions.endpoint).host.split('.')[0]
87
- } catch (error) {
88
- repositoryName = mergedOptions.endpoint
89
- }
90
- }
91
-
92
137
  // Add toolbar
93
- nuxt.options.meta ||= {}
94
- nuxt.options.meta.script ||= []
95
- nuxt.options.meta.script.push({
138
+ const repositoryName = isRepositoryEndpoint(mergedOptions.endpoint)
139
+ ? getRepositoryName(mergedOptions.endpoint)
140
+ : mergedOptions.endpoint
141
+ nuxt.options.head ||= {}
142
+ nuxt.options.head.script ||= []
143
+ nuxt.options.head.script.push({
96
144
  src: `https://static.cdn.prismic.io/prismic.min.js?repo=${repositoryName}&new=true`
97
145
  })
98
146
  }
@@ -1,11 +1,26 @@
1
1
  import { defineNuxtPlugin } from '#app'
2
+ import NuxtLink from '#app/components/nuxt-link'
3
+
2
4
  import { createPrismic } from '@prismicio/vue'
3
5
 
4
6
  import { name as pkgName } from '../../package.json'
5
7
  import { PrismicModuleOptions } from '../types'
6
8
 
9
+ import linkResolver from '#build/prismic/linkResolver'
10
+ import client from '#build/prismic/client'
11
+
7
12
  export default defineNuxtPlugin((nuxtApp) => {
8
13
  const mergedOptions: PrismicModuleOptions = nuxtApp.payload.config[pkgName]
9
14
 
10
- nuxtApp.vueApp.use(createPrismic(mergedOptions))
15
+ nuxtApp.vueApp.use(createPrismic({
16
+ ...mergedOptions,
17
+ client,
18
+ linkResolver,
19
+ injectComponents: false, // Handled at module level
20
+ components: {
21
+ linkInternalComponent: NuxtLink,
22
+ linkExternalComponent: NuxtLink,
23
+ ...mergedOptions.components
24
+ }
25
+ }))
11
26
  })
@@ -4,7 +4,7 @@
4
4
  <img
5
5
  src="data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" width="140" height="36">
  <path fill="#212735" fill-rule="evenodd" d="M35.538 18.74l-2.655-2.66a1.126 1.126 0 0 1-.329-.796v-3.256c0-3.009-.313-4.1-.9-5.2a6.127 6.127 0 0 0-2.546-2.551c-1.097-.589-2.186-.902-5.188-.902h-4.295a.225.225 0 0 1-.158-.384L22.122.33c.21-.211.496-.33.794-.33h1.493c4.003 0 5.455.418 6.919 1.202a8.169 8.169 0 0 1 3.394 3.402c.783 1.467 1.2 2.922 1.2 6.933v7.045a.225.225 0 0 1-.384.159zM17.222 35.617l2.655-2.661c.21-.211.496-.33.794-.33h3.249c3.002 0 4.09-.313 5.188-.902a6.127 6.127 0 0 0 2.546-2.551c.587-1.1.9-2.191.9-5.2v-4.304a.225.225 0 0 1 .383-.159l2.656 2.661c.21.211.329.498.329.796v1.497c0 4.011-.417 5.466-1.2 6.933a8.169 8.169 0 0 1-3.394 3.402C29.864 35.582 28.412 36 24.409 36H17.38a.225.225 0 0 1-.158-.384zM.383 17.259L3.04 19.92c.21.211.329.498.329.796v3.256c0 3.009.312 4.1.9 5.2a6.127 6.127 0 0 0 2.545 2.551c1.098.589 2.187.902 5.189.902h4.294a.225.225 0 0 1 .16.384l-2.657 2.661c-.21.211-.496.33-.793.33h-1.494c-4.003 0-5.454-.418-6.918-1.202A8.169 8.169 0 0 1 1.2 31.396C.417 29.929 0 28.474 0 24.463v-7.045a.225.225 0 0 1 .383-.159zM16.045 3.045c-.211.211-.496.33-.794.33h-3.249c-3.002 0-4.091.313-5.189.902a6.127 6.127 0 0 0-2.546 2.551c-.587 1.1-.9 2.191-.9 5.2v4.304a.225.225 0 0 1-.383.159L.33 13.83A1.126 1.126 0 0 1 0 13.034v-1.497c0-4.011.417-5.466 1.2-6.933a8.169 8.169 0 0 1 3.394-3.402C6.058.418 7.51 0 11.512 0h7.03a.225.225 0 0 1 .158.384l-2.655 2.661zm13.884 10.091l-3.62-3.468c-.24-.24-.52-.414-.819-.523A2.236 2.236 0 0 0 24.696 9H14.01a.225.225 0 0 1-.159-.384l2.659-2.662c.21-.21.495-.329.793-.329h8.516c2.48 0 4.49 2.015 4.49 4.5v2.849a.225.225 0 0 1-.38.162zm-7.115 16.861l3.46-3.629c.24-.24.414-.52.523-.82a2.25 2.25 0 0 0 .144-.795v-10.71a.225.225 0 0 1 .384-.159l2.656 2.664c.21.211.328.497.328.796v8.534c0 2.485-2.01 4.5-4.49 4.5h-2.843a.225.225 0 0 1-.162-.38zM5.992 22.864l3.622 3.468c.239.24.52.414.818.523.246.094.514.145.794.145h10.686a.225.225 0 0 1 .158.384l-2.658 2.662c-.21.21-.496.329-.793.329h-8.516a4.495 4.495 0 0 1-4.49-4.5v-2.849a.225.225 0 0 1 .38-.162zm7.116-16.859l-3.461 3.63c-.24.24-.413.52-.522.82a2.25 2.25 0 0 0-.145.795v10.71a.225.225 0 0 1-.383.158l-2.656-2.664a1.126 1.126 0 0 1-.328-.795v-8.534c0-2.485 2.01-4.5 4.49-4.5h2.843a.225.225 0 0 1 .162.38zm33.105 4.379h.868c.593 0 1.074.48 1.074 1.074v1.016c0 .032.026.057.057.057.495-.875 1.16-1.51 1.998-1.909a6.236 6.236 0 0 1 2.71-.596c1.047 0 1.989.194 2.826.582.837.387 1.55.92 2.14 1.595a6.896 6.896 0 0 1 1.34 2.386c.305.915.457 1.9.457 2.953a8.795 8.795 0 0 1-.485 2.953 7.418 7.418 0 0 1-1.355 2.386 6.269 6.269 0 0 1-2.097 1.595 6.182 6.182 0 0 1-2.683.582c-.647 0-1.217-.07-1.712-.209a5.751 5.751 0 0 1-1.312-.537 5.252 5.252 0 0 1-.97-.7 5.012 5.012 0 0 1-.657-.731.086.086 0 0 0-.086.085v7.224a1.31 1.31 0 0 1-1.31 1.31h-.803a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm10.046 7.158c0-.557-.09-1.094-.27-1.61a4.078 4.078 0 0 0-.8-1.373 3.99 3.99 0 0 0-1.27-.954c-.494-.239-1.055-.358-1.683-.358-.628 0-1.19.12-1.684.358a3.99 3.99 0 0 0-1.27.954 4.078 4.078 0 0 0-.799 1.372 4.845 4.845 0 0 0-.27 1.61c0 .558.09 1.094.27 1.611.181.517.447.975.8 1.372a3.99 3.99 0 0 0 1.27.955c.494.238 1.055.358 1.683.358.628 0 1.189-.12 1.683-.358a3.99 3.99 0 0 0 1.27-.955c.352-.397.618-.855.8-1.372.18-.517.27-1.053.27-1.61zm8.359-7.158h.98c.626 0 1.134.507 1.134 1.133v1.077c0 .031.025.057.057.057.38-.836.922-1.482 1.626-1.939.704-.457 1.513-.686 2.426-.686.209 0 .414.02.613.06a.762.762 0 0 1 .614.747v1.964a.715.715 0 0 1-.842.704 4.58 4.58 0 0 0-.813-.075c-.8 0-1.441.154-1.926.462-.485.309-.856.661-1.113 1.06a3.6 3.6 0 0 0-.514 1.192c-.086.398-.128.696-.128.895v6.355a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm11.585 0h.804c.723 0 1.31.587 1.31 1.31V23.39a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm-1.795-4.862c0-.576.204-1.078.613-1.506.41-.427.928-.641 1.555-.641.628 0 1.156.204 1.584.611.428.408.642.92.642 1.536 0 .617-.214 1.129-.642 1.536-.428.408-.956.612-1.584.612-.627 0-1.146-.214-1.555-.641a2.108 2.108 0 0 1-.613-1.507zm14.753 8.133c-.695-.51-1.314-.766-1.855-.766-.457 0-.904.12-1.342.358-.437.239-.656.626-.656 1.163 0 .438.18.756.542.955.362.198.818.368 1.37.507.552.139 1.146.283 1.783.432.638.15 1.232.378 1.784.686.552.308 1.008.73 1.37 1.268.361.537.542 1.272.542 2.207 0 .855-.176 1.575-.528 2.162a4.241 4.241 0 0 1-1.37 1.417 5.927 5.927 0 0 1-1.897.775 9.553 9.553 0 0 1-2.112.239c-1.065 0-2.045-.16-2.94-.477-.35-.125-.77-.375-1.26-.751a1.31 1.31 0 0 1-.119-1.976l.355-.348a1.31 1.31 0 0 1 1.783-.048c.208.183.388.324.54.423.504.329 1.118.493 1.84.493.248 0 .505-.03.771-.09.267-.06.514-.159.742-.298.228-.14.414-.313.557-.522.142-.209.214-.452.214-.73 0-.498-.181-.866-.543-1.104-.361-.239-.818-.433-1.37-.582a28.746 28.746 0 0 0-1.783-.417 6.707 6.707 0 0 1-1.783-.627 3.795 3.795 0 0 1-1.37-1.208c-.361-.517-.542-1.233-.542-2.147 0-.795.157-1.486.47-2.073a4.265 4.265 0 0 1 1.242-1.446 5.256 5.256 0 0 1 1.77-.836 7.773 7.773 0 0 1 2.025-.268c.913 0 1.817.164 2.711.492.324.119.685.339 1.084.66a1.31 1.31 0 0 1 .075 1.975l-.426.401a1.31 1.31 0 0 1-1.674.101zm7.787-3.271h.633c.723 0 1.31.587 1.31 1.31v.927a5.602 5.602 0 0 1 1.527-1.805c.675-.527 1.583-.79 2.725-.79 2.15 0 3.576.885 4.28 2.654.495-.914 1.113-1.585 1.855-2.013.742-.427 1.626-.641 2.654-.641.913 0 1.683.159 2.311.477a4.084 4.084 0 0 1 1.527 1.312c.39.557.67 1.208.841 1.954.172.746.257 1.546.257 2.4v7.22a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31v-6.802c0-.437-.038-.86-.114-1.267a3.111 3.111 0 0 0-.4-1.074 2.062 2.062 0 0 0-.77-.73c-.324-.18-.742-.269-1.256-.269-.532 0-.984.104-1.355.313a2.686 2.686 0 0 0-.913.835 3.508 3.508 0 0 0-.514 1.193 5.94 5.94 0 0 0-.157 1.357v6.445a1.31 1.31 0 0 1-1.31 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31v-7.22c0-.895-.18-1.606-.542-2.133-.362-.526-.96-.79-1.798-.79-.57 0-1.051.1-1.441.298-.39.2-.713.468-.97.806a3.26 3.26 0 0 0-.557 1.163 5.413 5.413 0 0 0-.17 1.372v6.504a1.31 1.31 0 0 1-1.311 1.31h-.804a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.587-1.31 1.31-1.31zm25.454 0h.803c.724 0 1.31.587 1.31 1.31V23.39a1.31 1.31 0 0 1-1.31 1.31h-.803a1.31 1.31 0 0 1-1.31-1.31V11.694c0-.723.586-1.31 1.31-1.31zm-1.796-4.862c0-.576.205-1.078.614-1.506.409-.427.927-.641 1.555-.641.628 0 1.156.204 1.584.611.428.408.642.92.642 1.536 0 .617-.214 1.129-.642 1.536-.428.408-.956.612-1.584.612-.628 0-1.146-.214-1.555-.641a2.108 2.108 0 0 1-.614-1.507zm16.751 8.373a3.564 3.564 0 0 0-.371-.26 2.607 2.607 0 0 0-1.342-.388c-.627 0-1.189.12-1.683.358a3.99 3.99 0 0 0-1.27.954 4.078 4.078 0 0 0-.799 1.372 4.845 4.845 0 0 0-.271 1.61c0 .558.09 1.094.271 1.611.18.517.447.975.8 1.372a3.99 3.99 0 0 0 1.269.955c.494.238 1.056.358 1.683.358.533 0 1.028-.115 1.484-.343.093-.047.193-.11.3-.189a1.31 1.31 0 0 1 1.756.185l.52.584a1.248 1.248 0 0 1-.307 1.91 7.98 7.98 0 0 1-2.668.97c-.419.069-.78.104-1.085.104a7.904 7.904 0 0 1-2.91-.537A6.938 6.938 0 0 1 130.365 23a7.23 7.23 0 0 1-1.583-2.371c-.39-.925-.585-1.954-.585-3.087 0-1.133.195-2.162.585-3.087a7.23 7.23 0 0 1 1.583-2.371 6.938 6.938 0 0 1 2.369-1.521 7.904 7.904 0 0 1 2.91-.537c.876 0 1.755.174 2.64.522.337.133.735.37 1.193.711a1.31 1.31 0 0 1 .164 1.957l-.53.553a1.31 1.31 0 0 1-1.754.126z"/>
</svg>"
6
6
  alt="Prismic"
7
- >
7
+ />
8
8
  <figcaption>Loading preview...</figcaption>
9
9
  </figure>
10
10
  </section>
@@ -13,7 +13,7 @@
13
13
  <script setup>
14
14
  import { onMounted } from 'vue'
15
15
 
16
- useMeta({
16
+ useHead({
17
17
  title: 'Prismic Preview - Loading'
18
18
  })
19
19
 
@@ -37,14 +37,15 @@ onMounted(async () => {
37
37
  position: fixed;
38
38
  top: 0;
39
39
  left: 0;
40
- display: flex;
40
+ display: flex;
41
41
  justify-content: center;
42
42
  align-items: center;
43
43
  background: #ffffff;
44
- color: #666666;
45
- font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
46
- font-size: 1rem;
47
- text-align: center;
44
+ color: #666666;
45
+ font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
46
+ Ubuntu, Cantarell, "Open Sans", "Helvetica Neue", sans-serif;
47
+ font-size: 1rem;
48
+ text-align: center;
48
49
  }
49
50
 
50
51
  img {
package/src/types.ts CHANGED
@@ -1,5 +1,8 @@
1
1
  import { PrismicPluginOptions } from '@prismicio/vue'
2
2
 
3
- export type PrismicModuleOptions = PrismicPluginOptions & {
4
- preview?: string | false
3
+ export type PrismicModuleOptions = Omit<PrismicPluginOptions, 'endpoint' | 'client' | 'linkResolver'> & {
4
+ endpoint: string,
5
+ client?: string,
6
+ linkResolver?: string,
7
+ preview?: string | false,
5
8
  };
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
+ }