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>

102 lines 15.7 kB
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } var _excluded = ["afterClose", "content", "contentTitle", "contentText", "intent", "onCancel", "onClose", "onConfirm"]; function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; } function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } 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 _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; } function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; } function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } 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 * as React from "react"; import * as ReactDOM from "react-dom"; import classNames from "classnames"; import Dialog from "./Dialog"; import Icon from "../icon"; import "./style"; var prefix = "adui-dialog"; var ICON_INTENTS = { danger: "alert-circle", info: "info-circle", success: "tick-circle", warning: "warning" }; var Confirm = function Confirm(props) { var afterClose = props.afterClose, content = props.content, contentTitle = props.contentTitle, contentText = props.contentText, intent = props.intent, _onCancel = props.onCancel, onClose = props.onClose, _onConfirm = props.onConfirm, otherProps = _objectWithoutProperties(props, _excluded); return React.createElement(Dialog, _extends({ afterClose: afterClose, destroyAfterClose: true, onCancel: function onCancel() { if (onClose) { onClose(_onCancel); } }, onConfirm: function onConfirm() { if (onClose) { onClose(_onConfirm); } }, intent: intent }, otherProps), intent ? React.createElement("div", { className: classNames("".concat(prefix, "-intentWrapper"), "".concat(prefix, "-").concat(intent), _defineProperty({}, "".concat(prefix, "-intentWrapper_center"), !contentTitle || !contentText)) }, React.createElement(Icon, { className: "".concat(prefix, "-intentIcon"), size: 48, icon: ICON_INTENTS[intent] }), React.createElement("div", { className: "".concat(prefix, "-intentContent") }, !!contentTitle && React.createElement("div", { className: "".concat(prefix, "-intentTitle") }, contentTitle), !!contentText && React.createElement("div", { className: "".concat(prefix, "-intentText") }, contentText))) : content); }; var confirm = function confirm(config) { var container = document.createElement("div"); document.body.appendChild(container); function afterClose() { var unmountResult = ReactDOM.unmountComponentAtNode(container); if (unmountResult && container.parentNode) { container.parentNode.removeChild(container); } } function render(props) { ReactDOM.render(React.createElement(Confirm, props), container); } var currentConfig = {}; function onClose(cb) { var cbReturn; if (cb) { cbReturn = cb(); } currentConfig = _objectSpread(_objectSpread({}, currentConfig), {}, { afterClose: afterClose, visible: cbReturn === false }); render(currentConfig); } currentConfig = _objectSpread(_objectSpread({}, config), {}, { afterClose: afterClose, onClose: onClose, visible: true }); function update(newConfig) { currentConfig = _objectSpread(_objectSpread({}, currentConfig), newConfig); render(currentConfig); } render(currentConfig); return { destroy: onClose, update: update }; }; export default confirm; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","ReactDOM","classNames","Dialog","Icon","prefix","ICON_INTENTS","danger","info","success","warning","Confirm","props","afterClose","content","contentTitle","contentText","intent","onCancel","onClose","onConfirm","otherProps","_objectWithoutProperties","_excluded","createElement","_extends","destroyAfterClose","className","concat","_defineProperty","size","icon","confirm","config","container","document","body","appendChild","unmountResult","unmountComponentAtNode","parentNode","removeChild","render","currentConfig","cb","cbReturn","_objectSpread","visible","update","newConfig","destroy"],"sources":["../../components/dialog/confirm.tsx"],"sourcesContent":["/**\n * confirm 是将 Dialog 函数式编程的结果。\n * 1. confirm 是为了让使用者方便地函数式调用组件；因此 confirm 方法的 visible 状态是不交给外部处理的；\n * 2. 每次调用 confirm 都会创建一个 Dialog，在 close 时都需要进行 unmountComponentAtNode。\n */\nimport * as React from \"react\"\nimport * as ReactDOM from \"react-dom\"\nimport classNames from \"classnames\"\nimport Dialog, { IDialogProps } from \"./Dialog\"\nimport Icon from \"../icon\"\nimport \"./style\"\n\nconst prefix = \"adui-dialog\"\n\nconst ICON_INTENTS = {\n  danger: \"alert-circle\" as \"alert-circle\",\n  info: \"info-circle\" as \"info-circle\",\n  success: \"tick-circle\" as \"tick-circle\",\n  warning: \"warning\" as \"warning\",\n}\n\nexport interface IConfirmProps extends IDialogProps {\n  content?: React.ReactNode\n  contentTitle?: React.ReactNode\n  contentText?: React.ReactNode\n  intent?: \"danger\" | \"info\" | \"success\" | \"warning\"\n  onClose?: (func?: (() => void) | null) => void\n}\n\n/**\n * content, contentTitle, contentText, intent 都不是 Dialog 直接处理的 prop；\n * 其中，content 其实就是 children，\n * contentTitle、contentText 是专门提供给 .info .success .warning .danger 的 prop。\n */\nconst Confirm = (props: IConfirmProps) => {\n  const {\n    afterClose,\n    content,\n    contentTitle,\n    contentText,\n    intent,\n    onCancel,\n    onClose,\n    onConfirm,\n    ...otherProps\n  } = props\n\n  return (\n    <Dialog\n      afterClose={afterClose}\n      destroyAfterClose\n      onCancel={() => {\n        if (onClose) {\n          onClose(onCancel)\n        }\n      }}\n      onConfirm={() => {\n        if (onClose) {\n          onClose(onConfirm)\n        }\n      }}\n      intent={intent}\n      {...otherProps}\n    >\n      {intent ? (\n        <div\n          className={classNames(\n            `${prefix}-intentWrapper`,\n            `${prefix}-${intent}`,\n            {\n              [`${prefix}-intentWrapper_center`]: !contentTitle || !contentText,\n            }\n          )}\n        >\n          <Icon\n            className={`${prefix}-intentIcon`}\n            size={48}\n            icon={ICON_INTENTS[intent]}\n          />\n          <div className={`${prefix}-intentContent`}>\n            {!!contentTitle && (\n              <div className={`${prefix}-intentTitle`}>{contentTitle}</div>\n            )}\n            {!!contentText && (\n              <div className={`${prefix}-intentText`}>{contentText}</div>\n            )}\n          </div>\n        </div>\n      ) : (\n        content\n      )}\n    </Dialog>\n  )\n}\n\nconst confirm = (config: IConfirmProps) => {\n  const container = document.createElement(\"div\")\n  document.body.appendChild(container)\n\n  function afterClose() {\n    const unmountResult = ReactDOM.unmountComponentAtNode(container)\n    if (unmountResult && container.parentNode) {\n      container.parentNode.removeChild(container)\n    }\n  }\n\n  /**\n   * 这里挂载到 container 实际上是空的，因为 Dialog 自身会去解决挂载；\n   * 因此每一次 render 都会有两个 div append 到 dom 中，一个为空，即这个，另一个为 Dialog。\n   */\n  function render(props: IConfirmProps) {\n    ReactDOM.render(<Confirm {...props} />, container)\n  }\n\n  let currentConfig: any = {}\n\n  /**\n   * 关闭时一定要执行 afterClose，Dialog 自身会去 destroy，但是那个空的 div 需要在这里 destory。\n   */\n  function onClose(cb: () => void) {\n    let cbReturn: any\n    if (cb) {\n      cbReturn = cb()\n    }\n    currentConfig = {\n      ...currentConfig,\n      afterClose,\n      visible: cbReturn === false,\n    }\n    render(currentConfig)\n  }\n\n  currentConfig = {\n    ...config,\n    afterClose,\n    onClose,\n    visible: true,\n  }\n\n  function update(newConfig: IConfirmProps) {\n    currentConfig = {\n      ...currentConfig,\n      ...newConfig,\n    }\n    render(currentConfig)\n  }\n\n  render(currentConfig)\n\n  return {\n    destroy: onClose,\n    update,\n  }\n}\n\nexport default confirm\n"],"mappings":"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","ignoreList":[]}