Skip to content
On this page

Farfetched and React

To use Farfetched with React, you need to install React-bindings Effector:

sh
pnpm install effector-react
sh
yarn add effector-react
sh
npm install effector-react

TIP

Farfetched uses Effector under the hood to handle reactive states and its relations. It is the reason, why you can reuse Effector's binding for React to work with Farfetched.

useUnit(query)

To subscribe on Query and get its state, you can use useUnit from effector-react:

tsx
import { useUnit } from 'effector-react';

function UserProfile() {
  const { data: user, pending } = useUnit(userQuery);

  if (pending) {
    return <Loader />;
  }

  return (
    <section>
      <p>{user.name}</p>
      <p>{user.email}</p>
      //...
    </section>
  );
}

useUnit(mutation)

To start Mutation, you can use useUnit from effector-react as well:

tsx
import { useUnit } from 'effector-react';

function UserProfile() {
  const { start: deleteAccount, pending: deletionInProgress } = useUnit(deleteAccountMutation);

  return (
    <section>
      //...
      <button disabled={deletionInProgress} onClick={deleteAccount}>
        Delete my account
      </button>
    </section>
  );
}

Released under the MIT License.