LogoLogo
  • Eventrix
  • Introduction
    • Installation
    • Quick start
    • Getting started
    • Demo
    • About
  • Devtools - EventrixDebugger
  • Use cases
    • Handle errors
    • Simple form management
    • Communication between components
    • Next.js
    • Basic setup on project
    • Fetch list and display in component
  • CONTEXT
    • EventrixProvider
    • PersistStoreGate
    • EventrixScope
  • MIGRATION
    • Redux -> Eventrix
  • Receivers
    • EventsReceiver
    • RequestsHandler
    • fetchToStateReceiver
    • fetchStateReceiver
    • fetchHandler
  • HOC
    • withEventrix
    • withEventrixState
  • HOOKS
    • useEventrixState
    • useEmit
    • useEvent
    • useEventState
    • useFetchToState
    • useReceiver
    • useFetchState
  • CLASS DECORATORS
    • @useEventrix
    • @receiver
    • @fetchToState
    • @listener
  • COMPONENT DECORATORS
    • @eventrixComponent
    • @eventListener
    • @stateListener
    • @eventrixState
Powered by GitBook
On this page

Was this helpful?

  1. HOOKS

useEvent

This hook listen on emit required event.

If You want use hooks, hocs or component decorator You must use EventrixProvider in Your application. Go to "EventrixProvider" page in "Context" section for more details.

import React, { useState, useCallback } from 'react';
import { useEvent, useEmit } from 'eventrix';

const UndoDeleteUserButton = () => {
    const [removedUser, setRemovedUser] = useState();
    const emit = useEmit();
    useEvent('removeUser', (eventData) => {
        const user = eventData;
        setRemovedUser(user);
    });
    const addUser = useCallback(() => {
        emit('addUser', removedUser);
        setRemovedUser(null);
    }, [emit, removedUser, setRemovedUser]);
    
    if (!removedUser) {
        return null;
    }
    return (
        <button onClick={addUser}>
            Undo user delete
        </button>
    );
}
import { useEvent, useEmit } from 'eventrix';
import { User } from './interfaces';

const UndoDeleteUserButton = () => {
    const [removedUser, setRemovedUser] = useState<User | null>();
    const emit = useEmit<User>();
    useEvent('removeUser', (eventData: User) => {
        const user = eventData;
        setRemovedUser(user);
    });
    const addUser = useCallback(() => {
        if (removedUser) {
            emit('addUser', removedUser);
            setRemovedUser(null);
        }
    }, [emit, removedUser, setRemovedUser]);
    
    if (!removedUser) {
        return null;
    }
    return (
        <button onClick={addUser}>
            Undo user delete
        </button>
    );
}
PrevioususeEmitNextuseEventState

Last updated 3 years ago

Was this helpful?