// @flow import type { Node } from 'react'; import React from 'react'; import classnames from 'classnames'; import FileListItem from 'component/fileListItem'; import Spinner from 'component/spinner'; import { FormField } from 'component/common/form'; import usePersistedState from 'util/use-persisted-state'; const SORT_NEW = 'new'; const SORT_OLD = 'old'; type Props = { uris: Array, header: Node, headerAltControls: Node, injectedItem?: Node, loading: boolean, noHeader?: boolean, slim?: string, empty?: string, meta?: Node, // If using the default header, this is a unique ID needed to persist the state of the filter setting persistedStorageKey?: string, }; export default function FileList(props: Props) { const { uris, header, headerAltControls, injectedItem, loading, persistedStorageKey, noHeader, slim, empty, meta, } = props; const [currentSort, setCurrentSort] = usePersistedState(persistedStorageKey, SORT_NEW); const sortedUris = uris && currentSort === SORT_OLD ? uris.reverse() : uris; const hasUris = uris && !!uris.length; function handleSortChange() { setCurrentSort(currentSort === SORT_NEW ? SORT_OLD : SORT_NEW); } return (
{!noHeader && (
{header || ( )} {loading && }
{headerAltControls}
)} {meta &&
{meta}
} {hasUris && ( )} {!hasUris && !loading &&

{empty || __('No results')}

}
); }