{"version":3,"file":"Toast-DyCOed9b.js","sources":["../../Client/components/Modal.tsx","../../Client/components/FormErrorText.tsx","../../Client/components/Input.tsx","../../Client/shared/Toast.ts"],"sourcesContent":["import { useEffect, useState } from 'react';\nimport { createPortal } from 'react-dom';\nimport MicroModal from '../shared/Modal';\nimport { R } from '@/Resources.resx';\nimport classNames from 'classnames';\n\nconst containers: { [id: string]: HTMLElement } = {};\nlet _modalContainer: HTMLElement | null;\nfunction getModalContainer(id: string) {\n if (_modalContainer == null) {\n _modalContainer = document.createElement('div');\n document.body.appendChild(_modalContainer);\n }\n\n let container = containers[id];\n if (container == null) {\n container = document.createElement('div');\n container.id = id;\n container.className = 'modal';\n container.ariaHidden = 'true';\n containers[id] = container;\n _modalContainer.appendChild(container);\n }\n\n return container;\n}\n\ntype Props = {\n title?: string;\n hideCloseButton?: boolean;\n showCloseButtonInRightCorner?: boolean;\n onClose: () => void;\n children: React.ReactNode;\n containerClassName?: string;\n className?: string;\n};\nexport function Modal({\n title,\n hideCloseButton = false,\n showCloseButtonInRightCorner = false,\n containerClassName,\n className,\n onClose,\n children,\n}: Props) {\n const [id, setID] = useState(crypto.randomUUID());\n const container = getModalContainer(id);\n useEffect(() => {\n MicroModal.show(id, () => {\n onClose();\n setID(crypto.randomUUID());\n });\n return () => {\n MicroModal.close(id);\n container.remove();\n };\n }, [id]);\n\n const modal = (\n