matsuri-ui 10.1.0 → 10.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (128) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/dist/cjs/@utils/arrayShallowEqual.js +13 -0
  3. package/dist/cjs/@utils/arrayShallowEqual.js.map +1 -0
  4. package/dist/cjs/Alert/Alert.js +10 -10
  5. package/dist/cjs/Alert/Alert.js.map +1 -1
  6. package/dist/cjs/Breadcrumbs/Breadcrumbs.js +3 -3
  7. package/dist/cjs/Breadcrumbs/Breadcrumbs.js.map +1 -1
  8. package/dist/cjs/Calendar/CalendarDay.js +2 -2
  9. package/dist/cjs/Calendar/CalendarDay.js.map +1 -1
  10. package/dist/cjs/Calendar/CalendarDaysInMonth.js +14 -4
  11. package/dist/cjs/Calendar/CalendarDaysInMonth.js.map +1 -1
  12. package/dist/cjs/Chip/Chip.js +2 -4
  13. package/dist/cjs/Chip/Chip.js.map +1 -1
  14. package/dist/cjs/DateTextField/DateTextField.js +6 -6
  15. package/dist/cjs/DateTextField/DateTextField.js.map +1 -1
  16. package/dist/cjs/DropArea/DropArea.js +2 -4
  17. package/dist/cjs/DropArea/DropArea.js.map +1 -1
  18. package/dist/cjs/ImageUploadArea/ImageUploadArea.js +7 -7
  19. package/dist/cjs/ImageUploadArea/ImageUploadArea.js.map +1 -1
  20. package/dist/cjs/ImageUploader/ImageUploader.js +306 -0
  21. package/dist/cjs/ImageUploader/ImageUploader.js.map +1 -0
  22. package/dist/cjs/ImageUploader/index.js +19 -0
  23. package/dist/cjs/ImageUploader/index.js.map +1 -0
  24. package/dist/cjs/ImageViewer/ImageViewer.js +7 -7
  25. package/dist/cjs/ImageViewer/ImageViewer.js.map +1 -1
  26. package/dist/cjs/List/List.js +2 -4
  27. package/dist/cjs/List/List.js.map +1 -1
  28. package/dist/cjs/List/ListItem.js +10 -4
  29. package/dist/cjs/List/ListItem.js.map +1 -1
  30. package/dist/cjs/List/ListItemIcon.js +6 -6
  31. package/dist/cjs/List/ListItemIcon.js.map +1 -1
  32. package/dist/cjs/Menu/Menu.js +0 -1
  33. package/dist/cjs/Menu/Menu.js.map +1 -1
  34. package/dist/cjs/Menu/MenuList.js.map +1 -1
  35. package/dist/cjs/NumberField/NumberField.js +1 -1
  36. package/dist/cjs/NumberField/NumberField.js.map +1 -1
  37. package/dist/cjs/Popper/Popper.js +4 -4
  38. package/dist/cjs/Popper/Popper.js.map +1 -1
  39. package/dist/cjs/SearchField/SearchField.js +1 -1
  40. package/dist/cjs/SearchField/SearchField.js.map +1 -1
  41. package/dist/cjs/SelectAsyncSearchField/SelectAsyncSearchField.js +10 -10
  42. package/dist/cjs/SelectAsyncSearchField/SelectAsyncSearchField.js.map +1 -1
  43. package/dist/cjs/SelectField/Select.js +3 -7
  44. package/dist/cjs/SelectField/Select.js.map +1 -1
  45. package/dist/cjs/SelectField/SelectList.js +1 -1
  46. package/dist/cjs/SelectField/SelectList.js.map +1 -1
  47. package/dist/cjs/SelectSearchField/SelectSearchField.js +3 -3
  48. package/dist/cjs/SelectSearchField/SelectSearchField.js.map +1 -1
  49. package/dist/cjs/SortArea/index.js +37 -23
  50. package/dist/cjs/SortArea/index.js.map +1 -1
  51. package/dist/cjs/Status/Status.js +1 -3
  52. package/dist/cjs/Status/Status.js.map +1 -1
  53. package/dist/cjs/Table/useTable.js +4 -10
  54. package/dist/cjs/Table/useTable.js.map +1 -1
  55. package/dist/cjs/Thumbnail/index.js +1 -1
  56. package/dist/cjs/Thumbnail/index.js.map +1 -1
  57. package/dist/cjs/WeeklyCalendarUI/WeeklyCalendar.js +1 -3
  58. package/dist/cjs/WeeklyCalendarUI/WeeklyCalendar.js.map +1 -1
  59. package/dist/cjs/index.js +13 -0
  60. package/dist/cjs/index.js.map +1 -1
  61. package/dist/esm/@utils/arrayShallowEqual.js +4 -0
  62. package/dist/esm/@utils/arrayShallowEqual.js.map +1 -0
  63. package/dist/esm/Alert/Alert.js +11 -11
  64. package/dist/esm/Alert/Alert.js.map +1 -1
  65. package/dist/esm/Breadcrumbs/Breadcrumbs.js +3 -3
  66. package/dist/esm/Breadcrumbs/Breadcrumbs.js.map +1 -1
  67. package/dist/esm/Button/Button.js +2 -2
  68. package/dist/esm/Calendar/CalendarDay.js +2 -2
  69. package/dist/esm/Calendar/CalendarDay.js.map +1 -1
  70. package/dist/esm/Calendar/CalendarDaysInMonth.js +13 -3
  71. package/dist/esm/Calendar/CalendarDaysInMonth.js.map +1 -1
  72. package/dist/esm/Chip/Chip.js +2 -2
  73. package/dist/esm/Chip/Chip.js.map +1 -1
  74. package/dist/esm/FullHeight/FullHeight.js +2 -2
  75. package/dist/esm/ImageUploadArea/ImageUploadArea.js +7 -7
  76. package/dist/esm/ImageUploadArea/ImageUploadArea.js.map +1 -1
  77. package/dist/esm/ImageUploader/ImageUploader.js +339 -0
  78. package/dist/esm/ImageUploader/ImageUploader.js.map +1 -0
  79. package/dist/esm/ImageUploader/index.js +2 -0
  80. package/dist/esm/ImageUploader/index.js.map +1 -0
  81. package/dist/esm/ImageViewer/ImageViewer.js +7 -7
  82. package/dist/esm/ImageViewer/ImageViewer.js.map +1 -1
  83. package/dist/esm/List/List.js +3 -5
  84. package/dist/esm/List/List.js.map +1 -1
  85. package/dist/esm/List/ListItem.js +12 -6
  86. package/dist/esm/List/ListItem.js.map +1 -1
  87. package/dist/esm/List/ListItemIcon.js +6 -7
  88. package/dist/esm/List/ListItemIcon.js.map +1 -1
  89. package/dist/esm/Loading/Loading.js +2 -2
  90. package/dist/esm/Menu/Menu.js +2 -3
  91. package/dist/esm/Menu/Menu.js.map +1 -1
  92. package/dist/esm/Menu/MenuList.js.map +1 -1
  93. package/dist/esm/Modal/Modal.js +2 -2
  94. package/dist/esm/SearchField/SearchField.js +1 -1
  95. package/dist/esm/SearchField/SearchField.js.map +1 -1
  96. package/dist/esm/SearchField/useSearch.js +2 -2
  97. package/dist/esm/SelectAsyncSearchField/SelectAsyncSearchField.js +5 -5
  98. package/dist/esm/SelectAsyncSearchField/SelectAsyncSearchField.js.map +1 -1
  99. package/dist/esm/ShimmerEffect/index.js +2 -2
  100. package/dist/esm/SortArea/index.js +43 -26
  101. package/dist/esm/SortArea/index.js.map +1 -1
  102. package/dist/esm/Steper/Step.js +2 -2
  103. package/dist/esm/Table/Table.js +2 -2
  104. package/dist/esm/Table/useTable.js +2 -2
  105. package/dist/esm/Tabs/Tab.js +2 -2
  106. package/dist/esm/Timeline/Timeline.js +2 -2
  107. package/dist/esm/Typography/index.js +2 -2
  108. package/dist/esm/ZipCodeField/ZipCodeField.js +2 -2
  109. package/dist/esm/hooks/useFetch.js +2 -2
  110. package/dist/esm/index.js +1 -0
  111. package/dist/esm/index.js.map +1 -1
  112. package/dist/types/@utils/arrayShallowEqual.d.ts +1 -0
  113. package/dist/types/Calendar/CalendarDay.d.ts +2 -2
  114. package/dist/types/Calendar/CalendarDaysInMonth.d.ts +2 -2
  115. package/dist/types/ImageUploader/ImageUploader.d.ts +27 -0
  116. package/dist/types/ImageUploader/index.d.ts +1 -0
  117. package/dist/types/List/List.d.ts +2 -4
  118. package/dist/types/List/ListItemIcon.d.ts +1 -1
  119. package/dist/types/Menu/Menu.d.ts +3 -5
  120. package/dist/types/Menu/MenuList.d.ts +3 -5
  121. package/dist/types/SortArea/index.d.ts +1 -1
  122. package/dist/types/index.d.ts +1 -0
  123. package/package.json +37 -57
  124. package/dist/cjs/Popper/useOnClickOutside.js +0 -36
  125. package/dist/cjs/Popper/useOnClickOutside.js.map +0 -1
  126. package/dist/esm/Popper/useOnClickOutside.js +0 -26
  127. package/dist/esm/Popper/useOnClickOutside.js.map +0 -1
  128. package/dist/types/Popper/useOnClickOutside.d.ts +0 -1
