UNPKG

adui

Version:

<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>

114 lines 16.2 kB
var _excluded = ["cancelButton", "cancelText", "confirmButton", "confirmText", "onCancel", "onConfirm", "onVisibleChange", "popup", "visible"]; function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } } function _arrayWithHoles(r) { if (Array.isArray(r)) return r; } function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; } function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; } import React, { forwardRef, useState } from "react"; import PropTypes from "prop-types"; import Button from "../button/Button"; import Popover from "../popover"; import "./style"; var noop = function noop() {}; var prefix = "adui-popconfirm"; var Popconfirm = forwardRef(function (_ref, ref) { var cancelButton = _ref.cancelButton, cancelText = _ref.cancelText, confirmButton = _ref.confirmButton, confirmText = _ref.confirmText, onCancel = _ref.onCancel, onConfirm = _ref.onConfirm, onVisibleChange = _ref.onVisibleChange, popup = _ref.popup, visibleProp = _ref.visible, otherProps = _objectWithoutProperties(_ref, _excluded); var _useState = useState(visibleProp), _useState2 = _slicedToArray(_useState, 2), visible = _useState2[0], setVisible = _useState2[1]; if (visibleProp !== null && visible !== visibleProp) { setVisible(!!visibleProp); } var handleClickCancel = function handleClickCancel(e) { if (visibleProp === null) { setVisible(false); } if (onVisibleChange) { onVisibleChange(false, { target: "cancel" }); } if (onCancel) { onCancel(e); } }; var handleClickConfirm = function handleClickConfirm(e) { if (visibleProp === null) { setVisible(false); } if (onVisibleChange) { onVisibleChange(false, { target: "confirm" }); } if (onConfirm) { onConfirm(e); } }; var handleVisibleChange = function handleVisibleChange(bool) { if (visibleProp === null) { setVisible(bool); } if (onVisibleChange) { onVisibleChange(bool, {}); } }; return React.createElement(Popover, _extends({ popup: React.createElement("div", null, React.createElement("div", { className: "".concat(prefix, "-top") }, popup), React.createElement("div", { className: "".concat(prefix, "-bottom") }, React.createElement(Button, _extends({ onClick: handleClickCancel, theme: "light" }, cancelButton), cancelText), React.createElement(Button, _extends({ intent: "primary", onClick: handleClickConfirm, theme: "light" }, confirmButton), confirmText))), visible: visible, onVisibleChange: handleVisibleChange, ref: ref }, otherProps)); }); Popconfirm.displayName = "Popconfirm"; Popconfirm.propTypes = { cancelButton: PropTypes.object, cancelText: PropTypes.node, confirmButton: PropTypes.object, confirmText: PropTypes.node, onCancel: PropTypes.func, onConfirm: PropTypes.func, onVisibleChange: PropTypes.func, popup: PropTypes.node, trigger: PropTypes.string, visible: PropTypes.oneOf([null, true, false]) }; Popconfirm.defaultProps = { cancelButton: {}, cancelText: "取消", confirmButton: {}, confirmText: "确认", onCancel: noop, onConfirm: noop, onVisibleChange: noop, popup: null, trigger: "click", visible: null }; export default Popconfirm; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useState","PropTypes","Button","Popover","noop","prefix","Popconfirm","_ref","ref","cancelButton","cancelText","confirmButton","confirmText","onCancel","onConfirm","onVisibleChange","popup","visibleProp","visible","otherProps","_objectWithoutProperties","_excluded","_useState","_useState2","_slicedToArray","setVisible","handleClickCancel","e","target","handleClickConfirm","handleVisibleChange","bool","createElement","_extends","className","concat","onClick","theme","intent","displayName","propTypes","object","node","func","trigger","string","oneOf","defaultProps"],"sources":["../../components/popconfirm/Popconfirm.tsx"],"sourcesContent":["import React, { forwardRef, useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport Button, { IButtonProps } from \"../button/Button\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport \"./style\"\n\nconst noop = () => {}\nconst prefix = `adui-popconfirm`\n\ninterface IVisibleOptions {\n  target?: \"cancel\" | \"confirm\"\n}\n\nexport interface IPopconfirmProps\n  extends Omit<IPopoverProps, \"onVisibleChange\"> {\n  cancelButton?: IButtonProps\n  cancelText?: React.ReactNode\n  confirmButton?: IButtonProps\n  confirmText?: React.ReactNode\n  onCancel?: (\n    e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n  ) => void\n  onConfirm?: (\n    e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n  ) => void\n  onVisibleChange?: (visible: boolean, options: IVisibleOptions) => void\n}\n\n/**\n * 弹出式面板组件。\n */\nconst Popconfirm: React.ForwardRefExoticComponent<\n  IPopconfirmProps & React.RefAttributes<any>\n> = forwardRef(\n  (\n    {\n      cancelButton,\n      cancelText,\n      confirmButton,\n      confirmText,\n      onCancel,\n      onConfirm,\n      onVisibleChange,\n      popup,\n      visible: visibleProp,\n      ...otherProps\n    }: IPopconfirmProps,\n    ref: React.Ref<any>\n  ) => {\n    const [visible, setVisible] = useState(visibleProp)\n\n    // 相当于生命周期 getDerivedStateFromProps\n    if (visibleProp !== null && visible !== visibleProp) {\n      setVisible(!!visibleProp)\n    }\n\n    const handleClickCancel = (\n      e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n    ) => {\n      // 判断是否由外部控制，如果等于 null 则交由组件自己控制\n      if (visibleProp === null) {\n        setVisible(false)\n      }\n      if (onVisibleChange) {\n        onVisibleChange(false, { target: \"cancel\" })\n      }\n      if (onCancel) {\n        onCancel(e)\n      }\n    }\n\n    const handleClickConfirm = (\n      e: React.MouseEvent<HTMLButtonElement | HTMLAnchorElement>\n    ) => {\n      if (visibleProp === null) {\n        setVisible(false)\n      }\n      if (onVisibleChange) {\n        onVisibleChange(false, { target: \"confirm\" })\n      }\n      if (onConfirm) {\n        onConfirm(e)\n      }\n    }\n\n    const handleVisibleChange = (bool: boolean) => {\n      if (visibleProp === null) {\n        setVisible(bool)\n      }\n      if (onVisibleChange) {\n        onVisibleChange(bool, {})\n      }\n    }\n\n    return (\n      <Popover\n        popup={\n          <div>\n            <div className={`${prefix}-top`}>{popup}</div>\n            <div className={`${prefix}-bottom`}>\n              <Button\n                onClick={handleClickCancel}\n                theme=\"light\"\n                {...cancelButton}\n              >\n                {cancelText}\n              </Button>\n              <Button\n                intent=\"primary\"\n                onClick={handleClickConfirm}\n                theme=\"light\"\n                {...confirmButton}\n              >\n                {confirmText}\n              </Button>\n            </div>\n          </div>\n        }\n        visible={visible}\n        onVisibleChange={handleVisibleChange}\n        ref={ref}\n        {...otherProps}\n      />\n    )\n  }\n)\n\nPopconfirm.displayName = \"Popconfirm\"\n\nPopconfirm.propTypes = {\n  /**\n   * 取消按钮prop\n   */\n  cancelButton: PropTypes.object,\n  /**\n   * 取消按钮文本\n   */\n  cancelText: PropTypes.node,\n  /**\n   * 确定按钮prop\n   */\n  confirmButton: PropTypes.object,\n  /**\n   * 确定按钮文本\n   */\n  confirmText: PropTypes.node,\n  /**\n   * 点击取消按钮时的事件\n   */\n  onCancel: PropTypes.func,\n  /**\n   * 点击确认按钮时的事件\n   */\n  onConfirm: PropTypes.func,\n  /**\n   *  是否显示隐藏的handler\n   */\n  onVisibleChange: PropTypes.func,\n  /**\n   * 弹窗自定义内容节点\n   */\n  popup: PropTypes.node,\n  /**\n   * 触发弹窗类型\n   */\n  trigger: PropTypes.string,\n  /**\n   * 触发弹窗类型\n   */\n  visible: PropTypes.oneOf([null, true, false]),\n}\n\nPopconfirm.defaultProps = {\n  cancelButton: {},\n  cancelText: \"取消\",\n  confirmButton: {},\n  confirmText: \"确认\",\n  onCancel: noop,\n  onConfirm: noop,\n  onVisibleChange: noop,\n  popup: null,\n  trigger: \"click\",\n  visible: null,\n}\n\nexport default Popconfirm\n"],"mappings":"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","ignoreList":[]}