@payloadcms/ui 3.68.0-internal-debug.2eb12b9 → 3.68.0-internal-debug.185cc5f

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 (253) hide show
  1. package/dist/elements/AnimateHeight/usePatchAnimateHeight.js +2 -2
  2. package/dist/elements/AnimateHeight/usePatchAnimateHeight.js.map +1 -1
  3. package/dist/elements/Autosave/index.js +1 -0
  4. package/dist/elements/Autosave/index.js.map +1 -1
  5. package/dist/elements/BulkUpload/EditMany/index.js +2 -2
  6. package/dist/elements/BulkUpload/EditMany/index.js.map +1 -1
  7. package/dist/elements/BulkUpload/FormsManager/index.js +8 -8
  8. package/dist/elements/BulkUpload/FormsManager/index.js.map +1 -1
  9. package/dist/elements/BulkUpload/index.js +12 -1
  10. package/dist/elements/BulkUpload/index.js.map +1 -1
  11. package/dist/elements/Button/index.js +2 -2
  12. package/dist/elements/Button/index.js.map +1 -1
  13. package/dist/elements/Button/types.js +13 -1
  14. package/dist/elements/Button/types.js.map +1 -1
  15. package/dist/elements/Card/index.js +5 -1
  16. package/dist/elements/Card/index.js.map +1 -1
  17. package/dist/elements/CodeEditor/CodeEditor.js +2 -2
  18. package/dist/elements/CodeEditor/CodeEditor.js.map +1 -1
  19. package/dist/elements/CodeEditor/types.js +3 -1
  20. package/dist/elements/CodeEditor/types.js.map +1 -1
  21. package/dist/elements/Collapsible/index.js +8 -1
  22. package/dist/elements/Collapsible/index.js.map +1 -1
  23. package/dist/elements/Combobox/index.js +6 -0
  24. package/dist/elements/Combobox/index.js.map +1 -1
  25. package/dist/elements/DatePicker/DatePicker.js +1 -0
  26. package/dist/elements/DatePicker/DatePicker.js.map +1 -1
  27. package/dist/elements/DatePicker/getFormattedLocale.js +1 -0
  28. package/dist/elements/DatePicker/getFormattedLocale.js.map +1 -1
  29. package/dist/elements/DeleteMany/index.js +25 -1
  30. package/dist/elements/DeleteMany/index.js.map +1 -1
  31. package/dist/elements/DocumentControls/index.js +1 -1
  32. package/dist/elements/DocumentControls/index.js.map +1 -1
  33. package/dist/elements/DocumentDrawer/Provider.js +5 -1
  34. package/dist/elements/DocumentDrawer/Provider.js.map +1 -1
  35. package/dist/elements/DocumentDrawer/types.js +11 -1
  36. package/dist/elements/DocumentDrawer/types.js.map +1 -1
  37. package/dist/elements/DraggableSortable/useDraggableSortable/index.js +1 -0
  38. package/dist/elements/DraggableSortable/useDraggableSortable/index.js.map +1 -1
  39. package/dist/elements/Drawer/index.js +3 -1
  40. package/dist/elements/Drawer/index.js.map +1 -1
  41. package/dist/elements/EditMany/DrawerContent.js +15 -1
  42. package/dist/elements/EditMany/DrawerContent.js.map +1 -1
  43. package/dist/elements/EditMany/index.js +3 -1
  44. package/dist/elements/EditMany/index.js.map +1 -1
  45. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +8 -1
  46. package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +1 -1
  47. package/dist/elements/FolderView/FolderFileCard/index.js +1 -0
  48. package/dist/elements/FolderView/FolderFileCard/index.js.map +1 -1
  49. package/dist/elements/FolderView/MoveDocToFolder/index.js +2 -3
  50. package/dist/elements/FolderView/MoveDocToFolder/index.js.map +1 -1
  51. package/dist/elements/HTMLDiff/diff/index.js +24 -3
  52. package/dist/elements/HTMLDiff/diff/index.js.map +1 -1
  53. package/dist/elements/HydrateAuthProvider/index.js +6 -1
  54. package/dist/elements/HydrateAuthProvider/index.js.map +1 -1
  55. package/dist/elements/LeaveWithoutSaving/usePreventLeave.js +3 -1
  56. package/dist/elements/LeaveWithoutSaving/usePreventLeave.js.map +1 -1
  57. package/dist/elements/Link/index.js +5 -1
  58. package/dist/elements/Link/index.js.map +1 -1
  59. package/dist/elements/ListControls/types.js +7 -1
  60. package/dist/elements/ListControls/types.js.map +1 -1
  61. package/dist/elements/ListDrawer/DrawerContent.js +2 -2
  62. package/dist/elements/ListDrawer/DrawerContent.js.map +1 -1
  63. package/dist/elements/ListDrawer/Provider.js +8 -1
  64. package/dist/elements/ListDrawer/Provider.js.map +1 -1
  65. package/dist/elements/ListDrawer/index.js +2 -1
  66. package/dist/elements/ListDrawer/index.js.map +1 -1
  67. package/dist/elements/ListDrawer/types.js +5 -1
  68. package/dist/elements/ListDrawer/types.js.map +1 -1
  69. package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js +5 -1
  70. package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js.map +1 -1
  71. package/dist/elements/ListSelection/index.js +11 -1
  72. package/dist/elements/ListSelection/index.js.map +1 -1
  73. package/dist/elements/LivePreview/Toolbar/Controls/index.js +1 -1
  74. package/dist/elements/LivePreview/Toolbar/Controls/index.js.map +1 -1
  75. package/dist/elements/Logout/index.js +5 -1
  76. package/dist/elements/Logout/index.js.map +1 -1
  77. package/dist/elements/Pill/index.js +5 -2
  78. package/dist/elements/Pill/index.js.map +1 -1
  79. package/dist/elements/PublishMany/index.js +3 -1
  80. package/dist/elements/PublishMany/index.js.map +1 -1
  81. package/dist/elements/QueryPresets/QueryPresetBar/index.js +1 -2
  82. package/dist/elements/QueryPresets/QueryPresetBar/index.js.map +1 -1
  83. package/dist/elements/ReactSelect/index.js +2 -2
  84. package/dist/elements/ReactSelect/index.js.map +1 -1
  85. package/dist/elements/ReactSelect/types.js +8 -1
  86. package/dist/elements/ReactSelect/types.js.map +1 -1
  87. package/dist/elements/RelationshipTable/index.js +2 -2
  88. package/dist/elements/RelationshipTable/index.js.map +1 -1
  89. package/dist/elements/RestoreMany/index.js +1 -0
  90. package/dist/elements/RestoreMany/index.js.map +1 -1
  91. package/dist/elements/SaveButton/index.js +1 -2
  92. package/dist/elements/SaveButton/index.js.map +1 -1
  93. package/dist/elements/SaveDraftButton/index.js +1 -2
  94. package/dist/elements/SaveDraftButton/index.js.map +1 -1
  95. package/dist/elements/SearchFilter/types.js +19 -1
  96. package/dist/elements/SearchFilter/types.js.map +1 -1
  97. package/dist/elements/Status/index.js +2 -2
  98. package/dist/elements/Status/index.js.map +1 -1
  99. package/dist/elements/StepNav/index.js +5 -1
  100. package/dist/elements/StepNav/index.js.map +1 -1
  101. package/dist/elements/Table/DefaultCell/fields/Select/index.js +4 -4
  102. package/dist/elements/Table/DefaultCell/fields/Select/index.js.map +1 -1
  103. package/dist/elements/Table/DefaultCell/index.js +2 -1
  104. package/dist/elements/Table/DefaultCell/index.js.map +1 -1
  105. package/dist/elements/Table/RelationshipProvider/index.js +3 -0
  106. package/dist/elements/Table/RelationshipProvider/index.js.map +1 -1
  107. package/dist/elements/Thumbnail/createThumbnail.js +12 -12
  108. package/dist/elements/Thumbnail/createThumbnail.js.map +1 -1
  109. package/dist/elements/Tooltip/index.js +3 -1
  110. package/dist/elements/Tooltip/index.js.map +1 -1
  111. package/dist/elements/UnpublishMany/index.js +3 -1
  112. package/dist/elements/UnpublishMany/index.js.map +1 -1
  113. package/dist/elements/Upload/index.js +8 -8
  114. package/dist/elements/Upload/index.js.map +1 -1
  115. package/dist/elements/WhereBuilder/Condition/Number/index.js +1 -0
  116. package/dist/elements/WhereBuilder/Condition/Number/index.js.map +1 -1
  117. package/dist/elements/WhereBuilder/Condition/Relationship/index.js +5 -6
  118. package/dist/elements/WhereBuilder/Condition/Relationship/index.js.map +1 -1
  119. package/dist/elements/WhereBuilder/Condition/Text/index.js +1 -0
  120. package/dist/elements/WhereBuilder/Condition/Text/index.js.map +1 -1
  121. package/dist/elements/WhereBuilder/index.js +2 -2
  122. package/dist/elements/WhereBuilder/index.js.map +1 -1
  123. package/dist/exports/client/index.js +26 -2
  124. package/dist/exports/client/index.js.map +1 -1
  125. package/dist/exports/shared/index.js +2 -1
  126. package/dist/exports/shared/index.js.map +1 -1
  127. package/dist/fields/Blocks/BlockSelector/index.js +3 -1
  128. package/dist/fields/Blocks/BlockSelector/index.js.map +1 -1
  129. package/dist/fields/Email/index.js +1 -1
  130. package/dist/fields/Email/index.js.map +1 -1
  131. package/dist/fields/Group/index.js +1 -1
  132. package/dist/fields/Group/index.js.map +1 -1
  133. package/dist/fields/Number/index.js +5 -3
  134. package/dist/fields/Number/index.js.map +1 -1
  135. package/dist/fields/Password/types.js +11 -1
  136. package/dist/fields/Password/types.js.map +1 -1
  137. package/dist/fields/Point/index.js +2 -2
  138. package/dist/fields/Point/index.js.map +1 -1
  139. package/dist/fields/Relationship/select-components/MultiValueLabel/index.js +4 -1
  140. package/dist/fields/Relationship/select-components/MultiValueLabel/index.js.map +1 -1
  141. package/dist/fields/Relationship/select-components/SingleValue/index.js +4 -1
  142. package/dist/fields/Relationship/select-components/SingleValue/index.js.map +1 -1
  143. package/dist/fields/Text/index.js +3 -2
  144. package/dist/fields/Text/index.js.map +1 -1
  145. package/dist/fields/Upload/Input.js +3 -1
  146. package/dist/fields/Upload/Input.js.map +1 -1
  147. package/dist/fields/Upload/types.js +1 -0
  148. package/dist/fields/Upload/types.js.map +1 -1
  149. package/dist/fields/shared/index.js +2 -3
  150. package/dist/fields/shared/index.js.map +1 -1
  151. package/dist/forms/Form/fieldReducer.js +2 -1
  152. package/dist/forms/Form/fieldReducer.js.map +1 -1
  153. package/dist/forms/Form/index.js +12 -9
  154. package/dist/forms/Form/index.js.map +1 -1
  155. package/dist/forms/Form/mergeServerFormState.js +11 -3
  156. package/dist/forms/Form/mergeServerFormState.js.map +1 -1
  157. package/dist/forms/Form/reduceToSerializableFields.js +2 -2
  158. package/dist/forms/Form/reduceToSerializableFields.js.map +1 -1
  159. package/dist/forms/Form/types.js +52 -1
  160. package/dist/forms/Form/types.js.map +1 -1
  161. package/dist/forms/NullifyField/index.js +2 -1
  162. package/dist/forms/NullifyField/index.js.map +1 -1
  163. package/dist/forms/WatchChildErrors/index.js +6 -1
  164. package/dist/forms/WatchChildErrors/index.js.map +1 -1
  165. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js +20 -0
  166. package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js.map +1 -1
  167. package/dist/forms/fieldSchemasToFormState/index.js +33 -1
  168. package/dist/forms/fieldSchemasToFormState/index.js.map +1 -1
  169. package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js +2 -2
  170. package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js.map +1 -1
  171. package/dist/forms/fieldSchemasToFormState/iterateFields.js +16 -0
  172. package/dist/forms/fieldSchemasToFormState/iterateFields.js.map +1 -1
  173. package/dist/forms/fieldSchemasToFormState/renderField.js +2 -2
  174. package/dist/forms/fieldSchemasToFormState/renderField.js.map +1 -1
  175. package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js +22 -1
  176. package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js.map +1 -1
  177. package/dist/forms/fieldSchemasToFormState/types.js +5 -1
  178. package/dist/forms/fieldSchemasToFormState/types.js.map +1 -1
  179. package/dist/forms/useField/index.js +1 -0
  180. package/dist/forms/useField/index.js.map +1 -1
  181. package/dist/forms/useField/types.js +19 -1
  182. package/dist/forms/useField/types.js.map +1 -1
  183. package/dist/hooks/useControllableState.js +9 -1
  184. package/dist/hooks/useControllableState.js.map +1 -1
  185. package/dist/hooks/useDelayedRender.js +3 -1
  186. package/dist/hooks/useDelayedRender.js.map +1 -1
  187. package/dist/hooks/useHotkey.js +2 -2
  188. package/dist/hooks/useHotkey.js.map +1 -1
  189. package/dist/hooks/usePayloadAPI.js +3 -4
  190. package/dist/hooks/usePayloadAPI.js.map +1 -1
  191. package/dist/hooks/usePopupWindow.js +2 -2
  192. package/dist/hooks/usePopupWindow.js.map +1 -1
  193. package/dist/hooks/useQueue.js +15 -7
  194. package/dist/hooks/useQueue.js.map +1 -1
  195. package/dist/hooks/useResize.js +4 -3
  196. package/dist/hooks/useResize.js.map +1 -1
  197. package/dist/providers/Auth/index.js +35 -3
  198. package/dist/providers/Auth/index.js.map +1 -1
  199. package/dist/providers/Config/index.js +10 -1
  200. package/dist/providers/Config/index.js.map +1 -1
  201. package/dist/providers/DocumentInfo/index.js +6 -7
  202. package/dist/providers/DocumentInfo/index.js.map +1 -1
  203. package/dist/providers/DocumentInfo/types.js +25 -1
  204. package/dist/providers/DocumentInfo/types.js.map +1 -1
  205. package/dist/providers/Folders/index.js +44 -2
  206. package/dist/providers/Folders/index.js.map +1 -1
  207. package/dist/providers/ListQuery/types.js +5 -1
  208. package/dist/providers/ListQuery/types.js.map +1 -1
  209. package/dist/providers/LivePreview/context.js +11 -1
  210. package/dist/providers/LivePreview/context.js.map +1 -1
  211. package/dist/providers/LivePreview/index.js +7 -4
  212. package/dist/providers/LivePreview/index.js.map +1 -1
  213. package/dist/providers/Preferences/index.js +7 -2
  214. package/dist/providers/Preferences/index.js.map +1 -1
  215. package/dist/providers/RouteTransition/index.js +9 -9
  216. package/dist/providers/RouteTransition/index.js.map +1 -1
  217. package/dist/providers/Selection/index.js +7 -2
  218. package/dist/providers/Selection/index.js.map +1 -1
  219. package/dist/providers/ServerFunctions/index.js +25 -22
  220. package/dist/providers/ServerFunctions/index.js.map +1 -1
  221. package/dist/providers/TableColumns/buildColumnState/index.js +10 -9
  222. package/dist/providers/TableColumns/buildColumnState/index.js.map +1 -1
  223. package/dist/providers/TableColumns/buildColumnState/renderCell.js +4 -3
  224. package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
  225. package/dist/providers/TableColumns/types.js +17 -1
  226. package/dist/providers/TableColumns/types.js.map +1 -1
  227. package/dist/utilities/abortAndIgnore.js +4 -6
  228. package/dist/utilities/abortAndIgnore.js.map +1 -1
  229. package/dist/utilities/buildFieldSchemaMap/traverseFields.js +2 -2
  230. package/dist/utilities/buildFieldSchemaMap/traverseFields.js.map +1 -1
  231. package/dist/utilities/copyDataFromLocale.js +6 -2
  232. package/dist/utilities/copyDataFromLocale.js.map +1 -1
  233. package/dist/utilities/getDisplayedFieldValue.js +8 -8
  234. package/dist/utilities/getDisplayedFieldValue.js.map +1 -1
  235. package/dist/utilities/getFolderResultsComponentAndData.js +2 -1
  236. package/dist/utilities/getFolderResultsComponentAndData.js.map +1 -1
  237. package/dist/utilities/handleFormStateLocking.js +2 -2
  238. package/dist/utilities/handleFormStateLocking.js.map +1 -1
  239. package/dist/utilities/hasSavePermission.js +5 -1
  240. package/dist/utilities/hasSavePermission.js.map +1 -1
  241. package/dist/utilities/isURLAllowed.js +6 -6
  242. package/dist/utilities/isURLAllowed.js.map +1 -1
  243. package/dist/utilities/renderTable.js +2 -1
  244. package/dist/utilities/renderTable.js.map +1 -1
  245. package/dist/utilities/schedulePublishHandler.js +3 -1
  246. package/dist/utilities/schedulePublishHandler.js.map +1 -1
  247. package/dist/utilities/upsertPreferences.js +1 -0
  248. package/dist/utilities/upsertPreferences.js.map +1 -1
  249. package/dist/views/Edit/index.js +7 -7
  250. package/dist/views/Edit/index.js.map +1 -1
  251. package/dist/views/List/ListHeader/index.js +6 -1
  252. package/dist/views/List/ListHeader/index.js.map +1 -1
  253. package/package.json +6 -5
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/Form/types.ts"],"sourcesContent":["import type {\n ClientField,\n Data,\n FormField,\n FormState,\n Row,\n TypedUser,\n ValidationFieldError,\n} from 'payload'\nimport type React from 'react'\nimport type { Dispatch } from 'react'\n\nimport type { AcceptValues } from './mergeServerFormState.js'\n\nexport type Preferences = {\n [key: string]: unknown\n}\n\nexport type FormOnSuccess<T = unknown, C = Record<string, unknown>> = (\n json: T,\n ctx?: {\n /**\n * Arbitrary context passed to the onSuccess callback.\n */\n context?: C\n /**\n * The form state that was sent with the request when retrieving the `json` arg.\n */\n formState?: FormState\n },\n) => Promise<FormState | void> | void\n\nexport type FormProps = {\n beforeSubmit?: ((args: { formState: FormState }) => Promise<FormState>)[]\n children?: React.ReactNode\n className?: string\n disabled?: boolean\n disableSuccessStatus?: boolean\n /**\n * If you would like to solely leverage server-side validation on submit,\n * you can disable checks that the form makes before it submits\n */\n disableValidationOnSubmit?: boolean\n /**\n * If you don't want the form to be a <form> element, you can pass a string here to use as the wrapper element.\n */\n el?: string\n /**\n * By default, the form will get the field schema (not data) from the current document. If you pass this in, you can override that behavior.\n * This is very useful for sub-forms, where the form's field schema is not necessarily the field schema of the current document (e.g. for the Blocks\n * feature of the Lexical Rich Text field)\n */\n fields?: ClientField[]\n handleResponse?: (\n res: Response,\n successToast: (value: string) => void,\n errorToast: (value: string) => void,\n ) => void\n initialState?: FormState\n /**\n * Determines if this Form is the main, top-level Form of a document. If set to true, the\n * Form's children will be wrapped in a DocumentFormContext, which lets you access this document\n * Form's data and fields from any child component - even if that child component is wrapped in a child\n * Form (e.g. a lexical block).\n */\n isDocumentForm?: boolean\n isInitializing?: boolean\n log?: boolean\n onChange?: ((args: { formState: FormState; submitted?: boolean }) => Promise<FormState>)[]\n onSubmit?: (fields: FormState, data: Data) => void\n onSuccess?: FormOnSuccess\n redirect?: string\n submitted?: boolean\n uuid?: string\n validationOperation?: 'create' | 'update'\n waitForAutocomplete?: boolean\n} & (\n | {\n action: (formData: FormData) => Promise<void>\n }\n | {\n action?: string\n method?: 'DELETE' | 'GET' | 'PATCH' | 'POST'\n }\n)\n\nexport type SubmitOptions<C = Record<string, unknown>> = {\n acceptValues?: AcceptValues\n action?: string\n /**\n * If you want to pass additional data to the onSuccess callback, you can use this context object.\n *\n * @experimental This property is experimental and may change in the future.\n */\n context?: C\n /**\n * When true, will disable the form while it is processing.\n * @default true\n */\n disableFormWhileProcessing?: boolean\n /**\n * When true, will disable the success toast after form submission.\n * @default false\n */\n disableSuccessStatus?: boolean\n method?: string\n overrides?: ((formState) => FormData) | Record<string, unknown>\n /**\n * When true, will skip validation before submitting the form.\n * @default false\n */\n skipValidation?: boolean\n}\n\nexport type DispatchFields = React.Dispatch<any>\n\nexport type Submit = <T extends Response, C extends Record<string, unknown>>(\n options?: SubmitOptions<C>,\n e?: React.FormEvent<HTMLFormElement>,\n) => Promise</**\n * Returns the form state and the response from the server.\n *\n * @experimental - Note: the `{ res: ... }` return type is experimental and may change in the future. Use at your own risk.\n */\n{ formState?: FormState; res: T } | void>\n\nexport type ValidateForm = () => Promise<boolean>\n\nexport type CreateFormData = (\n overrides?: Record<string, unknown>,\n /**\n * If mergeOverrideData true, the data will be merged with the existing data in the form state.\n * @default true\n */\n options?: {\n /**\n * If provided, will use this instead of of derived data from the current form state.\n */\n data?: Data\n mergeOverrideData?: boolean\n },\n) => FormData | Promise<FormData>\n\nexport type GetFields = () => FormState\nexport type GetField = (path: string) => FormField\nexport type GetData = () => Data\nexport type GetSiblingData = (path: string) => Data\nexport type GetDataByPath = <T = unknown>(path: string) => T\nexport type SetModified = (modified: boolean) => void\nexport type SetSubmitted = (submitted: boolean) => void\nexport type SetProcessing = (processing: boolean) => void\n\nexport type Reset = (data: unknown) => Promise<void>\n\nexport type REPLACE_STATE = {\n optimize?: boolean\n /**\n * If `sanitize` is true, default values will be set for form field properties that are not present in the incoming state.\n * For example, `valid` will be set to true if it is not present in the incoming state.\n */\n sanitize?: boolean\n state: FormState\n type: 'REPLACE_STATE'\n}\n\nexport type REMOVE = {\n path: string\n type: 'REMOVE'\n}\n\nexport type MODIFY_CONDITION = {\n path: string\n result: boolean\n type: 'MODIFY_CONDITION'\n user: TypedUser\n}\n\nexport type UPDATE = {\n path: string\n type: 'UPDATE'\n} & Partial<FormField>\n\nexport type UPDATE_MANY = {\n formState: FormState\n type: 'UPDATE_MANY'\n}\n\nexport type REMOVE_ROW = {\n path: string\n rowIndex: number\n type: 'REMOVE_ROW'\n}\n\nexport type ADD_ROW = {\n blockType?: string\n path: string\n rowIndex?: number\n subFieldState?: FormState\n type: 'ADD_ROW'\n}\n\nexport type MERGE_SERVER_STATE = {\n acceptValues?: AcceptValues\n prevStateRef: React.RefObject<FormState>\n serverState: FormState\n type: 'MERGE_SERVER_STATE'\n}\n\nexport type REPLACE_ROW = {\n blockType?: string\n path: string\n rowIndex: number\n subFieldState?: FormState\n type: 'REPLACE_ROW'\n}\n\nexport type DUPLICATE_ROW = {\n path: string\n rowIndex: number\n type: 'DUPLICATE_ROW'\n}\n\nexport type MOVE_ROW = {\n moveFromIndex: number\n moveToIndex: number\n path: string\n type: 'MOVE_ROW'\n}\n\nexport type ADD_SERVER_ERRORS = {\n errors: ValidationFieldError[]\n type: 'ADD_SERVER_ERRORS'\n}\n\nexport type SET_ROW_COLLAPSED = {\n path: string\n type: 'SET_ROW_COLLAPSED'\n updatedRows: Row[]\n}\n\nexport type SET_ALL_ROWS_COLLAPSED = {\n path: string\n type: 'SET_ALL_ROWS_COLLAPSED'\n updatedRows: Row[]\n}\n\nexport type FieldAction =\n | ADD_ROW\n | ADD_SERVER_ERRORS\n | DUPLICATE_ROW\n | MERGE_SERVER_STATE\n | MODIFY_CONDITION\n | MOVE_ROW\n | REMOVE\n | REMOVE_ROW\n | REPLACE_ROW\n | REPLACE_STATE\n | SET_ALL_ROWS_COLLAPSED\n | SET_ROW_COLLAPSED\n | UPDATE\n | UPDATE_MANY\n\nexport type FormFieldsContext = [FormState, Dispatch<FieldAction>]\n\nexport type Context = {\n addFieldRow: ({\n blockType,\n path,\n rowIndex,\n schemaPath,\n subFieldState,\n }: {\n blockType?: string\n path: string\n rowIndex?: number\n schemaPath: string\n subFieldState?: FormState\n }) => void\n buildRowErrors: () => void\n createFormData: CreateFormData\n disabled: boolean\n dispatchFields: Dispatch<FieldAction>\n /**\n * Form context fields may be outdated and should not be relied on. Instead, prefer `useFormFields`.\n */\n fields: FormState\n formRef: React.RefObject<HTMLFormElement>\n getData: GetData\n getDataByPath: GetDataByPath\n getField: GetField\n getFields: GetFields\n getSiblingData: GetSiblingData\n initializing: boolean\n /**\n * Tracks wether the form state passes validation.\n * For example the state could be submitted but invalid as field errors have been returned.\n */\n isValid: boolean\n moveFieldRow: ({\n moveFromIndex,\n moveToIndex,\n path,\n }: {\n moveFromIndex: number\n moveToIndex: number\n path: string\n }) => void\n removeFieldRow: ({ path, rowIndex }: { path: string; rowIndex: number }) => void\n replaceFieldRow: ({\n blockType,\n path,\n rowIndex,\n schemaPath,\n subFieldState,\n }: {\n blockType?: string\n path: string\n rowIndex: number\n schemaPath: string\n subFieldState?: FormState\n }) => void\n replaceState: (state: FormState) => void\n reset: Reset\n /**\n * If the form has started processing in the background (e.g.\n * if autosave is running), this will be true.\n */\n setBackgroundProcessing: SetProcessing\n setDisabled: (disabled: boolean) => void\n setIsValid: (processing: boolean) => void\n setModified: SetModified\n setProcessing: SetProcessing\n setSubmitted: SetSubmitted\n submit: Submit\n uuid?: string\n validateForm: ValidateForm\n}\n"],"names":[],"mappings":"AAwQA,WAwEC"}
1
+ {"version":3,"sources":["../../../src/forms/Form/types.ts"],"sourcesContent":["import type {\n ClientField,\n Data,\n FormField,\n FormState,\n Row,\n TypedUser,\n ValidationFieldError,\n} from 'payload'\nimport type React from 'react'\nimport type { Dispatch } from 'react'\n\nimport type { AcceptValues } from './mergeServerFormState.js'\n\nexport type Preferences = {\n [key: string]: unknown\n}\n\nexport type FormOnSuccess<T = unknown, C = Record<string, unknown>> = (\n json: T,\n ctx?: {\n /**\n * Arbitrary context passed to the onSuccess callback.\n */\n context?: C\n /**\n * The form state that was sent with the request when retrieving the `json` arg.\n */\n formState?: FormState\n },\n) => Promise<FormState | void> | void\n\nexport type FormProps = {\n beforeSubmit?: ((args: { formState: FormState }) => Promise<FormState>)[]\n children?: React.ReactNode\n className?: string\n disabled?: boolean\n disableSuccessStatus?: boolean\n /**\n * If you would like to solely leverage server-side validation on submit,\n * you can disable checks that the form makes before it submits\n */\n disableValidationOnSubmit?: boolean\n /**\n * If you don't want the form to be a <form> element, you can pass a string here to use as the wrapper element.\n */\n el?: string\n /**\n * By default, the form will get the field schema (not data) from the current document. If you pass this in, you can override that behavior.\n * This is very useful for sub-forms, where the form's field schema is not necessarily the field schema of the current document (e.g. for the Blocks\n * feature of the Lexical Rich Text field)\n */\n fields?: ClientField[]\n handleResponse?: (\n res: Response,\n successToast: (value: string) => void,\n errorToast: (value: string) => void,\n ) => void\n initialState?: FormState\n /**\n * Determines if this Form is the main, top-level Form of a document. If set to true, the\n * Form's children will be wrapped in a DocumentFormContext, which lets you access this document\n * Form's data and fields from any child component - even if that child component is wrapped in a child\n * Form (e.g. a lexical block).\n */\n isDocumentForm?: boolean\n isInitializing?: boolean\n log?: boolean\n onChange?: ((args: { formState: FormState; submitted?: boolean }) => Promise<FormState>)[]\n onSubmit?: (fields: FormState, data: Data) => void\n onSuccess?: FormOnSuccess\n redirect?: string\n submitted?: boolean\n uuid?: string\n validationOperation?: 'create' | 'update'\n waitForAutocomplete?: boolean\n} & (\n | {\n action: (formData: FormData) => Promise<void>\n }\n | {\n action?: string\n method?: 'DELETE' | 'GET' | 'PATCH' | 'POST'\n }\n)\n\nexport type SubmitOptions<C = Record<string, unknown>> = {\n acceptValues?: AcceptValues\n action?: string\n /**\n * If you want to pass additional data to the onSuccess callback, you can use this context object.\n *\n * @experimental This property is experimental and may change in the future.\n */\n context?: C\n /**\n * When true, will disable the form while it is processing.\n * @default true\n */\n disableFormWhileProcessing?: boolean\n /**\n * When true, will disable the success toast after form submission.\n * @default false\n */\n disableSuccessStatus?: boolean\n method?: string\n overrides?: ((formState) => FormData) | Record<string, unknown>\n /**\n * When true, will skip validation before submitting the form.\n * @default false\n */\n skipValidation?: boolean\n}\n\nexport type DispatchFields = React.Dispatch<any>\n\nexport type Submit = <T extends Response, C extends Record<string, unknown>>(\n options?: SubmitOptions<C>,\n e?: React.FormEvent<HTMLFormElement>,\n) => Promise</**\n * Returns the form state and the response from the server.\n *\n * @experimental - Note: the `{ res: ... }` return type is experimental and may change in the future. Use at your own risk.\n */\n{ formState?: FormState; res: T } | void>\n\nexport type ValidateForm = () => Promise<boolean>\n\nexport type CreateFormData = (\n overrides?: Record<string, unknown>,\n /**\n * If mergeOverrideData true, the data will be merged with the existing data in the form state.\n * @default true\n */\n options?: {\n /**\n * If provided, will use this instead of of derived data from the current form state.\n */\n data?: Data\n mergeOverrideData?: boolean\n },\n) => FormData | Promise<FormData>\n\nexport type GetFields = () => FormState\nexport type GetField = (path: string) => FormField\nexport type GetData = () => Data\nexport type GetSiblingData = (path: string) => Data\nexport type GetDataByPath = <T = unknown>(path: string) => T\nexport type SetModified = (modified: boolean) => void\nexport type SetSubmitted = (submitted: boolean) => void\nexport type SetProcessing = (processing: boolean) => void\n\nexport type Reset = (data: unknown) => Promise<void>\n\nexport type REPLACE_STATE = {\n optimize?: boolean\n /**\n * If `sanitize` is true, default values will be set for form field properties that are not present in the incoming state.\n * For example, `valid` will be set to true if it is not present in the incoming state.\n */\n sanitize?: boolean\n state: FormState\n type: 'REPLACE_STATE'\n}\n\nexport type REMOVE = {\n path: string\n type: 'REMOVE'\n}\n\nexport type MODIFY_CONDITION = {\n path: string\n result: boolean\n type: 'MODIFY_CONDITION'\n user: TypedUser\n}\n\nexport type UPDATE = {\n path: string\n type: 'UPDATE'\n} & Partial<FormField>\n\nexport type UPDATE_MANY = {\n formState: FormState\n type: 'UPDATE_MANY'\n}\n\nexport type REMOVE_ROW = {\n path: string\n rowIndex: number\n type: 'REMOVE_ROW'\n}\n\nexport type ADD_ROW = {\n blockType?: string\n path: string\n rowIndex?: number\n subFieldState?: FormState\n type: 'ADD_ROW'\n}\n\nexport type MERGE_SERVER_STATE = {\n acceptValues?: AcceptValues\n prevStateRef: React.RefObject<FormState>\n serverState: FormState\n type: 'MERGE_SERVER_STATE'\n}\n\nexport type REPLACE_ROW = {\n blockType?: string\n path: string\n rowIndex: number\n subFieldState?: FormState\n type: 'REPLACE_ROW'\n}\n\nexport type DUPLICATE_ROW = {\n path: string\n rowIndex: number\n type: 'DUPLICATE_ROW'\n}\n\nexport type MOVE_ROW = {\n moveFromIndex: number\n moveToIndex: number\n path: string\n type: 'MOVE_ROW'\n}\n\nexport type ADD_SERVER_ERRORS = {\n errors: ValidationFieldError[]\n type: 'ADD_SERVER_ERRORS'\n}\n\nexport type SET_ROW_COLLAPSED = {\n path: string\n type: 'SET_ROW_COLLAPSED'\n updatedRows: Row[]\n}\n\nexport type SET_ALL_ROWS_COLLAPSED = {\n path: string\n type: 'SET_ALL_ROWS_COLLAPSED'\n updatedRows: Row[]\n}\n\nexport type FieldAction =\n | ADD_ROW\n | ADD_SERVER_ERRORS\n | DUPLICATE_ROW\n | MERGE_SERVER_STATE\n | MODIFY_CONDITION\n | MOVE_ROW\n | REMOVE\n | REMOVE_ROW\n | REPLACE_ROW\n | REPLACE_STATE\n | SET_ALL_ROWS_COLLAPSED\n | SET_ROW_COLLAPSED\n | UPDATE\n | UPDATE_MANY\n\nexport type FormFieldsContext = [FormState, Dispatch<FieldAction>]\n\nexport type Context = {\n addFieldRow: ({\n blockType,\n path,\n rowIndex,\n schemaPath,\n subFieldState,\n }: {\n blockType?: string\n path: string\n rowIndex?: number\n schemaPath: string\n subFieldState?: FormState\n }) => void\n buildRowErrors: () => void\n createFormData: CreateFormData\n disabled: boolean\n dispatchFields: Dispatch<FieldAction>\n /**\n * Form context fields may be outdated and should not be relied on. Instead, prefer `useFormFields`.\n */\n fields: FormState\n formRef: React.RefObject<HTMLFormElement>\n getData: GetData\n getDataByPath: GetDataByPath\n getField: GetField\n getFields: GetFields\n getSiblingData: GetSiblingData\n initializing: boolean\n /**\n * Tracks wether the form state passes validation.\n * For example the state could be submitted but invalid as field errors have been returned.\n */\n isValid: boolean\n moveFieldRow: ({\n moveFromIndex,\n moveToIndex,\n path,\n }: {\n moveFromIndex: number\n moveToIndex: number\n path: string\n }) => void\n removeFieldRow: ({ path, rowIndex }: { path: string; rowIndex: number }) => void\n replaceFieldRow: ({\n blockType,\n path,\n rowIndex,\n schemaPath,\n subFieldState,\n }: {\n blockType?: string\n path: string\n rowIndex: number\n schemaPath: string\n subFieldState?: FormState\n }) => void\n replaceState: (state: FormState) => void\n reset: Reset\n /**\n * If the form has started processing in the background (e.g.\n * if autosave is running), this will be true.\n */\n setBackgroundProcessing: SetProcessing\n setDisabled: (disabled: boolean) => void\n setIsValid: (processing: boolean) => void\n setModified: SetModified\n setProcessing: SetProcessing\n setSubmitted: SetSubmitted\n submit: Submit\n uuid?: string\n validateForm: ValidateForm\n}\n"],"names":[],"mappings":"AAqBI;;KAEC,GAED;;KAEC,GAWH;;;GAGC,GAED;;GAEC,GAED;;;;GAIC,GAQD;;;;;GAKC,GAyBD;;;;GAIC,GAED;;;GAGC,GAED;;;GAGC,GAID;;;GAGC,GASU;;;;CAIZ,GAOC;;;GAGC,GAEC;;KAEC,GAmBH;;;GAGC,GAyGH,WAwEC,CAtDC;;GAEC,IASD;;;GAGC,IA2BD;;;GAGC"}
@@ -44,7 +44,8 @@ export const NullifyLocaleField = ({ fieldValue, localized, path, readOnly = fal
44
44
  if (hideCheckbox) {
45
45
  if (checked) {
46
46
  setChecked(false);
47
- } // uncheck when field has value
47
+ }
48
+ // uncheck when field has value
48
49
  return null;
49
50
  }
50
51
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/NullifyField/index.tsx"],"sourcesContent":["'use client'\n\nimport * as React from 'react'\n\nimport { Banner } from '../../elements/Banner/index.js'\nimport { CheckboxField } from '../../fields/Checkbox/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { useForm } from '../Form/context.js'\nimport './index.scss'\n\nconst baseClass = 'nullify-locale-field'\n\ntype NullifyLocaleFieldProps = {\n readonly fieldValue?: [] | null | number\n readonly localized: boolean\n readonly path: string\n readonly readOnly?: boolean\n}\n\nexport const NullifyLocaleField: React.FC<NullifyLocaleFieldProps> = ({\n fieldValue,\n localized,\n path,\n readOnly = false,\n}) => {\n const { code: currentLocale } = useLocale()\n const {\n config: { localization },\n } = useConfig()\n const [checked, setChecked] = React.useState<boolean>(typeof fieldValue !== 'number')\n const { t } = useTranslation()\n const { dispatchFields, setModified } = useForm()\n\n if (!localized || !localization) {\n // hide when field is not localized or localization is not enabled\n return null\n }\n\n if (localization.defaultLocale === currentLocale || !localization.fallback) {\n // if editing default locale or when fallback is disabled\n return null\n }\n\n const onChange = () => {\n const useFallback = !checked\n\n dispatchFields({\n type: 'UPDATE',\n path,\n value: useFallback ? null : fieldValue || 0,\n })\n setModified(true)\n setChecked(useFallback)\n }\n\n if (fieldValue) {\n let hideCheckbox = false\n if (typeof fieldValue === 'number' && fieldValue > 0) {\n hideCheckbox = true\n }\n if (Array.isArray(fieldValue) && fieldValue.length > 0) {\n hideCheckbox = true\n }\n\n if (hideCheckbox) {\n if (checked) {\n setChecked(false)\n } // uncheck when field has value\n return null\n }\n }\n\n return (\n <Banner className={baseClass}>\n {!fieldValue && readOnly ? (\n t('general:fallbackToDefaultLocale')\n ) : (\n <CheckboxField\n checked={checked}\n field={{\n name: '',\n label: t('general:fallbackToDefaultLocale'),\n }}\n id={`field-${path.replace(/\\./g, '__')}`}\n onChange={onChange}\n path={path}\n schemaPath=\"\"\n />\n )}\n </Banner>\n )\n}\n"],"names":["React","Banner","CheckboxField","useConfig","useLocale","useTranslation","useForm","baseClass","NullifyLocaleField","fieldValue","localized","path","readOnly","code","currentLocale","config","localization","checked","setChecked","useState","t","dispatchFields","setModified","defaultLocale","fallback","onChange","useFallback","type","value","hideCheckbox","Array","isArray","length","className","field","name","label","id","replace","schemaPath"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAO;AAE9B,SAASC,MAAM,QAAQ,iCAAgC;AACvD,SAASC,aAAa,QAAQ,iCAAgC;AAC9D,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,cAAc,QAAQ,uCAAsC;AACrE,SAASC,OAAO,QAAQ,qBAAoB;AAC5C,OAAO,eAAc;AAErB,MAAMC,YAAY;AASlB,OAAO,MAAMC,qBAAwD,CAAC,EACpEC,UAAU,EACVC,SAAS,EACTC,IAAI,EACJC,WAAW,KAAK,EACjB;IACC,MAAM,EAAEC,MAAMC,aAAa,EAAE,GAAGV;IAChC,MAAM,EACJW,QAAQ,EAAEC,YAAY,EAAE,EACzB,GAAGb;IACJ,MAAM,CAACc,SAASC,WAAW,GAAGlB,MAAMmB,QAAQ,CAAU,OAAOV,eAAe;IAC5E,MAAM,EAAEW,CAAC,EAAE,GAAGf;IACd,MAAM,EAAEgB,cAAc,EAAEC,WAAW,EAAE,GAAGhB;IAExC,IAAI,CAACI,aAAa,CAACM,cAAc;QAC/B,kEAAkE;QAClE,OAAO;IACT;IAEA,IAAIA,aAAaO,aAAa,KAAKT,iBAAiB,CAACE,aAAaQ,QAAQ,EAAE;QAC1E,yDAAyD;QACzD,OAAO;IACT;IAEA,MAAMC,WAAW;QACf,MAAMC,cAAc,CAACT;QAErBI,eAAe;YACbM,MAAM;YACNhB;YACAiB,OAAOF,cAAc,OAAOjB,cAAc;QAC5C;QACAa,YAAY;QACZJ,WAAWQ;IACb;IAEA,IAAIjB,YAAY;QACd,IAAIoB,eAAe;QACnB,IAAI,OAAOpB,eAAe,YAAYA,aAAa,GAAG;YACpDoB,eAAe;QACjB;QACA,IAAIC,MAAMC,OAAO,CAACtB,eAAeA,WAAWuB,MAAM,GAAG,GAAG;YACtDH,eAAe;QACjB;QAEA,IAAIA,cAAc;YAChB,IAAIZ,SAAS;gBACXC,WAAW;YACb,EAAE,+BAA+B;YACjC,OAAO;QACT;IACF;IAEA,qBACE,KAACjB;QAAOgC,WAAW1B;kBAChB,CAACE,cAAcG,WACdQ,EAAE,mDAEF,KAAClB;YACCe,SAASA;YACTiB,OAAO;gBACLC,MAAM;gBACNC,OAAOhB,EAAE;YACX;YACAiB,IAAI,CAAC,MAAM,EAAE1B,KAAK2B,OAAO,CAAC,OAAO,OAAO;YACxCb,UAAUA;YACVd,MAAMA;YACN4B,YAAW;;;AAKrB,EAAC"}
1
+ {"version":3,"sources":["../../../src/forms/NullifyField/index.tsx"],"sourcesContent":["'use client'\n\nimport * as React from 'react'\n\nimport { Banner } from '../../elements/Banner/index.js'\nimport { CheckboxField } from '../../fields/Checkbox/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { useForm } from '../Form/context.js'\nimport './index.scss'\n\nconst baseClass = 'nullify-locale-field'\n\ntype NullifyLocaleFieldProps = {\n readonly fieldValue?: [] | null | number\n readonly localized: boolean\n readonly path: string\n readonly readOnly?: boolean\n}\n\nexport const NullifyLocaleField: React.FC<NullifyLocaleFieldProps> = ({\n fieldValue,\n localized,\n path,\n readOnly = false,\n}) => {\n const { code: currentLocale } = useLocale()\n const {\n config: { localization },\n } = useConfig()\n const [checked, setChecked] = React.useState<boolean>(typeof fieldValue !== 'number')\n const { t } = useTranslation()\n const { dispatchFields, setModified } = useForm()\n\n if (!localized || !localization) {\n // hide when field is not localized or localization is not enabled\n return null\n }\n\n if (localization.defaultLocale === currentLocale || !localization.fallback) {\n // if editing default locale or when fallback is disabled\n return null\n }\n\n const onChange = () => {\n const useFallback = !checked\n\n dispatchFields({\n type: 'UPDATE',\n path,\n value: useFallback ? null : fieldValue || 0,\n })\n setModified(true)\n setChecked(useFallback)\n }\n\n if (fieldValue) {\n let hideCheckbox = false\n if (typeof fieldValue === 'number' && fieldValue > 0) {\n hideCheckbox = true\n }\n if (Array.isArray(fieldValue) && fieldValue.length > 0) {\n hideCheckbox = true\n }\n\n if (hideCheckbox) {\n if (checked) {\n setChecked(false)\n } // uncheck when field has value\n return null\n }\n }\n\n return (\n <Banner className={baseClass}>\n {!fieldValue && readOnly ? (\n t('general:fallbackToDefaultLocale')\n ) : (\n <CheckboxField\n checked={checked}\n field={{\n name: '',\n label: t('general:fallbackToDefaultLocale'),\n }}\n id={`field-${path.replace(/\\./g, '__')}`}\n onChange={onChange}\n path={path}\n schemaPath=\"\"\n />\n )}\n </Banner>\n )\n}\n"],"names":["React","Banner","CheckboxField","useConfig","useLocale","useTranslation","useForm","baseClass","NullifyLocaleField","fieldValue","localized","path","readOnly","code","currentLocale","config","localization","checked","setChecked","useState","t","dispatchFields","setModified","defaultLocale","fallback","onChange","useFallback","type","value","hideCheckbox","Array","isArray","length","className","field","name","label","id","replace","schemaPath"],"mappings":"AAAA;;AAEA,YAAYA,WAAW,QAAO;AAE9B,SAASC,MAAM,QAAQ,iCAAgC;AACvD,SAASC,aAAa,QAAQ,iCAAgC;AAC9D,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,SAAS,QAAQ,kCAAiC;AAC3D,SAASC,cAAc,QAAQ,uCAAsC;AACrE,SAASC,OAAO,QAAQ,qBAAoB;AAC5C,OAAO,eAAc;AAErB,MAAMC,YAAY;AASlB,OAAO,MAAMC,qBAAwD,CAAC,EACpEC,UAAU,EACVC,SAAS,EACTC,IAAI,EACJC,WAAW,KAAK,EACjB;IACC,MAAM,EAAEC,MAAMC,aAAa,EAAE,GAAGV;IAChC,MAAM,EACJW,QAAQ,EAAEC,YAAY,EAAE,EACzB,GAAGb;IACJ,MAAM,CAACc,SAASC,WAAW,GAAGlB,MAAMmB,QAAQ,CAAU,OAAOV,eAAe;IAC5E,MAAM,EAAEW,CAAC,EAAE,GAAGf;IACd,MAAM,EAAEgB,cAAc,EAAEC,WAAW,EAAE,GAAGhB;IAExC,IAAI,CAACI,aAAa,CAACM,cAAc;QAC/B,kEAAkE;QAClE,OAAO;IACT;IAEA,IAAIA,aAAaO,aAAa,KAAKT,iBAAiB,CAACE,aAAaQ,QAAQ,EAAE;QAC1E,yDAAyD;QACzD,OAAO;IACT;IAEA,MAAMC,WAAW;QACf,MAAMC,cAAc,CAACT;QAErBI,eAAe;YACbM,MAAM;YACNhB;YACAiB,OAAOF,cAAc,OAAOjB,cAAc;QAC5C;QACAa,YAAY;QACZJ,WAAWQ;IACb;IAEA,IAAIjB,YAAY;QACd,IAAIoB,eAAe;QACnB,IAAI,OAAOpB,eAAe,YAAYA,aAAa,GAAG;YACpDoB,eAAe;QACjB;QACA,IAAIC,MAAMC,OAAO,CAACtB,eAAeA,WAAWuB,MAAM,GAAG,GAAG;YACtDH,eAAe;QACjB;QAEA,IAAIA,cAAc;YAChB,IAAIZ,SAAS;gBACXC,WAAW;YACb;YAAE,+BAA+B;YACjC,OAAO;QACT;IACF;IAEA,qBACE,KAACjB;QAAOgC,WAAW1B;kBAChB,CAACE,cAAcG,WACdQ,EAAE,mDAEF,KAAClB;YACCe,SAASA;YACTiB,OAAO;gBACLC,MAAM;gBACNC,OAAOhB,EAAE;YACX;YACAiB,IAAI,CAAC,MAAM,EAAE1B,KAAK2B,OAAO,CAAC,OAAO,OAAO;YACxCb,UAAUA;YACVd,MAAMA;YACN4B,YAAW;;;AAKrB,EAAC"}
@@ -2,7 +2,12 @@
2
2
  import { useThrottledEffect } from '../../hooks/useThrottledEffect.js';
3
3
  import { useAllFormFields, useFormSubmitted } from '../Form/context.js';
4
4
  import { buildPathSegments } from './buildPathSegments.js';
5
- export const WatchChildErrors = ({ fields, path: parentPath, setErrorCount })=>{
5
+ /**
6
+ * This path should only include path segments that affect data
7
+ * i.e. it should not include _index-0 type segments
8
+ *
9
+ * For collapsibles and tabs you can simply pass their parent path
10
+ */ export const WatchChildErrors = ({ fields, path: parentPath, setErrorCount })=>{
6
11
  const [formState] = useAllFormFields();
7
12
  const hasSubmitted = useFormSubmitted();
8
13
  const segmentsToMatch = buildPathSegments(fields);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/WatchChildErrors/index.tsx"],"sourcesContent":["'use client'\nimport type { ClientField } from 'payload'\nimport type React from 'react'\n\nimport { useThrottledEffect } from '../../hooks/useThrottledEffect.js'\nimport { useAllFormFields, useFormSubmitted } from '../Form/context.js'\nimport { buildPathSegments } from './buildPathSegments.js'\n\ntype TrackSubSchemaErrorCountProps = {\n fields?: ClientField[]\n /**\n * This path should only include path segments that affect data\n * i.e. it should not include _index-0 type segments\n *\n * For collapsibles and tabs you can simply pass their parent path\n */\n path: (number | string)[]\n setErrorCount: (count: number) => void\n}\nexport const WatchChildErrors: React.FC<TrackSubSchemaErrorCountProps> = ({\n fields,\n path: parentPath,\n setErrorCount,\n}) => {\n const [formState] = useAllFormFields()\n const hasSubmitted = useFormSubmitted()\n\n const segmentsToMatch = buildPathSegments(fields)\n\n useThrottledEffect(\n () => {\n if (hasSubmitted) {\n let errorCount = 0\n Object.entries(formState).forEach(([key]) => {\n const matchingSegment = segmentsToMatch?.some((segment) => {\n const segmentToMatch = [...parentPath, segment].join('.')\n // match fields with same parent path\n if (segmentToMatch.endsWith('.')) {\n return key.startsWith(segmentToMatch)\n }\n // match fields with same path\n return key === segmentToMatch\n })\n\n if (matchingSegment) {\n const pathState = formState[key]\n if ('valid' in pathState && !pathState.valid) {\n errorCount += 1\n }\n }\n })\n setErrorCount(errorCount)\n }\n },\n 250,\n [formState, hasSubmitted, fields],\n )\n\n return null\n}\n"],"names":["useThrottledEffect","useAllFormFields","useFormSubmitted","buildPathSegments","WatchChildErrors","fields","path","parentPath","setErrorCount","formState","hasSubmitted","segmentsToMatch","errorCount","Object","entries","forEach","key","matchingSegment","some","segment","segmentToMatch","join","endsWith","startsWith","pathState","valid"],"mappings":"AAAA;AAIA,SAASA,kBAAkB,QAAQ,oCAAmC;AACtE,SAASC,gBAAgB,EAAEC,gBAAgB,QAAQ,qBAAoB;AACvE,SAASC,iBAAiB,QAAQ,yBAAwB;AAa1D,OAAO,MAAMC,mBAA4D,CAAC,EACxEC,MAAM,EACNC,MAAMC,UAAU,EAChBC,aAAa,EACd;IACC,MAAM,CAACC,UAAU,GAAGR;IACpB,MAAMS,eAAeR;IAErB,MAAMS,kBAAkBR,kBAAkBE;IAE1CL,mBACE;QACE,IAAIU,cAAc;YAChB,IAAIE,aAAa;YACjBC,OAAOC,OAAO,CAACL,WAAWM,OAAO,CAAC,CAAC,CAACC,IAAI;gBACtC,MAAMC,kBAAkBN,iBAAiBO,KAAK,CAACC;oBAC7C,MAAMC,iBAAiB;2BAAIb;wBAAYY;qBAAQ,CAACE,IAAI,CAAC;oBACrD,qCAAqC;oBACrC,IAAID,eAAeE,QAAQ,CAAC,MAAM;wBAChC,OAAON,IAAIO,UAAU,CAACH;oBACxB;oBACA,8BAA8B;oBAC9B,OAAOJ,QAAQI;gBACjB;gBAEA,IAAIH,iBAAiB;oBACnB,MAAMO,YAAYf,SAAS,CAACO,IAAI;oBAChC,IAAI,WAAWQ,aAAa,CAACA,UAAUC,KAAK,EAAE;wBAC5Cb,cAAc;oBAChB;gBACF;YACF;YACAJ,cAAcI;QAChB;IACF,GACA,KACA;QAACH;QAAWC;QAAcL;KAAO;IAGnC,OAAO;AACT,EAAC"}
1
+ {"version":3,"sources":["../../../src/forms/WatchChildErrors/index.tsx"],"sourcesContent":["'use client'\nimport type { ClientField } from 'payload'\nimport type React from 'react'\n\nimport { useThrottledEffect } from '../../hooks/useThrottledEffect.js'\nimport { useAllFormFields, useFormSubmitted } from '../Form/context.js'\nimport { buildPathSegments } from './buildPathSegments.js'\n\ntype TrackSubSchemaErrorCountProps = {\n fields?: ClientField[]\n /**\n * This path should only include path segments that affect data\n * i.e. it should not include _index-0 type segments\n *\n * For collapsibles and tabs you can simply pass their parent path\n */\n path: (number | string)[]\n setErrorCount: (count: number) => void\n}\nexport const WatchChildErrors: React.FC<TrackSubSchemaErrorCountProps> = ({\n fields,\n path: parentPath,\n setErrorCount,\n}) => {\n const [formState] = useAllFormFields()\n const hasSubmitted = useFormSubmitted()\n\n const segmentsToMatch = buildPathSegments(fields)\n\n useThrottledEffect(\n () => {\n if (hasSubmitted) {\n let errorCount = 0\n Object.entries(formState).forEach(([key]) => {\n const matchingSegment = segmentsToMatch?.some((segment) => {\n const segmentToMatch = [...parentPath, segment].join('.')\n // match fields with same parent path\n if (segmentToMatch.endsWith('.')) {\n return key.startsWith(segmentToMatch)\n }\n // match fields with same path\n return key === segmentToMatch\n })\n\n if (matchingSegment) {\n const pathState = formState[key]\n if ('valid' in pathState && !pathState.valid) {\n errorCount += 1\n }\n }\n })\n setErrorCount(errorCount)\n }\n },\n 250,\n [formState, hasSubmitted, fields],\n )\n\n return null\n}\n"],"names":["useThrottledEffect","useAllFormFields","useFormSubmitted","buildPathSegments","WatchChildErrors","fields","path","parentPath","setErrorCount","formState","hasSubmitted","segmentsToMatch","errorCount","Object","entries","forEach","key","matchingSegment","some","segment","segmentToMatch","join","endsWith","startsWith","pathState","valid"],"mappings":"AAAA;AAIA,SAASA,kBAAkB,QAAQ,oCAAmC;AACtE,SAASC,gBAAgB,EAAEC,gBAAgB,QAAQ,qBAAoB;AACvE,SAASC,iBAAiB,QAAQ,yBAAwB;AAIxD;;;;;GAKC,GAIH,OAAO,MAAMC,mBAA4D,CAAC,EACxEC,MAAM,EACNC,MAAMC,UAAU,EAChBC,aAAa,EACd;IACC,MAAM,CAACC,UAAU,GAAGR;IACpB,MAAMS,eAAeR;IAErB,MAAMS,kBAAkBR,kBAAkBE;IAE1CL,mBACE;QACE,IAAIU,cAAc;YAChB,IAAIE,aAAa;YACjBC,OAAOC,OAAO,CAACL,WAAWM,OAAO,CAAC,CAAC,CAACC,IAAI;gBACtC,MAAMC,kBAAkBN,iBAAiBO,KAAK,CAACC;oBAC7C,MAAMC,iBAAiB;2BAAIb;wBAAYY;qBAAQ,CAACE,IAAI,CAAC;oBACrD,qCAAqC;oBACrC,IAAID,eAAeE,QAAQ,CAAC,MAAM;wBAChC,OAAON,IAAIO,UAAU,CAACH;oBACxB;oBACA,8BAA8B;oBAC9B,OAAOJ,QAAQI;gBACjB;gBAEA,IAAIH,iBAAiB;oBACnB,MAAMO,YAAYf,SAAS,CAACO,IAAI;oBAChC,IAAI,WAAWQ,aAAa,CAACA,UAAUC,KAAK,EAAE;wBAC5Cb,cAAc;oBAChB;gBACF;YACF;YACAJ,cAAcI;QAChB;IACF,GACA,KACA;QAACH;QAAWC;QAAcL;KAAO;IAGnC,OAAO;AACT,EAAC"}
@@ -6,6 +6,25 @@ import { isRowCollapsed } from './isRowCollapsed.js';
6
6
  import { iterateFields } from './iterateFields.js';
7
7
  const ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectIdImport;
8
8
  /**
9
+ * if all parents are localized, then the field is localized
10
+ */ /**
11
+ * Data of the nearest parent block, or undefined
12
+ */ /**
13
+ * 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.
14
+ */ /**
15
+ * Force the value of fields like arrays or blocks to be the full value instead of the length @default false
16
+ */ /**
17
+ * Whether the field schema should be included in the state
18
+ */ /**
19
+ * Whether to omit parent fields in the state. @default false
20
+ */ /**
21
+ * Req is used for validation and defaultValue calculation. If you don't need validation,
22
+ * just create your own req and pass in the locale and the user
23
+ */ /**
24
+ * Whether to skip checking the field's condition. @default false
25
+ */ /**
26
+ * Whether to skip validating the field. @default false
27
+ */ /**
9
28
  * Flattens the fields schema and fields data.
10
29
  * The output is the field path (e.g. array.0.name) mapped to a FormField object.
11
30
  */ export const addFieldStatePromise = async (args)=>{
@@ -540,6 +559,7 @@ const ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectId
540
559
  parentPath,
541
560
  parentSchemaPath,
542
561
  permissions: parentPermissions,
562
+ // TODO: Verify this is correct
543
563
  preferences,
544
564
  previousFormState,
545
565
  readOnly,
@@ -1 +1 @@
1
- {"version":3,"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"],"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"],"mappings":"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"}
1
+ {"version":3,"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"],"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"],"mappings":"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"}
@@ -1,6 +1,38 @@
1
1
  import { calculateDefaultValues } from './calculateDefaultValues/index.js';
2
2
  import { iterateFields } from './iterateFields.js';
3
- export const fieldSchemasToFormState = async ({ id, clientFieldSchemaMap, collectionSlug, data = {}, documentData, fields, fieldSchemaMap, initialBlockData, mockRSCs, operation, permissions, preferences, previousFormState, readOnly, renderAllFields, renderFieldFn, req, schemaPath, select, selectMode, skipValidation })=>{
3
+ /**
4
+ * The client field schema map is required for field rendering.
5
+ * If fields should not be rendered (=> `renderFieldFn` is not provided),
6
+ * then the client field schema map is not required.
7
+ */ /**
8
+ * If this is undefined, the `data` passed to this function will serve as `fullData` and `data` when iterating over
9
+ * the top-level-fields to generate form state.
10
+ * For sub fields, the `data` will be narrowed down to the sub fields, while `fullData` remains the same.
11
+ *
12
+ * Usually, the `data` passed to this function will be the document data. This means that running validation, read access control
13
+ * or executing filterOptions here will have access to the full document through the passed `fullData` parameter, and that `fullData` and `data` will be identical.
14
+ *
15
+ * In some cases however, this function is used to generate form state solely for sub fields - independent from the parent form state.
16
+ * This means that `data` will be the form state of the sub fields - the document data won't be available here.
17
+ *
18
+ * In these cases, you can pass `documentData` which will be used as `fullData` instead of `data`.
19
+ *
20
+ * This is useful for lexical blocks, as lexical block fields there are not part of the parent form state, yet we still want
21
+ * document data to be available for validation and filterOptions, under the `data` key.
22
+ */ /**
23
+ * The field schema map is required for field rendering.
24
+ * If fields should not be rendered (=> `renderFieldFn` is not provided),
25
+ * then the field schema map is not required.
26
+ */ /**
27
+ * Validation, filterOptions and read access control will receive the `blockData`, which is the data of the nearest parent block. You can pass in
28
+ * the initial block data here, which will be used as `blockData` for the top-level fields, until the first block is encountered.
29
+ */ /**
30
+ * Optionally accept the previous form state,
31
+ * to be able to determine if custom fields need to be re-rendered.
32
+ */ /**
33
+ * If renderAllFields is true, then no matter what is in previous form state,
34
+ * all custom fields will be re-rendered.
35
+ */ export const fieldSchemasToFormState = async ({ id, clientFieldSchemaMap, collectionSlug, data = {}, documentData, fields, fieldSchemaMap, initialBlockData, mockRSCs, operation, permissions, preferences, previousFormState, readOnly, renderAllFields, renderFieldFn, req, schemaPath, select, selectMode, skipValidation })=>{
4
36
  if (!clientFieldSchemaMap && renderFieldFn) {
5
37
  // eslint-disable-next-line no-console
6
38
  console.warn('clientFieldSchemaMap is not passed to fieldSchemasToFormState - this will reduce performance');
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/index.tsx"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field,\n FieldSchemaMap,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n} from 'payload'\n\nimport type { RenderFieldMethod } from './types.js'\n\nimport { calculateDefaultValues } from './calculateDefaultValues/index.js'\nimport { iterateFields } from './iterateFields.js'\n\ntype Args = {\n /**\n * The client field schema map is required for field rendering.\n * If fields should not be rendered (=> `renderFieldFn` is not provided),\n * then the client field schema map is not required.\n */\n clientFieldSchemaMap?: ClientFieldSchemaMap\n collectionSlug?: string\n data?: Data\n /**\n * If this is undefined, the `data` passed to this function will serve as `fullData` and `data` when iterating over\n * the top-level-fields to generate form state.\n * For sub fields, the `data` will be narrowed down to the sub fields, while `fullData` remains the same.\n *\n * Usually, the `data` passed to this function will be the document data. This means that running validation, read access control\n * or executing filterOptions here will have access to the full document through the passed `fullData` parameter, and that `fullData` and `data` will be identical.\n *\n * In some cases however, this function is used to generate form state solely for sub fields - independent from the parent form state.\n * This means that `data` will be the form state of the sub fields - the document data won't be available here.\n *\n * In these cases, you can pass `documentData` which will be used as `fullData` instead of `data`.\n *\n * This is useful for lexical blocks, as lexical block fields there are not part of the parent form state, yet we still want\n * document data to be available for validation and filterOptions, under the `data` key.\n */\n documentData?: Data\n fields: Field[] | undefined\n /**\n * The field schema map is required for field rendering.\n * If fields should not be rendered (=> `renderFieldFn` is not provided),\n * then the field schema map is not required.\n */\n fieldSchemaMap: FieldSchemaMap | undefined\n id?: number | string\n /**\n * Validation, filterOptions and read access control will receive the `blockData`, which is the data of the nearest parent block. You can pass in\n * the initial block data here, which will be used as `blockData` for the top-level fields, until the first block is encountered.\n */\n initialBlockData?: Data\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n operation?: 'create' | 'update'\n permissions: SanitizedFieldsPermissions\n preferences: DocumentPreferences\n /**\n * Optionally accept the previous form state,\n * to be able to determine if custom fields need to be re-rendered.\n */\n previousFormState?: FormState\n readOnly?: boolean\n /**\n * If renderAllFields is true, then no matter what is in previous form state,\n * all custom fields will be re-rendered.\n */\n renderAllFields: boolean\n renderFieldFn?: RenderFieldMethod\n req: PayloadRequest\n schemaPath: string\n select?: SelectType\n selectMode?: SelectMode\n skipValidation?: boolean\n}\n\nexport const fieldSchemasToFormState = async ({\n id,\n clientFieldSchemaMap,\n collectionSlug,\n data = {},\n documentData,\n fields,\n fieldSchemaMap,\n initialBlockData,\n mockRSCs,\n operation,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n schemaPath,\n select,\n selectMode,\n skipValidation,\n}: Args): Promise<FormState> => {\n if (!clientFieldSchemaMap && renderFieldFn) {\n // eslint-disable-next-line no-console\n console.warn(\n 'clientFieldSchemaMap is not passed to fieldSchemasToFormState - this will reduce performance',\n )\n }\n\n if (fields && fields.length) {\n const state: FormStateWithoutComponents = {}\n\n const dataWithDefaultValues = { ...data }\n\n await calculateDefaultValues({\n id,\n data: dataWithDefaultValues,\n fields,\n locale: req.locale,\n req,\n select,\n selectMode,\n siblingData: dataWithDefaultValues,\n user: req.user,\n })\n\n let fullData = dataWithDefaultValues\n\n if (documentData) {\n // By the time this function is used to get form state for nested forms, their default values should have already been calculated\n // => no need to run calculateDefaultValues here\n fullData = documentData\n }\n\n await iterateFields({\n id,\n addErrorPathToParent: null,\n blockData: initialBlockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: dataWithDefaultValues,\n fields,\n fieldSchemaMap,\n fullData,\n mockRSCs,\n operation,\n parentIndexPath: '',\n parentPassesCondition: true,\n parentPath: '',\n parentSchemaPath: schemaPath,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select,\n selectMode,\n skipValidation,\n state,\n })\n\n return state\n }\n\n return {}\n}\n\nexport { iterateFields }\n"],"names":["calculateDefaultValues","iterateFields","fieldSchemasToFormState","id","clientFieldSchemaMap","collectionSlug","data","documentData","fields","fieldSchemaMap","initialBlockData","mockRSCs","operation","permissions","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","schemaPath","select","selectMode","skipValidation","console","warn","length","state","dataWithDefaultValues","locale","siblingData","user","fullData","addErrorPathToParent","blockData","parentIndexPath","parentPassesCondition","parentPath","parentSchemaPath"],"mappings":"AAiBA,SAASA,sBAAsB,QAAQ,oCAAmC;AAC1E,SAASC,aAAa,QAAQ,qBAAoB;AAgElD,OAAO,MAAMC,0BAA0B,OAAO,EAC5CC,EAAE,EACFC,oBAAoB,EACpBC,cAAc,EACdC,OAAO,CAAC,CAAC,EACTC,YAAY,EACZC,MAAM,EACNC,cAAc,EACdC,gBAAgB,EAChBC,QAAQ,EACRC,SAAS,EACTC,WAAW,EACXC,WAAW,EACXC,iBAAiB,EACjBC,QAAQ,EACRC,eAAe,EACfC,aAAa,EACbC,GAAG,EACHC,UAAU,EACVC,MAAM,EACNC,UAAU,EACVC,cAAc,EACT;IACL,IAAI,CAACnB,wBAAwBc,eAAe;QAC1C,sCAAsC;QACtCM,QAAQC,IAAI,CACV;IAEJ;IAEA,IAAIjB,UAAUA,OAAOkB,MAAM,EAAE;QAC3B,MAAMC,QAAoC,CAAC;QAE3C,MAAMC,wBAAwB;YAAE,GAAGtB,IAAI;QAAC;QAExC,MAAMN,uBAAuB;YAC3BG;YACAG,MAAMsB;YACNpB;YACAqB,QAAQV,IAAIU,MAAM;YAClBV;YACAE;YACAC;YACAQ,aAAaF;YACbG,MAAMZ,IAAIY,IAAI;QAChB;QAEA,IAAIC,WAAWJ;QAEf,IAAIrB,cAAc;YAChB,iIAAiI;YACjI,gDAAgD;YAChDyB,WAAWzB;QACb;QAEA,MAAMN,cAAc;YAClBE;YACA8B,sBAAsB;YACtBC,WAAWxB;YACXN;YACAC;YACAC,MAAMsB;YACNpB;YACAC;YACAuB;YACArB;YACAC;YACAuB,iBAAiB;YACjBC,uBAAuB;YACvBC,YAAY;YACZC,kBAAkBlB;YAClBP;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAE;YACAC;YACAC;YACAI;QACF;QAEA,OAAOA;IACT;IAEA,OAAO,CAAC;AACV,EAAC;AAED,SAAS1B,aAAa,GAAE"}
1
+ {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/index.tsx"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field,\n FieldSchemaMap,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n} from 'payload'\n\nimport type { RenderFieldMethod } from './types.js'\n\nimport { calculateDefaultValues } from './calculateDefaultValues/index.js'\nimport { iterateFields } from './iterateFields.js'\n\ntype Args = {\n /**\n * The client field schema map is required for field rendering.\n * If fields should not be rendered (=> `renderFieldFn` is not provided),\n * then the client field schema map is not required.\n */\n clientFieldSchemaMap?: ClientFieldSchemaMap\n collectionSlug?: string\n data?: Data\n /**\n * If this is undefined, the `data` passed to this function will serve as `fullData` and `data` when iterating over\n * the top-level-fields to generate form state.\n * For sub fields, the `data` will be narrowed down to the sub fields, while `fullData` remains the same.\n *\n * Usually, the `data` passed to this function will be the document data. This means that running validation, read access control\n * or executing filterOptions here will have access to the full document through the passed `fullData` parameter, and that `fullData` and `data` will be identical.\n *\n * In some cases however, this function is used to generate form state solely for sub fields - independent from the parent form state.\n * This means that `data` will be the form state of the sub fields - the document data won't be available here.\n *\n * In these cases, you can pass `documentData` which will be used as `fullData` instead of `data`.\n *\n * This is useful for lexical blocks, as lexical block fields there are not part of the parent form state, yet we still want\n * document data to be available for validation and filterOptions, under the `data` key.\n */\n documentData?: Data\n fields: Field[] | undefined\n /**\n * The field schema map is required for field rendering.\n * If fields should not be rendered (=> `renderFieldFn` is not provided),\n * then the field schema map is not required.\n */\n fieldSchemaMap: FieldSchemaMap | undefined\n id?: number | string\n /**\n * Validation, filterOptions and read access control will receive the `blockData`, which is the data of the nearest parent block. You can pass in\n * the initial block data here, which will be used as `blockData` for the top-level fields, until the first block is encountered.\n */\n initialBlockData?: Data\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n operation?: 'create' | 'update'\n permissions: SanitizedFieldsPermissions\n preferences: DocumentPreferences\n /**\n * Optionally accept the previous form state,\n * to be able to determine if custom fields need to be re-rendered.\n */\n previousFormState?: FormState\n readOnly?: boolean\n /**\n * If renderAllFields is true, then no matter what is in previous form state,\n * all custom fields will be re-rendered.\n */\n renderAllFields: boolean\n renderFieldFn?: RenderFieldMethod\n req: PayloadRequest\n schemaPath: string\n select?: SelectType\n selectMode?: SelectMode\n skipValidation?: boolean\n}\n\nexport const fieldSchemasToFormState = async ({\n id,\n clientFieldSchemaMap,\n collectionSlug,\n data = {},\n documentData,\n fields,\n fieldSchemaMap,\n initialBlockData,\n mockRSCs,\n operation,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n schemaPath,\n select,\n selectMode,\n skipValidation,\n}: Args): Promise<FormState> => {\n if (!clientFieldSchemaMap && renderFieldFn) {\n // eslint-disable-next-line no-console\n console.warn(\n 'clientFieldSchemaMap is not passed to fieldSchemasToFormState - this will reduce performance',\n )\n }\n\n if (fields && fields.length) {\n const state: FormStateWithoutComponents = {}\n\n const dataWithDefaultValues = { ...data }\n\n await calculateDefaultValues({\n id,\n data: dataWithDefaultValues,\n fields,\n locale: req.locale,\n req,\n select,\n selectMode,\n siblingData: dataWithDefaultValues,\n user: req.user,\n })\n\n let fullData = dataWithDefaultValues\n\n if (documentData) {\n // By the time this function is used to get form state for nested forms, their default values should have already been calculated\n // => no need to run calculateDefaultValues here\n fullData = documentData\n }\n\n await iterateFields({\n id,\n addErrorPathToParent: null,\n blockData: initialBlockData,\n clientFieldSchemaMap,\n collectionSlug,\n data: dataWithDefaultValues,\n fields,\n fieldSchemaMap,\n fullData,\n mockRSCs,\n operation,\n parentIndexPath: '',\n parentPassesCondition: true,\n parentPath: '',\n parentSchemaPath: schemaPath,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn,\n req,\n select,\n selectMode,\n skipValidation,\n state,\n })\n\n return state\n }\n\n return {}\n}\n\nexport { iterateFields }\n"],"names":["calculateDefaultValues","iterateFields","fieldSchemasToFormState","id","clientFieldSchemaMap","collectionSlug","data","documentData","fields","fieldSchemaMap","initialBlockData","mockRSCs","operation","permissions","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","schemaPath","select","selectMode","skipValidation","console","warn","length","state","dataWithDefaultValues","locale","siblingData","user","fullData","addErrorPathToParent","blockData","parentIndexPath","parentPassesCondition","parentPath","parentSchemaPath"],"mappings":"AAiBA,SAASA,sBAAsB,QAAQ,oCAAmC;AAC1E,SAASC,aAAa,QAAQ,qBAAoB;AAGhD;;;;GAIC,GAID;;;;;;;;;;;;;;;GAeC,GAGD;;;;GAIC,GAGD;;;GAGC,GAMD;;;GAGC,GAGD;;;GAGC,GAUH,OAAO,MAAMC,0BAA0B,OAAO,EAC5CC,EAAE,EACFC,oBAAoB,EACpBC,cAAc,EACdC,OAAO,CAAC,CAAC,EACTC,YAAY,EACZC,MAAM,EACNC,cAAc,EACdC,gBAAgB,EAChBC,QAAQ,EACRC,SAAS,EACTC,WAAW,EACXC,WAAW,EACXC,iBAAiB,EACjBC,QAAQ,EACRC,eAAe,EACfC,aAAa,EACbC,GAAG,EACHC,UAAU,EACVC,MAAM,EACNC,UAAU,EACVC,cAAc,EACT;IACL,IAAI,CAACnB,wBAAwBc,eAAe;QAC1C,sCAAsC;QACtCM,QAAQC,IAAI,CACV;IAEJ;IAEA,IAAIjB,UAAUA,OAAOkB,MAAM,EAAE;QAC3B,MAAMC,QAAoC,CAAC;QAE3C,MAAMC,wBAAwB;YAAE,GAAGtB,IAAI;QAAC;QAExC,MAAMN,uBAAuB;YAC3BG;YACAG,MAAMsB;YACNpB;YACAqB,QAAQV,IAAIU,MAAM;YAClBV;YACAE;YACAC;YACAQ,aAAaF;YACbG,MAAMZ,IAAIY,IAAI;QAChB;QAEA,IAAIC,WAAWJ;QAEf,IAAIrB,cAAc;YAChB,iIAAiI;YACjI,gDAAgD;YAChDyB,WAAWzB;QACb;QAEA,MAAMN,cAAc;YAClBE;YACA8B,sBAAsB;YACtBC,WAAWxB;YACXN;YACAC;YACAC,MAAMsB;YACNpB;YACAC;YACAuB;YACArB;YACAC;YACAuB,iBAAiB;YACjBC,uBAAuB;YACvBC,YAAY;YACZC,kBAAkBlB;YAClBP;YACAC;YACAC;YACAC;YACAC;YACAC;YACAC;YACAE;YACAC;YACAC;YACAI;QACF;QAEA,OAAOA;IACT;IAEA,OAAO,CAAC;AACV,EAAC;AAED,SAAS1B,aAAa,GAAE"}
@@ -4,9 +4,9 @@ export function isRowCollapsed({ collapsedPrefs, field, previousRow, row }) {
4
4
  }
5
5
  // If previousFormState is `undefined`, check preferences
6
6
  if (collapsedPrefs !== undefined) {
7
- return collapsedPrefs.includes(row.id) // Check if collapsed in preferences
8
- ;
7
+ return collapsedPrefs.includes(row.id);
9
8
  }
9
+ // Check if collapsed in preferences
10
10
  // If neither exists, fallback to `field.admin.initCollapsed`
11
11
  return field.admin.initCollapsed;
12
12
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/isRowCollapsed.ts"],"sourcesContent":["import type { ArrayField, BlocksField, CollapsedPreferences, Row } from 'payload'\n\nexport function isRowCollapsed({\n collapsedPrefs,\n field,\n previousRow,\n row,\n}: {\n collapsedPrefs: CollapsedPreferences\n field: ArrayField | BlocksField\n previousRow: Row | undefined\n row: Row\n}): boolean {\n if (previousRow && 'collapsed' in previousRow) {\n return previousRow.collapsed ?? false\n }\n\n // If previousFormState is `undefined`, check preferences\n if (collapsedPrefs !== undefined) {\n return collapsedPrefs.includes(row.id) // Check if collapsed in preferences\n }\n\n // If neither exists, fallback to `field.admin.initCollapsed`\n return field.admin.initCollapsed\n}\n"],"names":["isRowCollapsed","collapsedPrefs","field","previousRow","row","collapsed","undefined","includes","id","admin","initCollapsed"],"mappings":"AAEA,OAAO,SAASA,eAAe,EAC7BC,cAAc,EACdC,KAAK,EACLC,WAAW,EACXC,GAAG,EAMJ;IACC,IAAID,eAAe,eAAeA,aAAa;QAC7C,OAAOA,YAAYE,SAAS,IAAI;IAClC;IAEA,yDAAyD;IACzD,IAAIJ,mBAAmBK,WAAW;QAChC,OAAOL,eAAeM,QAAQ,CAACH,IAAII,EAAE,EAAE,oCAAoC;;IAC7E;IAEA,6DAA6D;IAC7D,OAAON,MAAMO,KAAK,CAACC,aAAa;AAClC"}
1
+ {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/isRowCollapsed.ts"],"sourcesContent":["import type { ArrayField, BlocksField, CollapsedPreferences, Row } from 'payload'\n\nexport function isRowCollapsed({\n collapsedPrefs,\n field,\n previousRow,\n row,\n}: {\n collapsedPrefs: CollapsedPreferences\n field: ArrayField | BlocksField\n previousRow: Row | undefined\n row: Row\n}): boolean {\n if (previousRow && 'collapsed' in previousRow) {\n return previousRow.collapsed ?? false\n }\n\n // If previousFormState is `undefined`, check preferences\n if (collapsedPrefs !== undefined) {\n return collapsedPrefs.includes(row.id) // Check if collapsed in preferences\n }\n\n // If neither exists, fallback to `field.admin.initCollapsed`\n return field.admin.initCollapsed\n}\n"],"names":["isRowCollapsed","collapsedPrefs","field","previousRow","row","collapsed","undefined","includes","id","admin","initCollapsed"],"mappings":"AAEA,OAAO,SAASA,eAAe,EAC7BC,cAAc,EACdC,KAAK,EACLC,WAAW,EACXC,GAAG,EAMJ;IACC,IAAID,eAAe,eAAeA,aAAa;QAC7C,OAAOA,YAAYE,SAAS,IAAI;IAClC;IAEA,yDAAyD;IACzD,IAAIJ,mBAAmBK,WAAW;QAChC,OAAOL,eAAeM,QAAQ,CAACH,IAAII,EAAE;IACvC;IADyC,oCAAoC;IAG7E,6DAA6D;IAC7D,OAAON,MAAMO,KAAK,CAACC,aAAa;AAClC"}
@@ -2,6 +2,22 @@ import { stripUnselectedFields } from 'payload';
2
2
  import { getFieldPaths } from 'payload/shared';
3
3
  import { addFieldStatePromise } from './addFieldStatePromise.js';
4
4
  /**
5
+ * if any parents is localized, then the field is localized. @default false
6
+ */ /**
7
+ * Data of the nearest parent block, or undefined
8
+ */ /**
9
+ * Force the value of fields like arrays or blocks to be the full value instead of the length @default false
10
+ */ /**
11
+ * Whether the field schema should be included in the state. @default false
12
+ */ /**
13
+ * Whether to omit parent fields in the state. @default false
14
+ */ /**
15
+ * operation is only needed for validation
16
+ */ /**
17
+ * Whether to skip checking the field's condition. @default false
18
+ */ /**
19
+ * Whether to skip validating the field. @default false
20
+ */ /**
5
21
  * Flattens the fields schema and fields data
6
22
  */ export const iterateFields = async ({ id, addErrorPathToParent: addErrorPathToParentArg, anyParentLocalized = false, blockData, clientFieldSchemaMap, collectionSlug, data, fields, fieldSchemaMap, filter, forceFullValue = false, fullData, includeSchema = false, mockRSCs, omitParents = false, operation, parentIndexPath, parentPassesCondition = true, parentPath, parentSchemaPath, permissions, preferences, previousFormState, readOnly, renderAllFields, renderFieldFn: renderFieldFn, req, select, selectMode, skipConditionChecks = false, skipValidation = false, state = {} })=>{
7
23
  const promises = [];
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/iterateFields.ts"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field as FieldSchema,\n FieldSchemaMap,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n} from 'payload'\n\nimport { stripUnselectedFields } from 'payload'\nimport { getFieldPaths } from 'payload/shared'\n\nimport type { AddFieldStatePromiseArgs } from './addFieldStatePromise.js'\nimport type { RenderFieldMethod } from './types.js'\n\nimport { addFieldStatePromise } from './addFieldStatePromise.js'\n\ntype Args = {\n addErrorPathToParent: (fieldPath: string) => void\n /**\n * if any parents is localized, then the field is localized. @default false\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 fields: FieldSchema[]\n fieldSchemaMap: FieldSchemaMap\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. @default false\n */\n includeSchema?: boolean\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n /**\n * Whether to omit parent fields in the state. @default false\n */\n omitParents?: boolean\n /**\n * operation is only needed for validation\n */\n operation: 'create' | 'update'\n parentIndexPath: string\n parentPassesCondition?: boolean\n parentPath: string\n parentSchemaPath: string\n permissions: SanitizedFieldsPermissions\n preferences?: DocumentPreferences\n previousFormState: FormState\n readOnly?: boolean\n renderAllFields: boolean\n renderFieldFn: RenderFieldMethod\n req: PayloadRequest\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 */\nexport const iterateFields = async ({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized = false,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n fields,\n fieldSchemaMap,\n filter,\n forceFullValue = false,\n fullData,\n includeSchema = false,\n mockRSCs,\n omitParents = false,\n operation,\n parentIndexPath,\n parentPassesCondition = true,\n parentPath,\n parentSchemaPath,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn: renderFieldFn,\n req,\n select,\n selectMode,\n skipConditionChecks = false,\n skipValidation = false,\n state = {},\n}: Args): Promise<void> => {\n const promises = []\n\n fields.forEach((field, fieldIndex) => {\n let passesCondition = true\n\n const { indexPath, path, schemaPath } = getFieldPaths({\n field,\n index: fieldIndex,\n parentIndexPath: 'name' in field ? '' : parentIndexPath,\n parentPath,\n parentSchemaPath,\n })\n\n if (path !== 'id') {\n const shouldContinue = stripUnselectedFields({\n field,\n select,\n selectMode,\n siblingDoc: data,\n })\n\n if (!shouldContinue) {\n return\n }\n }\n\n const pathSegments = path ? path.split('.') : []\n\n if (!skipConditionChecks) {\n try {\n passesCondition = Boolean(\n (field?.admin?.condition\n ? Boolean(\n field.admin.condition(fullData || {}, data || {}, {\n blockData,\n operation,\n path: pathSegments,\n user: req.user,\n }),\n )\n : true) && parentPassesCondition,\n )\n } catch (err) {\n passesCondition = false\n\n req.payload.logger.error({\n err,\n msg: `Error evaluating field condition at path: ${path}`,\n })\n }\n }\n\n promises.push(\n addFieldStatePromise({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n field,\n fieldIndex,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n indexPath,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath,\n parentPath,\n parentPermissions: permissions,\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,\n skipValidation,\n state,\n }),\n )\n })\n\n await Promise.all(promises)\n}\n"],"names":["stripUnselectedFields","getFieldPaths","addFieldStatePromise","iterateFields","id","addErrorPathToParent","addErrorPathToParentArg","anyParentLocalized","blockData","clientFieldSchemaMap","collectionSlug","data","fields","fieldSchemaMap","filter","forceFullValue","fullData","includeSchema","mockRSCs","omitParents","operation","parentIndexPath","parentPassesCondition","parentPath","parentSchemaPath","permissions","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","select","selectMode","skipConditionChecks","skipValidation","state","promises","forEach","field","fieldIndex","passesCondition","indexPath","path","schemaPath","index","shouldContinue","siblingDoc","pathSegments","split","Boolean","admin","condition","user","err","payload","logger","error","msg","push","parentPermissions","Promise","all"],"mappings":"AAeA,SAASA,qBAAqB,QAAQ,UAAS;AAC/C,SAASC,aAAa,QAAQ,iBAAgB;AAK9C,SAASC,oBAAoB,QAAQ,4BAA2B;AA6DhE;;CAEC,GACD,OAAO,MAAMC,gBAAgB,OAAO,EAClCC,EAAE,EACFC,sBAAsBC,uBAAuB,EAC7CC,qBAAqB,KAAK,EAC1BC,SAAS,EACTC,oBAAoB,EACpBC,cAAc,EACdC,IAAI,EACJC,MAAM,EACNC,cAAc,EACdC,MAAM,EACNC,iBAAiB,KAAK,EACtBC,QAAQ,EACRC,gBAAgB,KAAK,EACrBC,QAAQ,EACRC,cAAc,KAAK,EACnBC,SAAS,EACTC,eAAe,EACfC,wBAAwB,IAAI,EAC5BC,UAAU,EACVC,gBAAgB,EAChBC,WAAW,EACXC,WAAW,EACXC,iBAAiB,EACjBC,QAAQ,EACRC,eAAe,EACfC,eAAeA,aAAa,EAC5BC,GAAG,EACHC,MAAM,EACNC,UAAU,EACVC,sBAAsB,KAAK,EAC3BC,iBAAiB,KAAK,EACtBC,QAAQ,CAAC,CAAC,EACL;IACL,MAAMC,WAAW,EAAE;IAEnBzB,OAAO0B,OAAO,CAAC,CAACC,OAAOC;QACrB,IAAIC,kBAAkB;QAEtB,MAAM,EAAEC,SAAS,EAAEC,IAAI,EAAEC,UAAU,EAAE,GAAG3C,cAAc;YACpDsC;YACAM,OAAOL;YACPnB,iBAAiB,UAAUkB,QAAQ,KAAKlB;YACxCE;YACAC;QACF;QAEA,IAAImB,SAAS,MAAM;YACjB,MAAMG,iBAAiB9C,sBAAsB;gBAC3CuC;gBACAP;gBACAC;gBACAc,YAAYpC;YACd;YAEA,IAAI,CAACmC,gBAAgB;gBACnB;YACF;QACF;QAEA,MAAME,eAAeL,OAAOA,KAAKM,KAAK,CAAC,OAAO,EAAE;QAEhD,IAAI,CAACf,qBAAqB;YACxB,IAAI;gBACFO,kBAAkBS,QAChB,AAACX,CAAAA,OAAOY,OAAOC,YACXF,QACEX,MAAMY,KAAK,CAACC,SAAS,CAACpC,YAAY,CAAC,GAAGL,QAAQ,CAAC,GAAG;oBAChDH;oBACAY;oBACAuB,MAAMK;oBACNK,MAAMtB,IAAIsB,IAAI;gBAChB,MAEF,IAAG,KAAM/B;YAEjB,EAAE,OAAOgC,KAAK;gBACZb,kBAAkB;gBAElBV,IAAIwB,OAAO,CAACC,MAAM,CAACC,KAAK,CAAC;oBACvBH;oBACAI,KAAK,CAAC,0CAA0C,EAAEf,MAAM;gBAC1D;YACF;QACF;QAEAN,SAASsB,IAAI,CACXzD,qBAAqB;YACnBE;YACAC,sBAAsBC;YACtBC;YACAC;YACAC;YACAC;YACAC;YACA4B;YACAC;YACA3B;YACAC;YACAC;YACAC;YACAC;YACAyB;YACAxB;YACAC;YACAC;YACAC;YACAE;YACAqC,mBAAmBnC;YACnBD;YACAiB;YACAE;YACAjB;YACAC;YACAC;YACAC;YACAC;YACAC;YACAa;YACAZ;YACAC;YACAC;YACAC;YACAC;QACF;IAEJ;IAEA,MAAMyB,QAAQC,GAAG,CAACzB;AACpB,EAAC"}
1
+ {"version":3,"sources":["../../../src/forms/fieldSchemasToFormState/iterateFields.ts"],"sourcesContent":["import type {\n BuildFormStateArgs,\n ClientFieldSchemaMap,\n Data,\n DocumentPreferences,\n Field as FieldSchema,\n FieldSchemaMap,\n FormState,\n FormStateWithoutComponents,\n PayloadRequest,\n SanitizedFieldsPermissions,\n SelectMode,\n SelectType,\n} from 'payload'\n\nimport { stripUnselectedFields } from 'payload'\nimport { getFieldPaths } from 'payload/shared'\n\nimport type { AddFieldStatePromiseArgs } from './addFieldStatePromise.js'\nimport type { RenderFieldMethod } from './types.js'\n\nimport { addFieldStatePromise } from './addFieldStatePromise.js'\n\ntype Args = {\n addErrorPathToParent: (fieldPath: string) => void\n /**\n * if any parents is localized, then the field is localized. @default false\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 fields: FieldSchema[]\n fieldSchemaMap: FieldSchemaMap\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. @default false\n */\n includeSchema?: boolean\n mockRSCs?: BuildFormStateArgs['mockRSCs']\n /**\n * Whether to omit parent fields in the state. @default false\n */\n omitParents?: boolean\n /**\n * operation is only needed for validation\n */\n operation: 'create' | 'update'\n parentIndexPath: string\n parentPassesCondition?: boolean\n parentPath: string\n parentSchemaPath: string\n permissions: SanitizedFieldsPermissions\n preferences?: DocumentPreferences\n previousFormState: FormState\n readOnly?: boolean\n renderAllFields: boolean\n renderFieldFn: RenderFieldMethod\n req: PayloadRequest\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 */\nexport const iterateFields = async ({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized = false,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n fields,\n fieldSchemaMap,\n filter,\n forceFullValue = false,\n fullData,\n includeSchema = false,\n mockRSCs,\n omitParents = false,\n operation,\n parentIndexPath,\n parentPassesCondition = true,\n parentPath,\n parentSchemaPath,\n permissions,\n preferences,\n previousFormState,\n readOnly,\n renderAllFields,\n renderFieldFn: renderFieldFn,\n req,\n select,\n selectMode,\n skipConditionChecks = false,\n skipValidation = false,\n state = {},\n}: Args): Promise<void> => {\n const promises = []\n\n fields.forEach((field, fieldIndex) => {\n let passesCondition = true\n\n const { indexPath, path, schemaPath } = getFieldPaths({\n field,\n index: fieldIndex,\n parentIndexPath: 'name' in field ? '' : parentIndexPath,\n parentPath,\n parentSchemaPath,\n })\n\n if (path !== 'id') {\n const shouldContinue = stripUnselectedFields({\n field,\n select,\n selectMode,\n siblingDoc: data,\n })\n\n if (!shouldContinue) {\n return\n }\n }\n\n const pathSegments = path ? path.split('.') : []\n\n if (!skipConditionChecks) {\n try {\n passesCondition = Boolean(\n (field?.admin?.condition\n ? Boolean(\n field.admin.condition(fullData || {}, data || {}, {\n blockData,\n operation,\n path: pathSegments,\n user: req.user,\n }),\n )\n : true) && parentPassesCondition,\n )\n } catch (err) {\n passesCondition = false\n\n req.payload.logger.error({\n err,\n msg: `Error evaluating field condition at path: ${path}`,\n })\n }\n }\n\n promises.push(\n addFieldStatePromise({\n id,\n addErrorPathToParent: addErrorPathToParentArg,\n anyParentLocalized,\n blockData,\n clientFieldSchemaMap,\n collectionSlug,\n data,\n field,\n fieldIndex,\n fieldSchemaMap,\n filter,\n forceFullValue,\n fullData,\n includeSchema,\n indexPath,\n mockRSCs,\n omitParents,\n operation,\n parentIndexPath,\n parentPath,\n parentPermissions: permissions,\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,\n skipValidation,\n state,\n }),\n )\n })\n\n await Promise.all(promises)\n}\n"],"names":["stripUnselectedFields","getFieldPaths","addFieldStatePromise","iterateFields","id","addErrorPathToParent","addErrorPathToParentArg","anyParentLocalized","blockData","clientFieldSchemaMap","collectionSlug","data","fields","fieldSchemaMap","filter","forceFullValue","fullData","includeSchema","mockRSCs","omitParents","operation","parentIndexPath","parentPassesCondition","parentPath","parentSchemaPath","permissions","preferences","previousFormState","readOnly","renderAllFields","renderFieldFn","req","select","selectMode","skipConditionChecks","skipValidation","state","promises","forEach","field","fieldIndex","passesCondition","indexPath","path","schemaPath","index","shouldContinue","siblingDoc","pathSegments","split","Boolean","admin","condition","user","err","payload","logger","error","msg","push","parentPermissions","Promise","all"],"mappings":"AAeA,SAASA,qBAAqB,QAAQ,UAAS;AAC/C,SAASC,aAAa,QAAQ,iBAAgB;AAK9C,SAASC,oBAAoB,QAAQ,4BAA2B;AAI9D;;GAEC,GAED;;GAEC,GAQD;;GAEC,GAID;;GAEC,GAGD;;GAEC,GAED;;GAEC,GAeD;;GAEC,GAED;;GAEC,GAKH;;CAEC,GACD,OAAO,MAAMC,gBAAgB,OAAO,EAClCC,EAAE,EACFC,sBAAsBC,uBAAuB,EAC7CC,qBAAqB,KAAK,EAC1BC,SAAS,EACTC,oBAAoB,EACpBC,cAAc,EACdC,IAAI,EACJC,MAAM,EACNC,cAAc,EACdC,MAAM,EACNC,iBAAiB,KAAK,EACtBC,QAAQ,EACRC,gBAAgB,KAAK,EACrBC,QAAQ,EACRC,cAAc,KAAK,EACnBC,SAAS,EACTC,eAAe,EACfC,wBAAwB,IAAI,EAC5BC,UAAU,EACVC,gBAAgB,EAChBC,WAAW,EACXC,WAAW,EACXC,iBAAiB,EACjBC,QAAQ,EACRC,eAAe,EACfC,eAAeA,aAAa,EAC5BC,GAAG,EACHC,MAAM,EACNC,UAAU,EACVC,sBAAsB,KAAK,EAC3BC,iBAAiB,KAAK,EACtBC,QAAQ,CAAC,CAAC,EACL;IACL,MAAMC,WAAW,EAAE;IAEnBzB,OAAO0B,OAAO,CAAC,CAACC,OAAOC;QACrB,IAAIC,kBAAkB;QAEtB,MAAM,EAAEC,SAAS,EAAEC,IAAI,EAAEC,UAAU,EAAE,GAAG3C,cAAc;YACpDsC;YACAM,OAAOL;YACPnB,iBAAiB,UAAUkB,QAAQ,KAAKlB;YACxCE;YACAC;QACF;QAEA,IAAImB,SAAS,MAAM;YACjB,MAAMG,iBAAiB9C,sBAAsB;gBAC3CuC;gBACAP;gBACAC;gBACAc,YAAYpC;YACd;YAEA,IAAI,CAACmC,gBAAgB;gBACnB;YACF;QACF;QAEA,MAAME,eAAeL,OAAOA,KAAKM,KAAK,CAAC,OAAO,EAAE;QAEhD,IAAI,CAACf,qBAAqB;YACxB,IAAI;gBACFO,kBAAkBS,QAChB,AAACX,CAAAA,OAAOY,OAAOC,YACXF,QACEX,MAAMY,KAAK,CAACC,SAAS,CAACpC,YAAY,CAAC,GAAGL,QAAQ,CAAC,GAAG;oBAChDH;oBACAY;oBACAuB,MAAMK;oBACNK,MAAMtB,IAAIsB,IAAI;gBAChB,MAEF,IAAG,KAAM/B;YAEjB,EAAE,OAAOgC,KAAK;gBACZb,kBAAkB;gBAElBV,IAAIwB,OAAO,CAACC,MAAM,CAACC,KAAK,CAAC;oBACvBH;oBACAI,KAAK,CAAC,0CAA0C,EAAEf,MAAM;gBAC1D;YACF;QACF;QAEAN,SAASsB,IAAI,CACXzD,qBAAqB;YACnBE;YACAC,sBAAsBC;YACtBC;YACAC;YACAC;YACAC;YACAC;YACA4B;YACAC;YACA3B;YACAC;YACAC;YACAC;YACAC;YACAyB;YACAxB;YACAC;YACAC;YACAC;YACAE;YACAqC,mBAAmBnC;YACnBD;YACAiB;YACAE;YACAjB;YACAC;YACAC;YACAC;YACAC;YACAC;YACAa;YACAZ;YACAC;YACAC;YACAC;YACAC;QACF;IAEJ;IAEA,MAAMyB,QAAQC,GAAG,CAACzB;AACpB,EAAC"}
@@ -150,9 +150,9 @@ export const renderField = ({ id, clientFieldSchemaMap, collectionSlug, data, fi
150
150
  case 'richText':
151
151
  {
152
152
  if (!fieldConfig?.editor) {
153
- throw new MissingEditorProp(fieldConfig) // while we allow disabling editor functionality, you should not have any richText fields defined if you do not have an editor
154
- ;
153
+ throw new MissingEditorProp(fieldConfig);
155
154
  }
155
+ // while we allow disabling editor functionality, you should not have any richText fields defined if you do not have an editor
156
156
  if (typeof fieldConfig?.editor === 'function') {
157
157
  throw new Error('Attempted to access unsanitized rich text editor.');
158
158
  }