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.
- package/Alert/Alert.js +48 -24
- package/Alert/Alert.js.map +1 -1
- package/ImageViewer/ImageViewer.js +34 -33
- package/ImageViewer/ImageViewer.js.map +1 -1
- package/cjs/Alert/Alert.js +64 -40
- package/cjs/Alert/Alert.js.map +1 -1
- package/cjs/ImageViewer/ImageViewer.js +51 -50
- package/cjs/ImageViewer/ImageViewer.js.map +1 -1
- package/esm/Alert/Alert.js +48 -24
- package/esm/Alert/Alert.js.map +1 -1
- package/esm/ImageViewer/ImageViewer.js +34 -33
- package/esm/ImageViewer/ImageViewer.js.map +1 -1
- package/package.json +3 -4
- package/Alert/useAlertMotion.d.ts +0 -10
- package/Alert/useAlertMotion.js +0 -50
- package/Alert/useAlertMotion.js.map +0 -1
- package/cjs/Alert/useAlertMotion.js +0 -54
- package/cjs/Alert/useAlertMotion.js.map +0 -1
- package/cjs/react-spring.d.js +0 -4
- package/cjs/react-spring.d.js.map +0 -1
- package/esm/Alert/useAlertMotion.js +0 -50
- package/esm/Alert/useAlertMotion.js.map +0 -1
- package/esm/react-spring.d.js +0 -2
- package/esm/react-spring.d.js.map +0 -1
- package/react-spring.d.js +0 -2
- package/react-spring.d.js.map +0 -1
- package/types/Alert/useAlertMotion.d.ts +0 -10
package/cjs/Alert/Alert.js
CHANGED
|
@@ -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
|
|
7
|
+
var _react = require("motion/react");
|
|
8
8
|
var _copyToClipboard = require("../@utils/copyToClipboard");
|
|
9
|
-
var
|
|
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
|
|
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,
|
|
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,
|
|
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,
|
|
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
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
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,
|
|
67
|
-
css: /*#__PURE__*/(0,
|
|
68
|
-
}, (0,
|
|
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,
|
|
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,
|
|
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,
|
|
74
|
-
}, typeof message === "string" ? message : message.happend), typeof message === "string" ? null : (0,
|
|
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,
|
|
76
|
-
}, message.reason, message.action ? (0,
|
|
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,
|
|
100
|
+
}, message.action) : null), message.log ? (0, _react2.jsx)("div", {
|
|
79
101
|
css: _ref2
|
|
80
|
-
}, (0,
|
|
102
|
+
}, (0, _react2.jsx)(CopyButton, {
|
|
81
103
|
value: message.log
|
|
82
|
-
}, "\u30A8\u30E9\u30FC\u30ED\u30B0\u3092\u30B3\u30D4\u30FC\u3059\u308B")) : null)), (0,
|
|
83
|
-
css: /*#__PURE__*/(0,
|
|
84
|
-
icon: (0,
|
|
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:
|
|
89
|
-
|
|
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,
|
|
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,
|
|
107
|
-
const [copied, setCopied] = (0,
|
|
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,
|
|
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,
|
|
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,
|
|
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 ? "コピーしました" : "コピーできませんでした");
|