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>

101 lines 17.4 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 = ["alignEdge", "arrowed", "autoAdjustPlacement", "children", "getPopupContainer", "placement", "popup", "popupClassName", "popupStyle"]; 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 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 _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 React, { forwardRef, useContext, useMemo } from "react"; import PropTypes from "prop-types"; import classNames from "classnames"; import { ConfigContext } from "../config-provider"; import Tooltip from "../tooltip"; import getPlacements from "./placements"; import "./style"; var prefix = "adui-popover"; var Popover = forwardRef(function (_ref, ref) { var alignEdge = _ref.alignEdge, arrowed = _ref.arrowed, _ref$autoAdjustPlacem = _ref.autoAdjustPlacement, autoAdjustPlacement = _ref$autoAdjustPlacem === void 0 ? true : _ref$autoAdjustPlacem, children = _ref.children, getPopupContainer = _ref.getPopupContainer, placement = _ref.placement, popup = _ref.popup, popupClassName = _ref.popupClassName, popupStyle = _ref.popupStyle, otherProps = _objectWithoutProperties(_ref, _excluded); var _useContext = useContext(ConfigContext), getPopupContainerContext = _useContext.getPopupContainer; var popupTransitionName = useMemo(function () { if (arrowed) { return "zoom-big"; } if (placement && placement.indexOf("top") === 0) { return "slide-down"; } if (placement && placement.indexOf("right") === 0) { return "slide-left"; } if (placement && placement.indexOf("left") === 0) { return "slide-right"; } return "slide-up"; }, [arrowed, placement]); return React.createElement(Tooltip, _extends({ autoAdjustPlacement: autoAdjustPlacement, getPopupContainer: getPopupContainer || getPopupContainerContext, placement: placement, popup: popup, popupClassName: classNames("".concat(prefix, "-popover"), popupClassName, _defineProperty(_defineProperty({}, "".concat(prefix, "-popover_noArrow"), !arrowed), "".concat(prefix, "-removeContentPadding"), !arrowed || typeof popup !== "string")), popupStyle: arrowed ? popupStyle : _objectSpread({ padding: 0 }, popupStyle), popupTransitionName: popupTransitionName, builtinPlacements: getPlacements({ alignEdge: alignEdge, autoAdjustPlacement: autoAdjustPlacement }), ref: ref }, otherProps), children); }); Popover.displayName = "Popover"; Popover.propTypes = { alignEdge: PropTypes.bool, arrowed: PropTypes.bool, children: PropTypes.node, defaultVisible: PropTypes.oneOf([null, true, false]), getPopupContainer: PropTypes.func, forceRender: PropTypes.bool, mouseEnterDelay: PropTypes.number, mouseLeaveDelay: PropTypes.number, onVisibleChange: PropTypes.func, placement: PropTypes.oneOf(["top", "left", "right", "bottom", "topLeft", "topRight", "bottomLeft", "bottomRight", "leftTop", "leftBottom", "rightTop", "rightBottom"]), popup: PropTypes.node, popupClassName: PropTypes.string, popupStyle: PropTypes.object, trigger: PropTypes.oneOf(["hover", "focus", "click"]), visible: PropTypes.oneOf([null, true, false]) }; Popover.defaultProps = { alignEdge: true, arrowed: true, children: "", defaultVisible: null, getPopupContainer: null, forceRender: false, mouseEnterDelay: 0, mouseLeaveDelay: 0.1, onVisibleChange: function onVisibleChange() {}, placement: "bottomLeft", popup: "文字提示", popupClassName: "", popupStyle: {}, trigger: "hover", visible: null }; export default Popover; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","useContext","useMemo","PropTypes","classNames","ConfigContext","Tooltip","getPlacements","prefix","Popover","_ref","ref","alignEdge","arrowed","_ref$autoAdjustPlacem","autoAdjustPlacement","children","getPopupContainer","placement","popup","popupClassName","popupStyle","otherProps","_objectWithoutProperties","_excluded","_useContext","getPopupContainerContext","popupTransitionName","indexOf","createElement","_extends","concat","_defineProperty","_objectSpread","padding","builtinPlacements","displayName","propTypes","bool","node","defaultVisible","oneOf","func","forceRender","mouseEnterDelay","number","mouseLeaveDelay","onVisibleChange","string","object","trigger","visible","defaultProps"],"sources":["../../components/popover/Popover.tsx"],"sourcesContent":["import React, { forwardRef, useContext, useMemo } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport { ConfigContext } from \"../config-provider\"\nimport Tooltip, { ITooltipProps } from \"../tooltip\"\nimport getPlacements from \"./placements\"\nimport \"./style\"\n\nconst prefix = \"adui-popover\"\n\nexport interface IPopoverProps extends ITooltipProps {\n  [key: string]: any\n  /**\n   * 是否边缘对齐\n   */\n  alignEdge?: boolean\n  /**\n   * 是否带有箭头\n   */\n  arrowed?: boolean\n}\n\n/**\n * 气泡提示用于触发、操作某项信息临时性弹出的内容，高于当前页面层级，为内容的轻量延伸。\n * Popover 是基于 Tooltip 进行封装的。\n * 可能是文字解释，也可能内涵操作，可设置带箭头、或不带箭头。\n * Popover 默认边缘对齐。\n */\nconst Popover: React.ForwardRefExoticComponent<\n  IPopoverProps & React.RefAttributes<any>\n> = forwardRef(\n  (\n    {\n      alignEdge,\n      arrowed,\n      autoAdjustPlacement = true,\n      children,\n      getPopupContainer,\n      placement,\n      popup,\n      popupClassName,\n      popupStyle,\n      ...otherProps\n    }: IPopoverProps,\n    ref\n  ) => {\n    const { getPopupContainer: getPopupContainerContext } =\n      useContext(ConfigContext)\n\n    const popupTransitionName = useMemo(() => {\n      if (arrowed) {\n        return \"zoom-big\"\n      }\n      if (placement && placement.indexOf(\"top\") === 0) {\n        return \"slide-down\"\n      }\n      if (placement && placement.indexOf(\"right\") === 0) {\n        return \"slide-left\"\n      }\n      if (placement && placement.indexOf(\"left\") === 0) {\n        return \"slide-right\"\n      }\n      return \"slide-up\"\n    }, [arrowed, placement])\n\n    return (\n      <Tooltip\n        autoAdjustPlacement={autoAdjustPlacement}\n        getPopupContainer={getPopupContainer || getPopupContainerContext}\n        placement={placement}\n        popup={popup}\n        popupClassName={classNames(`${prefix}-popover`, popupClassName, {\n          [`${prefix}-popover_noArrow`]: !arrowed,\n          [`${prefix}-removeContentPadding`]:\n            !arrowed || typeof popup !== \"string\",\n        })}\n        popupStyle={arrowed ? popupStyle : { padding: 0, ...popupStyle }}\n        popupTransitionName={popupTransitionName}\n        builtinPlacements={getPlacements({ alignEdge, autoAdjustPlacement })}\n        ref={ref}\n        {...otherProps}\n      >\n        {children}\n      </Tooltip>\n    )\n  }\n)\n\nPopover.displayName = \"Popover\"\n\nPopover.propTypes = {\n  /**\n   * 是否边缘对齐\n   */\n  alignEdge: PropTypes.bool,\n  /**\n   * 是否带有箭头\n   */\n  arrowed: PropTypes.bool,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 气泡提示是否默认显示\n   */\n  defaultVisible: PropTypes.oneOf([null, true, false]),\n  /**\n   * 指定气泡提示的父级，默认为 document\n   */\n  getPopupContainer: PropTypes.func,\n  /**\n   * forceRender before first visible\n   */\n  forceRender: PropTypes.bool,\n  /**\n   * mouseEnter 显示的延时，单位：s，只在 trigger=\"hover\" 时有效\n   */\n  mouseEnterDelay: PropTypes.number,\n  /**\n   * mouseLeave 消失的延时，单位：s，只在 trigger=\"hover\" 时有效\n   */\n  mouseLeaveDelay: PropTypes.number,\n  /**\n   * 显示发生变化时的 handler\n   */\n  onVisibleChange: PropTypes.func,\n  /**\n   * 弹出层位置\n   */\n  placement: PropTypes.oneOf([\n    \"top\",\n    \"left\",\n    \"right\",\n    \"bottom\",\n    \"topLeft\",\n    \"topRight\",\n    \"bottomLeft\",\n    \"bottomRight\",\n    \"leftTop\",\n    \"leftBottom\",\n    \"rightTop\",\n    \"rightBottom\",\n  ]),\n  /**\n   * 弹出内容\n   */\n  popup: PropTypes.node,\n  /**\n   * 弹出框的附加类名\n   */\n  popupClassName: PropTypes.string,\n  /**\n   * 气泡提示的附加样式\n   */\n  popupStyle: PropTypes.object,\n  /**\n   * 触发方式\n   */\n  trigger: PropTypes.oneOf([\"hover\", \"focus\", \"click\"]),\n  /**\n   * 手动控制气泡提示是否显示\n   */\n  visible: PropTypes.oneOf([null, true, false]),\n}\n\nPopover.defaultProps = {\n  alignEdge: true,\n  arrowed: true,\n  children: \"\",\n  defaultVisible: null,\n  getPopupContainer: null,\n  forceRender: false,\n  mouseEnterDelay: 0,\n  mouseLeaveDelay: 0.1,\n  onVisibleChange: () => {},\n  placement: \"bottomLeft\",\n  popup: \"文字提示\",\n  popupClassName: \"\",\n  popupStyle: {},\n  trigger: \"hover\",\n  visible: null,\n}\n\nexport default Popover\n"],"mappings":"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","ignoreList":[]}