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); }
var _excluded = ["foldersUuids", "filesUuids", "hasFolders", "hasFiles", "isFoldersLoading", "isFilesLoading", "handleNavigatingThroughArrows", "containerWidth", "handleContextMenuToggle", "hideAccordionHeader", "openCurrentFolderContextMenu", "fetchNextFiles", "fetchNextFolders"];
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; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
import { useState } from 'react';
import { useSelector, useDispatch } from 'react-redux';
import FilesSection from './FilesSection';
import Styled from '../AssetsList.styled';
import FoldersSection from './FoldersSection';
import SearchGridView from './SearchGridView';
import InfiniteScroll from '../../InfiniteScroll/InfiniteScroll';
import { useExplorer } from '../../../hooks';
import { selectFoldersStats, selectNoMoreFolders } from '../../../slices/folders.slice';
import { selectSearchQuery } from '../../../slices/search.slice';
import { selectIsAssetsView, selectIsFoldersView, selectIsShareboxView } from '../../../slices/views.slice';
import { selectIsNoMoreFiles, selectFilesStats } from '../../../slices/files.slice';
import { selectIsFiltersActive } from '../../../slices/filters.slice';
import { scrollToTopButtonToggled, topSectionElevated } from '../../../slices/topSection.slice';
import GridViewFoldersSkeleton from './FoldersSkeleton';
import GridViewFilesSkeleton from './FilesSkeleton';

