Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

react-menu-list

Package Overview
Dependencies
Maintainers
1
Versions
50
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-menu-list - npm Package Compare versions

Comparing version 6.0.5 to 6.1.0

5

CHANGELOG.md

@@ -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 @@

3

index.d.ts

@@ -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;

12

js/MenuButton.js

@@ -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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc