@economic/taco 2.47.0-server.10 → 2.47.0-server.11
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js +11 -3
- package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js.map +1 -1
- package/dist/esm/packages/taco/src/components/Table3/features/useEditingState.js +3 -2
- package/dist/esm/packages/taco/src/components/Table3/features/useEditingState.js.map +1 -1
- package/dist/esm/packages/taco/src/utils/dom.js +3 -0
- package/dist/esm/packages/taco/src/utils/dom.js.map +1 -1
- package/dist/taco.cjs.development.js +17 -5
- package/dist/taco.cjs.development.js.map +1 -1
- package/dist/taco.cjs.production.min.js +1 -1
- package/dist/taco.cjs.production.min.js.map +1 -1
- package/package.json +1 -1
package/dist/esm/packages/taco/src/components/Table3/components/Columns/Cell/EditingControlCell.js
CHANGED
@@ -40,20 +40,28 @@ function EditingControlCell(props) {
|
|
40
40
|
if (nextValue !== value) {
|
41
41
|
tableMeta.editing.setCellValue(cell, rowIndex, nextValue);
|
42
42
|
if (hasNonTextControl) {
|
43
|
-
|
43
|
+
requestAnimationFrame(function () {
|
44
|
+
return tableMeta.editing.onCellChanged(cell, rowIndex, nextValue);
|
45
|
+
});
|
44
46
|
}
|
45
47
|
}
|
46
48
|
};
|
47
|
-
|
49
|
+
function blur() {
|
48
50
|
tableMeta.editing.toggleDetailedMode(false);
|
49
51
|
tableMeta.editing.onCellChanged(cell, rowIndex, undefined, !hasNonTextControl);
|
52
|
+
}
|
53
|
+
var handleBlur = function handleBlur(event) {
|
54
|
+
if (isElementInsideOrTriggeredFromContainer(event.relatedTarget, event.currentTarget)) {
|
55
|
+
return;
|
56
|
+
}
|
57
|
+
blur();
|
50
58
|
};
|
51
59
|
// ensure that blur runs when the cell gets unmounted (when vertically arrow key navigating)
|
52
60
|
React__default.useEffect(function () {
|
53
61
|
var ref = cellRef.current;
|
54
62
|
return function () {
|
55
63
|
if (document.activeElement === ref || isElementInsideOrTriggeredFromContainer(document.activeElement, ref)) {
|
56
|
-
|
64
|
+
blur();
|
57
65
|
}
|
58
66
|
};
|
59
67
|
}, []);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"EditingControlCell.js","sources":["../../../../../../../../../../src/components/Table3/components/Columns/Cell/EditingControlCell.tsx"],"sourcesContent":["import React from 'react';\nimport { TableMeta as ReactTableMeta, ColumnMeta as ReactTableColumnMeta } from '@tanstack/react-table';\nimport { isDate } from 'date-fns';\nimport { Datepicker } from '../../../../Datepicker/Datepicker';\nimport { Switch } from '../../../../Switch/Switch';\nimport { Input } from '../../../../Input/Input';\nimport { TableColumnDataType, TableColumnRendererControl, TableFontSize } from '../../../../../primitives/Table/types';\nimport * as date from '../../../../../utils/date';\nimport { RowMoveIndicator } from './Editing/RowMoveIndicator';\nimport { TextareaWithAutosizing } from './Editing/TextareaWithAutosizing';\nimport { Field } from '../../../../Field/Field';\nimport { isElementInsideOrTriggeredFromContainer } from '../../../../../utils/dom';\nimport { TableCellRendererProps } from '../../../../../primitives/Table/Core/types';\nimport { RowContext } from '../../../../../primitives/Table/Core/components/Row/RowContext';\nimport { getCellAttributes } from '../../../../../primitives/Table/Core/components/Columns/Cell/util';\nimport { useEditingCellAutofocus } from './util';\nimport { isPressingMetaKey } from '../../../../../utils/keyboard';\nimport { Checkbox } from '../../../../Checkbox/Checkbox';\n\nexport function EditingControlCell<TType = unknown>(props: TableCellRendererProps<TType>) {\n const { cell, cellRef, isHighlighted, index } = props;\n const { rowIndex } = React.useContext(RowContext);\n const { table } = cell.getContext();\n const tableMeta = table.options.meta as ReactTableMeta<TType>;\n const columnMeta = cell.column.columnDef.meta as ReactTableColumnMeta<TType, unknown>;\n const isActiveRow = tableMeta.rowActive.rowActiveIndex === rowIndex;\n const type = columnMeta.control ?? 'input';\n const handleFocus = useEditingCellAutofocus<TType>(props);\n const value = cell.getValue();\n\n // some controls, like select2, should trigger cell changed (validation, updates) as the value changes\n const hasNonTextControl = React.useMemo(() => {\n return (\n typeof type === 'function' &&\n !!cellRef.current?.querySelector('[data-taco=\"Select2\"],[data-taco=\"switch\"],[data-taco=\"checkbox\"]')\n );\n }, [cellRef.current]);\n\n const handleChange = (nextValue: unknown) => {\n if (nextValue !== value) {\n tableMeta.editing.setCellValue(cell, rowIndex, nextValue);\n\n if (hasNonTextControl) {\n tableMeta.editing.onCellChanged(cell, rowIndex, nextValue);\n }\n }\n };\n\n const handleBlur = () => {\n tableMeta.editing.toggleDetailedMode(false);\n tableMeta.editing.onCellChanged(cell, rowIndex, undefined, !hasNonTextControl);\n };\n\n // ensure that blur runs when the cell gets unmounted (when vertically arrow key navigating)\n React.useEffect(() => {\n const ref = cellRef.current;\n\n return () => {\n if (document.activeElement === ref || isElementInsideOrTriggeredFromContainer(document.activeElement, ref)) {\n handleBlur();\n }\n };\n }, []);\n\n const error = tableMeta.editing.getCellError<TType>(cell);\n\n const controlProps = {\n dataType: columnMeta.dataType,\n fontSize: tableMeta.fontSize.size,\n id: cell.column.id,\n invalid: !!error,\n isDetailedMode: tableMeta.editing.isDetailedMode,\n isTruncated: !!columnMeta.enableTruncate,\n onBlur: handleBlur,\n onChange: handleChange,\n row: cell.row.original,\n rowPendingChanges: tableMeta.editing.getRowValue(cell.row.id),\n tabIndex: isActiveRow ? 0 : -1,\n toggleDetailedMode: tableMeta.editing.toggleDetailedMode,\n type,\n value,\n };\n\n const cellAttributes = {\n ...getCellAttributes(cell, index, isHighlighted),\n 'data-cell-editing-invalid': error ? true : undefined,\n 'data-taco': 'cell-control',\n onFocus: handleFocus,\n ref: cellRef,\n tabIndex: -1,\n };\n\n return (\n <td {...cellAttributes}>\n <Field invalid={!!error} message={error}>\n <MemoedEditingCell<TType> {...controlProps} />\n </Field>\n {\n // we show row move indicator here within the cell rather than the row because it is\n // an editing only feature, and we don't want to leak editing into the shared row component\n }\n <RowMoveIndicator cell={cell} cellRef={cellRef} isActiveRow={isActiveRow} />\n </td>\n );\n}\n\ntype MemoedEditingCellProps<TType = unknown, TValue = unknown> = {\n dataType?: TableColumnDataType;\n fontSize: TableFontSize;\n id: string;\n invalid: boolean;\n isDetailedMode: boolean;\n isTruncated: boolean;\n onBlur: () => void;\n onChange: (value: TValue) => void;\n row: TType;\n rowPendingChanges: Partial<TType> | undefined;\n tabIndex?: number;\n toggleDetailedMode: (detailed: React.SetStateAction<boolean>) => void;\n type: TableColumnRendererControl<TType>;\n value: TValue;\n};\n\nconst MemoedEditingCell = React.memo(function MemoedEditingCell<TType = unknown>(props: MemoedEditingCellProps<TType>) {\n const {\n dataType,\n fontSize,\n id,\n invalid,\n isDetailedMode,\n isTruncated,\n onBlur,\n onChange,\n row,\n rowPendingChanges,\n tabIndex = -1,\n toggleDetailedMode,\n type = 'input',\n value,\n } = props;\n const controlRef = React.useRef<HTMLElement>(null);\n const currentValue = row[id];\n const commonProps = {\n onBlur,\n ref: controlRef,\n tabIndex,\n };\n\n if (typeof type === 'function') {\n const controlFnProps = {\n ...commonProps,\n invalid,\n setValue: onChange,\n value,\n };\n\n return type(controlFnProps, { ...row, ...rowPendingChanges });\n }\n\n if (type === 'switch') {\n return (\n <Switch\n {...commonProps}\n checked={Boolean(value)}\n onChange={onChange}\n ref={controlRef as React.RefObject<HTMLButtonElement>}\n />\n );\n }\n\n if (type === 'checkbox') {\n return (\n <Checkbox\n {...commonProps}\n checked={Boolean(value)}\n onChange={onChange}\n ref={controlRef as React.RefObject<HTMLButtonElement>}\n />\n );\n }\n\n const handleInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n const target = event.target as HTMLInputElement | HTMLTextAreaElement;\n\n if (target.readOnly) {\n return;\n }\n\n // prevent active row navigation while in detailed mode\n if (\n isDetailedMode &&\n (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'ArrowLeft' || event.key === 'ArrowRight')\n ) {\n event.stopPropagation();\n }\n\n // enter or exit detail mode when pressing enter\n if (event.key === 'Enter') {\n // textareas support shift and enter, don't prevent default in that case\n if (event.shiftKey && isDetailedMode) {\n return;\n }\n\n event.preventDefault();\n\n if (isDetailedMode) {\n target.select?.();\n } else {\n target.setSelectionRange?.(target.value?.length, target.value?.length);\n }\n\n toggleDetailedMode(editing => !editing);\n return;\n }\n\n // reset the value, or exit edit mode when pressing escape\n if (event.key === 'Escape') {\n if (isDetailedMode) {\n event.preventDefault();\n toggleDetailedMode(false);\n\n if (value !== currentValue) {\n props.onChange(currentValue);\n }\n\n // have to let onChange run before selecting, otherwise the value changes\n requestAnimationFrame(() => target.select?.());\n }\n\n return;\n }\n\n // toggle into detailed mode when actually inputting something\n if (!isPressingMetaKey(event) && (/^[a-z0-9]$/i.test(event.key) || event.key === 'Backspace')) {\n toggleDetailedMode(true);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n if (!isDetailedMode) {\n event.target.select();\n }\n };\n\n if (type === 'datepicker') {\n const valueAsDate = date.parse(value as Date | string | undefined);\n\n const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n const newDate = (event as any).detail as Date;\n\n if (!valueAsDate || !newDate || (isDate(valueAsDate) && isDate(newDate) && !date.isWeakEqual(valueAsDate, newDate))) {\n props.onChange(newDate);\n }\n };\n\n return (\n <Datepicker\n {...commonProps}\n invalid={invalid}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLInputElement>}\n value={valueAsDate}\n />\n );\n }\n\n if (type === 'textarea') {\n const handleChange = (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n onChange(event.target.value);\n };\n\n return (\n <TextareaWithAutosizing\n {...commonProps}\n fontSize={fontSize}\n invalid={invalid}\n isTruncated={isTruncated}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLTextAreaElement>}\n value={String(value ?? '')}\n />\n );\n }\n\n const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n onChange(dataType === 'number' && event.target.value ? Number.parseInt(event.target.value) : event.target.value);\n };\n\n return (\n <Input\n {...commonProps}\n invalid={invalid}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLInputElement>}\n type={dataType === 'number' ? 'number' : undefined}\n value={dataType === 'number' ? (value as number) : String(value ?? '')}\n />\n );\n}) as <TType = unknown>(props: MemoedEditingCellProps<TType>) => JSX.Element;\n"],"names":["EditingControlCell","props","cell","cellRef","isHighlighted","index","_React$useContext","React","useContext","RowContext","rowIndex","_cell$getContext","getContext","table","tableMeta","options","meta","columnMeta","column","columnDef","isActiveRow","rowActive","rowActiveIndex","type","_columnMeta$control","control","handleFocus","useEditingCellAutofocus","value","getValue","hasNonTextControl","useMemo","_cellRef$current","current","querySelector","handleChange","nextValue","editing","setCellValue","onCellChanged","handleBlur","toggleDetailedMode","undefined","useEffect","ref","document","activeElement","isElementInsideOrTriggeredFromContainer","error","getCellError","controlProps","dataType","fontSize","size","id","invalid","isDetailedMode","isTruncated","enableTruncate","onBlur","onChange","row","original","rowPendingChanges","getRowValue","tabIndex","cellAttributes","_extends","getCellAttributes","onFocus","Field","message","MemoedEditingCell","RowMoveIndicator","memo","_props$tabIndex","_props$type","controlRef","useRef","currentValue","commonProps","controlFnProps","setValue","Switch","checked","Boolean","Checkbox","handleInputKeyDown","event","target","readOnly","key","stopPropagation","shiftKey","preventDefault","_target$select","select","call","_target$setSelectionR","_target$value","_target$value2","setSelectionRange","length","requestAnimationFrame","_target$select2","isPressingMetaKey","test","valueAsDate","date","newDate","detail","isDate","Datepicker","onKeyDown","TextareaWithAutosizing","String","Number","parseInt","Input"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"EditingControlCell.js","sources":["../../../../../../../../../../src/components/Table3/components/Columns/Cell/EditingControlCell.tsx"],"sourcesContent":["import React from 'react';\nimport { TableMeta as ReactTableMeta, ColumnMeta as ReactTableColumnMeta } from '@tanstack/react-table';\nimport { isDate } from 'date-fns';\nimport { Datepicker } from '../../../../Datepicker/Datepicker';\nimport { Switch } from '../../../../Switch/Switch';\nimport { Input } from '../../../../Input/Input';\nimport { TableColumnDataType, TableColumnRendererControl, TableFontSize } from '../../../../../primitives/Table/types';\nimport * as date from '../../../../../utils/date';\nimport { RowMoveIndicator } from './Editing/RowMoveIndicator';\nimport { TextareaWithAutosizing } from './Editing/TextareaWithAutosizing';\nimport { Field } from '../../../../Field/Field';\nimport { isElementInsideOrTriggeredFromContainer } from '../../../../../utils/dom';\nimport { TableCellRendererProps } from '../../../../../primitives/Table/Core/types';\nimport { RowContext } from '../../../../../primitives/Table/Core/components/Row/RowContext';\nimport { getCellAttributes } from '../../../../../primitives/Table/Core/components/Columns/Cell/util';\nimport { useEditingCellAutofocus } from './util';\nimport { isPressingMetaKey } from '../../../../../utils/keyboard';\nimport { Checkbox } from '../../../../Checkbox/Checkbox';\n\nexport function EditingControlCell<TType = unknown>(props: TableCellRendererProps<TType>) {\n const { cell, cellRef, isHighlighted, index } = props;\n const { rowIndex } = React.useContext(RowContext);\n const { table } = cell.getContext();\n const tableMeta = table.options.meta as ReactTableMeta<TType>;\n const columnMeta = cell.column.columnDef.meta as ReactTableColumnMeta<TType, unknown>;\n const isActiveRow = tableMeta.rowActive.rowActiveIndex === rowIndex;\n const type = columnMeta.control ?? 'input';\n const handleFocus = useEditingCellAutofocus<TType>(props);\n const value = cell.getValue();\n\n // some controls, like select2, should trigger cell changed (validation, updates) as the value changes\n const hasNonTextControl = React.useMemo(() => {\n return (\n typeof type === 'function' &&\n !!cellRef.current?.querySelector('[data-taco=\"Select2\"],[data-taco=\"switch\"],[data-taco=\"checkbox\"]')\n );\n }, [cellRef.current]);\n\n const handleChange = (nextValue: unknown) => {\n if (nextValue !== value) {\n tableMeta.editing.setCellValue(cell, rowIndex, nextValue);\n\n if (hasNonTextControl) {\n requestAnimationFrame(() => tableMeta.editing.onCellChanged(cell, rowIndex, nextValue));\n }\n }\n };\n\n function blur() {\n tableMeta.editing.toggleDetailedMode(false);\n tableMeta.editing.onCellChanged(cell, rowIndex, undefined, !hasNonTextControl);\n }\n\n const handleBlur = (event: React.FocusEvent) => {\n if (isElementInsideOrTriggeredFromContainer(event.relatedTarget, event.currentTarget)) {\n return;\n }\n blur();\n };\n\n // ensure that blur runs when the cell gets unmounted (when vertically arrow key navigating)\n React.useEffect(() => {\n const ref = cellRef.current;\n\n return () => {\n if (document.activeElement === ref || isElementInsideOrTriggeredFromContainer(document.activeElement, ref)) {\n blur();\n }\n };\n }, []);\n\n const error = tableMeta.editing.getCellError<TType>(cell);\n\n const controlProps = {\n dataType: columnMeta.dataType,\n fontSize: tableMeta.fontSize.size,\n id: cell.column.id,\n invalid: !!error,\n isDetailedMode: tableMeta.editing.isDetailedMode,\n isTruncated: !!columnMeta.enableTruncate,\n onBlur: handleBlur,\n onChange: handleChange,\n row: cell.row.original,\n rowPendingChanges: tableMeta.editing.getRowValue(cell.row.id),\n tabIndex: isActiveRow ? 0 : -1,\n toggleDetailedMode: tableMeta.editing.toggleDetailedMode,\n type,\n value,\n };\n\n const cellAttributes = {\n ...getCellAttributes(cell, index, isHighlighted),\n 'data-cell-editing-invalid': error ? true : undefined,\n 'data-taco': 'cell-control',\n onFocus: handleFocus,\n ref: cellRef,\n tabIndex: -1,\n };\n\n return (\n <td {...cellAttributes}>\n <Field invalid={!!error} message={error}>\n <MemoedEditingCell<TType> {...controlProps} />\n </Field>\n {\n // we show row move indicator here within the cell rather than the row because it is\n // an editing only feature, and we don't want to leak editing into the shared row component\n }\n <RowMoveIndicator cell={cell} cellRef={cellRef} isActiveRow={isActiveRow} />\n </td>\n );\n}\n\ntype MemoedEditingCellProps<TType = unknown, TValue = unknown> = {\n dataType?: TableColumnDataType;\n fontSize: TableFontSize;\n id: string;\n invalid: boolean;\n isDetailedMode: boolean;\n isTruncated: boolean;\n onBlur: (event: React.FocusEvent) => void;\n onChange: (value: TValue) => void;\n row: TType;\n rowPendingChanges: Partial<TType> | undefined;\n tabIndex?: number;\n toggleDetailedMode: (detailed: React.SetStateAction<boolean>) => void;\n type: TableColumnRendererControl<TType>;\n value: TValue;\n};\n\nconst MemoedEditingCell = React.memo(function MemoedEditingCell<TType = unknown>(props: MemoedEditingCellProps<TType>) {\n const {\n dataType,\n fontSize,\n id,\n invalid,\n isDetailedMode,\n isTruncated,\n onBlur,\n onChange,\n row,\n rowPendingChanges,\n tabIndex = -1,\n toggleDetailedMode,\n type = 'input',\n value,\n } = props;\n const controlRef = React.useRef<HTMLElement>(null);\n const currentValue = row[id];\n const commonProps = {\n onBlur,\n ref: controlRef,\n tabIndex,\n };\n\n if (typeof type === 'function') {\n const controlFnProps = {\n ...commonProps,\n invalid,\n setValue: onChange,\n value,\n };\n\n return type(controlFnProps, { ...row, ...rowPendingChanges });\n }\n\n if (type === 'switch') {\n return (\n <Switch\n {...commonProps}\n checked={Boolean(value)}\n onChange={onChange}\n ref={controlRef as React.RefObject<HTMLButtonElement>}\n />\n );\n }\n\n if (type === 'checkbox') {\n return (\n <Checkbox\n {...commonProps}\n checked={Boolean(value)}\n onChange={onChange}\n ref={controlRef as React.RefObject<HTMLButtonElement>}\n />\n );\n }\n\n const handleInputKeyDown = (event: React.KeyboardEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n const target = event.target as HTMLInputElement | HTMLTextAreaElement;\n\n if (target.readOnly) {\n return;\n }\n\n // prevent active row navigation while in detailed mode\n if (\n isDetailedMode &&\n (event.key === 'ArrowUp' || event.key === 'ArrowDown' || event.key === 'ArrowLeft' || event.key === 'ArrowRight')\n ) {\n event.stopPropagation();\n }\n\n // enter or exit detail mode when pressing enter\n if (event.key === 'Enter') {\n // textareas support shift and enter, don't prevent default in that case\n if (event.shiftKey && isDetailedMode) {\n return;\n }\n\n event.preventDefault();\n\n if (isDetailedMode) {\n target.select?.();\n } else {\n target.setSelectionRange?.(target.value?.length, target.value?.length);\n }\n\n toggleDetailedMode(editing => !editing);\n return;\n }\n\n // reset the value, or exit edit mode when pressing escape\n if (event.key === 'Escape') {\n if (isDetailedMode) {\n event.preventDefault();\n toggleDetailedMode(false);\n\n if (value !== currentValue) {\n props.onChange(currentValue);\n }\n\n // have to let onChange run before selecting, otherwise the value changes\n requestAnimationFrame(() => target.select?.());\n }\n\n return;\n }\n\n // toggle into detailed mode when actually inputting something\n if (!isPressingMetaKey(event) && (/^[a-z0-9]$/i.test(event.key) || event.key === 'Backspace')) {\n toggleDetailedMode(true);\n }\n };\n\n const handleFocus = (event: React.FocusEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n if (!isDetailedMode) {\n event.target.select();\n }\n };\n\n if (type === 'datepicker') {\n const valueAsDate = date.parse(value as Date | string | undefined);\n\n const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n const newDate = (event as any).detail as Date;\n\n if (!valueAsDate || !newDate || (isDate(valueAsDate) && isDate(newDate) && !date.isWeakEqual(valueAsDate, newDate))) {\n props.onChange(newDate);\n }\n };\n\n return (\n <Datepicker\n {...commonProps}\n invalid={invalid}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLInputElement>}\n value={valueAsDate}\n />\n );\n }\n\n if (type === 'textarea') {\n const handleChange = (event: React.ChangeEvent<HTMLTextAreaElement>) => {\n onChange(event.target.value);\n };\n\n return (\n <TextareaWithAutosizing\n {...commonProps}\n fontSize={fontSize}\n invalid={invalid}\n isTruncated={isTruncated}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLTextAreaElement>}\n value={String(value ?? '')}\n />\n );\n }\n\n const handleChange = (event: React.ChangeEvent<HTMLInputElement>) => {\n onChange(dataType === 'number' && event.target.value ? Number.parseInt(event.target.value) : event.target.value);\n };\n\n return (\n <Input\n {...commonProps}\n invalid={invalid}\n onChange={handleChange}\n onFocus={handleFocus}\n onKeyDown={handleInputKeyDown}\n ref={controlRef as React.RefObject<HTMLInputElement>}\n type={dataType === 'number' ? 'number' : undefined}\n value={dataType === 'number' ? (value as number) : String(value ?? '')}\n />\n );\n}) as <TType = unknown>(props: MemoedEditingCellProps<TType>) => JSX.Element;\n"],"names":["EditingControlCell","props","cell","cellRef","isHighlighted","index","_React$useContext","React","useContext","RowContext","rowIndex","_cell$getContext","getContext","table","tableMeta","options","meta","columnMeta","column","columnDef","isActiveRow","rowActive","rowActiveIndex","type","_columnMeta$control","control","handleFocus","useEditingCellAutofocus","value","getValue","hasNonTextControl","useMemo","_cellRef$current","current","querySelector","handleChange","nextValue","editing","setCellValue","requestAnimationFrame","onCellChanged","blur","toggleDetailedMode","undefined","handleBlur","event","isElementInsideOrTriggeredFromContainer","relatedTarget","currentTarget","useEffect","ref","document","activeElement","error","getCellError","controlProps","dataType","fontSize","size","id","invalid","isDetailedMode","isTruncated","enableTruncate","onBlur","onChange","row","original","rowPendingChanges","getRowValue","tabIndex","cellAttributes","_extends","getCellAttributes","onFocus","Field","message","MemoedEditingCell","RowMoveIndicator","memo","_props$tabIndex","_props$type","controlRef","useRef","currentValue","commonProps","controlFnProps","setValue","Switch","checked","Boolean","Checkbox","handleInputKeyDown","target","readOnly","key","stopPropagation","shiftKey","preventDefault","_target$select","select","call","_target$setSelectionR","_target$value","_target$value2","setSelectionRange","length","_target$select2","isPressingMetaKey","test","valueAsDate","date","newDate","detail","isDate","Datepicker","onKeyDown","TextareaWithAutosizing","String","Number","parseInt","Input"],"mappings":"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"}
|
@@ -268,10 +268,11 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
|
|
268
268
|
var nextChanges = _extends({}, changes, updatesForOtherCells);
|
269
269
|
var nextMoveReasons = _extends({}, state.changes.moveReasons[cell.row.id]);
|
270
270
|
var nextCellErrors = _extends({}, (_state$changes$errors11 = state.changes.errors[cell.row.id]) === null || _state$changes$errors11 === void 0 ? void 0 : _state$changes$errors11.cells);
|
271
|
-
// run validation
|
271
|
+
// run validation - if there are changes, and if there is an original stored
|
272
272
|
var validationErrors = {};
|
273
273
|
var _temp = function () {
|
274
|
-
if (validator) {
|
274
|
+
if (validator && Object.keys(nextChanges).length && state.changes.originals[cell.row.id]) {
|
275
|
+
// merge with the original so we get a full row
|
275
276
|
var nextRowValue = _extends({}, state.changes.originals[cell.row.id], changes, updatesForOtherCells);
|
276
277
|
return Promise.resolve(validator(nextRowValue)).then(function (_validator) {
|
277
278
|
validationErrors = _validator !== null && _validator !== void 0 ? _validator : {};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"useEditingState.js","sources":["../../../../../../../../src/components/Table3/features/useEditingState.ts"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, Cell as ReactTableCell } from '@tanstack/react-table';\nimport { v4 as uuid } from 'uuid';\nimport omit from 'lodash/omit';\nimport setWith from 'lodash/setWith';\nimport { Table3EditingChangeHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';\nimport { isTemporaryRow, TEMPORARY_ROW_ID_PREFIX, willRowMove } from '../util/editing';\nimport { useLocalization } from '../../Provider/Localization';\n\nconst DELAY_BEFORE_REMOVING_SAVE_STATUS = 3000;\n\ntype EditingError = {\n row: string;\n cells: Record<string, string>;\n shouldShowErrorAlert: boolean;\n};\ntype EditingRowMoveReason = Record<string, 'search' | 'sorting' | 'filter'>;\ntype EditingSaveState = 'saving' | 'saved' | 'errored';\ntype EditingChangeset<TType = unknown> = Partial<TType>;\ntype EditingState<TType = unknown> = {\n changes: {\n rows: Record<string, EditingChangeset<TType>>;\n errors: Record<string, EditingError>;\n moveReasons: Record<string, EditingRowMoveReason>;\n originals: Record<string, TType>;\n status: Record<string, EditingSaveState>;\n };\n indexes: Record<string, number>;\n temporaryRows: TType[];\n};\ntype EditingStateAction = {\n type:\n | 'setCellValue'\n | 'removeCellValue'\n | 'updateRow'\n | 'mergeRowValue'\n | 'removeRow'\n | 'setRowStatus'\n | 'setRowErrors'\n | 'insertTemporaryRow';\n rowId: string;\n payload?: any;\n};\n\nfunction reducer<TType = unknown>(state: EditingState<TType>, action: EditingStateAction) {\n const { type, rowId, payload } = action;\n\n switch (type) {\n case 'setCellValue': {\n const { columnId, index, row, value } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, `${rowId}.${columnId}`, value, Object),\n originals: setWith(state.changes.originals, rowId, row, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n case 'removeCellValue': {\n const { columnId, rowIdentityAccessor } = payload;\n const changes = omit(state.changes.rows, `${rowId}.${columnId}`);\n\n // if there are no changes left, remove the row\n if (!Object.keys(changes[rowId]).length) {\n return reducer(state, { type: 'removeRow', rowId, payload: { rowIdentityAccessor } });\n }\n\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: omit(state.changes.rows, `${rowId}.${columnId}`),\n errors: omit(state.changes.errors, `${rowId}.cells.${columnId}`),\n moveReasons: omit(state.changes.moveReasons, `${rowId}.${columnId}`),\n },\n };\n }\n\n case 'updateRow': {\n const { cellErrors, index, moveReasons, original, value } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, rowId, value, Object),\n errors: setWith(\n state.changes.errors,\n `${rowId}.cells`,\n cellErrors ?? state.changes.errors.cells[rowId],\n Object\n ),\n originals: setWith(state.changes.originals, rowId, original ?? state.changes.originals[rowId], Object),\n moveReasons: setWith(\n state.changes.moveReasons,\n rowId,\n moveReasons ?? state.changes.moveReasons[rowId],\n Object\n ),\n // status can be undefined, so don't use ??\n status: setWith(state.changes.status, rowId, undefined, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n case 'removeRow': {\n const { rowIdentityAccessor } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: omit(state.changes.rows, rowId),\n errors: omit(state.changes.errors, rowId),\n moveReasons: omit(state.changes.moveReasons, rowId),\n originals: omit(state.changes.originals, rowId),\n status: omit(state.changes.status, rowId),\n },\n indexes: omit(state.indexes, rowId),\n temporaryRows: state.temporaryRows.filter(row => row[rowIdentityAccessor] !== rowId),\n };\n }\n\n case 'setRowStatus': {\n const { status } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n status: status ? setWith(state.changes.status, rowId, status, Object) : omit(state.changes.status, rowId),\n },\n };\n }\n\n case 'setRowErrors': {\n const { ...errors } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n errors: setWith(state.changes.errors, rowId, errors, Object),\n },\n };\n }\n\n case 'insertTemporaryRow': {\n const { index, value } = payload;\n return {\n ...state,\n temporaryRows: state.temporaryRows.concat(value),\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, rowId, value, Object),\n originals: setWith(state.changes.originals, rowId, value, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n default:\n return state;\n }\n}\n\nexport function usePendingChangesState<TType = unknown>(\n handleSave: Table3EditingSaveHandler<TType> | undefined,\n handleChange: Table3EditingChangeHandler<TType> | undefined,\n rowIdentityAccessor: keyof TType,\n validator: Table3EditingValidatorFn<TType> | undefined\n) {\n const localization = useLocalization();\n const [state, dispatch] = React.useReducer(reducer, {\n changes: { rows: {}, errors: {}, moveReasons: {}, originals: {}, status: {} },\n indexes: {},\n temporaryRows: [],\n });\n\n // rows\n function getRowValue(rowId: string) {\n return state.changes.rows?.[rowId] ?? undefined;\n }\n\n function getRowMoveReason(rowId: string) {\n return Object.values(state.changes.moveReasons?.[rowId] ?? {})[0] ?? undefined;\n }\n\n function hasRowErrors(rowId: string) {\n return !!state.changes.errors[rowId]?.row || !!Object.keys(state.changes.errors[rowId]?.cells ?? {}).length;\n }\n\n function hasRowErrorsShownInAlert(rowId: string) {\n return hasRowErrors(rowId) && !!state.changes.errors[rowId]?.shouldShowErrorAlert;\n }\n\n function hasTemporaryRowErrors<T extends TType>() {\n const newRow = state.temporaryRows?.[0] as T | undefined;\n\n if (!newRow) {\n return false;\n }\n\n const rowId = newRow[rowIdentityAccessor as string];\n return !!state.changes.errors[rowId]?.row || !!Object.keys(state.changes.errors[rowId]?.cells ?? {}).length;\n }\n\n function getRowStatus(rowId: string) {\n return state.changes.status[rowId];\n }\n\n function setRowStatus(rowId: string, status: EditingSaveState | undefined) {\n dispatch({\n type: 'setRowStatus',\n rowId,\n payload: {\n status,\n },\n });\n }\n\n function insertTemporaryRow<T extends TType>(data: Partial<T>, rowIndex: number) {\n const newRowId = `${TEMPORARY_ROW_ID_PREFIX}${uuid()}`;\n const value: Partial<TType> = {\n ...data,\n [rowIdentityAccessor]: newRowId,\n };\n\n dispatch({\n type: 'insertTemporaryRow',\n rowId: newRowId,\n payload: { index: rowIndex, value },\n });\n\n return newRowId;\n }\n\n // cells\n function setCellValue<T extends TType>(cell: ReactTableCell<T, unknown>, rowIndex: number, value: unknown) {\n const rowId = cell.row.id;\n const columnId = cell.column.id;\n\n // update if the change is different to the original value\n if (value !== cell.row.original[columnId]) {\n dispatch({\n type: 'setCellValue',\n rowId,\n payload: {\n columnId,\n index: rowIndex,\n row: cell.row.original,\n value,\n },\n });\n }\n // otherwise remove any previous change - no point saving the same value\n else if (cell.row.id in state.changes.rows) {\n dispatch({\n type: 'removeCellValue',\n rowId,\n payload: {\n columnId,\n rowIdentityAccessor,\n },\n });\n }\n }\n\n function getCellValue<T extends TType>(cell: ReactTableCell<T, unknown>): unknown | undefined {\n return state.changes.rows?.[cell.row.id]?.[cell.column.id];\n }\n\n function getCellError<T extends TType>(cell: ReactTableCell<T, unknown>): string | undefined {\n return state.changes.errors?.[cell.row.id]?.cells?.[cell.column.id];\n }\n\n async function onCellChanged<T extends TType>(\n cell: ReactTableCell<T, unknown>,\n rowIndex: number,\n nextValue,\n shouldRunUpdaters = true\n ) {\n const changes =\n nextValue !== undefined\n ? { ...state.changes.rows[cell.row.id], [cell.column.id]: nextValue }\n : { ...state.changes.rows[cell.row.id] };\n\n if (!Object.keys(changes).length) {\n return;\n }\n\n let updatesForOtherCells: Partial<T> = {};\n\n // run the updater handler if there is one, to see if there are any other cells to update\n if (typeof handleChange === 'function' && shouldRunUpdaters) {\n const previousRowValue = {\n ...state.changes.originals[cell.row.id],\n //...getRowChangeset(updatersRef.current[cell.row.id], rowIdentityAccessor),\n };\n const nextRowValue = {\n ...state.changes.originals[cell.row.id],\n ...changes,\n };\n updatesForOtherCells = ((await handleChange(\n cell.column.id,\n changes[cell.column.id],\n nextRowValue,\n previousRowValue\n )) ?? {}) as Partial<T>;\n }\n\n // create a projection of the next state, so we can act against it\n const nextChanges = { ...changes, ...updatesForOtherCells };\n const nextMoveReasons: EditingRowMoveReason = { ...state.changes.moveReasons[cell.row.id] };\n const nextCellErrors: Record<string, string> = { ...state.changes.errors[cell.row.id]?.cells };\n\n // run validation\n let validationErrors: Record<string, string> = {};\n\n if (validator) {\n const nextRowValue = { ...state.changes.originals[cell.row.id], ...changes, ...updatesForOtherCells };\n validationErrors = ((await validator(nextRowValue)) ?? {}) as Record<string, string>;\n }\n\n // only set errors and move reasons for the cells we're currently acting on\n // why? because the UX is not good if we set them for cells the user hasn't touched yet\n const cellsToActOn = [cell.column.id, ...Object.keys(updatesForOtherCells)];\n const allCells = cell.row._getAllCellsByColumnId();\n\n cellsToActOn.forEach(accessor => {\n if (validationErrors[accessor]) {\n nextCellErrors[accessor] = validationErrors[accessor];\n // don't show move indicator for cells with errors, they aren't valid and can't be saved\n delete nextMoveReasons[accessor];\n } else {\n // there isn't any error in this run, remove any error set in state\n delete nextCellErrors[accessor];\n\n if (allCells[accessor]?.column.getIsSorted()) {\n // run row move determination\n const reason = willRowMove(cell, nextChanges[accessor], rowIndex, localization);\n\n // if the row will move based on this change save why, otherwise delete any existing state\n if (reason) {\n nextMoveReasons[accessor] = reason;\n } else {\n delete nextMoveReasons[accessor];\n }\n }\n }\n });\n\n dispatch({\n type: 'updateRow',\n rowId: cell.row.id,\n payload: {\n cellErrors: nextCellErrors,\n index: rowIndex,\n moveReasons: nextMoveReasons,\n value: nextChanges,\n },\n });\n }\n\n // general\n function getErrorsShownInAlert<T extends TType>() {\n const rowsWithErrors = Object.keys(state.changes.errors);\n\n if (!rowsWithErrors.length) {\n return [];\n }\n\n return rowsWithErrors.filter(hasRowErrorsShownInAlert).map(rowId => ({\n rowId,\n index: state.indexes[rowId],\n changes: state.changes.rows[rowId] as EditingChangeset<T>,\n errors: state.changes.errors[rowId],\n }));\n }\n\n function hasSaved() {\n return !!Object.values(state.changes.status).filter(value => value === 'saved').length;\n }\n\n function hasChanges(rowId?: string) {\n return rowId ? !!state.changes.rows[rowId] : !!Object.keys(state.changes.rows).length;\n }\n\n async function saveChanges<T extends TType>(table: ReactTable<T>, rowId: string | undefined = undefined): Promise<boolean> {\n if (!handleSave) {\n console.warn('Tried to save, but Table has no onEditingSave handler');\n return false;\n }\n\n // sometimes we only want to save one row\n const changes = rowId ? { [rowId]: state.changes.rows[rowId] } : state.changes.rows;\n\n let completed = true;\n\n for (const rowId of Object.keys(changes)) {\n const status = getRowStatus(rowId);\n\n try {\n const rowChanges = changes[rowId] ?? {};\n\n // don't try to save if - already saving, or there are known errors\n if (!Object.keys(rowChanges).length || status === 'saving' || status === 'errored') {\n continue;\n }\n\n setRowStatus(rowId, 'saving');\n\n const changeSet = { ...state.changes.originals[rowId], ...rowChanges };\n\n // if we had to create a temporary id, delete it first - it's our data, not theirs\n if (isTemporaryRow(changeSet[rowIdentityAccessor as string])) {\n delete changeSet[rowIdentityAccessor];\n }\n\n // re-run validation, maybe a cell is already invalid but has never been blurred\n if (validator) {\n const errors = await validator(changeSet);\n\n if (errors && Object.keys(errors).length) {\n throw errors;\n }\n }\n\n // send new data to the server\n await handleSave(changeSet);\n\n // cleanup changes, we don't need them after saving\n discardChanges(rowId, table);\n\n // show the saved status, then remove it after a delay\n setRowStatus(rowId, 'saved');\n setTimeout(() => {\n setRowStatus(rowId, undefined);\n }, DELAY_BEFORE_REMOVING_SAVE_STATUS);\n } catch (error) {\n if (error instanceof ReferenceError || error instanceof TypeError || (error as any)?.response?.status >= 500) {\n console.error(error);\n }\n\n // the onEditingSave handler should throw errors when something fails, e.g. validation, network errors etc\n // this code handles those errors and maps them either to row errors or cell specific errors\n let rowError: string | undefined;\n let cellErrors;\n\n if (typeof error === 'string') {\n rowError = error;\n } else if (error instanceof Error) {\n rowError = error.message;\n\n // most of our apis return error objects within this shape\n if (typeof (error as any).response?.data === 'object') {\n cellErrors = (error as any).response?.data;\n }\n } else if (typeof error === 'object') {\n cellErrors = error;\n }\n\n if (rowError || cellErrors) {\n dispatch({\n type: 'setRowErrors',\n rowId,\n payload: {\n row: rowError,\n cells: cellErrors,\n shouldShowErrorAlert: true,\n },\n });\n }\n\n setRowStatus(rowId, 'errored');\n completed = false;\n }\n }\n\n return completed;\n }\n\n function discardChanges<T extends TType>(rowId: string, table: ReactTable<T>) {\n // remove any new rows from pinned state before discarding them\n table.resetRowPinning(true);\n\n dispatch({\n type: 'removeRow',\n rowId,\n payload: { rowIdentityAccessor },\n });\n }\n\n return {\n // row\n getRowValue,\n getRowMoveReason,\n hasRowErrors,\n hasRowErrorsShownInAlert,\n hasTemporaryRowErrors,\n getRowStatus,\n setRowStatus,\n // cells\n setCellValue,\n getCellValue,\n getCellError,\n onCellChanged,\n // general\n getErrorsShownInAlert,\n hasChanges,\n saveChanges,\n discardChanges,\n hasSaved,\n // new rows\n insertTemporaryRow,\n temporaryRows: state.temporaryRows,\n };\n}\n"],"names":["DELAY_BEFORE_REMOVING_SAVE_STATUS","reducer","state","action","type","rowId","payload","columnId","index","row","value","_extends","changes","rows","setWith","Object","originals","indexes","rowIdentityAccessor","omit","keys","length","errors","moveReasons","cellErrors","original","cells","status","undefined","temporaryRows","filter","_objectDestructuringEmpty","concat","usePendingChangesState","handleSave","handleChange","validator","saveChanges","table","console","warn","Promise","resolve","_ref","completed","_temp7","_forOf","getRowStatus","_catch","_changes$rowId","_temp6","_result","_exit","changeSet","then","discardChanges","setRowStatus","setTimeout","rowChanges","isTemporaryRow","_temp5","error","_error$response","ReferenceError","TypeError","response","rowError","Error","_error$response2","message","data","_error$response3","dispatch","shouldShowErrorAlert","_result3","e","reject","onCellChanged","cell","rowIndex","nextValue","shouldRunUpdaters","cellsToActOn","column","id","updatesForOtherCells","allCells","_getAllCellsByColumnId","forEach","accessor","validationErrors","nextCellErrors","nextMoveReasons","_allCells$accessor","getIsSorted","reason","willRowMove","nextChanges","localization","_state$changes$errors11","_temp","nextRowValue","_validator","_temp2","_extends3","_temp3","previousRowValue","_handleChange","_temp4","useLocalization","_React$useReducer","React","useReducer","getRowValue","_state$changes$rows$r","_state$changes$rows","getRowMoveReason","_Object$values$","values","_state$changes$moveRe","_state$changes$moveRe2","hasRowErrors","_state$changes$errors","_state$changes$errors2","_state$changes$errors3","hasRowErrorsShownInAlert","_state$changes$errors4","hasTemporaryRowErrors","newRow","_state$temporaryRows","_state$changes$errors5","_state$changes$errors6","_state$changes$errors7","insertTemporaryRow","newRowId","TEMPORARY_ROW_ID_PREFIX","uuid","_extends2","setCellValue","getCellValue","_state$changes$rows2","_state$changes$rows2$","getCellError","_state$changes$errors8","_state$changes$errors9","_state$changes$errors10","getErrorsShownInAlert","rowsWithErrors","map","hasSaved","hasChanges","resetRowPinning"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"useEditingState.js","sources":["../../../../../../../../src/components/Table3/features/useEditingState.ts"],"sourcesContent":["import React from 'react';\nimport { Table as ReactTable, Cell as ReactTableCell } from '@tanstack/react-table';\nimport { v4 as uuid } from 'uuid';\nimport omit from 'lodash/omit';\nimport setWith from 'lodash/setWith';\nimport { Table3EditingChangeHandler, Table3EditingSaveHandler, Table3EditingValidatorFn } from '../types';\nimport { isTemporaryRow, TEMPORARY_ROW_ID_PREFIX, willRowMove } from '../util/editing';\nimport { useLocalization } from '../../Provider/Localization';\n\nconst DELAY_BEFORE_REMOVING_SAVE_STATUS = 3000;\n\ntype EditingError = {\n row: string;\n cells: Record<string, string>;\n shouldShowErrorAlert: boolean;\n};\ntype EditingRowMoveReason = Record<string, 'search' | 'sorting' | 'filter'>;\ntype EditingSaveState = 'saving' | 'saved' | 'errored';\ntype EditingChangeset<TType = unknown> = Partial<TType>;\ntype EditingState<TType = unknown> = {\n changes: {\n rows: Record<string, EditingChangeset<TType>>;\n errors: Record<string, EditingError>;\n moveReasons: Record<string, EditingRowMoveReason>;\n originals: Record<string, TType>;\n status: Record<string, EditingSaveState>;\n };\n indexes: Record<string, number>;\n temporaryRows: TType[];\n};\ntype EditingStateAction = {\n type:\n | 'setCellValue'\n | 'removeCellValue'\n | 'updateRow'\n | 'mergeRowValue'\n | 'removeRow'\n | 'setRowStatus'\n | 'setRowErrors'\n | 'insertTemporaryRow';\n rowId: string;\n payload?: any;\n};\n\nfunction reducer<TType = unknown>(state: EditingState<TType>, action: EditingStateAction) {\n const { type, rowId, payload } = action;\n\n switch (type) {\n case 'setCellValue': {\n const { columnId, index, row, value } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, `${rowId}.${columnId}`, value, Object),\n originals: setWith(state.changes.originals, rowId, row, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n case 'removeCellValue': {\n const { columnId, rowIdentityAccessor } = payload;\n const changes = omit(state.changes.rows, `${rowId}.${columnId}`);\n\n // if there are no changes left, remove the row\n if (!Object.keys(changes[rowId]).length) {\n return reducer(state, { type: 'removeRow', rowId, payload: { rowIdentityAccessor } });\n }\n\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: omit(state.changes.rows, `${rowId}.${columnId}`),\n errors: omit(state.changes.errors, `${rowId}.cells.${columnId}`),\n moveReasons: omit(state.changes.moveReasons, `${rowId}.${columnId}`),\n },\n };\n }\n\n case 'updateRow': {\n const { cellErrors, index, moveReasons, original, value } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, rowId, value, Object),\n errors: setWith(\n state.changes.errors,\n `${rowId}.cells`,\n cellErrors ?? state.changes.errors.cells[rowId],\n Object\n ),\n originals: setWith(state.changes.originals, rowId, original ?? state.changes.originals[rowId], Object),\n moveReasons: setWith(\n state.changes.moveReasons,\n rowId,\n moveReasons ?? state.changes.moveReasons[rowId],\n Object\n ),\n // status can be undefined, so don't use ??\n status: setWith(state.changes.status, rowId, undefined, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n case 'removeRow': {\n const { rowIdentityAccessor } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n rows: omit(state.changes.rows, rowId),\n errors: omit(state.changes.errors, rowId),\n moveReasons: omit(state.changes.moveReasons, rowId),\n originals: omit(state.changes.originals, rowId),\n status: omit(state.changes.status, rowId),\n },\n indexes: omit(state.indexes, rowId),\n temporaryRows: state.temporaryRows.filter(row => row[rowIdentityAccessor] !== rowId),\n };\n }\n\n case 'setRowStatus': {\n const { status } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n status: status ? setWith(state.changes.status, rowId, status, Object) : omit(state.changes.status, rowId),\n },\n };\n }\n\n case 'setRowErrors': {\n const { ...errors } = payload;\n return {\n ...state,\n changes: {\n ...state.changes,\n errors: setWith(state.changes.errors, rowId, errors, Object),\n },\n };\n }\n\n case 'insertTemporaryRow': {\n const { index, value } = payload;\n return {\n ...state,\n temporaryRows: state.temporaryRows.concat(value),\n changes: {\n ...state.changes,\n rows: setWith(state.changes.rows, rowId, value, Object),\n originals: setWith(state.changes.originals, rowId, value, Object),\n },\n indexes: setWith(state.indexes, rowId, index, Object),\n };\n }\n\n default:\n return state;\n }\n}\n\nexport function usePendingChangesState<TType = unknown>(\n handleSave: Table3EditingSaveHandler<TType> | undefined,\n handleChange: Table3EditingChangeHandler<TType> | undefined,\n rowIdentityAccessor: keyof TType,\n validator: Table3EditingValidatorFn<TType> | undefined\n) {\n const localization = useLocalization();\n const [state, dispatch] = React.useReducer(reducer, {\n changes: { rows: {}, errors: {}, moveReasons: {}, originals: {}, status: {} },\n indexes: {},\n temporaryRows: [],\n });\n\n // rows\n function getRowValue(rowId: string) {\n return state.changes.rows?.[rowId] ?? undefined;\n }\n\n function getRowMoveReason(rowId: string) {\n return Object.values(state.changes.moveReasons?.[rowId] ?? {})[0] ?? undefined;\n }\n\n function hasRowErrors(rowId: string) {\n return !!state.changes.errors[rowId]?.row || !!Object.keys(state.changes.errors[rowId]?.cells ?? {}).length;\n }\n\n function hasRowErrorsShownInAlert(rowId: string) {\n return hasRowErrors(rowId) && !!state.changes.errors[rowId]?.shouldShowErrorAlert;\n }\n\n function hasTemporaryRowErrors<T extends TType>() {\n const newRow = state.temporaryRows?.[0] as T | undefined;\n\n if (!newRow) {\n return false;\n }\n\n const rowId = newRow[rowIdentityAccessor as string];\n return !!state.changes.errors[rowId]?.row || !!Object.keys(state.changes.errors[rowId]?.cells ?? {}).length;\n }\n\n function getRowStatus(rowId: string) {\n return state.changes.status[rowId];\n }\n\n function setRowStatus(rowId: string, status: EditingSaveState | undefined) {\n dispatch({\n type: 'setRowStatus',\n rowId,\n payload: {\n status,\n },\n });\n }\n\n function insertTemporaryRow<T extends TType>(data: Partial<T>, rowIndex: number) {\n const newRowId = `${TEMPORARY_ROW_ID_PREFIX}${uuid()}`;\n const value: Partial<TType> = {\n ...data,\n [rowIdentityAccessor]: newRowId,\n };\n\n dispatch({\n type: 'insertTemporaryRow',\n rowId: newRowId,\n payload: { index: rowIndex, value },\n });\n\n return newRowId;\n }\n\n // cells\n function setCellValue<T extends TType>(cell: ReactTableCell<T, unknown>, rowIndex: number, value: unknown) {\n const rowId = cell.row.id;\n const columnId = cell.column.id;\n\n // update if the change is different to the original value\n if (value !== cell.row.original[columnId]) {\n dispatch({\n type: 'setCellValue',\n rowId,\n payload: {\n columnId,\n index: rowIndex,\n row: cell.row.original,\n value,\n },\n });\n }\n // otherwise remove any previous change - no point saving the same value\n else if (cell.row.id in state.changes.rows) {\n dispatch({\n type: 'removeCellValue',\n rowId,\n payload: {\n columnId,\n rowIdentityAccessor,\n },\n });\n }\n }\n\n function getCellValue<T extends TType>(cell: ReactTableCell<T, unknown>): unknown | undefined {\n return state.changes.rows?.[cell.row.id]?.[cell.column.id];\n }\n\n function getCellError<T extends TType>(cell: ReactTableCell<T, unknown>): string | undefined {\n return state.changes.errors?.[cell.row.id]?.cells?.[cell.column.id];\n }\n\n async function onCellChanged<T extends TType>(\n cell: ReactTableCell<T, unknown>,\n rowIndex: number,\n nextValue,\n shouldRunUpdaters = true\n ) {\n const changes =\n nextValue !== undefined\n ? { ...state.changes.rows[cell.row.id], [cell.column.id]: nextValue }\n : { ...state.changes.rows[cell.row.id] };\n\n if (!Object.keys(changes).length) {\n return;\n }\n\n let updatesForOtherCells: Partial<T> = {};\n\n // run the updater handler if there is one, to see if there are any other cells to update\n if (typeof handleChange === 'function' && shouldRunUpdaters) {\n const previousRowValue = {\n ...state.changes.originals[cell.row.id],\n //...getRowChangeset(updatersRef.current[cell.row.id], rowIdentityAccessor),\n };\n const nextRowValue = {\n ...state.changes.originals[cell.row.id],\n ...changes,\n };\n updatesForOtherCells = ((await handleChange(\n cell.column.id,\n changes[cell.column.id],\n nextRowValue,\n previousRowValue\n )) ?? {}) as Partial<T>;\n }\n\n // create a projection of the next state, so we can act against it\n const nextChanges = { ...changes, ...updatesForOtherCells };\n const nextMoveReasons: EditingRowMoveReason = { ...state.changes.moveReasons[cell.row.id] };\n const nextCellErrors: Record<string, string> = { ...state.changes.errors[cell.row.id]?.cells };\n\n // run validation - if there are changes, and if there is an original stored\n let validationErrors: Record<string, string> = {};\n\n if (validator && Object.keys(nextChanges).length && state.changes.originals[cell.row.id]) {\n // merge with the original so we get a full row\n const nextRowValue = { ...state.changes.originals[cell.row.id], ...changes, ...updatesForOtherCells };\n validationErrors = ((await validator(nextRowValue)) ?? {}) as Record<string, string>;\n }\n\n // only set errors and move reasons for the cells we're currently acting on\n // why? because the UX is not good if we set them for cells the user hasn't touched yet\n const cellsToActOn = [cell.column.id, ...Object.keys(updatesForOtherCells)];\n const allCells = cell.row._getAllCellsByColumnId();\n\n cellsToActOn.forEach(accessor => {\n if (validationErrors[accessor]) {\n nextCellErrors[accessor] = validationErrors[accessor];\n // don't show move indicator for cells with errors, they aren't valid and can't be saved\n delete nextMoveReasons[accessor];\n } else {\n // there isn't any error in this run, remove any error set in state\n delete nextCellErrors[accessor];\n\n if (allCells[accessor]?.column.getIsSorted()) {\n // run row move determination\n const reason = willRowMove(cell, nextChanges[accessor], rowIndex, localization);\n\n // if the row will move based on this change save why, otherwise delete any existing state\n if (reason) {\n nextMoveReasons[accessor] = reason;\n } else {\n delete nextMoveReasons[accessor];\n }\n }\n }\n });\n\n dispatch({\n type: 'updateRow',\n rowId: cell.row.id,\n payload: {\n cellErrors: nextCellErrors,\n index: rowIndex,\n moveReasons: nextMoveReasons,\n value: nextChanges,\n },\n });\n }\n\n // general\n function getErrorsShownInAlert<T extends TType>() {\n const rowsWithErrors = Object.keys(state.changes.errors);\n\n if (!rowsWithErrors.length) {\n return [];\n }\n\n return rowsWithErrors.filter(hasRowErrorsShownInAlert).map(rowId => ({\n rowId,\n index: state.indexes[rowId],\n changes: state.changes.rows[rowId] as EditingChangeset<T>,\n errors: state.changes.errors[rowId],\n }));\n }\n\n function hasSaved() {\n return !!Object.values(state.changes.status).filter(value => value === 'saved').length;\n }\n\n function hasChanges(rowId?: string) {\n return rowId ? !!state.changes.rows[rowId] : !!Object.keys(state.changes.rows).length;\n }\n\n async function saveChanges<T extends TType>(table: ReactTable<T>, rowId: string | undefined = undefined): Promise<boolean> {\n if (!handleSave) {\n console.warn('Tried to save, but Table has no onEditingSave handler');\n return false;\n }\n\n // sometimes we only want to save one row\n const changes = rowId ? { [rowId]: state.changes.rows[rowId] } : state.changes.rows;\n\n let completed = true;\n\n for (const rowId of Object.keys(changes)) {\n const status = getRowStatus(rowId);\n\n try {\n const rowChanges = changes[rowId] ?? {};\n\n // don't try to save if - already saving, or there are known errors\n if (!Object.keys(rowChanges).length || status === 'saving' || status === 'errored') {\n continue;\n }\n\n setRowStatus(rowId, 'saving');\n\n const changeSet = { ...state.changes.originals[rowId], ...rowChanges };\n\n // if we had to create a temporary id, delete it first - it's our data, not theirs\n if (isTemporaryRow(changeSet[rowIdentityAccessor as string])) {\n delete changeSet[rowIdentityAccessor];\n }\n\n // re-run validation, maybe a cell is already invalid but has never been blurred\n if (validator) {\n const errors = await validator(changeSet);\n\n if (errors && Object.keys(errors).length) {\n throw errors;\n }\n }\n\n // send new data to the server\n await handleSave(changeSet);\n\n // cleanup changes, we don't need them after saving\n discardChanges(rowId, table);\n\n // show the saved status, then remove it after a delay\n setRowStatus(rowId, 'saved');\n setTimeout(() => {\n setRowStatus(rowId, undefined);\n }, DELAY_BEFORE_REMOVING_SAVE_STATUS);\n } catch (error) {\n if (error instanceof ReferenceError || error instanceof TypeError || (error as any)?.response?.status >= 500) {\n console.error(error);\n }\n\n // the onEditingSave handler should throw errors when something fails, e.g. validation, network errors etc\n // this code handles those errors and maps them either to row errors or cell specific errors\n let rowError: string | undefined;\n let cellErrors;\n\n if (typeof error === 'string') {\n rowError = error;\n } else if (error instanceof Error) {\n rowError = error.message;\n\n // most of our apis return error objects within this shape\n if (typeof (error as any).response?.data === 'object') {\n cellErrors = (error as any).response?.data;\n }\n } else if (typeof error === 'object') {\n cellErrors = error;\n }\n\n if (rowError || cellErrors) {\n dispatch({\n type: 'setRowErrors',\n rowId,\n payload: {\n row: rowError,\n cells: cellErrors,\n shouldShowErrorAlert: true,\n },\n });\n }\n\n setRowStatus(rowId, 'errored');\n completed = false;\n }\n }\n\n return completed;\n }\n\n function discardChanges<T extends TType>(rowId: string, table: ReactTable<T>) {\n // remove any new rows from pinned state before discarding them\n table.resetRowPinning(true);\n\n dispatch({\n type: 'removeRow',\n rowId,\n payload: { rowIdentityAccessor },\n });\n }\n\n return {\n // row\n getRowValue,\n getRowMoveReason,\n hasRowErrors,\n hasRowErrorsShownInAlert,\n hasTemporaryRowErrors,\n getRowStatus,\n setRowStatus,\n // cells\n setCellValue,\n getCellValue,\n getCellError,\n onCellChanged,\n // general\n getErrorsShownInAlert,\n hasChanges,\n saveChanges,\n discardChanges,\n hasSaved,\n // new rows\n insertTemporaryRow,\n temporaryRows: state.temporaryRows,\n };\n}\n"],"names":["DELAY_BEFORE_REMOVING_SAVE_STATUS","reducer","state","action","type","rowId","payload","columnId","index","row","value","_extends","changes","rows","setWith","Object","originals","indexes","rowIdentityAccessor","omit","keys","length","errors","moveReasons","cellErrors","original","cells","status","undefined","temporaryRows","filter","_objectDestructuringEmpty","concat","usePendingChangesState","handleSave","handleChange","validator","saveChanges","table","console","warn","Promise","resolve","_ref","completed","_temp7","_forOf","getRowStatus","_catch","_changes$rowId","_temp6","_result","_exit","changeSet","then","discardChanges","setRowStatus","setTimeout","rowChanges","isTemporaryRow","_temp5","error","_error$response","ReferenceError","TypeError","response","rowError","Error","_error$response2","message","data","_error$response3","dispatch","shouldShowErrorAlert","_result3","e","reject","onCellChanged","cell","rowIndex","nextValue","shouldRunUpdaters","cellsToActOn","column","id","updatesForOtherCells","allCells","_getAllCellsByColumnId","forEach","accessor","validationErrors","nextCellErrors","nextMoveReasons","_allCells$accessor","getIsSorted","reason","willRowMove","nextChanges","localization","_state$changes$errors11","_temp","nextRowValue","_validator","_temp2","_extends3","_temp3","previousRowValue","_handleChange","_temp4","useLocalization","_React$useReducer","React","useReducer","getRowValue","_state$changes$rows$r","_state$changes$rows","getRowMoveReason","_Object$values$","values","_state$changes$moveRe","_state$changes$moveRe2","hasRowErrors","_state$changes$errors","_state$changes$errors2","_state$changes$errors3","hasRowErrorsShownInAlert","_state$changes$errors4","hasTemporaryRowErrors","newRow","_state$temporaryRows","_state$changes$errors5","_state$changes$errors6","_state$changes$errors7","insertTemporaryRow","newRowId","TEMPORARY_ROW_ID_PREFIX","uuid","_extends2","setCellValue","getCellValue","_state$changes$rows2","_state$changes$rows2$","getCellError","_state$changes$errors8","_state$changes$errors9","_state$changes$errors10","getErrorsShownInAlert","rowsWithErrors","map","hasSaved","hasChanges","resetRowPinning"],"mappings":"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"}
|
@@ -64,6 +64,9 @@ function isElementTriggeredFromContainer(element, container) {
|
|
64
64
|
return true;
|
65
65
|
}
|
66
66
|
var elementInDocument = document.querySelector(selector);
|
67
|
+
if (elementInDocument === container) {
|
68
|
+
return true;
|
69
|
+
}
|
67
70
|
// if the element does exist, see if it is itself connected to somethng that was triggered from the container
|
68
71
|
if (elementInDocument) {
|
69
72
|
return isElementTriggeredFromContainer(elementInDocument, container);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"dom.js","sources":["../../../../../../src/utils/dom.ts"],"sourcesContent":["// taken from react-aria\nconst FOCUSABLE_ELEMENTS = [\n '[tabindex]:not([disabled])',\n 'input:not([disabled])',\n 'select:not([disabled])',\n 'textarea:not([disabled])',\n 'button:not([disabled])',\n 'a[href]',\n 'area[href]',\n 'summary',\n 'iframe',\n 'object',\n 'embed',\n 'audio[controls]',\n 'video[controls]',\n '[contenteditable]',\n 'details:not([disabled])',\n 'summary:not(:disabled)',\n];\n\nexport const hasFocusableElement = (element: HTMLElement | null) => {\n if (!element) {\n return null;\n }\n\n return !!element.querySelector(FOCUSABLE_ELEMENTS.join(','));\n};\n\nexport const isOverflowing = (element: HTMLElement | null) =>\n element !== null ? element.scrollWidth > element.offsetWidth : false;\n\nexport const getIndexOfFirstChildOverflowingParent = (element: HTMLElement, overscan = 0) => {\n let index = 0;\n let boundaryChildIndex: number | null = null;\n const clientRect = element.getBoundingClientRect();\n\n for (const child of Array.from(element.children)) {\n const right = child.getBoundingClientRect().right - clientRect.left;\n const width = clientRect.width - overscan;\n\n if (right > width) {\n boundaryChildIndex = index;\n break;\n }\n index++;\n }\n\n return boundaryChildIndex;\n};\n\nexport const getNextFocussableElement = (currentElement: HTMLElement | null) => {\n if (!currentElement) {\n return null;\n }\n\n let focussableElements = [...document.querySelectorAll<HTMLElement>(FOCUSABLE_ELEMENTS.join(','))];\n const currentElementIndex = focussableElements.indexOf(currentElement);\n\n if (currentElementIndex > -1) {\n focussableElements = focussableElements\n .slice(currentElementIndex + 1)\n .filter(element => element.getAttribute('tabindex') !== '-1');\n\n if (focussableElements.length) {\n focussableElements = focussableElements.filter(element => (element as any).checkVisibility?.() ?? true);\n return focussableElements[0] ?? null;\n }\n }\n\n return null;\n};\n\nconst getOverlaySelector = (element: Element | null) => {\n switch (element?.getAttribute('role')) {\n case 'dialog':\n return `[aria-controls='${element.id}']`;\n\n case 'menu':\n return `#${element.getAttribute('aria-labelledby')}`;\n\n default:\n return undefined;\n }\n};\n\nexport function isElementTriggeredFromContainer(element: Element | null, container: Element | null) {\n const selector = getOverlaySelector(element) ?? getOverlaySelector(element?.closest('[role=dialog],[role=menu]') ?? null);\n\n if (selector) {\n if (container?.querySelector(selector)) {\n return true;\n }\n\n const elementInDocument = document.querySelector(selector);\n\n // if the element does exist, see if it is itself connected to somethng that was triggered from the container\n if (elementInDocument) {\n return isElementTriggeredFromContainer(elementInDocument, container);\n }\n\n return false;\n }\n\n return false;\n}\n\nexport function isElementInsideOrTriggeredFromContainer(element: Element | null, container: Element | null) {\n return isElementTriggeredFromContainer(element, container) || !!container?.contains(element);\n}\n\nexport function isElementInsideOverlay(element: Element | null) {\n return !!element?.closest('[role=dialog],[role=menu]');\n}\n\nexport function isSiblingElementInsideSameParentOverlay(element: Element | null, sibling: Element | null) {\n return !!element?.closest('[role=dialog],[role=menu]')?.contains(sibling);\n}\n\nexport function isElementInteractive(element: Element | null) {\n if (!element) {\n return false;\n }\n\n const interactiveElements = ['A', 'BUTTON', 'INPUT', 'TEXTAREA', 'SELECT', 'LABEL', 'OPTION'];\n\n const isInteractive =\n interactiveElements.includes(element.tagName) &&\n !(element as HTMLElement).hidden &&\n !(element as HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement).disabled &&\n !(element as HTMLInputElement | HTMLTextAreaElement).readOnly;\n\n // sometimes buttons contain content like an icon, and we can't rely on pointer events being disabled\n // so search for a focusable parent\n if (!isInteractive) {\n const focusableParent = element.closest(FOCUSABLE_ELEMENTS.join(','));\n return focusableParent ? interactiveElements.includes(focusableParent.tagName) : false;\n }\n\n return isInteractive;\n}\n\nexport function isElementInsideTable3OrReport(element: Element | null) {\n return !!element?.closest('[data-taco^=table]');\n}\n\nexport function setDataFocusAttribute(target: Element) {\n target.setAttribute('data-focus', 'programmatic');\n\n const cleanup = () => {\n target.removeAttribute('data-focus');\n target.removeEventListener('blur', cleanup);\n };\n\n target.addEventListener('blur', cleanup);\n}\n"],"names":["FOCUSABLE_ELEMENTS","hasFocusableElement","element","querySelector","join","getIndexOfFirstChildOverflowingParent","overscan","index","boundaryChildIndex","clientRect","getBoundingClientRect","_i","_Array$from","Array","from","children","length","child","right","left","width","getNextFocussableElement","currentElement","focussableElements","concat","document","querySelectorAll","currentElementIndex","indexOf","slice","filter","getAttribute","_focussableElements$","_element$checkVisibil","_element$checkVisibil2","checkVisibility","call","getOverlaySelector","id","undefined","isElementTriggeredFromContainer","container","selector","_getOverlaySelector","_element$closest","closest","elementInDocument","isElementInsideOrTriggeredFromContainer","contains","isElementInsideOverlay","isSiblingElementInsideSameParentOverlay","sibling","_element$closest2","isElementInteractive","interactiveElements","isInteractive","includes","tagName","hidden","disabled","readOnly","focusableParent","isElementInsideTable3OrReport","setDataFocusAttribute","target","setAttribute","cleanup","removeAttribute","removeEventListener","addEventListener"],"mappings":"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"}
|
1
|
+
{"version":3,"file":"dom.js","sources":["../../../../../../src/utils/dom.ts"],"sourcesContent":["// taken from react-aria\nconst FOCUSABLE_ELEMENTS = [\n '[tabindex]:not([disabled])',\n 'input:not([disabled])',\n 'select:not([disabled])',\n 'textarea:not([disabled])',\n 'button:not([disabled])',\n 'a[href]',\n 'area[href]',\n 'summary',\n 'iframe',\n 'object',\n 'embed',\n 'audio[controls]',\n 'video[controls]',\n '[contenteditable]',\n 'details:not([disabled])',\n 'summary:not(:disabled)',\n];\n\nexport const hasFocusableElement = (element: HTMLElement | null) => {\n if (!element) {\n return null;\n }\n\n return !!element.querySelector(FOCUSABLE_ELEMENTS.join(','));\n};\n\nexport const isOverflowing = (element: HTMLElement | null) =>\n element !== null ? element.scrollWidth > element.offsetWidth : false;\n\nexport const getIndexOfFirstChildOverflowingParent = (element: HTMLElement, overscan = 0) => {\n let index = 0;\n let boundaryChildIndex: number | null = null;\n const clientRect = element.getBoundingClientRect();\n\n for (const child of Array.from(element.children)) {\n const right = child.getBoundingClientRect().right - clientRect.left;\n const width = clientRect.width - overscan;\n\n if (right > width) {\n boundaryChildIndex = index;\n break;\n }\n index++;\n }\n\n return boundaryChildIndex;\n};\n\nexport const getNextFocussableElement = (currentElement: HTMLElement | null) => {\n if (!currentElement) {\n return null;\n }\n\n let focussableElements = [...document.querySelectorAll<HTMLElement>(FOCUSABLE_ELEMENTS.join(','))];\n const currentElementIndex = focussableElements.indexOf(currentElement);\n\n if (currentElementIndex > -1) {\n focussableElements = focussableElements\n .slice(currentElementIndex + 1)\n .filter(element => element.getAttribute('tabindex') !== '-1');\n\n if (focussableElements.length) {\n focussableElements = focussableElements.filter(element => (element as any).checkVisibility?.() ?? true);\n return focussableElements[0] ?? null;\n }\n }\n\n return null;\n};\n\nconst getOverlaySelector = (element: Element | null) => {\n switch (element?.getAttribute('role')) {\n case 'dialog':\n return `[aria-controls='${element.id}']`;\n\n case 'menu':\n return `#${element.getAttribute('aria-labelledby')}`;\n\n default:\n return undefined;\n }\n};\n\nexport function isElementTriggeredFromContainer(element: Element | null, container: Element | null) {\n const selector = getOverlaySelector(element) ?? getOverlaySelector(element?.closest('[role=dialog],[role=menu]') ?? null);\n\n if (selector) {\n if (container?.querySelector(selector)) {\n return true;\n }\n\n const elementInDocument = document.querySelector(selector);\n\n if (elementInDocument === container) {\n return true;\n }\n\n // if the element does exist, see if it is itself connected to somethng that was triggered from the container\n if (elementInDocument) {\n return isElementTriggeredFromContainer(elementInDocument, container);\n }\n\n return false;\n }\n\n return false;\n}\n\nexport function isElementInsideOrTriggeredFromContainer(element: Element | null, container: Element | null) {\n return isElementTriggeredFromContainer(element, container) || !!container?.contains(element);\n}\n\nexport function isElementInsideOverlay(element: Element | null) {\n return !!element?.closest('[role=dialog],[role=menu]');\n}\n\nexport function isSiblingElementInsideSameParentOverlay(element: Element | null, sibling: Element | null) {\n return !!element?.closest('[role=dialog],[role=menu]')?.contains(sibling);\n}\n\nexport function isElementInteractive(element: Element | null) {\n if (!element) {\n return false;\n }\n\n const interactiveElements = ['A', 'BUTTON', 'INPUT', 'TEXTAREA', 'SELECT', 'LABEL', 'OPTION'];\n\n const isInteractive =\n interactiveElements.includes(element.tagName) &&\n !(element as HTMLElement).hidden &&\n !(element as HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | HTMLButtonElement).disabled &&\n !(element as HTMLInputElement | HTMLTextAreaElement).readOnly;\n\n // sometimes buttons contain content like an icon, and we can't rely on pointer events being disabled\n // so search for a focusable parent\n if (!isInteractive) {\n const focusableParent = element.closest(FOCUSABLE_ELEMENTS.join(','));\n return focusableParent ? interactiveElements.includes(focusableParent.tagName) : false;\n }\n\n return isInteractive;\n}\n\nexport function isElementInsideTable3OrReport(element: Element | null) {\n return !!element?.closest('[data-taco^=table]');\n}\n\nexport function setDataFocusAttribute(target: Element) {\n target.setAttribute('data-focus', 'programmatic');\n\n const cleanup = () => {\n target.removeAttribute('data-focus');\n target.removeEventListener('blur', cleanup);\n };\n\n target.addEventListener('blur', cleanup);\n}\n"],"names":["FOCUSABLE_ELEMENTS","hasFocusableElement","element","querySelector","join","getIndexOfFirstChildOverflowingParent","overscan","index","boundaryChildIndex","clientRect","getBoundingClientRect","_i","_Array$from","Array","from","children","length","child","right","left","width","getNextFocussableElement","currentElement","focussableElements","concat","document","querySelectorAll","currentElementIndex","indexOf","slice","filter","getAttribute","_focussableElements$","_element$checkVisibil","_element$checkVisibil2","checkVisibility","call","getOverlaySelector","id","undefined","isElementTriggeredFromContainer","container","selector","_getOverlaySelector","_element$closest","closest","elementInDocument","isElementInsideOrTriggeredFromContainer","contains","isElementInsideOverlay","isSiblingElementInsideSameParentOverlay","sibling","_element$closest2","isElementInteractive","interactiveElements","isInteractive","includes","tagName","hidden","disabled","readOnly","focusableParent","isElementInsideTable3OrReport","setDataFocusAttribute","target","setAttribute","cleanup","removeAttribute","removeEventListener","addEventListener"],"mappings":"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"}
|
@@ -4363,6 +4363,9 @@ function isElementTriggeredFromContainer(element, container) {
|
|
4363
4363
|
return true;
|
4364
4364
|
}
|
4365
4365
|
var elementInDocument = document.querySelector(selector);
|
4366
|
+
if (elementInDocument === container) {
|
4367
|
+
return true;
|
4368
|
+
}
|
4366
4369
|
// if the element does exist, see if it is itself connected to somethng that was triggered from the container
|
4367
4370
|
if (elementInDocument) {
|
4368
4371
|
return isElementTriggeredFromContainer(elementInDocument, container);
|
@@ -19950,10 +19953,11 @@ function usePendingChangesState(handleSave, handleChange, rowIdentityAccessor, v
|
|
19950
19953
|
var nextChanges = _extends({}, changes, updatesForOtherCells);
|
19951
19954
|
var nextMoveReasons = _extends({}, state.changes.moveReasons[cell.row.id]);
|
19952
19955
|
var nextCellErrors = _extends({}, (_state$changes$errors11 = state.changes.errors[cell.row.id]) === null || _state$changes$errors11 === void 0 ? void 0 : _state$changes$errors11.cells);
|
19953
|
-
// run validation
|
19956
|
+
// run validation - if there are changes, and if there is an original stored
|
19954
19957
|
var validationErrors = {};
|
19955
19958
|
var _temp = function () {
|
19956
|
-
if (validator) {
|
19959
|
+
if (validator && Object.keys(nextChanges).length && state.changes.originals[cell.row.id]) {
|
19960
|
+
// merge with the original so we get a full row
|
19957
19961
|
var nextRowValue = _extends({}, state.changes.originals[cell.row.id], changes, updatesForOtherCells);
|
19958
19962
|
return Promise.resolve(validator(nextRowValue)).then(function (_validator) {
|
19959
19963
|
validationErrors = _validator !== null && _validator !== void 0 ? _validator : {};
|
@@ -20495,20 +20499,28 @@ function EditingControlCell(props) {
|
|
20495
20499
|
if (nextValue !== value) {
|
20496
20500
|
tableMeta.editing.setCellValue(cell, rowIndex, nextValue);
|
20497
20501
|
if (hasNonTextControl) {
|
20498
|
-
|
20502
|
+
requestAnimationFrame(function () {
|
20503
|
+
return tableMeta.editing.onCellChanged(cell, rowIndex, nextValue);
|
20504
|
+
});
|
20499
20505
|
}
|
20500
20506
|
}
|
20501
20507
|
};
|
20502
|
-
|
20508
|
+
function blur() {
|
20503
20509
|
tableMeta.editing.toggleDetailedMode(false);
|
20504
20510
|
tableMeta.editing.onCellChanged(cell, rowIndex, undefined, !hasNonTextControl);
|
20511
|
+
}
|
20512
|
+
var handleBlur = function handleBlur(event) {
|
20513
|
+
if (isElementInsideOrTriggeredFromContainer(event.relatedTarget, event.currentTarget)) {
|
20514
|
+
return;
|
20515
|
+
}
|
20516
|
+
blur();
|
20505
20517
|
};
|
20506
20518
|
// ensure that blur runs when the cell gets unmounted (when vertically arrow key navigating)
|
20507
20519
|
React__default.useEffect(function () {
|
20508
20520
|
var ref = cellRef.current;
|
20509
20521
|
return function () {
|
20510
20522
|
if (document.activeElement === ref || isElementInsideOrTriggeredFromContainer(document.activeElement, ref)) {
|
20511
|
-
|
20523
|
+
blur();
|
20512
20524
|
}
|
20513
20525
|
};
|
20514
20526
|
}, []);
|