payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
176 lines (175 loc) • 19.5 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _sortable = require("@dnd-kit/sortable");
const _react = /*#__PURE__*/ _interop_require_default(require("react"));
const _reacti18next = require("react-i18next");
const _reactselect = /*#__PURE__*/ _interop_require_default(require("react-select"));
const _creatable = /*#__PURE__*/ _interop_require_default(require("react-select/creatable"));
const _getTranslation = require("../../../../utilities/getTranslation");
const _Chevron = /*#__PURE__*/ _interop_require_default(require("../../icons/Chevron"));
const _DraggableSortable = /*#__PURE__*/ _interop_require_default(require("../DraggableSortable"));
const _ClearIndicator = require("./ClearIndicator");
const _Control = require("./Control");
const _MultiValue = require("./MultiValue");
const _MultiValueLabel = require("./MultiValueLabel");
const _MultiValueRemove = require("./MultiValueRemove");
const _SingleValue = require("./SingleValue");
const _ValueContainer = require("./ValueContainer");
require("./index.scss");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const createOption = (label)=>({
label,
value: label
});
const SelectAdapter = (props)=>{
const { i18n, t } = (0, _reacti18next.useTranslation)();
const [inputValue, setInputValue] = _react.default.useState('') // for creatable select
;
const { className, components, customProps, disabled = false, filterOption = undefined, isClearable = true, isCreatable, isLoading, isSearchable = true, noOptionsMessage, numberOnly = false, onChange, onMenuOpen, options, placeholder = t('general:selectValue'), showError, value } = props;
const classes = [
className,
'react-select',
showError && 'react-select--error'
].filter(Boolean).join(' ');
if (!isCreatable) {
return /*#__PURE__*/ _react.default.createElement(_reactselect.default, {
captureMenuScroll: true,
customProps: customProps,
isLoading: isLoading,
placeholder: (0, _getTranslation.getTranslation)(placeholder, i18n),
...props,
className: classes,
classNamePrefix: "rs",
components: {
ClearIndicator: _ClearIndicator.ClearIndicator,
Control: _Control.Control,
DropdownIndicator: _Chevron.default,
MultiValue: _MultiValue.MultiValue,
MultiValueLabel: _MultiValueLabel.MultiValueLabel,
MultiValueRemove: _MultiValueRemove.MultiValueRemove,
SingleValue: _SingleValue.SingleValue,
ValueContainer: _ValueContainer.ValueContainer,
...components
},
filterOption: filterOption,
isClearable: isClearable,
isDisabled: disabled,
isSearchable: isSearchable,
menuPlacement: "auto",
noOptionsMessage: noOptionsMessage,
onChange: onChange,
onMenuOpen: onMenuOpen,
options: options,
value: value
});
}
const handleKeyDown = (event)=>{
// eslint-disable-next-line no-restricted-globals
if (numberOnly === true) {
const acceptableKeys = [
'Tab',
'Escape',
'Backspace',
'Enter',
'ArrowRight',
'ArrowLeft',
'ArrowUp',
'ArrowDown'
];
const isNumber = !/\D/.test(event.key);
const isActionKey = acceptableKeys.includes(event.key);
if (!isNumber && !isActionKey) {
event.preventDefault();
return;
}
}
if (!value || !inputValue || inputValue.trim() === '') return;
if (filterOption && !filterOption(null, inputValue)) {
return;
}
switch(event.key){
case 'Enter':
case 'Tab':
onChange([
...value,
createOption(inputValue)
]);
setInputValue('');
event.preventDefault();
break;
default:
break;
}
};
return /*#__PURE__*/ _react.default.createElement(_creatable.default, {
captureMenuScroll: true,
isLoading: isLoading,
placeholder: (0, _getTranslation.getTranslation)(placeholder, i18n),
...props,
className: classes,
classNamePrefix: "rs",
components: {
ClearIndicator: _ClearIndicator.ClearIndicator,
Control: _Control.Control,
DropdownIndicator: _Chevron.default,
MultiValue: _MultiValue.MultiValue,
MultiValueLabel: _MultiValueLabel.MultiValueLabel,
MultiValueRemove: _MultiValueRemove.MultiValueRemove,
SingleValue: _SingleValue.SingleValue,
ValueContainer: _ValueContainer.ValueContainer,
...components
},
filterOption: filterOption,
inputValue: inputValue,
isClearable: isClearable,
isDisabled: disabled,
isSearchable: isSearchable,
menuPlacement: "auto",
noOptionsMessage: noOptionsMessage,
onChange: onChange,
onInputChange: (newValue)=>setInputValue(newValue),
onKeyDown: handleKeyDown,
onMenuOpen: onMenuOpen,
options: options,
value: value
});
};
const SortableSelect = (props)=>{
const { onChange, value } = props;
let ids = [];
if (value) ids = Array.isArray(value) ? value.map((item)=>item?.id ?? `${item?.value}`) : [
value?.id || `${value?.value}`
];
return /*#__PURE__*/ _react.default.createElement(_DraggableSortable.default, {
className: "react-select-container",
ids: ids,
onDragEnd: ({ moveFromIndex, moveToIndex })=>{
let sorted = value;
if (value && Array.isArray(value)) {
sorted = (0, _sortable.arrayMove)(value, moveFromIndex, moveToIndex);
}
onChange(sorted);
}
}, /*#__PURE__*/ _react.default.createElement(SelectAdapter, props));
};
const ReactSelect = (props)=>{
const { isMulti, isSortable } = props;
if (isMulti && isSortable) {
return /*#__PURE__*/ _react.default.createElement(SortableSelect, props);
}
return /*#__PURE__*/ _react.default.createElement(SelectAdapter, props);
};
const _default = ReactSelect;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../../../src/admin/components/elements/ReactSelect/index.tsx"],"sourcesContent":["import type { KeyboardEventHandler } from 'react'\n\nimport { arrayMove } from '@dnd-kit/sortable'\nimport React from 'react'\nimport { useTranslation } from 'react-i18next'\nimport Select from 'react-select'\nimport CreatableSelect from 'react-select/creatable'\n\nimport type { Option } from './types'\nimport type { Props as ReactSelectAdapterProps } from './types'\n\nimport { getTranslation } from '../../../../utilities/getTranslation'\nimport Chevron from '../../icons/Chevron'\nimport DraggableSortable from '../DraggableSortable'\nimport { ClearIndicator } from './ClearIndicator'\nimport { Control } from './Control'\nimport { MultiValue } from './MultiValue'\nimport { MultiValueLabel } from './MultiValueLabel'\nimport { MultiValueRemove } from './MultiValueRemove'\nimport { SingleValue } from './SingleValue'\nimport { ValueContainer } from './ValueContainer'\nimport './index.scss'\n\nconst createOption = (label: string) => ({\n  label,\n  value: label,\n})\n\nconst SelectAdapter: React.FC<ReactSelectAdapterProps> = (props) => {\n  const { i18n, t } = useTranslation()\n  const [inputValue, setInputValue] = React.useState('') // for creatable select\n\n  const {\n    className,\n    components,\n    customProps,\n    disabled = false,\n    filterOption = undefined,\n    isClearable = true,\n    isCreatable,\n    isLoading,\n    isSearchable = true,\n    noOptionsMessage,\n    numberOnly = false,\n    onChange,\n    onMenuOpen,\n    options,\n    placeholder = t('general:selectValue'),\n    showError,\n    value,\n  } = props\n\n  const classes = [className, 'react-select', showError && 'react-select--error']\n    .filter(Boolean)\n    .join(' ')\n\n  if (!isCreatable) {\n    return (\n      <Select\n        captureMenuScroll\n        customProps={customProps}\n        isLoading={isLoading}\n        placeholder={getTranslation(placeholder, i18n)}\n        {...props}\n        className={classes}\n        classNamePrefix=\"rs\"\n        components={{\n          ClearIndicator,\n          Control,\n          DropdownIndicator: Chevron,\n          MultiValue,\n          MultiValueLabel,\n          MultiValueRemove,\n          SingleValue,\n          ValueContainer,\n          ...components,\n        }}\n        filterOption={filterOption}\n        isClearable={isClearable}\n        isDisabled={disabled}\n        isSearchable={isSearchable}\n        menuPlacement=\"auto\"\n        noOptionsMessage={noOptionsMessage}\n        onChange={onChange}\n        onMenuOpen={onMenuOpen}\n        options={options}\n        value={value}\n      />\n    )\n  }\n  const handleKeyDown: KeyboardEventHandler = (event) => {\n    // eslint-disable-next-line no-restricted-globals\n    if (numberOnly === true) {\n      const acceptableKeys = [\n        'Tab',\n        'Escape',\n        'Backspace',\n        'Enter',\n        'ArrowRight',\n        'ArrowLeft',\n        'ArrowUp',\n        'ArrowDown',\n      ]\n      const isNumber = !/\\D/.test(event.key)\n      const isActionKey = acceptableKeys.includes(event.key)\n      if (!isNumber && !isActionKey) {\n        event.preventDefault()\n        return\n      }\n    }\n    if (!value || !inputValue || inputValue.trim() === '') return\n    if (filterOption && !filterOption(null, inputValue)) {\n      return\n    }\n    switch (event.key) {\n      case 'Enter':\n      case 'Tab':\n        onChange([...(value as Option[]), createOption(inputValue)])\n        setInputValue('')\n        event.preventDefault()\n        break\n      default:\n        break\n    }\n  }\n\n  return (\n    <CreatableSelect\n      captureMenuScroll\n      isLoading={isLoading}\n      placeholder={getTranslation(placeholder, i18n)}\n      {...props}\n      className={classes}\n      classNamePrefix=\"rs\"\n      components={{\n        ClearIndicator,\n        Control,\n        DropdownIndicator: Chevron,\n        MultiValue,\n        MultiValueLabel,\n        MultiValueRemove,\n        SingleValue,\n        ValueContainer,\n        ...components,\n      }}\n      filterOption={filterOption}\n      inputValue={inputValue}\n      isClearable={isClearable}\n      isDisabled={disabled}\n      isSearchable={isSearchable}\n      menuPlacement=\"auto\"\n      noOptionsMessage={noOptionsMessage}\n      onChange={onChange}\n      onInputChange={(newValue) => setInputValue(newValue)}\n      onKeyDown={handleKeyDown}\n      onMenuOpen={onMenuOpen}\n      options={options}\n      value={value}\n    />\n  )\n}\n\nconst SortableSelect: React.FC<ReactSelectAdapterProps> = (props) => {\n  const { onChange, value } = props\n\n  let ids: string[] = []\n  if (value)\n    ids = Array.isArray(value)\n      ? value.map((item) => item?.id ?? `${item?.value}`)\n      : [value?.id || `${value?.value}`]\n\n  return (\n    <DraggableSortable\n      className=\"react-select-container\"\n      ids={ids}\n      onDragEnd={({ moveFromIndex, moveToIndex }) => {\n        let sorted = value\n        if (value && Array.isArray(value)) {\n          sorted = arrayMove(value, moveFromIndex, moveToIndex)\n        }\n        onChange(sorted)\n      }}\n    >\n      <SelectAdapter {...props} />\n    </DraggableSortable>\n  )\n}\n\nconst ReactSelect: React.FC<ReactSelectAdapterProps> = (props) => {\n  const { isMulti, isSortable } = props\n\n  if (isMulti && isSortable) {\n    return <SortableSelect {...props} />\n  }\n\n  return <SelectAdapter {...props} />\n}\n\nexport default ReactSelect\n"],"names":["createOption","label","value","SelectAdapter","props","i18n","t","useTranslation","inputValue","setInputValue","React","useState","className","components","customProps","disabled","filterOption","undefined","isClearable","isCreatable","isLoading","isSearchable","noOptionsMessage","numberOnly","onChange","onMenuOpen","options","placeholder","showError","classes","filter","Boolean","join","Select","captureMenuScroll","getTranslation","classNamePrefix","ClearIndicator","Control","DropdownIndicator","Chevron","MultiValue","MultiValueLabel","MultiValueRemove","SingleValue","ValueContainer","isDisabled","menuPlacement","handleKeyDown","event","acceptableKeys","isNumber","test","key","isActionKey","includes","preventDefault","trim","CreatableSelect","onInputChange","newValue","onKeyDown","SortableSelect","ids","Array","isArray","map","item","id","DraggableSortable","onDragEnd","moveFromIndex","moveToIndex","sorted","arrayMove","ReactSelect","isMulti","isSortable"],"mappings":";;;;+BAsMA;;;eAAA;;;0BApM0B;8DACR;8BACa;oEACZ;kEACS;gCAKG;gEACX;0EACU;gCACC;yBACP;4BACG;iCACK;kCACC;6BACL;gCACG;QACxB;;;;;;AAEP,MAAMA,eAAe,CAACC,QAAmB,CAAA;QACvCA;QACAC,OAAOD;IACT,CAAA;AAEA,MAAME,gBAAmD,CAACC;IACxD,MAAM,EAAEC,IAAI,EAAEC,CAAC,EAAE,GAAGC,IAAAA,4BAAc;IAClC,MAAM,CAACC,YAAYC,cAAc,GAAGC,cAAK,CAACC,QAAQ,CAAC,IAAI,uBAAuB;;IAE9E,MAAM,EACJC,SAAS,EACTC,UAAU,EACVC,WAAW,EACXC,WAAW,KAAK,EAChBC,eAAeC,SAAS,EACxBC,cAAc,IAAI,EAClBC,WAAW,EACXC,SAAS,EACTC,eAAe,IAAI,EACnBC,gBAAgB,EAChBC,aAAa,KAAK,EAClBC,QAAQ,EACRC,UAAU,EACVC,OAAO,EACPC,cAAcrB,EAAE,sBAAsB,EACtCsB,SAAS,EACT1B,KAAK,EACN,GAAGE;IAEJ,MAAMyB,UAAU;QAACjB;QAAW;QAAgBgB,aAAa;KAAsB,CAC5EE,MAAM,CAACC,SACPC,IAAI,CAAC;IAER,IAAI,CAACb,aAAa;QAChB,qBACE,6BAACc,oBAAM;YACLC,mBAAAA;YACApB,aAAaA;YACbM,WAAWA;YACXO,aAAaQ,IAAAA,8BAAc,EAACR,aAAatB;YACxC,GAAGD,KAAK;YACTQ,WAAWiB;YACXO,iBAAgB;YAChBvB,YAAY;gBACVwB,gBAAAA,8BAAc;gBACdC,SAAAA,gBAAO;gBACPC,mBAAmBC,gBAAO;gBAC1BC,YAAAA,sBAAU;gBACVC,iBAAAA,gCAAe;gBACfC,kBAAAA,kCAAgB;gBAChBC,aAAAA,wBAAW;gBACXC,gBAAAA,8BAAc;gBACd,GAAGhC,UAAU;YACf;YACAG,cAAcA;YACdE,aAAaA;YACb4B,YAAY/B;YACZM,cAAcA;YACd0B,eAAc;YACdzB,kBAAkBA;YAClBE,UAAUA;YACVC,YAAYA;YACZC,SAASA;YACTxB,OAAOA;;IAGb;IACA,MAAM8C,gBAAsC,CAACC;QAC3C,iDAAiD;QACjD,IAAI1B,eAAe,MAAM;YACvB,MAAM2B,iBAAiB;gBACrB;gBACA;gBACA;gBACA;gBACA;gBACA;gBACA;gBACA;aACD;YACD,MAAMC,WAAW,CAAC,KAAKC,IAAI,CAACH,MAAMI,GAAG;YACrC,MAAMC,cAAcJ,eAAeK,QAAQ,CAACN,MAAMI,GAAG;YACrD,IAAI,CAACF,YAAY,CAACG,aAAa;gBAC7BL,MAAMO,cAAc;gBACpB;YACF;QACF;QACA,IAAI,CAACtD,SAAS,CAACM,cAAcA,WAAWiD,IAAI,OAAO,IAAI;QACvD,IAAIzC,gBAAgB,CAACA,aAAa,MAAMR,aAAa;YACnD;QACF;QACA,OAAQyC,MAAMI,GAAG;YACf,KAAK;YACL,KAAK;gBACH7B,SAAS;uBAAKtB;oBAAoBF,aAAaQ;iBAAY;gBAC3DC,cAAc;gBACdwC,MAAMO,cAAc;gBACpB;YACF;gBACE;QACJ;IACF;IAEA,qBACE,6BAACE,kBAAe;QACdxB,mBAAAA;QACAd,WAAWA;QACXO,aAAaQ,IAAAA,8BAAc,EAACR,aAAatB;QACxC,GAAGD,KAAK;QACTQ,WAAWiB;QACXO,iBAAgB;QAChBvB,YAAY;YACVwB,gBAAAA,8BAAc;YACdC,SAAAA,gBAAO;YACPC,mBAAmBC,gBAAO;YAC1BC,YAAAA,sBAAU;YACVC,iBAAAA,gCAAe;YACfC,kBAAAA,kCAAgB;YAChBC,aAAAA,wBAAW;YACXC,gBAAAA,8BAAc;YACd,GAAGhC,UAAU;QACf;QACAG,cAAcA;QACdR,YAAYA;QACZU,aAAaA;QACb4B,YAAY/B;QACZM,cAAcA;QACd0B,eAAc;QACdzB,kBAAkBA;QAClBE,UAAUA;QACVmC,eAAe,CAACC,WAAanD,cAAcmD;QAC3CC,WAAWb;QACXvB,YAAYA;QACZC,SAASA;QACTxB,OAAOA;;AAGb;AAEA,MAAM4D,iBAAoD,CAAC1D;IACzD,MAAM,EAAEoB,QAAQ,EAAEtB,KAAK,EAAE,GAAGE;IAE5B,IAAI2D,MAAgB,EAAE;IACtB,IAAI7D,OACF6D,MAAMC,MAAMC,OAAO,CAAC/D,SAChBA,MAAMgE,GAAG,CAAC,CAACC,OAASA,MAAMC,MAAM,CAAC,EAAED,MAAMjE,MAAM,CAAC,IAChD;QAACA,OAAOkE,MAAM,CAAC,EAAElE,OAAOA,MAAM,CAAC;KAAC;IAEtC,qBACE,6BAACmE,0BAAiB;QAChBzD,WAAU;QACVmD,KAAKA;QACLO,WAAW,CAAC,EAAEC,aAAa,EAAEC,WAAW,EAAE;YACxC,IAAIC,SAASvE;YACb,IAAIA,SAAS8D,MAAMC,OAAO,CAAC/D,QAAQ;gBACjCuE,SAASC,IAAAA,mBAAS,EAACxE,OAAOqE,eAAeC;YAC3C;YACAhD,SAASiD;QACX;qBAEA,6BAACtE,eAAkBC;AAGzB;AAEA,MAAMuE,cAAiD,CAACvE;IACtD,MAAM,EAAEwE,OAAO,EAAEC,UAAU,EAAE,GAAGzE;IAEhC,IAAIwE,WAAWC,YAAY;QACzB,qBAAO,6BAACf,gBAAmB1D;IAC7B;IAEA,qBAAO,6BAACD,eAAkBC;AAC5B;MAEA,WAAeuE"}