Repository URL to install this package:
|
Version:
3.12.16 ▾
|
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", "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 { useExplorer } from '../../../hooks';
import { selectIsExplorerPluginLoading } from '../../../slices/common.slice';
import { selectFoldersStats, selectNoMoreFolders } from '../../../slices/folders.slice';
import { selectIsAssetsView, selectIsFavoritesView, selectIsFoldersView, selectIsProductView, selectIsShareboxView } from '../../../slices/views.slice';
import { scrollToTopButtonToggled, topSectionElevated } from '../../../slices/topSection.slice';
import { selectSearchQuery } from '../../../slices/search.slice';
import { selectFilesStats, selectIsNoMoreFiles } from '../../../slices/files.slice';
import FoldersSection from './FoldersSection';
import AssetsSection from './AssetsSection';
import Styled from '../AssetsList.styled';
import ListViewFoldersSkeleton from './FoldersSkeleton';
import ListViewFilesSkeleton from './FilesSkeleton';
import SearchListView from './SearchListView';
import InfiniteScroll from '../../InfiniteScroll/InfiniteScroll';
import { getDefaultColumns } from './ListView.utils';
// TODO: This component needs to be refactored, to split FoldersSection with its skeleton/selectors/functions into a component
// and another for FilesSection. or maybe compose it with GridView 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 ListView = function ListView(_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,
fetchNextFiles = _ref.fetchNextFiles,
fetchNextFolders = _ref.fetchNextFolders,
props = _objectWithoutProperties(_ref, _excluded);
var dispatch = useDispatch();
var _useExplorer = useExplorer(),
i18n = _useExplorer.i18n,
_useExplorer$opts = _useExplorer.opts,
selectedListViewCols = _useExplorer$opts.selectedListViewCols,
selectedListViewFoldersCols = _useExplorer$opts.selectedListViewFoldersCols;
var isShareboxView = useSelector(selectIsShareboxView);
var loading = useSelector(selectIsExplorerPluginLoading);
var isProductView = useSelector(selectIsProductView);
var searchQuery = useSelector(selectSearchQuery);
var isAssetView = useSelector(selectIsAssetsView);
var isFavoritesView = useSelector(selectIsFavoritesView);
var noMoreFiles = useSelector(selectIsNoMoreFiles);
var noMoreFolders = useSelector(selectNoMoreFolders);
var isFoldersView = useSelector(selectIsFoldersView);
var _useSelector = useSelector(selectFoldersStats),
foldersStatsLoading = _useSelector.loading,
totalFoldersCount = _useSelector.totalFoldersCount,
totalFilesCount = _useSelector.totalFilesCount;
var _useSelector2 = useSelector(selectFilesStats),
filesStatsLoading = _useSelector2.loading,
filesCount = _useSelector2.filesCount;
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 _useState5 = useState(getDefaultColumns({
isAssetsColumns: true,
isShareboxView: isShareboxView,
selectedListViewCols: selectedListViewCols
})),
_useState6 = _slicedToArray(_useState5, 2),
assetsListVisibleColumns = _useState6[0],
setAssetsListVisibleColumns = _useState6[1];
var _useState7 = useState(getDefaultColumns({
isShareboxView: isShareboxView,
selectedListViewFoldersCols: selectedListViewFoldersCols
})),
_useState8 = _slicedToArray(_useState7, 2),
foldersListVisibleColumns = _useState8[0],
setFoldersListVisibleColumns = _useState8[1];
var foldersLength = (foldersUuids === null || foldersUuids === void 0 ? void 0 : foldersUuids.length) || 0;
var filesLength = filesUuids.length;
var showFoldersSection = (hasFolders || isFoldersView && isFoldersLoading) && !isFavoritesView && !isProductView;
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 (isAssetView && searchQuery) {
return /*#__PURE__*/_jsx(SearchListView, _objectSpread({
containerWidth: containerWidth,
handleContextMenuToggle: handleContextMenuToggle,
handleNavigatingThroughArrows: handleNavigatingThroughArrows,
handleToggleFiles: handleToggleFiles
}, props));
}
return /*#__PURE__*/_jsxs(_Fragment, {
children: [showFoldersSection && /*#__PURE__*/_jsxs(_Fragment, {
children: [isFoldersLoading && /*#__PURE__*/_jsx(ListViewFoldersSkeleton, {
hideAccordionHeader: hideAccordionHeader
}), hasFolders && !isFoldersLoading && /*#__PURE__*/_jsx(Styled.Accordion, {
expanded: showFolders,
hideHeader: hideAccordionHeader,
label: i18n('foldersViewFoldersWithCountLabel', {
folders_count: foldersStatsLoading ? '...' : totalFoldersCount || foldersLength
}),
onClick: loading ? null : handleToggleFolders,
detailStyle: {
paddingLeft: '20px'
},
onContextMenu: function onContextMenu(e) {
return e.stopPropagation();
},
hideIcon: loading,
children: /*#__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,
isDisabled: false,
containerWidth: containerWidth,
showFolders: showFolders,
visibleColumns: foldersListVisibleColumns,
setVisibleColumns: setFoldersListVisibleColumns
}, props))
})
})]
}), isFilesLoading && /*#__PURE__*/_jsx(ListViewFilesSkeleton, {
hideAccordionHeader: hideAccordionHeader
}), hasFiles && !isFilesLoading && /*#__PURE__*/_jsx(Styled.Accordion, {
expanded: showFiles,
hideHeader: hideAccordionHeader,
label: i18n('mutualizedFilesWithCountLabel', {
files_count: !isFoldersView && filesStatsLoading || filesStatsLoading && foldersStatsLoading ? '...' : filesCount || totalFilesCount || filesLength
}),
onClick: loading ? undefined : handleToggleFiles,
onContextMenu: function onContextMenu(e) {
return e.stopPropagation();
},
hideIcon: loading,
detailStyle: {
paddingLeft: '20px'
},
isListView: true,
children: /*#__PURE__*/_jsx(InfiniteScroll, {
dataLength: filesUuids.length,
next: fetchNextFiles,
hasMore: !noMoreFiles,
scrollableTarget: "scrollableElement",
onScroll: onScroll,
children: /*#__PURE__*/_jsx(AssetsSection, _objectSpread({
filesUuids: filesUuids,
handleContextMenuToggle: handleContextMenuToggle,
handleNavigatingThroughArrows: handleNavigatingThroughArrows,
isDisabled: false,
containerWidth: containerWidth,
showFiles: showFiles,
visibleColumns: assetsListVisibleColumns,
setVisibleColumns: setAssetsListVisibleColumns
}, props))
})
})]
});
};
export default ListView;