Библиотека позволяет обмениваться данными в приложениях с модульной архитектурой (module federation), используя событийную модель браузера.
Это особенно актуально для приложений на базе Webpack Module Federation
, обеспечивая взаимодействие без создания жестких зависимостей.
По сути представляет собой EventEmitter
с добавлением методов для
получения последнего отправленного события уже после того, как это событие произошло.
Для того чтобы добавить типизацию событий на проекте, не трогая основной пакет, можно сделать следующее:
constants/event-bus.ts
- заводим ключ, по которому создается шина данных
// constants/event-bus.ts
export const BUS_KEY = 'my-first-bus';
types/event-bus.ts
- определяем типы событий
// types/event-bus.ts
type EventType = 'busValueFirst' | 'busValueSecond'
type EventPayload = string | null
export type EventTypes = Record<EventType, EventPayload>;
types/event-types.d.ts
- добавляем файл для типизации функций getEventBus
и createBus
// types/event-types.d.ts
import type { AbstractAppEventBus } from '@alfalab/client-event-bus';
import { BUS_KEY } from '~/constants/event-bus';
import type { EventTypes } from '~types/event-bus'
export declare type EventBus = AbstractAppEventBus<EventTypes>;
declare module '@alfalab/client-event-bus' {
export declare function getEventBus(busKey: typeof BUS_KEY): EventBus;
}
declare module '@alfalab/client-event-bus' {
export declare function createBus(
key: typeof BUS_KEY,
params?: EventBusParams,
): EventBus;
}
Для именования событий предлагается следующие договоренности:
- Имя события начинается с названия вашего проекта, исключая префикс вашей системы/направления (
corp-
,ufr-
и так далее) и суффикс-ui
. То есть если ваш проект называетсяufr-cards-ui
событие должно начинаться сcards_
,corp-sales-ui
это соответственноsales_
. - Название события пишется в
camelCase
.
Возвращает EventBus
, со следующими методами:
addEventListener(eventName: string, eventHandler: (event: CustomEvent) => void, options?: AddEventListenerOptions)
- стандартная функция добавления подписки на событиеremoveEventListener(eventName: string, eventHandler: (event: CustomEvent) => void, options?: EventListenerOptions)
- стандартная функция удаления подписки на событиеgetLastEventDetail(eventName: string)
- Функция, которая возвращает последнее событие заданного типа. Если событие еще не происходило - возвращаетundefined
addEventListenerAndGetLast(eventName: string, eventHandler: (event: CustomEvent) => void, options?: AddEventListenerOptions)
- объединяет в себеaddEventListener
иgetLastEvent
. Подписывает на событие и возвращает последнее событие этого типа
Если вам нужно использовать значение из event-bus в react коде - вы можете использовать хук useEventBusValue
:
import { useEventBusValue } from '@alfalab/client-event-bus';
const MyComponent = () => {
const currentOrganizationId = useEventBusValue('shared_currentOrganizationId');
return (
<div>
ID текущей организации: {currentOrganizationId}
</div>
)
}
Хук всегда будет возвращать последнее значение из eventBus. При изменениях значения будет происходить ререндер.