react-lightning-design-components
Version:
Salesforce Lightning Design System components built with React 16
192 lines (152 loc) • 18.5 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 _typeof2 = require('babel-runtime/helpers/typeof');
var _typeof3 = _interopRequireDefault(_typeof2);
var _defineProperty2 = require('babel-runtime/helpers/defineProperty');
var _defineProperty3 = _interopRequireDefault(_defineProperty2);
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 _util = require('./util');
var _propTypes = require('prop-types');
var _propTypes2 = _interopRequireDefault(_propTypes);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var FormElement = function (_React$Component) {
(0, _inherits3.default)(FormElement, _React$Component);
function FormElement(props) {
(0, _classCallCheck3.default)(this, FormElement);
/* eslint-disable max-len */
var _this = (0, _possibleConstructorReturn3.default)(this, (FormElement.__proto__ || (0, _getPrototypeOf2.default)(FormElement)).call(this, props));
(0, _util.registerStyle)('dropdown', [['.react-slds-dropdown-control-wrapper', '{ height: 0; }'], ['.slds-has-error .react-slds-dropdown-control-wrapper', '{ height: auto; }'], ['.react-slds-dropdown-control-wrapper > .slds-form-element__control', '{ position: relative; padding-top: 0.1px; margin-top: -0.1px }'], ['.react-slds-dropdown-form-element', '{ position: static; }'], ['.slds-form--horizontal .react-slds-dropdown-control-wrapper .slds-dropdown', '{ top: -1em; }'], ['.slds-form--horizontal .react-slds-dropdown-control-wrapper .slds-lookup__menu', '{ top: -1em; }'], ['.slds-form--horizontal .slds-has-error .react-slds-dropdown-control-wrapper .slds-dropdown', '{ top: 0; }'], ['.slds-modal .react-slds-dropdown-control-wrapper > .slds-form-element__control', '{ position: absolute; }']]);
return _this;
}
(0, _createClass3.default)(FormElement, [{
key: 'renderFormElement',
value: function renderFormElement(props) {
var className = props.className,
error = props.error,
totalCols = props.totalCols,
_props$cols = props.cols,
cols = _props$cols === undefined ? 1 : _props$cols,
children = props.children;
var formElementClassNames = (0, _classnames3.default)('slds-form-element', (0, _defineProperty3.default)({
'slds-has-error': error
}, 'slds-size--' + cols + '-of-' + totalCols, typeof totalCols === 'number'), className);
return _react2.default.createElement(
'div',
{ key: 'form-element', className: formElementClassNames },
children
);
}
}, {
key: 'renderLabel',
value: function renderLabel() {
var _props = this.props,
id = _props.id,
label = _props.label,
required = _props.required,
tooltip = _props.tooltip;
return label ? _react2.default.createElement(
'label',
{
key: 'form-element-label',
className: 'slds-form-element__label',
htmlFor: id
},
label,
required ? _react2.default.createElement(
'abbr',
{ className: 'slds-required' },
'*'
) : undefined,
tooltip
) : undefined;
}
}, {
key: 'renderControl',
value: function renderControl(props) {
var error = props.error,
children = props.children;
var errorMessage = error ? typeof error === 'string' ? error : (typeof error === 'undefined' ? 'undefined' : (0, _typeof3.default)(error)) === 'object' ? error.message : undefined : undefined;
return _react2.default.createElement(
'div',
{ key: 'form-element-control', className: 'slds-form-element__control' },
children,
errorMessage ? _react2.default.createElement(
'span',
{ className: 'slds-form-element__help' },
errorMessage
) : undefined
);
}
}, {
key: 'render',
value: function render() {
var _props2 = this.props,
dropdown = _props2.dropdown,
className = _props2.className,
totalCols = _props2.totalCols,
cols = _props2.cols,
error = _props2.error,
children = _props2.children,
props = (0, _objectWithoutProperties3.default)(_props2, ['dropdown', 'className', 'totalCols', 'cols', 'error', 'children']);
var labelElem = this.renderLabel();
if (dropdown) {
var _controlElem = this.renderControl({ children: children });
var _formElemChildren = [labelElem, _controlElem];
var innerFormElem = this.renderFormElement((0, _extends3.default)({}, props, { children: _formElemChildren }));
var outerControlElem = this.renderControl({ error: error, children: dropdown });
var outerFormElemChildren = [innerFormElem, _react2.default.createElement(
'div',
{ key: 'dropdown-control-wrapper', className: 'react-slds-dropdown-control-wrapper' },
outerControlElem
)];
var outerFormClassName = (0, _classnames3.default)('react-slds-dropdown-form-element', className);
return this.renderFormElement((0, _extends3.default)({}, props, { error: error, totalCols: totalCols, cols: cols,
className: outerFormClassName,
children: outerFormElemChildren
}));
}
var controlElem = this.renderControl({ children: children, error: error });
var formElemChildren = [labelElem, controlElem];
return this.renderFormElement((0, _extends3.default)({}, props, { className: className, error: error, totalCols: totalCols, cols: cols,
children: formElemChildren
}));
}
}]);
return FormElement;
}(_react2.default.Component);
exports.default = FormElement;
FormElement.propTypes = {
id: _propTypes2.default.string,
className: _propTypes2.default.string,
label: _propTypes2.default.string,
required: _propTypes2.default.bool,
error: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.string, _propTypes2.default.shape({
message: _propTypes2.default.string
})]),
cols: _propTypes2.default.number,
totalCols: _propTypes2.default.number,
dropdown: _propTypes2.default.element,
children: _propTypes2.default.element,
tooltip: _propTypes2.default.element
};
FormElement.isFormElement = true;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/scripts/FormElement.js"],"names":["FormElement","props","className","error","totalCols","cols","children","formElementClassNames","id","label","required","tooltip","undefined","errorMessage","message","dropdown","labelElem","renderLabel","controlElem","renderControl","formElemChildren","innerFormElem","renderFormElement","outerControlElem","outerFormElemChildren","outerFormClassName","Component","propTypes","string","bool","oneOfType","shape","number","element","isFormElement"],"mappings":"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","file":"FormElement.js","sourcesContent":["import React from 'react';\nimport classnames from 'classnames';\nimport { registerStyle } from './util';\nimport PropTypes from 'prop-types';\n\n\nexport default class FormElement extends React.Component {\n\n  constructor(props) {\n    super(props);\n    /* eslint-disable max-len */\n    registerStyle('dropdown', [\n      [\n        '.react-slds-dropdown-control-wrapper',\n        '{ height: 0; }',\n      ],\n      [\n        '.slds-has-error .react-slds-dropdown-control-wrapper',\n        '{ height: auto; }',\n      ],\n      [\n        '.react-slds-dropdown-control-wrapper > .slds-form-element__control',\n        '{ position: relative; padding-top: 0.1px; margin-top: -0.1px }',\n      ],\n      [\n        '.react-slds-dropdown-form-element',\n        '{ position: static; }',\n      ],\n      [\n        '.slds-form--horizontal .react-slds-dropdown-control-wrapper .slds-dropdown',\n        '{ top: -1em; }',\n      ],\n      [\n        '.slds-form--horizontal .react-slds-dropdown-control-wrapper .slds-lookup__menu',\n        '{ top: -1em; }',\n      ],\n      [\n        '.slds-form--horizontal .slds-has-error .react-slds-dropdown-control-wrapper .slds-dropdown',\n        '{ top: 0; }',\n      ],\n      [\n        '.slds-modal .react-slds-dropdown-control-wrapper > .slds-form-element__control',\n        '{ position: absolute; }',\n      ],\n    ]);\n  }\n\n  renderFormElement(props) {\n    const { className, error, totalCols, cols = 1, children } = props;\n    const formElementClassNames = classnames(\n      'slds-form-element',\n      {\n        'slds-has-error': error,\n        [`slds-size--${cols}-of-${totalCols}`]: typeof totalCols === 'number',\n      },\n      className\n    );\n    return (\n      <div key='form-element' className={ formElementClassNames }>\n        { children }\n      </div>\n    );\n  }\n\n  renderLabel() {\n    const { id, label, required, tooltip } = this.props;\n    return (\n      label ?\n        <label\n          key='form-element-label'\n          className='slds-form-element__label'\n          htmlFor={ id }\n        >\n          { label }\n          {\n            required ?\n              <abbr className='slds-required'>*</abbr> :\n              undefined\n          }\n          { tooltip }\n        </label> :\n        undefined\n    );\n  }\n\n  renderControl(props) {\n    const { error, children } = props;\n    const errorMessage =\n      error ?\n      (typeof error === 'string' ? error :\n       typeof error === 'object' ? error.message :\n       undefined) :\n      undefined;\n    return (\n      <div key='form-element-control' className='slds-form-element__control'>\n        { children }\n        {\n          errorMessage ?\n            <span className='slds-form-element__help'>{ errorMessage }</span> :\n            undefined\n        }\n      </div>\n    );\n  }\n\n  render() {\n    const { dropdown, className, totalCols, cols, error, children, ...props } = this.props;\n    const labelElem = this.renderLabel();\n    if (dropdown) {\n      const controlElem = this.renderControl({ children });\n      const formElemChildren = [labelElem, controlElem];\n      const innerFormElem = this.renderFormElement({ ...props, children: formElemChildren });\n      const outerControlElem = this.renderControl({ error, children: dropdown });\n      const outerFormElemChildren = [\n        innerFormElem,\n        <div key='dropdown-control-wrapper' className='react-slds-dropdown-control-wrapper'>{ outerControlElem }</div>,\n      ];\n      const outerFormClassName = classnames('react-slds-dropdown-form-element', className);\n      return this.renderFormElement({\n        ...props, error, totalCols, cols,\n        className: outerFormClassName,\n        children: outerFormElemChildren,\n      });\n    }\n    const controlElem = this.renderControl({ children, error });\n    const formElemChildren = [labelElem, controlElem];\n    return this.renderFormElement({\n      ...props, className, error, totalCols, cols,\n      children: formElemChildren,\n    });\n  }\n\n}\n\nFormElement.propTypes = {\n  id: PropTypes.string,\n  className: PropTypes.string,\n  label: PropTypes.string,\n  required: PropTypes.bool,\n  error: PropTypes.oneOfType([\n    PropTypes.bool,\n    PropTypes.string,\n    PropTypes.shape({\n      message: PropTypes.string,\n    }),\n  ]),\n  cols: PropTypes.number,\n  totalCols: PropTypes.number,\n  dropdown: PropTypes.element,\n  children: PropTypes.element,\n  tooltip: PropTypes.element,\n};\n\nFormElement.isFormElement = true;\n"]}