UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

210 lines (162 loc) 15.2 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); 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 _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _Icon = require('./Icon'); var _Icon2 = _interopRequireDefault(_Icon); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var SalesPath = function (_React$Component) { (0, _inherits3.default)(SalesPath, _React$Component); function SalesPath(props) { (0, _classCallCheck3.default)(this, SalesPath); var _this = (0, _possibleConstructorReturn3.default)(this, (SalesPath.__proto__ || (0, _getPrototypeOf2.default)(SalesPath)).call(this, props)); _this.state = {}; return _this; } (0, _createClass3.default)(SalesPath, [{ key: 'onItemClick', value: function onItemClick(itemKey) { if (this.props.onSelect) { this.props.onSelect(itemKey); } // Uncontrolled this.setState({ activeKey: itemKey }); } }, { key: 'renderSalesPath', value: function renderSalesPath(activeKey, paths) { var _this2 = this; var typeTracker = -1; return _react2.default.Children.map(paths, function (path) { var _path$props = path.props, eventKey = _path$props.eventKey, type = _path$props.type, props = (0, _objectWithoutProperties3.default)(_path$props, ['eventKey', 'type']); var isActive = eventKey === activeKey; typeTracker = isActive ? 0 : typeTracker >= 0 ? 1 : -1; var evaluatedType = type || (isActive ? 'current' : typeTracker === -1 ? 'complete' : 'incomplete'); return _react2.default.createElement(PathItem, (0, _extends3.default)({ eventKey: eventKey, type: evaluatedType, onSelect: _this2.onItemClick.bind(_this2) }, props)); }); } }, { key: 'render', value: function render() { var _props = this.props, className = _props.className, children = _props.children; var activeKey = this.props.activeKey || this.state.activeKey || this.props.defaultActiveKey; var salesPathClassNames = (0, _classnames2.default)(className, 'slds-tabs--path'); return _react2.default.createElement( 'div', { className: salesPathClassNames, role: 'application tablist' }, _react2.default.createElement( 'ul', { className: 'slds-tabs--path__nav', role: 'presentation' }, this.renderSalesPath(activeKey, children) ) ); } }]); return SalesPath; }(_react2.default.Component); SalesPath.propTypes = { className: _propTypes2.default.string, defaultActiveKey: _propTypes2.default.any, activeKey: _propTypes2.default.any, onSelect: _propTypes2.default.func, children: _propTypes2.default.node }; var PathItem = function (_React$Component2) { (0, _inherits3.default)(PathItem, _React$Component2); function PathItem() { (0, _classCallCheck3.default)(this, PathItem); return (0, _possibleConstructorReturn3.default)(this, (PathItem.__proto__ || (0, _getPrototypeOf2.default)(PathItem)).apply(this, arguments)); } (0, _createClass3.default)(PathItem, [{ key: 'onItemClick', value: function onItemClick(itemKey) { if (this.props.onSelect) { this.props.onSelect(itemKey); } } }, { key: 'render', value: function render() { var _props2 = this.props, className = _props2.className, eventKey = _props2.eventKey, title = _props2.title, completedTitle = _props2.completedTitle, type = _props2.type; var pathItemClassName = (0, _classnames2.default)('slds-tabs--path__item', 'slds-is-' + type, className); var tabIndex = type === 'current' ? 0 : -1; var completedText = completedTitle || 'Stage Complete'; return _react2.default.createElement( 'li', { className: pathItemClassName, role: 'presentation' }, _react2.default.createElement( 'a', { className: 'slds-tabs--path__link', 'aria-selected': 'false', tabIndex: tabIndex, role: 'tab', 'aria-live': 'assertive', onClick: this.onItemClick.bind(this, eventKey) }, _react2.default.createElement( 'span', { className: 'slds-tabs--path__stage' }, _react2.default.createElement(_Icon2.default, { category: 'utility', icon: 'check', size: 'x-small' }), type === 'complete' ? _react2.default.createElement( 'span', { className: 'slds-assistive-text' }, completedText ) : null ), _react2.default.createElement( 'span', { className: 'slds-tabs--path__title' }, title ) ) ); } }]); return PathItem; }(_react2.default.Component); PathItem.propTypes = { className: _propTypes2.default.string, eventKey: _propTypes2.default.any, type: _propTypes2.default.oneOf(['complete', 'current', 'incomplete']), title: _propTypes2.default.string, completedTitle: _propTypes2.default.string, onSelect: _propTypes2.default.func }; SalesPath.PathItem = PathItem; exports.default = SalesPath; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/SalesPath.js"],"names":["SalesPath","props","state","itemKey","onSelect","setState","activeKey","paths","typeTracker","Children","map","path","eventKey","type","isActive","evaluatedType","onItemClick","bind","className","children","defaultActiveKey","salesPathClassNames","renderSalesPath","Component","propTypes","string","any","func","node","PathItem","title","completedTitle","pathItemClassName","tabIndex","completedText","oneOf"],"mappings":"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","file":"SalesPath.js","sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport Icon from './Icon';\nimport PropTypes from 'prop-types';\n\nclass SalesPath extends React.Component {\n\n  constructor(props) {\n    super(props);\n    this.state = {};\n  }\n\n  onItemClick(itemKey) {\n    if (this.props.onSelect) {\n      this.props.onSelect(itemKey);\n    }\n    // Uncontrolled\n    this.setState({ activeKey: itemKey });\n  }\n\n  renderSalesPath(activeKey, paths) {\n    let typeTracker = -1;\n\n    return React.Children.map(paths, (path) => {\n      const { eventKey, type, ...props } = path.props;\n      const isActive = eventKey === activeKey;\n\n      typeTracker = (isActive) ? 0 :\n        (typeTracker >= 0) ? 1 : -1;\n\n      const evaluatedType = type || (\n        (isActive) ? 'current' :\n        ((typeTracker === -1) ? 'complete' : 'incomplete')\n      );\n\n      return (<PathItem\n        eventKey={ eventKey }\n        type={ evaluatedType }\n        onSelect={ this.onItemClick.bind(this) }\n        { ...props }\n      />);\n    });\n  }\n\n  render() {\n    const { className, children } = this.props;\n    const activeKey = this.props.activeKey || this.state.activeKey || this.props.defaultActiveKey;\n\n    const salesPathClassNames = classnames(className, 'slds-tabs--path');\n    return (\n      <div className={ salesPathClassNames } role='application tablist'>\n        <ul className='slds-tabs--path__nav' role='presentation'>\n          { this.renderSalesPath(activeKey, children) }\n        </ul>\n      </div>\n    );\n  }\n}\n\nSalesPath.propTypes = {\n  className: PropTypes.string,\n  defaultActiveKey: PropTypes.any,\n  activeKey: PropTypes.any,\n  onSelect: PropTypes.func,\n  children: PropTypes.node,\n};\n\n\nclass PathItem extends React.Component {\n\n  onItemClick(itemKey) {\n    if (this.props.onSelect) {\n      this.props.onSelect(itemKey);\n    }\n  }\n\n  render() {\n    const { className, eventKey, title, completedTitle, type } = this.props;\n\n    const pathItemClassName = classnames(\n      'slds-tabs--path__item',\n      `slds-is-${type}`,\n      className\n    );\n\n    const tabIndex = (type === 'current') ? 0 : -1;\n    const completedText = completedTitle || 'Stage Complete';\n\n    return (\n      <li className={ pathItemClassName } role='presentation'>\n        <a\n          className='slds-tabs--path__link'\n          aria-selected='false'\n          tabIndex={ tabIndex }\n          role='tab'\n          aria-live='assertive'\n          onClick={ this.onItemClick.bind(this, eventKey) }\n        >\n          <span className='slds-tabs--path__stage'>\n            <Icon category='utility' icon='check' size='x-small' />\n            { (type === 'complete') ? (\n              <span className='slds-assistive-text'>{ completedText }</span>\n            ) : null }\n          </span>\n          <span className='slds-tabs--path__title'>{ title }</span>\n        </a>\n      </li>\n    );\n  }\n}\n\nPathItem.propTypes = {\n  className: PropTypes.string,\n  eventKey: PropTypes.any,\n  type: PropTypes.oneOf(['complete', 'current', 'incomplete']),\n  title: PropTypes.string,\n  completedTitle: PropTypes.string,\n  onSelect: PropTypes.func,\n};\n\nSalesPath.PathItem = PathItem;\n\nexport default SalesPath;\n"]}