@payloadcms/ui 3.84.1 → 3.85.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/elements/BulkUpload/FormsManager/index.d.ts.map +1 -1
- package/dist/elements/BulkUpload/FormsManager/index.js +26 -10
- package/dist/elements/BulkUpload/FormsManager/index.js.map +1 -1
- package/dist/elements/ListControls/index.d.ts.map +1 -1
- package/dist/elements/ListControls/index.js +17 -21
- package/dist/elements/ListControls/index.js.map +1 -1
- package/dist/exports/client/{CodeEditor-67I2RYO2.js → CodeEditor-TL3K3PHG.js} +2 -2
- package/dist/exports/client/{DatePicker-T2DMDMM5.js → DatePicker-IJKMHICL.js} +2 -2
- package/dist/exports/client/{chunk-WDZJLNNB.js → chunk-B52EQI3B.js} +1 -1
- package/dist/exports/client/{chunk-WDZJLNNB.js.map → chunk-B52EQI3B.js.map} +1 -1
- package/dist/exports/client/{chunk-QP5KC7MG.js → chunk-MRRDX6D7.js} +1 -1
- package/dist/exports/client/{chunk-QP5KC7MG.js.map → chunk-MRRDX6D7.js.map} +1 -1
- package/dist/exports/client/index.js +12 -12
- package/dist/exports/client/index.js.map +4 -4
- package/dist/providers/TableColumns/RenderDefaultCell/index.js +1 -1
- package/dist/providers/TableColumns/RenderDefaultCell/index.js.map +1 -1
- package/package.json +8 -8
- /package/dist/exports/client/{CodeEditor-67I2RYO2.js.map → CodeEditor-TL3K3PHG.js.map} +0 -0
- /package/dist/exports/client/{DatePicker-T2DMDMM5.js.map → DatePicker-IJKMHICL.js.map} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/elements/BulkUpload/FormsManager/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAEV,IAAI,EACJ,aAAa,EACb,SAAS,EAET,4BAA4B,EAC5B,WAAW,EACZ,MAAM,SAAS,CAAA;AAKhB,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/elements/BulkUpload/FormsManager/index.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAEV,IAAI,EACJ,aAAa,EACb,SAAS,EAET,4BAA4B,EAC5B,WAAW,EACZ,MAAM,SAAS,CAAA;AAKhB,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAiBzC,KAAK,mBAAmB,GAAG;IACzB,QAAQ,CAAC,WAAW,EAAE,KAAK,CAAC,aAAa,CAAC,CAAA;IAC1C,QAAQ,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IACxD,QAAQ,CAAC,cAAc,EAAE,CACvB,aAAa,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACtC,gBAAgB,CAAC,EAAE,MAAM,IAAI,KAC1B,OAAO,CAAC,IAAI,CAAC,CAAA;IAClB,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAA;IAC/B,QAAQ,CAAC,cAAc,CAAC,EAAE,4BAA4B,CAAA;IACtD,QAAQ,CAAC,aAAa,EAAE,aAAa,CAAA;IACrC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,CAAA;IAC9B,cAAc,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,CAAA;IAC3C,QAAQ,CAAC,oBAAoB,EAAE,OAAO,CAAA;IACtC,QAAQ,CAAC,iBAAiB,EAAE,OAAO,CAAA;IACnC,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAA;IAC9B,QAAQ,CAAC,cAAc,EAAE,OAAO,CAAA;IAChC,QAAQ,CAAC,UAAU,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAC5C,QAAQ,CAAC,gBAAgB,CAAC,EAAE,MAAM,IAAI,CAAA;IACtC,QAAQ,CAAC,WAAW,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAA;IAChG,QAAQ,CAAC,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAChD,QAAQ,CAAC,sBAAsB,EAAE,CAAC,EAChC,UAAU,EACV,KAAK,GACN,EAAE;QACD,UAAU,EAAE,MAAM,CAAA;QAClB,KAAK,EAAE,MAAM,CAAA;KACd,KAAK,IAAI,CAAA;IACV,QAAQ,CAAC,eAAe,CAAC,EAAE,MAAM,CAAA;IACjC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,IAAI,EAAE,WAAW,KAAK,IAAI,CAAA;CACxD,CAAA;AA6BD,MAAM,MAAM,YAAY,GAAG,KAAK,CAAC;IAC/B,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,YAAY,CAAC,EAAE,SAAS,GAAG,IAAI,CAAA;CAChC,CAAC,CAAA;AAEF,KAAK,iBAAiB,GAAG;IACvB,QAAQ,CAAC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAA;CACnC,CAAA;AAED,wBAAgB,oBAAoB,CAAC,EAAE,QAAQ,EAAE,EAAE,iBAAiB,qBAgoBnE;AAED,wBAAgB,eAAe,wBAE9B"}
|
|
@@ -16,6 +16,7 @@ import { useUploadHandlers } from '../../../providers/UploadHandlers/index.js';
|
|
|
16
16
|
import { hasSavePermission as getHasSavePermission } from '../../../utilities/hasSavePermission.js';
|
|
17
17
|
import { LoadingOverlay } from '../../Loading/index.js';
|
|
18
18
|
import { useLoadingOverlay } from '../../LoadingOverlay/index.js';
|
|
19
|
+
import { FieldErrorsToast } from '../../Toasts/fieldErrors.js';
|
|
19
20
|
import { useBulkUpload } from '../index.js';
|
|
20
21
|
import { createFormData } from './createFormData.js';
|
|
21
22
|
import { formsManagementReducer } from './reducer.js';
|
|
@@ -323,7 +324,8 @@ export function FormsManagerProvider({
|
|
|
323
324
|
method: 'POST'
|
|
324
325
|
});
|
|
325
326
|
const json_0 = await req.json();
|
|
326
|
-
|
|
327
|
+
const wasSuccessful = req.status === 201 && json_0?.doc;
|
|
328
|
+
if (wasSuccessful) {
|
|
327
329
|
newDocs.push({
|
|
328
330
|
collectionSlug,
|
|
329
331
|
doc: json_0.doc,
|
|
@@ -394,14 +396,28 @@ export function FormsManagerProvider({
|
|
|
394
396
|
}
|
|
395
397
|
toast.error(nonFieldErrors[0]?.message);
|
|
396
398
|
} else {
|
|
399
|
+
let errorCount_0 = fieldErrors.length;
|
|
400
|
+
// Fall back to non-field errors when no field errors are present
|
|
401
|
+
// (e.g., APIError thrown from a hook).
|
|
402
|
+
if (!wasSuccessful && errorCount_0 === 0) {
|
|
403
|
+
errorCount_0 = nonFieldErrors.length || 1;
|
|
404
|
+
}
|
|
397
405
|
currentForms[i_0] = {
|
|
398
|
-
errorCount:
|
|
406
|
+
errorCount: errorCount_0,
|
|
399
407
|
formID: currentForms[i_0].formID,
|
|
400
408
|
formState: fieldReducer(currentForms[i_0].formState, {
|
|
401
409
|
type: 'ADD_SERVER_ERRORS',
|
|
402
410
|
errors: fieldErrors
|
|
403
411
|
})
|
|
404
412
|
};
|
|
413
|
+
// Mimic forms/Form/index.tsx.
|
|
414
|
+
if (!wasSuccessful) {
|
|
415
|
+
nonFieldErrors.forEach(err_0 => {
|
|
416
|
+
toast.error(/*#__PURE__*/_jsx(FieldErrorsToast, {
|
|
417
|
+
errorMessage: err_0.message || t('error:unknown')
|
|
418
|
+
}));
|
|
419
|
+
});
|
|
420
|
+
}
|
|
405
421
|
}
|
|
406
422
|
} catch (_) {
|
|
407
423
|
// swallow
|
|
@@ -412,23 +428,23 @@ export function FormsManagerProvider({
|
|
|
412
428
|
setIsUploading(false);
|
|
413
429
|
const remainingForms = [];
|
|
414
430
|
currentForms.forEach(({
|
|
415
|
-
errorCount:
|
|
431
|
+
errorCount: errorCount_1
|
|
416
432
|
}, i_1) => {
|
|
417
|
-
if (
|
|
433
|
+
if (errorCount_1) {
|
|
418
434
|
remainingForms.push(currentForms[i_1]);
|
|
419
435
|
}
|
|
420
436
|
});
|
|
421
437
|
const successCount = Math.max(0, currentForms.length - remainingForms.length);
|
|
422
|
-
const
|
|
438
|
+
const errorCount_2 = currentForms.length - successCount;
|
|
423
439
|
if (successCount) {
|
|
424
440
|
toast.success(`Successfully saved ${successCount} files`);
|
|
425
441
|
setSuccessfullyUploaded(true);
|
|
426
442
|
if (typeof onSuccess === 'function') {
|
|
427
|
-
onSuccess(newDocs,
|
|
443
|
+
onSuccess(newDocs, errorCount_2);
|
|
428
444
|
}
|
|
429
445
|
}
|
|
430
|
-
if (
|
|
431
|
-
toast.error(`Failed to save ${
|
|
446
|
+
if (errorCount_2) {
|
|
447
|
+
toast.error(`Failed to save ${errorCount_2} files`);
|
|
432
448
|
} else {
|
|
433
449
|
closeModal(drawerSlug);
|
|
434
450
|
}
|
|
@@ -445,8 +461,8 @@ export function FormsManagerProvider({
|
|
|
445
461
|
}, 0),
|
|
446
462
|
forms: remainingForms,
|
|
447
463
|
totalErrorCount: remainingForms.reduce((acc_1, {
|
|
448
|
-
errorCount:
|
|
449
|
-
}) => acc_1 +
|
|
464
|
+
errorCount: errorCount_3
|
|
465
|
+
}) => acc_1 + errorCount_3, 0)
|
|
450
466
|
}
|
|
451
467
|
});
|
|
452
468
|
if (remainingForms.length === 0) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["useModal","formatAdminURL","qs","React","toast","fieldReducer","useEffectEvent","useConfig","useLocale","useServerFunctions","useTranslation","useUploadHandlers","hasSavePermission","getHasSavePermission","LoadingOverlay","useLoadingOverlay","useBulkUpload","createFormData","formsManagementReducer","Context","createContext","activeIndex","addFiles","Promise","resolve","bulkUpdateForm","collectionSlug","docPermissions","undefined","documentSlots","forms","getFormDataRef","current","hasPublishPermission","hasSubmitted","isInitializing","removeFile","saveAllDocs","setActiveIndex","setFormTotalErrorCount","totalErrorCount","updateUploadEdits","initialState","FormsManagerProvider","children","config","routes","api","folderFieldName","folders","fieldName","code","i18n","t","getDocumentSlots","getFormState","getUploadHandler","setDocumentSlots","useState","setHasSubmitted","setDocPermissions","setHasSavePermission","setHasPublishPermission","hasInitializedState","setHasInitializedState","hasInitializedDocPermissions","setHasInitializedDocPermissions","setIsInitializing","state","dispatch","useReducer","formsRef","useRef","toggleLoadingOverlay","closeModal","drawerSlug","folderID","initialFiles","initialForms","onSuccess","setInitialFiles","setInitialForms","setSuccessfullyUploaded","isUploading","setIsUploading","loadingText","setLoadingText","hasInitializedWithFiles","initialStateRef","baseAPIPath","apiRoute","path","actionURL","initializeSharedDocPermissions","useCallback","params","locale","docAccessURL","res","fetch","stringify","credentials","headers","language","method","json","publishedAccessJSON","body","JSON","_status","then","isEditing","update","initializeSharedFormState","abortController","signal","abort","formStateWithoutFiles","docPreferences","fields","operation","renderAllFields","schemaPath","skipValidation","customComponents","Field","_err","index","currentFormsData","type","map","form","i","errorCount","formID","formState","uploadEdits","applyFolderToState","baseState","initialValue","value","files","length","isLoading","key","Array","from","file","addFilesEffectEvent","addInitialForms","count","overrides","currentForms","activeFormID","newDocs","fileValue","total","actionURLWithParams","addQueryPrefix","req","status","doc","push","fieldErrors","nonFieldErrors","errors","reduce","fieldErrs","nonFieldErrs","err","newFieldErrs","newNonFieldErrs","message","isArray","data","forEach","dataError","missingFile","exceedsLimit","missingFilename","name","valid","originalFileValue","formStateForServer","File","newState","Object","values","acc","error","_","remainingForms","successCount","Math","max","success","updatedFields","afterStateUpdate","entries","newFormErrorCount","resetUploadEdits","useEffect","_jsxs","_jsx","animationDuration","overlayType","show","useFormsManager","use"],"sources":["../../../../src/elements/BulkUpload/FormsManager/index.tsx"],"sourcesContent":["'use client'\n\nimport type {\n CollectionSlug,\n Data,\n DocumentSlots,\n FormState,\n JsonObject,\n SanitizedDocumentPermissions,\n UploadEdits,\n} from 'payload'\n\nimport { useModal } from '@faceless-ui/modal'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React from 'react'\nimport { toast } from 'sonner'\n\nimport type { State } from './reducer.js'\n\nimport { fieldReducer } from '../../../forms/Form/fieldReducer.js'\nimport { useEffectEvent } from '../../../hooks/useEffectEvent.js'\nimport { useConfig } from '../../../providers/Config/index.js'\nimport { useLocale } from '../../../providers/Locale/index.js'\nimport { useServerFunctions } from '../../../providers/ServerFunctions/index.js'\nimport { useTranslation } from '../../../providers/Translation/index.js'\nimport { useUploadHandlers } from '../../../providers/UploadHandlers/index.js'\nimport { hasSavePermission as getHasSavePermission } from '../../../utilities/hasSavePermission.js'\nimport { LoadingOverlay } from '../../Loading/index.js'\nimport { useLoadingOverlay } from '../../LoadingOverlay/index.js'\nimport { useBulkUpload } from '../index.js'\nimport { createFormData } from './createFormData.js'\nimport { formsManagementReducer } from './reducer.js'\n\ntype FormsManagerContext = {\n readonly activeIndex: State['activeIndex']\n readonly addFiles: (filelist: FileList) => Promise<void>\n readonly bulkUpdateForm: (\n updatedFields: Record<string, unknown>,\n afterStateUpdate?: () => void,\n ) => Promise<void>\n readonly collectionSlug: string\n readonly docPermissions?: SanitizedDocumentPermissions\n readonly documentSlots: DocumentSlots\n readonly forms: State['forms']\n getFormDataRef: React.RefObject<() => Data>\n readonly hasPublishPermission: boolean\n readonly hasSavePermission: boolean\n readonly hasSubmitted: boolean\n readonly isInitializing: boolean\n readonly removeFile: (index: number) => void\n readonly resetUploadEdits?: () => void\n readonly saveAllDocs: ({ overrides }?: { overrides?: Record<string, unknown> }) => Promise<void>\n readonly setActiveIndex: (index: number) => void\n readonly setFormTotalErrorCount: ({\n errorCount,\n index,\n }: {\n errorCount: number\n index: number\n }) => void\n readonly totalErrorCount?: number\n readonly updateUploadEdits: (args: UploadEdits) => void\n}\n\nconst Context = React.createContext<FormsManagerContext>({\n activeIndex: 0,\n addFiles: () => Promise.resolve(),\n bulkUpdateForm: () => null,\n collectionSlug: '',\n docPermissions: undefined,\n documentSlots: {},\n forms: [],\n getFormDataRef: { current: () => ({}) },\n hasPublishPermission: false,\n hasSavePermission: false,\n hasSubmitted: false,\n isInitializing: false,\n removeFile: () => {},\n saveAllDocs: () => Promise.resolve(),\n setActiveIndex: () => 0,\n setFormTotalErrorCount: () => {},\n totalErrorCount: 0,\n updateUploadEdits: () => {},\n})\n\nconst initialState: State = {\n activeIndex: 0,\n forms: [],\n totalErrorCount: 0,\n}\n\nexport type InitialForms = Array<{\n file: File\n formID?: string\n initialState?: FormState | null\n}>\n\ntype FormsManagerProps = {\n readonly children: React.ReactNode\n}\n\nexport function FormsManagerProvider({ children }: FormsManagerProps) {\n const { config } = useConfig()\n const {\n routes: { api },\n } = config\n const folderFieldName = config.folders ? config.folders.fieldName : undefined\n const { code } = useLocale()\n const { i18n, t } = useTranslation()\n\n const { getDocumentSlots, getFormState } = useServerFunctions()\n const { getUploadHandler } = useUploadHandlers()\n\n const [documentSlots, setDocumentSlots] = React.useState<DocumentSlots>({})\n const [hasSubmitted, setHasSubmitted] = React.useState(false)\n const [docPermissions, setDocPermissions] = React.useState<SanitizedDocumentPermissions>()\n const [hasSavePermission, setHasSavePermission] = React.useState(false)\n const [hasPublishPermission, setHasPublishPermission] = React.useState(false)\n const [hasInitializedState, setHasInitializedState] = React.useState(false)\n const [hasInitializedDocPermissions, setHasInitializedDocPermissions] = React.useState(false)\n const [isInitializing, setIsInitializing] = React.useState(false)\n const [state, dispatch] = React.useReducer(formsManagementReducer, initialState)\n const { activeIndex, forms, totalErrorCount } = state\n\n const formsRef = React.useRef(forms)\n formsRef.current = forms\n\n const { toggleLoadingOverlay } = useLoadingOverlay()\n const { closeModal } = useModal()\n const {\n collectionSlug,\n drawerSlug,\n folderID,\n initialFiles,\n initialForms,\n onSuccess,\n setInitialFiles,\n setInitialForms,\n setSuccessfullyUploaded,\n } = useBulkUpload()\n\n const [isUploading, setIsUploading] = React.useState(false)\n const [loadingText, setLoadingText] = React.useState('')\n\n const hasInitializedWithFiles = React.useRef(false)\n const initialStateRef = React.useRef<FormState>(null)\n const getFormDataRef = React.useRef<() => Data>(() => ({}))\n\n const baseAPIPath = formatAdminURL({\n apiRoute: api,\n path: '',\n })\n\n const actionURL = `${baseAPIPath}/${collectionSlug}`\n\n const initializeSharedDocPermissions = React.useCallback(async () => {\n const params = {\n locale: code || undefined,\n }\n\n const docAccessURL = `/${collectionSlug}/access`\n const res = await fetch(`${baseAPIPath}${docAccessURL}?${qs.stringify(params)}`, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n })\n\n const json: SanitizedDocumentPermissions = await res.json()\n const publishedAccessJSON = await fetch(\n `${baseAPIPath}${docAccessURL}?${qs.stringify(params)}`,\n {\n body: JSON.stringify({\n _status: 'published',\n }),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n },\n ).then((res) => res.json())\n\n setDocPermissions(json)\n\n setHasSavePermission(\n getHasSavePermission({\n collectionSlug,\n docPermissions: json,\n isEditing: false,\n }),\n )\n\n setHasPublishPermission(publishedAccessJSON?.update)\n setHasInitializedDocPermissions(true)\n }, [baseAPIPath, code, collectionSlug, i18n.language])\n\n const initializeSharedFormState = React.useCallback(\n async (abortController?: AbortController) => {\n if (abortController?.signal) {\n abortController.abort('aborting previous fetch for initial form state without files')\n }\n\n // FETCH AND SET THE DOCUMENT SLOTS HERE!\n const documentSlots = await getDocumentSlots({ collectionSlug })\n setDocumentSlots(documentSlots)\n\n try {\n const { state: formStateWithoutFiles } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: { fields: {} },\n locale: code,\n operation: 'create',\n renderAllFields: true,\n schemaPath: collectionSlug,\n skipValidation: true,\n })\n\n if (folderFieldName && formStateWithoutFiles?.[folderFieldName]) {\n formStateWithoutFiles[folderFieldName] = {\n ...formStateWithoutFiles[folderFieldName],\n customComponents: {\n ...formStateWithoutFiles[folderFieldName].customComponents,\n Field: undefined,\n },\n }\n }\n\n initialStateRef.current = formStateWithoutFiles\n setHasInitializedState(true)\n } catch (_err) {\n // swallow error\n }\n },\n [getDocumentSlots, collectionSlug, getFormState, docPermissions, code, folderFieldName],\n )\n\n const setActiveIndex: FormsManagerContext['setActiveIndex'] = React.useCallback(\n (index: number) => {\n const currentFormsData = getFormDataRef.current()\n\n dispatch({\n type: 'REPLACE',\n state: {\n activeIndex: index,\n forms: forms.map((form, i) => {\n if (i === activeIndex) {\n return {\n errorCount: form.errorCount,\n formID: form.formID,\n formState: currentFormsData,\n uploadEdits: form.uploadEdits,\n }\n }\n return form\n }),\n },\n })\n },\n [forms, activeIndex],\n )\n\n const applyFolderToState = React.useCallback(\n (baseState: FormState | null): FormState | null => {\n if (folderID && folderFieldName && baseState?.[folderFieldName]) {\n return {\n ...baseState,\n [folderFieldName]: {\n ...baseState[folderFieldName],\n initialValue: folderID,\n value: folderID,\n },\n }\n }\n return baseState\n },\n [folderID, folderFieldName],\n )\n\n const addFiles = React.useCallback(\n async (files: FileList) => {\n if (forms.length) {\n // save the state of the current form before adding new files\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[activeIndex].errorCount,\n formState: getFormDataRef.current(),\n index: activeIndex,\n })\n }\n\n toggleLoadingOverlay({ isLoading: true, key: 'addingDocs' })\n if (!hasInitializedState) {\n await initializeSharedFormState()\n }\n dispatch({\n type: 'ADD_FORMS',\n forms: Array.from(files).map((file) => ({\n file,\n initialState: applyFolderToState(initialStateRef.current),\n })),\n })\n toggleLoadingOverlay({ isLoading: false, key: 'addingDocs' })\n },\n [\n initializeSharedFormState,\n hasInitializedState,\n toggleLoadingOverlay,\n activeIndex,\n forms,\n applyFolderToState,\n ],\n )\n\n const addFilesEffectEvent = useEffectEvent(addFiles)\n\n const addInitialForms = useEffectEvent(async (initialForms: InitialForms) => {\n toggleLoadingOverlay({ isLoading: true, key: 'addingDocs' })\n\n if (!hasInitializedState) {\n await initializeSharedFormState()\n }\n\n dispatch({\n type: 'ADD_FORMS',\n forms: initialForms.map((form) => ({\n ...form,\n initialState: applyFolderToState(form?.initialState || initialStateRef.current),\n })),\n })\n\n toggleLoadingOverlay({ isLoading: false, key: 'addingDocs' })\n })\n\n const removeFile: FormsManagerContext['removeFile'] = React.useCallback((index) => {\n dispatch({ type: 'REMOVE_FORM', index })\n }, [])\n\n const setFormTotalErrorCount: FormsManagerContext['setFormTotalErrorCount'] = React.useCallback(\n ({ errorCount, index }) => {\n dispatch({\n type: 'UPDATE_ERROR_COUNT',\n count: errorCount,\n index,\n })\n },\n [],\n )\n\n const saveAllDocs: FormsManagerContext['saveAllDocs'] = React.useCallback(\n async ({ overrides } = {}) => {\n const currentFormsData = getFormDataRef.current()\n const currentForms = [...forms]\n currentForms[activeIndex] = {\n errorCount: currentForms[activeIndex].errorCount,\n formID: currentForms[activeIndex].formID,\n formState: currentFormsData,\n uploadEdits: currentForms[activeIndex].uploadEdits,\n }\n const activeFormID = currentForms[activeIndex]?.formID\n const newDocs: Array<{\n collectionSlug: CollectionSlug\n doc: JsonObject\n /**\n * ID of the form that created this document\n */\n formID: string\n }> = []\n\n setIsUploading(true)\n\n for (let i = 0; i < currentForms.length; i++) {\n try {\n const form = currentForms[i]\n const fileValue = form.formState?.file?.value\n\n setLoadingText(t('general:uploadingBulk', { current: i + 1, total: currentForms.length }))\n\n const actionURLWithParams = `${actionURL}${qs.stringify(\n {\n locale: code,\n uploadEdits: form?.uploadEdits || undefined,\n },\n {\n addQueryPrefix: true,\n },\n )}`\n\n const req = await fetch(actionURLWithParams, {\n body: await createFormData(\n form.formState,\n overrides,\n collectionSlug,\n getUploadHandler({ collectionSlug }),\n ),\n credentials: 'include',\n method: 'POST',\n })\n\n const json = await req.json()\n\n if (req.status === 201 && json?.doc) {\n newDocs.push({\n collectionSlug,\n doc: json.doc,\n formID: form.formID,\n })\n }\n\n // should expose some sort of helper for this\n const [fieldErrors, nonFieldErrors] = (json?.errors || []).reduce(\n ([fieldErrs, nonFieldErrs], err) => {\n const newFieldErrs: any[] = []\n const newNonFieldErrs: any[] = []\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 const missingFile = !fileValue && req.status === 400\n const exceedsLimit = fileValue && req.status === 413\n const missingFilename =\n fileValue &&\n typeof fileValue === 'object' &&\n 'name' in fileValue &&\n (!fileValue.name || fileValue.name === '')\n\n if (missingFile || exceedsLimit || missingFilename) {\n currentForms[i].formState.file.valid = false\n\n // File/Blob objects cannot be serialized via the RSC flight protocol,\n // so replace with a plain object before calling the server function.\n const originalFileValue = currentForms[i].formState.file?.value\n const formStateForServer = { ...currentForms[i].formState }\n if (originalFileValue instanceof File) {\n formStateForServer.file = {\n ...formStateForServer.file,\n value: { name: originalFileValue.name },\n }\n }\n\n // Need to get the field state to extract count since field errors\n // are not returned when file is missing or exceeds limit\n const { state: newState } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: null,\n formState: formStateForServer,\n operation: 'update',\n schemaPath: collectionSlug,\n })\n\n if (newState) {\n if (originalFileValue instanceof File && newState.file) {\n newState.file = { ...newState.file, value: originalFileValue }\n }\n\n currentForms[i] = {\n errorCount: Object.values(newState).reduce(\n (acc, value) => (value?.valid === false ? acc + 1 : acc),\n 0,\n ),\n formID: currentForms[i].formID,\n formState: newState,\n }\n }\n\n toast.error(nonFieldErrors[0]?.message)\n } else {\n currentForms[i] = {\n errorCount: fieldErrors.length,\n formID: currentForms[i].formID,\n formState: fieldReducer(currentForms[i].formState, {\n type: 'ADD_SERVER_ERRORS',\n errors: fieldErrors,\n }),\n }\n }\n } catch (_) {\n // swallow\n }\n }\n\n setHasSubmitted(true)\n setLoadingText('')\n setIsUploading(false)\n\n const remainingForms = []\n\n currentForms.forEach(({ errorCount }, i) => {\n if (errorCount) {\n remainingForms.push(currentForms[i])\n }\n })\n\n const successCount = Math.max(0, currentForms.length - remainingForms.length)\n const errorCount = currentForms.length - successCount\n\n if (successCount) {\n toast.success(`Successfully saved ${successCount} files`)\n setSuccessfullyUploaded(true)\n\n if (typeof onSuccess === 'function') {\n onSuccess(newDocs, errorCount)\n }\n }\n\n if (errorCount) {\n toast.error(`Failed to save ${errorCount} files`)\n } else {\n closeModal(drawerSlug)\n }\n\n dispatch({\n type: 'REPLACE',\n state: {\n activeIndex: remainingForms.reduce((acc, { formID }, i) => {\n if (formID === activeFormID) {\n return i\n }\n return acc\n }, 0),\n forms: remainingForms,\n totalErrorCount: remainingForms.reduce((acc, { errorCount }) => acc + errorCount, 0),\n },\n })\n\n if (remainingForms.length === 0) {\n setInitialFiles(undefined)\n setInitialForms(undefined)\n }\n },\n [\n forms,\n activeIndex,\n t,\n actionURL,\n code,\n collectionSlug,\n getUploadHandler,\n getFormState,\n docPermissions,\n setSuccessfullyUploaded,\n onSuccess,\n closeModal,\n drawerSlug,\n setInitialFiles,\n setInitialForms,\n ],\n )\n\n const bulkUpdateForm = React.useCallback(\n async (updatedFields: Record<string, unknown>, afterStateUpdate?: () => void) => {\n for (let i = 0; i < forms.length; i++) {\n Object.entries(updatedFields).forEach(([path, value]) => {\n if (forms[i].formState[path]) {\n forms[i].formState[path].value = value\n\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[i].errorCount,\n formState: forms[i].formState,\n index: i,\n })\n }\n })\n\n if (typeof afterStateUpdate === 'function') {\n afterStateUpdate()\n }\n\n if (hasSubmitted) {\n const { state } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: null,\n formState: forms[i].formState,\n operation: 'create',\n schemaPath: collectionSlug,\n })\n\n const newFormErrorCount = Object.values(state).reduce(\n (acc, value) => (value?.valid === false ? acc + 1 : acc),\n 0,\n )\n\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: newFormErrorCount,\n formState: state,\n index: i,\n })\n }\n }\n },\n [collectionSlug, docPermissions, forms, getFormState, hasSubmitted],\n )\n\n const updateUploadEdits = React.useCallback<FormsManagerContext['updateUploadEdits']>(\n (uploadEdits) => {\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[activeIndex].errorCount,\n formState: forms[activeIndex].formState,\n index: activeIndex,\n uploadEdits,\n })\n },\n [activeIndex, forms],\n )\n\n const resetUploadEdits = React.useCallback<FormsManagerContext['resetUploadEdits']>(() => {\n dispatch({\n type: 'REPLACE',\n state: {\n forms: forms.map((form) => ({\n ...form,\n uploadEdits: {},\n })),\n },\n })\n }, [forms])\n\n React.useEffect(() => {\n if (!collectionSlug) {\n return\n }\n if (!hasInitializedState) {\n void initializeSharedFormState()\n }\n\n if (!hasInitializedDocPermissions) {\n void initializeSharedDocPermissions()\n }\n\n if (initialFiles || initialForms) {\n if (!hasInitializedState || !hasInitializedDocPermissions) {\n setIsInitializing(true)\n } else {\n setIsInitializing(false)\n }\n }\n\n if (\n hasInitializedState &&\n (initialForms?.length || initialFiles?.length) &&\n !hasInitializedWithFiles.current\n ) {\n if (initialForms?.length) {\n void addInitialForms(initialForms)\n }\n if (initialFiles?.length) {\n void addFilesEffectEvent(initialFiles)\n }\n hasInitializedWithFiles.current = true\n }\n return\n }, [\n initialFiles,\n initializeSharedFormState,\n initializeSharedDocPermissions,\n collectionSlug,\n hasInitializedState,\n hasInitializedDocPermissions,\n initialForms,\n ])\n\n return (\n <Context\n value={{\n activeIndex: state.activeIndex,\n addFiles,\n bulkUpdateForm,\n collectionSlug,\n docPermissions,\n documentSlots,\n forms,\n getFormDataRef,\n hasPublishPermission,\n hasSavePermission,\n hasSubmitted,\n isInitializing,\n removeFile,\n resetUploadEdits,\n saveAllDocs,\n setActiveIndex,\n setFormTotalErrorCount,\n totalErrorCount,\n updateUploadEdits,\n }}\n >\n {isUploading && (\n <LoadingOverlay\n animationDuration=\"250ms\"\n loadingText={loadingText}\n overlayType=\"fullscreen\"\n show\n />\n )}\n {children}\n </Context>\n )\n}\n\nexport function useFormsManager() {\n return React.use(Context)\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["useModal","formatAdminURL","qs","React","toast","fieldReducer","useEffectEvent","useConfig","useLocale","useServerFunctions","useTranslation","useUploadHandlers","hasSavePermission","getHasSavePermission","LoadingOverlay","useLoadingOverlay","FieldErrorsToast","useBulkUpload","createFormData","formsManagementReducer","Context","createContext","activeIndex","addFiles","Promise","resolve","bulkUpdateForm","collectionSlug","docPermissions","undefined","documentSlots","forms","getFormDataRef","current","hasPublishPermission","hasSubmitted","isInitializing","removeFile","saveAllDocs","setActiveIndex","setFormTotalErrorCount","totalErrorCount","updateUploadEdits","initialState","FormsManagerProvider","children","config","routes","api","folderFieldName","folders","fieldName","code","i18n","t","getDocumentSlots","getFormState","getUploadHandler","setDocumentSlots","useState","setHasSubmitted","setDocPermissions","setHasSavePermission","setHasPublishPermission","hasInitializedState","setHasInitializedState","hasInitializedDocPermissions","setHasInitializedDocPermissions","setIsInitializing","state","dispatch","useReducer","formsRef","useRef","toggleLoadingOverlay","closeModal","drawerSlug","folderID","initialFiles","initialForms","onSuccess","setInitialFiles","setInitialForms","setSuccessfullyUploaded","isUploading","setIsUploading","loadingText","setLoadingText","hasInitializedWithFiles","initialStateRef","baseAPIPath","apiRoute","path","actionURL","initializeSharedDocPermissions","useCallback","params","locale","docAccessURL","res","fetch","stringify","credentials","headers","language","method","json","publishedAccessJSON","body","JSON","_status","then","isEditing","update","initializeSharedFormState","abortController","signal","abort","formStateWithoutFiles","docPreferences","fields","operation","renderAllFields","schemaPath","skipValidation","customComponents","Field","_err","index","currentFormsData","type","map","form","i","errorCount","formID","formState","uploadEdits","applyFolderToState","baseState","initialValue","value","files","length","isLoading","key","Array","from","file","addFilesEffectEvent","addInitialForms","count","overrides","currentForms","activeFormID","newDocs","fileValue","total","actionURLWithParams","addQueryPrefix","req","wasSuccessful","status","doc","push","fieldErrors","nonFieldErrors","errors","reduce","fieldErrs","nonFieldErrs","err","newFieldErrs","newNonFieldErrs","message","isArray","data","forEach","dataError","missingFile","exceedsLimit","missingFilename","name","valid","originalFileValue","formStateForServer","File","newState","Object","values","acc","error","_jsx","errorMessage","_","remainingForms","successCount","Math","max","success","updatedFields","afterStateUpdate","entries","newFormErrorCount","resetUploadEdits","useEffect","_jsxs","animationDuration","overlayType","show","useFormsManager","use"],"sources":["../../../../src/elements/BulkUpload/FormsManager/index.tsx"],"sourcesContent":["'use client'\n\nimport type {\n CollectionSlug,\n Data,\n DocumentSlots,\n FormState,\n JsonObject,\n SanitizedDocumentPermissions,\n UploadEdits,\n} from 'payload'\n\nimport { useModal } from '@faceless-ui/modal'\nimport { formatAdminURL } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React from 'react'\nimport { toast } from 'sonner'\n\nimport type { State } from './reducer.js'\n\nimport { fieldReducer } from '../../../forms/Form/fieldReducer.js'\nimport { useEffectEvent } from '../../../hooks/useEffectEvent.js'\nimport { useConfig } from '../../../providers/Config/index.js'\nimport { useLocale } from '../../../providers/Locale/index.js'\nimport { useServerFunctions } from '../../../providers/ServerFunctions/index.js'\nimport { useTranslation } from '../../../providers/Translation/index.js'\nimport { useUploadHandlers } from '../../../providers/UploadHandlers/index.js'\nimport { hasSavePermission as getHasSavePermission } from '../../../utilities/hasSavePermission.js'\nimport { LoadingOverlay } from '../../Loading/index.js'\nimport { useLoadingOverlay } from '../../LoadingOverlay/index.js'\nimport { FieldErrorsToast } from '../../Toasts/fieldErrors.js'\nimport { useBulkUpload } from '../index.js'\nimport { createFormData } from './createFormData.js'\nimport { formsManagementReducer } from './reducer.js'\n\ntype FormsManagerContext = {\n readonly activeIndex: State['activeIndex']\n readonly addFiles: (filelist: FileList) => Promise<void>\n readonly bulkUpdateForm: (\n updatedFields: Record<string, unknown>,\n afterStateUpdate?: () => void,\n ) => Promise<void>\n readonly collectionSlug: string\n readonly docPermissions?: SanitizedDocumentPermissions\n readonly documentSlots: DocumentSlots\n readonly forms: State['forms']\n getFormDataRef: React.RefObject<() => Data>\n readonly hasPublishPermission: boolean\n readonly hasSavePermission: boolean\n readonly hasSubmitted: boolean\n readonly isInitializing: boolean\n readonly removeFile: (index: number) => void\n readonly resetUploadEdits?: () => void\n readonly saveAllDocs: ({ overrides }?: { overrides?: Record<string, unknown> }) => Promise<void>\n readonly setActiveIndex: (index: number) => void\n readonly setFormTotalErrorCount: ({\n errorCount,\n index,\n }: {\n errorCount: number\n index: number\n }) => void\n readonly totalErrorCount?: number\n readonly updateUploadEdits: (args: UploadEdits) => void\n}\n\nconst Context = React.createContext<FormsManagerContext>({\n activeIndex: 0,\n addFiles: () => Promise.resolve(),\n bulkUpdateForm: () => null,\n collectionSlug: '',\n docPermissions: undefined,\n documentSlots: {},\n forms: [],\n getFormDataRef: { current: () => ({}) },\n hasPublishPermission: false,\n hasSavePermission: false,\n hasSubmitted: false,\n isInitializing: false,\n removeFile: () => {},\n saveAllDocs: () => Promise.resolve(),\n setActiveIndex: () => 0,\n setFormTotalErrorCount: () => {},\n totalErrorCount: 0,\n updateUploadEdits: () => {},\n})\n\nconst initialState: State = {\n activeIndex: 0,\n forms: [],\n totalErrorCount: 0,\n}\n\nexport type InitialForms = Array<{\n file: File\n formID?: string\n initialState?: FormState | null\n}>\n\ntype FormsManagerProps = {\n readonly children: React.ReactNode\n}\n\nexport function FormsManagerProvider({ children }: FormsManagerProps) {\n const { config } = useConfig()\n const {\n routes: { api },\n } = config\n const folderFieldName = config.folders ? config.folders.fieldName : undefined\n const { code } = useLocale()\n const { i18n, t } = useTranslation()\n\n const { getDocumentSlots, getFormState } = useServerFunctions()\n const { getUploadHandler } = useUploadHandlers()\n\n const [documentSlots, setDocumentSlots] = React.useState<DocumentSlots>({})\n const [hasSubmitted, setHasSubmitted] = React.useState(false)\n const [docPermissions, setDocPermissions] = React.useState<SanitizedDocumentPermissions>()\n const [hasSavePermission, setHasSavePermission] = React.useState(false)\n const [hasPublishPermission, setHasPublishPermission] = React.useState(false)\n const [hasInitializedState, setHasInitializedState] = React.useState(false)\n const [hasInitializedDocPermissions, setHasInitializedDocPermissions] = React.useState(false)\n const [isInitializing, setIsInitializing] = React.useState(false)\n const [state, dispatch] = React.useReducer(formsManagementReducer, initialState)\n const { activeIndex, forms, totalErrorCount } = state\n\n const formsRef = React.useRef(forms)\n formsRef.current = forms\n\n const { toggleLoadingOverlay } = useLoadingOverlay()\n const { closeModal } = useModal()\n const {\n collectionSlug,\n drawerSlug,\n folderID,\n initialFiles,\n initialForms,\n onSuccess,\n setInitialFiles,\n setInitialForms,\n setSuccessfullyUploaded,\n } = useBulkUpload()\n\n const [isUploading, setIsUploading] = React.useState(false)\n const [loadingText, setLoadingText] = React.useState('')\n\n const hasInitializedWithFiles = React.useRef(false)\n const initialStateRef = React.useRef<FormState>(null)\n const getFormDataRef = React.useRef<() => Data>(() => ({}))\n\n const baseAPIPath = formatAdminURL({\n apiRoute: api,\n path: '',\n })\n\n const actionURL = `${baseAPIPath}/${collectionSlug}`\n\n const initializeSharedDocPermissions = React.useCallback(async () => {\n const params = {\n locale: code || undefined,\n }\n\n const docAccessURL = `/${collectionSlug}/access`\n const res = await fetch(`${baseAPIPath}${docAccessURL}?${qs.stringify(params)}`, {\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n })\n\n const json: SanitizedDocumentPermissions = await res.json()\n const publishedAccessJSON = await fetch(\n `${baseAPIPath}${docAccessURL}?${qs.stringify(params)}`,\n {\n body: JSON.stringify({\n _status: 'published',\n }),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/json',\n },\n method: 'POST',\n },\n ).then((res) => res.json())\n\n setDocPermissions(json)\n\n setHasSavePermission(\n getHasSavePermission({\n collectionSlug,\n docPermissions: json,\n isEditing: false,\n }),\n )\n\n setHasPublishPermission(publishedAccessJSON?.update)\n setHasInitializedDocPermissions(true)\n }, [baseAPIPath, code, collectionSlug, i18n.language])\n\n const initializeSharedFormState = React.useCallback(\n async (abortController?: AbortController) => {\n if (abortController?.signal) {\n abortController.abort('aborting previous fetch for initial form state without files')\n }\n\n // FETCH AND SET THE DOCUMENT SLOTS HERE!\n const documentSlots = await getDocumentSlots({ collectionSlug })\n setDocumentSlots(documentSlots)\n\n try {\n const { state: formStateWithoutFiles } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: { fields: {} },\n locale: code,\n operation: 'create',\n renderAllFields: true,\n schemaPath: collectionSlug,\n skipValidation: true,\n })\n\n if (folderFieldName && formStateWithoutFiles?.[folderFieldName]) {\n formStateWithoutFiles[folderFieldName] = {\n ...formStateWithoutFiles[folderFieldName],\n customComponents: {\n ...formStateWithoutFiles[folderFieldName].customComponents,\n Field: undefined,\n },\n }\n }\n\n initialStateRef.current = formStateWithoutFiles\n setHasInitializedState(true)\n } catch (_err) {\n // swallow error\n }\n },\n [getDocumentSlots, collectionSlug, getFormState, docPermissions, code, folderFieldName],\n )\n\n const setActiveIndex: FormsManagerContext['setActiveIndex'] = React.useCallback(\n (index: number) => {\n const currentFormsData = getFormDataRef.current()\n\n dispatch({\n type: 'REPLACE',\n state: {\n activeIndex: index,\n forms: forms.map((form, i) => {\n if (i === activeIndex) {\n return {\n errorCount: form.errorCount,\n formID: form.formID,\n formState: currentFormsData,\n uploadEdits: form.uploadEdits,\n }\n }\n return form\n }),\n },\n })\n },\n [forms, activeIndex],\n )\n\n const applyFolderToState = React.useCallback(\n (baseState: FormState | null): FormState | null => {\n if (folderID && folderFieldName && baseState?.[folderFieldName]) {\n return {\n ...baseState,\n [folderFieldName]: {\n ...baseState[folderFieldName],\n initialValue: folderID,\n value: folderID,\n },\n }\n }\n return baseState\n },\n [folderID, folderFieldName],\n )\n\n const addFiles = React.useCallback(\n async (files: FileList) => {\n if (forms.length) {\n // save the state of the current form before adding new files\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[activeIndex].errorCount,\n formState: getFormDataRef.current(),\n index: activeIndex,\n })\n }\n\n toggleLoadingOverlay({ isLoading: true, key: 'addingDocs' })\n if (!hasInitializedState) {\n await initializeSharedFormState()\n }\n dispatch({\n type: 'ADD_FORMS',\n forms: Array.from(files).map((file) => ({\n file,\n initialState: applyFolderToState(initialStateRef.current),\n })),\n })\n toggleLoadingOverlay({ isLoading: false, key: 'addingDocs' })\n },\n [\n initializeSharedFormState,\n hasInitializedState,\n toggleLoadingOverlay,\n activeIndex,\n forms,\n applyFolderToState,\n ],\n )\n\n const addFilesEffectEvent = useEffectEvent(addFiles)\n\n const addInitialForms = useEffectEvent(async (initialForms: InitialForms) => {\n toggleLoadingOverlay({ isLoading: true, key: 'addingDocs' })\n\n if (!hasInitializedState) {\n await initializeSharedFormState()\n }\n\n dispatch({\n type: 'ADD_FORMS',\n forms: initialForms.map((form) => ({\n ...form,\n initialState: applyFolderToState(form?.initialState || initialStateRef.current),\n })),\n })\n\n toggleLoadingOverlay({ isLoading: false, key: 'addingDocs' })\n })\n\n const removeFile: FormsManagerContext['removeFile'] = React.useCallback((index) => {\n dispatch({ type: 'REMOVE_FORM', index })\n }, [])\n\n const setFormTotalErrorCount: FormsManagerContext['setFormTotalErrorCount'] = React.useCallback(\n ({ errorCount, index }) => {\n dispatch({\n type: 'UPDATE_ERROR_COUNT',\n count: errorCount,\n index,\n })\n },\n [],\n )\n\n const saveAllDocs: FormsManagerContext['saveAllDocs'] = React.useCallback(\n async ({ overrides } = {}) => {\n const currentFormsData = getFormDataRef.current()\n const currentForms = [...forms]\n currentForms[activeIndex] = {\n errorCount: currentForms[activeIndex].errorCount,\n formID: currentForms[activeIndex].formID,\n formState: currentFormsData,\n uploadEdits: currentForms[activeIndex].uploadEdits,\n }\n const activeFormID = currentForms[activeIndex]?.formID\n const newDocs: Array<{\n collectionSlug: CollectionSlug\n doc: JsonObject\n /**\n * ID of the form that created this document\n */\n formID: string\n }> = []\n\n setIsUploading(true)\n\n for (let i = 0; i < currentForms.length; i++) {\n try {\n const form = currentForms[i]\n const fileValue = form.formState?.file?.value\n\n setLoadingText(t('general:uploadingBulk', { current: i + 1, total: currentForms.length }))\n\n const actionURLWithParams = `${actionURL}${qs.stringify(\n {\n locale: code,\n uploadEdits: form?.uploadEdits || undefined,\n },\n {\n addQueryPrefix: true,\n },\n )}`\n\n const req = await fetch(actionURLWithParams, {\n body: await createFormData(\n form.formState,\n overrides,\n collectionSlug,\n getUploadHandler({ collectionSlug }),\n ),\n credentials: 'include',\n method: 'POST',\n })\n\n const json = await req.json()\n\n const wasSuccessful = req.status === 201 && json?.doc\n\n if (wasSuccessful) {\n newDocs.push({\n collectionSlug,\n doc: json.doc,\n formID: form.formID,\n })\n }\n\n // should expose some sort of helper for this\n const [fieldErrors, nonFieldErrors] = (json?.errors || []).reduce(\n ([fieldErrs, nonFieldErrs], err) => {\n const newFieldErrs: any[] = []\n const newNonFieldErrs: any[] = []\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 const missingFile = !fileValue && req.status === 400\n const exceedsLimit = fileValue && req.status === 413\n const missingFilename =\n fileValue &&\n typeof fileValue === 'object' &&\n 'name' in fileValue &&\n (!fileValue.name || fileValue.name === '')\n\n if (missingFile || exceedsLimit || missingFilename) {\n currentForms[i].formState.file.valid = false\n\n // File/Blob objects cannot be serialized via the RSC flight protocol,\n // so replace with a plain object before calling the server function.\n const originalFileValue = currentForms[i].formState.file?.value\n const formStateForServer = { ...currentForms[i].formState }\n if (originalFileValue instanceof File) {\n formStateForServer.file = {\n ...formStateForServer.file,\n value: { name: originalFileValue.name },\n }\n }\n\n // Need to get the field state to extract count since field errors\n // are not returned when file is missing or exceeds limit\n const { state: newState } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: null,\n formState: formStateForServer,\n operation: 'update',\n schemaPath: collectionSlug,\n })\n\n if (newState) {\n if (originalFileValue instanceof File && newState.file) {\n newState.file = { ...newState.file, value: originalFileValue }\n }\n\n currentForms[i] = {\n errorCount: Object.values(newState).reduce(\n (acc, value) => (value?.valid === false ? acc + 1 : acc),\n 0,\n ),\n formID: currentForms[i].formID,\n formState: newState,\n }\n }\n\n toast.error(nonFieldErrors[0]?.message)\n } else {\n let errorCount = fieldErrors.length\n\n // Fall back to non-field errors when no field errors are present\n // (e.g., APIError thrown from a hook).\n if (!wasSuccessful && errorCount === 0) {\n errorCount = nonFieldErrors.length || 1\n }\n\n currentForms[i] = {\n errorCount,\n formID: currentForms[i].formID,\n formState: fieldReducer(currentForms[i].formState, {\n type: 'ADD_SERVER_ERRORS',\n errors: fieldErrors,\n }),\n }\n\n // Mimic forms/Form/index.tsx.\n if (!wasSuccessful) {\n nonFieldErrors.forEach((err) => {\n toast.error(<FieldErrorsToast errorMessage={err.message || t('error:unknown')} />)\n })\n }\n }\n } catch (_) {\n // swallow\n }\n }\n\n setHasSubmitted(true)\n setLoadingText('')\n setIsUploading(false)\n\n const remainingForms = []\n\n currentForms.forEach(({ errorCount }, i) => {\n if (errorCount) {\n remainingForms.push(currentForms[i])\n }\n })\n\n const successCount = Math.max(0, currentForms.length - remainingForms.length)\n const errorCount = currentForms.length - successCount\n\n if (successCount) {\n toast.success(`Successfully saved ${successCount} files`)\n setSuccessfullyUploaded(true)\n\n if (typeof onSuccess === 'function') {\n onSuccess(newDocs, errorCount)\n }\n }\n\n if (errorCount) {\n toast.error(`Failed to save ${errorCount} files`)\n } else {\n closeModal(drawerSlug)\n }\n\n dispatch({\n type: 'REPLACE',\n state: {\n activeIndex: remainingForms.reduce((acc, { formID }, i) => {\n if (formID === activeFormID) {\n return i\n }\n return acc\n }, 0),\n forms: remainingForms,\n totalErrorCount: remainingForms.reduce((acc, { errorCount }) => acc + errorCount, 0),\n },\n })\n\n if (remainingForms.length === 0) {\n setInitialFiles(undefined)\n setInitialForms(undefined)\n }\n },\n [\n forms,\n activeIndex,\n t,\n actionURL,\n code,\n collectionSlug,\n getUploadHandler,\n getFormState,\n docPermissions,\n setSuccessfullyUploaded,\n onSuccess,\n closeModal,\n drawerSlug,\n setInitialFiles,\n setInitialForms,\n ],\n )\n\n const bulkUpdateForm = React.useCallback(\n async (updatedFields: Record<string, unknown>, afterStateUpdate?: () => void) => {\n for (let i = 0; i < forms.length; i++) {\n Object.entries(updatedFields).forEach(([path, value]) => {\n if (forms[i].formState[path]) {\n forms[i].formState[path].value = value\n\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[i].errorCount,\n formState: forms[i].formState,\n index: i,\n })\n }\n })\n\n if (typeof afterStateUpdate === 'function') {\n afterStateUpdate()\n }\n\n if (hasSubmitted) {\n const { state } = await getFormState({\n collectionSlug,\n docPermissions,\n docPreferences: null,\n formState: forms[i].formState,\n operation: 'create',\n schemaPath: collectionSlug,\n })\n\n const newFormErrorCount = Object.values(state).reduce(\n (acc, value) => (value?.valid === false ? acc + 1 : acc),\n 0,\n )\n\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: newFormErrorCount,\n formState: state,\n index: i,\n })\n }\n }\n },\n [collectionSlug, docPermissions, forms, getFormState, hasSubmitted],\n )\n\n const updateUploadEdits = React.useCallback<FormsManagerContext['updateUploadEdits']>(\n (uploadEdits) => {\n dispatch({\n type: 'UPDATE_FORM',\n errorCount: forms[activeIndex].errorCount,\n formState: forms[activeIndex].formState,\n index: activeIndex,\n uploadEdits,\n })\n },\n [activeIndex, forms],\n )\n\n const resetUploadEdits = React.useCallback<FormsManagerContext['resetUploadEdits']>(() => {\n dispatch({\n type: 'REPLACE',\n state: {\n forms: forms.map((form) => ({\n ...form,\n uploadEdits: {},\n })),\n },\n })\n }, [forms])\n\n React.useEffect(() => {\n if (!collectionSlug) {\n return\n }\n if (!hasInitializedState) {\n void initializeSharedFormState()\n }\n\n if (!hasInitializedDocPermissions) {\n void initializeSharedDocPermissions()\n }\n\n if (initialFiles || initialForms) {\n if (!hasInitializedState || !hasInitializedDocPermissions) {\n setIsInitializing(true)\n } else {\n setIsInitializing(false)\n }\n }\n\n if (\n hasInitializedState &&\n (initialForms?.length || initialFiles?.length) &&\n !hasInitializedWithFiles.current\n ) {\n if (initialForms?.length) {\n void addInitialForms(initialForms)\n }\n if (initialFiles?.length) {\n void addFilesEffectEvent(initialFiles)\n }\n hasInitializedWithFiles.current = true\n }\n return\n }, [\n initialFiles,\n initializeSharedFormState,\n initializeSharedDocPermissions,\n collectionSlug,\n hasInitializedState,\n hasInitializedDocPermissions,\n initialForms,\n ])\n\n return (\n <Context\n value={{\n activeIndex: state.activeIndex,\n addFiles,\n bulkUpdateForm,\n collectionSlug,\n docPermissions,\n documentSlots,\n forms,\n getFormDataRef,\n hasPublishPermission,\n hasSavePermission,\n hasSubmitted,\n isInitializing,\n removeFile,\n resetUploadEdits,\n saveAllDocs,\n setActiveIndex,\n setFormTotalErrorCount,\n totalErrorCount,\n updateUploadEdits,\n }}\n >\n {isUploading && (\n <LoadingOverlay\n animationDuration=\"250ms\"\n loadingText={loadingText}\n overlayType=\"fullscreen\"\n show\n />\n )}\n {children}\n </Context>\n )\n}\n\nexport function useFormsManager() {\n return React.use(Context)\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/elements/ListControls/index.tsx"],"names":[],"mappings":"AAKA,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/elements/ListControls/index.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAyD,MAAM,OAAO,CAAA;AAE7E,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAgBnD,OAAO,cAAc,CAAA;AAIrB;;;;GAIG;AACH,eAAO,MAAM,YAAY,EAAE,KAAK,CAAC,EAAE,CAAC,iBAAiB,CAyNpD,CAAA"}
|
|
@@ -4,7 +4,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
4
4
|
import { useWindowInfo } from '@faceless-ui/window-info';
|
|
5
5
|
import { getTranslation } from '@payloadcms/translations';
|
|
6
6
|
import { validateWhereQuery } from 'payload/shared';
|
|
7
|
-
import React, { Fragment, useEffect, useRef, useState } from 'react';
|
|
7
|
+
import React, { Fragment, useEffect, useMemo, useRef, useState } from 'react';
|
|
8
8
|
import { Popup, PopupList } from '../../elements/Popup/index.js';
|
|
9
9
|
import { useUseTitleField } from '../../hooks/useUseAsTitle.js';
|
|
10
10
|
import { ChevronIcon } from '../../icons/Chevron/index.js';
|
|
@@ -57,22 +57,9 @@ export const ListControls = props => {
|
|
|
57
57
|
} = useWindowInfo();
|
|
58
58
|
const searchLabel = (titleField && getTranslation('label' in titleField && (typeof titleField.label === 'string' || typeof titleField.label === 'object') ? titleField.label : 'name' in titleField ? titleField.name : null, i18n)) ?? 'ID';
|
|
59
59
|
const listSearchableFields = getTextFieldsToBeSearched(collectionConfig.admin.listSearchableFields, collectionConfig.fields, i18n);
|
|
60
|
-
const searchLabelTranslated =
|
|
61
|
-
label: getTranslation(searchLabel, i18n)
|
|
62
|
-
}));
|
|
63
|
-
const hasWhereParam = useRef(Boolean(query?.where));
|
|
64
|
-
const shouldInitializeWhereOpened = validateWhereQuery(query?.where);
|
|
65
|
-
const [visibleDrawer, setVisibleDrawer] = useState(shouldInitializeWhereOpened ? 'where' : undefined);
|
|
66
|
-
useEffect(() => {
|
|
67
|
-
if (hasWhereParam.current && !query?.where) {
|
|
68
|
-
hasWhereParam.current = false;
|
|
69
|
-
} else if (query?.where) {
|
|
70
|
-
hasWhereParam.current = true;
|
|
71
|
-
}
|
|
72
|
-
}, [setVisibleDrawer, query?.where]);
|
|
73
|
-
useEffect(() => {
|
|
60
|
+
const searchLabelTranslated = useMemo(() => {
|
|
74
61
|
if (listSearchableFields?.length > 0) {
|
|
75
|
-
|
|
62
|
+
return listSearchableFields.reduce((placeholderText, field, i) => {
|
|
76
63
|
const label = 'label' in field && field.label ? field.label : 'name' in field ? field.name : null;
|
|
77
64
|
if (i === 0) {
|
|
78
65
|
return `${t('general:searchBy', {
|
|
@@ -84,12 +71,21 @@ export const ListControls = props => {
|
|
|
84
71
|
}
|
|
85
72
|
return `${placeholderText}, ${getTranslation(label, i18n)}`;
|
|
86
73
|
}, '');
|
|
87
|
-
} else {
|
|
88
|
-
searchLabelTranslated.current = t('general:searchBy', {
|
|
89
|
-
label: getTranslation(searchLabel, i18n)
|
|
90
|
-
});
|
|
91
74
|
}
|
|
75
|
+
return t('general:searchBy', {
|
|
76
|
+
label: getTranslation(searchLabel, i18n)
|
|
77
|
+
});
|
|
92
78
|
}, [t, listSearchableFields, i18n, searchLabel]);
|
|
79
|
+
const hasWhereParam = useRef(Boolean(query?.where));
|
|
80
|
+
const shouldInitializeWhereOpened = validateWhereQuery(query?.where);
|
|
81
|
+
const [visibleDrawer, setVisibleDrawer] = useState(shouldInitializeWhereOpened ? 'where' : undefined);
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
if (hasWhereParam.current && !query?.where) {
|
|
84
|
+
hasWhereParam.current = false;
|
|
85
|
+
} else if (query?.where) {
|
|
86
|
+
hasWhereParam.current = true;
|
|
87
|
+
}
|
|
88
|
+
}, [setVisibleDrawer, query?.where]);
|
|
93
89
|
return /*#__PURE__*/_jsxs("div", {
|
|
94
90
|
className: baseClass,
|
|
95
91
|
children: [collectionConfig?.enableQueryPresets && !disableQueryPresets && /*#__PURE__*/_jsx(QueryPresetBar, {
|
|
@@ -162,7 +158,7 @@ export const ListControls = props => {
|
|
|
162
158
|
}, `list-menu-item-${i_0}`))
|
|
163
159
|
})
|
|
164
160
|
}, "list-menu")].filter(Boolean),
|
|
165
|
-
label: searchLabelTranslated
|
|
161
|
+
label: searchLabelTranslated,
|
|
166
162
|
onSearchChange: handleSearchChange,
|
|
167
163
|
searchQueryParam: query?.search
|
|
168
164
|
}, collectionSlug), enableColumns && /*#__PURE__*/_jsx(AnimateHeight, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["useWindowInfo","getTranslation","validateWhereQuery","React","Fragment","useEffect","useRef","useState","Popup","PopupList","useUseTitleField","ChevronIcon","Dots","useListQuery","useTranslation","AnimateHeight","ColumnSelector","GroupByBuilder","Pill","QueryPresetBar","SearchBar","WhereBuilder","getTextFieldsToBeSearched","baseClass","ListControls","props","beforeActions","collectionConfig","collectionSlug","disableQueryPresets","enableColumns","enableFilters","enableSort","listMenuItems","queryPreset","activePreset","queryPresetPermissions","renderedFilters","resolvedFilterOptions","handleSearchChange","query","titleField","i18n","t","breakpoints","s","smallBreak","searchLabel","label","name","listSearchableFields","admin","fields","searchLabelTranslated","hasWhereParam","Boolean","where","shouldInitializeWhereOpened","visibleDrawer","setVisibleDrawer","undefined","current","length","reduce","placeholderText","field","i","_jsxs","className","enableQueryPresets","_jsx","Actions","icon","direction","id","onClick","pillStyle","size","groupBy","Array","isArray","button","ariaLabel","horizontalAlign","verticalAlign","ButtonGroup","map","item","filter","onSearchChange","searchQueryParam","search","height","slug","collectionPluralLabel","labels","plural"],"sources":["../../../src/elements/ListControls/index.tsx"],"sourcesContent":["'use client'\n\nimport { useWindowInfo } from '@faceless-ui/window-info'\nimport { getTranslation } from '@payloadcms/translations'\nimport { validateWhereQuery } from 'payload/shared'\nimport React, { Fragment, useEffect, useRef, useState } from 'react'\n\nimport type { ListControlsProps } from './types.js'\n\nimport { Popup, PopupList } from '../../elements/Popup/index.js'\nimport { useUseTitleField } from '../../hooks/useUseAsTitle.js'\nimport { ChevronIcon } from '../../icons/Chevron/index.js'\nimport { Dots } from '../../icons/Dots/index.js'\nimport { useListQuery } from '../../providers/ListQuery/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { AnimateHeight } from '../AnimateHeight/index.js'\nimport { ColumnSelector } from '../ColumnSelector/index.js'\nimport { GroupByBuilder } from '../GroupByBuilder/index.js'\nimport { Pill } from '../Pill/index.js'\nimport { QueryPresetBar } from '../QueryPresets/QueryPresetBar/index.js'\nimport { SearchBar } from '../SearchBar/index.js'\nimport { WhereBuilder } from '../WhereBuilder/index.js'\nimport { getTextFieldsToBeSearched } from './getTextFieldsToBeSearched.js'\nimport './index.scss'\n\nconst baseClass = 'list-controls'\n\n/**\n * The ListControls component is used to render the controls (search, filter, where)\n * for a collection's list view. You can find those directly above the table which lists\n * the collection's documents.\n */\nexport const ListControls: React.FC<ListControlsProps> = (props) => {\n const {\n beforeActions,\n collectionConfig,\n collectionSlug,\n disableQueryPresets,\n enableColumns = true,\n enableFilters = true,\n enableSort = false,\n listMenuItems,\n queryPreset: activePreset,\n queryPresetPermissions,\n renderedFilters,\n resolvedFilterOptions,\n } = props\n\n const { handleSearchChange, query } = useListQuery()\n\n const titleField = useUseTitleField(collectionConfig)\n const { i18n, t } = useTranslation()\n\n const {\n breakpoints: { s: smallBreak },\n } = useWindowInfo()\n\n const searchLabel =\n (titleField &&\n getTranslation(\n 'label' in titleField &&\n (typeof titleField.label === 'string' || typeof titleField.label === 'object')\n ? titleField.label\n : 'name' in titleField\n ? titleField.name\n : null,\n i18n,\n )) ??\n 'ID'\n\n const listSearchableFields = getTextFieldsToBeSearched(\n collectionConfig.admin.listSearchableFields,\n collectionConfig.fields,\n i18n,\n )\n\n const searchLabelTranslated = useRef(\n t('general:searchBy', { label: getTranslation(searchLabel, i18n) }),\n )\n\n const hasWhereParam = useRef(Boolean(query?.where))\n\n const shouldInitializeWhereOpened = validateWhereQuery(query?.where)\n\n const [visibleDrawer, setVisibleDrawer] = useState<'columns' | 'group-by' | 'sort' | 'where'>(\n shouldInitializeWhereOpened ? 'where' : undefined,\n )\n\n useEffect(() => {\n if (hasWhereParam.current && !query?.where) {\n hasWhereParam.current = false\n } else if (query?.where) {\n hasWhereParam.current = true\n }\n }, [setVisibleDrawer, query?.where])\n\n useEffect(() => {\n if (listSearchableFields?.length > 0) {\n searchLabelTranslated.current = listSearchableFields.reduce(\n (placeholderText: string, field, i: number) => {\n const label =\n 'label' in field && field.label ? field.label : 'name' in field ? field.name : null\n\n if (i === 0) {\n return `${t('general:searchBy', {\n label: getTranslation(label, i18n),\n })}`\n }\n\n if (i === listSearchableFields.length - 1) {\n return `${placeholderText} ${t('general:or')} ${getTranslation(label, i18n)}`\n }\n\n return `${placeholderText}, ${getTranslation(label, i18n)}`\n },\n '',\n )\n } else {\n searchLabelTranslated.current = t('general:searchBy', {\n label: getTranslation(searchLabel, i18n),\n })\n }\n }, [t, listSearchableFields, i18n, searchLabel])\n\n return (\n <div className={baseClass}>\n {collectionConfig?.enableQueryPresets && !disableQueryPresets && (\n <QueryPresetBar\n activePreset={activePreset}\n collectionSlug={collectionSlug}\n queryPresetPermissions={queryPresetPermissions}\n />\n )}\n <SearchBar\n Actions={[\n !smallBreak && (\n <React.Fragment key=\"before-actions\">{beforeActions && beforeActions}</React.Fragment>\n ),\n enableColumns && (\n <Pill\n aria-controls={`${baseClass}-columns`}\n aria-expanded={visibleDrawer === 'columns'}\n className={`${baseClass}__toggle-columns`}\n icon={<ChevronIcon direction={visibleDrawer === 'columns' ? 'up' : 'down'} />}\n id=\"toggle-list-columns\"\n key=\"toggle-list-columns\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'columns' ? 'columns' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:columns')}\n </Pill>\n ),\n enableFilters && (\n <Pill\n aria-controls={`${baseClass}-where`}\n aria-expanded={visibleDrawer === 'where'}\n className={`${baseClass}__toggle-where`}\n icon={<ChevronIcon direction={visibleDrawer === 'where' ? 'up' : 'down'} />}\n id=\"toggle-list-filters\"\n key=\"toggle-list-filters\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'where' ? 'where' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:filters')}\n </Pill>\n ),\n enableSort && (\n <Pill\n aria-controls={`${baseClass}-sort`}\n aria-expanded={visibleDrawer === 'sort'}\n className={`${baseClass}__toggle-sort`}\n icon={<ChevronIcon />}\n id=\"toggle-list-sort\"\n key=\"toggle-list-sort\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'sort' ? 'sort' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:sort')}\n </Pill>\n ),\n collectionConfig.admin.groupBy && (\n <Pill\n aria-controls={`${baseClass}-group-by`}\n aria-expanded={visibleDrawer === 'group-by'}\n className={`${baseClass}__toggle-group-by`}\n icon={<ChevronIcon direction={visibleDrawer === 'group-by' ? 'up' : 'down'} />}\n id=\"toggle-group-by\"\n key=\"toggle-group-by\"\n onClick={() =>\n setVisibleDrawer(visibleDrawer !== 'group-by' ? 'group-by' : undefined)\n }\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:groupByLabel', {\n label: '',\n })}\n </Pill>\n ),\n listMenuItems && Array.isArray(listMenuItems) && listMenuItems.length > 0 && (\n <Popup\n button={<Dots ariaLabel={t('general:moreOptions')} />}\n className={`${baseClass}__popup`}\n horizontalAlign=\"right\"\n id=\"list-menu\"\n key=\"list-menu\"\n size=\"small\"\n verticalAlign=\"bottom\"\n >\n <PopupList.ButtonGroup>\n {listMenuItems.map((item, i) => (\n <Fragment key={`list-menu-item-${i}`}>{item}</Fragment>\n ))}\n </PopupList.ButtonGroup>\n </Popup>\n ),\n ].filter(Boolean)}\n key={collectionSlug}\n label={searchLabelTranslated.current}\n onSearchChange={handleSearchChange}\n searchQueryParam={query?.search}\n />\n {enableColumns && (\n <AnimateHeight\n className={`${baseClass}__columns`}\n height={visibleDrawer === 'columns' ? 'auto' : 0}\n id={`${baseClass}-columns`}\n >\n <ColumnSelector collectionSlug={collectionConfig.slug} />\n </AnimateHeight>\n )}\n <AnimateHeight\n className={`${baseClass}__where`}\n height={visibleDrawer === 'where' ? 'auto' : 0}\n id={`${baseClass}-where`}\n >\n <WhereBuilder\n collectionPluralLabel={collectionConfig?.labels?.plural}\n collectionSlug={collectionConfig.slug}\n fields={collectionConfig?.fields}\n renderedFilters={renderedFilters}\n resolvedFilterOptions={resolvedFilterOptions}\n />\n </AnimateHeight>\n {collectionConfig.admin.groupBy && (\n <AnimateHeight\n className={`${baseClass}__group-by`}\n height={visibleDrawer === 'group-by' ? 'auto' : 0}\n id={`${baseClass}-group-by`}\n >\n <GroupByBuilder collectionSlug={collectionConfig.slug} fields={collectionConfig.fields} />\n </AnimateHeight>\n )}\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["useWindowInfo","getTranslation","validateWhereQuery","React","Fragment","useEffect","useMemo","useRef","useState","Popup","PopupList","useUseTitleField","ChevronIcon","Dots","useListQuery","useTranslation","AnimateHeight","ColumnSelector","GroupByBuilder","Pill","QueryPresetBar","SearchBar","WhereBuilder","getTextFieldsToBeSearched","baseClass","ListControls","props","beforeActions","collectionConfig","collectionSlug","disableQueryPresets","enableColumns","enableFilters","enableSort","listMenuItems","queryPreset","activePreset","queryPresetPermissions","renderedFilters","resolvedFilterOptions","handleSearchChange","query","titleField","i18n","t","breakpoints","s","smallBreak","searchLabel","label","name","listSearchableFields","admin","fields","searchLabelTranslated","length","reduce","placeholderText","field","i","hasWhereParam","Boolean","where","shouldInitializeWhereOpened","visibleDrawer","setVisibleDrawer","undefined","current","_jsxs","className","enableQueryPresets","_jsx","Actions","icon","direction","id","onClick","pillStyle","size","groupBy","Array","isArray","button","ariaLabel","horizontalAlign","verticalAlign","ButtonGroup","map","item","filter","onSearchChange","searchQueryParam","search","height","slug","collectionPluralLabel","labels","plural"],"sources":["../../../src/elements/ListControls/index.tsx"],"sourcesContent":["'use client'\n\nimport { useWindowInfo } from '@faceless-ui/window-info'\nimport { getTranslation } from '@payloadcms/translations'\nimport { validateWhereQuery } from 'payload/shared'\nimport React, { Fragment, useEffect, useMemo, useRef, useState } from 'react'\n\nimport type { ListControlsProps } from './types.js'\n\nimport { Popup, PopupList } from '../../elements/Popup/index.js'\nimport { useUseTitleField } from '../../hooks/useUseAsTitle.js'\nimport { ChevronIcon } from '../../icons/Chevron/index.js'\nimport { Dots } from '../../icons/Dots/index.js'\nimport { useListQuery } from '../../providers/ListQuery/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport { AnimateHeight } from '../AnimateHeight/index.js'\nimport { ColumnSelector } from '../ColumnSelector/index.js'\nimport { GroupByBuilder } from '../GroupByBuilder/index.js'\nimport { Pill } from '../Pill/index.js'\nimport { QueryPresetBar } from '../QueryPresets/QueryPresetBar/index.js'\nimport { SearchBar } from '../SearchBar/index.js'\nimport { WhereBuilder } from '../WhereBuilder/index.js'\nimport { getTextFieldsToBeSearched } from './getTextFieldsToBeSearched.js'\nimport './index.scss'\n\nconst baseClass = 'list-controls'\n\n/**\n * The ListControls component is used to render the controls (search, filter, where)\n * for a collection's list view. You can find those directly above the table which lists\n * the collection's documents.\n */\nexport const ListControls: React.FC<ListControlsProps> = (props) => {\n const {\n beforeActions,\n collectionConfig,\n collectionSlug,\n disableQueryPresets,\n enableColumns = true,\n enableFilters = true,\n enableSort = false,\n listMenuItems,\n queryPreset: activePreset,\n queryPresetPermissions,\n renderedFilters,\n resolvedFilterOptions,\n } = props\n\n const { handleSearchChange, query } = useListQuery()\n\n const titleField = useUseTitleField(collectionConfig)\n const { i18n, t } = useTranslation()\n\n const {\n breakpoints: { s: smallBreak },\n } = useWindowInfo()\n\n const searchLabel =\n (titleField &&\n getTranslation(\n 'label' in titleField &&\n (typeof titleField.label === 'string' || typeof titleField.label === 'object')\n ? titleField.label\n : 'name' in titleField\n ? titleField.name\n : null,\n i18n,\n )) ??\n 'ID'\n\n const listSearchableFields = getTextFieldsToBeSearched(\n collectionConfig.admin.listSearchableFields,\n collectionConfig.fields,\n i18n,\n )\n\n const searchLabelTranslated = useMemo(() => {\n if (listSearchableFields?.length > 0) {\n return listSearchableFields.reduce((placeholderText: string, field, i: number) => {\n const label =\n 'label' in field && field.label ? field.label : 'name' in field ? field.name : null\n\n if (i === 0) {\n return `${t('general:searchBy', {\n label: getTranslation(label, i18n),\n })}`\n }\n\n if (i === listSearchableFields.length - 1) {\n return `${placeholderText} ${t('general:or')} ${getTranslation(label, i18n)}`\n }\n\n return `${placeholderText}, ${getTranslation(label, i18n)}`\n }, '')\n }\n\n return t('general:searchBy', { label: getTranslation(searchLabel, i18n) })\n }, [t, listSearchableFields, i18n, searchLabel])\n\n const hasWhereParam = useRef(Boolean(query?.where))\n\n const shouldInitializeWhereOpened = validateWhereQuery(query?.where)\n\n const [visibleDrawer, setVisibleDrawer] = useState<'columns' | 'group-by' | 'sort' | 'where'>(\n shouldInitializeWhereOpened ? 'where' : undefined,\n )\n\n useEffect(() => {\n if (hasWhereParam.current && !query?.where) {\n hasWhereParam.current = false\n } else if (query?.where) {\n hasWhereParam.current = true\n }\n }, [setVisibleDrawer, query?.where])\n\n return (\n <div className={baseClass}>\n {collectionConfig?.enableQueryPresets && !disableQueryPresets && (\n <QueryPresetBar\n activePreset={activePreset}\n collectionSlug={collectionSlug}\n queryPresetPermissions={queryPresetPermissions}\n />\n )}\n <SearchBar\n Actions={[\n !smallBreak && (\n <React.Fragment key=\"before-actions\">{beforeActions && beforeActions}</React.Fragment>\n ),\n enableColumns && (\n <Pill\n aria-controls={`${baseClass}-columns`}\n aria-expanded={visibleDrawer === 'columns'}\n className={`${baseClass}__toggle-columns`}\n icon={<ChevronIcon direction={visibleDrawer === 'columns' ? 'up' : 'down'} />}\n id=\"toggle-list-columns\"\n key=\"toggle-list-columns\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'columns' ? 'columns' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:columns')}\n </Pill>\n ),\n enableFilters && (\n <Pill\n aria-controls={`${baseClass}-where`}\n aria-expanded={visibleDrawer === 'where'}\n className={`${baseClass}__toggle-where`}\n icon={<ChevronIcon direction={visibleDrawer === 'where' ? 'up' : 'down'} />}\n id=\"toggle-list-filters\"\n key=\"toggle-list-filters\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'where' ? 'where' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:filters')}\n </Pill>\n ),\n enableSort && (\n <Pill\n aria-controls={`${baseClass}-sort`}\n aria-expanded={visibleDrawer === 'sort'}\n className={`${baseClass}__toggle-sort`}\n icon={<ChevronIcon />}\n id=\"toggle-list-sort\"\n key=\"toggle-list-sort\"\n onClick={() => setVisibleDrawer(visibleDrawer !== 'sort' ? 'sort' : undefined)}\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:sort')}\n </Pill>\n ),\n collectionConfig.admin.groupBy && (\n <Pill\n aria-controls={`${baseClass}-group-by`}\n aria-expanded={visibleDrawer === 'group-by'}\n className={`${baseClass}__toggle-group-by`}\n icon={<ChevronIcon direction={visibleDrawer === 'group-by' ? 'up' : 'down'} />}\n id=\"toggle-group-by\"\n key=\"toggle-group-by\"\n onClick={() =>\n setVisibleDrawer(visibleDrawer !== 'group-by' ? 'group-by' : undefined)\n }\n pillStyle=\"light\"\n size=\"small\"\n >\n {t('general:groupByLabel', {\n label: '',\n })}\n </Pill>\n ),\n listMenuItems && Array.isArray(listMenuItems) && listMenuItems.length > 0 && (\n <Popup\n button={<Dots ariaLabel={t('general:moreOptions')} />}\n className={`${baseClass}__popup`}\n horizontalAlign=\"right\"\n id=\"list-menu\"\n key=\"list-menu\"\n size=\"small\"\n verticalAlign=\"bottom\"\n >\n <PopupList.ButtonGroup>\n {listMenuItems.map((item, i) => (\n <Fragment key={`list-menu-item-${i}`}>{item}</Fragment>\n ))}\n </PopupList.ButtonGroup>\n </Popup>\n ),\n ].filter(Boolean)}\n key={collectionSlug}\n label={searchLabelTranslated}\n onSearchChange={handleSearchChange}\n searchQueryParam={query?.search}\n />\n {enableColumns && (\n <AnimateHeight\n className={`${baseClass}__columns`}\n height={visibleDrawer === 'columns' ? 'auto' : 0}\n id={`${baseClass}-columns`}\n >\n <ColumnSelector collectionSlug={collectionConfig.slug} />\n </AnimateHeight>\n )}\n <AnimateHeight\n className={`${baseClass}__where`}\n height={visibleDrawer === 'where' ? 'auto' : 0}\n id={`${baseClass}-where`}\n >\n <WhereBuilder\n collectionPluralLabel={collectionConfig?.labels?.plural}\n collectionSlug={collectionConfig.slug}\n fields={collectionConfig?.fields}\n renderedFilters={renderedFilters}\n resolvedFilterOptions={resolvedFilterOptions}\n />\n </AnimateHeight>\n {collectionConfig.admin.groupBy && (\n <AnimateHeight\n className={`${baseClass}__group-by`}\n height={visibleDrawer === 'group-by' ? 'auto' : 0}\n id={`${baseClass}-group-by`}\n >\n <GroupByBuilder collectionSlug={collectionConfig.slug} fields={collectionConfig.fields} />\n </AnimateHeight>\n )}\n </div>\n )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -10,5 +10,5 @@ function require(m) {
|
|
|
10
10
|
}
|
|
11
11
|
// Workaround end
|
|
12
12
|
|
|
13
|
-
import{l as a}from"./chunk-
|
|
14
|
-
//# sourceMappingURL=CodeEditor-
|
|
13
|
+
import{l as a}from"./chunk-MRRDX6D7.js";import"./chunk-5LKBKI4T.js";export{a as default};
|
|
14
|
+
//# sourceMappingURL=CodeEditor-TL3K3PHG.js.map
|
|
@@ -10,5 +10,5 @@ function require(m) {
|
|
|
10
10
|
}
|
|
11
11
|
// Workaround end
|
|
12
12
|
|
|
13
|
-
import{n as a}from"./chunk-
|
|
14
|
-
//# sourceMappingURL=DatePicker-
|
|
13
|
+
import{n as a}from"./chunk-B52EQI3B.js";import"./chunk-5LKBKI4T.js";export{a as default};
|
|
14
|
+
//# sourceMappingURL=DatePicker-IJKMHICL.js.map
|