A library that allows you to easily manage components that ultimately return a value as a Promise
.
This is a simple wrapper that provided the context
to resolve or reject the Promise
.
This abstract component is designed for dialogs, popups, modals, toasts, dynamic messages, notifications, etc.
It is all up to you.
npm install @piotar/react-promise-bridge
- lightweight, no additional dependencies
- multiple instances and mulitple containers
- nested containers and nested entries
- containers can be placed anywhere in other application contexts
- no additional properties, based on
context
- different types of strategies to create a
Promise
entry - does not require additional changes to existing components, just use the context of the
Promise Bridge
- support
AbortSignal
- function call to open a bridge, works both inside and outside
React
components
- Import and create container with invoke function of
Promise Bridge
// ./SystemPromiseBridge.tsx
import { PromiseBridge } from '@piotar/react-promise-bridge';
// the name of the container and function depends on you
export const [Container, open] = PromiseBridge.create();
- Put Container of
Promise Bridge
wherever you want in the domReact
or mount in directly onDOM
// ./main.tsx
import React from 'react';
import ReactDOM from 'react-dom/client';
import { App } from './App';
import { Container } from './SystemPromiseBridge';
ReactDOM.createRoot(document.getElementById('root')).render(
<App>
{/* ... */}
<Container />
</App>,
);
// or directly as DOM element
ReactDOM.createRoot(document.getElementById('modals')).render(<Container />);
- Use
usePromiseBridge
in component toresolve
orreject
Promise
.
// ./Confirm.tsx
import { usePromiseBridge } from '@piotar/react-promise-bridge';
interface ConfirmProps {
header?: string;
message: string;
}
export function Confirm({ header, message }: ConfirmProps): JSX.Element {
const { resolve, reject } = usePromiseBridge<boolean>();
return (
<dialog open={true}>
{header ? <header>{header}</header> : null}
<p>{message}</p>
<footer>
<button type="button" onClick={() => reject(new Error('Canceled'))}>
Cancel
</button>
<button type="button" onClick={() => resolve(true)}>
Confirm
</button>
</footer>
</dialog>
);
}
- Use the invoke
Promise Bridge
function wherever you want.
Invoke promise bridge function to open component inside React
component:
// ./App.tsx
import { open } from './SystemPromiseBridge';
export function App({ children }: React.PropsWithChildren<unknown>): JSX.Element {
const handleConfirmClick = async () => {
try {
await open(<Confirm header="Confirmation" message="Some custom message" />);
// handle confirm
console.log('confirmed');
} catch (error) {
console.warn(error);
}
};
return (
<div>
<button type="button" onClick={handleConfirmClick}>
Open confirm modal
</button>
{/* ... */}
</div>
);
}
Invoke promise bridge function to open component outside React
:
import { open } from './SystemPromiseBridge';
setTimeout(async () => {
try {
const result = await open(<Confirm message="my custom message" />);
console.log(result);
} catch (error) {
console.error(error);
}
}, 1000);
Try it on:
The main hook for resolving or rejecting Promise
.
const { resolve, reject, signal } = usePromiseBridge<ResolveType, RejectType>();
A hook based on usePromiseBridge
.
The hook is designed to manage animation.
The hook allows you to defer the fulfilled Promise
and release it by calling a trigger
function.
const {
resolve,
reject,
signal,
state,
trigger,
Provider,
} = useDeferredPromiseBridge<ResolveType, RejectType>();
The helper hook is designed to help create an abort controller to reject Promise
after the trigger component is destroyed.
const abortController = useDisposePromiseBridge(signals);
A helper hook for creating a new Promise Bridge
instance for dynamic React components.
const [Container, opener] = useFactoryPromiseBridge(options);
Repository example | Open in StackBlitz |
---|---|
#i01 Material UI (MUI) | |
#i02 React Bootstrap | |
#i03 Ant design (antd) |