tinacms 2.3.0 → 2.4.0

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.
@@ -1,2 +1,3 @@
1
1
  import type { Cache } from './index';
2
+ export declare const makeCacheDir: (dir: string, fs: any, path: any, os: any) => Promise<string>;
2
3
  export declare const NodeCache: (dir: string) => Promise<Cache>;
package/dist/client.js CHANGED
@@ -105,21 +105,27 @@
105
105
  const client = new TinaClient(args);
106
106
  return client;
107
107
  }
108
- const makeCacheDir = async (dir, fs) => {
109
- const path = await Promise.resolve().then(() => __viteBrowserExternal$1);
110
- const os = await Promise.resolve().then(() => __viteBrowserExternal$1);
111
- const parts = dir.split(path.sep).filter(Boolean);
108
+ const makeCacheDir = async (dir, fs, path, os) => {
109
+ const pathParts = dir.split(path.sep).filter(Boolean);
110
+ const cacheHash = pathParts[pathParts.length - 1];
111
+ const rootUser = pathParts[0];
112
112
  let cacheDir = dir;
113
- if (!fs.existsSync(path.join(path.sep, parts[0]))) {
114
- cacheDir = path.join(os.tmpdir(), parts[parts.length - 1]);
113
+ if (!fs.existsSync(path.join(path.sep, rootUser))) {
114
+ cacheDir = path.join(os.tmpdir(), cacheHash);
115
+ }
116
+ try {
117
+ fs.mkdirSync(cacheDir, { recursive: true });
118
+ } catch (error) {
119
+ throw new Error(`Failed to create cache directory: ${error.message}`);
115
120
  }
116
- fs.mkdirSync(cacheDir, { recursive: true });
117
121
  return cacheDir;
118
122
  };
119
123
  const NodeCache = async (dir) => {
120
- const fs = await Promise.resolve().then(() => __viteBrowserExternal$1);
121
- const { createHash } = await Promise.resolve().then(() => __viteBrowserExternal$1);
122
- const cacheDir = await makeCacheDir(dir, fs);
124
+ const fs = require("node:fs");
125
+ const path = require("node:path");
126
+ const os = require("node:os");
127
+ const { createHash } = require("node:crypto");
128
+ const cacheDir = await makeCacheDir(dir, fs, path, os);
123
129
  return {
124
130
  makeKey: (key) => {
125
131
  const input = key && key instanceof Object ? JSON.stringify(key) : key || "";
@@ -147,12 +153,8 @@
147
153
  };
148
154
  const nodeCache = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
149
155
  __proto__: null,
150
- NodeCache
151
- }, Symbol.toStringTag, { value: "Module" }));
152
- const __viteBrowserExternal = {};
153
- const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
154
- __proto__: null,
155
- default: __viteBrowserExternal
156
+ NodeCache,
157
+ makeCacheDir
156
158
  }, Symbol.toStringTag, { value: "Module" }));
157
159
  exports2.TINA_HOST = TINA_HOST;
158
160
  exports2.TinaClient = TinaClient;
package/dist/client.mjs CHANGED
@@ -24,7 +24,7 @@ class TinaClient {
24
24
  }
25
25
  try {
26
26
  if (this.cacheDir && typeof window === "undefined" && typeof require !== "undefined") {
27
- const { NodeCache } = await import("./node-cache-7fa2452c.mjs");
27
+ const { NodeCache } = await import("./node-cache-4c336858.mjs");
28
28
  this.cache = await NodeCache(this.cacheDir);
29
29
  }
30
30
  } catch (e) {
package/dist/index.js CHANGED
@@ -774,6 +774,22 @@ var __publicField = (obj, key, value) => {
774
774
  );
775
775
  };
776
776
  }
