react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
451 lines (400 loc) • 40.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.PicklistItem = undefined;
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _reactDom = require('react-dom');
var _reactDom2 = _interopRequireDefault(_reactDom);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _uuid = require('uuid');
var _uuid2 = _interopRequireDefault(_uuid);
var _FormElement = require('./FormElement');
var _FormElement2 = _interopRequireDefault(_FormElement);
var _Icon = require('./Icon');
var _Icon2 = _interopRequireDefault(_Icon);
var _DropdownMenu = require('./DropdownMenu');
var _DropdownMenu2 = _interopRequireDefault(_DropdownMenu);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var Picklist = function (_Component) {
(0, _inherits3.default)(Picklist, _Component);
function Picklist(props) {
(0, _classCallCheck3.default)(this, Picklist);
var _this = (0, _possibleConstructorReturn3.default)(this, (Picklist.__proto__ || (0, _getPrototypeOf2.default)(Picklist)).call(this, props));
_this.state = {
id: 'form-element-' + (0, _uuid2.default)(),
opened: props.defaultOpened,
value: props.defaultValue
};
_this.picklistButtonRef = _this.picklistButtonRef.bind(_this);
_this.dropdownRef = _this.dropdownRef.bind(_this);
return _this;
}
(0, _createClass3.default)(Picklist, [{
key: 'componentDidUpdate',
value: function componentDidUpdate(prevProps, prevState) {
if (this.props.onValueChange && prevState.value !== this.state.value) {
this.props.onValueChange(this.state.value, prevState.value);
}
if (this.props.focusOnOpen && prevState.opened === false && this.state.opened === true) {
this.focusToTargetItemEl();
}
}
}, {
key: 'onClick',
value: function onClick(e) {
var onDropDownClick = this.props.onDropDownClick;
this.setState(function (state) {
return { opened: !state.opened };
});
if (onDropDownClick) onDropDownClick(e);
}
}, {
key: 'onPicklistItemClick',
value: function onPicklistItemClick(item, e) {
var _this2 = this;
this.setState({ value: item.value });
if (this.props.onChange) {
this.props.onChange(e, item.value);
}
if (this.props.onSelect) {
this.props.onSelect(item);
}
setTimeout(function () {
_this2.setState({ opened: false });
if (_this2.props.onComplete) {
_this2.props.onComplete();
}
var picklistButtonEl = _reactDom2.default.findDOMNode(_this2.picklistButton);
if (picklistButtonEl) {
picklistButtonEl.focus();
}
}, 200);
e.preventDefault();
e.stopPropagation();
}
}, {
key: 'onPicklistClose',
value: function onPicklistClose() {
var picklistButtonEl = _reactDom2.default.findDOMNode(this.picklistButton);
picklistButtonEl.focus();
this.setState({ opened: false });
}
}, {
key: 'onBlur',
value: function onBlur() {
var _this3 = this;
setTimeout(function () {
if (!_this3.isFocusedInComponent()) {
_this3.setState({ opened: false });
if (_this3.props.onBlur) {
_this3.props.onBlur();
}
if (_this3.props.onComplete) {
_this3.props.onComplete();
}
}
}, 10);
}
}, {
key: 'onKeydown',
value: function onKeydown(e) {
if (e.keyCode === 40) {
// down
e.preventDefault();
e.stopPropagation();
if (!this.state.opened) {
this.setState({ opened: true });
} else {
this.focusToTargetItemEl();
}
} else if (e.keyCode === 27) {
// ESC
e.preventDefault();
e.stopPropagation();
this.setState({ opened: false });
if (this.props.onComplete) {
this.props.onComplete();
}
}
if (this.props.onKeyDown) {
this.props.onKeyDown(e);
}
}
}, {
key: 'onDropdownScroll',
value: function onDropdownScroll(page) {
if (this.props.onScroll) {
this.props.onScroll(page);
}
}
}, {
key: 'getSelectedValue',
value: function getSelectedValue() {
var _props = this.props,
defaultValue = _props.defaultValue,
value = _props.value;
return typeof value !== 'undefined' ? value : typeof this.state.value !== 'undefined' ? this.state.value : defaultValue;
}
}, {
key: 'getSelectedItemLabel',
value: function getSelectedItemLabel() {
var selectedValue = this.getSelectedValue();
var selected = null;
_react2.default.Children.forEach(this.props.children, function (item) {
if (item.props.value === selectedValue) {
selected = item.props.label || item.props.children;
}
});
return selected || this.props.selectedText;
}
}, {
key: 'isFocusedInComponent',
value: function isFocusedInComponent() {
var rootEl = _reactDom2.default.findDOMNode(this);
var targetEl = document.activeElement;
while (targetEl && targetEl !== rootEl) {
targetEl = targetEl.parentNode;
}
return !!targetEl;
}
}, {
key: 'focusToTargetItemEl',
value: function focusToTargetItemEl() {
var dropdownEl = _reactDom2.default.findDOMNode(this.dropdown);
if (!dropdownEl) return;
var firstItemEl = dropdownEl.querySelector('.slds-is-selected > .react-slds-menuitem[tabIndex]') || dropdownEl.querySelector('.react-slds-menuitem[tabIndex]');
if (firstItemEl) {
firstItemEl.focus();
}
}
}, {
key: 'picklistButtonRef',
value: function picklistButtonRef(ref) {
this.picklistButton = ref;
}
}, {
key: 'dropdownRef',
value: function dropdownRef(ref) {
this.dropdown = ref;
}
}, {
key: 'renderPicklist',
value: function renderPicklist(props) {
var className = props.className,
id = props.id,
htmlAttributes = props.htmlAttributes,
buttonClassName = props.buttonClassName,
pprops = (0, _objectWithoutProperties3.default)(props, ['className', 'id', 'htmlAttributes', 'buttonClassName']);
delete pprops.initialValue;
delete pprops.onUpdate;
delete pprops.valid;
delete pprops.invalid;
delete pprops.dirty;
delete pprops.pristine;
delete pprops.active;
delete pprops.touched;
delete pprops.visited;
delete pprops.maxHeight;
delete pprops.onValueChange;
delete pprops.defaultOpened;
delete pprops.menuSize;
delete pprops.selectedText;
delete pprops.onBlur;
delete pprops.hasMore;
delete pprops.onScroll;
delete pprops.resetPageLoader;
delete pprops.pageStart;
delete pprops.useNone;
delete pprops.noneText;
delete pprops.align;
delete pprops.focusOnOpen;
delete pprops.onDropDownClick;
var picklistClassNames = (0, _classnames2.default)(className, 'slds-picklist');
return _react2.default.createElement(
'div',
{ className: picklistClassNames, 'aria-expanded': this.state.opened },
_react2.default.createElement(
'button',
(0, _extends3.default)({
id: id,
ref: this.picklistButtonRef,
className: (0, _classnames2.default)('slds-picklist__label slds-button slds-button--neutral', buttonClassName),
type: 'button',
'aria-haspopup': true,
onClick: this.onClick.bind(this),
onBlur: this.onBlur.bind(this),
onKeyDown: this.onKeydown.bind(this)
}, pprops),
_react2.default.createElement(
'span',
(0, _extends3.default)({ className: 'slds-truncate' }, htmlAttributes),
this.getSelectedItemLabel() || _react2.default.createElement(
'span',
null,
'\xA0'
)
),
_react2.default.createElement(_Icon2.default, { icon: 'down' })
)
);
}
}, {
key: 'renderNoneMenuItem',
value: function renderNoneMenuItem() {
var _props2 = this.props,
required = _props2.required,
noneText = _props2.noneText;
return _react2.default.createElement(PicklistItem, {
disabled: required,
value: null,
onBlur: this.onBlur.bind(this),
selected: this.getSelectedValue() === null,
label: noneText
});
}
}, {
key: 'renderDropdown',
value: function renderDropdown() {
var _props3 = this.props,
menuSize = _props3.menuSize,
children = _props3.children,
maxHeight = _props3.maxHeight,
hasMore = _props3.hasMore,
pageStart = _props3.pageStart,
resetPageLoader = _props3.resetPageLoader,
useNone = _props3.useNone,
align = _props3.align;
return this.state.opened ? _react2.default.createElement(
_DropdownMenu2.default,
{
ref: this.dropdownRef,
maxHeight: maxHeight,
size: menuSize,
onMenuItemClick: this.onPicklistItemClick.bind(this),
onMenuClose: this.onPicklistClose.bind(this),
hasMore: hasMore,
pageStart: pageStart,
resetPageLoader: resetPageLoader,
onScroll: this.onDropdownScroll.bind(this),
align: align,
onBlur: this.onBlur.bind(this)
},
useNone && this.renderNoneMenuItem(),
_react2.default.Children.map(children, this.renderPicklistItem.bind(this))
) : _react2.default.createElement('div', { ref: this.dropdownRef });
}
}, {
key: 'renderPicklistItem',
value: function renderPicklistItem(item) {
var selected = item.props.value === this.getSelectedValue();
var onBlur = this.onBlur.bind(this);
return _react2.default.cloneElement(item, { selected: selected, onBlur: onBlur });
}
}, {
key: 'render',
value: function render() {
var id = this.props.id || this.state.id;
var _props4 = this.props,
label = _props4.label,
required = _props4.required,
error = _props4.error,
totalCols = _props4.totalCols,
cols = _props4.cols,
tooltip = _props4.tooltip,
props = (0, _objectWithoutProperties3.default)(_props4, ['label', 'required', 'error', 'totalCols', 'cols', 'tooltip']);
var dropdown = this.renderDropdown();
var formElemProps = { id: id, label: label, required: required, error: error, totalCols: totalCols, cols: cols, dropdown: dropdown, tooltip: tooltip };
return _react2.default.createElement(
_FormElement2.default,
formElemProps,
this.renderPicklist((0, _extends3.default)({}, props, { id: id }))
);
}
}]);
return Picklist;
}(_react.Component);
exports.default = Picklist;
Picklist.defaultProps = {
maxHeight: 10,
focusOnOpen: true
};
Picklist.propTypes = {
id: _propTypes2.default.string,
className: _propTypes2.default.string,
label: _propTypes2.default.string,
required: _propTypes2.default.bool,
error: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.string, _propTypes2.default.shape({
message: _propTypes2.default.string
})]),
totalCols: _propTypes2.default.number,
cols: _propTypes2.default.number,
name: _propTypes2.default.string,
value: _propTypes2.default.any,
defaultValue: _propTypes2.default.any,
selectedText: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.node]),
defaultOpened: _propTypes2.default.bool,
onChange: _propTypes2.default.func,
onDropDownClick: _propTypes2.default.func,
onValueChange: _propTypes2.default.func,
onSelect: _propTypes2.default.func,
onComplete: _propTypes2.default.func,
onKeyDown: _propTypes2.default.func,
onBlur: _propTypes2.default.func,
menuSize: _propTypes2.default.string,
children: _propTypes2.default.node,
maxHeight: _propTypes2.default.oneOf([5, 7, 10]),
htmlAttributes: _propTypes2.default.object,
hasMore: _propTypes2.default.bool,
pageStart: _propTypes2.default.number,
resetPageLoader: _propTypes2.default.bool,
onScroll: _propTypes2.default.func,
useNone: _propTypes2.default.bool,
noneText: _propTypes2.default.string,
align: _propTypes2.default.oneOf(['left', 'center', 'right']),
focusOnOpen: _propTypes2.default.bool,
buttonClassName: _propTypes2.default.string,
tooltip: _propTypes2.default.element
};
Picklist.isFormElement = true;
var PicklistItem = function PicklistItem(_ref) {
var label = _ref.label,
selected = _ref.selected,
children = _ref.children,
props = (0, _objectWithoutProperties3.default)(_ref, ['label', 'selected', 'children']);
return _react2.default.createElement(
_DropdownMenu.DropdownMenuItem,
(0, _extends3.default)({
icon: selected ? 'check' : 'none',
role: 'menuitemradio',
selected: selected
}, props),
label || children
);
};
exports.PicklistItem = PicklistItem;
PicklistItem.propTypes = {
label: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.number]),
selected: _propTypes2.default.bool,
value: _propTypes2.default.any,
children: _propTypes2.default.node
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Picklist.js"],"names":["Picklist","props","state","id","opened","defaultOpened","value","defaultValue","picklistButtonRef","bind","dropdownRef","prevProps","prevState","onValueChange","focusOnOpen","focusToTargetItemEl","e","onDropDownClick","setState","item","onChange","onSelect","setTimeout","onComplete","picklistButtonEl","findDOMNode","picklistButton","focus","preventDefault","stopPropagation","isFocusedInComponent","onBlur","keyCode","onKeyDown","page","onScroll","selectedValue","getSelectedValue","selected","Children","forEach","children","label","selectedText","rootEl","targetEl","document","activeElement","parentNode","dropdownEl","dropdown","firstItemEl","querySelector","ref","className","htmlAttributes","buttonClassName","pprops","initialValue","onUpdate","valid","invalid","dirty","pristine","active","touched","visited","maxHeight","menuSize","hasMore","resetPageLoader","pageStart","useNone","noneText","align","picklistClassNames","onClick","onKeydown","getSelectedItemLabel","required","onPicklistItemClick","onPicklistClose","onDropdownScroll","renderNoneMenuItem","map","renderPicklistItem","cloneElement","error","totalCols","cols","tooltip","renderDropdown","formElemProps","renderPicklist","defaultProps","propTypes","string","bool","oneOfType","shape","message","number","name","any","node","func","oneOf","object","element","isFormElement","PicklistItem"],"mappings":"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","file":"Picklist.js","sourcesContent":["import React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport classnames from 'classnames';\nimport uuid from 'uuid';\nimport FormElement from './FormElement';\nimport Icon from './Icon';\nimport { default as DropdownMenu, DropdownMenuItem } from './DropdownMenu';\n\nexport default class Picklist extends Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      id: `form-element-${uuid()}`,\n      opened: props.defaultOpened,\n      value: props.defaultValue,\n    };\n    this.picklistButtonRef = this.picklistButtonRef.bind(this);\n    this.dropdownRef = this.dropdownRef.bind(this);\n  }\n\n  componentDidUpdate(prevProps, prevState) {\n    if (this.props.onValueChange && prevState.value !== this.state.value) {\n      this.props.onValueChange(this.state.value, prevState.value);\n    }\n    if (this.props.focusOnOpen && prevState.opened === false && this.state.opened === true) {\n      this.focusToTargetItemEl();\n    }\n  }\n\n  onClick(e) {\n    const { onDropDownClick } = this.props;\n    this.setState((state => ({ opened: !state.opened })));\n    if (onDropDownClick) onDropDownClick(e);\n  }\n\n  onPicklistItemClick(item, e) {\n    this.setState({ value: item.value });\n    if (this.props.onChange) {\n      this.props.onChange(e, item.value);\n    }\n    if (this.props.onSelect) {\n      this.props.onSelect(item);\n    }\n    setTimeout(() => {\n      this.setState({ opened: false });\n      if (this.props.onComplete) {\n        this.props.onComplete();\n      }\n      const picklistButtonEl = ReactDOM.findDOMNode(this.picklistButton);\n      if (picklistButtonEl) {\n        picklistButtonEl.focus();\n      }\n    }, 200);\n    e.preventDefault();\n    e.stopPropagation();\n  }\n\n  onPicklistClose() {\n    const picklistButtonEl = ReactDOM.findDOMNode(this.picklistButton);\n    picklistButtonEl.focus();\n    this.setState({ opened: false });\n  }\n\n  onBlur() {\n    setTimeout(() => {\n      if (!this.isFocusedInComponent()) {\n        this.setState({ opened: false });\n        if (this.props.onBlur) {\n          this.props.onBlur();\n        }\n        if (this.props.onComplete) {\n          this.props.onComplete();\n        }\n      }\n    }, 10);\n  }\n\n  onKeydown(e) {\n    if (e.keyCode === 40) {\n      // down\n      e.preventDefault();\n      e.stopPropagation();\n      if (!this.state.opened) {\n        this.setState({ opened: true });\n      } else {\n        this.focusToTargetItemEl();\n      }\n    } else if (e.keyCode === 27) {\n      // ESC\n      e.preventDefault();\n      e.stopPropagation();\n      this.setState({ opened: false });\n      if (this.props.onComplete) {\n        this.props.onComplete();\n      }\n    }\n    if (this.props.onKeyDown) {\n      this.props.onKeyDown(e);\n    }\n  }\n\n  onDropdownScroll(page) {\n    if (this.props.onScroll) {\n      this.props.onScroll(page);\n    }\n  }\n\n  getSelectedValue() {\n    const { defaultValue, value } = this.props;\n    return typeof value !== 'undefined'\n      ? value\n      : typeof this.state.value !== 'undefined' ? this.state.value : defaultValue;\n  }\n\n  getSelectedItemLabel() {\n    const selectedValue = this.getSelectedValue();\n    let selected = null;\n    React.Children.forEach(this.props.children, item => {\n      if (item.props.value === selectedValue) {\n        selected = item.props.label || item.props.children;\n      }\n    });\n    return selected || this.props.selectedText;\n  }\n\n  isFocusedInComponent() {\n    const rootEl = ReactDOM.findDOMNode(this);\n    let targetEl = document.activeElement;\n    while (targetEl && targetEl !== rootEl) {\n      targetEl = targetEl.parentNode;\n    }\n    return !!targetEl;\n  }\n\n  focusToTargetItemEl() {\n    const dropdownEl = ReactDOM.findDOMNode(this.dropdown);\n    if (!dropdownEl) return;\n    const firstItemEl =\n      dropdownEl.querySelector('.slds-is-selected > .react-slds-menuitem[tabIndex]') ||\n      dropdownEl.querySelector('.react-slds-menuitem[tabIndex]');\n    if (firstItemEl) {\n      firstItemEl.focus();\n    }\n  }\n\n  picklistButtonRef(ref) {\n    this.picklistButton = ref;\n  }\n\n  dropdownRef(ref) {\n    this.dropdown = ref;\n  }\n\n  renderPicklist(props) {\n    const { className, id, htmlAttributes, buttonClassName, ...pprops } = props;\n    delete pprops.initialValue;\n    delete pprops.onUpdate;\n    delete pprops.valid;\n    delete pprops.invalid;\n    delete pprops.dirty;\n    delete pprops.pristine;\n    delete pprops.active;\n    delete pprops.touched;\n    delete pprops.visited;\n    delete pprops.maxHeight;\n    delete pprops.onValueChange;\n    delete pprops.defaultOpened;\n    delete pprops.menuSize;\n    delete pprops.selectedText;\n    delete pprops.onBlur;\n    delete pprops.hasMore;\n    delete pprops.onScroll;\n    delete pprops.resetPageLoader;\n    delete pprops.pageStart;\n    delete pprops.useNone;\n    delete pprops.noneText;\n    delete pprops.align;\n    delete pprops.focusOnOpen;\n    delete pprops.onDropDownClick;\n    const picklistClassNames = classnames(className, 'slds-picklist');\n    return (\n      <div className={picklistClassNames} aria-expanded={this.state.opened}>\n        <button\n          id={id}\n          ref={this.picklistButtonRef}\n          className={classnames('slds-picklist__label slds-button slds-button--neutral',\n            buttonClassName)}\n          type='button'\n          aria-haspopup\n          onClick={this.onClick.bind(this)}\n          onBlur={this.onBlur.bind(this)}\n          onKeyDown={this.onKeydown.bind(this)}\n          {...pprops}\n        >\n          <span className='slds-truncate' {...htmlAttributes}>\n            {this.getSelectedItemLabel() || <span>&nbsp;</span>}\n          </span>\n          <Icon icon='down' />\n        </button>\n      </div>\n    );\n  }\n\n  renderNoneMenuItem() {\n    const { required, noneText } = this.props;\n    return (\n      <PicklistItem\n        disabled={required}\n        value={null}\n        onBlur={this.onBlur.bind(this)}\n        selected={this.getSelectedValue() === null}\n        label={noneText}\n      />\n    );\n  }\n\n  renderDropdown() {\n    const {\n      menuSize,\n      children,\n      maxHeight,\n      hasMore,\n      pageStart,\n      resetPageLoader,\n      useNone,\n      align,\n    } = this.props;\n    return this.state.opened ? (\n      <DropdownMenu\n        ref={this.dropdownRef}\n        maxHeight={maxHeight}\n        size={menuSize}\n        onMenuItemClick={this.onPicklistItemClick.bind(this)}\n        onMenuClose={this.onPicklistClose.bind(this)}\n        hasMore={hasMore}\n        pageStart={pageStart}\n        resetPageLoader={resetPageLoader}\n        onScroll={this.onDropdownScroll.bind(this)}\n        align={align}\n        onBlur={this.onBlur.bind(this)}\n      >\n        {useNone && this.renderNoneMenuItem()}\n        {React.Children.map(children, this.renderPicklistItem.bind(this))}\n      </DropdownMenu>\n    ) : (\n      <div ref={this.dropdownRef} />\n    );\n  }\n\n  renderPicklistItem(item) {\n    const selected = item.props.value === this.getSelectedValue();\n    const onBlur = this.onBlur.bind(this);\n    return React.cloneElement(item, { selected, onBlur });\n  }\n\n  render() {\n    const id = this.props.id || this.state.id;\n    const { label, required, error, totalCols, cols, tooltip, ...props } = this.props;\n    const dropdown = this.renderDropdown();\n    const formElemProps = { id, label, required, error, totalCols, cols, dropdown, tooltip };\n    return <FormElement {...formElemProps}>{this.renderPicklist({ ...props, id })}</FormElement>;\n  }\n}\nPicklist.defaultProps = {\n  maxHeight: 10,\n  focusOnOpen: true,\n};\n\nPicklist.propTypes = {\n  id: PropTypes.string,\n  className: PropTypes.string,\n  label: PropTypes.string,\n  required: PropTypes.bool,\n  error: PropTypes.oneOfType([\n    PropTypes.bool,\n    PropTypes.string,\n    PropTypes.shape({\n      message: PropTypes.string,\n    }),\n  ]),\n  totalCols: PropTypes.number,\n  cols: PropTypes.number,\n  name: PropTypes.string,\n  value: PropTypes.any,\n  defaultValue: PropTypes.any,\n  selectedText: PropTypes.oneOfType([PropTypes.string, PropTypes.node]),\n  defaultOpened: PropTypes.bool,\n  onChange: PropTypes.func,\n  onDropDownClick: PropTypes.func,\n  onValueChange: PropTypes.func,\n  onSelect: PropTypes.func,\n  onComplete: PropTypes.func,\n  onKeyDown: PropTypes.func,\n  onBlur: PropTypes.func,\n  menuSize: PropTypes.string,\n  children: PropTypes.node,\n  maxHeight: PropTypes.oneOf([5, 7, 10]),\n  htmlAttributes: PropTypes.object,\n  hasMore: PropTypes.bool,\n  pageStart: PropTypes.number,\n  resetPageLoader: PropTypes.bool,\n  onScroll: PropTypes.func,\n  useNone: PropTypes.bool,\n  noneText: PropTypes.string,\n  align: PropTypes.oneOf(['left', 'center', 'right']),\n  focusOnOpen: PropTypes.bool,\n  buttonClassName: PropTypes.string,\n  tooltip: PropTypes.element,\n};\n\nPicklist.isFormElement = true;\n\nexport const PicklistItem = ({ label, selected, children, ...props }) => (\n  <DropdownMenuItem\n    icon={selected ? 'check' : 'none'}\n    role='menuitemradio'\n    selected={selected}\n    {...props}\n  >\n    {label || children}\n  </DropdownMenuItem>\n);\n\nPicklistItem.propTypes = {\n  label: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),\n  selected: PropTypes.bool,\n  value: PropTypes.any,\n  children: PropTypes.node,\n};\n"]}