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
JavaScript
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":[]}