@e-group/material-module
Version:
EGroup Team react component modules.
155 lines (129 loc) • 6.44 kB
JavaScript
"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;