@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 +29 -18
- package/dist/{index.mjs → index.esm.js} +36 -14
- package/dist/index.esm.js.map +7 -0
- package/dist/index.js +35 -24
- package/dist/index.js.map +7 -0
- package/package.json +25 -14
- package/dist/index.d.mts +0 -53
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
|
|
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
|
-
|
|
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
|
-
|
|
37
|
-
declare function
|
|
38
|
-
|
|
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 {
|
|
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: (
|
|
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: (
|
|
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: (
|
|
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: (
|
|
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
|
-
|
|
232
|
-
const resp =
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
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 =
|
|
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: (
|
|
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: (
|
|
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: (
|
|
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: (
|
|
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: (
|
|
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
|
-
|
|
264
|
-
const resp =
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
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 =
|
|
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: (
|
|
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
|
-
|
|
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": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,+BAEO;AACP,mCAAkC;;;ACHlC,qCAAqC;AACrC,kBAMO;AACP,mBAAoC;AACpC,wBAIO;AACP,yBAA2B;AAC3B,iBAAgB;AAChB,mBAA6C;;;AChBtC,IAAM,mBAAmB;AAAA,EAC9B;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AAAA,EACA;AAAA,IACE,OAAO;AAAA,IACP,OAAO;AAAA,EACT;AACF;;;ADEA,IAAM,aAAa;AAEnB,IAAM,uBAAuB,CAAC,gBAC5B,wBAAoB,+BAAW,WAAW;AAQ5C,IAAM,qBAAqB,aAAAA,QAAM,cAE/B,MAAS;AAEJ,IAAM,oCACX;AAAA,EACE,MAAM;AAAA,EACN,aAAa;AAAA,EACb,aACE;AAAA,EACF,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,OAAO;AAAA,IACL,OAAO;AAAA,MACL,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,cAAc;AAAA,IAChB;AAAA,IACA,aAAa;AAAA,MACX,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,cAAc;AAAA,IAChB;AAAA,IACA,aAAa;AAAA,MACX,MAAM;AAAA,MACN,aAAa;AAAA,MACb,cAAc;AAAA,IAChB;AAAA,EACF;AACF;AAEK,SAAS,8BAA8B;AAAA,EAC5C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAAgE;AAC9D,SACE,6BAAAA,QAAA,cAAC,mBAAmB,UAAnB,EAA4B,OAAO,EAAE,OAAO,aAAa,YAAY,KACnE,QACH;AAEJ;AAwBO,IAAM,wBAA+D;AAAA,EAC1E,MAAM;AAAA,EACN,aAAa;AAAA,EACb,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,aACE;AAAA,EACF,eAAe;AAAA,IACb,SAAS;AAAA,IACT,qBAAqB;AAAA,IACrB,YAAY;AAAA,IACZ,eAAe;AAAA,IACf,SAAS;AAAA,IACT,UAAU;AAAA,EACZ;AAAA,EACA,OAAO;AAAA,IACL,UAAU;AAAA,MACR,MAAM;AAAA,MACN,cAAc;AAAA,QACZ,MAAM;AAAA,QACN,QAAQ;AAAA,UACN,SAAS;AAAA,QACX;AAAA,QACA,UAAU;AAAA,UACR,MAAM;AAAA,UACN,MAAM;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAAA,IACA,aAAa;AAAA,MACX,MAAM;AAAA,MACN,SAAS,CAAC,QAAQ,QAAK;AAlI7B;AAmIQ,sDAAK,UAAL,mBAAY,IAAI,CAAC,SAAW;AAnIpC,cAAAC;AAmIwC;AAAA,YAC9B,OAAO,6BAAM;AAAA,YACb,QAAOA,MAAA,6BAAM,QAAN,gBAAAA,IAAW;AAAA,UACpB;AAAA,eAHA,YAGO,CAAC;AAAA;AAAA,MACV,aAAa;AAAA,MACb,aAAa;AAAA,IACf;AAAA,IAEA,aAAa;AAAA,MACX,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,SAAS,CAAC,QAAQ,QAAK;AA/I7B;AA+IgC,gDAAK,WAAL,YAAe,CAAC;AAAA;AAAA,MAC1C,QAAQ,CAAC,UAAU,CAAC,MAAM;AAAA,IAC5B;AAAA,IACA,iBAAiB;AAAA,MACf,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aACE;AAAA,MACF,SAAS,CAAC,QAAQ,QAAK;AAvJ7B;AAuJgC,gDAAK,iBAAL,YAAqB,CAAC;AAAA;AAAA,MAChD,QAAQ,CAAC,UAAU,CAAC,MAAM;AAAA,IAC5B;AAAA,IACA,aAAa;AAAA,MACX,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,QAAQ,CAAC,UAAU,CAAC,MAAM;AAAA,IAC5B;AAAA,IACA,OAAO;AAAA,MACL,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,SAAS,CAAC,QAAQ,QAAK;AApK7B;AAoKgC;AAAA,UACxB,IAAI,gCAAK,WAAL,YAAe,CAAC;AAAA,UACpB;AAAA,UACA;AAAA,QACF;AAAA;AAAA,MACA,QAAQ,CAAC,UAAU,CAAC,MAAM;AAAA,IAC5B;AAAA,IACA,cAAc;AAAA,MACZ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,cAAc;AAAA,MACd,QAAQ,CAAC,UAAU,CAAC,MAAM;AAAA,IAC5B;AAAA,IACA,OAAO;AAAA,MACL,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,IACf;AAAA,IACA,SAAS;AAAA,MACP,MAAM;AAAA,MACN,aAAa;AAAA,MACb,kBAAkB;AAAA,MAClB,aACE;AAAA,MACF,KAAK;AAAA,MACL,KAAK;AAAA,IACP;AAAA,IACA,cAAc;AAAA,MACZ,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aAAa;AAAA,MACb,cAAc;AAAA,IAChB;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,MACN,aAAa;AAAA,MACb,aACE;AAAA,MACF,cAAc;AAAA,IAChB;AAAA,EACF;AACF;AAEO,SAAS,kBAAkB;AAAA,EAChC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AA9N3B;AA+NE,QAAM,YAAQ,kBAAAC;AAAA,QACZ,yBAAW,kBAAkB;AAAA,IAC7B;AAAA,EACF;AACA,QAAM,WAAW,KAAK,UAAU;AAAA,IAC9B;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,CAAC;AAED,QAAM,UAAU;AAEhB,QAAM,EAAE,MAAM,aAAa,QAAI;AAAA,IAC7B,GAAG;AAAA,IACH,MAAY;AACV,YAAM,OAAO,MAAM;AAAA,QACjB,GAAG,kBAAkB,MAAM,sBAAsB,MAAM,0CAA0C,MAAM;AAAA,MACzG;AACA,aAAO,KAAK,KAAK;AAAA,IACnB;AAAA,EACF;AACA,iEAAwB;AAAA,IACtB,QAAO,kDAAc,UAAd,YAAuB,CAAC;AAAA,EACjC;AAEA,WAAS,cAAc,cAA+B;AACpD,QAAI,OAAO;AACT,mBAAa;AAAA,QACX;AAAA,QACA,GAAG,eAAe,MAAM,KACtB,MAAM,WAAW,MAAM,IAAI,QAAQ,UAAU;AAAA,MAEjD;AAAA,IACF;AAAA,EACF;AAEA,QAAM,EAAE,MAAM,YAAY,QAAI;AAAA,IAC5B,cAAc,GAAG,YAAY,4BAA4B;AAAA,IACzD,MAAY;AACV,YAAM,OAAO,WAAW,MAAM,sBAAsB,MAAM;AAE1D,YAAM,eAAe,IAAI,gBAAgB;AACzC,mBAAa,IAAI,gBAAgB,MAAM,WAAW;AAClD,mBAAa,IAAI,gBAAgB,WAAW;AAC5C,UAAI,OAAO;AACT,qBAAa,IAAI,SAAS,MAAM,SAAS,CAAC;AAAA,MAC5C;AACA,oBAAc,YAAY;AAC1B,UAAI,SAAS;AACX,qBAAa,IAAI,WAAW,QAAQ,SAAS,CAAC;AAAA,MAChD;AAEA,YAAM,OAAO,MAAM,MAAM,GAAG,UAAU,QAAQ,aAAa,SAAS,GAAG;AACvE,aAAO,KAAK,KAAK;AAAA,IACnB;AAAA,EACF;AAEA,QAAM,EAAE,MAAM,aAAa,QAAI;AAAA,IAC7B,eAAe,eAAe,cAC1B,GAAG,YAAY,6BACf;AAAA,IACJ,MAAY;AACV,YAAM,OAAO,WAAW,MAAM,sBAAsB,MAAM;AAE1D,YAAM,eAAe,IAAI,gBAAgB;AACzC,mBAAa,IAAI,gBAAgB,MAAM,WAAW;AAClD,mBAAa,IAAI,gBAAgB,WAAW;AAC5C,UAAI,OAAO;AACT,qBAAa,IAAI,SAAS,MAAM,SAAS,CAAC;AAAA,MAC5C;AACA,oBAAc,YAAY;AAE1B,UAAI,SAAS;AACX,qBAAa,IAAI,WAAW,QAAQ,SAAS,CAAC;AAAA,MAChD;AAEA,UAAI,eAAe,mBAAmB,aAAa;AACjD,qBAAa;AAAA,UACX,UAAU,cAAc;AAAA,UACxB,YAAY,SAAS;AAAA,QACvB;AAAA,MACF;AAEA,YAAM,OAAO,MAAM,MAAM,GAAG,UAAU,QAAQ,aAAa,SAAS,GAAG;AACvE,aAAO,KAAK,KAAK;AAAA,IACnB;AAAA,EACF;AAEA,MAAI,CAAC,MAAM,SAAS,CAAC,MAAM,aAAa;AACtC,WACE,6BAAAF,QAAA,cAAC,aAAI,6EAGL;AAAA,EAEJ;AAEA,MAAI,CAAC,cAAc;AACjB,WAAO,6BAAAA,QAAA,cAAC,aAAI,6CAA2C;AAAA,EACzD;AAEA,MAAI,CAAC,aAAa;AAChB,WAAO,6BAAAA,QAAA,cAAC,aAAI,8BAA4B;AAAA,EAC1C;AAEA,QAAM,eAAyB,2CAAa,MAAM,QAAQ,CAAC,SAAc;AACvE,UAAM,SAAS,OAAO,KAAK,KAAK,MAAM,EAAE,OAAO,CAAC,UAAU;AACxD,YAAM,YAAQ,WAAAG,SAAI,MAAM,KAAK;AAC7B,aAAO,OAAO,UAAU,YAAY,UAAU;AAAA,IAChD,CAAC;AACD,WAAO;AAAA,EACT;AAEA,MAAI;AACJ,QAAM,gBAAgB,OAAO,OAAO,YAAY,KAAK,EAAE,IAAI,CAAC,SAAc;AACxE,UAAM,SAAS,OAAO,QAAQ,KAAK,MAAM,EAAE;AAAA,MACzC,CAAC,OAAO,GAAG,CAAC,MAAM;AAAA,IACpB;AACA,WAAO;AAAA,EACT,CAAC;AAED,SAAO,OAAO,aAAa,EACxB,IAAI,CAAC,UAAgB,MAAM,QAAQ,KAAK,IAAI,QAAQ,CAAC,KAAK,CAAE,EAC5D,IAAI,CAAC,SAAc;AAClB,QAAI,OAAO,KAAK,CAAC,MAAM,YAAY,OAAO,KAAK,CAAC,MAAM,UAAU;AAC9D,kBAAY;AAAA,IACd,WACE,OAAO,KAAK,CAAC,MAAM,YACnB,OAAO,KAAK,CAAC,MAAM,YACnB,OAAO,KAAK,CAAC,MAAM,UACnB;AACA,kBAAY;AAAA,QACV;AAAA,UACE,OAAO;AAAA,UACP,OAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF;AAAA,EACF,CAAC;AAEH,iEAAwB;AAAA,IACtB,cAAc,gCAAa,CAAC;AAAA,IAC5B,QAAO,kDAAc,UAAd,YAAuB,CAAC;AAAA,IAC/B,YAAQ,kBAAAC,OAAK,sCAAgB,CAAC,CAAC;AAAA,EACjC;AAEA,MAAI,aAAa;AACf,QAAI,CAAC,iBAAiB;AACpB,aAAO,6BAAAJ,QAAA,cAAC,aAAI,mCAAiC;AAAA,IAC/C;AACA,QAAI,CAAC,aAAa;AAChB,aAAO,6BAAAA,QAAA,cAAC,aAAI,+BAA6B;AAAA,IAC3C;AAAA,EACF;AAEA,MAAI;AAEJ,QAAM,YAAY,kBAAc,kBAAAK,kBAAgB,WAAW,IAAI;AAE/D,MAAI,cAAc;AAChB,UAAI,kDAAc,UAAd,mBAAqB,YAAW,GAAG;AACrC,aAAO,6BAAAL,QAAA,cAAC,SAAI,aAAsB,0BAAwB;AAAA,IAC5D;AAEA,mBAAe,eACX,YACA,iCAAAK,kBAAgB,YAAY,MAA5B,mBAA+B,UAA/B,mBAAsC;AAAA,MACpC,CAAC,MAAW,UAAe;AA3YrC,YAAAJ;AA4YY,4CAAAD,QAAA;AAAA,UAAC;AAAA;AAAA,YACC,MAAKC,MAAA,6BAAM,QAAN,gBAAAA,IAAW;AAAA,YAChB,MAAM;AAAA,YACN,MAAM;AAAA,YACN,QAAQ;AAAA;AAAA,UAER,6BAAAD,QAAA;AAAA,YAAC;AAAA;AAAA,cACC,MAAM,qBAAqB,WAAW;AAAA,cACtC,MAAM;AAAA;AAAA,gBAEL,6BAAgB,OAAO,QAAQ;AAAA,UAClC;AAAA,QACF;AAAA;AAAA;AAAA,EAGV,OAAO;AACL,UAAI,4CAAW,UAAX,mBAAkB,YAAW,GAAG;AAClC,aAAO,6BAAAA,QAAA,cAAC,SAAI,aAAuB,aAAY,WAAS;AAAA,IAC1D;AAEA,mBAAe,eACX,YACA,4CAAW,UAAX,mBAAkB,IAAI,CAAC,MAAW,UAAe;AAlazD,UAAAC;AAmaU,0CAAAD,QAAA;AAAA,QAAC;AAAA;AAAA,UACC,MAAKC,MAAA,6BAAM,QAAN,gBAAAA,IAAW;AAAA,UAChB,MAAM;AAAA,UACN,MAAM;AAAA,UACN,QAAQ;AAAA;AAAA,QAER,6BAAAD,QAAA,cAAC,4BAAa,MAAM,qBAAqB,WAAW,GAAG,MAAM,YAC1D,6BAAgB,OAAO,QAAQ,CAClC;AAAA,MACF;AAAA;AAAA,EAER;AACA,SACE,6BAAAA,QAAA,cAAC,4BAAa,MAAK,mBAAkB,MAAM,uCAAW,SACnD,WACC,6BAAAA,QAAA,2BAAAA,QAAA,gBAAE,KAAE,cAAa,GAAC,IAElB,6BAAAA,QAAA,cAAC,SAAI,aAAsB,KAAE,cAAa,GAAC,CAE/C;AAEJ;AAOO,IAAM,sBAA2D;AAAA,EACtE,MAAM;AAAA,EACN,aAAa;AAAA,EACb,YAAY;AAAA,EACZ,YAAY;AAAA,EACZ,OAAO;AAAA,IACL,YAAY;AAAA,MACV,MAAM;AAAA,MACN,MAAM,CAAC,QAAQ,QAAK;AAvc1B;AAuc6B,gDAAK,SAAL,YAAa,CAAC;AAAA;AAAA,MACrC,aAAa;AAAA,MACb,aAAa;AAAA,IACf;AAAA,EACF;AACF;AAEO,SAAS,gBAAgB;AAAA,EAC9B;AAAA,EACA;AAAA,EACA;AACF,GAAyB;AAldzB;AAmdE,QAAM,QAAO,kCAAY,gBAAgB,MAA5B,mBAA+B;AAC5C,MAAI,CAAC,MAAM;AACT,WAAO,6BAAAA,QAAA,cAAC,aAAI,0DAAwD;AAAA,EACtE;AACA,iEAAwB;AAAA,IACtB,MAAM;AAAA,EACR;AACA,MAAI,CAAC,YAAY;AACf,WAAO,6BAAAA,QAAA,cAAC,aAAI,gDAA8C;AAAA,EAC5D;AAEA,QAAM,WAAO,WAAAG,SAAI,MAAM,UAAU;AACjC,MACE,OAAO,SAAS,YAChB,cAAc,QACd,KAAK,aAAa,YAClB;AACA,WACE,6BAAAH,QAAA;AAAA,MAAC;AAAA;AAAA,QACC;AAAA,QACA,yBAAyB,EAAE,YAAQ,qDAAqB,IAAI,EAAE;AAAA;AAAA,IAChE;AAAA,EAEJ,WACE,OAAO,SAAS,cAChB,UAAK,QAAL,mBAAU,cAAa,WACvB,KAAK,KACL;AACA,WAAO,6BAAAA,QAAA,cAAC,SAAI,WAAsB,KAAK,KAAK,KAAK;AAAA,EACnD,WAAW,CAAC,MAAM;AAChB,WAAO,6BAAAA,QAAA,cAAC,aAAI,+BAA6B;AAAA,EAC3C,WAAW,OAAO,SAAS,UAAU;AACnC,WAAO,6BAAAA,QAAA,cAAC,SAAI,aAAuB,IAAK;AAAA,EAC1C,OAAO;AACL,WAAO,6BAAAA,QAAA,cAAC,SAAI,aAAuB,KAAK,SAAS,CAAE;AAAA,EACrD;AACF;;;AD1eO,SAAS,YAAY,QAGzB;AACD,QAAM,qBAAqB,CACzB,WACA,gBACG;AACH,QAAI,QAAQ;AACV,aAAO,kBAAkB,WAAW,WAAW;AAAA,IACjD,OAAO;AACL,mCAAAM,SAAkB,WAAW,WAAW;AAAA,IAC1C;AAAA,EACF;AAEA,MAAI,QAAQ;AACV,WAAO;AAAA,MACL;AAAA,MACA;AAAA,IACF;AAAA,EACF,OAAO;AACL,qCAAAC;AAAA,MACE;AAAA,MACA;AAAA,IACF;AAAA,EACF;AACA,qBAAmB,mBAAmB,qBAAqB;AAC3D,qBAAmB,iBAAiB,mBAAmB;AACzD;",
|
|
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.
|
|
3
|
+
"version": "0.0.179",
|
|
4
4
|
"description": "Plasmic Contentful components.",
|
|
5
|
-
"
|
|
6
|
-
|
|
7
|
-
|
|
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": "
|
|
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
|
-
"
|
|
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
|
-
"
|
|
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 };
|