bigbuffet-rw/app/soapbox/features/notifications/components/setting-toggle.tsx

35 lines
922 B
TypeScript
Raw Normal View History

2022-05-06 11:03:55 -07:00
import React from 'react';
2022-05-06 12:55:16 -07:00
import { Toggle } from 'soapbox/components/ui';
2022-05-06 11:03:55 -07:00
import type { Map as ImmutableMap } from 'immutable';
interface ISettingToggle {
/** Unique identifier for the Toggle. */
id?: string
2022-05-06 11:03:55 -07:00
/** The full user settings map. */
settings: ImmutableMap<string, any>
2022-05-06 11:03:55 -07:00
/** Array of key names leading into the setting map. */
settingPath: string[]
2022-05-06 11:03:55 -07:00
/** Callback when the setting is toggled. */
onChange: (settingPath: string[], checked: boolean) => void
2022-05-06 11:03:55 -07:00
}
/** 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;