777
+ function wrapFieldWithNoHeader(Field) {
778
+ return (props) => {
779
+ return /* @__PURE__ */ React__namespace.createElement(
780
+ FieldMeta,
781
+ {
782
+ name: props.input.name,
783
+ label: false,
784
+ description: "",
785
+ error: props.meta.error,
786
+ index: props.index,
787
+ tinaForm: props.tinaForm
788
+ },
789
+ /* @__PURE__ */ React__namespace.createElement(Field, { ...props })
790
+ );
791
+ };
792
+ }
777
793
  function wrapFieldWithError(Field) {
778
794
  return (props) => {
779
795
  return /* @__PURE__ */ React__namespace.createElement(
@@ -850,9 +866,9 @@ var __publicField = (obj, key, value) => {
850
866
  "span",
851
867
  {
852
868
  className: `block font-sans text-xs italic font-light text-gray-400 pt-0.5 whitespace-normal m-0 ${className}`,
853
- ...props
854
- },
855
- children
869
+ ...props,
870
+ dangerouslySetInnerHTML: { __html: children }
871
+ }
856
872
  );
857
873
  };
858
874
  const FieldError = ({
@@ -3676,7 +3692,7 @@ flowchart TD
3676
3692
  };
3677
3693
  const sizeClasses = {
3678
3694
  small: `text-xs h-8 px-3`,
3679
- medium: `text-sm h-10 px-4`,
3695
+ medium: `text-sm h-10 px-8`,
3680
3696
  custom: ``
3681
3697
  };
3682
3698
  return /* @__PURE__ */ React__namespace.createElement(
@@ -5791,27 +5807,35 @@ flowchart TD
5791
5807
  ))))
5792
5808
  ))));
5793
5809
  };
