react-sink
v1.3.1
Published
A classy kitchen sink for all react pieces daily used - not the ordinary.
Downloads
4
Readme
react sink
A classy kitchen sink for all react pieces daily used - not the ordinary.
Install
yarn
yarn add react-sink
npm
npm i react-sink
Components
<AsyncContent/>
import { Conditional } from 'react-sink'
function MyComponent({ isLoading, isError }) {
return (
<AsyncContent isLoading={ isLoading } isError={ isLoading }>
rendered when complete
</AsyncContent>
)
}
<Conditional/>
import { Conditional } from 'react-sink'
function MyComponent({ flag }) {
return (
<Conditional condition={ flag }>
rendered when true
</Conditional>
)
}
<ConditionalWrapper/>
import {ConditionalWrapper} from 'react-sink'
function MyComponent({flag}) {
return (
<ConditionalWrapper condition={true} wrapper={(children: ReactNode) => <h1>{children}</h1>}>
rendered for truthy condition
</ConditionalWrapper>
)
}
Hooks
useAllBoolean
import { useAllBoolean } from 'react-sink'
function MyComponent() {
const expectAllTrueWillBeFalse = useAllBoolean({ hello: true, world: false })
const expectAllTrueWillBeTrue = useAllBoolean({ hello: true, world: true })
const expectAllFalseWillBeFalse = useAllBoolean({ hello: false, world: false }, false)
}
usePeriodicCallback
import {useCallback} from "react";
import {usePeriodicCallback} from 'react-sink'
function MyComponent() {
const callback = useCallback(()=> console.log("called!"), [])
const result = usePeriodicCallback(callback, 100)
}
useWindowSize
import {useWindowSize} from 'react-sink'
function MyComponent() {
const { width, height } = useWindowSize()
}
useAbortOnUnmount
import {useAbortOnUnmount} from 'react-sink'
function MyComponent() {
const abortSignal = useAbortOnUnmount()
}