You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
99 lines
5.0 KiB
99 lines
5.0 KiB
'use strict';
|
|
|
|
var _objectSpread = require('@babel/runtime/helpers/objectSpread2');
|
|
var _toConsumableArray = require('@babel/runtime/helpers/toConsumableArray');
|
|
var _objectWithoutProperties = require('@babel/runtime/helpers/objectWithoutProperties');
|
|
var React = require('react');
|
|
var index = require('./index-78cf371e.cjs.prod.js');
|
|
var Select = require('./Select-a4b66b9e.cjs.prod.js');
|
|
|
|
var _excluded = ["allowCreateWhileLoading", "createOptionPosition", "formatCreateLabel", "isValidNewOption", "getNewOptionData", "onCreateOption", "options", "onChange"];
|
|
var compareOption = function compareOption() {
|
|
var inputValue = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '';
|
|
var option = arguments.length > 1 ? arguments[1] : undefined;
|
|
var accessors = arguments.length > 2 ? arguments[2] : undefined;
|
|
var candidate = String(inputValue).toLowerCase();
|
|
var optionValue = String(accessors.getOptionValue(option)).toLowerCase();
|
|
var optionLabel = String(accessors.getOptionLabel(option)).toLowerCase();
|
|
return optionValue === candidate || optionLabel === candidate;
|
|
};
|
|
var builtins = {
|
|
formatCreateLabel: function formatCreateLabel(inputValue) {
|
|
return "Create \"".concat(inputValue, "\"");
|
|
},
|
|
isValidNewOption: function isValidNewOption(inputValue, selectValue, selectOptions, accessors) {
|
|
return !(!inputValue || selectValue.some(function (option) {
|
|
return compareOption(inputValue, option, accessors);
|
|
}) || selectOptions.some(function (option) {
|
|
return compareOption(inputValue, option, accessors);
|
|
}));
|
|
},
|
|
getNewOptionData: function getNewOptionData(inputValue, optionLabel) {
|
|
return {
|
|
label: optionLabel,
|
|
value: inputValue,
|
|
__isNew__: true
|
|
};
|
|
}
|
|
};
|
|
function useCreatable(_ref) {
|
|
var _ref$allowCreateWhile = _ref.allowCreateWhileLoading,
|
|
allowCreateWhileLoading = _ref$allowCreateWhile === void 0 ? false : _ref$allowCreateWhile,
|
|
_ref$createOptionPosi = _ref.createOptionPosition,
|
|
createOptionPosition = _ref$createOptionPosi === void 0 ? 'last' : _ref$createOptionPosi,
|
|
_ref$formatCreateLabe = _ref.formatCreateLabel,
|
|
formatCreateLabel = _ref$formatCreateLabe === void 0 ? builtins.formatCreateLabel : _ref$formatCreateLabe,
|
|
_ref$isValidNewOption = _ref.isValidNewOption,
|
|
isValidNewOption = _ref$isValidNewOption === void 0 ? builtins.isValidNewOption : _ref$isValidNewOption,
|
|
_ref$getNewOptionData = _ref.getNewOptionData,
|
|
getNewOptionData = _ref$getNewOptionData === void 0 ? builtins.getNewOptionData : _ref$getNewOptionData,
|
|
onCreateOption = _ref.onCreateOption,
|
|
_ref$options = _ref.options,
|
|
propsOptions = _ref$options === void 0 ? [] : _ref$options,
|
|
propsOnChange = _ref.onChange,
|
|
restSelectProps = _objectWithoutProperties(_ref, _excluded);
|
|
var _restSelectProps$getO = restSelectProps.getOptionValue,
|
|
getOptionValue = _restSelectProps$getO === void 0 ? Select.getOptionValue : _restSelectProps$getO,
|
|
_restSelectProps$getO2 = restSelectProps.getOptionLabel,
|
|
getOptionLabel = _restSelectProps$getO2 === void 0 ? Select.getOptionLabel : _restSelectProps$getO2,
|
|
inputValue = restSelectProps.inputValue,
|
|
isLoading = restSelectProps.isLoading,
|
|
isMulti = restSelectProps.isMulti,
|
|
value = restSelectProps.value,
|
|
name = restSelectProps.name;
|
|
var newOption = React.useMemo(function () {
|
|
return isValidNewOption(inputValue, index.cleanValue(value), propsOptions, {
|
|
getOptionValue: getOptionValue,
|
|
getOptionLabel: getOptionLabel
|
|
}) ? getNewOptionData(inputValue, formatCreateLabel(inputValue)) : undefined;
|
|
}, [formatCreateLabel, getNewOptionData, getOptionLabel, getOptionValue, inputValue, isValidNewOption, propsOptions, value]);
|
|
var options = React.useMemo(function () {
|
|
return (allowCreateWhileLoading || !isLoading) && newOption ? createOptionPosition === 'first' ? [newOption].concat(_toConsumableArray(propsOptions)) : [].concat(_toConsumableArray(propsOptions), [newOption]) : propsOptions;
|
|
}, [allowCreateWhileLoading, createOptionPosition, isLoading, newOption, propsOptions]);
|
|
var onChange = React.useCallback(function (newValue, actionMeta) {
|
|
if (actionMeta.action !== 'select-option') {
|
|
return propsOnChange(newValue, actionMeta);
|
|
}
|
|
var valueArray = Array.isArray(newValue) ? newValue : [newValue];
|
|
if (valueArray[valueArray.length - 1] === newOption) {
|
|
if (onCreateOption) onCreateOption(inputValue);else {
|
|
var newOptionData = getNewOptionData(inputValue, inputValue);
|
|
var newActionMeta = {
|
|
action: 'create-option',
|
|
name: name,
|
|
option: newOptionData
|
|
};
|
|
propsOnChange(index.valueTernary(isMulti, [].concat(_toConsumableArray(index.cleanValue(value)), [newOptionData]), newOptionData), newActionMeta);
|
|
}
|
|
return;
|
|
}
|
|
propsOnChange(newValue, actionMeta);
|
|
}, [getNewOptionData, inputValue, isMulti, name, newOption, onCreateOption, propsOnChange, value]);
|
|
return _objectSpread(_objectSpread({}, restSelectProps), {}, {
|
|
options: options,
|
|
onChange: onChange
|
|
});
|
|
}
|
|
|
|
exports.useCreatable = useCreatable;
|