waveterm/frontend/app/element/toggle.tsx

47 lines
1.2 KiB
TypeScript
Raw Normal View History

// Copyright 2024, Command Line Inc.
// SPDX-License-Identifier: Apache-2.0
2024-09-11 18:26:43 +02:00
import { useRef } from "react";
import "./toggle.scss";
interface ToggleProps {
checked: boolean;
onChange: (value: boolean) => void;
label?: string;
id?: string;
}
const Toggle = ({ checked, onChange, label, id }: ToggleProps) => {
2024-09-11 18:26:43 +02:00
const inputRef = useRef<HTMLInputElement>(null);
const handleChange = (e: any) => {
if (onChange != null) {
onChange(e.target.checked);
}
};
2024-09-11 18:26:43 +02:00
const handleLabelClick = () => {
if (inputRef.current) {
inputRef.current.click();
}
};
const inputId = id || `toggle-${Math.random().toString(36).substr(2, 9)}`;
return (
<div className="check-toggle-wrapper">
2024-09-11 18:26:43 +02:00
<label htmlFor={inputId} className="checkbox-toggle">
<input id={inputId} type="checkbox" checked={checked} onChange={handleChange} ref={inputRef} />
<span className="slider" />
2024-09-11 18:26:43 +02:00
</label>
{label && (
2024-09-11 18:26:43 +02:00
<span className="toggle-label" onClick={handleLabelClick}>
{label}
2024-09-11 18:26:43 +02:00
</span>
)}
</div>
);
};
export { Toggle };