Repository URL to install this package:
|
Version:
3.12.20 ▾
|
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;