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.
@@ -4,16 +4,16 @@ exports.__esModule = true;
4
4
  exports.Alert = void 0;
5
5
  var _Button = require("../Button");
6
6
  var _Tooltip = require("../Tooltip");
7
- var _reactSpring = require("react-spring");
7
+ var _react = require("motion/react");
8
8
  var _copyToClipboard = require("../@utils/copyToClipboard");
9
- var _react = require("@emotion/react");
10
- var _useAlertMotion = require("./useAlertMotion");
9
+ var _react2 = require("@emotion/react");
11
10
  var _theme = require("../theme");
12
11
  var _Check = _interopRequireDefault(require("@mui/icons-material/Check"));
13
12
  var _Close = _interopRequireDefault(require("@mui/icons-material/Close"));
14
13
  var _Error = _interopRequireDefault(require("@mui/icons-material/Error"));
15
- var _react2 = _interopRequireWildcard(require("react"));
14
+ var _react3 = _interopRequireWildcard(require("react"));
16
15
  var _Warning = _interopRequireDefault(require("@mui/icons-material/Warning"));
16
+ var _AlertContext = require("./AlertContext");
17
17
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
18
18
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
19
19
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
@@ -23,7 +23,7 @@ var _ref2 = process.env.NODE_ENV === "production" ? {
23
23
  styles: "text-align:right"
24
24
  } : {
25
25
  name: "qxyhg0-Alert",
26
- 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"]} */",
26
+ 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"]} */",
27
27
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
28
28
  };
