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

react-menu-list

Package Overview
Dependencies
Maintainers
6
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 7.0.4 to 7.1.0-beta.0

10

CHANGELOG.md

@@ -0,1 +1,7 @@

## 7.1.0 (2022-09-14)
- MenuList: "keydown" events are now listened for on the MenuList's own div, fixing issues where an ancestor React element could handle the "keydown" event before MenuList does.
- MenuButton: Enter and space "keydown" events on the button element that toggle it now have `stopPropagation()` called so that no other components attempt to handle the event redundantly.
- MenuButton: The third argument of the `renderButton` prop callback is now `onKeyDown`, meant to be used as a keydown event handler instead of a keypress event handler. It will still work as a keypress event handler as previously recommended, so this isn't a breaking change.
## 7.0.4 (2022-08-11)

@@ -49,6 +55,6 @@

<MenuButton
renderButton={(domRef, opened, onKeyPress, onMouseDown) =>
renderButton={(domRef, opened, onKeyDown, onMouseDown) =>
<MyButtonComponent
domRef={domRef}
onKeyPress={onKeyPress}
onKeyDown={onKeyDown}
onMouseDown={onMouseDown}

@@ -55,0 +61,0 @@ />

30

index.d.ts

@@ -9,3 +9,3 @@ import * as React from 'react';

export type Rect = {
export interface Rect {
top: number;

@@ -15,3 +15,3 @@ bottom: number;

right: number;
};
}

@@ -32,3 +32,3 @@ export interface MenuEvent {

export type MenuListProps = {
export interface MenuListProps {
onItemChosen?: (event: ChosenEvent) => void;

@@ -38,3 +38,3 @@ onLeftPushed?: (event: MenuEvent) => void;

children?: ReactNode;
};
}
export class MenuList extends React.Component<MenuListProps> {

@@ -47,3 +47,3 @@ moveCursor(direction: Direction, prevCursorLocation?: Rect): void;

export type MenuItemProps = {
export interface MenuItemProps {
onItemChosen?: (event: ChosenEvent) => void;

@@ -75,3 +75,3 @@ onLeftPushed?: (event: MenuEvent) => void;

'aria-expanded'?: boolean;
};
}
export class MenuItem extends React.Component<MenuItemProps> {

@@ -96,3 +96,3 @@ hasHighlight(): boolean;

export type MenuListInspectorProps = {
export interface MenuListInspectorProps {
onItemChosen?: (event: ChosenEvent) => void;

@@ -102,3 +102,3 @@ onLeftPushed?: (event: MenuEvent) => void;

children: ReactNode;
};
}
export class MenuListInspector extends React.Component<MenuListInspectorProps> {

@@ -115,10 +115,10 @@ moveCursor(direction: Direction, prevCursorLocation?: Rect): boolean;

type RenderProp = (
export type MenuButtonRenderProp = (
domRef: React.Ref<any>,
opened: boolean,
onKeyPress: (e: React.KeyboardEvent) => void,
onKeyDown: (e: React.KeyboardEvent) => void,
onMouseDown: (e: React.MouseEvent) => void
) => ReactNode;
export type MenuButtonProps = {
export interface MenuButtonProps {
className?: string;

@@ -132,3 +132,3 @@ style?: Object;

renderButton?: RenderProp;
renderButton?: MenuButtonRenderProp;

@@ -143,3 +143,3 @@ positionOptions?: FloatAnchorOptions;

onWillClose?: () => void;
};
}
export class MenuButton extends React.Component<MenuButtonProps> {

@@ -154,3 +154,3 @@ open(): Promise<void>;

export type SubMenuItemProps = {
export interface SubMenuItemProps {
menu: ReactNode;

@@ -185,3 +185,3 @@ positionOptions?: FloatAnchorOptions;

children?: ReactNode;
};
}
export class SubMenuItem extends React.Component<SubMenuItemProps> {

@@ -188,0 +188,0 @@ open(): Promise<void>;

@@ -90,8 +90,15 @@ "use strict";

});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onKeyPress", function (e) {
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_onKeyDown", function (e) {
if (e.isComposing) {
return;
}
if (e.key === 'Enter' || e.key === ' ') {
e.stopPropagation();
e.preventDefault();
_this.toggle();
}
});
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_defaultRenderButton", function (domRef, opened, onKeyPress, onMouseDown) {
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "_defaultRenderButton", function (domRef, opened, onKeyDown, onMouseDown) {
var _this$props = _this.props,

@@ -120,3 +127,3 @@ openedStyle = _this$props.openedStyle,

"aria-expanded": opened,
onKeyPress: onKeyPress,
onKeyDown: onKeyDown,
onMouseDown: onMouseDown,

@@ -169,4 +176,10 @@ disabled: _this.props.disabled,

});
});
}); // Possible alternative future design: instead of registering focus/blur/mouse/keydown
// handlers globally, we could have a hidden input or menuitem inside of the
// menu that's kept focused, and just receive blur and keydown events that bubble up
// from it.
// This would be more similar to React Select.
// Similar design note is in MenuList.
return new Promise(function (resolve) {

@@ -243,3 +256,3 @@ _this2.setState({

return _this3._setRef(el, anchorRef);
}, opened, _this3._onKeyPress, _this3._onMouseDown);
}, opened, _this3._onKeyDown, _this3._onMouseDown);
},

