@payloadcms/ui 3.71.0-internal.27e1e08 → 3.71.0-internal.49c4f67

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.
Files changed (27) hide show
  1. package/dist/exports/client/index.js +12 -12
  2. package/dist/exports/client/index.js.map +3 -3
  3. package/dist/fields/Group/index.scss +2 -0
  4. package/dist/fields/Tabs/index.d.ts.map +1 -1
  5. package/dist/fields/Tabs/index.js +138 -201
  6. package/dist/fields/Tabs/index.js.map +1 -1
  7. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.d.ts +2 -2
  8. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.d.ts.map +1 -1
  9. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js +125 -103
  10. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js.map +1 -1
  11. package/dist/forms/fieldSchemasToFormState/iterateFields.d.ts +2 -2
  12. package/dist/forms/fieldSchemasToFormState/iterateFields.d.ts.map +1 -1
  13. package/dist/forms/fieldSchemasToFormState/iterateFields.js +1 -1
  14. package/dist/forms/fieldSchemasToFormState/iterateFields.js.map +1 -1
  15. package/dist/forms/fieldSchemasToFormState/renderField.d.ts.map +1 -1
  16. package/dist/forms/fieldSchemasToFormState/renderField.js +5 -3
  17. package/dist/forms/fieldSchemasToFormState/renderField.js.map +1 -1
  18. package/dist/styles.css +1 -1
  19. package/dist/utilities/buildClientFieldSchemaMap/traverseFields.d.ts +2 -2
  20. package/dist/utilities/buildClientFieldSchemaMap/traverseFields.d.ts.map +1 -1
  21. package/dist/utilities/buildClientFieldSchemaMap/traverseFields.js +40 -36
  22. package/dist/utilities/buildClientFieldSchemaMap/traverseFields.js.map +1 -1
  23. package/dist/utilities/buildFieldSchemaMap/traverseFields.d.ts +2 -2
  24. package/dist/utilities/buildFieldSchemaMap/traverseFields.d.ts.map +1 -1
  25. package/dist/utilities/buildFieldSchemaMap/traverseFields.js +40 -38
  26. package/dist/utilities/buildFieldSchemaMap/traverseFields.js.map +1 -1
  27. package/package.json +4 -4