29
29
  var _ref3 = process.env.NODE_ENV === "production" ? {
@@ -31,7 +31,7 @@ var _ref3 = process.env.NODE_ENV === "production" ? {
31
31
  styles: "font-weight:bolder"
32
32
  } : {
33
33
  name: "urp5hr-Alert",
34
- 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"]} */",
34
+ 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"]} */",
35
35
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
36
36
  };
37
37
  var _ref4 = process.env.NODE_ENV === "production" ? {
@@ -39,7 +39,7 @@ var _ref4 = process.env.NODE_ENV === "production" ? {
39
39
  styles: "word-break:break-all"
40
40
  } : {
41
41
  name: "6c2gwf-Alert",
42
- 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"]} */",
42
+ 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"]} */",
43
43
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
44
44
  };
45
45
  const Alert = ({
@@ -49,44 +49,68 @@ const Alert = ({
49
49
  severity = "success"
50
50
  }) => {
51
51
  const {
52
- transitions,
53
- handleClick
54
- } = (0, _useAlertMotion.useAlertMotion)({
55
- duration,
56
- id
57
- });
58
- const Icon = (0, _react2.useMemo)(() => {
52
+ removeAlert
53
+ } = (0, _AlertContext.useAlert)();
54
+ const [show, setShow] = (0, _react3.useState)(true);
55
+ const Icon = (0, _react3.useMemo)(() => {
59
56
  return severity === "success" ? _Check.default : severity === "warning" ? _Warning.default : _Error.default;
60
57
  }, [severity]);
61
58
  const theme = (0, _theme.useTheme)();
62
- return (0, _react.jsx)(_react2.default.Fragment, null, transitions((style, item) => item ? (0, _react.jsx)(_reactSpring.animated.div, {
63
- style: style,
64
- css: /*#__PURE__*/(0, _react.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"]} */"),
59
+ (0, _react3.useEffect)(() => {
60
+ if (show && duration !== Infinity) {
61
+ const timeout = setTimeout(() => {
62
+ setShow(false);
63
+ }, duration === "standard" ? 3500 : duration === "short" ? 1500 : duration);
64
+ return () => clearTimeout(timeout);
65
+ }
66
+ return undefined;
67
+ }, [duration, id, removeAlert, show]);
68
+ return (0, _react2.jsx)(_react.AnimatePresence, null, show && (0, _react2.jsx)(_react.motion.div, {
69
+ key: id,
70
+ initial: {
71
+ opacity: 0
72
+ },
73
+ animate: {
74
+ opacity: 1
75
+ },
76
+ exit: {
77
+ opacity: 0
78
+ },
79
+ onAnimationComplete: def => {
80
+ if (def.opacity === 0) {
81
+ if (id) {
82
+ removeAlert(id);
83
+ }
84
+ }
85
+ },
86
+ css: /*#__PURE__*/(0, _react2.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"]} */"),
65
87
  role: "alert"
66
- }, (0, _react.jsx)("div", {
67
- css: /*#__PURE__*/(0, _react.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"]} */")
68
- }, (0, _react.jsx)(Icon, {
88
+ }, (0, _react2.jsx)("div", {
89
+ css: /*#__PURE__*/(0, _react2.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"]} */")
90
+ }, (0, _react2.jsx)(Icon, {
69
91
  fontSize: "medium"
70
- })), (0, _react.jsx)("div", {
71
- css: [/*#__PURE__*/(0, _react.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"]} */"]
72
- }, (0, _react.jsx)("div", {
73
- 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"]} */"]
74
- }, typeof message === "string" ? message : message.happend), typeof message === "string" ? null : (0, _react.jsx)(_react2.default.Fragment, null, (0, _react.jsx)("div", {
75
- 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"]} */"]
76
- }, message.reason, message.action ? (0, _react.jsx)("span", {
92
+ })), (0, _react2.jsx)("div", {
93
+ css: [/*#__PURE__*/(0, _react2.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"]} */"]
94
+ }, (0, _react2.jsx)("div", {
95
+ 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"]} */"]
96
+ }, typeof message === "string" ? message : message.happend), typeof message === "string" ? null : (0, _react2.jsx)(_react3.default.Fragment, null, (0, _react2.jsx)("div", {
97
+ 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"]} */"]
98
+ }, message.reason, message.action ? (0, _react2.jsx)("span", {
77
99
  css: _ref3
78
- }, message.action) : null), message.log ? (0, _react.jsx)("div", {
100
+ }, message.action) : null), message.log ? (0, _react2.jsx)("div", {
79
101
  css: _ref2
80
- }, (0, _react.jsx)(CopyButton, {
102
+ }, (0, _react2.jsx)(CopyButton, {
81
103
  value: message.log
82
- }, "\u30A8\u30E9\u30FC\u30ED\u30B0\u3092\u30B3\u30D4\u30FC\u3059\u308B")) : null)), (0, _react.jsx)("div", null, (0, _react.jsx)(_Button.Button, {
83
- css: /*#__PURE__*/(0, _react.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"]} */"),
84
- icon: (0, _react.jsx)(_Close.default, {
104
+ }, "\u30A8\u30E9\u30FC\u30ED\u30B0\u3092\u30B3\u30D4\u30FC\u3059\u308B")) : null)), (0, _react2.jsx)("div", null, (0, _react2.jsx)(_Button.Button, {
105
+ css: /*#__PURE__*/(0, _react2.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"]} */"),
106
+ icon: (0, _react2.jsx)(_Close.default, {
85
107
  fontSize: "small"
86
108
  }),
87
109
  rounded: true,
88
- onClick: handleClick
89
- }))) : null));
110
+ onClick: () => {
111
+ setShow(false);
112
+ }
113
+ }))));
90
114
  };
91
115
 
92
116
  // Todo: Use TextButton
@@ -96,23 +120,23 @@ var _ref = process.env.NODE_ENV === "production" ? {
96
120
  styles: "text-decoration:underline"
97
121
  } : {
98
122
  name: "11cmobw-CopyButton",
99
- 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"]} */",
123
+ 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"]} */",
100
124
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
101
125
  };
102
126
  const CopyButton = ({
103
127
  children,
104
128
  value
105
129
  }) => {
106
- const [copyMessage, setCopyMessage] = (0, _react2.useState)("");
107
- const [copied, setCopied] = (0, _react2.useState)(false);
130
+ const [copyMessage, setCopyMessage] = (0, _react3.useState)("");
131
+ const [copied, setCopied] = (0, _react3.useState)(false);
108
132
  const theme = (0, _theme.useTheme)();
109
- return (0, _react.jsx)(_Tooltip.Tooltip, {
133
+ return (0, _react2.jsx)(_Tooltip.Tooltip, {
110
134
  title: copyMessage,
111
135
  arrow: true,
112
136
  placement: "top-end",
113
137
  open: copied
114
- }, (0, _react.jsx)("button", {
115
- css: [_Button.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"]} */"],
138
+ }, (0, _react2.jsx)("button", {
139
+ css: [_Button.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"]} */"],
116
140
  onClick: () => {
117
141
  const flag = (0, _copyToClipboard.copyToClipboard)(value);
118
142
  setCopyMessage(flag ? "コピーしました" : "コピーできませんでした");