lbry-desktop/ui/component/fileViewerEmbeddedTitle/view.jsx

57 lines
1.5 KiB
React
Raw Normal View History

// @flow
import React from 'react';
import Button from 'component/button';
2020-05-22 16:47:10 -04:00
import FilePrice from 'component/filePrice';
import { formatLbryUrlForWeb } from 'util/url';
import { withRouter } from 'react-router';
import { URL } from 'config';
2021-07-25 18:03:48 -04:00
import Logo from 'component/logo';
type Props = {
uri: string,
title: ?string,
isInApp: boolean,
preferEmbed: boolean,
};
function FileViewerEmbeddedTitle(props: Props) {
const { uri, title, isInApp, preferEmbed } = props;
let contentLink = `${formatLbryUrlForWeb(uri)}`;
if (!isInApp) {
contentLink = `${contentLink}?src=embed`;
}
const contentLinkProps = isInApp ? { navigate: contentLink } : { href: contentLink };
const lbryLinkProps = isInApp ? { navigate: '/' } : { href: URL };
return (
2020-05-22 16:47:10 -04:00
<div className="file-viewer__embedded-header">
<div className="file-viewer__embedded-gradient" />
{preferEmbed ? (
<div className="file-viewer__embedded-title ">
<span dir="auto">{title}</span>
</div>
) : (
<Button
label={title}
aria-label={title}
button="link"
className="file-viewer__embedded-title"
{...contentLinkProps}
/>
)}
2020-05-22 16:47:10 -04:00
<div className="file-viewer__embedded-info">
<Button className="file-viewer__overlay-logo" disabled={preferEmbed} aria-label={__('Home')} {...lbryLinkProps}>
2021-07-25 18:03:48 -04:00
<Logo type={'embed'} />
</Button>
2020-05-26 14:42:44 -04:00
{isInApp && <FilePrice uri={uri} />}
2020-05-22 16:47:10 -04:00
</div>
</div>
);
}
export default withRouter(FileViewerEmbeddedTitle);