[MM-52833]: Migrate "components/admin_console/multiselect_settings.jsx" to Typescript (#23542)

This commit is contained in:
Judy Hanson 2023-06-06 00:21:36 -07:00 committed by GitHub
parent e4982908d6
commit 8690da4b0d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 34 additions and 25 deletions

View File

@ -1,39 +1,50 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import PropTypes from 'prop-types';
import React from 'react';
import ReactSelect from 'react-select';
import ReactSelect, {ValueType} from 'react-select';
import FormError from 'components/form_error';
import Setting from './setting';
export default class MultiSelectSetting extends React.PureComponent {
static propTypes = {
id: PropTypes.string.isRequired,
values: PropTypes.array.isRequired,
label: PropTypes.node.isRequired,
selected: PropTypes.array.isRequired,
onChange: PropTypes.func.isRequired,
disabled: PropTypes.bool,
setByEnv: PropTypes.bool.isRequired,
helpText: PropTypes.node,
noResultText: PropTypes.node,
};
interface Option {
value: string;
text: string;
}
static defaultProps = {
interface Props {
id: string;
values: Option[];
label: React.ReactNode;
selected: string[];
onChange: (id: string, values: string[]) => void;
disabled?: boolean;
setByEnv: boolean;
helpText?: React.ReactNode;
noResultText?: React.ReactNode;
}
interface State {
error: boolean;
}
export default class MultiSelectSetting extends React.PureComponent<
Props,
State
> {
static defaultProps: Partial<Props> = {
disabled: false,
};
constructor(props) {
constructor(props: Props) {
super(props);
this.state = {error: false};
}
handleChange = (newValue) => {
const values = newValue.map((n) => {
handleChange = (newValue: ValueType<Option>) => {
const values = (newValue as Option[]).map((n) => {
return n.value;
});
@ -42,18 +53,16 @@ export default class MultiSelectSetting extends React.PureComponent {
};
calculateValue = () => {
return this.props.selected.reduce((values, item) => {
const found = this.props.values.find((e) => {
return e.value === item;
});
if (found !== null) {
return this.props.selected.reduce<Option[]>((values, item) => {
const found = this.props.values.find((e) => e.value === item);
if (found) {
values.push(found);
}
return values;
}, []);
};
getOptionLabel = ({text}) => text;
getOptionLabel = ({text}: { text: string}) => text;
render() {
return (

View File

@ -17,7 +17,7 @@ import RequestButton from 'components/admin_console/request_button/request_butto
import BooleanSetting from 'components/admin_console/boolean_setting';
import TextSetting from 'components/admin_console/text_setting';
import DropdownSetting from 'components/admin_console/dropdown_setting.jsx';
import MultiSelectSetting from 'components/admin_console/multiselect_settings.jsx';
import MultiSelectSetting from 'components/admin_console/multiselect_settings';
import RadioSetting from 'components/admin_console/radio_setting';
import ColorSetting from 'components/admin_console/color_setting';
import GeneratedSetting from 'components/admin_console/generated_setting';