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", "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;