matsuri-ui 17.0.1 → 17.0.2-alpha-1744436880353-cd10d5a.0

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.
@@ -1,23 +1,23 @@
1
1
  function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
2
2
  import { Button, resetButtonStyle } from "../Button";
3
3
  import { Tooltip } from "../Tooltip";
4
- import { animated } from "react-spring";
4
+ import { motion, AnimatePresence } from "motion/react";
5
5
  import { copyToClipboard } from "../@utils/copyToClipboard";
6
6
  import { css } from "@emotion/react";
7
- import { useAlertMotion } from "./useAlertMotion";
8
7
  import { useTheme } from "../theme";
9
8
  import CheckIcon from "@mui/icons-material/Check";
10
9
  import CloseIcon from "@mui/icons-material/Close";
11
10
  import ErrorIcon from "@mui/icons-material/Error";
12
- import React, { useMemo, useState } from "react";
11
+ import React, { useEffect, useMemo, useState } from "react";
13
12
  import WarningIcon from "@mui/icons-material/Warning";
13
+ import { useAlert } from "./AlertContext";
14
14
  import { jsx as ___EmotionJSX } from "@emotion/react";
15
15
  var _ref2 = process.env.NODE_ENV === "production" ? {
16
16
  name: "2qga7i",
17
17
  styles: "text-align:right"
18
18
  } : {
19
19
  name: "qxyhg0-Alert",
20
- styles: "text-align:right;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAiI8B","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
20
+ styles: "text-align:right;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAyJ4B","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
21
21
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
22
22
  };
23
23
  var _ref3 = process.env.NODE_ENV === "production" ? {
@@ -25,7 +25,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
25
25
  styles: "font-weight:bolder"
26
26
  } : {
27
27
  name: "urp5hr-Alert",
28
- styles: "font-weight:bolder;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAuHgC","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
28
+ styles: "font-weight:bolder;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA+I8B","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
29
29
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
30
30
  };
31
31
  var _ref4 = process.env.NODE_ENV === "production" ? {
@@ -33,7 +33,7 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
33
33
  styles: "word-break:break-all"
34
34
  } : {
35
35
  name: "6c2gwf-Alert",
36
- styles: "word-break:break-all;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA0GqB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
36
+ styles: "word-break:break-all;label:Alert;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAkImB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
37
37
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
38
38
  };
39
39
  export var Alert = _ref5 => {
@@ -44,30 +44,52 @@ export var Alert = _ref5 => {
44
44
  severity = "success"
45
45
  } = _ref5;
46
46
  var {
47
- transitions,
48
- handleClick
49
- } = useAlertMotion({
50
- duration,
51
- id
52
- });
47
+ removeAlert
48
+ } = useAlert();
49
+ var [show, setShow] = useState(true);
53
50
  var Icon = useMemo(() => {
54
51
  return severity === "success" ? CheckIcon : severity === "warning" ? WarningIcon : ErrorIcon;
55
52
  }, [severity]);
56
53
  var theme = useTheme();
