
Security News
High Salaries No Longer Enough to Attract Top Cybersecurity Talent
A survey of 500 cybersecurity pros reveals high pay isn't enough—lack of growth and flexibility is driving attrition and risking organizational security.
react-dialog-async
Advanced tools
A simple, promise-based approach to managing Dialogs in React.
# With npm
> npm i react-dialog-async
# With yarn
> yarn add react-dialog-async
This example demonstrates how to create a simple dialog that asks the user a question and logs their response to the console
// 1. Wrap your app with DialogProvider
<DialogProvider>
<App />
</DialogProvider>
// 2. Create a dialog component
const QuestionDialog = ({ data, open, handleClose }) => {
if (!open) return null; // Don't render if the dialog is closed
return (
<div className={'dialog'}>
<p>{data.question}</p>
<button onClick={() => handleClose("No")}>No</button>
<button onClick={() => handleClose("Yes")}>Yes</button>
</div>
)
};
// 3. Use the useDialog hook to show the dialog
const App = () => {
const questionDialog = useDialog(QuestionDialog);
const handleClick = async () => {
const response = await questionDialog.show({
// pass data to the dialog
question: "Do you like apples?"
});
console.log(response) // Will be either "Yes" or "No"
};
return (
<button onClick={handleClick}>
Ask me a question
</button>
);
};
For examples of usage with different UI frameworks such as Material UI & Bootstrap, see the examples folder.
Use the AsyncDialogProps
type to define types for the data being passed into the dialog, as well as the value returned by the dialog.
import { AsyncDialogProps } from "react-dialog-async";
type QuestionDialogData = {
question: string;
}
type QuestionDialogResponse = "Yes" | "No";
const QuestionDialog = ({
data,
open,
handleClose
}: AsyncDialogProps<QuestionDialogData, QuestionDialogResponse>) => {
if (!open) return null;
return (
<div className={'dialog'}>
<p>{data.question}</p>
<button onClick={() => handleClose("No")}>No</button>
<button onClick={() => handleClose("Yes")}>Yes</button>
</div>
)
};
const App = () => {
const questionDialog = useDialog(QuestionDialog);
const handleClick = async () => {
// .show() now expects QuestionDialogData
const response = await questionDialog.show({
question: "Do you like apples?"
});
// NOTE: response is of type QuestionDialogResponse | undefined
// it may be undefined if the dialog was force closed, or if no argument was passed to handleClose()
if(response !== undefined) {
console.log(response)
}
};
return (
<button onClick={handleClick}>
Ask me a question
</button>
);
};
Contributions are more than welcome! If you have a use-case that the library currently doesn't support please raise it in an issue or pull request 😄
If you're using the same dialog across multiple components, you can optimize performance by assigning a dialogKey
to your dialog component:
const QuestionDialog = ({ open }) => {
if (!open) return null;
return (
<div className={'dialog'}>
...
</div>
)
};
QuestionDialog.dialogKey = "QuestionDialog";
This allows the DialogProvider to reuse the same instance of the dialog, instead of maintaining separate instances of the dialog for each useDialog()
hook
FAQs
A promise-based way to show dialogs in React
The npm package react-dialog-async receives a total of 390 weekly downloads. As such, react-dialog-async popularity was classified as not popular.
We found that react-dialog-async demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
A survey of 500 cybersecurity pros reveals high pay isn't enough—lack of growth and flexibility is driving attrition and risking organizational security.
Product
Socket, the leader in open source security, is now available on Google Cloud Marketplace for simplified procurement and enhanced protection against supply chain attacks.
Security News
Corepack will be phased out from future Node.js releases following a TSC vote.