UNPKG

@brightleaf/elements

Version:

React UI elements styled with Bulma CSS

104 lines (85 loc) 5.45 kB
"use strict"; function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.TextInput = void 0; var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _propTypes = _interopRequireDefault(require("prop-types")); var _useFormElement2 = _interopRequireDefault(require("react-form-elements/lib/utils/use-form-element")); var _elementAttributes = _interopRequireDefault(require("../element-attributes")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; } function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; } function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } /** * TextBox Component. * */ var TextInput = (0, _react.forwardRef)(function (_ref, ref) { var name = _ref.name, initialValue = _ref.initialValue, label = _ref.label, type = _ref.type, className = _ref.className, controlClassName = _ref.controlClassName, labelClassName = _ref.labelClassName, inputClassName = _ref.inputClassName, children = _ref.children, otherProps = _objectWithoutProperties(_ref, ["name", "initialValue", "label", "type", "className", "controlClassName", "labelClassName", "inputClassName", "children"]); var _useFormElement = (0, _useFormElement2.default)(initialValue, ref), id = _useFormElement.id, value = _useFormElement.value, handleChange = _useFormElement.handleChange, inputRef = _useFormElement.inputRef; var labelStyleProp = labelClassName === '' ? {} : { className: labelClassName }; var inputStyleProp = inputClassName === '' ? {} : { className: inputClassName }; var hasLabel = label.length > 0; var clean = _elementAttributes.default['*'].concat(_elementAttributes.default['input'] || []).reduce(function (objs, current) { if (otherProps[current]) { objs[current] = otherProps[current]; } return objs; }, {}); return _react.default.createElement("div", { className: (0, _classnames.default)('field', className) }, hasLabel && _react.default.createElement("label", _extends({ htmlFor: id }, labelStyleProp), label || ''), _react.default.createElement("div", { className: (0, _classnames.default)('control', controlClassName) }, _react.default.createElement("input", _extends({ type: type, id: id, ref: inputRef, name: name, onChange: handleChange, value: value }, inputStyleProp, clean)), children)); }); exports.TextInput = TextInput; TextInput.displayName = 'BrightleafElements(TextInput)'; var _default = TextInput; exports.default = _default; TextInput.propTypes = { name: _propTypes.default.string, initialValue: _propTypes.default.string, label: _propTypes.default.string, type: _propTypes.default.string, className: _propTypes.default.string, controlClassName: _propTypes.default.string, inputClassName: _propTypes.default.string, labelClassName: _propTypes.default.string }; TextInput.defaultProps = { name: 'TextInput', initialValue: '', type: 'text', label: 'label' };