@plasmicpkgs/plasmic-contentful 0.0.178 → 0.0.179

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/dist/index.d.ts CHANGED
@@ -1,16 +1,11 @@
1
+ import { ComponentMeta } from '@plasmicapp/host';
2
+ import { GlobalContextMeta } from '@plasmicapp/host';
3
+ import { default as React_2 } from 'react';
4
+ import { ReactNode } from 'react';
1
5
  import registerComponent from '@plasmicapp/host/registerComponent';
2
6
  import registerGlobalContext from '@plasmicapp/host/registerGlobalContext';
3
- import { GlobalContextMeta, ComponentMeta } from '@plasmicapp/host';
4
- import React, { ReactNode } from 'react';
5
7
 
6
- interface ContentfulCredentialsProviderProps {
7
- space: string;
8
- accessToken: string;
9
- environment?: string;
10
- }
11
- declare const ContentfulCredentialsProviderMeta: GlobalContextMeta<ContentfulCredentialsProviderProps>;
12
- declare function ContentfulCredentialsProvider({ accessToken, space, environment, children, }: React.PropsWithChildren<ContentfulCredentialsProviderProps>): React.JSX.Element;
13
- interface ContentfulControlContextData {
8
+ declare interface ContentfulControlContextData {
14
9
  types?: {
15
10
  name: string;
16
11
  id: string;
@@ -18,7 +13,22 @@ interface ContentfulControlContextData {
18
13
  fields?: string[];
19
14
  queryOptions?: [];
20
15
  }
21
- interface ContentfulFetcherProps {
16
+
17
+ export declare function ContentfulCredentialsProvider({ accessToken, space, environment, children, }: React_2.PropsWithChildren<ContentfulCredentialsProviderProps>): React_2.JSX.Element;
18
+
19
+ export declare const ContentfulCredentialsProviderMeta: GlobalContextMeta<ContentfulCredentialsProviderProps>;
20
+
21
+ declare interface ContentfulCredentialsProviderProps {
22
+ space: string;
23
+ accessToken: string;
24
+ environment?: string;
25
+ }
26
+
27
+ export declare function ContentfulFetcher({ filterField, filterValue, searchParameter, noAutoRepeat, contentType, children, className, order, reverseOrder, limit, include, noLayout, setControlContextData, }: ContentfulFetcherProps): React_2.JSX.Element;
28
+
29
+ export declare const ContentfulFetcherMeta: ComponentMeta<ContentfulFetcherProps>;
30
+
31
+ declare interface ContentfulFetcherProps {
22
32
  contentType: string;
23
33
  children?: ReactNode;
24
34
  className?: string;
@@ -33,21 +43,22 @@ interface ContentfulFetcherProps {
33
43
  noLayout?: boolean;
34
44
  setControlContextData?: (data: ContentfulControlContextData) => void;
35
45
  }
36
- declare const ContentfulFetcherMeta: ComponentMeta<ContentfulFetcherProps>;
37
- declare function ContentfulFetcher({ filterField, filterValue, searchParameter, noAutoRepeat, contentType, children, className, order, reverseOrder, limit, include, noLayout, setControlContextData, }: ContentfulFetcherProps): React.JSX.Element;
38
- interface ContentfulFieldProps {
46
+
47
+ export declare function ContentfulField({ className, objectPath, setControlContextData, }: ContentfulFieldProps): React_2.JSX.Element;
48
+
49
+ export declare const ContentfulFieldMeta: ComponentMeta<ContentfulFieldProps>;
50
+
51
+ declare interface ContentfulFieldProps {
39
52
  className?: string;
40
53
  objectPath?: (string | number)[];
41
54
  setControlContextData?: (data: {
42
55
  data: object;
43
56
  }) => void;
44
57
  }
45
- declare const ContentfulFieldMeta: ComponentMeta<ContentfulFieldProps>;
46
- declare function ContentfulField({ className, objectPath, setControlContextData, }: ContentfulFieldProps): React.JSX.Element;
47
58
 
48
- declare function registerAll(loader?: {
59
+ export declare function registerAll(loader?: {
49
60
  registerComponent: typeof registerComponent;
50
61
  registerGlobalContext: typeof registerGlobalContext;
51
62
  }): void;
52
63
 
53
- export { ContentfulCredentialsProvider, ContentfulCredentialsProviderMeta, ContentfulFetcher, ContentfulFetcherMeta, ContentfulField, ContentfulFieldMeta, registerAll };
64
+ export { }
@@ -1,3 +1,24 @@
1
+ var __async = (__this, __arguments, generator) => {
2
+ return new Promise((resolve, reject) => {
3
+ var fulfilled = (value) => {
4
+ try {
5
+ step(generator.next(value));
6
+ } catch (e) {
7
+ reject(e);
8
+ }
9
+ };
10
+ var rejected = (value) => {
11
+ try {
12
+ step(generator.throw(value));
13
+ } catch (e) {
14
+ reject(e);
15
+ }
16
+ };
17
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
+ step((generator = generator.apply(__this, __arguments)).next());
19
+ });
20
+ };
21
+
1
22
  // src/index.tsx
2
23
  import registerComponent from "@plasmicapp/host/registerComponent";
3
24
  import registerGlobalContext from "@plasmicapp/host/registerGlobalContext";
@@ -108,7 +129,7 @@ var ContentfulFetcherMeta = {
108
129
  },
109
130
  contentType: {
110
131
  type: "choice",
111
- options: (props, ctx) => {
132
+ options: (_props, ctx) => {
112
133
  var _a, _b;
113
134
  return (_b = (_a = ctx == null ? void 0 : ctx.types) == null ? void 0 : _a.map((type) => {
114
135
  var _a2;
@@ -125,7 +146,7 @@ var ContentfulFetcherMeta = {
125
146
  type: "choice",
126
147
  displayName: "Filter field",
127
148
  description: "Field (from Collection) to filter by.",
128
- options: (props, ctx) => {
149
+ options: (_props, ctx) => {
129
150
  var _a;
130
151
  return (_a = ctx == null ? void 0 : ctx.fields) != null ? _a : [];
131
152
  },
@@ -135,7 +156,7 @@ var ContentfulFetcherMeta = {
135
156
  type: "choice",
136
157
  displayName: "Search Parameter",
137
158
  description: "Search Parameter to filter by (see Contentful Content Delivery API documentation for details).",
138
- options: (props, ctx) => {
159
+ options: (_props, ctx) => {
139
160
  var _a;
140
161
  return (_a = ctx == null ? void 0 : ctx.queryOptions) != null ? _a : [];
141
162
  },
@@ -151,7 +172,7 @@ var ContentfulFetcherMeta = {
151
172
  type: "choice",
152
173
  displayName: "Order",
153
174
  description: "Field that the entries should be ordered by.",
154
- options: (props, ctx) => {
175
+ options: (_props, ctx) => {
155
176
  var _a;
156
177
  return [
157
178
  ...(_a = ctx == null ? void 0 : ctx.fields) != null ? _a : [],
@@ -228,12 +249,12 @@ function ContentfulFetcher({
228
249
  const baseUrl = "https://cdn.contentful.com";
229
250
  const { data: contentTypes } = usePlasmicQueryData(
230
251
  `${cacheKey}/contentTypes`,
231
- async () => {
232
- const resp = await fetch(
252
+ () => __async(this, null, function* () {
253
+ const resp = yield fetch(
233
254
  `${baseUrl}/spaces/${creds.space}/environments/${creds.environment}/content_types?access_token=${creds.accessToken}`
234
255
  );
235
256
  return resp.json();
236
- }
257
+ })
237
258
  );
238
259
  setControlContextData == null ? void 0 : setControlContextData({
239
260
  types: (_a = contentTypes == null ? void 0 : contentTypes.items) != null ? _a : []
@@ -248,7 +269,7 @@ function ContentfulFetcher({
248
269
  }
249
270
  const { data: entriesData } = usePlasmicQueryData(
250
271
  contentType ? `${cacheKey}/${contentType}/entriesData` : null,
251
- async () => {
272
+ () => __async(this, null, function* () {
252
273
  const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;
253
274
  const searchParams = new URLSearchParams();
254
275
  searchParams.set("access_token", creds.accessToken);
@@ -260,13 +281,13 @@ function ContentfulFetcher({
260
281
  if (include) {
261
282
  searchParams.set("include", include.toString());
262
283
  }
263
- const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);
284
+ const resp = yield fetch(`${baseUrl}${path}?${searchParams.toString()}`);
264
285
  return resp.json();
265
- }
286
+ })
266
287
  );
267
288
  const { data: filteredData } = usePlasmicQueryData(
268
289
  contentType && filterField && filterValue ? `${cacheKey}/${contentType}/filteredData` : null,
269
- async () => {
290
+ () => __async(this, null, function* () {
270
291
  const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;
271
292
  const searchParams = new URLSearchParams();
272
293
  searchParams.set("access_token", creds.accessToken);
@@ -284,9 +305,9 @@ function ContentfulFetcher({
284
305
  filterValue.toString()
285
306
  );
286
307
  }
287
- const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);
308
+ const resp = yield fetch(`${baseUrl}${path}?${searchParams.toString()}`);
288
309
  return resp.json();
289
- }
310
+ })
290
311
  );
291
312
  if (!creds.space || !creds.accessToken) {
292
313
  return /* @__PURE__ */ React.createElement("div", null, "Please specify a valid API Credentials: Space, Access Token and Environment");
@@ -392,7 +413,7 @@ var ContentfulFieldMeta = {
392
413
  props: {
393
414
  objectPath: {
394
415
  type: "dataSelector",
395
- data: (props, ctx) => {
416
+ data: (_props, ctx) => {
396
417
  var _a;
397
418
  return (_a = ctx == null ? void 0 : ctx.data) != null ? _a : {};
398
419
  },
@@ -469,3 +490,4 @@ export {
469
490
  ContentfulFieldMeta,
470
491
  registerAll
471
492
  };
493
+ //# sourceMappingURL=index.esm.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/index.tsx", "../src/contentful.tsx", "../src/utils.ts"],
4
+ "sourcesContent": ["import registerComponent, {\n ComponentMeta,\n} from \"@plasmicapp/host/registerComponent\";\nimport registerGlobalContext from \"@plasmicapp/host/registerGlobalContext\";\nimport {\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta,\n ContentfulFetcher,\n ContentfulFetcherMeta,\n ContentfulField,\n ContentfulFieldMeta,\n} from \"./contentful\";\n\nexport function registerAll(loader?: {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n}) {\n const _registerComponent = <T extends React.ComponentType<any>>(\n Component: T,\n defaultMeta: ComponentMeta<React.ComponentProps<T>>\n ) => {\n if (loader) {\n loader.registerComponent(Component, defaultMeta);\n } else {\n registerComponent(Component, defaultMeta);\n }\n };\n\n if (loader) {\n loader.registerGlobalContext(\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta\n );\n } else {\n registerGlobalContext(\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta\n );\n }\n _registerComponent(ContentfulFetcher, ContentfulFetcherMeta);\n _registerComponent(ContentfulField, ContentfulFieldMeta);\n}\n\nexport * from \"./contentful\";\n", "import { documentToHtmlString } from \"@contentful/rich-text-html-renderer\";\nimport {\n ComponentMeta,\n DataProvider,\n GlobalContextMeta,\n repeatedElement,\n useSelector,\n} from \"@plasmicapp/host\";\nimport { usePlasmicQueryData } from \"@plasmicapp/query\";\nimport {\n _denormalizeData as denormalizeData,\n _ensure as ensure,\n _uniq as uniq,\n} from \"@plasmicpkgs/contentful\";\nimport { pascalCase } from \"change-case\";\nimport get from \"dlv\";\nimport React, { ReactNode, useContext } from \"react\";\nimport { searchParameters } from \"./utils\";\n\nconst modulePath = \"@plasmicpkgs/plasmic-contentful\";\n\nconst makeDataProviderName = (contentType: string) =>\n `currentContentful${pascalCase(contentType)}Item`;\n\ninterface ContentfulCredentialsProviderProps {\n space: string;\n accessToken: string;\n environment?: string;\n}\n\nconst CredentialsContext = React.createContext<\n ContentfulCredentialsProviderProps | undefined\n>(undefined);\n\nexport const ContentfulCredentialsProviderMeta: GlobalContextMeta<ContentfulCredentialsProviderProps> =\n {\n name: \"Contentful CredentialsProvider\",\n displayName: \"Contentful Credentials Provider\",\n description:\n \"Any client requesting content from the CDA needs to provide an access token that has access to the environment you're requesting content from. Learn how to [get your API key](https://www.contentful.com/developers/docs/references/authentication/).\",\n importName: \"ContentfulCredentialsProvider\",\n importPath: modulePath,\n props: {\n space: {\n type: \"string\",\n displayName: \"Space\",\n description: \"Name of your space\",\n defaultValue: \"lmfbwqzbh93n\",\n },\n accessToken: {\n type: \"string\",\n displayName: \"Access Token \",\n description: \"Access Token\",\n defaultValue: \"aWvf6oSLTuqxKCxSUpokajdQr84hGQFE6zoJG7DVVLg\",\n },\n environment: {\n type: \"string\",\n displayName: \"Environment\",\n defaultValue: \"master\",\n },\n },\n };\n\nexport function ContentfulCredentialsProvider({\n accessToken,\n space,\n environment,\n children,\n}: React.PropsWithChildren<ContentfulCredentialsProviderProps>) {\n return (\n <CredentialsContext.Provider value={{ space, accessToken, environment }}>\n {children}\n </CredentialsContext.Provider>\n );\n}\n\ninterface ContentfulControlContextData {\n types?: { name: string; id: string }[];\n fields?: string[];\n queryOptions?: [];\n}\n\ninterface ContentfulFetcherProps {\n contentType: string;\n children?: ReactNode;\n className?: string;\n limit?: number;\n include?: number;\n order?: string;\n reverseOrder?: boolean;\n filterField?: string;\n searchParameter?: string;\n filterValue?: string | number;\n noAutoRepeat?: boolean;\n noLayout?: boolean;\n setControlContextData?: (data: ContentfulControlContextData) => void;\n}\n\nexport const ContentfulFetcherMeta: ComponentMeta<ContentfulFetcherProps> = {\n name: \"ContentfulFetcher\",\n displayName: \"Contentful Fetcher\",\n importName: \"ContentfulFetcher\",\n importPath: modulePath,\n providesData: true,\n description:\n \"Fetches Contentful data and repeats content of children once for every row fetched. \",\n defaultStyles: {\n display: \"grid\",\n gridTemplateColumns: \"1fr 1fr 1fr 1fr\",\n gridRowGap: \"8px\",\n gridColumnGap: \"8px\",\n padding: \"8px\",\n maxWidth: \"100%\",\n },\n props: {\n children: {\n type: \"slot\",\n defaultValue: {\n type: \"vbox\",\n styles: {\n padding: \"8px\",\n },\n children: {\n type: \"component\",\n name: \"ContentfulField\",\n },\n },\n },\n contentType: {\n type: \"choice\",\n options: (_props, ctx) =>\n ctx?.types?.map((type: any) => ({\n label: type?.name,\n value: type?.sys?.id,\n })) ?? [],\n displayName: \"Content type\",\n description: \"Content type to be queried.\",\n },\n\n filterField: {\n type: \"choice\",\n displayName: \"Filter field\",\n description: \"Field (from Collection) to filter by.\",\n options: (_props, ctx) => ctx?.fields ?? [],\n hidden: (props) => !props.contentType,\n },\n searchParameter: {\n type: \"choice\",\n displayName: \"Search Parameter\",\n description:\n \"Search Parameter to filter by (see Contentful Content Delivery API documentation for details).\",\n options: (_props, ctx) => ctx?.queryOptions ?? [],\n hidden: (props) => !props.filterField,\n },\n filterValue: {\n type: \"string\",\n displayName: \"Filter value\",\n description: \"Value to filter by, should be of filter field type.\",\n hidden: (props) => !props.searchParameter,\n },\n order: {\n type: \"choice\",\n displayName: \"Order\",\n description: \"Field that the entries should be ordered by.\",\n options: (_props, ctx) => [\n ...(ctx?.fields ?? []),\n \"sys.createdAt\",\n \"sys.updatedAt\",\n ],\n hidden: (props) => !props.contentType,\n },\n reverseOrder: {\n type: \"boolean\",\n displayName: \"Reverse order\",\n description: \"Reverse the order of the entries.\",\n defaultValue: false,\n hidden: (props) => !props.order,\n },\n limit: {\n type: \"number\",\n displayName: \"Limit\",\n description: \"Limit the number of entries that are returned.\",\n },\n include: {\n type: \"number\",\n displayName: \"Linked items depth\",\n defaultValueHint: 1,\n description:\n \"When you have related content (e.g. entries with links to image assets) it's possible to include both search results and related data in a single request. Using the include parameter, you can specify the number of levels to resolve.\",\n max: 10,\n min: 0,\n },\n noAutoRepeat: {\n type: \"boolean\",\n displayName: \"No auto-repeat\",\n description: \"Do not automatically repeat children for every entry.\",\n defaultValue: false,\n },\n noLayout: {\n type: \"boolean\",\n displayName: \"No layout\",\n description:\n \"When set, Contentful Fetcher will not layout its children; instead, the layout set on its parent element will be used. Useful if you want to set flex gap or control container tag type.\",\n defaultValue: false,\n },\n },\n};\n\nexport function ContentfulFetcher({\n filterField,\n filterValue,\n searchParameter,\n noAutoRepeat,\n contentType,\n children,\n className,\n order,\n reverseOrder,\n limit,\n include,\n noLayout,\n setControlContextData,\n}: ContentfulFetcherProps) {\n const creds = ensure(\n useContext(CredentialsContext),\n \"Could not find context with current credentials\"\n );\n const cacheKey = JSON.stringify({\n include,\n order,\n reverseOrder,\n limit,\n filterField,\n filterValue,\n searchParameter,\n creds,\n });\n\n const baseUrl = \"https://cdn.contentful.com\";\n\n const { data: contentTypes } = usePlasmicQueryData<any | null>(\n `${cacheKey}/contentTypes`,\n async () => {\n const resp = await fetch(\n `${baseUrl}/spaces/${creds.space}/environments/${creds.environment}/content_types?access_token=${creds.accessToken}`\n );\n return resp.json();\n }\n );\n setControlContextData?.({\n types: contentTypes?.items ?? [],\n });\n\n function setOrderField(searchParams: URLSearchParams) {\n if (order) {\n searchParams.set(\n \"order\",\n `${reverseOrder ? \"-\" : \"\"}${\n order.startsWith(\"sys.\") ? order : `fields.${order}`\n }`\n );\n }\n }\n\n const { data: entriesData } = usePlasmicQueryData<any | null>(\n contentType ? `${cacheKey}/${contentType}/entriesData` : null,\n async () => {\n const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;\n\n const searchParams = new URLSearchParams();\n searchParams.set(\"access_token\", creds.accessToken);\n searchParams.set(\"content_type\", contentType);\n if (limit) {\n searchParams.set(\"limit\", limit.toString());\n }\n setOrderField(searchParams);\n if (include) {\n searchParams.set(\"include\", include.toString());\n }\n\n const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);\n return resp.json();\n }\n );\n\n const { data: filteredData } = usePlasmicQueryData<any | null>(\n contentType && filterField && filterValue\n ? `${cacheKey}/${contentType}/filteredData`\n : null,\n async () => {\n const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;\n\n const searchParams = new URLSearchParams();\n searchParams.set(\"access_token\", creds.accessToken);\n searchParams.set(\"content_type\", contentType);\n if (limit) {\n searchParams.set(\"limit\", limit.toString());\n }\n setOrderField(searchParams);\n\n if (include) {\n searchParams.set(\"include\", include.toString());\n }\n\n if (filterField && searchParameter && filterValue) {\n searchParams.set(\n `fields.${filterField}${searchParameter}`,\n filterValue.toString()\n );\n }\n\n const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);\n return resp.json();\n }\n );\n\n if (!creds.space || !creds.accessToken) {\n return (\n <div>\n Please specify a valid API Credentials: Space, Access Token and\n Environment\n </div>\n );\n }\n\n if (!contentTypes) {\n return <div>Please configure the Contentful credentials</div>;\n }\n\n if (!entriesData) {\n return <div>Please select a content type</div>;\n }\n\n const filterFields: string[] = entriesData?.items.flatMap((item: any) => {\n const fields = Object.keys(item.fields).filter((field) => {\n const value = get(item, field);\n return typeof value !== \"object\" && field !== \"photos\";\n });\n return fields;\n });\n\n let operators;\n const matchedFields = Object.values(entriesData.items).map((item: any) => {\n const fields = Object.entries(item.fields).find(\n (el) => el[0] === filterField\n );\n return fields;\n });\n\n Object.values(matchedFields)\n .map((model: any) => (Array.isArray(model) ? model : [model]))\n .map((item: any) => {\n if (typeof item[1] === \"number\" && typeof item[1] !== \"object\") {\n operators = searchParameters;\n } else if (\n typeof item[1] !== \"number\" &&\n typeof item[1] !== \"object\" &&\n typeof item[1] === \"string\"\n ) {\n operators = [\n {\n value: \"[match]\",\n label: \"Full text search\",\n },\n ];\n }\n });\n\n setControlContextData?.({\n queryOptions: operators ?? [],\n types: contentTypes?.items ?? [],\n fields: uniq(filterFields ?? []),\n });\n\n if (filterField) {\n if (!searchParameter) {\n return <div>Please specify a Search Parameter</div>;\n }\n if (!filterValue) {\n return <div>Please specify a Filter value</div>;\n }\n }\n\n let renderedData;\n\n const fixedData = entriesData ? denormalizeData(entriesData) : undefined;\n\n if (filteredData) {\n if (filteredData?.items?.length === 0) {\n return <div className={className}>No published entry found</div>;\n }\n\n renderedData = noAutoRepeat\n ? children\n : denormalizeData(filteredData)?.items?.map(\n (item: any, index: number) => (\n <DataProvider\n key={item?.sys?.id}\n name={\"contentfulItem\"}\n data={item}\n hidden={true}\n >\n <DataProvider\n name={makeDataProviderName(contentType)}\n data={item}\n >\n {repeatedElement(index, children)}\n </DataProvider>\n </DataProvider>\n )\n );\n } else {\n if (fixedData?.items?.length === 0) {\n return <div className={className}>{contentType} is empty</div>;\n }\n\n renderedData = noAutoRepeat\n ? children\n : fixedData?.items?.map((item: any, index: number) => (\n <DataProvider\n key={item?.sys?.id}\n name={\"contentfulItem\"}\n data={item}\n hidden={true}\n >\n <DataProvider name={makeDataProviderName(contentType)} data={item}>\n {repeatedElement(index, children)}\n </DataProvider>\n </DataProvider>\n ));\n }\n return (\n <DataProvider name=\"contentfulItems\" data={fixedData?.items}>\n {noLayout ? (\n <> {renderedData} </>\n ) : (\n <div className={className}> {renderedData} </div>\n )}\n </DataProvider>\n );\n}\ninterface ContentfulFieldProps {\n className?: string;\n objectPath?: (string | number)[];\n setControlContextData?: (data: { data: object }) => void;\n}\n\nexport const ContentfulFieldMeta: ComponentMeta<ContentfulFieldProps> = {\n name: \"ContentfulField\",\n displayName: \"Contentful Field\",\n importName: \"ContentfulField\",\n importPath: modulePath,\n props: {\n objectPath: {\n type: \"dataSelector\",\n data: (_props, ctx) => ctx?.data ?? {},\n displayName: \"Field\",\n description: \"Field to be displayed.\",\n },\n },\n};\n\nexport function ContentfulField({\n className,\n objectPath,\n setControlContextData,\n}: ContentfulFieldProps) {\n const item = useSelector(\"contentfulItem\")?.fields;\n if (!item) {\n return <div>ContentfulField must be used within a ContentfulFetcher </div>;\n }\n setControlContextData?.({\n data: item,\n });\n if (!objectPath) {\n return <div>Please specify a valid path or select a field.</div>;\n }\n\n const data = get(item, objectPath);\n if (\n typeof data === \"object\" &&\n \"nodeType\" in data &&\n data.nodeType === \"document\"\n ) {\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: documentToHtmlString(data) }}\n />\n );\n } else if (\n typeof data === \"object\" &&\n data.sys?.linkType === \"Asset\" &&\n data.url\n ) {\n return <img className={className} src={data.url} />;\n } else if (!data) {\n return <div>Please specify a valid field.</div>;\n } else if (typeof data !== \"object\") {\n return <div className={className}>{data}</div>;\n } else {\n return <div className={className}>{data.toString()}</div>;\n }\n}\n", "export const searchParameters = [\n {\n value: \"[lt]\",\n label: \"Less than\",\n },\n {\n value: \"[lte]\",\n label: \"Less than or equal\",\n },\n {\n value: \"[gt]\",\n label: \"Greater than\",\n },\n {\n value: \"[gte]\",\n label: \"Greater than or equal \",\n },\n];\n"],
5
+ "mappings": "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",
6
+ "names": ["_a"]
7
+ }
package/dist/index.js CHANGED
@@ -26,6 +26,26 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
26
  mod
27
27
  ));
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var __async = (__this, __arguments, generator) => {
30
+ return new Promise((resolve, reject) => {
31
+ var fulfilled = (value) => {
32
+ try {
33
+ step(generator.next(value));
34
+ } catch (e) {
35
+ reject(e);
36
+ }
37
+ };
38
+ var rejected = (value) => {
39
+ try {
40
+ step(generator.throw(value));
41
+ } catch (e) {
42
+ reject(e);
43
+ }
44
+ };
45
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
46
+ step((generator = generator.apply(__this, __arguments)).next());
47
+ });
48
+ };
29
49
 
30
50
  // src/index.tsx
31
51
  var src_exports = {};
@@ -140,7 +160,7 @@ var ContentfulFetcherMeta = {
140
160
  },
141
161
  contentType: {
142
162
  type: "choice",
143
- options: (props, ctx) => {
163
+ options: (_props, ctx) => {
144
164
  var _a, _b;
145
165
  return (_b = (_a = ctx == null ? void 0 : ctx.types) == null ? void 0 : _a.map((type) => {
146
166
  var _a2;
@@ -157,7 +177,7 @@ var ContentfulFetcherMeta = {
157
177
  type: "choice",
158
178
  displayName: "Filter field",
159
179
  description: "Field (from Collection) to filter by.",
160
- options: (props, ctx) => {
180
+ options: (_props, ctx) => {
161
181
  var _a;
162
182
  return (_a = ctx == null ? void 0 : ctx.fields) != null ? _a : [];
163
183
  },
@@ -167,7 +187,7 @@ var ContentfulFetcherMeta = {
167
187
  type: "choice",
168
188
  displayName: "Search Parameter",
169
189
  description: "Search Parameter to filter by (see Contentful Content Delivery API documentation for details).",
170
- options: (props, ctx) => {
190
+ options: (_props, ctx) => {
171
191
  var _a;
172
192
  return (_a = ctx == null ? void 0 : ctx.queryOptions) != null ? _a : [];
173
193
  },
@@ -183,7 +203,7 @@ var ContentfulFetcherMeta = {
183
203
  type: "choice",
184
204
  displayName: "Order",
185
205
  description: "Field that the entries should be ordered by.",
186
- options: (props, ctx) => {
206
+ options: (_props, ctx) => {
187
207
  var _a;
188
208
  return [
189
209
  ...(_a = ctx == null ? void 0 : ctx.fields) != null ? _a : [],
@@ -260,12 +280,12 @@ function ContentfulFetcher({
260
280
  const baseUrl = "https://cdn.contentful.com";
261
281
  const { data: contentTypes } = (0, import_query.usePlasmicQueryData)(
262
282
  `${cacheKey}/contentTypes`,
263
- async () => {
264
- const resp = await fetch(
283
+ () => __async(this, null, function* () {
284
+ const resp = yield fetch(
265
285
  `${baseUrl}/spaces/${creds.space}/environments/${creds.environment}/content_types?access_token=${creds.accessToken}`
266
286
  );
267
287
  return resp.json();
268
- }
288
+ })
269
289
  );
270
290
  setControlContextData == null ? void 0 : setControlContextData({
271
291
  types: (_a = contentTypes == null ? void 0 : contentTypes.items) != null ? _a : []
@@ -280,7 +300,7 @@ function ContentfulFetcher({
280
300
  }
281
301
  const { data: entriesData } = (0, import_query.usePlasmicQueryData)(
282
302
  contentType ? `${cacheKey}/${contentType}/entriesData` : null,
283
- async () => {
303
+ () => __async(this, null, function* () {
284
304
  const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;
285
305
  const searchParams = new URLSearchParams();
286
306
  searchParams.set("access_token", creds.accessToken);
@@ -292,13 +312,13 @@ function ContentfulFetcher({
292
312
  if (include) {
293
313
  searchParams.set("include", include.toString());
294
314
  }
295
- const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);
315
+ const resp = yield fetch(`${baseUrl}${path}?${searchParams.toString()}`);
296
316
  return resp.json();
297
- }
317
+ })
298
318
  );
299
319
  const { data: filteredData } = (0, import_query.usePlasmicQueryData)(
300
320
  contentType && filterField && filterValue ? `${cacheKey}/${contentType}/filteredData` : null,
301
- async () => {
321
+ () => __async(this, null, function* () {
302
322
  const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;
303
323
  const searchParams = new URLSearchParams();
304
324
  searchParams.set("access_token", creds.accessToken);
@@ -316,9 +336,9 @@ function ContentfulFetcher({
316
336
  filterValue.toString()
317
337
  );
318
338
  }
319
- const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);
339
+ const resp = yield fetch(`${baseUrl}${path}?${searchParams.toString()}`);
320
340
  return resp.json();
321
- }
341
+ })
322
342
  );
323
343
  if (!creds.space || !creds.accessToken) {
324
344
  return /* @__PURE__ */ import_react.default.createElement("div", null, "Please specify a valid API Credentials: Space, Access Token and Environment");
@@ -424,7 +444,7 @@ var ContentfulFieldMeta = {
424
444
  props: {
425
445
  objectPath: {
426
446
  type: "dataSelector",
427
- data: (props, ctx) => {
447
+ data: (_props, ctx) => {
428
448
  var _a;
429
449
  return (_a = ctx == null ? void 0 : ctx.data) != null ? _a : {};
430
450
  },
@@ -492,13 +512,4 @@ function registerAll(loader) {
492
512
  _registerComponent(ContentfulFetcher, ContentfulFetcherMeta);
493
513
  _registerComponent(ContentfulField, ContentfulFieldMeta);
494
514
  }
495
- // Annotate the CommonJS export names for ESM import in node:
496
- 0 && (module.exports = {
497
- ContentfulCredentialsProvider,
498
- ContentfulCredentialsProviderMeta,
499
- ContentfulFetcher,
500
- ContentfulFetcherMeta,
501
- ContentfulField,
502
- ContentfulFieldMeta,
503
- registerAll
504
- });
515
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/index.tsx", "../src/contentful.tsx", "../src/utils.ts"],
4
+ "sourcesContent": ["import registerComponent, {\n ComponentMeta,\n} from \"@plasmicapp/host/registerComponent\";\nimport registerGlobalContext from \"@plasmicapp/host/registerGlobalContext\";\nimport {\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta,\n ContentfulFetcher,\n ContentfulFetcherMeta,\n ContentfulField,\n ContentfulFieldMeta,\n} from \"./contentful\";\n\nexport function registerAll(loader?: {\n registerComponent: typeof registerComponent;\n registerGlobalContext: typeof registerGlobalContext;\n}) {\n const _registerComponent = <T extends React.ComponentType<any>>(\n Component: T,\n defaultMeta: ComponentMeta<React.ComponentProps<T>>\n ) => {\n if (loader) {\n loader.registerComponent(Component, defaultMeta);\n } else {\n registerComponent(Component, defaultMeta);\n }\n };\n\n if (loader) {\n loader.registerGlobalContext(\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta\n );\n } else {\n registerGlobalContext(\n ContentfulCredentialsProvider,\n ContentfulCredentialsProviderMeta\n );\n }\n _registerComponent(ContentfulFetcher, ContentfulFetcherMeta);\n _registerComponent(ContentfulField, ContentfulFieldMeta);\n}\n\nexport * from \"./contentful\";\n", "import { documentToHtmlString } from \"@contentful/rich-text-html-renderer\";\nimport {\n ComponentMeta,\n DataProvider,\n GlobalContextMeta,\n repeatedElement,\n useSelector,\n} from \"@plasmicapp/host\";\nimport { usePlasmicQueryData } from \"@plasmicapp/query\";\nimport {\n _denormalizeData as denormalizeData,\n _ensure as ensure,\n _uniq as uniq,\n} from \"@plasmicpkgs/contentful\";\nimport { pascalCase } from \"change-case\";\nimport get from \"dlv\";\nimport React, { ReactNode, useContext } from \"react\";\nimport { searchParameters } from \"./utils\";\n\nconst modulePath = \"@plasmicpkgs/plasmic-contentful\";\n\nconst makeDataProviderName = (contentType: string) =>\n `currentContentful${pascalCase(contentType)}Item`;\n\ninterface ContentfulCredentialsProviderProps {\n space: string;\n accessToken: string;\n environment?: string;\n}\n\nconst CredentialsContext = React.createContext<\n ContentfulCredentialsProviderProps | undefined\n>(undefined);\n\nexport const ContentfulCredentialsProviderMeta: GlobalContextMeta<ContentfulCredentialsProviderProps> =\n {\n name: \"Contentful CredentialsProvider\",\n displayName: \"Contentful Credentials Provider\",\n description:\n \"Any client requesting content from the CDA needs to provide an access token that has access to the environment you're requesting content from. Learn how to [get your API key](https://www.contentful.com/developers/docs/references/authentication/).\",\n importName: \"ContentfulCredentialsProvider\",\n importPath: modulePath,\n props: {\n space: {\n type: \"string\",\n displayName: \"Space\",\n description: \"Name of your space\",\n defaultValue: \"lmfbwqzbh93n\",\n },\n accessToken: {\n type: \"string\",\n displayName: \"Access Token \",\n description: \"Access Token\",\n defaultValue: \"aWvf6oSLTuqxKCxSUpokajdQr84hGQFE6zoJG7DVVLg\",\n },\n environment: {\n type: \"string\",\n displayName: \"Environment\",\n defaultValue: \"master\",\n },\n },\n };\n\nexport function ContentfulCredentialsProvider({\n accessToken,\n space,\n environment,\n children,\n}: React.PropsWithChildren<ContentfulCredentialsProviderProps>) {\n return (\n <CredentialsContext.Provider value={{ space, accessToken, environment }}>\n {children}\n </CredentialsContext.Provider>\n );\n}\n\ninterface ContentfulControlContextData {\n types?: { name: string; id: string }[];\n fields?: string[];\n queryOptions?: [];\n}\n\ninterface ContentfulFetcherProps {\n contentType: string;\n children?: ReactNode;\n className?: string;\n limit?: number;\n include?: number;\n order?: string;\n reverseOrder?: boolean;\n filterField?: string;\n searchParameter?: string;\n filterValue?: string | number;\n noAutoRepeat?: boolean;\n noLayout?: boolean;\n setControlContextData?: (data: ContentfulControlContextData) => void;\n}\n\nexport const ContentfulFetcherMeta: ComponentMeta<ContentfulFetcherProps> = {\n name: \"ContentfulFetcher\",\n displayName: \"Contentful Fetcher\",\n importName: \"ContentfulFetcher\",\n importPath: modulePath,\n providesData: true,\n description:\n \"Fetches Contentful data and repeats content of children once for every row fetched. \",\n defaultStyles: {\n display: \"grid\",\n gridTemplateColumns: \"1fr 1fr 1fr 1fr\",\n gridRowGap: \"8px\",\n gridColumnGap: \"8px\",\n padding: \"8px\",\n maxWidth: \"100%\",\n },\n props: {\n children: {\n type: \"slot\",\n defaultValue: {\n type: \"vbox\",\n styles: {\n padding: \"8px\",\n },\n children: {\n type: \"component\",\n name: \"ContentfulField\",\n },\n },\n },\n contentType: {\n type: \"choice\",\n options: (_props, ctx) =>\n ctx?.types?.map((type: any) => ({\n label: type?.name,\n value: type?.sys?.id,\n })) ?? [],\n displayName: \"Content type\",\n description: \"Content type to be queried.\",\n },\n\n filterField: {\n type: \"choice\",\n displayName: \"Filter field\",\n description: \"Field (from Collection) to filter by.\",\n options: (_props, ctx) => ctx?.fields ?? [],\n hidden: (props) => !props.contentType,\n },\n searchParameter: {\n type: \"choice\",\n displayName: \"Search Parameter\",\n description:\n \"Search Parameter to filter by (see Contentful Content Delivery API documentation for details).\",\n options: (_props, ctx) => ctx?.queryOptions ?? [],\n hidden: (props) => !props.filterField,\n },\n filterValue: {\n type: \"string\",\n displayName: \"Filter value\",\n description: \"Value to filter by, should be of filter field type.\",\n hidden: (props) => !props.searchParameter,\n },\n order: {\n type: \"choice\",\n displayName: \"Order\",\n description: \"Field that the entries should be ordered by.\",\n options: (_props, ctx) => [\n ...(ctx?.fields ?? []),\n \"sys.createdAt\",\n \"sys.updatedAt\",\n ],\n hidden: (props) => !props.contentType,\n },\n reverseOrder: {\n type: \"boolean\",\n displayName: \"Reverse order\",\n description: \"Reverse the order of the entries.\",\n defaultValue: false,\n hidden: (props) => !props.order,\n },\n limit: {\n type: \"number\",\n displayName: \"Limit\",\n description: \"Limit the number of entries that are returned.\",\n },\n include: {\n type: \"number\",\n displayName: \"Linked items depth\",\n defaultValueHint: 1,\n description:\n \"When you have related content (e.g. entries with links to image assets) it's possible to include both search results and related data in a single request. Using the include parameter, you can specify the number of levels to resolve.\",\n max: 10,\n min: 0,\n },\n noAutoRepeat: {\n type: \"boolean\",\n displayName: \"No auto-repeat\",\n description: \"Do not automatically repeat children for every entry.\",\n defaultValue: false,\n },\n noLayout: {\n type: \"boolean\",\n displayName: \"No layout\",\n description:\n \"When set, Contentful Fetcher will not layout its children; instead, the layout set on its parent element will be used. Useful if you want to set flex gap or control container tag type.\",\n defaultValue: false,\n },\n },\n};\n\nexport function ContentfulFetcher({\n filterField,\n filterValue,\n searchParameter,\n noAutoRepeat,\n contentType,\n children,\n className,\n order,\n reverseOrder,\n limit,\n include,\n noLayout,\n setControlContextData,\n}: ContentfulFetcherProps) {\n const creds = ensure(\n useContext(CredentialsContext),\n \"Could not find context with current credentials\"\n );\n const cacheKey = JSON.stringify({\n include,\n order,\n reverseOrder,\n limit,\n filterField,\n filterValue,\n searchParameter,\n creds,\n });\n\n const baseUrl = \"https://cdn.contentful.com\";\n\n const { data: contentTypes } = usePlasmicQueryData<any | null>(\n `${cacheKey}/contentTypes`,\n async () => {\n const resp = await fetch(\n `${baseUrl}/spaces/${creds.space}/environments/${creds.environment}/content_types?access_token=${creds.accessToken}`\n );\n return resp.json();\n }\n );\n setControlContextData?.({\n types: contentTypes?.items ?? [],\n });\n\n function setOrderField(searchParams: URLSearchParams) {\n if (order) {\n searchParams.set(\n \"order\",\n `${reverseOrder ? \"-\" : \"\"}${\n order.startsWith(\"sys.\") ? order : `fields.${order}`\n }`\n );\n }\n }\n\n const { data: entriesData } = usePlasmicQueryData<any | null>(\n contentType ? `${cacheKey}/${contentType}/entriesData` : null,\n async () => {\n const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;\n\n const searchParams = new URLSearchParams();\n searchParams.set(\"access_token\", creds.accessToken);\n searchParams.set(\"content_type\", contentType);\n if (limit) {\n searchParams.set(\"limit\", limit.toString());\n }\n setOrderField(searchParams);\n if (include) {\n searchParams.set(\"include\", include.toString());\n }\n\n const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);\n return resp.json();\n }\n );\n\n const { data: filteredData } = usePlasmicQueryData<any | null>(\n contentType && filterField && filterValue\n ? `${cacheKey}/${contentType}/filteredData`\n : null,\n async () => {\n const path = `/spaces/${creds.space}/environments/${creds.environment}/entries`;\n\n const searchParams = new URLSearchParams();\n searchParams.set(\"access_token\", creds.accessToken);\n searchParams.set(\"content_type\", contentType);\n if (limit) {\n searchParams.set(\"limit\", limit.toString());\n }\n setOrderField(searchParams);\n\n if (include) {\n searchParams.set(\"include\", include.toString());\n }\n\n if (filterField && searchParameter && filterValue) {\n searchParams.set(\n `fields.${filterField}${searchParameter}`,\n filterValue.toString()\n );\n }\n\n const resp = await fetch(`${baseUrl}${path}?${searchParams.toString()}`);\n return resp.json();\n }\n );\n\n if (!creds.space || !creds.accessToken) {\n return (\n <div>\n Please specify a valid API Credentials: Space, Access Token and\n Environment\n </div>\n );\n }\n\n if (!contentTypes) {\n return <div>Please configure the Contentful credentials</div>;\n }\n\n if (!entriesData) {\n return <div>Please select a content type</div>;\n }\n\n const filterFields: string[] = entriesData?.items.flatMap((item: any) => {\n const fields = Object.keys(item.fields).filter((field) => {\n const value = get(item, field);\n return typeof value !== \"object\" && field !== \"photos\";\n });\n return fields;\n });\n\n let operators;\n const matchedFields = Object.values(entriesData.items).map((item: any) => {\n const fields = Object.entries(item.fields).find(\n (el) => el[0] === filterField\n );\n return fields;\n });\n\n Object.values(matchedFields)\n .map((model: any) => (Array.isArray(model) ? model : [model]))\n .map((item: any) => {\n if (typeof item[1] === \"number\" && typeof item[1] !== \"object\") {\n operators = searchParameters;\n } else if (\n typeof item[1] !== \"number\" &&\n typeof item[1] !== \"object\" &&\n typeof item[1] === \"string\"\n ) {\n operators = [\n {\n value: \"[match]\",\n label: \"Full text search\",\n },\n ];\n }\n });\n\n setControlContextData?.({\n queryOptions: operators ?? [],\n types: contentTypes?.items ?? [],\n fields: uniq(filterFields ?? []),\n });\n\n if (filterField) {\n if (!searchParameter) {\n return <div>Please specify a Search Parameter</div>;\n }\n if (!filterValue) {\n return <div>Please specify a Filter value</div>;\n }\n }\n\n let renderedData;\n\n const fixedData = entriesData ? denormalizeData(entriesData) : undefined;\n\n if (filteredData) {\n if (filteredData?.items?.length === 0) {\n return <div className={className}>No published entry found</div>;\n }\n\n renderedData = noAutoRepeat\n ? children\n : denormalizeData(filteredData)?.items?.map(\n (item: any, index: number) => (\n <DataProvider\n key={item?.sys?.id}\n name={\"contentfulItem\"}\n data={item}\n hidden={true}\n >\n <DataProvider\n name={makeDataProviderName(contentType)}\n data={item}\n >\n {repeatedElement(index, children)}\n </DataProvider>\n </DataProvider>\n )\n );\n } else {\n if (fixedData?.items?.length === 0) {\n return <div className={className}>{contentType} is empty</div>;\n }\n\n renderedData = noAutoRepeat\n ? children\n : fixedData?.items?.map((item: any, index: number) => (\n <DataProvider\n key={item?.sys?.id}\n name={\"contentfulItem\"}\n data={item}\n hidden={true}\n >\n <DataProvider name={makeDataProviderName(contentType)} data={item}>\n {repeatedElement(index, children)}\n </DataProvider>\n </DataProvider>\n ));\n }\n return (\n <DataProvider name=\"contentfulItems\" data={fixedData?.items}>\n {noLayout ? (\n <> {renderedData} </>\n ) : (\n <div className={className}> {renderedData} </div>\n )}\n </DataProvider>\n );\n}\ninterface ContentfulFieldProps {\n className?: string;\n objectPath?: (string | number)[];\n setControlContextData?: (data: { data: object }) => void;\n}\n\nexport const ContentfulFieldMeta: ComponentMeta<ContentfulFieldProps> = {\n name: \"ContentfulField\",\n displayName: \"Contentful Field\",\n importName: \"ContentfulField\",\n importPath: modulePath,\n props: {\n objectPath: {\n type: \"dataSelector\",\n data: (_props, ctx) => ctx?.data ?? {},\n displayName: \"Field\",\n description: \"Field to be displayed.\",\n },\n },\n};\n\nexport function ContentfulField({\n className,\n objectPath,\n setControlContextData,\n}: ContentfulFieldProps) {\n const item = useSelector(\"contentfulItem\")?.fields;\n if (!item) {\n return <div>ContentfulField must be used within a ContentfulFetcher </div>;\n }\n setControlContextData?.({\n data: item,\n });\n if (!objectPath) {\n return <div>Please specify a valid path or select a field.</div>;\n }\n\n const data = get(item, objectPath);\n if (\n typeof data === \"object\" &&\n \"nodeType\" in data &&\n data.nodeType === \"document\"\n ) {\n return (\n <div\n className={className}\n dangerouslySetInnerHTML={{ __html: documentToHtmlString(data) }}\n />\n );\n } else if (\n typeof data === \"object\" &&\n data.sys?.linkType === \"Asset\" &&\n data.url\n ) {\n return <img className={className} src={data.url} />;\n } else if (!data) {\n return <div>Please specify a valid field.</div>;\n } else if (typeof data !== \"object\") {\n return <div className={className}>{data}</div>;\n } else {\n return <div className={className}>{data.toString()}</div>;\n }\n}\n", "export const searchParameters = [\n {\n value: \"[lt]\",\n label: \"Less than\",\n },\n {\n value: \"[lte]\",\n label: \"Less than or equal\",\n },\n {\n value: \"[gt]\",\n label: \"Greater than\",\n },\n {\n value: \"[gte]\",\n label: \"Greater than or equal \",\n },\n];\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "_a", "ensure", "get", "uniq", "denormalizeData", "registerComponent", "registerGlobalContext"]
7
+ }
package/package.json CHANGED
@@ -1,25 +1,35 @@
1
1
  {
2
2
  "name": "@plasmicpkgs/plasmic-contentful",
3
- "version": "0.0.178",
3
+ "version": "0.0.179",
4
4
  "description": "Plasmic Contentful components.",
5
- "main": "dist/index.js",
6
- "typings": "dist/index.d.ts",
7
- "module": "dist/index.mjs",
5
+ "repository": {
6
+ "type": "git",
7
+ "url": "git+https://github.com/plasmicapp/plasmic.git",
8
+ "directory": "plasmicpkgs/plasmic-contentful"
9
+ },
8
10
  "publishConfig": {
9
11
  "access": "public"
10
12
  },
13
+ "main": "./dist/index.js",
14
+ "types": "./dist/index.d.ts",
15
+ "module": "./dist/index.esm.js",
16
+ "exports": {
17
+ ".": {
18
+ "types": "./dist/index.d.ts",
19
+ "import": "./dist/index.esm.js",
20
+ "require": "./dist/index.js"
21
+ }
22
+ },
11
23
  "files": [
12
24
  "dist"
13
25
  ],
14
26
  "scripts": {
15
- "build": "tsup-node src/index.tsx --dts --format esm,cjs --target es2019",
27
+ "build": "yarn build:types && yarn build:index",
28
+ "build:types": "yarn tsc",
29
+ "build:index": "node ../../build.mjs ./src/index.tsx",
16
30
  "test": "TEST_CWD=`pwd` yarn --cwd=../.. test --passWithNoTests",
17
31
  "prepublishOnly": "npm run build",
18
- "size": "size-limit",
19
- "analyze": "size-limit --why"
20
- },
21
- "peerDependencies": {
22
- "react": ">=16"
32
+ "postpublish": "bash ../../scripts/publish-api-doc-model.sh"
23
33
  },
24
34
  "size-limit": [
25
35
  {
@@ -38,11 +48,8 @@
38
48
  "@types/dlv": "^1.1.2",
39
49
  "@types/react": "^18.0.27",
40
50
  "@types/react-dom": "^18.0.10",
41
- "husky": "^7.0.4",
42
51
  "react": "^18.2.0",
43
52
  "react-dom": "^18.2.0",
44
- "tslib": "^2.3.1",
45
- "tsup": "^7.2.0",
46
53
  "typescript": "^5.7.3"
47
54
  },
48
55
  "dependencies": {
@@ -51,5 +58,9 @@
51
58
  "change-case": "^4.1.2",
52
59
  "dlv": "^1.1.3"
53
60
  },
54
- "gitHead": "462339160d0de4b8fbef39bd14830b4be8bc4787"
61
+ "peerDependencies": {
62
+ "@plasmicapp/host": "^1.0.211",
63
+ "react": ">=16.8.0"
64
+ },
65
+ "gitHead": "1e8a75eb4e5dcf4aa0c74b830234d5a0c3e2eabf"
55
66
  }
package/dist/index.d.mts DELETED
@@ -1,53 +0,0 @@
1
- import registerComponent from '@plasmicapp/host/registerComponent';
2
- import registerGlobalContext from '@plasmicapp/host/registerGlobalContext';
3
- import { GlobalContextMeta, ComponentMeta } from '@plasmicapp/host';
4
- import React, { ReactNode } from 'react';
5
-
6
- interface ContentfulCredentialsProviderProps {
7
- space: string;
8
- accessToken: string;
9
- environment?: string;
10
- }
11
- declare const ContentfulCredentialsProviderMeta: GlobalContextMeta<ContentfulCredentialsProviderProps>;
12
- declare function ContentfulCredentialsProvider({ accessToken, space, environment, children, }: React.PropsWithChildren<ContentfulCredentialsProviderProps>): React.JSX.Element;
13
- interface ContentfulControlContextData {
14
- types?: {
15
- name: string;
16
- id: string;
17
- }[];
18
- fields?: string[];
19
- queryOptions?: [];
20
- }
21
- interface ContentfulFetcherProps {
22
- contentType: string;
23
- children?: ReactNode;
24
- className?: string;
25
- limit?: number;
26
- include?: number;
27
- order?: string;
28
- reverseOrder?: boolean;
29
- filterField?: string;
30
- searchParameter?: string;
31
- filterValue?: string | number;
32
- noAutoRepeat?: boolean;
33
- noLayout?: boolean;
34
- setControlContextData?: (data: ContentfulControlContextData) => void;
35
- }
36
- declare const ContentfulFetcherMeta: ComponentMeta<ContentfulFetcherProps>;
37
- declare function ContentfulFetcher({ filterField, filterValue, searchParameter, noAutoRepeat, contentType, children, className, order, reverseOrder, limit, include, noLayout, setControlContextData, }: ContentfulFetcherProps): React.JSX.Element;
38
- interface ContentfulFieldProps {
39
- className?: string;
40
- objectPath?: (string | number)[];
41
- setControlContextData?: (data: {
42
- data: object;
43
- }) => void;
44
- }
45
- declare const ContentfulFieldMeta: ComponentMeta<ContentfulFieldProps>;
46
- declare function ContentfulField({ className, objectPath, setControlContextData, }: ContentfulFieldProps): React.JSX.Element;
47
-
48
- declare function registerAll(loader?: {
49
- registerComponent: typeof registerComponent;
50
- registerGlobalContext: typeof registerGlobalContext;
51
- }): void;
52
-
53
- export { ContentfulCredentialsProvider, ContentfulCredentialsProviderMeta, ContentfulFetcher, ContentfulFetcherMeta, ContentfulField, ContentfulFieldMeta, registerAll };