UNPKG

payload

Version:

Node, React and MongoDB Headless CMS and Application Framework

176 lines (175 loc) • 19.5 kB
"use strict"; 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":"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"}