chore: make Preferences' lint happy

This commit is contained in:
CrescentLeaf
2025-10-07 23:05:34 +08:00
parent 4b91bc9dbb
commit 8d7ddd46be
7 changed files with 63 additions and 36 deletions

View File

@@ -1,13 +1,22 @@
import { $ } from 'mdui/jq'
import { Switch } from 'mdui'
import React from 'react'
import useEventListener from '../useEventListener.ts'
export default function SwitchPreference({ title, icon, updater, disabled, description } = {
disabled: false,
}) {
interface Args extends React.HTMLAttributes<HTMLElement> {
title: string
description?: string
icon: string
updater: (value: unknown) => void
defaultState: boolean
disabled?: boolean
}
export default function SwitchPreference({ title, icon, updater, disabled, description, defaultState }: Args) {
const switchRef = React.useRef<Switch>(null)
React.useEffect(() => {
switchRef.current!.checked = defaultState
}, [defaultState])
return <mdui-list-item disabled={disabled ? true : undefined} rounded icon={icon} onClick={() => {
switchRef.current!.checked = !switchRef.current!.checked
updater(switchRef.current!.checked)