react-menu-list
Advanced tools
Comparing version 3.2.3 to 3.3.0
@@ -84,3 +84,3 @@ 'use strict'; | ||
key: 'open', | ||
value: function open() { | ||
value: function open(callback) { | ||
var _this2 = this; | ||
@@ -90,3 +90,6 @@ | ||
if (this.props.onWillOpen) this.props.onWillOpen(); | ||
this.setState({ opened: true }, this.props.onDidOpen); | ||
this.setState({ opened: true }, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
if (callback) callback(); | ||
}); | ||
@@ -254,2 +257,2 @@ // Clicking outside of the dropdown or pressing escape should close the | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":["MenuButton","state","opened","_onClose","props","onWillOpen","setState","onDidOpen","merge","window","filter","el","parentNodes","e","target","node","fromEvents","key","which","map","preventDefault","stopPropagation","takeUntilBy","onValue","close","onWillClose","emit","open","refs","floatAnchor","reposition","children","menu","positionOptions","menuZIndex","disabled","title","ButtonComponent","style","className","openedStyle","openedClassName","button","toggle","_itemChosen","Component","propTypes","string","object","bool","oneOfType","number","func","element","defaultProps","position","hAlign"],"mappings":"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","file":"MenuButton.js","sourcesContent":["/* @flow */\n\nimport React, {PropTypes} from 'react';\nimport {findDOMNode} from 'react-dom';\nimport FloatAnchor 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 MenuListInspector from './MenuListInspector';\n\ntype State = {\n  opened: boolean;\n};\n\nexport default class MenuButton extends React.Component {\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.oneOfType([PropTypes.string, 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: 'button'\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _onClose: Bus<void> = kefirBus();\n\n  open() {\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, this.props.onDidOpen);\n\n    // Clicking outside of the dropdown or pressing escape should close the\n    // dropdown.\n    Kefir.merge([\n      Kefir.merge([\n        fromEventsCapture(window, 'click'),\n        fromEventsCapture(window, 'focus')\n      ])\n        .filter(e => {\n          const el = findDOMNode(this);\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\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    this.refs.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=\"floatAnchor\"\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={\n          <ButtonComponent\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","state","opened","_onClose","callback","props","onWillOpen","setState","onDidOpen","merge","window","filter","el","parentNodes","e","target","node","fromEvents","key","which","map","preventDefault","stopPropagation","takeUntilBy","onValue","close","onWillClose","emit","open","refs","floatAnchor","reposition","children","menu","positionOptions","menuZIndex","disabled","title","ButtonComponent","style","className","openedStyle","openedClassName","button","toggle","_itemChosen","Component","propTypes","string","object","bool","oneOfType","number","func","element","defaultProps","position","hAlign"],"mappings":"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","file":"MenuButton.js","sourcesContent":["/* @flow */\n\nimport React, {PropTypes} from 'react';\nimport {findDOMNode} from 'react-dom';\nimport FloatAnchor 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 MenuListInspector from './MenuListInspector';\n\ntype State = {\n  opened: boolean;\n};\n\nexport default class MenuButton extends React.Component {\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.oneOfType([PropTypes.string, 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: 'button'\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _onClose: Bus<void> = kefirBus();\n\n  open(callback?: () => any) {\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, () => {\n      if (this.props.onDidOpen) this.props.onDidOpen();\n      if (callback) callback();\n    });\n\n    // Clicking outside of the dropdown or pressing escape should close the\n    // dropdown.\n    Kefir.merge([\n      Kefir.merge([\n        fromEventsCapture(window, 'click'),\n        fromEventsCapture(window, 'focus')\n      ])\n        .filter(e => {\n          const el = findDOMNode(this);\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\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    this.refs.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=\"floatAnchor\"\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={\n          <ButtonComponent\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"]} |
@@ -91,7 +91,12 @@ 'use strict'; | ||
key: 'open', | ||
value: function open() { | ||
value: function open(callback) { | ||
var _this2 = this; | ||
this.refs.menuItem.lockHighlight(); | ||
if (this.state.opened) return; | ||
if (this.props.onWillOpen) this.props.onWillOpen(); | ||
this.setState({ opened: true }, this.props.onDidOpen); | ||
this.setState({ opened: true }, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
if (callback) callback(); | ||
}); | ||
this.refs.menuItem.takeKeyboard(); | ||
@@ -147,3 +152,3 @@ } | ||
value: function _onHighlightChange(highlighted, event) { | ||
var _this2 = this; | ||
var _this3 = this; | ||
@@ -156,3 +161,3 @@ this._resetMouseLeaveWatcher.emit(null); | ||
_kefir2.default.later(OPEN_DELAY).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
_this2.open(); | ||
_this3.open(); | ||
}); | ||
@@ -166,3 +171,3 @@ } else if (!highlighted) { | ||
value: function _onMouseLeaveItem(event) { | ||
var _this3 = this; | ||
var _this4 = this; | ||
@@ -217,4 +222,4 @@ if (!this.state.opened) { | ||
}).merge(_kefir2.default.later(MAX_TIME * 1000)).take(1).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
_this3.close(); | ||
_this3.refs.menuItem.unhighlight(); | ||
_this4.close(); | ||
_this4.refs.menuItem.unhighlight(); | ||
}); | ||
@@ -231,3 +236,3 @@ } | ||
value: function render() { | ||
var _this4 = this; | ||
var _this5 = this; | ||
@@ -266,13 +271,13 @@ var _props = this.props, | ||
onHighlightChange: function onHighlightChange(h, e) { | ||
return _this4._onHighlightChange(h, e); | ||
return _this5._onHighlightChange(h, e); | ||
}, | ||
onMouseLeave: function onMouseLeave(e) { | ||
return _this4._onMouseLeaveItem(e); | ||
return _this5._onMouseLeaveItem(e); | ||
}, | ||
onRightPushed: function onRightPushed(e) { | ||
if (!_this4.state.opened) { | ||
if (!_this5.state.opened) { | ||
e.stopPropagation(); | ||
e.preventDefault(); | ||
_this4.open(); | ||
_this4.refs.menuInspector.moveCursor('down'); | ||
_this5.open(); | ||
_this5.refs.menuInspector.moveCursor('down'); | ||
} | ||
@@ -283,5 +288,5 @@ }, | ||
e.preventDefault(); | ||
_this4.open(); | ||
_this5.open(); | ||
if (e.byKeyboard) { | ||
_this4.refs.menuInspector.moveCursor('down'); | ||
_this5.refs.menuInspector.moveCursor('down'); | ||
} | ||
@@ -308,3 +313,3 @@ }, | ||
e.preventDefault(); | ||
_this4.close(); | ||
_this5.close(); | ||
} | ||
@@ -317,3 +322,3 @@ }, | ||
onMouseEnter: function onMouseEnter() { | ||
return _this4._mouseEnterMenu(); | ||
return _this5._mouseEnterMenu(); | ||
} | ||
@@ -359,2 +364,2 @@ }, | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":["SubMenuItem","state","opened","_resetMouseLeaveWatcher","_stopper","destroy","refs","menuItem","lockHighlight","props","onWillOpen","setState","onDidOpen","takeKeyboard","onWillClose","releaseKeyboard","unlockHighlight","close","open","floatAnchor","reposition","hasHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","highlighted","event","emit","OPEN_DELAY","later","takeUntilBy","onValue","menuRect","menuContainer","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","h","e","_onHighlightChange","_onMouseLeaveItem","stopPropagation","preventDefault","menuInspector","_mouseEnterMenu","Component","propTypes","node","object","oneOfType","string","number","func","onItemChosen","onHighlightChange","defaultProps","position","vAlign","hAlign"],"mappings":"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","file":"SubMenuItem.js","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, {PropTypes} from 'react';\nimport pointRectDistance from './lib/pointRectDistance';\n\nimport MenuListInspector from './MenuListInspector';\nimport FloatAnchor 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 default class SubMenuItem extends React.Component {\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  _resetMouseLeaveWatcher: Bus<null> = kefirBus();\n  _stopper = kefirStopper();\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n  }\n\n  open() {\n    this.refs.menuItem.lockHighlight();\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, this.props.onDidOpen);\n    this.refs.menuItem.takeKeyboard();\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.refs.menuItem.releaseKeyboard();\n    this.refs.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    this.refs.floatAnchor.reposition();\n  }\n\n  hasHighlight(): boolean {\n    return this.refs.menuItem.hasHighlight();\n  }\n\n  highlight(byKeyboard: boolean=true) {\n    this.refs.menuItem.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    this.refs.menuItem.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    this.refs.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    if (!this.state.opened) {\n      this.refs.menuItem.unhighlight();\n      return;\n    }\n\n    // If the mouse isn't going toward the menu, then unhighlight ourself.\n\n    const menuRect = this.refs.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        this.refs.menuItem.unhighlight();\n      });\n  }\n\n  _mouseEnterMenu() {\n    this._resetMouseLeaveWatcher.emit(null);\n    this.refs.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      <MenuItem\n        ref=\"menuItem\"\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            this.refs.menuInspector.moveCursor('down');\n          }\n        }}\n        onItemChosen={(e: ChosenEvent) => {\n          e.stopPropagation();\n          e.preventDefault();\n          this.open();\n          if (e.byKeyboard) {\n            this.refs.menuInspector.moveCursor('down');\n          }\n        }}\n        aria-haspopup={true}\n        aria-expanded={opened}\n      >\n        <FloatAnchor\n          ref=\"floatAnchor\"\n          options={positionOptions}\n          zIndex={menuZIndex}\n          anchor={\n            <div>\n              {children}\n            </div>\n          }\n          float={\n            !opened ? null :\n              <MenuListInspector\n                ref=\"menuInspector\"\n                onLeftPushed={e => {\n                  e.stopPropagation();\n                  e.preventDefault();\n                  this.close();\n                }}\n              >\n                <div\n                  ref=\"menuContainer\"\n                  onMouseEnter={()=>this._mouseEnterMenu()}\n                  >\n                  {menu}\n                </div>\n              </MenuListInspector>\n          }\n          />\n      </MenuItem>\n    );\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":["SubMenuItem","state","opened","_resetMouseLeaveWatcher","_stopper","destroy","callback","refs","menuItem","lockHighlight","props","onWillOpen","setState","onDidOpen","takeKeyboard","onWillClose","releaseKeyboard","unlockHighlight","close","open","floatAnchor","reposition","hasHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","highlighted","event","emit","OPEN_DELAY","later","takeUntilBy","onValue","menuRect","menuContainer","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","h","e","_onHighlightChange","_onMouseLeaveItem","stopPropagation","preventDefault","menuInspector","_mouseEnterMenu","Component","propTypes","node","object","oneOfType","string","number","func","onItemChosen","onHighlightChange","defaultProps","position","vAlign","hAlign"],"mappings":"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","file":"SubMenuItem.js","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, {PropTypes} from 'react';\nimport pointRectDistance from './lib/pointRectDistance';\n\nimport MenuListInspector from './MenuListInspector';\nimport FloatAnchor 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 default class SubMenuItem extends React.Component {\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  _resetMouseLeaveWatcher: Bus<null> = kefirBus();\n  _stopper = kefirStopper();\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n  }\n\n  open(callback?: () => any) {\n    this.refs.menuItem.lockHighlight();\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, () => {\n      if (this.props.onDidOpen) this.props.onDidOpen();\n      if (callback) callback();\n    });\n    this.refs.menuItem.takeKeyboard();\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.refs.menuItem.releaseKeyboard();\n    this.refs.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    this.refs.floatAnchor.reposition();\n  }\n\n  hasHighlight(): boolean {\n    return this.refs.menuItem.hasHighlight();\n  }\n\n  highlight(byKeyboard: boolean=true) {\n    this.refs.menuItem.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    this.refs.menuItem.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    this.refs.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    if (!this.state.opened) {\n      this.refs.menuItem.unhighlight();\n      return;\n    }\n\n    // If the mouse isn't going toward the menu, then unhighlight ourself.\n\n    const menuRect = this.refs.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        this.refs.menuItem.unhighlight();\n      });\n  }\n\n  _mouseEnterMenu() {\n    this._resetMouseLeaveWatcher.emit(null);\n    this.refs.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      <MenuItem\n        ref=\"menuItem\"\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            this.refs.menuInspector.moveCursor('down');\n          }\n        }}\n        onItemChosen={(e: ChosenEvent) => {\n          e.stopPropagation();\n          e.preventDefault();\n          this.open();\n          if (e.byKeyboard) {\n            this.refs.menuInspector.moveCursor('down');\n          }\n        }}\n        aria-haspopup={true}\n        aria-expanded={opened}\n      >\n        <FloatAnchor\n          ref=\"floatAnchor\"\n          options={positionOptions}\n          zIndex={menuZIndex}\n          anchor={\n            <div>\n              {children}\n            </div>\n          }\n          float={\n            !opened ? null :\n              <MenuListInspector\n                ref=\"menuInspector\"\n                onLeftPushed={e => {\n                  e.stopPropagation();\n                  e.preventDefault();\n                  this.close();\n                }}\n              >\n                <div\n                  ref=\"menuContainer\"\n                  onMouseEnter={()=>this._mouseEnterMenu()}\n                  >\n                  {menu}\n                </div>\n              </MenuListInspector>\n          }\n          />\n      </MenuItem>\n    );\n  }\n}\n"]} |
{ | ||
"name": "react-menu-list", | ||
"version": "3.2.3", | ||
"version": "3.3.0", | ||
"description": "React component for menu lists and submenus", | ||
@@ -5,0 +5,0 @@ "main": "js/index.js", |
@@ -163,3 +163,3 @@ # react-menu-list | ||
* `open()` | ||
* `open(callback?: Function)` | ||
* `close()` | ||
@@ -217,3 +217,3 @@ * `toggle()` | ||
* `open()` | ||
* `open(callback?: Function)` | ||
* `close()` | ||
@@ -220,0 +220,0 @@ * `toggle()` |
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
205908
1791