UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

364 lines (307 loc) 35.3 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); var _slicedToArray2 = require('babel-runtime/helpers/slicedToArray'); var _slicedToArray3 = _interopRequireDefault(_slicedToArray2); 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 _reactDom = require('react-dom'); var _reactDom2 = _interopRequireDefault(_reactDom); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _util = require('./util'); var _DropdownButton = require('./DropdownButton'); var _DropdownButton2 = _interopRequireDefault(_DropdownButton); var _DropdownMenu = require('./DropdownMenu'); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var Tabs = function (_Component) { (0, _inherits3.default)(Tabs, _Component); function Tabs(props) { (0, _classCallCheck3.default)(this, Tabs); var _this = (0, _possibleConstructorReturn3.default)(this, (Tabs.__proto__ || (0, _getPrototypeOf2.default)(Tabs)).call(this, props)); var _this$getvisibleAndHi = _this.getvisibleAndHiddenTabs(props), _this$getvisibleAndHi2 = (0, _slicedToArray3.default)(_this$getvisibleAndHi, 2), visibleTabs = _this$getvisibleAndHi2[0], hiddenTabs = _this$getvisibleAndHi2[1]; _this.state = { visibleTabs: visibleTabs, hiddenTabs: hiddenTabs }; _this.modifyVisibleTabs = _this.modifyVisibleTabs.bind(_this); _this.activeTabRef = _this.activeTabRef.bind(_this); (0, _util.registerStyle)('tab-menu', [['.slds-tabs__item.react-slds-tab-with-menu', '{ position: relative !important; overflow: visible !important; }'], ['.slds-tabs__item.react-slds-tab-with-menu > .react-slds-tab-item-inner', '{ overflow: hidden }'], ['.slds-tabs__item.react-slds-tab-with-menu > .react-slds-tab-item-inner > a', '{ padding-right: 2rem; }'], ['.react-slds-tab-menu', '{ position: absolute; top: 0; right: 0; visibility: hidden }'], ['.react-slds-tab-menu button', '{ height: 3rem; line-height: 3rem; width: 2rem; }'], ['.slds-tabs__item.slds-active .react-slds-tab-menu', '.slds-tabs__item:hover .react-slds-tab-menu', '{ visibility: visible }']]); return _this; } (0, _createClass3.default)(Tabs, [{ key: 'componentWillReceiveProps', value: function componentWillReceiveProps(nextProps) { var _getvisibleAndHiddenT = this.getvisibleAndHiddenTabs(nextProps), _getvisibleAndHiddenT2 = (0, _slicedToArray3.default)(_getvisibleAndHiddenT, 2), visibleTabs = _getvisibleAndHiddenT2[0], hiddenTabs = _getvisibleAndHiddenT2[1]; this.setState({ visibleTabs: visibleTabs, hiddenTabs: hiddenTabs }); } }, { key: 'componentDidUpdate', value: function componentDidUpdate() { if (this.state.focusTab) { var el = _reactDom2.default.findDOMNode(this.activeTab); if (el) { el.focus(); } /* eslint-disable react/no-did-update-set-state */ this.setState({ focusTab: false }); } } }, { key: 'onTabClick', value: function onTabClick(tabKey) { if (this.props.onSelect) { this.props.onSelect(tabKey); } // Uncontrolled this.setState({ activeKey: tabKey, focusTab: true }); } }, { key: 'onTabKeyDown', value: function onTabKeyDown(tabKey, e) { if (e.keyCode === 37 || e.keyCode === 39) { // left/right cursor key var idx = 0; var tabKeys = []; _react2.default.Children.forEach(this.props.children, function (tab, i) { tabKeys.push(tab.props.eventKey); if (tabKey === tab.props.eventKey) { idx = i; } }); var dir = e.keyCode === 37 ? -1 : 1; var activeIdx = (idx + dir + tabKeys.length) % tabKeys.length; var activeKey = tabKeys[activeIdx]; this.onTabClick(activeKey); e.preventDefault(); e.stopPropagation(); } } }, { key: 'getActiveKey', value: function getActiveKey(props) { var activeKey = props.activeKey, defaultActiveKey = props.defaultActiveKey; if (typeof activeKey !== 'undefined') return activeKey; if (this.state && typeof this.state.activeKey !== 'undefined') return this.state.activeKey; return defaultActiveKey; } }, { key: 'getvisibleAndHiddenTabs', value: function getvisibleAndHiddenTabs(props) { var children = props.children, maxVisibleTabs = props.maxVisibleTabs; var _ref = [children.slice(0, maxVisibleTabs), children.slice(maxVisibleTabs, children.length)], visibleTabs = _ref[0], hiddenTabs = _ref[1]; var activeKey = this.getActiveKey(props); var isActiveTabHidden = hiddenTabs.findIndex(function (tab) { return tab.props.eventKey === activeKey; }) !== -1; return isActiveTabHidden ? this.selectHiddenTab(visibleTabs, hiddenTabs, activeKey) : [visibleTabs, hiddenTabs]; } }, { key: 'selectHiddenTab', value: function selectHiddenTab(visibleTabs, hiddenTabs, activeKey) { var tabToShowIndex = hiddenTabs.findIndex(function (tab) { return tab.props.eventKey === activeKey; }); var tabToShow = hiddenTabs[tabToShowIndex]; var tabToHide = visibleTabs[visibleTabs.length - 1]; var newVisibleTabs = [].concat((0, _toConsumableArray3.default)(visibleTabs.slice(0, visibleTabs.length - 1)), [tabToShow]); var newHiddenTabs = [tabToHide].concat((0, _toConsumableArray3.default)(hiddenTabs.filter(function (tab) { return tab.props.eventKey !== activeKey; }))); return [newVisibleTabs, newHiddenTabs]; } }, { key: 'tabsType', value: function tabsType() { return this.props.type === 'scoped' ? 'scoped' : 'default'; } }, { key: 'modifyVisibleTabs', value: function modifyVisibleTabs(event) { var tabIndex = event.tabIndex; var onSelect = this.props.onSelect; if (onSelect) onSelect(tabIndex); var _selectHiddenTab = this.selectHiddenTab(this.state.visibleTabs, this.state.hiddenTabs, tabIndex), _selectHiddenTab2 = (0, _slicedToArray3.default)(_selectHiddenTab, 2), visibleTabs = _selectHiddenTab2[0], hiddenTabs = _selectHiddenTab2[1]; if (this.props.onSelect) { this.props.onSelect(tabIndex); } this.setState({ visibleTabs: visibleTabs, hiddenTabs: hiddenTabs, activeKey: tabIndex, focusTab: true }); } }, { key: 'activeTabRef', value: function activeTabRef(ref) { this.activeTab = ref; } }, { key: 'renderController', value: function renderController() { var label = this.props.moreLabel; var normalizedLabel = this.props.allCaps ? label.toUpperCase() : label; var marginTop = this.props.allCaps ? 4 : 7; return _react2.default.createElement( _DropdownButton2.default, { label: normalizedLabel, style: { marginTop: marginTop, marginLeft: 20, color: '#54698d' }, onMenuItemClick: this.modifyVisibleTabs }, this.state.hiddenTabs.map(function (tab) { return _react2.default.createElement( _DropdownMenu.MenuItem, { key: tab.props.eventKey, tabIndex: tab.props.eventKey }, tab.props.title ); }) ); } }, { key: 'renderTabNav', value: function renderTabNav() { var _this2 = this; var type = this.tabsType(); var _props = this.props, children = _props.children, maxVisibleTabs = _props.maxVisibleTabs; var currentActiveKey = this.getActiveKey(this.props); var tabNavClassName = 'slds-tabs--' + type + '__nav'; return _react2.default.createElement( 'ul', { className: tabNavClassName, role: 'tablist' }, this.state.visibleTabs.map(function (tab) { var _tab$props = tab.props, title = _tab$props.title, eventKey = _tab$props.eventKey, menu = _tab$props.menu, menuIcon = _tab$props.menuIcon; var menuItems = tab.props.menuItems; menuItems = menu ? menu.props.children : menuItems; var menuProps = menu ? menu.props : {}; var isActive = eventKey === currentActiveKey; var tabItemClassName = (0, _classnames2.default)('slds-tabs__item', 'slds-tabs--' + type + '__item', 'slds-text-heading---label', { 'slds-active': isActive }, { 'react-slds-tab-with-menu': menu || menuItems }); var tabLinkClassName = 'slds-tabs--' + type + '__link'; return _react2.default.createElement( 'li', { className: tabItemClassName, role: 'presentation', key: tab.props.eventKey }, _react2.default.createElement( 'span', { className: 'react-slds-tab-item-inner' }, _react2.default.createElement( 'a', { className: tabLinkClassName, onClick: _this2.onTabClick.bind(_this2, eventKey), onKeyDown: _this2.onTabKeyDown.bind(_this2, eventKey), role: 'tab', ref: isActive ? _this2.activeTabRef : null, tabIndex: isActive ? 0 : -1, 'aria-selected': isActive }, title ), menuItems ? _this2.renderTabMenu(menuIcon, menuItems, menuProps) : null ) ); }), maxVisibleTabs < children.length && this.renderController() ); } }, { key: 'renderTabMenu', value: function renderTabMenu() { var menuIcon = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'down'; var menuItems = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; var menuProps = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; return _react2.default.createElement( _DropdownButton2.default, (0, _extends3.default)({ className: 'react-slds-tab-menu', icon: menuIcon, type: 'icon-bare', iconSize: 'small', nubbinTop: true }, menuProps), menuItems ); } }, { key: 'renderTabPanel', value: function renderTabPanel() { var activeKey = this.getActiveKey(this.props); return this.state.visibleTabs.map(function (tab) { var eventKey = tab.props.eventKey; var isActive = eventKey === activeKey; return _react2.default.cloneElement(tab, { active: isActive, key: tab.props.eventKey }); }); } }, { key: 'render', value: function render() { var className = this.props.className; var tabsClassNames = (0, _classnames2.default)(className, 'slds-tabs--' + this.tabsType()); return _react2.default.createElement( 'div', { className: tabsClassNames }, this.renderTabNav(), this.renderTabPanel() ); } }]); return Tabs; }(_react.Component); exports.default = Tabs; var TAB_TYPES = ['default', 'scoped']; Tabs.propTypes = { className: _propTypes2.default.string, type: _propTypes2.default.oneOf(TAB_TYPES), defaultActiveKey: _propTypes2.default.any, activeKey: _propTypes2.default.any, onSelect: _propTypes2.default.func, children: _propTypes2.default.node, controller: _propTypes2.default.node, maxVisibleTabs: _propTypes2.default.number, allCaps: _propTypes2.default.bool, moreLabel: _propTypes2.default.string }; Tabs.defaultProps = { maxVisibleTabs: 10, moreLabel: 'More' }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Tabs.js"],"names":["Tabs","props","getvisibleAndHiddenTabs","visibleTabs","hiddenTabs","state","modifyVisibleTabs","bind","activeTabRef","nextProps","setState","focusTab","el","findDOMNode","activeTab","focus","tabKey","onSelect","activeKey","e","keyCode","idx","tabKeys","Children","forEach","children","tab","i","push","eventKey","dir","activeIdx","length","onTabClick","preventDefault","stopPropagation","defaultActiveKey","maxVisibleTabs","slice","getActiveKey","isActiveTabHidden","findIndex","selectHiddenTab","tabToShowIndex","tabToShow","tabToHide","newVisibleTabs","newHiddenTabs","filter","type","event","tabIndex","ref","label","moreLabel","normalizedLabel","allCaps","toUpperCase","marginTop","marginLeft","color","map","title","tabsType","currentActiveKey","tabNavClassName","menu","menuIcon","menuItems","menuProps","isActive","tabItemClassName","tabLinkClassName","onTabKeyDown","renderTabMenu","renderController","cloneElement","active","key","className","tabsClassNames","renderTabNav","renderTabPanel","TAB_TYPES","propTypes","string","oneOf","any","func","node","controller","number","bool","defaultProps"],"mappings":"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","file":"Tabs.js","sourcesContent":["import React, { Component } from 'react';\nimport ReactDOM from 'react-dom';\nimport classnames from 'classnames';\nimport { registerStyle } from './util';\nimport DropdownButton from './DropdownButton';\nimport { MenuItem } from './DropdownMenu';\nimport PropTypes from 'prop-types';\n\nexport default class Tabs extends Component {\n  constructor(props) {\n    super(props);\n    const [visibleTabs, hiddenTabs] = this.getvisibleAndHiddenTabs(props);\n\n    this.state = {\n      visibleTabs,\n      hiddenTabs,\n    };\n\n    this.modifyVisibleTabs = this.modifyVisibleTabs.bind(this);\n    this.activeTabRef = this.activeTabRef.bind(this);\n\n    registerStyle('tab-menu', [\n      [\n        '.slds-tabs__item.react-slds-tab-with-menu',\n        '{ position: relative !important; overflow: visible !important; }',\n      ],\n      [\n        '.slds-tabs__item.react-slds-tab-with-menu > .react-slds-tab-item-inner',\n        '{ overflow: hidden }',\n      ],\n      [\n        '.slds-tabs__item.react-slds-tab-with-menu > .react-slds-tab-item-inner > a',\n        '{ padding-right: 2rem; }',\n      ],\n      [\n        '.react-slds-tab-menu',\n        '{ position: absolute; top: 0; right: 0; visibility: hidden }',\n      ],\n      [\n        '.react-slds-tab-menu button',\n        '{ height: 3rem; line-height: 3rem; width: 2rem; }',\n      ],\n      [\n        '.slds-tabs__item.slds-active .react-slds-tab-menu',\n        '.slds-tabs__item:hover .react-slds-tab-menu',\n        '{ visibility: visible }',\n      ],\n    ]);\n  }\n\n  componentWillReceiveProps(nextProps) {\n    const [visibleTabs, hiddenTabs] = this.getvisibleAndHiddenTabs(nextProps);\n    this.setState({\n      visibleTabs,\n      hiddenTabs,\n    });\n  }\n\n  componentDidUpdate() {\n    if (this.state.focusTab) {\n      const el = ReactDOM.findDOMNode(this.activeTab);\n      if (el) {\n        el.focus();\n      }\n      /* eslint-disable react/no-did-update-set-state */\n      this.setState({ focusTab: false });\n    }\n  }\n\n  onTabClick(tabKey) {\n    if (this.props.onSelect) {\n      this.props.onSelect(tabKey);\n    }\n    // Uncontrolled\n    this.setState({ activeKey: tabKey, focusTab: true });\n  }\n\n  onTabKeyDown(tabKey, e) {\n    if (e.keyCode === 37 || e.keyCode === 39) { // left/right cursor key\n      let idx = 0;\n      const tabKeys = [];\n      React.Children.forEach(this.props.children, (tab, i) => {\n        tabKeys.push(tab.props.eventKey);\n        if (tabKey === tab.props.eventKey) {\n          idx = i;\n        }\n      });\n      const dir = e.keyCode === 37 ? -1 : 1;\n      const activeIdx = (idx + dir + tabKeys.length) % tabKeys.length;\n      const activeKey = tabKeys[activeIdx];\n      this.onTabClick(activeKey);\n      e.preventDefault();\n      e.stopPropagation();\n    }\n  }\n\n  getActiveKey(props) {\n    const { activeKey, defaultActiveKey } = props;\n    if (typeof activeKey !== 'undefined') return activeKey;\n    if (this.state && typeof this.state.activeKey !== 'undefined') return this.state.activeKey;\n    return defaultActiveKey;\n  }\n\n  getvisibleAndHiddenTabs(props) {\n    const { children, maxVisibleTabs } = props;\n\n    const [visibleTabs, hiddenTabs] = [\n      children.slice(0, maxVisibleTabs),\n      children.slice(maxVisibleTabs, children.length),\n    ];\n    const activeKey = this.getActiveKey(props);\n    const isActiveTabHidden = hiddenTabs.findIndex(tab => tab.props.eventKey === activeKey) !== -1;\n    return isActiveTabHidden ?\n      this.selectHiddenTab(visibleTabs, hiddenTabs, activeKey) : [visibleTabs, hiddenTabs];\n  }\n\n  selectHiddenTab(visibleTabs, hiddenTabs, activeKey) {\n    const tabToShowIndex = hiddenTabs.findIndex(tab => tab.props.eventKey === activeKey);\n    const tabToShow = hiddenTabs[tabToShowIndex];\n    const tabToHide = visibleTabs[visibleTabs.length - 1];\n    const newVisibleTabs = [...visibleTabs.slice(0, visibleTabs.length - 1), tabToShow];\n    const newHiddenTabs = [\n      tabToHide,\n      ...hiddenTabs.filter(tab => tab.props.eventKey !== activeKey),\n    ];\n\n    return [newVisibleTabs, newHiddenTabs];\n  }\n\n  tabsType() {\n    return this.props.type === 'scoped' ? 'scoped' : 'default';\n  }\n\n  modifyVisibleTabs(event) {\n    const { tabIndex } = event;\n    const { onSelect } = this.props;\n    if (onSelect) onSelect(tabIndex);\n    const [visibleTabs, hiddenTabs] =\n      this.selectHiddenTab(this.state.visibleTabs, this.state.hiddenTabs, tabIndex);\n\n    if (this.props.onSelect) {\n      this.props.onSelect(tabIndex);\n    }\n\n    this.setState({\n      visibleTabs,\n      hiddenTabs,\n      activeKey: tabIndex,\n      focusTab: true,\n    });\n  }\n\n  activeTabRef(ref) {\n    this.activeTab = ref;\n  }\n\n  renderController() {\n    const label = this.props.moreLabel;\n    const normalizedLabel = this.props.allCaps ? label.toUpperCase() : label;\n    const marginTop = this.props.allCaps ? 4 : 7;\n    return (\n      <DropdownButton\n        label={normalizedLabel}\n        style={{ marginTop, marginLeft: 20, color: '#54698d' }}\n        onMenuItemClick={this.modifyVisibleTabs}\n      >\n        {\n          this.state.hiddenTabs.map((tab) => (\n            <MenuItem key={tab.props.eventKey} tabIndex={tab.props.eventKey}>\n              {tab.props.title}\n            </MenuItem>\n          ))\n        }\n      </DropdownButton>\n    );\n  }\n\n  renderTabNav() {\n    const type = this.tabsType();\n    const { children, maxVisibleTabs } = this.props;\n    const currentActiveKey = this.getActiveKey(this.props);\n    const tabNavClassName = `slds-tabs--${type}__nav`;\n    return (\n      <ul className={ tabNavClassName } role='tablist'>\n      {\n        this.state.visibleTabs.map((tab) => {\n          const { title, eventKey, menu, menuIcon } = tab.props;\n          let { menuItems } = tab.props;\n          menuItems = menu ? menu.props.children : menuItems;\n          const menuProps = menu ? menu.props : {};\n          const isActive = eventKey === currentActiveKey;\n          const tabItemClassName = classnames(\n            'slds-tabs__item',\n            `slds-tabs--${type}__item`,\n            'slds-text-heading---label',\n            { 'slds-active': isActive },\n            { 'react-slds-tab-with-menu': menu || menuItems }\n          );\n          const tabLinkClassName = `slds-tabs--${type}__link`;\n          return (\n            <li className={ tabItemClassName } role='presentation' key={tab.props.eventKey}>\n              <span className='react-slds-tab-item-inner'>\n                <a\n                  className={ tabLinkClassName }\n                  onClick={ this.onTabClick.bind(this, eventKey) }\n                  onKeyDown={ this.onTabKeyDown.bind(this, eventKey) }\n                  role='tab'\n                  ref={ isActive ? this.activeTabRef : null }\n                  tabIndex={ isActive ? 0 : -1 }\n                  aria-selected={ isActive }\n                >\n                  { title }\n                </a>\n                { menuItems ? this.renderTabMenu(menuIcon, menuItems, menuProps) : null }\n              </span>\n            </li>\n          );\n        })\n      }\n      {\n        maxVisibleTabs < children.length && this.renderController()\n      }\n      </ul>\n    );\n  }\n\n  renderTabMenu(menuIcon = 'down', menuItems = [], menuProps = {}) {\n    return (\n      <DropdownButton\n        className='react-slds-tab-menu'\n        icon={ menuIcon }\n        type='icon-bare'\n        iconSize='small'\n        nubbinTop\n        { ...menuProps }\n      >\n        { menuItems }\n      </DropdownButton>\n    );\n  }\n\n  renderTabPanel() {\n    const activeKey = this.getActiveKey(this.props);\n    return (\n      this.state.visibleTabs.map((tab) => {\n        const { eventKey } = tab.props;\n        const isActive = eventKey === activeKey;\n        return React.cloneElement(tab, { active: isActive, key: tab.props.eventKey });\n      })\n    );\n  }\n\n  render() {\n    const { className } = this.props;\n    const tabsClassNames = classnames(className, `slds-tabs--${this.tabsType()}`);\n    return (\n      <div className={ tabsClassNames }>\n        { this.renderTabNav() }\n        { this.renderTabPanel() }\n      </div>\n    );\n  }\n}\n\nconst TAB_TYPES = ['default', 'scoped'];\n\nTabs.propTypes = {\n  className: PropTypes.string,\n  type: PropTypes.oneOf(TAB_TYPES),\n  defaultActiveKey: PropTypes.any,\n  activeKey: PropTypes.any,\n  onSelect: PropTypes.func,\n  children: PropTypes.node,\n  controller: PropTypes.node,\n  maxVisibleTabs: PropTypes.number,\n  allCaps: PropTypes.bool,\n  moreLabel: PropTypes.string,\n};\n\nTabs.defaultProps = {\n  maxVisibleTabs: 10,\n  moreLabel: 'More',\n};\n"]}