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 1.3.1 to 1.4.0

8

js/MenuButton.js

@@ -97,2 +97,7 @@ 'use strict';

}, {
key: 'reposition',
value: function reposition() {
this.refs.floatAnchor.reposition();
}
}, {
key: '_itemChosen',

@@ -134,2 +139,3 @@ value: function _itemChosen() {

return _react2.default.createElement(_reactFloatAnchor2.default, {
ref: 'floatAnchor',
options: positionOptions,

@@ -235,2 +241,2 @@ zIndex: zIndex,

module.exports = exports['default'];
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":[],"mappings":"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","file":"MenuButton.js","sourcesContent":["/* @flow */\n\nimport React, {PropTypes} from 'react';\nimport FloatAnchor from 'react-float-anchor';\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    zIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\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  };\n\n  state: State = {\n    opened: false\n  };\n\n  // Safari and Firefox on OS X don't focus the button on mousedown, so on\n  // mousedown we do a quick setTimeout and focus a dummy child element if the\n  // button wasn't focused.\n  _focusFixerTimeout: any = null;\n\n  // Set to true after mousedown until the focus event happens. When it's true,\n  // blur events on the dummy child element should not cause the menu to close.\n  _focusing: boolean = false;\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\n  close() {\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  _itemChosen() {\n    this.close();\n  }\n\n  componentWillUnmount() {\n    clearTimeout(this._focusFixerTimeout);\n  }\n\n  render() {\n    const {\n      children, menu,\n      positionOptions, zIndex,\n      disabled, title\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        options={positionOptions}\n        zIndex={zIndex}\n        anchor={\n          <button\n            type=\"button\"\n            ref=\"button\"\n            className={className}\n            style={style}\n            onFocus={()=>{\n              this._focusing = false;\n              clearTimeout(this._focusFixerTimeout);\n            }}\n            onBlur={()=>{\n              clearTimeout(this._focusFixerTimeout);\n              this.close();\n            }}\n            onMouseDown={()=>{\n              clearTimeout(this._focusFixerTimeout);\n              if (!opened) {\n                this._focusing = true;\n                this._focusFixerTimeout = setTimeout(() => {\n                  if (document.activeElement !== this.refs.button) {\n                    this.refs.focusHolder.focus();\n                  }\n                }, 0);\n              }\n              this.toggle();\n            }}\n            onKeyPress={e=>{\n              if (e.key === 'Enter' || e.key === ' ') {\n                this.toggle();\n              }\n            }}\n            onKeyDown={e=>{\n              if (e.key === 'Escape' && opened) {\n                this.close();\n                e.preventDefault();\n                e.stopPropagation();\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n            disabled={disabled}\n            title={title}\n          >\n            <div\n              ref=\"focusHolder\"\n              tabIndex=\"-1\"\n              aria-hidden={true}\n              style={{\n                opacity: '0',\n                outline: 'none',\n                width: '0px',\n                height: '0px',\n                overflow: 'hidden'\n              }}\n              onBlur={e=>{\n                if (this._focusing) {\n                  e.stopPropagation();\n                }\n              }}\n            />\n            {children}\n          </button>\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;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":[],"mappings":"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","file":"MenuButton.js","sourcesContent":["/* @flow */\n\nimport React, {PropTypes} from 'react';\nimport FloatAnchor from 'react-float-anchor';\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    zIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\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  };\n\n  state: State = {\n    opened: false\n  };\n\n  // Safari and Firefox on OS X don't focus the button on mousedown, so on\n  // mousedown we do a quick setTimeout and focus a dummy child element if the\n  // button wasn't focused.\n  _focusFixerTimeout: any = null;\n\n  // Set to true after mousedown until the focus event happens. When it's true,\n  // blur events on the dummy child element should not cause the menu to close.\n  _focusing: boolean = false;\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\n  close() {\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\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    clearTimeout(this._focusFixerTimeout);\n  }\n\n  render() {\n    const {\n      children, menu,\n      positionOptions, zIndex,\n      disabled, title\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={zIndex}\n        anchor={\n          <button\n            type=\"button\"\n            ref=\"button\"\n            className={className}\n            style={style}\n            onFocus={()=>{\n              this._focusing = false;\n              clearTimeout(this._focusFixerTimeout);\n            }}\n            onBlur={()=>{\n              clearTimeout(this._focusFixerTimeout);\n              this.close();\n            }}\n            onMouseDown={()=>{\n              clearTimeout(this._focusFixerTimeout);\n              if (!opened) {\n                this._focusing = true;\n                this._focusFixerTimeout = setTimeout(() => {\n                  if (document.activeElement !== this.refs.button) {\n                    this.refs.focusHolder.focus();\n                  }\n                }, 0);\n              }\n              this.toggle();\n            }}\n            onKeyPress={e=>{\n              if (e.key === 'Enter' || e.key === ' ') {\n                this.toggle();\n              }\n            }}\n            onKeyDown={e=>{\n              if (e.key === 'Escape' && opened) {\n                this.close();\n                e.preventDefault();\n                e.stopPropagation();\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n            disabled={disabled}\n            title={title}\n          >\n            <div\n              ref=\"focusHolder\"\n              tabIndex=\"-1\"\n              aria-hidden={true}\n              style={{\n                opacity: '0',\n                outline: 'none',\n                width: '0px',\n                height: '0px',\n                overflow: 'hidden'\n              }}\n              onBlur={e=>{\n                if (this._focusing) {\n                  e.stopPropagation();\n                }\n              }}\n            />\n            {children}\n          </button>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]}

@@ -113,2 +113,7 @@ 'use strict';

}, {
key: 'reposition',
value: function reposition() {
this.refs.floatAnchor.reposition();
}
}, {
key: '_onHighlightChange',

@@ -255,2 +260,3 @@ value: function _onHighlightChange(highlighted, event) {

_react2.default.createElement(_reactFloatAnchor2.default, {
ref: 'floatAnchor',
options: positionOptions,

@@ -319,2 +325,2 @@ zIndex: zIndex,

module.exports = exports['default'];
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":[],"mappings":"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","file":"SubMenuItem.js","sourcesContent":["/* @flow */\n\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\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 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    zIndex: 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: Object = kefirBus();\n  _stopper: Object = kefirBus();\n\n  componentWillUnmount() {\n    this._stopper.emit(null);\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  _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, zIndex, 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          options={positionOptions}\n          zIndex={zIndex}\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;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":[],"mappings":"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","file":"SubMenuItem.js","sourcesContent":["/* @flow */\n\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\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 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    zIndex: 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: Object = kefirBus();\n  _stopper: Object = kefirBus();\n\n  componentWillUnmount() {\n    this._stopper.emit(null);\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  _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, zIndex, 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={zIndex}\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"]}

2

package.json
{
"name": "react-menu-list",
"version": "1.3.1",
"version": "1.4.0",
"description": "React component for menu lists and submenus",

@@ -5,0 +5,0 @@ "main": "js/index.js",

@@ -162,2 +162,4 @@ # react-menu-list

* `toggle()`
* `reposition()`: Repositions the floating submenu. Call this if you change the
size of the menu.

@@ -200,2 +202,4 @@ ### MenuListInspector

* `toggle()`
* `reposition()`: Repositions the floating submenu. Call this if you change the
size of the menu.

@@ -202,0 +206,0 @@ ### Dropdown

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