UNPKG

@adaptabletools/adaptable-cjs

Version:

Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements

65 lines (64 loc) 3.82 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.BulkUpdateValueSelector = void 0; const tslib_1 = require("tslib"); const React = tslib_1.__importStar(require("react")); const FieldWrap_1 = tslib_1.__importDefault(require("../../../components/FieldWrap")); const UIHelper_1 = tslib_1.__importDefault(require("../../UIHelper")); const AdaptableInput_1 = tslib_1.__importDefault(require("../AdaptableInput")); const rebass_1 = require("rebass"); const PermittedValuesSelector_1 = require("./PermittedValuesSelector"); const Select_1 = require("../../../components/Select"); const AdaptableContext_1 = require("../../AdaptableContext"); const react_1 = require("react"); const BulkUpdateValueSelector = (props) => { const [valueType, setValueType] = React.useState('existing'); const adaptable = (0, AdaptableContext_1.useAdaptable)(); const columnDataType = props.selectedColumn?.dataType; const isDateType = props.selectedColumn && columnDataType === 'date'; const columnId = props.selectedColumn?.columnId; // TODO = this seems to be called whenever we edit a cell // which is then triggering a get all values // not sure that we need to const permittedValueSelector = (React.createElement(rebass_1.Box, null, React.createElement(PermittedValuesSelector_1.PermittedValuesSelector, { allowNewValues: true, searchable: 'inline', disabled: props.disabled || !props.selectedColumn, value: props.selectedColumnValue === '' ? null : props.selectedColumnValue, columnId: columnId, placeholder: isDateType ? 'Select' : 'Select or type new value', loadValues: (0, react_1.useCallback)(({ currentSearchValue }) => { if (!columnId || !props.selectedGridCells.length) { return Promise.resolve([]); } return adaptable.api.gridApi.internalApi.getDistinctEditDisplayValuesForColumn({ columnId, gridCell: props.selectedGridCells[0], currentSearchValue, }); }, [ columnId, props.selectedGridCells?.[0]?.column.columnId, props.selectedGridCells?.[0]?.primaryKeyValue, ]), onChange: (value) => { props.onColumnValueChange(value || null); } }))); const input = (React.createElement(AdaptableInput_1.default, { "data-name": "bulkupdate-value-input", "aria-label": "Bulk Update Value Input", type: props.selectedColumn ? UIHelper_1.default.getDescriptionForDataType(props.selectedColumn.dataType) : 'text', placeholder: props.selectedColumn ? UIHelper_1.default.getPlaceholderForDataType(props.selectedColumn.dataType) : 'Enter Value', autoFocus: true, disabled: props.disabled, style: { width: '100%' }, value: props.selectedColumnValue, onChange: (e) => { props.onColumnValueChange(e.target.value); } })); let valueTypeSelector = null; if (isDateType) { valueTypeSelector = (React.createElement(Select_1.Select, { "aria-label": "Bulk Update Value Selector", options: [ { label: 'New', value: 'new' }, { label: 'Existing', value: 'existing' }, ], value: valueType, onChange: (value) => { setValueType(value); } })); } return (React.createElement(FieldWrap_1.default, { className: props.className, style: { ...props.style, overflow: 'visible', maxWidth: '100%', } }, isDateType ? (React.createElement(React.Fragment, null, valueType === 'new' ? input : permittedValueSelector, valueTypeSelector)) : (permittedValueSelector))); }; exports.BulkUpdateValueSelector = BulkUpdateValueSelector;