UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

451 lines (400 loc) 40.7 kB
'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"]}