react-menu-list
Advanced tools
Comparing version 5.0.1 to 6.0.0
@@ -0,1 +1,13 @@ | ||
## 6.0.0 (2018-10-31) | ||
### Breaking Changes | ||
* react-menu-list now requires React v16.6.0 or above. | ||
* The component passed to the optional MenuButton prop `ButtonComponent` must support a `domRef` prop which is passed as a ref to the button's DOM element. | ||
* The `open` method of MenuButton and SubMenuItem no longer takes a callback as a parameter. It returns a Promise now instead. | ||
### Improvements | ||
* No longer uses any deprecated APIs (legacy Context API, lifecycle methods, | ||
and ReactDOM.findDOMNode). | ||
* Added TypeScript type definitions. | ||
## 5.0.1 (2018-05-15) | ||
@@ -2,0 +14,0 @@ |
@@ -1,68 +0,56 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var Dropdown = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(Dropdown, _React$Component); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _react = require('react'); | ||
var _react2 = _interopRequireDefault(_react); | ||
var _propTypes = require('prop-types'); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var Dropdown = function (_React$Component) { | ||
(0, _inherits3.default)(Dropdown, _React$Component); | ||
function Dropdown() { | ||
(0, _classCallCheck3.default)(this, Dropdown); | ||
return (0, _possibleConstructorReturn3.default)(this, (Dropdown.__proto__ || (0, _getPrototypeOf2.default)(Dropdown)).apply(this, arguments)); | ||
(0, _classCallCheck2.default)(this, Dropdown); | ||
return (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(Dropdown).apply(this, arguments)); | ||
} | ||
(0, _createClass3.default)(Dropdown, [{ | ||
key: 'render', | ||
(0, _createClass2.default)(Dropdown, [{ | ||
key: "render", | ||
value: function render() { | ||
return _react2.default.createElement( | ||
'div', | ||
{ style: { | ||
background: 'white', | ||
border: '1px solid rgba(0,0,0,.2)', | ||
boxShadow: '0 2px 4px rgba(0,0,0,0.2)', | ||
padding: '6px 0' | ||
} }, | ||
this.props.children | ||
); | ||
return _react.default.createElement("div", { | ||
style: { | ||
background: 'white', | ||
border: '1px solid rgba(0,0,0,.2)', | ||
boxShadow: '0 2px 4px rgba(0,0,0,0.2)', | ||
padding: '6px 0' | ||
} | ||
}, this.props.children); | ||
} | ||
}]); | ||
return Dropdown; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
Dropdown.propTypes = { | ||
children: _propTypes2.default.node | ||
}; | ||
exports.default = Dropdown; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9Ecm9wZG93bi5qcyJdLCJuYW1lcyI6WyJEcm9wZG93biIsImJhY2tncm91bmQiLCJib3JkZXIiLCJib3hTaGFkb3ciLCJwYWRkaW5nIiwicHJvcHMiLCJjaGlsZHJlbiIsIlJlYWN0IiwiQ29tcG9uZW50IiwicHJvcFR5cGVzIiwiUHJvcFR5cGVzIiwibm9kZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7OztBQUVBOzs7Ozs7SUFNcUJBLFE7Ozs7Ozs7Ozs7NkJBS1Y7QUFDUCxhQUNFO0FBQUE7QUFBQSxVQUFLLE9BQU87QUFDVkMsd0JBQVksT0FERjtBQUVWQyxvQkFBUSwwQkFGRTtBQUdWQyx1QkFBVywyQkFIRDtBQUlWQyxxQkFBUztBQUpDLFdBQVo7QUFNRyxhQUFLQyxLQUFMLENBQVdDO0FBTmQsT0FERjtBQVVEOzs7RUFoQm1DQyxnQkFBTUMsUzs7QUFBdkJSLFEsQ0FDWlMsUyxHQUFZO0FBQ2pCSCxZQUFVSSxvQkFBVUM7QUFESCxDO2tCQURBWCxRIiwiZmlsZSI6IkRyb3Bkb3duLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB0eXBlIHtOb2RlIGFzIFJlYWN0Tm9kZX0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IFByb3BUeXBlcyBmcm9tICdwcm9wLXR5cGVzJztcblxudHlwZSBQcm9wcyA9IHtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBEcm9wZG93biBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxQcm9wcz4ge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZVxuICB9O1xuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBzdHlsZT17e1xuICAgICAgICBiYWNrZ3JvdW5kOiAnd2hpdGUnLFxuICAgICAgICBib3JkZXI6ICcxcHggc29saWQgcmdiYSgwLDAsMCwuMiknLFxuICAgICAgICBib3hTaGFkb3c6ICcwIDJweCA0cHggcmdiYSgwLDAsMCwwLjIpJyxcbiAgICAgICAgcGFkZGluZzogJzZweCAwJ1xuICAgICAgfX0+XG4gICAgICAgIHt0aGlzLnByb3BzLmNoaWxkcmVufVxuICAgICAgPC9kaXY+XG4gICAgKTtcbiAgfVxufVxuIl19 | ||
(0, _defineProperty2.default)(Dropdown, "propTypes", { | ||
children: _propTypes.default.node | ||
}); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9Ecm9wZG93bi5qcyJdLCJuYW1lcyI6WyJEcm9wZG93biIsImJhY2tncm91bmQiLCJib3JkZXIiLCJib3hTaGFkb3ciLCJwYWRkaW5nIiwicHJvcHMiLCJjaGlsZHJlbiIsIlJlYWN0IiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwibm9kZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUE7O0FBRUE7O0lBTXFCQSxROzs7Ozs7Ozs7Ozs7NkJBS1Y7QUFDUCxhQUNFO0FBQUssUUFBQSxLQUFLLEVBQUU7QUFDVkMsVUFBQUEsVUFBVSxFQUFFLE9BREY7QUFFVkMsVUFBQUEsTUFBTSxFQUFFLDBCQUZFO0FBR1ZDLFVBQUFBLFNBQVMsRUFBRSwyQkFIRDtBQUlWQyxVQUFBQSxPQUFPLEVBQUU7QUFKQztBQUFaLFNBTUcsS0FBS0MsS0FBTCxDQUFXQyxRQU5kLENBREY7QUFVRDs7O0VBaEJtQ0MsZUFBTUMsUzs7OzhCQUF2QlIsUSxlQUNBO0FBQ2pCTSxFQUFBQSxRQUFRLEVBQUVHLG1CQUFVQztBQURILEMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHR5cGUge05vZGUgYXMgUmVhY3ROb2RlfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuXG50eXBlIFByb3BzID0ge1xuICBjaGlsZHJlbj86IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIERyb3Bkb3duIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50PFByb3BzPiB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlXG4gIH07XG5cbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiAoXG4gICAgICA8ZGl2IHN0eWxlPXt7XG4gICAgICAgIGJhY2tncm91bmQ6ICd3aGl0ZScsXG4gICAgICAgIGJvcmRlcjogJzFweCBzb2xpZCByZ2JhKDAsMCwwLC4yKScsXG4gICAgICAgIGJveFNoYWRvdzogJzAgMnB4IDRweCByZ2JhKDAsMCwwLDAuMiknLFxuICAgICAgICBwYWRkaW5nOiAnNnB4IDAnXG4gICAgICB9fT5cbiAgICAgICAge3RoaXMucHJvcHMuY2hpbGRyZW59XG4gICAgICA8L2Rpdj5cbiAgICApO1xuICB9XG59XG4iXX0= |
@@ -1,37 +0,35 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _MenuEvent2 = _interopRequireDefault(require("./MenuEvent")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var ChosenEvent = | ||
/*#__PURE__*/ | ||
function (_MenuEvent) { | ||
(0, _inherits2.default)(ChosenEvent, _MenuEvent); | ||
var _MenuEvent2 = require('./MenuEvent'); | ||
var _MenuEvent3 = _interopRequireDefault(_MenuEvent2); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var ChosenEvent = function (_MenuEvent) { | ||
(0, _inherits3.default)(ChosenEvent, _MenuEvent); | ||
function ChosenEvent(type, byKeyboard) { | ||
(0, _classCallCheck3.default)(this, ChosenEvent); | ||
var _this; | ||
var _this = (0, _possibleConstructorReturn3.default)(this, (ChosenEvent.__proto__ || (0, _getPrototypeOf2.default)(ChosenEvent)).call(this, type)); | ||
(0, _classCallCheck2.default)(this, ChosenEvent); | ||
_this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(ChosenEvent).call(this, type)); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "byKeyboard", void 0); | ||
_this.byKeyboard = byKeyboard; | ||
@@ -42,6 +40,5 @@ return _this; | ||
return ChosenEvent; | ||
}(_MenuEvent3.default); | ||
}(_MenuEvent2.default); | ||
exports.default = ChosenEvent; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ldmVudHMvQ2hvc2VuRXZlbnQuanMiXSwibmFtZXMiOlsiQ2hvc2VuRXZlbnQiLCJ0eXBlIiwiYnlLZXlib2FyZCIsIk1lbnVFdmVudCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBOzs7Ozs7SUFFcUJBLFc7OztBQUduQix1QkFBWUMsSUFBWixFQUEwQkMsVUFBMUIsRUFBK0M7QUFBQTs7QUFBQSxnSkFDdkNELElBRHVDOztBQUU3QyxVQUFLQyxVQUFMLEdBQWtCQSxVQUFsQjtBQUY2QztBQUc5Qzs7O0VBTnNDQyxtQjs7a0JBQXBCSCxXIiwiZmlsZSI6IkNob3NlbkV2ZW50LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuaW1wb3J0IE1lbnVFdmVudCBmcm9tICcuL01lbnVFdmVudCc7XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIENob3NlbkV2ZW50IGV4dGVuZHMgTWVudUV2ZW50IHtcbiAgYnlLZXlib2FyZDogYm9vbGVhbjtcblxuICBjb25zdHJ1Y3Rvcih0eXBlOiBzdHJpbmcsIGJ5S2V5Ym9hcmQ6IGJvb2xlYW4pIHtcbiAgICBzdXBlcih0eXBlKTtcbiAgICB0aGlzLmJ5S2V5Ym9hcmQgPSBieUtleWJvYXJkO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ldmVudHMvQ2hvc2VuRXZlbnQuanMiXSwibmFtZXMiOlsiQ2hvc2VuRXZlbnQiLCJ0eXBlIiwiYnlLZXlib2FyZCIsIk1lbnVFdmVudCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUE7O0lBRXFCQSxXOzs7OztBQUduQix1QkFBWUMsSUFBWixFQUEwQkMsVUFBMUIsRUFBK0M7QUFBQTs7QUFBQTtBQUM3QyxpSEFBTUQsSUFBTjtBQUQ2QztBQUU3QyxVQUFLQyxVQUFMLEdBQWtCQSxVQUFsQjtBQUY2QztBQUc5Qzs7O0VBTnNDQyxtQiIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBmbG93ICovXG5cbmltcG9ydCBNZW51RXZlbnQgZnJvbSAnLi9NZW51RXZlbnQnO1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBDaG9zZW5FdmVudCBleHRlbmRzIE1lbnVFdmVudCB7XG4gIGJ5S2V5Ym9hcmQ6IGJvb2xlYW47XG5cbiAgY29uc3RydWN0b3IodHlwZTogc3RyaW5nLCBieUtleWJvYXJkOiBib29sZWFuKSB7XG4gICAgc3VwZXIodHlwZSk7XG4gICAgdGhpcy5ieUtleWJvYXJkID0gYnlLZXlib2FyZDtcbiAgfVxufVxuIl19 |
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _classCallCheck2 = require("babel-runtime/helpers/classCallCheck"); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _createClass2 = require("babel-runtime/helpers/createClass"); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var MenuEvent = function () { | ||
var MenuEvent = | ||
/*#__PURE__*/ | ||
function () { | ||
function MenuEvent(type) { | ||
(0, _classCallCheck3.default)(this, MenuEvent); | ||
this.cancelBubble = false; | ||
this.defaultPrevented = false; | ||
(0, _classCallCheck2.default)(this, MenuEvent); | ||
(0, _defineProperty2.default)(this, "type", void 0); | ||
(0, _defineProperty2.default)(this, "cancelBubble", false); | ||
(0, _defineProperty2.default)(this, "defaultPrevented", false); | ||
this.type = type; | ||
} | ||
(0, _createClass3.default)(MenuEvent, [{ | ||
(0, _createClass2.default)(MenuEvent, [{ | ||
key: "stopPropagation", | ||
@@ -41,3 +42,2 @@ value: function stopPropagation() { | ||
exports.default = MenuEvent; | ||
module.exports = exports["default"]; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ldmVudHMvTWVudUV2ZW50LmpzIl0sIm5hbWVzIjpbIk1lbnVFdmVudCIsInR5cGUiLCJjYW5jZWxCdWJibGUiLCJkZWZhdWx0UHJldmVudGVkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0lBRXFCQSxTO0FBS25CLHFCQUFZQyxJQUFaLEVBQTBCO0FBQUE7QUFBQSxTQUgxQkMsWUFHMEIsR0FIRixLQUdFO0FBQUEsU0FGMUJDLGdCQUUwQixHQUZFLEtBRUY7O0FBQ3hCLFNBQUtGLElBQUwsR0FBWUEsSUFBWjtBQUNEOzs7O3NDQUVpQjtBQUNoQixXQUFLQyxZQUFMLEdBQW9CLElBQXBCO0FBQ0Q7OztxQ0FFZ0I7QUFDZixXQUFLQyxnQkFBTCxHQUF3QixJQUF4QjtBQUNEOzs7OztrQkFma0JILFMiLCJmaWxlIjoiTWVudUV2ZW50LmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgTWVudUV2ZW50IHtcbiAgdHlwZTogc3RyaW5nO1xuICBjYW5jZWxCdWJibGU6IGJvb2xlYW4gPSBmYWxzZTtcbiAgZGVmYXVsdFByZXZlbnRlZDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKHR5cGU6IHN0cmluZykge1xuICAgIHRoaXMudHlwZSA9IHR5cGU7XG4gIH1cblxuICBzdG9wUHJvcGFnYXRpb24oKSB7XG4gICAgdGhpcy5jYW5jZWxCdWJibGUgPSB0cnVlO1xuICB9XG5cbiAgcHJldmVudERlZmF1bHQoKSB7XG4gICAgdGhpcy5kZWZhdWx0UHJldmVudGVkID0gdHJ1ZTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ldmVudHMvTWVudUV2ZW50LmpzIl0sIm5hbWVzIjpbIk1lbnVFdmVudCIsInR5cGUiLCJjYW5jZWxCdWJibGUiLCJkZWZhdWx0UHJldmVudGVkIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7SUFFcUJBLFM7OztBQUtuQixxQkFBWUMsSUFBWixFQUEwQjtBQUFBO0FBQUE7QUFBQSx3REFIRixLQUdFO0FBQUEsNERBRkUsS0FFRjtBQUN4QixTQUFLQSxJQUFMLEdBQVlBLElBQVo7QUFDRDs7OztzQ0FFaUI7QUFDaEIsV0FBS0MsWUFBTCxHQUFvQixJQUFwQjtBQUNEOzs7cUNBRWdCO0FBQ2YsV0FBS0MsZ0JBQUwsR0FBd0IsSUFBeEI7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBmbG93ICovXG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1lbnVFdmVudCB7XG4gIHR5cGU6IHN0cmluZztcbiAgY2FuY2VsQnViYmxlOiBib29sZWFuID0gZmFsc2U7XG4gIGRlZmF1bHRQcmV2ZW50ZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICBjb25zdHJ1Y3Rvcih0eXBlOiBzdHJpbmcpIHtcbiAgICB0aGlzLnR5cGUgPSB0eXBlO1xuICB9XG5cbiAgc3RvcFByb3BhZ2F0aW9uKCkge1xuICAgIHRoaXMuY2FuY2VsQnViYmxlID0gdHJ1ZTtcbiAgfVxuXG4gIHByZXZlbnREZWZhdWx0KCkge1xuICAgIHRoaXMuZGVmYXVsdFByZXZlbnRlZCA9IHRydWU7XG4gIH1cbn1cbiJdfQ== |
@@ -1,62 +0,56 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
var _MenuList = require('./MenuList'); | ||
Object.defineProperty(exports, 'MenuList', { | ||
Object.defineProperty(exports, "MenuList", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_MenuList).default; | ||
return _MenuList.default; | ||
} | ||
}); | ||
var _MenuItem = require('./MenuItem'); | ||
Object.defineProperty(exports, 'MenuItem', { | ||
Object.defineProperty(exports, "MenuItem", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_MenuItem).default; | ||
return _MenuItem.default; | ||
} | ||
}); | ||
var _MenuListInspector = require('./MenuListInspector'); | ||
Object.defineProperty(exports, 'MenuListInspector', { | ||
Object.defineProperty(exports, "MenuListInspector", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_MenuListInspector).default; | ||
return _MenuListInspector.default; | ||
} | ||
}); | ||
var _Dropdown = require('./Dropdown'); | ||
Object.defineProperty(exports, 'Dropdown', { | ||
Object.defineProperty(exports, "Dropdown", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_Dropdown).default; | ||
return _Dropdown.default; | ||
} | ||
}); | ||
var _MenuButton = require('./MenuButton'); | ||
Object.defineProperty(exports, 'MenuButton', { | ||
Object.defineProperty(exports, "MenuButton", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_MenuButton).default; | ||
return _MenuButton.default; | ||
} | ||
}); | ||
var _SubMenuItem = require('./SubMenuItem'); | ||
Object.defineProperty(exports, 'SubMenuItem', { | ||
Object.defineProperty(exports, "SubMenuItem", { | ||
enumerable: true, | ||
get: function get() { | ||
return _interopRequireDefault(_SubMenuItem).default; | ||
return _SubMenuItem.default; | ||
} | ||
}); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6WyJkZWZhdWx0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs2Q0FFUUEsTzs7Ozs7Ozs7OzZDQUNBQSxPOzs7Ozs7Ozs7c0RBQ0FBLE87Ozs7Ozs7Ozs2Q0FDQUEsTzs7Ozs7Ozs7OytDQUNBQSxPOzs7Ozs7Ozs7Z0RBQ0FBLE8iLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5leHBvcnQge2RlZmF1bHQgYXMgTWVudUxpc3R9IGZyb20gJy4vTWVudUxpc3QnO1xuZXhwb3J0IHtkZWZhdWx0IGFzIE1lbnVJdGVtfSBmcm9tICcuL01lbnVJdGVtJztcbmV4cG9ydCB7ZGVmYXVsdCBhcyBNZW51TGlzdEluc3BlY3Rvcn0gZnJvbSAnLi9NZW51TGlzdEluc3BlY3Rvcic7XG5leHBvcnQge2RlZmF1bHQgYXMgRHJvcGRvd259IGZyb20gJy4vRHJvcGRvd24nO1xuZXhwb3J0IHtkZWZhdWx0IGFzIE1lbnVCdXR0b259IGZyb20gJy4vTWVudUJ1dHRvbic7XG5leHBvcnQge2RlZmF1bHQgYXMgU3ViTWVudUl0ZW19IGZyb20gJy4vU3ViTWVudUl0ZW0nO1xuIl19 | ||
var _MenuList = _interopRequireDefault(require("./MenuList")); | ||
var _MenuItem = _interopRequireDefault(require("./MenuItem")); | ||
var _MenuListInspector = _interopRequireDefault(require("./MenuListInspector")); | ||
var _Dropdown = _interopRequireDefault(require("./Dropdown")); | ||
var _MenuButton = _interopRequireDefault(require("./MenuButton")); | ||
var _SubMenuItem = _interopRequireDefault(require("./SubMenuItem")); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC5qcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBIiwic291cmNlc0NvbnRlbnQiOlsiLyogQGZsb3cgKi9cblxuZXhwb3J0IHtkZWZhdWx0IGFzIE1lbnVMaXN0fSBmcm9tICcuL01lbnVMaXN0JztcbmV4cG9ydCB7ZGVmYXVsdCBhcyBNZW51SXRlbX0gZnJvbSAnLi9NZW51SXRlbSc7XG5leHBvcnQge2RlZmF1bHQgYXMgTWVudUxpc3RJbnNwZWN0b3J9IGZyb20gJy4vTWVudUxpc3RJbnNwZWN0b3InO1xuZXhwb3J0IHtkZWZhdWx0IGFzIERyb3Bkb3dufSBmcm9tICcuL0Ryb3Bkb3duJztcbmV4cG9ydCB7ZGVmYXVsdCBhcyBNZW51QnV0dG9ufSBmcm9tICcuL01lbnVCdXR0b24nO1xuZXhwb3J0IHtkZWZhdWx0IGFzIFN1Yk1lbnVJdGVtfSBmcm9tICcuL1N1Yk1lbnVJdGVtJztcbmV4cG9ydCB0eXBlIHtGbG9hdEFuY2hvck9wdGlvbnN9IGZyb20gJy4vU3ViTWVudUl0ZW0nO1xuIl19 |
@@ -1,3 +0,5 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
@@ -8,10 +10,6 @@ value: true | ||
var _kefir = require('kefir'); | ||
var _kefir = _interopRequireDefault(require("kefir")); | ||
var _kefir2 = _interopRequireDefault(_kefir); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
function fromEventsCapture(target, eventName) { | ||
return _kefir2.default.stream(function (emitter) { | ||
return _kefir.default.stream(function (emitter) { | ||
target.addEventListener(eventName, emitter.emit, true); | ||
@@ -23,4 +21,2 @@ return function () { | ||
} | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvZnJvbUV2ZW50c0NhcHR1cmUuanMiXSwibmFtZXMiOlsiZnJvbUV2ZW50c0NhcHR1cmUiLCJ0YXJnZXQiLCJldmVudE5hbWUiLCJLZWZpciIsInN0cmVhbSIsImFkZEV2ZW50TGlzdGVuZXIiLCJlbWl0dGVyIiwiZW1pdCIsInJlbW92ZUV2ZW50TGlzdGVuZXIiXSwibWFwcGluZ3MiOiI7Ozs7O2tCQUl3QkEsaUI7O0FBRnhCOzs7Ozs7QUFFZSxTQUFTQSxpQkFBVCxDQUEyQkMsTUFBM0IsRUFBZ0RDLFNBQWhELEVBQTZGO0FBQzFHLFNBQU9DLGdCQUFNQyxNQUFOLENBQWEsbUJBQVc7QUFDN0JILFdBQU9JLGdCQUFQLENBQXdCSCxTQUF4QixFQUFtQ0ksUUFBUUMsSUFBM0MsRUFBaUQsSUFBakQ7QUFDQSxXQUFPLFlBQU07QUFDWE4sYUFBT08sbUJBQVAsQ0FBMkJOLFNBQTNCLEVBQXNDSSxRQUFRQyxJQUE5QyxFQUFvRCxJQUFwRDtBQUNELEtBRkQ7QUFHRCxHQUxNLENBQVA7QUFNRCIsImZpbGUiOiJmcm9tRXZlbnRzQ2FwdHVyZS5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBmbG93ICovXG5cbmltcG9ydCBLZWZpciBmcm9tICdrZWZpcic7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIGZyb21FdmVudHNDYXB0dXJlKHRhcmdldDogRXZlbnRUYXJnZXQsIGV2ZW50TmFtZTogc3RyaW5nKTogS2VmaXIuT2JzZXJ2YWJsZTxPYmplY3Q+IHtcbiAgcmV0dXJuIEtlZmlyLnN0cmVhbShlbWl0dGVyID0+IHtcbiAgICB0YXJnZXQuYWRkRXZlbnRMaXN0ZW5lcihldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgdHJ1ZSk7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIHRhcmdldC5yZW1vdmVFdmVudExpc3RlbmVyKGV2ZW50TmFtZSwgZW1pdHRlci5lbWl0LCB0cnVlKTtcbiAgICB9O1xuICB9KTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvZnJvbUV2ZW50c0NhcHR1cmUuanMiXSwibmFtZXMiOlsiZnJvbUV2ZW50c0NhcHR1cmUiLCJ0YXJnZXQiLCJldmVudE5hbWUiLCJLZWZpciIsInN0cmVhbSIsImVtaXR0ZXIiLCJhZGRFdmVudExpc3RlbmVyIiwiZW1pdCIsInJlbW92ZUV2ZW50TGlzdGVuZXIiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7OztBQUVBOztBQUVlLFNBQVNBLGlCQUFULENBQTJCQyxNQUEzQixFQUFnREMsU0FBaEQsRUFBNkY7QUFDMUcsU0FBT0MsZUFBTUMsTUFBTixDQUFhLFVBQUFDLE9BQU8sRUFBSTtBQUM3QkosSUFBQUEsTUFBTSxDQUFDSyxnQkFBUCxDQUF3QkosU0FBeEIsRUFBbUNHLE9BQU8sQ0FBQ0UsSUFBM0MsRUFBaUQsSUFBakQ7QUFDQSxXQUFPLFlBQU07QUFDWE4sTUFBQUEsTUFBTSxDQUFDTyxtQkFBUCxDQUEyQk4sU0FBM0IsRUFBc0NHLE9BQU8sQ0FBQ0UsSUFBOUMsRUFBb0QsSUFBcEQ7QUFDRCxLQUZEO0FBR0QsR0FMTSxDQUFQO0FBTUQiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgS2VmaXIgZnJvbSAna2VmaXInO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBmcm9tRXZlbnRzQ2FwdHVyZSh0YXJnZXQ6IEV2ZW50VGFyZ2V0LCBldmVudE5hbWU6IHN0cmluZyk6IEtlZmlyLk9ic2VydmFibGU8T2JqZWN0PiB7XG4gIHJldHVybiBLZWZpci5zdHJlYW0oZW1pdHRlciA9PiB7XG4gICAgdGFyZ2V0LmFkZEV2ZW50TGlzdGVuZXIoZXZlbnROYW1lLCBlbWl0dGVyLmVtaXQsIHRydWUpO1xuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICB0YXJnZXQucmVtb3ZlRXZlbnRMaXN0ZW5lcihldmVudE5hbWUsIGVtaXR0ZXIuZW1pdCwgdHJ1ZSk7XG4gICAgfTtcbiAgfSk7XG59XG4iXX0= |
@@ -7,2 +7,3 @@ "use strict"; | ||
exports.default = pointRectDistance; | ||
function pointRectDistance(px, py, rx, ry, rwidth, rheight) { | ||
@@ -13,3 +14,2 @@ var cx = Math.max(Math.min(px, rx + rwidth), rx); | ||
} | ||
module.exports = exports["default"]; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcG9pbnRSZWN0RGlzdGFuY2UuanMiXSwibmFtZXMiOlsicG9pbnRSZWN0RGlzdGFuY2UiLCJweCIsInB5IiwicngiLCJyeSIsInJ3aWR0aCIsInJoZWlnaHQiLCJjeCIsIk1hdGgiLCJtYXgiLCJtaW4iLCJjeSIsInNxcnQiXSwibWFwcGluZ3MiOiI7Ozs7O2tCQUV3QkEsaUI7QUFBVCxTQUFTQSxpQkFBVCxDQUNiQyxFQURhLEVBQ0RDLEVBREMsRUFDV0MsRUFEWCxFQUN1QkMsRUFEdkIsRUFDbUNDLE1BRG5DLEVBQ21EQyxPQURuRCxFQUVMO0FBQ1IsTUFBTUMsS0FBS0MsS0FBS0MsR0FBTCxDQUFTRCxLQUFLRSxHQUFMLENBQVNULEVBQVQsRUFBYUUsS0FBR0UsTUFBaEIsQ0FBVCxFQUFrQ0YsRUFBbEMsQ0FBWDtBQUNBLE1BQU1RLEtBQUtILEtBQUtDLEdBQUwsQ0FBU0QsS0FBS0UsR0FBTCxDQUFTUixFQUFULEVBQWFFLEtBQUdFLE9BQWhCLENBQVQsRUFBbUNGLEVBQW5DLENBQVg7QUFDQSxTQUFPSSxLQUFLSSxJQUFMLENBQVUsQ0FBQ1gsS0FBR00sRUFBSixLQUFTTixLQUFHTSxFQUFaLElBQWtCLENBQUNMLEtBQUdTLEVBQUosS0FBU1QsS0FBR1MsRUFBWixDQUE1QixDQUFQO0FBQ0QiLCJmaWxlIjoicG9pbnRSZWN0RGlzdGFuY2UuanMiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBwb2ludFJlY3REaXN0YW5jZShcbiAgcHg6IG51bWJlciwgcHk6IG51bWJlciwgcng6IG51bWJlciwgcnk6IG51bWJlciwgcndpZHRoOiBudW1iZXIsIHJoZWlnaHQ6IG51bWJlclxuKTogbnVtYmVyIHtcbiAgY29uc3QgY3ggPSBNYXRoLm1heChNYXRoLm1pbihweCwgcngrcndpZHRoKSwgcngpO1xuICBjb25zdCBjeSA9IE1hdGgubWF4KE1hdGgubWluKHB5LCByeStyaGVpZ2h0KSwgcnkpO1xuICByZXR1cm4gTWF0aC5zcXJ0KChweC1jeCkqKHB4LWN4KSArIChweS1jeSkqKHB5LWN5KSk7XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcG9pbnRSZWN0RGlzdGFuY2UuanMiXSwibmFtZXMiOlsicG9pbnRSZWN0RGlzdGFuY2UiLCJweCIsInB5IiwicngiLCJyeSIsInJ3aWR0aCIsInJoZWlnaHQiLCJjeCIsIk1hdGgiLCJtYXgiLCJtaW4iLCJjeSIsInNxcnQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFFZSxTQUFTQSxpQkFBVCxDQUNiQyxFQURhLEVBQ0RDLEVBREMsRUFDV0MsRUFEWCxFQUN1QkMsRUFEdkIsRUFDbUNDLE1BRG5DLEVBQ21EQyxPQURuRCxFQUVMO0FBQ1IsTUFBTUMsRUFBRSxHQUFHQyxJQUFJLENBQUNDLEdBQUwsQ0FBU0QsSUFBSSxDQUFDRSxHQUFMLENBQVNULEVBQVQsRUFBYUUsRUFBRSxHQUFDRSxNQUFoQixDQUFULEVBQWtDRixFQUFsQyxDQUFYO0FBQ0EsTUFBTVEsRUFBRSxHQUFHSCxJQUFJLENBQUNDLEdBQUwsQ0FBU0QsSUFBSSxDQUFDRSxHQUFMLENBQVNSLEVBQVQsRUFBYUUsRUFBRSxHQUFDRSxPQUFoQixDQUFULEVBQW1DRixFQUFuQyxDQUFYO0FBQ0EsU0FBT0ksSUFBSSxDQUFDSSxJQUFMLENBQVUsQ0FBQ1gsRUFBRSxHQUFDTSxFQUFKLEtBQVNOLEVBQUUsR0FBQ00sRUFBWixJQUFrQixDQUFDTCxFQUFFLEdBQUNTLEVBQUosS0FBU1QsRUFBRSxHQUFDUyxFQUFaLENBQTVCLENBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBmbG93ICovXG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIHBvaW50UmVjdERpc3RhbmNlKFxuICBweDogbnVtYmVyLCBweTogbnVtYmVyLCByeDogbnVtYmVyLCByeTogbnVtYmVyLCByd2lkdGg6IG51bWJlciwgcmhlaWdodDogbnVtYmVyXG4pOiBudW1iZXIge1xuICBjb25zdCBjeCA9IE1hdGgubWF4KE1hdGgubWluKHB4LCByeCtyd2lkdGgpLCByeCk7XG4gIGNvbnN0IGN5ID0gTWF0aC5tYXgoTWF0aC5taW4ocHksIHJ5K3JoZWlnaHQpLCByeSk7XG4gIHJldHVybiBNYXRoLnNxcnQoKHB4LWN4KSoocHgtY3gpICsgKHB5LWN5KSoocHktY3kpKTtcbn1cbiJdfQ== |
@@ -1,104 +0,83 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); | ||
var _getIterator2 = require('babel-runtime/core-js/get-iterator'); | ||
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread")); | ||
var _getIterator3 = _interopRequireDefault(_getIterator2); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _reactFloatAnchor = _interopRequireDefault(require("react-float-anchor")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _kefir = _interopRequireDefault(require("kefir")); | ||
var _react = require('react'); | ||
var _kefirBus = _interopRequireDefault(require("kefir-bus")); | ||
var _react2 = _interopRequireDefault(_react); | ||
var _fromEventsCapture = _interopRequireDefault(require("./lib/fromEventsCapture")); | ||
var _reactDom = require('react-dom'); | ||
var _setRef = _interopRequireDefault(require("./lib/setRef")); | ||
var _propTypes = require('prop-types'); | ||
var _MenuListInspector = _interopRequireDefault(require("./MenuListInspector")); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
var MenuButton = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(MenuButton, _React$Component); | ||
var _reactFloatAnchor = require('react-float-anchor'); | ||
var _reactFloatAnchor2 = _interopRequireDefault(_reactFloatAnchor); | ||
var _kefir = require('kefir'); | ||
var _kefir2 = _interopRequireDefault(_kefir); | ||
var _kefirBus = require('kefir-bus'); | ||
var _kefirBus2 = _interopRequireDefault(_kefirBus); | ||
var _fromEventsCapture = require('./lib/fromEventsCapture'); | ||
var _fromEventsCapture2 = _interopRequireDefault(_fromEventsCapture); | ||
var _MenuListInspector = require('./MenuListInspector'); | ||
var _MenuListInspector2 = _interopRequireDefault(_MenuListInspector); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
/* eslint-disable react/no-find-dom-node */ | ||
var MenuButton = function (_React$Component) { | ||
(0, _inherits3.default)(MenuButton, _React$Component); | ||
function MenuButton() { | ||
var _ref; | ||
var _getPrototypeOf2; | ||
var _temp, _this, _ret; | ||
var _this; | ||
(0, _classCallCheck3.default)(this, MenuButton); | ||
(0, _classCallCheck2.default)(this, MenuButton); | ||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | ||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = MenuButton.__proto__ || (0, _getPrototypeOf2.default)(MenuButton)).call.apply(_ref, [this].concat(args))), _this), _this.state = { | ||
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(MenuButton)).call.apply(_getPrototypeOf2, [this].concat(args))); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "state", { | ||
opened: false | ||
}, _this._onClose = (0, _kefirBus2.default)(), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); | ||
}); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_floatAnchorRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_anchorEl", null); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_onClose", (0, _kefirBus.default)()); | ||
return _this; | ||
} | ||
(0, _createClass3.default)(MenuButton, [{ | ||
key: 'open', | ||
value: function open(callback) { | ||
(0, _createClass2.default)(MenuButton, [{ | ||
key: "open", | ||
value: function open() { | ||
var _this2 = this; | ||
if (this.state.opened) return; | ||
if (this.props.onWillOpen) this.props.onWillOpen(); | ||
this.setState({ opened: true }, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
if (callback) callback(); | ||
}); | ||
if (this.state.opened) return Promise.resolve(); | ||
if (this.props.onWillOpen) this.props.onWillOpen(); // Clicking outside of the dropdown or pressing escape should close the | ||
// dropdown. | ||
// Clicking outside of the dropdown or pressing escape should close the | ||
// dropdown. | ||
_kefir2.default.merge([_kefir2.default.merge([(0, _fromEventsCapture2.default)(window, 'click'), (0, _fromEventsCapture2.default)(window, 'focus')]).filter(function (e) { | ||
var el = (0, _reactDom.findDOMNode)(_this2); | ||
_kefir.default.merge([_kefir.default.merge([(0, _fromEventsCapture.default)(window, 'click'), (0, _fromEventsCapture.default)(window, 'focus')]).filter(function (e) { | ||
var el = _this2._anchorEl; | ||
var _iteratorNormalCompletion = true; | ||
@@ -109,5 +88,4 @@ var _didIteratorError = false; | ||
try { | ||
for (var _iterator = (0, _getIterator3.default)(_reactFloatAnchor2.default.parentNodes(e.target)), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { | ||
for (var _iterator = _reactFloatAnchor.default.parentNodes(e.target)[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) { | ||
var node = _step.value; | ||
if (node === el) return false; | ||
@@ -120,3 +98,3 @@ } | ||
try { | ||
if (!_iteratorNormalCompletion && _iterator.return) { | ||
if (!_iteratorNormalCompletion && _iterator.return != null) { | ||
_iterator.return(); | ||
@@ -132,3 +110,3 @@ } | ||
return true; | ||
}), _kefir2.default.fromEvents(window, 'keydown').filter(function (e) { | ||
}), _kefir.default.fromEvents(window, 'keydown').filter(function (e) { | ||
return e.key ? e.key === 'Escape' : e.which === 27; | ||
@@ -141,13 +119,25 @@ }).map(function (e) { | ||
}); | ||
return new Promise(function (resolve) { | ||
_this2.setState({ | ||
opened: true | ||
}, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
resolve(); | ||
}); | ||
}); | ||
} | ||
}, { | ||
key: 'close', | ||
key: "close", | ||
value: function close() { | ||
if (!this.state.opened) return; | ||
if (this.props.onWillClose) this.props.onWillClose(); | ||
this.setState({ opened: false }); | ||
this.setState({ | ||
opened: false | ||
}); | ||
this._onClose.emit(); | ||
} | ||
}, { | ||
key: 'toggle', | ||
key: "toggle", | ||
value: function toggle() { | ||
@@ -161,8 +151,10 @@ if (this.state.opened) { | ||
}, { | ||
key: 'reposition', | ||
key: "reposition", | ||
value: function reposition() { | ||
this._floatAnchor.reposition(); | ||
var floatAnchor = this._floatAnchorRef.current; | ||
if (!floatAnchor) throw new Error(); | ||
floatAnchor.reposition(); | ||
} | ||
}, { | ||
key: '_itemChosen', | ||
key: "_itemChosen", | ||
value: function _itemChosen() { | ||
@@ -172,3 +164,3 @@ this.close(); | ||
}, { | ||
key: 'componentWillUnmount', | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
@@ -178,38 +170,39 @@ this._onClose.emit(); | ||
}, { | ||
key: 'render', | ||
key: "render", | ||
value: function render() { | ||
var _this3 = this; | ||
var _props = this.props, | ||
children = _props.children, | ||
menu = _props.menu, | ||
positionOptions = _props.positionOptions, | ||
menuZIndex = _props.menuZIndex, | ||
disabled = _props.disabled, | ||
title = _props.title, | ||
ButtonComponent = _props.ButtonComponent; | ||
var _this$props = this.props, | ||
children = _this$props.children, | ||
menu = _this$props.menu, | ||
positionOptions = _this$props.positionOptions, | ||
menuZIndex = _this$props.menuZIndex, | ||
disabled = _this$props.disabled, | ||
title = _this$props.title, | ||
ButtonComponent = _this$props.ButtonComponent; | ||
var opened = this.state.opened; | ||
var style = this.props.style; | ||
var className = this.props.className; | ||
if (opened) { | ||
if (this.props.openedStyle) { | ||
style = (0, _extends3.default)({}, style, this.props.openedStyle); | ||
style = (0, _objectSpread2.default)({}, style, this.props.openedStyle); | ||
} | ||
if (this.props.openedClassName) { | ||
className = (className || '') + ' ' + this.props.openedClassName; | ||
className = "".concat(className || '', " ").concat(this.props.openedClassName); | ||
} | ||
} | ||
return _react2.default.createElement(_reactFloatAnchor2.default, { | ||
ref: function ref(el) { | ||
if (el) _this3._floatAnchor = el; | ||
}, | ||
return _react.default.createElement(_reactFloatAnchor.default, { | ||
ref: this._floatAnchorRef, | ||
options: positionOptions, | ||
zIndex: menuZIndex, | ||
anchor: _react2.default.createElement( | ||
ButtonComponent, | ||
{ | ||
type: 'button', | ||
anchor: function anchor(anchorRef) { | ||
return _react.default.createElement(ButtonComponent, { | ||
domRef: function domRef(el) { | ||
_this3._anchorEl = el; | ||
(0, _setRef.default)(anchorRef, el); | ||
}, | ||
type: "button", | ||
className: className, | ||
@@ -219,2 +212,3 @@ style: style, | ||
if (e.button !== 0) return; | ||
_this3.toggle(); | ||
@@ -227,16 +221,13 @@ }, | ||
}, | ||
'aria-haspopup': true, | ||
'aria-expanded': opened, | ||
"aria-haspopup": true, | ||
"aria-expanded": opened, | ||
disabled: disabled, | ||
title: title | ||
}, | ||
children | ||
), | ||
float: !opened ? null : _react2.default.createElement( | ||
_MenuListInspector2.default, | ||
{ onItemChosen: function onItemChosen() { | ||
return _this3._itemChosen(); | ||
} }, | ||
menu | ||
) | ||
}, children); | ||
}, | ||
float: !opened ? null : _react.default.createElement(_MenuListInspector.default, { | ||
onItemChosen: function onItemChosen() { | ||
return _this3._itemChosen(); | ||
} | ||
}, menu) | ||
}); | ||
@@ -246,28 +237,34 @@ } | ||
return MenuButton; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
MenuButton.propTypes = { | ||
className: _propTypes2.default.string, | ||
style: _propTypes2.default.object, | ||
disabled: _propTypes2.default.bool, | ||
title: _propTypes2.default.string, | ||
openedClassName: _propTypes2.default.string, | ||
openedStyle: _propTypes2.default.object, | ||
positionOptions: _propTypes2.default.object, | ||
menuZIndex: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.number]), | ||
ButtonComponent: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]), | ||
children: _propTypes2.default.node, | ||
menu: _propTypes2.default.element, | ||
onWillOpen: _propTypes2.default.func, | ||
onDidOpen: _propTypes2.default.func, | ||
onWillClose: _propTypes2.default.func | ||
}; | ||
MenuButton.defaultProps = { | ||
positionOptions: { position: 'bottom', hAlign: 'left' }, | ||
ButtonComponent: 'button' | ||
}; | ||
exports.default = MenuButton; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuButton.js"],"names":["MenuButton","state","opened","_onClose","callback","props","onWillOpen","setState","onDidOpen","Kefir","merge","window","filter","el","FloatAnchor","parentNodes","e","target","node","fromEvents","key","which","map","preventDefault","stopPropagation","takeUntilBy","onValue","close","onWillClose","emit","open","_floatAnchor","reposition","children","menu","positionOptions","menuZIndex","disabled","title","ButtonComponent","style","className","openedStyle","openedClassName","button","toggle","_itemChosen","React","Component","propTypes","PropTypes","string","object","bool","oneOfType","number","func","element","defaultProps","position","hAlign"],"mappings":"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","file":"MenuButton.js","sourcesContent":["/* @flow */\n/* eslint-disable react/no-find-dom-node */\n\nimport React from 'react';\nimport type {Node as ReactNode, Element as ReactElement, ElementType as ReactElementType} from 'react';\nimport {findDOMNode} 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 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: ReactElementType;\n\n  children?: ReactNode;\n  menu?: ?ReactElement<any>;\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.oneOfType([PropTypes.string, PropTypes.func]),\n\n    children: PropTypes.node,\n    menu: PropTypes.element,\n    onWillOpen: PropTypes.func,\n    onDidOpen: PropTypes.func,\n    onWillClose: PropTypes.func\n  };\n\n  static defaultProps = {\n    positionOptions: {position:'bottom', hAlign:'left'},\n    ButtonComponent: 'button'\n  };\n\n  state: State = {\n    opened: false\n  };\n\n  _floatAnchor: FloatAnchor;\n  _onClose: Bus<void> = kefirBus();\n\n  open(callback?: () => any) {\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, () => {\n      if (this.props.onDidOpen) this.props.onDidOpen();\n      if (callback) callback();\n    });\n\n    // Clicking outside of the dropdown or pressing escape should close the\n    // dropdown.\n    Kefir.merge([\n      Kefir.merge([\n        fromEventsCapture(window, 'click'),\n        fromEventsCapture(window, 'focus')\n      ])\n        .filter(e => {\n          const el = findDOMNode(this);\n          for (let node of FloatAnchor.parentNodes(e.target)) {\n            if (node === el) return false;\n          }\n          return true;\n        }),\n      Kefir.fromEvents(window, 'keydown')\n        .filter(e => e.key ? e.key === 'Escape' : e.which === 27)\n        .map(e => {\n          e.preventDefault();\n          e.stopPropagation();\n        })\n    ])\n      .takeUntilBy(this._onClose)\n      .onValue(() => {\n        this.close();\n      });\n  }\n\n  close() {\n    if (!this.state.opened) return;\n    if (this.props.onWillClose) this.props.onWillClose();\n    this.setState({opened: false});\n    this._onClose.emit();\n  }\n\n  toggle() {\n    if (this.state.opened) {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  reposition() {\n    this._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={el => {\n          if (el) this._floatAnchor = el;\n        }}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={\n          <ButtonComponent\n            type=\"button\"\n            className={className}\n            style={style}\n            onMouseDown={e => {\n              if (e.button !== 0) return;\n              this.toggle();\n            }}\n            onKeyPress={e=>{\n              if (e.key === 'Enter' || e.key === ' ') {\n                this.toggle();\n              }\n            }}\n            aria-haspopup={true}\n            aria-expanded={opened}\n            disabled={disabled}\n            title={title}\n          >\n            {children}\n          </ButtonComponent>\n        }\n        float={\n          !opened ? null :\n            <MenuListInspector onItemChosen={() => this._itemChosen()}>\n              {menu}\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} | ||
(0, _defineProperty2.default)(MenuButton, "propTypes", { | ||
className: _propTypes.default.string, | ||
style: _propTypes.default.object, | ||
disabled: _propTypes.default.bool, | ||
title: _propTypes.default.string, | ||
openedClassName: _propTypes.default.string, | ||
openedStyle: _propTypes.default.object, | ||
positionOptions: _propTypes.default.object, | ||
menuZIndex: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.number]), | ||
ButtonComponent: _propTypes.default.func, | ||
children: _propTypes.default.node, | ||
menu: _propTypes.default.element, | ||
onWillOpen: _propTypes.default.func, | ||
onDidOpen: _propTypes.default.func, | ||
onWillClose: _propTypes.default.func | ||
}); | ||
(0, _defineProperty2.default)(MenuButton, "defaultProps", { | ||
positionOptions: { | ||
position: 'bottom', | ||
hAlign: 'left' | ||
}, | ||
ButtonComponent: function ButtonComponent(_ref) { | ||
var domRef = _ref.domRef, | ||
props = (0, _objectWithoutProperties2.default)(_ref, ["domRef"]); | ||
return _react.default.createElement("button", (0, _extends2.default)({ | ||
ref: domRef | ||
}, props)); | ||
} | ||
}); | ||
//# 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 {Node as ReactNode, ElementType as ReactElementType} 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: ReactElementType;\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<Class<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, 'click'),\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"]} |
@@ -1,68 +0,70 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread")); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _ChosenEvent = _interopRequireDefault(require("./events/ChosenEvent")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _MenuList = require("./MenuList"); | ||
var _react = require('react'); | ||
var _setRef = _interopRequireDefault(require("./lib/setRef")); | ||
var _react2 = _interopRequireDefault(_react); | ||
var MenuItem = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(MenuItem, _React$Component); | ||
var _propTypes = require('prop-types'); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
var _ChosenEvent = require('./events/ChosenEvent'); | ||
var _ChosenEvent2 = _interopRequireDefault(_ChosenEvent); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var MenuItem = function (_React$Component) { | ||
(0, _inherits3.default)(MenuItem, _React$Component); | ||
function MenuItem() { | ||
var _ref; | ||
var _getPrototypeOf2; | ||
var _temp, _this, _ret; | ||
var _this; | ||
(0, _classCallCheck3.default)(this, MenuItem); | ||
(0, _classCallCheck2.default)(this, MenuItem); | ||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | ||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = MenuItem.__proto__ || (0, _getPrototypeOf2.default)(MenuItem)).call.apply(_ref, [this].concat(args))), _this), _this.state = { | ||
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(MenuItem)).call.apply(_getPrototypeOf2, [this].concat(args))); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuListHandle", void 0); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "state", { | ||
highlighted: false | ||
}, _this._elSetter = function (el) { | ||
}); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_el", void 0); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_elSetter", function (el) { | ||
_this._el = el; | ||
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); | ||
if (_this.props.domRef) { | ||
(0, _setRef.default)(_this.props.domRef, el); | ||
} | ||
}); | ||
return _this; | ||
} | ||
(0, _createClass3.default)(MenuItem, [{ | ||
key: 'hasHighlight', | ||
(0, _createClass2.default)(MenuItem, [{ | ||
key: "hasHighlight", | ||
value: function hasHighlight() { | ||
@@ -72,3 +74,3 @@ return this.state.highlighted; | ||
}, { | ||
key: 'takeKeyboard', | ||
key: "takeKeyboard", | ||
value: function takeKeyboard() { | ||
@@ -78,3 +80,3 @@ this._menuListHandle.takeKeyboard(); | ||
}, { | ||
key: 'releaseKeyboard', | ||
key: "releaseKeyboard", | ||
value: function releaseKeyboard() { | ||
@@ -84,3 +86,3 @@ this._menuListHandle.releaseKeyboard(); | ||
}, { | ||
key: 'lockHighlight', | ||
key: "lockHighlight", | ||
value: function lockHighlight() { | ||
@@ -90,8 +92,6 @@ this._menuListHandle.lockHighlight(); | ||
}, { | ||
key: 'unlockHighlight', | ||
key: "unlockHighlight", | ||
value: function unlockHighlight() { | ||
this._menuListHandle.unlockHighlight(); | ||
} | ||
// byKeyboard forces focus immediately and scrolls the item into view. | ||
} // byKeyboard forces focus immediately and scrolls the item into view. | ||
// With it false, the highlight might be delayed depending on mouse movement | ||
@@ -101,3 +101,3 @@ // and won't cause anything to scroll. | ||
}, { | ||
key: 'highlight', | ||
key: "highlight", | ||
value: function highlight() { | ||
@@ -109,3 +109,3 @@ var byKeyboard = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; | ||
}, { | ||
key: 'unhighlight', | ||
key: "unhighlight", | ||
value: function unhighlight() { | ||
@@ -115,3 +115,3 @@ this._menuListHandle.unhighlight(); | ||
}, { | ||
key: 'moveCursor', | ||
key: "moveCursor", | ||
value: function moveCursor(direction, prevCursorLocation) { | ||
@@ -121,3 +121,3 @@ this._menuListHandle.moveCursor(direction, prevCursorLocation); | ||
}, { | ||
key: 'componentDidMount', | ||
key: "componentDidMount", | ||
value: function componentDidMount() { | ||
@@ -129,8 +129,11 @@ var _this2 = this; | ||
this._menuListHandle = this.context.menuList.registerItem(this.props, { | ||
this._menuListHandle = this.context.registerItem(this.props, { | ||
notifyHighlighted: function notifyHighlighted(highlighted, byKeyboard, direction, prevCursorLocation) { | ||
_this2.setState({ highlighted: highlighted }, function () { | ||
_this2.setState({ | ||
highlighted: highlighted | ||
}, function () { | ||
if (highlighted && byKeyboard) { | ||
var _el = _this2._el; | ||
/*:: if (!el) throw new Error(); */ | ||
if (typeof _el.scrollIntoViewIfNeeded === 'function') { | ||
@@ -143,4 +146,9 @@ _el.scrollIntoViewIfNeeded(); | ||
}); | ||
if (_this2.props.onHighlightChange) { | ||
_this2.props.onHighlightChange(highlighted, { byKeyboard: byKeyboard, prevCursorLocation: prevCursorLocation, direction: direction }); | ||
_this2.props.onHighlightChange(highlighted, { | ||
byKeyboard: byKeyboard == null ? undefined : byKeyboard, | ||
prevCursorLocation: prevCursorLocation == null ? undefined : prevCursorLocation, | ||
direction: direction == null ? undefined : direction | ||
}); | ||
} | ||
@@ -154,5 +162,7 @@ }, | ||
break; | ||
case 'left': | ||
if (_this2.props.onLeftPushed) _this2.props.onLeftPushed(event); | ||
break; | ||
case 'right': | ||
@@ -166,3 +176,3 @@ if (_this2.props.onRightPushed) _this2.props.onRightPushed(event); | ||
}, { | ||
key: 'componentWillUnmount', | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
@@ -172,78 +182,68 @@ this._menuListHandle.unregister(); | ||
}, { | ||
key: 'componentWillReceiveProps', | ||
value: function componentWillReceiveProps(newProps) { | ||
this._menuListHandle.updateProps(newProps); | ||
key: "componentDidUpdate", | ||
value: function componentDidUpdate() { | ||
this._menuListHandle.updateProps(this.props); | ||
} | ||
}, { | ||
key: 'render', | ||
key: "render", | ||
value: function render() { | ||
var _this3 = this; | ||
var _props = this.props, | ||
children = _props.children, | ||
onMouseLeave = _props.onMouseLeave; | ||
var _this$props = this.props, | ||
children = _this$props.children, | ||
onMouseLeave = _this$props.onMouseLeave; | ||
var highlighted = this.state.highlighted; | ||
var style = this.props.style; | ||
var className = this.props.className; | ||
if (highlighted) { | ||
if (this.props.highlightedStyle) { | ||
style = (0, _extends3.default)({}, style, this.props.highlightedStyle); | ||
style = (0, _objectSpread2.default)({}, style, this.props.highlightedStyle); | ||
} | ||
if (this.props.highlightedClassName) { | ||
className = (className || '') + ' ' + this.props.highlightedClassName; | ||
className = "".concat(className || '', " ").concat(this.props.highlightedClassName); | ||
} | ||
} | ||
return _react2.default.createElement( | ||
'div', | ||
{ | ||
ref: this._elSetter, | ||
style: style, | ||
className: className, | ||
onClick: function onClick() { | ||
return _this3._menuListHandle.itemChosen(); | ||
}, | ||
onMouseEnter: function onMouseEnter() { | ||
return _this3.highlight(false); | ||
}, | ||
onMouseLeave: onMouseLeave || function () { | ||
return _this3.unhighlight(); | ||
}, | ||
role: 'menuitem', | ||
'aria-haspopup': this.props['aria-haspopup'], | ||
'aria-expanded': this.props['aria-expanded'] | ||
return _react.default.createElement("div", { | ||
ref: this._elSetter, | ||
style: style, | ||
className: className, | ||
onClick: function onClick() { | ||
return _this3._menuListHandle.itemChosen(); | ||
}, | ||
children | ||
); | ||
onMouseEnter: function onMouseEnter() { | ||
return _this3.highlight(false); | ||
}, | ||
onMouseLeave: onMouseLeave || function () { | ||
return _this3.unhighlight(); | ||
}, | ||
role: "menuitem", | ||
"aria-haspopup": this.props['aria-haspopup'], | ||
"aria-expanded": this.props['aria-expanded'] | ||
}, children); | ||
} | ||
}]); | ||
return MenuItem; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
MenuItem.propTypes = { | ||
onItemChosen: _propTypes2.default.func, | ||
onHighlightChange: _propTypes2.default.func, | ||
onLeftPushed: _propTypes2.default.func, | ||
onRightPushed: _propTypes2.default.func, | ||
className: _propTypes2.default.string, | ||
style: _propTypes2.default.object, | ||
highlightedClassName: _propTypes2.default.string, | ||
highlightedStyle: _propTypes2.default.object, | ||
index: _propTypes2.default.number, | ||
onMouseLeave: _propTypes2.default.func, | ||
children: _propTypes2.default.node, | ||
'aria-haspopup': _propTypes2.default.bool, | ||
'aria-expanded': _propTypes2.default.bool | ||
}; | ||
MenuItem.contextTypes = { | ||
menuList: _propTypes2.default.object | ||
}; | ||
exports.default = MenuItem; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuItem.js"],"names":["MenuItem","state","highlighted","_elSetter","el","_el","_menuListHandle","takeKeyboard","releaseKeyboard","lockHighlight","unlockHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","context","menuList","registerItem","props","notifyHighlighted","setState","scrollIntoViewIfNeeded","scrollIntoView","onHighlightChange","notifyEvent","event","type","onItemChosen","onLeftPushed","onRightPushed","unregister","newProps","updateProps","children","onMouseLeave","style","className","highlightedStyle","highlightedClassName","itemChosen","React","Component","propTypes","PropTypes","func","string","object","index","number","node","bool","contextTypes"],"mappings":"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","file":"MenuItem.js","sourcesContent":["/* @flow */\n\nimport React from 'react';\nimport type {Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\n\nimport type MenuEvent from './events/MenuEvent';\nimport ChosenEvent from './events/ChosenEvent';\nimport type {MenuListContext, MenuListHandle} from './MenuList';\nimport type {Direction, Rect} from './types';\n\ntype State = {\n  highlighted: boolean;\n};\n\nexport type Props = {\n  onItemChosen?: ?(event: ChosenEvent) => void;\n  onLeftPushed?: ?(event: MenuEvent) => void;\n  onRightPushed?: ?(event: MenuEvent) => void;\n  onHighlightChange?: ?(highlighted: boolean, details: {byKeyboard: ?boolean, prevCursorLocation: ?Rect, direction: ?Direction}) => void;\n\n  className?: ?string;\n  style?: ?Object;\n  highlightedClassName?: ?string;\n  highlightedStyle?: ?Object;\n\n  index?: ?number;\n  onMouseLeave?: ?Function;\n\n  children?: ReactNode;\n\n  'aria-haspopup'?: ?boolean;\n  'aria-expanded'?: ?boolean;\n};\n\nexport default class MenuItem extends React.Component<Props, State> {\n  _menuListHandle: MenuListHandle;\n  state = {\n    highlighted: false\n  };\n  static propTypes = {\n    onItemChosen: PropTypes.func,\n    onHighlightChange: PropTypes.func,\n    onLeftPushed: PropTypes.func,\n    onRightPushed: PropTypes.func,\n\n    className: PropTypes.string,\n    style: PropTypes.object,\n    highlightedClassName: PropTypes.string,\n    highlightedStyle: PropTypes.object,\n\n    index: PropTypes.number,\n    onMouseLeave: PropTypes.func,\n\n    children: PropTypes.node,\n\n    'aria-haspopup': PropTypes.bool,\n    'aria-expanded': PropTypes.bool\n  };\n\n  static contextTypes = {\n    menuList: PropTypes.object\n  };\n\n  _el: ?HTMLElement;\n  _elSetter = (el: ?HTMLElement) => {\n    this._el = el;\n  };\n\n  hasHighlight(): boolean {\n    return this.state.highlighted;\n  }\n\n  takeKeyboard() {\n    this._menuListHandle.takeKeyboard();\n  }\n\n  releaseKeyboard() {\n    this._menuListHandle.releaseKeyboard();\n  }\n\n  lockHighlight() {\n    this._menuListHandle.lockHighlight();\n  }\n\n  unlockHighlight() {\n    this._menuListHandle.unlockHighlight();\n  }\n\n  // byKeyboard forces focus immediately and scrolls the item into view.\n  // With it false, the highlight might be delayed depending on mouse movement\n  // and won't cause anything to scroll.\n  highlight(byKeyboard: boolean=true) {\n    this._menuListHandle.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    this._menuListHandle.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    this._menuListHandle.moveCursor(direction, prevCursorLocation);\n  }\n\n  componentDidMount() {\n    const el = this._el;\n    /*:: if (!el) throw new Error(); */\n\n    this._menuListHandle = (this.context.menuList:MenuListContext).registerItem(this.props, {\n      notifyHighlighted: (highlighted: boolean, byKeyboard: ?boolean, direction: ?Direction, prevCursorLocation: ?Rect) => {\n        this.setState({highlighted}, () => {\n          if (highlighted && byKeyboard) {\n            const el = this._el;\n            /*:: if (!el) throw new Error(); */\n            if (typeof (el: any).scrollIntoViewIfNeeded === 'function') {\n              (el: any).scrollIntoViewIfNeeded();\n            } else if (el.scrollIntoView) {\n              el.scrollIntoView();\n            }\n          }\n        });\n        if (this.props.onHighlightChange) {\n          this.props.onHighlightChange(highlighted, {byKeyboard, prevCursorLocation, direction});\n        }\n      },\n      notifyEvent: (event: MenuEvent) => {\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 '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      }\n    }, el);\n  }\n\n  componentWillUnmount() {\n    this._menuListHandle.unregister();\n  }\n\n  componentWillReceiveProps(newProps: Props) {\n    this._menuListHandle.updateProps(newProps);\n  }\n\n  render() {\n    const {children, onMouseLeave} = this.props;\n    const {highlighted} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (highlighted) {\n      if (this.props.highlightedStyle) {\n        style = {...style, ...this.props.highlightedStyle};\n      }\n      if (this.props.highlightedClassName) {\n        className = `${className||''} ${this.props.highlightedClassName}`;\n      }\n    }\n\n    return (\n      <div\n        ref={this._elSetter}\n        style={style}\n        className={className}\n        onClick={()=>this._menuListHandle.itemChosen()}\n        onMouseEnter={() => this.highlight(false)}\n        onMouseLeave={onMouseLeave || (() => this.unhighlight())}\n        role=\"menuitem\"\n        aria-haspopup={this.props['aria-haspopup']}\n        aria-expanded={this.props['aria-expanded']}\n      >\n        {children}\n      </div>\n    );\n  }\n}\n"]} | ||
(0, _defineProperty2.default)(MenuItem, "propTypes", { | ||
onItemChosen: _propTypes.default.func, | ||
onHighlightChange: _propTypes.default.func, | ||
onLeftPushed: _propTypes.default.func, | ||
onRightPushed: _propTypes.default.func, | ||
className: _propTypes.default.string, | ||
style: _propTypes.default.object, | ||
highlightedClassName: _propTypes.default.string, | ||
highlightedStyle: _propTypes.default.object, | ||
index: _propTypes.default.number, | ||
onMouseLeave: _propTypes.default.func, | ||
children: _propTypes.default.node, | ||
domRef: _propTypes.default.oneOfType([_propTypes.default.object, _propTypes.default.func]), | ||
'aria-haspopup': _propTypes.default.bool, | ||
'aria-expanded': _propTypes.default.bool | ||
}); | ||
(0, _defineProperty2.default)(MenuItem, "contextType", _MenuList.MenuListContext); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuItem.js"],"names":["MenuItem","highlighted","el","_el","props","domRef","state","_menuListHandle","takeKeyboard","releaseKeyboard","lockHighlight","unlockHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","context","registerItem","notifyHighlighted","setState","scrollIntoViewIfNeeded","scrollIntoView","onHighlightChange","undefined","notifyEvent","event","type","onItemChosen","onLeftPushed","onRightPushed","unregister","updateProps","children","onMouseLeave","style","className","highlightedStyle","highlightedClassName","_elSetter","itemChosen","React","Component","PropTypes","func","string","object","index","number","node","oneOfType","bool","MenuListContext"],"mappings":"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","sourcesContent":["/* @flow */\n\nimport React from 'react';\nimport type {Ref as ReactRef, Node as ReactNode} from 'react';\nimport PropTypes from 'prop-types';\n\nimport type MenuEvent from './events/MenuEvent';\nimport ChosenEvent from './events/ChosenEvent';\nimport {MenuListContext} from './MenuList';\nimport type {MenuListContextValue, MenuListHandle} from './MenuList';\nimport setRef from './lib/setRef';\nimport type {Direction, Rect} from './types';\n\ntype State = {\n  highlighted: boolean;\n};\n\nexport type Props = {\n  onItemChosen?: (event: ChosenEvent) => void;\n  onLeftPushed?: (event: MenuEvent) => void;\n  onRightPushed?: (event: MenuEvent) => void;\n  onHighlightChange?: (highlighted: boolean, details: {byKeyboard?: boolean, prevCursorLocation?: Rect, direction?: Direction}) => void;\n\n  className?: string;\n  style?: Object;\n  highlightedClassName?: string;\n  highlightedStyle?: Object;\n\n  index?: number;\n  onMouseLeave?: (event: MouseEvent) => void;\n\n  children?: ReactNode;\n\n  domRef?: ReactRef<'div'>;\n\n  'aria-haspopup'?: boolean;\n  'aria-expanded'?: boolean;\n};\n\nexport default class MenuItem extends React.Component<Props, State> {\n  _menuListHandle: MenuListHandle;\n  state = {\n    highlighted: false\n  };\n  static propTypes = {\n    onItemChosen: PropTypes.func,\n    onHighlightChange: PropTypes.func,\n    onLeftPushed: PropTypes.func,\n    onRightPushed: PropTypes.func,\n\n    className: PropTypes.string,\n    style: PropTypes.object,\n    highlightedClassName: PropTypes.string,\n    highlightedStyle: PropTypes.object,\n\n    index: PropTypes.number,\n    onMouseLeave: PropTypes.func,\n\n    children: PropTypes.node,\n\n    domRef: PropTypes.oneOfType([\n      PropTypes.object,\n      PropTypes.func\n    ]),\n\n    'aria-haspopup': PropTypes.bool,\n    'aria-expanded': PropTypes.bool\n  };\n\n  static contextType = MenuListContext;\n\n  _el: ?HTMLDivElement;\n  _elSetter = (el: ?HTMLDivElement) => {\n    this._el = el;\n\n    if (this.props.domRef) {\n      setRef(this.props.domRef, el);\n    }\n  };\n\n  hasHighlight(): boolean {\n    return this.state.highlighted;\n  }\n\n  takeKeyboard() {\n    this._menuListHandle.takeKeyboard();\n  }\n\n  releaseKeyboard() {\n    this._menuListHandle.releaseKeyboard();\n  }\n\n  lockHighlight() {\n    this._menuListHandle.lockHighlight();\n  }\n\n  unlockHighlight() {\n    this._menuListHandle.unlockHighlight();\n  }\n\n  // byKeyboard forces focus immediately and scrolls the item into view.\n  // With it false, the highlight might be delayed depending on mouse movement\n  // and won't cause anything to scroll.\n  highlight(byKeyboard: boolean=true) {\n    this._menuListHandle.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    this._menuListHandle.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    this._menuListHandle.moveCursor(direction, prevCursorLocation);\n  }\n\n  componentDidMount() {\n    const el = this._el;\n    /*:: if (!el) throw new Error(); */\n\n    this._menuListHandle = (this.context: MenuListContextValue).registerItem(this.props, {\n      notifyHighlighted: (highlighted: boolean, byKeyboard: ?boolean, direction: ?Direction, prevCursorLocation: ?Rect) => {\n        this.setState({highlighted}, () => {\n          if (highlighted && byKeyboard) {\n            const el = this._el;\n            /*:: if (!el) throw new Error(); */\n            if (typeof (el: any).scrollIntoViewIfNeeded === 'function') {\n              (el: any).scrollIntoViewIfNeeded();\n            } else if (el.scrollIntoView) {\n              el.scrollIntoView();\n            }\n          }\n        });\n        if (this.props.onHighlightChange) {\n          this.props.onHighlightChange(highlighted, {\n            byKeyboard: byKeyboard == null ? undefined : byKeyboard,\n            prevCursorLocation: prevCursorLocation == null ? undefined : prevCursorLocation,\n            direction: direction == null ? undefined : direction\n          });\n        }\n      },\n      notifyEvent: (event: MenuEvent) => {\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 '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      }\n    }, el);\n  }\n\n  componentWillUnmount() {\n    this._menuListHandle.unregister();\n  }\n\n  componentDidUpdate() {\n    this._menuListHandle.updateProps(this.props);\n  }\n\n  render() {\n    const {children, onMouseLeave} = this.props;\n    const {highlighted} = this.state;\n\n    let style = this.props.style;\n    let className = this.props.className;\n    if (highlighted) {\n      if (this.props.highlightedStyle) {\n        style = {...style, ...this.props.highlightedStyle};\n      }\n      if (this.props.highlightedClassName) {\n        className = `${className||''} ${this.props.highlightedClassName}`;\n      }\n    }\n\n    return (\n      <div\n        ref={this._elSetter}\n        style={style}\n        className={className}\n        onClick={()=>this._menuListHandle.itemChosen()}\n        onMouseEnter={() => this.highlight(false)}\n        onMouseLeave={onMouseLeave || (() => this.unhighlight())}\n        role=\"menuitem\"\n        aria-haspopup={this.props['aria-haspopup']}\n        aria-expanded={this.props['aria-expanded']}\n      >\n        {children}\n      </div>\n    );\n  }\n}\n"]} |
@@ -1,235 +0,234 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = exports.MenuListContext = void 0; | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _kefir = _interopRequireDefault(require("kefir")); | ||
var _react = require('react'); | ||
var _kefirStopper = _interopRequireDefault(require("kefir-stopper")); | ||
var _react2 = _interopRequireDefault(_react); | ||
var _arrayFindIndex = _interopRequireDefault(require("array-find-index")); | ||
var _propTypes = require('prop-types'); | ||
var _fromEventsCapture = _interopRequireDefault(require("./lib/fromEventsCapture")); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
var _MenuEvent = _interopRequireDefault(require("./events/MenuEvent")); | ||
var _kefir = require('kefir'); | ||
var _ChosenEvent = _interopRequireDefault(require("./events/ChosenEvent")); | ||
var _kefir2 = _interopRequireDefault(_kefir); | ||
var _MenuListInspector = require("./MenuListInspector"); | ||
var _kefirStopper = require('kefir-stopper'); | ||
var MenuListContext = _react.default.createContext(null); | ||
var _kefirStopper2 = _interopRequireDefault(_kefirStopper); | ||
exports.MenuListContext = MenuListContext; | ||
var _arrayFindIndex = require('array-find-index'); | ||
var MenuList = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(MenuList, _React$Component); | ||
var _arrayFindIndex2 = _interopRequireDefault(_arrayFindIndex); | ||
function MenuList() { | ||
var _getPrototypeOf2; | ||
var _fromEventsCapture = require('./lib/fromEventsCapture'); | ||
var _this; | ||
var _fromEventsCapture2 = _interopRequireDefault(_fromEventsCapture); | ||
(0, _classCallCheck2.default)(this, MenuList); | ||
var _MenuEvent = require('./events/MenuEvent'); | ||
for (var _len = arguments.length, args = new Array(_len), _key2 = 0; _key2 < _len; _key2++) { | ||
args[_key2] = arguments[_key2]; | ||
} | ||
var _MenuEvent2 = _interopRequireDefault(_MenuEvent); | ||
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(MenuList)).call.apply(_getPrototypeOf2, [this].concat(args))); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_stopper", (0, _kefirStopper.default)()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_listItems", []); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_naturalHighlightedIndex", void 0); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_lockedHighlightedIndex", void 0); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_keyboardTakenByIndex", void 0); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_elRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuListContext", { | ||
registerItem: function registerItem(props, control, el) { | ||
var item = { | ||
props: props, | ||
control: control, | ||
el: el | ||
}; | ||
var _ChosenEvent = require('./events/ChosenEvent'); | ||
var register = function register() { | ||
var i = -1; | ||
var _ChosenEvent2 = _interopRequireDefault(_ChosenEvent); | ||
if (item.props.index == null) { | ||
i = (0, _arrayFindIndex.default)(_this._listItems, function (_item) { | ||
return (item.el.compareDocumentPosition(_item.el) & Node.DOCUMENT_POSITION_PRECEDING) === 0; | ||
}); | ||
} else { | ||
i = (0, _arrayFindIndex.default)(_this._listItems, function (_item) { | ||
return _item.props.index != null && item.props.index < _item.props.index; | ||
}); | ||
} | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
if (i < 0) { | ||
_this._listItems.push(item); | ||
} else { | ||
_this._listItems.splice(i, 0, item); | ||
// This type of object is given to a MenuItem to talk to the MenuList. | ||
if (_this._naturalHighlightedIndex != null && i <= _this._naturalHighlightedIndex) { | ||
_this._naturalHighlightedIndex++; | ||
} | ||
if (_this._lockedHighlightedIndex != null && i <= _this._lockedHighlightedIndex) { | ||
_this._lockedHighlightedIndex++; | ||
} | ||
// This type of object is given to a MenuList to talk to a MenuItem. | ||
if (_this._keyboardTakenByIndex != null && i <= _this._keyboardTakenByIndex) { | ||
_this._keyboardTakenByIndex++; | ||
} | ||
} | ||
}; | ||
register(); | ||
var menuListHandle = { | ||
highlight: function highlight(byKeyboard) { | ||
var i = _this._listItems.indexOf(item); | ||
// This is the type of the object that MenuList gives as context to its | ||
// descendants. | ||
var MenuList = function (_React$Component) { | ||
(0, _inherits3.default)(MenuList, _React$Component); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
function MenuList() { | ||
var _ref; | ||
_this._naturalHighlight(i, byKeyboard); | ||
}, | ||
unhighlight: function unhighlight() { | ||
var i = _this._listItems.indexOf(item); | ||
var _temp, _this, _ret; | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
(0, _classCallCheck3.default)(this, MenuList); | ||
if (_this._naturalHighlightedIndex === i) { | ||
_this._naturalHighlight(null, false); | ||
} | ||
}, | ||
itemChosen: function itemChosen() { | ||
_this._dispatchEvent(control, new _ChosenEvent.default('chosen', false)); | ||
}, | ||
takeKeyboard: function takeKeyboard() { | ||
var i = _this._listItems.indexOf(item); | ||
for (var _len = arguments.length, args = Array(_len), _key2 = 0; _key2 < _len; _key2++) { | ||
args[_key2] = arguments[_key2]; | ||
} | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
_this._keyboardTakenByIndex = i; | ||
}, | ||
releaseKeyboard: function releaseKeyboard() { | ||
var i = _this._listItems.indexOf(item); | ||
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = MenuList.__proto__ || (0, _getPrototypeOf2.default)(MenuList)).call.apply(_ref, [this].concat(args))), _this), _this._stopper = (0, _kefirStopper2.default)(), _this._listItems = [], _this._elSetter = function (el) { | ||
_this._el = el; | ||
}, _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); | ||
} | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
// The natural highlight is where the highlight would be if no lock is active. | ||
if (_this._keyboardTakenByIndex === i) { | ||
_this._keyboardTakenByIndex = null; | ||
} | ||
}, | ||
lockHighlight: function lockHighlight() { | ||
var i = _this._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
(0, _createClass3.default)(MenuList, [{ | ||
key: '_getVisibleHighlightedIndex', | ||
value: function _getVisibleHighlightedIndex() { | ||
return this._lockedHighlightedIndex != null ? this._lockedHighlightedIndex : this._naturalHighlightedIndex; | ||
} | ||
}, { | ||
key: 'getChildContext', | ||
value: function getChildContext() { | ||
var _this2 = this; | ||
_this._lockHighlight(i); | ||
}, | ||
unlockHighlight: function unlockHighlight() { | ||
var i = _this._listItems.indexOf(item); | ||
var menuList = { | ||
registerItem: function registerItem(props, control, el) { | ||
var item = { props: props, control: control, el: el }; | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
var register = function register() { | ||
var i = -1; | ||
if (item.props.index == null) { | ||
i = (0, _arrayFindIndex2.default)(_this2._listItems, function (_item) { | ||
return (item.el.compareDocumentPosition(_item.el) & Node.DOCUMENT_POSITION_PRECEDING) === 0; | ||
}); | ||
} else { | ||
i = (0, _arrayFindIndex2.default)(_this2._listItems, function (_item) { | ||
return _item.props.index != null && item.props.index < _item.props.index; | ||
}); | ||
if (_this._lockedHighlightedIndex === i) { | ||
_this._lockHighlight(null); | ||
} | ||
if (i < 0) { | ||
_this2._listItems.push(item); | ||
}, | ||
moveCursor: function moveCursor(direction, prevCursorLocation) { | ||
_this.moveCursor(direction, prevCursorLocation); | ||
}, | ||
updateProps: function updateProps(newProps) { | ||
if (item.props.index !== newProps.index) { | ||
var oldIndex = _this._listItems.indexOf(item); | ||
var isNaturalHighlightIndex = _this._naturalHighlightedIndex === oldIndex; | ||
var isLockedHighlightIndex = _this._lockedHighlightedIndex === oldIndex; | ||
var isKeyboardTakenByIndex = _this._keyboardTakenByIndex === oldIndex; | ||
menuListHandle.unregister(); | ||
props = newProps; | ||
item.props = newProps; | ||
register(); | ||
if (isNaturalHighlightIndex || isLockedHighlightIndex || isKeyboardTakenByIndex) { | ||
var newIndex = _this._listItems.indexOf(item); | ||
if (isNaturalHighlightIndex) _this._naturalHighlightedIndex = newIndex; | ||
if (isLockedHighlightIndex) _this._lockedHighlightedIndex = newIndex; | ||
if (isKeyboardTakenByIndex) _this._keyboardTakenByIndex = newIndex; | ||
} | ||
} else { | ||
_this2._listItems.splice(i, 0, item); | ||
if (_this2._naturalHighlightedIndex != null && i <= _this2._naturalHighlightedIndex) { | ||
_this2._naturalHighlightedIndex++; | ||
} | ||
if (_this2._lockedHighlightedIndex != null && i <= _this2._lockedHighlightedIndex) { | ||
_this2._lockedHighlightedIndex++; | ||
} | ||
if (_this2._keyboardTakenByIndex != null && i <= _this2._keyboardTakenByIndex) { | ||
_this2._keyboardTakenByIndex++; | ||
} | ||
props = newProps; | ||
item.props = newProps; | ||
} | ||
}; | ||
}, | ||
unregister: function unregister() { | ||
var i = _this._listItems.indexOf(item); | ||
register(); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
var menuListHandle = { | ||
highlight: function highlight(byKeyboard) { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
_this2._naturalHighlight(i, byKeyboard); | ||
}, | ||
unhighlight: function unhighlight() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
if (_this2._naturalHighlightedIndex === i) { | ||
_this2._naturalHighlight(null, false); | ||
} | ||
}, | ||
itemChosen: function itemChosen() { | ||
_this2._dispatchEvent(control, new _ChosenEvent2.default('chosen', false)); | ||
}, | ||
takeKeyboard: function takeKeyboard() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
_this2._keyboardTakenByIndex = i; | ||
}, | ||
releaseKeyboard: function releaseKeyboard() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
if (_this2._keyboardTakenByIndex === i) { | ||
_this2._keyboardTakenByIndex = null; | ||
} | ||
}, | ||
lockHighlight: function lockHighlight() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
_this2._lockHighlight(i); | ||
}, | ||
unlockHighlight: function unlockHighlight() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
if (_this2._lockedHighlightedIndex === i) { | ||
_this2._lockHighlight(null); | ||
} | ||
}, | ||
moveCursor: function moveCursor(direction, prevCursorLocation) { | ||
_this2.moveCursor(direction, prevCursorLocation); | ||
}, | ||
updateProps: function updateProps(newProps) { | ||
if (item.props.index !== newProps.index) { | ||
var oldIndex = _this2._listItems.indexOf(item); | ||
var isNaturalHighlightIndex = _this2._naturalHighlightedIndex === oldIndex; | ||
var isLockedHighlightIndex = _this2._lockedHighlightedIndex === oldIndex; | ||
var isKeyboardTakenByIndex = _this2._keyboardTakenByIndex === oldIndex; | ||
if (i === _this._naturalHighlightedIndex) { | ||
_this._naturalHighlightedIndex = null; | ||
} else if (_this._naturalHighlightedIndex != null && i < _this._naturalHighlightedIndex) { | ||
_this._naturalHighlightedIndex--; | ||
} | ||
menuListHandle.unregister(); | ||
props = newProps; | ||
item.props = newProps; | ||
register(); | ||
if (i === _this._lockedHighlightedIndex) { | ||
_this._lockedHighlightedIndex = null; | ||
} else if (_this._lockedHighlightedIndex != null && i < _this._lockedHighlightedIndex) { | ||
_this._lockedHighlightedIndex--; | ||
} | ||
if (isNaturalHighlightIndex || isLockedHighlightIndex || isKeyboardTakenByIndex) { | ||
var newIndex = _this2._listItems.indexOf(item); | ||
if (isNaturalHighlightIndex) _this2._naturalHighlightedIndex = newIndex; | ||
if (isLockedHighlightIndex) _this2._lockedHighlightedIndex = newIndex; | ||
if (isKeyboardTakenByIndex) _this2._keyboardTakenByIndex = newIndex; | ||
} | ||
} else { | ||
props = newProps; | ||
item.props = newProps; | ||
} | ||
}, | ||
unregister: function unregister() { | ||
var i = _this2._listItems.indexOf(item); | ||
if (i < 0) throw new Error('Already unregistered MenuItem'); | ||
if (i === _this2._naturalHighlightedIndex) { | ||
_this2._naturalHighlightedIndex = null; | ||
} else if (_this2._naturalHighlightedIndex != null && i < _this2._naturalHighlightedIndex) { | ||
_this2._naturalHighlightedIndex--; | ||
} | ||
if (i === _this2._lockedHighlightedIndex) { | ||
_this2._lockedHighlightedIndex = null; | ||
} else if (_this2._lockedHighlightedIndex != null && i < _this2._lockedHighlightedIndex) { | ||
_this2._lockedHighlightedIndex--; | ||
} | ||
if (i === _this2._keyboardTakenByIndex) { | ||
_this2._keyboardTakenByIndex = null; | ||
} else if (_this2._keyboardTakenByIndex != null && i < _this2._keyboardTakenByIndex) { | ||
_this2._keyboardTakenByIndex--; | ||
} | ||
_this2._listItems.splice(i, 1); | ||
if (i === _this._keyboardTakenByIndex) { | ||
_this._keyboardTakenByIndex = null; | ||
} else if (_this._keyboardTakenByIndex != null && i < _this._keyboardTakenByIndex) { | ||
_this._keyboardTakenByIndex--; | ||
} | ||
}; | ||
return menuListHandle; | ||
} | ||
}; | ||
return { menuList: menuList }; | ||
_this._listItems.splice(i, 1); | ||
} | ||
}; | ||
return menuListHandle; | ||
} | ||
}); | ||
return _this; | ||
} | ||
(0, _createClass2.default)(MenuList, [{ | ||
key: "_getVisibleHighlightedIndex", | ||
value: function _getVisibleHighlightedIndex() { | ||
return this._lockedHighlightedIndex != null ? this._lockedHighlightedIndex : this._naturalHighlightedIndex; | ||
} | ||
}, { | ||
key: '_parentCtx', | ||
key: "_parentCtx", | ||
value: function _parentCtx() { | ||
return this.context.menuListInspector; | ||
return this.context; | ||
} | ||
}, { | ||
key: 'componentDidMount', | ||
key: "componentDidMount", | ||
value: function componentDidMount() { | ||
var _this3 = this; | ||
var _this2 = this; | ||
@@ -239,17 +238,19 @@ var isEnterOrArrowKey = function isEnterOrArrowKey(e) { | ||
}; | ||
var el = this._el; | ||
var el = this._elRef.current; | ||
/*:: 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. | ||
_kefir2.default.merge([_kefir2.default.fromEvents(window, 'keydown').filter(isEnterOrArrowKey).filter(function (e) { | ||
_kefir.default.merge([_kefir.default.fromEvents(window, 'keydown').filter(isEnterOrArrowKey).filter(function (e) { | ||
return el.contains(e.target); | ||
}), (0, _fromEventsCapture2.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) { | ||
return _this3._key(event); | ||
return _this2._key(event); | ||
}); | ||
var parentCtx = this._parentCtx(); | ||
if (parentCtx) { | ||
@@ -260,3 +261,3 @@ parentCtx.registerMenuList(this); | ||
}, { | ||
key: 'componentWillUnmount', | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
@@ -266,2 +267,3 @@ this._stopper.destroy(); | ||
var parentCtx = this._parentCtx(); | ||
if (parentCtx) { | ||
@@ -272,3 +274,3 @@ parentCtx.unregisterMenuList(this); | ||
}, { | ||
key: '_naturalHighlight', | ||
key: "_naturalHighlight", | ||
value: function _naturalHighlight(index, byKeyboard, direction, prevCursorLocation) { | ||
@@ -280,3 +282,5 @@ var visibleHighlightedIndex = this._getVisibleHighlightedIndex(); | ||
} | ||
this._naturalHighlightedIndex = index; | ||
if (this._lockedHighlightedIndex == null) { | ||
@@ -286,2 +290,3 @@ if (index != null) { | ||
} | ||
if (visibleHighlightedIndex != null && visibleHighlightedIndex != index) { | ||
@@ -293,8 +298,12 @@ this._listItems[visibleHighlightedIndex].control.notifyHighlighted(false); | ||
}, { | ||
key: '_lockHighlight', | ||
key: "_lockHighlight", | ||
value: function _lockHighlight(index) { | ||
if (index === this._lockedHighlightedIndex) return; | ||
var visibleHighlightedIndex = this._getVisibleHighlightedIndex(); | ||
this._lockedHighlightedIndex = index; | ||
var newVisibleHighlightedIndex = this._getVisibleHighlightedIndex(); | ||
if (visibleHighlightedIndex != null && newVisibleHighlightedIndex == null) { | ||
@@ -308,2 +317,3 @@ // When unlocking, prefer to keep the current selection over de-selecting | ||
} | ||
if (newVisibleHighlightedIndex != null) { | ||
@@ -317,3 +327,3 @@ this._listItems[newVisibleHighlightedIndex].control.notifyHighlighted(true, false); | ||
}, { | ||
key: '_dispatchEvent', | ||
key: "_dispatchEvent", | ||
value: function _dispatchEvent(control, event) { | ||
@@ -324,2 +334,3 @@ if (control) { | ||
} | ||
switch (event.type) { | ||
@@ -334,5 +345,7 @@ case 'chosen': | ||
// break; | ||
case 'left': | ||
if (this.props.onLeftPushed) this.props.onLeftPushed(event); | ||
break; | ||
case 'right': | ||
@@ -342,4 +355,7 @@ if (this.props.onRightPushed) this.props.onRightPushed(event); | ||
} | ||
if (event.cancelBubble) return; | ||
var parentCtx = this._parentCtx(); | ||
if (parentCtx) { | ||
@@ -350,3 +366,3 @@ parentCtx.dispatchEvent(event); | ||
}, { | ||
key: '_key', | ||
key: "_key", | ||
value: function _key(event) { | ||
@@ -357,8 +373,7 @@ if (this._keyboardTakenByIndex != null || this._listItems.length === 0) { | ||
var visibleHighlightedIndex = this._getVisibleHighlightedIndex(); | ||
// enter, left, right activate for the current visibly selected item. | ||
var visibleHighlightedIndex = this._getVisibleHighlightedIndex(); // enter, left, right activate for the current visibly selected item. | ||
// up and down de-activate any locks in place, so that they act from the last | ||
// naturally-selected item. | ||
var mEvent = null; | ||
@@ -370,19 +385,25 @@ | ||
if (visibleHighlightedIndex != null) { | ||
mEvent = new _ChosenEvent2.default('chosen', true); | ||
mEvent = new _ChosenEvent.default('chosen', true); | ||
event.preventDefault(); | ||
event.stopPropagation(); | ||
} | ||
break; | ||
case 37: | ||
//left | ||
if (visibleHighlightedIndex != null) { | ||
mEvent = new _MenuEvent2.default('left'); | ||
mEvent = new _MenuEvent.default('left'); | ||
} | ||
break; | ||
case 39: | ||
//right | ||
if (visibleHighlightedIndex != null) { | ||
mEvent = new _MenuEvent2.default('right'); | ||
mEvent = new _MenuEvent.default('right'); | ||
} | ||
break; | ||
case 38: | ||
@@ -394,2 +415,3 @@ //up | ||
break; | ||
case 40: | ||
@@ -405,3 +427,5 @@ //down | ||
var _control = visibleHighlightedIndex == null ? null : this._listItems[visibleHighlightedIndex].control; | ||
this._dispatchEvent(_control, mEvent); | ||
if (mEvent.defaultPrevented) event.preventDefault(); | ||
@@ -412,3 +436,3 @@ if (mEvent.defaultPrevented || mEvent.cancelBubble) event.stopPropagation(); | ||
}, { | ||
key: 'moveCursor', | ||
key: "moveCursor", | ||
value: function moveCursor(direction, prevCursorLocation) { | ||
@@ -424,3 +448,5 @@ if (this._listItems.length == 0) return; | ||
} | ||
break; | ||
case 'down': | ||
@@ -432,2 +458,3 @@ if (this._naturalHighlightedIndex == null || this._naturalHighlightedIndex == this._listItems.length - 1) { | ||
} | ||
break; | ||
@@ -437,3 +464,3 @@ } | ||
}, { | ||
key: 'hasHighlight', | ||
key: "hasHighlight", | ||
value: function hasHighlight() { | ||
@@ -443,28 +470,23 @@ return this._getVisibleHighlightedIndex() != null; | ||
}, { | ||
key: 'render', | ||
key: "render", | ||
value: function render() { | ||
return _react2.default.createElement( | ||
'div', | ||
{ role: 'menu', ref: this._elSetter }, | ||
this.props.children | ||
); | ||
return _react.default.createElement("div", { | ||
role: "menu", | ||
ref: this._elRef | ||
}, _react.default.createElement(MenuListContext.Provider, { | ||
value: this._menuListContext | ||
}, this.props.children)); | ||
} | ||
}]); | ||
return MenuList; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
MenuList.propTypes = { | ||
onItemChosen: _propTypes2.default.func, | ||
onLeftPushed: _propTypes2.default.func, | ||
onRightPushed: _propTypes2.default.func, | ||
children: _propTypes2.default.node | ||
}; | ||
MenuList.childContextTypes = { | ||
menuList: _propTypes2.default.object | ||
}; | ||
MenuList.contextTypes = { | ||
menuListInspector: _propTypes2.default.object | ||
}; | ||
exports.default = MenuList; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/MenuList.js"],"names":["MenuList","_stopper","_listItems","_elSetter","el","_el","_lockedHighlightedIndex","_naturalHighlightedIndex","menuList","registerItem","props","control","item","register","i","index","compareDocumentPosition","_item","Node","DOCUMENT_POSITION_PRECEDING","push","splice","_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","menuListInspector","isEnterOrArrowKey","e","which","Kefir","merge","fromEvents","window","filter","contains","target","takeUntilBy","onValue","_key","event","parentCtx","_parentCtx","registerMenuList","destroy","unregisterMenuList","visibleHighlightedIndex","_getVisibleHighlightedIndex","notifyHighlighted","newVisibleHighlightedIndex","notifyEvent","cancelBubble","type","onItemChosen","onLeftPushed","onRightPushed","dispatchEvent","length","mEvent","preventDefault","stopPropagation","MenuEvent","defaultPrevented","children","React","Component","propTypes","PropTypes","func","node","childContextTypes","object","contextTypes"],"mappings":"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","file":"MenuList.js","sourcesContent":["/* @flow */\n\nimport React from 'react';\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 type {MenuListInspectorContext} 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 MenuListContext = {\n  registerItem(\n    props: MenuItemProps,\n    control: MenuItemControl,\n    el: HTMLElement\n  ): MenuListHandle;\n};\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  _el: ?HTMLElement;\n  _elSetter = (el: ?HTMLElement) => {\n    this._el = el;\n  };\n\n  _getVisibleHighlightedIndex(): ?number {\n    return this._lockedHighlightedIndex != null ?\n      this._lockedHighlightedIndex : this._naturalHighlightedIndex;\n  }\n\n  static childContextTypes = {\n    menuList: PropTypes.object\n  };\n\n  static contextTypes = {\n    menuListInspector: PropTypes.object\n  };\n\n  getChildContext(): Object {\n    const menuList: MenuListContext = {\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)&Node.DOCUMENT_POSITION_PRECEDING) === 0\n            );\n          } else {\n            i = findIndex(\n              this._listItems,\n              _item => _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 (this._naturalHighlightedIndex != null && i <= this._naturalHighlightedIndex) {\n              this._naturalHighlightedIndex++;\n            }\n            if (this._lockedHighlightedIndex != null && i <= this._lockedHighlightedIndex) {\n              this._lockedHighlightedIndex++;\n            }\n            if (this._keyboardTakenByIndex != null && i <= this._keyboardTakenByIndex) {\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 = this._naturalHighlightedIndex === oldIndex;\n              const isLockedHighlightIndex = this._lockedHighlightedIndex === oldIndex;\n              const isKeyboardTakenByIndex = this._keyboardTakenByIndex === oldIndex;\n\n              menuListHandle.unregister();\n              props = newProps;\n              item.props = newProps;\n              register();\n\n              if (isNaturalHighlightIndex || isLockedHighlightIndex || isKeyboardTakenByIndex) {\n                const newIndex = this._listItems.indexOf(item);\n                if (isNaturalHighlightIndex) this._naturalHighlightedIndex = newIndex;\n                if (isLockedHighlightIndex) 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 (this._naturalHighlightedIndex != null && i < this._naturalHighlightedIndex) {\n              this._naturalHighlightedIndex--;\n            }\n            if (i === this._lockedHighlightedIndex) {\n              this._lockedHighlightedIndex = null;\n            } else if (this._lockedHighlightedIndex != null && i < this._lockedHighlightedIndex) {\n              this._lockedHighlightedIndex--;\n            }\n            if (i === this._keyboardTakenByIndex) {\n              this._keyboardTakenByIndex = null;\n            } else if (this._keyboardTakenByIndex != null && i < this._keyboardTakenByIndex) {\n              this._keyboardTakenByIndex--;\n            }\n            this._listItems.splice(i, 1);\n          }\n        };\n        return menuListHandle;\n      }\n    };\n    return {menuList};\n  }\n\n  _parentCtx(): ?MenuListInspectorContext {\n    return this.context.menuListInspector;\n  }\n\n  componentDidMount() {\n    const isEnterOrArrowKey = e =>\n      (e.which === 13) || (37 <= e.which && e.which <= 40);\n    const el = this._el;\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').filter(isEnterOrArrowKey)\n        .filter(e => el.contains(e.target)),\n      fromEventsCapture(window, 'keydown').filter(isEnterOrArrowKey)\n        .filter(e => !el.contains(e.target))\n    ])\n      .takeUntilBy(this._stopper)\n      .onValue(event => this._key(event));\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(index: ?number, byKeyboard: boolean, direction: ?Direction, prevCursorLocation: ?Rect) {\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(true, byKeyboard, direction, prevCursorLocation);\n      }\n      if (visibleHighlightedIndex != null && visibleHighlightedIndex != index) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(false);\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(false);\n      }\n      if (newVisibleHighlightedIndex != null) {\n        this._listItems[newVisibleHighlightedIndex].control.notifyHighlighted(true, false);\n      } else if (this._naturalHighlightedIndex != null) {\n        this._listItems[this._naturalHighlightedIndex].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 = visibleHighlightedIndex == null ? null :\n        this._listItems[visibleHighlightedIndex].control;\n      this._dispatchEvent(control, mEvent);\n      if (mEvent.defaultPrevented) event.preventDefault();\n      if (mEvent.defaultPrevented || mEvent.cancelBubble) 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 (this._naturalHighlightedIndex == null || this._naturalHighlightedIndex == 0) {\n        this._naturalHighlight(this._listItems.length-1, true, direction, prevCursorLocation);\n      } else {\n        this._naturalHighlight(this._naturalHighlightedIndex-1, true, direction, prevCursorLocation);\n      }\n      break;\n    case 'down':\n      if (this._naturalHighlightedIndex == null || this._naturalHighlightedIndex == this._listItems.length-1) {\n        this._naturalHighlight(0, true, direction, prevCursorLocation);\n      } else {\n        this._naturalHighlight(this._naturalHighlightedIndex+1, true, direction, prevCursorLocation);\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._elSetter}>\n        {this.props.children}\n      </div>\n    );\n  }\n}\n"]} | ||
(0, _defineProperty2.default)(MenuList, "propTypes", { | ||
onItemChosen: _propTypes.default.func, | ||
onLeftPushed: _propTypes.default.func, | ||
onRightPushed: _propTypes.default.func, | ||
children: _propTypes.default.node | ||
}); | ||
(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","_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 React from 'react';\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<'div'>();\n\n  _getVisibleHighlightedIndex(): ?number {\n    return this._lockedHighlightedIndex != null ?\n      this._lockedHighlightedIndex : 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)&Node.DOCUMENT_POSITION_PRECEDING) === 0\n          );\n        } else {\n          i = findIndex(\n            this._listItems,\n            _item => _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 (this._naturalHighlightedIndex != null && i <= this._naturalHighlightedIndex) {\n            this._naturalHighlightedIndex++;\n          }\n          if (this._lockedHighlightedIndex != null && i <= this._lockedHighlightedIndex) {\n            this._lockedHighlightedIndex++;\n          }\n          if (this._keyboardTakenByIndex != null && i <= this._keyboardTakenByIndex) {\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 = this._naturalHighlightedIndex === oldIndex;\n            const isLockedHighlightIndex = this._lockedHighlightedIndex === oldIndex;\n            const isKeyboardTakenByIndex = this._keyboardTakenByIndex === oldIndex;\n\n            menuListHandle.unregister();\n            props = newProps;\n            item.props = newProps;\n            register();\n\n            if (isNaturalHighlightIndex || isLockedHighlightIndex || isKeyboardTakenByIndex) {\n              const newIndex = this._listItems.indexOf(item);\n              if (isNaturalHighlightIndex) this._naturalHighlightedIndex = newIndex;\n              if (isLockedHighlightIndex) 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 (this._naturalHighlightedIndex != null && i < this._naturalHighlightedIndex) {\n            this._naturalHighlightedIndex--;\n          }\n          if (i === this._lockedHighlightedIndex) {\n            this._lockedHighlightedIndex = null;\n          } else if (this._lockedHighlightedIndex != null && i < this._lockedHighlightedIndex) {\n            this._lockedHighlightedIndex--;\n          }\n          if (i === this._keyboardTakenByIndex) {\n            this._keyboardTakenByIndex = null;\n          } else if (this._keyboardTakenByIndex != null && i < this._keyboardTakenByIndex) {\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').filter(isEnterOrArrowKey)\n        .filter(e => el.contains(e.target)),\n      fromEventsCapture(window, 'keydown').filter(isEnterOrArrowKey)\n        .filter(e => !el.contains(e.target))\n    ])\n      .takeUntilBy(this._stopper)\n      .onValue(event => this._key(event));\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(index: ?number, byKeyboard: boolean, direction: ?Direction, prevCursorLocation: ?Rect) {\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(true, byKeyboard, direction, prevCursorLocation);\n      }\n      if (visibleHighlightedIndex != null && visibleHighlightedIndex != index) {\n        this._listItems[visibleHighlightedIndex].control.notifyHighlighted(false);\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(false);\n      }\n      if (newVisibleHighlightedIndex != null) {\n        this._listItems[newVisibleHighlightedIndex].control.notifyHighlighted(true, false);\n      } else if (this._naturalHighlightedIndex != null) {\n        this._listItems[this._naturalHighlightedIndex].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 = visibleHighlightedIndex == null ? null :\n        this._listItems[visibleHighlightedIndex].control;\n      this._dispatchEvent(control, mEvent);\n      if (mEvent.defaultPrevented) event.preventDefault();\n      if (mEvent.defaultPrevented || mEvent.cancelBubble) 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 (this._naturalHighlightedIndex == null || this._naturalHighlightedIndex == 0) {\n        this._naturalHighlight(this._listItems.length-1, true, direction, prevCursorLocation);\n      } else {\n        this._naturalHighlight(this._naturalHighlightedIndex-1, true, direction, prevCursorLocation);\n      }\n      break;\n    case 'down':\n      if (this._naturalHighlightedIndex == null || this._naturalHighlightedIndex == this._listItems.length-1) {\n        this._naturalHighlight(0, true, direction, prevCursorLocation);\n      } else {\n        this._naturalHighlight(this._naturalHighlightedIndex+1, true, direction, prevCursorLocation);\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"]} |
@@ -1,106 +0,105 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = exports.MenuListInspectorContext = void 0; | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _ChosenEvent = _interopRequireDefault(require("./events/ChosenEvent")); | ||
var _react = require('react'); | ||
var MenuListInspectorContext = _react.default.createContext(null); | ||
var _react2 = _interopRequireDefault(_react); | ||
exports.MenuListInspectorContext = MenuListInspectorContext; | ||
var _propTypes = require('prop-types'); | ||
var MenuListInspector = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(MenuListInspector, _React$Component); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
function MenuListInspector() { | ||
var _getPrototypeOf2; | ||
var _ChosenEvent = require('./events/ChosenEvent'); | ||
var _this; | ||
var _ChosenEvent2 = _interopRequireDefault(_ChosenEvent); | ||
(0, _classCallCheck2.default)(this, MenuListInspector); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
var MenuListInspector = function (_React$Component) { | ||
(0, _inherits3.default)(MenuListInspector, _React$Component); | ||
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(MenuListInspector)).call.apply(_getPrototypeOf2, [this].concat(args))); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_descendantMenuLists", []); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuListInspectorContext", { | ||
registerMenuList: function registerMenuList(menuList) { | ||
_this._descendantMenuLists.push(menuList); | ||
}, | ||
unregisterMenuList: function unregisterMenuList(menuList) { | ||
var i = _this._descendantMenuLists.indexOf(menuList); | ||
function MenuListInspector() { | ||
var _ref; | ||
if (i < 0) throw new Error('MenuList not registered'); | ||
var _temp, _this, _ret; | ||
_this._descendantMenuLists.splice(i, 1); | ||
}, | ||
dispatchEvent: function dispatchEvent(event) { | ||
switch (event.type) { | ||
case 'chosen': | ||
/*:: if (!(event instanceof ChosenEvent)) throw new Error(); */ | ||
if (_this.props.onItemChosen) _this.props.onItemChosen(event); | ||
break; | ||
(0, _classCallCheck3.default)(this, MenuListInspector); | ||
case 'left': | ||
if (_this.props.onLeftPushed) _this.props.onLeftPushed(event); | ||
break; | ||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
case 'right': | ||
if (_this.props.onRightPushed) _this.props.onRightPushed(event); | ||
break; | ||
} | ||
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = MenuListInspector.__proto__ || (0, _getPrototypeOf2.default)(MenuListInspector)).call.apply(_ref, [this].concat(args))), _this), _this._descendantMenuLists = [], _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); | ||
if (event.cancelBubble) return; | ||
var parentCtx = _this._parentCtx(); | ||
if (parentCtx) { | ||
parentCtx.dispatchEvent(event); | ||
} | ||
} | ||
}); | ||
return _this; | ||
} | ||
(0, _createClass3.default)(MenuListInspector, [{ | ||
key: '_parentCtx', | ||
(0, _createClass2.default)(MenuListInspector, [{ | ||
key: "_parentCtx", | ||
value: function _parentCtx() { | ||
return this.context.menuListInspector; | ||
return this.context; | ||
} | ||
}, { | ||
key: 'getChildContext', | ||
value: function getChildContext() { | ||
var _this2 = this; | ||
var menuListInspector = { | ||
registerMenuList: function registerMenuList(menuList) { | ||
_this2._descendantMenuLists.push(menuList); | ||
}, | ||
unregisterMenuList: function unregisterMenuList(menuList) { | ||
var i = _this2._descendantMenuLists.indexOf(menuList); | ||
if (i < 0) throw new Error('MenuList not registered'); | ||
_this2._descendantMenuLists.splice(i, 1); | ||
}, | ||
dispatchEvent: function dispatchEvent(event) { | ||
switch (event.type) { | ||
case 'chosen': | ||
/*:: if (!(event instanceof ChosenEvent)) throw new Error(); */ | ||
if (_this2.props.onItemChosen) _this2.props.onItemChosen(event); | ||
break; | ||
case 'left': | ||
if (_this2.props.onLeftPushed) _this2.props.onLeftPushed(event); | ||
break; | ||
case 'right': | ||
if (_this2.props.onRightPushed) _this2.props.onRightPushed(event); | ||
break; | ||
} | ||
if (event.cancelBubble) return; | ||
var parentCtx = _this2._parentCtx(); | ||
if (parentCtx) { | ||
parentCtx.dispatchEvent(event); | ||
} | ||
} | ||
}; | ||
return { menuListInspector: menuListInspector }; | ||
} | ||
}, { | ||
key: 'moveCursor', | ||
key: "moveCursor", | ||
value: function moveCursor(direction, prevCursorLocation) { | ||
var menuList = this._descendantMenuLists[0]; | ||
if (!menuList) { | ||
return false; | ||
} | ||
menuList.moveCursor(direction, prevCursorLocation); | ||
@@ -110,3 +109,3 @@ return true; | ||
}, { | ||
key: 'hasHighlight', | ||
key: "hasHighlight", | ||
value: function hasHighlight() { | ||
@@ -118,28 +117,24 @@ for (var i = 0, len = this._descendantMenuLists.length; i < len; i++) { | ||
} | ||
return false; | ||
} | ||
}, { | ||
key: 'render', | ||
key: "render", | ||
value: function render() { | ||
return this.props.children; | ||
return _react.default.createElement(MenuListInspectorContext.Provider, { | ||
value: this._menuListInspectorContext | ||
}, this.props.children); | ||
} | ||
}]); | ||
return MenuListInspector; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
MenuListInspector.propTypes = { | ||
onItemChosen: _propTypes2.default.func, | ||
onLeftPushed: _propTypes2.default.func, | ||
onRightPushed: _propTypes2.default.func, | ||
children: _propTypes2.default.element | ||
}; | ||
MenuListInspector.childContextTypes = { | ||
menuListInspector: _propTypes2.default.object | ||
}; | ||
MenuListInspector.contextTypes = { | ||
menuListInspector: _propTypes2.default.object | ||
}; | ||
exports.default = MenuListInspector; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9NZW51TGlzdEluc3BlY3Rvci5qcyJdLCJuYW1lcyI6WyJNZW51TGlzdEluc3BlY3RvciIsIl9kZXNjZW5kYW50TWVudUxpc3RzIiwiY29udGV4dCIsIm1lbnVMaXN0SW5zcGVjdG9yIiwicmVnaXN0ZXJNZW51TGlzdCIsIm1lbnVMaXN0IiwicHVzaCIsInVucmVnaXN0ZXJNZW51TGlzdCIsImkiLCJpbmRleE9mIiwiRXJyb3IiLCJzcGxpY2UiLCJkaXNwYXRjaEV2ZW50IiwiZXZlbnQiLCJ0eXBlIiwicHJvcHMiLCJvbkl0ZW1DaG9zZW4iLCJvbkxlZnRQdXNoZWQiLCJvblJpZ2h0UHVzaGVkIiwiY2FuY2VsQnViYmxlIiwicGFyZW50Q3R4IiwiX3BhcmVudEN0eCIsImRpcmVjdGlvbiIsInByZXZDdXJzb3JMb2NhdGlvbiIsIm1vdmVDdXJzb3IiLCJsZW4iLCJsZW5ndGgiLCJoYXNIaWdobGlnaHQiLCJjaGlsZHJlbiIsIlJlYWN0IiwiQ29tcG9uZW50IiwicHJvcFR5cGVzIiwiUHJvcFR5cGVzIiwiZnVuYyIsImVsZW1lbnQiLCJjaGlsZENvbnRleHRUeXBlcyIsIm9iamVjdCIsImNvbnRleHRUeXBlcyJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFQTs7OztBQUVBOzs7O0FBR0E7Ozs7OztJQWdCcUJBLGlCOzs7Ozs7Ozs7Ozs7OztrT0FpQm5CQyxvQixHQUF3QyxFOzs7OztpQ0FFQTtBQUN0QyxhQUFPLEtBQUtDLE9BQUwsQ0FBYUMsaUJBQXBCO0FBQ0Q7OztzQ0FFeUI7QUFBQTs7QUFDeEIsVUFBTUEsb0JBQThDO0FBQ2xEQywwQkFBa0IsMEJBQUNDLFFBQUQsRUFBd0I7QUFDeEMsaUJBQUtKLG9CQUFMLENBQTBCSyxJQUExQixDQUErQkQsUUFBL0I7QUFDRCxTQUhpRDtBQUlsREUsNEJBQW9CLDRCQUFDRixRQUFELEVBQXdCO0FBQzFDLGNBQU1HLElBQUksT0FBS1Asb0JBQUwsQ0FBMEJRLE9BQTFCLENBQWtDSixRQUFsQyxDQUFWO0FBQ0EsY0FBSUcsSUFBSSxDQUFSLEVBQVcsTUFBTSxJQUFJRSxLQUFKLENBQVUseUJBQVYsQ0FBTjtBQUNYLGlCQUFLVCxvQkFBTCxDQUEwQlUsTUFBMUIsQ0FBaUNILENBQWpDLEVBQW9DLENBQXBDO0FBQ0QsU0FSaUQ7QUFTbERJLHVCQUFlLHVCQUFDQyxLQUFELEVBQXNCO0FBQ25DLGtCQUFRQSxNQUFNQyxJQUFkO0FBQ0EsaUJBQUssUUFBTDtBQUNFO0FBQ0Esa0JBQUksT0FBS0MsS0FBTCxDQUFXQyxZQUFmLEVBQTZCLE9BQUtELEtBQUwsQ0FBV0MsWUFBWCxDQUF3QkgsS0FBeEI7QUFDN0I7QUFDRixpQkFBSyxNQUFMO0FBQ0Usa0JBQUksT0FBS0UsS0FBTCxDQUFXRSxZQUFmLEVBQTZCLE9BQUtGLEtBQUwsQ0FBV0UsWUFBWCxDQUF3QkosS0FBeEI7QUFDN0I7QUFDRixpQkFBSyxPQUFMO0FBQ0Usa0JBQUksT0FBS0UsS0FBTCxDQUFXRyxhQUFmLEVBQThCLE9BQUtILEtBQUwsQ0FBV0csYUFBWCxDQUF5QkwsS0FBekI7QUFDOUI7QUFWRjtBQVlBLGNBQUlBLE1BQU1NLFlBQVYsRUFBd0I7QUFDeEIsY0FBTUMsWUFBWSxPQUFLQyxVQUFMLEVBQWxCO0FBQ0EsY0FBSUQsU0FBSixFQUFlO0FBQ2JBLHNCQUFVUixhQUFWLENBQXdCQyxLQUF4QjtBQUNEO0FBQ0Y7QUEzQmlELE9BQXBEO0FBNkJBLGFBQU8sRUFBQ1Ysb0NBQUQsRUFBUDtBQUNEOzs7K0JBRVVtQixTLEVBQXNCQyxrQixFQUFvQztBQUNuRSxVQUFNbEIsV0FBVyxLQUFLSixvQkFBTCxDQUEwQixDQUExQixDQUFqQjtBQUNBLFVBQUksQ0FBQ0ksUUFBTCxFQUFlO0FBQ2IsZUFBTyxLQUFQO0FBQ0Q7QUFDREEsZUFBU21CLFVBQVQsQ0FBb0JGLFNBQXBCLEVBQStCQyxrQkFBL0I7QUFDQSxhQUFPLElBQVA7QUFDRDs7O21DQUV1QjtBQUN0QixXQUFLLElBQUlmLElBQUUsQ0FBTixFQUFTaUIsTUFBSSxLQUFLeEIsb0JBQUwsQ0FBMEJ5QixNQUE1QyxFQUFvRGxCLElBQUVpQixHQUF0RCxFQUEyRGpCLEdBQTNELEVBQWdFO0FBQzlELFlBQUksS0FBS1Asb0JBQUwsQ0FBMEJPLENBQTFCLEVBQTZCbUIsWUFBN0IsRUFBSixFQUFpRDtBQUMvQyxpQkFBTyxJQUFQO0FBQ0Q7QUFDRjtBQUNELGFBQU8sS0FBUDtBQUNEOzs7NkJBRVE7QUFDUCxhQUFPLEtBQUtaLEtBQUwsQ0FBV2EsUUFBbEI7QUFDRDs7O0VBNUU0Q0MsZ0JBQU1DLFM7O0FBQWhDOUIsaUIsQ0FDWitCLFMsR0FBWTtBQUNqQmYsZ0JBQWNnQixvQkFBVUMsSUFEUDtBQUVqQmhCLGdCQUFjZSxvQkFBVUMsSUFGUDtBQUdqQmYsaUJBQWVjLG9CQUFVQyxJQUhSOztBQUtqQkwsWUFBVUksb0JBQVVFO0FBTEgsQztBQURBbEMsaUIsQ0FTWm1DLGlCLEdBQW9CO0FBQ3pCaEMscUJBQW1CNkIsb0JBQVVJO0FBREosQztBQVRScEMsaUIsQ0FhWnFDLFksR0FBZTtBQUNwQmxDLHFCQUFtQjZCLG9CQUFVSTtBQURULEM7a0JBYkhwQyxpQiIsImZpbGUiOiJNZW51TGlzdEluc3BlY3Rvci5qcyIsInNvdXJjZXNDb250ZW50IjpbIi8qIEBmbG93ICovXG5cbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XG5pbXBvcnQgdHlwZSB7Tm9kZSBhcyBSZWFjdE5vZGV9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgdHlwZSBNZW51TGlzdCBmcm9tICcuL01lbnVMaXN0JztcbmltcG9ydCB0eXBlIE1lbnVFdmVudCBmcm9tICcuL2V2ZW50cy9NZW51RXZlbnQnO1xuaW1wb3J0IENob3NlbkV2ZW50IGZyb20gJy4vZXZlbnRzL0Nob3NlbkV2ZW50JztcbmltcG9ydCB0eXBlIHtEaXJlY3Rpb24sIFJlY3R9IGZyb20gJy4vdHlwZXMnO1xuXG5leHBvcnQgdHlwZSBNZW51TGlzdEluc3BlY3RvckNvbnRleHQgPSB7XG4gIHJlZ2lzdGVyTWVudUxpc3QobWVudUxpc3Q6IE1lbnVMaXN0KTogdm9pZDtcbiAgdW5yZWdpc3Rlck1lbnVMaXN0KG1lbnVMaXN0OiBNZW51TGlzdCk6IHZvaWQ7XG4gIGRpc3BhdGNoRXZlbnQoZXZlbnQ6IE1lbnVFdmVudCk6IHZvaWQ7XG59O1xuXG5leHBvcnQgdHlwZSBQcm9wcyA9IHtcbiAgb25JdGVtQ2hvc2VuPzogPyhldmVudDogQ2hvc2VuRXZlbnQpID0+IHZvaWQ7XG4gIG9uTGVmdFB1c2hlZD86ID8oZXZlbnQ6IE1lbnVFdmVudCkgPT4gdm9pZDtcbiAgb25SaWdodFB1c2hlZD86ID8oZXZlbnQ6IE1lbnVFdmVudCkgPT4gdm9pZDtcbiAgY2hpbGRyZW4/OiBSZWFjdE5vZGU7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBNZW51TGlzdEluc3BlY3RvciBleHRlbmRzIFJlYWN0LkNvbXBvbmVudDxQcm9wcz4ge1xuICBzdGF0aWMgcHJvcFR5cGVzID0ge1xuICAgIG9uSXRlbUNob3NlbjogUHJvcFR5cGVzLmZ1bmMsXG4gICAgb25MZWZ0UHVzaGVkOiBQcm9wVHlwZXMuZnVuYyxcbiAgICBvblJpZ2h0UHVzaGVkOiBQcm9wVHlwZXMuZnVuYyxcblxuICAgIGNoaWxkcmVuOiBQcm9wVHlwZXMuZWxlbWVudFxuICB9O1xuXG4gIHN0YXRpYyBjaGlsZENvbnRleHRUeXBlcyA9IHtcbiAgICBtZW51TGlzdEluc3BlY3RvcjogUHJvcFR5cGVzLm9iamVjdFxuICB9O1xuXG4gIHN0YXRpYyBjb250ZXh0VHlwZXMgPSB7XG4gICAgbWVudUxpc3RJbnNwZWN0b3I6IFByb3BUeXBlcy5vYmplY3RcbiAgfTtcblxuICBfZGVzY2VuZGFudE1lbnVMaXN0czogQXJyYXk8TWVudUxpc3Q+ID0gW107XG5cbiAgX3BhcmVudEN0eCgpOiA/TWVudUxpc3RJbnNwZWN0b3JDb250ZXh0IHtcbiAgICByZXR1cm4gdGhpcy5jb250ZXh0Lm1lbnVMaXN0SW5zcGVjdG9yO1xuICB9XG5cbiAgZ2V0Q2hpbGRDb250ZXh0KCk6IE9iamVjdCB7XG4gICAgY29uc3QgbWVudUxpc3RJbnNwZWN0b3I6IE1lbnVMaXN0SW5zcGVjdG9yQ29udGV4dCA9IHtcbiAgICAgIHJlZ2lzdGVyTWVudUxpc3Q6IChtZW51TGlzdDogTWVudUxpc3QpID0+IHtcbiAgICAgICAgdGhpcy5fZGVzY2VuZGFudE1lbnVMaXN0cy5wdXNoKG1lbnVMaXN0KTtcbiAgICAgIH0sXG4gICAgICB1bnJlZ2lzdGVyTWVudUxpc3Q6IChtZW51TGlzdDogTWVudUxpc3QpID0+IHtcbiAgICAgICAgY29uc3QgaSA9IHRoaXMuX2Rlc2NlbmRhbnRNZW51TGlzdHMuaW5kZXhPZihtZW51TGlzdCk7XG4gICAgICAgIGlmIChpIDwgMCkgdGhyb3cgbmV3IEVycm9yKCdNZW51TGlzdCBub3QgcmVnaXN0ZXJlZCcpO1xuICAgICAgICB0aGlzLl9kZXNjZW5kYW50TWVudUxpc3RzLnNwbGljZShpLCAxKTtcbiAgICAgIH0sXG4gICAgICBkaXNwYXRjaEV2ZW50OiAoZXZlbnQ6IE1lbnVFdmVudCkgPT4ge1xuICAgICAgICBzd2l0Y2ggKGV2ZW50LnR5cGUpIHtcbiAgICAgICAgY2FzZSAnY2hvc2VuJzpcbiAgICAgICAgICAvKjo6IGlmICghKGV2ZW50IGluc3RhbmNlb2YgQ2hvc2VuRXZlbnQpKSB0aHJvdyBuZXcgRXJyb3IoKTsgKi9cbiAgICAgICAgICBpZiAodGhpcy5wcm9wcy5vbkl0ZW1DaG9zZW4pIHRoaXMucHJvcHMub25JdGVtQ2hvc2VuKGV2ZW50KTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnbGVmdCc6XG4gICAgICAgICAgaWYgKHRoaXMucHJvcHMub25MZWZ0UHVzaGVkKSB0aGlzLnByb3BzLm9uTGVmdFB1c2hlZChldmVudCk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ3JpZ2h0JzpcbiAgICAgICAgICBpZiAodGhpcy5wcm9wcy5vblJpZ2h0UHVzaGVkKSB0aGlzLnByb3BzLm9uUmlnaHRQdXNoZWQoZXZlbnQpO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICAgIGlmIChldmVudC5jYW5jZWxCdWJibGUpIHJldHVybjtcbiAgICAgICAgY29uc3QgcGFyZW50Q3R4ID0gdGhpcy5fcGFyZW50Q3R4KCk7XG4gICAgICAgIGlmIChwYXJlbnRDdHgpIHtcbiAgICAgICAgICBwYXJlbnRDdHguZGlzcGF0Y2hFdmVudChldmVudCk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9O1xuICAgIHJldHVybiB7bWVudUxpc3RJbnNwZWN0b3J9O1xuICB9XG5cbiAgbW92ZUN1cnNvcihkaXJlY3Rpb246IERpcmVjdGlvbiwgcHJldkN1cnNvckxvY2F0aW9uOiA/UmVjdCk6IGJvb2xlYW4ge1xuICAgIGNvbnN0IG1lbnVMaXN0ID0gdGhpcy5fZGVzY2VuZGFudE1lbnVMaXN0c1swXTtcbiAgICBpZiAoIW1lbnVMaXN0KSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIG1lbnVMaXN0Lm1vdmVDdXJzb3IoZGlyZWN0aW9uLCBwcmV2Q3Vyc29yTG9jYXRpb24pO1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaGFzSGlnaGxpZ2h0KCk6IGJvb2xlYW4ge1xuICAgIGZvciAobGV0IGk9MCwgbGVuPXRoaXMuX2Rlc2NlbmRhbnRNZW51TGlzdHMubGVuZ3RoOyBpPGxlbjsgaSsrKSB7XG4gICAgICBpZiAodGhpcy5fZGVzY2VuZGFudE1lbnVMaXN0c1tpXS5oYXNIaWdobGlnaHQoKSkge1xuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIHJldHVybiB0aGlzLnByb3BzLmNoaWxkcmVuO1xuICB9XG59XG4iXX0= | ||
(0, _defineProperty2.default)(MenuListInspector, "propTypes", { | ||
onItemChosen: _propTypes.default.func, | ||
onLeftPushed: _propTypes.default.func, | ||
onRightPushed: _propTypes.default.func, | ||
children: _propTypes.default.element | ||
}); | ||
(0, _defineProperty2.default)(MenuListInspector, "contextType", MenuListInspectorContext); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9NZW51TGlzdEluc3BlY3Rvci5qcyJdLCJuYW1lcyI6WyJNZW51TGlzdEluc3BlY3RvckNvbnRleHQiLCJSZWFjdCIsImNyZWF0ZUNvbnRleHQiLCJNZW51TGlzdEluc3BlY3RvciIsInJlZ2lzdGVyTWVudUxpc3QiLCJtZW51TGlzdCIsIl9kZXNjZW5kYW50TWVudUxpc3RzIiwicHVzaCIsInVucmVnaXN0ZXJNZW51TGlzdCIsImkiLCJpbmRleE9mIiwiRXJyb3IiLCJzcGxpY2UiLCJkaXNwYXRjaEV2ZW50IiwiZXZlbnQiLCJ0eXBlIiwicHJvcHMiLCJvbkl0ZW1DaG9zZW4iLCJvbkxlZnRQdXNoZWQiLCJvblJpZ2h0UHVzaGVkIiwiY2FuY2VsQnViYmxlIiwicGFyZW50Q3R4IiwiX3BhcmVudEN0eCIsImNvbnRleHQiLCJkaXJlY3Rpb24iLCJwcmV2Q3Vyc29yTG9jYXRpb24iLCJtb3ZlQ3Vyc29yIiwibGVuIiwibGVuZ3RoIiwiaGFzSGlnaGxpZ2h0IiwiX21lbnVMaXN0SW5zcGVjdG9yQ29udGV4dCIsImNoaWxkcmVuIiwiQ29tcG9uZW50IiwiUHJvcFR5cGVzIiwiZnVuYyIsImVsZW1lbnQiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUE7O0FBRUE7O0FBR0E7O0FBU08sSUFBTUEsd0JBQXdCLEdBQUdDLGVBQU1DLGFBQU4sQ0FBb0QsSUFBcEQsQ0FBakM7Ozs7SUFTY0MsaUI7Ozs7Ozs7Ozs7Ozs7Ozs7OzZJQVdxQixFO2tKQU1tQjtBQUN6REMsTUFBQUEsZ0JBQWdCLEVBQUUsMEJBQUNDLFFBQUQsRUFBd0I7QUFDeEMsY0FBS0Msb0JBQUwsQ0FBMEJDLElBQTFCLENBQStCRixRQUEvQjtBQUNELE9BSHdEO0FBSXpERyxNQUFBQSxrQkFBa0IsRUFBRSw0QkFBQ0gsUUFBRCxFQUF3QjtBQUMxQyxZQUFNSSxDQUFDLEdBQUcsTUFBS0gsb0JBQUwsQ0FBMEJJLE9BQTFCLENBQWtDTCxRQUFsQyxDQUFWOztBQUNBLFlBQUlJLENBQUMsR0FBRyxDQUFSLEVBQVcsTUFBTSxJQUFJRSxLQUFKLENBQVUseUJBQVYsQ0FBTjs7QUFDWCxjQUFLTCxvQkFBTCxDQUEwQk0sTUFBMUIsQ0FBaUNILENBQWpDLEVBQW9DLENBQXBDO0FBQ0QsT0FSd0Q7QUFTekRJLE1BQUFBLGFBQWEsRUFBRSx1QkFBQ0MsS0FBRCxFQUFzQjtBQUNuQyxnQkFBUUEsS0FBSyxDQUFDQyxJQUFkO0FBQ0EsZUFBSyxRQUFMO0FBQ0U7QUFDQSxnQkFBSSxNQUFLQyxLQUFMLENBQVdDLFlBQWYsRUFBNkIsTUFBS0QsS0FBTCxDQUFXQyxZQUFYLENBQXdCSCxLQUF4QjtBQUM3Qjs7QUFDRixlQUFLLE1BQUw7QUFDRSxnQkFBSSxNQUFLRSxLQUFMLENBQVdFLFlBQWYsRUFBNkIsTUFBS0YsS0FBTCxDQUFXRSxZQUFYLENBQXdCSixLQUF4QjtBQUM3Qjs7QUFDRixlQUFLLE9BQUw7QUFDRSxnQkFBSSxNQUFLRSxLQUFMLENBQVdHLGFBQWYsRUFBOEIsTUFBS0gsS0FBTCxDQUFXRyxhQUFYLENBQXlCTCxLQUF6QjtBQUM5QjtBQVZGOztBQVlBLFlBQUlBLEtBQUssQ0FBQ00sWUFBVixFQUF3Qjs7QUFDeEIsWUFBTUMsU0FBUyxHQUFHLE1BQUtDLFVBQUwsRUFBbEI7O0FBQ0EsWUFBSUQsU0FBSixFQUFlO0FBQ2JBLFVBQUFBLFNBQVMsQ0FBQ1IsYUFBVixDQUF3QkMsS0FBeEI7QUFDRDtBQUNGO0FBM0J3RCxLOzs7Ozs7aUNBSmQ7QUFDM0MsYUFBTyxLQUFLUyxPQUFaO0FBQ0Q7OzsrQkFnQ1VDLFMsRUFBc0JDLGtCLEVBQW9DO0FBQ25FLFVBQU1wQixRQUFRLEdBQUcsS0FBS0Msb0JBQUwsQ0FBMEIsQ0FBMUIsQ0FBakI7O0FBQ0EsVUFBSSxDQUFDRCxRQUFMLEVBQWU7QUFDYixlQUFPLEtBQVA7QUFDRDs7QUFDREEsTUFBQUEsUUFBUSxDQUFDcUIsVUFBVCxDQUFvQkYsU0FBcEIsRUFBK0JDLGtCQUEvQjtBQUNBLGFBQU8sSUFBUDtBQUNEOzs7bUNBRXVCO0FBQ3RCLFdBQUssSUFBSWhCLENBQUMsR0FBQyxDQUFOLEVBQVNrQixHQUFHLEdBQUMsS0FBS3JCLG9CQUFMLENBQTBCc0IsTUFBNUMsRUFBb0RuQixDQUFDLEdBQUNrQixHQUF0RCxFQUEyRGxCLENBQUMsRUFBNUQsRUFBZ0U7QUFDOUQsWUFBSSxLQUFLSCxvQkFBTCxDQUEwQkcsQ0FBMUIsRUFBNkJvQixZQUE3QixFQUFKLEVBQWlEO0FBQy9DLGlCQUFPLElBQVA7QUFDRDtBQUNGOztBQUNELGFBQU8sS0FBUDtBQUNEOzs7NkJBRVE7QUFDUCxhQUNFLDZCQUFDLHdCQUFELENBQTBCLFFBQTFCO0FBQW1DLFFBQUEsS0FBSyxFQUFFLEtBQUtDO0FBQS9DLFNBQ0csS0FBS2QsS0FBTCxDQUFXZSxRQURkLENBREY7QUFLRDs7O0VBdkU0QzlCLGVBQU0rQixTOzs7OEJBQWhDN0IsaUIsZUFDQTtBQUNqQmMsRUFBQUEsWUFBWSxFQUFFZ0IsbUJBQVVDLElBRFA7QUFFakJoQixFQUFBQSxZQUFZLEVBQUVlLG1CQUFVQyxJQUZQO0FBR2pCZixFQUFBQSxhQUFhLEVBQUVjLG1CQUFVQyxJQUhSO0FBS2pCSCxFQUFBQSxRQUFRLEVBQUVFLG1CQUFVRTtBQUxILEM7OEJBREFoQyxpQixpQkFTRUgsd0IiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBAZmxvdyAqL1xuXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHR5cGUge05vZGUgYXMgUmVhY3ROb2RlfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHR5cGUgTWVudUxpc3QgZnJvbSAnLi9NZW51TGlzdCc7XG5pbXBvcnQgdHlwZSBNZW51RXZlbnQgZnJvbSAnLi9ldmVudHMvTWVudUV2ZW50JztcbmltcG9ydCBDaG9zZW5FdmVudCBmcm9tICcuL2V2ZW50cy9DaG9zZW5FdmVudCc7XG5pbXBvcnQgdHlwZSB7RGlyZWN0aW9uLCBSZWN0fSBmcm9tICcuL3R5cGVzJztcblxuZXhwb3J0IHR5cGUgTWVudUxpc3RJbnNwZWN0b3JDb250ZXh0VmFsdWUgPSB7XG4gIHJlZ2lzdGVyTWVudUxpc3QobWVudUxpc3Q6IE1lbnVMaXN0KTogdm9pZDtcbiAgdW5yZWdpc3Rlck1lbnVMaXN0KG1lbnVMaXN0OiBNZW51TGlzdCk6IHZvaWQ7XG4gIGRpc3BhdGNoRXZlbnQoZXZlbnQ6IE1lbnVFdmVudCk6IHZvaWQ7XG59O1xuXG5leHBvcnQgY29uc3QgTWVudUxpc3RJbnNwZWN0b3JDb250ZXh0ID0gUmVhY3QuY3JlYXRlQ29udGV4dDw/TWVudUxpc3RJbnNwZWN0b3JDb250ZXh0VmFsdWU+KG51bGwpO1xuXG5leHBvcnQgdHlwZSBQcm9wcyA9IHtcbiAgb25JdGVtQ2hvc2VuPzogKGV2ZW50OiBDaG9zZW5FdmVudCkgPT4gdm9pZDtcbiAgb25MZWZ0UHVzaGVkPzogKGV2ZW50OiBNZW51RXZlbnQpID0+IHZvaWQ7XG4gIG9uUmlnaHRQdXNoZWQ/OiAoZXZlbnQ6IE1lbnVFdmVudCkgPT4gdm9pZDtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IGNsYXNzIE1lbnVMaXN0SW5zcGVjdG9yIGV4dGVuZHMgUmVhY3QuQ29tcG9uZW50PFByb3BzPiB7XG4gIHN0YXRpYyBwcm9wVHlwZXMgPSB7XG4gICAgb25JdGVtQ2hvc2VuOiBQcm9wVHlwZXMuZnVuYyxcbiAgICBvbkxlZnRQdXNoZWQ6IFByb3BUeXBlcy5mdW5jLFxuICAgIG9uUmlnaHRQdXNoZWQ6IFByb3BUeXBlcy5mdW5jLFxuXG4gICAgY2hpbGRyZW46IFByb3BUeXBlcy5lbGVtZW50XG4gIH07XG5cbiAgc3RhdGljIGNvbnRleHRUeXBlID0gTWVudUxpc3RJbnNwZWN0b3JDb250ZXh0O1xuXG4gIF9kZXNjZW5kYW50TWVudUxpc3RzOiBBcnJheTxNZW51TGlzdD4gPSBbXTtcblxuICBfcGFyZW50Q3R4KCk6ID9NZW51TGlzdEluc3BlY3RvckNvbnRleHRWYWx1ZSB7XG4gICAgcmV0dXJuIHRoaXMuY29udGV4dDtcbiAgfVxuXG4gIF9tZW51TGlzdEluc3BlY3RvckNvbnRleHQ6IE1lbnVMaXN0SW5zcGVjdG9yQ29udGV4dFZhbHVlID0ge1xuICAgIHJlZ2lzdGVyTWVudUxpc3Q6IChtZW51TGlzdDogTWVudUxpc3QpID0+IHtcbiAgICAgIHRoaXMuX2Rlc2NlbmRhbnRNZW51TGlzdHMucHVzaChtZW51TGlzdCk7XG4gICAgfSxcbiAgICB1bnJlZ2lzdGVyTWVudUxpc3Q6IChtZW51TGlzdDogTWVudUxpc3QpID0+IHtcbiAgICAgIGNvbnN0IGkgPSB0aGlzLl9kZXNjZW5kYW50TWVudUxpc3RzLmluZGV4T2YobWVudUxpc3QpO1xuICAgICAgaWYgKGkgPCAwKSB0aHJvdyBuZXcgRXJyb3IoJ01lbnVMaXN0IG5vdCByZWdpc3RlcmVkJyk7XG4gICAgICB0aGlzLl9kZXNjZW5kYW50TWVudUxpc3RzLnNwbGljZShpLCAxKTtcbiAgICB9LFxuICAgIGRpc3BhdGNoRXZlbnQ6IChldmVudDogTWVudUV2ZW50KSA9PiB7XG4gICAgICBzd2l0Y2ggKGV2ZW50LnR5cGUpIHtcbiAgICAgIGNhc2UgJ2Nob3Nlbic6XG4gICAgICAgIC8qOjogaWYgKCEoZXZlbnQgaW5zdGFuY2VvZiBDaG9zZW5FdmVudCkpIHRocm93IG5ldyBFcnJvcigpOyAqL1xuICAgICAgICBpZiAodGhpcy5wcm9wcy5vbkl0ZW1DaG9zZW4pIHRoaXMucHJvcHMub25JdGVtQ2hvc2VuKGV2ZW50KTtcbiAgICAgICAgYnJlYWs7XG4gICAgICBjYXNlICdsZWZ0JzpcbiAgICAgICAgaWYgKHRoaXMucHJvcHMub25MZWZ0UHVzaGVkKSB0aGlzLnByb3BzLm9uTGVmdFB1c2hlZChldmVudCk7XG4gICAgICAgIGJyZWFrO1xuICAgICAgY2FzZSAncmlnaHQnOlxuICAgICAgICBpZiAodGhpcy5wcm9wcy5vblJpZ2h0UHVzaGVkKSB0aGlzLnByb3BzLm9uUmlnaHRQdXNoZWQoZXZlbnQpO1xuICAgICAgICBicmVhaztcbiAgICAgIH1cbiAgICAgIGlmIChldmVudC5jYW5jZWxCdWJibGUpIHJldHVybjtcbiAgICAgIGNvbnN0IHBhcmVudEN0eCA9IHRoaXMuX3BhcmVudEN0eCgpO1xuICAgICAgaWYgKHBhcmVudEN0eCkge1xuICAgICAgICBwYXJlbnRDdHguZGlzcGF0Y2hFdmVudChldmVudCk7XG4gICAgICB9XG4gICAgfVxuICB9O1xuXG4gIG1vdmVDdXJzb3IoZGlyZWN0aW9uOiBEaXJlY3Rpb24sIHByZXZDdXJzb3JMb2NhdGlvbjogP1JlY3QpOiBib29sZWFuIHtcbiAgICBjb25zdCBtZW51TGlzdCA9IHRoaXMuX2Rlc2NlbmRhbnRNZW51TGlzdHNbMF07XG4gICAgaWYgKCFtZW51TGlzdCkge1xuICAgICAgcmV0dXJuIGZhbHNlO1xuICAgIH1cbiAgICBtZW51TGlzdC5tb3ZlQ3Vyc29yKGRpcmVjdGlvbiwgcHJldkN1cnNvckxvY2F0aW9uKTtcbiAgICByZXR1cm4gdHJ1ZTtcbiAgfVxuXG4gIGhhc0hpZ2hsaWdodCgpOiBib29sZWFuIHtcbiAgICBmb3IgKGxldCBpPTAsIGxlbj10aGlzLl9kZXNjZW5kYW50TWVudUxpc3RzLmxlbmd0aDsgaTxsZW47IGkrKykge1xuICAgICAgaWYgKHRoaXMuX2Rlc2NlbmRhbnRNZW51TGlzdHNbaV0uaGFzSGlnaGxpZ2h0KCkpIHtcbiAgICAgICAgcmV0dXJuIHRydWU7XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICByZXR1cm4gKFxuICAgICAgPE1lbnVMaXN0SW5zcGVjdG9yQ29udGV4dC5Qcm92aWRlciB2YWx1ZT17dGhpcy5fbWVudUxpc3RJbnNwZWN0b3JDb250ZXh0fT5cbiAgICAgICAge3RoaXMucHJvcHMuY2hpbGRyZW59XG4gICAgICA8L01lbnVMaXN0SW5zcGVjdG9yQ29udGV4dC5Qcm92aWRlcj5cbiAgICApO1xuICB9XG59XG4iXX0= |
@@ -1,90 +0,75 @@ | ||
'use strict'; | ||
"use strict"; | ||
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); | ||
Object.defineProperty(exports, "__esModule", { | ||
value: true | ||
}); | ||
exports.default = void 0; | ||
var _extends2 = require('babel-runtime/helpers/extends'); | ||
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread")); | ||
var _extends3 = _interopRequireDefault(_extends2); | ||
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); | ||
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of'); | ||
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); | ||
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf); | ||
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); | ||
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); | ||
var _getPrototypeOf3 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); | ||
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); | ||
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); | ||
var _createClass2 = require('babel-runtime/helpers/createClass'); | ||
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized")); | ||
var _createClass3 = _interopRequireDefault(_createClass2); | ||
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); | ||
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); | ||
var _kefir = _interopRequireDefault(require("kefir")); | ||
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); | ||
var _kefirBus = _interopRequireDefault(require("kefir-bus")); | ||
var _inherits2 = require('babel-runtime/helpers/inherits'); | ||
var _kefirStopper = _interopRequireDefault(require("kefir-stopper")); | ||
var _inherits3 = _interopRequireDefault(_inherits2); | ||
var _react = _interopRequireDefault(require("react")); | ||
var _kefir = require('kefir'); | ||
var _propTypes = _interopRequireDefault(require("prop-types")); | ||
var _kefir2 = _interopRequireDefault(_kefir); | ||
var _pointRectDistance = _interopRequireDefault(require("./lib/pointRectDistance")); | ||
var _kefirBus = require('kefir-bus'); | ||
var _MenuListInspector = _interopRequireDefault(require("./MenuListInspector")); | ||
var _kefirBus2 = _interopRequireDefault(_kefirBus); | ||
var _reactFloatAnchor = _interopRequireDefault(require("react-float-anchor")); | ||
var _kefirStopper = require('kefir-stopper'); | ||
var _MenuItem = _interopRequireDefault(require("./MenuItem")); | ||
var _kefirStopper2 = _interopRequireDefault(_kefirStopper); | ||
var SubMenuItem = | ||
/*#__PURE__*/ | ||
function (_React$Component) { | ||
(0, _inherits2.default)(SubMenuItem, _React$Component); | ||
var _react = require('react'); | ||
var _react2 = _interopRequireDefault(_react); | ||
var _propTypes = require('prop-types'); | ||
var _propTypes2 = _interopRequireDefault(_propTypes); | ||
var _pointRectDistance = require('./lib/pointRectDistance'); | ||
var _pointRectDistance2 = _interopRequireDefault(_pointRectDistance); | ||
var _MenuListInspector = require('./MenuListInspector'); | ||
var _MenuListInspector2 = _interopRequireDefault(_MenuListInspector); | ||
var _reactFloatAnchor = require('react-float-anchor'); | ||
var _reactFloatAnchor2 = _interopRequireDefault(_reactFloatAnchor); | ||
var _MenuItem = require('./MenuItem'); | ||
var _MenuItem2 = _interopRequireDefault(_MenuItem); | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
var SubMenuItem = function (_React$Component) { | ||
(0, _inherits3.default)(SubMenuItem, _React$Component); | ||
function SubMenuItem() { | ||
var _ref; | ||
var _getPrototypeOf2; | ||
var _temp, _this, _ret; | ||
var _this; | ||
(0, _classCallCheck3.default)(this, SubMenuItem); | ||
(0, _classCallCheck2.default)(this, SubMenuItem); | ||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | ||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { | ||
args[_key] = arguments[_key]; | ||
} | ||
return _ret = (_temp = (_this = (0, _possibleConstructorReturn3.default)(this, (_ref = SubMenuItem.__proto__ || (0, _getPrototypeOf2.default)(SubMenuItem)).call.apply(_ref, [this].concat(args))), _this), _this.state = { | ||
_this = (0, _possibleConstructorReturn2.default)(this, (_getPrototypeOf2 = (0, _getPrototypeOf3.default)(SubMenuItem)).call.apply(_getPrototypeOf2, [this].concat(args))); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "state", { | ||
opened: false | ||
}, _this._resetMouseLeaveWatcher = (0, _kefirBus2.default)(), _this._stopper = (0, _kefirStopper2.default)(), _temp), (0, _possibleConstructorReturn3.default)(_this, _ret); | ||
}); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuItemRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_floatAnchorRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuInspectorRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_menuContainerRef", _react.default.createRef()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_resetMouseLeaveWatcher", (0, _kefirBus.default)()); | ||
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)((0, _assertThisInitialized2.default)(_this)), "_stopper", (0, _kefirStopper.default)()); | ||
return _this; | ||
} | ||
(0, _createClass3.default)(SubMenuItem, [{ | ||
key: 'componentWillUnmount', | ||
(0, _createClass2.default)(SubMenuItem, [{ | ||
key: "componentWillUnmount", | ||
value: function componentWillUnmount() { | ||
@@ -94,26 +79,36 @@ this._stopper.destroy(); | ||
}, { | ||
key: 'open', | ||
value: function open(callback) { | ||
key: "open", | ||
value: function open() { | ||
var _this2 = this; | ||
this._menuItem.lockHighlight(); | ||
if (this.state.opened) return; | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
menuItem.lockHighlight(); | ||
if (this.state.opened) return Promise.resolve(); | ||
if (this.props.onWillOpen) this.props.onWillOpen(); | ||
this.setState({ opened: true }, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
if (callback) callback(); | ||
menuItem.takeKeyboard(); | ||
return new Promise(function (resolve) { | ||
_this2.setState({ | ||
opened: true | ||
}, function () { | ||
if (_this2.props.onDidOpen) _this2.props.onDidOpen(); | ||
resolve(); | ||
}); | ||
}); | ||
this._menuItem.takeKeyboard(); | ||
} | ||
}, { | ||
key: 'close', | ||
key: "close", | ||
value: function close() { | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
if (!this.state.opened) return; | ||
if (this.props.onWillClose) this.props.onWillClose(); | ||
this.setState({ opened: false }); | ||
this._menuItem.releaseKeyboard(); | ||
this._menuItem.unlockHighlight(); | ||
this.setState({ | ||
opened: false | ||
}); | ||
menuItem.releaseKeyboard(); | ||
menuItem.unlockHighlight(); | ||
} | ||
}, { | ||
key: 'toggle', | ||
key: "toggle", | ||
value: function toggle() { | ||
@@ -127,30 +122,39 @@ if (this.state.opened) { | ||
}, { | ||
key: 'reposition', | ||
key: "reposition", | ||
value: function reposition() { | ||
this._floatAnchor.reposition(); | ||
var floatAnchor = this._floatAnchorRef.current; | ||
if (!floatAnchor) throw new Error(); | ||
floatAnchor.reposition(); | ||
} | ||
}, { | ||
key: 'hasHighlight', | ||
key: "hasHighlight", | ||
value: function hasHighlight() { | ||
return this._menuItem.hasHighlight(); | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
return menuItem.hasHighlight(); | ||
} | ||
}, { | ||
key: 'highlight', | ||
key: "highlight", | ||
value: function highlight() { | ||
var byKeyboard = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; | ||
this._menuItem.highlight(byKeyboard); | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
menuItem.highlight(byKeyboard); | ||
} | ||
}, { | ||
key: 'unhighlight', | ||
key: "unhighlight", | ||
value: function unhighlight() { | ||
this._menuItem.unhighlight(); | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
menuItem.unhighlight(); | ||
} | ||
}, { | ||
key: 'moveCursor', | ||
key: "moveCursor", | ||
value: function moveCursor(direction, prevCursorLocation) { | ||
this._menuItem.moveCursor(direction, prevCursorLocation); | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
menuItem.moveCursor(direction, prevCursorLocation); | ||
} | ||
}, { | ||
key: '_onHighlightChange', | ||
key: "_onHighlightChange", | ||
value: function _onHighlightChange(highlighted, event) { | ||
@@ -164,3 +168,3 @@ var _this3 = this; | ||
_kefir2.default.later(OPEN_DELAY).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
_kefir.default.later(OPEN_DELAY).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
_this3.open(); | ||
@@ -173,15 +177,17 @@ }); | ||
}, { | ||
key: '_onMouseLeaveItem', | ||
key: "_onMouseLeaveItem", | ||
value: function _onMouseLeaveItem(event) { | ||
var _this4 = this; | ||
var menuItem = this._menuItemRef.current; | ||
var menuContainer = this._menuContainerRef.current; | ||
if (!menuItem || !menuContainer) throw new Error(); | ||
if (!this.state.opened) { | ||
this._menuItem.unhighlight(); | ||
menuItem.unhighlight(); | ||
return; | ||
} | ||
} // If the mouse isn't going toward the menu, then unhighlight ourself. | ||
// If the mouse isn't going toward the menu, then unhighlight ourself. | ||
var menuRect = this._menuContainer.getBoundingClientRect(); | ||
var menuRect = menuContainer.getBoundingClientRect(); | ||
var startTime = Date.now(); | ||
@@ -192,85 +198,88 @@ var startX = event.pageX, | ||
function getDistance(x, y) { | ||
return (0, _pointRectDistance2.default)(x, y, menuRect.left, menuRect.top, menuRect.right - menuRect.width, menuRect.bottom - menuRect.top); | ||
return (0, _pointRectDistance.default)(x, y, menuRect.left, menuRect.top, menuRect.right - menuRect.width, menuRect.bottom - menuRect.top); | ||
} | ||
var startDistance = getDistance(startX, startY); | ||
var lastCoords = { pageX: startX, pageY: startY }; | ||
// pixels per second the user must be moving the mouse toward the menu for | ||
var lastCoords = { | ||
pageX: startX, | ||
pageY: startY | ||
}; // pixels per second the user must be moving the mouse toward the menu for | ||
// the menu to stay open. | ||
var MIN_SPEED = 60; | ||
// ms before the menu will close if the user hasn't reached it yet, no | ||
var MIN_SPEED = 60; // ms before the menu will close if the user hasn't reached it yet, no | ||
// matter how they're moving the cursor toward it. | ||
var MAX_TIME = 750; | ||
// ms to offset start time, to set maxDistance back a little so it's not so | ||
var MAX_TIME = 750; // ms to offset start time, to set maxDistance back a little so it's not so | ||
// unforgiving at the very start. | ||
var LEAD_TIME = 50; | ||
// Listen to mouse moves, find the first event not going towards the menu, | ||
var LEAD_TIME = 50; // Listen to mouse moves, find the first event not going towards the menu, | ||
// and end it there. Or end after a timer. | ||
_kefir2.default.fromEvents(window, 'mousemove').bufferBy(_kefir2.default.interval(60, null)).map(function (events) { | ||
_kefir.default.fromEvents(window, 'mousemove').bufferBy(_kefir.default.interval(60, null)).map(function (events) { | ||
if (events.length) { | ||
var last = events[events.length - 1]; | ||
lastCoords = { pageX: last.pageX, pageY: last.pageY }; | ||
lastCoords = { | ||
pageX: last.pageX, | ||
pageY: last.pageY | ||
}; | ||
} | ||
return lastCoords; | ||
}).filter(function (_ref2) { | ||
var pageX = _ref2.pageX, | ||
pageY = _ref2.pageY; | ||
}).filter(function (_ref) { | ||
var pageX = _ref.pageX, | ||
pageY = _ref.pageY; | ||
var distance = getDistance(pageX, pageY); | ||
var maxDistance = startDistance - (Date.now() - startTime - LEAD_TIME) / 1000 * MIN_SPEED; | ||
return distance > maxDistance; | ||
}).merge(_kefir2.default.later(MAX_TIME * 1000)).take(1).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
}).merge(_kefir.default.later(MAX_TIME * 1000)).take(1).takeUntilBy(this._resetMouseLeaveWatcher).takeUntilBy(this._stopper).onValue(function () { | ||
_this4.close(); | ||
_this4._menuItem.unhighlight(); | ||
menuItem.unhighlight(); | ||
}); | ||
} | ||
}, { | ||
key: '_mouseEnterMenu', | ||
key: "_mouseEnterMenu", | ||
value: function _mouseEnterMenu() { | ||
var menuItem = this._menuItemRef.current; | ||
if (!menuItem) throw new Error(); | ||
this._resetMouseLeaveWatcher.emit(null); | ||
this._menuItem.unlockHighlight(); | ||
menuItem.unlockHighlight(); | ||
} | ||
}, { | ||
key: 'render', | ||
key: "render", | ||
value: function render() { | ||
var _this5 = this; | ||
var _props = this.props, | ||
index = _props.index, | ||
highlightedStyle = _props.highlightedStyle, | ||
highlightedClassName = _props.highlightedClassName, | ||
positionOptions = _props.positionOptions, | ||
menuZIndex = _props.menuZIndex, | ||
children = _props.children, | ||
menu = _props.menu; | ||
var _this$props = this.props, | ||
index = _this$props.index, | ||
highlightedStyle = _this$props.highlightedStyle, | ||
highlightedClassName = _this$props.highlightedClassName, | ||
positionOptions = _this$props.positionOptions, | ||
menuZIndex = _this$props.menuZIndex, | ||
children = _this$props.children, | ||
menu = _this$props.menu; | ||
var opened = this.state.opened; | ||
var style = this.props.style; | ||
var className = this.props.className; | ||
if (opened) { | ||
if (this.props.openedStyle) { | ||
style = (0, _extends3.default)({}, style, this.props.openedStyle); | ||
style = (0, _objectSpread2.default)({}, style, this.props.openedStyle); | ||
} | ||
if (this.props.openedClassName) { | ||
className = (className || '') + ' ' + this.props.openedClassName; | ||
className = "".concat(className || '', " ").concat(this.props.openedClassName); | ||
} | ||
} | ||
return _react2.default.createElement(_reactFloatAnchor2.default, { | ||
ref: function ref(el) { | ||
if (el) _this5._floatAnchor = el; | ||
}, | ||
return _react.default.createElement(_reactFloatAnchor.default, { | ||
ref: this._floatAnchorRef, | ||
options: positionOptions, | ||
zIndex: menuZIndex, | ||
anchor: _react2.default.createElement( | ||
_MenuItem2.default, | ||
{ | ||
ref: function ref(el) { | ||
if (el) _this5._menuItem = el; | ||
}, | ||
anchor: function anchor(anchorRef) { | ||
return _react.default.createElement(_MenuItem.default, { | ||
ref: _this5._menuItemRef, | ||
domRef: anchorRef, | ||
index: index, | ||
@@ -291,4 +300,8 @@ style: style, | ||
e.preventDefault(); | ||
_this5.open(); | ||
_this5._menuInspector.moveCursor('down'); | ||
var menuInspector = _this5._menuInspectorRef.current; | ||
if (!menuInspector) throw new Error(); | ||
menuInspector.moveCursor('down'); | ||
} | ||
@@ -299,37 +312,29 @@ }, | ||
e.preventDefault(); | ||
_this5.open(); | ||
if (e.byKeyboard) { | ||
_this5._menuInspector.moveCursor('down'); | ||
var menuInspector = _this5._menuInspectorRef.current; | ||
if (!menuInspector) throw new Error(); | ||
menuInspector.moveCursor('down'); | ||
} | ||
}, | ||
'aria-haspopup': true, | ||
'aria-expanded': opened | ||
}, | ||
children | ||
), | ||
float: !opened ? null : _react2.default.createElement( | ||
_MenuListInspector2.default, | ||
{ | ||
ref: function ref(el) { | ||
if (el) _this5._menuInspector = el; | ||
}, | ||
onLeftPushed: function onLeftPushed(e) { | ||
e.stopPropagation(); | ||
e.preventDefault(); | ||
_this5.close(); | ||
} | ||
}, | ||
_react2.default.createElement( | ||
'div', | ||
{ | ||
ref: function ref(el) { | ||
if (el) _this5._menuContainer = el; | ||
}, | ||
onMouseEnter: function onMouseEnter() { | ||
return _this5._mouseEnterMenu(); | ||
} | ||
}, | ||
menu | ||
) | ||
) | ||
"aria-haspopup": true, | ||
"aria-expanded": opened | ||
}, children); | ||
}, | ||
float: !opened ? null : _react.default.createElement(_MenuListInspector.default, { | ||
ref: this._menuInspectorRef, | ||
onLeftPushed: function onLeftPushed(e) { | ||
e.stopPropagation(); | ||
e.preventDefault(); | ||
_this5.close(); | ||
} | ||
}, _react.default.createElement("div", { | ||
ref: this._menuContainerRef, | ||
onMouseEnter: function onMouseEnter() { | ||
return _this5._mouseEnterMenu(); | ||
} | ||
}, menu)) | ||
}); | ||
@@ -339,32 +344,30 @@ } | ||
return SubMenuItem; | ||
}(_react2.default.Component); | ||
}(_react.default.Component); | ||
SubMenuItem.propTypes = { | ||
menu: _propTypes2.default.node, | ||
positionOptions: _propTypes2.default.object, | ||
menuZIndex: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.number]), | ||
onWillOpen: _propTypes2.default.func, | ||
onDidOpen: _propTypes2.default.func, | ||
onWillClose: _propTypes2.default.func, | ||
className: _propTypes2.default.string, | ||
style: _propTypes2.default.object, | ||
highlightedClassName: _propTypes2.default.string, | ||
highlightedStyle: _propTypes2.default.object, | ||
index: _propTypes2.default.number, | ||
openedClassName: _propTypes2.default.string, | ||
openedStyle: _propTypes2.default.object, | ||
onItemChosen: _propTypes2.default.func, | ||
onHighlightChange: _propTypes2.default.func, | ||
children: _propTypes2.default.node | ||
}; | ||
SubMenuItem.defaultProps = { | ||
positionOptions: { position: 'right', vAlign: 'top', hAlign: 'left' } | ||
}; | ||
exports.default = SubMenuItem; | ||
module.exports = exports['default']; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/SubMenuItem.js"],"names":["SubMenuItem","state","opened","_resetMouseLeaveWatcher","_stopper","destroy","callback","_menuItem","lockHighlight","props","onWillOpen","setState","onDidOpen","takeKeyboard","onWillClose","releaseKeyboard","unlockHighlight","close","open","_floatAnchor","reposition","hasHighlight","byKeyboard","highlight","unhighlight","direction","prevCursorLocation","moveCursor","highlighted","event","emit","OPEN_DELAY","Kefir","later","takeUntilBy","onValue","menuRect","_menuContainer","getBoundingClientRect","startTime","Date","now","startX","pageX","startY","pageY","getDistance","x","y","left","top","right","width","bottom","startDistance","lastCoords","MIN_SPEED","MAX_TIME","LEAD_TIME","fromEvents","window","bufferBy","interval","map","events","length","last","filter","distance","maxDistance","merge","take","index","highlightedStyle","highlightedClassName","positionOptions","menuZIndex","children","menu","style","className","openedStyle","openedClassName","el","h","e","_onHighlightChange","_onMouseLeaveItem","stopPropagation","preventDefault","_menuInspector","_mouseEnterMenu","React","Component","propTypes","PropTypes","node","object","oneOfType","string","number","func","onItemChosen","onHighlightChange","defaultProps","position","vAlign","hAlign"],"mappings":"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","file":"SubMenuItem.js","sourcesContent":["/* @flow */\n\nimport Kefir from 'kefir';\nimport kefirBus from 'kefir-bus';\nimport type {Bus} from 'kefir-bus';\nimport kefirStopper from 'kefir-stopper';\nimport React from 'react';\nimport type {Node as ReactNode, Element as ReactElement} 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';\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?: ReactElement<any>;\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  _menuItem: MenuItem;\n  _menuInspector: MenuListInspector;\n  _menuContainer: HTMLElement;\n  _floatAnchor: FloatAnchor;\n  _resetMouseLeaveWatcher: Bus<null> = kefirBus();\n  _stopper = kefirStopper();\n\n  componentWillUnmount() {\n    this._stopper.destroy();\n  }\n\n  open(callback?: () => any) {\n    this._menuItem.lockHighlight();\n    if (this.state.opened) return;\n    if (this.props.onWillOpen) this.props.onWillOpen();\n    this.setState({opened: true}, () => {\n      if (this.props.onDidOpen) this.props.onDidOpen();\n      if (callback) callback();\n    });\n    this._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._menuItem.releaseKeyboard();\n    this._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._floatAnchor.reposition();\n  }\n\n  hasHighlight(): boolean {\n    return this._menuItem.hasHighlight();\n  }\n\n  highlight(byKeyboard: boolean=true) {\n    this._menuItem.highlight(byKeyboard);\n  }\n\n  unhighlight() {\n    this._menuItem.unhighlight();\n  }\n\n  moveCursor(direction: Direction, prevCursorLocation: ?Rect) {\n    this._menuItem.moveCursor(direction, prevCursorLocation);\n  }\n\n  _onHighlightChange(highlighted: boolean, event: Object) {\n    this._resetMouseLeaveWatcher.emit(null);\n\n    if (highlighted && !event.byKeyboard) {\n      const OPEN_DELAY = 200;\n\n      Kefir.later(OPEN_DELAY)\n        .takeUntilBy(this._resetMouseLeaveWatcher)\n        .takeUntilBy(this._stopper)\n        .onValue(() => {\n          this.open();\n        });\n    } else if (!highlighted) {\n      this.close();\n    }\n  }\n\n  _onMouseLeaveItem(event: Object) {\n    if (!this.state.opened) {\n      this._menuItem.unhighlight();\n      return;\n    }\n\n    // If the mouse isn't going toward the menu, then unhighlight ourself.\n\n    const menuRect = this._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._menuItem.unhighlight();\n      });\n  }\n\n  _mouseEnterMenu() {\n    this._resetMouseLeaveWatcher.emit(null);\n    this._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={el => {\n          if (el) this._floatAnchor = el;\n        }}\n        options={positionOptions}\n        zIndex={menuZIndex}\n        anchor={\n          <MenuItem\n            ref={el => {\n              if (el) this._menuItem = el;\n            }}\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._menuInspector.moveCursor('down');\n              }\n            }}\n            onItemChosen={(e: ChosenEvent) => {\n              e.stopPropagation();\n              e.preventDefault();\n              this.open();\n              if (e.byKeyboard) {\n                this._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={el => {\n                if (el) this._menuInspector = el;\n              }}\n              onLeftPushed={e => {\n                e.stopPropagation();\n                e.preventDefault();\n                this.close();\n              }}\n            >\n              <div\n                ref={el => {\n                  if (el) this._menuContainer = el;\n                }}\n                onMouseEnter={()=>this._mouseEnterMenu()}\n              >\n                {menu}\n              </div>\n            </MenuListInspector>\n        }\n      />\n    );\n  }\n}\n"]} | ||
(0, _defineProperty2.default)(SubMenuItem, "propTypes", { | ||
menu: _propTypes.default.node, | ||
positionOptions: _propTypes.default.object, | ||
menuZIndex: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.number]), | ||
onWillOpen: _propTypes.default.func, | ||
onDidOpen: _propTypes.default.func, | ||
onWillClose: _propTypes.default.func, | ||
className: _propTypes.default.string, | ||
style: _propTypes.default.object, | ||
highlightedClassName: _propTypes.default.string, | ||
highlightedStyle: _propTypes.default.object, | ||
index: _propTypes.default.number, | ||
openedClassName: _propTypes.default.string, | ||
openedStyle: _propTypes.default.object, | ||
onItemChosen: _propTypes.default.func, | ||
onHighlightChange: _propTypes.default.func, | ||
children: _propTypes.default.node | ||
}); | ||
(0, _defineProperty2.default)(SubMenuItem, "defaultProps", { | ||
positionOptions: { | ||
position: 'right', | ||
vAlign: 'top', | ||
hAlign: 'left' | ||
} | ||
}); | ||
//# 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<Class<MenuItem>>();\n  _floatAnchorRef = React.createRef<Class<FloatAnchor>>();\n  _menuInspectorRef = React.createRef<Class<MenuListInspector>>();\n  _menuContainerRef = React.createRef<'div'>();\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    const menuContainer = this._menuContainerRef.current;\n    if (!menuItem || !menuContainer) throw new Error();\n\n    if (!this.state.opened) {\n      menuItem.unhighlight();\n      return;\n    }\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"]} |
@@ -1,2 +0,2 @@ | ||
'use strict'; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsImZpbGUiOiJ0eXBlcy5qcyIsInNvdXJjZXNDb250ZW50IjpbXX0= | ||
"use strict"; | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbXX0= |
{ | ||
"name": "react-menu-list", | ||
"version": "5.0.1", | ||
"version": "6.0.0", | ||
"description": "React component for menu lists and submenus", | ||
"main": "js/index.js", | ||
"sideEffects": false, | ||
"scripts": { | ||
"prepare": "rimraf js/ && babel -s inline -d js/ src/ && flow-copy-source -v src js", | ||
"prepare": "rimraf js && babel -s inline -d js/ src/ --ignore '**/*.test.js' && flow-copy-source -v src js --ignore '**/*.test.*'", | ||
"example-build": "cross-env NODE_ENV=development browserify -t babelify -do example/bundle.js example/main.js", | ||
"example-watch": "cross-env NODE_ENV=development-hmr watchify -v -p browserify-hmr -t babelify -do example/bundle.js example/main.js", | ||
"example-watch": "cross-env NODE_ENV=development watchify -v -t babelify -do example/bundle.js example/main.js", | ||
"example-build-prod": "cross-env NODE_ENV=production browserify -t babelify -do example/bundle.js example/main.js", | ||
"test": "npm run lint && npm run flow_check && jest", | ||
"test": "yarn run lint && yarn run flow_check && jest && tsc", | ||
"flow_check": "flow check", | ||
@@ -33,32 +34,33 @@ "lint": "eslint .", | ||
"devDependencies": { | ||
"babel-cli": "^6.18.0", | ||
"babel-core": "^6.26.3", | ||
"babel-eslint": "^8.0.1", | ||
"babel-jest": "^22.4.3", | ||
"babel-plugin-add-module-exports": "^0.2.1", | ||
"babel-plugin-transform-runtime": "^6.15.0", | ||
"babel-preset-es2015": "^6.18.0", | ||
"babel-preset-react": "^6.16.0", | ||
"babel-preset-react-hmre": "^1.1.1", | ||
"babel-preset-stage-2": "^6.18.0", | ||
"babel-register": "^6.18.0", | ||
"babelify": "^8.0.0", | ||
"@babel/cli": "^7.0.0", | ||
"@babel/core": "^7.0.0", | ||
"@babel/plugin-proposal-class-properties": "^7.0.0", | ||
"@babel/plugin-transform-runtime": "^7.0.0", | ||
"@babel/preset-env": "^7.0.0", | ||
"@babel/preset-flow": "^7.0.0", | ||
"@babel/preset-react": "^7.0.0", | ||
"@babel/register": "^7.0.0", | ||
"@types/react": "^16.4.18", | ||
"babel-core": "^7.0.0-bridge.0", | ||
"babel-eslint": "^10.0.1", | ||
"babel-jest": "^23.4.2", | ||
"babelify": "^10.0.0", | ||
"browserify": "^16.2.2", | ||
"browserify-hmr": "^0.3.1", | ||
"cross-env": "^5.0.1", | ||
"eslint": "^4.8.0", | ||
"eslint-plugin-flowtype": "^2.37.0", | ||
"eslint": "^5.8.0", | ||
"eslint-plugin-flowtype": "^3.1.4", | ||
"eslint-plugin-react": "^7.4.0", | ||
"flow-bin": "^0.72.0", | ||
"flow-copy-source": "^1.0.1", | ||
"jest": "^22.4.3", | ||
"react": "^16.0.0", | ||
"react-dom": "^16.0.0", | ||
"react-test-renderer": "^16.0.0", | ||
"flow-bin": "^0.85.0", | ||
"flow-copy-source": "^2.0.2", | ||
"jest": "^23.6.0", | ||
"react": "^16.6.0", | ||
"react-dom": "^16.6.0", | ||
"react-test-renderer": "^16.6.0", | ||
"rimraf": "^2.6.1", | ||
"typescript": "^3.1.4", | ||
"watchify": "^3.7.0" | ||
}, | ||
"dependencies": { | ||
"@babel/runtime": "^7.0.0", | ||
"array-find-index": "1.0.2", | ||
"babel-runtime": "^6.23.0", | ||
"kefir": "^3.5.1", | ||
@@ -68,8 +70,8 @@ "kefir-bus": "^2.2.0", | ||
"prop-types": "^15.6.0", | ||
"react-float-anchor": "^2.0.1" | ||
"react-float-anchor": "^3.0.0" | ||
}, | ||
"peerDependencies": { | ||
"react": "^16.0.0", | ||
"react-dom": "^16.0.0" | ||
"react": "^16.6.0", | ||
"react-dom": "^16.6.0" | ||
} | ||
} |
@@ -35,9 +35,3 @@ # react-menu-list | ||
yarn example-build | ||
``` | ||
You can build the example with live editing enabled (using | ||
[react-transform-hmr](https://github.com/gaearon/react-transform-hmr) and | ||
[browserify-hmr](https://github.com/AgentME/browserify-hmr)) by running: | ||
``` | ||
# or use this to auto-rebuild on changes: | ||
yarn example-watch | ||
@@ -113,2 +107,4 @@ ``` | ||
this. | ||
* `domRef`: Optional prop which is passed as the `ref` value to the MenuItem's | ||
div element. | ||
@@ -165,3 +161,3 @@ A MenuItem has the following public methods: | ||
* `open(callback?: Function)` | ||
* `open(): Promise<void>` | ||
* `close()` | ||
@@ -215,7 +211,8 @@ * `toggle()` | ||
* `ButtonComponent`: Optional prop that allows a different component to be used | ||
instead of an html `<button>`. | ||
instead of an html `<button>`. The component passed here must support a | ||
`domRef` prop which is passed as a ref to the button's DOM element. | ||
A MenuButton has the following public methods: | ||
* `open(callback?: Function)` | ||
* `open(): Promise<void>` | ||
* `close()` | ||
@@ -253,3 +250,4 @@ * `toggle()` | ||
[Flow](https://flowtype.org/) type declarations for this module are included! | ||
If you are using Flow, they won't require any configuration to use. | ||
Both [TypeScript](https://www.typescriptlang.org/) and | ||
[Flow](https://flowtype.org/) type definitions for this module are included! | ||
The type definitions won't require any configuration to use. |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
Major refactor
Supply chain riskPackage has recently undergone a major refactor. It may be unstable or indicate significant internal changes. Use caution when updating to versions that include significant changes.
Found 1 instance in 1 package
New author
Supply chain riskA new npm collaborator published a version of the package for the first time. New collaborators are usually benign additions to a project, but do indicate a change to the security surface area of a package.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
223748
33
1538
27
249
2
+ Added@babel/runtime@^7.0.0
+ Added@types/lodash@4.17.13(transitive)
+ Addedcontain-by-screen@2.1.0(transitive)
+ Addedreact-float-anchor@3.4.1(transitive)
- Removedbabel-runtime@^6.23.0
- Removedbabel-runtime@6.26.0(transitive)
- Removedcontain-by-screen@1.3.0(transitive)
- Removedcore-js@2.6.12(transitive)
- Removedreact-float-anchor@2.2.1(transitive)
- Removedregenerator-runtime@0.11.1(transitive)
Updatedreact-float-anchor@^3.0.0