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>

137 lines (114 loc) 16.1 kB
var _excluded = ["cancelButton", "cancelText", "confirmButton", "confirmText", "onCancel", "onConfirm", "onVisibleChange", "popup", "visible"]; function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _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(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } 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","cancelButton","cancelText","confirmButton","confirmText","onCancel","onConfirm","onVisibleChange","popup","visibleProp","visible","otherProps","setVisible","handleClickCancel","e","target","handleClickConfirm","handleVisibleChange","bool","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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"}