Collection of React user-experience hooks + containers for common interactions
yarn add actionsack
🎣
hook
Takes any function and gives you a loading and error state. Good for handling general asynchronous interactions.
import { useAsyncCallback } from 'actionsack'
function MyAsyncButton(props) {
const [onClick, { loading, error, data }] = useAsyncCallback(props.onClick)
return (
<>
{error && <span>{error}!</span>}
<button onClick={onClick}>{loading ? 'Saving...' : 'Save'}</button>
{data && <span>Success! {data}</span>}
</>
)
}
🎣
hook
Pass it a keyboard key and a handler to automatically listen for keyboard clicks.
import { useKeyboardListener } from 'actionsack'
function Modal(props) {
useKeyboardListener('Escape', props.onClose)
return <div>Hello World</div>
}
hook
🎣
Hook that gives you a temporary state value that you can either commit with submit
or revert with reset
.
import { useTempValue } from 'actionsack'
function MyForm(props) {
const initialName = props.name
const { hasChanged, value, onInputChange, submit, reset } = useTempValue(initialName)
return (
<form onSubmit={e => e.preventDefault()}>
<input value={value || ''} onChange={onInputChange} />
<button disabled={!hasChanged} onClick={submit}>
Submit
</button>
<button disabled={!hasChanged} onClick={reset}>
Cancel
</button>
</form>
)
}
hook
🎣
Creates an onClick
handler that copies the text you pass in, and updates the copied
field accordingly.
Note: you must pass onClick
to a <button>
in order to copy the text.
For more information about options
, see API.
import { useCopyTextHandler } from 'actionsack'
const options = {
interval: 2 * 1000, // 2 seconds
format: "text/html",
}
function MyCopyButton() {
const { onClick, copied } = useCopyTextHandler('https://github.com/mfix22/actionsack', options)
return <button onClick={onClick}>{copied ? 'COPIED!' : 'Copy URL'}</button>
}
hook
🎣
Subscribes to whether the network is online or off
import { useOnline } from 'actionsack'
function MyComponent() {
const online = useOnline()
return <span>You are {online ? 'online' : 'offline'}</span>
}
Show children after a certain amount of time, for a certain amount of time.
import { TimeWindow } from 'actionsack'
function MyMessage() {
return (
<TimeWindow showAfter={3000} showUntil={6000}>
Timed Message!
</TimeWindow>
)
}
wrapper HOC
component
Class controlled Modal component with click-away and ESC-key to close
import {Modal} from 'actionsack'
<Modal open={this.state.open} onClickAway={() => this.setState({ open: false})}>
<form>
<input placeholder="Enter name here . . ." />
</form>
</>
MIT