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