Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Debian packages RPM packages NuGet packages

Repository URL to install this package:

Details    
Size: Mime:
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
import { useState, useMemo, useRef } from 'react';
import { FormHint, Label, Menu } from '@scaleflex/ui/core';
import Tag from './Tag';
import Spinner from '../Spinner';
import Styled from './UsersAutocomplete.styled';
import { jsx as _jsx } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
export var INPUT_TYPE = {
  USER_INPUT: 'UserInput'
};

/**
 * This component is shared and used in Hub Admin Console.
 * If we have some breaking changes here we should also update Hub.
 */
var UsersAutocomplete = function UsersAutocomplete(_ref) {
  var _ref$suggestions = _ref.suggestions,
    suggestions = _ref$suggestions === void 0 ? [] : _ref$suggestions,
    _ref$value = _ref.value,
    value = _ref$value === void 0 ? [] : _ref$value,
    onAdd = _ref.onAdd,
    _onRemove = _ref.onRemove,
    label = _ref.label,
    renderMenuItem = _ref.renderMenuItem,
    renderTagIcon = _ref.renderTagIcon,
    renderTagLabel = _ref.renderTagLabel,
    placeholder = _ref.placeholder,
    error = _ref.error,
    loading = _ref.loading,
    hint = _ref.hint,
    _ref$getLabel = _ref.getLabel,
    getLabel = _ref$getLabel === void 0 ? function (item) {
      return item;
    } : _ref$getLabel,
    _ref$getValue = _ref.getValue,
    getValue = _ref$getValue === void 0 ? function (item) {
      return item;
    } : _ref$getValue,
    fullWidth = _ref.fullWidth,
    disabled = _ref.disabled,
    readOnly = _ref.readOnly,
    _ref$background = _ref.background,
    background = _ref$background === void 0 ? 'primary' : _ref$background,
    _ref$showPlaceholderO = _ref.showPlaceholderOnlyWhenNoSelection,
    showPlaceholderOnlyWhenNoSelection = _ref$showPlaceholderO === void 0 ? false : _ref$showPlaceholderO,
    suggestionsGroups = _ref.suggestionsGroups;
  var selectedItems = useMemo(function () {
    return (value || []).map(function (id) {
      return (suggestions || []).find(function (suggestion) {
        return getValue(suggestion) === id;
      });
    }).filter(Boolean);
  }, [value, suggestions]);
  var _useState = useState(''),
    _useState2 = _slicedToArray(_useState, 2),
    userInput = _useState2[0],
    setUserInput = _useState2[1];
  var _useState3 = useState(null),
    _useState4 = _slicedToArray(_useState3, 2),
    suggestionsAnchorEl = _useState4[0],
    setSuggestionsAnchorEl = _useState4[1];
  var fieldContainerRef = useRef(null);
  var availableSuggestions = useMemo(function () {
    return (suggestions || []).filter(function (suggestion) {
      return !value.includes(getValue(suggestion));
    });
  }, [suggestions, value]);
  var filtredSuggestions = useMemo(function () {
    var loweredInput = userInput.toLowerCase();
    return userInput ? availableSuggestions.filter(function (_ref2) {
      var name = _ref2.name,
        email = _ref2.email;
      return name && name.toLowerCase().includes(loweredInput) || email && email.toLowerCase().includes(loweredInput);
    }) : availableSuggestions;
  }, [userInput, availableSuggestions]);
  var handleTagAdd = function handleTagAdd(item, type) {
    if (!item) return;
    onAdd(item, type);
  };
  var handleUserInputKeyDown = function handleUserInputKeyDown(event) {
    if (event.key === 'Enter' && userInput) {
      event.preventDefault();
      handleTagAdd(userInput, INPUT_TYPE.USER_INPUT);
      setUserInput('');
    } else if (event.key === 'Backspace' && !userInput) {
      var index = selectedItems.length - 1;
      if (index > -1) {
        _onRemove(getValue(selectedItems[index]), index);
      }
    } else if (event.key === 'Escape') {
      setUserInput('');
    }
  };
  var toggleSuggestions = function toggleSuggestions() {
    setSuggestionsAnchorEl(suggestionsAnchorEl ? null : fieldContainerRef.current);
  };
  var handleSelectSuggestion = function handleSelectSuggestion(suggestion) {
    var newSelectedSuggestion = _objectSpread(_objectSpread({}, suggestion), {}, {
      photo: suggestion.photo || suggestion.photo_uri
    });
    toggleSuggestions();
    setUserInput('');
    handleTagAdd(newSelectedSuggestion);
  };
  var handleRenderMenuItem = function handleRenderMenuItem(suggestion) {
    return renderMenuItem(suggestion, {
      selectSuggestion: disabled ? function () {} : handleSelectSuggestion
    });
  };
  var menuItemsArray = suggestionsGroups && suggestionsGroups.length > 0 ? suggestionsGroups.reduce(function (accum, _ref3) {
    var label = _ref3.label,
      filterFn = _ref3.filterFn;
    var filteredItems = filtredSuggestions.filter(filterFn);
    return filteredItems.length > 0 ? [].concat(_toConsumableArray(accum), [/*#__PURE__*/_jsx(Styled.Label, {
      children: label
    }, label)], _toConsumableArray(filteredItems.map(handleRenderMenuItem))) : accum;
  }, []) : filtredSuggestions.map(handleRenderMenuItem);
  return /*#__PURE__*/_jsxs(Styled.Container, {
    className: "filerobot-common-UsersAutocomplete",
    children: [label && /*#__PURE__*/_jsx(Label, {
      error: error,
      children: label
    }), /*#__PURE__*/_jsx(Styled.FieldContainer, {
      fullWidth: Boolean(fullWidth),
      ref: fieldContainerRef,
      background: background,
      children: /*#__PURE__*/_jsxs(Styled.FieldListContainer, {
        children: [(selectedItems || []).map(function (item, index) {
          return /*#__PURE__*/_jsx(Styled.FieldItem, {
            children: /*#__PURE__*/_jsx(Tag, {
              label: typeof renderTagLabel === 'function' ? renderTagLabel(item) : getLabel(item),
              icon: typeof renderTagIcon === 'function' ? renderTagIcon(item) : undefined,
              onRemove: function onRemove() {
                return _onRemove(getValue(item), index);
              }
            })
          }, getValue(item));
        }), loading ? /*#__PURE__*/_jsx(Styled.FieldLoader, {
          children: /*#__PURE__*/_jsx(Spinner, {
            color: "#768184"
          })
        }) : /*#__PURE__*/_jsx(Styled.FieldInputContainer, {
          children: /*#__PURE__*/_jsx(Styled.FieldInput, {
            value: userInput,
            type: "text",
            autoComplete: "off",
            placeholder: !showPlaceholderOnlyWhenNoSelection || selectedItems.length === 0 ? placeholder : undefined,
            onChange: function onChange(ev) {
              return setUserInput(ev.target.value);
            },
            onKeyDown: handleUserInputKeyDown,
            readOnly: readOnly,
            disabled: disabled,
            onFocus: toggleSuggestions
          })
        })]
      })
    }), hint && /*#__PURE__*/_jsx(FormHint, {
      error: error,
      children: hint
    }), menuItemsArray.length > 0 && /*#__PURE__*/_jsx(Menu, {
      anchorEl: suggestionsAnchorEl,
      open: Boolean(suggestionsAnchorEl),
      onClose: toggleSuggestions,
      hideScroll: false,
      style: {
        maxHeight: 300
      },
      children: menuItemsArray
    })]
  });
};
export default UsersAutocomplete;