@@ -280,2 +293,2 @@ "float": !opened ? null : /*#__PURE__*/React.createElement(_MenuListInspector["default"], {

});
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":["MenuButton","opened","React","createRef","e","button","toggle","key","domRef","onKeyPress","onMouseDown","props","openedStyle","openedClassName","style","className","disabled","title","children","state","Promise","resolve","onWillOpen","Kefir","merge","window","filter","target","el","_anchorRef","FloatAnchor","parentNodes","node","fromEvents","which","map","preventDefault","stopPropagation","takeUntilBy","_onClose","onValue","ReactDOM","unstable_batchedUpdates","close","setState","onDidOpen","onWillClose","emit","open","floatAnchor","_floatAnchorRef","current","Error","reposition","anchorRef","menu","positionOptions","menuZIndex","renderButton","_defaultRenderButton","menuParentElement","_setRef","_onKeyPress","_onMouseDown","_itemChosen","Component","PropTypes","object","oneOfType","string","number","func","bool","element","position","hAlign"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\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};\n\ntype RenderProp = (\n  domRef: React.Ref<any>,\n  opened: boolean,\n  onKeyPress: (e: KeyboardEvent) => void,\n  onMouseDown: (e: MouseEvent) => void\n) => React.Node;\nexport type Props = {\n  positionOptions: FloatAnchorOptions,\n  menuZIndex?: string | number,\n  menuParentElement?: HTMLElement,\n\n  renderButton?: RenderProp,\n\n  children?: React.Node,\n  className?: string,\n  style?: Object,\n  openedClassName?: string,\n  openedStyle?: Object,\n  disabled?: boolean,\n  title?: string,\n\n  menu: React.Node,\n  onWillOpen?: () => void,\n  onDidOpen?: () => void,\n  onWillClose?: () => void,\n};\n\nexport default class MenuButton extends React.Component<Props, State> {\n  static propTypes = {\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n    renderButton: PropTypes.func,\n\n    className: PropTypes.string,\n    openedClassName: PropTypes.string,\n    children: PropTypes.node,\n    style: PropTypes.object,\n    openedStyle: PropTypes.object,\n    disabled: PropTypes.bool,\n    title: PropTypes.string,\n\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  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _anchorRef = React.createRef<HTMLElement>();\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          // Ignore window focus events that happen when the page regains focus\n          .filter(e => e.target !== window),\n      ]).filter(e => {\n        const el = this._anchorRef;\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        ReactDOM.unstable_batchedUpdates(() => {\n          this.close();\n        });\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  _onMouseDown = (e: MouseEvent) => {\n    if (e.button !== 0) {\n      return;\n    }\n\n    this.toggle();\n  };\n\n  _onKeyPress = (e: KeyboardEvent) => {\n    if (e.key === 'Enter' || e.key === ' ') {\n      this.toggle();\n    }\n  };\n\n  _setRef(el: HTMLElement | null, anchorRef: React.Ref<any>) {\n    this._anchorRef = el;\n    setRef(anchorRef, el);\n  }\n\n  _itemChosen() {\n    this.close();\n  }\n\n  _defaultRenderButton = (\n    domRef: React.Ref<any>,\n    opened: boolean,\n    onKeyPress: (e: KeyboardEvent) => void,\n    onMouseDown: (e: MouseEvent) => void\n  ) => {\n    const {openedStyle, openedClassName} = this.props;\n    let {style, className} = this.props;\n    if (opened) {\n      if (openedStyle) {\n        style = {...style, ...openedStyle};\n      }\n      if (openedClassName) {\n        className = `${className || ''} ${openedClassName}`;\n      }\n    }\n\n    return (\n      <button\n        className={className}\n        style={style}\n        ref={domRef}\n        aria-haspopup={true}\n        aria-expanded={opened}\n        onKeyPress={onKeyPress}\n        onMouseDown={onMouseDown}\n        disabled={this.props.disabled}\n        title={this.props.title}\n      >\n        {this.props.children}\n      </button>\n    );\n  };\n\n  componentWillUnmount() {\n    this._onClose.emit();\n  }\n\n  render() {\n    const {menu, positionOptions, menuZIndex} = this.props;\n    const {opened} = this.state;\n\n    const renderButton = this.props.renderButton || this._defaultRenderButton;\n\n    return (\n      <FloatAnchor\n        parentElement={this.props.menuParentElement}\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          renderButton(\n            el => this._setRef(el, anchorRef),\n            opened,\n            this._onKeyPress,\n            this._onMouseDown\n          )\n        }\n        float={\n          !opened ? null : (\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n          )\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","e","button","toggle","isComposing","key","stopPropagation","preventDefault","domRef","onKeyDown","onMouseDown","props","openedStyle","openedClassName","style","className","disabled","title","children","state","Promise","resolve","onWillOpen","Kefir","merge","window","filter","target","el","_anchorRef","FloatAnchor","parentNodes","node","fromEvents","which","map","takeUntilBy","_onClose","onValue","ReactDOM","unstable_batchedUpdates","close","setState","onDidOpen","onWillClose","emit","open","floatAnchor","_floatAnchorRef","current","Error","reposition","anchorRef","menu","positionOptions","menuZIndex","renderButton","_defaultRenderButton","menuParentElement","_setRef","_onKeyDown","_onMouseDown","_itemChosen","Component","PropTypes","object","oneOfType","string","number","func","bool","element","position","hAlign"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\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};\n\nexport type MenuButtonRenderProp = (\n  domRef: React.Ref<any>,\n  opened: boolean,\n  onKeyDown: (e: KeyboardEvent) => void,\n  onMouseDown: (e: MouseEvent) => void\n) => React.Node;\nexport type Props = {\n  positionOptions: FloatAnchorOptions,\n  menuZIndex?: string | number,\n  menuParentElement?: HTMLElement,\n\n  renderButton?: MenuButtonRenderProp,\n\n  children?: React.Node,\n  className?: string,\n  style?: Object,\n  openedClassName?: string,\n  openedStyle?: Object,\n  disabled?: boolean,\n  title?: string,\n\n  menu: React.Node,\n  onWillOpen?: () => void,\n  onDidOpen?: () => void,\n  onWillClose?: () => void,\n};\n\nexport default class MenuButton extends React.Component<Props, State> {\n  static propTypes = {\n    positionOptions: PropTypes.object,\n    menuZIndex: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n\n    renderButton: PropTypes.func,\n\n    className: PropTypes.string,\n    openedClassName: PropTypes.string,\n    children: PropTypes.node,\n    style: PropTypes.object,\n    openedStyle: PropTypes.object,\n    disabled: PropTypes.bool,\n    title: PropTypes.string,\n\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  _floatAnchorRef = React.createRef<FloatAnchor>();\n  _anchorRef = React.createRef<HTMLElement>();\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          // Ignore window focus events that happen when the page regains focus\n          .filter(e => e.target !== window),\n      ]).filter(e => {\n        const el = this._anchorRef;\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        ReactDOM.unstable_batchedUpdates(() => {\n          this.close();\n        });\n      });\n\n    // Possible alternative future design: instead of registering focus/blur/mouse/keydown\n    // handlers globally, we could have a hidden input or menuitem inside of the\n    // menu that's kept focused, and just receive blur and keydown events that bubble up\n    // from it.\n    // This would be more similar to React Select.\n    // Similar design note is in MenuList.\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  _onMouseDown = (e: MouseEvent) => {\n    if (e.button !== 0) {\n      return;\n    }\n\n    this.toggle();\n  };\n\n  _onKeyDown = (e: KeyboardEvent) => {\n    if (e.isComposing) {\n      return;\n    }\n    if (e.key === 'Enter' || e.key === ' ') {\n      e.stopPropagation();\n      e.preventDefault();\n      this.toggle();\n    }\n  };\n\n  _setRef(el: HTMLElement | null, anchorRef: React.Ref<any>) {\n    this._anchorRef = el;\n    setRef(anchorRef, el);\n  }\n\n  _itemChosen() {\n    this.close();\n  }\n\n  _defaultRenderButton = (\n    domRef: React.Ref<any>,\n    opened: boolean,\n    onKeyDown: (e: KeyboardEvent) => void,\n    onMouseDown: (e: MouseEvent) => void\n  ) => {\n    const {openedStyle, openedClassName} = this.props;\n    let {style, className} = this.props;\n    if (opened) {\n      if (openedStyle) {\n        style = {...style, ...openedStyle};\n      }\n      if (openedClassName) {\n        className = `${className || ''} ${openedClassName}`;\n      }\n    }\n\n    return (\n      <button\n        className={className}\n        style={style}\n        ref={domRef}\n        aria-haspopup={true}\n        aria-expanded={opened}\n        onKeyDown={onKeyDown}\n        onMouseDown={onMouseDown}\n        disabled={this.props.disabled}\n        title={this.props.title}\n      >\n        {this.props.children}\n      </button>\n    );\n  };\n\n  componentWillUnmount() {\n    this._onClose.emit();\n  }\n\n  render() {\n    const {menu, positionOptions, menuZIndex} = this.props;\n    const {opened} = this.state;\n\n    const renderButton = this.props.renderButton || this._defaultRenderButton;\n\n    return (\n      <FloatAnchor\n        parentElement={this.props.menuParentElement}\n        ref={this._floatAnchorRef}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={anchorRef =>\n          renderButton(\n            el => this._setRef(el, anchorRef),\n            opened,\n            this._onKeyDown,\n            this._onMouseDown\n          )\n        }\n        float={\n          !opened ? null : (\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n          )\n        }\n      />\n    );\n  }\n}\n"]}

@@ -32,4 +32,2 @@ "use strict";

var _kefir = _interopRequireDefault(require("kefir"));
var _kefirStopper = _interopRequireDefault(require("kefir-stopper"));

@@ -251,15 +249,25 @@

/*:: if (!el) throw new Error(); */
// The only things that should receive keydown/keypress events before us
// are our children. This allows a MenuItem to contain a text input
// which selectively stops propagation on key events for example.
// We want to receive keydown events before any elements that aren't
// our children. (Our children specifically should be able to get keydown events
// before us and choose to stop propagation on them if desired. This allows a
// MenuItem to contain a text input that handles arrow keys itself for example.
// We receive keydown events that originate from our children through the
// onKeyDown handler attached to our own div. This block of code here
// is only for receiving keydown events that don't originate inside of our
// div.)
_kefir["default"].merge([_kefir["default"].fromEvents(window, 'keydown').filter(isEnterOrArrowKey).filter(function (e) {
return el.contains(e.target);
}), (0, _fromEventsCapture["default"])(window, 'keydown').filter(isEnterOrArrowKey).filter(function (e) {
(0, _fromEventsCapture["default"])(window, 'keydown').filter(isEnterOrArrowKey).filter(function (e) {
return !el.contains(e.target);
})]).takeUntilBy(this._stopper).onValue(function (event) {
}).takeUntilBy(this._stopper).onValue(function (event) {
ReactDOM.unstable_batchedUpdates(function () {
_this2._key(event);
});
});
}); // Possible alternative future design: instead of registering keydown handlers
// globally, we could have a hidden input inside of the menu that's kept
// focused, and just receive keydown events that bubble up from there.
// This would be similar to React Select and StreakSheet.
// This would prevent us from needing to add an event handler on window with
// special target-filtering logic, and it would fix certain cases with the
// target-filtering logic where React portals are used inside the children.
// Similar design note is in MenuButton.

@@ -464,5 +472,10 @@ var parentCtx = this._parentCtx();

value: function render() {
var _this3 = this;
return /*#__PURE__*/React.createElement("div", {
role: "menu",
ref: this._elRef
ref: this._elRef,
onKeyDown: function onKeyDown(e) {
_this3._key(e);
}
}, /*#__PURE__*/React.createElement(MenuListContext.Provider, {

@@ -484,2 +497,2 @@ value: this._menuListContext

(0, _defineProperty2["default"])(MenuList, "contextType", _MenuListInspector.MenuListInspectorContext);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuList.js"],"names":["MenuListContext","React","createContext","MenuList","createRef","registerItem","props","control","el","item","register","i","index","_listItems","_item","compareDocumentPosition","Node","DOCUMENT_POSITION_PRECEDING","push","splice","_naturalHighlightedIndex","_lockedHighlightedIndex","_keyboardTakenByIndex","menuListHandle","highlight","byKeyboard","indexOf","Error","_naturalHighlight","unhighlight","itemChosen","_dispatchEvent","ChosenEvent","takeKeyboard","releaseKeyboard","lockHighlight","_lockHighlight","unlockHighlight","moveCursor","direction","prevCursorLocation","updateProps","newProps","oldIndex","isNaturalHighlightIndex","isLockedHighlightIndex","isKeyboardTakenByIndex","unregister","newIndex","context","isEnterOrArrowKey","e","which","_elRef","current","Kefir","merge","fromEvents","window","filter","contains","target","takeUntilBy","_stopper","onValue","event","ReactDOM","unstable_batchedUpdates","_key","parentCtx","_parentCtx","registerMenuList","destroy","unregisterMenuList","visibleHighlightedIndex","_getVisibleHighlightedIndex","notifyHighlighted","newVisibleHighlightedIndex","notifyEvent","cancelBubble","type","onItemChosen","onLeftPushed","onRightPushed","dispatchEvent","length","mEvent","preventDefault","stopPropagation","MenuEvent","defaultPrevented","_menuListContext","children","Component","PropTypes","func","node","MenuListInspectorContext"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport type {Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\nimport Kefir from 'kefir';\nimport kefirStopper from 'kefir-stopper';\nimport findIndex from 'array-find-index';\nimport fromEventsCapture from './lib/fromEventsCapture';\n\nimport MenuEvent from './events/MenuEvent';\nimport ChosenEvent from './events/ChosenEvent';\nimport type {Props as MenuItemProps} from './MenuItem';\nimport {MenuListInspectorContext} from './MenuListInspector';\nimport type {MenuListInspectorContextValue} from './MenuListInspector';\nimport type {Direction, Rect} from './types';\n\n// This type of object is given to a MenuItem to talk to the MenuList.\nexport type MenuListHandle = {\n  highlight(byKeyboard: boolean): void,\n  unhighlight(): void,\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect): void,\n  itemChosen(): void,\n  takeKeyboard(): void,\n  releaseKeyboard(): void,\n  lockHighlight(): void,\n  unlockHighlight(): void,\n  updateProps(props: MenuItemProps): void,\n  unregister(): void,\n};\n\n// This type of object is given to a MenuList to talk to a MenuItem.\nexport type MenuItemControl = {\n  notifyHighlighted(\n    highlighted: boolean,\n    byKeyboard: ?boolean,\n    direction: ?Direction,\n    prevCursorLocation: ?Rect\n  ): void,\n  notifyEvent(event: MenuEvent): void,\n};\n\n// This is the type of the object that MenuList gives as context to its\n// descendants.\nexport type MenuListContextValue = {\n  registerItem(\n    props: MenuItemProps,\n    control: MenuItemControl,\n    el: HTMLElement\n  ): MenuListHandle,\n};\n\nexport const MenuListContext = React.createContext<?MenuListContextValue>(null);\n\nexport type Props = {\n  onItemChosen?: (event: ChosenEvent) => void,\n  onLeftPushed?: (event: MenuEvent) => void,\n  onRightPushed?: (event: MenuEvent) => void,\n  children?: ReactNode,\n};\n\nexport default class MenuList extends React.Component<Props> {\n  static propTypes = {\n    onItemChosen: PropTypes.func,\n    onLeftPushed: PropTypes.func,\n    onRightPushed: PropTypes.func,\n    children: PropTypes.node,\n  };\n\n  _stopper = kefirStopper();\n  _listItems: Array<{\n    props: MenuItemProps,\n    control: MenuItemControl,\n  }> = [];\n\n  // The natural highlight is where the highlight would be if no lock is active.\n  _naturalHighlightedIndex: ?number;\n  _lockedHighlightedIndex: ?number;\n  _keyboardTakenByIndex: ?number;\n\n  _elRef = React.createRef<HTMLDivElement>();\n\n  _getVisibleHighlightedIndex(): ?number {\n    return this._lockedHighlightedIndex != null\n      ? this._lockedHighlightedIndex\n      : this._naturalHighlightedIndex;\n  }\n\n  static contextType = MenuListInspectorContext;\n\n  _menuListContext: MenuListContextValue = {\n    registerItem: (props, control, el) => {\n      const item = {props, control, el};\n\n      const register = () => {\n        let i = -1;\n        if (item.props.index == null) {\n          i = findIndex(\n            this._listItems,\n            _item =>\n              (item.el.compareDocumentPosition(_item.el) &\n                Node.DOCUMENT_POSITION_PRECEDING) ===\n              0\n          );\n        } else {\n          i = findIndex(\n            this._listItems,\n            _item =>\n              _item.props.index != null && item.props.index < _item.props.index\n          );\n        }\n        if (i < 0) {\n          this._listItems.push(item);\n        } else {\n          this._listItems.splice(i, 0, item);\n          if (\n            this._naturalHighlightedIndex != null &&\n            i <= this._naturalHighlightedIndex\n          ) {\n            this._naturalHighlightedIndex++;\n          }\n          if (\n            this._lockedHighlightedIndex != null &&\n            i <= this._lockedHighlightedIndex\n          ) {\n            this._lockedHighlightedIndex++;\n          }\n          if (\n            this._keyboardTakenByIndex != null &&\n            i <= this._keyboardTakenByIndex\n          ) {\n            this._keyboardTakenByIndex++;\n          }\n        }\n      };\n\n      register();\n\n      const menuListHandle: MenuListHandle = {\n        highlight: (byKeyboard: boolean) => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._naturalHighlight(i, byKeyboard);\n        },\n        unhighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._naturalHighlightedIndex === i) {\n            this._naturalHighlight(null, false);\n          }\n        },\n        itemChosen: () => {\n          this._dispatchEvent(control, new ChosenEvent('chosen', false));\n        },\n        takeKeyboard: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._keyboardTakenByIndex = i;\n        },\n        releaseKeyboard: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._keyboardTakenByIndex === i) {\n            this._keyboardTakenByIndex = null;\n          }\n        },\n        lockHighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._lockHighlight(i);\n        },\n        unlockHighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._lockedHighlightedIndex === i) {\n            this._lockHighlight(null);\n          }\n        },\n        moveCursor: (direction: Direction, prevCursorLocation: ?Rect) => {\n          this.moveCursor(direction, prevCursorLocation);\n        },\n        updateProps: (newProps: MenuItemProps) => {\n          if (item.props.index !== newProps.index) {\n            const oldIndex = this._listItems.indexOf(item);\n            const isNaturalHighlightIndex =\n              this._naturalHighlightedIndex === oldIndex;\n            const isLockedHighlightIndex =\n              this._lockedHighlightedIndex === oldIndex;\n            const isKeyboardTakenByIndex =\n              this._keyboardTakenByIndex === oldIndex;\n\n            menuListHandle.unregister();\n            props = newProps;\n            item.props = newProps;\n            register();\n\n            if (\n              isNaturalHighlightIndex ||\n              isLockedHighlightIndex ||\n              isKeyboardTakenByIndex\n            ) {\n              const newIndex = this._listItems.indexOf(item);\n              if (isNaturalHighlightIndex)\n                this._naturalHighlightedIndex = newIndex;\n              if (isLockedHighlightIndex)\n                this._lockedHighlightedIndex = newIndex;\n              if (isKeyboardTakenByIndex) this._keyboardTakenByIndex = newIndex;\n            }\n          } else {\n            props = newProps;\n            item.props = newProps;\n          }\n        },\n        unregister: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (i === this._naturalHighlightedIndex) {\n            this._naturalHighlightedIndex = null;\n          } else if (\n            this._naturalHighlightedIndex != null &&\n            i < this._naturalHighlightedIndex\n          ) {\n            this._naturalHighlightedIndex--;\n          }\n          if (i === this._lockedHighlightedIndex) {\n            this._lockedHighlightedIndex = null;\n          } else if (\n            this._lockedHighlightedIndex != null &&\n            i < this._lockedHighlightedIndex\n          ) {\n            this._lockedHighlightedIndex--;\n          }\n          if (i === this._keyboardTakenByIndex) {\n            this._keyboardTakenByIndex = null;\n          } else if (\n            this._keyboardTakenByIndex != null &&\n            i < this._keyboardTakenByIndex\n          ) {\n            this._keyboardTakenByIndex--;\n          }\n          this._listItems.splice(i, 1);\n        },\n      };\n      return menuListHandle;\n    },\n  };\n\n  _parentCtx(): ?MenuListInspectorContextValue {\n    return this.context;\n  }\n\n  componentDidMount() {\n    const isEnterOrArrowKey = e =>\n      e.which === 13 || (37 <= e.which && e.which <= 40);\n    const el = this._elRef.current;\n    /*:: if (!el) throw new Error(); */\n\n    // The only things that should receive keydown/keypress events before us\n    // are our children. This allows a MenuItem to contain a text input\n    // which selectively stops propagation on key events for example.\n    Kefir.merge([\n      Kefir.fromEvents(window, 'keydown')\n        .filter(isEnterOrArrowKey)\n        .filter(e => el.contains(e.target)),\n      fromEventsCapture(window, 'keydown')\n        .filter(isEnterOrArrowKey)\n        .filter(e => !el.contains(e.target)),\n    ])\n      .takeUntilBy(this._stopper)\n      .onValue(event => {\n        ReactDOM.unstable_batchedUpdates(() => {\n          this._key(event);\n        });\n      });\n\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.registerMenuList(this);\n    }\n  }\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.unregisterMenuList(this);\n    }\n  }\n\n  _naturalHighlight(\n    index: ?number,\n    byKeyboard: boolean,\n    direction: ?Direction,\n    prevCursorLocation: ?Rect\n  ) {\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n\n    if (this._lockedHighlightedIndex != null && byKeyboard) {\n      this._lockedHighlightedIndex = null;\n    }\n    this._naturalHighlightedIndex = index;\n    if (this._lockedHighlightedIndex == null) {\n      if (index != null) {\n        this._listItems[index].control.notifyHighlighted(\n          true,\n          byKeyboard,\n          direction,\n          prevCursorLocation\n        );\n      }\n      if (visibleHighlightedIndex != null && visibleHighlightedIndex != index) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(\n          false\n        );\n      }\n    }\n  }\n\n  _lockHighlight(index: ?number) {\n    if (index === this._lockedHighlightedIndex) return;\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n    this._lockedHighlightedIndex = index;\n    const newVisibleHighlightedIndex = this._getVisibleHighlightedIndex();\n    if (visibleHighlightedIndex != null && newVisibleHighlightedIndex == null) {\n      // When unlocking, prefer to keep the current selection over de-selecting\n      // everything.\n      this._naturalHighlightedIndex = visibleHighlightedIndex;\n    } else if (visibleHighlightedIndex != newVisibleHighlightedIndex) {\n      if (visibleHighlightedIndex != null) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(\n          false\n        );\n      }\n      if (newVisibleHighlightedIndex != null) {\n        this._listItems[newVisibleHighlightedIndex].control.notifyHighlighted(\n          true,\n          false\n        );\n      } else if (this._naturalHighlightedIndex != null) {\n        this._listItems[\n          this._naturalHighlightedIndex\n        ].control.notifyHighlighted(true, false);\n      }\n    }\n  }\n\n  _dispatchEvent(control: ?MenuItemControl, event: MenuEvent) {\n    if (control) {\n      control.notifyEvent(event);\n      if (event.cancelBubble) return;\n    }\n    switch (event.type) {\n      case 'chosen':\n        /*:: if (!(event instanceof ChosenEvent)) throw new Error(); */\n        if (this.props.onItemChosen) this.props.onItemChosen(event);\n        break;\n      // case 'up':\n      //   break;\n      // case 'down':\n      //   break;\n      case 'left':\n        if (this.props.onLeftPushed) this.props.onLeftPushed(event);\n        break;\n      case 'right':\n        if (this.props.onRightPushed) this.props.onRightPushed(event);\n        break;\n    }\n    if (event.cancelBubble) return;\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.dispatchEvent(event);\n    }\n  }\n\n  _key(event: KeyboardEvent) {\n    if (this._keyboardTakenByIndex != null || this._listItems.length === 0) {\n      return;\n    }\n\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n\n    // enter, left, right activate for the current visibly selected item.\n    // up and down de-activate any locks in place, so that they act from the last\n    // naturally-selected item.\n\n    let mEvent = null;\n\n    switch (event.which) {\n      case 13: //enter\n        if (visibleHighlightedIndex != null) {\n          mEvent = new ChosenEvent('chosen', true);\n          event.preventDefault();\n          event.stopPropagation();\n        }\n        break;\n      case 37: //left\n        if (visibleHighlightedIndex != null) {\n          mEvent = new MenuEvent('left');\n        }\n        break;\n      case 39: //right\n        if (visibleHighlightedIndex != null) {\n          mEvent = new MenuEvent('right');\n        }\n        break;\n      case 38: //up\n        event.preventDefault();\n        event.stopPropagation();\n        this.moveCursor('up');\n        break;\n      case 40: //down\n        event.preventDefault();\n        event.stopPropagation();\n        this.moveCursor('down');\n        break;\n    }\n\n    if (mEvent) {\n      const control =\n        visibleHighlightedIndex == null\n          ? null\n          : this._listItems[visibleHighlightedIndex].control;\n      this._dispatchEvent(control, mEvent);\n      if (mEvent.defaultPrevented) event.preventDefault();\n      if (mEvent.defaultPrevented || mEvent.cancelBubble)\n        event.stopPropagation();\n    }\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    if (this._listItems.length == 0) return;\n\n    switch (direction) {\n      case 'up':\n        if (\n          this._naturalHighlightedIndex == null ||\n          this._naturalHighlightedIndex == 0\n        ) {\n          this._naturalHighlight(\n            this._listItems.length - 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        } else {\n          this._naturalHighlight(\n            this._naturalHighlightedIndex - 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        }\n        break;\n      case 'down':\n        if (\n          this._naturalHighlightedIndex == null ||\n          this._naturalHighlightedIndex == this._listItems.length - 1\n        ) {\n          this._naturalHighlight(0, true, direction, prevCursorLocation);\n        } else {\n          this._naturalHighlight(\n            this._naturalHighlightedIndex + 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        }\n        break;\n    }\n  }\n\n  hasHighlight(): boolean {\n    return this._getVisibleHighlightedIndex() != null;\n  }\n\n  render() {\n    return (\n      <div role=\"menu\" ref={this._elRef}>\n        <MenuListContext.Provider value={this._menuListContext}>\n          {this.props.children}\n        </MenuListContext.Provider>\n      </div>\n    );\n  }\n}\n"]}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuList.js"],"names":["MenuListContext","React","createContext","MenuList","createRef","registerItem","props","control","el","item","register","i","index","_listItems","_item","compareDocumentPosition","Node","DOCUMENT_POSITION_PRECEDING","push","splice","_naturalHighlightedIndex","_lockedHighlightedIndex","_keyboardTakenByIndex","menuListHandle","highlight","byKeyboard","indexOf","Error","_naturalHighlight","unhighlight","itemChosen","_dispatchEvent","ChosenEvent","takeKeyboard","releaseKeyboard","lockHighlight","_lockHighlight","unlockHighlight","moveCursor","direction","prevCursorLocation","updateProps","newProps","oldIndex","isNaturalHighlightIndex","isLockedHighlightIndex","isKeyboardTakenByIndex","unregister","newIndex","context","isEnterOrArrowKey","e","which","_elRef","current","window","filter","contains","target","takeUntilBy","_stopper","onValue","event","ReactDOM","unstable_batchedUpdates","_key","parentCtx","_parentCtx","registerMenuList","destroy","unregisterMenuList","visibleHighlightedIndex","_getVisibleHighlightedIndex","notifyHighlighted","newVisibleHighlightedIndex","notifyEvent","cancelBubble","type","onItemChosen","onLeftPushed","onRightPushed","dispatchEvent","length","mEvent","preventDefault","stopPropagation","MenuEvent","defaultPrevented","_menuListContext","children","Component","PropTypes","func","node","MenuListInspectorContext"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport * as React from 'react';\nimport * as ReactDOM from 'react-dom';\nimport type {Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\nimport kefirStopper from 'kefir-stopper';\nimport findIndex from 'array-find-index';\nimport fromEventsCapture from './lib/fromEventsCapture';\n\nimport MenuEvent from './events/MenuEvent';\nimport ChosenEvent from './events/ChosenEvent';\nimport type {Props as MenuItemProps} from './MenuItem';\nimport {MenuListInspectorContext} from './MenuListInspector';\nimport type {MenuListInspectorContextValue} from './MenuListInspector';\nimport type {Direction, Rect} from './types';\n\n// This type of object is given to a MenuItem to talk to the MenuList.\nexport type MenuListHandle = {\n  highlight(byKeyboard: boolean): void,\n  unhighlight(): void,\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect): void,\n  itemChosen(): void,\n  takeKeyboard(): void,\n  releaseKeyboard(): void,\n  lockHighlight(): void,\n  unlockHighlight(): void,\n  updateProps(props: MenuItemProps): void,\n  unregister(): void,\n};\n\n// This type of object is given to a MenuList to talk to a MenuItem.\nexport type MenuItemControl = {\n  notifyHighlighted(\n    highlighted: boolean,\n    byKeyboard: ?boolean,\n    direction: ?Direction,\n    prevCursorLocation: ?Rect\n  ): void,\n  notifyEvent(event: MenuEvent): void,\n};\n\n// This is the type of the object that MenuList gives as context to its\n// descendants.\nexport type MenuListContextValue = {\n  registerItem(\n    props: MenuItemProps,\n    control: MenuItemControl,\n    el: HTMLElement\n  ): MenuListHandle,\n};\n\nexport const MenuListContext = React.createContext<?MenuListContextValue>(null);\n\nexport type Props = {\n  onItemChosen?: (event: ChosenEvent) => void,\n  onLeftPushed?: (event: MenuEvent) => void,\n  onRightPushed?: (event: MenuEvent) => void,\n  children?: ReactNode,\n};\n\nexport default class MenuList extends React.Component<Props> {\n  static propTypes = {\n    onItemChosen: PropTypes.func,\n    onLeftPushed: PropTypes.func,\n    onRightPushed: PropTypes.func,\n    children: PropTypes.node,\n  };\n\n  _stopper = kefirStopper();\n  _listItems: Array<{\n    props: MenuItemProps,\n    control: MenuItemControl,\n  }> = [];\n\n  // The natural highlight is where the highlight would be if no lock is active.\n  _naturalHighlightedIndex: ?number;\n  _lockedHighlightedIndex: ?number;\n  _keyboardTakenByIndex: ?number;\n\n  _elRef = React.createRef<HTMLDivElement>();\n\n  _getVisibleHighlightedIndex(): ?number {\n    return this._lockedHighlightedIndex != null\n      ? this._lockedHighlightedIndex\n      : this._naturalHighlightedIndex;\n  }\n\n  static contextType = MenuListInspectorContext;\n\n  _menuListContext: MenuListContextValue = {\n    registerItem: (props, control, el) => {\n      const item = {props, control, el};\n\n      const register = () => {\n        let i = -1;\n        if (item.props.index == null) {\n          i = findIndex(\n            this._listItems,\n            _item =>\n              (item.el.compareDocumentPosition(_item.el) &\n                Node.DOCUMENT_POSITION_PRECEDING) ===\n              0\n          );\n        } else {\n          i = findIndex(\n            this._listItems,\n            _item =>\n              _item.props.index != null && item.props.index < _item.props.index\n          );\n        }\n        if (i < 0) {\n          this._listItems.push(item);\n        } else {\n          this._listItems.splice(i, 0, item);\n          if (\n            this._naturalHighlightedIndex != null &&\n            i <= this._naturalHighlightedIndex\n          ) {\n            this._naturalHighlightedIndex++;\n          }\n          if (\n            this._lockedHighlightedIndex != null &&\n            i <= this._lockedHighlightedIndex\n          ) {\n            this._lockedHighlightedIndex++;\n          }\n          if (\n            this._keyboardTakenByIndex != null &&\n            i <= this._keyboardTakenByIndex\n          ) {\n            this._keyboardTakenByIndex++;\n          }\n        }\n      };\n\n      register();\n\n      const menuListHandle: MenuListHandle = {\n        highlight: (byKeyboard: boolean) => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._naturalHighlight(i, byKeyboard);\n        },\n        unhighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._naturalHighlightedIndex === i) {\n            this._naturalHighlight(null, false);\n          }\n        },\n        itemChosen: () => {\n          this._dispatchEvent(control, new ChosenEvent('chosen', false));\n        },\n        takeKeyboard: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._keyboardTakenByIndex = i;\n        },\n        releaseKeyboard: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._keyboardTakenByIndex === i) {\n            this._keyboardTakenByIndex = null;\n          }\n        },\n        lockHighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          this._lockHighlight(i);\n        },\n        unlockHighlight: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (this._lockedHighlightedIndex === i) {\n            this._lockHighlight(null);\n          }\n        },\n        moveCursor: (direction: Direction, prevCursorLocation: ?Rect) => {\n          this.moveCursor(direction, prevCursorLocation);\n        },\n        updateProps: (newProps: MenuItemProps) => {\n          if (item.props.index !== newProps.index) {\n            const oldIndex = this._listItems.indexOf(item);\n            const isNaturalHighlightIndex =\n              this._naturalHighlightedIndex === oldIndex;\n            const isLockedHighlightIndex =\n              this._lockedHighlightedIndex === oldIndex;\n            const isKeyboardTakenByIndex =\n              this._keyboardTakenByIndex === oldIndex;\n\n            menuListHandle.unregister();\n            props = newProps;\n            item.props = newProps;\n            register();\n\n            if (\n              isNaturalHighlightIndex ||\n              isLockedHighlightIndex ||\n              isKeyboardTakenByIndex\n            ) {\n              const newIndex = this._listItems.indexOf(item);\n              if (isNaturalHighlightIndex)\n                this._naturalHighlightedIndex = newIndex;\n              if (isLockedHighlightIndex)\n                this._lockedHighlightedIndex = newIndex;\n              if (isKeyboardTakenByIndex) this._keyboardTakenByIndex = newIndex;\n            }\n          } else {\n            props = newProps;\n            item.props = newProps;\n          }\n        },\n        unregister: () => {\n          const i = this._listItems.indexOf(item);\n          if (i < 0) throw new Error('Already unregistered MenuItem');\n          if (i === this._naturalHighlightedIndex) {\n            this._naturalHighlightedIndex = null;\n          } else if (\n            this._naturalHighlightedIndex != null &&\n            i < this._naturalHighlightedIndex\n          ) {\n            this._naturalHighlightedIndex--;\n          }\n          if (i === this._lockedHighlightedIndex) {\n            this._lockedHighlightedIndex = null;\n          } else if (\n            this._lockedHighlightedIndex != null &&\n            i < this._lockedHighlightedIndex\n          ) {\n            this._lockedHighlightedIndex--;\n          }\n          if (i === this._keyboardTakenByIndex) {\n            this._keyboardTakenByIndex = null;\n          } else if (\n            this._keyboardTakenByIndex != null &&\n            i < this._keyboardTakenByIndex\n          ) {\n            this._keyboardTakenByIndex--;\n          }\n          this._listItems.splice(i, 1);\n        },\n      };\n      return menuListHandle;\n    },\n  };\n\n  _parentCtx(): ?MenuListInspectorContextValue {\n    return this.context;\n  }\n\n  componentDidMount() {\n    const isEnterOrArrowKey = e =>\n      e.which === 13 || (37 <= e.which && e.which <= 40);\n    const el = this._elRef.current;\n    /*:: if (!el) throw new Error(); */\n\n    // We want to receive keydown events before any elements that aren't\n    // our children. (Our children specifically should be able to get keydown events\n    // before us and choose to stop propagation on them if desired. This allows a\n    // MenuItem to contain a text input that handles arrow keys itself for example.\n    // We receive keydown events that originate from our children through the\n    // onKeyDown handler attached to our own div. This block of code here\n    // is only for receiving keydown events that don't originate inside of our\n    // div.)\n    fromEventsCapture(window, 'keydown')\n      .filter(isEnterOrArrowKey)\n      .filter(e => !el.contains(e.target))\n      .takeUntilBy(this._stopper)\n      .onValue(event => {\n        ReactDOM.unstable_batchedUpdates(() => {\n          this._key(event);\n        });\n      });\n\n    // Possible alternative future design: instead of registering keydown handlers\n    // globally, we could have a hidden input inside of the menu that's kept\n    // focused, and just receive keydown events that bubble up from there.\n    // This would be similar to React Select and StreakSheet.\n    // This would prevent us from needing to add an event handler on window with\n    // special target-filtering logic, and it would fix certain cases with the\n    // target-filtering logic where React portals are used inside the children.\n    // Similar design note is in MenuButton.\n\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.registerMenuList(this);\n    }\n  }\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.unregisterMenuList(this);\n    }\n  }\n\n  _naturalHighlight(\n    index: ?number,\n    byKeyboard: boolean,\n    direction: ?Direction,\n    prevCursorLocation: ?Rect\n  ) {\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n\n    if (this._lockedHighlightedIndex != null && byKeyboard) {\n      this._lockedHighlightedIndex = null;\n    }\n    this._naturalHighlightedIndex = index;\n    if (this._lockedHighlightedIndex == null) {\n      if (index != null) {\n        this._listItems[index].control.notifyHighlighted(\n          true,\n          byKeyboard,\n          direction,\n          prevCursorLocation\n        );\n      }\n      if (visibleHighlightedIndex != null && visibleHighlightedIndex != index) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(\n          false\n        );\n      }\n    }\n  }\n\n  _lockHighlight(index: ?number) {\n    if (index === this._lockedHighlightedIndex) return;\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n    this._lockedHighlightedIndex = index;\n    const newVisibleHighlightedIndex = this._getVisibleHighlightedIndex();\n    if (visibleHighlightedIndex != null && newVisibleHighlightedIndex == null) {\n      // When unlocking, prefer to keep the current selection over de-selecting\n      // everything.\n      this._naturalHighlightedIndex = visibleHighlightedIndex;\n    } else if (visibleHighlightedIndex != newVisibleHighlightedIndex) {\n      if (visibleHighlightedIndex != null) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(\n          false\n        );\n      }\n      if (newVisibleHighlightedIndex != null) {\n        this._listItems[newVisibleHighlightedIndex].control.notifyHighlighted(\n          true,\n          false\n        );\n      } else if (this._naturalHighlightedIndex != null) {\n        this._listItems[\n          this._naturalHighlightedIndex\n        ].control.notifyHighlighted(true, false);\n      }\n    }\n  }\n\n  _dispatchEvent(control: ?MenuItemControl, event: MenuEvent) {\n    if (control) {\n      control.notifyEvent(event);\n      if (event.cancelBubble) return;\n    }\n    switch (event.type) {\n      case 'chosen':\n        /*:: if (!(event instanceof ChosenEvent)) throw new Error(); */\n        if (this.props.onItemChosen) this.props.onItemChosen(event);\n        break;\n      // case 'up':\n      //   break;\n      // case 'down':\n      //   break;\n      case 'left':\n        if (this.props.onLeftPushed) this.props.onLeftPushed(event);\n        break;\n      case 'right':\n        if (this.props.onRightPushed) this.props.onRightPushed(event);\n        break;\n    }\n    if (event.cancelBubble) return;\n    const parentCtx = this._parentCtx();\n    if (parentCtx) {\n      parentCtx.dispatchEvent(event);\n    }\n  }\n\n  _key(event: KeyboardEvent) {\n    if (this._keyboardTakenByIndex != null || this._listItems.length === 0) {\n      return;\n    }\n\n    const visibleHighlightedIndex = this._getVisibleHighlightedIndex();\n\n    // enter, left, right activate for the current visibly selected item.\n    // up and down de-activate any locks in place, so that they act from the last\n    // naturally-selected item.\n\n    let mEvent = null;\n\n    switch (event.which) {\n      case 13: //enter\n        if (visibleHighlightedIndex != null) {\n          mEvent = new ChosenEvent('chosen', true);\n          event.preventDefault();\n          event.stopPropagation();\n        }\n        break;\n      case 37: //left\n        if (visibleHighlightedIndex != null) {\n          mEvent = new MenuEvent('left');\n        }\n        break;\n      case 39: //right\n        if (visibleHighlightedIndex != null) {\n          mEvent = new MenuEvent('right');\n        }\n        break;\n      case 38: //up\n        event.preventDefault();\n        event.stopPropagation();\n        this.moveCursor('up');\n        break;\n      case 40: //down\n        event.preventDefault();\n        event.stopPropagation();\n        this.moveCursor('down');\n        break;\n    }\n\n    if (mEvent) {\n      const control =\n        visibleHighlightedIndex == null\n          ? null\n          : this._listItems[visibleHighlightedIndex].control;\n      this._dispatchEvent(control, mEvent);\n      if (mEvent.defaultPrevented) event.preventDefault();\n      if (mEvent.defaultPrevented || mEvent.cancelBubble)\n        event.stopPropagation();\n    }\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    if (this._listItems.length == 0) return;\n\n    switch (direction) {\n      case 'up':\n        if (\n          this._naturalHighlightedIndex == null ||\n          this._naturalHighlightedIndex == 0\n        ) {\n          this._naturalHighlight(\n            this._listItems.length - 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        } else {\n          this._naturalHighlight(\n            this._naturalHighlightedIndex - 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        }\n        break;\n      case 'down':\n        if (\n          this._naturalHighlightedIndex == null ||\n          this._naturalHighlightedIndex == this._listItems.length - 1\n        ) {\n          this._naturalHighlight(0, true, direction, prevCursorLocation);\n        } else {\n          this._naturalHighlight(\n            this._naturalHighlightedIndex + 1,\n            true,\n            direction,\n            prevCursorLocation\n          );\n        }\n        break;\n    }\n  }\n\n  hasHighlight(): boolean {\n    return this._getVisibleHighlightedIndex() != null;\n  }\n\n  render() {\n    return (\n      <div\n        role=\"menu\"\n        ref={this._elRef}\n        onKeyDown={e => {\n          this._key(e);\n        }}\n      >\n        <MenuListContext.Provider value={this._menuListContext}>\n          {this.props.children}\n        </MenuListContext.Provider>\n      </div>\n    );\n  }\n}\n"]}
{
"name": "react-menu-list",
"version": "7.0.4",
"version": "7.1.0-beta.0",
"description": "React component for menu lists and submenus",

@@ -66,3 +66,3 @@ "main": "js/index.js",

"rimraf": "^3.0.0",
"typescript": "^4.0.2",
"typescript": "^4.8.3",
"watchify": "^4.0.0"

@@ -69,0 +69,0 @@ },

@@ -208,7 +208,7 @@ # react-menu-list

- `renderButton`: Optional render prop that allows a different component to be used
instead of an html `<button>`. `renderButton` is a function with a signature of `(domRef: React.Ref<any>, opened: boolean, onKeyPress: (e: KeyboardEvent) => void, onMouseDown: (e: MouseEvent) => void) => React.Node`
instead of an html `<button>`. `renderButton` is a function with a signature of `(domRef: React.Ref<any>, opened: boolean, onKeyDown: (e: KeyboardEvent) => void, onMouseDown: (e: MouseEvent) => void) => React.Node`
- `domRef` must be passed as a ref to the button's DOM element in your custom implementation
- `opened` is whether the menu is being opened. Useful if you want the appearance of the button to change in this state
- `onKeyPress` must be called when your custom button registers key press events
- `onMouseDown` must be called when your custom button registers mouse down events
- `onKeyDown` must be used to handle keydown events on your button
- `onMouseDown` must be used to handle mousedown events on your custom button

@@ -215,0 +215,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