2018-06-13 17:07:06 -04:00
|
|
|
// @flow
|
2020-05-11 11:54:39 -04:00
|
|
|
import * as ICONS from 'constants/icons';
|
2019-10-03 17:20:55 -04:00
|
|
|
import React, { useState } from 'react';
|
2020-06-10 05:55:04 +02:00
|
|
|
import usePersistedState from 'effects/use-persisted-state';
|
2018-03-26 14:32:43 -07:00
|
|
|
import Button from 'component/button';
|
2019-06-19 01:05:43 -04:00
|
|
|
import ClaimList from 'component/claimList';
|
2019-09-23 13:32:38 -04:00
|
|
|
import Paginate from 'component/common/paginate';
|
|
|
|
import { PAGE_SIZE } from 'constants/claim';
|
2019-10-03 17:20:55 -04:00
|
|
|
import { Form } from 'component/common/form-components/form';
|
|
|
|
import Icon from 'component/common/icon';
|
2020-05-11 11:54:39 -04:00
|
|
|
import { FormField } from 'component/common/form-components/form-field';
|
2019-10-03 17:20:55 -04:00
|
|
|
import { withRouter } from 'react-router';
|
2020-05-11 11:54:39 -04:00
|
|
|
import Card from 'component/common/card';
|
|
|
|
import classnames from 'classnames';
|
2020-05-21 11:38:28 -04:00
|
|
|
import Yrbl from 'component/yrbl';
|
2020-05-21 13:18:55 -04:00
|
|
|
import { PURCHASES_PAGE_SIZE } from 'page/library/view';
|
|
|
|
import Spinner from 'component/spinner';
|
2017-04-23 23:10:45 +07:00
|
|
|
|
2018-06-13 17:07:06 -04:00
|
|
|
type Props = {
|
2020-05-11 11:54:39 -04:00
|
|
|
fetchingFileList: boolean,
|
2019-09-25 17:37:01 -04:00
|
|
|
downloadedUrls: Array<string>,
|
|
|
|
downloadedUrlsCount: ?number,
|
2019-09-23 13:32:38 -04:00
|
|
|
history: { replace: string => void },
|
2019-10-27 10:41:43 -04:00
|
|
|
query: string,
|
2020-05-11 11:54:39 -04:00
|
|
|
doPurchaseList: () => void,
|
|
|
|
myDownloads: Array<string>,
|
|
|
|
myPurchases: Array<string>,
|
|
|
|
myPurchasesCount: ?number,
|
|
|
|
fetchingMyPurchases: boolean,
|
2018-06-13 17:07:06 -04:00
|
|
|
};
|
|
|
|
|
2020-05-11 11:54:39 -04:00
|
|
|
const VIEW_DOWNLOADS = 'view_download';
|
|
|
|
const VIEW_PURCHASES = 'view_purchases';
|
2019-10-03 17:20:55 -04:00
|
|
|
|
2020-05-11 11:54:39 -04:00
|
|
|
function FileListDownloaded(props: Props) {
|
|
|
|
const {
|
|
|
|
history,
|
|
|
|
query,
|
|
|
|
downloadedUrlsCount,
|
|
|
|
myPurchasesCount,
|
|
|
|
myPurchases,
|
|
|
|
myDownloads,
|
|
|
|
fetchingFileList,
|
|
|
|
fetchingMyPurchases,
|
|
|
|
} = props;
|
|
|
|
const loading = fetchingFileList || fetchingMyPurchases;
|
2020-06-10 05:55:04 +02:00
|
|
|
const [viewMode, setViewMode] = usePersistedState('library-view-mode', VIEW_PURCHASES);
|
2019-10-03 17:20:55 -04:00
|
|
|
const [searchQuery, setSearchQuery] = useState('');
|
|
|
|
|
|
|
|
function handleInputChange(e) {
|
|
|
|
const { value } = e.target;
|
|
|
|
if (value !== searchQuery) {
|
|
|
|
setSearchQuery(value);
|
|
|
|
history.replace(`?query=${value}&page=1`);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-11 14:10:58 -04:00
|
|
|
return (
|
2020-05-11 11:54:39 -04:00
|
|
|
<Card
|
|
|
|
title={
|
|
|
|
<div>
|
|
|
|
<Button
|
|
|
|
icon={ICONS.LIBRARY}
|
|
|
|
button="alt"
|
2020-05-21 11:38:28 -04:00
|
|
|
label={__('Downloads')}
|
2020-05-11 11:54:39 -04:00
|
|
|
className={classnames(`button-toggle`, {
|
|
|
|
'button-toggle--active': viewMode === VIEW_DOWNLOADS,
|
|
|
|
})}
|
|
|
|
onClick={() => setViewMode(VIEW_DOWNLOADS)}
|
|
|
|
/>
|
|
|
|
<Button
|
|
|
|
icon={ICONS.PURCHASED}
|
|
|
|
button="alt"
|
2020-05-21 11:38:28 -04:00
|
|
|
label={__('Purchases')}
|
2020-05-11 11:54:39 -04:00
|
|
|
className={classnames(`button-toggle`, {
|
|
|
|
'button-toggle--active': viewMode === VIEW_PURCHASES,
|
|
|
|
})}
|
|
|
|
onClick={() => setViewMode(VIEW_PURCHASES)}
|
|
|
|
/>
|
2020-05-21 13:18:55 -04:00
|
|
|
{loading && <Spinner type="small" />}
|
2020-05-11 11:54:39 -04:00
|
|
|
</div>
|
|
|
|
}
|
|
|
|
titleActions={
|
|
|
|
<div className="card__actions--inline">
|
|
|
|
<Form onSubmit={() => {}} className="wunderbar--inline">
|
|
|
|
<Icon icon={ICONS.SEARCH} />
|
|
|
|
<FormField
|
|
|
|
className="wunderbar__input"
|
|
|
|
onChange={handleInputChange}
|
|
|
|
value={query}
|
|
|
|
type="text"
|
|
|
|
name="query"
|
|
|
|
placeholder={__('Search')}
|
|
|
|
/>
|
|
|
|
</Form>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
isBodyList
|
|
|
|
body={
|
2020-05-21 11:38:28 -04:00
|
|
|
IS_WEB && viewMode === VIEW_DOWNLOADS ? (
|
|
|
|
<div className="main--empty">
|
|
|
|
<Yrbl
|
|
|
|
title={__('Try Out the App!')}
|
|
|
|
subtitle={
|
|
|
|
<>
|
|
|
|
<p className="section__subtitle">
|
|
|
|
{__("Download the app to track files you've viewed and downloaded.")}
|
|
|
|
</p>
|
|
|
|
<div className="section__actions">
|
|
|
|
<Button button="primary" label={__('Get The App')} href="https://lbry.com/get" />
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
) : (
|
|
|
|
<div>
|
|
|
|
<ClaimList
|
|
|
|
isCardBody
|
|
|
|
renderProperties={() => null}
|
|
|
|
empty={
|
|
|
|
viewMode === VIEW_PURCHASES && !query ? (
|
|
|
|
<div>{__('No purchases found.')}</div>
|
|
|
|
) : (
|
|
|
|
__('No results for %query%', { query })
|
|
|
|
)
|
|
|
|
}
|
|
|
|
uris={viewMode === VIEW_PURCHASES ? myPurchases : myDownloads}
|
2020-05-11 11:54:39 -04:00
|
|
|
loading={loading}
|
|
|
|
/>
|
2020-05-21 11:38:28 -04:00
|
|
|
{!query && (
|
|
|
|
<Paginate
|
|
|
|
totalPages={Math.ceil(
|
2020-05-21 13:18:55 -04:00
|
|
|
Number(viewMode === VIEW_PURCHASES ? myPurchasesCount : downloadedUrlsCount) /
|
|
|
|
Number(viewMode === VIEW_PURCHASES ? PURCHASES_PAGE_SIZE : PAGE_SIZE)
|
2020-05-21 11:38:28 -04:00
|
|
|
)}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
)
|
2020-05-11 11:54:39 -04:00
|
|
|
}
|
|
|
|
/>
|
2019-06-11 14:10:58 -04:00
|
|
|
);
|
2017-04-23 23:10:45 +07:00
|
|
|
}
|
|
|
|
|
2019-10-03 17:20:55 -04:00
|
|
|
export default withRouter(FileListDownloaded);
|