5794
- const Group = wrapFieldWithError(({ tinaForm, field }) => {
5795
- const cms = useCMS$1();
5796
- React__namespace.useState(false);
5797
- return /* @__PURE__ */ React__namespace.createElement(React__namespace.Fragment, null, /* @__PURE__ */ React__namespace.createElement(
5798
- Header,
5799
- {
5800
- onClick: () => {
5801
- const state = tinaForm.finalForm.getState();
5802
- if (state.invalid === true) {
5803
- cms.alerts.error("Cannot navigate away from an invalid form.");
5804
- return;
5810
+ const Group = wrapFieldWithNoHeader(
5811
+ ({ tinaForm, field }) => {
5812
+ const cms = useCMS$1();
5813
+ return /* @__PURE__ */ React__namespace.createElement(React__namespace.Fragment, null, /* @__PURE__ */ React__namespace.createElement(
5814
+ Header,
5815
+ {
5816
+ onClick: () => {
5817
+ const state = tinaForm.finalForm.getState();
5818
+ if (state.invalid === true) {
5819
+ cms.alerts.error("Cannot navigate away from an invalid form.");
5820
+ return;
5821
+ }
5822
+ cms.dispatch({
5823
+ type: "forms:set-active-field-name",
5824
+ value: { formId: tinaForm.id, fieldName: field.name }
5825
+ });
5805
5826
  }
5806
- cms.dispatch({
5807
- type: "forms:set-active-field-name",
5808
- value: { formId: tinaForm.id, fieldName: field.name }
5809
- });
5810
- }
5811
- },
5812
- field.label || field.name
5813
- ));
5814
- });
5827
+ },
5828
+ field.label || field.name,
5829
+ field.description && /* @__PURE__ */ React__namespace.createElement(
5830
+ "span",
5831
+ {
5832
+ className: `block font-sans text-xs italic font-light text-gray-400 pt-0.5 whitespace-normal m-0`,
5833
+ dangerouslySetInnerHTML: { __html: field.description }
5834
+ }
5835
+ )
5836
+ ));
5837
+ }
5838
+ );
5815
5839
  const Header = ({ onClick, children }) => {
5816
5840
  return /* @__PURE__ */ React__namespace.createElement("div", { className: "pt-1 mb-5" }, /* @__PURE__ */ React__namespace.createElement(
5817
5841
  "button",
@@ -10308,7 +10332,7 @@ flowchart TD
10308
10332
  "Event Log"
10309
10333
  ));
10310
10334
  };
10311
- const version = "2.3.0";
10335
+ const version = "2.4.0";
10312
10336
  const Nav = ({
10313
10337
  isLocalMode,
10314
10338
  className = "",
@@ -12839,15 +12863,14 @@ flowchart TD
12839
12863
  fields: fieldGroup.fields
12840
12864
  }
12841
12865
  ) : /* @__PURE__ */ React__namespace.createElement(NoFieldsPlaceholder, null)
12842
- )), !hideFooter && /* @__PURE__ */ React__namespace.createElement("div", { className: "relative flex-none w-full h-16 px-6 bg-white border-t border-gray-100 flex items-center justify-center" }, /* @__PURE__ */ React__namespace.createElement("div", { className: "flex-1 w-full flex justify-between gap-4 items-center max-w-form" }, tinaForm.reset && /* @__PURE__ */ React__namespace.createElement(
12866
+ )), !hideFooter && /* @__PURE__ */ React__namespace.createElement("div", { className: "relative flex-none w-full h-16 px-12 bg-white border-t border-gray-100 flex items-center justify-end" }, /* @__PURE__ */ React__namespace.createElement("div", { className: "flex-1 w-full justify-end gap-2 flex items-center max-w-form" }, tinaForm.reset && /* @__PURE__ */ React__namespace.createElement(
12843
12867
  ResetForm,
12844
12868
  {
12845
12869
  pristine,
12846
12870
  reset: async () => {
12847
12871
  finalForm2.reset();
12848
12872
  await tinaForm.reset();
12849
- },
12850
- style: { flexGrow: 1 }
12873
+ }
12851
12874
  },
12852
12875
  tinaForm.buttons.reset
12853
12876
  ), /* @__PURE__ */ React__namespace.createElement(
@@ -12856,8 +12879,7 @@ flowchart TD
12856
12879
  onClick: safeHandleSubmit,
12857
12880
  disabled: !canSubmit,
12858
12881
  busy: submitting,
12859
- variant: "primary",
12860
- style: { flexGrow: 3 }
12882
+ variant: "primary"
12861
12883
  },
12862
12884
  submitting && /* @__PURE__ */ React__namespace.createElement(LoadingDots, null),
12863
12885
  !submitting && tinaForm.buttons.save
@@ -14427,6 +14449,7 @@ flowchart TD
14427
14449
  ToolbarButton,
14428
14450
  {
14429
14451
  showArrow: false,
14452
+ "data-testid": "rich-text-editor-overflow-menu-button",
14430
14453
  className: "lg:min-w-[130px]",
14431
14454
  isDropdown: true,
14432
14455
  pressed: openState.open,
@@ -14480,7 +14503,17 @@ flowchart TD
14480
14503
  };
14481
14504
  const RawMarkdownToolbarButton = cn$1.withRef(({ clear, ...rest }, ref) => {
14482
14505
  const { props } = useRawMarkdownToolbarButton();
14483
- return /* @__PURE__ */ React.createElement(ToolbarButton, { ref, tooltip: "Link", ...rest, ...props }, /* @__PURE__ */ React.createElement(Icons.raw, null));
14506
+ return /* @__PURE__ */ React.createElement(
14507
+ ToolbarButton,
14508
+ {
14509
+ ref,
14510
+ tooltip: "Link",
14511
+ ...rest,
14512
+ ...props,
14513
+ "data-testid": "markdown-button"
14514
+ },
14515
+ /* @__PURE__ */ React.createElement(Icons.raw, null)
14516
+ );
14484
14517
  });
14485
14518
  function TableDropdownMenu(props) {
14486
14519
  const tableSelected = plateCommon.useEditorSelector(
@@ -33796,6 +33829,7 @@ This will work when developing locally but NOT when deployed to production.
33796
33829
  exports2.useScreenPlugin = useScreenPlugin;
33797
33830
  exports2.useTinaAuthRedirect = useTinaAuthRedirect;
33798
33831
  exports2.wrapFieldWithError = wrapFieldWithError;
33832
+ exports2.wrapFieldWithNoHeader = wrapFieldWithNoHeader;
33799
33833
  exports2.wrapFieldsWithMeta = wrapFieldsWithMeta;
33800
33834
  Object.defineProperties(exports2, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
33801
33835
  });
package/dist/index.mjs CHANGED
@@ -801,6 +801,22 @@ function wrapFieldsWithMeta(Field2) {
801
801
  );
802
802
  };
803
803
  }
804
+ function wrapFieldWithNoHeader(Field2) {
805
+ return (props) => {
806
+ return /* @__PURE__ */ React.createElement(
807
+ FieldMeta,
808
+ {
809
+ name: props.input.name,
810
+ label: false,
811
+ description: "",
812
+ error: props.meta.error,
813
+ index: props.index,
814
+ tinaForm: props.tinaForm
815
+ },
816
+ /* @__PURE__ */ React.createElement(Field2, { ...props })
817
+ );
818
+ };
819
+ }
804
820
  function wrapFieldWithError(Field2) {
805
821
  return (props) => {
806
822
  return /* @__PURE__ */ React.createElement(
@@ -877,9 +893,9 @@ const FieldDescription = ({
877
893
  "span",
878
894
  {
879
895
  className: `block font-sans text-xs italic font-light text-gray-400 pt-0.5 whitespace-normal m-0 ${className}`,
880
- ...props
881
- },
882
- children
896
+ ...props,
897
+ dangerouslySetInnerHTML: { __html: children }
898
+ }
883
899
  );
884
900
  };
885
901
  const FieldError = ({
@@ -3703,7 +3719,7 @@ const Button$1 = ({
3703
3719
  };
3704
3720
  const sizeClasses = {
3705
3721
  small: `text-xs h-8 px-3`,
3706
- medium: `text-sm h-10 px-4`,
3722
+ medium: `text-sm h-10 px-8`,
3707
3723
  custom: ``
3708
3724
  };
3709
3725
  return /* @__PURE__ */ React.createElement(
@@ -5818,27 +5834,35 @@ const BlockSelector = ({
5818
5834
  ))))
5819
5835
  ))));
5820
5836
  };
