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>
66 lines (59 loc) • 13.1 kB
JavaScript
var _excluded = ["children", "popup", "popupVisible"];
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 _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 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","children","popup","popupVisible","otherProps","visibleProp","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,KAAP,IAAgBC,UAAhB,QAAkC,OAAlC;AACA,OAAOC,SAAP,MAAsB,YAAtB;AACA,OAAOC,OAAP,MAAoB,YAApB;AACA,SAASC,iBAAT,QAAkC,qBAAlC;AACA,OAAO,SAAP;AA2DA,IAAMC,UAEL,GAAGJ,UAAU,CACZ,gBAAqEK,GAArE,EAA6E;EAAA,IAA1EC,QAA0E,QAA1EA,QAA0E;EAAA,IAAhEC,KAAgE,QAAhEA,KAAgE;EAAA,IAAzDC,YAAyD,QAAzDA,YAAyD;EAAA,IAAxCC,UAAwC;;EAC3E,IAAMC,WAAqB,GAAG,EAA9B;;EAEA,IAAIF,YAAY,KAAK,IAArB,EAA2B;IACzBE,WAAW,CAACF,YAAZ,GAA2BA,YAA3B;EACD;;EAED,OACE,oBAAC,OAAD;IACE,GAAG,EAAEH,GADP;IAEE,KAAK,EAAE,OAAOE,KAAP,KAAiB,QAAjB,GAA4B,iCAAMA,KAAN,CAA5B,GAAiDA;EAF1D,GAGMG,WAHN,EAIMD,UAJN,GAMG,OAAOH,QAAP,KAAoB,QAApB,GAA+B,kCAAOA,QAAP,CAA/B,GAAyDA,QAN5D,CADF;AAUD,CAlBW,CAFd;AAuBAF,UAAU,CAACO,WAAX,GAAyB,YAAzB;AAEAP,UAAU,CAACQ,SAAX,GAAuB;EAIrBC,MAAM,EAAEZ,SAAS,CAACa,GAJG;EAQrBX,iBAAiB,EAAEF,SAAS,CAACc,MARR;EAYrBT,QAAQ,EAAEL,SAAS,CAACe,IAZC;EAgBrBC,mBAAmB,EAAEhB,SAAS,CAACiB,IAhBV;EAoBrBC,kBAAkB,EAAElB,SAAS,CAACiB,IApBT;EAwBrBE,iBAAiB,EAAEnB,SAAS,CAACoB,IAxBR;EA4BrBC,eAAe,EAAErB,SAAS,CAACsB,MA5BN;EAgCrBC,eAAe,EAAEvB,SAAS,CAACsB,MAhCN;EAoCrBhB,KAAK,EAAEN,SAAS,CAACe,IAAV,CAAeS,UApCD;EAwCrBC,UAAU,EAAEzB,SAAS,CAACc,MAxCD;EA4CrBY,cAAc,EAAE1B,SAAS,CAAC2B,MA5CL;EAmDrBC,cAAc,EAAE5B,SAAS,CAAC6B,KAAV,CAAgB,CAC9B,KAD8B,EAE9B,MAF8B,EAG9B,OAH8B,EAI9B,QAJ8B,EAK9B,SAL8B,EAM9B,UAN8B,EAO9B,YAP8B,EAQ9B,aAR8B,EAS9B,SAT8B,EAU9B,YAV8B,EAW9B,UAX8B,EAY9B,aAZ8B,CAAhB,CAnDK;EAoErBC,UAAU,EAAE9B,SAAS,CAACc,MApED;EAwErBiB,mBAAmB,EAAE/B,SAAS,CAAC2B,MAxEV;EA4ErBpB,YAAY,EAAEP,SAAS,CAAC6B,KAAV,CAAgB,CAAC,IAAD,EAAO,IAAP,EAAa,KAAb,CAAhB;AA5EO,CAAvB;AA+EA1B,UAAU,CAAC6B,YAAX,GAA0B;EACxBpB,MAAM,EAAE,CAAC,OAAD,CADgB;EAExBV,iBAAiB,EAAjBA,iBAFwB;EAGxBG,QAAQ,EAAE,EAHc;EAIxBW,mBAAmB,EAAE,KAJG;EAKxBE,kBAAkB,EAAE,KALI;EAMxBC,iBAAiB,EAAE,IANK;EAOxBE,eAAe,EAAE,CAPO;EAQxBE,eAAe,EAAE,GARO;EASxBE,UAAU,EAAE,IATY;EAUxBC,cAAc,EAAE,EAVQ;EAWxBE,cAAc,EAAE,QAXQ;EAYxBE,UAAU,EAAE,IAZY;EAaxBC,mBAAmB,EAAEE,SAbG;EAcxB1B,YAAY,EAAE;AAdU,CAA1B;AAiBA,eAAeJ,UAAf"}