!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/var/www/html/wincloud_gateway/node_modules/strapi-plugin-upload/admin/src/components/BrowseAssets/   drwxr-xr-x
Free 13.17 GB of 57.97 GB (22.72%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     index.js (4.93 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
import React from 'react';
import { isEmpty } from 'lodash';
import { PageFooter } from 'strapi-helper-plugin';
import { Flex, Padded } from '@buffetjs/core';

import { generatePageFromStart, generateStartFromPage } from '../../utils';
import Filters from '../Filters';
import List from '../List';
import ListEmpty from '../ListEmpty';
import SelectAll from '../SelectAll';
import SortPicker from '../SortPicker';
import useModalContext from '../../hooks/useModalContext';
import Wrapper from './Wrapper';
import CardControl from '../CardControl';

const BrowseAssets = () => {
  const {
    allowedActions,
    allowedTypes,
    count,
    files,
    goTo,
    handleAllFilesSelection,
    handleFileSelection,
    handleGoToEditFile,
    multiple,
    noNavigation,
    params,
    removeFilter,
    selectedFiles,
    setParam,
  } = useModalContext();

  const handleChangeParams = ({ target: { name, value } }) => {
    setParam({ name, value });
  };

  const handleChangeListParams = ({ target: { name, value } }) => {
    if (name.includes('_page')) {
      handleChangeParams({
        target: { name: '_start', value: generateStartFromPage(value, params._limit) },
      });
    } else {
      handleChangeParams({ target: { name: '_limit', value } });
    }
  };

  const handleDeleteFilter = index => {
    removeFilter(index);
  };

  const handleGoToUpload = () => {
    goTo('browse');
  };

  const limit = parseInt(params._limit, 10) || 10;
  const start = parseInt(params._start, 10) || 0;
  const canSelectFile = multiple === true || (selectedFiles.length < 1 && !multiple);

  const handleCheckboxChange = ({ target: { name } }) => {
    handleListCardClick(name);
  };

  const handleListCardClick = id => {
    if (!canSelectFile && id !== selectedFiles[0].id) {
      handleFileSelection({
        target: {
          name: selectedFiles[0].id,
        },
      });
    }

    handleFileSelection({
      target: {
        name: id,
      },
    });
  };

  /* eslint-disable indent */
  /* eslint-disable react/jsx-indent */
  const renderCardControl = noNavigation
    ? null
    : id => {
        if (!allowedActions.canUpdate) {
          return null;
        }

        return (
          <CardControl
            small
            title="edit"
            color="#9EA7B8"
            type="pencil"
            onClick={e => {
              e.stopPropagation();
              handleGoToEditFile(id);
            }}
          />
        );
      };

  /* eslint-enable indent */
  /* eslint-enable react/jsx-indent */

  const paginationParams = {
    _limit: parseInt(params._limit, 10) || 10,
    _page: generatePageFromStart(start, limit),
  };

  const hasSomeCheckboxSelected = files.some(file =>
    selectedFiles.find(selectedFile => file.id === selectedFile.id)
  );
  const areAllCheckboxesSelected =
    files.every(file => selectedFiles.find(selectedFile => file.id === selectedFile.id)) &&
    hasSomeCheckboxSelected;

  const hasFilters = !isEmpty(params.filters.filter(filter => !filter.isDisabled));
  const hasSearch = !isEmpty(params._q);
  const areResultsEmptyWithSearchOrFilters = isEmpty(files) && (hasSearch || hasFilters);

  return (
    <>
      <Wrapper>
        <Padded top>
          {allowedActions.canRead && (
            <Flex flexWrap="wrap">
              {multiple && (
                <Padded right size="sm">
                  <SelectAll
                    checked={areAllCheckboxesSelected}
                    onChange={handleAllFilesSelection}
                    someChecked={hasSomeCheckboxSelected && !areAllCheckboxesSelected}
                  />
                </Padded>
              )}
              <SortPicker onChange={handleChangeParams} value={params._sort} />
              <Padded left size="sm" />
              <Filters
                filters={params.filters}
                onChange={handleChangeParams}
                onClick={handleDeleteFilter}
              />
            </Flex>
          )}
        </Padded>
        {!files || files.length === 0 ? (
          <ListEmpty
            canCreate={allowedActions.canCreate}
            numberOfRows={2}
            onClick={handleGoToUpload}
            hasSearchApplied={areResultsEmptyWithSearchOrFilters}
          />
        ) : (
          <>
            <List
              data={files}
              onChange={handleCheckboxChange}
              selectedItems={selectedFiles}
              onCardClick={handleListCardClick}
              allowedTypes={allowedTypes}
              smallCards
              renderCardControl={renderCardControl}
            />
            <Padded left right>
              <Padded left right size="xs">
                <PageFooter
                  context={{ emitEvent: () => {} }}
                  count={count}
                  onChangeParams={handleChangeListParams}
                  params={paginationParams}
                />
              </Padded>
            </Padded>
          </>
        )}
      </Wrapper>
    </>
  );
};

export default BrowseAssets;

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0052 ]--