Alert Handling Duplicated Messages
src / Demo.tsx
import type { ReactElement } from "react";
import type { DuplicateBehavior, ToastMessage } from "@react-md/alert";
import { MessageQueue, useAddMessage } from "@react-md/alert";
import { Button } from "@react-md/button";
import { Divider } from "@react-md/divider";
import { Fieldset, Form, NativeSelect, Radio, useChoice } from "@react-md/form";
import { ArrowDropDownSVGIcon } from "@react-md/material-icons";
import Code from "./Code";
interface Props {
duplicates: DuplicateBehavior;
onDuplicateChange: React.ChangeEventHandler<HTMLInputElement>;
}
const ONLINE = "ONLINE";
const OFFLINE = "OFFLINE";
const SOMETHING_HAPPENED = "SOMETHING_HAPPENED";
type MessageKeys = typeof ONLINE | typeof OFFLINE | typeof SOMETHING_HAPPENED;
const MESSAGES: Record<MessageKeys, ToastMessage> = {
[ONLINE]: {
messageId: ONLINE,
children: "Internet connection restored.",
},
[OFFLINE]: {
messageId: OFFLINE,
children: "Internet connection lost.",
},
[SOMETHING_HAPPENED]: {
messageId: SOMETHING_HAPPENED,
children: "Something happened...",
},
};
function HandlingDuplicatedMessages({
duplicates,
onDuplicateChange,
}: Props): ReactElement {
const addMessage = useAddMessage();
const [key, handleKeyChange] = useChoice<MessageKeys>(ONLINE);
return (
<Form onSubmit={() => addMessage(MESSAGES[key])}>
<Fieldset
legend={
<>
<Code>MessageQueue</Code>
{" duplicate behavior"}
</>
}
>
<Radio
id="mq-duplicates-1"
name="duplicates"
value="allow"
label="Allow"
checked={duplicates === "allow"}
onChange={onDuplicateChange}
/>
<Radio
id="mq-duplicates-2"
name="duplicates"
value="prevent"
label="Prevent"
checked={duplicates === "prevent"}
onChange={onDuplicateChange}
/>
<Radio
id="mq-duplicates-3"
name="duplicates"
value="restart"
label="Restart"
checked={duplicates === "restart"}
onChange={onDuplicateChange}
/>
</Fieldset>
<NativeSelect
id="mq-duplicates-message"
icon={<ArrowDropDownSVGIcon />}
label="Message"
inline
style={{ margin: "1rem 0" }}
value={key}
onChange={handleKeyChange}
>
{Object.keys(MESSAGES).map((key) => (
<option key={key} value={key}>
{MESSAGES[key as MessageKeys].children}
</option>
))}
</NativeSelect>
<Divider />
<Button id="mq-duplicates-submit" type="submit" theme="primary">
Add Message
</Button>
</Form>
);
}
export default function Demo(): ReactElement {
const [duplicates, onDuplicateChange] = useChoice<DuplicateBehavior>("allow");
return (
<MessageQueue id="duplicate-message-queue" duplicates={duplicates}>
<HandlingDuplicatedMessages
duplicates={duplicates}
onDuplicateChange={onDuplicateChange}
/>
</MessageQueue>
);
}