UNPKG

@e-group/material-module

Version:
155 lines (129 loc) 6.44 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireDefault(require("react")); var _clsx = _interopRequireDefault(require("clsx")); var _reactSelect = require("react-select"); var _core = require("@material-ui/core"); var _Cancel = _interopRequireDefault(require("@material-ui/icons/Cancel")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } const NoOptionsMessage = props => /*#__PURE__*/_react.default.createElement(_core.Typography, (0, _extends2.default)({ color: "textSecondary", className: props.selectProps.classes.noOptionsMessage }, props.innerProps), props.children); const inputComponent = props => { const inputRef = props.inputRef, other = (0, _objectWithoutProperties2.default)(props, ["inputRef"]); return /*#__PURE__*/_react.default.createElement("div", (0, _extends2.default)({ ref: inputRef }, other)); }; const Control = props => { const _ref = props.selectProps.MuiTextFieldProps || {}, InputLabelProps = _ref.InputLabelProps, InputProps = _ref.InputProps, inputProps = _ref.inputProps, variant = _ref.variant, other = (0, _objectWithoutProperties2.default)(_ref, ["InputLabelProps", "InputProps", "inputProps", "variant"]); const inputValue = props.selectProps.inputValue; const isMulti = props.isMulti; const isFilled = variant === 'filled'; const isOutlined = variant === 'outlined'; const isStandard = !isFilled && !isOutlined; return /*#__PURE__*/_react.default.createElement(_core.TextField, (0, _extends2.default)({ InputLabelProps: _objectSpread({ shrink: props.isFocused || props.hasValue || inputValue !== '' }, InputLabelProps), InputProps: _objectSpread({ inputComponent }, InputProps), inputProps: _objectSpread(_objectSpread({ className: (0, _clsx.default)(props.selectProps.classes.input, { [props.selectProps.classes.single]: !isMulti }, { [props.selectProps.classes.multi]: isMulti }, { [props.selectProps.classes.multiStandard]: isMulti && isStandard }, { [props.selectProps.classes.multiFilled]: isMulti && isFilled }, { [props.selectProps.classes.multiOutlined]: isMulti && isOutlined }), inputRef: props.innerRef, children: props.children }, inputProps), props.innerProps), variant: variant }, other)); }; const Option = props => /*#__PURE__*/_react.default.createElement(_core.MenuItem, (0, _extends2.default)({ buttonRef: props.innerRef, selected: props.isFocused, component: "div", style: { fontWeight: props.isSelected ? 500 : 400 } }, props.innerProps), props.children); const Placeholder = props => { if (props.children === 'Select...') return null; const hasLabel = props.selectProps.MuiTextFieldProps && props.selectProps.MuiTextFieldProps.label; return /*#__PURE__*/_react.default.createElement(_core.Fade, { in: props.isFocused || !hasLabel }, /*#__PURE__*/_react.default.createElement(_core.Typography, (0, _extends2.default)({ color: "textSecondary", className: props.selectProps.classes.placeholder }, props.innerProps), props.children)); }; const ValueContainer = props => /*#__PURE__*/_react.default.createElement("div", { className: props.selectProps.classes.valueContainer }, props.children); const SingleValue = props => /*#__PURE__*/_react.default.createElement(_core.Typography, (0, _extends2.default)({ className: props.selectProps.classes.singleValue }, props.innerProps), props.children); const MultiValue = props => { const _ref2 = props.selectProps.MuiTextFieldProps || {}, variant = _ref2.variant; const isFocused = props.isFocused; const isFilled = variant === 'filled'; return /*#__PURE__*/_react.default.createElement(_core.Chip, (0, _extends2.default)({}, props.selectProps.ChipProps, { tabIndex: -1, label: props.children, size: "small", className: (0, _clsx.default)(props.selectProps.classes.chip, { [props.selectProps.classes.chipFocused]: isFocused }), color: isFilled ? 'primary' : undefined, onDelete: props.removeProps.onClick, deleteIcon: /*#__PURE__*/_react.default.createElement(_Cancel.default, (0, _extends2.default)({ fontSize: "small" }, props.removeProps)) })); }; const ClearIndicator = props => _reactSelect.components.ClearIndicator && /*#__PURE__*/_react.default.createElement(_reactSelect.components.ClearIndicator, (0, _extends2.default)({ className: props.selectProps.classes.indicator }, props)); const DropdownIndicator = props => _reactSelect.components.DropdownIndicator && /*#__PURE__*/_react.default.createElement(_reactSelect.components.DropdownIndicator, (0, _extends2.default)({ className: props.selectProps.classes.indicator }, props)); const IndicatorSeparator = props => /*#__PURE__*/_react.default.createElement("span", { className: props.selectProps.classes.separator }); var _default = { Control, ClearIndicator, DropdownIndicator, IndicatorSeparator, NoOptionsMessage, Option, Placeholder, ValueContainer, SingleValue, MultiValue }; exports.default = _default;