@payloadcms/ui 3.35.0-internal.5e55452 → 3.35.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/ActionsBar/index.scss +0 -4
- package/dist/elements/Button/index.scss +1 -1
- package/dist/elements/Localizer/LocalizerLabel/index.js +1 -2
- package/dist/elements/Localizer/LocalizerLabel/index.js.map +1 -1
- package/dist/elements/Localizer/LocalizerLabel/index.scss +1 -2
- package/dist/elements/PerPage/index.scss +0 -4
- package/dist/elements/Pill/index.scss +2 -1
- package/dist/elements/Popup/PopupTrigger/index.scss +3 -3
- package/dist/elements/QueryPresets/fields/ColumnsField/index.d.ts.map +1 -1
- package/dist/elements/QueryPresets/fields/ColumnsField/index.js +14 -24
- package/dist/elements/QueryPresets/fields/ColumnsField/index.js.map +1 -1
- package/dist/elements/QueryPresets/fields/WhereField/index.d.ts.map +1 -1
- package/dist/elements/QueryPresets/fields/WhereField/index.js +3 -15
- package/dist/elements/QueryPresets/fields/WhereField/index.js.map +1 -1
- package/dist/elements/ReactSelect/index.scss +0 -4
- package/dist/elements/SortColumn/index.scss +1 -1
- package/dist/exports/client/index.js +11 -11
- package/dist/exports/client/index.js.map +4 -4
- package/dist/fields/Array/index.d.ts.map +1 -1
- package/dist/fields/Array/index.js +5 -4
- package/dist/fields/Array/index.js.map +1 -1
- package/dist/fields/Blocks/index.d.ts.map +1 -1
- package/dist/fields/Blocks/index.js +5 -4
- package/dist/fields/Blocks/index.js.map +1 -1
- package/dist/fields/Checkbox/index.d.ts.map +1 -1
- package/dist/fields/Checkbox/index.js +3 -2
- package/dist/fields/Checkbox/index.js.map +1 -1
- package/dist/fields/Code/index.d.ts.map +1 -1
- package/dist/fields/Code/index.js +3 -2
- package/dist/fields/Code/index.js.map +1 -1
- package/dist/fields/DateTime/index.d.ts.map +1 -1
- package/dist/fields/DateTime/index.js +3 -2
- package/dist/fields/DateTime/index.js.map +1 -1
- package/dist/fields/Email/index.d.ts.map +1 -1
- package/dist/fields/Email/index.js +4 -3
- package/dist/fields/Email/index.js.map +1 -1
- package/dist/fields/Hidden/index.d.ts.map +1 -1
- package/dist/fields/Hidden/index.js +6 -4
- package/dist/fields/Hidden/index.js.map +1 -1
- package/dist/fields/JSON/index.d.ts.map +1 -1
- package/dist/fields/JSON/index.js +3 -2
- package/dist/fields/JSON/index.js.map +1 -1
- package/dist/fields/Join/index.d.ts.map +1 -1
- package/dist/fields/Join/index.js +3 -2
- package/dist/fields/Join/index.js.map +1 -1
- package/dist/fields/Number/index.d.ts.map +1 -1
- package/dist/fields/Number/index.js +3 -2
- package/dist/fields/Number/index.js.map +1 -1
- package/dist/fields/Point/index.d.ts.map +1 -1
- package/dist/fields/Point/index.js +3 -2
- package/dist/fields/Point/index.js.map +1 -1
- package/dist/fields/RadioGroup/index.d.ts.map +1 -1
- package/dist/fields/RadioGroup/index.js +3 -2
- package/dist/fields/RadioGroup/index.js.map +1 -1
- package/dist/fields/Relationship/index.d.ts.map +1 -1
- package/dist/fields/Relationship/index.js +85 -22
- package/dist/fields/Relationship/index.js.map +1 -1
- package/dist/fields/Select/index.d.ts.map +1 -1
- package/dist/fields/Select/index.js +3 -2
- package/dist/fields/Select/index.js.map +1 -1
- package/dist/fields/Tabs/index.js +41 -51
- package/dist/fields/Tabs/index.js.map +1 -1
- package/dist/fields/Text/index.d.ts.map +1 -1
- package/dist/fields/Text/index.js +3 -2
- package/dist/fields/Text/index.js.map +1 -1
- package/dist/fields/Textarea/index.d.ts.map +1 -1
- package/dist/fields/Textarea/index.js +3 -2
- package/dist/fields/Textarea/index.js.map +1 -1
- package/dist/fields/Upload/index.d.ts.map +1 -1
- package/dist/fields/Upload/index.js +3 -2
- package/dist/fields/Upload/index.js.map +1 -1
- package/dist/forms/Form/fieldReducer.d.ts.map +1 -1
- package/dist/forms/Form/fieldReducer.js +3 -1
- package/dist/forms/Form/fieldReducer.js.map +1 -1
- package/dist/forms/RenderFields/context.d.ts +4 -0
- package/dist/forms/RenderFields/context.d.ts.map +1 -0
- package/dist/forms/RenderFields/context.js +11 -0
- package/dist/forms/RenderFields/context.js.map +1 -0
- package/dist/forms/RenderFields/index.d.ts.map +1 -1
- package/dist/forms/RenderFields/index.js +15 -11
- package/dist/forms/RenderFields/index.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.d.ts.map +1 -1
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js +1 -0
- package/dist/forms/fieldSchemasToFormState/addFieldStatePromise.js.map +1 -1
- package/dist/forms/fieldSchemasToFormState/iterateFields.d.ts.map +1 -1
- package/dist/forms/fieldSchemasToFormState/iterateFields.js +1 -0
- package/dist/forms/fieldSchemasToFormState/iterateFields.js.map +1 -1
- package/dist/forms/useField/index.d.ts +1 -1
- package/dist/forms/useField/index.d.ts.map +1 -1
- package/dist/forms/useField/index.js +128 -116
- package/dist/forms/useField/index.js.map +1 -1
- package/dist/forms/useField/types.d.ts +22 -1
- package/dist/forms/useField/types.d.ts.map +1 -1
- package/dist/forms/useField/types.js.map +1 -1
- package/dist/icons/Chevron/index.js +2 -2
- package/dist/icons/Chevron/index.js.map +1 -1
- package/dist/icons/Chevron/index.scss +4 -4
- package/dist/styles.css +1 -1
- package/package.json +5 -5
|
@@ -7,6 +7,7 @@ import * as qs from 'qs-esm';
|
|
|
7
7
|
import React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from 'react';
|
|
8
8
|
import { AddNewRelation } from '../../elements/AddNewRelation/index.js';
|
|
9
9
|
import { useDocumentDrawer } from '../../elements/DocumentDrawer/index.js';
|
|
10
|
+
import { useListDrawer } from '../../elements/ListDrawer/index.js';
|
|
10
11
|
import { ReactSelect } from '../../elements/ReactSelect/index.js';
|
|
11
12
|
import { RenderCustomComponent } from '../../elements/RenderCustomComponent/index.js';
|
|
12
13
|
import { FieldDescription } from '../../fields/FieldDescription/index.js';
|
|
@@ -37,6 +38,7 @@ const RelationshipFieldComponent = props => {
|
|
|
37
38
|
admin: {
|
|
38
39
|
allowCreate = true,
|
|
39
40
|
allowEdit = true,
|
|
41
|
+
appearance = 'select',
|
|
40
42
|
className,
|
|
41
43
|
description,
|
|
42
44
|
isSortable = true,
|
|
@@ -48,7 +50,7 @@ const RelationshipFieldComponent = props => {
|
|
|
48
50
|
relationTo,
|
|
49
51
|
required
|
|
50
52
|
},
|
|
51
|
-
path,
|
|
53
|
+
path: pathFromProps,
|
|
52
54
|
readOnly,
|
|
53
55
|
validate
|
|
54
56
|
} = props;
|
|
@@ -105,11 +107,12 @@ const RelationshipFieldComponent = props => {
|
|
|
105
107
|
disabled,
|
|
106
108
|
filterOptions,
|
|
107
109
|
initialValue,
|
|
110
|
+
path,
|
|
108
111
|
setValue,
|
|
109
112
|
showError,
|
|
110
113
|
value: value_0
|
|
111
114
|
} = useField({
|
|
112
|
-
|
|
115
|
+
potentiallyStalePath: pathFromProps,
|
|
113
116
|
validate: memoizedValidate
|
|
114
117
|
});
|
|
115
118
|
const [options, dispatchOptions] = useReducer(optionsReducer, []);
|
|
@@ -122,6 +125,53 @@ const RelationshipFieldComponent = props => {
|
|
|
122
125
|
id: currentlyOpenRelationship.id,
|
|
123
126
|
collectionSlug: currentlyOpenRelationship.collectionSlug
|
|
124
127
|
});
|
|
128
|
+
// Filter selected values from displaying in the list drawer
|
|
129
|
+
const listDrawerFilterOptions = useMemo(() => {
|
|
130
|
+
let newFilterOptions = filterOptions;
|
|
131
|
+
if (value_0) {
|
|
132
|
+
;
|
|
133
|
+
(Array.isArray(value_0) ? value_0 : [value_0]).forEach(val => {
|
|
134
|
+
;
|
|
135
|
+
(Array.isArray(relationTo) ? relationTo : [relationTo]).forEach(relationTo_0 => {
|
|
136
|
+
newFilterOptions = {
|
|
137
|
+
...(filterOptions || {}),
|
|
138
|
+
[relationTo_0]: {
|
|
139
|
+
...(typeof filterOptions?.[relationTo_0] === 'object' ? filterOptions[relationTo_0] : {}),
|
|
140
|
+
id: {
|
|
141
|
+
not_in: [typeof val === 'object' ? val.value : val]
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
return newFilterOptions;
|
|
149
|
+
}, [filterOptions, value_0, relationTo]);
|
|
150
|
+
const [ListDrawer,, {
|
|
151
|
+
closeDrawer: closeListDrawer,
|
|
152
|
+
isDrawerOpen: isListDrawerOpen,
|
|
153
|
+
openDrawer: openListDrawer
|
|
154
|
+
}] = useListDrawer({
|
|
155
|
+
collectionSlugs: hasMultipleRelations ? relationTo : [relationTo],
|
|
156
|
+
filterOptions: listDrawerFilterOptions
|
|
157
|
+
});
|
|
158
|
+
const onListSelect = useCallback(({
|
|
159
|
+
collectionSlug,
|
|
160
|
+
doc
|
|
161
|
+
}) => {
|
|
162
|
+
const formattedSelection = hasMultipleRelations ? {
|
|
163
|
+
relationTo: collectionSlug,
|
|
164
|
+
value: doc.id
|
|
165
|
+
} : doc.id;
|
|
166
|
+
if (hasMany) {
|
|
167
|
+
const withSelection = Array.isArray(value_0) ? value_0 : [];
|
|
168
|
+
withSelection.push(formattedSelection);
|
|
169
|
+
setValue(withSelection);
|
|
170
|
+
} else {
|
|
171
|
+
setValue(formattedSelection);
|
|
172
|
+
}
|
|
173
|
+
closeListDrawer();
|
|
174
|
+
}, [hasMany, hasMultipleRelations, setValue, closeListDrawer, value_0]);
|
|
125
175
|
const openDrawerWhenRelationChanges = useRef(false);
|
|
126
176
|
const getResults = useCallback(async ({
|
|
127
177
|
filterOptions: filterOptions_0,
|
|
@@ -456,13 +506,13 @@ const RelationshipFieldComponent = props => {
|
|
|
456
506
|
}, []);
|
|
457
507
|
const onDocumentDrawerOpen = useCallback(({
|
|
458
508
|
id: id_0,
|
|
459
|
-
collectionSlug,
|
|
509
|
+
collectionSlug: collectionSlug_0,
|
|
460
510
|
hasReadPermission
|
|
461
511
|
}) => {
|
|
462
512
|
openDrawerWhenRelationChanges.current = true;
|
|
463
513
|
setCurrentlyOpenRelationship({
|
|
464
514
|
id: id_0,
|
|
465
|
-
collectionSlug,
|
|
515
|
+
collectionSlug: collectionSlug_0,
|
|
466
516
|
hasReadPermission
|
|
467
517
|
});
|
|
468
518
|
}, []);
|
|
@@ -504,18 +554,21 @@ const RelationshipFieldComponent = props => {
|
|
|
504
554
|
}), BeforeInput, !errorLoading && /*#__PURE__*/_jsxs("div", {
|
|
505
555
|
className: `${baseClass}__wrap`,
|
|
506
556
|
children: [/*#__PURE__*/_jsx(ReactSelect, {
|
|
507
|
-
backspaceRemovesValue: !isDrawerOpen,
|
|
557
|
+
backspaceRemovesValue: !(isDrawerOpen || isListDrawerOpen),
|
|
508
558
|
components: {
|
|
509
559
|
MultiValueLabel,
|
|
510
|
-
SingleValue
|
|
560
|
+
SingleValue,
|
|
561
|
+
...(appearance !== 'select' && {
|
|
562
|
+
DropdownIndicator: null
|
|
563
|
+
})
|
|
511
564
|
},
|
|
512
565
|
customProps: {
|
|
513
|
-
disableKeyDown: isDrawerOpen,
|
|
514
|
-
disableMouseDown: isDrawerOpen,
|
|
566
|
+
disableKeyDown: isDrawerOpen || isListDrawerOpen,
|
|
567
|
+
disableMouseDown: isDrawerOpen || isListDrawerOpen,
|
|
515
568
|
onDocumentDrawerOpen,
|
|
516
569
|
onSave
|
|
517
570
|
},
|
|
518
|
-
disabled: readOnly || disabled || isDrawerOpen,
|
|
571
|
+
disabled: readOnly || disabled || isDrawerOpen || isListDrawerOpen,
|
|
519
572
|
filterOption: enableWordBoundarySearch ? filterOption : undefined,
|
|
520
573
|
getOptionValue: option_3 => {
|
|
521
574
|
if (!option_3) {
|
|
@@ -523,9 +576,11 @@ const RelationshipFieldComponent = props => {
|
|
|
523
576
|
}
|
|
524
577
|
return hasMany && Array.isArray(relationTo) ? `${option_3.relationTo}_${option_3.value}` : option_3.value;
|
|
525
578
|
},
|
|
526
|
-
isLoading: isLoading,
|
|
579
|
+
isLoading: appearance === 'select' && isLoading,
|
|
527
580
|
isMulti: hasMany,
|
|
581
|
+
isSearchable: appearance === 'select',
|
|
528
582
|
isSortable: isSortable,
|
|
583
|
+
menuIsOpen: appearance === 'select' ? menuIsOpen : false,
|
|
529
584
|
onChange: !(readOnly || disabled) ? selected => {
|
|
530
585
|
if (selected === null) {
|
|
531
586
|
setValue(hasMany ? [] : null);
|
|
@@ -553,18 +608,22 @@ const RelationshipFieldComponent = props => {
|
|
|
553
608
|
setMenuIsOpen(false);
|
|
554
609
|
},
|
|
555
610
|
onMenuOpen: () => {
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
611
|
+
if (appearance === 'drawer') {
|
|
612
|
+
openListDrawer();
|
|
613
|
+
} else if (appearance === 'select') {
|
|
614
|
+
setMenuIsOpen(true);
|
|
615
|
+
if (!hasLoadedFirstPageRef.current) {
|
|
616
|
+
setIsLoading(true);
|
|
617
|
+
void getResults({
|
|
618
|
+
filterOptions,
|
|
619
|
+
lastLoadedPage: {},
|
|
620
|
+
onSuccess: () => {
|
|
621
|
+
hasLoadedFirstPageRef.current = true;
|
|
622
|
+
setIsLoading(false);
|
|
623
|
+
},
|
|
624
|
+
value: initialValue
|
|
625
|
+
});
|
|
626
|
+
}
|
|
568
627
|
}
|
|
569
628
|
},
|
|
570
629
|
onMenuScrollToBottom: () => {
|
|
@@ -601,6 +660,10 @@ const RelationshipFieldComponent = props => {
|
|
|
601
660
|
onDelete: onDelete,
|
|
602
661
|
onDuplicate: onDuplicate,
|
|
603
662
|
onSave: onSave
|
|
663
|
+
}), appearance === 'drawer' && !readOnly && /*#__PURE__*/_jsx(ListDrawer, {
|
|
664
|
+
allowCreate: allowCreate,
|
|
665
|
+
enableRowSelections: false,
|
|
666
|
+
onSelect: onListSelect
|
|
604
667
|
})]
|
|
605
668
|
});
|
|
606
669
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["dequal","wordBoundariesRegex","qs","React","useCallback","useEffect","useMemo","useReducer","useRef","useState","AddNewRelation","useDocumentDrawer","ReactSelect","RenderCustomComponent","FieldDescription","FieldError","FieldLabel","useField","withCondition","useDebouncedCallback","useEffectEvent","useAuth","useConfig","useLocale","useTranslation","mergeFieldStyles","fieldBaseClass","createRelationMap","findOptionsByValue","optionsReducer","MultiValueLabel","SingleValue","maxResultsPerRequest","baseClass","RelationshipFieldComponent","props","field","admin","allowCreate","allowEdit","className","description","isSortable","sortOptions","hasMany","label","localized","relationTo","required","path","readOnly","validate","config","getEntityConfig","routes","api","serverURL","i18n","t","permissions","code","locale","hasMultipleRelations","Array","isArray","currentlyOpenRelationship","setCurrentlyOpenRelationship","id","undefined","collectionSlug","hasReadPermission","lastFullyLoadedRelation","setLastFullyLoadedRelation","lastLoadedPage","setLastLoadedPage","errorLoading","setErrorLoading","search","setSearch","isLoading","setIsLoading","enableWordBoundarySearch","setEnableWordBoundarySearch","menuIsOpen","setMenuIsOpen","hasLoadedFirstPageRef","memoizedValidate","value","validationOptions","customComponents","AfterInput","BeforeInput","Description","Error","Label","disabled","filterOptions","initialValue","setValue","showError","options","dispatchOptions","valueRef","current","DocumentDrawer","isDrawerOpen","openDrawer","openDrawerWhenRelationChanges","getResults","lastFullyLoadedRelationArg","lastLoadedPageArg","onSuccess","searchArg","sort","valueArg","lastFullyLoadedRelationToUse","relations","relationsToFetch","slice","resultsFetched","relationMap","reduce","priorRelation","relation","relationFilterOption","lastLoadedPageToUse","indexOf","Promise","resolve","collection","fieldToSearch","useAsTitle","fieldToSort","defaultSort","query","depth","draft","limit","page","where","and","not_in","push","like","response","fetch","body","stringify","credentials","headers","language","method","ok","data","json","prevState","nextPage","docs","length","type","status","ids","updateSearch","handleInputChange","handleValueChange","Object","entries","idsToLoad","filter","find","optionGroup","option","in","prevValue","isFirstRenderRef","isIdOnly","idOnly","getResultsEffectEvent","args","exemptValues","onSave","collectionConfig","doc","currentValue","docID","unchanged","some","valuesToSet","map","slug","onDuplicate","concat","onDelete","filterOption","item","searchFilter","r","breakApartThreshold","labelString","String","indexOfSpace","test","onDocumentDrawerOpen","valueToRender","styles","_jsxs","Boolean","join","replace","style","_jsx","CustomComponent","Fallback","backspaceRemovesValue","components","customProps","disableKeyDown","disableMouseDown","getOptionValue","isMulti","onChange","selected","onInputChange","newSearch","onMenuClose","onMenuOpen","onMenuScrollToBottom","RelationshipField"],"sources":["../../../src/fields/Relationship/index.tsx"],"sourcesContent":["'use client'\nimport type { PaginatedDocs, RelationshipFieldClientComponent, Where } from 'payload'\n\nimport { dequal } from 'dequal/lite'\nimport { wordBoundariesRegex } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from 'react'\n\nimport type { DocumentDrawerProps } from '../../elements/DocumentDrawer/types.js'\nimport type { ReactSelectAdapterProps } from '../../elements/ReactSelect/types.js'\nimport type { GetResults, Option, Value } from './types.js'\n\nimport { AddNewRelation } from '../../elements/AddNewRelation/index.js'\nimport { useDocumentDrawer } from '../../elements/DocumentDrawer/index.js'\nimport { ReactSelect } from '../../elements/ReactSelect/index.js'\nimport { RenderCustomComponent } from '../../elements/RenderCustomComponent/index.js'\nimport { FieldDescription } from '../../fields/FieldDescription/index.js'\nimport { FieldError } from '../../fields/FieldError/index.js'\nimport { FieldLabel } from '../../fields/FieldLabel/index.js'\nimport { useField } from '../../forms/useField/index.js'\nimport { withCondition } from '../../forms/withCondition/index.js'\nimport { useDebouncedCallback } from '../../hooks/useDebouncedCallback.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useAuth } from '../../providers/Auth/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport './index.scss'\nimport { mergeFieldStyles } from '../mergeFieldStyles.js'\nimport { fieldBaseClass } from '../shared/index.js'\nimport { createRelationMap } from './createRelationMap.js'\nimport { findOptionsByValue } from './findOptionsByValue.js'\nimport { optionsReducer } from './optionsReducer.js'\nimport { MultiValueLabel } from './select-components/MultiValueLabel/index.js'\nimport { SingleValue } from './select-components/SingleValue/index.js'\n\nconst maxResultsPerRequest = 10\n\nconst baseClass = 'relationship'\n\nconst RelationshipFieldComponent: RelationshipFieldClientComponent = (props) => {\n const {\n field,\n field: {\n admin: {\n allowCreate = true,\n allowEdit = true,\n className,\n description,\n isSortable = true,\n sortOptions,\n } = {},\n hasMany,\n label,\n localized,\n relationTo,\n required,\n },\n path,\n readOnly,\n validate,\n } = props\n\n const { config, getEntityConfig } = useConfig()\n\n const {\n routes: { api },\n serverURL,\n } = config\n\n const { i18n, t } = useTranslation()\n const { permissions } = useAuth()\n const { code: locale } = useLocale()\n const hasMultipleRelations = Array.isArray(relationTo)\n\n const [currentlyOpenRelationship, setCurrentlyOpenRelationship] = useState<\n Parameters<ReactSelectAdapterProps['customProps']['onDocumentDrawerOpen']>[0]\n >({\n id: undefined,\n collectionSlug: undefined,\n hasReadPermission: false,\n })\n\n const [lastFullyLoadedRelation, setLastFullyLoadedRelation] = useState(-1)\n const [lastLoadedPage, setLastLoadedPage] = useState<Record<string, number>>({})\n const [errorLoading, setErrorLoading] = useState('')\n const [search, setSearch] = useState('')\n const [isLoading, setIsLoading] = useState(false)\n const [enableWordBoundarySearch, setEnableWordBoundarySearch] = useState(false)\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n const hasLoadedFirstPageRef = useRef(false)\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, { ...validationOptions, required })\n }\n },\n [validate, required],\n )\n\n const {\n customComponents: { AfterInput, BeforeInput, Description, Error, Label } = {},\n disabled,\n filterOptions,\n initialValue,\n setValue,\n showError,\n value,\n } = useField<Value | Value[]>({\n path,\n validate: memoizedValidate,\n })\n const [options, dispatchOptions] = useReducer(optionsReducer, [])\n\n const valueRef = useRef(value)\n valueRef.current = value\n\n const [DocumentDrawer, , { isDrawerOpen, openDrawer }] = useDocumentDrawer({\n id: currentlyOpenRelationship.id,\n collectionSlug: currentlyOpenRelationship.collectionSlug,\n })\n\n const openDrawerWhenRelationChanges = useRef(false)\n\n const getResults: GetResults = useCallback(\n async ({\n filterOptions,\n lastFullyLoadedRelation: lastFullyLoadedRelationArg,\n lastLoadedPage: lastLoadedPageArg,\n onSuccess,\n search: searchArg,\n sort,\n value: valueArg,\n }) => {\n if (!permissions) {\n return\n }\n const lastFullyLoadedRelationToUse =\n typeof lastFullyLoadedRelationArg !== 'undefined' ? lastFullyLoadedRelationArg : -1\n\n const relations = Array.isArray(relationTo) ? relationTo : [relationTo]\n const relationsToFetch =\n lastFullyLoadedRelationToUse === -1\n ? relations\n : relations.slice(lastFullyLoadedRelationToUse + 1)\n\n let resultsFetched = 0\n const relationMap = createRelationMap({\n hasMany,\n relationTo,\n value: valueArg,\n })\n\n if (!errorLoading) {\n await relationsToFetch.reduce(async (priorRelation, relation) => {\n const relationFilterOption = filterOptions?.[relation]\n\n let lastLoadedPageToUse\n if (search !== searchArg) {\n lastLoadedPageToUse = 1\n } else {\n lastLoadedPageToUse = lastLoadedPageArg[relation] + 1\n }\n await priorRelation\n\n if (relationFilterOption === false) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n return Promise.resolve()\n }\n\n if (resultsFetched < 10) {\n const collection = getEntityConfig({ collectionSlug: relation })\n const fieldToSearch = collection?.admin?.useAsTitle || 'id'\n let fieldToSort = collection?.defaultSort || 'id'\n if (typeof sortOptions === 'string') {\n fieldToSort = sortOptions\n } else if (sortOptions?.[relation]) {\n fieldToSort = sortOptions[relation]\n }\n\n const query: {\n [key: string]: unknown\n where: Where\n } = {\n depth: 0,\n draft: true,\n limit: maxResultsPerRequest,\n locale,\n page: lastLoadedPageToUse,\n sort: fieldToSort,\n where: {\n and: [\n {\n id: {\n not_in: relationMap[relation],\n },\n },\n ],\n },\n }\n\n if (searchArg) {\n query.where.and.push({\n [fieldToSearch]: {\n like: searchArg,\n },\n })\n }\n\n if (relationFilterOption && typeof relationFilterOption !== 'boolean') {\n query.where.and.push(relationFilterOption)\n }\n\n const response = await fetch(`${serverURL}${api}/${relation}`, {\n body: qs.stringify(query),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/x-www-form-urlencoded',\n 'X-HTTP-Method-Override': 'GET',\n },\n method: 'POST',\n })\n\n if (response.ok) {\n const data: PaginatedDocs<unknown> = await response.json()\n setLastLoadedPage((prevState) => {\n return {\n ...prevState,\n [relation]: lastLoadedPageToUse,\n }\n })\n\n if (!data.nextPage) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n }\n\n if (data.docs.length > 0) {\n resultsFetched += data.docs.length\n\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs: data.docs,\n i18n,\n sort,\n })\n }\n } else if (response.status === 403) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs: [],\n i18n,\n ids: relationMap[relation],\n sort,\n })\n } else {\n setErrorLoading(t('error:unspecific'))\n }\n }\n }, Promise.resolve())\n\n if (typeof onSuccess === 'function') {\n onSuccess()\n }\n }\n },\n [\n permissions,\n relationTo,\n hasMany,\n errorLoading,\n search,\n getEntityConfig,\n locale,\n serverURL,\n sortOptions,\n api,\n i18n,\n config,\n t,\n ],\n )\n\n const updateSearch = useDebouncedCallback((searchArg: string, valueArg: Value | Value[]) => {\n void getResults({\n filterOptions,\n lastLoadedPage: {},\n search: searchArg,\n sort: true,\n value: valueArg,\n })\n setSearch(searchArg)\n }, 300)\n\n const handleInputChange = useCallback(\n (searchArg: string, valueArg: Value | Value[]) => {\n if (search !== searchArg) {\n setLastLoadedPage({})\n updateSearch(searchArg, valueArg, searchArg !== '')\n }\n },\n [search, updateSearch],\n )\n\n const handleValueChange = useEffectEvent((value: Value | Value[]) => {\n const relationMap = createRelationMap({\n hasMany,\n relationTo,\n value,\n })\n\n void Object.entries(relationMap).reduce(async (priorRelation, [relation, ids]) => {\n await priorRelation\n\n const idsToLoad = ids.filter((id) => {\n return !options.find((optionGroup) =>\n optionGroup?.options?.find(\n (option) => option.value === id && option.relationTo === relation,\n ),\n )\n })\n\n if (idsToLoad.length > 0) {\n const query = {\n depth: 0,\n draft: true,\n limit: idsToLoad.length,\n locale,\n where: {\n id: {\n in: idsToLoad,\n },\n },\n }\n\n if (!errorLoading) {\n const response = await fetch(`${serverURL}${api}/${relation}`, {\n body: qs.stringify(query),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/x-www-form-urlencoded',\n 'X-HTTP-Method-Override': 'GET',\n },\n method: 'POST',\n })\n\n const collection = getEntityConfig({ collectionSlug: relation })\n let docs = []\n\n if (response.ok) {\n const data = await response.json()\n docs = data.docs\n }\n\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs,\n i18n,\n ids: idsToLoad,\n sort: true,\n })\n }\n }\n }, Promise.resolve())\n })\n\n const prevValue = useRef(value)\n const isFirstRenderRef = useRef(true)\n // ///////////////////////////////////\n // Ensure we have an option for each value\n // ///////////////////////////////////\n useEffect(() => {\n if (isFirstRenderRef.current || !dequal(value, prevValue.current)) {\n handleValueChange(value)\n }\n isFirstRenderRef.current = false\n prevValue.current = value\n }, [value])\n\n // Determine if we should switch to word boundary search\n useEffect(() => {\n const relations = Array.isArray(relationTo) ? relationTo : [relationTo]\n const isIdOnly = relations.reduce((idOnly, relation) => {\n const collection = getEntityConfig({ collectionSlug: relation })\n const fieldToSearch = collection?.admin?.useAsTitle || 'id'\n return fieldToSearch === 'id' && idOnly\n }, true)\n setEnableWordBoundarySearch(!isIdOnly)\n }, [relationTo, getEntityConfig])\n\n const getResultsEffectEvent: GetResults = useEffectEvent(async (args) => {\n return await getResults(args)\n })\n\n // When (`relationTo` || `filterOptions` || `locale`) changes, reset component\n // Note - effect should not run on first run\n useEffect(() => {\n // If the menu is open while filterOptions changes\n // due to latency of form state and fast clicking into this field,\n // re-fetch options\n if (hasLoadedFirstPageRef.current && menuIsOpen) {\n setIsLoading(true)\n void getResultsEffectEvent({\n filterOptions,\n lastLoadedPage: {},\n onSuccess: () => {\n hasLoadedFirstPageRef.current = true\n setIsLoading(false)\n },\n value: valueRef.current,\n })\n }\n\n // If the menu is not open, still reset the field state\n // because we need to get new options next time the menu opens\n dispatchOptions({\n type: 'CLEAR',\n exemptValues: valueRef.current,\n })\n\n setLastFullyLoadedRelation(-1)\n setLastLoadedPage({})\n }, [relationTo, filterOptions, locale, path, menuIsOpen])\n\n const onSave = useCallback<DocumentDrawerProps['onSave']>(\n (args) => {\n dispatchOptions({\n type: 'UPDATE',\n collection: args.collectionConfig,\n config,\n doc: args.doc,\n i18n,\n })\n\n const currentValue = valueRef.current\n const docID = args.doc.id\n\n if (hasMany) {\n const unchanged = (currentValue as Option[]).some((option) =>\n typeof option === 'string' ? option === docID : option.value === docID,\n )\n\n const valuesToSet = (currentValue as Option[]).map((option) =>\n option.value === docID\n ? { relationTo: args.collectionConfig.slug, value: docID }\n : option,\n )\n\n setValue(valuesToSet, unchanged)\n } else {\n const unchanged = currentValue === docID\n\n setValue({ relationTo: args.collectionConfig.slug, value: docID }, unchanged)\n }\n },\n [i18n, config, hasMany, setValue],\n )\n\n const onDuplicate = useCallback<DocumentDrawerProps['onDuplicate']>(\n (args) => {\n dispatchOptions({\n type: 'ADD',\n collection: args.collectionConfig,\n config,\n docs: [args.doc],\n i18n,\n sort: true,\n })\n\n if (hasMany) {\n setValue(\n valueRef.current\n ? (valueRef.current as Option[]).concat({\n relationTo: args.collectionConfig.slug,\n value: args.doc.id,\n } as Option)\n : null,\n )\n } else {\n setValue({\n relationTo: args.collectionConfig.slug,\n value: args.doc.id,\n })\n }\n },\n [i18n, config, hasMany, setValue],\n )\n\n const onDelete = useCallback<DocumentDrawerProps['onDelete']>(\n (args) => {\n dispatchOptions({\n id: args.id,\n type: 'REMOVE',\n collection: args.collectionConfig,\n config,\n i18n,\n })\n\n if (hasMany) {\n setValue(\n valueRef.current\n ? (valueRef.current as Option[]).filter((option) => {\n return option.value !== args.id\n })\n : null,\n )\n } else {\n setValue(null)\n }\n\n return\n },\n [i18n, config, hasMany, setValue],\n )\n\n const filterOption = useCallback((item: Option, searchFilter: string) => {\n if (!searchFilter) {\n return true\n }\n const r = wordBoundariesRegex(searchFilter || '')\n // breaking the labels to search into smaller parts increases performance\n const breakApartThreshold = 250\n let labelString = String(item.label)\n // strings less than breakApartThreshold length won't be chunked\n while (labelString.length > breakApartThreshold) {\n // slicing by the next space after the length of the search input prevents slicing the string up by partial words\n const indexOfSpace = labelString.indexOf(' ', searchFilter.length)\n if (\n r.test(labelString.slice(0, indexOfSpace === -1 ? searchFilter.length : indexOfSpace + 1))\n ) {\n return true\n }\n labelString = labelString.slice(indexOfSpace === -1 ? searchFilter.length : indexOfSpace + 1)\n }\n return r.test(labelString.slice(-breakApartThreshold))\n }, [])\n\n const onDocumentDrawerOpen = useCallback<\n ReactSelectAdapterProps['customProps']['onDocumentDrawerOpen']\n >(({ id, collectionSlug, hasReadPermission }) => {\n openDrawerWhenRelationChanges.current = true\n setCurrentlyOpenRelationship({\n id,\n collectionSlug,\n hasReadPermission,\n })\n }, [])\n\n useEffect(() => {\n if (openDrawerWhenRelationChanges.current) {\n openDrawer()\n openDrawerWhenRelationChanges.current = false\n }\n }, [openDrawer, currentlyOpenRelationship])\n\n const valueToRender = findOptionsByValue({ allowEdit, options, value })\n\n if (!Array.isArray(valueToRender) && valueToRender?.value === 'null') {\n valueToRender.value = null\n }\n\n const styles = useMemo(() => mergeFieldStyles(field), [field])\n\n return (\n <div\n className={[\n fieldBaseClass,\n baseClass,\n className,\n showError && 'error',\n errorLoading && 'error-loading',\n (readOnly || disabled) && `${baseClass}--read-only`,\n !(readOnly || disabled) && allowCreate && `${baseClass}--allow-create`,\n ]\n .filter(Boolean)\n .join(' ')}\n id={`field-${path.replace(/\\./g, '__')}`}\n style={styles}\n >\n <RenderCustomComponent\n CustomComponent={Label}\n Fallback={\n <FieldLabel label={label} localized={localized} path={path} required={required} />\n }\n />\n <div className={`${fieldBaseClass}__wrap`}>\n <RenderCustomComponent\n CustomComponent={Error}\n Fallback={<FieldError path={path} showError={showError} />}\n />\n {BeforeInput}\n {!errorLoading && (\n <div className={`${baseClass}__wrap`}>\n <ReactSelect\n backspaceRemovesValue={!isDrawerOpen}\n components={{\n MultiValueLabel,\n SingleValue,\n }}\n customProps={{\n disableKeyDown: isDrawerOpen,\n disableMouseDown: isDrawerOpen,\n onDocumentDrawerOpen,\n onSave,\n }}\n disabled={readOnly || disabled || isDrawerOpen}\n filterOption={enableWordBoundarySearch ? filterOption : undefined}\n getOptionValue={(option) => {\n if (!option) {\n return undefined\n }\n return hasMany && Array.isArray(relationTo)\n ? `${option.relationTo}_${option.value}`\n : (option.value as string)\n }}\n isLoading={isLoading}\n isMulti={hasMany}\n isSortable={isSortable}\n onChange={\n !(readOnly || disabled)\n ? (selected) => {\n if (selected === null) {\n setValue(hasMany ? [] : null)\n } else if (hasMany && Array.isArray(selected)) {\n setValue(\n selected\n ? selected.map((option) => {\n if (hasMultipleRelations) {\n return {\n relationTo: option.relationTo,\n value: option.value,\n }\n }\n\n return option.value\n })\n : null,\n )\n } else if (hasMultipleRelations && !Array.isArray(selected)) {\n setValue({\n relationTo: selected.relationTo,\n value: selected.value,\n })\n } else if (!Array.isArray(selected)) {\n setValue(selected.value)\n }\n }\n : undefined\n }\n onInputChange={(newSearch) => handleInputChange(newSearch, value)}\n onMenuClose={() => {\n setMenuIsOpen(false)\n }}\n onMenuOpen={() => {\n setMenuIsOpen(true)\n\n if (!hasLoadedFirstPageRef.current) {\n setIsLoading(true)\n void getResults({\n filterOptions,\n lastLoadedPage: {},\n onSuccess: () => {\n hasLoadedFirstPageRef.current = true\n setIsLoading(false)\n },\n value: initialValue,\n })\n }\n }}\n onMenuScrollToBottom={() => {\n void getResults({\n filterOptions,\n lastFullyLoadedRelation,\n lastLoadedPage,\n search,\n sort: false,\n value: initialValue,\n })\n }}\n options={options}\n showError={showError}\n value={valueToRender ?? null}\n />\n {!(readOnly || disabled) && allowCreate && (\n <AddNewRelation\n hasMany={hasMany}\n path={path}\n relationTo={relationTo}\n setValue={setValue}\n value={value}\n />\n )}\n </div>\n )}\n {errorLoading && <div className={`${baseClass}__error-loading`}>{errorLoading}</div>}\n {AfterInput}\n <RenderCustomComponent\n CustomComponent={Description}\n Fallback={<FieldDescription description={description} path={path} />}\n />\n </div>\n {currentlyOpenRelationship.collectionSlug && currentlyOpenRelationship.hasReadPermission && (\n <DocumentDrawer onDelete={onDelete} onDuplicate={onDuplicate} onSave={onSave} />\n )}\n </div>\n )\n}\n\nexport const RelationshipField = withCondition(RelationshipFieldComponent)\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"index.js","names":["dequal","wordBoundariesRegex","qs","React","useCallback","useEffect","useMemo","useReducer","useRef","useState","AddNewRelation","useDocumentDrawer","useListDrawer","ReactSelect","RenderCustomComponent","FieldDescription","FieldError","FieldLabel","useField","withCondition","useDebouncedCallback","useEffectEvent","useAuth","useConfig","useLocale","useTranslation","mergeFieldStyles","fieldBaseClass","createRelationMap","findOptionsByValue","optionsReducer","MultiValueLabel","SingleValue","maxResultsPerRequest","baseClass","RelationshipFieldComponent","props","field","admin","allowCreate","allowEdit","appearance","className","description","isSortable","sortOptions","hasMany","label","localized","relationTo","required","path","pathFromProps","readOnly","validate","config","getEntityConfig","routes","api","serverURL","i18n","t","permissions","code","locale","hasMultipleRelations","Array","isArray","currentlyOpenRelationship","setCurrentlyOpenRelationship","id","undefined","collectionSlug","hasReadPermission","lastFullyLoadedRelation","setLastFullyLoadedRelation","lastLoadedPage","setLastLoadedPage","errorLoading","setErrorLoading","search","setSearch","isLoading","setIsLoading","enableWordBoundarySearch","setEnableWordBoundarySearch","menuIsOpen","setMenuIsOpen","hasLoadedFirstPageRef","memoizedValidate","value","validationOptions","customComponents","AfterInput","BeforeInput","Description","Error","Label","disabled","filterOptions","initialValue","setValue","showError","potentiallyStalePath","options","dispatchOptions","valueRef","current","DocumentDrawer","isDrawerOpen","openDrawer","listDrawerFilterOptions","newFilterOptions","forEach","val","not_in","ListDrawer","closeDrawer","closeListDrawer","isListDrawerOpen","openListDrawer","collectionSlugs","onListSelect","doc","formattedSelection","withSelection","push","openDrawerWhenRelationChanges","getResults","lastFullyLoadedRelationArg","lastLoadedPageArg","onSuccess","searchArg","sort","valueArg","lastFullyLoadedRelationToUse","relations","relationsToFetch","slice","resultsFetched","relationMap","reduce","priorRelation","relation","relationFilterOption","lastLoadedPageToUse","indexOf","Promise","resolve","collection","fieldToSearch","useAsTitle","fieldToSort","defaultSort","query","depth","draft","limit","page","where","and","like","response","fetch","body","stringify","credentials","headers","language","method","ok","data","json","prevState","nextPage","docs","length","type","status","ids","updateSearch","handleInputChange","handleValueChange","Object","entries","idsToLoad","filter","find","optionGroup","option","in","prevValue","isFirstRenderRef","isIdOnly","idOnly","getResultsEffectEvent","args","exemptValues","onSave","collectionConfig","currentValue","docID","unchanged","some","valuesToSet","map","slug","onDuplicate","concat","onDelete","filterOption","item","searchFilter","r","breakApartThreshold","labelString","String","indexOfSpace","test","onDocumentDrawerOpen","valueToRender","styles","_jsxs","Boolean","join","replace","style","_jsx","CustomComponent","Fallback","backspaceRemovesValue","components","DropdownIndicator","customProps","disableKeyDown","disableMouseDown","getOptionValue","isMulti","isSearchable","onChange","selected","onInputChange","newSearch","onMenuClose","onMenuOpen","onMenuScrollToBottom","enableRowSelections","onSelect","RelationshipField"],"sources":["../../../src/fields/Relationship/index.tsx"],"sourcesContent":["'use client'\nimport type {\n FilterOptionsResult,\n PaginatedDocs,\n RelationshipFieldClientComponent,\n Where,\n} from 'payload'\n\nimport { dequal } from 'dequal/lite'\nimport { wordBoundariesRegex } from 'payload/shared'\nimport * as qs from 'qs-esm'\nimport React, { useCallback, useEffect, useMemo, useReducer, useRef, useState } from 'react'\n\nimport type { DocumentDrawerProps } from '../../elements/DocumentDrawer/types.js'\nimport type { ListDrawerProps } from '../../elements/ListDrawer/types.js'\nimport type { ReactSelectAdapterProps } from '../../elements/ReactSelect/types.js'\nimport type { GetResults, Option, Value } from './types.js'\n\nimport { AddNewRelation } from '../../elements/AddNewRelation/index.js'\nimport { useDocumentDrawer } from '../../elements/DocumentDrawer/index.js'\nimport { useListDrawer } from '../../elements/ListDrawer/index.js'\nimport { ReactSelect } from '../../elements/ReactSelect/index.js'\nimport { RenderCustomComponent } from '../../elements/RenderCustomComponent/index.js'\nimport { FieldDescription } from '../../fields/FieldDescription/index.js'\nimport { FieldError } from '../../fields/FieldError/index.js'\nimport { FieldLabel } from '../../fields/FieldLabel/index.js'\nimport { useField } from '../../forms/useField/index.js'\nimport { withCondition } from '../../forms/withCondition/index.js'\nimport { useDebouncedCallback } from '../../hooks/useDebouncedCallback.js'\nimport { useEffectEvent } from '../../hooks/useEffectEvent.js'\nimport { useAuth } from '../../providers/Auth/index.js'\nimport { useConfig } from '../../providers/Config/index.js'\nimport { useLocale } from '../../providers/Locale/index.js'\nimport { useTranslation } from '../../providers/Translation/index.js'\nimport './index.scss'\nimport { mergeFieldStyles } from '../mergeFieldStyles.js'\nimport { fieldBaseClass } from '../shared/index.js'\nimport { createRelationMap } from './createRelationMap.js'\nimport { findOptionsByValue } from './findOptionsByValue.js'\nimport { optionsReducer } from './optionsReducer.js'\nimport { MultiValueLabel } from './select-components/MultiValueLabel/index.js'\nimport { SingleValue } from './select-components/SingleValue/index.js'\n\nconst maxResultsPerRequest = 10\n\nconst baseClass = 'relationship'\n\nconst RelationshipFieldComponent: RelationshipFieldClientComponent = (props) => {\n const {\n field,\n field: {\n admin: {\n allowCreate = true,\n allowEdit = true,\n appearance = 'select',\n className,\n description,\n isSortable = true,\n sortOptions,\n } = {},\n hasMany,\n label,\n localized,\n relationTo,\n required,\n },\n path: pathFromProps,\n readOnly,\n validate,\n } = props\n\n const { config, getEntityConfig } = useConfig()\n\n const {\n routes: { api },\n serverURL,\n } = config\n\n const { i18n, t } = useTranslation()\n const { permissions } = useAuth()\n const { code: locale } = useLocale()\n const hasMultipleRelations = Array.isArray(relationTo)\n\n const [currentlyOpenRelationship, setCurrentlyOpenRelationship] = useState<\n Parameters<ReactSelectAdapterProps['customProps']['onDocumentDrawerOpen']>[0]\n >({\n id: undefined,\n collectionSlug: undefined,\n hasReadPermission: false,\n })\n\n const [lastFullyLoadedRelation, setLastFullyLoadedRelation] = useState(-1)\n const [lastLoadedPage, setLastLoadedPage] = useState<Record<string, number>>({})\n const [errorLoading, setErrorLoading] = useState('')\n const [search, setSearch] = useState('')\n const [isLoading, setIsLoading] = useState(false)\n const [enableWordBoundarySearch, setEnableWordBoundarySearch] = useState(false)\n const [menuIsOpen, setMenuIsOpen] = useState(false)\n const hasLoadedFirstPageRef = useRef(false)\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, { ...validationOptions, required })\n }\n },\n [validate, required],\n )\n\n const {\n customComponents: { AfterInput, BeforeInput, Description, Error, Label } = {},\n disabled,\n filterOptions,\n initialValue,\n path,\n setValue,\n showError,\n value,\n } = useField<Value | Value[]>({\n potentiallyStalePath: pathFromProps,\n validate: memoizedValidate,\n })\n\n const [options, dispatchOptions] = useReducer(optionsReducer, [])\n\n const valueRef = useRef(value)\n valueRef.current = value\n\n const [DocumentDrawer, , { isDrawerOpen, openDrawer }] = useDocumentDrawer({\n id: currentlyOpenRelationship.id,\n collectionSlug: currentlyOpenRelationship.collectionSlug,\n })\n\n // Filter selected values from displaying in the list drawer\n const listDrawerFilterOptions = useMemo<FilterOptionsResult>(() => {\n let newFilterOptions = filterOptions\n\n if (value) {\n ;(Array.isArray(value) ? value : [value]).forEach((val) => {\n ;(Array.isArray(relationTo) ? relationTo : [relationTo]).forEach((relationTo) => {\n newFilterOptions = {\n ...(filterOptions || {}),\n [relationTo]: {\n ...(typeof filterOptions?.[relationTo] === 'object' ? filterOptions[relationTo] : {}),\n id: {\n not_in: [typeof val === 'object' ? val.value : val],\n },\n },\n }\n })\n })\n }\n\n return newFilterOptions\n }, [filterOptions, value, relationTo])\n\n const [\n ListDrawer,\n ,\n { closeDrawer: closeListDrawer, isDrawerOpen: isListDrawerOpen, openDrawer: openListDrawer },\n ] = useListDrawer({\n collectionSlugs: hasMultipleRelations ? relationTo : [relationTo],\n filterOptions: listDrawerFilterOptions,\n })\n\n const onListSelect = useCallback<NonNullable<ListDrawerProps['onSelect']>>(\n ({ collectionSlug, doc }) => {\n const formattedSelection = hasMultipleRelations\n ? {\n relationTo: collectionSlug,\n value: doc.id,\n }\n : doc.id\n\n if (hasMany) {\n const withSelection = Array.isArray(value) ? value : []\n withSelection.push(formattedSelection)\n setValue(withSelection)\n } else {\n setValue(formattedSelection)\n }\n\n closeListDrawer()\n },\n [hasMany, hasMultipleRelations, setValue, closeListDrawer, value],\n )\n\n const openDrawerWhenRelationChanges = useRef(false)\n\n const getResults: GetResults = useCallback(\n async ({\n filterOptions,\n lastFullyLoadedRelation: lastFullyLoadedRelationArg,\n lastLoadedPage: lastLoadedPageArg,\n onSuccess,\n search: searchArg,\n sort,\n value: valueArg,\n }) => {\n if (!permissions) {\n return\n }\n const lastFullyLoadedRelationToUse =\n typeof lastFullyLoadedRelationArg !== 'undefined' ? lastFullyLoadedRelationArg : -1\n\n const relations = Array.isArray(relationTo) ? relationTo : [relationTo]\n const relationsToFetch =\n lastFullyLoadedRelationToUse === -1\n ? relations\n : relations.slice(lastFullyLoadedRelationToUse + 1)\n\n let resultsFetched = 0\n const relationMap = createRelationMap({\n hasMany,\n relationTo,\n value: valueArg,\n })\n\n if (!errorLoading) {\n await relationsToFetch.reduce(async (priorRelation, relation) => {\n const relationFilterOption = filterOptions?.[relation]\n\n let lastLoadedPageToUse\n if (search !== searchArg) {\n lastLoadedPageToUse = 1\n } else {\n lastLoadedPageToUse = lastLoadedPageArg[relation] + 1\n }\n await priorRelation\n\n if (relationFilterOption === false) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n return Promise.resolve()\n }\n\n if (resultsFetched < 10) {\n const collection = getEntityConfig({ collectionSlug: relation })\n const fieldToSearch = collection?.admin?.useAsTitle || 'id'\n let fieldToSort = collection?.defaultSort || 'id'\n if (typeof sortOptions === 'string') {\n fieldToSort = sortOptions\n } else if (sortOptions?.[relation]) {\n fieldToSort = sortOptions[relation]\n }\n\n const query: {\n [key: string]: unknown\n where: Where\n } = {\n depth: 0,\n draft: true,\n limit: maxResultsPerRequest,\n locale,\n page: lastLoadedPageToUse,\n sort: fieldToSort,\n where: {\n and: [\n {\n id: {\n not_in: relationMap[relation],\n },\n },\n ],\n },\n }\n\n if (searchArg) {\n query.where.and.push({\n [fieldToSearch]: {\n like: searchArg,\n },\n })\n }\n\n if (relationFilterOption && typeof relationFilterOption !== 'boolean') {\n query.where.and.push(relationFilterOption)\n }\n\n const response = await fetch(`${serverURL}${api}/${relation}`, {\n body: qs.stringify(query),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/x-www-form-urlencoded',\n 'X-HTTP-Method-Override': 'GET',\n },\n method: 'POST',\n })\n\n if (response.ok) {\n const data: PaginatedDocs<unknown> = await response.json()\n setLastLoadedPage((prevState) => {\n return {\n ...prevState,\n [relation]: lastLoadedPageToUse,\n }\n })\n\n if (!data.nextPage) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n }\n\n if (data.docs.length > 0) {\n resultsFetched += data.docs.length\n\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs: data.docs,\n i18n,\n sort,\n })\n }\n } else if (response.status === 403) {\n setLastFullyLoadedRelation(relations.indexOf(relation))\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs: [],\n i18n,\n ids: relationMap[relation],\n sort,\n })\n } else {\n setErrorLoading(t('error:unspecific'))\n }\n }\n }, Promise.resolve())\n\n if (typeof onSuccess === 'function') {\n onSuccess()\n }\n }\n },\n [\n permissions,\n relationTo,\n hasMany,\n errorLoading,\n search,\n getEntityConfig,\n locale,\n serverURL,\n sortOptions,\n api,\n i18n,\n config,\n t,\n ],\n )\n\n const updateSearch = useDebouncedCallback((searchArg: string, valueArg: Value | Value[]) => {\n void getResults({\n filterOptions,\n lastLoadedPage: {},\n search: searchArg,\n sort: true,\n value: valueArg,\n })\n setSearch(searchArg)\n }, 300)\n\n const handleInputChange = useCallback(\n (searchArg: string, valueArg: Value | Value[]) => {\n if (search !== searchArg) {\n setLastLoadedPage({})\n updateSearch(searchArg, valueArg, searchArg !== '')\n }\n },\n [search, updateSearch],\n )\n\n const handleValueChange = useEffectEvent((value: Value | Value[]) => {\n const relationMap = createRelationMap({\n hasMany,\n relationTo,\n value,\n })\n\n void Object.entries(relationMap).reduce(async (priorRelation, [relation, ids]) => {\n await priorRelation\n\n const idsToLoad = ids.filter((id) => {\n return !options.find((optionGroup) =>\n optionGroup?.options?.find(\n (option) => option.value === id && option.relationTo === relation,\n ),\n )\n })\n\n if (idsToLoad.length > 0) {\n const query = {\n depth: 0,\n draft: true,\n limit: idsToLoad.length,\n locale,\n where: {\n id: {\n in: idsToLoad,\n },\n },\n }\n\n if (!errorLoading) {\n const response = await fetch(`${serverURL}${api}/${relation}`, {\n body: qs.stringify(query),\n credentials: 'include',\n headers: {\n 'Accept-Language': i18n.language,\n 'Content-Type': 'application/x-www-form-urlencoded',\n 'X-HTTP-Method-Override': 'GET',\n },\n method: 'POST',\n })\n\n const collection = getEntityConfig({ collectionSlug: relation })\n let docs = []\n\n if (response.ok) {\n const data = await response.json()\n docs = data.docs\n }\n\n dispatchOptions({\n type: 'ADD',\n collection,\n config,\n docs,\n i18n,\n ids: idsToLoad,\n sort: true,\n })\n }\n }\n }, Promise.resolve())\n })\n\n const prevValue = useRef(value)\n const isFirstRenderRef = useRef(true)\n // ///////////////////////////////////\n // Ensure we have an option for each value\n // ///////////////////////////////////\n useEffect(() => {\n if (isFirstRenderRef.current || !dequal(value, prevValue.current)) {\n handleValueChange(value)\n }\n isFirstRenderRef.current = false\n prevValue.current = value\n }, [value])\n\n // Determine if we should switch to word boundary search\n useEffect(() => {\n const relations = Array.isArray(relationTo) ? relationTo : [relationTo]\n const isIdOnly = relations.reduce((idOnly, relation) => {\n const collection = getEntityConfig({ collectionSlug: relation })\n const fieldToSearch = collection?.admin?.useAsTitle || 'id'\n return fieldToSearch === 'id' && idOnly\n }, true)\n setEnableWordBoundarySearch(!isIdOnly)\n }, [relationTo, getEntityConfig])\n\n const getResultsEffectEvent: GetResults = useEffectEvent(async (args) => {\n return await getResults(args)\n })\n\n // When (`relationTo` || `filterOptions` || `locale`) changes, reset component\n // Note - effect should not run on first run\n useEffect(() => {\n // If the menu is open while filterOptions changes\n // due to latency of form state and fast clicking into this field,\n // re-fetch options\n if (hasLoadedFirstPageRef.current && menuIsOpen) {\n setIsLoading(true)\n void getResultsEffectEvent({\n filterOptions,\n lastLoadedPage: {},\n onSuccess: () => {\n hasLoadedFirstPageRef.current = true\n setIsLoading(false)\n },\n value: valueRef.current,\n })\n }\n\n // If the menu is not open, still reset the field state\n // because we need to get new options next time the menu opens\n dispatchOptions({\n type: 'CLEAR',\n exemptValues: valueRef.current,\n })\n\n setLastFullyLoadedRelation(-1)\n setLastLoadedPage({})\n }, [relationTo, filterOptions, locale, path, menuIsOpen])\n\n const onSave = useCallback<DocumentDrawerProps['onSave']>(\n (args) => {\n dispatchOptions({\n type: 'UPDATE',\n collection: args.collectionConfig,\n config,\n doc: args.doc,\n i18n,\n })\n\n const currentValue = valueRef.current\n const docID = args.doc.id\n\n if (hasMany) {\n const unchanged = (currentValue as Option[]).some((option) =>\n typeof option === 'string' ? option === docID : option.value === docID,\n )\n\n const valuesToSet = (currentValue as Option[]).map((option) =>\n option.value === docID\n ? { relationTo: args.collectionConfig.slug, value: docID }\n : option,\n )\n\n setValue(valuesToSet, unchanged)\n } else {\n const unchanged = currentValue === docID\n\n setValue({ relationTo: args.collectionConfig.slug, value: docID }, unchanged)\n }\n },\n [i18n, config, hasMany, setValue],\n )\n\n const onDuplicate = useCallback<DocumentDrawerProps['onDuplicate']>(\n (args) => {\n dispatchOptions({\n type: 'ADD',\n collection: args.collectionConfig,\n config,\n docs: [args.doc],\n i18n,\n sort: true,\n })\n\n if (hasMany) {\n setValue(\n valueRef.current\n ? (valueRef.current as Option[]).concat({\n relationTo: args.collectionConfig.slug,\n value: args.doc.id,\n } as Option)\n : null,\n )\n } else {\n setValue({\n relationTo: args.collectionConfig.slug,\n value: args.doc.id,\n })\n }\n },\n [i18n, config, hasMany, setValue],\n )\n\n const onDelete = useCallback<DocumentDrawerProps['onDelete']>(\n (args) => {\n dispatchOptions({\n id: args.id,\n type: 'REMOVE',\n collection: args.collectionConfig,\n config,\n i18n,\n })\n\n if (hasMany) {\n setValue(\n valueRef.current\n ? (valueRef.current as Option[]).filter((option) => {\n return option.value !== args.id\n })\n : null,\n )\n } else {\n setValue(null)\n }\n\n return\n },\n [i18n, config, hasMany, setValue],\n )\n\n const filterOption = useCallback((item: Option, searchFilter: string) => {\n if (!searchFilter) {\n return true\n }\n const r = wordBoundariesRegex(searchFilter || '')\n // breaking the labels to search into smaller parts increases performance\n const breakApartThreshold = 250\n let labelString = String(item.label)\n // strings less than breakApartThreshold length won't be chunked\n while (labelString.length > breakApartThreshold) {\n // slicing by the next space after the length of the search input prevents slicing the string up by partial words\n const indexOfSpace = labelString.indexOf(' ', searchFilter.length)\n if (\n r.test(labelString.slice(0, indexOfSpace === -1 ? searchFilter.length : indexOfSpace + 1))\n ) {\n return true\n }\n labelString = labelString.slice(indexOfSpace === -1 ? searchFilter.length : indexOfSpace + 1)\n }\n return r.test(labelString.slice(-breakApartThreshold))\n }, [])\n\n const onDocumentDrawerOpen = useCallback<\n ReactSelectAdapterProps['customProps']['onDocumentDrawerOpen']\n >(({ id, collectionSlug, hasReadPermission }) => {\n openDrawerWhenRelationChanges.current = true\n setCurrentlyOpenRelationship({\n id,\n collectionSlug,\n hasReadPermission,\n })\n }, [])\n\n useEffect(() => {\n if (openDrawerWhenRelationChanges.current) {\n openDrawer()\n openDrawerWhenRelationChanges.current = false\n }\n }, [openDrawer, currentlyOpenRelationship])\n\n const valueToRender = findOptionsByValue({ allowEdit, options, value })\n\n if (!Array.isArray(valueToRender) && valueToRender?.value === 'null') {\n valueToRender.value = null\n }\n\n const styles = useMemo(() => mergeFieldStyles(field), [field])\n\n return (\n <div\n className={[\n fieldBaseClass,\n baseClass,\n className,\n showError && 'error',\n errorLoading && 'error-loading',\n (readOnly || disabled) && `${baseClass}--read-only`,\n !(readOnly || disabled) && allowCreate && `${baseClass}--allow-create`,\n ]\n .filter(Boolean)\n .join(' ')}\n id={`field-${path.replace(/\\./g, '__')}`}\n style={styles}\n >\n <RenderCustomComponent\n CustomComponent={Label}\n Fallback={\n <FieldLabel label={label} localized={localized} path={path} required={required} />\n }\n />\n <div className={`${fieldBaseClass}__wrap`}>\n <RenderCustomComponent\n CustomComponent={Error}\n Fallback={<FieldError path={path} showError={showError} />}\n />\n {BeforeInput}\n {!errorLoading && (\n <div className={`${baseClass}__wrap`}>\n <ReactSelect\n backspaceRemovesValue={!(isDrawerOpen || isListDrawerOpen)}\n components={{\n MultiValueLabel,\n SingleValue,\n ...(appearance !== 'select' && { DropdownIndicator: null }),\n }}\n customProps={{\n disableKeyDown: isDrawerOpen || isListDrawerOpen,\n disableMouseDown: isDrawerOpen || isListDrawerOpen,\n onDocumentDrawerOpen,\n onSave,\n }}\n disabled={readOnly || disabled || isDrawerOpen || isListDrawerOpen}\n filterOption={enableWordBoundarySearch ? filterOption : undefined}\n getOptionValue={(option) => {\n if (!option) {\n return undefined\n }\n return hasMany && Array.isArray(relationTo)\n ? `${option.relationTo}_${option.value}`\n : (option.value as string)\n }}\n isLoading={appearance === 'select' && isLoading}\n isMulti={hasMany}\n isSearchable={appearance === 'select'}\n isSortable={isSortable}\n menuIsOpen={appearance === 'select' ? menuIsOpen : false}\n onChange={\n !(readOnly || disabled)\n ? (selected) => {\n if (selected === null) {\n setValue(hasMany ? [] : null)\n } else if (hasMany && Array.isArray(selected)) {\n setValue(\n selected\n ? selected.map((option) => {\n if (hasMultipleRelations) {\n return {\n relationTo: option.relationTo,\n value: option.value,\n }\n }\n\n return option.value\n })\n : null,\n )\n } else if (hasMultipleRelations && !Array.isArray(selected)) {\n setValue({\n relationTo: selected.relationTo,\n value: selected.value,\n })\n } else if (!Array.isArray(selected)) {\n setValue(selected.value)\n }\n }\n : undefined\n }\n onInputChange={(newSearch) => handleInputChange(newSearch, value)}\n onMenuClose={() => {\n setMenuIsOpen(false)\n }}\n onMenuOpen={() => {\n if (appearance === 'drawer') {\n openListDrawer()\n } else if (appearance === 'select') {\n setMenuIsOpen(true)\n if (!hasLoadedFirstPageRef.current) {\n setIsLoading(true)\n void getResults({\n filterOptions,\n lastLoadedPage: {},\n onSuccess: () => {\n hasLoadedFirstPageRef.current = true\n setIsLoading(false)\n },\n value: initialValue,\n })\n }\n }\n }}\n onMenuScrollToBottom={() => {\n void getResults({\n filterOptions,\n lastFullyLoadedRelation,\n lastLoadedPage,\n search,\n sort: false,\n value: initialValue,\n })\n }}\n options={options}\n showError={showError}\n value={valueToRender ?? null}\n />\n {!(readOnly || disabled) && allowCreate && (\n <AddNewRelation\n hasMany={hasMany}\n path={path}\n relationTo={relationTo}\n setValue={setValue}\n value={value}\n />\n )}\n </div>\n )}\n {errorLoading && <div className={`${baseClass}__error-loading`}>{errorLoading}</div>}\n {AfterInput}\n <RenderCustomComponent\n CustomComponent={Description}\n Fallback={<FieldDescription description={description} path={path} />}\n />\n </div>\n {currentlyOpenRelationship.collectionSlug && currentlyOpenRelationship.hasReadPermission && (\n <DocumentDrawer onDelete={onDelete} onDuplicate={onDuplicate} onSave={onSave} />\n )}\n {appearance === 'drawer' && !readOnly && (\n <ListDrawer allowCreate={allowCreate} enableRowSelections={false} onSelect={onListSelect} />\n )}\n </div>\n )\n}\n\nexport const RelationshipField = withCondition(RelationshipFieldComponent)\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/fields/Select/index.tsx"],"names":[],"mappings":"AAQA,OAAO,KAA+B,MAAM,OAAO,CAAA;AAGnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAKlD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/fields/Select/index.tsx"],"names":[],"mappings":"AAQA,OAAO,KAA+B,MAAM,OAAO,CAAA;AAGnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAKlD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAiHxC,eAAO,MAAM,WAAW;;;;;;;+EAAsC,CAAA;AAE9D,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,CAAA"}
|
|
@@ -33,7 +33,7 @@ const SelectFieldComponent = props => {
|
|
|
33
33
|
required
|
|
34
34
|
},
|
|
35
35
|
onChange: onChangeFromProps,
|
|
36
|
-
path,
|
|
36
|
+
path: pathFromProps,
|
|
37
37
|
readOnly,
|
|
38
38
|
validate
|
|
39
39
|
} = props;
|
|
@@ -57,11 +57,12 @@ const SelectFieldComponent = props => {
|
|
|
57
57
|
Label
|
|
58
58
|
} = {},
|
|
59
59
|
disabled,
|
|
60
|
+
path,
|
|
60
61
|
setValue,
|
|
61
62
|
showError,
|
|
62
63
|
value: value_0
|
|
63
64
|
} = useField({
|
|
64
|
-
|
|
65
|
+
potentiallyStalePath: pathFromProps,
|
|
65
66
|
validate: memoizedValidate
|
|
66
67
|
});
|
|
67
68
|
const onChange = useCallback(selectedOption => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","names":["React","useCallback","useMemo","useField","withCondition","mergeFieldStyles","SelectInput","formatOptions","options","map","option","value","label","SelectFieldComponent","props","field","name","admin","className","description","isClearable","isSortable","hasMany","localized","optionsFromProps","required","onChange","onChangeFromProps","path","readOnly","validate","memoizedValidate","validationOptions","customComponents","AfterInput","BeforeInput","Description","Error","Label","disabled","setValue","showError","selectedOption","newValue","Array","isArray","styles","_jsx","style","SelectField"],"sources":["../../../src/fields/Select/index.tsx"],"sourcesContent":["'use client'\nimport type {\n Option,\n OptionObject,\n SelectFieldClientComponent,\n SelectFieldClientProps,\n} from 'payload'\n\nimport React, { useCallback, useMemo } from 'react'\n\nimport type { ReactSelectAdapterProps } from '../../elements/ReactSelect/types.js'\nimport type { SelectInputProps } from './Input.js'\n\nimport { useField } from '../../forms/useField/index.js'\nimport { withCondition } from '../../forms/withCondition/index.js'\nimport { mergeFieldStyles } from '../mergeFieldStyles.js'\nimport { SelectInput } from './Input.js'\n\nconst formatOptions = (options: Option[]): OptionObject[] =>\n options.map((option) => {\n if (typeof option === 'object' && (option.value || option.value === '')) {\n return option\n }\n\n return {\n label: option,\n value: option,\n } as OptionObject\n })\n\nconst SelectFieldComponent: SelectFieldClientComponent = (props) => {\n const {\n field,\n field: {\n name,\n admin: {\n className,\n description,\n isClearable = true,\n isSortable = true,\n } = {} as SelectFieldClientProps['field']['admin'],\n hasMany = false,\n label,\n localized,\n options: optionsFromProps = [],\n required,\n },\n onChange: onChangeFromProps,\n path,\n readOnly,\n validate,\n } = props\n\n const options = React.useMemo(() => formatOptions(optionsFromProps), [optionsFromProps])\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, { ...validationOptions, hasMany, options, required })\n }\n },\n [validate, required, hasMany, options],\n )\n\n const {\n customComponents: { AfterInput, BeforeInput, Description, Error, Label } = {},\n disabled,\n setValue,\n showError,\n value,\n } = useField({\n
|
|
1
|
+
{"version":3,"file":"index.js","names":["React","useCallback","useMemo","useField","withCondition","mergeFieldStyles","SelectInput","formatOptions","options","map","option","value","label","SelectFieldComponent","props","field","name","admin","className","description","isClearable","isSortable","hasMany","localized","optionsFromProps","required","onChange","onChangeFromProps","path","pathFromProps","readOnly","validate","memoizedValidate","validationOptions","customComponents","AfterInput","BeforeInput","Description","Error","Label","disabled","setValue","showError","potentiallyStalePath","selectedOption","newValue","Array","isArray","styles","_jsx","style","SelectField"],"sources":["../../../src/fields/Select/index.tsx"],"sourcesContent":["'use client'\nimport type {\n Option,\n OptionObject,\n SelectFieldClientComponent,\n SelectFieldClientProps,\n} from 'payload'\n\nimport React, { useCallback, useMemo } from 'react'\n\nimport type { ReactSelectAdapterProps } from '../../elements/ReactSelect/types.js'\nimport type { SelectInputProps } from './Input.js'\n\nimport { useField } from '../../forms/useField/index.js'\nimport { withCondition } from '../../forms/withCondition/index.js'\nimport { mergeFieldStyles } from '../mergeFieldStyles.js'\nimport { SelectInput } from './Input.js'\n\nconst formatOptions = (options: Option[]): OptionObject[] =>\n options.map((option) => {\n if (typeof option === 'object' && (option.value || option.value === '')) {\n return option\n }\n\n return {\n label: option,\n value: option,\n } as OptionObject\n })\n\nconst SelectFieldComponent: SelectFieldClientComponent = (props) => {\n const {\n field,\n field: {\n name,\n admin: {\n className,\n description,\n isClearable = true,\n isSortable = true,\n } = {} as SelectFieldClientProps['field']['admin'],\n hasMany = false,\n label,\n localized,\n options: optionsFromProps = [],\n required,\n },\n onChange: onChangeFromProps,\n path: pathFromProps,\n readOnly,\n validate,\n } = props\n\n const options = React.useMemo(() => formatOptions(optionsFromProps), [optionsFromProps])\n\n const memoizedValidate = useCallback(\n (value, validationOptions) => {\n if (typeof validate === 'function') {\n return validate(value, { ...validationOptions, hasMany, options, required })\n }\n },\n [validate, required, hasMany, options],\n )\n\n const {\n customComponents: { AfterInput, BeforeInput, Description, Error, Label } = {},\n disabled,\n path,\n setValue,\n showError,\n value,\n } = useField({\n potentiallyStalePath: pathFromProps,\n validate: memoizedValidate,\n })\n\n const onChange: ReactSelectAdapterProps['onChange'] = useCallback(\n (selectedOption: OptionObject | OptionObject[]) => {\n if (!readOnly || disabled) {\n let newValue: string | string[] = null\n if (selectedOption && hasMany) {\n if (Array.isArray(selectedOption)) {\n newValue = selectedOption.map((option) => option.value)\n } else {\n newValue = []\n }\n } else if (selectedOption && !Array.isArray(selectedOption)) {\n newValue = selectedOption.value\n }\n\n if (typeof onChangeFromProps === 'function') {\n onChangeFromProps(newValue)\n }\n\n setValue(newValue)\n }\n },\n [readOnly, disabled, hasMany, setValue, onChangeFromProps],\n )\n\n const styles = useMemo(() => mergeFieldStyles(field), [field])\n\n return (\n <SelectInput\n AfterInput={AfterInput}\n BeforeInput={BeforeInput}\n className={className}\n Description={Description}\n description={description}\n Error={Error}\n hasMany={hasMany}\n isClearable={isClearable}\n isSortable={isSortable}\n Label={Label}\n label={label}\n localized={localized}\n name={name}\n onChange={onChange}\n options={options}\n path={path}\n readOnly={readOnly || disabled}\n required={required}\n showError={showError}\n style={styles}\n value={value as string | string[]}\n />\n )\n}\n\nexport const SelectField = withCondition(SelectFieldComponent)\n\nexport { SelectInput, type SelectInputProps }\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -406,7 +406,7 @@ const TabsFieldComponent = props => {
|
|
|
406
406
|
};
|
|
407
407
|
export const TabsField = withCondition(TabsFieldComponent);
|
|
408
408
|
function TabContent(t0) {
|
|
409
|
-
const $ = _c(
|
|
409
|
+
const $ = _c(19);
|
|
410
410
|
const {
|
|
411
411
|
description,
|
|
412
412
|
fields,
|
|
@@ -416,59 +416,49 @@ function TabContent(t0) {
|
|
|
416
416
|
parentIndexPath,
|
|
417
417
|
parentPath,
|
|
418
418
|
parentSchemaPath,
|
|
419
|
-
path,
|
|
420
419
|
permissions,
|
|
421
420
|
readOnly
|
|
422
421
|
} = t0;
|
|
423
422
|
const {
|
|
424
423
|
i18n
|
|
425
424
|
} = useTranslation();
|
|
426
|
-
let t1;
|
|
427
|
-
if ($[0] !== path) {
|
|
428
|
-
t1 = {
|
|
429
|
-
path
|
|
430
|
-
};
|
|
431
|
-
$[0] = path;
|
|
432
|
-
$[1] = t1;
|
|
433
|
-
} else {
|
|
434
|
-
t1 = $[1];
|
|
435
|
-
}
|
|
436
425
|
const {
|
|
437
|
-
customComponents:
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
$[
|
|
426
|
+
customComponents: t1,
|
|
427
|
+
path
|
|
428
|
+
} = useField();
|
|
429
|
+
let t2;
|
|
430
|
+
if ($[0] !== t1) {
|
|
431
|
+
t2 = t1 === undefined ? {} : t1;
|
|
432
|
+
$[0] = t1;
|
|
433
|
+
$[1] = t2;
|
|
444
434
|
} else {
|
|
445
|
-
|
|
435
|
+
t2 = $[1];
|
|
446
436
|
}
|
|
447
437
|
const {
|
|
448
438
|
AfterInput,
|
|
449
439
|
BeforeInput,
|
|
450
440
|
Description,
|
|
451
441
|
Field
|
|
452
|
-
} =
|
|
442
|
+
} = t2;
|
|
453
443
|
if (Field) {
|
|
454
444
|
return Field;
|
|
455
445
|
}
|
|
456
|
-
const
|
|
457
|
-
const
|
|
458
|
-
let
|
|
459
|
-
if ($[
|
|
460
|
-
|
|
461
|
-
$[
|
|
462
|
-
$[
|
|
463
|
-
$[
|
|
446
|
+
const t3 = hidden && `${baseClass}__tab--hidden`;
|
|
447
|
+
const t4 = label && `${baseClass}__tabConfigLabel-${toKebabCase(getTranslation(label, i18n))}`;
|
|
448
|
+
let t5;
|
|
449
|
+
if ($[2] !== t3 || $[3] !== t4) {
|
|
450
|
+
t5 = [t3, `${baseClass}__tab`, t4].filter(Boolean);
|
|
451
|
+
$[2] = t3;
|
|
452
|
+
$[3] = t4;
|
|
453
|
+
$[4] = t5;
|
|
464
454
|
} else {
|
|
465
|
-
|
|
455
|
+
t5 = $[4];
|
|
466
456
|
}
|
|
467
|
-
const
|
|
468
|
-
let
|
|
469
|
-
if ($[
|
|
470
|
-
|
|
471
|
-
className:
|
|
457
|
+
const t6 = t5.join(" ");
|
|
458
|
+
let t7;
|
|
459
|
+
if ($[5] !== AfterInput || $[6] !== BeforeInput || $[7] !== Description || $[8] !== description || $[9] !== fields || $[10] !== forceRender || $[11] !== parentIndexPath || $[12] !== parentPath || $[13] !== parentSchemaPath || $[14] !== path || $[15] !== permissions || $[16] !== readOnly || $[17] !== t6) {
|
|
460
|
+
t7 = _jsxs("div", {
|
|
461
|
+
className: t6,
|
|
472
462
|
children: [_jsx(RenderCustomComponent, {
|
|
473
463
|
CustomComponent: Description,
|
|
474
464
|
Fallback: _jsx(FieldDescription, {
|
|
@@ -486,24 +476,24 @@ function TabContent(t0) {
|
|
|
486
476
|
readOnly
|
|
487
477
|
}), AfterInput]
|
|
488
478
|
});
|
|
489
|
-
$[
|
|
490
|
-
$[
|
|
491
|
-
$[
|
|
492
|
-
$[
|
|
493
|
-
$[
|
|
494
|
-
$[
|
|
495
|
-
$[
|
|
496
|
-
$[
|
|
497
|
-
$[
|
|
498
|
-
$[
|
|
499
|
-
$[
|
|
500
|
-
$[
|
|
501
|
-
$[
|
|
502
|
-
$[
|
|
479
|
+
$[5] = AfterInput;
|
|
480
|
+
$[6] = BeforeInput;
|
|
481
|
+
$[7] = Description;
|
|
482
|
+
$[8] = description;
|
|
483
|
+
$[9] = fields;
|
|
484
|
+
$[10] = forceRender;
|
|
485
|
+
$[11] = parentIndexPath;
|
|
486
|
+
$[12] = parentPath;
|
|
487
|
+
$[13] = parentSchemaPath;
|
|
488
|
+
$[14] = path;
|
|
489
|
+
$[15] = permissions;
|
|
490
|
+
$[16] = readOnly;
|
|
491
|
+
$[17] = t6;
|
|
492
|
+
$[18] = t7;
|
|
503
493
|
} else {
|
|
504
|
-
|
|
494
|
+
t7 = $[18];
|
|
505
495
|
}
|
|
506
|
-
return
|
|
496
|
+
return t7;
|
|
507
497
|
}
|
|
508
498
|
function _temp(t0) {
|
|
509
499
|
const {
|