UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

353 lines (305 loc) 30.6 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.MenuItem = exports.DropdownMenuItem = undefined; var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); 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 _classnames3 = require('classnames'); var _classnames4 = _interopRequireDefault(_classnames3); var _Icon = require('./Icon'); var _Icon2 = _interopRequireDefault(_Icon); var _reactInfiniteScrollContainer = require('react-infinite-scroll-container'); var _reactInfiniteScrollContainer2 = _interopRequireDefault(_reactInfiniteScrollContainer); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var DropdownMenuItem = exports.DropdownMenuItem = function (_Component) { (0, _inherits3.default)(DropdownMenuItem, _Component); function DropdownMenuItem() { (0, _classCallCheck3.default)(this, DropdownMenuItem); return (0, _possibleConstructorReturn3.default)(this, (DropdownMenuItem.__proto__ || (0, _getPrototypeOf2.default)(DropdownMenuItem)).apply(this, arguments)); } (0, _createClass3.default)(DropdownMenuItem, [{ key: 'onKeyDown', value: function onKeyDown(e) { if (e.keyCode === 13 || e.keyCode === 32) { // return or space e.preventDefault(); e.stopPropagation(); if (this.props.onClick) { var _props; for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { args[_key - 1] = arguments[_key]; } (_props = this.props).onClick.apply(_props, [e].concat(args)); } } else if (e.keyCode === 40 || e.keyCode === 38) { e.preventDefault(); e.stopPropagation(); var currentEl = e.target.parentElement; var itemEl = e.keyCode === 40 ? currentEl.nextSibling : currentEl.previousSibling; while (itemEl) { var anchorEl = itemEl.querySelector('.react-slds-menuitem[tabIndex]'); if (anchorEl && !anchorEl.disabled) { anchorEl.focus(); return; } itemEl = e.keyCode === 40 ? itemEl.nextSibling : itemEl.previousSibling; } } } }, { key: 'onBlur', value: function onBlur(e) { if (this.props.onBlur) { this.props.onBlur(e); } } }, { key: 'onFocus', value: function onFocus(e) { if (this.props.onFocus) { this.props.onFocus(e); } } }, { key: 'render', value: function render() { var _props2 = this.props, className = _props2.className, label = _props2.label, icon = _props2.icon, iconRight = _props2.iconRight, selected = _props2.selected, disabled = _props2.disabled, _props2$tabIndex = _props2.tabIndex, tabIndex = _props2$tabIndex === undefined ? 0 : _props2$tabIndex, onClick = _props2.onClick, children = _props2.children, props = (0, _objectWithoutProperties3.default)(_props2, ['className', 'label', 'icon', 'iconRight', 'selected', 'disabled', 'tabIndex', 'onClick', 'children']); var menuItemClass = (0, _classnames4.default)('slds-dropdown__item', { 'slds-is-selected': selected }, className); return _react2.default.createElement( 'li', { className: menuItemClass, disabled: disabled }, _react2.default.createElement( 'a', (0, _extends3.default)({ className: 'slds-truncate react-slds-menuitem', role: 'menuitem', 'aria-disabled': disabled, tabIndex: disabled ? null : tabIndex, onClick: disabled ? null : onClick, onKeyDown: disabled ? null : this.onKeyDown.bind(this), onBlur: disabled ? null : this.onBlur.bind(this), onFocus: disabled ? null : this.onFocus.bind(this) }, props), _react2.default.createElement( 'p', { className: 'slds-truncate' }, icon ? _react2.default.createElement(_Icon2.default, { icon: icon, className: 'slds-pill__icon', align: 'left' }) : null, label || children ), iconRight ? _react2.default.createElement(_Icon2.default, { icon: iconRight, className: 'slds-pill__icon', align: 'right' }) : null ) ); } }]); return DropdownMenuItem; }(_react.Component); DropdownMenuItem.propTypes = { className: _propTypes2.default.string, label: _propTypes2.default.string, icon: _propTypes2.default.string, iconRight: _propTypes2.default.string, disabled: _propTypes2.default.bool, tabIndex: _propTypes2.default.number, selected: _propTypes2.default.bool, onClick: _propTypes2.default.func, onBlur: _propTypes2.default.func, onFocus: _propTypes2.default.func, children: _propTypes2.default.node }; var MenuItem = exports.MenuItem = DropdownMenuItem; var DropdownMenu = function (_Component2) { (0, _inherits3.default)(DropdownMenu, _Component2); function DropdownMenu() { (0, _classCallCheck3.default)(this, DropdownMenu); return (0, _possibleConstructorReturn3.default)(this, (DropdownMenu.__proto__ || (0, _getPrototypeOf2.default)(DropdownMenu)).apply(this, arguments)); } (0, _createClass3.default)(DropdownMenu, [{ key: 'onMenuItemBlur', value: function onMenuItemBlur(e) { if (this.props.onBlur) { this.props.onBlur(e); } } }, { key: 'onMenuItemFocus', value: function onMenuItemFocus(e) { if (this.props.onFocus) { this.props.onFocus(e); } } }, { key: 'onKeyDown', value: function onKeyDown(e) { var keyCodesToCloseMenu = [27].concat(this.props.keyCodesToCloseMenu || []); // ESC and others if (keyCodesToCloseMenu.some(function (num) { return e.keyCode === num; })) { if (this.props.onMenuClose) { this.props.onMenuClose(); } } } }, { key: 'loadMoreData', value: function loadMoreData(page) { if (this.props.onScroll) this.props.onScroll(page); } }, { key: 'renderMenuItem', value: function renderMenuItem(menuItem) { var _this3 = this; if (!menuItem) return null; var _menuItem$props = menuItem.props, onClick = _menuItem$props.onClick, onBlur = _menuItem$props.onBlur, onFocus = _menuItem$props.onFocus, props = (0, _objectWithoutProperties3.default)(_menuItem$props, ['onClick', 'onBlur', 'onFocus']); var onMenuItemClick = function onMenuItemClick() { for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { args[_key2] = arguments[_key2]; } if (onClick) { onClick.apply(undefined, args); } if (_this3.props.onMenuItemClick) { var _props3; (_props3 = _this3.props).onMenuItemClick.apply(_props3, [props].concat(args)); } }; var onMenuItemFocus = function onMenuItemFocus(e) { if (onFocus) { onFocus(e); } _this3.onMenuItemFocus(e); }; var onMenuItemBlur = function onMenuItemBlur(e) { if (onBlur) { onBlur(e); } _this3.onMenuItemBlur(e); }; return _react2.default.cloneElement(menuItem, { onClick: onMenuItemClick, onBlur: onMenuItemBlur, onFocus: onMenuItemFocus }); } }, { key: 'render', value: function render() { var _classnames; var _props4 = this.props, className = _props4.className, listClassName = _props4.listClassName, _props4$align = _props4.align, align = _props4$align === undefined ? 'left' : _props4$align, size = _props4.size, header = _props4.header, nubbinTop = _props4.nubbinTop, hoverPopup = _props4.hoverPopup, children = _props4.children, maxHeight = _props4.maxHeight, minWidth = _props4.minWidth, onBlur = _props4.onBlur, onFocus = _props4.onFocus; var dropdownMenuClassNames = (0, _classnames4.default)(className, 'slds-dropdown', 'slds-dropdown--menu', 'slds-dropdown--' + align, (_classnames = {}, (0, _defineProperty3.default)(_classnames, 'slds-dropdown--' + size, size), (0, _defineProperty3.default)(_classnames, 'slds-dropdown--nubbin-top', nubbinTop), (0, _defineProperty3.default)(_classnames, 'react-slds-no-hover-popup', !hoverPopup), _classnames)); var minWidthStyle = minWidth && minWidth > 0 ? { minWidth: minWidth } : {}; return _react2.default.createElement( 'div', { className: dropdownMenuClassNames, onKeyDown: this.onKeyDown.bind(this), tabIndex: '-1', onFocus: onFocus, onBlur: onBlur }, header ? _react2.default.createElement( 'div', { className: 'slds-dropdown__header' }, _react2.default.createElement( 'span', { className: 'slds-text-heading--label' }, header ) ) : null, _react2.default.createElement( 'ul', { className: (0, _classnames4.default)(listClassName, 'slds-dropdown__list', (0, _defineProperty3.default)({}, 'slds-dropdown--length-' + maxHeight, maxHeight)), style: minWidthStyle, role: 'menu' }, _react2.default.createElement( _reactInfiniteScrollContainer2.default, { pageStart: this.props.pageStart || 0, loadMore: this.loadMoreData.bind(this), hasMore: !!this.props.hasMore, useWindow: false, element: 'div', initialLoad: false, threshold: 20, resetPageLoader: this.props.resetPageLoader, loader: null }, _react2.default.Children.map(children, this.renderMenuItem.bind(this)) ) ) ); } }]); return DropdownMenu; }(_react.Component); exports.default = DropdownMenu; DropdownMenu.propTypes = { className: _propTypes2.default.string, listClassName: _propTypes2.default.string, align: _propTypes2.default.oneOf(['left', 'center', 'right']), size: _propTypes2.default.oneOf(['small', 'medium', 'large']), header: _propTypes2.default.string, nubbinTop: _propTypes2.default.bool, hoverPopup: _propTypes2.default.bool, onMenuItemClick: _propTypes2.default.func, onMenuClose: _propTypes2.default.func, onBlur: _propTypes2.default.func, onFocus: _propTypes2.default.func, children: _propTypes2.default.node, maxHeight: _propTypes2.default.oneOf([5, 7, 10]), minWidth: _propTypes2.default.number, hasMore: _propTypes2.default.bool, pageStart: _propTypes2.default.number, resetPageLoader: _propTypes2.default.bool, onScroll: _propTypes2.default.func, keyCodesToCloseMenu: _propTypes2.default.arrayOf(_propTypes2.default.number) }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/DropdownMenu.js"],"names":["DropdownMenuItem","e","keyCode","preventDefault","stopPropagation","props","onClick","args","currentEl","target","parentElement","itemEl","nextSibling","previousSibling","anchorEl","querySelector","disabled","focus","onBlur","onFocus","className","label","icon","iconRight","selected","tabIndex","children","menuItemClass","onKeyDown","bind","propTypes","string","bool","number","func","node","MenuItem","DropdownMenu","keyCodesToCloseMenu","concat","some","num","onMenuClose","page","onScroll","menuItem","onMenuItemClick","onMenuItemFocus","onMenuItemBlur","cloneElement","listClassName","align","size","header","nubbinTop","hoverPopup","maxHeight","minWidth","dropdownMenuClassNames","minWidthStyle","pageStart","loadMoreData","hasMore","resetPageLoader","Children","map","renderMenuItem","oneOf","arrayOf"],"mappings":"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","file":"DropdownMenu.js","sourcesContent":["import React, { Component } from 'react';\nimport classnames from 'classnames';\nimport Icon from './Icon';\nimport InfiniteScroll from 'react-infinite-scroll-container';\nimport PropTypes from 'prop-types';\n\nexport class DropdownMenuItem extends Component {\n  onKeyDown(e, ...args) {\n    if (e.keyCode === 13 || e.keyCode === 32) { // return or space\n      e.preventDefault();\n      e.stopPropagation();\n      if (this.props.onClick) {\n        this.props.onClick(e, ...args);\n      }\n    } else if (e.keyCode === 40 || e.keyCode === 38) {\n      e.preventDefault();\n      e.stopPropagation();\n      const currentEl = e.target.parentElement;\n      let itemEl = e.keyCode === 40 ? currentEl.nextSibling : currentEl.previousSibling;\n      while (itemEl) {\n        const anchorEl = itemEl.querySelector('.react-slds-menuitem[tabIndex]');\n        if (anchorEl && !anchorEl.disabled) {\n          anchorEl.focus();\n          return;\n        }\n        itemEl = e.keyCode === 40 ? itemEl.nextSibling : itemEl.previousSibling;\n      }\n    }\n  }\n\n  onBlur(e) {\n    if (this.props.onBlur) {\n      this.props.onBlur(e);\n    }\n  }\n\n  onFocus(e) {\n    if (this.props.onFocus) {\n      this.props.onFocus(e);\n    }\n  }\n\n  render() {\n    const {\n      className, label, icon, iconRight, selected, disabled, tabIndex = 0, onClick, children,\n      ...props,\n     } = this.props;\n    const menuItemClass = classnames(\n      'slds-dropdown__item',\n      { 'slds-is-selected': selected },\n      className\n    );\n    return (\n      <li className={ menuItemClass } disabled={ disabled }>\n        <a\n          className='slds-truncate react-slds-menuitem'\n          role='menuitem'\n          aria-disabled={ disabled }\n          tabIndex={ disabled ? null : tabIndex }\n          onClick={ disabled ? null : onClick }\n          onKeyDown={ disabled ? null : this.onKeyDown.bind(this) }\n          onBlur={ disabled ? null : this.onBlur.bind(this) }\n          onFocus={ disabled ? null : this.onFocus.bind(this) }\n          { ...props }\n        >\n          <p className='slds-truncate'>\n            { icon ? <Icon icon={ icon } className='slds-pill__icon' align='left' /> : null }\n            { label || children }\n          </p>\n          { iconRight ?\n            <Icon icon={ iconRight } className='slds-pill__icon' align='right' /> :\n            null\n          }\n        </a>\n      </li>\n    );\n  }\n}\n\nDropdownMenuItem.propTypes = {\n  className: PropTypes.string,\n  label: PropTypes.string,\n  icon: PropTypes.string,\n  iconRight: PropTypes.string,\n  disabled: PropTypes.bool,\n  tabIndex: PropTypes.number,\n  selected: PropTypes.bool,\n  onClick: PropTypes.func,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  children: PropTypes.node,\n};\n\n\nexport const MenuItem = DropdownMenuItem;\n\n\nexport default class DropdownMenu extends Component {\n  onMenuItemBlur(e) {\n    if (this.props.onBlur) {\n      this.props.onBlur(e);\n    }\n  }\n\n  onMenuItemFocus(e) {\n    if (this.props.onFocus) {\n      this.props.onFocus(e);\n    }\n  }\n\n  onKeyDown(e) {\n    const keyCodesToCloseMenu = [27].concat(this.props.keyCodesToCloseMenu || []); // ESC and others\n    if (keyCodesToCloseMenu.some(num => e.keyCode === num)) {\n      if (this.props.onMenuClose) {\n        this.props.onMenuClose();\n      }\n    }\n  }\n\n  loadMoreData(page) {\n    if (this.props.onScroll) this.props.onScroll(page);\n  }\n\n  renderMenuItem(menuItem) {\n    if (!menuItem) return null;\n    const { onClick, onBlur, onFocus, ...props } = menuItem.props;\n    const onMenuItemClick = (...args) => {\n      if (onClick) { onClick(...args); }\n      if (this.props.onMenuItemClick) {\n        this.props.onMenuItemClick(props, ...args);\n      }\n    };\n    const onMenuItemFocus = (e) => {\n      if (onFocus) { onFocus(e); }\n      this.onMenuItemFocus(e);\n    };\n    const onMenuItemBlur = (e) => {\n      if (onBlur) { onBlur(e); }\n      this.onMenuItemBlur(e);\n    };\n    return React.cloneElement(menuItem, {\n      onClick: onMenuItemClick,\n      onBlur: onMenuItemBlur,\n      onFocus: onMenuItemFocus,\n    });\n  }\n\n  render() {\n    const {\n      className, listClassName, align = 'left', size, header, nubbinTop, hoverPopup,\n      children, maxHeight, minWidth, onBlur, onFocus,\n    } = this.props;\n    const dropdownMenuClassNames = classnames(\n      className,\n      'slds-dropdown',\n      'slds-dropdown--menu',\n      `slds-dropdown--${align}`,\n      {\n        [`slds-dropdown--${size}`]: size,\n        'slds-dropdown--nubbin-top': nubbinTop,\n        'react-slds-no-hover-popup': !hoverPopup,\n      }\n    );\n    const minWidthStyle = (minWidth && minWidth > 0) ? ({ minWidth }) : ({});\n    return (\n      <div\n        className={ dropdownMenuClassNames }\n        onKeyDown={ this.onKeyDown.bind(this) }\n        tabIndex='-1'\n        onFocus={ onFocus }\n        onBlur={ onBlur }\n      >\n        {\n          header ?\n            <div className='slds-dropdown__header'>\n              <span className='slds-text-heading--label'>{ header }</span>\n            </div> :\n          null\n        }\n        <ul\n          className={classnames(\n            listClassName,\n            'slds-dropdown__list',\n            {\n              [`slds-dropdown--length-${maxHeight}`]: maxHeight,\n            })\n           }\n          style={minWidthStyle}\n          role='menu'\n        >\n          <InfiniteScroll\n            pageStart={this.props.pageStart || 0}\n            loadMore={this.loadMoreData.bind(this)}\n            hasMore={!!this.props.hasMore}\n            useWindow={false}\n            element='div'\n            initialLoad={false}\n            threshold={20}\n            resetPageLoader={this.props.resetPageLoader}\n            loader={null}\n          >\n            { React.Children.map(children, this.renderMenuItem.bind(this)) }\n          </InfiniteScroll>\n        </ul>\n      </div>\n    );\n  }\n\n}\n\n\nDropdownMenu.propTypes = {\n  className: PropTypes.string,\n  listClassName: PropTypes.string,\n  align: PropTypes.oneOf(['left', 'center', 'right']),\n  size: PropTypes.oneOf(['small', 'medium', 'large']),\n  header: PropTypes.string,\n  nubbinTop: PropTypes.bool,\n  hoverPopup: PropTypes.bool,\n  onMenuItemClick: PropTypes.func,\n  onMenuClose: PropTypes.func,\n  onBlur: PropTypes.func,\n  onFocus: PropTypes.func,\n  children: PropTypes.node,\n  maxHeight: PropTypes.oneOf([5, 7, 10]),\n  minWidth: PropTypes.number,\n  hasMore: PropTypes.bool,\n  pageStart: PropTypes.number,\n  resetPageLoader: PropTypes.bool,\n  onScroll: PropTypes.func,\n  keyCodesToCloseMenu: PropTypes.arrayOf(PropTypes.number),\n};\n"]}