2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2020-10-29 23:47:18 -04:00
|
|
|
import { SIMPLE_SITE } from 'config';
|
2020-10-22 18:11:22 -04:00
|
|
|
import React, { PureComponent } from 'react';
|
2018-03-26 14:32:43 -07:00
|
|
|
import Button from 'component/button';
|
2019-03-04 23:46:57 -05:00
|
|
|
import path from 'path';
|
2020-08-07 16:59:20 -04:00
|
|
|
import { formatBytes } from 'util/format-bytes';
|
2017-09-17 16:33:52 -04:00
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
type Props = {
|
2019-04-24 10:02:08 -04:00
|
|
|
claim: StreamClaim,
|
|
|
|
fileInfo: FileListItem,
|
|
|
|
metadata: StreamMetadata,
|
2018-03-26 14:32:43 -07:00
|
|
|
openFolder: string => void,
|
|
|
|
contentType: string,
|
2018-11-07 17:44:38 -05:00
|
|
|
user: ?any,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
2017-09-20 08:47:08 -04:00
|
|
|
|
2018-11-07 17:44:38 -05:00
|
|
|
class FileDetails extends PureComponent<Props> {
|
|
|
|
render() {
|
2020-06-08 14:42:29 -04:00
|
|
|
const { claim, contentType, fileInfo, metadata, openFolder } = this.props;
|
2018-04-25 15:31:58 -04:00
|
|
|
|
2018-11-07 17:44:38 -05:00
|
|
|
if (!claim || !metadata) {
|
2019-07-21 17:31:22 -04:00
|
|
|
return <span className="empty">{__('Empty claim or metadata info.')}</span>;
|
2018-11-07 17:44:38 -05:00
|
|
|
}
|
|
|
|
|
2020-03-24 23:15:05 -04:00
|
|
|
const { languages, license } = metadata;
|
2017-09-17 16:33:52 -04:00
|
|
|
|
2018-11-07 17:44:38 -05:00
|
|
|
const mediaType = contentType || 'unknown';
|
2020-02-13 16:32:06 -05:00
|
|
|
const fileSize =
|
|
|
|
metadata.source && metadata.source.size
|
|
|
|
? formatBytes(metadata.source.size)
|
|
|
|
: fileInfo && fileInfo.download_path && formatBytes(fileInfo.written_bytes);
|
2019-05-07 17:38:29 -04:00
|
|
|
let downloadPath = fileInfo && fileInfo.download_path ? path.normalize(fileInfo.download_path) : null;
|
2019-02-12 12:26:50 -05:00
|
|
|
let downloadNote;
|
2019-10-13 23:11:51 +05:30
|
|
|
// If the path is blank, file is not available. Streamed files won't have any blobs saved
|
2019-08-02 02:28:14 -04:00
|
|
|
// Create path from name so the folder opens on click.
|
|
|
|
if (fileInfo && fileInfo.blobs_completed >= 1 && fileInfo.download_path === null) {
|
2019-02-12 12:26:50 -05:00
|
|
|
downloadPath = `${fileInfo.download_directory}/${fileInfo.file_name}`;
|
2020-06-05 00:05:10 +03:00
|
|
|
downloadNote = __('This file may have been streamed, moved or deleted');
|
2019-02-12 12:26:50 -05:00
|
|
|
}
|
2018-11-07 17:44:38 -05:00
|
|
|
|
|
|
|
return (
|
2020-10-29 23:47:18 -04:00
|
|
|
<>
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('LBRY URL')}</span>
|
|
|
|
<span>{claim.canonical_url}</span>
|
|
|
|
</div>
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('Claim ID')}</span>
|
|
|
|
<span>{claim.claim_id}</span>
|
|
|
|
</div>
|
2020-07-29 13:04:23 -04:00
|
|
|
|
2020-10-29 23:47:18 -04:00
|
|
|
{!SIMPLE_SITE && (
|
|
|
|
<>
|
|
|
|
{languages && (
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('Languages')}</span>
|
|
|
|
<span>{languages.join(' ')}</span>
|
|
|
|
</div>
|
|
|
|
)}
|
2020-07-29 13:04:23 -04:00
|
|
|
|
2020-10-29 23:47:18 -04:00
|
|
|
{languages && (
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('Media Type')}</span>
|
|
|
|
<span>{mediaType}</span>
|
|
|
|
</div>
|
|
|
|
)}
|
2020-03-24 23:15:05 -04:00
|
|
|
|
2020-10-29 23:47:18 -04:00
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('License')}</span>
|
|
|
|
<span>{license}</span>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
{downloadPath && (
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{__('Downloaded to')}</span>
|
|
|
|
<span>
|
|
|
|
<Button
|
|
|
|
button="link"
|
|
|
|
className="button--download-link"
|
|
|
|
onClick={() => {
|
|
|
|
if (downloadPath) {
|
|
|
|
openFolder(downloadPath);
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
label={downloadNote || downloadPath.replace(/(.{10})/g, '$1\u200b')}
|
|
|
|
/>
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
|
|
|
|
{fileSize && (
|
|
|
|
<div className="media__details">
|
|
|
|
<span>{fileSize}</span>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</>
|
2018-11-07 17:44:38 -05:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2017-09-17 16:33:52 -04:00
|
|
|
|
|
|
|
export default FileDetails;
|