From 79e1b0c5d8a950a0a36a508a9e38e7d2b540046c Mon Sep 17 00:00:00 2001 From: Aditya Toshniwal Date: Fri, 9 Jul 2021 10:26:02 +0530 Subject: [PATCH] Added field key - optionsReloadBasis to allow options to be re-loaded. Add formatters to select and input control. --- .../static/js/SchemaView/MappedControl.jsx | 2 +- .../static/js/components/FormComponents.jsx | 29 +++++++++++++++---- 2 files changed, 24 insertions(+), 7 deletions(-) diff --git a/web/pgadmin/static/js/SchemaView/MappedControl.jsx b/web/pgadmin/static/js/SchemaView/MappedControl.jsx index 182519054..f7a49e359 100644 --- a/web/pgadmin/static/js/SchemaView/MappedControl.jsx +++ b/web/pgadmin/static/js/SchemaView/MappedControl.jsx @@ -158,7 +158,7 @@ MappedCellControlBase.propTypes = { const ALLOWED_PROPS_FIELD_COMMON = [ 'mode', 'value', 'readonly', 'disabled', 'hasError', 'id', 'label', 'options', 'optionsLoaded', 'controlProps', 'schema', 'inputRef', - 'visible', 'autoFocus', 'helpMessage', 'className' + 'visible', 'autoFocus', 'helpMessage', 'className', 'optionsReloadBasis' ]; const ALLOWED_PROPS_FIELD_FORM = [ diff --git a/web/pgadmin/static/js/components/FormComponents.jsx b/web/pgadmin/static/js/components/FormComponents.jsx index 2c63c98be..4219b5b9d 100644 --- a/web/pgadmin/static/js/components/FormComponents.jsx +++ b/web/pgadmin/static/js/components/FormComponents.jsx @@ -181,6 +181,18 @@ export const InputText = forwardRef(({ const classes = useStyles(); + let onChangeFinal = (changeVal)=>{ + if(controlProps?.formatter) { + changeVal = controlProps.formatter.toRaw(changeVal); + } + onChange && onChange(changeVal); + } + + let finalValue = (_.isNull(value) || _.isUndefined(value)) ? '' : value; + if(controlProps?.formatter) { + finalValue = controlProps.formatter.fromRaw(finalValue); + } + return( @@ -536,7 +548,7 @@ function getRealValue(options, value, creatable, formatter) { realValue = [...value]; /* If multi select options need to be in some format by UI, use formatter */ if(formatter) { - realValue = formatter.toSelect(realValue); + realValue = formatter.fromRaw(realValue); } if(creatable) { realValue = realValue.map((val)=>({label:val, value: val})); @@ -550,10 +562,15 @@ function getRealValue(options, value, creatable, formatter) { } export function InputSelect({ - cid, onChange, options, readonly=false, value, controlProps={}, optionsLoaded, disabled, ...props}) { + cid, onChange, options, readonly=false, value, controlProps={}, optionsLoaded, optionsReloadBasis, disabled, ...props}) { const [[finalOptions, isLoading], setFinalOptions] = useState([[], true]); const theme = useTheme(); + /* React will always take options var as changed parameter. So, + We cannot run the below effect with options dependency as it will keep on + loading the options. optionsReloadBasis is helpful to avoid repeated + options load. If optionsReloadBasis value changes, then options will be loaded again. + */ useEffect(()=>{ let optPromise = options, umounted=false; if(typeof options === 'function') { @@ -568,14 +585,14 @@ export function InputSelect({ } }); return ()=>umounted=true; - }, []); + }, [optionsReloadBasis]); const onChangeOption = useCallback((selectVal, action)=>{ if(_.isArray(selectVal)) { /* If multi select options need to be in some format by UI, use formatter */ selectVal = selectVal.map((option)=>option.value); if(controlProps.formatter) { - selectVal = controlProps.formatter.fromSelect(selectVal); + selectVal = controlProps.formatter.toRaw(selectVal); } onChange && onChange(selectVal, action.name); } else {