react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
364 lines (307 loc) • 35.3 kB
JavaScript
'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"]}