react-menu-list
Advanced tools
Comparing version 6.0.5 to 6.1.0
@@ -0,1 +1,6 @@ | ||
## 6.1.0 (2019-10-15) | ||
* Added `menuParentElement` prop. ([#14](https://github.com/StreakYC/react-menu-list/pull/14)) | ||
* Added `buttonProps` prop. ([#13](https://github.com/StreakYC/react-menu-list/pull/13)) | ||
## 6.0.5 (2019-08-09) | ||
@@ -2,0 +7,0 @@ |
@@ -111,3 +111,5 @@ import * as React from 'react'; | ||
menuZIndex?: string|number; | ||
menuParentElement?: HTMLElement; | ||
ButtonComponent?: React.ComponentType<{domRef: Ref<HTMLElement>}>; | ||
buttonProps?: object; | ||
@@ -133,2 +135,3 @@ children?: ReactNode; | ||
menuZIndex?: string|number; | ||
menuParentElement?: HTMLElement; | ||
@@ -135,0 +138,0 @@ onWillOpen?: () => void; |
@@ -10,6 +10,6 @@ "use strict"; | ||
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); | ||
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); | ||
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
@@ -194,2 +194,3 @@ | ||
return _react["default"].createElement(_reactFloatAnchor["default"], { | ||
parentElement: this.props.menuParentElement, | ||
ref: this._floatAnchorRef, | ||
@@ -199,3 +200,3 @@ options: positionOptions, | ||
anchor: function anchor(anchorRef) { | ||
return _react["default"].createElement(ButtonComponent, { | ||
return _react["default"].createElement(ButtonComponent, (0, _extends2["default"])({ | ||
domRef: function domRef(el) { | ||
@@ -222,3 +223,3 @@ _this3._anchorEl = el; | ||
title: title | ||
}, children); | ||
}, _this3.props.buttonProps), children); | ||
}, | ||
@@ -247,2 +248,3 @@ "float": !opened ? null : _react["default"].createElement(_MenuListInspector["default"], { | ||
ButtonComponent: _propTypes["default"].func, | ||
buttonProps: _propTypes["default"].object, | ||
children: _propTypes["default"].node, | ||
@@ -267,2 +269,2 @@ menu: _propTypes["default"].element, | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":["MenuButton","opened","React","createRef","state","Promise","resolve","props","onWillOpen","Kefir","merge","window","filter","e","el","_anchorEl","FloatAnchor","parentNodes","target","node","fromEvents","key","which","map","preventDefault","stopPropagation","takeUntilBy","_onClose","onValue","close","setState","onDidOpen","onWillClose","emit","open","floatAnchor","_floatAnchorRef","current","Error","reposition","children","menu","positionOptions","menuZIndex","disabled","title","ButtonComponent","style","className","openedStyle","openedClassName","anchorRef","button","toggle","_itemChosen","Component","PropTypes","string","object","bool","oneOfType","number","func","element","position","hAlign","domRef"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport React from 'react';\nimport type {Ref as ReactRef, Node as ReactNode, ComponentType as ReactComponentType} from 'react';\nimport PropTypes from 'prop-types';\nimport FloatAnchor from 'react-float-anchor';\nimport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport fromEventsCapture from './lib/fromEventsCapture';\nimport setRef from './lib/setRef';\nimport MenuListInspector from './MenuListInspector';\n\ntype State = {\n  opened: boolean;\n};\nexport type Props = {\n  className?: string;\n  style?: Object;\n  disabled?: boolean;\n  title?: string;\n  openedClassName?: string;\n  openedStyle?: Object;\n\n  positionOptions: FloatAnchorOptions;\n  menuZIndex?: string|number;\n  ButtonComponent: ReactComponentType<{domRef: ReactRef<any>}>;\n\n  children?: ReactNode;\n  menu: ReactNode;\n  onWillOpen?: () => void;\n  onDidOpen?: () => void;\n  onWillClose?: () => void;\n};\n\nexport default class MenuButton extends React.Component<Props, State> {\n  static propTypes = {\n    className: PropTypes.string,\n    style: PropTypes.object,\n    disabled: PropTypes.bool,\n    title: PropTypes.string,\n    openedClassName: PropTypes.string,\n    openedStyle: PropTypes.object,\n\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    ButtonComponent: PropTypes.func,\n\n    children: PropTypes.node,\n    menu: PropTypes.element,\n    onWillOpen: PropTypes.func,\n    onDidOpen: PropTypes.func,\n    onWillClose: PropTypes.func\n  };\n\n  static defaultProps = {\n    positionOptions: {position:'bottom', hAlign:'left'},\n    ButtonComponent: ({domRef, ...props}: Object) => <button ref={domRef} {...props} />\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _anchorEl: ?HTMLElement = null;\n  _onClose: Bus<void> = kefirBus();\n\n  open(): Promise<void> {\n    if (this.state.opened) return Promise.resolve();\n    if (this.props.onWillOpen) this.props.onWillOpen();\n\n    // Clicking outside of the dropdown or pressing escape should close the\n    // dropdown.\n    Kefir.merge([\n      Kefir.merge([\n        fromEventsCapture(window, 'mousedown'),\n        fromEventsCapture(window, 'focus')\n      ])\n        .filter(e => {\n          const el = this._anchorEl;\n          for (let node of FloatAnchor.parentNodes(e.target)) {\n            if (node === el) return false;\n          }\n          return true;\n        }),\n      Kefir.fromEvents(window, 'keydown')\n        .filter(e => e.key ? e.key === 'Escape' : e.which === 27)\n        .map(e => {\n          e.preventDefault();\n          e.stopPropagation();\n        })\n    ])\n      .takeUntilBy(this._onClose)\n      .onValue(() => {\n        this.close();\n      });\n\n    return new Promise(resolve => {\n      this.setState({opened: true}, () => {\n        if (this.props.onDidOpen) this.props.onDidOpen();\n        resolve();\n      });\n    });\n  }\n\n  close() {\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n    this._onClose.emit();\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  reposition() {\n    const floatAnchor = this._floatAnchorRef.current;\n    if (!floatAnchor) throw new Error();\n    floatAnchor.reposition();\n  }\n\n  _itemChosen() {\n    this.close();\n  }\n\n  componentWillUnmount() {\n    this._onClose.emit();\n  }\n\n  render() {\n    const {\n      children, menu,\n      positionOptions, menuZIndex,\n      disabled, title, ButtonComponent\n    } = this.props;\n    const {opened} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (opened) {\n      if (this.props.openedStyle) {\n        style = {...style, ...this.props.openedStyle};\n      }\n      if (this.props.openedClassName) {\n        className = `${className||''} ${this.props.openedClassName}`;\n      }\n    }\n\n    return (\n      <FloatAnchor\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          <ButtonComponent\n            domRef={el => {\n              this._anchorEl = el;\n              setRef(anchorRef, el);\n            }}\n            type=\"button\"\n            className={className}\n            style={style}\n            onMouseDown={e => {\n              if (e.button !== 0) return;\n              this.toggle();\n            }}\n            onKeyPress={e=>{\n              if (e.key === 'Enter' || e.key === ' ') {\n                this.toggle();\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n            disabled={disabled}\n            title={title}\n          >\n            {children}\n          </ButtonComponent>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":["MenuButton","opened","React","createRef","state","Promise","resolve","props","onWillOpen","Kefir","merge","window","filter","e","el","_anchorEl","FloatAnchor","parentNodes","target","node","fromEvents","key","which","map","preventDefault","stopPropagation","takeUntilBy","_onClose","onValue","close","setState","onDidOpen","onWillClose","emit","open","floatAnchor","_floatAnchorRef","current","Error","reposition","children","menu","positionOptions","menuZIndex","disabled","title","ButtonComponent","style","className","openedStyle","openedClassName","menuParentElement","anchorRef","button","toggle","buttonProps","_itemChosen","Component","PropTypes","string","object","bool","oneOfType","number","func","element","position","hAlign","domRef"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport React from 'react';\nimport type {Ref as ReactRef, Node as ReactNode, ComponentType as ReactComponentType} from 'react';\nimport PropTypes from 'prop-types';\nimport FloatAnchor from 'react-float-anchor';\nimport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport fromEventsCapture from './lib/fromEventsCapture';\nimport setRef from './lib/setRef';\nimport MenuListInspector from './MenuListInspector';\n\ntype State = {\n  opened: boolean;\n};\nexport type Props = {\n  className?: string;\n  style?: Object;\n  disabled?: boolean;\n  title?: string;\n  openedClassName?: string;\n  openedStyle?: Object;\n\n  positionOptions: FloatAnchorOptions;\n  menuZIndex?: string|number;\n  menuParentElement?: HTMLElement;\n  ButtonComponent: ReactComponentType<{domRef: ReactRef<any>}>;\n  buttonProps?: Object;\n\n  children?: ReactNode;\n  menu: ReactNode;\n  onWillOpen?: () => void;\n  onDidOpen?: () => void;\n  onWillClose?: () => void;\n};\n\nexport default class MenuButton extends React.Component<Props, State> {\n  static propTypes = {\n    className: PropTypes.string,\n    style: PropTypes.object,\n    disabled: PropTypes.bool,\n    title: PropTypes.string,\n    openedClassName: PropTypes.string,\n    openedStyle: PropTypes.object,\n\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n    ButtonComponent: PropTypes.func,\n    buttonProps: PropTypes.object,\n\n    children: PropTypes.node,\n    menu: PropTypes.element,\n    onWillOpen: PropTypes.func,\n    onDidOpen: PropTypes.func,\n    onWillClose: PropTypes.func\n  };\n\n  static defaultProps = {\n    positionOptions: {position:'bottom', hAlign:'left'},\n    ButtonComponent: ({domRef, ...props}: Object) => <button ref={domRef} {...props} />\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _anchorEl: ?HTMLElement = null;\n  _onClose: Bus<void> = kefirBus();\n\n  open(): Promise<void> {\n    if (this.state.opened) return Promise.resolve();\n    if (this.props.onWillOpen) this.props.onWillOpen();\n\n    // Clicking outside of the dropdown or pressing escape should close the\n    // dropdown.\n    Kefir.merge([\n      Kefir.merge([\n        fromEventsCapture(window, 'mousedown'),\n        fromEventsCapture(window, 'focus')\n      ])\n        .filter(e => {\n          const el = this._anchorEl;\n          for (let node of FloatAnchor.parentNodes(e.target)) {\n            if (node === el) return false;\n          }\n          return true;\n        }),\n      Kefir.fromEvents(window, 'keydown')\n        .filter(e => e.key ? e.key === 'Escape' : e.which === 27)\n        .map(e => {\n          e.preventDefault();\n          e.stopPropagation();\n        })\n    ])\n      .takeUntilBy(this._onClose)\n      .onValue(() => {\n        this.close();\n      });\n\n    return new Promise(resolve => {\n      this.setState({opened: true}, () => {\n        if (this.props.onDidOpen) this.props.onDidOpen();\n        resolve();\n      });\n    });\n  }\n\n  close() {\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n    this._onClose.emit();\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  reposition() {\n    const floatAnchor = this._floatAnchorRef.current;\n    if (!floatAnchor) throw new Error();\n    floatAnchor.reposition();\n  }\n\n  _itemChosen() {\n    this.close();\n  }\n\n  componentWillUnmount() {\n    this._onClose.emit();\n  }\n\n  render() {\n    const {\n      children, menu,\n      positionOptions, menuZIndex,\n      disabled, title, ButtonComponent\n    } = this.props;\n    const {opened} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (opened) {\n      if (this.props.openedStyle) {\n        style = {...style, ...this.props.openedStyle};\n      }\n      if (this.props.openedClassName) {\n        className = `${className||''} ${this.props.openedClassName}`;\n      }\n    }\n\n    return (\n      <FloatAnchor\n        parentElement={this.props.menuParentElement}\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          <ButtonComponent\n            domRef={el => {\n              this._anchorEl = el;\n              setRef(anchorRef, el);\n            }}\n            type=\"button\"\n            className={className}\n            style={style}\n            onMouseDown={e => {\n              if (e.button !== 0) return;\n              this.toggle();\n            }}\n            onKeyPress={e=>{\n              if (e.key === 'Enter' || e.key === ' ') {\n                this.toggle();\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n            disabled={disabled}\n            title={title}\n            {...this.props.buttonProps}\n          >\n            {children}\n          </ButtonComponent>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} |
@@ -276,2 +276,3 @@ "use strict"; | ||
return _react["default"].createElement(_reactFloatAnchor["default"], { | ||
parentElement: this.props.menuParentElement, | ||
ref: this._floatAnchorRef, | ||
@@ -369,2 +370,2 @@ options: positionOptions, | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":["SubMenuItem","opened","React","createRef","_stopper","destroy","menuItem","_menuItemRef","current","Error","lockHighlight","state","Promise","resolve","props","onWillOpen","takeKeyboard","setState","onDidOpen","onWillClose","releaseKeyboard","unlockHighlight","close","open","floatAnchor","_floatAnchorRef","reposition","hasHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","highlighted","event","_resetMouseLeaveWatcher","emit","OPEN_DELAY","Kefir","later","takeUntilBy","onValue","menuContainer","_menuContainerRef","menuRect","getBoundingClientRect","startTime","Date","now","startX","pageX","startY","pageY","getDistance","x","y","left","top","right","width","bottom","startDistance","lastCoords","MIN_SPEED","MAX_TIME","LEAD_TIME","fromEvents","window","bufferBy","interval","map","events","length","last","filter","distance","maxDistance","merge","take","index","highlightedStyle","highlightedClassName","positionOptions","menuZIndex","children","menu","style","className","openedStyle","openedClassName","anchorRef","h","e","_onHighlightChange","_onMouseLeaveItem","stopPropagation","preventDefault","menuInspector","_menuInspectorRef","_mouseEnterMenu","Component","PropTypes","node","object","oneOfType","string","number","func","onItemChosen","onHighlightChange","position","vAlign","hAlign"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport kefirStopper from 'kefir-stopper';\nimport React from 'react';\nimport type {Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\nimport pointRectDistance from './lib/pointRectDistance';\n\nimport MenuListInspector from './MenuListInspector';\nimport FloatAnchor from 'react-float-anchor';\nimport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nexport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nimport MenuItem from './MenuItem';\n\nimport type {Direction, Rect} from './types';\nimport type MenuEvent from './events/MenuEvent';\nimport type ChosenEvent from './events/ChosenEvent';\n\ntype State = {\n  opened: boolean;\n};\n\nexport type Props = {\n  menu: ReactNode;\n  positionOptions: FloatAnchorOptions;\n  menuZIndex?: string|number;\n\n  onWillOpen?: () => void;\n  onDidOpen?: () => void;\n  onWillClose?: () => void;\n\n  className?: string;\n  style?: Object;\n  highlightedClassName?: string;\n  highlightedStyle?: Object;\n  index?: number;\n\n  openedClassName?: string;\n  openedStyle?: Object;\n\n  onItemChosen?: (event: ChosenEvent) => void;\n  onHighlightChange?: (highlighted: boolean, details: {byKeyboard?: boolean, prevCursorLocation?: Rect, direction?: Direction}) => void;\n\n  children?: ReactNode;\n};\n\nexport default class SubMenuItem extends React.Component<Props, State> {\n  static propTypes = {\n    menu: PropTypes.node,\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n    onWillOpen: PropTypes.func,\n    onDidOpen: PropTypes.func,\n    onWillClose: PropTypes.func,\n\n    className: PropTypes.string,\n    style: PropTypes.object,\n    highlightedClassName: PropTypes.string,\n    highlightedStyle: PropTypes.object,\n    index: PropTypes.number,\n\n    openedClassName: PropTypes.string,\n    openedStyle: PropTypes.object,\n\n    onItemChosen: PropTypes.func,\n    onHighlightChange: PropTypes.func,\n\n    children: PropTypes.node\n  };\n\n  static defaultProps = {\n    positionOptions: {position:'right', vAlign:'top', hAlign: 'left'}\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _menuItemRef = React.createRef<MenuItem>();\n  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _menuInspectorRef = React.createRef<MenuListInspector>();\n  _menuContainerRef = React.createRef<HTMLDivElement>();\n  _resetMouseLeaveWatcher: Bus<null> = kefirBus();\n  _stopper = kefirStopper();\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n  }\n\n  open(): Promise<void> {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.lockHighlight();\n    if (this.state.opened) return Promise.resolve();\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    menuItem.takeKeyboard();\n    return new Promise(resolve => {\n      this.setState({opened: true}, () => {\n        if (this.props.onDidOpen) this.props.onDidOpen();\n        resolve();\n      });\n    });\n  }\n\n  close() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n    menuItem.releaseKeyboard();\n    menuItem.unlockHighlight();\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  reposition() {\n    const floatAnchor = this._floatAnchorRef.current;\n    if (!floatAnchor) throw new Error();\n\n    floatAnchor.reposition();\n  }\n\n  hasHighlight(): boolean {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    return menuItem.hasHighlight();\n  }\n\n  highlight(byKeyboard: boolean=true) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.moveCursor(direction, prevCursorLocation);\n  }\n\n  _onHighlightChange(highlighted: boolean, event: Object) {\n    this._resetMouseLeaveWatcher.emit(null);\n\n    if (highlighted && !event.byKeyboard) {\n      const OPEN_DELAY = 200;\n\n      Kefir.later(OPEN_DELAY)\n        .takeUntilBy(this._resetMouseLeaveWatcher)\n        .takeUntilBy(this._stopper)\n        .onValue(() => {\n          this.open();\n        });\n    } else if (!highlighted) {\n      this.close();\n    }\n  }\n\n  _onMouseLeaveItem(event: Object) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    if (!this.state.opened) {\n      menuItem.unhighlight();\n      return;\n    }\n\n    const menuContainer = this._menuContainerRef.current;\n    if (!menuContainer) throw new Error();\n\n    // If the mouse isn't going toward the menu, then unhighlight ourself.\n\n    const menuRect = menuContainer.getBoundingClientRect();\n\n    const startTime = Date.now();\n    const startX = event.pageX, startY = event.pageY;\n\n    function getDistance(x, y) {\n      return pointRectDistance(x, y, menuRect.left, menuRect.top, menuRect.right-menuRect.width, menuRect.bottom-menuRect.top);\n    }\n\n    const startDistance = getDistance(startX, startY);\n    let lastCoords = {pageX: startX, pageY: startY};\n\n    // pixels per second the user must be moving the mouse toward the menu for\n    // the menu to stay open.\n    const MIN_SPEED = 60;\n\n    // ms before the menu will close if the user hasn't reached it yet, no\n    // matter how they're moving the cursor toward it.\n    const MAX_TIME = 750;\n\n    // ms to offset start time, to set maxDistance back a little so it's not so\n    // unforgiving at the very start.\n    const LEAD_TIME = 50;\n\n    // Listen to mouse moves, find the first event not going towards the menu,\n    // and end it there. Or end after a timer.\n    Kefir.fromEvents(window, 'mousemove')\n      .bufferBy(Kefir.interval(60, null))\n      .map(events => {\n        if (events.length) {\n          const last = events[events.length-1];\n          lastCoords = {pageX: last.pageX, pageY: last.pageY};\n        }\n        return lastCoords;\n      })\n      .filter(({pageX, pageY}) => {\n        const distance = getDistance(pageX, pageY);\n        const maxDistance = startDistance - (Date.now()-startTime-LEAD_TIME)/1000 * MIN_SPEED;\n        return distance > maxDistance;\n      })\n      .merge(Kefir.later(MAX_TIME*1000))\n      .take(1)\n      .takeUntilBy(this._resetMouseLeaveWatcher)\n      .takeUntilBy(this._stopper)\n      .onValue(() => {\n        this.close();\n        menuItem.unhighlight();\n      });\n  }\n\n  _mouseEnterMenu() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    this._resetMouseLeaveWatcher.emit(null);\n    menuItem.unlockHighlight();\n  }\n\n  render() {\n    const {\n      index, highlightedStyle, highlightedClassName,\n      positionOptions, menuZIndex, children, menu\n    } = this.props;\n    const {opened} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (opened) {\n      if (this.props.openedStyle) {\n        style = {...style, ...this.props.openedStyle};\n      }\n      if (this.props.openedClassName) {\n        className = `${className||''} ${this.props.openedClassName}`;\n      }\n    }\n\n    return (\n      <FloatAnchor\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          <MenuItem\n            ref={this._menuItemRef}\n            domRef={anchorRef}\n            index={index}\n            style={style}\n            className={className}\n            highlightedStyle={highlightedStyle}\n            highlightedClassName={highlightedClassName}\n            onHighlightChange={(h,e) => this._onHighlightChange(h,e)}\n            onMouseLeave={e => this._onMouseLeaveItem(e)}\n            onRightPushed={(e: MenuEvent) => {\n              if (!this.state.opened) {\n                e.stopPropagation();\n                e.preventDefault();\n                this.open();\n                const menuInspector = this._menuInspectorRef.current;\n                if (!menuInspector) throw new Error();\n                menuInspector.moveCursor('down');\n              }\n            }}\n            onItemChosen={(e: ChosenEvent) => {\n              e.stopPropagation();\n              e.preventDefault();\n              this.open();\n              if (e.byKeyboard) {\n                const menuInspector = this._menuInspectorRef.current;\n                if (!menuInspector) throw new Error();\n                menuInspector.moveCursor('down');\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n          >\n            {children}\n          </MenuItem>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector\n              ref={this._menuInspectorRef}\n              onLeftPushed={e => {\n                e.stopPropagation();\n                e.preventDefault();\n                this.close();\n              }}\n            >\n              <div\n                ref={this._menuContainerRef}\n                onMouseEnter={()=>this._mouseEnterMenu()}\n              >\n                {menu}\n              </div>\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":["SubMenuItem","opened","React","createRef","_stopper","destroy","menuItem","_menuItemRef","current","Error","lockHighlight","state","Promise","resolve","props","onWillOpen","takeKeyboard","setState","onDidOpen","onWillClose","releaseKeyboard","unlockHighlight","close","open","floatAnchor","_floatAnchorRef","reposition","hasHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","highlighted","event","_resetMouseLeaveWatcher","emit","OPEN_DELAY","Kefir","later","takeUntilBy","onValue","menuContainer","_menuContainerRef","menuRect","getBoundingClientRect","startTime","Date","now","startX","pageX","startY","pageY","getDistance","x","y","left","top","right","width","bottom","startDistance","lastCoords","MIN_SPEED","MAX_TIME","LEAD_TIME","fromEvents","window","bufferBy","interval","map","events","length","last","filter","distance","maxDistance","merge","take","index","highlightedStyle","highlightedClassName","positionOptions","menuZIndex","children","menu","style","className","openedStyle","openedClassName","menuParentElement","anchorRef","h","e","_onHighlightChange","_onMouseLeaveItem","stopPropagation","preventDefault","menuInspector","_menuInspectorRef","_mouseEnterMenu","Component","PropTypes","node","object","oneOfType","string","number","func","onItemChosen","onHighlightChange","position","vAlign","hAlign"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport kefirStopper from 'kefir-stopper';\nimport React from 'react';\nimport type {Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\nimport pointRectDistance from './lib/pointRectDistance';\n\nimport MenuListInspector from './MenuListInspector';\nimport FloatAnchor from 'react-float-anchor';\nimport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nexport type {Options as FloatAnchorOptions} from 'react-float-anchor';\nimport MenuItem from './MenuItem';\n\nimport type {Direction, Rect} from './types';\nimport type MenuEvent from './events/MenuEvent';\nimport type ChosenEvent from './events/ChosenEvent';\n\ntype State = {\n  opened: boolean;\n};\n\nexport type Props = {\n  menu: ReactNode;\n  positionOptions: FloatAnchorOptions;\n  menuZIndex?: string|number;\n  menuParentElement?: HTMLElement;\n\n  onWillOpen?: () => void;\n  onDidOpen?: () => void;\n  onWillClose?: () => void;\n\n  className?: string;\n  style?: Object;\n  highlightedClassName?: string;\n  highlightedStyle?: Object;\n  index?: number;\n\n  openedClassName?: string;\n  openedStyle?: Object;\n\n  onItemChosen?: (event: ChosenEvent) => void;\n  onHighlightChange?: (highlighted: boolean, details: {byKeyboard?: boolean, prevCursorLocation?: Rect, direction?: Direction}) => void;\n\n  children?: ReactNode;\n};\n\nexport default class SubMenuItem extends React.Component<Props, State> {\n  static propTypes = {\n    menu: PropTypes.node,\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n    onWillOpen: PropTypes.func,\n    onDidOpen: PropTypes.func,\n    onWillClose: PropTypes.func,\n\n    className: PropTypes.string,\n    style: PropTypes.object,\n    highlightedClassName: PropTypes.string,\n    highlightedStyle: PropTypes.object,\n    index: PropTypes.number,\n\n    openedClassName: PropTypes.string,\n    openedStyle: PropTypes.object,\n\n    onItemChosen: PropTypes.func,\n    onHighlightChange: PropTypes.func,\n\n    children: PropTypes.node\n  };\n\n  static defaultProps = {\n    positionOptions: {position:'right', vAlign:'top', hAlign: 'left'}\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _menuItemRef = React.createRef<MenuItem>();\n  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _menuInspectorRef = React.createRef<MenuListInspector>();\n  _menuContainerRef = React.createRef<HTMLDivElement>();\n  _resetMouseLeaveWatcher: Bus<null> = kefirBus();\n  _stopper = kefirStopper();\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n  }\n\n  open(): Promise<void> {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.lockHighlight();\n    if (this.state.opened) return Promise.resolve();\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    menuItem.takeKeyboard();\n    return new Promise(resolve => {\n      this.setState({opened: true}, () => {\n        if (this.props.onDidOpen) this.props.onDidOpen();\n        resolve();\n      });\n    });\n  }\n\n  close() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n    menuItem.releaseKeyboard();\n    menuItem.unlockHighlight();\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  reposition() {\n    const floatAnchor = this._floatAnchorRef.current;\n    if (!floatAnchor) throw new Error();\n\n    floatAnchor.reposition();\n  }\n\n  hasHighlight(): boolean {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    return menuItem.hasHighlight();\n  }\n\n  highlight(byKeyboard: boolean=true) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    menuItem.moveCursor(direction, prevCursorLocation);\n  }\n\n  _onHighlightChange(highlighted: boolean, event: Object) {\n    this._resetMouseLeaveWatcher.emit(null);\n\n    if (highlighted && !event.byKeyboard) {\n      const OPEN_DELAY = 200;\n\n      Kefir.later(OPEN_DELAY)\n        .takeUntilBy(this._resetMouseLeaveWatcher)\n        .takeUntilBy(this._stopper)\n        .onValue(() => {\n          this.open();\n        });\n    } else if (!highlighted) {\n      this.close();\n    }\n  }\n\n  _onMouseLeaveItem(event: Object) {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    if (!this.state.opened) {\n      menuItem.unhighlight();\n      return;\n    }\n\n    const menuContainer = this._menuContainerRef.current;\n    if (!menuContainer) throw new Error();\n\n    // If the mouse isn't going toward the menu, then unhighlight ourself.\n\n    const menuRect = menuContainer.getBoundingClientRect();\n\n    const startTime = Date.now();\n    const startX = event.pageX, startY = event.pageY;\n\n    function getDistance(x, y) {\n      return pointRectDistance(x, y, menuRect.left, menuRect.top, menuRect.right-menuRect.width, menuRect.bottom-menuRect.top);\n    }\n\n    const startDistance = getDistance(startX, startY);\n    let lastCoords = {pageX: startX, pageY: startY};\n\n    // pixels per second the user must be moving the mouse toward the menu for\n    // the menu to stay open.\n    const MIN_SPEED = 60;\n\n    // ms before the menu will close if the user hasn't reached it yet, no\n    // matter how they're moving the cursor toward it.\n    const MAX_TIME = 750;\n\n    // ms to offset start time, to set maxDistance back a little so it's not so\n    // unforgiving at the very start.\n    const LEAD_TIME = 50;\n\n    // Listen to mouse moves, find the first event not going towards the menu,\n    // and end it there. Or end after a timer.\n    Kefir.fromEvents(window, 'mousemove')\n      .bufferBy(Kefir.interval(60, null))\n      .map(events => {\n        if (events.length) {\n          const last = events[events.length-1];\n          lastCoords = {pageX: last.pageX, pageY: last.pageY};\n        }\n        return lastCoords;\n      })\n      .filter(({pageX, pageY}) => {\n        const distance = getDistance(pageX, pageY);\n        const maxDistance = startDistance - (Date.now()-startTime-LEAD_TIME)/1000 * MIN_SPEED;\n        return distance > maxDistance;\n      })\n      .merge(Kefir.later(MAX_TIME*1000))\n      .take(1)\n      .takeUntilBy(this._resetMouseLeaveWatcher)\n      .takeUntilBy(this._stopper)\n      .onValue(() => {\n        this.close();\n        menuItem.unhighlight();\n      });\n  }\n\n  _mouseEnterMenu() {\n    const menuItem = this._menuItemRef.current;\n    if (!menuItem) throw new Error();\n\n    this._resetMouseLeaveWatcher.emit(null);\n    menuItem.unlockHighlight();\n  }\n\n  render() {\n    const {\n      index, highlightedStyle, highlightedClassName,\n      positionOptions, menuZIndex, children, menu\n    } = this.props;\n    const {opened} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (opened) {\n      if (this.props.openedStyle) {\n        style = {...style, ...this.props.openedStyle};\n      }\n      if (this.props.openedClassName) {\n        className = `${className||''} ${this.props.openedClassName}`;\n      }\n    }\n\n    return (\n      <FloatAnchor\n        parentElement={this.props.menuParentElement}\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          <MenuItem\n            ref={this._menuItemRef}\n            domRef={anchorRef}\n            index={index}\n            style={style}\n            className={className}\n            highlightedStyle={highlightedStyle}\n            highlightedClassName={highlightedClassName}\n            onHighlightChange={(h,e) => this._onHighlightChange(h,e)}\n            onMouseLeave={e => this._onMouseLeaveItem(e)}\n            onRightPushed={(e: MenuEvent) => {\n              if (!this.state.opened) {\n                e.stopPropagation();\n                e.preventDefault();\n                this.open();\n                const menuInspector = this._menuInspectorRef.current;\n                if (!menuInspector) throw new Error();\n                menuInspector.moveCursor('down');\n              }\n            }}\n            onItemChosen={(e: ChosenEvent) => {\n              e.stopPropagation();\n              e.preventDefault();\n              this.open();\n              if (e.byKeyboard) {\n                const menuInspector = this._menuInspectorRef.current;\n                if (!menuInspector) throw new Error();\n                menuInspector.moveCursor('down');\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n          >\n            {children}\n          </MenuItem>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector\n              ref={this._menuInspectorRef}\n              onLeftPushed={e => {\n                e.stopPropagation();\n                e.preventDefault();\n                this.close();\n              }}\n            >\n              <div\n                ref={this._menuContainerRef}\n                onMouseEnter={()=>this._mouseEnterMenu()}\n              >\n                {menu}\n              </div>\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} |
{ | ||
"name": "react-menu-list", | ||
"version": "6.0.5", | ||
"version": "6.1.0", | ||
"description": "React component for menu lists and submenus", | ||
@@ -52,7 +52,7 @@ "main": "js/index.js", | ||
"browserify": "^16.2.2", | ||
"cross-env": "^5.0.1", | ||
"cross-env": "^6.0.3", | ||
"eslint": "^6.1.0", | ||
"eslint-plugin-flowtype": "^4.2.0", | ||
"eslint-plugin-react": "^7.4.0", | ||
"flow-bin": "^0.104.0", | ||
"flow-bin": "^0.109.0", | ||
"flow-copy-source": "^2.0.2", | ||
@@ -63,3 +63,3 @@ "jest": "^24.0.0", | ||
"react-test-renderer": "^16.6.0", | ||
"rimraf": "^2.6.1", | ||
"rimraf": "^3.0.0", | ||
"typescript": "^3.5.1", | ||
@@ -75,3 +75,3 @@ "watchify": "^3.7.0" | ||
"prop-types": "^15.6.0", | ||
"react-float-anchor": "^3.0.0" | ||
"react-float-anchor": "^3.2.0" | ||
}, | ||
@@ -78,0 +78,0 @@ "peerDependencies": { |
@@ -96,3 +96,3 @@ # react-menu-list | ||
when the item is highlighted. | ||
* `index`: This an optional number which overrides the menu item's index in the | ||
* `index`: This is an optional number which overrides the menu item's index in the | ||
MenuList for keyboard control purposes. The order of menu items is normally | ||
@@ -140,3 +140,3 @@ determined by their position in the DOM when mounted. This property should be | ||
open. | ||
* `positionOptions`: This an optional object of options to control how the | ||
* `positionOptions`: This is an optional object of options to control how the | ||
dropdown is aligned to the menu item. The options are the same as those | ||
@@ -146,4 +146,6 @@ supported by | ||
This defaults to `{position:'right', vAlign:'top', hAlign: 'left'}`. | ||
* `menuZIndex`: This an optional number controlling the z-index CSS property of | ||
* `menuZIndex`: This is an optional number controlling the z-index CSS property of | ||
the menu's container. | ||
* `menuParentElement`: This is an optional HTMLElement to attach the menu's container | ||
to instead of the document's body element. | ||
* `onWillOpen`: This is an optional function called before the submenu opens. | ||
@@ -205,3 +207,3 @@ * `onDidOpen`: This is an optional function called after the submenu opened. | ||
* `menu`, `positionOptions`, `menuZIndex`, `onWillOpen`, `onDidOpen`, | ||
* `menu`, `positionOptions`, `menuZIndex`, `menuParentElement`, `onWillOpen`, `onDidOpen`, | ||
`onWillClose`, `className`, `style`, `openedClassName`, `openedStyle`: | ||
@@ -213,2 +215,4 @@ These work the same as the props on SubMenuItem. | ||
`domRef` prop which is passed as a ref to the button's DOM element. | ||
* `buttonProps`: Optional object that will be merged with the props passed to | ||
the button component. | ||
@@ -215,0 +219,0 @@ A MenuButton has the following public methods: |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
229600
1544
252
Updatedreact-float-anchor@^3.2.0