@payloadcms/live-preview 0.1.4 → 0.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,6 @@
1
1
  export declare const handleMessage: <T>(args: {
2
- depth: number;
2
+ apiRoute?: string;
3
+ depth?: number;
3
4
  event: MessageEvent;
4
5
  initialData: T;
5
6
  serverURL: string;
@@ -1 +1 @@
1
- {"version":3,"file":"handleMessage.d.ts","sourceRoot":"","sources":["../src/handleMessage.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,aAAa;WACjB,MAAM;WACN,YAAY;;eAER,MAAM;gBAwBlB,CAAA"}
1
+ {"version":3,"file":"handleMessage.d.ts","sourceRoot":"","sources":["../src/handleMessage.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,aAAa;eACb,MAAM;YACT,MAAM;WACP,YAAY;;eAER,MAAM;gBAmClB,CAAA"}
@@ -16,14 +16,20 @@ const _ = require(".");
16
16
  let payloadLivePreviewFieldSchema = undefined // TODO: type this from `fieldSchemaToJSON` return type
17
17
  ;
18
18
  const handleMessage = async (args)=>{
19
- const { depth, event, initialData, serverURL } = args;
19
+ const { apiRoute, depth, event, initialData, serverURL } = args;
20
20
  if (event.origin === serverURL && event.data) {
21
21
  const eventData = JSON.parse(event?.data);
22
22
  if (eventData.type === 'payload-live-preview') {
23
23
  if (!payloadLivePreviewFieldSchema && eventData.fieldSchemaJSON) {
24
24
  payloadLivePreviewFieldSchema = eventData.fieldSchemaJSON;
25
25
  }
26
+ if (!payloadLivePreviewFieldSchema) {
27
+ // eslint-disable-next-line no-console
28
+ console.warn('Payload Live Preview: No `fieldSchemaJSON` was received from the parent window. Unable to merge data.');
29
+ return initialData;
30
+ }
26
31
  const mergedData = await (0, _.mergeData)({
32
+ apiRoute,
27
33
  depth,
28
34
  fieldSchema: payloadLivePreviewFieldSchema,
29
35
  incomingData: eventData.data,
@@ -36,4 +42,4 @@ const handleMessage = async (args)=>{
36
42
  return initialData;
37
43
  };
38
44
 
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9oYW5kbGVNZXNzYWdlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lcmdlRGF0YSB9IGZyb20gJy4nXG5cbi8vIEZvciBwZXJmb3JtYW5jZSByZWFzb25zLCBgZmllbGRTY2hlbWFKU09OYCB3aWxsIG9ubHkgYmUgc2VudCBvbmNlIG9uIHRoZSBpbml0aWFsIG1lc3NhZ2Vcbi8vIFdlIG5lZWQgdG8gY2FjaGUgdGhpcyB2YWx1ZSBzbyB0aGF0IGl0IGNhbiBiZSB1c2VkIGFjcm9zcyBzdWJzZXF1ZW50IG1lc3NhZ2VzXG4vLyBUbyBkbyB0aGlzLCBzYXZlIGBmaWVsZFNjaGVtYUpTT05gIHdoZW4gaXQgYXJyaXZlcyBhcyBhIGdsb2JhbCB2YXJpYWJsZVxuLy8gU2VuZCB0aGlzIGNhY2hlZCB2YWx1ZSB0byBgbWVyZ2VEYXRhYCwgaW5zdGVhZCBvZiBgZXZlbnREYXRhLmZpZWxkU2NoZW1hSlNPTmAgZGlyZWN0bHlcbmxldCBwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSA9IHVuZGVmaW5lZCAvLyBUT0RPOiB0eXBlIHRoaXMgZnJvbSBgZmllbGRTY2hlbWFUb0pTT05gIHJldHVybiB0eXBlXG5cbmV4cG9ydCBjb25zdCBoYW5kbGVNZXNzYWdlID0gYXN5bmMgPFQ+KGFyZ3M6IHtcbiAgZGVwdGg6IG51bWJlclxuICBldmVudDogTWVzc2FnZUV2ZW50XG4gIGluaXRpYWxEYXRhOiBUXG4gIHNlcnZlclVSTDogc3RyaW5nXG59KTogUHJvbWlzZTxUPiA9PiB7XG4gIGNvbnN0IHsgZGVwdGgsIGV2ZW50LCBpbml0aWFsRGF0YSwgc2VydmVyVVJMIH0gPSBhcmdzXG4gIGlmIChldmVudC5vcmlnaW4gPT09IHNlcnZlclVSTCAmJiBldmVudC5kYXRhKSB7XG4gICAgY29uc3QgZXZlbnREYXRhID0gSlNPTi5wYXJzZShldmVudD8uZGF0YSlcblxuICAgIGlmIChldmVudERhdGEudHlwZSA9PT0gJ3BheWxvYWQtbGl2ZS1wcmV2aWV3Jykge1xuICAgICAgaWYgKCFwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSAmJiBldmVudERhdGEuZmllbGRTY2hlbWFKU09OKSB7XG4gICAgICAgIHBheWxvYWRMaXZlUHJldmlld0ZpZWxkU2NoZW1hID0gZXZlbnREYXRhLmZpZWxkU2NoZW1hSlNPTlxuICAgICAgfVxuXG4gICAgICBjb25zdCBtZXJnZWREYXRhID0gYXdhaXQgbWVyZ2VEYXRhPFQ+KHtcbiAgICAgICAgZGVwdGgsXG4gICAgICAgIGZpZWxkU2NoZW1hOiBwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSxcbiAgICAgICAgaW5jb21pbmdEYXRhOiBldmVudERhdGEuZGF0YSxcbiAgICAgICAgaW5pdGlhbERhdGEsXG4gICAgICAgIHNlcnZlclVSTCxcbiAgICAgIH0pXG5cbiAgICAgIHJldHVybiBtZXJnZWREYXRhXG4gICAgfVxuICB9XG5cbiAgcmV0dXJuIGluaXRpYWxEYXRhXG59XG4iXSwibmFtZXMiOlsiaGFuZGxlTWVzc2FnZSIsInBheWxvYWRMaXZlUHJldmlld0ZpZWxkU2NoZW1hIiwidW5kZWZpbmVkIiwiYXJncyIsImRlcHRoIiwiZXZlbnQiLCJpbml0aWFsRGF0YSIsInNlcnZlclVSTCIsIm9yaWdpbiIsImRhdGEiLCJldmVudERhdGEiLCJKU09OIiwicGFyc2UiLCJ0eXBlIiwiZmllbGRTY2hlbWFKU09OIiwibWVyZ2VkRGF0YSIsIm1lcmdlRGF0YSIsImZpZWxkU2NoZW1hIiwiaW5jb21pbmdEYXRhIl0sIm1hcHBpbmdzIjoiOzs7OytCQVFhQTs7O2VBQUFBOzs7a0JBUmE7QUFFMUIsMkZBQTJGO0FBQzNGLGdGQUFnRjtBQUNoRiwwRUFBMEU7QUFDMUUseUZBQXlGO0FBQ3pGLElBQUlDLGdDQUFnQ0MsVUFBVSx1REFBdUQ7O0FBRTlGLE1BQU1GLGdCQUFnQixPQUFVRztJQU1yQyxNQUFNLEVBQUVDLEtBQUssRUFBRUMsS0FBSyxFQUFFQyxXQUFXLEVBQUVDLFNBQVMsRUFBRSxHQUFHSjtJQUNqRCxJQUFJRSxNQUFNRyxNQUFNLEtBQUtELGFBQWFGLE1BQU1JLElBQUksRUFBRTtRQUM1QyxNQUFNQyxZQUFZQyxLQUFLQyxLQUFLLENBQUNQLE9BQU9JO1FBRXBDLElBQUlDLFVBQVVHLElBQUksS0FBSyx3QkFBd0I7WUFDN0MsSUFBSSxDQUFDWixpQ0FBaUNTLFVBQVVJLGVBQWUsRUFBRTtnQkFDL0RiLGdDQUFnQ1MsVUFBVUksZUFBZTtZQUMzRDtZQUVBLE1BQU1DLGFBQWEsTUFBTUMsSUFBQUEsV0FBUyxFQUFJO2dCQUNwQ1o7Z0JBQ0FhLGFBQWFoQjtnQkFDYmlCLGNBQWNSLFVBQVVELElBQUk7Z0JBQzVCSDtnQkFDQUM7WUFDRjtZQUVBLE9BQU9RO1FBQ1Q7SUFDRjtJQUVBLE9BQU9UO0FBQ1QifQ==
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9oYW5kbGVNZXNzYWdlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IG1lcmdlRGF0YSB9IGZyb20gJy4nXG5cbi8vIEZvciBwZXJmb3JtYW5jZSByZWFzb25zLCBgZmllbGRTY2hlbWFKU09OYCB3aWxsIG9ubHkgYmUgc2VudCBvbmNlIG9uIHRoZSBpbml0aWFsIG1lc3NhZ2Vcbi8vIFdlIG5lZWQgdG8gY2FjaGUgdGhpcyB2YWx1ZSBzbyB0aGF0IGl0IGNhbiBiZSB1c2VkIGFjcm9zcyBzdWJzZXF1ZW50IG1lc3NhZ2VzXG4vLyBUbyBkbyB0aGlzLCBzYXZlIGBmaWVsZFNjaGVtYUpTT05gIHdoZW4gaXQgYXJyaXZlcyBhcyBhIGdsb2JhbCB2YXJpYWJsZVxuLy8gU2VuZCB0aGlzIGNhY2hlZCB2YWx1ZSB0byBgbWVyZ2VEYXRhYCwgaW5zdGVhZCBvZiBgZXZlbnREYXRhLmZpZWxkU2NoZW1hSlNPTmAgZGlyZWN0bHlcbmxldCBwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSA9IHVuZGVmaW5lZCAvLyBUT0RPOiB0eXBlIHRoaXMgZnJvbSBgZmllbGRTY2hlbWFUb0pTT05gIHJldHVybiB0eXBlXG5cbmV4cG9ydCBjb25zdCBoYW5kbGVNZXNzYWdlID0gYXN5bmMgPFQ+KGFyZ3M6IHtcbiAgYXBpUm91dGU/OiBzdHJpbmdcbiAgZGVwdGg/OiBudW1iZXJcbiAgZXZlbnQ6IE1lc3NhZ2VFdmVudFxuICBpbml0aWFsRGF0YTogVFxuICBzZXJ2ZXJVUkw6IHN0cmluZ1xufSk6IFByb21pc2U8VD4gPT4ge1xuICBjb25zdCB7IGFwaVJvdXRlLCBkZXB0aCwgZXZlbnQsIGluaXRpYWxEYXRhLCBzZXJ2ZXJVUkwgfSA9IGFyZ3NcblxuICBpZiAoZXZlbnQub3JpZ2luID09PSBzZXJ2ZXJVUkwgJiYgZXZlbnQuZGF0YSkge1xuICAgIGNvbnN0IGV2ZW50RGF0YSA9IEpTT04ucGFyc2UoZXZlbnQ/LmRhdGEpXG5cbiAgICBpZiAoZXZlbnREYXRhLnR5cGUgPT09ICdwYXlsb2FkLWxpdmUtcHJldmlldycpIHtcbiAgICAgIGlmICghcGF5bG9hZExpdmVQcmV2aWV3RmllbGRTY2hlbWEgJiYgZXZlbnREYXRhLmZpZWxkU2NoZW1hSlNPTikge1xuICAgICAgICBwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSA9IGV2ZW50RGF0YS5maWVsZFNjaGVtYUpTT05cbiAgICAgIH1cblxuICAgICAgaWYgKCFwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSkge1xuICAgICAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICAgICAgICBjb25zb2xlLndhcm4oXG4gICAgICAgICAgJ1BheWxvYWQgTGl2ZSBQcmV2aWV3OiBObyBgZmllbGRTY2hlbWFKU09OYCB3YXMgcmVjZWl2ZWQgZnJvbSB0aGUgcGFyZW50IHdpbmRvdy4gVW5hYmxlIHRvIG1lcmdlIGRhdGEuJyxcbiAgICAgICAgKVxuXG4gICAgICAgIHJldHVybiBpbml0aWFsRGF0YVxuICAgICAgfVxuXG4gICAgICBjb25zdCBtZXJnZWREYXRhID0gYXdhaXQgbWVyZ2VEYXRhPFQ+KHtcbiAgICAgICAgYXBpUm91dGUsXG4gICAgICAgIGRlcHRoLFxuICAgICAgICBmaWVsZFNjaGVtYTogcGF5bG9hZExpdmVQcmV2aWV3RmllbGRTY2hlbWEsXG4gICAgICAgIGluY29taW5nRGF0YTogZXZlbnREYXRhLmRhdGEsXG4gICAgICAgIGluaXRpYWxEYXRhLFxuICAgICAgICBzZXJ2ZXJVUkwsXG4gICAgICB9KVxuXG4gICAgICByZXR1cm4gbWVyZ2VkRGF0YVxuICAgIH1cbiAgfVxuXG4gIHJldHVybiBpbml0aWFsRGF0YVxufVxuIl0sIm5hbWVzIjpbImhhbmRsZU1lc3NhZ2UiLCJwYXlsb2FkTGl2ZVByZXZpZXdGaWVsZFNjaGVtYSIsInVuZGVmaW5lZCIsImFyZ3MiLCJhcGlSb3V0ZSIsImRlcHRoIiwiZXZlbnQiLCJpbml0aWFsRGF0YSIsInNlcnZlclVSTCIsIm9yaWdpbiIsImRhdGEiLCJldmVudERhdGEiLCJKU09OIiwicGFyc2UiLCJ0eXBlIiwiZmllbGRTY2hlbWFKU09OIiwiY29uc29sZSIsIndhcm4iLCJtZXJnZWREYXRhIiwibWVyZ2VEYXRhIiwiZmllbGRTY2hlbWEiLCJpbmNvbWluZ0RhdGEiXSwibWFwcGluZ3MiOiI7Ozs7K0JBUWFBOzs7ZUFBQUE7OztrQkFSYTtBQUUxQiwyRkFBMkY7QUFDM0YsZ0ZBQWdGO0FBQ2hGLDBFQUEwRTtBQUMxRSx5RkFBeUY7QUFDekYsSUFBSUMsZ0NBQWdDQyxVQUFVLHVEQUF1RDs7QUFFOUYsTUFBTUYsZ0JBQWdCLE9BQVVHO0lBT3JDLE1BQU0sRUFBRUMsUUFBUSxFQUFFQyxLQUFLLEVBQUVDLEtBQUssRUFBRUMsV0FBVyxFQUFFQyxTQUFTLEVBQUUsR0FBR0w7SUFFM0QsSUFBSUcsTUFBTUcsTUFBTSxLQUFLRCxhQUFhRixNQUFNSSxJQUFJLEVBQUU7UUFDNUMsTUFBTUMsWUFBWUMsS0FBS0MsS0FBSyxDQUFDUCxPQUFPSTtRQUVwQyxJQUFJQyxVQUFVRyxJQUFJLEtBQUssd0JBQXdCO1lBQzdDLElBQUksQ0FBQ2IsaUNBQWlDVSxVQUFVSSxlQUFlLEVBQUU7Z0JBQy9EZCxnQ0FBZ0NVLFVBQVVJLGVBQWU7WUFDM0Q7WUFFQSxJQUFJLENBQUNkLCtCQUErQjtnQkFDbEMsc0NBQXNDO2dCQUN0Q2UsUUFBUUMsSUFBSSxDQUNWO2dCQUdGLE9BQU9WO1lBQ1Q7WUFFQSxNQUFNVyxhQUFhLE1BQU1DLElBQUFBLFdBQVMsRUFBSTtnQkFDcENmO2dCQUNBQztnQkFDQWUsYUFBYW5CO2dCQUNib0IsY0FBY1YsVUFBVUQsSUFBSTtnQkFDNUJIO2dCQUNBQztZQUNGO1lBRUEsT0FBT1U7UUFDVDtJQUNGO0lBRUEsT0FBT1g7QUFDVCJ9
@@ -1,10 +1,13 @@
1
- export type MergeLiveDataArgs<T> = {
1
+ import type { fieldSchemaToJSON } from 'payload/utilities';
2
+ export declare const mergeData: <T>(args: {
2
3
  apiRoute?: string;
3
- depth: number;
4
- fieldSchema: Record<string, unknown>[];
5
- incomingData: T;
4
+ depth?: number;
5
+ fieldSchema: ReturnType<typeof fieldSchemaToJSON>;
6
+ incomingData: Partial<T>;
6
7
  initialData: T;
8
+ returnNumberOfRequests?: boolean;
7
9
  serverURL: string;
8
- };
9
- export declare const mergeData: <T>({ apiRoute, depth, fieldSchema, incomingData, initialData, serverURL, }: MergeLiveDataArgs<T>) => Promise<T>;
10
+ }) => Promise<T & {
11
+ _numberOfRequests?: number;
12
+ }>;
10
13
  //# sourceMappingURL=mergeData.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"mergeData.d.ts","sourceRoot":"","sources":["../src/mergeData.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI;IACjC,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IACtC,YAAY,EAAE,CAAC,CAAA;IACf,WAAW,EAAE,CAAC,CAAA;IACd,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,SAAS,kHAyBrB,CAAA"}
1
+ {"version":3,"file":"mergeData.d.ts","sourceRoot":"","sources":["../src/mergeData.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;AAI1D,eAAO,MAAM,SAAS;eACT,MAAM;YACT,MAAM;iBACD,WAAW,wBAAwB,CAAC;;;6BAGxB,OAAO;eACrB,MAAM;;wBAGK,MAAM;EAiC7B,CAAA"}
package/dist/mergeData.js CHANGED
@@ -9,7 +9,8 @@ Object.defineProperty(exports, "mergeData", {
9
9
  }
10
10
  });
11
11
  const _traverseFields = require("./traverseFields");
12
- const mergeData = async ({ apiRoute, depth, fieldSchema, incomingData, initialData, serverURL })=>{
12
+ const mergeData = async (args)=>{
13
+ const { apiRoute, depth, fieldSchema, incomingData, initialData, returnNumberOfRequests, serverURL } = args;
13
14
  const result = {
14
15
  ...initialData
15
16
  };
@@ -24,7 +25,12 @@ const mergeData = async ({ apiRoute, depth, fieldSchema, incomingData, initialDa
24
25
  serverURL
25
26
  });
26
27
  await Promise.all(populationPromises);
27
- return result;
28
+ return {
29
+ ...result,
30
+ ...returnNumberOfRequests ? {
31
+ _numberOfRequests: populationPromises.length
32
+ } : {}
33
+ };
28
34
  };
29
35
 
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tZXJnZURhdGEudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHJhdmVyc2VGaWVsZHMgfSBmcm9tICcuL3RyYXZlcnNlRmllbGRzJ1xuXG5leHBvcnQgdHlwZSBNZXJnZUxpdmVEYXRhQXJnczxUPiA9IHtcbiAgYXBpUm91dGU/OiBzdHJpbmdcbiAgZGVwdGg6IG51bWJlclxuICBmaWVsZFNjaGVtYTogUmVjb3JkPHN0cmluZywgdW5rbm93bj5bXVxuICBpbmNvbWluZ0RhdGE6IFRcbiAgaW5pdGlhbERhdGE6IFRcbiAgc2VydmVyVVJMOiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IG1lcmdlRGF0YSA9IGFzeW5jIDxUPih7XG4gIGFwaVJvdXRlLFxuICBkZXB0aCxcbiAgZmllbGRTY2hlbWEsXG4gIGluY29taW5nRGF0YSxcbiAgaW5pdGlhbERhdGEsXG4gIHNlcnZlclVSTCxcbn06IE1lcmdlTGl2ZURhdGFBcmdzPFQ+KTogUHJvbWlzZTxUPiA9PiB7XG4gIGNvbnN0IHJlc3VsdCA9IHsgLi4uaW5pdGlhbERhdGEgfVxuXG4gIGNvbnN0IHBvcHVsYXRpb25Qcm9taXNlczogUHJvbWlzZTx2b2lkPltdID0gW11cblxuICB0cmF2ZXJzZUZpZWxkcyh7XG4gICAgYXBpUm91dGUsXG4gICAgZGVwdGgsXG4gICAgZmllbGRTY2hlbWEsXG4gICAgaW5jb21pbmdEYXRhLFxuICAgIHBvcHVsYXRpb25Qcm9taXNlcyxcbiAgICByZXN1bHQsXG4gICAgc2VydmVyVVJMLFxuICB9KVxuXG4gIGF3YWl0IFByb21pc2UuYWxsKHBvcHVsYXRpb25Qcm9taXNlcylcblxuICByZXR1cm4gcmVzdWx0XG59XG4iXSwibmFtZXMiOlsibWVyZ2VEYXRhIiwiYXBpUm91dGUiLCJkZXB0aCIsImZpZWxkU2NoZW1hIiwiaW5jb21pbmdEYXRhIiwiaW5pdGlhbERhdGEiLCJzZXJ2ZXJVUkwiLCJyZXN1bHQiLCJwb3B1bGF0aW9uUHJvbWlzZXMiLCJ0cmF2ZXJzZUZpZWxkcyIsIlByb21pc2UiLCJhbGwiXSwibWFwcGluZ3MiOiI7Ozs7K0JBV2FBOzs7ZUFBQUE7OztnQ0FYa0I7QUFXeEIsTUFBTUEsWUFBWSxPQUFVLEVBQ2pDQyxRQUFRLEVBQ1JDLEtBQUssRUFDTEMsV0FBVyxFQUNYQyxZQUFZLEVBQ1pDLFdBQVcsRUFDWEMsU0FBUyxFQUNZO0lBQ3JCLE1BQU1DLFNBQVM7UUFBRSxHQUFHRixXQUFXO0lBQUM7SUFFaEMsTUFBTUcscUJBQXNDLEVBQUU7SUFFOUNDLElBQUFBLDhCQUFjLEVBQUM7UUFDYlI7UUFDQUM7UUFDQUM7UUFDQUM7UUFDQUk7UUFDQUQ7UUFDQUQ7SUFDRjtJQUVBLE1BQU1JLFFBQVFDLEdBQUcsQ0FBQ0g7SUFFbEIsT0FBT0Q7QUFDVCJ9
36
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9tZXJnZURhdGEudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBmaWVsZFNjaGVtYVRvSlNPTiB9IGZyb20gJ3BheWxvYWQvdXRpbGl0aWVzJ1xuXG5pbXBvcnQgeyB0cmF2ZXJzZUZpZWxkcyB9IGZyb20gJy4vdHJhdmVyc2VGaWVsZHMnXG5cbmV4cG9ydCBjb25zdCBtZXJnZURhdGEgPSBhc3luYyA8VD4oYXJnczoge1xuICBhcGlSb3V0ZT86IHN0cmluZ1xuICBkZXB0aD86IG51bWJlclxuICBmaWVsZFNjaGVtYTogUmV0dXJuVHlwZTx0eXBlb2YgZmllbGRTY2hlbWFUb0pTT04+XG4gIGluY29taW5nRGF0YTogUGFydGlhbDxUPlxuICBpbml0aWFsRGF0YTogVFxuICByZXR1cm5OdW1iZXJPZlJlcXVlc3RzPzogYm9vbGVhblxuICBzZXJ2ZXJVUkw6IHN0cmluZ1xufSk6IFByb21pc2U8XG4gIFQgJiB7XG4gICAgX251bWJlck9mUmVxdWVzdHM/OiBudW1iZXJcbiAgfVxuPiA9PiB7XG4gIGNvbnN0IHtcbiAgICBhcGlSb3V0ZSxcbiAgICBkZXB0aCxcbiAgICBmaWVsZFNjaGVtYSxcbiAgICBpbmNvbWluZ0RhdGEsXG4gICAgaW5pdGlhbERhdGEsXG4gICAgcmV0dXJuTnVtYmVyT2ZSZXF1ZXN0cyxcbiAgICBzZXJ2ZXJVUkwsXG4gIH0gPSBhcmdzXG5cbiAgY29uc3QgcmVzdWx0ID0geyAuLi5pbml0aWFsRGF0YSB9XG5cbiAgY29uc3QgcG9wdWxhdGlvblByb21pc2VzOiBQcm9taXNlPHZvaWQ+W10gPSBbXVxuXG4gIHRyYXZlcnNlRmllbGRzKHtcbiAgICBhcGlSb3V0ZSxcbiAgICBkZXB0aCxcbiAgICBmaWVsZFNjaGVtYSxcbiAgICBpbmNvbWluZ0RhdGEsXG4gICAgcG9wdWxhdGlvblByb21pc2VzLFxuICAgIHJlc3VsdCxcbiAgICBzZXJ2ZXJVUkwsXG4gIH0pXG5cbiAgYXdhaXQgUHJvbWlzZS5hbGwocG9wdWxhdGlvblByb21pc2VzKVxuXG4gIHJldHVybiB7XG4gICAgLi4ucmVzdWx0LFxuICAgIC4uLihyZXR1cm5OdW1iZXJPZlJlcXVlc3RzID8geyBfbnVtYmVyT2ZSZXF1ZXN0czogcG9wdWxhdGlvblByb21pc2VzLmxlbmd0aCB9IDoge30pLFxuICB9XG59XG4iXSwibmFtZXMiOlsibWVyZ2VEYXRhIiwiYXJncyIsImFwaVJvdXRlIiwiZGVwdGgiLCJmaWVsZFNjaGVtYSIsImluY29taW5nRGF0YSIsImluaXRpYWxEYXRhIiwicmV0dXJuTnVtYmVyT2ZSZXF1ZXN0cyIsInNlcnZlclVSTCIsInJlc3VsdCIsInBvcHVsYXRpb25Qcm9taXNlcyIsInRyYXZlcnNlRmllbGRzIiwiUHJvbWlzZSIsImFsbCIsIl9udW1iZXJPZlJlcXVlc3RzIiwibGVuZ3RoIl0sIm1hcHBpbmdzIjoiOzs7OytCQUlhQTs7O2VBQUFBOzs7Z0NBRmtCO0FBRXhCLE1BQU1BLFlBQVksT0FBVUM7SUFhakMsTUFBTSxFQUNKQyxRQUFRLEVBQ1JDLEtBQUssRUFDTEMsV0FBVyxFQUNYQyxZQUFZLEVBQ1pDLFdBQVcsRUFDWEMsc0JBQXNCLEVBQ3RCQyxTQUFTLEVBQ1YsR0FBR1A7SUFFSixNQUFNUSxTQUFTO1FBQUUsR0FBR0gsV0FBVztJQUFDO0lBRWhDLE1BQU1JLHFCQUFzQyxFQUFFO0lBRTlDQyxJQUFBQSw4QkFBYyxFQUFDO1FBQ2JUO1FBQ0FDO1FBQ0FDO1FBQ0FDO1FBQ0FLO1FBQ0FEO1FBQ0FEO0lBQ0Y7SUFFQSxNQUFNSSxRQUFRQyxHQUFHLENBQUNIO0lBRWxCLE9BQU87UUFDTCxHQUFHRCxNQUFNO1FBQ1QsR0FBSUYseUJBQXlCO1lBQUVPLG1CQUFtQkosbUJBQW1CSyxNQUFNO1FBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEY7QUFDRiJ9
package/dist/promise.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- type Args = {
1
+ export declare const promise: (args: {
2
2
  accessor: number | string;
3
3
  apiRoute?: string;
4
4
  collection: string;
@@ -6,7 +6,5 @@ type Args = {
6
6
  id: number | string;
7
7
  ref: Record<string, unknown>;
8
8
  serverURL: string;
9
- };
10
- export declare const promise: ({ id, accessor, apiRoute, collection, depth, ref, serverURL, }: Args) => Promise<void>;
11
- export {};
9
+ }) => Promise<void>;
12
10
  //# sourceMappingURL=promise.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"promise.d.ts","sourceRoot":"","sources":["../src/promise.ts"],"names":[],"mappings":"AAAA,KAAK,IAAI,GAAG;IACV,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAA;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;IACb,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;IACnB,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAC5B,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,OAAO,mEAQjB,IAAI,KAAG,QAAQ,IAAI,CAMrB,CAAA"}
1
+ {"version":3,"file":"promise.d.ts","sourceRoot":"","sources":["../src/promise.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,OAAO,SAAgB;IAClC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAA;IACzB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,MAAM,CAAA;IACb,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;IACnB,GAAG,EAAE,OAAO,MAAM,EAAE,OAAO,CAAC,CAAA;IAC5B,SAAS,EAAE,MAAM,CAAA;CAClB,KAAG,QAAQ,IAAI,CAmBf,CAAA"}
package/dist/promise.js CHANGED
@@ -8,9 +8,22 @@ Object.defineProperty(exports, "promise", {
8
8
  return promise;
9
9
  }
10
10
  });
11
- const promise = async ({ id, accessor, apiRoute, collection, depth, ref, serverURL })=>{
12
- const res = await fetch(`${serverURL}${apiRoute || '/api'}/${collection}/${id}?depth=${depth}`).then((res)=>res.json());
11
+ const promise = async (args)=>{
12
+ const { id, accessor, apiRoute, collection, depth, ref, serverURL } = args;
13
+ const url = `${serverURL}${apiRoute || '/api'}/${collection}/${id}?depth=${depth}`;
14
+ let res = null;
15
+ try {
16
+ res = await fetch(url, {
17
+ credentials: 'include',
18
+ headers: {
19
+ 'Content-Type': 'application/json'
20
+ }
21
+ }).then((res)=>res.json());
22
+ } catch (err) {
23
+ console.error(err) // eslint-disable-line no-console
24
+ ;
25
+ }
13
26
  ref[accessor] = res;
14
27
  };
15
28
 
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcm9taXNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbInR5cGUgQXJncyA9IHtcbiAgYWNjZXNzb3I6IG51bWJlciB8IHN0cmluZ1xuICBhcGlSb3V0ZT86IHN0cmluZ1xuICBjb2xsZWN0aW9uOiBzdHJpbmdcbiAgZGVwdGg6IG51bWJlclxuICBpZDogbnVtYmVyIHwgc3RyaW5nXG4gIHJlZjogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgc2VydmVyVVJMOiBzdHJpbmdcbn1cblxuZXhwb3J0IGNvbnN0IHByb21pc2UgPSBhc3luYyAoe1xuICBpZCxcbiAgYWNjZXNzb3IsXG4gIGFwaVJvdXRlLFxuICBjb2xsZWN0aW9uLFxuICBkZXB0aCxcbiAgcmVmLFxuICBzZXJ2ZXJVUkwsXG59OiBBcmdzKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gIGNvbnN0IHJlczogYW55ID0gYXdhaXQgZmV0Y2goXG4gICAgYCR7c2VydmVyVVJMfSR7YXBpUm91dGUgfHwgJy9hcGknfS8ke2NvbGxlY3Rpb259LyR7aWR9P2RlcHRoPSR7ZGVwdGh9YCxcbiAgKS50aGVuKChyZXMpID0+IHJlcy5qc29uKCkpXG5cbiAgcmVmW2FjY2Vzc29yXSA9IHJlc1xufVxuIl0sIm5hbWVzIjpbInByb21pc2UiLCJpZCIsImFjY2Vzc29yIiwiYXBpUm91dGUiLCJjb2xsZWN0aW9uIiwiZGVwdGgiLCJyZWYiLCJzZXJ2ZXJVUkwiLCJyZXMiLCJmZXRjaCIsInRoZW4iLCJqc29uIl0sIm1hcHBpbmdzIjoiOzs7OytCQVVhQTs7O2VBQUFBOzs7QUFBTixNQUFNQSxVQUFVLE9BQU8sRUFDNUJDLEVBQUUsRUFDRkMsUUFBUSxFQUNSQyxRQUFRLEVBQ1JDLFVBQVUsRUFDVkMsS0FBSyxFQUNMQyxHQUFHLEVBQ0hDLFNBQVMsRUFDSjtJQUNMLE1BQU1DLE1BQVcsTUFBTUMsTUFDckIsQ0FBQyxFQUFFRixVQUFVLEVBQUVKLFlBQVksT0FBTyxDQUFDLEVBQUVDLFdBQVcsQ0FBQyxFQUFFSCxHQUFHLE9BQU8sRUFBRUksTUFBTSxDQUFDLEVBQ3RFSyxJQUFJLENBQUMsQ0FBQ0YsTUFBUUEsSUFBSUcsSUFBSTtJQUV4QkwsR0FBRyxDQUFDSixTQUFTLEdBQUdNO0FBQ2xCIn0=
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9wcm9taXNlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjb25zdCBwcm9taXNlID0gYXN5bmMgKGFyZ3M6IHtcbiAgYWNjZXNzb3I6IG51bWJlciB8IHN0cmluZ1xuICBhcGlSb3V0ZT86IHN0cmluZ1xuICBjb2xsZWN0aW9uOiBzdHJpbmdcbiAgZGVwdGg6IG51bWJlclxuICBpZDogbnVtYmVyIHwgc3RyaW5nXG4gIHJlZjogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgc2VydmVyVVJMOiBzdHJpbmdcbn0pOiBQcm9taXNlPHZvaWQ+ID0+IHtcbiAgY29uc3QgeyBpZCwgYWNjZXNzb3IsIGFwaVJvdXRlLCBjb2xsZWN0aW9uLCBkZXB0aCwgcmVmLCBzZXJ2ZXJVUkwgfSA9IGFyZ3NcblxuICBjb25zdCB1cmwgPSBgJHtzZXJ2ZXJVUkx9JHthcGlSb3V0ZSB8fCAnL2FwaSd9LyR7Y29sbGVjdGlvbn0vJHtpZH0/ZGVwdGg9JHtkZXB0aH1gXG5cbiAgbGV0IHJlczogUmVjb3JkPHN0cmluZywgdW5rbm93bj4gfCBudWxsIHwgdW5kZWZpbmVkID0gbnVsbFxuXG4gIHRyeSB7XG4gICAgcmVzID0gYXdhaXQgZmV0Y2godXJsLCB7XG4gICAgICBjcmVkZW50aWFsczogJ2luY2x1ZGUnLFxuICAgICAgaGVhZGVyczoge1xuICAgICAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxuICAgICAgfSxcbiAgICB9KS50aGVuKChyZXMpID0+IHJlcy5qc29uKCkpXG4gIH0gY2F0Y2ggKGVycikge1xuICAgIGNvbnNvbGUuZXJyb3IoZXJyKSAvLyBlc2xpbnQtZGlzYWJsZS1saW5lIG5vLWNvbnNvbGVcbiAgfVxuXG4gIHJlZlthY2Nlc3Nvcl0gPSByZXNcbn1cbiJdLCJuYW1lcyI6WyJwcm9taXNlIiwiYXJncyIsImlkIiwiYWNjZXNzb3IiLCJhcGlSb3V0ZSIsImNvbGxlY3Rpb24iLCJkZXB0aCIsInJlZiIsInNlcnZlclVSTCIsInVybCIsInJlcyIsImZldGNoIiwiY3JlZGVudGlhbHMiLCJoZWFkZXJzIiwidGhlbiIsImpzb24iLCJlcnIiLCJjb25zb2xlIiwiZXJyb3IiXSwibWFwcGluZ3MiOiI7Ozs7K0JBQWFBOzs7ZUFBQUE7OztBQUFOLE1BQU1BLFVBQVUsT0FBT0M7SUFTNUIsTUFBTSxFQUFFQyxFQUFFLEVBQUVDLFFBQVEsRUFBRUMsUUFBUSxFQUFFQyxVQUFVLEVBQUVDLEtBQUssRUFBRUMsR0FBRyxFQUFFQyxTQUFTLEVBQUUsR0FBR1A7SUFFdEUsTUFBTVEsTUFBTSxDQUFDLEVBQUVELFVBQVUsRUFBRUosWUFBWSxPQUFPLENBQUMsRUFBRUMsV0FBVyxDQUFDLEVBQUVILEdBQUcsT0FBTyxFQUFFSSxNQUFNLENBQUM7SUFFbEYsSUFBSUksTUFBa0Q7SUFFdEQsSUFBSTtRQUNGQSxNQUFNLE1BQU1DLE1BQU1GLEtBQUs7WUFDckJHLGFBQWE7WUFDYkMsU0FBUztnQkFDUCxnQkFBZ0I7WUFDbEI7UUFDRixHQUFHQyxJQUFJLENBQUMsQ0FBQ0osTUFBUUEsSUFBSUssSUFBSTtJQUMzQixFQUFFLE9BQU9DLEtBQUs7UUFDWkMsUUFBUUMsS0FBSyxDQUFDRixLQUFLLGlDQUFpQzs7SUFDdEQ7SUFFQVQsR0FBRyxDQUFDSixTQUFTLEdBQUdPO0FBQ2xCIn0=
@@ -1,6 +1,7 @@
1
1
  export declare const subscribe: <T>(args: {
2
+ apiRoute?: string;
2
3
  callback: (data: T) => void;
3
- depth: number;
4
+ depth?: number;
4
5
  initialData: T;
5
6
  serverURL: string;
6
7
  }) => (event: MessageEvent) => void;
@@ -1 +1 @@
1
- {"version":3,"file":"subscribe.d.ts","sourceRoot":"","sources":["../src/subscribe.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS;2BACG,IAAI;WACpB,MAAM;;eAEF,MAAM;cACN,YAAY,KAAK,IAa7B,CAAA"}
1
+ {"version":3,"file":"subscribe.d.ts","sourceRoot":"","sources":["../src/subscribe.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS;eACT,MAAM;2BACM,IAAI;YACnB,MAAM;;eAEH,MAAM;cACN,YAAY,KAAK,IAa7B,CAAA"}
package/dist/subscribe.js CHANGED
@@ -10,9 +10,10 @@ Object.defineProperty(exports, "subscribe", {
10
10
  });
11
11
  const _ = require(".");
12
12
  const subscribe = (args)=>{
13
- const { callback, depth, initialData, serverURL } = args;
13
+ const { apiRoute, callback, depth, initialData, serverURL } = args;
14
14
  const onMessage = async (event)=>{
15
15
  const mergedData = await (0, _.handleMessage)({
16
+ apiRoute,
16
17
  depth,
17
18
  event,
18
19
  initialData,
@@ -26,4 +27,4 @@ const subscribe = (args)=>{
26
27
  return onMessage;
27
28
  };
28
29
 
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9zdWJzY3JpYmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaGFuZGxlTWVzc2FnZSB9IGZyb20gJy4nXG5cbmV4cG9ydCBjb25zdCBzdWJzY3JpYmUgPSA8VD4oYXJnczoge1xuICBjYWxsYmFjazogKGRhdGE6IFQpID0+IHZvaWRcbiAgZGVwdGg6IG51bWJlclxuICBpbml0aWFsRGF0YTogVFxuICBzZXJ2ZXJVUkw6IHN0cmluZ1xufSk6ICgoZXZlbnQ6IE1lc3NhZ2VFdmVudCkgPT4gdm9pZCkgPT4ge1xuICBjb25zdCB7IGNhbGxiYWNrLCBkZXB0aCwgaW5pdGlhbERhdGEsIHNlcnZlclVSTCB9ID0gYXJnc1xuXG4gIGNvbnN0IG9uTWVzc2FnZSA9IGFzeW5jIChldmVudDogTWVzc2FnZUV2ZW50KSA9PiB7XG4gICAgY29uc3QgbWVyZ2VkRGF0YSA9IGF3YWl0IGhhbmRsZU1lc3NhZ2U8VD4oeyBkZXB0aCwgZXZlbnQsIGluaXRpYWxEYXRhLCBzZXJ2ZXJVUkwgfSlcbiAgICBjYWxsYmFjayhtZXJnZWREYXRhKVxuICB9XG5cbiAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCBvbk1lc3NhZ2UpXG4gIH1cblxuICByZXR1cm4gb25NZXNzYWdlXG59XG4iXSwibmFtZXMiOlsic3Vic2NyaWJlIiwiYXJncyIsImNhbGxiYWNrIiwiZGVwdGgiLCJpbml0aWFsRGF0YSIsInNlcnZlclVSTCIsIm9uTWVzc2FnZSIsImV2ZW50IiwibWVyZ2VkRGF0YSIsImhhbmRsZU1lc3NhZ2UiLCJ3aW5kb3ciLCJhZGRFdmVudExpc3RlbmVyIl0sIm1hcHBpbmdzIjoiOzs7OytCQUVhQTs7O2VBQUFBOzs7a0JBRmlCO0FBRXZCLE1BQU1BLFlBQVksQ0FBSUM7SUFNM0IsTUFBTSxFQUFFQyxRQUFRLEVBQUVDLEtBQUssRUFBRUMsV0FBVyxFQUFFQyxTQUFTLEVBQUUsR0FBR0o7SUFFcEQsTUFBTUssWUFBWSxPQUFPQztRQUN2QixNQUFNQyxhQUFhLE1BQU1DLElBQUFBLGVBQWEsRUFBSTtZQUFFTjtZQUFPSTtZQUFPSDtZQUFhQztRQUFVO1FBQ2pGSCxTQUFTTTtJQUNYO0lBRUEsSUFBSSxPQUFPRSxXQUFXLGFBQWE7UUFDakNBLE9BQU9DLGdCQUFnQixDQUFDLFdBQVdMO0lBQ3JDO0lBRUEsT0FBT0E7QUFDVCJ9
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9zdWJzY3JpYmUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaGFuZGxlTWVzc2FnZSB9IGZyb20gJy4nXG5cbmV4cG9ydCBjb25zdCBzdWJzY3JpYmUgPSA8VD4oYXJnczoge1xuICBhcGlSb3V0ZT86IHN0cmluZ1xuICBjYWxsYmFjazogKGRhdGE6IFQpID0+IHZvaWRcbiAgZGVwdGg/OiBudW1iZXJcbiAgaW5pdGlhbERhdGE6IFRcbiAgc2VydmVyVVJMOiBzdHJpbmdcbn0pOiAoKGV2ZW50OiBNZXNzYWdlRXZlbnQpID0+IHZvaWQpID0+IHtcbiAgY29uc3QgeyBhcGlSb3V0ZSwgY2FsbGJhY2ssIGRlcHRoLCBpbml0aWFsRGF0YSwgc2VydmVyVVJMIH0gPSBhcmdzXG5cbiAgY29uc3Qgb25NZXNzYWdlID0gYXN5bmMgKGV2ZW50OiBNZXNzYWdlRXZlbnQpID0+IHtcbiAgICBjb25zdCBtZXJnZWREYXRhID0gYXdhaXQgaGFuZGxlTWVzc2FnZTxUPih7IGFwaVJvdXRlLCBkZXB0aCwgZXZlbnQsIGluaXRpYWxEYXRhLCBzZXJ2ZXJVUkwgfSlcbiAgICBjYWxsYmFjayhtZXJnZWREYXRhKVxuICB9XG5cbiAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnKSB7XG4gICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ21lc3NhZ2UnLCBvbk1lc3NhZ2UpXG4gIH1cblxuICByZXR1cm4gb25NZXNzYWdlXG59XG4iXSwibmFtZXMiOlsic3Vic2NyaWJlIiwiYXJncyIsImFwaVJvdXRlIiwiY2FsbGJhY2siLCJkZXB0aCIsImluaXRpYWxEYXRhIiwic2VydmVyVVJMIiwib25NZXNzYWdlIiwiZXZlbnQiLCJtZXJnZWREYXRhIiwiaGFuZGxlTWVzc2FnZSIsIndpbmRvdyIsImFkZEV2ZW50TGlzdGVuZXIiXSwibWFwcGluZ3MiOiI7Ozs7K0JBRWFBOzs7ZUFBQUE7OztrQkFGaUI7QUFFdkIsTUFBTUEsWUFBWSxDQUFJQztJQU8zQixNQUFNLEVBQUVDLFFBQVEsRUFBRUMsUUFBUSxFQUFFQyxLQUFLLEVBQUVDLFdBQVcsRUFBRUMsU0FBUyxFQUFFLEdBQUdMO0lBRTlELE1BQU1NLFlBQVksT0FBT0M7UUFDdkIsTUFBTUMsYUFBYSxNQUFNQyxJQUFBQSxlQUFhLEVBQUk7WUFBRVI7WUFBVUU7WUFBT0k7WUFBT0g7WUFBYUM7UUFBVTtRQUMzRkgsU0FBU007SUFDWDtJQUVBLElBQUksT0FBT0UsV0FBVyxhQUFhO1FBQ2pDQSxPQUFPQyxnQkFBZ0IsQ0FBQyxXQUFXTDtJQUNyQztJQUVBLE9BQU9BO0FBQ1QifQ==
@@ -1,12 +1,11 @@
1
- type Args<T> = {
1
+ import type { fieldSchemaToJSON } from 'payload/utilities';
2
+ export declare const traverseFields: <T>(args: {
2
3
  apiRoute?: string;
3
- depth: number;
4
- fieldSchema: Record<string, unknown>[];
4
+ depth?: number;
5
+ fieldSchema: ReturnType<typeof fieldSchemaToJSON>;
5
6
  incomingData: T;
6
7
  populationPromises: Promise<void>[];
7
8
  result: T;
8
9
  serverURL: string;
9
- };
10
- export declare const traverseFields: <T>({ apiRoute, depth, fieldSchema, incomingData, populationPromises, result, serverURL, }: Args<T>) => void;
11
- export {};
10
+ }) => void;
12
11
  //# sourceMappingURL=traverseFields.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../src/traverseFields.ts"],"names":[],"mappings":"AAEA,KAAK,IAAI,CAAC,CAAC,IAAI;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,WAAW,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAA;IACtC,YAAY,EAAE,CAAC,CAAA;IACf,kBAAkB,EAAE,OAAO,CAAC,IAAI,CAAC,EAAE,CAAA;IACnC,MAAM,EAAE,CAAC,CAAA;IACT,SAAS,EAAE,MAAM,CAAA;CAClB,CAAA;AAED,eAAO,MAAM,cAAc,0GAQd,IAkNZ,CAAA"}
1
+ {"version":3,"file":"traverseFields.d.ts","sourceRoot":"","sources":["../src/traverseFields.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAA;AAI1D,eAAO,MAAM,cAAc;eACd,MAAM;YACT,MAAM;iBACD,WAAW,wBAAwB,CAAC;;wBAE7B,QAAQ,IAAI,CAAC,EAAE;;eAExB,MAAM;MACf,IA6PH,CAAA"}
@@ -9,56 +9,62 @@ Object.defineProperty(exports, "traverseFields", {
9
9
  }
10
10
  });
11
11
  const _promise = require("./promise");
12
- const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, populationPromises, result, serverURL })=>{
13
- fieldSchema.forEach((field)=>{
14
- if ('name' in field && typeof field.name === 'string') {
15
- // TODO: type this
16
- const fieldName = field.name;
17
- switch(field.type){
12
+ const traverseFields = (args)=>{
13
+ const { apiRoute, depth, fieldSchema: fieldSchemas, incomingData, populationPromises, result, serverURL } = args;
14
+ fieldSchemas.forEach((fieldSchema)=>{
15
+ if ('name' in fieldSchema && typeof fieldSchema.name === 'string') {
16
+ const fieldName = fieldSchema.name;
17
+ switch(fieldSchema.type){
18
18
  case 'array':
19
19
  if (Array.isArray(incomingData[fieldName])) {
20
- result[fieldName] = incomingData[fieldName].map((row, i)=>{
21
- const hasExistingRow = Array.isArray(result[fieldName]) && typeof result[fieldName][i] === 'object' && result[fieldName][i] !== null;
22
- const newRow = hasExistingRow ? {
23
- ...result[fieldName][i]
24
- } : {};
20
+ result[fieldName] = incomingData[fieldName].map((incomingRow, i)=>{
21
+ if (!result[fieldName]) {
22
+ result[fieldName] = [];
23
+ }
24
+ if (!result[fieldName][i]) {
25
+ result[fieldName][i] = {};
26
+ }
25
27
  traverseFields({
26
28
  apiRoute,
27
29
  depth,
28
- fieldSchema: field.fields,
29
- incomingData: row,
30
+ fieldSchema: fieldSchema.fields,
31
+ incomingData: incomingRow,
30
32
  populationPromises,
31
- result: newRow,
33
+ result: result[fieldName][i],
32
34
  serverURL
33
35
  });
34
- return newRow;
36
+ return result[fieldName][i];
35
37
  });
36
38
  }
37
39
  break;
38
40
  case 'blocks':
39
41
  if (Array.isArray(incomingData[fieldName])) {
40
- result[fieldName] = incomingData[fieldName].map((row, i)=>{
41
- const matchedBlock = field.blocks[row.blockType];
42
- const hasExistingRow = Array.isArray(result[fieldName]) && typeof result[fieldName][i] === 'object' && result[fieldName][i] !== null && result[fieldName][i].blockType === row.blockType;
43
- const newRow = hasExistingRow ? {
44
- ...result[fieldName][i]
45
- } : {
46
- blockType: matchedBlock.slug
47
- };
42
+ result[fieldName] = incomingData[fieldName].map((incomingBlock, i)=>{
43
+ const incomingBlockJSON = fieldSchema.blocks[incomingBlock.blockType];
44
+ if (!result[fieldName]) {
45
+ result[fieldName] = [];
46
+ }
47
+ if (!result[fieldName][i] || result[fieldName][i].id !== incomingBlock.id || result[fieldName][i].blockType !== incomingBlock.blockType) {
48
+ result[fieldName][i] = {
49
+ blockType: incomingBlock.blockType
50
+ };
51
+ }
48
52
  traverseFields({
49
53
  apiRoute,
50
54
  depth,
51
- fieldSchema: matchedBlock.fields,
52
- incomingData: row,
55
+ fieldSchema: incomingBlockJSON.fields,
56
+ incomingData: incomingBlock,
53
57
  populationPromises,
54
- result: newRow,
58
+ result: result[fieldName][i],
55
59
  serverURL
56
60
  });
57
- return newRow;
61
+ return result[fieldName][i];
58
62
  });
63
+ } else {
64
+ result[fieldName] = [];
59
65
  }
60
66
  break;
61
- case 'tab':
67
+ case 'tabs':
62
68
  case 'group':
63
69
  if (!result[fieldName]) {
64
70
  result[fieldName] = {};
@@ -66,7 +72,7 @@ const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, population
66
72
  traverseFields({
67
73
  apiRoute,
68
74
  depth,
69
- fieldSchema: field.fields,
75
+ fieldSchema: fieldSchema.fields,
70
76
  incomingData: incomingData[fieldName] || {},
71
77
  populationPromises,
72
78
  result: result[fieldName],
@@ -75,40 +81,44 @@ const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, population
75
81
  break;
76
82
  case 'upload':
77
83
  case 'relationship':
78
- if (field.hasMany && Array.isArray(incomingData[fieldName])) {
79
- const existingValue = Array.isArray(result[fieldName]) ? [
80
- ...result[fieldName]
81
- ] : [];
82
- result[fieldName] = Array.isArray(result[fieldName]) ? [
83
- ...result[fieldName]
84
- ].slice(0, incomingData[fieldName].length) : [];
85
- incomingData[fieldName].forEach((relation, i)=>{
84
+ // Handle `hasMany` relationships
85
+ if (fieldSchema.hasMany && Array.isArray(incomingData[fieldName])) {
86
+ if (!result[fieldName]) {
87
+ result[fieldName] = [];
88
+ }
89
+ incomingData[fieldName].forEach((incomingRelation, i)=>{
86
90
  // Handle `hasMany` polymorphic
87
- if (Array.isArray(field.relationTo)) {
88
- const existingID = existingValue[i]?.value?.id;
89
- if (existingID !== relation.value || existingValue[i]?.relationTo !== relation.relationTo) {
91
+ if (Array.isArray(fieldSchema.relationTo)) {
92
+ // if the field doesn't exist on the result, create it
93
+ // the value will be populated later
94
+ if (!result[fieldName][i]) {
90
95
  result[fieldName][i] = {
91
- relationTo: relation.relationTo
96
+ relationTo: incomingRelation.relationTo
92
97
  };
98
+ }
99
+ const oldID = result[fieldName][i]?.value?.id;
100
+ const oldRelation = result[fieldName][i]?.relationTo;
101
+ const newID = incomingRelation.value;
102
+ const newRelation = incomingRelation.relationTo;
103
+ if (oldID !== newID || oldRelation !== newRelation) {
93
104
  populationPromises.push((0, _promise.promise)({
94
- id: relation.value,
105
+ id: incomingRelation.value,
95
106
  accessor: 'value',
96
107
  apiRoute,
97
- collection: relation.relationTo,
108
+ collection: newRelation,
98
109
  depth,
99
110
  ref: result[fieldName][i],
100
111
  serverURL
101
112
  }));
102
113
  }
103
114
  } else {
104
- // Handle `hasMany` singular
105
- const existingID = existingValue[i]?.id;
106
- if (existingID !== relation) {
115
+ // Handle `hasMany` monomorphic
116
+ if (result[fieldName][i]?.id !== incomingRelation) {
107
117
  populationPromises.push((0, _promise.promise)({
108
- id: relation,
118
+ id: incomingRelation,
109
119
  accessor: i,
110
120
  apiRoute,
111
- collection: String(field.relationTo),
121
+ collection: String(fieldSchema.relationTo),
112
122
  depth,
113
123
  ref: result[fieldName],
114
124
  serverURL
@@ -118,22 +128,28 @@ const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, population
118
128
  });
119
129
  } else {
120
130
  // Handle `hasOne` polymorphic
121
- if (Array.isArray(field.relationTo)) {
122
- const hasNewValue = typeof incomingData[fieldName] === 'object' && incomingData[fieldName] !== null;
123
- const hasOldValue = typeof result[fieldName] === 'object' && result[fieldName] !== null;
124
- const newValue = hasNewValue ? incomingData[fieldName].value : '';
131
+ if (Array.isArray(fieldSchema.relationTo)) {
132
+ // if the field doesn't exist on the result, create it
133
+ // the value will be populated later
134
+ if (!result[fieldName]) {
135
+ result[fieldName] = {
136
+ relationTo: incomingData[fieldName]?.relationTo
137
+ };
138
+ }
139
+ const hasNewValue = incomingData[fieldName] && typeof incomingData[fieldName] === 'object' && incomingData[fieldName] !== null;
140
+ const hasOldValue = result[fieldName] && typeof result[fieldName] === 'object' && result[fieldName] !== null;
141
+ const newID = hasNewValue ? typeof incomingData[fieldName].value === 'object' ? incomingData[fieldName].value.id : incomingData[fieldName].value : '';
142
+ const oldID = hasOldValue ? typeof result[fieldName].value === 'object' ? result[fieldName].value.id : result[fieldName].value : '';
125
143
  const newRelation = hasNewValue ? incomingData[fieldName].relationTo : '';
126
- const oldValue = hasOldValue ? result[fieldName].value : '';
127
144
  const oldRelation = hasOldValue ? result[fieldName].relationTo : '';
128
- if (newValue !== oldValue || newRelation !== oldRelation) {
129
- if (newValue) {
130
- if (!result[fieldName]) {
131
- result[fieldName] = {
132
- relationTo: newRelation
133
- };
134
- }
145
+ // if the new value/relation is different from the old value/relation
146
+ // populate the new value, otherwise leave it alone
147
+ if (newID !== oldID || newRelation !== oldRelation) {
148
+ // if the new value is not empty, populate it
149
+ // otherwise set the value to null
150
+ if (newID) {
135
151
  populationPromises.push((0, _promise.promise)({
136
- id: newValue,
152
+ id: newID,
137
153
  accessor: 'value',
138
154
  apiRoute,
139
155
  collection: newRelation,
@@ -141,29 +157,32 @@ const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, population
141
157
  ref: result[fieldName],
142
158
  serverURL
143
159
  }));
160
+ } else {
161
+ result[fieldName] = null;
144
162
  }
145
- } else {
146
- result[fieldName] = null;
147
163
  }
148
164
  } else {
149
- const hasNewValue = typeof incomingData[fieldName] === 'object' && incomingData[fieldName] !== null;
150
- const hasOldValue = typeof result[fieldName] === 'object' && result[fieldName] !== null;
151
- const newValue = hasNewValue ? incomingData[fieldName].value : '';
152
- const oldValue = hasOldValue ? result[fieldName].value : '';
153
- if (newValue !== oldValue) {
154
- if (newValue) {
165
+ // Handle `hasOne` monomorphic
166
+ const newID = incomingData[fieldName] && typeof incomingData[fieldName] === 'object' && incomingData[fieldName].id || incomingData[fieldName];
167
+ const oldID = result[fieldName] && typeof result[fieldName] === 'object' && result[fieldName].id || result[fieldName];
168
+ // if the new value is different from the old value
169
+ // populate the new value, otherwise leave it alone
170
+ if (newID !== oldID) {
171
+ // if the new value is not empty, populate it
172
+ // otherwise set the value to null
173
+ if (newID) {
155
174
  populationPromises.push((0, _promise.promise)({
156
- id: newValue,
175
+ id: newID,
157
176
  accessor: fieldName,
158
177
  apiRoute,
159
- collection: String(field.relationTo),
178
+ collection: String(fieldSchema.relationTo),
160
179
  depth,
161
180
  ref: result,
162
181
  serverURL
163
182
  }));
183
+ } else {
184
+ result[fieldName] = null;
164
185
  }
165
- } else {
166
- result[fieldName] = null;
167
186
  }
168
187
  }
169
188
  }
@@ -173,7 +192,6 @@ const traverseFields = ({ apiRoute, depth, fieldSchema, incomingData, population
173
192
  }
174
193
  }
175
194
  });
176
- return null;
177
195
  };
178
196
 
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/traverseFields.ts"],"sourcesContent":["import { promise } from './promise'\n\ntype Args<T> = {\n  apiRoute?: string\n  depth: number\n  fieldSchema: Record<string, unknown>[]\n  incomingData: T\n  populationPromises: Promise<void>[]\n  result: T\n  serverURL: string\n}\n\nexport const traverseFields = <T>({\n  apiRoute,\n  depth,\n  fieldSchema,\n  incomingData,\n  populationPromises,\n  result,\n  serverURL,\n}: Args<T>): void => {\n  fieldSchema.forEach((field) => {\n    if ('name' in field && typeof field.name === 'string') {\n      // TODO: type this\n      const fieldName = field.name\n\n      switch (field.type) {\n        case 'array':\n          if (Array.isArray(incomingData[fieldName])) {\n            result[fieldName] = incomingData[fieldName].map((row, i) => {\n              const hasExistingRow =\n                Array.isArray(result[fieldName]) &&\n                typeof result[fieldName][i] === 'object' &&\n                result[fieldName][i] !== null\n\n              const newRow = hasExistingRow ? { ...result[fieldName][i] } : {}\n\n              traverseFields({\n                apiRoute,\n                depth,\n                fieldSchema: field.fields as Record<string, unknown>[], // TODO: type this\n                incomingData: row,\n                populationPromises,\n                result: newRow,\n                serverURL,\n              })\n\n              return newRow\n            })\n          }\n          break\n\n        case 'blocks':\n          if (Array.isArray(incomingData[fieldName])) {\n            result[fieldName] = incomingData[fieldName].map((row, i) => {\n              const matchedBlock = field.blocks[row.blockType]\n\n              const hasExistingRow =\n                Array.isArray(result[fieldName]) &&\n                typeof result[fieldName][i] === 'object' &&\n                result[fieldName][i] !== null &&\n                result[fieldName][i].blockType === row.blockType\n\n              const newRow = hasExistingRow\n                ? { ...result[fieldName][i] }\n                : {\n                    blockType: matchedBlock.slug,\n                  }\n\n              traverseFields({\n                apiRoute,\n                depth,\n                fieldSchema: matchedBlock.fields as Record<string, unknown>[], // TODO: type this\n                incomingData: row,\n                populationPromises,\n                result: newRow,\n                serverURL,\n              })\n\n              return newRow\n            })\n          }\n          break\n\n        case 'tab':\n        case 'group':\n          if (!result[fieldName]) {\n            result[fieldName] = {}\n          }\n\n          traverseFields({\n            apiRoute,\n            depth,\n            fieldSchema: field.fields as Record<string, unknown>[], // TODO: type this\n            incomingData: incomingData[fieldName] || {},\n            populationPromises,\n            result: result[fieldName],\n            serverURL,\n          })\n\n          break\n\n        case 'upload':\n        case 'relationship':\n          if (field.hasMany && Array.isArray(incomingData[fieldName])) {\n            const existingValue = Array.isArray(result[fieldName]) ? [...result[fieldName]] : []\n            result[fieldName] = Array.isArray(result[fieldName])\n              ? [...result[fieldName]].slice(0, incomingData[fieldName].length)\n              : []\n\n            incomingData[fieldName].forEach((relation, i) => {\n              // Handle `hasMany` polymorphic\n              if (Array.isArray(field.relationTo)) {\n                const existingID = existingValue[i]?.value?.id\n\n                if (\n                  existingID !== relation.value ||\n                  existingValue[i]?.relationTo !== relation.relationTo\n                ) {\n                  result[fieldName][i] = {\n                    relationTo: relation.relationTo,\n                  }\n\n                  populationPromises.push(\n                    promise({\n                      id: relation.value,\n                      accessor: 'value',\n                      apiRoute,\n                      collection: relation.relationTo,\n                      depth,\n                      ref: result[fieldName][i],\n                      serverURL,\n                    }),\n                  )\n                }\n              } else {\n                // Handle `hasMany` singular\n                const existingID = existingValue[i]?.id\n\n                if (existingID !== relation) {\n                  populationPromises.push(\n                    promise({\n                      id: relation,\n                      accessor: i,\n                      apiRoute,\n                      collection: String(field.relationTo),\n                      depth,\n                      ref: result[fieldName],\n                      serverURL,\n                    }),\n                  )\n                }\n              }\n            })\n          } else {\n            // Handle `hasOne` polymorphic\n            if (Array.isArray(field.relationTo)) {\n              const hasNewValue =\n                typeof incomingData[fieldName] === 'object' && incomingData[fieldName] !== null\n              const hasOldValue =\n                typeof result[fieldName] === 'object' && result[fieldName] !== null\n\n              const newValue = hasNewValue ? incomingData[fieldName].value : ''\n              const newRelation = hasNewValue ? incomingData[fieldName].relationTo : ''\n\n              const oldValue = hasOldValue ? result[fieldName].value : ''\n              const oldRelation = hasOldValue ? result[fieldName].relationTo : ''\n\n              if (newValue !== oldValue || newRelation !== oldRelation) {\n                if (newValue) {\n                  if (!result[fieldName]) {\n                    result[fieldName] = {\n                      relationTo: newRelation,\n                    }\n                  }\n\n                  populationPromises.push(\n                    promise({\n                      id: newValue,\n                      accessor: 'value',\n                      apiRoute,\n                      collection: newRelation,\n                      depth,\n                      ref: result[fieldName],\n                      serverURL,\n                    }),\n                  )\n                }\n              } else {\n                result[fieldName] = null\n              }\n            } else {\n              const hasNewValue =\n                typeof incomingData[fieldName] === 'object' && incomingData[fieldName] !== null\n              const hasOldValue =\n                typeof result[fieldName] === 'object' && result[fieldName] !== null\n\n              const newValue = hasNewValue ? incomingData[fieldName].value : ''\n\n              const oldValue = hasOldValue ? result[fieldName].value : ''\n\n              if (newValue !== oldValue) {\n                if (newValue) {\n                  populationPromises.push(\n                    promise({\n                      id: newValue,\n                      accessor: fieldName,\n                      apiRoute,\n                      collection: String(field.relationTo),\n                      depth,\n                      ref: result as Record<string, unknown>,\n                      serverURL,\n                    }),\n                  )\n                }\n              } else {\n                result[fieldName] = null\n              }\n            }\n          }\n\n          break\n\n        default:\n          result[fieldName] = incomingData[fieldName]\n      }\n    }\n  })\n\n  return null\n}\n"],"names":["traverseFields","apiRoute","depth","fieldSchema","incomingData","populationPromises","result","serverURL","forEach","field","name","fieldName","type","Array","isArray","map","row","i","hasExistingRow","newRow","fields","matchedBlock","blocks","blockType","slug","hasMany","existingValue","slice","length","relation","relationTo","existingID","value","id","push","promise","accessor","collection","ref","String","hasNewValue","hasOldValue","newValue","newRelation","oldValue","oldRelation"],"mappings":"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"}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/traverseFields.ts"],"sourcesContent":["import type { fieldSchemaToJSON } from 'payload/utilities'\n\nimport { promise } from './promise'\n\nexport const traverseFields = <T>(args: {\n  apiRoute?: string\n  depth?: number\n  fieldSchema: ReturnType<typeof fieldSchemaToJSON>\n  incomingData: T\n  populationPromises: Promise<void>[]\n  result: T\n  serverURL: string\n}): void => {\n  const {\n    apiRoute,\n    depth,\n    fieldSchema: fieldSchemas,\n    incomingData,\n    populationPromises,\n    result,\n    serverURL,\n  } = args\n\n  fieldSchemas.forEach((fieldSchema) => {\n    if ('name' in fieldSchema && typeof fieldSchema.name === 'string') {\n      const fieldName = fieldSchema.name\n\n      switch (fieldSchema.type) {\n        case 'array':\n          if (Array.isArray(incomingData[fieldName])) {\n            result[fieldName] = incomingData[fieldName].map((incomingRow, i) => {\n              if (!result[fieldName]) {\n                result[fieldName] = []\n              }\n\n              if (!result[fieldName][i]) {\n                result[fieldName][i] = {}\n              }\n\n              traverseFields({\n                apiRoute,\n                depth,\n                fieldSchema: fieldSchema.fields,\n                incomingData: incomingRow,\n                populationPromises,\n                result: result[fieldName][i],\n                serverURL,\n              })\n\n              return result[fieldName][i]\n            })\n          }\n          break\n\n        case 'blocks':\n          if (Array.isArray(incomingData[fieldName])) {\n            result[fieldName] = incomingData[fieldName].map((incomingBlock, i) => {\n              const incomingBlockJSON = fieldSchema.blocks[incomingBlock.blockType]\n\n              if (!result[fieldName]) {\n                result[fieldName] = []\n              }\n\n              if (\n                !result[fieldName][i] ||\n                result[fieldName][i].id !== incomingBlock.id ||\n                result[fieldName][i].blockType !== incomingBlock.blockType\n              ) {\n                result[fieldName][i] = {\n                  blockType: incomingBlock.blockType,\n                }\n              }\n\n              traverseFields({\n                apiRoute,\n                depth,\n                fieldSchema: incomingBlockJSON.fields,\n                incomingData: incomingBlock,\n                populationPromises,\n                result: result[fieldName][i],\n                serverURL,\n              })\n\n              return result[fieldName][i]\n            })\n          } else {\n            result[fieldName] = []\n          }\n\n          break\n\n        case 'tabs':\n        case 'group':\n          if (!result[fieldName]) {\n            result[fieldName] = {}\n          }\n\n          traverseFields({\n            apiRoute,\n            depth,\n            fieldSchema: fieldSchema.fields,\n            incomingData: incomingData[fieldName] || {},\n            populationPromises,\n            result: result[fieldName],\n            serverURL,\n          })\n\n          break\n\n        case 'upload':\n        case 'relationship':\n          // Handle `hasMany` relationships\n          if (fieldSchema.hasMany && Array.isArray(incomingData[fieldName])) {\n            if (!result[fieldName]) {\n              result[fieldName] = []\n            }\n\n            incomingData[fieldName].forEach((incomingRelation, i) => {\n              // Handle `hasMany` polymorphic\n              if (Array.isArray(fieldSchema.relationTo)) {\n                // if the field doesn't exist on the result, create it\n                // the value will be populated later\n                if (!result[fieldName][i]) {\n                  result[fieldName][i] = {\n                    relationTo: incomingRelation.relationTo,\n                  }\n                }\n\n                const oldID = result[fieldName][i]?.value?.id\n                const oldRelation = result[fieldName][i]?.relationTo\n                const newID = incomingRelation.value\n                const newRelation = incomingRelation.relationTo\n\n                if (oldID !== newID || oldRelation !== newRelation) {\n                  populationPromises.push(\n                    promise({\n                      id: incomingRelation.value,\n                      accessor: 'value',\n                      apiRoute,\n                      collection: newRelation,\n                      depth,\n                      ref: result[fieldName][i],\n                      serverURL,\n                    }),\n                  )\n                }\n              } else {\n                // Handle `hasMany` monomorphic\n                if (result[fieldName][i]?.id !== incomingRelation) {\n                  populationPromises.push(\n                    promise({\n                      id: incomingRelation,\n                      accessor: i,\n                      apiRoute,\n                      collection: String(fieldSchema.relationTo),\n                      depth,\n                      ref: result[fieldName],\n                      serverURL,\n                    }),\n                  )\n                }\n              }\n            })\n          } else {\n            // Handle `hasOne` polymorphic\n            if (Array.isArray(fieldSchema.relationTo)) {\n              // if the field doesn't exist on the result, create it\n              // the value will be populated later\n              if (!result[fieldName]) {\n                result[fieldName] = {\n                  relationTo: incomingData[fieldName]?.relationTo,\n                }\n              }\n\n              const hasNewValue =\n                incomingData[fieldName] &&\n                typeof incomingData[fieldName] === 'object' &&\n                incomingData[fieldName] !== null\n\n              const hasOldValue =\n                result[fieldName] &&\n                typeof result[fieldName] === 'object' &&\n                result[fieldName] !== null\n\n              const newID = hasNewValue\n                ? typeof incomingData[fieldName].value === 'object'\n                  ? incomingData[fieldName].value.id\n                  : incomingData[fieldName].value\n                : ''\n\n              const oldID = hasOldValue\n                ? typeof result[fieldName].value === 'object'\n                  ? result[fieldName].value.id\n                  : result[fieldName].value\n                : ''\n\n              const newRelation = hasNewValue ? incomingData[fieldName].relationTo : ''\n              const oldRelation = hasOldValue ? result[fieldName].relationTo : ''\n\n              // if the new value/relation is different from the old value/relation\n              // populate the new value, otherwise leave it alone\n              if (newID !== oldID || newRelation !== oldRelation) {\n                // if the new value is not empty, populate it\n                // otherwise set the value to null\n                if (newID) {\n                  populationPromises.push(\n                    promise({\n                      id: newID,\n                      accessor: 'value',\n                      apiRoute,\n                      collection: newRelation,\n                      depth,\n                      ref: result[fieldName],\n                      serverURL,\n                    }),\n                  )\n                } else {\n                  result[fieldName] = null\n                }\n              }\n            } else {\n              // Handle `hasOne` monomorphic\n              const newID: number | string | undefined =\n                (incomingData[fieldName] &&\n                  typeof incomingData[fieldName] === 'object' &&\n                  incomingData[fieldName].id) ||\n                incomingData[fieldName]\n\n              const oldID: number | string | undefined =\n                (result[fieldName] &&\n                  typeof result[fieldName] === 'object' &&\n                  result[fieldName].id) ||\n                result[fieldName]\n\n              // if the new value is different from the old value\n              // populate the new value, otherwise leave it alone\n              if (newID !== oldID) {\n                // if the new value is not empty, populate it\n                // otherwise set the value to null\n                if (newID) {\n                  populationPromises.push(\n                    promise({\n                      id: newID,\n                      accessor: fieldName,\n                      apiRoute,\n                      collection: String(fieldSchema.relationTo),\n                      depth,\n                      ref: result as Record<string, unknown>,\n                      serverURL,\n                    }),\n                  )\n                } else {\n                  result[fieldName] = null\n                }\n              }\n            }\n          }\n\n          break\n\n        default:\n          result[fieldName] = incomingData[fieldName]\n      }\n    }\n  })\n}\n"],"names":["traverseFields","args","apiRoute","depth","fieldSchema","fieldSchemas","incomingData","populationPromises","result","serverURL","forEach","name","fieldName","type","Array","isArray","map","incomingRow","i","fields","incomingBlock","incomingBlockJSON","blocks","blockType","id","hasMany","incomingRelation","relationTo","oldID","value","oldRelation","newID","newRelation","push","promise","accessor","collection","ref","String","hasNewValue","hasOldValue"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@payloadcms/live-preview",
3
- "version": "0.1.4",
3
+ "version": "0.1.6",
4
4
  "description": "The official live preview JavaScript SDK for Payload",
5
5
  "repository": "https://github.com/payloadcms/payload",
6
6
  "license": "MIT",
@@ -9,8 +9,11 @@
9
9
  "main": "./dist/index.js",
10
10
  "types": "./dist/index.d.ts",
11
11
  "devDependencies": {
12
- "@payloadcms/eslint-config": "0.0.1",
13
- "payload": "2.0.8"
12
+ "@payloadcms/eslint-config": "1.0.0",
13
+ "payload": "2.1.1"
14
+ },
15
+ "peerDependencies": {
16
+ "payload": "^2.0.0"
14
17
  },
15
18
  "exports": null,
16
19
  "publishConfig": {