This repository has been archived on 2024-11-20. You can view files and clone it, but cannot push or open issues or pull requests.

53 lines
887 B
TypeScript
Raw Permalink Normal View History

2024-02-16 22:51:50 +01:00
import { useState } from "react"
export interface UseBooleanResult {
value: boolean
2024-05-02 01:08:27 +02:00
setValue: React.Dispatch<React.SetStateAction<boolean>>
2024-02-16 22:51:50 +01:00
setTrue: () => void
setFalse: () => void
2024-05-02 01:08:27 +02:00
toggle: () => void
2024-02-16 22:51:50 +01:00
}
export interface UseBooleanOptions {
/**
* The initial value of the boolean.
* @default false
*/
initialValue?: boolean
}
/**
* Hook to manage a boolean state.
* @param options
* @returns
*/
export const useBoolean = (
options: UseBooleanOptions = {},
): UseBooleanResult => {
const { initialValue = false } = options
const [value, setValue] = useState(initialValue)
const toggle = (): void => {
setValue((old) => {
return !old
})
}
const setTrue = (): void => {
setValue(true)
}
const setFalse = (): void => {
setValue(false)
}
return {
value,
2024-05-02 01:08:27 +02:00
setValue,
2024-02-16 22:51:50 +01:00
toggle,
setTrue,
setFalse,
}
}