From 82401b4d3da77c6881ac8c9183aa4512dc536d24 Mon Sep 17 00:00:00 2001 From: Alexander Rose <alexander.rose@weirdbyte.de> Date: Mon, 11 Feb 2019 07:56:30 -0800 Subject: [PATCH] chache mappedcontrols --- src/mol-plugin/ui/controls/parameters.tsx | 16 ++++++++++++++-- 1 file changed, 14 insertions(+), 2 deletions(-) diff --git a/src/mol-plugin/ui/controls/parameters.tsx b/src/mol-plugin/ui/controls/parameters.tsx index 0674d2c1e..7d26c184c 100644 --- a/src/mol-plugin/ui/controls/parameters.tsx +++ b/src/mol-plugin/ui/controls/parameters.tsx @@ -410,16 +410,28 @@ export class GroupControl extends React.PureComponent<ParamProps<PD.Group<any>>, } export class MappedControl extends React.PureComponent<ParamProps<PD.Mapped<any>>> { + private valuesCache: { [name: string]: PD.Values<any> } = {} + private setValues(name: string, values: PD.Values<any>) { + this.valuesCache[name] = values + } + private getValues(name: string) { + if (name in this.valuesCache) { + return this.valuesCache[name] + } else { + return this.props.param.map(name).defaultValue + } + } + change(value: PD.Mapped<any>['defaultValue'] ) { this.props.onChange({ name: this.props.name, param: this.props.param, value }); } onChangeName: ParamOnChange = e => { - // TODO: Cache values when changing types? - this.change({ name: e.value, params: this.props.param.map(e.value).defaultValue }); + this.change({ name: e.value, params: this.getValues(e.value) }); } onChangeParam: ParamOnChange = e => { + this.setValues(this.props.value.name, e.value) this.change({ name: this.props.value.name, params: e.value }); } -- GitLab