react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
197 lines (153 loc) • 18.7 kB
JavaScript
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ButtonIcon = exports.BUTTON_TYPES = undefined;
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
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 _classnames2 = require('classnames');
var _classnames3 = _interopRequireDefault(_classnames2);
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
var _Icon = require('./Icon');
var _Icon2 = _interopRequireDefault(_Icon);
var _util = require('./util');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var Button = function (_Component) {
(0, _inherits3.default)(Button, _Component);
function Button(props) {
(0, _classCallCheck3.default)(this, Button);
var _this = (0, _possibleConstructorReturn3.default)(this, (Button.__proto__ || (0, _getPrototypeOf2.default)(Button)).call(this, props));
(0, _util.registerStyle)('button', [['.slds-button__icon--medium2', '{ width: 1.1rem; height: 1.1rem; }'], ['.slds-button__icon--x-small2', '{ width: 0.67rem; height: 0.67rem; }']]);
return _this;
}
(0, _createClass3.default)(Button, [{
key: 'renderIcon',
value: function renderIcon() {
var _props = this.props,
icon = _props.icon,
iconAlign = _props.iconAlign,
iconSize = _props.iconSize,
type = _props.type;
var inverse = this.props.inverse;
inverse = inverse || /\-?inverse$/.test(type);
return _react2.default.createElement(ButtonIcon, { icon: icon, align: iconAlign, size: iconSize, inverse: inverse });
}
}, {
key: 'renderIconMore',
value: function renderIconMore() {
var _props2 = this.props,
iconMore = _props2.iconMore,
icon = _props2.icon,
iconAlign = _props2.iconAlign,
label = _props2.label,
children = _props2.children;
var adjoining = icon && (iconAlign === 'right' || !(label || children));
var iconMoreSize = this.props.iconMoreSize || adjoining ? 'x-small' : 'small';
return _react2.default.createElement(ButtonIcon, { icon: iconMore, align: 'right', size: iconMoreSize });
}
}, {
key: 'render',
value: function render() {
var _classnames;
var _props3 = this.props,
className = _props3.className,
type = _props3.type,
size = _props3.size,
icon = _props3.icon,
iconAlign = _props3.iconAlign,
iconMore = _props3.iconMore,
selected = _props3.selected,
alt = _props3.alt,
label = _props3.label,
_props3$htmlType = _props3.htmlType,
htmlType = _props3$htmlType === undefined ? 'button' : _props3$htmlType,
children = _props3.children,
props = (0, _objectWithoutProperties3.default)(_props3, ['className', 'type', 'size', 'icon', 'iconAlign', 'iconMore', 'selected', 'alt', 'label', 'htmlType', 'children']);
var typeClassName = type ? 'slds-button--' + type : null;
var btnClassNames = (0, _classnames3.default)(className, 'slds-button', typeClassName, (_classnames = {
'slds-is-selected': selected
}, (0, _defineProperty3.default)(_classnames, 'slds-button--' + size, size && !/^icon-/.test(type)), (0, _defineProperty3.default)(_classnames, 'slds-button--icon-' + size, /^(x-small|small)$/.test(size) && /^icon-/.test(type)), _classnames));
var pprops = props;
delete pprops.inverse;
delete pprops.iconSize;
return _react2.default.createElement(
'button',
(0, _extends3.default)({
className: btnClassNames,
type: htmlType }, pprops),
icon && iconAlign !== 'right' ? this.renderIcon() : null,
children || label,
icon && iconAlign === 'right' ? this.renderIcon() : null,
iconMore ? this.renderIconMore() : null,
alt ? _react2.default.createElement(
'span',
{ className: 'slds-assistive-text' },
alt
) : null
);
}
}]);
return Button;
}(_react.Component);
exports.default = Button;
var BUTTON_TYPES = exports.BUTTON_TYPES = ['neutral', 'brand', 'destructive', 'inverse', 'icon-bare', 'icon-container', 'icon-inverse', 'icon-more', 'icon-border', 'icon-border-filled'];
var BUTTON_SIZES = ['x-small', 'small', 'medium', 'large'];
var ICON_SIZES = ['x-small', 'x-small2', 'small', 'medium', 'medium2', 'large'];
var ICON_ALIGNMENTS = ['left', 'right'];
Button.propTypes = {
className: _propTypes2.default.string,
label: _propTypes2.default.node,
alt: _propTypes2.default.string,
type: _propTypes2.default.oneOf(BUTTON_TYPES),
size: _propTypes2.default.oneOf(BUTTON_SIZES),
htmlType: _propTypes2.default.string,
disabled: _propTypes2.default.bool,
selected: _propTypes2.default.bool,
inverse: _propTypes2.default.bool,
icon: _propTypes2.default.string,
iconSize: _propTypes2.default.oneOf(ICON_SIZES),
iconAlign: _propTypes2.default.oneOf(ICON_ALIGNMENTS),
iconMore: _propTypes2.default.string,
iconMoreSize: _propTypes2.default.oneOf(ICON_SIZES),
children: _propTypes2.default.node,
labelColor: _propTypes2.default.string
};
var ButtonIcon = function ButtonIcon(_ref) {
var icon = _ref.icon,
align = _ref.align,
size = _ref.size,
inverse = _ref.inverse,
className = _ref.className,
props = (0, _objectWithoutProperties3.default)(_ref, ['icon', 'align', 'size', 'inverse', 'className']);
var alignClassName = ICON_ALIGNMENTS.indexOf(align) >= 0 ? 'slds-button__icon--' + align : null;
var sizeClassName = ICON_SIZES.indexOf(size) >= 0 ? 'slds-button__icon--' + size : null;
var inverseClassName = inverse ? 'slds-button__icon--inverse' : null;
var iconClassNames = (0, _classnames3.default)('slds-button__icon', alignClassName, sizeClassName, inverseClassName, className);
return _react2.default.createElement(_Icon2.default, (0, _extends3.default)({ className: iconClassNames, icon: icon, textColor: null }, props));
};
exports.ButtonIcon = ButtonIcon;
ButtonIcon.propTypes = {
className: _propTypes2.default.string,
icon: _propTypes2.default.string,
align: _propTypes2.default.oneOf(ICON_ALIGNMENTS),
size: _propTypes2.default.oneOf(ICON_SIZES),
inverse: _propTypes2.default.bool
};
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/Button.js"],"names":["Button","props","icon","iconAlign","iconSize","type","inverse","test","iconMore","label","children","adjoining","iconMoreSize","className","size","selected","alt","htmlType","typeClassName","btnClassNames","pprops","renderIcon","renderIconMore","BUTTON_TYPES","BUTTON_SIZES","ICON_SIZES","ICON_ALIGNMENTS","propTypes","string","node","oneOf","disabled","bool","labelColor","ButtonIcon","align","alignClassName","indexOf","sizeClassName","inverseClassName","iconClassNames"],"mappings":"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","file":"Button.js","sourcesContent":["import React, { Component } from 'react';\nimport classnames from 'classnames';\nimport PropTypes from 'prop-types';\nimport Icon from './Icon';\nimport { registerStyle } from './util';\n\nexport default class Button extends Component {\n  constructor(props) {\n    super(props);\n    registerStyle('button', [\n      [\n        '.slds-button__icon--medium2',\n        '{ width: 1.1rem; height: 1.1rem; }',\n      ],\n      [\n        '.slds-button__icon--x-small2',\n        '{ width: 0.67rem; height: 0.67rem; }',\n      ],\n    ]);\n  }\n\n  renderIcon() {\n    const { icon, iconAlign, iconSize, type } = this.props;\n    let { inverse } = this.props;\n    inverse = inverse || /\\-?inverse$/.test(type);\n    return <ButtonIcon icon={ icon } align={ iconAlign } size={ iconSize } inverse={ inverse } />;\n  }\n\n  renderIconMore() {\n    const { iconMore, icon, iconAlign, label, children } = this.props;\n    const adjoining = icon && (iconAlign === 'right' || !(label || children));\n    const iconMoreSize = this.props.iconMoreSize || adjoining ? 'x-small' : 'small';\n    return <ButtonIcon icon={ iconMore } align='right' size={ iconMoreSize } />;\n  }\n\n  render() {\n    const {\n      className, type, size, icon, iconAlign, iconMore, selected, alt, label,\n      htmlType = 'button', children, ...props,\n    } = this.props;\n    const typeClassName = type ? `slds-button--${type}` : null;\n    const btnClassNames = classnames(\n      className,\n      'slds-button',\n      typeClassName,\n      {\n        'slds-is-selected': selected,\n        [`slds-button--${size}`]: size && !/^icon-/.test(type),\n        [`slds-button--icon-${size}`]: /^(x-small|small)$/.test(size) && /^icon-/.test(type),\n      }\n    );\n    const pprops = props;\n    delete pprops.inverse;\n    delete pprops.iconSize;\n    return (\n      <button\n        className={ btnClassNames }\n        type={ htmlType } { ...pprops }\n      >\n        { icon && iconAlign !== 'right' ? this.renderIcon() : null }\n        { children || label }\n        { icon && iconAlign === 'right' ? this.renderIcon() : null }\n        { iconMore ? this.renderIconMore() : null }\n        { alt ? <span className='slds-assistive-text'>{ alt }</span> : null }\n      </button>\n    );\n  }\n}\n\nexport const BUTTON_TYPES = [\n  'neutral',\n  'brand',\n  'destructive',\n  'inverse',\n  'icon-bare',\n  'icon-container',\n  'icon-inverse',\n  'icon-more',\n  'icon-border',\n  'icon-border-filled',\n];\n\nconst BUTTON_SIZES = ['x-small', 'small', 'medium', 'large'];\n\nconst ICON_SIZES = ['x-small', 'x-small2', 'small', 'medium', 'medium2', 'large'];\n\nconst ICON_ALIGNMENTS = ['left', 'right'];\n\nButton.propTypes = {\n  className: PropTypes.string,\n  label: PropTypes.node,\n  alt: PropTypes.string,\n  type: PropTypes.oneOf(BUTTON_TYPES),\n  size: PropTypes.oneOf(BUTTON_SIZES),\n  htmlType: PropTypes.string,\n  disabled: PropTypes.bool,\n  selected: PropTypes.bool,\n  inverse: PropTypes.bool,\n  icon: PropTypes.string,\n  iconSize: PropTypes.oneOf(ICON_SIZES),\n  iconAlign: PropTypes.oneOf(ICON_ALIGNMENTS),\n  iconMore: PropTypes.string,\n  iconMoreSize: PropTypes.oneOf(ICON_SIZES),\n  children: PropTypes.node,\n  labelColor: PropTypes.string,\n};\n\n\nexport const ButtonIcon = ({ icon, align, size, inverse, className, ...props }) => {\n  const alignClassName = ICON_ALIGNMENTS.indexOf(align) >= 0 ? `slds-button__icon--${align}` : null;\n  const sizeClassName = ICON_SIZES.indexOf(size) >= 0 ? `slds-button__icon--${size}` : null;\n  const inverseClassName = inverse ? 'slds-button__icon--inverse' : null;\n  const iconClassNames = classnames('slds-button__icon', alignClassName, sizeClassName,\n    inverseClassName, className);\n  return <Icon className={ iconClassNames } icon={ icon } textColor={ null } { ...props } />;\n};\n\nButtonIcon.propTypes = {\n  className: PropTypes.string,\n  icon: PropTypes.string,\n  align: PropTypes.oneOf(ICON_ALIGNMENTS),\n  size: PropTypes.oneOf(ICON_SIZES),\n  inverse: PropTypes.bool,\n};\n"]}