package/CHANGELOG.md CHANGED
@@ -1,5 +1,7 @@
1
1
  # Changelog
2
2
 
3
+ See [Github Releases](https://github.com/matsuri-tech/matsuri-ui/releases).
4
+
3
5
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
6
 
5
7
  ## [10.1.0](https://github.com/matsuri-tech/matsuri-ui/compare/v10.0.0...v10.1.0) (2021-12-27)
@@ -0,0 +1,13 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.arrayShallowEqual = void 0;
7
+
8
+ const arrayShallowEqual = (a, b) => {
9
+ return a.length === b.length && a.every((v, i) => v === b[i]);
10
+ };
11
+
12
+ exports.arrayShallowEqual = arrayShallowEqual;
13
+ //# sourceMappingURL=arrayShallowEqual.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../../src/@utils/arrayShallowEqual.ts"],"names":["arrayShallowEqual","a","b","length","every","v","i"],"mappings":";;;;;;;AAAO,MAAMA,iBAAiB,GAAG,CAACC,CAAD,EAAwBC,CAAxB,KAAkD;AAC/E,SAAOD,CAAC,CAACE,MAAF,KAAaD,CAAC,CAACC,MAAf,IAAyBF,CAAC,CAACG,KAAF,CAAQ,CAACC,CAAD,EAAIC,CAAJ,KAAUD,CAAC,KAAKH,CAAC,CAACI,CAAD,CAAzB,CAAhC;AACH,CAFM","sourcesContent":["export const arrayShallowEqual = (a: readonly unknown[], b: readonly unknown[]) => {\n return a.length === b.length && a.every((v, i) => v === b[i])\n}\n"],"file":"arrayShallowEqual.js"}
@@ -15,15 +15,15 @@ var _react = require("@emotion/react");
15
15
 
16
16
  var _theme = require("../theme");
17
17
 
18
- var _Check = _interopRequireDefault(require("@material-ui/icons/Check"));
18
+ var _Check = _interopRequireDefault(require("@mui/icons-material/Check"));
19
19
 
20
- var _Close = _interopRequireDefault(require("@material-ui/icons/Close"));
20
+ var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
21
21
 
22
- var _Error = _interopRequireDefault(require("@material-ui/icons/Error"));
22
+ var _Error = _interopRequireDefault(require("@mui/icons-material/Error"));
23
23
 
24
24
  var _react2 = _interopRequireWildcard(require("react"));
25
25
 
26
- var _Warning = _interopRequireDefault(require("@material-ui/icons/Warning"));
26
+ var _Warning = _interopRequireDefault(require("@mui/icons-material/Warning"));
27
27
 
28
28
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
29
 
@@ -94,22 +94,22 @@ const Alert = ({
94
94
  props
95
95
  }) => item ? (0, _react.jsx)(_reactSpring.animated.div, {
96
96
  style: props,
97
- css: /*#__PURE__*/(0, _react.css)( /*#__PURE__*/(0, _react.css)(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Alert;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA8F8B","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */"), " z-index:", theme.zIndex.tooltip, ";display:flex;width:fit-content;max-width:360px;min-height:", theme.spacing * 8, "px;margin-top:", theme.spacing, "px;overflow:hidden;color:", theme.palette.intentions[severity].contrastText, ";background-color:", theme.palette.intentions[severity].main, ";border-radius:4px;box-shadow:", theme.shadows[4], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA6FgC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */"),
97
+ css: /*#__PURE__*/(0, _react.css)( /*#__PURE__*/(0, _react.css)(theme.typography.body, process.env.NODE_ENV === "production" ? "" : ";label:Alert;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA8F8B","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */"), " z-index:", theme.zIndex.tooltip, ";display:flex;width:fit-content;max-width:360px;min-height:", theme.spacing * 8, "px;margin-top:", theme.spacing, "px;overflow:hidden;color:", theme.palette.intentions[severity].contrastText, ";background-color:", theme.palette.intentions[severity].main, ";border-radius:4px;box-shadow:", theme.shadows[4], ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA6FgC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */"),
98
98
  key: key,
99
99
  role: "alert"
100
100
  }, (0, _react.jsx)("div", {
101
- css: /*#__PURE__*/(0, _react.css)("flex-shrink:0;width:30px;padding:", theme.spacing, "px 0px;margin-right:0.3em;font-size:1em;text-align:center;vertical-align:text-top;background-color:", theme.palette.intentions[severity].dark, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA+GoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
101
+ css: /*#__PURE__*/(0, _react.css)("flex-shrink:0;width:30px;padding:", theme.spacing, "px 0px;margin-right:0.3em;font-size:1em;text-align:center;vertical-align:text-top;background-color:", theme.palette.intentions[severity].dark, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA+GoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
102
102
  }, (0, _react.jsx)(Icon, {
103
103
  fontSize: "small"
104
104
  })), (0, _react.jsx)("span", {
105
- css: /*#__PURE__*/(0, _react.css)("padding:", theme.spacing, "px ", theme.spacing * 1.5, "px;word-break:break-all;" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA6HoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
105
+ css: /*#__PURE__*/(0, _react.css)("padding:", theme.spacing, "px ", theme.spacing * 1.5, "px;word-break:break-all;" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA6HoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
106
106
  }, message), (0, _react.jsx)(_Button.Button, {
107
107
  icon: (0, _react.jsx)(_Close.default, {
108
108
  fontSize: "small"
109
109
  }),
110
110
  rounded: true,
111
111
  onClick: handleClick,
112
- css: /*#__PURE__*/(0, _react.css)("flex-shrink:0;padding:", theme.spacing, "px ", theme.spacing * 1.5, "px;margin-left:0.3em;font-size:1.2em;color:", theme.palette.intentions[severity].contrastText, ";vertical-align:text-top;cursor:pointer;transition:color ", theme.transitions.duration.shorter, ";&:hover{color:", theme.palette.intentions[severity].contrastText, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAwIoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
112
+ css: /*#__PURE__*/(0, _react.css)("flex-shrink:0;padding:", theme.spacing, "px ", theme.spacing * 1.5, "px;margin-left:0.3em;font-size:1.2em;color:", theme.palette.intentions[severity].contrastText, ";vertical-align:text-top;cursor:pointer;transition:color ", theme.transitions.duration.shorter, ";&:hover{color:", theme.palette.intentions[severity].contrastText, ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:Alert;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAwIoC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
113
113
  })) : null));
114
114
  };
115
115
 
@@ -158,7 +158,7 @@ const AlertProvider = ({
158
158
  const [toasts, setAlerts] = _react2.default.useState([]);
159
159
 
160
160
  const add = (0, _react2.useCallback)((message, options) => {
161
- const id = options !== null && options !== void 0 && options.id ? options.id : Math.random().toString(36).substr(2, 9);
161
+ const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9);
162
162
  setAlerts(pre => {
163
163
  return [...pre, {
164
164
  id,
@@ -189,7 +189,7 @@ const AlertProvider = ({
189
189
  padding: "8px",
190
190
  zIndex: theme.zIndex.tooltip,
191
191
  ...sx[position]
192
- }, process.env.NODE_ENV === "production" ? "" : ";label:AlertProvider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAuOyB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
192
+ }, process.env.NODE_ENV === "production" ? "" : ";label:AlertProvider;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAuOyB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n    /**\n     * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n     * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n     */\n    id?: string\n    /**\n     * 役割を表し、左側のアイコンと色を変更します。\n     * @default \"success\"\n     */\n    severity?: \"error\" | \"success\" | \"warning\"\n    /**\n     * トーストコンポーネントが消えるまでの時間(ms)を表します。\n     * 指定しない場合、自動では消えなくなります。\n     * @default \"Infinity\"\n     */\n    duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n    message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n    {} as {\n        add: (message: React.ReactNode, options: AlertOptions) => string\n        remove: (id: string) => void\n    }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n    success: CheckIcon,\n    warning: WarningIcon,\n    error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n    message,\n    duration = Infinity,\n    id,\n    severity = \"success\"\n}) => {\n    const [show, setShow] = React.useState(true)\n    const { remove } = useContext(AlertContext)\n    const transitions = useTransition(show, null, {\n        from: { opacity: 0 },\n        enter: { opacity: 1 },\n        leave: { opacity: 0 }\n    })\n\n    useEffect(() => {\n        if (show && duration !== Infinity) {\n            const timeout = setTimeout(() => {\n                setShow(false)\n                if (remove && id) {\n                    remove(id)\n                }\n            }, duration)\n\n            return () => clearTimeout(timeout)\n        }\n        return undefined\n    }, [duration, id, remove, show])\n\n    const Icon = icons[severity]\n\n    const handleClick = useCallback(() => {\n        setShow(false)\n        if (remove && id) {\n            remove(id)\n        }\n    }, [id, remove])\n\n    const theme = useTheme()\n\n    return (\n        <React.Fragment>\n            {transitions.map(({ item, key, props }) =>\n                item ? (\n                    <animated.div\n                        style={props}\n                        css={css`\n                            ${css(theme.typography.body)}\n                            z-index: ${theme.zIndex.tooltip};\n                            display: flex;\n                            width: fit-content;\n                            max-width: 360px;\n                            min-height: ${theme.spacing * 8}px;\n                            margin-top: ${theme.spacing}px;\n                            overflow: hidden;\n                            color: ${theme.palette.intentions[severity].contrastText};\n                            background-color: ${theme.palette.intentions[severity].main};\n                            border-radius: 4px;\n                            box-shadow: ${theme.shadows[4]};\n                        `}\n                        key={key}\n                        role=\"alert\"\n                    >\n                        <div\n                            css={css`\n                                flex-shrink: 0;\n                                width: 30px;\n                                padding: ${theme.spacing}px 0px;\n                                margin-right: 0.3em;\n                                font-size: 1em;\n                                text-align: center;\n                                vertical-align: text-top;\n                                background-color: ${theme.palette.intentions[severity].dark};\n                            `}\n                        >\n                            <Icon fontSize=\"small\" />\n                        </div>\n                        <span\n                            css={css`\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                word-break: break-all;\n                            `}\n                        >\n                            {message}\n                        </span>\n                        <Button\n                            icon={<CloseIcon fontSize=\"small\" />}\n                            rounded\n                            onClick={handleClick}\n                            css={css`\n                                flex-shrink: 0;\n                                padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n                                margin-left: 0.3em;\n                                font-size: 1.2em;\n                                color: ${theme.palette.intentions[severity].contrastText};\n                                vertical-align: text-top;\n                                cursor: pointer;\n                                transition: color ${theme.transitions.duration.shorter};\n                                &:hover {\n                                    color: ${theme.palette.intentions[severity].contrastText};\n                                }\n                            `}\n                        />\n                    </animated.div>\n                ) : null\n            )}\n        </React.Fragment>\n    )\n}\n\nexport const alertPositions = [\n    \"top-left\",\n    \"top-center\",\n    \"top-right\",\n    \"bottom-left\",\n    \"bottom-center\",\n    \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n    \"bottom-right\": {\n        right: 0,\n        bottom: 0,\n        alignItems: \"flex-end\"\n    },\n    \"bottom-center\": {\n        bottom: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"bottom-left\": {\n        left: 0,\n        bottom: 0,\n        alignItems: \"flex-start\"\n    },\n    \"top-right\": {\n        right: 0,\n        top: 0,\n        alignItems: \"flex-end\"\n    },\n    \"top-center\": {\n        top: 0,\n        left: \"50%\",\n        transform: \"translateX(-50%)\",\n        alignItems: \"center\"\n    },\n    \"top-left\": {\n        left: 0,\n        top: 0,\n        alignItems: \"flex-start\"\n    }\n}\nexport const AlertProvider: React.FC<{\n    position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n    const [toasts, setAlerts] = React.useState<\n        ({\n            id: string\n            message: React.ReactNode\n        } & AlertOptions)[]\n    >([])\n\n    const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n        const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n        setAlerts((pre) => {\n            return [...pre, { id, message, ...options }]\n        })\n        return id\n    }, [])\n\n    const remove = useCallback((id) => {\n        setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n    }, [])\n\n    const theme = useTheme()\n\n    return (\n        <Provider value={{ add, remove }}>\n            <Portal>\n                <div\n                    css={css({\n                        position: \"fixed\",\n                        display: \"flex\",\n                        flexDirection: \"column\",\n                        overflow: \"hidden\",\n                        width: \"fit-content\",\n                        boxSizing: \"border-box\",\n                        maxHeight: \"100%\",\n                        padding: \"8px\",\n                        zIndex: theme.zIndex.tooltip,\n                        ...sx[position]\n                    })}\n                >\n                    {toasts.map((toast) => (\n                        <Alert {...toast} key={toast.id} />\n                    ))}\n                </div>\n            </Portal>\n            {children}\n        </Provider>\n    )\n}\n\nexport const useAlert = () => {\n    const ctx = useContext(AlertContext)\n    return {\n        addAlert: ctx.add,\n        removeAlert: ctx.remove\n    }\n}\n"]} */")
193
193
  }, toasts.map(toast => (0, _react.jsx)(Alert, _extends({}, toast, {
194
194
  key: toast.id
195
195
  }))))), children);
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":["AlertContext","Provider","icons","success","CheckIcon","warning","WarningIcon","error","ErrorIcon","Alert","message","duration","Infinity","id","severity","show","setShow","React","useState","remove","transitions","from","opacity","enter","leave","timeout","setTimeout","clearTimeout","undefined","Icon","handleClick","theme","map","item","key","props","css","typography","body","zIndex","tooltip","spacing","palette","intentions","contrastText","main","shadows","dark","shorter","alertPositions","sx","right","bottom","alignItems","left","transform","top","AlertProvider","children","position","toasts","setAlerts","add","options","Math","random","toString","substr","pre","filter","toast","display","flexDirection","overflow","width","boxSizing","maxHeight","padding","useAlert","ctx","addAlert","removeAlert"],"mappings":"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","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@material-ui/icons/Check\"\nimport CloseIcon from \"@material-ui/icons/Close\"\nimport ErrorIcon from \"@material-ui/icons/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@material-ui/icons/Warning\"\n\nexport interface AlertOptions {\n /**\n * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n */\n id?: string\n /**\n * 役割を表し、左側のアイコンと色を変更します。\n * @default \"success\"\n */\n severity?: \"error\" | \"success\" | \"warning\"\n /**\n * トーストコンポーネントが消えるまでの時間(ms)を表します。\n * 指定しない場合、自動では消えなくなります。\n * @default \"Infinity\"\n */\n duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n {} as {\n add: (message: React.ReactNode, options: AlertOptions) => string\n remove: (id: string) => void\n }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n success: CheckIcon,\n warning: WarningIcon,\n error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n message,\n duration = Infinity,\n id,\n severity = \"success\"\n}) => {\n const [show, setShow] = React.useState(true)\n const { remove } = useContext(AlertContext)\n const transitions = useTransition(show, null, {\n from: { opacity: 0 },\n enter: { opacity: 1 },\n leave: { opacity: 0 }\n })\n\n useEffect(() => {\n if (show && duration !== Infinity) {\n const timeout = setTimeout(() => {\n setShow(false)\n if (remove && id) {\n remove(id)\n }\n }, duration)\n\n return () => clearTimeout(timeout)\n }\n return undefined\n }, [duration, id, remove, show])\n\n const Icon = icons[severity]\n\n const handleClick = useCallback(() => {\n setShow(false)\n if (remove && id) {\n remove(id)\n }\n }, [id, remove])\n\n const theme = useTheme()\n\n return (\n <React.Fragment>\n {transitions.map(({ item, key, props }) =>\n item ? (\n <animated.div\n style={props}\n css={css`\n ${css(theme.typography.body)}\n z-index: ${theme.zIndex.tooltip};\n display: flex;\n width: fit-content;\n max-width: 360px;\n min-height: ${theme.spacing * 8}px;\n margin-top: ${theme.spacing}px;\n overflow: hidden;\n color: ${theme.palette.intentions[severity].contrastText};\n background-color: ${theme.palette.intentions[severity].main};\n border-radius: 4px;\n box-shadow: ${theme.shadows[4]};\n `}\n key={key}\n role=\"alert\"\n >\n <div\n css={css`\n flex-shrink: 0;\n width: 30px;\n padding: ${theme.spacing}px 0px;\n margin-right: 0.3em;\n font-size: 1em;\n text-align: center;\n vertical-align: text-top;\n background-color: ${theme.palette.intentions[severity].dark};\n `}\n >\n <Icon fontSize=\"small\" />\n </div>\n <span\n css={css`\n padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n word-break: break-all;\n `}\n >\n {message}\n </span>\n <Button\n icon={<CloseIcon fontSize=\"small\" />}\n rounded\n onClick={handleClick}\n css={css`\n flex-shrink: 0;\n padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n margin-left: 0.3em;\n font-size: 1.2em;\n color: ${theme.palette.intentions[severity].contrastText};\n vertical-align: text-top;\n cursor: pointer;\n transition: color ${theme.transitions.duration.shorter};\n &:hover {\n color: ${theme.palette.intentions[severity].contrastText};\n }\n `}\n />\n </animated.div>\n ) : null\n )}\n </React.Fragment>\n )\n}\n\nexport const alertPositions = [\n \"top-left\",\n \"top-center\",\n \"top-right\",\n \"bottom-left\",\n \"bottom-center\",\n \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n \"bottom-right\": {\n right: 0,\n bottom: 0,\n alignItems: \"flex-end\"\n },\n \"bottom-center\": {\n bottom: 0,\n left: \"50%\",\n transform: \"translateX(-50%)\",\n alignItems: \"center\"\n },\n \"bottom-left\": {\n left: 0,\n bottom: 0,\n alignItems: \"flex-start\"\n },\n \"top-right\": {\n right: 0,\n top: 0,\n alignItems: \"flex-end\"\n },\n \"top-center\": {\n top: 0,\n left: \"50%\",\n transform: \"translateX(-50%)\",\n alignItems: \"center\"\n },\n \"top-left\": {\n left: 0,\n top: 0,\n alignItems: \"flex-start\"\n }\n}\nexport const AlertProvider: React.FC<{\n position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n const [toasts, setAlerts] = React.useState<\n ({\n id: string\n message: React.ReactNode\n } & AlertOptions)[]\n >([])\n\n const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n setAlerts((pre) => {\n return [...pre, { id, message, ...options }]\n })\n return id\n }, [])\n\n const remove = useCallback((id) => {\n setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n }, [])\n\n const theme = useTheme()\n\n return (\n <Provider value={{ add, remove }}>\n <Portal>\n <div\n css={css({\n position: \"fixed\",\n display: \"flex\",\n flexDirection: \"column\",\n overflow: \"hidden\",\n width: \"fit-content\",\n boxSizing: \"border-box\",\n maxHeight: \"100%\",\n padding: \"8px\",\n zIndex: theme.zIndex.tooltip,\n ...sx[position]\n })}\n >\n {toasts.map((toast) => (\n <Alert {...toast} key={toast.id} />\n ))}\n </div>\n </Portal>\n {children}\n </Provider>\n )\n}\n\nexport const useAlert = () => {\n const ctx = useContext(AlertContext)\n return {\n addAlert: ctx.add,\n removeAlert: ctx.remove\n }\n}\n"],"file":"Alert.js"}
1
+ {"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":["AlertContext","Provider","icons","success","CheckIcon","warning","WarningIcon","error","ErrorIcon","Alert","message","duration","Infinity","id","severity","show","setShow","React","useState","remove","transitions","from","opacity","enter","leave","timeout","setTimeout","clearTimeout","undefined","Icon","handleClick","theme","map","item","key","props","css","typography","body","zIndex","tooltip","spacing","palette","intentions","contrastText","main","shadows","dark","shorter","alertPositions","sx","right","bottom","alignItems","left","transform","top","AlertProvider","children","position","toasts","setAlerts","add","options","Math","random","toString","substr","pre","filter","toast","display","flexDirection","overflow","width","boxSizing","maxHeight","padding","useAlert","ctx","addAlert","removeAlert"],"mappings":"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","sourcesContent":["import { Button } from \"../Button\"\nimport { Portal } from \"../Portal\"\nimport { animated, useTransition } from \"react-spring\"\nimport { css } from \"@emotion/react\"\nimport { useTheme } from \"../theme\"\nimport CheckIcon from \"@mui/icons-material/Check\"\nimport CloseIcon from \"@mui/icons-material/Close\"\nimport ErrorIcon from \"@mui/icons-material/Error\"\nimport React, { createContext, useCallback, useContext, useEffect } from \"react\"\nimport WarningIcon from \"@mui/icons-material/Warning\"\n\nexport interface AlertOptions {\n /**\n * uniqueな文字列を入れてください。removeAlertを用いて任意のAlertを削除する場合に使用できます。\n * 指定しない場合に任意の文字列が生成され、addAlertから取得できます。\n */\n id?: string\n /**\n * 役割を表し、左側のアイコンと色を変更します。\n * @default \"success\"\n */\n severity?: \"error\" | \"success\" | \"warning\"\n /**\n * トーストコンポーネントが消えるまでの時間(ms)を表します。\n * 指定しない場合、自動では消えなくなります。\n * @default \"Infinity\"\n */\n duration?: number\n}\n\nexport interface AlertProps extends AlertOptions {\n message: React.ReactNode\n}\n\nconst AlertContext = createContext(\n {} as {\n add: (message: React.ReactNode, options: AlertOptions) => string\n remove: (id: string) => void\n }\n)\nconst { Provider } = AlertContext\n\nconst icons = {\n success: CheckIcon,\n warning: WarningIcon,\n error: ErrorIcon\n}\n\nexport const Alert: React.FC<AlertProps & { id?: string }> = ({\n message,\n duration = Infinity,\n id,\n severity = \"success\"\n}) => {\n const [show, setShow] = React.useState(true)\n const { remove } = useContext(AlertContext)\n const transitions = useTransition(show, null, {\n from: { opacity: 0 },\n enter: { opacity: 1 },\n leave: { opacity: 0 }\n })\n\n useEffect(() => {\n if (show && duration !== Infinity) {\n const timeout = setTimeout(() => {\n setShow(false)\n if (remove && id) {\n remove(id)\n }\n }, duration)\n\n return () => clearTimeout(timeout)\n }\n return undefined\n }, [duration, id, remove, show])\n\n const Icon = icons[severity]\n\n const handleClick = useCallback(() => {\n setShow(false)\n if (remove && id) {\n remove(id)\n }\n }, [id, remove])\n\n const theme = useTheme()\n\n return (\n <React.Fragment>\n {transitions.map(({ item, key, props }) =>\n item ? (\n <animated.div\n style={props}\n css={css`\n ${css(theme.typography.body)}\n z-index: ${theme.zIndex.tooltip};\n display: flex;\n width: fit-content;\n max-width: 360px;\n min-height: ${theme.spacing * 8}px;\n margin-top: ${theme.spacing}px;\n overflow: hidden;\n color: ${theme.palette.intentions[severity].contrastText};\n background-color: ${theme.palette.intentions[severity].main};\n border-radius: 4px;\n box-shadow: ${theme.shadows[4]};\n `}\n key={key}\n role=\"alert\"\n >\n <div\n css={css`\n flex-shrink: 0;\n width: 30px;\n padding: ${theme.spacing}px 0px;\n margin-right: 0.3em;\n font-size: 1em;\n text-align: center;\n vertical-align: text-top;\n background-color: ${theme.palette.intentions[severity].dark};\n `}\n >\n <Icon fontSize=\"small\" />\n </div>\n <span\n css={css`\n padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n word-break: break-all;\n `}\n >\n {message}\n </span>\n <Button\n icon={<CloseIcon fontSize=\"small\" />}\n rounded\n onClick={handleClick}\n css={css`\n flex-shrink: 0;\n padding: ${theme.spacing}px ${theme.spacing * 1.5}px;\n margin-left: 0.3em;\n font-size: 1.2em;\n color: ${theme.palette.intentions[severity].contrastText};\n vertical-align: text-top;\n cursor: pointer;\n transition: color ${theme.transitions.duration.shorter};\n &:hover {\n color: ${theme.palette.intentions[severity].contrastText};\n }\n `}\n />\n </animated.div>\n ) : null\n )}\n </React.Fragment>\n )\n}\n\nexport const alertPositions = [\n \"top-left\",\n \"top-center\",\n \"top-right\",\n \"bottom-left\",\n \"bottom-center\",\n \"bottom-right\"\n] as const\n\nexport type AlertPosition = typeof alertPositions[number]\n\nconst sx = {\n \"bottom-right\": {\n right: 0,\n bottom: 0,\n alignItems: \"flex-end\"\n },\n \"bottom-center\": {\n bottom: 0,\n left: \"50%\",\n transform: \"translateX(-50%)\",\n alignItems: \"center\"\n },\n \"bottom-left\": {\n left: 0,\n bottom: 0,\n alignItems: \"flex-start\"\n },\n \"top-right\": {\n right: 0,\n top: 0,\n alignItems: \"flex-end\"\n },\n \"top-center\": {\n top: 0,\n left: \"50%\",\n transform: \"translateX(-50%)\",\n alignItems: \"center\"\n },\n \"top-left\": {\n left: 0,\n top: 0,\n alignItems: \"flex-start\"\n }\n}\nexport const AlertProvider: React.FC<{\n position?: AlertPosition\n}> = ({ children, position = \"bottom-right\" }) => {\n const [toasts, setAlerts] = React.useState<\n ({\n id: string\n message: React.ReactNode\n } & AlertOptions)[]\n >([])\n\n const add = useCallback((message: React.ReactNode, options: AlertOptions) => {\n const id = options?.id ? options.id : Math.random().toString(36).substr(2, 9)\n\n setAlerts((pre) => {\n return [...pre, { id, message, ...options }]\n })\n return id\n }, [])\n\n const remove = useCallback((id) => {\n setAlerts((toasts) => toasts.filter((toast) => toast.id !== id))\n }, [])\n\n const theme = useTheme()\n\n return (\n <Provider value={{ add, remove }}>\n <Portal>\n <div\n css={css({\n position: \"fixed\",\n display: \"flex\",\n flexDirection: \"column\",\n overflow: \"hidden\",\n width: \"fit-content\",\n boxSizing: \"border-box\",\n maxHeight: \"100%\",\n padding: \"8px\",\n zIndex: theme.zIndex.tooltip,\n ...sx[position]\n })}\n >\n {toasts.map((toast) => (\n <Alert {...toast} key={toast.id} />\n ))}\n </div>\n </Portal>\n {children}\n </Provider>\n )\n}\n\nexport const useAlert = () => {\n const ctx = useContext(AlertContext)\n return {\n addAlert: ctx.add,\n removeAlert: ctx.remove\n }\n}\n"],"file":"Alert.js"}
@@ -11,7 +11,7 @@ var _BreadcrumbSeparator = require("./BreadcrumbSeparator");
11
11
 
12
12
  var _react = require("@emotion/react");
13
13
 
14
- var _NavigateNext = _interopRequireDefault(require("@material-ui/icons/NavigateNext"));
14
+ var _NavigateNext = _interopRequireDefault(require("@mui/icons-material/NavigateNext"));
15
15
 
16
16
  var _react2 = _interopRequireWildcard(require("react"));
17
17
 
@@ -45,7 +45,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
45
45
  } : {
46
46
  name: "u18dgm-Breadcrumbs",
47
47
  styles: "display:flex;flex-wrap:wrap;align-items:center;padding:0;margin:0;label:Breadcrumbs;",
48
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CcmVhZGNydW1icy9CcmVhZGNydW1icy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkNxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQnJlYWRjcnVtYnMvQnJlYWRjcnVtYnMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZVR5cG9ncmFwaHlQcm9wcywgVHlwb2dyYXBoeSB9IGZyb20gXCIuLi9UeXBvZ3JhcGh5XCJcbmltcG9ydCB7IEJyZWFkY3J1bWJTZXBhcmF0b3IgfSBmcm9tIFwiLi9CcmVhZGNydW1iU2VwYXJhdG9yXCJcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiXG5pbXBvcnQgTmF2aWdhdGVOZXh0SWNvbiBmcm9tIFwiQG1hdGVyaWFsLXVpL2ljb25zL05hdmlnYXRlTmV4dFwiXG5pbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiXG5cbmNvbnN0IGluc2VydFNlcGFyYXRvcnMgPSAoaXRlbXM6IEpTWC5FbGVtZW50W10sIHNlcGFyYXRvcjogUmVhY3QuUmVhY3ROb2RlKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW1zLnJlZHVjZSgoYWNjOiBKU1guRWxlbWVudFtdLCBjdXJyZW50LCBpbmRleCkgPT4ge1xuICAgICAgICBpZiAoaW5kZXggPCBpdGVtcy5sZW5ndGggLSAxKSB7XG4gICAgICAgICAgICBhY2MgPSBhY2MuY29uY2F0KGN1cnJlbnQsIDxCcmVhZGNydW1iU2VwYXJhdG9yIGtleT17YHNlcGFyYXRvci0ke2luZGV4fWB9PntzZXBhcmF0b3J9PC9CcmVhZGNydW1iU2VwYXJhdG9yPilcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGFjYy5wdXNoKGN1cnJlbnQpXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGFjY1xuICAgIH0sIFtdKVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJyZWFkY3J1bWJzUHJvcHMgZXh0ZW5kcyBPbWl0PEJhc2VUeXBvZ3JhcGh5UHJvcHMsIFwidmFyaWFudFwiIHwgXCJhbGlnblwiPiB7XG4gICAgc2VwYXJhdG9yPzogUmVhY3QuUmVhY3ROb2RlXG59XG5cbmV4cG9ydCBjb25zdCBCcmVhZGNydW1iczogUmVhY3QuRkM8QnJlYWRjcnVtYnNQcm9wcz4gPSAoeyBjaGlsZHJlbiwgc2VwYXJhdG9yID0gPE5hdmlnYXRlTmV4dEljb24gLz4sIC4uLm90aGVycyB9KSA9PiB7XG4gICAgY29uc3QgYWxsSXRlbXMgPSB1c2VNZW1vKFxuICAgICAgICAoKSA9PlxuICAgICAgICAgICAgUmVhY3QuQ2hpbGRyZW4udG9BcnJheShjaGlsZHJlbilcbiAgICAgICAgICAgICAgICAuZmlsdGVyKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuaXNWYWxpZEVsZW1lbnQoY2hpbGQpXG4gICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICAubWFwKChjaGlsZCwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgICAgICAgICAgICBrZXk9e2BjaGlsZC0ke2luZGV4fWB9XG4gICAgICAgICAgICAgICAgICAgICAgICBjc3M9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlzdFN0eWxlOiBcIm5vbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtjaGlsZH1cbiAgICAgICAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICAgICApKSxcbiAgICAgICAgW2NoaWxkcmVuXVxuICAgIClcbiAgICByZXR1cm4gKFxuICAgICAgICA8VHlwb2dyYXBoeSBjb2xvcj1cInRleHRTZWNvbmRhcnlcIiBhcz1cIm5hdlwiIHsuLi5vdGhlcnN9PlxuICAgICAgICAgICAgPG9sXG4gICAgICAgICAgICAgICAgY3NzPXtjc3Moe1xuICAgICAgICAgICAgICAgICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgICAgICAgICAgICAgICAgZmxleFdyYXA6IFwid3JhcFwiLFxuICAgICAgICAgICAgICAgICAgICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICAgICAgICAgICAgICAgICAgICBwYWRkaW5nOiAwLCAvLyBSZXNldFxuICAgICAgICAgICAgICAgICAgICBtYXJnaW46IDAgLy8gUmVzZXRcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7aW5zZXJ0U2VwYXJhdG9ycyhhbGxJdGVtcywgc2VwYXJhdG9yKX1cbiAgICAgICAgICAgIDwvb2w+XG4gICAgICAgIDwvVHlwb2dyYXBoeT5cbiAgICApXG59XG4iXX0= */",
48
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CcmVhZGNydW1icy9CcmVhZGNydW1icy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkNxQiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQnJlYWRjcnVtYnMvQnJlYWRjcnVtYnMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZVR5cG9ncmFwaHlQcm9wcywgVHlwb2dyYXBoeSB9IGZyb20gXCIuLi9UeXBvZ3JhcGh5XCJcbmltcG9ydCB7IEJyZWFkY3J1bWJTZXBhcmF0b3IgfSBmcm9tIFwiLi9CcmVhZGNydW1iU2VwYXJhdG9yXCJcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiXG5pbXBvcnQgTmF2aWdhdGVOZXh0SWNvbiBmcm9tIFwiQG11aS9pY29ucy1tYXRlcmlhbC9OYXZpZ2F0ZU5leHRcIlxuaW1wb3J0IFJlYWN0LCB7IHVzZU1lbW8gfSBmcm9tIFwicmVhY3RcIlxuXG5jb25zdCBpbnNlcnRTZXBhcmF0b3JzID0gKGl0ZW1zOiBKU1guRWxlbWVudFtdLCBzZXBhcmF0b3I6IFJlYWN0LlJlYWN0Tm9kZSkgPT4ge1xuICAgIHJldHVybiBpdGVtcy5yZWR1Y2UoKGFjYzogSlNYLkVsZW1lbnRbXSwgY3VycmVudCwgaW5kZXgpID0+IHtcbiAgICAgICAgaWYgKGluZGV4IDwgaXRlbXMubGVuZ3RoIC0gMSkge1xuICAgICAgICAgICAgYWNjID0gYWNjLmNvbmNhdChjdXJyZW50LCA8QnJlYWRjcnVtYlNlcGFyYXRvciBrZXk9e2BzZXBhcmF0b3ItJHtpbmRleH1gfT57c2VwYXJhdG9yfTwvQnJlYWRjcnVtYlNlcGFyYXRvcj4pXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBhY2MucHVzaChjdXJyZW50KVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBhY2NcbiAgICB9LCBbXSlcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCcmVhZGNydW1ic1Byb3BzIGV4dGVuZHMgT21pdDxCYXNlVHlwb2dyYXBoeVByb3BzLCBcInZhcmlhbnRcIiB8IFwiYWxpZ25cIj4ge1xuICAgIHNlcGFyYXRvcj86IFJlYWN0LlJlYWN0Tm9kZVxufVxuXG5leHBvcnQgY29uc3QgQnJlYWRjcnVtYnM6IFJlYWN0LkZDPEJyZWFkY3J1bWJzUHJvcHM+ID0gKHsgY2hpbGRyZW4sIHNlcGFyYXRvciA9IDxOYXZpZ2F0ZU5leHRJY29uIC8+LCAuLi5vdGhlcnMgfSkgPT4ge1xuICAgIGNvbnN0IGFsbEl0ZW1zID0gdXNlTWVtbyhcbiAgICAgICAgKCkgPT5cbiAgICAgICAgICAgIFJlYWN0LkNoaWxkcmVuLnRvQXJyYXkoY2hpbGRyZW4pXG4gICAgICAgICAgICAgICAgLmZpbHRlcigoY2hpbGQpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmlzVmFsaWRFbGVtZW50KGNoaWxkKVxuICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgLm1hcCgoY2hpbGQsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxsaVxuICAgICAgICAgICAgICAgICAgICAgICAga2V5PXtgY2hpbGQtJHtpbmRleH1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3Moe1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxpc3RTdHlsZTogXCJub25lXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICB7Y2hpbGR9XG4gICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgKSksXG4gICAgICAgIFtjaGlsZHJlbl1cbiAgICApXG4gICAgcmV0dXJuIChcbiAgICAgICAgPFR5cG9ncmFwaHkgY29sb3I9XCJ0ZXh0U2Vjb25kYXJ5XCIgYXM9XCJuYXZcIiB7Li4ub3RoZXJzfT5cbiAgICAgICAgICAgIDxvbFxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiBcIndyYXBcIixcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogMCwgLy8gUmVzZXRcbiAgICAgICAgICAgICAgICAgICAgbWFyZ2luOiAwIC8vIFJlc2V0XG4gICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge2luc2VydFNlcGFyYXRvcnMoYWxsSXRlbXMsIHNlcGFyYXRvcil9XG4gICAgICAgICAgICA8L29sPlxuICAgICAgICA8L1R5cG9ncmFwaHk+XG4gICAgKVxufVxuIl19 */",
49
49
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
50
50
  };
51
51
 
@@ -55,7 +55,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
55
55
  } : {
56
56
  name: "1r8rblh-allItems",
57
57
  styles: "list-style:none;label:allItems;",
58
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CcmVhZGNydW1icy9CcmVhZGNydW1icy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0I2QiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQnJlYWRjcnVtYnMvQnJlYWRjcnVtYnMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZVR5cG9ncmFwaHlQcm9wcywgVHlwb2dyYXBoeSB9IGZyb20gXCIuLi9UeXBvZ3JhcGh5XCJcbmltcG9ydCB7IEJyZWFkY3J1bWJTZXBhcmF0b3IgfSBmcm9tIFwiLi9CcmVhZGNydW1iU2VwYXJhdG9yXCJcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiXG5pbXBvcnQgTmF2aWdhdGVOZXh0SWNvbiBmcm9tIFwiQG1hdGVyaWFsLXVpL2ljb25zL05hdmlnYXRlTmV4dFwiXG5pbXBvcnQgUmVhY3QsIHsgdXNlTWVtbyB9IGZyb20gXCJyZWFjdFwiXG5cbmNvbnN0IGluc2VydFNlcGFyYXRvcnMgPSAoaXRlbXM6IEpTWC5FbGVtZW50W10sIHNlcGFyYXRvcjogUmVhY3QuUmVhY3ROb2RlKSA9PiB7XG4gICAgcmV0dXJuIGl0ZW1zLnJlZHVjZSgoYWNjOiBKU1guRWxlbWVudFtdLCBjdXJyZW50LCBpbmRleCkgPT4ge1xuICAgICAgICBpZiAoaW5kZXggPCBpdGVtcy5sZW5ndGggLSAxKSB7XG4gICAgICAgICAgICBhY2MgPSBhY2MuY29uY2F0KGN1cnJlbnQsIDxCcmVhZGNydW1iU2VwYXJhdG9yIGtleT17YHNlcGFyYXRvci0ke2luZGV4fWB9PntzZXBhcmF0b3J9PC9CcmVhZGNydW1iU2VwYXJhdG9yPilcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGFjYy5wdXNoKGN1cnJlbnQpXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGFjY1xuICAgIH0sIFtdKVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEJyZWFkY3J1bWJzUHJvcHMgZXh0ZW5kcyBPbWl0PEJhc2VUeXBvZ3JhcGh5UHJvcHMsIFwidmFyaWFudFwiIHwgXCJhbGlnblwiPiB7XG4gICAgc2VwYXJhdG9yPzogUmVhY3QuUmVhY3ROb2RlXG59XG5cbmV4cG9ydCBjb25zdCBCcmVhZGNydW1iczogUmVhY3QuRkM8QnJlYWRjcnVtYnNQcm9wcz4gPSAoeyBjaGlsZHJlbiwgc2VwYXJhdG9yID0gPE5hdmlnYXRlTmV4dEljb24gLz4sIC4uLm90aGVycyB9KSA9PiB7XG4gICAgY29uc3QgYWxsSXRlbXMgPSB1c2VNZW1vKFxuICAgICAgICAoKSA9PlxuICAgICAgICAgICAgUmVhY3QuQ2hpbGRyZW4udG9BcnJheShjaGlsZHJlbilcbiAgICAgICAgICAgICAgICAuZmlsdGVyKChjaGlsZCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuaXNWYWxpZEVsZW1lbnQoY2hpbGQpXG4gICAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgICAgICAubWFwKChjaGlsZCwgaW5kZXgpID0+IChcbiAgICAgICAgICAgICAgICAgICAgPGxpXG4gICAgICAgICAgICAgICAgICAgICAgICBrZXk9e2BjaGlsZC0ke2luZGV4fWB9XG4gICAgICAgICAgICAgICAgICAgICAgICBjc3M9e2Nzcyh7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgbGlzdFN0eWxlOiBcIm5vbmVcIlxuICAgICAgICAgICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICAgICAgICAgIHtjaGlsZH1cbiAgICAgICAgICAgICAgICAgICAgPC9saT5cbiAgICAgICAgICAgICAgICApKSxcbiAgICAgICAgW2NoaWxkcmVuXVxuICAgIClcbiAgICByZXR1cm4gKFxuICAgICAgICA8VHlwb2dyYXBoeSBjb2xvcj1cInRleHRTZWNvbmRhcnlcIiBhcz1cIm5hdlwiIHsuLi5vdGhlcnN9PlxuICAgICAgICAgICAgPG9sXG4gICAgICAgICAgICAgICAgY3NzPXtjc3Moe1xuICAgICAgICAgICAgICAgICAgICBkaXNwbGF5OiBcImZsZXhcIixcbiAgICAgICAgICAgICAgICAgICAgZmxleFdyYXA6IFwid3JhcFwiLFxuICAgICAgICAgICAgICAgICAgICBhbGlnbkl0ZW1zOiBcImNlbnRlclwiLFxuICAgICAgICAgICAgICAgICAgICBwYWRkaW5nOiAwLCAvLyBSZXNldFxuICAgICAgICAgICAgICAgICAgICBtYXJnaW46IDAgLy8gUmVzZXRcbiAgICAgICAgICAgICAgICB9KX1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7aW5zZXJ0U2VwYXJhdG9ycyhhbGxJdGVtcywgc2VwYXJhdG9yKX1cbiAgICAgICAgICAgIDwvb2w+XG4gICAgICAgIDwvVHlwb2dyYXBoeT5cbiAgICApXG59XG4iXX0= */",
58
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CcmVhZGNydW1icy9CcmVhZGNydW1icy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBK0I2QiIsImZpbGUiOiIuLi8uLi8uLi9zcmMvQnJlYWRjcnVtYnMvQnJlYWRjcnVtYnMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQmFzZVR5cG9ncmFwaHlQcm9wcywgVHlwb2dyYXBoeSB9IGZyb20gXCIuLi9UeXBvZ3JhcGh5XCJcbmltcG9ydCB7IEJyZWFkY3J1bWJTZXBhcmF0b3IgfSBmcm9tIFwiLi9CcmVhZGNydW1iU2VwYXJhdG9yXCJcbmltcG9ydCB7IGNzcyB9IGZyb20gXCJAZW1vdGlvbi9yZWFjdFwiXG5pbXBvcnQgTmF2aWdhdGVOZXh0SWNvbiBmcm9tIFwiQG11aS9pY29ucy1tYXRlcmlhbC9OYXZpZ2F0ZU5leHRcIlxuaW1wb3J0IFJlYWN0LCB7IHVzZU1lbW8gfSBmcm9tIFwicmVhY3RcIlxuXG5jb25zdCBpbnNlcnRTZXBhcmF0b3JzID0gKGl0ZW1zOiBKU1guRWxlbWVudFtdLCBzZXBhcmF0b3I6IFJlYWN0LlJlYWN0Tm9kZSkgPT4ge1xuICAgIHJldHVybiBpdGVtcy5yZWR1Y2UoKGFjYzogSlNYLkVsZW1lbnRbXSwgY3VycmVudCwgaW5kZXgpID0+IHtcbiAgICAgICAgaWYgKGluZGV4IDwgaXRlbXMubGVuZ3RoIC0gMSkge1xuICAgICAgICAgICAgYWNjID0gYWNjLmNvbmNhdChjdXJyZW50LCA8QnJlYWRjcnVtYlNlcGFyYXRvciBrZXk9e2BzZXBhcmF0b3ItJHtpbmRleH1gfT57c2VwYXJhdG9yfTwvQnJlYWRjcnVtYlNlcGFyYXRvcj4pXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBhY2MucHVzaChjdXJyZW50KVxuICAgICAgICB9XG4gICAgICAgIHJldHVybiBhY2NcbiAgICB9LCBbXSlcbn1cblxuZXhwb3J0IGludGVyZmFjZSBCcmVhZGNydW1ic1Byb3BzIGV4dGVuZHMgT21pdDxCYXNlVHlwb2dyYXBoeVByb3BzLCBcInZhcmlhbnRcIiB8IFwiYWxpZ25cIj4ge1xuICAgIHNlcGFyYXRvcj86IFJlYWN0LlJlYWN0Tm9kZVxufVxuXG5leHBvcnQgY29uc3QgQnJlYWRjcnVtYnM6IFJlYWN0LkZDPEJyZWFkY3J1bWJzUHJvcHM+ID0gKHsgY2hpbGRyZW4sIHNlcGFyYXRvciA9IDxOYXZpZ2F0ZU5leHRJY29uIC8+LCAuLi5vdGhlcnMgfSkgPT4ge1xuICAgIGNvbnN0IGFsbEl0ZW1zID0gdXNlTWVtbyhcbiAgICAgICAgKCkgPT5cbiAgICAgICAgICAgIFJlYWN0LkNoaWxkcmVuLnRvQXJyYXkoY2hpbGRyZW4pXG4gICAgICAgICAgICAgICAgLmZpbHRlcigoY2hpbGQpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmlzVmFsaWRFbGVtZW50KGNoaWxkKVxuICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgLm1hcCgoY2hpbGQsIGluZGV4KSA9PiAoXG4gICAgICAgICAgICAgICAgICAgIDxsaVxuICAgICAgICAgICAgICAgICAgICAgICAga2V5PXtgY2hpbGQtJHtpbmRleH1gfVxuICAgICAgICAgICAgICAgICAgICAgICAgY3NzPXtjc3Moe1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGxpc3RTdHlsZTogXCJub25lXCJcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgICAgICB7Y2hpbGR9XG4gICAgICAgICAgICAgICAgICAgIDwvbGk+XG4gICAgICAgICAgICAgICAgKSksXG4gICAgICAgIFtjaGlsZHJlbl1cbiAgICApXG4gICAgcmV0dXJuIChcbiAgICAgICAgPFR5cG9ncmFwaHkgY29sb3I9XCJ0ZXh0U2Vjb25kYXJ5XCIgYXM9XCJuYXZcIiB7Li4ub3RoZXJzfT5cbiAgICAgICAgICAgIDxvbFxuICAgICAgICAgICAgICAgIGNzcz17Y3NzKHtcbiAgICAgICAgICAgICAgICAgICAgZGlzcGxheTogXCJmbGV4XCIsXG4gICAgICAgICAgICAgICAgICAgIGZsZXhXcmFwOiBcIndyYXBcIixcbiAgICAgICAgICAgICAgICAgICAgYWxpZ25JdGVtczogXCJjZW50ZXJcIixcbiAgICAgICAgICAgICAgICAgICAgcGFkZGluZzogMCwgLy8gUmVzZXRcbiAgICAgICAgICAgICAgICAgICAgbWFyZ2luOiAwIC8vIFJlc2V0XG4gICAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge2luc2VydFNlcGFyYXRvcnMoYWxsSXRlbXMsIHNlcGFyYXRvcil9XG4gICAgICAgICAgICA8L29sPlxuICAgICAgICA8L1R5cG9ncmFwaHk+XG4gICAgKVxufVxuIl19 */",
59
59
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
60
60
  };
61
61
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/Breadcrumbs/Breadcrumbs.tsx"],"names":["insertSeparators","items","separator","reduce","acc","current","index","length","concat","push","Breadcrumbs","children","others","allItems","React","Children","toArray","filter","child","isValidElement","map"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;AAEA,MAAMA,gBAAgB,GAAG,CAACC,KAAD,EAAuBC,SAAvB,KAAsD;AAC3E,SAAOD,KAAK,CAACE,MAAN,CAAa,CAACC,GAAD,EAAqBC,OAArB,EAA8BC,KAA9B,KAAwC;AACxD,QAAIA,KAAK,GAAGL,KAAK,CAACM,MAAN,GAAe,CAA3B,EAA8B;AAC1BH,MAAAA,GAAG,GAAGA,GAAG,CAACI,MAAJ,CAAWH,OAAX,EAAoB,gBAAC,wCAAD;AAAqB,QAAA,GAAG,EAAG,aAAYC,KAAM;AAA7C,SAAiDJ,SAAjD,CAApB,CAAN;AACH,KAFD,MAEO;AACHE,MAAAA,GAAG,CAACK,IAAJ,CAASJ,OAAT;AACH;;AACD,WAAOD,GAAP;AACH,GAPM,EAOJ,EAPI,CAAP;AAQH,CATD;;;;;;;;;;;;;;;;;;;;;;AAeO,MAAMM,WAAuC,GAAG,CAAC;AAAEC,EAAAA,QAAF;AAAYT,EAAAA,SAAS,GAAG,gBAAC,qBAAD,OAAxB;AAA8C,KAAGU;AAAjD,CAAD,KAA+D;AAClH,QAAMC,QAAQ,GAAG,qBACb,MACIC,gBAAMC,QAAN,CAAeC,OAAf,CAAuBL,QAAvB,EACKM,MADL,CACaC,KAAD,IAAW;AACf,wBAAOJ,gBAAMK,cAAN,CAAqBD,KAArB,CAAP;AACH,GAHL,EAIKE,GAJL,CAIS,CAACF,KAAD,EAAQZ,KAAR,KACD;AACI,IAAA,GAAG,EAAG,SAAQA,KAAM,EADxB;AAEI,IAAA,GAAG;AAFP,KAMKY,KANL,CALR,CAFS,EAgBb,CAACP,QAAD,CAhBa,CAAjB;AAkBA,SACI,gBAAC,sBAAD;AAAY,IAAA,KAAK,EAAC,eAAlB;AAAkC,IAAA,EAAE,EAAC;AAArC,KAA+CC,MAA/C,GACI;AACI,IAAA,GAAG;AADP,KASKZ,gBAAgB,CAACa,QAAD,EAAWX,SAAX,CATrB,CADJ,CADJ;AAeH,CAlCM","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { BreadcrumbSeparator } from \"./BreadcrumbSeparator\"\nimport { css } from \"@emotion/react\"\nimport NavigateNextIcon from \"@material-ui/icons/NavigateNext\"\nimport React, { useMemo } from \"react\"\n\nconst insertSeparators = (items: JSX.Element[], separator: React.ReactNode) => {\n return items.reduce((acc: JSX.Element[], current, index) => {\n if (index < items.length - 1) {\n acc = acc.concat(current, <BreadcrumbSeparator key={`separator-${index}`}>{separator}</BreadcrumbSeparator>)\n } else {\n acc.push(current)\n }\n return acc\n }, [])\n}\n\nexport interface BreadcrumbsProps extends Omit<BaseTypographyProps, \"variant\" | \"align\"> {\n separator?: React.ReactNode\n}\n\nexport const Breadcrumbs: React.FC<BreadcrumbsProps> = ({ children, separator = <NavigateNextIcon />, ...others }) => {\n const allItems = useMemo(\n () =>\n React.Children.toArray(children)\n .filter((child) => {\n return React.isValidElement(child)\n })\n .map((child, index) => (\n <li\n key={`child-${index}`}\n css={css({\n listStyle: \"none\"\n })}\n >\n {child}\n </li>\n )),\n [children]\n )\n return (\n <Typography color=\"textSecondary\" as=\"nav\" {...others}>\n <ol\n css={css({\n display: \"flex\",\n flexWrap: \"wrap\",\n alignItems: \"center\",\n padding: 0, // Reset\n margin: 0 // Reset\n })}\n >\n {insertSeparators(allItems, separator)}\n </ol>\n </Typography>\n )\n}\n"],"file":"Breadcrumbs.js"}
1
+ {"version":3,"sources":["../../../src/Breadcrumbs/Breadcrumbs.tsx"],"names":["insertSeparators","items","separator","reduce","acc","current","index","length","concat","push","Breadcrumbs","children","others","allItems","React","Children","toArray","filter","child","isValidElement","map"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;AAEA,MAAMA,gBAAgB,GAAG,CAACC,KAAD,EAAuBC,SAAvB,KAAsD;AAC3E,SAAOD,KAAK,CAACE,MAAN,CAAa,CAACC,GAAD,EAAqBC,OAArB,EAA8BC,KAA9B,KAAwC;AACxD,QAAIA,KAAK,GAAGL,KAAK,CAACM,MAAN,GAAe,CAA3B,EAA8B;AAC1BH,MAAAA,GAAG,GAAGA,GAAG,CAACI,MAAJ,CAAWH,OAAX,EAAoB,gBAAC,wCAAD;AAAqB,QAAA,GAAG,EAAG,aAAYC,KAAM;AAA7C,SAAiDJ,SAAjD,CAApB,CAAN;AACH,KAFD,MAEO;AACHE,MAAAA,GAAG,CAACK,IAAJ,CAASJ,OAAT;AACH;;AACD,WAAOD,GAAP;AACH,GAPM,EAOJ,EAPI,CAAP;AAQH,CATD;;;;;;;;;;;;;;;;;;;;;;AAeO,MAAMM,WAAuC,GAAG,CAAC;AAAEC,EAAAA,QAAF;AAAYT,EAAAA,SAAS,GAAG,gBAAC,qBAAD,OAAxB;AAA8C,KAAGU;AAAjD,CAAD,KAA+D;AAClH,QAAMC,QAAQ,GAAG,qBACb,MACIC,gBAAMC,QAAN,CAAeC,OAAf,CAAuBL,QAAvB,EACKM,MADL,CACaC,KAAD,IAAW;AACf,wBAAOJ,gBAAMK,cAAN,CAAqBD,KAArB,CAAP;AACH,GAHL,EAIKE,GAJL,CAIS,CAACF,KAAD,EAAQZ,KAAR,KACD;AACI,IAAA,GAAG,EAAG,SAAQA,KAAM,EADxB;AAEI,IAAA,GAAG;AAFP,KAMKY,KANL,CALR,CAFS,EAgBb,CAACP,QAAD,CAhBa,CAAjB;AAkBA,SACI,gBAAC,sBAAD;AAAY,IAAA,KAAK,EAAC,eAAlB;AAAkC,IAAA,EAAE,EAAC;AAArC,KAA+CC,MAA/C,GACI;AACI,IAAA,GAAG;AADP,KASKZ,gBAAgB,CAACa,QAAD,EAAWX,SAAX,CATrB,CADJ,CADJ;AAeH,CAlCM","sourcesContent":["import { BaseTypographyProps, Typography } from \"../Typography\"\nimport { BreadcrumbSeparator } from \"./BreadcrumbSeparator\"\nimport { css } from \"@emotion/react\"\nimport NavigateNextIcon from \"@mui/icons-material/NavigateNext\"\nimport React, { useMemo } from \"react\"\n\nconst insertSeparators = (items: JSX.Element[], separator: React.ReactNode) => {\n return items.reduce((acc: JSX.Element[], current, index) => {\n if (index < items.length - 1) {\n acc = acc.concat(current, <BreadcrumbSeparator key={`separator-${index}`}>{separator}</BreadcrumbSeparator>)\n } else {\n acc.push(current)\n }\n return acc\n }, [])\n}\n\nexport interface BreadcrumbsProps extends Omit<BaseTypographyProps, \"variant\" | \"align\"> {\n separator?: React.ReactNode\n}\n\nexport const Breadcrumbs: React.FC<BreadcrumbsProps> = ({ children, separator = <NavigateNextIcon />, ...others }) => {\n const allItems = useMemo(\n () =>\n React.Children.toArray(children)\n .filter((child) => {\n return React.isValidElement(child)\n })\n .map((child, index) => (\n <li\n key={`child-${index}`}\n css={css({\n listStyle: \"none\"\n })}\n >\n {child}\n </li>\n )),\n [children]\n )\n return (\n <Typography color=\"textSecondary\" as=\"nav\" {...others}>\n <ol\n css={css({\n display: \"flex\",\n flexWrap: \"wrap\",\n alignItems: \"center\",\n padding: 0, // Reset\n margin: 0 // Reset\n })}\n >\n {insertSeparators(allItems, separator)}\n </ol>\n </Typography>\n )\n}\n"],"file":"Breadcrumbs.js"}