mirror of
https://github.com/router-for-me/Cli-Proxy-API-Management-Center.git
synced 2026-02-18 02:30:51 +08:00
49 lines
1.1 KiB
TypeScript
49 lines
1.1 KiB
TypeScript
import type { ChangeEvent, ReactNode } from 'react';
|
|
import styles from './ToggleSwitch.module.scss';
|
|
|
|
interface ToggleSwitchProps {
|
|
checked: boolean;
|
|
onChange: (value: boolean) => void;
|
|
label?: ReactNode;
|
|
ariaLabel?: string;
|
|
disabled?: boolean;
|
|
labelPosition?: 'left' | 'right';
|
|
}
|
|
|
|
export function ToggleSwitch({
|
|
checked,
|
|
onChange,
|
|
label,
|
|
ariaLabel,
|
|
disabled = false,
|
|
labelPosition = 'right'
|
|
}: ToggleSwitchProps) {
|
|
const handleChange = (event: ChangeEvent<HTMLInputElement>) => {
|
|
onChange(event.target.checked);
|
|
};
|
|
|
|
const className = [
|
|
styles.root,
|
|
labelPosition === 'left' ? styles.labelLeft : '',
|
|
disabled ? styles.disabled : '',
|
|
]
|
|
.filter(Boolean)
|
|
.join(' ');
|
|
|
|
return (
|
|
<label className={className}>
|
|
<input
|
|
type="checkbox"
|
|
checked={checked}
|
|
onChange={handleChange}
|
|
disabled={disabled}
|
|
aria-label={ariaLabel}
|
|
/>
|
|
<span className={styles.track}>
|
|
<span className={styles.thumb} />
|
|
</span>
|
|
{label && <span className={styles.label}>{label}</span>}
|
|
</label>
|
|
);
|
|
}
|