@@ -1 +1 @@
1
- {"version":3,"file":"addFieldStatePromise.d.ts","sourceRoot":"","sources":["../../../src/forms/fieldSchemasToFormState/addFieldStatePromise.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,IAAI,EACJ,mBAAmB,EACnB,KAAK,EACL,cAAc,EAGd,SAAS,EACT,0BAA0B,EAC1B,cAAc,EAGd,0BAA0B,EAC1B,UAAU,EACV,UAAU,EAGX,MAAM,SAAS,CAAA;AAehB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAQnD,MAAM,MAAM,wBAAwB,GAAG;IACrC,oBAAoB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IACjD;;OAEG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B;;OAEG;IACH,SAAS,EAAE,IAAI,GAAG,SAAS,CAAA;IAC3B,oBAAoB,CAAC,EAAE,oBAAoB,CAAA;IAC3C,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,IAAI,CAAA;IACV,KAAK,EAAE,KAAK,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;IAClB,cAAc,EAAE,cAAc,CAAA;IAC9B;;OAEG;IACH,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,wBAAwB,KAAK,OAAO,CAAA;IACpD;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,EAAE,IAAI,CAAA;IACd,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;IACnB;;OAEG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,kBAAkB,CAAC,UAAU,CAAC,CAAA;IACzC;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,EAAE,QAAQ,GAAG,QAAQ,CAAA;IAC9B,eAAe,EAAE,MAAM,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;IAClB,iBAAiB,EAAE,0BAA0B,CAAA;IAC7C,gBAAgB,EAAE,MAAM,CAAA;IACxB,eAAe,EAAE,OAAO,CAAA;IACxB,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,mBAAmB,CAAA;IAChC,iBAAiB,EAAE,SAAS,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,eAAe,EAAE,OAAO,CAAA;IACxB,aAAa,EAAE,iBAAiB,CAAA;IAChC;;;OAGG;IACH,GAAG,EAAE,cAAc,CAAA;IACnB,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,KAAK,EAAE,0BAA0B,CAAA;CAClC,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,oBAAoB,SAAgB,wBAAwB,KAAG,OAAO,CAAC,IAAI,CAy4BvF,CAAA"}
1
+ {"version":3,"file":"addFieldStatePromise.d.ts","sourceRoot":"","sources":["../../../src/forms/fieldSchemasToFormState/addFieldStatePromise.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,IAAI,EACJ,mBAAmB,EACnB,KAAK,EACL,cAAc,EAGd,SAAS,EACT,0BAA0B,EAC1B,cAAc,EAGd,0BAA0B,EAC1B,UAAU,EACV,UAAU,EACV,UAAU,EAEX,MAAM,SAAS,CAAA;AAchB,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAQnD,MAAM,MAAM,wBAAwB,GAAG;IACrC,oBAAoB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IACjD;;OAEG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B;;OAEG;IACH,SAAS,EAAE,IAAI,GAAG,SAAS,CAAA;IAC3B,oBAAoB,CAAC,EAAE,oBAAoB,CAAA;IAC3C,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,IAAI,CAAA;IACV,KAAK,EAAE,KAAK,GAAG,UAAU,CAAA;IACzB,UAAU,EAAE,MAAM,CAAA;IAClB,cAAc,EAAE,cAAc,CAAA;IAC9B;;OAEG;IACH,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,wBAAwB,KAAK,OAAO,CAAA;IACpD;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,EAAE,IAAI,CAAA;IACd,EAAE,EAAE,MAAM,GAAG,MAAM,CAAA;IACnB;;OAEG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,kBAAkB,CAAC,UAAU,CAAC,CAAA;IACzC;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB,SAAS,EAAE,QAAQ,GAAG,QAAQ,CAAA;IAC9B,eAAe,EAAE,MAAM,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;IAClB,iBAAiB,EAAE,0BAA0B,CAAA;IAC7C,gBAAgB,EAAE,MAAM,CAAA;IACxB,eAAe,EAAE,OAAO,CAAA;IACxB,IAAI,EAAE,MAAM,CAAA;IACZ,WAAW,EAAE,mBAAmB,CAAA;IAChC,iBAAiB,EAAE,SAAS,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,eAAe,EAAE,OAAO,CAAA;IACxB,aAAa,EAAE,iBAAiB,CAAA;IAChC;;;OAGG;IACH,GAAG,EAAE,cAAc,CAAA;IACnB,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,KAAK,EAAE,0BAA0B,CAAA;CAClC,CAAA;AAED;;;GAGG;AACH,eAAO,MAAM,oBAAoB,SAAgB,wBAAwB,KAAG,OAAO,CAAC,IAAI,CA25BvF,CAAA"}
@@ -1,6 +1,6 @@
1
1
  import ObjectIdImport from 'bson-objectid';
2
2
  import { getBlockSelect, stripUnselectedFields, validateBlocksFilterOptions } from 'payload';
3
- import { deepCopyObjectSimple, fieldAffectsData, fieldHasSubFields, fieldIsHiddenOrDisabled, fieldIsID, fieldIsLocalized, getFieldPaths, tabHasName } from 'payload/shared';
3
+ import { deepCopyObjectSimple, fieldAffectsData, fieldHasSubFields, fieldIsHiddenOrDisabled, fieldIsID, fieldIsLocalized, tabHasName } from 'payload/shared';
4
4
  import { resolveFilterOptions } from '../../utilities/resolveFilterOptions.js';
5
5
  import { isRowCollapsed } from './isRowCollapsed.js';
6
6
  import { iterateFields } from './iterateFields.js';
@@ -71,7 +71,7 @@ export const addFieldStatePromise = async args => {
71
71
  if (includeSchema) {
72
72
  fieldState.fieldSchema = field;
73
73
  }
74
- if (fieldAffectsData(field) && !fieldIsHiddenOrDisabled(field)) {
74
+ if (fieldAffectsData(field) && !fieldIsHiddenOrDisabled(field) && field.type !== 'tab') {
75
75
  fieldPermissions = parentPermissions === true ? parentPermissions : deepCopyObjectSimple(parentPermissions?.[field.name]);
76
76
  let hasPermission = fieldPermissions === true || deepCopyObjectSimple(fieldPermissions?.read);
77
77
  if (typeof field?.access?.read === 'function') {
@@ -88,7 +88,7 @@ export const addFieldStatePromise = async args => {
88
88
  if (!hasPermission) {
89
89
  return;
90
90
  }
91
- const validate = field.validate;
91
+ const validate = 'validate' in field ? field.validate : undefined;
92
92
  let validationResult = true;
93
93
  if (typeof validate === 'function' && !skipValidation && passesCondition) {
94
94
  let jsonError;
@@ -154,11 +154,11 @@ export const addFieldStatePromise = async args => {
154
154
  const {
155
155
  promises,
156
156
  rows
157
- } = arrayValue.reduce((acc, row, i) => {
158
- const parentPath = path + '.' + i;
157
+ } = arrayValue.reduce((acc, row, rowIndex) => {
158
+ const rowPath = path + '.' + rowIndex;
159
159
  row.id = row?.id || new ObjectId().toHexString();
160
160
  if (!omitParents && (!filter || filter(args))) {
161
- const idKey = parentPath + '.id';
161
+ const idKey = rowPath + '.id';
162
162
  state[idKey] = {
163
163
  initialValue: row.id,
164
164
  value: row.id
@@ -186,7 +186,7 @@ export const addFieldStatePromise = async args => {
186
186
  operation,
187
187
  parentIndexPath: '',
188
188
  parentPassesCondition: passesCondition,
189
- parentPath,
189
+ parentPath: rowPath,
190
190
  parentSchemaPath: schemaPath,
191
191
  permissions: fieldPermissions === true ? fieldPermissions : fieldPermissions?.fields || {},
192
192
  preferences,
@@ -284,12 +284,12 @@ export const addFieldStatePromise = async args => {
284
284
  select: select?.[field.name],
285
285
  selectMode
286
286
  });
287
- const parentPath = path + '.' + i;
287
+ const rowPath = path + '.' + i;
288
288
  if (block) {
289
289
  row.id = row?.id || new ObjectId().toHexString();
290
290
  if (!omitParents && (!filter || filter(args))) {
291
291
  // Handle block `id` field
292
- const idKey = parentPath + '.id';
292
+ const idKey = rowPath + '.id';
293
293
  state[idKey] = {
294
294
  initialValue: row.id,
295
295
  value: row.id
@@ -311,7 +311,7 @@ export const addFieldStatePromise = async args => {
311
311
  state[idKey].fieldSchema = includeSchema ? block.fields.find(blockField => fieldIsID(blockField)) : undefined;
312
312
  }
313
313
  // Handle `blockType` field
314
- const fieldKey = parentPath + '.blockType';
314
+ const fieldKey = rowPath + '.blockType';
315
315
  state[fieldKey] = {
316
316
  initialValue: row.blockType,
317
317
  value: row.blockType
@@ -323,7 +323,7 @@ export const addFieldStatePromise = async args => {
323
323
  state[fieldKey].fieldSchema = block.fields.find(blockField => 'name' in blockField && blockField.name === 'blockType');
324
324
  }
325
325
  // Handle `blockName` field
326
- const blockNameKey = parentPath + '.blockName';
326
+ const blockNameKey = rowPath + '.blockName';
327
327
  state[blockNameKey] = {};
328
328
  if (row.blockName) {
329
329
  state[blockNameKey].initialValue = row.blockName;
@@ -352,7 +352,7 @@ export const addFieldStatePromise = async args => {
352
352
  operation,
353
353
  parentIndexPath: '',
354
354
  parentPassesCondition: passesCondition,
355
- parentPath,
355
+ parentPath: rowPath,
356
356
  parentSchemaPath: schemaPath + '.' + block.slug,
357
357
  permissions: fieldPermissions === true ? fieldPermissions : parentPermissions?.[field.name]?.blocks?.[block.slug] === true ? true : parentPermissions?.[field.name]?.blocks?.[block.slug]?.fields || {},
358
358
  preferences,
@@ -583,8 +583,8 @@ export const addFieldStatePromise = async args => {
583
583
  operation,
584
584
  parentIndexPath: indexPath,
585
585
  parentPassesCondition: passesCondition,
586
- parentPath,
587
- parentSchemaPath,
586
+ parentPath: path,
587
+ parentSchemaPath: schemaPath,
588
588
  permissions: parentPermissions,
589
589
  preferences,
590
590
  previousFormState,
@@ -596,106 +596,128 @@ export const addFieldStatePromise = async args => {
596
596
  skipValidation,
597
597
  state
598
598
  });
599
- } else if (field.type === 'tabs') {
600
- const promises = field.tabs.map((tab, tabIndex) => {
601
- const isNamedTab = tabHasName(tab);
602
- let tabSelect;
603
- const tabField = {
604
- ...tab,
605
- type: 'tab'
606
- };
607
- const {
608
- indexPath: tabIndexPath,
609
- path: tabPath,
610
- schemaPath: tabSchemaPath
611
- } = getFieldPaths({
599
+ } else if (field.type === 'tab') {
600
+ const isNamedTab = tabHasName(field);
601
+ let tabSelect;
602
+ const tabField = {
603
+ ...field,
604
+ type: 'tab'
605
+ };
606
+ let childPermissions = undefined;
607
+ if (isNamedTab) {
608
+ const shouldContinue = stripUnselectedFields({
612
609
  field: tabField,
613
- index: tabIndex,
614
- parentIndexPath: indexPath,
615
- parentPath,
616
- parentSchemaPath
610
+ select,
611
+ selectMode,
612
+ siblingDoc: data?.[field.name] || {}
617
613
  });
618
- let childPermissions = undefined;
619
- if (isNamedTab) {
620
- const shouldContinue = stripUnselectedFields({
621
- field: tabField,
622
- select,
623
- selectMode,
624
- siblingDoc: data?.[tab.name] || {}
625
- });
626
- if (!shouldContinue) {
627
- return;
628
- }
629
- if (parentPermissions === true) {
614
+ if (!shouldContinue) {
615
+ return;
616
+ }
617
+ if (parentPermissions === true) {
618
+ childPermissions = true;
619
+ } else {
620
+ const tabPermissions = parentPermissions?.[field.name];
621
+ if (tabPermissions === true) {
630
622
  childPermissions = true;
631
623
  } else {
632
- const tabPermissions = parentPermissions?.[tab.name];
633
- if (tabPermissions === true) {
634
- childPermissions = true;
635
- } else {
636
- childPermissions = tabPermissions?.fields;
637
- }
638
- }
639
- if (typeof select?.[tab.name] === 'object') {
640
- tabSelect = select?.[tab.name];
624
+ childPermissions = tabPermissions?.fields;
641
625
  }
642
- } else {
643
- childPermissions = parentPermissions;
644
- tabSelect = select;
645
626
  }
646
- const pathSegments = path ? path.split('.') : [];
647
- // If passesCondition is false then this should always result to false
648
- // If the tab has no admin.condition provided then fallback to passesCondition and let that decide the result
649
- let tabPassesCondition = passesCondition;
650
- if (passesCondition && typeof tab.admin?.condition === 'function') {
651
- tabPassesCondition = tab.admin.condition(fullData, data, {
652
- blockData,
653
- operation,
654
- path: pathSegments,
655
- user: req.user
656
- });
627
+ if (typeof select?.[field.name] === 'object') {
628
+ tabSelect = select?.[field.name];
657
629
  }
658
- if (tab?.id) {
659
- state[tab.id] = {
660
- passesCondition: tabPassesCondition
661
- };
662
- }
663
- return iterateFields({
664
- id,
665
- addErrorPathToParent: addErrorPathToParentArg,
666
- anyParentLocalized: tab.localized || anyParentLocalized,
630
+ } else {
631
+ childPermissions = parentPermissions;
632
+ tabSelect = select;
633
+ }
634
+ const pathSegments = path ? path.split('.') : [];
635
+ // If passesCondition is false then this should always result to false
636
+ // If the tab has no admin.condition provided then fallback to passesCondition and let that decide the result
637
+ let tabPassesCondition = passesCondition;
638
+ if (passesCondition && typeof field.admin?.condition === 'function') {
639
+ tabPassesCondition = field.admin.condition(fullData, data, {
667
640
  blockData,
668
- clientFieldSchemaMap,
669
- collectionSlug,
670
- data: isNamedTab ? data?.[tab.name] || {} : data,
671
- fields: tab.fields,
672
- fieldSchemaMap,
673
- filter,
674
- forceFullValue,
675
- fullData,
676
- includeSchema,
677
- mockRSCs,
678
- omitParents,
679
641
  operation,
680
- parentIndexPath: isNamedTab ? '' : tabIndexPath,
681
- parentPassesCondition: tabPassesCondition,
682
- parentPath: isNamedTab ? tabPath : parentPath,
683
- parentSchemaPath: isNamedTab ? tabSchemaPath : parentSchemaPath,
684
- permissions: childPermissions,
685
- preferences,
686
- previousFormState,
687
- readOnly,
688
- renderAllFields,
689
- renderFieldFn,
690
- req,
691
- select: tabSelect,
692
- selectMode,
693
- skipConditionChecks,
694
- skipValidation,
695
- state
642
+ path: pathSegments,
643
+ user: req.user
696
644
  });
645
+ }
646
+ if (field?.id) {
647
+ state[field.id] = {
648
+ passesCondition: tabPassesCondition
649
+ };
650
+ }
651
+ return iterateFields({
652
+ id,
653
+ addErrorPathToParent: addErrorPathToParentArg,
654
+ anyParentLocalized: field.localized || anyParentLocalized,
655
+ blockData,
656
+ clientFieldSchemaMap,
657
+ collectionSlug,
658
+ data: isNamedTab ? data?.[field.name] || {} : data,
659
+ fields: field.fields,
660
+ fieldSchemaMap,
661
+ filter,
662
+ forceFullValue,
663
+ fullData,
664
+ includeSchema,
665
+ mockRSCs,
666
+ omitParents,
667
+ operation,
668
+ parentIndexPath: indexPath,
669
+ parentPassesCondition: tabPassesCondition,
670
+ parentPath: path,
671
+ parentSchemaPath: schemaPath,
672
+ permissions: childPermissions,
673
+ preferences,
674
+ previousFormState,
675
+ readOnly,
676
+ renderAllFields,
677
+ renderFieldFn,
678
+ req,
679
+ select: tabSelect,
680
+ selectMode,
681
+ skipConditionChecks,
682
+ skipValidation,
683
+ state
684
+ });
685
+ } else if (field.type === 'tabs') {
686
+ return iterateFields({
687
+ id,
688
+ addErrorPathToParent: addErrorPathToParentArg,
689
+ anyParentLocalized: fieldIsLocalized(field) || anyParentLocalized,
690
+ blockData,
691
+ clientFieldSchemaMap,
692
+ collectionSlug,
693
+ data,
694
+ fields: field.tabs.map(tab => ({
695
+ ...tab,
696
+ type: 'tab'
697
+ })),
698
+ fieldSchemaMap,
699
+ filter,
700
+ forceFullValue,
701
+ fullData,
702
+ includeSchema,
703
+ omitParents,
704
+ operation,
705
+ parentIndexPath: indexPath,
706
+ parentPassesCondition: passesCondition,
707
+ parentPath: path,
708
+ parentSchemaPath: schemaPath,
709
+ permissions: parentPermissions,
710
+ preferences,
711
+ previousFormState,
712
+ renderAllFields,
713
+ renderFieldFn,
714
+ req,
715
+ select,
716
+ selectMode,
717
+ skipConditionChecks,
718
+ skipValidation,
719
+ state
697
720
  });
698
- await Promise.all(promises);
699
721
  } else if (field.type === 'ui') {
700
722
  if (!filter || filter(args)) {
701
723
  state[path] = fieldState;
@@ -1 +1 @@
1
- {"version":3,"file":"addFieldStatePromise.js","names":["ObjectIdImport","getBlockSelect","stripUnselectedFields","validateBlocksFilterOptions","deepCopyObjectSimple","fieldAffectsData","fieldHasSubFields","fieldIsHiddenOrDisabled","fieldIsID","fieldIsLocalized","getFieldPaths","tabHasName","resolveFilterOptions","isRowCollapsed","iterateFields","ObjectId","default","addFieldStatePromise","args","id","addErrorPathToParent","addErrorPathToParentArg","anyParentLocalized","blockData","clientFieldSchemaMap","collectionSlug","data","field","fieldSchemaMap","filter","forceFullValue","fullData","includeSchema","indexPath","mockRSCs","omitParents","operation","parentPath","parentPermissions","parentSchemaPath","passesCondition","path","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","schemaPath","select","selectMode","skipConditionChecks","skipValidation","state","console","warn","fieldPermissions","fieldState","lastRenderedPath","addedByServer","fieldSchema","name","hasPermission","read","access","siblingData","validate","validationResult","jsonError","type","JSON","parse","e","event","previousValue","initialValue","err","payload","logger","error","msg","errorPath","errorPaths","includes","push","valid","errorMessage","arrayValue","Array","isArray","arraySelect","promises","rows","reduce","acc","row","i","toHexString","idKey","value","fields","find","localized","parentIndexPath","parentPassesCondition","permissions","undefined","previousRow","prevRow","newRow","isLoading","isCollapsed","collapsedPrefs","collapsed","Promise","all","length","disableFormData","blocksValue","filterOptionsValidationResult","filterOptions","blocksFilterOptions","allowedBlockSlugs","rowMetadata","blockTypeToMatch","blockType","block","blocks","blockReferences","slug","Error","blockSelect","blockSelectMode","invalidBlockSlugs","t","blockField","fieldKey","blockNameKey","blockName","groupSelect","relationTo","relation","query","user","hasMany","relationshipValue","map","relationship","selectFilterOptions","options","tabs","tab","tabIndex","isNamedTab","tabSelect","tabField","tabIndexPath","tabPath","tabSchemaPath","index","childPermissions","shouldContinue","siblingDoc","tabPermissions","pathSegments","split","tabPassesCondition","admin","condition","fieldConfig","get","endsWith","formState","previousFieldState"],"sources":["../../../src/forms/fieldSchemasToFormState/addFieldStatePromise.ts"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field,\n FieldSchemaMap,\n FieldState,\n FlattenedBlock,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n Row,\n SanitizedFieldPermissions,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n TabAsField,\n Validate,\n} from 'payload'\n\nimport ObjectIdImport from 'bson-objectid'\nimport { getBlockSelect, stripUnselectedFields, validateBlocksFilterOptions } from 'payload'\nimport {\n deepCopyObjectSimple,\n fieldAffectsData,\n fieldHasSubFields,\n fieldIsHiddenOrDisabled,\n fieldIsID,\n fieldIsLocalized,\n getFieldPaths,\n tabHasName,\n} from 'payload/shared'\n\nimport type { RenderFieldMethod } from './types.js'\n\nimport { resolveFilterOptions } from '../../utilities/resolveFilterOptions.js'\nimport { isRowCollapsed } from './isRowCollapsed.js'\nimport { iterateFields } from './iterateFields.js'\n\nconst ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectIdImport\n\nexport type AddFieldStatePromiseArgs = {\n addErrorPathToParent: (fieldPath: string) => void\n /**\n * if all parents are localized, then the field is localized\n */\n anyParentLocalized?: boolean\n /**\n * Data of the nearest parent block, or undefined\n */\n blockData: Data | undefined\n clientFieldSchemaMap?: ClientFieldSchemaMap\n collectionSlug?: string\n data: Data\n field: Field\n fieldIndex: number\n fieldSchemaMap: FieldSchemaMap\n /**\n * You can use this to filter down to only `localized` fields that require translation (type: text, textarea, etc.). Another plugin might want to look for only `point` type fields to do some GIS function. With the filter function you can go in like a surgeon.\n */\n filter?: (args: AddFieldStatePromiseArgs) => boolean\n /**\n * Force the value of fields like arrays or blocks to be the full value instead of the length @default false\n */\n forceFullValue?: boolean\n fullData: Data\n id: number | string\n /**\n * Whether the field schema should be included in the state\n */\n includeSchema?: boolean\n indexPath: string\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n /**\n * Whether to omit parent fields in the state. @default false\n */\n omitParents?: boolean\n operation: 'create' | 'update'\n parentIndexPath: string\n parentPath: string\n parentPermissions: SanitizedFieldsPermissions\n parentSchemaPath: string\n passesCondition: boolean\n path: string\n preferences: DocumentPreferences\n previousFormState: FormState\n readOnly?: boolean\n renderAllFields: boolean\n renderFieldFn: RenderFieldMethod\n /**\n * Req is used for validation and defaultValue calculation. If you don't need validation,\n * just create your own req and pass in the locale and the user\n */\n req: PayloadRequest\n schemaPath: string\n select?: SelectType\n selectMode?: SelectMode\n /**\n * Whether to skip checking the field's condition. @default false\n */\n skipConditionChecks?: boolean\n /**\n * Whether to skip validating the field. @default false\n */\n skipValidation?: boolean\n state: FormStateWithoutComponents\n}\n\n/**\n * Flattens the fields schema and fields data.\n * The output is the field path (e.g. array.0.name) mapped to a FormField object.\n */\nexport const addFieldStatePromise = async (args: AddFieldStatePromiseArgs): Promise<void> => {\n const {\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized = false,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n field,\n fieldSchemaMap,\n filter,\n forceFullValue = false,\n fullData,\n includeSchema = false,\n indexPath,\n mockRSCs,\n omitParents = false,\n operation,\n parentPath,\n parentPermissions,\n parentSchemaPath,\n passesCondition,\n path,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n schemaPath,\n select,\n selectMode,\n skipConditionChecks = false,\n skipValidation = false,\n state,\n } = args\n\n if (!args.clientFieldSchemaMap && args.renderFieldFn) {\n // eslint-disable-next-line no-console\n console.warn(\n 'clientFieldSchemaMap is not passed to addFieldStatePromise - this will reduce performance',\n )\n }\n\n let fieldPermissions: SanitizedFieldPermissions = true\n\n const fieldState: FieldState = {}\n\n const lastRenderedPath = previousFormState?.[path]?.lastRenderedPath\n\n // Append only if true to avoid sending '$undefined' through the network\n if (lastRenderedPath) {\n fieldState.lastRenderedPath = lastRenderedPath\n }\n\n // If we're rendering all fields, no need to flag this as added by server\n const addedByServer = !renderAllFields && !previousFormState?.[path]\n\n // Append only if true to avoid sending '$undefined' through the network\n if (addedByServer) {\n fieldState.addedByServer = true\n }\n\n // Append only if true to avoid sending '$undefined' through the network\n if (passesCondition === false) {\n fieldState.passesCondition = false\n }\n\n // Append only if true to avoid sending '$undefined' through the network\n if (includeSchema) {\n fieldState.fieldSchema = field\n }\n\n if (fieldAffectsData(field) && !fieldIsHiddenOrDisabled(field)) {\n fieldPermissions =\n parentPermissions === true\n ? parentPermissions\n : deepCopyObjectSimple(parentPermissions?.[field.name])\n\n let hasPermission: boolean =\n fieldPermissions === true || deepCopyObjectSimple(fieldPermissions?.read)\n\n if (typeof field?.access?.read === 'function') {\n hasPermission = await field.access.read({\n id,\n blockData,\n data: fullData,\n req,\n siblingData: data,\n })\n } else {\n hasPermission = true\n }\n\n if (!hasPermission) {\n return\n }\n\n const validate: Validate = field.validate\n\n let validationResult: string | true = true\n\n if (typeof validate === 'function' && !skipValidation && passesCondition) {\n let jsonError\n\n if (field.type === 'json' && typeof data[field.name] === 'string') {\n try {\n JSON.parse(data[field.name])\n } catch (e) {\n jsonError = e\n }\n }\n\n try {\n validationResult = await validate(data?.[field.name], {\n ...field,\n id,\n blockData,\n collectionSlug,\n data: fullData,\n event: 'onChange',\n // @AlessioGr added `jsonError` in https://github.com/payloadcms/payload/commit/c7ea62a39473408c3ea912c4fbf73e11be4b538d\n // @ts-expect-error-next-line\n jsonError,\n operation,\n preferences,\n previousValue: previousFormState?.[path]?.initialValue,\n req,\n siblingData: data,\n })\n } catch (err) {\n validationResult = `Error validating field at path: ${path}`\n\n req.payload.logger.error({\n err,\n msg: validationResult,\n })\n }\n }\n\n /**\n * This function adds the error **path** to the current field and all its parents. If a field is invalid, all its parents are also invalid.\n * It does not add the error **message** to the current field, as that shouldn't apply to all parents.\n * This is done separately below.\n */\n const addErrorPathToParent = (errorPath: string) => {\n if (typeof addErrorPathToParentArg === 'function') {\n addErrorPathToParentArg(errorPath)\n }\n\n if (!fieldState.errorPaths) {\n fieldState.errorPaths = []\n }\n\n if (!fieldState.errorPaths.includes(errorPath)) {\n fieldState.errorPaths.push(errorPath)\n fieldState.valid = false\n }\n }\n\n if (typeof validationResult === 'string') {\n fieldState.errorMessage = validationResult\n fieldState.valid = false\n addErrorPathToParent(path)\n }\n\n switch (field.type) {\n case 'array': {\n const arrayValue = Array.isArray(data[field.name]) ? data[field.name] : []\n\n const arraySelect = select?.[field.name]\n\n const { promises, rows } = arrayValue.reduce(\n (acc, row, i: number) => {\n const parentPath = path + '.' + i\n row.id = row?.id || new ObjectId().toHexString()\n\n if (!omitParents && (!filter || filter(args))) {\n const idKey = parentPath + '.id'\n\n state[idKey] = {\n initialValue: row.id,\n value: row.id,\n }\n\n if (includeSchema) {\n state[idKey].fieldSchema = field.fields.find((field) => fieldIsID(field))\n }\n }\n\n acc.promises.push(\n iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: row,\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath,\n parentSchemaPath: schemaPath,\n permissions:\n fieldPermissions === true ? fieldPermissions : fieldPermissions?.fields || {},\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n }),\n )\n\n if (!acc.rows) {\n acc.rows = []\n }\n\n // First, check if `previousFormState` has a matching row\n const previousRow: Row = (previousFormState?.[path]?.rows || []).find(\n (prevRow) => prevRow.id === row.id,\n )\n\n const newRow: Row = {\n id: row.id,\n isLoading: false,\n }\n\n if (previousRow?.lastRenderedPath) {\n newRow.lastRenderedPath = previousRow.lastRenderedPath\n }\n\n // add addedByServer flag\n if (!previousRow) {\n newRow.addedByServer = true\n }\n\n const isCollapsed = isRowCollapsed({\n collapsedPrefs: preferences?.fields?.[path]?.collapsed,\n field,\n previousRow,\n row,\n })\n\n if (isCollapsed) {\n newRow.collapsed = true\n }\n\n acc.rows.push(newRow)\n\n return acc\n },\n {\n promises: [],\n rows: [],\n },\n )\n\n // Wait for all promises and update fields with the results\n await Promise.all(promises)\n\n if (rows) {\n fieldState.rows = rows\n }\n\n // Add values to field state\n if (data[field.name] !== null) {\n fieldState.value = forceFullValue ? arrayValue : arrayValue.length\n fieldState.initialValue = forceFullValue ? arrayValue : arrayValue.length\n\n if (arrayValue.length > 0) {\n fieldState.disableFormData = true\n }\n }\n\n // Add field to state\n if (!omitParents && (!filter || filter(args))) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'blocks': {\n const blocksValue = Array.isArray(data[field.name]) ? data[field.name] : []\n\n // Handle blocks filterOptions\n let filterOptionsValidationResult: Awaited<\n ReturnType<typeof validateBlocksFilterOptions>\n > | null = null\n if (field.filterOptions) {\n filterOptionsValidationResult = await validateBlocksFilterOptions({\n id,\n data: fullData,\n filterOptions: field.filterOptions,\n req,\n siblingData: data,\n value: data[field.name],\n })\n\n fieldState.blocksFilterOptions = filterOptionsValidationResult.allowedBlockSlugs\n }\n\n const { promises, rowMetadata } = blocksValue.reduce(\n (acc, row, i: number) => {\n const blockTypeToMatch: string = row.blockType\n\n const block =\n req.payload.blocks[blockTypeToMatch] ??\n ((field.blockReferences ?? field.blocks).find(\n (blockType) => typeof blockType !== 'string' && blockType.slug === blockTypeToMatch,\n ) as FlattenedBlock | undefined)\n\n if (!block) {\n throw new Error(\n `Block with type \"${row.blockType}\" was found in block data, but no block with that type is defined in the config for field with schema path ${schemaPath}.`,\n )\n }\n\n const { blockSelect, blockSelectMode } = getBlockSelect({\n block,\n select: select?.[field.name],\n selectMode,\n })\n\n const parentPath = path + '.' + i\n\n if (block) {\n row.id = row?.id || new ObjectId().toHexString()\n\n if (!omitParents && (!filter || filter(args))) {\n // Handle block `id` field\n const idKey = parentPath + '.id'\n\n state[idKey] = {\n initialValue: row.id,\n value: row.id,\n }\n\n // If the blocks field fails filterOptions validation, add error paths to the individual blocks that are no longer allowed\n if (\n filterOptionsValidationResult?.invalidBlockSlugs?.length &&\n filterOptionsValidationResult.invalidBlockSlugs.includes(row.blockType)\n ) {\n state[idKey].errorMessage = req.t('validation:invalidBlock', {\n block: row.blockType,\n })\n state[idKey].valid = false\n addErrorPathToParent(idKey)\n\n // If the error is due to block filterOptions, we want the blocks field (fieldState) to include all the filterOptions-related\n // error paths for each sub-block, not for the validation result of the block itself. Otherwise, say there are 2 invalid blocks,\n // the blocks field will have 3 instead of 2 error paths - one for itself, and one for each invalid block.\n // Instead, we want only the 2 error paths for the individual, invalid blocks.\n fieldState.errorPaths = fieldState.errorPaths.filter(\n (errorPath) => errorPath !== path,\n )\n }\n\n if (includeSchema) {\n state[idKey].fieldSchema = includeSchema\n ? block.fields.find((blockField) => fieldIsID(blockField))\n : undefined\n }\n\n // Handle `blockType` field\n const fieldKey = parentPath + '.blockType'\n\n state[fieldKey] = {\n initialValue: row.blockType,\n value: row.blockType,\n }\n\n if (addedByServer) {\n state[fieldKey].addedByServer = addedByServer\n }\n\n if (includeSchema) {\n state[fieldKey].fieldSchema = block.fields.find(\n (blockField) => 'name' in blockField && blockField.name === 'blockType',\n )\n }\n\n // Handle `blockName` field\n const blockNameKey = parentPath + '.blockName'\n\n state[blockNameKey] = {}\n\n if (row.blockName) {\n state[blockNameKey].initialValue = row.blockName\n state[blockNameKey].value = row.blockName\n }\n\n if (includeSchema) {\n state[blockNameKey].fieldSchema = block.fields.find(\n (blockField) => 'name' in blockField && blockField.name === 'blockName',\n )\n }\n }\n\n acc.promises.push(\n iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData: row,\n clientFieldSchemaMap,\n collectionSlug,\n data: row,\n fields: block.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath,\n parentSchemaPath: schemaPath + '.' + block.slug,\n permissions:\n fieldPermissions === true\n ? fieldPermissions\n : parentPermissions?.[field.name]?.blocks?.[block.slug] === true\n ? true\n : parentPermissions?.[field.name]?.blocks?.[block.slug]?.fields || {},\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n skipConditionChecks,\n skipValidation,\n state,\n }),\n )\n\n // First, check if `previousFormState` has a matching row\n const previousRow: Row = (previousFormState?.[path]?.rows || []).find(\n (prevRow) => prevRow.id === row.id,\n )\n\n const newRow: Row = {\n id: row.id,\n blockType: row.blockType,\n isLoading: false,\n }\n\n if (previousRow?.lastRenderedPath) {\n newRow.lastRenderedPath = previousRow.lastRenderedPath\n }\n\n acc.rowMetadata.push(newRow)\n\n const isCollapsed = isRowCollapsed({\n collapsedPrefs: preferences?.fields?.[path]?.collapsed,\n field,\n previousRow,\n row,\n })\n\n if (isCollapsed) {\n acc.rowMetadata[acc.rowMetadata.length - 1].collapsed = true\n }\n }\n\n return acc\n },\n {\n promises: [],\n rowMetadata: [],\n },\n )\n\n await Promise.all(promises)\n\n // Add values to field state\n if (data[field.name] === null) {\n fieldState.value = null\n fieldState.initialValue = null\n } else {\n fieldState.value = forceFullValue ? blocksValue : blocksValue.length\n fieldState.initialValue = forceFullValue ? blocksValue : blocksValue.length\n\n if (blocksValue.length > 0) {\n fieldState.disableFormData = true\n }\n }\n\n fieldState.rows = rowMetadata\n\n // Add field to state\n if (!omitParents && (!filter || filter(args))) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'group': {\n if (!filter || filter(args)) {\n fieldState.disableFormData = true\n state[path] = fieldState\n }\n\n const groupSelect = select?.[field.name]\n\n await iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: data?.[field.name] || {},\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath: path,\n parentSchemaPath: schemaPath,\n permissions:\n typeof fieldPermissions === 'boolean' ? fieldPermissions : fieldPermissions?.fields,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof groupSelect === 'object' ? groupSelect : undefined,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n })\n\n break\n }\n\n case 'relationship':\n case 'upload': {\n if (field.filterOptions) {\n if (typeof field.filterOptions === 'object') {\n if (typeof field.relationTo === 'string') {\n fieldState.filterOptions = {\n [field.relationTo]: field.filterOptions,\n }\n } else {\n fieldState.filterOptions = field.relationTo.reduce((acc, relation) => {\n acc[relation] = field.filterOptions\n return acc\n }, {})\n }\n }\n\n if (typeof field.filterOptions === 'function') {\n const query = await resolveFilterOptions(field.filterOptions, {\n id,\n blockData,\n data: fullData,\n relationTo: field.relationTo,\n req,\n siblingData: data,\n user: req.user,\n })\n\n fieldState.filterOptions = query\n }\n }\n\n if (field.hasMany) {\n const relationshipValue = Array.isArray(data[field.name])\n ? data[field.name].map((relationship) => {\n if (Array.isArray(field.relationTo)) {\n return {\n relationTo: relationship.relationTo,\n value:\n relationship.value && typeof relationship.value === 'object'\n ? relationship.value?.id\n : relationship.value,\n }\n }\n if (typeof relationship === 'object' && relationship !== null) {\n return relationship.id\n }\n return relationship\n })\n : undefined\n\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n } else if (Array.isArray(field.relationTo)) {\n if (\n data[field.name] &&\n typeof data[field.name] === 'object' &&\n 'relationTo' in data[field.name] &&\n 'value' in data[field.name]\n ) {\n const value =\n typeof data[field.name]?.value === 'object' &&\n data[field.name]?.value &&\n 'id' in data[field.name].value\n ? data[field.name].value.id\n : data[field.name].value\n const relationshipValue = {\n relationTo: data[field.name]?.relationTo,\n value,\n }\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n }\n } else {\n const relationshipValue =\n data[field.name] && typeof data[field.name] === 'object' && 'id' in data[field.name]\n ? data[field.name].id\n : data[field.name]\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n }\n\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'select': {\n if (typeof field.filterOptions === 'function') {\n fieldState.selectFilterOptions = field.filterOptions({\n data: fullData,\n options: field.options,\n req,\n siblingData: data,\n })\n }\n\n if (data[field.name] !== undefined) {\n fieldState.value = data[field.name]\n fieldState.initialValue = data[field.name]\n }\n\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n\n default: {\n if (data[field.name] !== undefined) {\n fieldState.value = data[field.name]\n fieldState.initialValue = data[field.name]\n }\n\n // Add field to state\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n }\n } else if (fieldHasSubFields(field) && !fieldAffectsData(field)) {\n // Handle field types that do not use names (row, collapsible, unnamed group etc)\n\n if (!filter || filter(args)) {\n state[path] = {\n disableFormData: true,\n }\n\n if (passesCondition === false) {\n state[path].passesCondition = false\n }\n }\n\n await iterateFields({\n id,\n mockRSCs,\n select,\n selectMode,\n // passthrough parent functionality\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized: fieldIsLocalized(field) || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n omitParents,\n operation,\n parentIndexPath: indexPath,\n parentPassesCondition: passesCondition,\n parentPath,\n parentSchemaPath,\n permissions: parentPermissions, // TODO: Verify this is correct\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n skipConditionChecks,\n skipValidation,\n state,\n })\n } else if (field.type === 'tabs') {\n const promises = field.tabs.map((tab, tabIndex) => {\n const isNamedTab = tabHasName(tab)\n let tabSelect: SelectType | undefined\n\n const tabField: TabAsField = {\n ...tab,\n type: 'tab',\n }\n\n const {\n indexPath: tabIndexPath,\n path: tabPath,\n schemaPath: tabSchemaPath,\n } = getFieldPaths({\n field: tabField,\n index: tabIndex,\n parentIndexPath: indexPath,\n parentPath,\n parentSchemaPath,\n })\n\n let childPermissions: SanitizedFieldsPermissions = undefined\n\n if (isNamedTab) {\n const shouldContinue = stripUnselectedFields({\n field: tabField,\n select,\n selectMode,\n siblingDoc: data?.[tab.name] || {},\n })\n\n if (!shouldContinue) {\n return\n }\n\n if (parentPermissions === true) {\n childPermissions = true\n } else {\n const tabPermissions = parentPermissions?.[tab.name]\n if (tabPermissions === true) {\n childPermissions = true\n } else {\n childPermissions = tabPermissions?.fields\n }\n }\n\n if (typeof select?.[tab.name] === 'object') {\n tabSelect = select?.[tab.name] as SelectType\n }\n } else {\n childPermissions = parentPermissions\n tabSelect = select\n }\n\n const pathSegments = path ? path.split('.') : []\n\n // If passesCondition is false then this should always result to false\n // If the tab has no admin.condition provided then fallback to passesCondition and let that decide the result\n let tabPassesCondition = passesCondition\n\n if (passesCondition && typeof tab.admin?.condition === 'function') {\n tabPassesCondition = tab.admin.condition(fullData, data, {\n blockData,\n operation,\n path: pathSegments,\n user: req.user,\n })\n }\n\n if (tab?.id) {\n state[tab.id] = {\n passesCondition: tabPassesCondition,\n }\n }\n\n return iterateFields({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized: tab.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: isNamedTab ? data?.[tab.name] || {} : data,\n fields: tab.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: isNamedTab ? '' : tabIndexPath,\n parentPassesCondition: tabPassesCondition,\n parentPath: isNamedTab ? tabPath : parentPath,\n parentSchemaPath: isNamedTab ? tabSchemaPath : parentSchemaPath,\n permissions: childPermissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: tabSelect,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n })\n })\n\n await Promise.all(promises)\n } else if (field.type === 'ui') {\n if (!filter || filter(args)) {\n state[path] = fieldState\n state[path].disableFormData = true\n }\n }\n\n if (renderFieldFn && !fieldIsHiddenOrDisabled(field)) {\n const fieldConfig = fieldSchemaMap.get(schemaPath)\n\n if (!fieldConfig && !mockRSCs) {\n if (schemaPath.endsWith('.blockType')) {\n return\n } else {\n throw new Error(`Field config not found for ${schemaPath}`)\n }\n }\n\n if (!state[path]) {\n // Some fields (ie `Tab`) do not live in form state\n // therefore we cannot attach customComponents to them\n return\n }\n\n if (addedByServer) {\n state[path].addedByServer = addedByServer\n }\n\n renderFieldFn({\n id,\n clientFieldSchemaMap,\n collectionSlug,\n data: fullData,\n fieldConfig: fieldConfig as Field,\n fieldSchemaMap,\n fieldState: state[path],\n formState: state,\n indexPath,\n lastRenderedPath,\n mockRSCs,\n operation,\n parentPath,\n parentSchemaPath,\n path,\n permissions: fieldPermissions,\n preferences,\n previousFieldState: previousFormState?.[path],\n readOnly,\n renderAllFields,\n req,\n schemaPath,\n siblingData: data,\n })\n }\n}\n"],"mappings":"AAqBA,OAAOA,cAAA,MAAoB;AAC3B,SAASC,cAAc,EAAEC,qBAAqB,EAAEC,2BAA2B,QAAQ;AACnF,SACEC,oBAAoB,EACpBC,gBAAgB,EAChBC,iBAAiB,EACjBC,uBAAuB,EACvBC,SAAS,EACTC,gBAAgB,EAChBC,aAAa,EACbC,UAAU,QACL;AAIP,SAASC,oBAAoB,QAAQ;AACrC,SAASC,cAAc,QAAQ;AAC/B,SAASC,aAAa,QAAQ;AAE9B,MAAMC,QAAA,GAAW,aAAaf,cAAA,GAAiBA,cAAA,CAAegB,OAAO,GAAGhB,cAAA;AAqExE;;;;AAIA,OAAO,MAAMiB,oBAAA,GAAuB,MAAOC,IAAA;EACzC,MAAM;IACJC,EAAE;IACFC,oBAAA,EAAsBC,uBAAuB;IAC7CC,kBAAA,GAAqB,KAAK;IAC1BC,SAAS;IACTC,oBAAoB;IACpBC,cAAc;IACdC,IAAI;IACJC,KAAK;IACLC,cAAc;IACdC,MAAM;IACNC,cAAA,GAAiB,KAAK;IACtBC,QAAQ;IACRC,aAAA,GAAgB,KAAK;IACrBC,SAAS;IACTC,QAAQ;IACRC,WAAA,GAAc,KAAK;IACnBC,SAAS;IACTC,UAAU;IACVC,iBAAiB;IACjBC,gBAAgB;IAChBC,eAAe;IACfC,IAAI;IACJC,WAAW;IACXC,iBAAiB;IACjBC,QAAQ;IACRC,eAAe;IACfC,aAAa;IACbC,GAAG;IACHC,UAAU;IACVC,MAAM;IACNC,UAAU;IACVC,mBAAA,GAAsB,KAAK;IAC3BC,cAAA,GAAiB,KAAK;IACtBC;EAAK,CACN,GAAGnC,IAAA;EAEJ,IAAI,CAACA,IAAA,CAAKM,oBAAoB,IAAIN,IAAA,CAAK4B,aAAa,EAAE;IACpD;IACAQ,OAAA,CAAQC,IAAI,CACV;EAEJ;EAEA,IAAIC,gBAAA,GAA8C;EAElD,MAAMC,UAAA,GAAyB,CAAC;EAEhC,MAAMC,gBAAA,GAAmBf,iBAAA,GAAoBF,IAAA,CAAK,EAAEiB,gBAAA;EAEpD;EACA,IAAIA,gBAAA,EAAkB;IACpBD,UAAA,CAAWC,gBAAgB,GAAGA,gBAAA;EAChC;EAEA;EACA,MAAMC,aAAA,GAAgB,CAACd,eAAA,IAAmB,CAACF,iBAAA,GAAoBF,IAAA,CAAK;EAEpE;EACA,IAAIkB,aAAA,EAAe;IACjBF,UAAA,CAAWE,aAAa,GAAG;EAC7B;EAEA;EACA,IAAInB,eAAA,KAAoB,OAAO;IAC7BiB,UAAA,CAAWjB,eAAe,GAAG;EAC/B;EAEA;EACA,IAAIR,aAAA,EAAe;IACjByB,UAAA,CAAWG,WAAW,GAAGjC,KAAA;EAC3B;EAEA,IAAItB,gBAAA,CAAiBsB,KAAA,KAAU,CAACpB,uBAAA,CAAwBoB,KAAA,GAAQ;IAC9D6B,gBAAA,GACElB,iBAAA,KAAsB,OAClBA,iBAAA,GACAlC,oBAAA,CAAqBkC,iBAAA,GAAoBX,KAAA,CAAMkC,IAAI,CAAC;IAE1D,IAAIC,aAAA,GACFN,gBAAA,KAAqB,QAAQpD,oBAAA,CAAqBoD,gBAAA,EAAkBO,IAAA;IAEtE,IAAI,OAAOpC,KAAA,EAAOqC,MAAA,EAAQD,IAAA,KAAS,YAAY;MAC7CD,aAAA,GAAgB,MAAMnC,KAAA,CAAMqC,MAAM,CAACD,IAAI,CAAC;QACtC5C,EAAA;QACAI,SAAA;QACAG,IAAA,EAAMK,QAAA;QACNgB,GAAA;QACAkB,WAAA,EAAavC;MACf;IACF,OAAO;MACLoC,aAAA,GAAgB;IAClB;IAEA,IAAI,CAACA,aAAA,EAAe;MAClB;IACF;IAEA,MAAMI,QAAA,GAAqBvC,KAAA,CAAMuC,QAAQ;IAEzC,IAAIC,gBAAA,GAAkC;IAEtC,IAAI,OAAOD,QAAA,KAAa,cAAc,CAACd,cAAA,IAAkBZ,eAAA,EAAiB;MACxE,IAAI4B,SAAA;MAEJ,IAAIzC,KAAA,CAAM0C,IAAI,KAAK,UAAU,OAAO3C,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK,UAAU;QACjE,IAAI;UACFS,IAAA,CAAKC,KAAK,CAAC7C,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;QAC7B,EAAE,OAAOW,CAAA,EAAG;UACVJ,SAAA,GAAYI,CAAA;QACd;MACF;MAEA,IAAI;QACFL,gBAAA,GAAmB,MAAMD,QAAA,CAASxC,IAAA,GAAOC,KAAA,CAAMkC,IAAI,CAAC,EAAE;UACpD,GAAGlC,KAAK;UACRR,EAAA;UACAI,SAAA;UACAE,cAAA;UACAC,IAAA,EAAMK,QAAA;UACN0C,KAAA,EAAO;UACP;UACA;UACAL,SAAA;UACAhC,SAAA;UACAM,WAAA;UACAgC,aAAA,EAAe/B,iBAAA,GAAoBF,IAAA,CAAK,EAAEkC,YAAA;UAC1C5B,GAAA;UACAkB,WAAA,EAAavC;QACf;MACF,EAAE,OAAOkD,GAAA,EAAK;QACZT,gBAAA,GAAmB,mCAAmC1B,IAAA,EAAM;QAE5DM,GAAA,CAAI8B,OAAO,CAACC,MAAM,CAACC,KAAK,CAAC;UACvBH,GAAA;UACAI,GAAA,EAAKb;QACP;MACF;IACF;IAEA;;;;;IAKA,MAAM/C,oBAAA,GAAwB6D,SAAA;MAC5B,IAAI,OAAO5D,uBAAA,KAA4B,YAAY;QACjDA,uBAAA,CAAwB4D,SAAA;MAC1B;MAEA,IAAI,CAACxB,UAAA,CAAWyB,UAAU,EAAE;QAC1BzB,UAAA,CAAWyB,UAAU,GAAG,EAAE;MAC5B;MAEA,IAAI,CAACzB,UAAA,CAAWyB,UAAU,CAACC,QAAQ,CAACF,SAAA,GAAY;QAC9CxB,UAAA,CAAWyB,UAAU,CAACE,IAAI,CAACH,SAAA;QAC3BxB,UAAA,CAAW4B,KAAK,GAAG;MACrB;IACF;IAEA,IAAI,OAAOlB,gBAAA,KAAqB,UAAU;MACxCV,UAAA,CAAW6B,YAAY,GAAGnB,gBAAA;MAC1BV,UAAA,CAAW4B,KAAK,GAAG;MACnBjE,oBAAA,CAAqBqB,IAAA;IACvB;IAEA,QAAQd,KAAA,CAAM0C,IAAI;MAChB,KAAK;QAAS;UACZ,MAAMkB,UAAA,GAAaC,KAAA,CAAMC,OAAO,CAAC/D,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IAAInC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,GAAG,EAAE;UAE1E,MAAM6B,WAAA,GAAczC,MAAA,GAAStB,KAAA,CAAMkC,IAAI,CAAC;UAExC,MAAM;YAAE8B,QAAQ;YAAEC;UAAI,CAAE,GAAGL,UAAA,CAAWM,MAAM,CAC1C,CAACC,GAAA,EAAKC,GAAA,EAAKC,CAAA;YACT,MAAM3D,UAAA,GAAaI,IAAA,GAAO,MAAMuD,CAAA;YAChCD,GAAA,CAAI5E,EAAE,GAAG4E,GAAA,EAAK5E,EAAA,IAAM,IAAIJ,QAAA,GAAWkF,WAAW;YAE9C,IAAI,CAAC9D,WAAA,KAAgB,CAACN,MAAA,IAAUA,MAAA,CAAOX,IAAA,CAAI,GAAI;cAC7C,MAAMgF,KAAA,GAAQ7D,UAAA,GAAa;cAE3BgB,KAAK,CAAC6C,KAAA,CAAM,GAAG;gBACbvB,YAAA,EAAcoB,GAAA,CAAI5E,EAAE;gBACpBgF,KAAA,EAAOJ,GAAA,CAAI5E;cACb;cAEA,IAAIa,aAAA,EAAe;gBACjBqB,KAAK,CAAC6C,KAAA,CAAM,CAACtC,WAAW,GAAGjC,KAAA,CAAMyE,MAAM,CAACC,IAAI,CAAE1E,KAAA,IAAUnB,SAAA,CAAUmB,KAAA;cACpE;YACF;YAEAmE,GAAA,CAAIH,QAAQ,CAACP,IAAI,CACftE,aAAA,CAAc;cACZK,EAAA;cACAC,oBAAA;cACAE,kBAAA,EAAoBK,KAAA,CAAM2E,SAAS,IAAIhF,kBAAA;cACvCC,SAAA;cACAC,oBAAA;cACAC,cAAA;cACAC,IAAA,EAAMqE,GAAA;cACNK,MAAA,EAAQzE,KAAA,CAAMyE,MAAM;cACpBxE,cAAA;cACAC,MAAA;cACAC,cAAA;cACAC,QAAA;cACAC,aAAA;cACAE,QAAA;cACAC,WAAA;cACAC,SAAA;cACAmE,eAAA,EAAiB;cACjBC,qBAAA,EAAuBhE,eAAA;cACvBH,UAAA;cACAE,gBAAA,EAAkBS,UAAA;cAClByD,WAAA,EACEjD,gBAAA,KAAqB,OAAOA,gBAAA,GAAmBA,gBAAA,EAAkB4C,MAAA,IAAU,CAAC;cAC9E1D,WAAA;cACAC,iBAAA;cACAC,QAAA;cACAC,eAAA;cACAC,aAAA;cACAC,GAAA;cACAE,MAAA,EAAQ,OAAOyC,WAAA,KAAgB,WAAWA,WAAA,GAAcgB,SAAA;cACxDxD,UAAA;cACAC,mBAAA;cACAC,cAAA;cACAC;YACF;YAGF,IAAI,CAACyC,GAAA,CAAIF,IAAI,EAAE;cACbE,GAAA,CAAIF,IAAI,GAAG,EAAE;YACf;YAEA;YACA,MAAMe,WAAA,GAAmB,CAAChE,iBAAA,GAAoBF,IAAA,CAAK,EAAEmD,IAAA,IAAQ,EAAE,EAAES,IAAI,CAClEO,OAAA,IAAYA,OAAA,CAAQzF,EAAE,KAAK4E,GAAA,CAAI5E,EAAE;YAGpC,MAAM0F,MAAA,GAAc;cAClB1F,EAAA,EAAI4E,GAAA,CAAI5E,EAAE;cACV2F,SAAA,EAAW;YACb;YAEA,IAAIH,WAAA,EAAajD,gBAAA,EAAkB;cACjCmD,MAAA,CAAOnD,gBAAgB,GAAGiD,WAAA,CAAYjD,gBAAgB;YACxD;YAEA;YACA,IAAI,CAACiD,WAAA,EAAa;cAChBE,MAAA,CAAOlD,aAAa,GAAG;YACzB;YAEA,MAAMoD,WAAA,GAAclG,cAAA,CAAe;cACjCmG,cAAA,EAAgBtE,WAAA,EAAa0D,MAAA,GAAS3D,IAAA,CAAK,EAAEwE,SAAA;cAC7CtF,KAAA;cACAgF,WAAA;cACAZ;YACF;YAEA,IAAIgB,WAAA,EAAa;cACfF,MAAA,CAAOI,SAAS,GAAG;YACrB;YAEAnB,GAAA,CAAIF,IAAI,CAACR,IAAI,CAACyB,MAAA;YAEd,OAAOf,GAAA;UACT,GACA;YACEH,QAAA,EAAU,EAAE;YACZC,IAAA,EAAM;UACR;UAGF;UACA,MAAMsB,OAAA,CAAQC,GAAG,CAACxB,QAAA;UAElB,IAAIC,IAAA,EAAM;YACRnC,UAAA,CAAWmC,IAAI,GAAGA,IAAA;UACpB;UAEA;UACA,IAAIlE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK,MAAM;YAC7BJ,UAAA,CAAW0C,KAAK,GAAGrE,cAAA,GAAiByD,UAAA,GAAaA,UAAA,CAAW6B,MAAM;YAClE3D,UAAA,CAAWkB,YAAY,GAAG7C,cAAA,GAAiByD,UAAA,GAAaA,UAAA,CAAW6B,MAAM;YAEzE,IAAI7B,UAAA,CAAW6B,MAAM,GAAG,GAAG;cACzB3D,UAAA,CAAW4D,eAAe,GAAG;YAC/B;UACF;UAEA;UACA,IAAI,CAAClF,WAAA,KAAgB,CAACN,MAAA,IAAUA,MAAA,CAAOX,IAAA,CAAI,GAAI;YAC7CmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA;QACF;MAEA,KAAK;QAAU;UACb,MAAM6D,WAAA,GAAc9B,KAAA,CAAMC,OAAO,CAAC/D,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IAAInC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,GAAG,EAAE;UAE3E;UACA,IAAI0D,6BAAA,GAEO;UACX,IAAI5F,KAAA,CAAM6F,aAAa,EAAE;YACvBD,6BAAA,GAAgC,MAAMpH,2BAAA,CAA4B;cAChEgB,EAAA;cACAO,IAAA,EAAMK,QAAA;cACNyF,aAAA,EAAe7F,KAAA,CAAM6F,aAAa;cAClCzE,GAAA;cACAkB,WAAA,EAAavC,IAAA;cACbyE,KAAA,EAAOzE,IAAI,CAACC,KAAA,CAAMkC,IAAI;YACxB;YAEAJ,UAAA,CAAWgE,mBAAmB,GAAGF,6BAAA,CAA8BG,iBAAiB;UAClF;UAEA,MAAM;YAAE/B,QAAQ;YAAEgC;UAAW,CAAE,GAAGL,WAAA,CAAYzB,MAAM,CAClD,CAACC,GAAA,EAAKC,GAAA,EAAKC,CAAA;YACT,MAAM4B,gBAAA,GAA2B7B,GAAA,CAAI8B,SAAS;YAE9C,MAAMC,KAAA,GACJ/E,GAAA,CAAI8B,OAAO,CAACkD,MAAM,CAACH,gBAAA,CAAiB,IACnC,CAACjG,KAAA,CAAMqG,eAAe,IAAIrG,KAAA,CAAMoG,MAAM,EAAE1B,IAAI,CAC1CwB,SAAA,IAAc,OAAOA,SAAA,KAAc,YAAYA,SAAA,CAAUI,IAAI,KAAKL,gBAAA;YAGvE,IAAI,CAACE,KAAA,EAAO;cACV,MAAM,IAAII,KAAA,CACR,oBAAoBnC,GAAA,CAAI8B,SAAS,8GAA8G7E,UAAA,GAAa;YAEhK;YAEA,MAAM;cAAEmF,WAAW;cAAEC;YAAe,CAAE,GAAGnI,cAAA,CAAe;cACtD6H,KAAA;cACA7E,MAAA,EAAQA,MAAA,GAAStB,KAAA,CAAMkC,IAAI,CAAC;cAC5BX;YACF;YAEA,MAAMb,UAAA,GAAaI,IAAA,GAAO,MAAMuD,CAAA;YAEhC,IAAI8B,KAAA,EAAO;cACT/B,GAAA,CAAI5E,EAAE,GAAG4E,GAAA,EAAK5E,EAAA,IAAM,IAAIJ,QAAA,GAAWkF,WAAW;cAE9C,IAAI,CAAC9D,WAAA,KAAgB,CAACN,MAAA,IAAUA,MAAA,CAAOX,IAAA,CAAI,GAAI;gBAC7C;gBACA,MAAMgF,KAAA,GAAQ7D,UAAA,GAAa;gBAE3BgB,KAAK,CAAC6C,KAAA,CAAM,GAAG;kBACbvB,YAAA,EAAcoB,GAAA,CAAI5E,EAAE;kBACpBgF,KAAA,EAAOJ,GAAA,CAAI5E;gBACb;gBAEA;gBACA,IACEoG,6BAAA,EAA+Bc,iBAAA,EAAmBjB,MAAA,IAClDG,6BAAA,CAA8Bc,iBAAiB,CAAClD,QAAQ,CAACY,GAAA,CAAI8B,SAAS,GACtE;kBACAxE,KAAK,CAAC6C,KAAA,CAAM,CAACZ,YAAY,GAAGvC,GAAA,CAAIuF,CAAC,CAAC,2BAA2B;oBAC3DR,KAAA,EAAO/B,GAAA,CAAI8B;kBACb;kBACAxE,KAAK,CAAC6C,KAAA,CAAM,CAACb,KAAK,GAAG;kBACrBjE,oBAAA,CAAqB8E,KAAA;kBAErB;kBACA;kBACA;kBACA;kBACAzC,UAAA,CAAWyB,UAAU,GAAGzB,UAAA,CAAWyB,UAAU,CAACrD,MAAM,CACjDoD,SAAA,IAAcA,SAAA,KAAcxC,IAAA;gBAEjC;gBAEA,IAAIT,aAAA,EAAe;kBACjBqB,KAAK,CAAC6C,KAAA,CAAM,CAACtC,WAAW,GAAG5B,aAAA,GACvB8F,KAAA,CAAM1B,MAAM,CAACC,IAAI,CAAEkC,UAAA,IAAe/H,SAAA,CAAU+H,UAAA,KAC5C7B,SAAA;gBACN;gBAEA;gBACA,MAAM8B,QAAA,GAAWnG,UAAA,GAAa;gBAE9BgB,KAAK,CAACmF,QAAA,CAAS,GAAG;kBAChB7D,YAAA,EAAcoB,GAAA,CAAI8B,SAAS;kBAC3B1B,KAAA,EAAOJ,GAAA,CAAI8B;gBACb;gBAEA,IAAIlE,aAAA,EAAe;kBACjBN,KAAK,CAACmF,QAAA,CAAS,CAAC7E,aAAa,GAAGA,aAAA;gBAClC;gBAEA,IAAI3B,aAAA,EAAe;kBACjBqB,KAAK,CAACmF,QAAA,CAAS,CAAC5E,WAAW,GAAGkE,KAAA,CAAM1B,MAAM,CAACC,IAAI,CAC5CkC,UAAA,IAAe,UAAUA,UAAA,IAAcA,UAAA,CAAW1E,IAAI,KAAK;gBAEhE;gBAEA;gBACA,MAAM4E,YAAA,GAAepG,UAAA,GAAa;gBAElCgB,KAAK,CAACoF,YAAA,CAAa,GAAG,CAAC;gBAEvB,IAAI1C,GAAA,CAAI2C,SAAS,EAAE;kBACjBrF,KAAK,CAACoF,YAAA,CAAa,CAAC9D,YAAY,GAAGoB,GAAA,CAAI2C,SAAS;kBAChDrF,KAAK,CAACoF,YAAA,CAAa,CAACtC,KAAK,GAAGJ,GAAA,CAAI2C,SAAS;gBAC3C;gBAEA,IAAI1G,aAAA,EAAe;kBACjBqB,KAAK,CAACoF,YAAA,CAAa,CAAC7E,WAAW,GAAGkE,KAAA,CAAM1B,MAAM,CAACC,IAAI,CAChDkC,UAAA,IAAe,UAAUA,UAAA,IAAcA,UAAA,CAAW1E,IAAI,KAAK;gBAEhE;cACF;cAEAiC,GAAA,CAAIH,QAAQ,CAACP,IAAI,CACftE,aAAA,CAAc;gBACZK,EAAA;gBACAC,oBAAA;gBACAE,kBAAA,EAAoBK,KAAA,CAAM2E,SAAS,IAAIhF,kBAAA;gBACvCC,SAAA,EAAWwE,GAAA;gBACXvE,oBAAA;gBACAC,cAAA;gBACAC,IAAA,EAAMqE,GAAA;gBACNK,MAAA,EAAQ0B,KAAA,CAAM1B,MAAM;gBACpBxE,cAAA;gBACAC,MAAA;gBACAC,cAAA;gBACAC,QAAA;gBACAC,aAAA;gBACAE,QAAA;gBACAC,WAAA;gBACAC,SAAA;gBACAmE,eAAA,EAAiB;gBACjBC,qBAAA,EAAuBhE,eAAA;gBACvBH,UAAA;gBACAE,gBAAA,EAAkBS,UAAA,GAAa,MAAM8E,KAAA,CAAMG,IAAI;gBAC/CxB,WAAA,EACEjD,gBAAA,KAAqB,OACjBA,gBAAA,GACAlB,iBAAA,GAAoBX,KAAA,CAAMkC,IAAI,CAAC,EAAEkE,MAAA,GAASD,KAAA,CAAMG,IAAI,CAAC,KAAK,OACxD,OACA3F,iBAAA,GAAoBX,KAAA,CAAMkC,IAAI,CAAC,EAAEkE,MAAA,GAASD,KAAA,CAAMG,IAAI,CAAC,EAAE7B,MAAA,IAAU,CAAC;gBAC1E1D,WAAA;gBACAC,iBAAA;gBACAC,QAAA;gBACAC,eAAA;gBACAC,aAAA;gBACAC,GAAA;gBACAE,MAAA,EAAQ,OAAOkF,WAAA,KAAgB,WAAWA,WAAA,GAAczB,SAAA;gBACxDxD,UAAA,EAAYkF,eAAA;gBACZjF,mBAAA;gBACAC,cAAA;gBACAC;cACF;cAGF;cACA,MAAMsD,WAAA,GAAmB,CAAChE,iBAAA,GAAoBF,IAAA,CAAK,EAAEmD,IAAA,IAAQ,EAAE,EAAES,IAAI,CAClEO,OAAA,IAAYA,OAAA,CAAQzF,EAAE,KAAK4E,GAAA,CAAI5E,EAAE;cAGpC,MAAM0F,MAAA,GAAc;gBAClB1F,EAAA,EAAI4E,GAAA,CAAI5E,EAAE;gBACV0G,SAAA,EAAW9B,GAAA,CAAI8B,SAAS;gBACxBf,SAAA,EAAW;cACb;cAEA,IAAIH,WAAA,EAAajD,gBAAA,EAAkB;gBACjCmD,MAAA,CAAOnD,gBAAgB,GAAGiD,WAAA,CAAYjD,gBAAgB;cACxD;cAEAoC,GAAA,CAAI6B,WAAW,CAACvC,IAAI,CAACyB,MAAA;cAErB,MAAME,WAAA,GAAclG,cAAA,CAAe;gBACjCmG,cAAA,EAAgBtE,WAAA,EAAa0D,MAAA,GAAS3D,IAAA,CAAK,EAAEwE,SAAA;gBAC7CtF,KAAA;gBACAgF,WAAA;gBACAZ;cACF;cAEA,IAAIgB,WAAA,EAAa;gBACfjB,GAAA,CAAI6B,WAAW,CAAC7B,GAAA,CAAI6B,WAAW,CAACP,MAAM,GAAG,EAAE,CAACH,SAAS,GAAG;cAC1D;YACF;YAEA,OAAOnB,GAAA;UACT,GACA;YACEH,QAAA,EAAU,EAAE;YACZgC,WAAA,EAAa;UACf;UAGF,MAAMT,OAAA,CAAQC,GAAG,CAACxB,QAAA;UAElB;UACA,IAAIjE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK,MAAM;YAC7BJ,UAAA,CAAW0C,KAAK,GAAG;YACnB1C,UAAA,CAAWkB,YAAY,GAAG;UAC5B,OAAO;YACLlB,UAAA,CAAW0C,KAAK,GAAGrE,cAAA,GAAiBwF,WAAA,GAAcA,WAAA,CAAYF,MAAM;YACpE3D,UAAA,CAAWkB,YAAY,GAAG7C,cAAA,GAAiBwF,WAAA,GAAcA,WAAA,CAAYF,MAAM;YAE3E,IAAIE,WAAA,CAAYF,MAAM,GAAG,GAAG;cAC1B3D,UAAA,CAAW4D,eAAe,GAAG;YAC/B;UACF;UAEA5D,UAAA,CAAWmC,IAAI,GAAG+B,WAAA;UAElB;UACA,IAAI,CAACxF,WAAA,KAAgB,CAACN,MAAA,IAAUA,MAAA,CAAOX,IAAA,CAAI,GAAI;YAC7CmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA;QACF;MAEA,KAAK;QAAS;UACZ,IAAI,CAAC5B,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;YAC3BuC,UAAA,CAAW4D,eAAe,GAAG;YAC7BhE,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA,MAAMkF,WAAA,GAAc1F,MAAA,GAAStB,KAAA,CAAMkC,IAAI,CAAC;UAExC,MAAM/C,aAAA,CAAc;YAClBK,EAAA;YACAC,oBAAA;YACAE,kBAAA,EAAoBK,KAAA,CAAM2E,SAAS,IAAIhF,kBAAA;YACvCC,SAAA;YACAC,oBAAA;YACAC,cAAA;YACAC,IAAA,EAAMA,IAAA,GAAOC,KAAA,CAAMkC,IAAI,CAAC,IAAI,CAAC;YAC7BuC,MAAA,EAAQzE,KAAA,CAAMyE,MAAM;YACpBxE,cAAA;YACAC,MAAA;YACAC,cAAA;YACAC,QAAA;YACAC,aAAA;YACAE,QAAA;YACAC,WAAA;YACAC,SAAA;YACAmE,eAAA,EAAiB;YACjBC,qBAAA,EAAuBhE,eAAA;YACvBH,UAAA,EAAYI,IAAA;YACZF,gBAAA,EAAkBS,UAAA;YAClByD,WAAA,EACE,OAAOjD,gBAAA,KAAqB,YAAYA,gBAAA,GAAmBA,gBAAA,EAAkB4C,MAAA;YAC/E1D,WAAA;YACAC,iBAAA;YACAC,QAAA;YACAC,eAAA;YACAC,aAAA;YACAC,GAAA;YACAE,MAAA,EAAQ,OAAO0F,WAAA,KAAgB,WAAWA,WAAA,GAAcjC,SAAA;YACxDxD,UAAA;YACAC,mBAAA;YACAC,cAAA;YACAC;UACF;UAEA;QACF;MAEA,KAAK;MACL,KAAK;QAAU;UACb,IAAI1B,KAAA,CAAM6F,aAAa,EAAE;YACvB,IAAI,OAAO7F,KAAA,CAAM6F,aAAa,KAAK,UAAU;cAC3C,IAAI,OAAO7F,KAAA,CAAMiH,UAAU,KAAK,UAAU;gBACxCnF,UAAA,CAAW+D,aAAa,GAAG;kBACzB,CAAC7F,KAAA,CAAMiH,UAAU,GAAGjH,KAAA,CAAM6F;gBAC5B;cACF,OAAO;gBACL/D,UAAA,CAAW+D,aAAa,GAAG7F,KAAA,CAAMiH,UAAU,CAAC/C,MAAM,CAAC,CAACC,GAAA,EAAK+C,QAAA;kBACvD/C,GAAG,CAAC+C,QAAA,CAAS,GAAGlH,KAAA,CAAM6F,aAAa;kBACnC,OAAO1B,GAAA;gBACT,GAAG,CAAC;cACN;YACF;YAEA,IAAI,OAAOnE,KAAA,CAAM6F,aAAa,KAAK,YAAY;cAC7C,MAAMsB,KAAA,GAAQ,MAAMlI,oBAAA,CAAqBe,KAAA,CAAM6F,aAAa,EAAE;gBAC5DrG,EAAA;gBACAI,SAAA;gBACAG,IAAA,EAAMK,QAAA;gBACN6G,UAAA,EAAYjH,KAAA,CAAMiH,UAAU;gBAC5B7F,GAAA;gBACAkB,WAAA,EAAavC,IAAA;gBACbqH,IAAA,EAAMhG,GAAA,CAAIgG;cACZ;cAEAtF,UAAA,CAAW+D,aAAa,GAAGsB,KAAA;YAC7B;UACF;UAEA,IAAInH,KAAA,CAAMqH,OAAO,EAAE;YACjB,MAAMC,iBAAA,GAAoBzD,KAAA,CAAMC,OAAO,CAAC/D,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IACpDnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,CAACqF,GAAG,CAAEC,YAAA;cACpB,IAAI3D,KAAA,CAAMC,OAAO,CAAC9D,KAAA,CAAMiH,UAAU,GAAG;gBACnC,OAAO;kBACLA,UAAA,EAAYO,YAAA,CAAaP,UAAU;kBACnCzC,KAAA,EACEgD,YAAA,CAAahD,KAAK,IAAI,OAAOgD,YAAA,CAAahD,KAAK,KAAK,WAChDgD,YAAA,CAAahD,KAAK,EAAEhF,EAAA,GACpBgI,YAAA,CAAahD;gBACrB;cACF;cACA,IAAI,OAAOgD,YAAA,KAAiB,YAAYA,YAAA,KAAiB,MAAM;gBAC7D,OAAOA,YAAA,CAAahI,EAAE;cACxB;cACA,OAAOgI,YAAA;YACT,KACAzC,SAAA;YAEJjD,UAAA,CAAW0C,KAAK,GAAG8C,iBAAA;YACnBxF,UAAA,CAAWkB,YAAY,GAAGsE,iBAAA;UAC5B,OAAO,IAAIzD,KAAA,CAAMC,OAAO,CAAC9D,KAAA,CAAMiH,UAAU,GAAG;YAC1C,IACElH,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IAChB,OAAOnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK,YAC5B,gBAAgBnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IAChC,WAAWnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,EAC3B;cACA,MAAMsC,KAAA,GACJ,OAAOzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,EAAEsC,KAAA,KAAU,YACnCzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,EAAEsC,KAAA,IAClB,QAAQzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,CAACsC,KAAK,GAC1BzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,CAACsC,KAAK,CAAChF,EAAE,GACzBO,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,CAACsC,KAAK;cAC5B,MAAM8C,iBAAA,GAAoB;gBACxBL,UAAA,EAAYlH,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,EAAE+E,UAAA;gBAC9BzC;cACF;cACA1C,UAAA,CAAW0C,KAAK,GAAG8C,iBAAA;cACnBxF,UAAA,CAAWkB,YAAY,GAAGsE,iBAAA;YAC5B;UACF,OAAO;YACL,MAAMA,iBAAA,GACJvH,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,IAAI,OAAOnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK,YAAY,QAAQnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,GAChFnC,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,CAAC1C,EAAE,GACnBO,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;YACtBJ,UAAA,CAAW0C,KAAK,GAAG8C,iBAAA;YACnBxF,UAAA,CAAWkB,YAAY,GAAGsE,iBAAA;UAC5B;UAEA,IAAI,CAACpH,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;YAC3BmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA;QACF;MAEA,KAAK;QAAU;UACb,IAAI,OAAO9B,KAAA,CAAM6F,aAAa,KAAK,YAAY;YAC7C/D,UAAA,CAAW2F,mBAAmB,GAAGzH,KAAA,CAAM6F,aAAa,CAAC;cACnD9F,IAAA,EAAMK,QAAA;cACNsH,OAAA,EAAS1H,KAAA,CAAM0H,OAAO;cACtBtG,GAAA;cACAkB,WAAA,EAAavC;YACf;UACF;UAEA,IAAIA,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK6C,SAAA,EAAW;YAClCjD,UAAA,CAAW0C,KAAK,GAAGzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;YACnCJ,UAAA,CAAWkB,YAAY,GAAGjD,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;UAC5C;UAEA,IAAI,CAAChC,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;YAC3BmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA;QACF;MAEA;QAAS;UACP,IAAI/B,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC,KAAK6C,SAAA,EAAW;YAClCjD,UAAA,CAAW0C,KAAK,GAAGzE,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;YACnCJ,UAAA,CAAWkB,YAAY,GAAGjD,IAAI,CAACC,KAAA,CAAMkC,IAAI,CAAC;UAC5C;UAEA;UACA,IAAI,CAAChC,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;YAC3BmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;UAChB;UAEA;QACF;IACF;EACF,OAAO,IAAInD,iBAAA,CAAkBqB,KAAA,KAAU,CAACtB,gBAAA,CAAiBsB,KAAA,GAAQ;IAC/D;IAEA,IAAI,CAACE,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;MAC3BmC,KAAK,CAACZ,IAAA,CAAK,GAAG;QACZ4E,eAAA,EAAiB;MACnB;MAEA,IAAI7E,eAAA,KAAoB,OAAO;QAC7Ba,KAAK,CAACZ,IAAA,CAAK,CAACD,eAAe,GAAG;MAChC;IACF;IAEA,MAAM1B,aAAA,CAAc;MAClBK,EAAA;MACAe,QAAA;MACAe,MAAA;MACAC,UAAA;MACA;MACA9B,oBAAA,EAAsBC,uBAAA;MACtBC,kBAAA,EAAoBb,gBAAA,CAAiBkB,KAAA,KAAUL,kBAAA;MAC/CC,SAAA;MACAC,oBAAA;MACAC,cAAA;MACAC,IAAA;MACA0E,MAAA,EAAQzE,KAAA,CAAMyE,MAAM;MACpBxE,cAAA;MACAC,MAAA;MACAC,cAAA;MACAC,QAAA;MACAC,aAAA;MACAG,WAAA;MACAC,SAAA;MACAmE,eAAA,EAAiBtE,SAAA;MACjBuE,qBAAA,EAAuBhE,eAAA;MACvBH,UAAA;MACAE,gBAAA;MACAkE,WAAA,EAAanE,iBAAA;MACbI,WAAA;MACAC,iBAAA;MACAC,QAAA;MACAC,eAAA;MACAC,aAAA;MACAC,GAAA;MACAI,mBAAA;MACAC,cAAA;MACAC;IACF;EACF,OAAO,IAAI1B,KAAA,CAAM0C,IAAI,KAAK,QAAQ;IAChC,MAAMsB,QAAA,GAAWhE,KAAA,CAAM2H,IAAI,CAACJ,GAAG,CAAC,CAACK,GAAA,EAAKC,QAAA;MACpC,MAAMC,UAAA,GAAa9I,UAAA,CAAW4I,GAAA;MAC9B,IAAIG,SAAA;MAEJ,MAAMC,QAAA,GAAuB;QAC3B,GAAGJ,GAAG;QACNlF,IAAA,EAAM;MACR;MAEA,MAAM;QACJpC,SAAA,EAAW2H,YAAY;QACvBnH,IAAA,EAAMoH,OAAO;QACb7G,UAAA,EAAY8G;MAAa,CAC1B,GAAGpJ,aAAA,CAAc;QAChBiB,KAAA,EAAOgI,QAAA;QACPI,KAAA,EAAOP,QAAA;QACPjD,eAAA,EAAiBtE,SAAA;QACjBI,UAAA;QACAE;MACF;MAEA,IAAIyH,gBAAA,GAA+CtD,SAAA;MAEnD,IAAI+C,UAAA,EAAY;QACd,MAAMQ,cAAA,GAAiB/J,qBAAA,CAAsB;UAC3CyB,KAAA,EAAOgI,QAAA;UACP1G,MAAA;UACAC,UAAA;UACAgH,UAAA,EAAYxI,IAAA,GAAO6H,GAAA,CAAI1F,IAAI,CAAC,IAAI,CAAC;QACnC;QAEA,IAAI,CAACoG,cAAA,EAAgB;UACnB;QACF;QAEA,IAAI3H,iBAAA,KAAsB,MAAM;UAC9B0H,gBAAA,GAAmB;QACrB,OAAO;UACL,MAAMG,cAAA,GAAiB7H,iBAAA,GAAoBiH,GAAA,CAAI1F,IAAI,CAAC;UACpD,IAAIsG,cAAA,KAAmB,MAAM;YAC3BH,gBAAA,GAAmB;UACrB,OAAO;YACLA,gBAAA,GAAmBG,cAAA,EAAgB/D,MAAA;UACrC;QACF;QAEA,IAAI,OAAOnD,MAAA,GAASsG,GAAA,CAAI1F,IAAI,CAAC,KAAK,UAAU;UAC1C6F,SAAA,GAAYzG,MAAA,GAASsG,GAAA,CAAI1F,IAAI,CAAC;QAChC;MACF,OAAO;QACLmG,gBAAA,GAAmB1H,iBAAA;QACnBoH,SAAA,GAAYzG,MAAA;MACd;MAEA,MAAMmH,YAAA,GAAe3H,IAAA,GAAOA,IAAA,CAAK4H,KAAK,CAAC,OAAO,EAAE;MAEhD;MACA;MACA,IAAIC,kBAAA,GAAqB9H,eAAA;MAEzB,IAAIA,eAAA,IAAmB,OAAO+G,GAAA,CAAIgB,KAAK,EAAEC,SAAA,KAAc,YAAY;QACjEF,kBAAA,GAAqBf,GAAA,CAAIgB,KAAK,CAACC,SAAS,CAACzI,QAAA,EAAUL,IAAA,EAAM;UACvDH,SAAA;UACAa,SAAA;UACAK,IAAA,EAAM2H,YAAA;UACNrB,IAAA,EAAMhG,GAAA,CAAIgG;QACZ;MACF;MAEA,IAAIQ,GAAA,EAAKpI,EAAA,EAAI;QACXkC,KAAK,CAACkG,GAAA,CAAIpI,EAAE,CAAC,GAAG;UACdqB,eAAA,EAAiB8H;QACnB;MACF;MAEA,OAAOxJ,aAAA,CAAc;QACnBK,EAAA;QACAC,oBAAA,EAAsBC,uBAAA;QACtBC,kBAAA,EAAoBiI,GAAA,CAAIjD,SAAS,IAAIhF,kBAAA;QACrCC,SAAA;QACAC,oBAAA;QACAC,cAAA;QACAC,IAAA,EAAM+H,UAAA,GAAa/H,IAAA,GAAO6H,GAAA,CAAI1F,IAAI,CAAC,IAAI,CAAC,IAAInC,IAAA;QAC5C0E,MAAA,EAAQmD,GAAA,CAAInD,MAAM;QAClBxE,cAAA;QACAC,MAAA;QACAC,cAAA;QACAC,QAAA;QACAC,aAAA;QACAE,QAAA;QACAC,WAAA;QACAC,SAAA;QACAmE,eAAA,EAAiBkD,UAAA,GAAa,KAAKG,YAAA;QACnCpD,qBAAA,EAAuB8D,kBAAA;QACvBjI,UAAA,EAAYoH,UAAA,GAAaI,OAAA,GAAUxH,UAAA;QACnCE,gBAAA,EAAkBkH,UAAA,GAAaK,aAAA,GAAgBvH,gBAAA;QAC/CkE,WAAA,EAAauD,gBAAA;QACbtH,WAAA;QACAC,iBAAA;QACAC,QAAA;QACAC,eAAA;QACAC,aAAA;QACAC,GAAA;QACAE,MAAA,EAAQyG,SAAA;QACRxG,UAAA;QACAC,mBAAA;QACAC,cAAA;QACAC;MACF;IACF;IAEA,MAAM6D,OAAA,CAAQC,GAAG,CAACxB,QAAA;EACpB,OAAO,IAAIhE,KAAA,CAAM0C,IAAI,KAAK,MAAM;IAC9B,IAAI,CAACxC,MAAA,IAAUA,MAAA,CAAOX,IAAA,GAAO;MAC3BmC,KAAK,CAACZ,IAAA,CAAK,GAAGgB,UAAA;MACdJ,KAAK,CAACZ,IAAA,CAAK,CAAC4E,eAAe,GAAG;IAChC;EACF;EAEA,IAAIvE,aAAA,IAAiB,CAACvC,uBAAA,CAAwBoB,KAAA,GAAQ;IACpD,MAAM8I,WAAA,GAAc7I,cAAA,CAAe8I,GAAG,CAAC1H,UAAA;IAEvC,IAAI,CAACyH,WAAA,IAAe,CAACvI,QAAA,EAAU;MAC7B,IAAIc,UAAA,CAAW2H,QAAQ,CAAC,eAAe;QACrC;MACF,OAAO;QACL,MAAM,IAAIzC,KAAA,CAAM,8BAA8BlF,UAAA,EAAY;MAC5D;IACF;IAEA,IAAI,CAACK,KAAK,CAACZ,IAAA,CAAK,EAAE;MAChB;MACA;MACA;IACF;IAEA,IAAIkB,aAAA,EAAe;MACjBN,KAAK,CAACZ,IAAA,CAAK,CAACkB,aAAa,GAAGA,aAAA;IAC9B;IAEAb,aAAA,CAAc;MACZ3B,EAAA;MACAK,oBAAA;MACAC,cAAA;MACAC,IAAA,EAAMK,QAAA;MACN0I,WAAA,EAAaA,WAAA;MACb7I,cAAA;MACA6B,UAAA,EAAYJ,KAAK,CAACZ,IAAA,CAAK;MACvBmI,SAAA,EAAWvH,KAAA;MACXpB,SAAA;MACAyB,gBAAA;MACAxB,QAAA;MACAE,SAAA;MACAC,UAAA;MACAE,gBAAA;MACAE,IAAA;MACAgE,WAAA,EAAajD,gBAAA;MACbd,WAAA;MACAmI,kBAAA,EAAoBlI,iBAAA,GAAoBF,IAAA,CAAK;MAC7CG,QAAA;MACAC,eAAA;MACAE,GAAA;MACAC,UAAA;MACAiB,WAAA,EAAavC;IACf;EACF;AACF","ignoreList":[]}
1
+ {"version":3,"file":"addFieldStatePromise.js","names":["ObjectIdImport","getBlockSelect","stripUnselectedFields","validateBlocksFilterOptions","deepCopyObjectSimple","fieldAffectsData","fieldHasSubFields","fieldIsHiddenOrDisabled","fieldIsID","fieldIsLocalized","tabHasName","resolveFilterOptions","isRowCollapsed","iterateFields","ObjectId","default","addFieldStatePromise","args","id","addErrorPathToParent","addErrorPathToParentArg","anyParentLocalized","blockData","clientFieldSchemaMap","collectionSlug","data","field","fieldSchemaMap","filter","forceFullValue","fullData","includeSchema","indexPath","mockRSCs","omitParents","operation","parentPath","parentPermissions","parentSchemaPath","passesCondition","path","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","schemaPath","select","selectMode","skipConditionChecks","skipValidation","state","console","warn","fieldPermissions","fieldState","lastRenderedPath","addedByServer","fieldSchema","type","name","hasPermission","read","access","siblingData","validate","undefined","validationResult","jsonError","JSON","parse","e","event","previousValue","initialValue","err","payload","logger","error","msg","errorPath","errorPaths","includes","push","valid","errorMessage","arrayValue","Array","isArray","arraySelect","promises","rows","reduce","acc","row","rowIndex","rowPath","toHexString","idKey","value","fields","find","localized","parentIndexPath","parentPassesCondition","permissions","previousRow","prevRow","newRow","isLoading","isCollapsed","collapsedPrefs","collapsed","Promise","all","length","disableFormData","blocksValue","filterOptionsValidationResult","filterOptions","blocksFilterOptions","allowedBlockSlugs","rowMetadata","i","blockTypeToMatch","blockType","block","blocks","blockReferences","slug","Error","blockSelect","blockSelectMode","invalidBlockSlugs","t","blockField","fieldKey","blockNameKey","blockName","groupSelect","relationTo","relation","query","user","hasMany","relationshipValue","map","relationship","selectFilterOptions","options","isNamedTab","tabSelect","tabField","childPermissions","shouldContinue","siblingDoc","tabPermissions","pathSegments","split","tabPassesCondition","admin","condition","tabs","tab","fieldConfig","get","endsWith","formState","previousFieldState"],"sources":["../../../src/forms/fieldSchemasToFormState/addFieldStatePromise.ts"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field,\n FieldSchemaMap,\n FieldState,\n FlattenedBlock,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n Row,\n SanitizedFieldPermissions,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n TabAsField,\n Validate,\n} from 'payload'\n\nimport ObjectIdImport from 'bson-objectid'\nimport { getBlockSelect, stripUnselectedFields, validateBlocksFilterOptions } from 'payload'\nimport {\n deepCopyObjectSimple,\n fieldAffectsData,\n fieldHasSubFields,\n fieldIsHiddenOrDisabled,\n fieldIsID,\n fieldIsLocalized,\n tabHasName,\n} from 'payload/shared'\n\nimport type { RenderFieldMethod } from './types.js'\n\nimport { resolveFilterOptions } from '../../utilities/resolveFilterOptions.js'\nimport { isRowCollapsed } from './isRowCollapsed.js'\nimport { iterateFields } from './iterateFields.js'\n\nconst ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectIdImport\n\nexport type AddFieldStatePromiseArgs = {\n addErrorPathToParent: (fieldPath: string) => void\n /**\n * if all parents are localized, then the field is localized\n */\n anyParentLocalized?: boolean\n /**\n * Data of the nearest parent block, or undefined\n */\n blockData: Data | undefined\n clientFieldSchemaMap?: ClientFieldSchemaMap\n collectionSlug?: string\n data: Data\n field: Field | TabAsField\n fieldIndex: number\n fieldSchemaMap: FieldSchemaMap\n /**\n * You can use this to filter down to only `localized` fields that require translation (type: text, textarea, etc.). Another plugin might want to look for only `point` type fields to do some GIS function. With the filter function you can go in like a surgeon.\n */\n filter?: (args: AddFieldStatePromiseArgs) => boolean\n /**\n * Force the value of fields like arrays or blocks to be the full value instead of the length @default false\n */\n forceFullValue?: boolean\n fullData: Data\n id: number | string\n /**\n * Whether the field schema should be included in the state\n */\n includeSchema?: boolean\n indexPath: string\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n /**\n * Whether to omit parent fields in the state. @default false\n */\n omitParents?: boolean\n operation: 'create' | 'update'\n parentIndexPath: string\n parentPath: string\n parentPermissions: SanitizedFieldsPermissions\n parentSchemaPath: string\n passesCondition: boolean\n path: string\n preferences: DocumentPreferences\n previousFormState: FormState\n readOnly?: boolean\n renderAllFields: boolean\n renderFieldFn: RenderFieldMethod\n /**\n * Req is used for validation and defaultValue calculation. If you don't need validation,\n * just create your own req and pass in the locale and the user\n */\n req: PayloadRequest\n schemaPath: string\n select?: SelectType\n selectMode?: SelectMode\n /**\n * Whether to skip checking the field's condition. @default false\n */\n skipConditionChecks?: boolean\n /**\n * Whether to skip validating the field. @default false\n */\n skipValidation?: boolean\n state: FormStateWithoutComponents\n}\n\n/**\n * Flattens the fields schema and fields data.\n * The output is the field path (e.g. array.0.name) mapped to a FormField object.\n */\nexport const addFieldStatePromise = async (args: AddFieldStatePromiseArgs): Promise<void> => {\n const {\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized = false,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n field,\n fieldSchemaMap,\n filter,\n forceFullValue = false,\n fullData,\n includeSchema = false,\n indexPath,\n mockRSCs,\n omitParents = false,\n operation,\n parentPath,\n parentPermissions,\n parentSchemaPath,\n passesCondition,\n path,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n schemaPath,\n select,\n selectMode,\n skipConditionChecks = false,\n skipValidation = false,\n state,\n } = args\n\n if (!args.clientFieldSchemaMap && args.renderFieldFn) {\n // eslint-disable-next-line no-console\n console.warn(\n 'clientFieldSchemaMap is not passed to addFieldStatePromise - this will reduce performance',\n )\n }\n\n let fieldPermissions: SanitizedFieldPermissions = true\n\n const fieldState: FieldState = {}\n\n const lastRenderedPath = previousFormState?.[path]?.lastRenderedPath\n\n // Append only if true to avoid sending '$undefined' through the network\n if (lastRenderedPath) {\n fieldState.lastRenderedPath = lastRenderedPath\n }\n\n // If we're rendering all fields, no need to flag this as added by server\n const addedByServer = !renderAllFields && !previousFormState?.[path]\n\n // Append only if true to avoid sending '$undefined' through the network\n if (addedByServer) {\n fieldState.addedByServer = true\n }\n\n // Append only if true to avoid sending '$undefined' through the network\n if (passesCondition === false) {\n fieldState.passesCondition = false\n }\n\n // Append only if true to avoid sending '$undefined' through the network\n if (includeSchema) {\n fieldState.fieldSchema = field\n }\n\n if (fieldAffectsData(field) && !fieldIsHiddenOrDisabled(field) && field.type !== 'tab') {\n fieldPermissions =\n parentPermissions === true\n ? parentPermissions\n : deepCopyObjectSimple(parentPermissions?.[field.name])\n\n let hasPermission: boolean =\n fieldPermissions === true || deepCopyObjectSimple(fieldPermissions?.read)\n\n if (typeof field?.access?.read === 'function') {\n hasPermission = await field.access.read({\n id,\n blockData,\n data: fullData,\n req,\n siblingData: data,\n })\n } else {\n hasPermission = true\n }\n\n if (!hasPermission) {\n return\n }\n\n const validate: Validate = 'validate' in field ? field.validate : undefined\n\n let validationResult: string | true = true\n\n if (typeof validate === 'function' && !skipValidation && passesCondition) {\n let jsonError\n\n if (field.type === 'json' && typeof data[field.name] === 'string') {\n try {\n JSON.parse(data[field.name])\n } catch (e) {\n jsonError = e\n }\n }\n\n try {\n validationResult = await validate(data?.[field.name], {\n ...field,\n id,\n blockData,\n collectionSlug,\n data: fullData,\n event: 'onChange',\n // @AlessioGr added `jsonError` in https://github.com/payloadcms/payload/commit/c7ea62a39473408c3ea912c4fbf73e11be4b538d\n // @ts-expect-error-next-line\n jsonError,\n operation,\n preferences,\n previousValue: previousFormState?.[path]?.initialValue,\n req,\n siblingData: data,\n })\n } catch (err) {\n validationResult = `Error validating field at path: ${path}`\n\n req.payload.logger.error({\n err,\n msg: validationResult,\n })\n }\n }\n\n /**\n * This function adds the error **path** to the current field and all its parents. If a field is invalid, all its parents are also invalid.\n * It does not add the error **message** to the current field, as that shouldn't apply to all parents.\n * This is done separately below.\n */\n const addErrorPathToParent = (errorPath: string) => {\n if (typeof addErrorPathToParentArg === 'function') {\n addErrorPathToParentArg(errorPath)\n }\n\n if (!fieldState.errorPaths) {\n fieldState.errorPaths = []\n }\n\n if (!fieldState.errorPaths.includes(errorPath)) {\n fieldState.errorPaths.push(errorPath)\n fieldState.valid = false\n }\n }\n\n if (typeof validationResult === 'string') {\n fieldState.errorMessage = validationResult\n fieldState.valid = false\n addErrorPathToParent(path)\n }\n\n switch (field.type) {\n case 'array': {\n const arrayValue = Array.isArray(data[field.name]) ? data[field.name] : []\n\n const arraySelect = select?.[field.name]\n\n const { promises, rows } = arrayValue.reduce(\n (acc, row, rowIndex: number) => {\n const rowPath = path + '.' + rowIndex\n\n row.id = row?.id || new ObjectId().toHexString()\n\n if (!omitParents && (!filter || filter(args))) {\n const idKey = rowPath + '.id'\n\n state[idKey] = {\n initialValue: row.id,\n value: row.id,\n }\n\n if (includeSchema) {\n state[idKey].fieldSchema = field.fields.find((field) => fieldIsID(field))\n }\n }\n\n acc.promises.push(\n iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: row,\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath: rowPath,\n parentSchemaPath: schemaPath,\n permissions:\n fieldPermissions === true ? fieldPermissions : fieldPermissions?.fields || {},\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof arraySelect === 'object' ? arraySelect : undefined,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n }),\n )\n\n if (!acc.rows) {\n acc.rows = []\n }\n\n // First, check if `previousFormState` has a matching row\n const previousRow: Row = (previousFormState?.[path]?.rows || []).find(\n (prevRow) => prevRow.id === row.id,\n )\n\n const newRow: Row = {\n id: row.id,\n isLoading: false,\n }\n\n if (previousRow?.lastRenderedPath) {\n newRow.lastRenderedPath = previousRow.lastRenderedPath\n }\n\n // add addedByServer flag\n if (!previousRow) {\n newRow.addedByServer = true\n }\n\n const isCollapsed = isRowCollapsed({\n collapsedPrefs: preferences?.fields?.[path]?.collapsed,\n field,\n previousRow,\n row,\n })\n\n if (isCollapsed) {\n newRow.collapsed = true\n }\n\n acc.rows.push(newRow)\n\n return acc\n },\n {\n promises: [],\n rows: [],\n },\n )\n\n // Wait for all promises and update fields with the results\n await Promise.all(promises)\n\n if (rows) {\n fieldState.rows = rows\n }\n\n // Add values to field state\n if (data[field.name] !== null) {\n fieldState.value = forceFullValue ? arrayValue : arrayValue.length\n fieldState.initialValue = forceFullValue ? arrayValue : arrayValue.length\n\n if (arrayValue.length > 0) {\n fieldState.disableFormData = true\n }\n }\n\n // Add field to state\n if (!omitParents && (!filter || filter(args))) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'blocks': {\n const blocksValue = Array.isArray(data[field.name]) ? data[field.name] : []\n\n // Handle blocks filterOptions\n let filterOptionsValidationResult: Awaited<\n ReturnType<typeof validateBlocksFilterOptions>\n > | null = null\n if (field.filterOptions) {\n filterOptionsValidationResult = await validateBlocksFilterOptions({\n id,\n data: fullData,\n filterOptions: field.filterOptions,\n req,\n siblingData: data,\n value: data[field.name],\n })\n\n fieldState.blocksFilterOptions = filterOptionsValidationResult.allowedBlockSlugs\n }\n\n const { promises, rowMetadata } = blocksValue.reduce(\n (acc, row, i: number) => {\n const blockTypeToMatch: string = row.blockType\n\n const block =\n req.payload.blocks[blockTypeToMatch] ??\n ((field.blockReferences ?? field.blocks).find(\n (blockType) => typeof blockType !== 'string' && blockType.slug === blockTypeToMatch,\n ) as FlattenedBlock | undefined)\n\n if (!block) {\n throw new Error(\n `Block with type \"${row.blockType}\" was found in block data, but no block with that type is defined in the config for field with schema path ${schemaPath}.`,\n )\n }\n\n const { blockSelect, blockSelectMode } = getBlockSelect({\n block,\n select: select?.[field.name],\n selectMode,\n })\n\n const rowPath = path + '.' + i\n\n if (block) {\n row.id = row?.id || new ObjectId().toHexString()\n\n if (!omitParents && (!filter || filter(args))) {\n // Handle block `id` field\n const idKey = rowPath + '.id'\n\n state[idKey] = {\n initialValue: row.id,\n value: row.id,\n }\n\n // If the blocks field fails filterOptions validation, add error paths to the individual blocks that are no longer allowed\n if (\n filterOptionsValidationResult?.invalidBlockSlugs?.length &&\n filterOptionsValidationResult.invalidBlockSlugs.includes(row.blockType)\n ) {\n state[idKey].errorMessage = req.t('validation:invalidBlock', {\n block: row.blockType,\n })\n state[idKey].valid = false\n addErrorPathToParent(idKey)\n\n // If the error is due to block filterOptions, we want the blocks field (fieldState) to include all the filterOptions-related\n // error paths for each sub-block, not for the validation result of the block itself. Otherwise, say there are 2 invalid blocks,\n // the blocks field will have 3 instead of 2 error paths - one for itself, and one for each invalid block.\n // Instead, we want only the 2 error paths for the individual, invalid blocks.\n fieldState.errorPaths = fieldState.errorPaths.filter(\n (errorPath) => errorPath !== path,\n )\n }\n\n if (includeSchema) {\n state[idKey].fieldSchema = includeSchema\n ? block.fields.find((blockField) => fieldIsID(blockField))\n : undefined\n }\n\n // Handle `blockType` field\n const fieldKey = rowPath + '.blockType'\n\n state[fieldKey] = {\n initialValue: row.blockType,\n value: row.blockType,\n }\n\n if (addedByServer) {\n state[fieldKey].addedByServer = addedByServer\n }\n\n if (includeSchema) {\n state[fieldKey].fieldSchema = block.fields.find(\n (blockField) => 'name' in blockField && blockField.name === 'blockType',\n )\n }\n\n // Handle `blockName` field\n const blockNameKey = rowPath + '.blockName'\n\n state[blockNameKey] = {}\n\n if (row.blockName) {\n state[blockNameKey].initialValue = row.blockName\n state[blockNameKey].value = row.blockName\n }\n\n if (includeSchema) {\n state[blockNameKey].fieldSchema = block.fields.find(\n (blockField) => 'name' in blockField && blockField.name === 'blockName',\n )\n }\n }\n\n acc.promises.push(\n iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData: row,\n clientFieldSchemaMap,\n collectionSlug,\n data: row,\n fields: block.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath: rowPath,\n parentSchemaPath: schemaPath + '.' + block.slug,\n permissions:\n fieldPermissions === true\n ? fieldPermissions\n : parentPermissions?.[field.name]?.blocks?.[block.slug] === true\n ? true\n : parentPermissions?.[field.name]?.blocks?.[block.slug]?.fields || {},\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof blockSelect === 'object' ? blockSelect : undefined,\n selectMode: blockSelectMode,\n skipConditionChecks,\n skipValidation,\n state,\n }),\n )\n\n // First, check if `previousFormState` has a matching row\n const previousRow: Row = (previousFormState?.[path]?.rows || []).find(\n (prevRow) => prevRow.id === row.id,\n )\n\n const newRow: Row = {\n id: row.id,\n blockType: row.blockType,\n isLoading: false,\n }\n\n if (previousRow?.lastRenderedPath) {\n newRow.lastRenderedPath = previousRow.lastRenderedPath\n }\n\n acc.rowMetadata.push(newRow)\n\n const isCollapsed = isRowCollapsed({\n collapsedPrefs: preferences?.fields?.[path]?.collapsed,\n field,\n previousRow,\n row,\n })\n\n if (isCollapsed) {\n acc.rowMetadata[acc.rowMetadata.length - 1].collapsed = true\n }\n }\n\n return acc\n },\n {\n promises: [],\n rowMetadata: [],\n },\n )\n\n await Promise.all(promises)\n\n // Add values to field state\n if (data[field.name] === null) {\n fieldState.value = null\n fieldState.initialValue = null\n } else {\n fieldState.value = forceFullValue ? blocksValue : blocksValue.length\n fieldState.initialValue = forceFullValue ? blocksValue : blocksValue.length\n\n if (blocksValue.length > 0) {\n fieldState.disableFormData = true\n }\n }\n\n fieldState.rows = rowMetadata\n\n // Add field to state\n if (!omitParents && (!filter || filter(args))) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'group': {\n if (!filter || filter(args)) {\n fieldState.disableFormData = true\n state[path] = fieldState\n }\n\n const groupSelect = select?.[field.name]\n\n await iterateFields({\n id,\n addErrorPathToParent,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: data?.[field.name] || {},\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: '',\n parentPassesCondition: passesCondition,\n parentPath: path,\n parentSchemaPath: schemaPath,\n permissions:\n typeof fieldPermissions === 'boolean' ? fieldPermissions : fieldPermissions?.fields,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: typeof groupSelect === 'object' ? groupSelect : undefined,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n })\n\n break\n }\n\n case 'relationship':\n case 'upload': {\n if (field.filterOptions) {\n if (typeof field.filterOptions === 'object') {\n if (typeof field.relationTo === 'string') {\n fieldState.filterOptions = {\n [field.relationTo]: field.filterOptions,\n }\n } else {\n fieldState.filterOptions = field.relationTo.reduce((acc, relation) => {\n acc[relation] = field.filterOptions\n return acc\n }, {})\n }\n }\n\n if (typeof field.filterOptions === 'function') {\n const query = await resolveFilterOptions(field.filterOptions, {\n id,\n blockData,\n data: fullData,\n relationTo: field.relationTo,\n req,\n siblingData: data,\n user: req.user,\n })\n\n fieldState.filterOptions = query\n }\n }\n\n if (field.hasMany) {\n const relationshipValue = Array.isArray(data[field.name])\n ? data[field.name].map((relationship) => {\n if (Array.isArray(field.relationTo)) {\n return {\n relationTo: relationship.relationTo,\n value:\n relationship.value && typeof relationship.value === 'object'\n ? relationship.value?.id\n : relationship.value,\n }\n }\n if (typeof relationship === 'object' && relationship !== null) {\n return relationship.id\n }\n return relationship\n })\n : undefined\n\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n } else if (Array.isArray(field.relationTo)) {\n if (\n data[field.name] &&\n typeof data[field.name] === 'object' &&\n 'relationTo' in data[field.name] &&\n 'value' in data[field.name]\n ) {\n const value =\n typeof data[field.name]?.value === 'object' &&\n data[field.name]?.value &&\n 'id' in data[field.name].value\n ? data[field.name].value.id\n : data[field.name].value\n const relationshipValue = {\n relationTo: data[field.name]?.relationTo,\n value,\n }\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n }\n } else {\n const relationshipValue =\n data[field.name] && typeof data[field.name] === 'object' && 'id' in data[field.name]\n ? data[field.name].id\n : data[field.name]\n fieldState.value = relationshipValue\n fieldState.initialValue = relationshipValue\n }\n\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n\n case 'select': {\n if (typeof field.filterOptions === 'function') {\n fieldState.selectFilterOptions = field.filterOptions({\n data: fullData,\n options: field.options,\n req,\n siblingData: data,\n })\n }\n\n if (data[field.name] !== undefined) {\n fieldState.value = data[field.name]\n fieldState.initialValue = data[field.name]\n }\n\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n\n default: {\n if (data[field.name] !== undefined) {\n fieldState.value = data[field.name]\n fieldState.initialValue = data[field.name]\n }\n\n // Add field to state\n if (!filter || filter(args)) {\n state[path] = fieldState\n }\n\n break\n }\n }\n } else if (fieldHasSubFields(field) && !fieldAffectsData(field)) {\n // Handle field types that do not use names (row, collapsible, unnamed group etc)\n\n if (!filter || filter(args)) {\n state[path] = {\n disableFormData: true,\n }\n\n if (passesCondition === false) {\n state[path].passesCondition = false\n }\n }\n\n await iterateFields({\n id,\n mockRSCs,\n select,\n selectMode,\n // passthrough parent functionality\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized: fieldIsLocalized(field) || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n omitParents,\n operation,\n parentIndexPath: indexPath,\n parentPassesCondition: passesCondition,\n parentPath: path,\n parentSchemaPath: schemaPath,\n permissions: parentPermissions, // TODO: Verify this is correct\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n skipConditionChecks,\n skipValidation,\n state,\n })\n } else if (field.type === 'tab') {\n const isNamedTab = tabHasName(field)\n let tabSelect: SelectType | undefined\n\n const tabField: TabAsField = {\n ...field,\n type: 'tab',\n }\n\n let childPermissions: SanitizedFieldsPermissions = undefined\n\n if (isNamedTab) {\n const shouldContinue = stripUnselectedFields({\n field: tabField,\n select,\n selectMode,\n siblingDoc: data?.[field.name] || {},\n })\n\n if (!shouldContinue) {\n return\n }\n\n if (parentPermissions === true) {\n childPermissions = true\n } else {\n const tabPermissions = parentPermissions?.[field.name]\n if (tabPermissions === true) {\n childPermissions = true\n } else {\n childPermissions = tabPermissions?.fields\n }\n }\n\n if (typeof select?.[field.name] === 'object') {\n tabSelect = select?.[field.name] as SelectType\n }\n } else {\n childPermissions = parentPermissions\n tabSelect = select\n }\n\n const pathSegments = path ? path.split('.') : []\n\n // If passesCondition is false then this should always result to false\n // If the tab has no admin.condition provided then fallback to passesCondition and let that decide the result\n let tabPassesCondition = passesCondition\n\n if (passesCondition && typeof field.admin?.condition === 'function') {\n tabPassesCondition = field.admin.condition(fullData, data, {\n blockData,\n operation,\n path: pathSegments,\n user: req.user,\n })\n }\n\n if (field?.id) {\n state[field.id] = {\n passesCondition: tabPassesCondition,\n }\n }\n\n return iterateFields({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized: field.localized || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: isNamedTab ? data?.[field.name] || {} : data,\n fields: field.fields,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath: indexPath,\n parentPassesCondition: tabPassesCondition,\n parentPath: path,\n parentSchemaPath: schemaPath,\n permissions: childPermissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select: tabSelect,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n })\n } else if (field.type === 'tabs') {\n return iterateFields({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized: fieldIsLocalized(field) || anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n fields: field.tabs.map((tab) => ({ ...tab, type: 'tab' })),\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n omitParents,\n operation,\n parentIndexPath: indexPath,\n parentPassesCondition: passesCondition,\n parentPath: path,\n parentSchemaPath: schemaPath,\n permissions: parentPermissions,\n preferences,\n previousFormState,\n renderAllFields,\n renderFieldFn,\n req,\n select,\n selectMode,\n skipConditionChecks,\n skipValidation,\n state,\n })\n } else if (field.type === 'ui') {\n if (!filter || filter(args)) {\n state[path] = fieldState\n state[path].disableFormData = true\n }\n }\n\n if (renderFieldFn && !fieldIsHiddenOrDisabled(field)) {\n const fieldConfig = fieldSchemaMap.get(schemaPath)\n\n if (!fieldConfig && !mockRSCs) {\n if (schemaPath.endsWith('.blockType')) {\n return\n } else {\n throw new Error(`Field config not found for ${schemaPath}`)\n }\n }\n\n if (!state[path]) {\n // Some fields (ie `Tab`) do not live in form state\n // therefore we cannot attach customComponents to them\n return\n }\n\n if (addedByServer) {\n state[path].addedByServer = addedByServer\n }\n\n renderFieldFn({\n id,\n clientFieldSchemaMap,\n collectionSlug,\n data: fullData,\n fieldConfig: fieldConfig as Field,\n fieldSchemaMap,\n fieldState: state[path],\n formState: state,\n indexPath,\n lastRenderedPath,\n mockRSCs,\n operation,\n parentPath,\n parentSchemaPath,\n path,\n permissions: fieldPermissions,\n preferences,\n previousFieldState: previousFormState?.[path],\n readOnly,\n renderAllFields,\n req,\n schemaPath,\n siblingData: data,\n })\n }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -1,4 +1,4 @@
1
- import type { BuildFormStateArgs, ClientFieldSchemaMap, Data, DocumentPreferences, Field as FieldSchema, FieldSchemaMap, FormState, FormStateWithoutComponents, PayloadRequest, SanitizedFieldsPermissions, SelectMode, SelectType } from 'payload';
1
+ import type { BuildFormStateArgs, ClientFieldSchemaMap, Data, DocumentPreferences, Field, FieldSchemaMap, FormState, FormStateWithoutComponents, PayloadRequest, SanitizedFieldsPermissions, SelectMode, SelectType, TabAsField } from 'payload';
2
2
  import type { AddFieldStatePromiseArgs } from './addFieldStatePromise.js';
3
3
  import type { RenderFieldMethod } from './types.js';
4
4
  type Args = {
@@ -14,7 +14,7 @@ type Args = {
14
14
  clientFieldSchemaMap?: ClientFieldSchemaMap;
15
15
  collectionSlug?: string;
16
16
  data: Data;
17
- fields: FieldSchema[];
17
+ fields: (Field | TabAsField)[];
18
18
  fieldSchemaMap: FieldSchemaMap;
19
19
  filter?: (args: AddFieldStatePromiseArgs) => boolean;
20
20
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"iterateFields.d.ts","sourceRoot":"","sources":["../../../src/forms/fieldSchemasToFormState/iterateFields.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,IAAI,EACJ,mBAAmB,EACnB,KAAK,IAAI,WAAW,EACpB,cAAc,EACd,SAAS,EACT,0BAA0B,EAC1B,cAAc,EACd,0BAA0B,EAC1B,UAAU,EACV,UAAU,EACX,MAAM,SAAS,CAAA;AAKhB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AACzE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAInD,KAAK,IAAI,GAAG;IACV,oBAAoB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IACjD;;OAEG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B;;OAEG;IACH,SAAS,EAAE,IAAI,GAAG,SAAS,CAAA;IAC3B,oBAAoB,CAAC,EAAE,oBAAoB,CAAA;IAC3C,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,EAAE,WAAW,EAAE,CAAA;IACrB,cAAc,EAAE,cAAc,CAAA;IAC9B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,wBAAwB,KAAK,OAAO,CAAA;IACpD;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,EAAE,IAAI,CAAA;IACd,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACpB;;OAEG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,EAAE,kBAAkB,CAAC,UAAU,CAAC,CAAA;IACzC;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB;;OAEG;IACH,SAAS,EAAE,QAAQ,GAAG,QAAQ,CAAA;IAC9B,eAAe,EAAE,MAAM,CAAA;IACvB,qBAAqB,CAAC,EAAE,OAAO,CAAA;IAC/B,UAAU,EAAE,MAAM,CAAA;IAClB,gBAAgB,EAAE,MAAM,CAAA;IACxB,WAAW,EAAE,0BAA0B,CAAA;IACvC,WAAW,CAAC,EAAE,mBAAmB,CAAA;IACjC,iBAAiB,EAAE,SAAS,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,eAAe,EAAE,OAAO,CAAA;IACxB,aAAa,EAAE,iBAAiB,CAAA;IAChC,GAAG,EAAE,cAAc,CAAA;IACnB,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,KAAK,CAAC,EAAE,0BAA0B,CAAA;CACnC,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,aAAa,keAiCvB,IAAI,KAAG,OAAO,CAAC,IAAI,CAgGrB,CAAA"}
1
+ {"version":3,"file":"iterateFields.d.ts","sourceRoot":"","sources":["../../../src/forms/fieldSchemasToFormState/iterateFields.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EAClB,oBAAoB,EACpB,IAAI,EACJ,mBAAmB,EACnB,KAAK,EACL,cAAc,EACd,SAAS,EACT,0BAA0B,EAC1B,cAAc,EACd,0BAA0B,EAC1B,UAAU,EACV,UAAU,EACV,UAAU,EACX,MAAM,SAAS,CAAA;AAKhB,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,2BAA2B,CAAA;AACzE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAInD,KAAK,IAAI,GAAG;IACV,oBAAoB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAA;IACjD;;OAEG;IACH,kBAAkB,CAAC,EAAE,OAAO,CAAA;IAC5B;;OAEG;IACH,SAAS,EAAE,IAAI,GAAG,SAAS,CAAA;IAC3B,oBAAoB,CAAC,EAAE,oBAAoB,CAAA;IAC3C,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,EAAE,CAAC,KAAK,GAAG,UAAU,CAAC,EAAE,CAAA;IAC9B,cAAc,EAAE,cAAc,CAAA;IAC9B,MAAM,CAAC,EAAE,CAAC,IAAI,EAAE,wBAAwB,KAAK,OAAO,CAAA;IACpD;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,QAAQ,EAAE,IAAI,CAAA;IACd,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACpB;;OAEG;IACH,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,QAAQ,CAAC,EAAE,kBAAkB,CAAC,UAAU,CAAC,CAAA;IACzC;;OAEG;IACH,WAAW,CAAC,EAAE,OAAO,CAAA;IACrB;;OAEG;IACH,SAAS,EAAE,QAAQ,GAAG,QAAQ,CAAA;IAC9B,eAAe,EAAE,MAAM,CAAA;IACvB,qBAAqB,CAAC,EAAE,OAAO,CAAA;IAC/B,UAAU,EAAE,MAAM,CAAA;IAClB,gBAAgB,EAAE,MAAM,CAAA;IACxB,WAAW,EAAE,0BAA0B,CAAA;IACvC,WAAW,CAAC,EAAE,mBAAmB,CAAA;IACjC,iBAAiB,EAAE,SAAS,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,eAAe,EAAE,OAAO,CAAA;IACxB,aAAa,EAAE,iBAAiB,CAAA;IAChC,GAAG,EAAE,cAAc,CAAA;IACnB,MAAM,CAAC,EAAE,UAAU,CAAA;IACnB,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B;;OAEG;IACH,cAAc,CAAC,EAAE,OAAO,CAAA;IACxB,KAAK,CAAC,EAAE,0BAA0B,CAAA;CACnC,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,aAAa,keAiCvB,IAAI,KAAG,OAAO,CAAC,IAAI,CAgGrB,CAAA"}
@@ -48,7 +48,7 @@ export const iterateFields = async ({
48
48
  } = getFieldPaths({
49
49
  field,
50
50
  index: fieldIndex,
51
- parentIndexPath: 'name' in field ? '' : parentIndexPath,
51
+ parentIndexPath,
52
52
  parentPath,
53
53
  parentSchemaPath
54
54
  });