57
- return ___EmotionJSX(React.Fragment, null, transitions((style, item) => item ? ___EmotionJSX(animated.div, {
58
- style: style,
59
- css: /*#__PURE__*/css("z-index:", theme.zIndex.tooltip, ";display:grid;grid-template-columns:auto 1fr auto;width:fit-content;max-width:384px;min-height:56px;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":"AAqEoB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"),
54
+ useEffect(() => {
55
+ if (show && duration !== Infinity) {
56
+ var timeout = setTimeout(() => {
57
+ setShow(false);
58
+ }, duration === "standard" ? 3500 : duration === "short" ? 1500 : duration);
59
+ return () => clearTimeout(timeout);
60
+ }
61
+ return undefined;
62
+ }, [duration, id, removeAlert, show]);
63
+ return ___EmotionJSX(AnimatePresence, null, show && ___EmotionJSX(motion.div, {
64
+ key: id,
65
+ initial: {
66
+ opacity: 0
67
+ },
68
+ animate: {
69
+ opacity: 1
70
+ },
71
+ exit: {
72
+ opacity: 0
73
+ },
74
+ onAnimationComplete: def => {
75
+ if (def.opacity === 0) {
76
+ if (id) {
77
+ removeAlert(id);
78
+ }
79
+ }
80
+ },
81
+ css: /*#__PURE__*/css("z-index:", theme.zIndex.tooltip, ";display:grid;grid-template-columns:auto 1fr auto;width:fit-content;max-width:384px;min-height:56px;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":"AA6FkB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"),
60
82
  role: "alert"
61
83
  }, ___EmotionJSX("div", {
62
- css: /*#__PURE__*/css("padding:", theme.spacing, "px;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":"AAqFsB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */")
84
+ css: /*#__PURE__*/css("padding:", theme.spacing, "px;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":"AA6GoB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */")
63
85
  }, ___EmotionJSX(Icon, {
64
86
  fontSize: "medium"
65
87
  })), ___EmotionJSX("div", {
66
- css: [/*#__PURE__*/css("display:flex;flex-direction:column;gap:", theme.spacing, "px;padding:", theme.spacing, "px ", theme.spacing * 2, "px ", theme.spacing * 2, "px;" + (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":"AA8FmB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"), 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":"AA6Fc","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
88
+ css: [/*#__PURE__*/css("display:flex;flex-direction:column;gap:", theme.spacing, "px;padding:", theme.spacing, "px ", theme.spacing * 2, "px ", theme.spacing * 2, "px;" + (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":"AAsHiB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"), 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":"AAqHY","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
67
89
  }, ___EmotionJSX("div", {
68
- css: [theme.typography.body, _ref4, 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":"AAwGgB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
90
+ css: [theme.typography.body, _ref4, 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":"AAgIc","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
69
91
  }, typeof message === "string" ? message : message.happend), typeof message === "string" ? null : ___EmotionJSX(React.Fragment, null, ___EmotionJSX("div", {
70
- css: [theme.typography.caption, 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":"AAmHuB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
92
+ css: [theme.typography.caption, 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":"AA2IqB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"]
71
93
  }, message.reason, message.action ? ___EmotionJSX("span", {
72
94
  css: _ref3
73
95
  }, message.action) : null), message.log ? ___EmotionJSX("div", {
@@ -75,13 +97,15 @@ export var Alert = _ref5 => {
75
97
  }, ___EmotionJSX(CopyButton, {
76
98
  value: message.log
77
99
  }, "\u30A8\u30E9\u30FC\u30ED\u30B0\u3092\u30B3\u30D4\u30FC\u3059\u308B")) : null)), ___EmotionJSX("div", null, ___EmotionJSX(Button, {
78
- css: /*#__PURE__*/css("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":"AA+IwB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"),
100
+ css: /*#__PURE__*/css("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":"AAuKsB","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"),
79
101
  icon: ___EmotionJSX(CloseIcon, {
80
102
  fontSize: "small"
81
103
  }),
82
104
  rounded: true,
83
- onClick: handleClick
84
- }))) : null));
105
+ onClick: () => {
106
+ setShow(false);
107
+ }
108
+ }))));
85
109
  };
86
110
 
87
111
  // Todo: Use TextButton
@@ -90,7 +114,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
90
114
  styles: "text-decoration:underline"
91
115
  } : {
92
116
  name: "11cmobw-CopyButton",
93
- styles: "text-decoration:underline;label:CopyButton;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAgLa","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
117
+ styles: "text-decoration:underline;label:CopyButton;/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAyMa","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */",
94
118
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
95
119
  };
96
120
  var CopyButton = _ref6 => {
@@ -107,7 +131,7 @@ var CopyButton = _ref6 => {
107
131
  placement: "top-end",
108
132
  open: copied
109
133
  }, ___EmotionJSX("button", {
110
- css: [resetButtonStyle, theme.typography.caption, _ref, process.env.NODE_ENV === "production" ? "" : ";label:CopyButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AA6KQ","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { animated } from \"react-spring\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\nimport { css } from \"@emotion/react\";\nimport { useAlertMotion } from \"./useAlertMotion\";\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, { useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { transitions, handleClick } = useAlertMotion({ duration, id });\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  return (\n    <React.Fragment>\n      {transitions((style, item) =>\n        item ? (\n          <animated.div\n            style={style}\n            css={css`\n              z-index: ${theme.zIndex.tooltip};\n              display: grid;\n              grid-template-columns: auto 1fr auto;\n              width: fit-content;\n              max-width: 384px;\n              min-height: 56px;\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            role=\"alert\"\n          >\n            <div\n              css={css`\n                padding: ${theme.spacing}px;\n                background-color: ${theme.palette.intentions[severity].dark};\n              `}\n            >\n              <Icon fontSize=\"medium\" />\n            </div>\n            <div\n              css={[\n                css`\n                  display: flex;\n                  flex-direction: column;\n                  gap: ${theme.spacing}px;\n                  padding: ${theme.spacing}px ${theme.spacing * 2}px\n                    ${theme.spacing * 2}px;\n                `,\n              ]}\n            >\n              <div\n                css={[\n                  theme.typography.body,\n                  css`\n                    word-break: break-all;\n                  `,\n                ]}\n              >\n                {typeof message === \"string\" ? message : message.happend}\n              </div>\n              {typeof message === \"string\" ? null : (\n                <>\n                  <div css={[theme.typography.caption]}>\n                    {message.reason}\n                    {message.action ? (\n                      <span\n                        css={css`\n                          font-weight: bolder;\n                        `}\n                      >\n                        {message.action}\n                      </span>\n                    ) : null}\n                  </div>\n                  {message.log ? (\n                    <div\n                      css={css`\n                        text-align: right;\n                      `}\n                    >\n                      <CopyButton value={message.log}>\n                        エラーログをコピーする\n                      </CopyButton>\n                    </div>\n                  ) : null}\n                </>\n              )}\n            </div>\n            <div>\n              <Button\n                css={css`\n                  color: ${theme.palette.intentions[severity].contrastText};\n                `}\n                icon={<CloseIcon fontSize=\"small\" />}\n                rounded\n                onClick={handleClick}\n              />\n            </div>\n          </animated.div>\n        ) : null,\n      )}\n    </React.Fragment>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"],
134
+ css: [resetButtonStyle, theme.typography.caption, _ref, process.env.NODE_ENV === "production" ? "" : ";label:CopyButton;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/Alert/Alert.tsx"],"names":[],"mappings":"AAsMQ","file":"../../../src/Alert/Alert.tsx","sourcesContent":["import { Button, resetButtonStyle } from \"../Button\";\nimport { Tooltip } from \"../Tooltip\";\nimport { motion, AnimatePresence } from \"motion/react\";\nimport { copyToClipboard } from \"../@utils/copyToClipboard\";\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, { useEffect, useMemo, useState } from \"react\";\nimport WarningIcon from \"@mui/icons-material/Warning\";\nimport { useAlert } from \"./AlertContext\";\n\nexport type AlertDuration = number | \"standard\" | \"short\";\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   * @default Infinity\n   */\n  duration?: AlertDuration;\n}\n\nexport interface AlertRichMessageType {\n  reason?: string;\n  action?: string;\n  happend: string;\n  log?: string;\n}\n\nexport type AlertMessageType = string | AlertRichMessageType;\n\nexport interface AlertProps extends AlertOptions {\n  message: AlertMessageType;\n}\n\nexport const Alert = ({\n  message,\n  duration = Infinity,\n  id,\n  severity = \"success\",\n}: AlertProps) => {\n  const { removeAlert } = useAlert();\n  const [show, setShow] = useState(true);\n  const Icon = useMemo(() => {\n    return severity === \"success\"\n      ? CheckIcon\n      : severity === \"warning\"\n        ? WarningIcon\n        : ErrorIcon;\n  }, [severity]);\n\n  const theme = useTheme();\n\n  useEffect(() => {\n    if (show && duration !== Infinity) {\n      const timeout = setTimeout(\n        () => {\n          setShow(false);\n        },\n        duration === \"standard\" ? 3500 : duration === \"short\" ? 1500 : duration,\n      );\n\n      return () => clearTimeout(timeout);\n    }\n    return undefined;\n  }, [duration, id, removeAlert, show]);\n\n  return (\n    <AnimatePresence>\n      {show && (\n        <motion.div\n          key={id}\n          initial={{ opacity: 0 }}\n          animate={{ opacity: 1 }}\n          exit={{ opacity: 0 }}\n          onAnimationComplete={(def: { opacity: number }) => {\n            if (def.opacity === 0) {\n              if (id) {\n                removeAlert(id);\n              }\n            }\n          }}\n          css={css`\n            z-index: ${theme.zIndex.tooltip};\n            display: grid;\n            grid-template-columns: auto 1fr auto;\n            width: fit-content;\n            max-width: 384px;\n            min-height: 56px;\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          role=\"alert\"\n        >\n          <div\n            css={css`\n              padding: ${theme.spacing}px;\n              background-color: ${theme.palette.intentions[severity].dark};\n            `}\n          >\n            <Icon fontSize=\"medium\" />\n          </div>\n          <div\n            css={[\n              css`\n                display: flex;\n                flex-direction: column;\n                gap: ${theme.spacing}px;\n                padding: ${theme.spacing}px ${theme.spacing * 2}px\n                  ${theme.spacing * 2}px;\n              `,\n            ]}\n          >\n            <div\n              css={[\n                theme.typography.body,\n                css`\n                  word-break: break-all;\n                `,\n              ]}\n            >\n              {typeof message === \"string\" ? message : message.happend}\n            </div>\n            {typeof message === \"string\" ? null : (\n              <>\n                <div css={[theme.typography.caption]}>\n                  {message.reason}\n                  {message.action ? (\n                    <span\n                      css={css`\n                        font-weight: bolder;\n                      `}\n                    >\n                      {message.action}\n                    </span>\n                  ) : null}\n                </div>\n                {message.log ? (\n                  <div\n                    css={css`\n                      text-align: right;\n                    `}\n                  >\n                    <CopyButton value={message.log}>\n                      エラーログをコピーする\n                    </CopyButton>\n                  </div>\n                ) : null}\n              </>\n            )}\n          </div>\n          <div>\n            <Button\n              css={css`\n                color: ${theme.palette.intentions[severity].contrastText};\n              `}\n              icon={<CloseIcon fontSize=\"small\" />}\n              rounded\n              onClick={() => {\n                setShow(false);\n              }}\n            />\n          </div>\n        </motion.div>\n      )}\n    </AnimatePresence>\n  );\n};\n\n// Todo: Use TextButton\nconst CopyButton = ({\n  children,\n  value,\n}: {\n  children: string;\n  value: string;\n}) => {\n  const [copyMessage, setCopyMessage] = useState<string>(\"\");\n  const [copied, setCopied] = useState<boolean>(false);\n\n  const theme = useTheme();\n  return (\n    <Tooltip title={copyMessage} arrow placement=\"top-end\" open={copied}>\n      <button\n        css={[\n          resetButtonStyle,\n          theme.typography.caption,\n          css`\n            text-decoration: underline;\n          `,\n        ]}\n        onClick={() => {\n          const flag = copyToClipboard(value);\n          setCopyMessage(flag ? \"コピーしました\" : \"コピーできませんでした\");\n          setCopied(true);\n          setTimeout(\n            () => {\n              setCopied(false);\n            },\n            flag ? 2500 : 100000,\n          );\n        }}\n      >\n        {children}\n      </button>\n    </Tooltip>\n  );\n};\n"]} */"],
111
135
  onClick: () => {
112
136
  var flag = copyToClipboard(value);
113
137
  setCopyMessage(flag ? "コピーしました" : "コピーできませんでした");