SettingToggle: convert to TSX

This commit is contained in:
Alex Gleason 2022-05-06 13:03:55 -05:00
parent 2275a4e3fa
commit 1609118e14
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
3 changed files with 36 additions and 36 deletions

View file

@ -1,35 +0,0 @@
import PropTypes from 'prop-types';
import React from 'react';
import ImmutablePropTypes from 'react-immutable-proptypes';
import ImmutablePureComponent from 'react-immutable-pure-component';
import Toggle from 'soapbox/components/toggle';
export default class SettingToggle extends ImmutablePureComponent {
static propTypes = {
id: PropTypes.string,
prefix: PropTypes.string,
settings: ImmutablePropTypes.map.isRequired,
settingPath: PropTypes.array.isRequired,
onChange: PropTypes.func.isRequired,
}
onChange = ({ target }) => {
this.props.onChange(this.props.settingPath, target.checked);
}
render() {
const { id, settings, settingPath } = this.props;
return (
<Toggle
id={id}
checked={settings.getIn(settingPath)}
onChange={this.onChange}
onKeyDown={this.onKeyDown}
/>
);
}
}

View file

@ -0,0 +1,35 @@
import React from 'react';
import Toggle from 'soapbox/components/toggle';
import type { Map as ImmutableMap } from 'immutable';
interface ISettingToggle {
/** Unique identifier for the Toggle. */
id?: string,
/** The full user settings map. */
settings: ImmutableMap<string, any>,
/** Array of key names leading into the setting map. */
settingPath: string[],
/** Callback when the setting is toggled. */
onChange: (settingPath: string[], checked: boolean) => void,
}
/** Stateful toggle to change user settings. */
const SettingToggle: React.FC<ISettingToggle> = ({ id, settings, settingPath, onChange }) => {
const handleChange: React.ChangeEventHandler<HTMLInputElement> = ({ target }) => {
onChange(settingPath, target.checked);
};
return (
<Toggle
id={id}
checked={!!settings.getIn(settingPath)}
onChange={handleChange}
/>
);
};
export default SettingToggle;

View file

@ -101,7 +101,7 @@ const Preferences = () => {
// dispatch(changeSetting(['defaultContentType'], event.target.value));
// };
const onToggleChange = (key: string, checked: boolean) => {
const onToggleChange = (key: string[], checked: boolean) => {
dispatch(changeSetting(key, checked, intl));
};