@payloadcms/live-preview 3.37.0-internal.f2e6c68 → 3.37.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/handleMessage.d.ts +2 -1
- package/dist/handleMessage.d.ts.map +1 -1
- package/dist/handleMessage.js +2 -1
- package/dist/handleMessage.js.map +1 -1
- package/dist/mergeData.d.ts +6 -5
- package/dist/mergeData.d.ts.map +1 -1
- package/dist/mergeData.js +1 -1
- package/dist/mergeData.js.map +1 -1
- package/dist/subscribe.d.ts +2 -0
- package/dist/subscribe.d.ts.map +1 -1
- package/dist/subscribe.js +2 -1
- package/dist/subscribe.js.map +1 -1
- package/dist/types.d.ts +5 -0
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js.map +1 -1
- package/package.json +2 -2
package/dist/handleMessage.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import type { LivePreviewMessageEvent } from './types.js';
|
|
1
|
+
import type { CollectionPopulationRequestHandler, LivePreviewMessageEvent } from './types.js';
|
|
2
2
|
export declare const handleMessage: <T extends Record<string, any>>(args: {
|
|
3
3
|
apiRoute?: string;
|
|
4
4
|
depth?: number;
|
|
5
5
|
event: LivePreviewMessageEvent<T>;
|
|
6
6
|
initialData: T;
|
|
7
|
+
requestHandler?: CollectionPopulationRequestHandler;
|
|
7
8
|
serverURL: string;
|
|
8
9
|
}) => Promise<T>;
|
|
9
10
|
//# sourceMappingURL=handleMessage.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handleMessage.d.ts","sourceRoot":"","sources":["../src/handleMessage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"handleMessage.d.ts","sourceRoot":"","sources":["../src/handleMessage.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,kCAAkC,EAAE,uBAAuB,EAAE,MAAM,YAAY,CAAA;AAwB7F,eAAO,MAAM,aAAa,GAAU,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ;IACvE,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,uBAAuB,CAAC,CAAC,CAAC,CAAA;IACjC,WAAW,EAAE,CAAC,CAAA;IACd,cAAc,CAAC,EAAE,kCAAkC,CAAA;IACnD,SAAS,EAAE,MAAM,CAAA;CAClB,KAAG,OAAO,CAAC,CAAC,CAqCZ,CAAA"}
|
package/dist/handleMessage.js
CHANGED
|
@@ -13,7 +13,7 @@ const _payloadLivePreview = {
|
|
|
13
13
|
*/ previousData: undefined
|
|
14
14
|
};
|
|
15
15
|
export const handleMessage = async (args)=>{
|
|
16
|
-
const { apiRoute, depth, event, initialData, serverURL } = args;
|
|
16
|
+
const { apiRoute, depth, event, initialData, requestHandler, serverURL } = args;
|
|
17
17
|
if (isLivePreviewEvent(event, serverURL)) {
|
|
18
18
|
const { data, externallyUpdatedRelationship, fieldSchemaJSON, locale } = event.data;
|
|
19
19
|
if (!_payloadLivePreview?.fieldSchema && fieldSchemaJSON) {
|
|
@@ -32,6 +32,7 @@ export const handleMessage = async (args)=>{
|
|
|
32
32
|
incomingData: data,
|
|
33
33
|
initialData: _payloadLivePreview?.previousData || initialData,
|
|
34
34
|
locale,
|
|
35
|
+
requestHandler,
|
|
35
36
|
serverURL
|
|
36
37
|
});
|
|
37
38
|
_payloadLivePreview.previousData = mergedData;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/handleMessage.ts"],"sourcesContent":["import type { FieldSchemaJSON } from 'payload'\n\nimport type { LivePreviewMessageEvent } from './types.js'\n\nimport { isLivePreviewEvent } from './isLivePreviewEvent.js'\nimport { mergeData } from './mergeData.js'\n\nconst _payloadLivePreview: {\n fieldSchema: FieldSchemaJSON | undefined\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n previousData: any\n} = {\n /**\n * For performance reasons, `fieldSchemaJSON` will only be sent once on the initial message\n * We need to cache this value so that it can be used across subsequent messages\n * To do this, save `fieldSchemaJSON` when it arrives as a global variable\n * Send this cached value to `mergeData`, instead of `eventData.fieldSchemaJSON` directly\n */\n fieldSchema: undefined,\n /**\n * Each time the data is merged, cache the result as a `previousData` variable\n * This will ensure changes compound overtop of each other\n */\n previousData: undefined,\n}\n\nexport const handleMessage = async <T extends Record<string, any>>(args: {\n apiRoute?: string\n depth?: number\n event: LivePreviewMessageEvent<T>\n initialData: T\n serverURL: string\n}): Promise<T> => {\n const { apiRoute, depth, event, initialData, serverURL } = args\n\n if (isLivePreviewEvent(event, serverURL)) {\n const { data, externallyUpdatedRelationship, fieldSchemaJSON, locale } = event.data\n\n if (!_payloadLivePreview?.fieldSchema && fieldSchemaJSON) {\n _payloadLivePreview.fieldSchema = fieldSchemaJSON\n }\n\n if (!_payloadLivePreview?.fieldSchema) {\n // eslint-disable-next-line no-console\n console.warn(\n 'Payload Live Preview: No `fieldSchemaJSON` was received from the parent window. Unable to merge data.',\n )\n\n return initialData\n }\n\n const mergedData = await mergeData<T>({\n apiRoute,\n depth,\n externallyUpdatedRelationship,\n fieldSchema: _payloadLivePreview.fieldSchema,\n incomingData: data,\n initialData: _payloadLivePreview?.previousData || initialData,\n locale,\n serverURL,\n })\n\n _payloadLivePreview.previousData = mergedData\n\n return mergedData\n }\n\n return initialData\n}\n"],"names":["isLivePreviewEvent","mergeData","_payloadLivePreview","fieldSchema","undefined","previousData","handleMessage","args","apiRoute","depth","event","initialData","serverURL","data","externallyUpdatedRelationship","fieldSchemaJSON","locale","console","warn","mergedData","incomingData"],"mappings":"AAIA,SAASA,kBAAkB,QAAQ,0BAAyB;AAC5D,SAASC,SAAS,QAAQ,iBAAgB;AAE1C,MAAMC,sBAIF;IACF;;;;;GAKC,GACDC,aAAaC;IACb;;;GAGC,GACDC,cAAcD;AAChB;AAEA,OAAO,MAAME,gBAAgB,OAAsCC;
|
|
1
|
+
{"version":3,"sources":["../src/handleMessage.ts"],"sourcesContent":["import type { FieldSchemaJSON } from 'payload'\n\nimport type { CollectionPopulationRequestHandler, LivePreviewMessageEvent } from './types.js'\n\nimport { isLivePreviewEvent } from './isLivePreviewEvent.js'\nimport { mergeData } from './mergeData.js'\n\nconst _payloadLivePreview: {\n fieldSchema: FieldSchemaJSON | undefined\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n previousData: any\n} = {\n /**\n * For performance reasons, `fieldSchemaJSON` will only be sent once on the initial message\n * We need to cache this value so that it can be used across subsequent messages\n * To do this, save `fieldSchemaJSON` when it arrives as a global variable\n * Send this cached value to `mergeData`, instead of `eventData.fieldSchemaJSON` directly\n */\n fieldSchema: undefined,\n /**\n * Each time the data is merged, cache the result as a `previousData` variable\n * This will ensure changes compound overtop of each other\n */\n previousData: undefined,\n}\n\nexport const handleMessage = async <T extends Record<string, any>>(args: {\n apiRoute?: string\n depth?: number\n event: LivePreviewMessageEvent<T>\n initialData: T\n requestHandler?: CollectionPopulationRequestHandler\n serverURL: string\n}): Promise<T> => {\n const { apiRoute, depth, event, initialData, requestHandler, serverURL } = args\n\n if (isLivePreviewEvent(event, serverURL)) {\n const { data, externallyUpdatedRelationship, fieldSchemaJSON, locale } = event.data\n\n if (!_payloadLivePreview?.fieldSchema && fieldSchemaJSON) {\n _payloadLivePreview.fieldSchema = fieldSchemaJSON\n }\n\n if (!_payloadLivePreview?.fieldSchema) {\n // eslint-disable-next-line no-console\n console.warn(\n 'Payload Live Preview: No `fieldSchemaJSON` was received from the parent window. Unable to merge data.',\n )\n\n return initialData\n }\n\n const mergedData = await mergeData<T>({\n apiRoute,\n depth,\n externallyUpdatedRelationship,\n fieldSchema: _payloadLivePreview.fieldSchema,\n incomingData: data,\n initialData: _payloadLivePreview?.previousData || initialData,\n locale,\n requestHandler,\n serverURL,\n })\n\n _payloadLivePreview.previousData = mergedData\n\n return mergedData\n }\n\n return initialData\n}\n"],"names":["isLivePreviewEvent","mergeData","_payloadLivePreview","fieldSchema","undefined","previousData","handleMessage","args","apiRoute","depth","event","initialData","requestHandler","serverURL","data","externallyUpdatedRelationship","fieldSchemaJSON","locale","console","warn","mergedData","incomingData"],"mappings":"AAIA,SAASA,kBAAkB,QAAQ,0BAAyB;AAC5D,SAASC,SAAS,QAAQ,iBAAgB;AAE1C,MAAMC,sBAIF;IACF;;;;;GAKC,GACDC,aAAaC;IACb;;;GAGC,GACDC,cAAcD;AAChB;AAEA,OAAO,MAAME,gBAAgB,OAAsCC;IAQjE,MAAM,EAAEC,QAAQ,EAAEC,KAAK,EAAEC,KAAK,EAAEC,WAAW,EAAEC,cAAc,EAAEC,SAAS,EAAE,GAAGN;IAE3E,IAAIP,mBAAmBU,OAAOG,YAAY;QACxC,MAAM,EAAEC,IAAI,EAAEC,6BAA6B,EAAEC,eAAe,EAAEC,MAAM,EAAE,GAAGP,MAAMI,IAAI;QAEnF,IAAI,CAACZ,qBAAqBC,eAAea,iBAAiB;YACxDd,oBAAoBC,WAAW,GAAGa;QACpC;QAEA,IAAI,CAACd,qBAAqBC,aAAa;YACrC,sCAAsC;YACtCe,QAAQC,IAAI,CACV;YAGF,OAAOR;QACT;QAEA,MAAMS,aAAa,MAAMnB,UAAa;YACpCO;YACAC;YACAM;YACAZ,aAAaD,oBAAoBC,WAAW;YAC5CkB,cAAcP;YACdH,aAAaT,qBAAqBG,gBAAgBM;YAClDM;YACAL;YACAC;QACF;QAEAX,oBAAoBG,YAAY,GAAGe;QAEnC,OAAOA;IACT;IAEA,OAAOT;AACT,EAAC"}
|
package/dist/mergeData.d.ts
CHANGED
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
import type { DocumentEvent, FieldSchemaJSON } from 'payload';
|
|
2
|
+
import type { CollectionPopulationRequestHandler } from './types.js';
|
|
2
3
|
export declare const mergeData: <T extends Record<string, any>>(args: {
|
|
3
4
|
apiRoute?: string;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}) => Promise<Response>;
|
|
5
|
+
/**
|
|
6
|
+
* @deprecated Use `requestHandler` instead
|
|
7
|
+
*/
|
|
8
|
+
collectionPopulationRequestHandler?: CollectionPopulationRequestHandler;
|
|
9
9
|
depth?: number;
|
|
10
10
|
externallyUpdatedRelationship?: DocumentEvent;
|
|
11
11
|
fieldSchema: FieldSchemaJSON;
|
|
12
12
|
incomingData: Partial<T>;
|
|
13
13
|
initialData: T;
|
|
14
14
|
locale?: string;
|
|
15
|
+
requestHandler?: CollectionPopulationRequestHandler;
|
|
15
16
|
returnNumberOfRequests?: boolean;
|
|
16
17
|
serverURL: string;
|
|
17
18
|
}) => Promise<{
|
package/dist/mergeData.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"mergeData.d.ts","sourceRoot":"","sources":["../src/mergeData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAiB,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"mergeData.d.ts","sourceRoot":"","sources":["../src/mergeData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAiB,MAAM,SAAS,CAAA;AAE5E,OAAO,KAAK,EAAE,kCAAkC,EAA2B,MAAM,YAAY,CAAA;AA2B7F,eAAO,MAAM,SAAS,GAAU,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ;IACnE,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB;;OAEG;IACH,kCAAkC,CAAC,EAAE,kCAAkC,CAAA;IACvE,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,6BAA6B,CAAC,EAAE,aAAa,CAAA;IAC7C,WAAW,EAAE,eAAe,CAAA;IAC5B,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC,CAAA;IACxB,WAAW,EAAE,CAAC,CAAA;IACd,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,cAAc,CAAC,EAAE,kCAAkC,CAAA;IACnD,sBAAsB,CAAC,EAAE,OAAO,CAAA;IAChC,SAAS,EAAE,MAAM,CAAA;CAClB,KAAG,OAAO,CACT;IACE,iBAAiB,CAAC,EAAE,MAAM,CAAA;CAC3B,GAAG,CAAC,CAmEN,CAAA"}
|
package/dist/mergeData.js
CHANGED
|
@@ -29,7 +29,7 @@ export const mergeData = async (args)=>{
|
|
|
29
29
|
await Promise.all(Object.entries(populationsByCollection).map(async ([collection, populations])=>{
|
|
30
30
|
let res;
|
|
31
31
|
const ids = new Set(populations.map(({ id })=>id));
|
|
32
|
-
const requestHandler = args.collectionPopulationRequestHandler || defaultRequestHandler;
|
|
32
|
+
const requestHandler = args.collectionPopulationRequestHandler || args.requestHandler || defaultRequestHandler;
|
|
33
33
|
try {
|
|
34
34
|
res = await requestHandler({
|
|
35
35
|
apiPath: apiRoute || '/api',
|
package/dist/mergeData.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/mergeData.ts"],"sourcesContent":["import type { DocumentEvent, FieldSchemaJSON, PaginatedDocs } from 'payload'\n\nimport type { PopulationsByCollection } from './types.js'\n\nimport { traverseFields } from './traverseFields.js'\n\nconst defaultRequestHandler = ({\n apiPath,\n endpoint,\n serverURL,\n}: {\n apiPath: string\n endpoint: string\n serverURL: string\n}) => {\n const url = `${serverURL}${apiPath}/${endpoint}`\n return fetch(url, {\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n\n// Relationships are only updated when their `id` or `relationTo` changes, by comparing the old and new values\n// This needs to also happen when locale changes, except this is not not part of the API response\n// Instead, we keep track of the old locale ourselves and trigger a re-population when it changes\nlet prevLocale: string | undefined\n\nexport const mergeData = async <T extends Record<string, any>>(args: {\n apiRoute?: string\n
|
|
1
|
+
{"version":3,"sources":["../src/mergeData.ts"],"sourcesContent":["import type { DocumentEvent, FieldSchemaJSON, PaginatedDocs } from 'payload'\n\nimport type { CollectionPopulationRequestHandler, PopulationsByCollection } from './types.js'\n\nimport { traverseFields } from './traverseFields.js'\n\nconst defaultRequestHandler = ({\n apiPath,\n endpoint,\n serverURL,\n}: {\n apiPath: string\n endpoint: string\n serverURL: string\n}) => {\n const url = `${serverURL}${apiPath}/${endpoint}`\n return fetch(url, {\n credentials: 'include',\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n\n// Relationships are only updated when their `id` or `relationTo` changes, by comparing the old and new values\n// This needs to also happen when locale changes, except this is not not part of the API response\n// Instead, we keep track of the old locale ourselves and trigger a re-population when it changes\nlet prevLocale: string | undefined\n\nexport const mergeData = async <T extends Record<string, any>>(args: {\n apiRoute?: string\n /**\n * @deprecated Use `requestHandler` instead\n */\n collectionPopulationRequestHandler?: CollectionPopulationRequestHandler\n depth?: number\n externallyUpdatedRelationship?: DocumentEvent\n fieldSchema: FieldSchemaJSON\n incomingData: Partial<T>\n initialData: T\n locale?: string\n requestHandler?: CollectionPopulationRequestHandler\n returnNumberOfRequests?: boolean\n serverURL: string\n}): Promise<\n {\n _numberOfRequests?: number\n } & T\n> => {\n const {\n apiRoute,\n depth,\n externallyUpdatedRelationship,\n fieldSchema,\n incomingData,\n initialData,\n locale,\n returnNumberOfRequests,\n serverURL,\n } = args\n\n const result = { ...initialData }\n\n const populationsByCollection: PopulationsByCollection = {}\n\n traverseFields({\n externallyUpdatedRelationship,\n fieldSchema,\n incomingData,\n localeChanged: prevLocale !== locale,\n populationsByCollection,\n result,\n })\n\n await Promise.all(\n Object.entries(populationsByCollection).map(async ([collection, populations]) => {\n let res: PaginatedDocs\n\n const ids = new Set(populations.map(({ id }) => id))\n const requestHandler =\n args.collectionPopulationRequestHandler || args.requestHandler || defaultRequestHandler\n\n try {\n res = await requestHandler({\n apiPath: apiRoute || '/api',\n endpoint: encodeURI(\n `${collection}?depth=${depth}&where[id][in]=${Array.from(ids).join(',')}${locale ? `&locale=${locale}` : ''}`,\n ),\n serverURL,\n }).then((res) => res.json())\n\n if (res?.docs?.length > 0) {\n res.docs.forEach((doc) => {\n populationsByCollection[collection]?.forEach((population) => {\n if (population.id === doc.id) {\n population.ref[population.accessor] = doc\n }\n })\n })\n }\n } catch (err) {\n console.error(err) // eslint-disable-line no-console\n }\n }),\n )\n\n prevLocale = locale\n\n return {\n ...result,\n ...(returnNumberOfRequests\n ? { _numberOfRequests: Object.keys(populationsByCollection).length }\n : {}),\n }\n}\n"],"names":["traverseFields","defaultRequestHandler","apiPath","endpoint","serverURL","url","fetch","credentials","headers","prevLocale","mergeData","args","apiRoute","depth","externallyUpdatedRelationship","fieldSchema","incomingData","initialData","locale","returnNumberOfRequests","result","populationsByCollection","localeChanged","Promise","all","Object","entries","map","collection","populations","res","ids","Set","id","requestHandler","collectionPopulationRequestHandler","encodeURI","Array","from","join","then","json","docs","length","forEach","doc","population","ref","accessor","err","console","error","_numberOfRequests","keys"],"mappings":"AAIA,SAASA,cAAc,QAAQ,sBAAqB;AAEpD,MAAMC,wBAAwB,CAAC,EAC7BC,OAAO,EACPC,QAAQ,EACRC,SAAS,EAKV;IACC,MAAMC,MAAM,GAAGD,YAAYF,QAAQ,CAAC,EAAEC,UAAU;IAChD,OAAOG,MAAMD,KAAK;QAChBE,aAAa;QACbC,SAAS;YACP,gBAAgB;QAClB;IACF;AACF;AAEA,8GAA8G;AAC9G,iGAAiG;AACjG,iGAAiG;AACjG,IAAIC;AAEJ,OAAO,MAAMC,YAAY,OAAsCC;IAoB7D,MAAM,EACJC,QAAQ,EACRC,KAAK,EACLC,6BAA6B,EAC7BC,WAAW,EACXC,YAAY,EACZC,WAAW,EACXC,MAAM,EACNC,sBAAsB,EACtBf,SAAS,EACV,GAAGO;IAEJ,MAAMS,SAAS;QAAE,GAAGH,WAAW;IAAC;IAEhC,MAAMI,0BAAmD,CAAC;IAE1DrB,eAAe;QACbc;QACAC;QACAC;QACAM,eAAeb,eAAeS;QAC9BG;QACAD;IACF;IAEA,MAAMG,QAAQC,GAAG,CACfC,OAAOC,OAAO,CAACL,yBAAyBM,GAAG,CAAC,OAAO,CAACC,YAAYC,YAAY;QAC1E,IAAIC;QAEJ,MAAMC,MAAM,IAAIC,IAAIH,YAAYF,GAAG,CAAC,CAAC,EAAEM,EAAE,EAAE,GAAKA;QAChD,MAAMC,iBACJvB,KAAKwB,kCAAkC,IAAIxB,KAAKuB,cAAc,IAAIjC;QAEpE,IAAI;YACF6B,MAAM,MAAMI,eAAe;gBACzBhC,SAASU,YAAY;gBACrBT,UAAUiC,UACR,GAAGR,WAAW,OAAO,EAAEf,MAAM,eAAe,EAAEwB,MAAMC,IAAI,CAACP,KAAKQ,IAAI,CAAC,OAAOrB,SAAS,CAAC,QAAQ,EAAEA,QAAQ,GAAG,IAAI;gBAE/Gd;YACF,GAAGoC,IAAI,CAAC,CAACV,MAAQA,IAAIW,IAAI;YAEzB,IAAIX,KAAKY,MAAMC,SAAS,GAAG;gBACzBb,IAAIY,IAAI,CAACE,OAAO,CAAC,CAACC;oBAChBxB,uBAAuB,CAACO,WAAW,EAAEgB,QAAQ,CAACE;wBAC5C,IAAIA,WAAWb,EAAE,KAAKY,IAAIZ,EAAE,EAAE;4BAC5Ba,WAAWC,GAAG,CAACD,WAAWE,QAAQ,CAAC,GAAGH;wBACxC;oBACF;gBACF;YACF;QACF,EAAE,OAAOI,KAAK;YACZC,QAAQC,KAAK,CAACF,KAAK,iCAAiC;;QACtD;IACF;IAGFxC,aAAaS;IAEb,OAAO;QACL,GAAGE,MAAM;QACT,GAAID,yBACA;YAAEiC,mBAAmB3B,OAAO4B,IAAI,CAAChC,yBAAyBsB,MAAM;QAAC,IACjE,CAAC,CAAC;IACR;AACF,EAAC"}
|
package/dist/subscribe.d.ts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
import type { CollectionPopulationRequestHandler } from './types.js';
|
|
1
2
|
export declare const subscribe: <T extends Record<string, any>>(args: {
|
|
2
3
|
apiRoute?: string;
|
|
3
4
|
callback: (data: T) => void;
|
|
4
5
|
depth?: number;
|
|
5
6
|
initialData: T;
|
|
7
|
+
requestHandler?: CollectionPopulationRequestHandler;
|
|
6
8
|
serverURL: string;
|
|
7
9
|
}) => ((event: MessageEvent) => Promise<void> | void);
|
|
8
10
|
//# sourceMappingURL=subscribe.d.ts.map
|
package/dist/subscribe.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"subscribe.d.ts","sourceRoot":"","sources":["../src/subscribe.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"subscribe.d.ts","sourceRoot":"","sources":["../src/subscribe.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kCAAkC,EAAE,MAAM,YAAY,CAAA;AAIpE,eAAO,MAAM,SAAS,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,QAAQ;IAC7D,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAA;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,WAAW,EAAE,CAAC,CAAA;IACd,cAAc,CAAC,EAAE,kCAAkC,CAAA;IACnD,SAAS,EAAE,MAAM,CAAA;CAClB,KAAG,CAAC,CAAC,KAAK,EAAE,YAAY,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAqBjD,CAAA"}
|
package/dist/subscribe.js
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { handleMessage } from './handleMessage.js';
|
|
2
2
|
export const subscribe = (args)=>{
|
|
3
|
-
const { apiRoute, callback, depth, initialData, serverURL } = args;
|
|
3
|
+
const { apiRoute, callback, depth, initialData, requestHandler, serverURL } = args;
|
|
4
4
|
const onMessage = async (event)=>{
|
|
5
5
|
const mergedData = await handleMessage({
|
|
6
6
|
apiRoute,
|
|
7
7
|
depth,
|
|
8
8
|
event,
|
|
9
9
|
initialData,
|
|
10
|
+
requestHandler,
|
|
10
11
|
serverURL
|
|
11
12
|
});
|
|
12
13
|
callback(mergedData);
|
package/dist/subscribe.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/subscribe.ts"],"sourcesContent":["import { handleMessage } from './handleMessage.js'\n\nexport const subscribe = <T extends Record<string, any>>(args: {\n apiRoute?: string\n callback: (data: T) => void\n depth?: number\n initialData: T\n serverURL: string\n}): ((event: MessageEvent) => Promise<void> | void) => {\n const { apiRoute, callback, depth, initialData, serverURL } = args\n\n const onMessage = async (event: MessageEvent) => {\n const mergedData = await handleMessage<T>({\n apiRoute,\n depth,\n event,\n initialData,\n serverURL,\n })\n\n callback(mergedData)\n }\n\n if (typeof window !== 'undefined') {\n window.addEventListener('message', onMessage)\n }\n\n return onMessage\n}\n"],"names":["handleMessage","subscribe","args","apiRoute","callback","depth","initialData","serverURL","onMessage","event","mergedData","window","addEventListener"],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../src/subscribe.ts"],"sourcesContent":["import type { CollectionPopulationRequestHandler } from './types.js'\n\nimport { handleMessage } from './handleMessage.js'\n\nexport const subscribe = <T extends Record<string, any>>(args: {\n apiRoute?: string\n callback: (data: T) => void\n depth?: number\n initialData: T\n requestHandler?: CollectionPopulationRequestHandler\n serverURL: string\n}): ((event: MessageEvent) => Promise<void> | void) => {\n const { apiRoute, callback, depth, initialData, requestHandler, serverURL } = args\n\n const onMessage = async (event: MessageEvent) => {\n const mergedData = await handleMessage<T>({\n apiRoute,\n depth,\n event,\n initialData,\n requestHandler,\n serverURL,\n })\n\n callback(mergedData)\n }\n\n if (typeof window !== 'undefined') {\n window.addEventListener('message', onMessage)\n }\n\n return onMessage\n}\n"],"names":["handleMessage","subscribe","args","apiRoute","callback","depth","initialData","requestHandler","serverURL","onMessage","event","mergedData","window","addEventListener"],"mappings":"AAEA,SAASA,aAAa,QAAQ,qBAAoB;AAElD,OAAO,MAAMC,YAAY,CAAgCC;IAQvD,MAAM,EAAEC,QAAQ,EAAEC,QAAQ,EAAEC,KAAK,EAAEC,WAAW,EAAEC,cAAc,EAAEC,SAAS,EAAE,GAAGN;IAE9E,MAAMO,YAAY,OAAOC;QACvB,MAAMC,aAAa,MAAMX,cAAiB;YACxCG;YACAE;YACAK;YACAJ;YACAC;YACAC;QACF;QAEAJ,SAASO;IACX;IAEA,IAAI,OAAOC,WAAW,aAAa;QACjCA,OAAOC,gBAAgB,CAAC,WAAWJ;IACrC;IAEA,OAAOA;AACT,EAAC"}
|
package/dist/types.d.ts
CHANGED
|
@@ -1,4 +1,9 @@
|
|
|
1
1
|
import type { DocumentEvent, FieldSchemaJSON } from 'payload';
|
|
2
|
+
export type CollectionPopulationRequestHandler = ({ apiPath, endpoint, serverURL, }: {
|
|
3
|
+
apiPath: string;
|
|
4
|
+
endpoint: string;
|
|
5
|
+
serverURL: string;
|
|
6
|
+
}) => Promise<Response>;
|
|
2
7
|
export type LivePreviewArgs = {};
|
|
3
8
|
export type LivePreview = void;
|
|
4
9
|
export type PopulationsByCollection = {
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAE7D,MAAM,MAAM,eAAe,GAAG,EAAE,CAAA;AAEhC,MAAM,MAAM,WAAW,GAAG,IAAI,CAAA;AAE9B,MAAM,MAAM,uBAAuB,GAAG;IACpC,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK,CAAC;QACpB,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAA;QACzB,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;QACnB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAC7B,CAAC,CAAA;CACH,CAAA;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,IAAI,YAAY,CAAC;IACpD,IAAI,EAAE,CAAC,CAAA;IACP,6BAA6B,CAAC,EAAE,aAAa,CAAA;IAC7C,eAAe,EAAE,eAAe,CAAA;IAChC,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,sBAAsB,CAAA;CAC7B,CAAC,CAAA"}
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,SAAS,CAAA;AAE7D,MAAM,MAAM,kCAAkC,GAAG,CAAC,EAChD,OAAO,EACP,QAAQ,EACR,SAAS,GACV,EAAE;IACD,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;CAClB,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAA;AAEvB,MAAM,MAAM,eAAe,GAAG,EAAE,CAAA;AAEhC,MAAM,MAAM,WAAW,GAAG,IAAI,CAAA;AAE9B,MAAM,MAAM,uBAAuB,GAAG;IACpC,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK,CAAC;QACpB,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAA;QACzB,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;QACnB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAC7B,CAAC,CAAA;CACH,CAAA;AAED,MAAM,MAAM,uBAAuB,CAAC,CAAC,IAAI,YAAY,CAAC;IACpD,IAAI,EAAE,CAAC,CAAA;IACP,6BAA6B,CAAC,EAAE,aAAa,CAAA;IAC7C,eAAe,EAAE,eAAe,CAAA;IAChC,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,EAAE,sBAAsB,CAAA;CAC7B,CAAC,CAAA"}
|
package/dist/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { DocumentEvent, FieldSchemaJSON } from 'payload'\n\nexport type LivePreviewArgs = {}\n\nexport type LivePreview = void\n\nexport type PopulationsByCollection = {\n [slug: string]: Array<{\n accessor: number | string\n id: number | string\n ref: Record<string, unknown>\n }>\n}\n\nexport type LivePreviewMessageEvent<T> = MessageEvent<{\n data: T\n externallyUpdatedRelationship?: DocumentEvent\n fieldSchemaJSON: FieldSchemaJSON\n locale?: string\n type: 'payload-live-preview'\n}>\n"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"sources":["../src/types.ts"],"sourcesContent":["import type { DocumentEvent, FieldSchemaJSON } from 'payload'\n\nexport type CollectionPopulationRequestHandler = ({\n apiPath,\n endpoint,\n serverURL,\n}: {\n apiPath: string\n endpoint: string\n serverURL: string\n}) => Promise<Response>\n\nexport type LivePreviewArgs = {}\n\nexport type LivePreview = void\n\nexport type PopulationsByCollection = {\n [slug: string]: Array<{\n accessor: number | string\n id: number | string\n ref: Record<string, unknown>\n }>\n}\n\nexport type LivePreviewMessageEvent<T> = MessageEvent<{\n data: T\n externallyUpdatedRelationship?: DocumentEvent\n fieldSchemaJSON: FieldSchemaJSON\n locale?: string\n type: 'payload-live-preview'\n}>\n"],"names":[],"mappings":"AAwBA,WAME"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@payloadcms/live-preview",
|
|
3
|
-
"version": "3.37.0
|
|
3
|
+
"version": "3.37.0",
|
|
4
4
|
"description": "The official live preview JavaScript SDK for Payload",
|
|
5
5
|
"homepage": "https://payloadcms.com",
|
|
6
6
|
"repository": {
|
|
@@ -32,7 +32,7 @@
|
|
|
32
32
|
],
|
|
33
33
|
"devDependencies": {
|
|
34
34
|
"@payloadcms/eslint-config": "3.28.0",
|
|
35
|
-
"payload": "3.37.0
|
|
35
|
+
"payload": "3.37.0"
|
|
36
36
|
},
|
|
37
37
|
"publishConfig": {
|
|
38
38
|
"registry": "https://registry.npmjs.org/"
|