mirror of
https://github.com/outline/outline.git
synced 2025-12-30 15:30:12 -06:00
This PR moves the entire project to Typescript. Due to the ~1000 ignores this will lead to a messy codebase for a while, but the churn is worth it – all of those ignore comments are places that were never type-safe previously. closes #1282
24 lines
541 B
TypeScript
24 lines
541 B
TypeScript
import * as React from "react";
|
|
|
|
type InitialState = boolean | (() => boolean);
|
|
|
|
/**
|
|
* React hook to manage booleans
|
|
*
|
|
* @param initialState the initial boolean state value
|
|
*/
|
|
export default function useBoolean(
|
|
initialState: InitialState = false
|
|
): [boolean, () => void, () => void] {
|
|
const [value, setValue] = React.useState(initialState);
|
|
const setTrue = React.useCallback(() => {
|
|
setValue(true);
|
|
}, []);
|
|
|
|
const setFalse = React.useCallback(() => {
|
|
setValue(false);
|
|
}, []);
|
|
|
|
return [value, setTrue, setFalse];
|
|
}
|