UNPKG

react-tm-nucleus

Version:
106 lines (80 loc) 3.57 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 _select = require('./select'); var _select2 = _interopRequireDefault(_select); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var Dropdown = function (_React$Component) { (0, _inherits3.default)(Dropdown, _React$Component); function Dropdown(props) { (0, _classCallCheck3.default)(this, Dropdown); return (0, _possibleConstructorReturn3.default)(this, (0, _getPrototypeOf2.default)(Dropdown).call(this, props)); } (0, _createClass3.default)(Dropdown, [{ key: 'value', value: function value(v) { return this.refs.select.value(v); } }, { key: 'required', value: function required(v) { return this.refs.select.required(v); } }, { key: 'multiple', value: function multiple(v) { return this.refs.select.multiple(v); } }, { key: 'render', value: function render() { var _props = this.props; var label = _props.label; var icon = _props.icon; var other = (0, _objectWithoutProperties3.default)(_props, ['label', 'icon']); var labelHTML = label + ((this.refs.select ? this.refs.select.required() : this.props.required) ? '&nbsp;<span class="input-group__required">*</span>' : ''); return _react2.default.createElement( 'div', { className: 'input-group dropdown' }, _react2.default.createElement( _select2.default, (0, _extends3.default)({}, other, { ref: 'select' }), this.props.children ), _react2.default.createElement('label', { htmlFor: other.id, className: 'input-group__label', dangerouslySetInnerHTML: { __html: labelHTML } }), _react2.default.createElement('svg', { className: 'dropdown__icon-chevron', dangerouslySetInnerHTML: { __html: icon } }) ); } }]); return Dropdown; }(_react2.default.Component); Dropdown.propTypes = { id: _react2.default.PropTypes.string, label: _react2.default.PropTypes.string, icon: _react2.default.PropTypes.string, required: _react2.default.PropTypes.bool }; Dropdown.defaultProps = { id: '', label: '', icon: '', required: false }; exports.default = Dropdown;