UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

267 lines (223 loc) 22.3 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 _Button = require('./Button'); var _Button2 = _interopRequireDefault(_Button); var _Spinner = require('./Spinner'); var _Spinner2 = _interopRequireDefault(_Spinner); var _util = require('./util'); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var TreeNode = function (_Component) { (0, _inherits3.default)(TreeNode, _Component); function TreeNode(props) { (0, _classCallCheck3.default)(this, TreeNode); var _this = (0, _possibleConstructorReturn3.default)(this, (TreeNode.__proto__ || (0, _getPrototypeOf2.default)(TreeNode)).call(this, props)); _this.state = { opened: _this.props.defaultOpened }; _this.onLabelClickEvent = _this.onLabelClickEvent.bind(_this); (0, _util.registerStyle)('tree-node', [['.slds-tree__item .tree-buttons', '{ display: none; }'], ['.slds-tree__item:hover .tree-buttons', '{ display: initial; }']]); return _this; } // TODO: revert it babeljs bug https://phabricator.babeljs.io/T2892 (0, _createClass3.default)(TreeNode, [{ key: 'onToggleEvent', value: function onToggleEvent(e) { var _props = this.props, onToggle = _props.onToggle, onNodeToggle = _props.onNodeToggle; if (onToggle) { onToggle(e, this.props); } if (onNodeToggle) { onNodeToggle(e, this.props); } this.setState({ opened: !this.state.opened }); } }, { key: 'onLabelClickEvent', value: function onLabelClickEvent(e) { var _props2 = this.props, onLabelClick = _props2.onLabelClick, onNodeLabelClick = _props2.onNodeLabelClick; if (onLabelClick) { onLabelClick(e, this.props); } if (onNodeLabelClick) { onNodeLabelClick(e, this.props); } } }, { key: 'onClickEvent', value: function onClickEvent(e) { var _props3 = this.props, onClick = _props3.onClick, onNodeClick = _props3.onNodeClick, toggleOnNodeClick = _props3.toggleOnNodeClick; if (onClick) { onClick(e, this.props); } if (onNodeClick) { onNodeClick(e, this.props); } if (toggleOnNodeClick) { this.onToggleEvent(e); } } }, { key: 'renderTreeItem', value: function renderTreeItem(itemProps) { var className = itemProps.className, label = itemProps.label, _itemProps$icon = itemProps.icon, icon = _itemProps$icon === undefined ? 'chevronright' : _itemProps$icon, loading = itemProps.loading, selected = itemProps.selected, leaf = itemProps.leaf, isOpened = itemProps.isOpened, controls = itemProps.controls, children = itemProps.children, useInput = itemProps.useInput, props = (0, _objectWithoutProperties3.default)(itemProps, ['className', 'label', 'icon', 'loading', 'selected', 'leaf', 'isOpened', 'controls', 'children', 'useInput']); var itmClassNames = (0, _classnames2.default)(className, 'slds-tree__item', { 'slds-is-open': isOpened, 'slds-is-selected': selected }); var pprops = props; delete pprops.onNodeToggle; delete pprops.onNodeClick; delete pprops.onNodeLabelClick; delete pprops.toggleOnNodeClick; delete pprops.showAllways; return _react2.default.createElement( 'div', (0, _extends3.default)({ className: itmClassNames, onClick: this.onClickEvent.bind(this) }, pprops), loading ? _react2.default.createElement(_Spinner2.default, { size: 'small', className: 'slds-m-right--x-small' }) : !leaf ? _react2.default.createElement(_Button2.default, { className: 'slds-m-right--small', 'aria-controls': '', type: 'icon-bare', icon: icon, iconSize: 'small', onClick: this.onToggleEvent.bind(this) }) : null, useInput ? _react2.default.createElement( 'div', { className: 'treeNodeInputHolder' }, useInput ) : _react2.default.createElement( 'a', { className: 'slds-truncate', tabIndex: -1, role: 'presentation' }, label ), leaf ? children : null, controls ? _react2.default.createElement( 'div', { className: !props.showAllways ? 'tree-buttons' : undefined, style: { marginLeft: 'auto' } }, controls ) : null ); } }, { key: 'renderChildNode', value: function renderChildNode(level, tnode) { var _props4 = this.props, onNodeClick = _props4.onNodeClick, onNodeToggle = _props4.onNodeToggle, onNodeLabelClick = _props4.onNodeLabelClick, toggleOnNodeClick = _props4.toggleOnNodeClick; return _react2.default.cloneElement(tnode, { level: level, onNodeClick: onNodeClick, onNodeToggle: onNodeToggle, onNodeLabelClick: onNodeLabelClick, toggleOnNodeClick: toggleOnNodeClick }); } }, { key: 'render', value: function render() { var _props5 = this.props, defaultOpened = _props5.defaultOpened, opened = _props5.opened, leaf = _props5.leaf, level = _props5.level, children = _props5.children, props = (0, _objectWithoutProperties3.default)(_props5, ['defaultOpened', 'opened', 'leaf', 'level', 'children']); var isOpened = typeof opened !== 'undefined' ? opened : typeof this.state.opened !== 'undefined' ? this.state.opened : defaultOpened; var grpClassNames = (0, _classnames2.default)('slds-tree__group', { 'slds-nested': !leaf, 'is-expanded': isOpened, 'slds-show': isOpened, 'slds-hide': !isOpened }); var itemProps = (0, _extends3.default)({ leaf: leaf, isOpened: isOpened, children: children }, props); if (leaf) { return _react2.default.createElement( 'li', { role: 'treeitem', 'aria-level': level }, this.renderTreeItem(itemProps) ); } return _react2.default.createElement( 'li', { role: 'treeitem', 'aria-level': level, 'aria-expanded': isOpened }, this.renderTreeItem(itemProps), _react2.default.createElement( 'ul', { className: grpClassNames, role: 'group' }, _react2.default.Children.map(children, this.renderChildNode.bind(this, level + 1)) ) ); } }]); return TreeNode; }(_react.Component); exports.default = TreeNode; TreeNode.propTypes = { className: _propTypes2.default.string, label: _propTypes2.default.string, onClick: _propTypes2.default.func, onToggle: _propTypes2.default.func, onNodeToggle: _propTypes2.default.func, onNodeLabelClick: _propTypes2.default.func, onLabelClick: _propTypes2.default.func, onNodeClick: _propTypes2.default.func, toggleOnNodeClick: _propTypes2.default.bool, defaultOpened: _propTypes2.default.bool, opened: _propTypes2.default.bool, leaf: _propTypes2.default.bool, level: _propTypes2.default.number, children: _propTypes2.default.node, controls: _propTypes2.default.arrayOf(_propTypes2.default.element), showAllways: _propTypes2.default.bool }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/TreeNode.js"],"names":["TreeNode","props","state","opened","defaultOpened","onLabelClickEvent","bind","e","onToggle","onNodeToggle","setState","onLabelClick","onNodeLabelClick","onClick","onNodeClick","toggleOnNodeClick","onToggleEvent","itemProps","className","label","icon","loading","selected","leaf","isOpened","controls","children","useInput","itmClassNames","pprops","showAllways","onClickEvent","undefined","marginLeft","level","tnode","cloneElement","grpClassNames","renderTreeItem","Children","map","renderChildNode","propTypes","string","func","bool","number","node","arrayOf","element"],"mappings":"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","file":"TreeNode.js","sourcesContent":["import React, { Component } from 'react';\nimport classnames from 'classnames';\nimport Button from './Button';\nimport Spinner from './Spinner';\nimport { registerStyle } from './util';\nimport PropTypes from 'prop-types';\n\nexport default class TreeNode extends Component {\n  constructor(props) {\n    super(props);\n    this.state = { opened: this.props.defaultOpened };\n    this.onLabelClickEvent = this.onLabelClickEvent.bind(this);\n    registerStyle('tree-node', [\n      [\n        '.slds-tree__item .tree-buttons',\n        '{ display: none; }',\n      ],\n      [\n        '.slds-tree__item:hover .tree-buttons',\n        '{ display: initial; }',\n      ],\n    ]);\n  }\n\n  // TODO: revert it babeljs bug https://phabricator.babeljs.io/T2892\n  onToggleEvent(e) {\n    const { onToggle, onNodeToggle } = this.props;\n    if (onToggle) { onToggle(e, this.props); }\n    if (onNodeToggle) { onNodeToggle(e, this.props); }\n    this.setState({ opened: !this.state.opened });\n  }\n\n  onLabelClickEvent(e) {\n    const { onLabelClick, onNodeLabelClick } = this.props;\n    if (onLabelClick) { onLabelClick(e, this.props); }\n    if (onNodeLabelClick) { onNodeLabelClick(e, this.props); }\n  }\n\n  onClickEvent(e) {\n    const { onClick, onNodeClick, toggleOnNodeClick } = this.props;\n    if (onClick) { onClick(e, this.props); }\n    if (onNodeClick) { onNodeClick(e, this.props); }\n    if (toggleOnNodeClick) {\n      this.onToggleEvent(e);\n    }\n  }\n\n\n  renderTreeItem(itemProps) {\n    const {\n      className, label, icon = 'chevronright', loading, selected, leaf, isOpened, controls,\n      children, useInput, ...props,\n    } = itemProps;\n    const itmClassNames = classnames(className, 'slds-tree__item', {\n      'slds-is-open': isOpened,\n      'slds-is-selected': selected,\n    });\n    const pprops = props;\n    delete pprops.onNodeToggle;\n    delete pprops.onNodeClick;\n    delete pprops.onNodeLabelClick;\n    delete pprops.toggleOnNodeClick;\n    delete pprops.showAllways;\n    return (\n      <div\n        className={ itmClassNames }\n        onClick={ this.onClickEvent.bind(this) }\n        { ...pprops }\n      >\n        {\n          loading ? <Spinner size='small' className='slds-m-right--x-small' /> :\n          !leaf ?\n            <Button\n              className='slds-m-right--small'\n              aria-controls=''\n              type='icon-bare'\n              icon={ icon }\n              iconSize='small'\n              onClick={ this.onToggleEvent.bind(this) }\n            /> :\n            null\n        }\n        {\n          useInput\n          ?\n            <div className='treeNodeInputHolder'>{useInput}</div>\n          :\n            <a\n              className='slds-truncate'\n              tabIndex={ -1 }\n              role='presentation'\n            >\n              {label}\n            </a>\n        }\n        { leaf ? children : null }\n        { controls\n          ? <div\n            className={!props.showAllways ? 'tree-buttons' : undefined }\n            style={{ marginLeft: 'auto' }}\n          >\n            {controls}\n          </div>\n          : null }\n      </div>\n    );\n  }\n\n  renderChildNode(level, tnode) {\n    const { onNodeClick, onNodeToggle, onNodeLabelClick, toggleOnNodeClick } = this.props;\n    return React.cloneElement(tnode, {\n      level, onNodeClick, onNodeToggle, onNodeLabelClick, toggleOnNodeClick,\n    });\n  }\n\n  render() {\n    const {\n      defaultOpened, opened, leaf, level,\n      children, ...props,\n    } = this.props;\n    const isOpened =\n      typeof opened !== 'undefined' ? opened :\n      typeof this.state.opened !== 'undefined' ? this.state.opened :\n      defaultOpened;\n    const grpClassNames = classnames('slds-tree__group', {\n      'slds-nested': !leaf,\n      'is-expanded': isOpened,\n      'slds-show': isOpened,\n      'slds-hide': !isOpened,\n    });\n    const itemProps = { leaf, isOpened, children, ...props };\n    if (leaf) {\n      return (\n        <li role='treeitem' aria-level={ level }>\n          { this.renderTreeItem(itemProps) }\n        </li>\n      );\n    }\n\n    return (\n      <li\n        role='treeitem'\n        aria-level={ level }\n        aria-expanded={ isOpened }\n      >\n        { this.renderTreeItem(itemProps) }\n        <ul className={ grpClassNames } role='group'>\n          { React.Children.map(children, this.renderChildNode.bind(this, level + 1)) }\n        </ul>\n      </li>\n    );\n  }\n}\n\n\nTreeNode.propTypes = {\n  className: PropTypes.string,\n  label: PropTypes.string,\n  onClick: PropTypes.func,\n  onToggle: PropTypes.func,\n  onNodeToggle: PropTypes.func,\n  onNodeLabelClick: PropTypes.func,\n  onLabelClick: PropTypes.func,\n  onNodeClick: PropTypes.func,\n  toggleOnNodeClick: PropTypes.bool,\n  defaultOpened: PropTypes.bool,\n  opened: PropTypes.bool,\n  leaf: PropTypes.bool,\n  level: PropTypes.number,\n  children: PropTypes.node,\n  controls: PropTypes.arrayOf(PropTypes.element),\n  showAllways: PropTypes.bool,\n};\n"]}