This commit is contained in:
150
node_modules/decap-cms-widget-select/dist/esm/SelectControl.js
generated
vendored
Normal file
150
node_modules/decap-cms-widget-select/dist/esm/SelectControl.js
generated
vendored
Normal file
@@ -0,0 +1,150 @@
|
||||
"use strict";
|
||||
|
||||
Object.defineProperty(exports, "__esModule", {
|
||||
value: true
|
||||
});
|
||||
exports.default = void 0;
|
||||
var _find2 = _interopRequireDefault(require("lodash/find"));
|
||||
var _react = _interopRequireDefault(require("react"));
|
||||
var _propTypes = _interopRequireDefault(require("prop-types"));
|
||||
var _reactImmutableProptypes = _interopRequireDefault(require("react-immutable-proptypes"));
|
||||
var _immutable = require("immutable");
|
||||
var _reactSelect = _interopRequireDefault(require("react-select"));
|
||||
var _decapCmsUiDefault = require("decap-cms-ui-default");
|
||||
var _decapCmsLibWidgets = require("decap-cms-lib-widgets");
|
||||
var _react2 = require("@emotion/react");
|
||||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||||
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
||||
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
|
||||
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
||||
function optionToString(option) {
|
||||
return option && (typeof option.value === 'number' || typeof option.value === 'string') ? option.value : null;
|
||||
}
|
||||
function convertToOption(raw) {
|
||||
if (typeof raw === 'string') {
|
||||
return {
|
||||
label: raw,
|
||||
value: raw
|
||||
};
|
||||
}
|
||||
return _immutable.Map.isMap(raw) ? raw.toJS() : raw;
|
||||
}
|
||||
function getSelectedValue({
|
||||
value,
|
||||
options,
|
||||
isMultiple
|
||||
}) {
|
||||
if (isMultiple) {
|
||||
const selectedOptions = _immutable.List.isList(value) ? value.toJS() : value;
|
||||
if (!selectedOptions || !Array.isArray(selectedOptions)) {
|
||||
return null;
|
||||
}
|
||||
return selectedOptions.map(i => options.find(o => o.value === (i.value || i))).filter(Boolean).map(convertToOption);
|
||||
} else {
|
||||
return (0, _find2.default)(options, ['value', value]) || null;
|
||||
}
|
||||
}
|
||||
class SelectControl extends _react.default.Component {
|
||||
constructor(...args) {
|
||||
super(...args);
|
||||
_defineProperty(this, "isValid", () => {
|
||||
const {
|
||||
field,
|
||||
value,
|
||||
t
|
||||
} = this.props;
|
||||
const min = field.get('min');
|
||||
const max = field.get('max');
|
||||
if (!field.get('multiple')) {
|
||||
return {
|
||||
error: false
|
||||
};
|
||||
}
|
||||
const error = _decapCmsLibWidgets.validations.validateMinMax(t, field.get('label', field.get('name')), value, min, max);
|
||||
return error ? {
|
||||
error
|
||||
} : {
|
||||
error: false
|
||||
};
|
||||
});
|
||||
_defineProperty(this, "handleChange", selectedOption => {
|
||||
const {
|
||||
onChange,
|
||||
field
|
||||
} = this.props;
|
||||
const isMultiple = field.get('multiple', false);
|
||||
const isEmpty = isMultiple ? !(selectedOption !== null && selectedOption !== void 0 && selectedOption.length) : !selectedOption;
|
||||
if (field.get('required') && isEmpty && isMultiple) {
|
||||
onChange((0, _immutable.List)());
|
||||
} else if (isEmpty) {
|
||||
onChange(null);
|
||||
} else if (isMultiple) {
|
||||
const options = selectedOption.map(optionToString);
|
||||
onChange((0, _immutable.fromJS)(options));
|
||||
} else {
|
||||
onChange(optionToString(selectedOption));
|
||||
}
|
||||
});
|
||||
}
|
||||
componentDidMount() {
|
||||
const {
|
||||
field,
|
||||
onChange,
|
||||
value
|
||||
} = this.props;
|
||||
if (field.get('required') && field.get('multiple')) {
|
||||
if (value && !_immutable.List.isList(value)) {
|
||||
onChange((0, _immutable.fromJS)([value]));
|
||||
} else if (!value) {
|
||||
onChange((0, _immutable.fromJS)([]));
|
||||
}
|
||||
}
|
||||
}
|
||||
render() {
|
||||
const {
|
||||
field,
|
||||
value,
|
||||
forID,
|
||||
classNameWrapper,
|
||||
setActiveStyle,
|
||||
setInactiveStyle
|
||||
} = this.props;
|
||||
const fieldOptions = field.get('options');
|
||||
const isMultiple = field.get('multiple', false);
|
||||
const isClearable = !field.get('required', true) || isMultiple;
|
||||
const options = [...fieldOptions.map(convertToOption)];
|
||||
const selectedValue = getSelectedValue({
|
||||
options,
|
||||
value,
|
||||
isMultiple
|
||||
});
|
||||
return (0, _react2.jsx)(_reactSelect.default, {
|
||||
inputId: forID,
|
||||
value: selectedValue,
|
||||
onChange: this.handleChange,
|
||||
className: classNameWrapper,
|
||||
onFocus: setActiveStyle,
|
||||
onBlur: setInactiveStyle,
|
||||
options: options,
|
||||
styles: _decapCmsUiDefault.reactSelectStyles,
|
||||
isMulti: isMultiple,
|
||||
isClearable: isClearable,
|
||||
placeholder: ""
|
||||
});
|
||||
}
|
||||
}
|
||||
exports.default = SelectControl;
|
||||
_defineProperty(SelectControl, "propTypes", {
|
||||
onChange: _propTypes.default.func.isRequired,
|
||||
value: _propTypes.default.node,
|
||||
forID: _propTypes.default.string.isRequired,
|
||||
classNameWrapper: _propTypes.default.string.isRequired,
|
||||
setActiveStyle: _propTypes.default.func.isRequired,
|
||||
setInactiveStyle: _propTypes.default.func.isRequired,
|
||||
field: _reactImmutableProptypes.default.contains({
|
||||
options: _reactImmutableProptypes.default.listOf(_propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.number, _reactImmutableProptypes.default.contains({
|
||||
label: _propTypes.default.string.isRequired,
|
||||
value: _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.number]).isRequired
|
||||
})])).isRequired
|
||||
})
|
||||
});
|
||||
Reference in New Issue
Block a user