// TODO: This component needs to be refactored, to split FoldersSection with its skeleton/selectors/functions into a component
// and another for FilesSection and avoid the usage of isAssetsView, isFoldersView....etc. if possible.  or maybe compose it with ListView as they are almost similar?
import { jsx as _jsx } from "react/jsx-runtime";
import { Fragment as _Fragment } from "react/jsx-runtime";
import { jsxs as _jsxs } from "react/jsx-runtime";
var GridView = function GridView(_ref) {
  var foldersUuids = _ref.foldersUuids,
    filesUuids = _ref.filesUuids,
    hasFolders = _ref.hasFolders,
    hasFiles = _ref.hasFiles,
    isFoldersLoading = _ref.isFoldersLoading,
    isFilesLoading = _ref.isFilesLoading,
    handleNavigatingThroughArrows = _ref.handleNavigatingThroughArrows,
    containerWidth = _ref.containerWidth,
    handleContextMenuToggle = _ref.handleContextMenuToggle,
    hideAccordionHeader = _ref.hideAccordionHeader,
    openCurrentFolderContextMenu = _ref.openCurrentFolderContextMenu,
    fetchNextFiles = _ref.fetchNextFiles,
    fetchNextFolders = _ref.fetchNextFolders,
    props = _objectWithoutProperties(_ref, _excluded);
  var dispatch = useDispatch();
  var _useExplorer = useExplorer(),
    i18n = _useExplorer.i18n;
  var _useSelector = useSelector(selectFoldersStats),
    foldersStatsLoading = _useSelector.loading,
    totalFoldersCount = _useSelector.totalFoldersCount,
    totalFilesCount = _useSelector.totalFilesCount;
  var _useSelector2 = useSelector(selectFilesStats),
    filesStatsLoading = _useSelector2.loading,
    filesCount = _useSelector2.filesCount;
  var searchQuery = useSelector(selectSearchQuery);
  var isFiltersActive = useSelector(selectIsFiltersActive);
  var isAssetsView = useSelector(selectIsAssetsView);
  var isFoldersView = useSelector(selectIsFoldersView);
  var noMoreFiles = useSelector(selectIsNoMoreFiles);
  var noMoreFolders = useSelector(selectNoMoreFolders);
  var isShareboxView = useSelector(selectIsShareboxView);
  var _useState = useState(true),
    _useState2 = _slicedToArray(_useState, 2),
    showFiles = _useState2[0],
    setShowFiles = _useState2[1];
  var _useState3 = useState(true),
    _useState4 = _slicedToArray(_useState3, 2),
    showFolders = _useState4[0],
    setShowFolders = _useState4[1];
  var foldersLength = (foldersUuids === null || foldersUuids === void 0 ? void 0 : foldersUuids.length) || 0;
  var filesLength = filesUuids.length;
  var isFoldersSectionVisible = !isFiltersActive && (isFoldersView || isShareboxView);
  var handleToggleFolders = function handleToggleFolders() {
    setShowFolders(!showFolders);
  };
  var handleToggleFiles = function handleToggleFiles() {
    setShowFiles(!showFiles);
  };
  var onScroll = function onScroll(e) {
    if ((e === null || e === void 0 ? void 0 : e.target.scrollTop) > 0) {
      dispatch(topSectionElevated(true));
    }
    if ((e === null || e === void 0 ? void 0 : e.target.scrollTop) >= 500) {
      dispatch(scrollToTopButtonToggled(true));
    }
    if ((e === null || e === void 0 ? void 0 : e.target.scrollTop) === 0) {
      dispatch(topSectionElevated(false));
      dispatch(scrollToTopButtonToggled(false));
    }
  };

  // TODO: [Search] move search to it's own view
  if (isAssetsView && searchQuery) {
    return /*#__PURE__*/_jsx(SearchGridView, _objectSpread({
      openCurrentFolderContextMenu: openCurrentFolderContextMenu,
      containerWidth: containerWidth,
      handleContextMenuToggle: handleContextMenuToggle,
      handleNavigatingThroughArrows: handleNavigatingThroughArrows,
      handleToggleFiles: handleToggleFiles
    }, props));
  }
  return /*#__PURE__*/_jsxs(_Fragment, {
    children: [isFoldersSectionVisible && /*#__PURE__*/_jsxs(_Fragment, {
      children: [isFoldersLoading && /*#__PURE__*/_jsx(GridViewFoldersSkeleton, {
        hidePreviewSkeleton: isShareboxView
      }), hasFolders && !isFoldersLoading && /*#__PURE__*/_jsx(Styled.Accordion, {
        expanded: showFolders,
        hideHeader: hideAccordionHeader,
        label: i18n('foldersViewFoldersWithCountLabel', {
          folders_count: foldersStatsLoading ? '...' : totalFoldersCount || foldersLength
        }),
        onClick: handleToggleFolders,
        detailStyle: {
          margin: '0px'
        },
        onContextMenu: function onContextMenu(e) {
          return e.stopPropagation();
        },
        children: /*#__PURE__*/_jsx("div", {
          className: "filerobot-Provider-ItemCategory-wrapper",
          onContextMenu: openCurrentFolderContextMenu,
          id: "foldersScrollableElement",
          children: showFolders && /*#__PURE__*/_jsx(InfiniteScroll, {
            dataLength: foldersUuids.length,
            next: fetchNextFolders,
            hasMore: !noMoreFolders,
            scrollableTarget: "scrollableElement",
            targetedScrollElement: "foldersScrollableElement",
            onScroll: onScroll,
            children: /*#__PURE__*/_jsx(FoldersSection, _objectSpread({
              foldersUuids: foldersUuids,
              handleContextMenuToggle: handleContextMenuToggle,
              handleNavigatingThroughArrows: handleNavigatingThroughArrows
            }, props))
          })
        })
      })]
    }), isFilesLoading && /*#__PURE__*/_jsx(GridViewFilesSkeleton, {}), hasFiles && !isFilesLoading && /*#__PURE__*/_jsx(Styled.Accordion, {
      expanded: showFiles,
      hideHeader: hideAccordionHeader,
      label: i18n('mutualizedFilesWithCountLabel', {
        files_count: !isFoldersView && filesStatsLoading || filesStatsLoading && foldersStatsLoading ? '...' : filesCount || totalFilesCount || filesLength
      }),
      onClick: handleToggleFiles,
      detailStyle: {
        margin: '0px'
      },
      onContextMenu: function onContextMenu(e) {
        return e.stopPropagation();
      },
      children: /*#__PURE__*/_jsx("div", {
        className: "filerobot-Provider-ItemCategory-wrapper",
        onContextMenu: openCurrentFolderContextMenu,
        children: showFiles && /*#__PURE__*/_jsx(InfiniteScroll, {
          dataLength: filesUuids.length,
          next: fetchNextFiles,
          hasMore: !noMoreFiles,
          scrollableTarget: "scrollableElement",
          onScroll: onScroll,
          children: /*#__PURE__*/_jsx(FilesSection, _objectSpread({
            filesUuids: filesUuids,
            handleContextMenuToggle: handleContextMenuToggle,
            handleNavigatingThroughArrows: handleNavigatingThroughArrows,
            containerWidth: containerWidth,
            showFiles: showFiles
          }, props))
        })
      })
    })]
  });
};
export default GridView;