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>
119 lines (98 loc) • 14.8 kB
JavaScript
var _excluded = ["afterClose", "content", "contentTitle", "contentText", "intent", "onCancel", "onClose", "onConfirm"];
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; }
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-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, _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: 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","confirm","config","container","document","createElement","body","appendChild","unmountResult","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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"}