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>

141 lines (108 loc) 16.5 kB
"use strict"; function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var React = _interopRequireWildcard(require("react")); var ReactDOM = _interopRequireWildcard(require("react-dom")); var _classnames = _interopRequireDefault(require("classnames")); var _Dialog = _interopRequireDefault(require("./Dialog")); var _icon = _interopRequireDefault(require("../icon")); require("./style"); var _excluded = ["afterClose", "content", "contentTitle", "contentText", "intent", "onCancel", "onClose", "onConfirm"]; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); } function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } 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 _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } 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; } var prefix = "adui-channels-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["default"], _extends({ afterClose: afterClose, destroyAfterClose: true, onCancel: function onCancel() { if (onClose) { onClose(_onCancel); } }, onConfirm: function onConfirm() { if (onClose) { onClose(_onConfirm); } } }, otherProps), intent ? React.createElement("div", { className: (0, _classnames["default"])("".concat(prefix, "-intentWrapper"), "".concat(prefix, "-").concat(intent), _defineProperty({}, "".concat(prefix, "-intentWrapper_center"), !contentTitle || !contentText)) }, React.createElement(_icon["default"], { 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 }; }; var _default = confirm; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","ICON_INTENTS","danger","info","success","warning","Confirm","props","afterClose","content","contentTitle","contentText","intent","onCancel","onClose","onConfirm","otherProps","classNames","confirm","config","container","document","createElement","body","appendChild","unmountResult","ReactDOM","unmountComponentAtNode","parentNode","removeChild","render","currentConfig","cb","cbReturn","visible","update","newConfig","destroy"],"sources":["../../components/channels-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-channels-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      {...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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"}