@adaptabletools/adaptable
Version:
Powerful data-agnostic HTML5 AG Grid extension which provides advanced, cutting-edge functionality to meet all DataGrid requirements
65 lines (64 loc) • 3.37 kB
JavaScript
import * as React from 'react';
import { useState } from 'react';
import { Box } from 'rebass';
import { OnePageAdaptableWizard, OnePageWizardSummary } from '../../Wizard/OnePageAdaptableWizard';
import { cloneObject } from '../../../Utilities/Helpers/Helper';
import { FreeTextColumnSettingsWizardSection, isValidFreeTextColumn, renderFreeTextColumnSummary, } from './FreeTextColumnSettingsWizardSection';
import ObjectFactory from '../../../Utilities/ObjectFactory';
import * as FreeTextColumnRedux from '../../../Redux/ActionsReducers/FreeTextColumnRedux';
import { useDispatch, useSelector } from 'react-redux';
import { ObjectTagsWizardSection, renderObjectTagsSummary, } from '../../Wizard/ObjectTagsWizardSection';
import { useAdaptable } from '../../AdaptableContext';
export const FreeTextColumnWizard = (props) => {
const adaptable = useAdaptable();
const allFreeTextColumns = useSelector((state) => state.FreeTextColumn.FreeTextColumns);
const [freeTextColumn, setFreeTextColumn] = useState(() => {
if (props.data) {
return cloneObject(props.data);
}
if (props.popupParams?.action === 'Edit' && props.popupParams?.column) {
return allFreeTextColumns.find((column) => column.ColumnId === props.popupParams.column.columnId);
}
return ObjectFactory.CreateEmptyFreeTextColumn(adaptable.api.gridApi.internalApi.deriveSpecialColumnSettingsFromAgGridDefaultColDef());
});
const dispatch = useDispatch();
const isEdit = props.data || props.popupParams?.action === 'Edit';
const handleFinish = () => {
if (isEdit) {
dispatch(FreeTextColumnRedux.FreeTextColumnEdit(freeTextColumn));
}
else {
dispatch(FreeTextColumnRedux.FreeTextColumnAdd(freeTextColumn));
}
props.onFinishWizard(freeTextColumn);
};
return (React.createElement(OnePageAdaptableWizard, { defaultCurrentSectionName: props.defaultCurrentSectionName, moduleInfo: props.moduleInfo, data: freeTextColumn, onHide: props.onCloseWizard, onFinish: handleFinish, sections: [
{
title: 'Settings',
details: 'Configure the Free Text Column',
isValid: isValidFreeTextColumn,
render: () => {
return (React.createElement(Box, { padding: 2 },
React.createElement(FreeTextColumnSettingsWizardSection, { isEdit: Boolean(props.data), onChange: setFreeTextColumn })));
},
},
{
details: 'Select Free Text Column Tags',
title: 'Tags',
isVisible: (_, api) => api.internalApi.shouldDisplayTagSections(),
render: () => (React.createElement(Box, { padding: 2 },
React.createElement(ObjectTagsWizardSection, { onChange: setFreeTextColumn }))),
renderSummary: renderObjectTagsSummary,
},
'-',
{
details: 'Review the Free Text Column',
renderSummary: renderFreeTextColumnSummary,
render: () => {
return (React.createElement(Box, { padding: 2 },
React.createElement(OnePageWizardSummary, null)));
},
title: 'Summary',
},
] }));
};