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>

59 lines 12.9 kB
var _excluded = ["children", "popup", "popupVisible"]; 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 _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 } from "react"; import PropTypes from "prop-types"; import Trigger from "rc-trigger"; import { builtinPlacements } from "./builtinPlacements"; import "./style"; var PopTrigger = forwardRef(function (_ref, ref) { var children = _ref.children, popup = _ref.popup, popupVisible = _ref.popupVisible, otherProps = _objectWithoutProperties(_ref, _excluded); var visibleProp = {}; if (popupVisible !== null) { visibleProp.popupVisible = popupVisible; } return React.createElement(Trigger, _extends({ ref: ref, popup: typeof popup === "string" ? React.createElement("div", null, popup) : popup }, visibleProp, otherProps), typeof children === "string" ? React.createElement("span", null, children) : children); }); PopTrigger.displayName = "PopTrigger"; PopTrigger.propTypes = { action: PropTypes.any, builtinPlacements: PropTypes.object, children: PropTypes.node, defaultPopupVisible: PropTypes.bool, destroyPopupOnHide: PropTypes.bool, getPopupContainer: PropTypes.func, mouseEnterDelay: PropTypes.number, mouseLeaveDelay: PropTypes.number, popup: PropTypes.node.isRequired, popupAlign: PropTypes.object, popupClassName: PropTypes.string, popupPlacement: PropTypes.oneOf(["top", "left", "right", "bottom", "topLeft", "topRight", "bottomLeft", "bottomRight", "leftTop", "leftBottom", "rightTop", "rightBottom"]), popupStyle: PropTypes.object, popupTransitionName: PropTypes.string, popupVisible: PropTypes.oneOf([null, true, false]) }; PopTrigger.defaultProps = { action: ["hover"], builtinPlacements: builtinPlacements, children: "", defaultPopupVisible: false, destroyPopupOnHide: false, getPopupContainer: null, mouseEnterDelay: 0, mouseLeaveDelay: 0.1, popupAlign: null, popupClassName: "", popupPlacement: "bottom", popupStyle: null, popupTransitionName: undefined, popupVisible: null }; export default PopTrigger; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","forwardRef","PropTypes","Trigger","builtinPlacements","PopTrigger","_ref","ref","children","popup","popupVisible","otherProps","_objectWithoutProperties","_excluded","visibleProp","createElement","_extends","displayName","propTypes","action","any","object","node","defaultPopupVisible","bool","destroyPopupOnHide","getPopupContainer","func","mouseEnterDelay","number","mouseLeaveDelay","isRequired","popupAlign","popupClassName","string","popupPlacement","oneOf","popupStyle","popupTransitionName","defaultProps","undefined"],"sources":["../../components/pop-trigger/PopTrigger.tsx"],"sourcesContent":["import React, { forwardRef } from \"react\"\nimport PropTypes from \"prop-types\"\nimport Trigger from \"rc-trigger\"\nimport { builtinPlacements } from \"./builtinPlacements\"\nimport \"./style\"\n\ninterface IVisible {\n  popupVisible?: boolean\n}\n\ninterface IBaseObject {\n  [key: string]: any\n}\n\nexport interface ITrigger {\n  forcePopupAlign?: () => void\n  getRootDomNode?: () => HTMLElement\n}\n\nexport type Placement =\n  | \"bottom\"\n  | \"bottomLeft\"\n  | \"bottomRight\"\n  | \"left\"\n  | \"leftBottom\"\n  | \"leftTop\"\n  | \"right\"\n  | \"rightBottom\"\n  | \"rightTop\"\n  | \"top\"\n  | \"topLeft\"\n  | \"topRight\"\n\nexport interface IPopTriggerProps {\n  [key: string]: any\n  action?: string[]\n  builtinPlacements?: object\n  children?: React.ReactNode\n  defaultPopupVisible?: null | boolean\n  destroyPopupOnHide?: boolean\n  getPopupContainer?: null | ((node: HTMLElement) => HTMLElement)\n  mouseEnterDelay?: number\n  mouseLeaveDelay?: number\n  onPopupAlign: (node: HTMLElement, align?: IBaseObject) => void\n  onPopupVisibleChange: (visible: boolean) => void\n  popup: React.ReactNode\n  popupAlign?: null | object\n  popupClassName?: string\n  popupPlacement?: Placement\n  popupStyle?: null | React.CSSProperties\n  popupTransitionName?: string\n  popupVisible?: null | boolean\n  zIndex?: React.ReactNode\n}\n\n/**\n * 弹出行为。\n *\n * PopTrigger 是基于 rc-trigger (MIT License) 进行封装的。\n * PopTrigger 的定位是抽象的弹出行为。\n * PopTrigger 应提供所有弹出相关的能力与配置，供 Tooltip、Select 等调用。\n * PopTrigger 也可以被使用者直接使用，实现自定的弹出功能。\n */\nconst PopTrigger: React.ForwardRefExoticComponent<\n  IPopTriggerProps & React.RefAttributes<any>\n> = forwardRef(\n  ({ children, popup, popupVisible, ...otherProps }: IPopTriggerProps, ref) => {\n    const visibleProp: IVisible = {}\n\n    if (popupVisible !== null) {\n      visibleProp.popupVisible = popupVisible\n    }\n\n    return (\n      <Trigger\n        ref={ref}\n        popup={typeof popup === \"string\" ? <div>{popup}</div> : popup}\n        {...visibleProp}\n        {...otherProps}\n      >\n        {typeof children === \"string\" ? <span>{children}</span> : children}\n      </Trigger>\n    )\n  }\n)\n\nPopTrigger.displayName = \"PopTrigger\"\n\nPopTrigger.propTypes = {\n  /**\n   * 触发方式\n   */\n  action: PropTypes.any,\n  /**\n   * 预设位置，需要包含 popupPlacement 的 12 个位置\n   */\n  builtinPlacements: PropTypes.object,\n  /**\n   * 子节点\n   */\n  children: PropTypes.node,\n  /**\n   * 弹出框是否默认显示\n   */\n  defaultPopupVisible: PropTypes.bool,\n  /**\n   * 弹出框是否在消失时移出 dom\n   */\n  destroyPopupOnHide: PropTypes.bool,\n  /**\n   * 指定弹出框的父级，默认为 document\n   */\n  getPopupContainer: PropTypes.func,\n  /**\n   * mouseEnter 显示的延时，单位：s，只在 action=[\"hover\"] 时有效\n   */\n  mouseEnterDelay: PropTypes.number,\n  /**\n   * mouseLeave 消失的延时，单位：s，只在 action=[\"hover\"] 时有效\n   */\n  mouseLeaveDelay: PropTypes.number,\n  /**\n   * 弹出内容\n   */\n  popup: PropTypes.node.isRequired,\n  /**\n   * 弹出层的位置控制，API 请参考 https://github.com/yiminghe/dom-align\n   */\n  popupAlign: PropTypes.object,\n  /**\n   * 弹出框的附加类名\n   */\n  popupClassName: PropTypes.string,\n  /**\n   * 弹出层位置，也可以不使用这些预设位置，使用 popupAlign 属性。\n   * 页面在弹出方向上无法滚动时会往另外一个方向弹出，保证有空间去滚动看到。\n   * 如设置了 popupPlacement=\"bottom\"，但元素已经位于页面底部时，popup 则会变为 top。\n   * 因为有 Trigger 的这个”保证有空间去滚动看到“的设计逻辑，所以不考虑做页面滚动时的自动变换 popupPlacement。\n   */\n  popupPlacement: 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  popupStyle: PropTypes.object,\n  /**\n   * 弹出框的动画类名，动画格式遵循 rc-animate\n   */\n  popupTransitionName: PropTypes.string,\n  /**\n   * 弹出框是否显示\n   */\n  popupVisible: PropTypes.oneOf([null, true, false]),\n}\n\nPopTrigger.defaultProps = {\n  action: [\"hover\"],\n  builtinPlacements,\n  children: \"\",\n  defaultPopupVisible: false,\n  destroyPopupOnHide: false,\n  getPopupContainer: null,\n  mouseEnterDelay: 0,\n  mouseLeaveDelay: 0.1,\n  popupAlign: null,\n  popupClassName: \"\",\n  popupPlacement: \"bottom\",\n  popupStyle: null,\n  popupTransitionName: undefined,\n  popupVisible: null,\n}\n\nexport default PopTrigger\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,UAAU,QAAQ,OAAO;AACzC,OAAOC,SAAS,MAAM,YAAY;AAClC,OAAOC,OAAO,MAAM,YAAY;AAChC,SAASC,iBAAiB,QAAQ,qBAAqB;AACvD,OAAO,SAAS;AA2DhB,IAAMC,UAEL,GAAGJ,UAAU,CACZ,UAAAK,IAAA,EAAqEC,GAAG,EAAK;EAAA,IAA1EC,QAAQ,GAAAF,IAAA,CAARE,QAAQ;IAAEC,KAAK,GAAAH,IAAA,CAALG,KAAK;IAAEC,YAAY,GAAAJ,IAAA,CAAZI,YAAY;IAAKC,UAAU,GAAAC,wBAAA,CAAAN,IAAA,EAAAO,SAAA;EAC7C,IAAMC,WAAqB,GAAG,CAAC,CAAC;EAEhC,IAAIJ,YAAY,KAAK,IAAI,EAAE;IACzBI,WAAW,CAACJ,YAAY,GAAGA,YAAY;EACzC;EAEA,OACEV,KAAA,CAAAe,aAAA,CAACZ,OAAO,EAAAa,QAAA;IACNT,GAAG,EAAEA,GAAI;IACTE,KAAK,EAAE,OAAOA,KAAK,KAAK,QAAQ,GAAGT,KAAA,CAAAe,aAAA,cAAMN,KAAW,CAAC,GAAGA;EAAM,GAC1DK,WAAW,EACXH,UAAU,GAEb,OAAOH,QAAQ,KAAK,QAAQ,GAAGR,KAAA,CAAAe,aAAA,eAAOP,QAAe,CAAC,GAAGA,QACnD,CAAC;AAEd,CACF,CAAC;AAEDH,UAAU,CAACY,WAAW,GAAG,YAAY;AAErCZ,UAAU,CAACa,SAAS,GAAG;EAIrBC,MAAM,EAAEjB,SAAS,CAACkB,GAAG;EAIrBhB,iBAAiB,EAAEF,SAAS,CAACmB,MAAM;EAInCb,QAAQ,EAAEN,SAAS,CAACoB,IAAI;EAIxBC,mBAAmB,EAAErB,SAAS,CAACsB,IAAI;EAInCC,kBAAkB,EAAEvB,SAAS,CAACsB,IAAI;EAIlCE,iBAAiB,EAAExB,SAAS,CAACyB,IAAI;EAIjCC,eAAe,EAAE1B,SAAS,CAAC2B,MAAM;EAIjCC,eAAe,EAAE5B,SAAS,CAAC2B,MAAM;EAIjCpB,KAAK,EAAEP,SAAS,CAACoB,IAAI,CAACS,UAAU;EAIhCC,UAAU,EAAE9B,SAAS,CAACmB,MAAM;EAI5BY,cAAc,EAAE/B,SAAS,CAACgC,MAAM;EAOhCC,cAAc,EAAEjC,SAAS,CAACkC,KAAK,CAAC,CAC9B,KAAK,EACL,MAAM,EACN,OAAO,EACP,QAAQ,EACR,SAAS,EACT,UAAU,EACV,YAAY,EACZ,aAAa,EACb,SAAS,EACT,YAAY,EACZ,UAAU,EACV,aAAa,CACd,CAAC;EAIFC,UAAU,EAAEnC,SAAS,CAACmB,MAAM;EAI5BiB,mBAAmB,EAAEpC,SAAS,CAACgC,MAAM;EAIrCxB,YAAY,EAAER,SAAS,CAACkC,KAAK,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC;AACnD,CAAC;AAED/B,UAAU,CAACkC,YAAY,GAAG;EACxBpB,MAAM,EAAE,CAAC,OAAO,CAAC;EACjBf,iBAAiB,EAAjBA,iBAAiB;EACjBI,QAAQ,EAAE,EAAE;EACZe,mBAAmB,EAAE,KAAK;EAC1BE,kBAAkB,EAAE,KAAK;EACzBC,iBAAiB,EAAE,IAAI;EACvBE,eAAe,EAAE,CAAC;EAClBE,eAAe,EAAE,GAAG;EACpBE,UAAU,EAAE,IAAI;EAChBC,cAAc,EAAE,EAAE;EAClBE,cAAc,EAAE,QAAQ;EACxBE,UAAU,EAAE,IAAI;EAChBC,mBAAmB,EAAEE,SAAS;EAC9B9B,YAAY,EAAE;AAChB,CAAC;AAED,eAAeL,UAAU","ignoreList":[]}