UNPKG

react-lightning-design-components

Version:

Salesforce Lightning Design System components built with React 16

192 lines (152 loc) 18.5 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 _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"]}