5821
- const Group = wrapFieldWithError(({ tinaForm, field }) => {
5822
- const cms = useCMS$1();
5823
- React.useState(false);
5824
- return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
5825
- Header,
5826
- {
5827
- onClick: () => {
5828
- const state = tinaForm.finalForm.getState();
5829
- if (state.invalid === true) {
5830
- cms.alerts.error("Cannot navigate away from an invalid form.");
5831
- return;
5837
+ const Group = wrapFieldWithNoHeader(
5838
+ ({ tinaForm, field }) => {
5839
+ const cms = useCMS$1();
5840
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
5841
+ Header,
5842
+ {
5843
+ onClick: () => {
5844
+ const state = tinaForm.finalForm.getState();
5845
+ if (state.invalid === true) {
5846
+ cms.alerts.error("Cannot navigate away from an invalid form.");
5847
+ return;
5848
+ }
5849
+ cms.dispatch({
5850
+ type: "forms:set-active-field-name",
5851
+ value: { formId: tinaForm.id, fieldName: field.name }
5852
+ });
5832
5853
  }
5833
- cms.dispatch({
5834
- type: "forms:set-active-field-name",
5835
- value: { formId: tinaForm.id, fieldName: field.name }
5836
- });
5837
- }
5838
- },
5839
- field.label || field.name
5840
- ));
5841
- });
5854
+ },
5855
+ field.label || field.name,
5856
+ field.description && /* @__PURE__ */ React.createElement(
5857
+ "span",
5858
+ {
5859
+ className: `block font-sans text-xs italic font-light text-gray-400 pt-0.5 whitespace-normal m-0`,
5860
+ dangerouslySetInnerHTML: { __html: field.description }
5861
+ }
5862
+ )
5863
+ ));
5864
+ }
5865
+ );
5842
5866
  const Header = ({ onClick, children }) => {
5843
5867
  return /* @__PURE__ */ React.createElement("div", { className: "pt-1 mb-5" }, /* @__PURE__ */ React.createElement(
5844
5868
  "button",
@@ -10335,7 +10359,7 @@ const SyncStatus = ({ cms, setEventsOpen }) => {
10335
10359
  "Event Log"
10336
10360
  ));
10337
10361
  };
10338
- const version = "2.3.0";
10362
+ const version = "2.4.0";
10339
10363
  const Nav = ({
10340
10364
  isLocalMode,
10341
10365
  className = "",
@@ -12866,15 +12890,14 @@ const FormBuilder = ({
12866
12890
  fields: fieldGroup.fields
12867
12891
  }
12868
12892
  ) : /* @__PURE__ */ React.createElement(NoFieldsPlaceholder, null)
12869
- )), !hideFooter && /* @__PURE__ */ React.createElement("div", { className: "relative flex-none w-full h-16 px-6 bg-white border-t border-gray-100 flex items-center justify-center" }, /* @__PURE__ */ React.createElement("div", { className: "flex-1 w-full flex justify-between gap-4 items-center max-w-form" }, tinaForm.reset && /* @__PURE__ */ React.createElement(
12893
+ )), !hideFooter && /* @__PURE__ */ React.createElement("div", { className: "relative flex-none w-full h-16 px-12 bg-white border-t border-gray-100 flex items-center justify-end" }, /* @__PURE__ */ React.createElement("div", { className: "flex-1 w-full justify-end gap-2 flex items-center max-w-form" }, tinaForm.reset && /* @__PURE__ */ React.createElement(
12870
12894
  ResetForm,
12871
12895
  {
12872
12896
  pristine,
12873
12897
  reset: async () => {
12874
12898
  finalForm.reset();
12875
12899
  await tinaForm.reset();
12876
- },
12877
- style: { flexGrow: 1 }
12900
+ }
12878
12901
  },
12879
12902
  tinaForm.buttons.reset
12880
12903
  ), /* @__PURE__ */ React.createElement(
@@ -12883,8 +12906,7 @@ const FormBuilder = ({
12883
12906
  onClick: safeHandleSubmit,
12884
12907
  disabled: !canSubmit,
12885
12908
  busy: submitting,
12886
- variant: "primary",
12887
- style: { flexGrow: 3 }
12909
+ variant: "primary"
12888
12910
  },
12889
12911
  submitting && /* @__PURE__ */ React.createElement(LoadingDots, null),
12890
12912
  !submitting && tinaForm.buttons.save
@@ -14454,6 +14476,7 @@ function OverflowMenu({
14454
14476
  ToolbarButton,
14455
14477
  {
14456
14478
  showArrow: false,
14479
+ "data-testid": "rich-text-editor-overflow-menu-button",
14457
14480
  className: "lg:min-w-[130px]",
14458
14481
  isDropdown: true,
14459
14482
  pressed: openState.open,
@@ -14507,7 +14530,17 @@ const useRawMarkdownToolbarButton = () => {
14507
14530
  };
14508
14531
  const RawMarkdownToolbarButton = withRef(({ clear, ...rest }, ref) => {
14509
14532
  const { props } = useRawMarkdownToolbarButton();
14510
- return /* @__PURE__ */ React__default.createElement(ToolbarButton, { ref, tooltip: "Link", ...rest, ...props }, /* @__PURE__ */ React__default.createElement(Icons.raw, null));
14533
+ return /* @__PURE__ */ React__default.createElement(
14534
+ ToolbarButton,
14535
+ {
14536
+ ref,
14537
+ tooltip: "Link",
14538
+ ...rest,
14539
+ ...props,
14540
+ "data-testid": "markdown-button"
14541
+ },
14542
+ /* @__PURE__ */ React__default.createElement(Icons.raw, null)
14543
+ );
14511
14544
  });
14512
14545
  function TableDropdownMenu(props) {
14513
14546
  const tableSelected = useEditorSelector(
@@ -33818,5 +33851,6 @@ export {
33818
33851
  useScreenPlugin,
33819
33852
  useTinaAuthRedirect,
33820
33853
  wrapFieldWithError,
33854
+ wrapFieldWithNoHeader,
33821
33855
  wrapFieldsWithMeta
33822
33856
  };
@@ -1,18 +1,24 @@
1
- const makeCacheDir = async (dir, fs) => {
2
- const path = await import("./__vite-browser-external-d06ac358.mjs");
3
- const os = await import("./__vite-browser-external-d06ac358.mjs");
4
- const parts = dir.split(path.sep).filter(Boolean);
1
+ const makeCacheDir = async (dir, fs, path, os) => {
2
+ const pathParts = dir.split(path.sep).filter(Boolean);
3
+ const cacheHash = pathParts[pathParts.length - 1];
4
+ const rootUser = pathParts[0];
5
5
  let cacheDir = dir;
6
- if (!fs.existsSync(path.join(path.sep, parts[0]))) {
7
- cacheDir = path.join(os.tmpdir(), parts[parts.length - 1]);
6
+ if (!fs.existsSync(path.join(path.sep, rootUser))) {
7
+ cacheDir = path.join(os.tmpdir(), cacheHash);
8
+ }
9
+ try {
10
+ fs.mkdirSync(cacheDir, { recursive: true });
11
+ } catch (error) {
12
+ throw new Error(`Failed to create cache directory: ${error.message}`);
8
13
  }
9
- fs.mkdirSync(cacheDir, { recursive: true });
10
14
  return cacheDir;
11
15
  };
12
16
  const NodeCache = async (dir) => {
13
- const fs = await import("./__vite-browser-external-d06ac358.mjs");
14
- const { createHash } = await import("./__vite-browser-external-d06ac358.mjs");
15
- const cacheDir = await makeCacheDir(dir, fs);
17
+ const fs = require("node:fs");
18
+ const path = require("node:path");
19
+ const os = require("node:os");
20
+ const { createHash } = require("node:crypto");
21
+ const cacheDir = await makeCacheDir(dir, fs, path, os);
16
22
  return {
17
23
  makeKey: (key) => {
18
24
  const input = key && key instanceof Object ? JSON.stringify(key) : key || "";
@@ -39,5 +45,6 @@ const NodeCache = async (dir) => {
39
45
  };
40
46
  };
41
47
  export {
42
- NodeCache
48
+ NodeCache,
49
+ makeCacheDir
43
50
  };
@@ -3,6 +3,14 @@ import { FieldProps } from './field-props';
3
3
  import { Form } from '../../forms';
4
4
  export type InputFieldType<ExtraFieldProps, InputProps> = FieldProps<InputProps> & ExtraFieldProps;
5
5
  export declare function wrapFieldsWithMeta<ExtraFieldProps = {}, InputProps = {}>(Field: React.FunctionComponent<InputFieldType<ExtraFieldProps, InputProps>> | React.ComponentClass<InputFieldType<ExtraFieldProps, InputProps>>): (props: InputFieldType<ExtraFieldProps, InputProps>) => React.JSX.Element;
6
+ /**
7
+ * Same as wrapFieldsWithMeta but excludes the label, and description useful for fields that render their label and description
8
+ */
9
+ export declare function wrapFieldWithNoHeader<ExtraFieldProps = {}, InputProps = {}>(Field: React.FunctionComponent<InputFieldType<ExtraFieldProps, InputProps>> | React.ComponentClass<InputFieldType<ExtraFieldProps, InputProps>>): (props: InputFieldType<ExtraFieldProps, InputProps>) => React.JSX.Element;
10
+ /**
11
+ * Same as above but excludes the label, useful for fields that have their own label
12
+ * @deprecated This function is deprecated and will be removed in future versions.
13
+ */
6
14
  export declare function wrapFieldWithError<ExtraFieldProps = {}, InputProps = {}>(Field: React.FunctionComponent<InputFieldType<ExtraFieldProps, InputProps>> | React.ComponentClass<InputFieldType<ExtraFieldProps, InputProps>>): (props: InputFieldType<ExtraFieldProps, InputProps>) => React.JSX.Element;
7
15
  interface FieldMetaProps extends React.HTMLAttributes<HTMLElement> {
8
16
  name: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tinacms",
3
- "version": "2.3.0",
3
+ "version": "2.4.0",
4
4
  "main": "dist/index.js",
5
5
  "module": "./dist/index.mjs",
6
6
  "exports": {
@@ -129,9 +129,9 @@
129
129
  "webfontloader": "1.6.28",
130
130
  "yup": "^1.4.0",
131
131
  "zod": "^3.23.8",
132
- "@tinacms/mdx": "1.5.0",
133
- "@tinacms/schema-tools": "1.6.6",
134
- "@tinacms/search": "1.0.33"
132
+ "@tinacms/mdx": "1.5.1",
133
+ "@tinacms/schema-tools": "1.6.7",
134
+ "@tinacms/search": "1.0.34"
135
135
  },
136
136
  "devDependencies": {
137
137
  "@graphql-tools/utils": "^10.5.4",
@@ -1,4 +0,0 @@
1
- const __viteBrowserExternal = {};
2
- export {
3
- __viteBrowserExternal as default
4
- };