/react-async-hooks

Tame the async beast with the power of React Hooks!

Primary LanguageTypeScriptMIT LicenseMIT

Async Hooks for React

Tame that async beast right with the power of React Hooks!

NPM version Build Status

Installation

Add @mariosant/react-async-hooks to your package.json.

$ npm install @mariosant/react-async-hooks

# or
$ yarn add @mariosant/react-async-hooks

You can now import the module and use it like

import {useAsync, useAsyncTrigger} from '@mariosant/react-async-hooks';

Usage

The module consists of two different hooks, useAsync and useAsyncTrigger. The reason for that is, this way you can easily pick when the hook is going to be executed.

useAsync

useAsync(fn, deps) will execute the provided async function as soon as the component renders.

import {useAsync} from '@mariosant/react-async-hooks';

const fetchAsyncFn = async () => {
	// do something async
};

const Component = props => {
	const [{pending, data, error}, {reload}] = useAsync(fetchAsyncFn, []);

	return <div>...</div>;
};

useAsyncTrigger

useAsyncTrigger(fn) is very similar to useAsync, but instead the action will be invoked imperitevely.

import {useAsyncTrigger} from '@mariosant/react-async-hooks';

const fetchAsyncFn = async () => {
	// do something async
};

const Component = props => {
	const [{pending, data, error}, {trigger] = useAsyncTrigger(fetchAsyncFn);

	return (
		<div>
			...
			<button onClick={trigger}>Click me</button>
			...
		</div>
	);
};

Meta

Marios Antonoudiou – @marios_antmariosant@sent.com

Distributed under the MIT license.

https://github.com/mariosant/react-async-hooks

Contributing

  1. Fork it (https://github.com/mariosant/react-async-hooks/fork)
  2. Create your feature branch (git checkout -b feature/fooBar)
  3. Commit your changes using a semantic commit message.
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a new Pull Request