Files
oranguru/src/Griddy/editors/CheckboxEditor.tsx
Hein 635da0ea18 feat(pagination): add server-side pagination support and controls
- Implement pagination control UI with page navigation and size selector
- Enable server-side callbacks for page changes and size adjustments
- Integrate pagination into Griddy component with data count handling
2026-02-14 14:43:36 +02:00

44 lines
1.0 KiB
TypeScript

import { Checkbox } from '@mantine/core'
import { useEffect, useState } from 'react'
import type { BaseEditorProps } from './types'
export function CheckboxEditor({ autoFocus = true, onCancel, onCommit, onMoveNext, onMovePrev, value }: BaseEditorProps<boolean>) {
const [checked, setChecked] = useState(Boolean(value))
useEffect(() => {
setChecked(Boolean(value))
}, [value])
const handleKeyDown = (e: React.KeyboardEvent) => {
if (e.key === 'Enter') {
e.preventDefault()
onCommit(checked)
} else if (e.key === 'Escape') {
e.preventDefault()
onCancel()
} else if (e.key === 'Tab') {
e.preventDefault()
onCommit(checked)
if (e.shiftKey) {
onMovePrev?.()
} else {
onMoveNext?.()
}
} else if (e.key === ' ') {
e.preventDefault()
setChecked(!checked)
}
}
return (
<Checkbox
autoFocus={autoFocus}
checked={checked}
onChange={(e) => setChecked(e.currentTarget.checked)}
onKeyDown={handleKeyDown}
size="xs"
/>
)
}