PromucFlow_constructor/app/client/src/components/propertyControls/MultiSelectControl.tsx
Aswath K 9597c82f7c
feat: keyboard accessible multi-select dropdown, action selector and text input (#10622)
* feat: Add keyboard navigation to multiselect dropdown (#10397)

* feat: Make Action Selector keyboard accessible (#10005)

* feat: keyboard accessible text / code input (#10641)

* {Space} as an alternate option to make code editor editable
2022-02-10 16:42:44 +05:30

49 lines
1.2 KiB
TypeScript

import React from "react";
import BaseControl, { ControlProps } from "./BaseControl";
import _ from "lodash";
import { DropdownOption } from "components/ads/Dropdown";
import { StyledMultiSelectDropDown } from "./StyledControls";
class MultiSelectControl extends BaseControl<MultiSelectControlProps> {
render() {
const selectedItems: string[] = [];
_.map(this.props.propertyValue, (value) => {
const option = _.find(this.props.options, (option) => {
return option.value === value;
});
if (option) selectedItems.push(option.value as string);
return option;
});
return (
<StyledMultiSelectDropDown
onSelect={this.onItemSelect}
optionWidth="260px"
options={this.props.options}
selectAll
selectAllQuantifier="*"
selected={selectedItems}
showLabelOnly
width="100%"
/>
);
}
onItemSelect = (value: string[]): void => {
this.updateProperty(this.props.propertyName, value);
};
static getControlType() {
return "MULTI_SELECT";
}
}
export interface MultiSelectControlProps extends ControlProps {
options: DropdownOption[];
placeholderText: string;
propertyValue: string[];
}
export default MultiSelectControl;