react-dropdown-select
Advanced tools
Comparing version
@@ -10,85 +10,40 @@ "use strict"; | ||
var _react = _interopRequireWildcard(require("react")); | ||
var _react = _interopRequireDefault(require("react")); | ||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } } | ||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | ||
function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } | ||
var Item = function Item(_ref) { | ||
var parentProps = _ref.parentProps, | ||
parentState = _ref.parentState, | ||
parentMethods = _ref.parentMethods, | ||
item = _ref.item, | ||
itemIndex = _ref.itemIndex; | ||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | ||
if (!!parentProps.itemRenderer) { | ||
return parentProps.itemRenderer(item, itemIndex, parentProps, parentState, parentMethods); | ||
} | ||
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } | ||
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } | ||
function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } | ||
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } | ||
function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } | ||
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } | ||
function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } | ||
var Item = | ||
/*#__PURE__*/ | ||
function (_Component) { | ||
_inherits(Item, _Component); | ||
function Item() { | ||
_classCallCheck(this, Item); | ||
return _possibleConstructorReturn(this, _getPrototypeOf(Item).apply(this, arguments)); | ||
if (!parentProps.keepSelectedInList && parentMethods.isSelected(item)) { | ||
return null; | ||
} | ||
_createClass(Item, [{ | ||
key: "componentDidUpdate", | ||
value: function componentDidUpdate(prevProps, prevState, snapshot) { | ||
if (prevProps.parentState.cursor !== this.props.parentState.cursor && this.props.parentState.cursor === this.props.itemIndex) { | ||
this.props.parentMethods.activeCursorItem(this.props.item); | ||
} | ||
} | ||
}, { | ||
key: "render", | ||
value: function render() { | ||
var _this$props = this.props, | ||
parentProps = _this$props.parentProps, | ||
parentState = _this$props.parentState, | ||
parentMethods = _this$props.parentMethods, | ||
item = _this$props.item, | ||
itemIndex = _this$props.itemIndex; | ||
return _react.default.createElement(ItemComponent, { | ||
role: "option", | ||
"aria-selected": parentMethods.isSelected(item), | ||
"aria-disabled": item.disabled, | ||
disabled: item.disabled, | ||
"aria-label": item[parentProps.labelField], | ||
key: "".concat(item[parentProps.valueField]).concat(item[parentProps.labelField]), | ||
tabIndex: "-1", | ||
className: "react-dropdown-select-item ".concat(parentMethods.isSelected(item) ? 'react-dropdown-select-item-selected' : '', " ").concat(parentState.cursor === itemIndex ? 'react-dropdown-select-item-active' : null), | ||
onClick: item.disabled ? undefined : function () { | ||
return parentMethods.addItem(item); | ||
}, | ||
onKeyPress: item.disabled ? undefined : function () { | ||
return parentMethods.addItem(item); | ||
}, | ||
color: parentProps.color | ||
}, item[parentProps.labelField], " ", item.disabled && _react.default.createElement("ins", null, "disabled")); | ||
}; | ||
if (!!parentProps.itemRenderer) { | ||
return parentProps.itemRenderer(item, itemIndex, parentProps, parentState, parentMethods); | ||
} | ||
if (!parentProps.keepSelectedInList && parentMethods.isSelected(item)) { | ||
return null; | ||
} | ||
return _react.default.createElement(ItemComponent, { | ||
role: "option", | ||
"aria-selected": parentMethods.isSelected(item), | ||
"aria-disabled": item.disabled, | ||
disabled: item.disabled, | ||
"aria-label": item[parentProps.labelField], | ||
key: "".concat(item[parentProps.valueField]).concat(item[parentProps.labelField]), | ||
tabIndex: "-1", | ||
className: "react-dropdown-select-item ".concat(parentMethods.isSelected(item) ? 'react-dropdown-select-item-selected' : '', " ").concat(parentState.cursor === itemIndex ? 'react-dropdown-select-item-active' : null), | ||
onClick: item.disabled ? undefined : function () { | ||
return parentMethods.addItem(item); | ||
}, | ||
onKeyPress: item.disabled ? undefined : function () { | ||
return parentMethods.addItem(item); | ||
}, | ||
color: parentProps.color | ||
}, item[parentProps.labelField], " ", item.disabled && _react.default.createElement("ins", null, "disabled")); | ||
} | ||
}]); | ||
return Item; | ||
}(_react.Component); | ||
Item.propTypes = {}; | ||
@@ -98,11 +53,11 @@ var ItemComponent = (0, _styledBase.default)("span", { | ||
label: "ItemComponent" | ||
})("padding:5px 10px;cursor:pointer;border-bottom:1px solid #fff;&.react-dropdown-select-item-active{border-left:5px solid #ccc;}:hover,:focus{background:#f2f2f2;outline:none;}&.react-dropdown-select-item-selected{", function (_ref) { | ||
var disabled = _ref.disabled, | ||
color = _ref.color; | ||
})("padding:5px 10px;cursor:pointer;border-bottom:1px solid #fff;&.react-dropdown-select-item-active{border-left:5px solid #ccc;}:hover,:focus{background:#f2f2f2;outline:none;}&.react-dropdown-select-item-selected{", function (_ref2) { | ||
var disabled = _ref2.disabled, | ||
color = _ref2.color; | ||
return disabled ? "\n background: #f2f2f2;\n color: #ccc;\n " : "\n background: ".concat(color, ";\n color: #fff;\n border-bottom: 1px solid #fff;\n "); | ||
}, "}", function (_ref2) { | ||
var disabled = _ref2.disabled; | ||
}, "}", function (_ref3) { | ||
var disabled = _ref3.disabled; | ||
return disabled ? "\n background: #f2f2f2;\n color: #ccc;\n \n ins {\n text-decoration: none;\n border:1px solid #ccc;\n border-radius: 2px;\n padding: 0px 3px;\n font-size: x-small;\n text-transform: uppercase;\n }\n " : ''; | ||
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL0l0ZW0uanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkNpQyIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9JdGVtLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IENvbXBvbmVudCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY2xhc3MgSXRlbSBleHRlbmRzIENvbXBvbmVudCB7XG4gIGNvbXBvbmVudERpZFVwZGF0ZShwcmV2UHJvcHMsIHByZXZTdGF0ZSwgc25hcHNob3QpIHtcbiAgICBpZiAocHJldlByb3BzLnBhcmVudFN0YXRlLmN1cnNvciAhPT0gdGhpcy5wcm9wcy5wYXJlbnRTdGF0ZS5jdXJzb3IgJiYgdGhpcy5wcm9wcy5wYXJlbnRTdGF0ZS5jdXJzb3IgPT09IHRoaXMucHJvcHMuaXRlbUluZGV4KSB7XG4gICAgICB0aGlzLnByb3BzLnBhcmVudE1ldGhvZHMuYWN0aXZlQ3Vyc29ySXRlbSh0aGlzLnByb3BzLml0ZW0pO1xuICAgIH1cbiAgfVxuXG4gIHJlbmRlcigpIHtcbiAgICBsZXQgeyBwYXJlbnRQcm9wcywgcGFyZW50U3RhdGUsIHBhcmVudE1ldGhvZHMsIGl0ZW0sIGl0ZW1JbmRleCB9ID0gdGhpcy5wcm9wcztcbiAgICBpZiAoISFwYXJlbnRQcm9wcy5pdGVtUmVuZGVyZXIpIHtcbiAgICAgIHJldHVybiBwYXJlbnRQcm9wcy5pdGVtUmVuZGVyZXIoaXRlbSwgaXRlbUluZGV4LCBwYXJlbnRQcm9wcywgcGFyZW50U3RhdGUsIHBhcmVudE1ldGhvZHMpO1xuICAgIH1cblxuICAgIGlmICghcGFyZW50UHJvcHMua2VlcFNlbGVjdGVkSW5MaXN0ICYmIHBhcmVudE1ldGhvZHMuaXNTZWxlY3RlZChpdGVtKSkge1xuICAgICAgcmV0dXJuIG51bGw7XG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxJdGVtQ29tcG9uZW50XG4gICAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgICBhcmlhLXNlbGVjdGVkPXtwYXJlbnRNZXRob2RzLmlzU2VsZWN0ZWQoaXRlbSl9XG4gICAgICAgIGFyaWEtZGlzYWJsZWQ9e2l0ZW0uZGlzYWJsZWR9XG4gICAgICAgIGRpc2FibGVkPXtpdGVtLmRpc2FibGVkfVxuICAgICAgICBhcmlhLWxhYmVsPXtpdGVtW3BhcmVudFByb3BzLmxhYmVsRmllbGRdfVxuICAgICAgICBrZXk9e2Ake2l0ZW1bcGFyZW50UHJvcHMudmFsdWVGaWVsZF19JHtpdGVtW3BhcmVudFByb3BzLmxhYmVsRmllbGRdfWB9XG4gICAgICAgIHRhYkluZGV4PVwiLTFcIlxuICAgICAgICBjbGFzc05hbWU9e2ByZWFjdC1kcm9wZG93bi1zZWxlY3QtaXRlbSAke1xuICAgICAgICAgIHBhcmVudE1ldGhvZHMuaXNTZWxlY3RlZChpdGVtKSA/ICdyZWFjdC1kcm9wZG93bi1zZWxlY3QtaXRlbS1zZWxlY3RlZCcgOiAnJ1xuICAgICAgICAgIH0gJHtwYXJlbnRTdGF0ZS5jdXJzb3IgPT09IGl0ZW1JbmRleCA/ICdyZWFjdC1kcm9wZG93bi1zZWxlY3QtaXRlbS1hY3RpdmUnIDogbnVsbH1gfVxuICAgICAgICBvbkNsaWNrPXtpdGVtLmRpc2FibGVkID8gdW5kZWZpbmVkIDogKCkgPT4gcGFyZW50TWV0aG9kcy5hZGRJdGVtKGl0ZW0pfVxuICAgICAgICBvbktleVByZXNzPXtpdGVtLmRpc2FibGVkID8gdW5kZWZpbmVkIDogKCkgPT4gcGFyZW50TWV0aG9kcy5hZGRJdGVtKGl0ZW0pfVxuICAgICAgICBjb2xvcj17cGFyZW50UHJvcHMuY29sb3J9PlxuICAgICAgICB7aXRlbVtwYXJlbnRQcm9wcy5sYWJlbEZpZWxkXX0ge2l0ZW0uZGlzYWJsZWQgJiYgPGlucz5kaXNhYmxlZDwvaW5zPn1cbiAgICAgIDwvSXRlbUNvbXBvbmVudD5cbiAgICApO1xuICB9XG59XG5cbkl0ZW0ucHJvcFR5cGVzID0ge307XG5cbmNvbnN0IEl0ZW1Db21wb25lbnQgPSBzdHlsZWQuc3BhbmBcbiAgcGFkZGluZzogNXB4IDEwcHg7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNmZmY7XG4gIFxuICAmLnJlYWN0LWRyb3Bkb3duLXNlbGVjdC1pdGVtLWFjdGl2ZSB7XG4gICAgYm9yZGVyLWxlZnQ6IDVweCBzb2xpZCAjY2NjO1xuICB9XG5cbiAgOmhvdmVyLFxuICA6Zm9jdXMge1xuICAgIGJhY2tncm91bmQ6ICNmMmYyZjI7XG4gICAgb3V0bGluZTogbm9uZTtcbiAgfVxuXG4gICYucmVhY3QtZHJvcGRvd24tc2VsZWN0LWl0ZW0tc2VsZWN0ZWQge1xuICAgICR7KHsgZGlzYWJsZWQsIGNvbG9yIH0pID0+XG4gICAgICBkaXNhYmxlZFxuICAgICAgICA/IGBcbiAgICBiYWNrZ3JvdW5kOiAjZjJmMmYyO1xuICAgIGNvbG9yOiAjY2NjO1xuICAgIGBcbiAgICAgICAgOiBgXG4gICAgYmFja2dyb3VuZDogJHtjb2xvcn07XG4gICAgY29sb3I6ICNmZmY7XG4gICAgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNmZmY7XG4gICAgYH1cbiAgfVxuXG4gICR7KHsgZGlzYWJsZWQgfSkgPT5cbiAgICBkaXNhYmxlZFxuICAgICAgPyBgXG4gICAgYmFja2dyb3VuZDogI2YyZjJmMjtcbiAgICBjb2xvcjogI2NjYztcbiAgICBcbiAgICBpbnMge1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgYm9yZGVyOjFweCBzb2xpZCAjY2NjO1xuICAgICAgYm9yZGVyLXJhZGl1czogMnB4O1xuICAgICAgcGFkZGluZzogMHB4IDNweDtcbiAgICAgIGZvbnQtc2l6ZTogeC1zbWFsbDtcbiAgICAgIHRleHQtdHJhbnNmb3JtOiB1cHBlcmNhc2U7XG4gICAgfVxuICAgIGBcbiAgICAgIDogJyd9XG5gO1xuXG5leHBvcnQgZGVmYXVsdCBJdGVtO1xuIl19 */"); | ||
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL0l0ZW0uanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBa0NpQyIsImZpbGUiOiIuLi8uLi9zcmMvY29tcG9uZW50cy9JdGVtLmpzIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcblxuY29uc3QgSXRlbSA9ICh7IHBhcmVudFByb3BzLCBwYXJlbnRTdGF0ZSwgcGFyZW50TWV0aG9kcywgaXRlbSwgaXRlbUluZGV4IH0pID0+IHtcbiAgaWYgKCEhcGFyZW50UHJvcHMuaXRlbVJlbmRlcmVyKSB7XG4gICAgcmV0dXJuIHBhcmVudFByb3BzLml0ZW1SZW5kZXJlcihpdGVtLCBpdGVtSW5kZXgsIHBhcmVudFByb3BzLCBwYXJlbnRTdGF0ZSwgcGFyZW50TWV0aG9kcyk7XG4gIH1cblxuICBpZiAoIXBhcmVudFByb3BzLmtlZXBTZWxlY3RlZEluTGlzdCAmJiBwYXJlbnRNZXRob2RzLmlzU2VsZWN0ZWQoaXRlbSkpIHtcbiAgICByZXR1cm4gbnVsbDtcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPEl0ZW1Db21wb25lbnRcbiAgICAgIHJvbGU9XCJvcHRpb25cIlxuICAgICAgYXJpYS1zZWxlY3RlZD17cGFyZW50TWV0aG9kcy5pc1NlbGVjdGVkKGl0ZW0pfVxuICAgICAgYXJpYS1kaXNhYmxlZD17aXRlbS5kaXNhYmxlZH1cbiAgICAgIGRpc2FibGVkPXtpdGVtLmRpc2FibGVkfVxuICAgICAgYXJpYS1sYWJlbD17aXRlbVtwYXJlbnRQcm9wcy5sYWJlbEZpZWxkXX1cbiAgICAgIGtleT17YCR7aXRlbVtwYXJlbnRQcm9wcy52YWx1ZUZpZWxkXX0ke2l0ZW1bcGFyZW50UHJvcHMubGFiZWxGaWVsZF19YH1cbiAgICAgIHRhYkluZGV4PVwiLTFcIlxuICAgICAgY2xhc3NOYW1lPXtgcmVhY3QtZHJvcGRvd24tc2VsZWN0LWl0ZW0gJHtcbiAgICAgICAgcGFyZW50TWV0aG9kcy5pc1NlbGVjdGVkKGl0ZW0pID8gJ3JlYWN0LWRyb3Bkb3duLXNlbGVjdC1pdGVtLXNlbGVjdGVkJyA6ICcnXG4gICAgICAgIH0gJHtwYXJlbnRTdGF0ZS5jdXJzb3IgPT09IGl0ZW1JbmRleCA/ICdyZWFjdC1kcm9wZG93bi1zZWxlY3QtaXRlbS1hY3RpdmUnIDogbnVsbH1gfVxuICAgICAgb25DbGljaz17aXRlbS5kaXNhYmxlZCA/IHVuZGVmaW5lZCA6ICgpID0+IHBhcmVudE1ldGhvZHMuYWRkSXRlbShpdGVtKX1cbiAgICAgIG9uS2V5UHJlc3M9e2l0ZW0uZGlzYWJsZWQgPyB1bmRlZmluZWQgOiAoKSA9PiBwYXJlbnRNZXRob2RzLmFkZEl0ZW0oaXRlbSl9XG4gICAgICBjb2xvcj17cGFyZW50UHJvcHMuY29sb3J9PlxuICAgICAge2l0ZW1bcGFyZW50UHJvcHMubGFiZWxGaWVsZF19IHtpdGVtLmRpc2FibGVkICYmIDxpbnM+ZGlzYWJsZWQ8L2lucz59XG4gICAgPC9JdGVtQ29tcG9uZW50PlxuICApO1xufTtcblxuSXRlbS5wcm9wVHlwZXMgPSB7fTtcblxuY29uc3QgSXRlbUNvbXBvbmVudCA9IHN0eWxlZC5zcGFuYFxuICBwYWRkaW5nOiA1cHggMTBweDtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBib3JkZXItYm90dG9tOiAxcHggc29saWQgI2ZmZjtcbiAgXG4gICYucmVhY3QtZHJvcGRvd24tc2VsZWN0LWl0ZW0tYWN0aXZlIHtcbiAgICBib3JkZXItbGVmdDogNXB4IHNvbGlkICNjY2M7XG4gIH1cblxuICA6aG92ZXIsXG4gIDpmb2N1cyB7XG4gICAgYmFja2dyb3VuZDogI2YyZjJmMjtcbiAgICBvdXRsaW5lOiBub25lO1xuICB9XG5cbiAgJi5yZWFjdC1kcm9wZG93bi1zZWxlY3QtaXRlbS1zZWxlY3RlZCB7XG4gICAgJHsoeyBkaXNhYmxlZCwgY29sb3IgfSkgPT5cbiAgICAgIGRpc2FibGVkXG4gICAgICAgID8gYFxuICAgIGJhY2tncm91bmQ6ICNmMmYyZjI7XG4gICAgY29sb3I6ICNjY2M7XG4gICAgYFxuICAgICAgICA6IGBcbiAgICBiYWNrZ3JvdW5kOiAke2NvbG9yfTtcbiAgICBjb2xvcjogI2ZmZjtcbiAgICBib3JkZXItYm90dG9tOiAxcHggc29saWQgI2ZmZjtcbiAgICBgfVxuICB9XG5cbiAgJHsoeyBkaXNhYmxlZCB9KSA9PlxuICAgIGRpc2FibGVkXG4gICAgICA/IGBcbiAgICBiYWNrZ3JvdW5kOiAjZjJmMmYyO1xuICAgIGNvbG9yOiAjY2NjO1xuICAgIFxuICAgIGlucyB7XG4gICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgICBib3JkZXI6MXB4IHNvbGlkICNjY2M7XG4gICAgICBib3JkZXItcmFkaXVzOiAycHg7XG4gICAgICBwYWRkaW5nOiAwcHggM3B4O1xuICAgICAgZm9udC1zaXplOiB4LXNtYWxsO1xuICAgICAgdGV4dC10cmFuc2Zvcm06IHVwcGVyY2FzZTtcbiAgICB9XG4gICAgYFxuICAgICAgOiAnJ31cbmA7XG5cbmV4cG9ydCBkZWZhdWx0IEl0ZW07XG4iXX0= */"); | ||
var _default = Item; | ||
exports.default = _default; |
@@ -91,3 +91,3 @@ "use strict"; | ||
_this.setState({ | ||
cursor: null | ||
cursor: 0 | ||
}); | ||
@@ -262,2 +262,6 @@ | ||
_defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), "handleKeyDown", function (event) { | ||
if (event.key === 'ArrowUp' || event.key === 'ArrowDown') { | ||
event.preventDefault(); | ||
} | ||
var cursor = _this.state.cursor; | ||
@@ -270,6 +274,10 @@ | ||
if (event.key === 'Enter') { | ||
!_this.state.activeCursorItem.disabled && _this.addItem(_this.state.activeCursorItem); | ||
var currentItem = _this.searchResults()[cursor]; | ||
if (currentItem && !currentItem.disabled) { | ||
_this.addItem(currentItem); | ||
} | ||
} | ||
if (event.key === 'ArrowUp' && cursor > 0) { | ||
if (event.key === 'ArrowUp' && cursor >= 0) { | ||
_this.setState(function (prevState) { | ||
@@ -280,5 +288,5 @@ return { | ||
}); | ||
} | ||
event.preventDefault(); | ||
} else if (event.key === 'ArrowDown' && cursor < _this.searchResults().length + 1) { | ||
if (event.key === 'ArrowDown') { | ||
_this.setState(function (prevState) { | ||
@@ -289,4 +297,2 @@ return { | ||
}); | ||
event.preventDefault(); | ||
} | ||
@@ -299,3 +305,4 @@ }); | ||
search: '', | ||
selectBounds: {} | ||
selectBounds: {}, | ||
cursor: 0 | ||
}; | ||
@@ -474,2 +481,3 @@ _this.methods = { | ||
dropdownHeight: '300px', | ||
autoFocus: true, | ||
onDropdownOpen: function onDropdownOpen() { | ||
@@ -500,4 +508,4 @@ return undefined; | ||
return color; | ||
}, "3c;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":"AA0XsC","file":"../src/index.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from '@emotion/styled';\nimport ClickOutHandler from 'react-onclickout';\n\nimport Content from './components/Content';\nimport Dropdown from './components/Dropdown';\nimport Loading from './components/Loading';\nimport Clear from './components/Clear';\nimport Separator from './components/Separator';\nimport DropdownHandle from './components/DropdownHandle';\n\nconst debounce = (fn, delay = 0) => {\n  let timerId;\n\n  return (...args) => {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeout(() => {\n      fn(...args);\n      timerId = null;\n    }, delay);\n  };\n};\n\nexport class Select extends React.Component {\n  static propTypes = {\n    onChange: PropTypes.func.isRequired,\n    onDropdownClose: PropTypes.func,\n    onDropdownOpen: PropTypes.func,\n    onClearAll: PropTypes.func,\n    onSelectAll: PropTypes.func,\n    values: PropTypes.array,\n    options: PropTypes.array.isRequired,\n    keepOpen: PropTypes.bool,\n    dropdownGap: PropTypes.number,\n    multi: PropTypes.bool,\n    placeholder: PropTypes.string,\n    addPlaceholder: PropTypes.string,\n    disabled: PropTypes.bool,\n    className: PropTypes.string,\n    loading: PropTypes.bool,\n    clearable: PropTypes.bool,\n    separator: PropTypes.bool,\n    dropdownHandle: PropTypes.bool,\n    searchBy: PropTypes.string,\n    closeOnScroll: PropTypes.bool,\n    openOnTop: PropTypes.bool,\n    style: PropTypes.object,\n    contentRenderer: PropTypes.func,\n    dropdownRenderer: PropTypes.func,\n    itemRenderer: PropTypes.func,\n    noDataRenderer: PropTypes.func,\n    optionRenderer: PropTypes.func,\n    inputRenderer: PropTypes.func,\n    loadingRenderer: PropTypes.func,\n    clearRenderer: PropTypes.func,\n    separatorRenderer: PropTypes.func,\n    dropdownHandleRenderer: PropTypes.func\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      dropdown: false,\n      values: props.values,\n      search: '',\n      selectBounds: {}\n    };\n\n    this.methods = {\n      removeItem: this.removeItem,\n      dropDown: this.dropDown,\n      addItem: this.addItem,\n      setSearch: this.setSearch,\n      getInputSize: this.getInputSize,\n      toggleSelectAll: this.toggleSelectAll,\n      clearAll: this.clearAll,\n      selectAll: this.selectAll,\n      searchResults: this.searchResults,\n      getSelectRef: this.getSelectRef,\n      isSelected: this.isSelected,\n      getSelectBounds: this.getSelectBounds,\n      areAllSelected: this.areAllSelected,\n      handleKeyDown: this.handleKeyDown,\n      activeCursorItem: this.activeCursorItem\n    };\n\n    this.select = React.createRef();\n  }\n\n  componentDidMount() {\n    window.addEventListener('resize', debounce(this.updateSelectBounds));\n    window.addEventListener('scroll', debounce(this.onScroll));\n\n    this.props.onChange(this.state.values);\n\n    this.dropDown('close');\n\n    if (this.select) {\n      this.updateSelectBounds();\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (prevState.values !== this.state.values) {\n      this.props.onChange(this.state.values);\n      this.updateSelectBounds();\n    }\n\n    if (prevState.values !== this.state.values && this.props.closeOnSelect) {\n      this.dropDown('close');\n    }\n\n    if (prevProps.multi !== this.props.multi) {\n      this.updateSelectBounds();\n    }\n\n    if (prevState.dropdown && prevState.dropdown !== this.state.dropdown) {\n      this.onDropdownClose();\n    }\n\n    if (!prevState.dropdown && prevState.dropdown !== this.state.dropdown) {\n      this.props.onDropdownOpen();\n    }\n  }\n\n  componentWillUnmount() {\n    window.removeEventListener(\n      'resize',\n      debounce(this.updateSelectBounds, this.props.debounceDelay)\n    );\n    window.removeEventListener('scroll', debounce(this.onScroll, this.props.debounceDelay));\n  }\n\n  onDropdownClose = () => {\n    this.setState({ cursor: null });\n    this.props.onDropdownClose();\n  };\n\n  onScroll = () => {\n    if (this.props.closeOnScroll) {\n      this.dropDown('close');\n    }\n\n    this.updateSelectBounds();\n  };\n\n  updateSelectBounds = () =>\n    this.select.current &&\n    this.setState({\n      selectBounds: this.select.current.getBoundingClientRect()\n    });\n\n  getSelectBounds = () => this.state.selectBounds;\n\n  dropDown = (action = 'toggle') => {\n    if (this.props.keepOpen) {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'close') {\n      this.select.current.blur();\n      return this.setState({ dropdown: false, search: '' });\n    }\n\n    if (action === 'open') {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'toggle') {\n      this.select.current.focus();\n      return this.setState({ dropdown: !this.state.dropdown });\n    }\n\n    return false;\n  };\n\n  getSelectRef = () => this.select.current;\n\n  addItem = (item) => {\n    if (this.props.multi) {\n      if (this.state.values.indexOf(item) !== -1) {\n        return this.removeItem(null, item, false);\n      }\n\n      this.setState({\n        values: [...this.state.values, item]\n      });\n    } else {\n      this.setState({\n        values: [item],\n        dropdown: false,\n        search: ''\n      });\n    }\n\n    return true;\n  };\n\n  removeItem = (event, item, close = false) => {\n    if (event && close) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.dropDown('close');\n    }\n\n    this.setState({\n      values: this.state.values.filter(\n        (values) => values[this.props.valueField] !== item[this.props.valueField]\n      )\n    });\n  };\n\n  setSearch = (event) => {\n    this.setState({\n      cursor: null\n    });\n\n    this.setState({\n      search: event.target.value\n    });\n  };\n\n  getInputSize = () => {\n    if (this.state.search) {\n      return this.state.search.length;\n    }\n\n    if (this.state.values.length > 0) {\n      return this.props.addPlaceholder.length;\n    }\n\n    return this.props.placeholder.length;\n  };\n\n  toggleSelectAll = () => {\n    return this.setState({\n      values: this.state.values.length === 0 ? this.selectAll() : this.clearAll()\n    });\n  };\n\n  clearAll = () => {\n    this.props.onClearAll();\n    this.setState({\n      values: []\n    });\n  };\n\n  selectAll = () => {\n    this.props.onSelectAll();\n    return this.setState({\n      values: this.props.options.filter((option) => !option.disabled)\n    });\n  };\n\n  isSelected = (option) => this.state.values.indexOf(option) !== -1;\n\n  areAllSelected = () =>\n    this.state.values.length === this.props.options.filter((option) => !option.disabled).length;\n\n  searchResults = () => {\n    const regexp = new RegExp(this.state.search, 'i');\n\n    return this.props.options.filter((item) =>\n      regexp.test(item[this.props.searchBy] || item[[this.props.labelField]])\n    );\n  };\n\n  activeCursorItem = (activeCursorItem) =>\n    this.setState({\n      activeCursorItem\n    });\n\n  handleKeyDown = (event) => {\n    const { cursor } = this.state;\n\n    if (event.key === 'Escape') {\n      this.dropDown('close');\n    }\n\n    if (event.key === 'Enter') {\n      !this.state.activeCursorItem.disabled && this.addItem(this.state.activeCursorItem);\n    }\n\n    if (event.key === 'ArrowUp' && cursor > 0) {\n      this.setState((prevState) => ({\n        cursor: prevState.cursor - 1\n      }));\n      event.preventDefault();\n    } else if (event.key === 'ArrowDown' && cursor < this.searchResults().length + 1) {\n      this.setState((prevState) => ({\n        cursor: prevState.cursor + 1\n      }));\n      event.preventDefault();\n    }\n  };\n\n  render() {\n    return (\n      <ClickOutHandler onClickOut={() => this.dropDown('close')}>\n        <ReactDropdownSelect\n          onKeyDown={this.handleKeyDown}\n          tabIndex=\"0\"\n          style={this.props.style}\n          ref={this.select}\n          disabled={this.props.disabled}\n          className={this.props.className}\n          color={this.props.color}>\n          <Content parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n\n          {this.props.loading && <Loading parentProps={this.props} />}\n\n          {this.props.clearable && (\n            <Clear parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n          )}\n\n          {this.props.separator && (\n            <Separator\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.props.dropdownHandle && (\n            <DropdownHandle\n              onCLick={() => this.select.current.focus()}\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.state.dropdown && (\n            <Dropdown\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n        </ReactDropdownSelect>\n      </ClickOutHandler>\n    );\n  }\n}\n\nSelect.defaultProps = {\n  addPlaceholder: '+',\n  placeholder: 'Select...',\n  values: [],\n  options: [],\n  multi: false,\n  disabled: false,\n  searchBy: 'label',\n  clearable: true,\n  dropdownHandle: true,\n  separator: true,\n  keepOpen: undefined,\n  noDataLabel: 'No data',\n  dropdownGap: 5,\n  closeOnScroll: false,\n  debounceDelay: 0,\n  labelField: 'label',\n  valueField: 'value',\n  color: '#0074D9',\n  keepSelectedInList: true,\n  closeOnSelect: false,\n  openOnTop: false,\n  dropdownHeight: '300px',\n  onDropdownOpen: () => undefined,\n  onDropdownClose: () => undefined,\n  onClearAll: () => undefined,\n  onSelectAll: () => undefined\n};\n\nconst ReactDropdownSelect = styled.div`\n  position: relative;\n  display: flex;\n  border: 1px solid #ccc;\n  width: 100%;\n  border-radius: 2px;\n  padding: 2px 5px;\n  flex-direction: row;\n  align-items: center;\n  min-height: 36px;\n  ${({ disabled }) =>\n    disabled ? 'cursor: not-allowed;pointer-events: none;opacity: 0.3;' : 'pointer-events: all;'}\n\n  :hover, \n  :focus-within {\n    border-color: ${({ color }) => color};\n  }\n\n  :focus {\n    outline: 0;\n    box-shadow: 0 0 0 3px ${({ color }) => color}3c;\n  }\n`;\n\nexport default Select;\n"]} */")); | ||
}, "3c;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/index.js"],"names":[],"mappings":"AAoYsC","file":"../src/index.js","sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport styled from '@emotion/styled';\nimport ClickOutHandler from 'react-onclickout';\n\nimport Content from './components/Content';\nimport Dropdown from './components/Dropdown';\nimport Loading from './components/Loading';\nimport Clear from './components/Clear';\nimport Separator from './components/Separator';\nimport DropdownHandle from './components/DropdownHandle';\n\nconst debounce = (fn, delay = 0) => {\n  let timerId;\n\n  return (...args) => {\n    if (timerId) {\n      clearTimeout(timerId);\n    }\n    timerId = setTimeout(() => {\n      fn(...args);\n      timerId = null;\n    }, delay);\n  };\n};\n\nexport class Select extends React.Component {\n  static propTypes = {\n    onChange: PropTypes.func.isRequired,\n    onDropdownClose: PropTypes.func,\n    onDropdownOpen: PropTypes.func,\n    onClearAll: PropTypes.func,\n    onSelectAll: PropTypes.func,\n    values: PropTypes.array,\n    options: PropTypes.array.isRequired,\n    keepOpen: PropTypes.bool,\n    dropdownGap: PropTypes.number,\n    multi: PropTypes.bool,\n    placeholder: PropTypes.string,\n    addPlaceholder: PropTypes.string,\n    disabled: PropTypes.bool,\n    className: PropTypes.string,\n    loading: PropTypes.bool,\n    clearable: PropTypes.bool,\n    separator: PropTypes.bool,\n    dropdownHandle: PropTypes.bool,\n    searchBy: PropTypes.string,\n    closeOnScroll: PropTypes.bool,\n    openOnTop: PropTypes.bool,\n    style: PropTypes.object,\n    contentRenderer: PropTypes.func,\n    dropdownRenderer: PropTypes.func,\n    itemRenderer: PropTypes.func,\n    noDataRenderer: PropTypes.func,\n    optionRenderer: PropTypes.func,\n    inputRenderer: PropTypes.func,\n    loadingRenderer: PropTypes.func,\n    clearRenderer: PropTypes.func,\n    separatorRenderer: PropTypes.func,\n    dropdownHandleRenderer: PropTypes.func\n  };\n\n  constructor(props) {\n    super(props);\n\n    this.state = {\n      dropdown: false,\n      values: props.values,\n      search: '',\n      selectBounds: {},\n      cursor: 0\n    };\n\n    this.methods = {\n      removeItem: this.removeItem,\n      dropDown: this.dropDown,\n      addItem: this.addItem,\n      setSearch: this.setSearch,\n      getInputSize: this.getInputSize,\n      toggleSelectAll: this.toggleSelectAll,\n      clearAll: this.clearAll,\n      selectAll: this.selectAll,\n      searchResults: this.searchResults,\n      getSelectRef: this.getSelectRef,\n      isSelected: this.isSelected,\n      getSelectBounds: this.getSelectBounds,\n      areAllSelected: this.areAllSelected,\n      handleKeyDown: this.handleKeyDown,\n      activeCursorItem: this.activeCursorItem\n    };\n\n    this.select = React.createRef();\n  }\n\n  componentDidMount() {\n    window.addEventListener('resize', debounce(this.updateSelectBounds));\n    window.addEventListener('scroll', debounce(this.onScroll));\n\n    this.props.onChange(this.state.values);\n\n    this.dropDown('close');\n\n    if (this.select) {\n      this.updateSelectBounds();\n    }\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (prevState.values !== this.state.values) {\n      this.props.onChange(this.state.values);\n      this.updateSelectBounds();\n    }\n\n    if (prevState.values !== this.state.values && this.props.closeOnSelect) {\n      this.dropDown('close');\n    }\n\n    if (prevProps.multi !== this.props.multi) {\n      this.updateSelectBounds();\n    }\n\n    if (prevState.dropdown && prevState.dropdown !== this.state.dropdown) {\n      this.onDropdownClose();\n    }\n\n    if (!prevState.dropdown && prevState.dropdown !== this.state.dropdown) {\n      this.props.onDropdownOpen();\n    }\n  }\n\n  componentWillUnmount() {\n    window.removeEventListener(\n      'resize',\n      debounce(this.updateSelectBounds, this.props.debounceDelay)\n    );\n    window.removeEventListener('scroll', debounce(this.onScroll, this.props.debounceDelay));\n  }\n\n  onDropdownClose = () => {\n    this.setState({ cursor: 0 });\n    this.props.onDropdownClose();\n  };\n\n  onScroll = () => {\n    if (this.props.closeOnScroll) {\n      this.dropDown('close');\n    }\n\n    this.updateSelectBounds();\n  };\n\n  updateSelectBounds = () =>\n    this.select.current &&\n    this.setState({\n      selectBounds: this.select.current.getBoundingClientRect()\n    });\n\n  getSelectBounds = () => this.state.selectBounds;\n\n  dropDown = (action = 'toggle') => {\n    if (this.props.keepOpen) {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'close') {\n      this.select.current.blur();\n      return this.setState({ dropdown: false, search: '' });\n    }\n\n    if (action === 'open') {\n      return this.setState({ dropdown: true });\n    }\n\n    if (action === 'toggle') {\n      this.select.current.focus();\n      return this.setState({ dropdown: !this.state.dropdown });\n    }\n\n    return false;\n  };\n\n  getSelectRef = () => this.select.current;\n\n  addItem = (item) => {\n    if (this.props.multi) {\n      if (this.state.values.indexOf(item) !== -1) {\n        return this.removeItem(null, item, false);\n      }\n\n      this.setState({\n        values: [...this.state.values, item]\n      });\n    } else {\n      this.setState({\n        values: [item],\n        dropdown: false,\n        search: ''\n      });\n    }\n\n    return true;\n  };\n\n  removeItem = (event, item, close = false) => {\n    if (event && close) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.dropDown('close');\n    }\n\n    this.setState({\n      values: this.state.values.filter(\n        (values) => values[this.props.valueField] !== item[this.props.valueField]\n      )\n    });\n  };\n\n  setSearch = (event) => {\n    this.setState({\n      cursor: null\n    });\n\n    this.setState({\n      search: event.target.value\n    });\n  };\n\n  getInputSize = () => {\n    if (this.state.search) {\n      return this.state.search.length;\n    }\n\n    if (this.state.values.length > 0) {\n      return this.props.addPlaceholder.length;\n    }\n\n    return this.props.placeholder.length;\n  };\n\n  toggleSelectAll = () => {\n    return this.setState({\n      values: this.state.values.length === 0 ? this.selectAll() : this.clearAll()\n    });\n  };\n\n  clearAll = () => {\n    this.props.onClearAll();\n    this.setState({\n      values: []\n    });\n  };\n\n  selectAll = () => {\n    this.props.onSelectAll();\n    return this.setState({\n      values: this.props.options.filter((option) => !option.disabled)\n    });\n  };\n\n  isSelected = (option) => this.state.values.indexOf(option) !== -1;\n\n  areAllSelected = () =>\n    this.state.values.length === this.props.options.filter((option) => !option.disabled).length;\n\n  searchResults = () => {\n    const regexp = new RegExp(this.state.search, 'i');\n\n    return this.props.options.filter((item) =>\n      regexp.test(item[this.props.searchBy] || item[[this.props.labelField]])\n    );\n  };\n\n  activeCursorItem = (activeCursorItem) =>\n    this.setState({\n      activeCursorItem\n    });\n\n  handleKeyDown = (event) => {\n\n    if(event.key === 'ArrowUp' || event.key === 'ArrowDown' ) {\n      event.preventDefault();\n    }\n\n    const { cursor } = this.state;\n\n    if (event.key === 'Escape') {\n      this.dropDown('close');\n    }\n\n    if (event.key === 'Enter') {\n      const currentItem = this.searchResults()[cursor];\n      if (currentItem && !currentItem.disabled) {\n        this.addItem(currentItem);\n      }\n    }\n\n    if (event.key === 'ArrowUp' && cursor >= 0) {\n      this.setState((prevState) => ({\n        cursor: prevState.cursor - 1\n      }));\n    }\n\n    if (event.key === 'ArrowDown') {\n      this.setState((prevState) => ({\n        cursor: prevState.cursor + 1\n      }));\n    }\n  };\n\n  render() {\n    return (\n      <ClickOutHandler onClickOut={() => this.dropDown('close')}>\n        <ReactDropdownSelect\n          onKeyDown={this.handleKeyDown}\n          tabIndex=\"0\"\n          style={this.props.style}\n          ref={this.select}\n          disabled={this.props.disabled}\n          className={this.props.className}\n          color={this.props.color}>\n          <Content parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n\n          {this.props.loading && <Loading parentProps={this.props} />}\n\n          {this.props.clearable && (\n            <Clear parentProps={this.props} parentState={this.state} parentMethods={this.methods} />\n          )}\n\n          {this.props.separator && (\n            <Separator\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.props.dropdownHandle && (\n            <DropdownHandle\n              onCLick={() => this.select.current.focus()}\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n\n          {this.state.dropdown && (\n            <Dropdown\n              parentProps={this.props}\n              parentState={this.state}\n              parentMethods={this.methods}\n            />\n          )}\n        </ReactDropdownSelect>\n      </ClickOutHandler>\n    );\n  }\n}\n\nSelect.defaultProps = {\n  addPlaceholder: '+',\n  placeholder: 'Select...',\n  values: [],\n  options: [],\n  multi: false,\n  disabled: false,\n  searchBy: 'label',\n  clearable: true,\n  dropdownHandle: true,\n  separator: true,\n  keepOpen: undefined,\n  noDataLabel: 'No data',\n  dropdownGap: 5,\n  closeOnScroll: false,\n  debounceDelay: 0,\n  labelField: 'label',\n  valueField: 'value',\n  color: '#0074D9',\n  keepSelectedInList: true,\n  closeOnSelect: false,\n  openOnTop: false,\n  dropdownHeight: '300px',\n  autoFocus: true,\n  onDropdownOpen: () => undefined,\n  onDropdownClose: () => undefined,\n  onClearAll: () => undefined,\n  onSelectAll: () => undefined\n};\n\nconst ReactDropdownSelect = styled.div`\n  position: relative;\n  display: flex;\n  border: 1px solid #ccc;\n  width: 100%;\n  border-radius: 2px;\n  padding: 2px 5px;\n  flex-direction: row;\n  align-items: center;\n  min-height: 36px;\n  ${({ disabled }) =>\n    disabled ? 'cursor: not-allowed;pointer-events: none;opacity: 0.3;' : 'pointer-events: all;'}\n\n  :hover, \n  :focus-within {\n    border-color: ${({ color }) => color};\n  }\n\n  :focus {\n    outline: 0;\n    box-shadow: 0 0 0 3px ${({ color }) => color}3c;\n  }\n`;\n\nexport default Select;\n"]} */")); | ||
var _default = Select; | ||
exports.default = _default; |
{ | ||
"name": "react-dropdown-select", | ||
"version": "1.3.3", | ||
"version": "1.3.4", | ||
"description": "Customizable dropdown select for react", | ||
@@ -5,0 +5,0 @@ "main": "dist/index.js", |
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
82160
-4.35%937
-3%