@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.
- package/dist/elements/AnimateHeight/usePatchAnimateHeight.js +2 -2
- package/dist/elements/AnimateHeight/usePatchAnimateHeight.js.map +1 -1
- package/dist/elements/Autosave/index.js +1 -0
- package/dist/elements/Autosave/index.js.map +1 -1
- package/dist/elements/BulkUpload/EditMany/index.js +2 -2
- package/dist/elements/BulkUpload/EditMany/index.js.map +1 -1
- package/dist/elements/BulkUpload/FormsManager/index.js +8 -8
- package/dist/elements/BulkUpload/FormsManager/index.js.map +1 -1
- package/dist/elements/BulkUpload/index.js +12 -1
- package/dist/elements/BulkUpload/index.js.map +1 -1
- package/dist/elements/Button/index.js +2 -2
- package/dist/elements/Button/index.js.map +1 -1
- package/dist/elements/Button/types.js +13 -1
- package/dist/elements/Button/types.js.map +1 -1
- package/dist/elements/Card/index.js +5 -1
- package/dist/elements/Card/index.js.map +1 -1
- package/dist/elements/CodeEditor/CodeEditor.js +2 -2
- package/dist/elements/CodeEditor/CodeEditor.js.map +1 -1
- package/dist/elements/CodeEditor/types.js +3 -1
- package/dist/elements/CodeEditor/types.js.map +1 -1
- package/dist/elements/Collapsible/index.js +8 -1
- package/dist/elements/Collapsible/index.js.map +1 -1
- package/dist/elements/Combobox/index.js +6 -0
- package/dist/elements/Combobox/index.js.map +1 -1
- package/dist/elements/DatePicker/DatePicker.js +1 -0
- package/dist/elements/DatePicker/DatePicker.js.map +1 -1
- package/dist/elements/DatePicker/getFormattedLocale.js +1 -0
- package/dist/elements/DatePicker/getFormattedLocale.js.map +1 -1
- package/dist/elements/DeleteMany/index.js +25 -1
- package/dist/elements/DeleteMany/index.js.map +1 -1
- package/dist/elements/DocumentControls/index.js +1 -1
- package/dist/elements/DocumentControls/index.js.map +1 -1
- package/dist/elements/DocumentDrawer/Provider.js +5 -1
- package/dist/elements/DocumentDrawer/Provider.js.map +1 -1
- package/dist/elements/DocumentDrawer/types.js +11 -1
- package/dist/elements/DocumentDrawer/types.js.map +1 -1
- package/dist/elements/DraggableSortable/useDraggableSortable/index.js +1 -0
- package/dist/elements/DraggableSortable/useDraggableSortable/index.js.map +1 -1
- package/dist/elements/Drawer/index.js +3 -1
- package/dist/elements/Drawer/index.js.map +1 -1
- package/dist/elements/EditMany/DrawerContent.js +15 -1
- package/dist/elements/EditMany/DrawerContent.js.map +1 -1
- package/dist/elements/EditMany/index.js +3 -1
- package/dist/elements/EditMany/index.js.map +1 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js +8 -1
- package/dist/elements/FolderView/Drawers/MoveToFolder/index.js.map +1 -1
- package/dist/elements/FolderView/FolderFileCard/index.js +1 -0
- package/dist/elements/FolderView/FolderFileCard/index.js.map +1 -1
- package/dist/elements/FolderView/MoveDocToFolder/index.js +2 -3
- package/dist/elements/FolderView/MoveDocToFolder/index.js.map +1 -1
- package/dist/elements/HTMLDiff/diff/index.js +24 -3
- package/dist/elements/HTMLDiff/diff/index.js.map +1 -1
- package/dist/elements/HydrateAuthProvider/index.js +6 -1
- package/dist/elements/HydrateAuthProvider/index.js.map +1 -1
- package/dist/elements/LeaveWithoutSaving/usePreventLeave.js +3 -1
- package/dist/elements/LeaveWithoutSaving/usePreventLeave.js.map +1 -1
- package/dist/elements/Link/index.js +5 -1
- package/dist/elements/Link/index.js.map +1 -1
- package/dist/elements/ListControls/types.js +7 -1
- package/dist/elements/ListControls/types.js.map +1 -1
- package/dist/elements/ListDrawer/DrawerContent.js +2 -2
- package/dist/elements/ListDrawer/DrawerContent.js.map +1 -1
- package/dist/elements/ListDrawer/Provider.js +8 -1
- package/dist/elements/ListDrawer/Provider.js.map +1 -1
- package/dist/elements/ListDrawer/index.js +2 -1
- package/dist/elements/ListDrawer/index.js.map +1 -1
- package/dist/elements/ListDrawer/types.js +5 -1
- package/dist/elements/ListDrawer/types.js.map +1 -1
- package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js +5 -1
- package/dist/elements/ListHeader/TitleActions/ListBulkUploadButton.js.map +1 -1
- package/dist/elements/ListSelection/index.js +11 -1
- package/dist/elements/ListSelection/index.js.map +1 -1
- package/dist/elements/LivePreview/Toolbar/Controls/index.js +1 -1
- package/dist/elements/LivePreview/Toolbar/Controls/index.js.map +1 -1
- package/dist/elements/Logout/index.js +5 -1
- package/dist/elements/Logout/index.js.map +1 -1
- package/dist/elements/Pill/index.js +5 -2
- package/dist/elements/Pill/index.js.map +1 -1
- package/dist/elements/PublishMany/index.js +3 -1
- package/dist/elements/PublishMany/index.js.map +1 -1
- package/dist/elements/QueryPresets/QueryPresetBar/index.js +1 -2
- package/dist/elements/QueryPresets/QueryPresetBar/index.js.map +1 -1
- package/dist/elements/ReactSelect/index.js +2 -2
- package/dist/elements/ReactSelect/index.js.map +1 -1
- package/dist/elements/ReactSelect/types.js +8 -1
- package/dist/elements/ReactSelect/types.js.map +1 -1
- package/dist/elements/RelationshipTable/index.js +2 -2
- package/dist/elements/RelationshipTable/index.js.map +1 -1
- package/dist/elements/RestoreMany/index.js +1 -0
- package/dist/elements/RestoreMany/index.js.map +1 -1
- package/dist/elements/SaveButton/index.js +1 -2
- package/dist/elements/SaveButton/index.js.map +1 -1
- package/dist/elements/SaveDraftButton/index.js +1 -2
- package/dist/elements/SaveDraftButton/index.js.map +1 -1
- package/dist/elements/SearchFilter/types.js +19 -1
- package/dist/elements/SearchFilter/types.js.map +1 -1
- package/dist/elements/Status/index.js +2 -2
- package/dist/elements/Status/index.js.map +1 -1
- package/dist/elements/StepNav/index.js +5 -1
- package/dist/elements/StepNav/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/fields/Select/index.js +4 -4
- package/dist/elements/Table/DefaultCell/fields/Select/index.js.map +1 -1
- package/dist/elements/Table/DefaultCell/index.js +2 -1
- package/dist/elements/Table/DefaultCell/index.js.map +1 -1
- package/dist/elements/Table/RelationshipProvider/index.js +3 -0
- package/dist/elements/Table/RelationshipProvider/index.js.map +1 -1
- package/dist/elements/Thumbnail/createThumbnail.js +12 -12
- package/dist/elements/Thumbnail/createThumbnail.js.map +1 -1
- package/dist/elements/Tooltip/index.js +3 -1
- package/dist/elements/Tooltip/index.js.map +1 -1
- package/dist/elements/UnpublishMany/index.js +3 -1
- package/dist/elements/UnpublishMany/index.js.map +1 -1
- package/dist/elements/Upload/index.js +8 -8
- package/dist/elements/Upload/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Number/index.js +1 -0
- package/dist/elements/WhereBuilder/Condition/Number/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Relationship/index.js +5 -6
- package/dist/elements/WhereBuilder/Condition/Relationship/index.js.map +1 -1
- package/dist/elements/WhereBuilder/Condition/Text/index.js +1 -0
- package/dist/elements/WhereBuilder/Condition/Text/index.js.map +1 -1
- package/dist/elements/WhereBuilder/index.js +2 -2
- package/dist/elements/WhereBuilder/index.js.map +1 -1
- package/dist/exports/client/index.js +26 -2
- package/dist/exports/client/index.js.map +1 -1
- package/dist/exports/shared/index.js +2 -1
- package/dist/exports/shared/index.js.map +1 -1
- package/dist/fields/Blocks/BlockSelector/index.js +3 -1
- package/dist/fields/Blocks/BlockSelector/index.js.map +1 -1
- package/dist/fields/Email/index.js +1 -1
- package/dist/fields/Email/index.js.map +1 -1
- package/dist/fields/Group/index.js +1 -1
- package/dist/fields/Group/index.js.map +1 -1
- package/dist/fields/Number/index.js +5 -3
- package/dist/fields/Number/index.js.map +1 -1
- package/dist/fields/Password/types.js +11 -1
- package/dist/fields/Password/types.js.map +1 -1
- package/dist/fields/Point/index.js +2 -2
- package/dist/fields/Point/index.js.map +1 -1
- package/dist/fields/Relationship/select-components/MultiValueLabel/index.js +4 -1
- package/dist/fields/Relationship/select-components/MultiValueLabel/index.js.map +1 -1
- package/dist/fields/Relationship/select-components/SingleValue/index.js +4 -1
- package/dist/fields/Relationship/select-components/SingleValue/index.js.map +1 -1
- package/dist/fields/Text/index.js +3 -2
- package/dist/fields/Text/index.js.map +1 -1
- package/dist/fields/Upload/Input.js +3 -1
- package/dist/fields/Upload/Input.js.map +1 -1
- package/dist/fields/Upload/types.js +1 -0
- package/dist/fields/Upload/types.js.map +1 -1
- package/dist/fields/shared/index.js +2 -3
- package/dist/fields/shared/index.js.map +1 -1
- package/dist/forms/Form/fieldReducer.js +2 -1
- package/dist/forms/Form/fieldReducer.js.map +1 -1
- package/dist/forms/Form/index.js +12 -9
- package/dist/forms/Form/index.js.map +1 -1
- package/dist/forms/Form/mergeServerFormState.js +11 -3
- package/dist/forms/Form/mergeServerFormState.js.map +1 -1
- package/dist/forms/Form/reduceToSerializableFields.js +2 -2
- package/dist/forms/Form/reduceToSerializableFields.js.map +1 -1
- package/dist/forms/Form/types.js +52 -1
- package/dist/forms/Form/types.js.map +1 -1
- package/dist/forms/NullifyField/index.js +2 -1
- package/dist/forms/NullifyField/index.js.map +1 -1
- package/dist/forms/WatchChildErrors/index.js +6 -1
- package/dist/forms/WatchChildErrors/index.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js +20 -0
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/index.js +33 -1
- package/dist/forms/fieldSchemasToFormState/index.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js +2 -2
- package/dist/forms/fieldSchemasToFormState/isRowCollapsed.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/iterateFields.js +16 -0
- package/dist/forms/fieldSchemasToFormState/iterateFields.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/renderField.js +2 -2
- package/dist/forms/fieldSchemasToFormState/renderField.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js +22 -1
- package/dist/forms/fieldSchemasToFormState/serverFunctions/renderFieldServerFn.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/types.js +5 -1
- package/dist/forms/fieldSchemasToFormState/types.js.map +1 -1
- package/dist/forms/useField/index.js +1 -0
- package/dist/forms/useField/index.js.map +1 -1
- package/dist/forms/useField/types.js +19 -1
- package/dist/forms/useField/types.js.map +1 -1
- package/dist/hooks/useControllableState.js +9 -1
- package/dist/hooks/useControllableState.js.map +1 -1
- package/dist/hooks/useDelayedRender.js +3 -1
- package/dist/hooks/useDelayedRender.js.map +1 -1
- package/dist/hooks/useHotkey.js +2 -2
- package/dist/hooks/useHotkey.js.map +1 -1
- package/dist/hooks/usePayloadAPI.js +3 -4
- package/dist/hooks/usePayloadAPI.js.map +1 -1
- package/dist/hooks/usePopupWindow.js +2 -2
- package/dist/hooks/usePopupWindow.js.map +1 -1
- package/dist/hooks/useQueue.js +15 -7
- package/dist/hooks/useQueue.js.map +1 -1
- package/dist/hooks/useResize.js +4 -3
- package/dist/hooks/useResize.js.map +1 -1
- package/dist/providers/Auth/index.js +35 -3
- package/dist/providers/Auth/index.js.map +1 -1
- package/dist/providers/Config/index.js +10 -1
- package/dist/providers/Config/index.js.map +1 -1
- package/dist/providers/DocumentInfo/index.js +6 -7
- package/dist/providers/DocumentInfo/index.js.map +1 -1
- package/dist/providers/DocumentInfo/types.js +25 -1
- package/dist/providers/DocumentInfo/types.js.map +1 -1
- package/dist/providers/Folders/index.js +44 -2
- package/dist/providers/Folders/index.js.map +1 -1
- package/dist/providers/ListQuery/types.js +5 -1
- package/dist/providers/ListQuery/types.js.map +1 -1
- package/dist/providers/LivePreview/context.js +11 -1
- package/dist/providers/LivePreview/context.js.map +1 -1
- package/dist/providers/LivePreview/index.js +7 -4
- package/dist/providers/LivePreview/index.js.map +1 -1
- package/dist/providers/Preferences/index.js +7 -2
- package/dist/providers/Preferences/index.js.map +1 -1
- package/dist/providers/RouteTransition/index.js +9 -9
- package/dist/providers/RouteTransition/index.js.map +1 -1
- package/dist/providers/Selection/index.js +7 -2
- package/dist/providers/Selection/index.js.map +1 -1
- package/dist/providers/ServerFunctions/index.js +25 -22
- package/dist/providers/ServerFunctions/index.js.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/index.js +10 -9
- package/dist/providers/TableColumns/buildColumnState/index.js.map +1 -1
- package/dist/providers/TableColumns/buildColumnState/renderCell.js +4 -3
- package/dist/providers/TableColumns/buildColumnState/renderCell.js.map +1 -1
- package/dist/providers/TableColumns/types.js +17 -1
- package/dist/providers/TableColumns/types.js.map +1 -1
- package/dist/utilities/abortAndIgnore.js +4 -6
- package/dist/utilities/abortAndIgnore.js.map +1 -1
- package/dist/utilities/buildFieldSchemaMap/traverseFields.js +2 -2
- package/dist/utilities/buildFieldSchemaMap/traverseFields.js.map +1 -1
- package/dist/utilities/copyDataFromLocale.js +6 -2
- package/dist/utilities/copyDataFromLocale.js.map +1 -1
- package/dist/utilities/getDisplayedFieldValue.js +8 -8
- package/dist/utilities/getDisplayedFieldValue.js.map +1 -1
- package/dist/utilities/getFolderResultsComponentAndData.js +2 -1
- package/dist/utilities/getFolderResultsComponentAndData.js.map +1 -1
- package/dist/utilities/handleFormStateLocking.js +2 -2
- package/dist/utilities/handleFormStateLocking.js.map +1 -1
- package/dist/utilities/hasSavePermission.js +5 -1
- package/dist/utilities/hasSavePermission.js.map +1 -1
- package/dist/utilities/isURLAllowed.js +6 -6
- package/dist/utilities/isURLAllowed.js.map +1 -1
- package/dist/utilities/renderTable.js +2 -1
- package/dist/utilities/renderTable.js.map +1 -1
- package/dist/utilities/schedulePublishHandler.js +3 -1
- package/dist/utilities/schedulePublishHandler.js.map +1 -1
- package/dist/utilities/upsertPreferences.js +1 -0
- package/dist/utilities/upsertPreferences.js.map +1 -1
- package/dist/views/Edit/index.js +7 -7
- package/dist/views/Edit/index.js.map +1 -1
- package/dist/views/List/ListHeader/index.js +6 -1
- package/dist/views/List/ListHeader/index.js.map +1 -1
- package/package.json +6 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/forms/Form/fieldReducer.ts"],"sourcesContent":["'use client'\nimport type { FormField, FormState, Row } from 'payload'\n\nimport ObjectIdImport from 'bson-objectid'\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\nimport { deepCopyObjectSimpleWithoutReactComponents } from 'payload/shared'\n\nimport type { FieldAction } from './types.js'\n\nimport { mergeServerFormState } from './mergeServerFormState.js'\nimport { flattenRows, separateRows } from './rows.js'\n\nconst ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectIdImport\n\n/**\n * Reducer which modifies the form field state (all the current data of the fields in the form). When called using dispatch, it will return a new state object.\n */\nexport function fieldReducer(state: FormState, action: FieldAction): FormState {\n switch (action.type) {\n case 'ADD_ROW': {\n const { blockType, path, rowIndex: rowIndexFromArgs, subFieldState = {} } = action\n\n const rowIndex =\n typeof rowIndexFromArgs === 'number' ? rowIndexFromArgs : state[path]?.rows?.length || 0\n\n const withNewRow = [...(state[path]?.rows || [])]\n\n const newRow: Row = {\n id: (subFieldState?.id?.value as string) || new ObjectId().toHexString(),\n isLoading: true,\n }\n\n if (blockType) {\n newRow.blockType = blockType\n }\n\n withNewRow.splice(rowIndex, 0, newRow)\n\n if (blockType) {\n subFieldState.blockType = {\n initialValue: blockType,\n valid: true,\n value: blockType,\n }\n }\n\n // add new row to array _field state_\n const { remainingFields, rows: siblingRows } = separateRows(path, state)\n\n siblingRows.splice(rowIndex, 0, subFieldState)\n\n const newState: FormState = {\n ...remainingFields,\n ...flattenRows(path, siblingRows),\n [`${path}.${rowIndex}.id`]: {\n initialValue: newRow.id,\n passesCondition: true,\n valid: true,\n value: newRow.id,\n },\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: withNewRow,\n value: siblingRows.length,\n },\n }\n\n return newState\n }\n\n case 'ADD_SERVER_ERRORS': {\n let newState = { ...state }\n\n const errorPaths: { fieldErrorPath: string; parentPath: string }[] = []\n\n action.errors.forEach(({ message, path: fieldPath }) => {\n newState[fieldPath] = {\n ...(newState[fieldPath] || {\n initialValue: null,\n value: null,\n }),\n errorMessage: message,\n valid: false,\n }\n\n const segments = fieldPath.split('.')\n if (segments.length > 1) {\n errorPaths.push({\n fieldErrorPath: fieldPath,\n parentPath: segments.slice(0, segments.length - 1).join('.'),\n })\n }\n })\n\n newState = Object.entries(newState).reduce((acc, [path, fieldState]) => {\n const fieldErrorPaths = errorPaths.reduce((errorACC, { fieldErrorPath, parentPath }) => {\n if (parentPath.startsWith(path)) {\n errorACC.push(fieldErrorPath)\n }\n return errorACC\n }, [])\n\n let changed = false\n\n if (fieldErrorPaths.length > 0) {\n const newErrorPaths = Array.isArray(fieldState.errorPaths) ? fieldState.errorPaths : []\n\n fieldErrorPaths.forEach((fieldErrorPath) => {\n if (!newErrorPaths.includes(fieldErrorPath)) {\n newErrorPaths.push(fieldErrorPath)\n changed = true\n }\n })\n\n if (changed) {\n acc[path] = {\n ...fieldState,\n errorPaths: newErrorPaths,\n }\n }\n }\n\n if (!changed) {\n acc[path] = fieldState\n }\n\n return acc\n }, {})\n\n return newState\n }\n\n /**\n * Duplicates a row in an array or blocks field.\n * It needs to manipulate two distinct parts of the form state:\n * - The `rows` property of the parent field, e.g. `array.rows`, `blocks.rows`, etc.\n * - The row's state, e.g. `array.0.id`, `array.0.text`, etc.\n */\n case 'DUPLICATE_ROW': {\n const { path, rowIndex } = action\n const { remainingFields, rows } = separateRows(path, state)\n\n // 1. Duplicate the `rows` property of the parent field, e.g. `array.rows`, `blocks.rows`, etc.\n const newRows = [...(state[path].rows || [])]\n\n const newRow = deepCopyObjectSimpleWithoutReactComponents(newRows[rowIndex])\n\n const newRowID = new ObjectId().toHexString()\n\n if (newRow.id) {\n newRow.id = newRowID\n }\n\n if (newRows[rowIndex]?.customComponents?.RowLabel) {\n newRow.customComponents = {\n RowLabel: newRows[rowIndex].customComponents.RowLabel,\n }\n }\n\n // 2. Duplicate the row's state, e.g. `array.0.id`, `array.0.text`, etc.\n const newRowState = deepCopyObjectSimpleWithoutReactComponents(rows[rowIndex])\n\n // Ensure that `id` in form state exactly matches the row id on the parent field\n if (newRowState.id) {\n newRowState.id.value = newRowID\n newRowState.id.initialValue = newRowID\n }\n\n // Generate new ids for all nested id fields, e.g. `array.0.nestedArray.0.id`\n for (const key of Object.keys(newRowState).filter((key) => key.endsWith('.id'))) {\n const idState = newRowState[key]\n\n const newNestedFieldID = new ObjectId().toHexString()\n\n if (idState && typeof idState.value === 'string' && ObjectId.isValid(idState.value)) {\n newRowState[key].value = newNestedFieldID\n newRowState[key].initialValue = newNestedFieldID\n\n // Apply the ID to its corresponding parent field's rows, e.g. `array.0.nestedArray.rows[0].id`\n const segments = key.split('.')\n const rowIndex = parseInt(segments[segments.length - 2], 10)\n const parentFieldPath = segments.slice(0, segments.length - 2).join('.')\n const parentFieldRows = newRowState?.[parentFieldPath]?.rows\n\n if (newRowState[parentFieldPath] && Array.isArray(parentFieldRows)) {\n if (!parentFieldRows[rowIndex]) {\n parentFieldRows[rowIndex] = {\n id: newNestedFieldID,\n }\n } else {\n parentFieldRows[rowIndex].id = newNestedFieldID\n }\n }\n }\n }\n\n // If there are subfields\n if (Object.keys(newRowState).length > 0) {\n // Add new object containing subfield names to unflattenedRows array\n rows.splice(rowIndex + 1, 0, newRowState)\n newRows.splice(rowIndex + 1, 0, newRow)\n }\n\n const newState = {\n ...remainingFields,\n ...flattenRows(path, rows),\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: newRows,\n value: rows.length,\n },\n }\n\n return newState\n }\n\n case 'MERGE_SERVER_STATE': {\n const { acceptValues, prevStateRef, serverState } = action\n\n const newState = mergeServerFormState({\n acceptValues,\n currentState: state || {},\n incomingState: serverState,\n })\n\n prevStateRef.current = newState\n\n return newState\n }\n\n case 'MOVE_ROW': {\n const { moveFromIndex, moveToIndex, path } = action\n\n // Handle moving rows on the top-level, i.e. `array.0.text` -> `array.1.text`\n const { remainingFields, rows: topLevelRows } = separateRows(path, state)\n const copyOfMovingRow = topLevelRows[moveFromIndex]\n topLevelRows.splice(moveFromIndex, 1)\n topLevelRows.splice(moveToIndex, 0, copyOfMovingRow)\n\n // modify array/block internal row state (i.e. collapsed, blockType)\n const rowsWithinField = [...(state[path]?.rows || [])]\n const copyOfMovingRow2 = { ...rowsWithinField[moveFromIndex] }\n rowsWithinField.splice(moveFromIndex, 1)\n rowsWithinField.splice(moveToIndex, 0, copyOfMovingRow2)\n\n const newState = {\n ...remainingFields,\n ...flattenRows(path, topLevelRows),\n [path]: {\n ...state[path],\n rows: rowsWithinField,\n },\n }\n\n return newState\n }\n\n case 'REMOVE': {\n const newState = { ...state }\n if (newState[action.path]) {\n delete newState[action.path]\n }\n return newState\n }\n\n case 'REMOVE_ROW': {\n const { path, rowIndex } = action\n const { remainingFields, rows } = separateRows(path, state)\n const rowsMetadata = [...(state[path]?.rows || [])]\n\n rows.splice(rowIndex, 1)\n rowsMetadata.splice(rowIndex, 1)\n\n const newState: FormState = {\n ...remainingFields,\n [path]: {\n ...state[path],\n disableFormData: rows.length > 0,\n rows: rowsMetadata,\n value: rows.length,\n },\n ...flattenRows(path, rows),\n }\n\n return newState\n }\n\n case 'REPLACE_ROW': {\n const { blockType, path, rowIndex: rowIndexArg, subFieldState = {} } = action\n\n const { remainingFields, rows: siblingRows } = separateRows(path, state)\n const rowIndex = Math.max(0, Math.min(rowIndexArg, siblingRows?.length - 1 || 0))\n\n const rowsMetadata = [...(state[path]?.rows || [])]\n rowsMetadata[rowIndex] = {\n id: new ObjectId().toHexString(),\n blockType: blockType || undefined,\n collapsed: false,\n }\n\n if (blockType) {\n subFieldState.blockType = {\n initialValue: blockType,\n valid: true,\n value: blockType,\n }\n }\n\n // replace form _field state_\n siblingRows[rowIndex] = subFieldState\n\n const newState: FormState = {\n ...remainingFields,\n ...flattenRows(path, siblingRows),\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: rowsMetadata,\n value: siblingRows.length,\n },\n }\n\n return newState\n }\n\n case 'REPLACE_STATE': {\n if (action.optimize !== false) {\n // Only update fields that have changed\n // by comparing old value / initialValue to new\n // ..\n // This is a performance enhancement for saving\n // large documents with hundreds of fields\n const newState: FormState = {}\n\n for (const [path, newField] of Object.entries(action.state)) {\n const oldField = state[path]\n\n if (newField.valid !== false) {\n newField.valid = true\n }\n if (newField.passesCondition !== false) {\n newField.passesCondition = true\n }\n\n if (!dequal(oldField, newField)) {\n newState[path] = newField\n } else if (oldField) {\n newState[path] = oldField\n }\n }\n\n return newState\n }\n\n // TODO: Remove this in 4.0 - this is a temporary fix to prevent a breaking change\n if (action.sanitize) {\n for (const field of Object.values(action.state)) {\n if (field.valid !== false) {\n field.valid = true\n }\n if (field.passesCondition !== false) {\n field.passesCondition = true\n }\n }\n }\n // If we're not optimizing, just set the state to the new state\n return action.state\n }\n\n case 'SET_ALL_ROWS_COLLAPSED': {\n const { path, updatedRows } = action\n\n return {\n ...state,\n [path]: {\n ...state[path],\n rows: updatedRows,\n },\n }\n }\n\n case 'SET_ROW_COLLAPSED': {\n const { path, updatedRows } = action\n\n const newState = {\n ...state,\n [path]: {\n ...state[path],\n rows: updatedRows,\n },\n }\n\n return newState\n }\n\n case 'UPDATE': {\n const newField = Object.entries(action).reduce(\n (field, [key, value]) => {\n if (\n [\n 'disableFormData',\n 'errorMessage',\n 'initialValue',\n 'rows',\n 'valid',\n 'validate',\n 'value',\n ].includes(key)\n ) {\n return {\n ...field,\n [key]: value,\n ...(key === 'value' ? { isModified: true } : {}),\n }\n }\n\n return field\n },\n state?.[action.path] || ({} as FormField),\n )\n\n const newState = {\n ...state,\n [action.path]: newField,\n }\n\n // reset `isModified` in all other fields\n if ('value' in action) {\n for (const [path, field] of Object.entries(newState)) {\n if (path !== action.path && 'isModified' in field) {\n delete newState[path].isModified\n }\n }\n }\n\n return newState\n }\n\n case 'UPDATE_MANY': {\n const newState = { ...state }\n\n Object.entries(action.formState).forEach(([path, field]) => {\n newState[path] = field\n })\n\n return newState\n }\n\n default: {\n return state\n }\n }\n}\n"],"names":["ObjectIdImport","dequal","deepCopyObjectSimpleWithoutReactComponents","mergeServerFormState","flattenRows","separateRows","ObjectId","default","fieldReducer","state","action","type","blockType","path","rowIndex","rowIndexFromArgs","subFieldState","rows","length","withNewRow","newRow","id","value","toHexString","isLoading","splice","initialValue","valid","remainingFields","siblingRows","newState","passesCondition","disableFormData","errorPaths","errors","forEach","message","fieldPath","errorMessage","segments","split","push","fieldErrorPath","parentPath","slice","join","Object","entries","reduce","acc","fieldState","fieldErrorPaths","errorACC","startsWith","changed","newErrorPaths","Array","isArray","includes","newRows","newRowID","customComponents","RowLabel","newRowState","key","keys","filter","endsWith","idState","newNestedFieldID","isValid","parseInt","parentFieldPath","parentFieldRows","acceptValues","prevStateRef","serverState","currentState","incomingState","current","moveFromIndex","moveToIndex","topLevelRows","copyOfMovingRow","rowsWithinField","copyOfMovingRow2","rowsMetadata","rowIndexArg","Math","max","min","undefined","collapsed","optimize","newField","oldField","sanitize","field","values","updatedRows","isModified","formState"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/forms/Form/fieldReducer.ts"],"sourcesContent":["'use client'\nimport type { FormField, FormState, Row } from 'payload'\n\nimport ObjectIdImport from 'bson-objectid'\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\nimport { deepCopyObjectSimpleWithoutReactComponents } from 'payload/shared'\n\nimport type { FieldAction } from './types.js'\n\nimport { mergeServerFormState } from './mergeServerFormState.js'\nimport { flattenRows, separateRows } from './rows.js'\n\nconst ObjectId = 'default' in ObjectIdImport ? ObjectIdImport.default : ObjectIdImport\n\n/**\n * Reducer which modifies the form field state (all the current data of the fields in the form). When called using dispatch, it will return a new state object.\n */\nexport function fieldReducer(state: FormState, action: FieldAction): FormState {\n switch (action.type) {\n case 'ADD_ROW': {\n const { blockType, path, rowIndex: rowIndexFromArgs, subFieldState = {} } = action\n\n const rowIndex =\n typeof rowIndexFromArgs === 'number' ? rowIndexFromArgs : state[path]?.rows?.length || 0\n\n const withNewRow = [...(state[path]?.rows || [])]\n\n const newRow: Row = {\n id: (subFieldState?.id?.value as string) || new ObjectId().toHexString(),\n isLoading: true,\n }\n\n if (blockType) {\n newRow.blockType = blockType\n }\n\n withNewRow.splice(rowIndex, 0, newRow)\n\n if (blockType) {\n subFieldState.blockType = {\n initialValue: blockType,\n valid: true,\n value: blockType,\n }\n }\n\n // add new row to array _field state_\n const { remainingFields, rows: siblingRows } = separateRows(path, state)\n\n siblingRows.splice(rowIndex, 0, subFieldState)\n\n const newState: FormState = {\n ...remainingFields,\n ...flattenRows(path, siblingRows),\n [`${path}.${rowIndex}.id`]: {\n initialValue: newRow.id,\n passesCondition: true,\n valid: true,\n value: newRow.id,\n },\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: withNewRow,\n value: siblingRows.length,\n },\n }\n\n return newState\n }\n\n case 'ADD_SERVER_ERRORS': {\n let newState = { ...state }\n\n const errorPaths: { fieldErrorPath: string; parentPath: string }[] = []\n\n action.errors.forEach(({ message, path: fieldPath }) => {\n newState[fieldPath] = {\n ...(newState[fieldPath] || {\n initialValue: null,\n value: null,\n }),\n errorMessage: message,\n valid: false,\n }\n\n const segments = fieldPath.split('.')\n if (segments.length > 1) {\n errorPaths.push({\n fieldErrorPath: fieldPath,\n parentPath: segments.slice(0, segments.length - 1).join('.'),\n })\n }\n })\n\n newState = Object.entries(newState).reduce((acc, [path, fieldState]) => {\n const fieldErrorPaths = errorPaths.reduce((errorACC, { fieldErrorPath, parentPath }) => {\n if (parentPath.startsWith(path)) {\n errorACC.push(fieldErrorPath)\n }\n return errorACC\n }, [])\n\n let changed = false\n\n if (fieldErrorPaths.length > 0) {\n const newErrorPaths = Array.isArray(fieldState.errorPaths) ? fieldState.errorPaths : []\n\n fieldErrorPaths.forEach((fieldErrorPath) => {\n if (!newErrorPaths.includes(fieldErrorPath)) {\n newErrorPaths.push(fieldErrorPath)\n changed = true\n }\n })\n\n if (changed) {\n acc[path] = {\n ...fieldState,\n errorPaths: newErrorPaths,\n }\n }\n }\n\n if (!changed) {\n acc[path] = fieldState\n }\n\n return acc\n }, {})\n\n return newState\n }\n\n /**\n * Duplicates a row in an array or blocks field.\n * It needs to manipulate two distinct parts of the form state:\n * - The `rows` property of the parent field, e.g. `array.rows`, `blocks.rows`, etc.\n * - The row's state, e.g. `array.0.id`, `array.0.text`, etc.\n */\n case 'DUPLICATE_ROW': {\n const { path, rowIndex } = action\n const { remainingFields, rows } = separateRows(path, state)\n\n // 1. Duplicate the `rows` property of the parent field, e.g. `array.rows`, `blocks.rows`, etc.\n const newRows = [...(state[path].rows || [])]\n\n const newRow = deepCopyObjectSimpleWithoutReactComponents(newRows[rowIndex])\n\n const newRowID = new ObjectId().toHexString()\n\n if (newRow.id) {\n newRow.id = newRowID\n }\n\n if (newRows[rowIndex]?.customComponents?.RowLabel) {\n newRow.customComponents = {\n RowLabel: newRows[rowIndex].customComponents.RowLabel,\n }\n }\n\n // 2. Duplicate the row's state, e.g. `array.0.id`, `array.0.text`, etc.\n const newRowState = deepCopyObjectSimpleWithoutReactComponents(rows[rowIndex])\n\n // Ensure that `id` in form state exactly matches the row id on the parent field\n if (newRowState.id) {\n newRowState.id.value = newRowID\n newRowState.id.initialValue = newRowID\n }\n\n // Generate new ids for all nested id fields, e.g. `array.0.nestedArray.0.id`\n for (const key of Object.keys(newRowState).filter((key) => key.endsWith('.id'))) {\n const idState = newRowState[key]\n\n const newNestedFieldID = new ObjectId().toHexString()\n\n if (idState && typeof idState.value === 'string' && ObjectId.isValid(idState.value)) {\n newRowState[key].value = newNestedFieldID\n newRowState[key].initialValue = newNestedFieldID\n\n // Apply the ID to its corresponding parent field's rows, e.g. `array.0.nestedArray.rows[0].id`\n const segments = key.split('.')\n const rowIndex = parseInt(segments[segments.length - 2], 10)\n const parentFieldPath = segments.slice(0, segments.length - 2).join('.')\n const parentFieldRows = newRowState?.[parentFieldPath]?.rows\n\n if (newRowState[parentFieldPath] && Array.isArray(parentFieldRows)) {\n if (!parentFieldRows[rowIndex]) {\n parentFieldRows[rowIndex] = {\n id: newNestedFieldID,\n }\n } else {\n parentFieldRows[rowIndex].id = newNestedFieldID\n }\n }\n }\n }\n\n // If there are subfields\n if (Object.keys(newRowState).length > 0) {\n // Add new object containing subfield names to unflattenedRows array\n rows.splice(rowIndex + 1, 0, newRowState)\n newRows.splice(rowIndex + 1, 0, newRow)\n }\n\n const newState = {\n ...remainingFields,\n ...flattenRows(path, rows),\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: newRows,\n value: rows.length,\n },\n }\n\n return newState\n }\n\n case 'MERGE_SERVER_STATE': {\n const { acceptValues, prevStateRef, serverState } = action\n\n const newState = mergeServerFormState({\n acceptValues,\n currentState: state || {},\n incomingState: serverState,\n })\n\n prevStateRef.current = newState\n\n return newState\n }\n\n case 'MOVE_ROW': {\n const { moveFromIndex, moveToIndex, path } = action\n\n // Handle moving rows on the top-level, i.e. `array.0.text` -> `array.1.text`\n const { remainingFields, rows: topLevelRows } = separateRows(path, state)\n const copyOfMovingRow = topLevelRows[moveFromIndex]\n topLevelRows.splice(moveFromIndex, 1)\n topLevelRows.splice(moveToIndex, 0, copyOfMovingRow)\n\n // modify array/block internal row state (i.e. collapsed, blockType)\n const rowsWithinField = [...(state[path]?.rows || [])]\n const copyOfMovingRow2 = { ...rowsWithinField[moveFromIndex] }\n rowsWithinField.splice(moveFromIndex, 1)\n rowsWithinField.splice(moveToIndex, 0, copyOfMovingRow2)\n\n const newState = {\n ...remainingFields,\n ...flattenRows(path, topLevelRows),\n [path]: {\n ...state[path],\n rows: rowsWithinField,\n },\n }\n\n return newState\n }\n\n case 'REMOVE': {\n const newState = { ...state }\n if (newState[action.path]) {\n delete newState[action.path]\n }\n return newState\n }\n\n case 'REMOVE_ROW': {\n const { path, rowIndex } = action\n const { remainingFields, rows } = separateRows(path, state)\n const rowsMetadata = [...(state[path]?.rows || [])]\n\n rows.splice(rowIndex, 1)\n rowsMetadata.splice(rowIndex, 1)\n\n const newState: FormState = {\n ...remainingFields,\n [path]: {\n ...state[path],\n disableFormData: rows.length > 0,\n rows: rowsMetadata,\n value: rows.length,\n },\n ...flattenRows(path, rows),\n }\n\n return newState\n }\n\n case 'REPLACE_ROW': {\n const { blockType, path, rowIndex: rowIndexArg, subFieldState = {} } = action\n\n const { remainingFields, rows: siblingRows } = separateRows(path, state)\n const rowIndex = Math.max(0, Math.min(rowIndexArg, siblingRows?.length - 1 || 0))\n\n const rowsMetadata = [...(state[path]?.rows || [])]\n rowsMetadata[rowIndex] = {\n id: new ObjectId().toHexString(),\n blockType: blockType || undefined,\n collapsed: false,\n }\n\n if (blockType) {\n subFieldState.blockType = {\n initialValue: blockType,\n valid: true,\n value: blockType,\n }\n }\n\n // replace form _field state_\n siblingRows[rowIndex] = subFieldState\n\n const newState: FormState = {\n ...remainingFields,\n ...flattenRows(path, siblingRows),\n [path]: {\n ...state[path],\n disableFormData: true,\n rows: rowsMetadata,\n value: siblingRows.length,\n },\n }\n\n return newState\n }\n\n case 'REPLACE_STATE': {\n if (action.optimize !== false) {\n // Only update fields that have changed\n // by comparing old value / initialValue to new\n // ..\n // This is a performance enhancement for saving\n // large documents with hundreds of fields\n const newState: FormState = {}\n\n for (const [path, newField] of Object.entries(action.state)) {\n const oldField = state[path]\n\n if (newField.valid !== false) {\n newField.valid = true\n }\n if (newField.passesCondition !== false) {\n newField.passesCondition = true\n }\n\n if (!dequal(oldField, newField)) {\n newState[path] = newField\n } else if (oldField) {\n newState[path] = oldField\n }\n }\n\n return newState\n }\n\n // TODO: Remove this in 4.0 - this is a temporary fix to prevent a breaking change\n if (action.sanitize) {\n for (const field of Object.values(action.state)) {\n if (field.valid !== false) {\n field.valid = true\n }\n if (field.passesCondition !== false) {\n field.passesCondition = true\n }\n }\n }\n // If we're not optimizing, just set the state to the new state\n return action.state\n }\n\n case 'SET_ALL_ROWS_COLLAPSED': {\n const { path, updatedRows } = action\n\n return {\n ...state,\n [path]: {\n ...state[path],\n rows: updatedRows,\n },\n }\n }\n\n case 'SET_ROW_COLLAPSED': {\n const { path, updatedRows } = action\n\n const newState = {\n ...state,\n [path]: {\n ...state[path],\n rows: updatedRows,\n },\n }\n\n return newState\n }\n\n case 'UPDATE': {\n const newField = Object.entries(action).reduce(\n (field, [key, value]) => {\n if (\n [\n 'disableFormData',\n 'errorMessage',\n 'initialValue',\n 'rows',\n 'valid',\n 'validate',\n 'value',\n ].includes(key)\n ) {\n return {\n ...field,\n [key]: value,\n ...(key === 'value' ? { isModified: true } : {}),\n }\n }\n\n return field\n },\n state?.[action.path] || ({} as FormField),\n )\n\n const newState = {\n ...state,\n [action.path]: newField,\n }\n\n // reset `isModified` in all other fields\n if ('value' in action) {\n for (const [path, field] of Object.entries(newState)) {\n if (path !== action.path && 'isModified' in field) {\n delete newState[path].isModified\n }\n }\n }\n\n return newState\n }\n\n case 'UPDATE_MANY': {\n const newState = { ...state }\n\n Object.entries(action.formState).forEach(([path, field]) => {\n newState[path] = field\n })\n\n return newState\n }\n\n default: {\n return state\n }\n }\n}\n"],"names":["ObjectIdImport","dequal","deepCopyObjectSimpleWithoutReactComponents","mergeServerFormState","flattenRows","separateRows","ObjectId","default","fieldReducer","state","action","type","blockType","path","rowIndex","rowIndexFromArgs","subFieldState","rows","length","withNewRow","newRow","id","value","toHexString","isLoading","splice","initialValue","valid","remainingFields","siblingRows","newState","passesCondition","disableFormData","errorPaths","errors","forEach","message","fieldPath","errorMessage","segments","split","push","fieldErrorPath","parentPath","slice","join","Object","entries","reduce","acc","fieldState","fieldErrorPaths","errorACC","startsWith","changed","newErrorPaths","Array","isArray","includes","newRows","newRowID","customComponents","RowLabel","newRowState","key","keys","filter","endsWith","idState","newNestedFieldID","isValid","parseInt","parentFieldPath","parentFieldRows","acceptValues","prevStateRef","serverState","currentState","incomingState","current","moveFromIndex","moveToIndex","topLevelRows","copyOfMovingRow","rowsWithinField","copyOfMovingRow2","rowsMetadata","rowIndexArg","Math","max","min","undefined","collapsed","optimize","newField","oldField","sanitize","field","values","updatedRows","isModified","formState"],"mappings":"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"}
|
package/dist/forms/Form/index.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
'use client';
|
|
2
2
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
3
|
-
import { dequal } from 'dequal/lite';
|
|
3
|
+
import { dequal } from 'dequal/lite';
|
|
4
|
+
// lite: no need for Map and Set support
|
|
4
5
|
import { useRouter } from 'next/navigation.js';
|
|
5
6
|
import { serialize } from 'object-to-formdata';
|
|
6
7
|
import { deepCopyObjectSimpleWithoutReactComponents, getDataByPath as getDataByPathFunc, getSiblingData as getSiblingDataFunc, hasDraftValidationEnabled, reduceFieldsToValues, wait } from 'payload/shared';
|
|
@@ -31,7 +32,8 @@ export const Form = (props)=>{
|
|
|
31
32
|
const { id, collectionSlug, docConfig, docPermissions, getDocPreferences, globalSlug } = useDocumentInfo();
|
|
32
33
|
const validateDrafts = hasDraftValidationEnabled(docConfig);
|
|
33
34
|
const { action, beforeSubmit, children, className, disabled: disabledFromProps, disableSuccessStatus, disableValidationOnSubmit, // fields: fieldsFromProps = collection?.fields || global?.fields,
|
|
34
|
-
el, handleResponse, initialState,
|
|
35
|
+
el, handleResponse, initialState, // fully formed initial field state
|
|
36
|
+
isDocumentForm, isInitializing: initializingFromProps, onChange, onSubmit, onSuccess, redirect, submitted: submittedFromProps, uuid, waitForAutocomplete } = props;
|
|
35
37
|
const method = 'method' in props ? props?.method : undefined;
|
|
36
38
|
const router = useRouter();
|
|
37
39
|
const documentForm = useDocumentForm();
|
|
@@ -112,6 +114,7 @@ export const Form = (props)=>{
|
|
|
112
114
|
collectionSlug,
|
|
113
115
|
// If there is a parent document form, we can get the data from that form
|
|
114
116
|
blockData: undefined,
|
|
117
|
+
// Will be expensive to get - not worth to pass to client-side validation, as this can be obtained by the user using `useFormFields()`
|
|
115
118
|
data: documentForm?.getData ? documentForm.getData() : data,
|
|
116
119
|
event: 'submit',
|
|
117
120
|
operation,
|
|
@@ -326,8 +329,8 @@ export const Form = (props)=>{
|
|
|
326
329
|
}
|
|
327
330
|
contextRef.current = {
|
|
328
331
|
...contextRef.current
|
|
329
|
-
}
|
|
330
|
-
|
|
332
|
+
};
|
|
333
|
+
// triggers rerender of all components that subscribe to form
|
|
331
334
|
if (json.message) {
|
|
332
335
|
errorToast(json.message);
|
|
333
336
|
return;
|
|
@@ -382,8 +385,8 @@ export const Form = (props)=>{
|
|
|
382
385
|
res
|
|
383
386
|
};
|
|
384
387
|
} catch (err) {
|
|
385
|
-
console.error('Error submitting form', err)
|
|
386
|
-
|
|
388
|
+
console.error('Error submitting form', err);
|
|
389
|
+
// eslint-disable-line no-console
|
|
387
390
|
setProcessing(false);
|
|
388
391
|
setSubmitted(true);
|
|
389
392
|
setDisabled(false);
|
|
@@ -653,8 +656,8 @@ export const Form = (props)=>{
|
|
|
653
656
|
const handleLocaleChange = useEffectEvent(()=>{
|
|
654
657
|
contextRef.current = {
|
|
655
658
|
...contextRef.current
|
|
656
|
-
}
|
|
657
|
-
|
|
659
|
+
};
|
|
660
|
+
// triggers rerender of all components that subscribe to form
|
|
658
661
|
setModified(false);
|
|
659
662
|
});
|
|
660
663
|
useEffect(()=>{
|
|
@@ -727,7 +730,7 @@ export const Form = (props)=>{
|
|
|
727
730
|
value: backgroundProcessing,
|
|
728
731
|
children: /*#__PURE__*/ _jsx(ModifiedContext, {
|
|
729
732
|
value: modified,
|
|
730
|
-
children: /*#__PURE__*/ _jsx(FormFieldsContext.Provider, {
|
|
733
|
+
children: /* eslint-disable-next-line @eslint-react/no-context-provider */ /*#__PURE__*/ _jsx(FormFieldsContext.Provider, {
|
|
731
734
|
value: fieldsReducer,
|
|
732
735
|
children: children
|
|
733
736
|
})
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/forms/Form/index.tsx"],"sourcesContent":["'use client'\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\nimport { useRouter } from 'next/navigation.js'\nimport { serialize } from 'object-to-formdata'\nimport { type FormState, type PayloadRequest } from 'payload'\nimport {\n deepCopyObjectSimpleWithoutReactComponents,\n getDataByPath as getDataByPathFunc,\n getSiblingData as getSiblingDataFunc,\n hasDraftValidationEnabled,\n reduceFieldsToValues,\n wait,\n} from 'payload/shared'\nimport React, { useCallback, useEffect, useReducer, useRef, useState } from 'react'\nimport { toast } from 'sonner'\n\nimport type {\n CreateFormData,\n Context as FormContextType,\n FormProps,\n GetDataByPath,\n Submit,\n SubmitOptions,\n} from './types.js'\n\nimport { FieldErrorsToast } from '../../elements/Toasts/fieldErrors.js'\nimport { useDebouncedEffect } from '../../hooks/useDebouncedEffect.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useQueue } from '../../hooks/useQueue.js'\nimport { useThrottledEffect } from '../../hooks/useThrottledEffect.js'\nimport { useAuth } from '../../providers/Auth/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useDocumentInfo } from '../../providers/DocumentInfo/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useOperation } from '../../providers/Operation/index.js'\nimport { useRouteTransition } from '../../providers/RouteTransition/index.js'\nimport { useServerFunctions } from '../../providers/ServerFunctions/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { useUploadHandlers } from '../../providers/UploadHandlers/index.js'\nimport { abortAndIgnore, handleAbortRef } from '../../utilities/abortAndIgnore.js'\nimport { requests } from '../../utilities/api.js'\nimport {\n BackgroundProcessingContext,\n DocumentFormContext,\n FormContext,\n FormFieldsContext,\n FormWatchContext,\n InitializingContext,\n ModifiedContext,\n ProcessingContext,\n SubmittedContext,\n useDocumentForm,\n} from './context.js'\nimport { errorMessages } from './errorMessages.js'\nimport { fieldReducer } from './fieldReducer.js'\nimport { initContextState } from './initContextState.js'\n\nconst baseClass = 'form'\n\nexport const Form: React.FC<FormProps> = (props) => {\n const { id, collectionSlug, docConfig, docPermissions, getDocPreferences, globalSlug } =\n useDocumentInfo()\n\n const validateDrafts = hasDraftValidationEnabled(docConfig)\n\n const {\n action,\n beforeSubmit,\n children,\n className,\n disabled: disabledFromProps,\n disableSuccessStatus,\n disableValidationOnSubmit,\n // fields: fieldsFromProps = collection?.fields || global?.fields,\n el,\n handleResponse,\n initialState, // fully formed initial field state\n isDocumentForm,\n isInitializing: initializingFromProps,\n onChange,\n onSubmit,\n onSuccess,\n redirect,\n submitted: submittedFromProps,\n uuid,\n waitForAutocomplete,\n } = props\n\n const method = 'method' in props ? props?.method : undefined\n\n const router = useRouter()\n\n const documentForm = useDocumentForm()\n\n const { code: locale } = useLocale()\n const { i18n, t } = useTranslation()\n const { refreshCookie, user } = useAuth()\n const operation = useOperation()\n const { queueTask } = useQueue()\n\n const { getFormState } = useServerFunctions()\n const { startRouteTransition } = useRouteTransition()\n const { getUploadHandler } = useUploadHandlers()\n\n const { config } = useConfig()\n\n const [disabled, setDisabled] = useState(disabledFromProps || false)\n const [isMounted, setIsMounted] = useState(false)\n\n const [submitted, setSubmitted] = useState(false)\n\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 const [isValid, setIsValid] = useState(true)\n const [initializing, setInitializing] = useState(initializingFromProps)\n\n const [processing, setProcessing] = useState(false)\n\n /**\n * Determines whether the form is processing asynchronously in the background, e.g. autosave is running.\n * Useful to determine whether to disable the form or queue other processes while in flight, e.g. disable manual submits while an autosave is running.\n */\n const [backgroundProcessing, _setBackgroundProcessing] = useState(false)\n\n /**\n * A ref that can be read within the `setModified` interceptor.\n * Dependents of this state can read it immediately without needing to wait for a render cycle.\n */\n const backgroundProcessingRef = useRef(backgroundProcessing)\n\n /**\n * Flag to track if the form was modified _during a submission_, e.g. while autosave is running.\n * Useful in order to avoid resetting `modified` to false wrongfully after a submit.\n * For example, if the user modifies a field while the a background process (autosave) is running,\n * we need to ensure that after the submit completes, the `modified` state remains true.\n */\n const modifiedWhileProcessingRef = useRef(false)\n\n /**\n * Intercept the `setBackgroundProcessing` method to keep the ref in sync.\n * See the `backgroundProcessingRef` for more details.\n */\n const setBackgroundProcessing = useCallback((backgroundProcessing: boolean) => {\n backgroundProcessingRef.current = backgroundProcessing\n _setBackgroundProcessing(backgroundProcessing)\n }, [])\n\n const [modified, _setModified] = useState(false)\n\n /**\n * Intercept the `setModified` method to track whether the event happened during background processing.\n * See the `modifiedWhileProcessingRef` ref for more details.\n */\n const setModified = useCallback((modified: boolean) => {\n if (backgroundProcessingRef.current) {\n modifiedWhileProcessingRef.current = true\n }\n\n _setModified(modified)\n }, [])\n\n const formRef = useRef<HTMLFormElement>(null)\n const contextRef = useRef({} as FormContextType)\n const abortResetFormRef = useRef<AbortController>(null)\n const isFirstRenderRef = useRef(true)\n\n const fieldsReducer = useReducer(fieldReducer, {}, () => initialState)\n\n const [formState, dispatchFields] = fieldsReducer\n\n contextRef.current.fields = formState\n\n const prevFormState = useRef(formState)\n\n const validateForm = useCallback(async () => {\n const validatedFieldState = {}\n let isValid = true\n\n const data = contextRef.current.getData()\n\n const validationPromises = Object.entries(contextRef.current.fields).map(\n async ([path, field]) => {\n const validatedField = field\n const pathSegments = path ? path.split('.') : []\n\n if (field.passesCondition !== false) {\n let validationResult: boolean | string = validatedField.valid\n\n if ('validate' in field && typeof field.validate === 'function') {\n let valueToValidate = field.value\n\n if (field?.rows && Array.isArray(field.rows)) {\n valueToValidate = contextRef.current.getDataByPath(path)\n }\n\n validationResult = await field.validate(valueToValidate, {\n ...field,\n id,\n collectionSlug,\n // If there is a parent document form, we can get the data from that form\n blockData: undefined, // Will be expensive to get - not worth to pass to client-side validation, as this can be obtained by the user using `useFormFields()`\n data: documentForm?.getData ? documentForm.getData() : data,\n event: 'submit',\n operation,\n path: pathSegments,\n preferences: {} as any,\n req: {\n payload: {\n config,\n },\n t,\n user,\n } as unknown as PayloadRequest,\n siblingData: contextRef.current.getSiblingData(path),\n })\n\n if (typeof validationResult === 'string') {\n validatedField.errorMessage = validationResult\n validatedField.valid = false\n } else {\n validatedField.valid = true\n validatedField.errorMessage = undefined\n }\n }\n\n if (validatedField.valid === false) {\n isValid = false\n }\n }\n\n validatedFieldState[path] = validatedField\n },\n )\n\n await Promise.all(validationPromises)\n\n if (!dequal(contextRef.current.fields, validatedFieldState)) {\n dispatchFields({ type: 'REPLACE_STATE', state: validatedFieldState })\n }\n\n setIsValid(isValid)\n\n return isValid\n }, [collectionSlug, config, dispatchFields, id, operation, t, user, documentForm])\n\n const submit = useCallback<Submit>(\n async (options, e) => {\n const {\n acceptValues = true,\n action: actionArg = action,\n context,\n disableFormWhileProcessing = true,\n disableSuccessStatus: disableSuccessStatusFromArgs,\n method: methodToUse = method,\n overrides: overridesFromArgs = {},\n skipValidation,\n } = options || ({} as SubmitOptions)\n\n const disableToast = disableSuccessStatusFromArgs ?? disableSuccessStatus\n\n if (disabled) {\n if (e) {\n e.preventDefault()\n }\n return\n }\n\n // create new toast promise which will resolve manually later\n let errorToast, successToast\n\n const promise = new Promise((resolve, reject) => {\n successToast = resolve\n errorToast = reject\n })\n\n const hasFormSubmitAction =\n actionArg || typeof action === 'string' || typeof action === 'function'\n\n if (redirect || disableToast || !hasFormSubmitAction) {\n // Do not show submitting toast, as the promise toast may never disappear under these conditions.\n // Instead, make successToast() or errorToast() throw toast.success / toast.error\n successToast = (data) => toast.success(data)\n errorToast = (data) => toast.error(data)\n } else {\n toast.promise(promise, {\n error: (data) => {\n return data as string\n },\n loading: t('general:submitting'),\n success: (data) => {\n return data as string\n },\n })\n }\n\n if (e) {\n e.stopPropagation()\n e.preventDefault()\n }\n\n if (disableFormWhileProcessing) {\n setProcessing(true)\n setDisabled(true)\n }\n\n if (waitForAutocomplete) {\n await wait(100)\n }\n\n const data = reduceFieldsToValues(contextRef.current.fields, true)\n\n const serializableFormState = deepCopyObjectSimpleWithoutReactComponents(\n contextRef.current.fields,\n )\n\n // Execute server side validations\n if (Array.isArray(beforeSubmit)) {\n let revalidatedFormState: FormState\n\n await beforeSubmit.reduce(async (priorOnChange, beforeSubmitFn) => {\n await priorOnChange\n\n const result = await beforeSubmitFn({\n formState: serializableFormState,\n })\n\n revalidatedFormState = result\n }, Promise.resolve())\n\n const isValid = Object.entries(revalidatedFormState).every(\n ([, field]) => field.valid !== false,\n )\n\n setIsValid(isValid)\n\n if (!isValid) {\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return dispatchFields({ type: 'REPLACE_STATE', state: revalidatedFormState })\n }\n }\n\n const isValid =\n skipValidation || disableValidationOnSubmit ? true : await contextRef.current.validateForm()\n\n setIsValid(isValid)\n\n // If not valid, prevent submission\n if (!isValid) {\n errorToast(t('error:correctInvalidFields'))\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return\n }\n\n let overrides = {}\n\n if (typeof overridesFromArgs === 'function') {\n overrides = overridesFromArgs(contextRef.current.fields)\n } else if (typeof overridesFromArgs === 'object') {\n overrides = overridesFromArgs\n }\n\n // If submit handler comes through via props, run that\n if (onSubmit) {\n for (const [key, value] of Object.entries(overrides)) {\n data[key] = value\n }\n\n onSubmit(contextRef.current.fields, data)\n }\n\n if (!hasFormSubmitAction) {\n // No action provided, so we should return. An example where this happens are lexical link drawers. Upon submitting the drawer, we\n // want to close it without submitting the form. Stuff like validation would be handled by lexical before this, through beforeSubmit\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return\n }\n\n const formData = await contextRef.current.createFormData(overrides, {\n data,\n mergeOverrideData: Boolean(typeof overridesFromArgs !== 'function'),\n })\n\n try {\n let res\n\n if (typeof actionArg === 'string') {\n res = await requests[methodToUse.toLowerCase()](actionArg, {\n body: formData,\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n } else if (typeof action === 'function') {\n res = await action(formData)\n }\n\n if (!modifiedWhileProcessingRef.current) {\n setModified(false)\n } else {\n modifiedWhileProcessingRef.current = false\n }\n\n setDisabled(false)\n\n if (typeof handleResponse === 'function') {\n handleResponse(res, successToast, errorToast)\n return\n }\n\n const contentType = res.headers.get('content-type')\n const isJSON = contentType && contentType.indexOf('application/json') !== -1\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let json: Record<string, any> = {}\n\n if (isJSON) {\n json = await res.json()\n }\n\n if (res.status < 400) {\n if (typeof onSuccess === 'function') {\n const newFormState = await onSuccess(json, {\n context,\n formState: serializableFormState,\n })\n\n if (newFormState) {\n dispatchFields({\n type: 'MERGE_SERVER_STATE',\n acceptValues,\n prevStateRef: prevFormState,\n serverState: newFormState,\n })\n }\n }\n\n setSubmitted(false)\n setProcessing(false)\n\n if (redirect) {\n startRouteTransition(() => router.push(redirect))\n } else if (!disableToast) {\n successToast(json.message || t('general:submissionSuccessful'))\n }\n } else {\n setProcessing(false)\n setSubmitted(true)\n\n // When there was an error submitting a draft,\n // set the form state to unsubmitted, to not trigger visible form validation on changes after the failed submit.\n // Also keep the form as modified so the save button remains enabled for retry.\n if (overridesFromArgs['_status'] === 'draft') {\n setModified(true)\n\n if (!validateDrafts) {\n setSubmitted(false)\n }\n }\n\n contextRef.current = { ...contextRef.current } // triggers rerender of all components that subscribe to form\n\n if (json.message) {\n errorToast(json.message)\n return\n }\n\n if (Array.isArray(json.errors)) {\n const [fieldErrors, nonFieldErrors] = json.errors.reduce(\n ([fieldErrs, nonFieldErrs], err) => {\n const newFieldErrs = []\n const newNonFieldErrs = []\n\n if (err?.message) {\n newNonFieldErrs.push(err)\n }\n\n if (Array.isArray(err?.data?.errors)) {\n err.data?.errors.forEach((dataError) => {\n if (dataError?.path) {\n newFieldErrs.push(dataError)\n } else {\n newNonFieldErrs.push(dataError)\n }\n })\n }\n\n return [\n [...fieldErrs, ...newFieldErrs],\n [...nonFieldErrs, ...newNonFieldErrs],\n ]\n },\n [[], []],\n )\n\n setIsValid(false)\n\n dispatchFields({\n type: 'ADD_SERVER_ERRORS',\n errors: fieldErrors,\n })\n\n nonFieldErrors.forEach((err) => {\n errorToast(<FieldErrorsToast errorMessage={err.message || t('error:unknown')} />)\n })\n\n return\n }\n\n const message = errorMessages?.[res.status] || res?.statusText || t('error:unknown')\n\n errorToast(message)\n }\n\n return { formState: contextRef.current.fields, res }\n } catch (err) {\n console.error('Error submitting form', err) // eslint-disable-line no-console\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n errorToast(err.message)\n }\n },\n [\n beforeSubmit,\n startRouteTransition,\n action,\n disableSuccessStatus,\n disableValidationOnSubmit,\n disabled,\n dispatchFields,\n handleResponse,\n method,\n onSubmit,\n onSuccess,\n redirect,\n router,\n t,\n i18n,\n validateDrafts,\n waitForAutocomplete,\n setModified,\n setSubmitted,\n ],\n )\n\n const getFields = useCallback(() => contextRef.current.fields, [])\n\n const getField = useCallback((path: string) => contextRef.current.fields[path], [])\n\n const getData = useCallback(() => reduceFieldsToValues(contextRef.current.fields, true), [])\n\n const getSiblingData = useCallback(\n (path: string) => getSiblingDataFunc(contextRef.current.fields, path),\n [],\n )\n\n const getDataByPath = useCallback<GetDataByPath>(\n (path: string) => getDataByPathFunc(contextRef.current.fields, path),\n [],\n )\n\n const createFormData = useCallback<CreateFormData>(\n async (overrides, { data: dataFromArgs, mergeOverrideData = true }) => {\n let data = dataFromArgs || reduceFieldsToValues(contextRef.current.fields, true)\n\n let file = data?.file\n\n if (docConfig && 'upload' in docConfig && docConfig.upload && file) {\n delete data.file\n\n const handler = getUploadHandler({ collectionSlug })\n\n if (typeof handler === 'function') {\n let filename = file.name\n const clientUploadContext = await handler({\n file,\n updateFilename: (value) => {\n filename = value\n },\n })\n\n file = JSON.stringify({\n clientUploadContext,\n collectionSlug,\n filename,\n mimeType: file.type,\n size: file.size,\n })\n }\n }\n\n if (mergeOverrideData) {\n data = {\n ...data,\n ...overrides,\n }\n } else {\n data = overrides\n }\n\n const dataToSerialize: Record<string, unknown> = {\n _payload: JSON.stringify(data),\n }\n\n if (docConfig && 'upload' in docConfig && docConfig.upload && file) {\n dataToSerialize.file = file\n }\n\n // nullAsUndefineds is important to allow uploads and relationship fields to clear themselves\n const formData = serialize(dataToSerialize, {\n indices: true,\n nullsAsUndefineds: false,\n })\n\n return formData\n },\n [collectionSlug, docConfig, getUploadHandler],\n )\n\n const reset = useCallback(\n async (data: unknown) => {\n const controller = handleAbortRef(abortResetFormRef)\n\n const docPreferences = await getDocPreferences()\n\n const { state: newState } = await getFormState({\n id,\n collectionSlug,\n data,\n docPermissions,\n docPreferences,\n globalSlug,\n locale,\n operation,\n renderAllFields: true,\n schemaPath: collectionSlug ? collectionSlug : globalSlug,\n signal: controller.signal,\n skipValidation: true,\n })\n\n contextRef.current = { ...initContextState } as FormContextType\n setModified(false)\n dispatchFields({ type: 'REPLACE_STATE', state: newState })\n\n abortResetFormRef.current = null\n },\n [\n collectionSlug,\n dispatchFields,\n globalSlug,\n id,\n operation,\n getFormState,\n docPermissions,\n getDocPreferences,\n locale,\n setModified,\n ],\n )\n\n const replaceState = useCallback(\n (state: FormState) => {\n contextRef.current = { ...initContextState } as FormContextType\n setModified(false)\n dispatchFields({ type: 'REPLACE_STATE', state })\n },\n [dispatchFields, setModified],\n )\n\n const addFieldRow: FormContextType['addFieldRow'] = useCallback(\n ({ blockType, path, rowIndex: rowIndexArg, subFieldState }) => {\n const newRows: unknown[] = getDataByPath(path) || []\n const rowIndex = rowIndexArg === undefined ? newRows.length : rowIndexArg\n\n // dispatch ADD_ROW adds a blank row to local form state.\n // This performs no form state request, as the debounced onChange effect will do that for us.\n dispatchFields({\n type: 'ADD_ROW',\n blockType,\n path,\n rowIndex,\n subFieldState,\n })\n\n setModified(true)\n },\n [dispatchFields, getDataByPath, setModified],\n )\n\n const moveFieldRow: FormContextType['moveFieldRow'] = useCallback(\n ({ moveFromIndex, moveToIndex, path }) => {\n dispatchFields({\n type: 'MOVE_ROW',\n moveFromIndex,\n moveToIndex,\n path,\n })\n\n setModified(true)\n },\n [dispatchFields, setModified],\n )\n\n const removeFieldRow: FormContextType['removeFieldRow'] = useCallback(\n ({ path, rowIndex }) => {\n dispatchFields({ type: 'REMOVE_ROW', path, rowIndex })\n\n setModified(true)\n },\n [dispatchFields, setModified],\n )\n\n const replaceFieldRow: FormContextType['replaceFieldRow'] = useCallback(\n ({ blockType, path, rowIndex: rowIndexArg, subFieldState }) => {\n const currentRows: unknown[] = getDataByPath(path)\n const rowIndex = rowIndexArg === undefined ? currentRows.length : rowIndexArg\n\n dispatchFields({\n type: 'REPLACE_ROW',\n blockType,\n path,\n rowIndex,\n subFieldState,\n })\n\n setModified(true)\n },\n [dispatchFields, getDataByPath, setModified],\n )\n\n useEffect(() => {\n const abortOnChange = abortResetFormRef.current\n\n return () => {\n abortAndIgnore(abortOnChange)\n }\n }, [])\n\n useEffect(() => {\n if (initializingFromProps !== undefined) {\n setInitializing(initializingFromProps)\n }\n }, [initializingFromProps])\n\n contextRef.current.submit = submit\n contextRef.current.getFields = getFields\n contextRef.current.getField = getField\n contextRef.current.getData = getData\n contextRef.current.getSiblingData = getSiblingData\n contextRef.current.getDataByPath = getDataByPath\n contextRef.current.validateForm = validateForm\n contextRef.current.createFormData = createFormData\n contextRef.current.setModified = setModified\n contextRef.current.setProcessing = setProcessing\n contextRef.current.setBackgroundProcessing = setBackgroundProcessing\n\n contextRef.current.setSubmitted = setSubmitted\n contextRef.current.setIsValid = setIsValid\n contextRef.current.disabled = disabled\n contextRef.current.setDisabled = setDisabled\n contextRef.current.formRef = formRef\n contextRef.current.reset = reset\n contextRef.current.replaceState = replaceState\n contextRef.current.dispatchFields = dispatchFields\n contextRef.current.addFieldRow = addFieldRow\n contextRef.current.removeFieldRow = removeFieldRow\n contextRef.current.moveFieldRow = moveFieldRow\n contextRef.current.replaceFieldRow = replaceFieldRow\n contextRef.current.uuid = uuid\n contextRef.current.initializing = initializing\n contextRef.current.isValid = isValid\n\n useEffect(() => {\n setIsMounted(true)\n }, [])\n\n useEffect(() => {\n if (typeof disabledFromProps === 'boolean') {\n setDisabled(disabledFromProps)\n }\n }, [disabledFromProps])\n\n useEffect(() => {\n if (typeof submittedFromProps === 'boolean') {\n setSubmitted(submittedFromProps)\n }\n }, [submittedFromProps])\n\n useEffect(() => {\n if (initialState) {\n contextRef.current = { ...initContextState } as FormContextType\n dispatchFields({\n type: 'REPLACE_STATE',\n optimize: false,\n sanitize: true,\n state: initialState,\n })\n }\n }, [initialState, dispatchFields])\n\n useThrottledEffect(\n () => {\n refreshCookie()\n },\n 15000,\n [formState],\n )\n\n const handleLocaleChange = useEffectEvent(() => {\n contextRef.current = { ...contextRef.current } // triggers rerender of all components that subscribe to form\n setModified(false)\n })\n\n useEffect(() => {\n handleLocaleChange()\n }, [locale])\n\n const classes = [className, baseClass].filter(Boolean).join(' ')\n\n const executeOnChange = useEffectEvent((submitted: boolean) => {\n queueTask(async () => {\n if (Array.isArray(onChange)) {\n let serverState: FormState\n\n for (const onChangeFn of onChange) {\n // Edit view default onChange is in packages/ui/src/views/Edit/index.tsx. This onChange usually sends a form state request\n serverState = await onChangeFn({\n formState: deepCopyObjectSimpleWithoutReactComponents(formState),\n submitted,\n })\n }\n\n dispatchFields({\n type: 'MERGE_SERVER_STATE',\n prevStateRef: prevFormState,\n serverState,\n })\n }\n })\n })\n\n useDebouncedEffect(\n () => {\n if ((isFirstRenderRef.current || !dequal(formState, prevFormState.current)) && modified) {\n executeOnChange(submitted)\n }\n\n prevFormState.current = formState\n isFirstRenderRef.current = false\n },\n [modified, submitted, formState],\n 250,\n )\n\n const DocumentFormContextComponent: React.FC<any> = isDocumentForm\n ? DocumentFormContext\n : React.Fragment\n\n const documentFormContextProps = isDocumentForm\n ? {\n value: contextRef.current,\n }\n : {}\n\n const El: 'form' = (el as unknown as 'form') || 'form'\n\n return (\n <El\n action={typeof action === 'function' ? void action : action}\n className={classes}\n method={method}\n noValidate\n onSubmit={(e) => void contextRef.current.submit({}, e)}\n ref={formRef}\n >\n <DocumentFormContextComponent {...documentFormContextProps}>\n <FormContext value={contextRef.current}>\n <FormWatchContext\n value={{\n fields: formState,\n ...contextRef.current,\n }}\n >\n <SubmittedContext value={submitted}>\n <InitializingContext value={!isMounted || (isMounted && initializing)}>\n <ProcessingContext value={processing}>\n <BackgroundProcessingContext value={backgroundProcessing}>\n <ModifiedContext value={modified}>\n {/* eslint-disable-next-line @eslint-react/no-context-provider */}\n <FormFieldsContext.Provider value={fieldsReducer}>\n {children}\n </FormFieldsContext.Provider>\n </ModifiedContext>\n </BackgroundProcessingContext>\n </ProcessingContext>\n </InitializingContext>\n </SubmittedContext>\n </FormWatchContext>\n </FormContext>\n </DocumentFormContextComponent>\n </El>\n )\n}\n\nexport {\n DocumentFormContext,\n FormContext,\n FormFieldsContext,\n FormWatchContext,\n ModifiedContext,\n ProcessingContext,\n SubmittedContext,\n useAllFormFields,\n useDocumentForm,\n useForm,\n useFormFields,\n useFormModified,\n useFormProcessing,\n useFormSubmitted,\n useWatchForm,\n} from './context.js'\n\nexport { FormProps }\n"],"names":["dequal","useRouter","serialize","deepCopyObjectSimpleWithoutReactComponents","getDataByPath","getDataByPathFunc","getSiblingData","getSiblingDataFunc","hasDraftValidationEnabled","reduceFieldsToValues","wait","React","useCallback","useEffect","useReducer","useRef","useState","toast","FieldErrorsToast","useDebouncedEffect","useEffectEvent","useQueue","useThrottledEffect","useAuth","useConfig","useDocumentInfo","useLocale","useOperation","useRouteTransition","useServerFunctions","useTranslation","useUploadHandlers","abortAndIgnore","handleAbortRef","requests","BackgroundProcessingContext","DocumentFormContext","FormContext","FormFieldsContext","FormWatchContext","InitializingContext","ModifiedContext","ProcessingContext","SubmittedContext","useDocumentForm","errorMessages","fieldReducer","initContextState","baseClass","Form","props","id","collectionSlug","docConfig","docPermissions","getDocPreferences","globalSlug","validateDrafts","action","beforeSubmit","children","className","disabled","disabledFromProps","disableSuccessStatus","disableValidationOnSubmit","el","handleResponse","initialState","isDocumentForm","isInitializing","initializingFromProps","onChange","onSubmit","onSuccess","redirect","submitted","submittedFromProps","uuid","waitForAutocomplete","method","undefined","router","documentForm","code","locale","i18n","t","refreshCookie","user","operation","queueTask","getFormState","startRouteTransition","getUploadHandler","config","setDisabled","isMounted","setIsMounted","setSubmitted","isValid","setIsValid","initializing","setInitializing","processing","setProcessing","backgroundProcessing","_setBackgroundProcessing","backgroundProcessingRef","modifiedWhileProcessingRef","setBackgroundProcessing","current","modified","_setModified","setModified","formRef","contextRef","abortResetFormRef","isFirstRenderRef","fieldsReducer","formState","dispatchFields","fields","prevFormState","validateForm","validatedFieldState","data","getData","validationPromises","Object","entries","map","path","field","validatedField","pathSegments","split","passesCondition","validationResult","valid","validate","valueToValidate","value","rows","Array","isArray","blockData","event","preferences","req","payload","siblingData","errorMessage","Promise","all","type","state","submit","options","e","acceptValues","actionArg","context","disableFormWhileProcessing","disableSuccessStatusFromArgs","methodToUse","overrides","overridesFromArgs","skipValidation","disableToast","preventDefault","errorToast","successToast","promise","resolve","reject","hasFormSubmitAction","success","error","loading","stopPropagation","serializableFormState","revalidatedFormState","reduce","priorOnChange","beforeSubmitFn","result","every","key","formData","createFormData","mergeOverrideData","Boolean","res","toLowerCase","body","headers","language","contentType","get","isJSON","indexOf","json","status","newFormState","prevStateRef","serverState","push","message","errors","fieldErrors","nonFieldErrors","fieldErrs","nonFieldErrs","err","newFieldErrs","newNonFieldErrs","forEach","dataError","statusText","console","getFields","getField","dataFromArgs","file","upload","handler","filename","name","clientUploadContext","updateFilename","JSON","stringify","mimeType","size","dataToSerialize","_payload","indices","nullsAsUndefineds","reset","controller","docPreferences","newState","renderAllFields","schemaPath","signal","replaceState","addFieldRow","blockType","rowIndex","rowIndexArg","subFieldState","newRows","length","moveFieldRow","moveFromIndex","moveToIndex","removeFieldRow","replaceFieldRow","currentRows","abortOnChange","optimize","sanitize","handleLocaleChange","classes","filter","join","executeOnChange","onChangeFn","DocumentFormContextComponent","Fragment","documentFormContextProps","El","noValidate","ref","Provider","useAllFormFields","useForm","useFormFields","useFormModified","useFormProcessing","useFormSubmitted","useWatchForm"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/forms/Form/index.tsx"],"sourcesContent":["'use client'\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\nimport { useRouter } from 'next/navigation.js'\nimport { serialize } from 'object-to-formdata'\nimport { type FormState, type PayloadRequest } from 'payload'\nimport {\n deepCopyObjectSimpleWithoutReactComponents,\n getDataByPath as getDataByPathFunc,\n getSiblingData as getSiblingDataFunc,\n hasDraftValidationEnabled,\n reduceFieldsToValues,\n wait,\n} from 'payload/shared'\nimport React, { useCallback, useEffect, useReducer, useRef, useState } from 'react'\nimport { toast } from 'sonner'\n\nimport type {\n CreateFormData,\n Context as FormContextType,\n FormProps,\n GetDataByPath,\n Submit,\n SubmitOptions,\n} from './types.js'\n\nimport { FieldErrorsToast } from '../../elements/Toasts/fieldErrors.js'\nimport { useDebouncedEffect } from '../../hooks/useDebouncedEffect.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useQueue } from '../../hooks/useQueue.js'\nimport { useThrottledEffect } from '../../hooks/useThrottledEffect.js'\nimport { useAuth } from '../../providers/Auth/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useDocumentInfo } from '../../providers/DocumentInfo/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useOperation } from '../../providers/Operation/index.js'\nimport { useRouteTransition } from '../../providers/RouteTransition/index.js'\nimport { useServerFunctions } from '../../providers/ServerFunctions/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { useUploadHandlers } from '../../providers/UploadHandlers/index.js'\nimport { abortAndIgnore, handleAbortRef } from '../../utilities/abortAndIgnore.js'\nimport { requests } from '../../utilities/api.js'\nimport {\n BackgroundProcessingContext,\n DocumentFormContext,\n FormContext,\n FormFieldsContext,\n FormWatchContext,\n InitializingContext,\n ModifiedContext,\n ProcessingContext,\n SubmittedContext,\n useDocumentForm,\n} from './context.js'\nimport { errorMessages } from './errorMessages.js'\nimport { fieldReducer } from './fieldReducer.js'\nimport { initContextState } from './initContextState.js'\n\nconst baseClass = 'form'\n\nexport const Form: React.FC<FormProps> = (props) => {\n const { id, collectionSlug, docConfig, docPermissions, getDocPreferences, globalSlug } =\n useDocumentInfo()\n\n const validateDrafts = hasDraftValidationEnabled(docConfig)\n\n const {\n action,\n beforeSubmit,\n children,\n className,\n disabled: disabledFromProps,\n disableSuccessStatus,\n disableValidationOnSubmit,\n // fields: fieldsFromProps = collection?.fields || global?.fields,\n el,\n handleResponse,\n initialState, // fully formed initial field state\n isDocumentForm,\n isInitializing: initializingFromProps,\n onChange,\n onSubmit,\n onSuccess,\n redirect,\n submitted: submittedFromProps,\n uuid,\n waitForAutocomplete,\n } = props\n\n const method = 'method' in props ? props?.method : undefined\n\n const router = useRouter()\n\n const documentForm = useDocumentForm()\n\n const { code: locale } = useLocale()\n const { i18n, t } = useTranslation()\n const { refreshCookie, user } = useAuth()\n const operation = useOperation()\n const { queueTask } = useQueue()\n\n const { getFormState } = useServerFunctions()\n const { startRouteTransition } = useRouteTransition()\n const { getUploadHandler } = useUploadHandlers()\n\n const { config } = useConfig()\n\n const [disabled, setDisabled] = useState(disabledFromProps || false)\n const [isMounted, setIsMounted] = useState(false)\n\n const [submitted, setSubmitted] = useState(false)\n\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 const [isValid, setIsValid] = useState(true)\n const [initializing, setInitializing] = useState(initializingFromProps)\n\n const [processing, setProcessing] = useState(false)\n\n /**\n * Determines whether the form is processing asynchronously in the background, e.g. autosave is running.\n * Useful to determine whether to disable the form or queue other processes while in flight, e.g. disable manual submits while an autosave is running.\n */\n const [backgroundProcessing, _setBackgroundProcessing] = useState(false)\n\n /**\n * A ref that can be read within the `setModified` interceptor.\n * Dependents of this state can read it immediately without needing to wait for a render cycle.\n */\n const backgroundProcessingRef = useRef(backgroundProcessing)\n\n /**\n * Flag to track if the form was modified _during a submission_, e.g. while autosave is running.\n * Useful in order to avoid resetting `modified` to false wrongfully after a submit.\n * For example, if the user modifies a field while the a background process (autosave) is running,\n * we need to ensure that after the submit completes, the `modified` state remains true.\n */\n const modifiedWhileProcessingRef = useRef(false)\n\n /**\n * Intercept the `setBackgroundProcessing` method to keep the ref in sync.\n * See the `backgroundProcessingRef` for more details.\n */\n const setBackgroundProcessing = useCallback((backgroundProcessing: boolean) => {\n backgroundProcessingRef.current = backgroundProcessing\n _setBackgroundProcessing(backgroundProcessing)\n }, [])\n\n const [modified, _setModified] = useState(false)\n\n /**\n * Intercept the `setModified` method to track whether the event happened during background processing.\n * See the `modifiedWhileProcessingRef` ref for more details.\n */\n const setModified = useCallback((modified: boolean) => {\n if (backgroundProcessingRef.current) {\n modifiedWhileProcessingRef.current = true\n }\n\n _setModified(modified)\n }, [])\n\n const formRef = useRef<HTMLFormElement>(null)\n const contextRef = useRef({} as FormContextType)\n const abortResetFormRef = useRef<AbortController>(null)\n const isFirstRenderRef = useRef(true)\n\n const fieldsReducer = useReducer(fieldReducer, {}, () => initialState)\n\n const [formState, dispatchFields] = fieldsReducer\n\n contextRef.current.fields = formState\n\n const prevFormState = useRef(formState)\n\n const validateForm = useCallback(async () => {\n const validatedFieldState = {}\n let isValid = true\n\n const data = contextRef.current.getData()\n\n const validationPromises = Object.entries(contextRef.current.fields).map(\n async ([path, field]) => {\n const validatedField = field\n const pathSegments = path ? path.split('.') : []\n\n if (field.passesCondition !== false) {\n let validationResult: boolean | string = validatedField.valid\n\n if ('validate' in field && typeof field.validate === 'function') {\n let valueToValidate = field.value\n\n if (field?.rows && Array.isArray(field.rows)) {\n valueToValidate = contextRef.current.getDataByPath(path)\n }\n\n validationResult = await field.validate(valueToValidate, {\n ...field,\n id,\n collectionSlug,\n // If there is a parent document form, we can get the data from that form\n blockData: undefined, // Will be expensive to get - not worth to pass to client-side validation, as this can be obtained by the user using `useFormFields()`\n data: documentForm?.getData ? documentForm.getData() : data,\n event: 'submit',\n operation,\n path: pathSegments,\n preferences: {} as any,\n req: {\n payload: {\n config,\n },\n t,\n user,\n } as unknown as PayloadRequest,\n siblingData: contextRef.current.getSiblingData(path),\n })\n\n if (typeof validationResult === 'string') {\n validatedField.errorMessage = validationResult\n validatedField.valid = false\n } else {\n validatedField.valid = true\n validatedField.errorMessage = undefined\n }\n }\n\n if (validatedField.valid === false) {\n isValid = false\n }\n }\n\n validatedFieldState[path] = validatedField\n },\n )\n\n await Promise.all(validationPromises)\n\n if (!dequal(contextRef.current.fields, validatedFieldState)) {\n dispatchFields({ type: 'REPLACE_STATE', state: validatedFieldState })\n }\n\n setIsValid(isValid)\n\n return isValid\n }, [collectionSlug, config, dispatchFields, id, operation, t, user, documentForm])\n\n const submit = useCallback<Submit>(\n async (options, e) => {\n const {\n acceptValues = true,\n action: actionArg = action,\n context,\n disableFormWhileProcessing = true,\n disableSuccessStatus: disableSuccessStatusFromArgs,\n method: methodToUse = method,\n overrides: overridesFromArgs = {},\n skipValidation,\n } = options || ({} as SubmitOptions)\n\n const disableToast = disableSuccessStatusFromArgs ?? disableSuccessStatus\n\n if (disabled) {\n if (e) {\n e.preventDefault()\n }\n return\n }\n\n // create new toast promise which will resolve manually later\n let errorToast, successToast\n\n const promise = new Promise((resolve, reject) => {\n successToast = resolve\n errorToast = reject\n })\n\n const hasFormSubmitAction =\n actionArg || typeof action === 'string' || typeof action === 'function'\n\n if (redirect || disableToast || !hasFormSubmitAction) {\n // Do not show submitting toast, as the promise toast may never disappear under these conditions.\n // Instead, make successToast() or errorToast() throw toast.success / toast.error\n successToast = (data) => toast.success(data)\n errorToast = (data) => toast.error(data)\n } else {\n toast.promise(promise, {\n error: (data) => {\n return data as string\n },\n loading: t('general:submitting'),\n success: (data) => {\n return data as string\n },\n })\n }\n\n if (e) {\n e.stopPropagation()\n e.preventDefault()\n }\n\n if (disableFormWhileProcessing) {\n setProcessing(true)\n setDisabled(true)\n }\n\n if (waitForAutocomplete) {\n await wait(100)\n }\n\n const data = reduceFieldsToValues(contextRef.current.fields, true)\n\n const serializableFormState = deepCopyObjectSimpleWithoutReactComponents(\n contextRef.current.fields,\n )\n\n // Execute server side validations\n if (Array.isArray(beforeSubmit)) {\n let revalidatedFormState: FormState\n\n await beforeSubmit.reduce(async (priorOnChange, beforeSubmitFn) => {\n await priorOnChange\n\n const result = await beforeSubmitFn({\n formState: serializableFormState,\n })\n\n revalidatedFormState = result\n }, Promise.resolve())\n\n const isValid = Object.entries(revalidatedFormState).every(\n ([, field]) => field.valid !== false,\n )\n\n setIsValid(isValid)\n\n if (!isValid) {\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return dispatchFields({ type: 'REPLACE_STATE', state: revalidatedFormState })\n }\n }\n\n const isValid =\n skipValidation || disableValidationOnSubmit ? true : await contextRef.current.validateForm()\n\n setIsValid(isValid)\n\n // If not valid, prevent submission\n if (!isValid) {\n errorToast(t('error:correctInvalidFields'))\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return\n }\n\n let overrides = {}\n\n if (typeof overridesFromArgs === 'function') {\n overrides = overridesFromArgs(contextRef.current.fields)\n } else if (typeof overridesFromArgs === 'object') {\n overrides = overridesFromArgs\n }\n\n // If submit handler comes through via props, run that\n if (onSubmit) {\n for (const [key, value] of Object.entries(overrides)) {\n data[key] = value\n }\n\n onSubmit(contextRef.current.fields, data)\n }\n\n if (!hasFormSubmitAction) {\n // No action provided, so we should return. An example where this happens are lexical link drawers. Upon submitting the drawer, we\n // want to close it without submitting the form. Stuff like validation would be handled by lexical before this, through beforeSubmit\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n return\n }\n\n const formData = await contextRef.current.createFormData(overrides, {\n data,\n mergeOverrideData: Boolean(typeof overridesFromArgs !== 'function'),\n })\n\n try {\n let res\n\n if (typeof actionArg === 'string') {\n res = await requests[methodToUse.toLowerCase()](actionArg, {\n body: formData,\n headers: {\n 'Accept-Language': i18n.language,\n },\n })\n } else if (typeof action === 'function') {\n res = await action(formData)\n }\n\n if (!modifiedWhileProcessingRef.current) {\n setModified(false)\n } else {\n modifiedWhileProcessingRef.current = false\n }\n\n setDisabled(false)\n\n if (typeof handleResponse === 'function') {\n handleResponse(res, successToast, errorToast)\n return\n }\n\n const contentType = res.headers.get('content-type')\n const isJSON = contentType && contentType.indexOf('application/json') !== -1\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n let json: Record<string, any> = {}\n\n if (isJSON) {\n json = await res.json()\n }\n\n if (res.status < 400) {\n if (typeof onSuccess === 'function') {\n const newFormState = await onSuccess(json, {\n context,\n formState: serializableFormState,\n })\n\n if (newFormState) {\n dispatchFields({\n type: 'MERGE_SERVER_STATE',\n acceptValues,\n prevStateRef: prevFormState,\n serverState: newFormState,\n })\n }\n }\n\n setSubmitted(false)\n setProcessing(false)\n\n if (redirect) {\n startRouteTransition(() => router.push(redirect))\n } else if (!disableToast) {\n successToast(json.message || t('general:submissionSuccessful'))\n }\n } else {\n setProcessing(false)\n setSubmitted(true)\n\n // When there was an error submitting a draft,\n // set the form state to unsubmitted, to not trigger visible form validation on changes after the failed submit.\n // Also keep the form as modified so the save button remains enabled for retry.\n if (overridesFromArgs['_status'] === 'draft') {\n setModified(true)\n\n if (!validateDrafts) {\n setSubmitted(false)\n }\n }\n\n contextRef.current = { ...contextRef.current } // triggers rerender of all components that subscribe to form\n\n if (json.message) {\n errorToast(json.message)\n return\n }\n\n if (Array.isArray(json.errors)) {\n const [fieldErrors, nonFieldErrors] = json.errors.reduce(\n ([fieldErrs, nonFieldErrs], err) => {\n const newFieldErrs = []\n const newNonFieldErrs = []\n\n if (err?.message) {\n newNonFieldErrs.push(err)\n }\n\n if (Array.isArray(err?.data?.errors)) {\n err.data?.errors.forEach((dataError) => {\n if (dataError?.path) {\n newFieldErrs.push(dataError)\n } else {\n newNonFieldErrs.push(dataError)\n }\n })\n }\n\n return [\n [...fieldErrs, ...newFieldErrs],\n [...nonFieldErrs, ...newNonFieldErrs],\n ]\n },\n [[], []],\n )\n\n setIsValid(false)\n\n dispatchFields({\n type: 'ADD_SERVER_ERRORS',\n errors: fieldErrors,\n })\n\n nonFieldErrors.forEach((err) => {\n errorToast(<FieldErrorsToast errorMessage={err.message || t('error:unknown')} />)\n })\n\n return\n }\n\n const message = errorMessages?.[res.status] || res?.statusText || t('error:unknown')\n\n errorToast(message)\n }\n\n return { formState: contextRef.current.fields, res }\n } catch (err) {\n console.error('Error submitting form', err) // eslint-disable-line no-console\n setProcessing(false)\n setSubmitted(true)\n setDisabled(false)\n errorToast(err.message)\n }\n },\n [\n beforeSubmit,\n startRouteTransition,\n action,\n disableSuccessStatus,\n disableValidationOnSubmit,\n disabled,\n dispatchFields,\n handleResponse,\n method,\n onSubmit,\n onSuccess,\n redirect,\n router,\n t,\n i18n,\n validateDrafts,\n waitForAutocomplete,\n setModified,\n setSubmitted,\n ],\n )\n\n const getFields = useCallback(() => contextRef.current.fields, [])\n\n const getField = useCallback((path: string) => contextRef.current.fields[path], [])\n\n const getData = useCallback(() => reduceFieldsToValues(contextRef.current.fields, true), [])\n\n const getSiblingData = useCallback(\n (path: string) => getSiblingDataFunc(contextRef.current.fields, path),\n [],\n )\n\n const getDataByPath = useCallback<GetDataByPath>(\n (path: string) => getDataByPathFunc(contextRef.current.fields, path),\n [],\n )\n\n const createFormData = useCallback<CreateFormData>(\n async (overrides, { data: dataFromArgs, mergeOverrideData = true }) => {\n let data = dataFromArgs || reduceFieldsToValues(contextRef.current.fields, true)\n\n let file = data?.file\n\n if (docConfig && 'upload' in docConfig && docConfig.upload && file) {\n delete data.file\n\n const handler = getUploadHandler({ collectionSlug })\n\n if (typeof handler === 'function') {\n let filename = file.name\n const clientUploadContext = await handler({\n file,\n updateFilename: (value) => {\n filename = value\n },\n })\n\n file = JSON.stringify({\n clientUploadContext,\n collectionSlug,\n filename,\n mimeType: file.type,\n size: file.size,\n })\n }\n }\n\n if (mergeOverrideData) {\n data = {\n ...data,\n ...overrides,\n }\n } else {\n data = overrides\n }\n\n const dataToSerialize: Record<string, unknown> = {\n _payload: JSON.stringify(data),\n }\n\n if (docConfig && 'upload' in docConfig && docConfig.upload && file) {\n dataToSerialize.file = file\n }\n\n // nullAsUndefineds is important to allow uploads and relationship fields to clear themselves\n const formData = serialize(dataToSerialize, {\n indices: true,\n nullsAsUndefineds: false,\n })\n\n return formData\n },\n [collectionSlug, docConfig, getUploadHandler],\n )\n\n const reset = useCallback(\n async (data: unknown) => {\n const controller = handleAbortRef(abortResetFormRef)\n\n const docPreferences = await getDocPreferences()\n\n const { state: newState } = await getFormState({\n id,\n collectionSlug,\n data,\n docPermissions,\n docPreferences,\n globalSlug,\n locale,\n operation,\n renderAllFields: true,\n schemaPath: collectionSlug ? collectionSlug : globalSlug,\n signal: controller.signal,\n skipValidation: true,\n })\n\n contextRef.current = { ...initContextState } as FormContextType\n setModified(false)\n dispatchFields({ type: 'REPLACE_STATE', state: newState })\n\n abortResetFormRef.current = null\n },\n [\n collectionSlug,\n dispatchFields,\n globalSlug,\n id,\n operation,\n getFormState,\n docPermissions,\n getDocPreferences,\n locale,\n setModified,\n ],\n )\n\n const replaceState = useCallback(\n (state: FormState) => {\n contextRef.current = { ...initContextState } as FormContextType\n setModified(false)\n dispatchFields({ type: 'REPLACE_STATE', state })\n },\n [dispatchFields, setModified],\n )\n\n const addFieldRow: FormContextType['addFieldRow'] = useCallback(\n ({ blockType, path, rowIndex: rowIndexArg, subFieldState }) => {\n const newRows: unknown[] = getDataByPath(path) || []\n const rowIndex = rowIndexArg === undefined ? newRows.length : rowIndexArg\n\n // dispatch ADD_ROW adds a blank row to local form state.\n // This performs no form state request, as the debounced onChange effect will do that for us.\n dispatchFields({\n type: 'ADD_ROW',\n blockType,\n path,\n rowIndex,\n subFieldState,\n })\n\n setModified(true)\n },\n [dispatchFields, getDataByPath, setModified],\n )\n\n const moveFieldRow: FormContextType['moveFieldRow'] = useCallback(\n ({ moveFromIndex, moveToIndex, path }) => {\n dispatchFields({\n type: 'MOVE_ROW',\n moveFromIndex,\n moveToIndex,\n path,\n })\n\n setModified(true)\n },\n [dispatchFields, setModified],\n )\n\n const removeFieldRow: FormContextType['removeFieldRow'] = useCallback(\n ({ path, rowIndex }) => {\n dispatchFields({ type: 'REMOVE_ROW', path, rowIndex })\n\n setModified(true)\n },\n [dispatchFields, setModified],\n )\n\n const replaceFieldRow: FormContextType['replaceFieldRow'] = useCallback(\n ({ blockType, path, rowIndex: rowIndexArg, subFieldState }) => {\n const currentRows: unknown[] = getDataByPath(path)\n const rowIndex = rowIndexArg === undefined ? currentRows.length : rowIndexArg\n\n dispatchFields({\n type: 'REPLACE_ROW',\n blockType,\n path,\n rowIndex,\n subFieldState,\n })\n\n setModified(true)\n },\n [dispatchFields, getDataByPath, setModified],\n )\n\n useEffect(() => {\n const abortOnChange = abortResetFormRef.current\n\n return () => {\n abortAndIgnore(abortOnChange)\n }\n }, [])\n\n useEffect(() => {\n if (initializingFromProps !== undefined) {\n setInitializing(initializingFromProps)\n }\n }, [initializingFromProps])\n\n contextRef.current.submit = submit\n contextRef.current.getFields = getFields\n contextRef.current.getField = getField\n contextRef.current.getData = getData\n contextRef.current.getSiblingData = getSiblingData\n contextRef.current.getDataByPath = getDataByPath\n contextRef.current.validateForm = validateForm\n contextRef.current.createFormData = createFormData\n contextRef.current.setModified = setModified\n contextRef.current.setProcessing = setProcessing\n contextRef.current.setBackgroundProcessing = setBackgroundProcessing\n\n contextRef.current.setSubmitted = setSubmitted\n contextRef.current.setIsValid = setIsValid\n contextRef.current.disabled = disabled\n contextRef.current.setDisabled = setDisabled\n contextRef.current.formRef = formRef\n contextRef.current.reset = reset\n contextRef.current.replaceState = replaceState\n contextRef.current.dispatchFields = dispatchFields\n contextRef.current.addFieldRow = addFieldRow\n contextRef.current.removeFieldRow = removeFieldRow\n contextRef.current.moveFieldRow = moveFieldRow\n contextRef.current.replaceFieldRow = replaceFieldRow\n contextRef.current.uuid = uuid\n contextRef.current.initializing = initializing\n contextRef.current.isValid = isValid\n\n useEffect(() => {\n setIsMounted(true)\n }, [])\n\n useEffect(() => {\n if (typeof disabledFromProps === 'boolean') {\n setDisabled(disabledFromProps)\n }\n }, [disabledFromProps])\n\n useEffect(() => {\n if (typeof submittedFromProps === 'boolean') {\n setSubmitted(submittedFromProps)\n }\n }, [submittedFromProps])\n\n useEffect(() => {\n if (initialState) {\n contextRef.current = { ...initContextState } as FormContextType\n dispatchFields({\n type: 'REPLACE_STATE',\n optimize: false,\n sanitize: true,\n state: initialState,\n })\n }\n }, [initialState, dispatchFields])\n\n useThrottledEffect(\n () => {\n refreshCookie()\n },\n 15000,\n [formState],\n )\n\n const handleLocaleChange = useEffectEvent(() => {\n contextRef.current = { ...contextRef.current } // triggers rerender of all components that subscribe to form\n setModified(false)\n })\n\n useEffect(() => {\n handleLocaleChange()\n }, [locale])\n\n const classes = [className, baseClass].filter(Boolean).join(' ')\n\n const executeOnChange = useEffectEvent((submitted: boolean) => {\n queueTask(async () => {\n if (Array.isArray(onChange)) {\n let serverState: FormState\n\n for (const onChangeFn of onChange) {\n // Edit view default onChange is in packages/ui/src/views/Edit/index.tsx. This onChange usually sends a form state request\n serverState = await onChangeFn({\n formState: deepCopyObjectSimpleWithoutReactComponents(formState),\n submitted,\n })\n }\n\n dispatchFields({\n type: 'MERGE_SERVER_STATE',\n prevStateRef: prevFormState,\n serverState,\n })\n }\n })\n })\n\n useDebouncedEffect(\n () => {\n if ((isFirstRenderRef.current || !dequal(formState, prevFormState.current)) && modified) {\n executeOnChange(submitted)\n }\n\n prevFormState.current = formState\n isFirstRenderRef.current = false\n },\n [modified, submitted, formState],\n 250,\n )\n\n const DocumentFormContextComponent: React.FC<any> = isDocumentForm\n ? DocumentFormContext\n : React.Fragment\n\n const documentFormContextProps = isDocumentForm\n ? {\n value: contextRef.current,\n }\n : {}\n\n const El: 'form' = (el as unknown as 'form') || 'form'\n\n return (\n <El\n action={typeof action === 'function' ? void action : action}\n className={classes}\n method={method}\n noValidate\n onSubmit={(e) => void contextRef.current.submit({}, e)}\n ref={formRef}\n >\n <DocumentFormContextComponent {...documentFormContextProps}>\n <FormContext value={contextRef.current}>\n <FormWatchContext\n value={{\n fields: formState,\n ...contextRef.current,\n }}\n >\n <SubmittedContext value={submitted}>\n <InitializingContext value={!isMounted || (isMounted && initializing)}>\n <ProcessingContext value={processing}>\n <BackgroundProcessingContext value={backgroundProcessing}>\n <ModifiedContext value={modified}>\n {/* eslint-disable-next-line @eslint-react/no-context-provider */}\n <FormFieldsContext.Provider value={fieldsReducer}>\n {children}\n </FormFieldsContext.Provider>\n </ModifiedContext>\n </BackgroundProcessingContext>\n </ProcessingContext>\n </InitializingContext>\n </SubmittedContext>\n </FormWatchContext>\n </FormContext>\n </DocumentFormContextComponent>\n </El>\n )\n}\n\nexport {\n DocumentFormContext,\n FormContext,\n FormFieldsContext,\n FormWatchContext,\n ModifiedContext,\n ProcessingContext,\n SubmittedContext,\n useAllFormFields,\n useDocumentForm,\n useForm,\n useFormFields,\n useFormModified,\n useFormProcessing,\n useFormSubmitted,\n useWatchForm,\n} from './context.js'\n\nexport { FormProps }\n"],"names":["dequal","useRouter","serialize","deepCopyObjectSimpleWithoutReactComponents","getDataByPath","getDataByPathFunc","getSiblingData","getSiblingDataFunc","hasDraftValidationEnabled","reduceFieldsToValues","wait","React","useCallback","useEffect","useReducer","useRef","useState","toast","FieldErrorsToast","useDebouncedEffect","useEffectEvent","useQueue","useThrottledEffect","useAuth","useConfig","useDocumentInfo","useLocale","useOperation","useRouteTransition","useServerFunctions","useTranslation","useUploadHandlers","abortAndIgnore","handleAbortRef","requests","BackgroundProcessingContext","DocumentFormContext","FormContext","FormFieldsContext","FormWatchContext","InitializingContext","ModifiedContext","ProcessingContext","SubmittedContext","useDocumentForm","errorMessages","fieldReducer","initContextState","baseClass","Form","props","id","collectionSlug","docConfig","docPermissions","getDocPreferences","globalSlug","validateDrafts","action","beforeSubmit","children","className","disabled","disabledFromProps","disableSuccessStatus","disableValidationOnSubmit","el","handleResponse","initialState","isDocumentForm","isInitializing","initializingFromProps","onChange","onSubmit","onSuccess","redirect","submitted","submittedFromProps","uuid","waitForAutocomplete","method","undefined","router","documentForm","code","locale","i18n","t","refreshCookie","user","operation","queueTask","getFormState","startRouteTransition","getUploadHandler","config","setDisabled","isMounted","setIsMounted","setSubmitted","isValid","setIsValid","initializing","setInitializing","processing","setProcessing","backgroundProcessing","_setBackgroundProcessing","backgroundProcessingRef","modifiedWhileProcessingRef","setBackgroundProcessing","current","modified","_setModified","setModified","formRef","contextRef","abortResetFormRef","isFirstRenderRef","fieldsReducer","formState","dispatchFields","fields","prevFormState","validateForm","validatedFieldState","data","getData","validationPromises","Object","entries","map","path","field","validatedField","pathSegments","split","passesCondition","validationResult","valid","validate","valueToValidate","value","rows","Array","isArray","blockData","event","preferences","req","payload","siblingData","errorMessage","Promise","all","type","state","submit","options","e","acceptValues","actionArg","context","disableFormWhileProcessing","disableSuccessStatusFromArgs","methodToUse","overrides","overridesFromArgs","skipValidation","disableToast","preventDefault","errorToast","successToast","promise","resolve","reject","hasFormSubmitAction","success","error","loading","stopPropagation","serializableFormState","revalidatedFormState","reduce","priorOnChange","beforeSubmitFn","result","every","key","formData","createFormData","mergeOverrideData","Boolean","res","toLowerCase","body","headers","language","contentType","get","isJSON","indexOf","json","status","newFormState","prevStateRef","serverState","push","message","errors","fieldErrors","nonFieldErrors","fieldErrs","nonFieldErrs","err","newFieldErrs","newNonFieldErrs","forEach","dataError","statusText","console","getFields","getField","dataFromArgs","file","upload","handler","filename","name","clientUploadContext","updateFilename","JSON","stringify","mimeType","size","dataToSerialize","_payload","indices","nullsAsUndefineds","reset","controller","docPreferences","newState","renderAllFields","schemaPath","signal","replaceState","addFieldRow","blockType","rowIndex","rowIndexArg","subFieldState","newRows","length","moveFieldRow","moveFromIndex","moveToIndex","removeFieldRow","replaceFieldRow","currentRows","abortOnChange","optimize","sanitize","handleLocaleChange","classes","filter","join","executeOnChange","onChangeFn","DocumentFormContextComponent","Fragment","documentFormContextProps","El","noValidate","ref","Provider","useAllFormFields","useForm","useFormFields","useFormModified","useFormProcessing","useFormSubmitted","useWatchForm"],"mappings":"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"}
|
|
@@ -1,6 +1,14 @@
|
|
|
1
1
|
'use client';
|
|
2
|
-
import { dequal } from 'dequal/lite';
|
|
2
|
+
import { dequal } from 'dequal/lite';
|
|
3
|
+
// lite: no need for Map and Set support
|
|
3
4
|
/**
|
|
5
|
+
* If true, will accept all values from the server, overriding any current values in local state.
|
|
6
|
+
* Can also provide an options object for more granular control.
|
|
7
|
+
*/ /**
|
|
8
|
+
* When `false`, will accept the values from the server _UNLESS_ the value has been modified locally since the request was made.
|
|
9
|
+
* This is useful for autosave, for example, where hooks may have modified the field's value on the server while you were still making changes.
|
|
10
|
+
* @default undefined
|
|
11
|
+
*/ /**
|
|
4
12
|
* This function receives form state from the server and intelligently merges it into the client state.
|
|
5
13
|
* The server contains extra properties that the client may not have, e.g. custom components and error states.
|
|
6
14
|
* We typically do not want to merge properties that rely on user input, however, such as values, unless explicitly requested.
|
|
@@ -50,8 +58,8 @@ import { dequal } from 'dequal/lite'; // lite: no need for Map and Set support
|
|
|
50
58
|
*/ if (Array.isArray(incomingField.rows) && path in currentState) {
|
|
51
59
|
newState[path].rows = [
|
|
52
60
|
...currentState[path]?.rows || []
|
|
53
|
-
]
|
|
54
|
-
|
|
61
|
+
];
|
|
62
|
+
// shallow copy to avoid mutating the original array
|
|
55
63
|
incomingField.rows.forEach((row)=>{
|
|
56
64
|
const indexInCurrentState = currentState[path].rows?.findIndex((existingRow)=>existingRow.id === row.id);
|
|
57
65
|
if (indexInCurrentState > -1) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/forms/Form/mergeServerFormState.ts"],"sourcesContent":["'use client'\nimport type { FormState } from 'payload'\n\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\n\n/**\n * If true, will accept all values from the server, overriding any current values in local state.\n * Can also provide an options object for more granular control.\n */\nexport type AcceptValues =\n | {\n /**\n * When `false`, will accept the values from the server _UNLESS_ the value has been modified locally since the request was made.\n * This is useful for autosave, for example, where hooks may have modified the field's value on the server while you were still making changes.\n * @default undefined\n */\n overrideLocalChanges?: boolean\n }\n | boolean\n\ntype Args = {\n acceptValues?: AcceptValues\n currentState?: FormState\n incomingState: FormState\n}\n\n/**\n * This function receives form state from the server and intelligently merges it into the client state.\n * The server contains extra properties that the client may not have, e.g. custom components and error states.\n * We typically do not want to merge properties that rely on user input, however, such as values, unless explicitly requested.\n * Doing this would cause the client to lose any local changes to those fields.\n *\n * Note: Local state is the source of truth, not the new server state that is getting merged in. This is critical for array row\n * manipulation specifically, where the user may have added, removed, or reordered rows while a request was pending and is now stale.\n *\n * This function applies some defaults, as well as cleans up the server response in preparation for the client.\n * e.g. it will set `valid` and `passesCondition` to true if undefined, and remove `addedByServer` from the response.\n */\nexport const mergeServerFormState = ({\n acceptValues,\n currentState = {},\n incomingState,\n}: Args): FormState => {\n const newState = { ...currentState }\n\n for (const [path, incomingField] of Object.entries(incomingState || {})) {\n if (!(path in currentState) && !incomingField.addedByServer) {\n continue\n }\n\n /**\n * If it's a new field added by the server, always accept the value.\n * Otherwise:\n * a. accept all values when explicitly requested, e.g. on submit\n * b. only accept values for unmodified fields, e.g. on autosave\n */\n const shouldAcceptValue =\n incomingField.addedByServer ||\n acceptValues === true ||\n (typeof acceptValues === 'object' &&\n acceptValues !== null &&\n // Note: Must be explicitly `false`, allow `null` or `undefined` to mean true\n acceptValues.overrideLocalChanges === false &&\n !currentState[path]?.isModified)\n\n let sanitizedIncomingField = incomingField\n\n if (!shouldAcceptValue) {\n /**\n * Note: do not delete properties off `incomingField` as this will mutate the original object\n * Instead, omit them from the destructured object by excluding specific keys\n * This will also ensure we don't set `undefined` into the result unnecessarily\n */\n const { initialValue, value, ...rest } = incomingField\n sanitizedIncomingField = rest\n }\n\n newState[path] = {\n ...currentState[path],\n ...sanitizedIncomingField,\n }\n\n if (\n currentState[path] &&\n 'errorPaths' in currentState[path] &&\n !('errorPaths' in incomingField)\n ) {\n newState[path].errorPaths = []\n }\n\n /**\n * Deeply merge the rows array to ensure changes to local state are not lost while the request was pending\n * For example, the server response could come back with a row which has been deleted on the client\n * Loop over the incoming rows, if it exists in client side form state, merge in any new properties from the server\n * Note: read `currentState` and not `newState` here, as the `rows` property have already been merged above\n */\n if (Array.isArray(incomingField.rows) && path in currentState) {\n newState[path].rows = [...(currentState[path]?.rows || [])] // shallow copy to avoid mutating the original array\n\n incomingField.rows.forEach((row) => {\n const indexInCurrentState = currentState[path].rows?.findIndex(\n (existingRow) => existingRow.id === row.id,\n )\n\n if (indexInCurrentState > -1) {\n newState[path].rows[indexInCurrentState] = {\n ...currentState[path].rows[indexInCurrentState],\n ...row,\n }\n } else if (row.addedByServer) {\n /**\n * Note: This is a known limitation of computed array and block rows\n * If a new row was added by the server, we append it to the _end_ of this array\n * This is because the client is the source of truth, and it has arrays ordered in a certain position\n * For example, the user may have re-ordered rows client-side while a long running request is processing\n * This means that we _cannot_ slice a new row into the second position on the server, for example\n * By the time it gets back to the client, its index is stale\n */\n const newRow = { ...row }\n delete newRow.addedByServer\n newState[path].rows.push(newRow)\n }\n })\n }\n\n // If `valid` is `undefined`, mark it as `true`\n if (incomingField.valid !== false) {\n newState[path].valid = true\n }\n\n // If `passesCondition` is `undefined`, mark it as `true`\n if (incomingField.passesCondition !== false) {\n newState[path].passesCondition = true\n }\n\n /**\n * Undefined values for blocksFilterOptions coming back should be treated as \"all blocks allowed\" and\n * should always be merged in.\n * Without this, an undefined value coming back will incorrectly be ignored, and the previous filter will remain.\n */\n if (!incomingField.blocksFilterOptions) {\n delete newState[path].blocksFilterOptions\n }\n\n // Strip away the `addedByServer` property from the client\n // This will prevent it from being passed back to the server\n delete newState[path].addedByServer\n }\n\n // Return the original object reference if the state is unchanged\n // This will avoid unnecessary re-renders and dependency updates\n return dequal(newState, currentState) ? currentState : newState\n}\n"],"names":["dequal","mergeServerFormState","acceptValues","currentState","incomingState","newState","path","incomingField","Object","entries","addedByServer","shouldAcceptValue","overrideLocalChanges","isModified","sanitizedIncomingField","initialValue","value","rest","errorPaths","Array","isArray","rows","forEach","row","indexInCurrentState","findIndex","existingRow","id","newRow","push","valid","passesCondition","blocksFilterOptions"],"mappings":"AAAA;AAGA,SAASA,MAAM,QAAQ,cAAa,
|
|
1
|
+
{"version":3,"sources":["../../../src/forms/Form/mergeServerFormState.ts"],"sourcesContent":["'use client'\nimport type { FormState } from 'payload'\n\nimport { dequal } from 'dequal/lite' // lite: no need for Map and Set support\n\n/**\n * If true, will accept all values from the server, overriding any current values in local state.\n * Can also provide an options object for more granular control.\n */\nexport type AcceptValues =\n | {\n /**\n * When `false`, will accept the values from the server _UNLESS_ the value has been modified locally since the request was made.\n * This is useful for autosave, for example, where hooks may have modified the field's value on the server while you were still making changes.\n * @default undefined\n */\n overrideLocalChanges?: boolean\n }\n | boolean\n\ntype Args = {\n acceptValues?: AcceptValues\n currentState?: FormState\n incomingState: FormState\n}\n\n/**\n * This function receives form state from the server and intelligently merges it into the client state.\n * The server contains extra properties that the client may not have, e.g. custom components and error states.\n * We typically do not want to merge properties that rely on user input, however, such as values, unless explicitly requested.\n * Doing this would cause the client to lose any local changes to those fields.\n *\n * Note: Local state is the source of truth, not the new server state that is getting merged in. This is critical for array row\n * manipulation specifically, where the user may have added, removed, or reordered rows while a request was pending and is now stale.\n *\n * This function applies some defaults, as well as cleans up the server response in preparation for the client.\n * e.g. it will set `valid` and `passesCondition` to true if undefined, and remove `addedByServer` from the response.\n */\nexport const mergeServerFormState = ({\n acceptValues,\n currentState = {},\n incomingState,\n}: Args): FormState => {\n const newState = { ...currentState }\n\n for (const [path, incomingField] of Object.entries(incomingState || {})) {\n if (!(path in currentState) && !incomingField.addedByServer) {\n continue\n }\n\n /**\n * If it's a new field added by the server, always accept the value.\n * Otherwise:\n * a. accept all values when explicitly requested, e.g. on submit\n * b. only accept values for unmodified fields, e.g. on autosave\n */\n const shouldAcceptValue =\n incomingField.addedByServer ||\n acceptValues === true ||\n (typeof acceptValues === 'object' &&\n acceptValues !== null &&\n // Note: Must be explicitly `false`, allow `null` or `undefined` to mean true\n acceptValues.overrideLocalChanges === false &&\n !currentState[path]?.isModified)\n\n let sanitizedIncomingField = incomingField\n\n if (!shouldAcceptValue) {\n /**\n * Note: do not delete properties off `incomingField` as this will mutate the original object\n * Instead, omit them from the destructured object by excluding specific keys\n * This will also ensure we don't set `undefined` into the result unnecessarily\n */\n const { initialValue, value, ...rest } = incomingField\n sanitizedIncomingField = rest\n }\n\n newState[path] = {\n ...currentState[path],\n ...sanitizedIncomingField,\n }\n\n if (\n currentState[path] &&\n 'errorPaths' in currentState[path] &&\n !('errorPaths' in incomingField)\n ) {\n newState[path].errorPaths = []\n }\n\n /**\n * Deeply merge the rows array to ensure changes to local state are not lost while the request was pending\n * For example, the server response could come back with a row which has been deleted on the client\n * Loop over the incoming rows, if it exists in client side form state, merge in any new properties from the server\n * Note: read `currentState` and not `newState` here, as the `rows` property have already been merged above\n */\n if (Array.isArray(incomingField.rows) && path in currentState) {\n newState[path].rows = [...(currentState[path]?.rows || [])] // shallow copy to avoid mutating the original array\n\n incomingField.rows.forEach((row) => {\n const indexInCurrentState = currentState[path].rows?.findIndex(\n (existingRow) => existingRow.id === row.id,\n )\n\n if (indexInCurrentState > -1) {\n newState[path].rows[indexInCurrentState] = {\n ...currentState[path].rows[indexInCurrentState],\n ...row,\n }\n } else if (row.addedByServer) {\n /**\n * Note: This is a known limitation of computed array and block rows\n * If a new row was added by the server, we append it to the _end_ of this array\n * This is because the client is the source of truth, and it has arrays ordered in a certain position\n * For example, the user may have re-ordered rows client-side while a long running request is processing\n * This means that we _cannot_ slice a new row into the second position on the server, for example\n * By the time it gets back to the client, its index is stale\n */\n const newRow = { ...row }\n delete newRow.addedByServer\n newState[path].rows.push(newRow)\n }\n })\n }\n\n // If `valid` is `undefined`, mark it as `true`\n if (incomingField.valid !== false) {\n newState[path].valid = true\n }\n\n // If `passesCondition` is `undefined`, mark it as `true`\n if (incomingField.passesCondition !== false) {\n newState[path].passesCondition = true\n }\n\n /**\n * Undefined values for blocksFilterOptions coming back should be treated as \"all blocks allowed\" and\n * should always be merged in.\n * Without this, an undefined value coming back will incorrectly be ignored, and the previous filter will remain.\n */\n if (!incomingField.blocksFilterOptions) {\n delete newState[path].blocksFilterOptions\n }\n\n // Strip away the `addedByServer` property from the client\n // This will prevent it from being passed back to the server\n delete newState[path].addedByServer\n }\n\n // Return the original object reference if the state is unchanged\n // This will avoid unnecessary re-renders and dependency updates\n return dequal(newState, currentState) ? currentState : newState\n}\n"],"names":["dequal","mergeServerFormState","acceptValues","currentState","incomingState","newState","path","incomingField","Object","entries","addedByServer","shouldAcceptValue","overrideLocalChanges","isModified","sanitizedIncomingField","initialValue","value","rest","errorPaths","Array","isArray","rows","forEach","row","indexInCurrentState","findIndex","existingRow","id","newRow","push","valid","passesCondition","blocksFilterOptions"],"mappings":"AAAA;AAGA,SAASA,MAAM,QAAQ,cAAa;AAAC,wCAAwC;AAE7E;;;CAGC,GAGK;;;;OAIC,GAWP;;;;;;;;;;;CAWC,GACD,OAAO,MAAMC,uBAAuB,CAAC,EACnCC,YAAY,EACZC,eAAe,CAAC,CAAC,EACjBC,aAAa,EACR;IACL,MAAMC,WAAW;QAAE,GAAGF,YAAY;IAAC;IAEnC,KAAK,MAAM,CAACG,MAAMC,cAAc,IAAIC,OAAOC,OAAO,CAACL,iBAAiB,CAAC,GAAI;QACvE,IAAI,CAAEE,CAAAA,QAAQH,YAAW,KAAM,CAACI,cAAcG,aAAa,EAAE;YAC3D;QACF;QAEA;;;;;KAKC,GACD,MAAMC,oBACJJ,cAAcG,aAAa,IAC3BR,iBAAiB,QAChB,OAAOA,iBAAiB,YACvBA,iBAAiB,QACjB,6EAA6E;QAC7EA,aAAaU,oBAAoB,KAAK,SACtC,CAACT,YAAY,CAACG,KAAK,EAAEO;QAEzB,IAAIC,yBAAyBP;QAE7B,IAAI,CAACI,mBAAmB;YACtB;;;;OAIC,GACD,MAAM,EAAEI,YAAY,EAAEC,KAAK,EAAE,GAAGC,MAAM,GAAGV;YACzCO,yBAAyBG;QAC3B;QAEAZ,QAAQ,CAACC,KAAK,GAAG;YACf,GAAGH,YAAY,CAACG,KAAK;YACrB,GAAGQ,sBAAsB;QAC3B;QAEA,IACEX,YAAY,CAACG,KAAK,IAClB,gBAAgBH,YAAY,CAACG,KAAK,IAClC,CAAE,CAAA,gBAAgBC,aAAY,GAC9B;YACAF,QAAQ,CAACC,KAAK,CAACY,UAAU,GAAG,EAAE;QAChC;QAEA;;;;;KAKC,GACD,IAAIC,MAAMC,OAAO,CAACb,cAAcc,IAAI,KAAKf,QAAQH,cAAc;YAC7DE,QAAQ,CAACC,KAAK,CAACe,IAAI,GAAG;mBAAKlB,YAAY,CAACG,KAAK,EAAEe,QAAQ,EAAE;aAAE;YAAC,oDAAoD;YAEhHd,cAAcc,IAAI,CAACC,OAAO,CAAC,CAACC;gBAC1B,MAAMC,sBAAsBrB,YAAY,CAACG,KAAK,CAACe,IAAI,EAAEI,UACnD,CAACC,cAAgBA,YAAYC,EAAE,KAAKJ,IAAII,EAAE;gBAG5C,IAAIH,sBAAsB,CAAC,GAAG;oBAC5BnB,QAAQ,CAACC,KAAK,CAACe,IAAI,CAACG,oBAAoB,GAAG;wBACzC,GAAGrB,YAAY,CAACG,KAAK,CAACe,IAAI,CAACG,oBAAoB;wBAC/C,GAAGD,GAAG;oBACR;gBACF,OAAO,IAAIA,IAAIb,aAAa,EAAE;oBAC5B;;;;;;;WAOC,GACD,MAAMkB,SAAS;wBAAE,GAAGL,GAAG;oBAAC;oBACxB,OAAOK,OAAOlB,aAAa;oBAC3BL,QAAQ,CAACC,KAAK,CAACe,IAAI,CAACQ,IAAI,CAACD;gBAC3B;YACF;QACF;QAEA,+CAA+C;QAC/C,IAAIrB,cAAcuB,KAAK,KAAK,OAAO;YACjCzB,QAAQ,CAACC,KAAK,CAACwB,KAAK,GAAG;QACzB;QAEA,yDAAyD;QACzD,IAAIvB,cAAcwB,eAAe,KAAK,OAAO;YAC3C1B,QAAQ,CAACC,KAAK,CAACyB,eAAe,GAAG;QACnC;QAEA;;;;KAIC,GACD,IAAI,CAACxB,cAAcyB,mBAAmB,EAAE;YACtC,OAAO3B,QAAQ,CAACC,KAAK,CAAC0B,mBAAmB;QAC3C;QAEA,0DAA0D;QAC1D,4DAA4D;QAC5D,OAAO3B,QAAQ,CAACC,KAAK,CAACI,aAAa;IACrC;IAEA,iEAAiE;IACjE,gEAAgE;IAChE,OAAOV,OAAOK,UAAUF,gBAAgBA,eAAeE;AACzD,EAAC"}
|
|
@@ -5,8 +5,8 @@ const blacklistedKeys = [
|
|
|
5
5
|
const sanitizeField = (incomingField)=>{
|
|
6
6
|
const field = {
|
|
7
7
|
...incomingField
|
|
8
|
-
}
|
|
9
|
-
|
|
8
|
+
};
|
|
9
|
+
// shallow copy, as we only need to remove top-level keys
|
|
10
10
|
for (const key of blacklistedKeys){
|
|
11
11
|
delete field[key];
|
|
12
12
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/forms/Form/reduceToSerializableFields.ts"],"sourcesContent":["import { type FormField, type FormState } from 'payload'\n\ntype BlacklistedKeys = 'customComponents' | 'validate'\nconst blacklistedKeys: BlacklistedKeys[] = ['validate', 'customComponents']\n\nconst sanitizeField = (incomingField: FormField): FormField => {\n const field = { ...incomingField } // shallow copy, as we only need to remove top-level keys\n\n for (const key of blacklistedKeys) {\n delete field[key]\n }\n\n return field\n}\n\n/**\n * Takes in FormState and removes fields that are not serializable.\n * Returns FormState without blacklisted keys.\n */\nexport const reduceToSerializableFields = (\n fields: FormState,\n): {\n [key: string]: Omit<FormField, BlacklistedKeys>\n} => {\n const result: Record<string, Omit<FormField, BlacklistedKeys>> = {}\n\n for (const key in fields) {\n result[key] = sanitizeField(fields[key])\n }\n\n return result\n}\n"],"names":["blacklistedKeys","sanitizeField","incomingField","field","key","reduceToSerializableFields","fields","result"],"mappings":"AAGA,MAAMA,kBAAqC;IAAC;IAAY;CAAmB;AAE3E,MAAMC,gBAAgB,CAACC;IACrB,MAAMC,QAAQ;QAAE,GAAGD,aAAa;IAAC,
|
|
1
|
+
{"version":3,"sources":["../../../src/forms/Form/reduceToSerializableFields.ts"],"sourcesContent":["import { type FormField, type FormState } from 'payload'\n\ntype BlacklistedKeys = 'customComponents' | 'validate'\nconst blacklistedKeys: BlacklistedKeys[] = ['validate', 'customComponents']\n\nconst sanitizeField = (incomingField: FormField): FormField => {\n const field = { ...incomingField } // shallow copy, as we only need to remove top-level keys\n\n for (const key of blacklistedKeys) {\n delete field[key]\n }\n\n return field\n}\n\n/**\n * Takes in FormState and removes fields that are not serializable.\n * Returns FormState without blacklisted keys.\n */\nexport const reduceToSerializableFields = (\n fields: FormState,\n): {\n [key: string]: Omit<FormField, BlacklistedKeys>\n} => {\n const result: Record<string, Omit<FormField, BlacklistedKeys>> = {}\n\n for (const key in fields) {\n result[key] = sanitizeField(fields[key])\n }\n\n return result\n}\n"],"names":["blacklistedKeys","sanitizeField","incomingField","field","key","reduceToSerializableFields","fields","result"],"mappings":"AAGA,MAAMA,kBAAqC;IAAC;IAAY;CAAmB;AAE3E,MAAMC,gBAAgB,CAACC;IACrB,MAAMC,QAAQ;QAAE,GAAGD,aAAa;IAAC;IAAE,yDAAyD;IAE5F,KAAK,MAAME,OAAOJ,gBAAiB;QACjC,OAAOG,KAAK,CAACC,IAAI;IACnB;IAEA,OAAOD;AACT;AAEA;;;CAGC,GACD,OAAO,MAAME,6BAA6B,CACxCC;IAIA,MAAMC,SAA2D,CAAC;IAElE,IAAK,MAAMH,OAAOE,OAAQ;QACxBC,MAAM,CAACH,IAAI,GAAGH,cAAcK,MAAM,CAACF,IAAI;IACzC;IAEA,OAAOG;AACT,EAAC"}
|
package/dist/forms/Form/types.js
CHANGED
|
@@ -1,3 +1,54 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* Arbitrary context passed to the onSuccess callback.
|
|
3
|
+
*/ /**
|
|
4
|
+
* The form state that was sent with the request when retrieving the `json` arg.
|
|
5
|
+
*/ /**
|
|
6
|
+
* If you would like to solely leverage server-side validation on submit,
|
|
7
|
+
* you can disable checks that the form makes before it submits
|
|
8
|
+
*/ /**
|
|
9
|
+
* If you don't want the form to be a <form> element, you can pass a string here to use as the wrapper element.
|
|
10
|
+
*/ /**
|
|
11
|
+
* 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.
|
|
12
|
+
* 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
|
|
13
|
+
* feature of the Lexical Rich Text field)
|
|
14
|
+
*/ /**
|
|
15
|
+
* Determines if this Form is the main, top-level Form of a document. If set to true, the
|
|
16
|
+
* Form's children will be wrapped in a DocumentFormContext, which lets you access this document
|
|
17
|
+
* Form's data and fields from any child component - even if that child component is wrapped in a child
|
|
18
|
+
* Form (e.g. a lexical block).
|
|
19
|
+
*/ /**
|
|
20
|
+
* If you want to pass additional data to the onSuccess callback, you can use this context object.
|
|
21
|
+
*
|
|
22
|
+
* @experimental This property is experimental and may change in the future.
|
|
23
|
+
*/ /**
|
|
24
|
+
* When true, will disable the form while it is processing.
|
|
25
|
+
* @default true
|
|
26
|
+
*/ /**
|
|
27
|
+
* When true, will disable the success toast after form submission.
|
|
28
|
+
* @default false
|
|
29
|
+
*/ /**
|
|
30
|
+
* When true, will skip validation before submitting the form.
|
|
31
|
+
* @default false
|
|
32
|
+
*/ /**
|
|
33
|
+
* Returns the form state and the response from the server.
|
|
34
|
+
*
|
|
35
|
+
* @experimental - Note: the `{ res: ... }` return type is experimental and may change in the future. Use at your own risk.
|
|
36
|
+
*/ /**
|
|
37
|
+
* If mergeOverrideData true, the data will be merged with the existing data in the form state.
|
|
38
|
+
* @default true
|
|
39
|
+
*/ /**
|
|
40
|
+
* If provided, will use this instead of of derived data from the current form state.
|
|
41
|
+
*/ /**
|
|
42
|
+
* If `sanitize` is true, default values will be set for form field properties that are not present in the incoming state.
|
|
43
|
+
* For example, `valid` will be set to true if it is not present in the incoming state.
|
|
44
|
+
*/ export { }; /**
|
|
45
|
+
* Form context fields may be outdated and should not be relied on. Instead, prefer `useFormFields`.
|
|
46
|
+
*/ /**
|
|
47
|
+
* Tracks wether the form state passes validation.
|
|
48
|
+
* For example the state could be submitted but invalid as field errors have been returned.
|
|
49
|
+
*/ /**
|
|
50
|
+
* If the form has started processing in the background (e.g.
|
|
51
|
+
* if autosave is running), this will be true.
|
|
52
|
+
*/
|
|
2
53
|
|
|
3
54
|
//# sourceMappingURL=types.js.map
|