mirror of https://github.com/portainer/portainer
74 lines
1.5 KiB
TypeScript
74 lines
1.5 KiB
TypeScript
import clsx from 'clsx';
|
|
|
|
import { FeatureId } from '@/portainer/feature-flags/enums';
|
|
|
|
import { Tooltip } from '@@/Tip/Tooltip';
|
|
|
|
import styles from './SwitchField.module.css';
|
|
import { Switch } from './Switch';
|
|
|
|
export interface Props {
|
|
label: string;
|
|
checked: boolean;
|
|
onChange(value: boolean): void;
|
|
|
|
name?: string;
|
|
tooltip?: string;
|
|
labelClass?: string;
|
|
switchClass?: string;
|
|
dataCy?: string;
|
|
disabled?: boolean;
|
|
featureId?: FeatureId;
|
|
switchValues?: {
|
|
on: string;
|
|
off: string;
|
|
};
|
|
}
|
|
|
|
export function SwitchField({
|
|
tooltip,
|
|
checked,
|
|
label,
|
|
name,
|
|
labelClass,
|
|
dataCy,
|
|
disabled,
|
|
onChange,
|
|
featureId,
|
|
switchValues,
|
|
switchClass,
|
|
}: Props) {
|
|
const toggleName = name ? `toggle_${name}` : '';
|
|
|
|
return (
|
|
<label className={styles.root}>
|
|
<span
|
|
className={clsx(
|
|
'control-label text-left space-right',
|
|
styles.label,
|
|
labelClass
|
|
)}
|
|
>
|
|
{label}
|
|
{tooltip && <Tooltip message={tooltip} />}
|
|
</span>
|
|
<Switch
|
|
className={clsx('space-right', switchClass)}
|
|
name={toggleName}
|
|
id={toggleName}
|
|
checked={checked}
|
|
disabled={disabled}
|
|
onChange={onChange}
|
|
featureId={featureId}
|
|
dataCy={dataCy}
|
|
/>
|
|
{switchValues && checked && (
|
|
<span className="ml-2">{switchValues.on}</span>
|
|
)}
|
|
{switchValues && !checked && (
|
|
<span className="ml-2">{switchValues.off}</span>
|
|
)}
|
|
</label>
|
|
);
|
|
}
|