2020-04-13 19:48:11 -04:00
|
|
|
// @flow
|
|
|
|
import React from 'react';
|
|
|
|
import Button from 'component/button';
|
2021-09-21 23:48:05 +08:00
|
|
|
import * as ICONS from 'constants/icons';
|
2020-04-13 19:48:11 -04:00
|
|
|
import { formatLbryUrlForWeb } from 'util/url';
|
|
|
|
import { withRouter } from 'react-router';
|
2020-10-01 16:59:11 -04:00
|
|
|
import { URL, SITE_NAME } from 'config';
|
2021-07-25 18:03:48 -04:00
|
|
|
import Logo from 'component/logo';
|
2020-04-13 19:48:11 -04:00
|
|
|
|
2022-03-31 17:36:48 -03:00
|
|
|
const DEFAULT_PROMPTS = {
|
|
|
|
bigtech: 'Together, we can take back control from big tech',
|
|
|
|
discuss: `Continue the discussion on ${SITE_NAME}`,
|
|
|
|
find: `Find more great content on ${SITE_NAME}`,
|
|
|
|
test: "We test a lot of messages here. Wouldn't it be funny if the one telling you that did the best?",
|
|
|
|
};
|
|
|
|
|
2020-04-13 19:48:11 -04:00
|
|
|
type Props = {
|
|
|
|
uri: string,
|
|
|
|
isAuthenticated: boolean,
|
2021-09-18 10:23:30 -04:00
|
|
|
preferEmbed: boolean,
|
2020-04-13 19:48:11 -04:00
|
|
|
};
|
|
|
|
|
2020-04-29 14:35:55 -04:00
|
|
|
function FileViewerEmbeddedEnded(props: Props) {
|
2021-09-18 10:23:30 -04:00
|
|
|
const { uri, isAuthenticated, preferEmbed } = props;
|
2020-04-13 19:48:11 -04:00
|
|
|
|
|
|
|
const prompts = isAuthenticated
|
|
|
|
? {
|
2022-03-31 17:36:48 -03:00
|
|
|
...DEFAULT_PROMPTS,
|
2020-04-13 19:48:11 -04:00
|
|
|
tip_auth: 'Always tip your creators',
|
|
|
|
}
|
|
|
|
: {
|
2022-03-31 17:36:48 -03:00
|
|
|
...DEFAULT_PROMPTS,
|
2020-10-01 16:59:11 -04:00
|
|
|
earn_unauth: `Join ${SITE_NAME} and earn to watch.`,
|
2020-04-13 19:48:11 -04:00
|
|
|
blockchain_unauth: "Now if anyone asks, you can say you've used a blockchain.",
|
|
|
|
};
|
|
|
|
|
|
|
|
const promptKeys = Object.keys(prompts);
|
|
|
|
const promptKey = promptKeys[Math.floor(Math.random() * promptKeys.length)];
|
2020-10-01 16:59:11 -04:00
|
|
|
// $FlowFixMe
|
2020-04-13 19:48:11 -04:00
|
|
|
const prompt = prompts[promptKey];
|
2022-03-28 15:37:16 -03:00
|
|
|
const odyseeLink = `${URL}${formatLbryUrlForWeb(uri)}?src=${promptKey}`;
|
2021-09-21 23:48:05 +08:00
|
|
|
const showReplay = Boolean(window.player);
|
2020-04-13 19:48:11 -04:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="file-viewer__overlay">
|
|
|
|
<div className="file-viewer__overlay-secondary">
|
2022-05-05 09:39:49 -03:00
|
|
|
<Button className="file-viewer__overlay-logo" href="/" disabled={preferEmbed}>
|
2021-09-15 11:28:45 -04:00
|
|
|
<Logo type={'embed'} />
|
2021-07-25 18:03:48 -04:00
|
|
|
</Button>
|
2020-04-13 19:48:11 -04:00
|
|
|
</div>
|
2021-09-21 12:47:56 -04:00
|
|
|
|
|
|
|
<div className="file-viewer__overlay-title file-viewer_embed-ended-title">
|
|
|
|
<p>{prompt}</p>
|
|
|
|
</div>
|
|
|
|
<div className="file-viewer__overlay-actions">
|
2021-09-18 10:23:30 -04:00
|
|
|
<>
|
2021-09-21 12:47:56 -04:00
|
|
|
{showReplay && (
|
|
|
|
<Button
|
|
|
|
title={__('Replay')}
|
|
|
|
button="link"
|
|
|
|
label={preferEmbed ? __('Replay') : undefined}
|
|
|
|
iconRight={ICONS.REPLAY}
|
|
|
|
onClick={() => {
|
|
|
|
if (window.player) window.player.play();
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
{!preferEmbed && (
|
2021-09-18 10:23:30 -04:00
|
|
|
<>
|
2022-03-28 15:37:16 -03:00
|
|
|
<a target="_blank" rel="noopener noreferrer" href={odyseeLink}>
|
|
|
|
<Button label={__('Discuss')} iconRight={ICONS.EXTERNAL} button="primary" />
|
|
|
|
</a>
|
2021-09-18 10:23:30 -04:00
|
|
|
{!isAuthenticated && (
|
2022-03-28 15:37:16 -03:00
|
|
|
<a target="_blank" rel="noopener noreferrer" href={`${URL}/$/signup?src=embed_signup`}>
|
|
|
|
<Button label={__('Join %SITE_NAME%', { SITE_NAME })} button="secondary" />
|
|
|
|
</a>
|
2021-09-18 10:23:30 -04:00
|
|
|
)}
|
|
|
|
</>
|
2021-09-21 12:47:56 -04:00
|
|
|
)}
|
2021-09-18 10:23:30 -04:00
|
|
|
</>
|
2021-09-21 12:47:56 -04:00
|
|
|
</div>
|
2020-04-13 19:48:11 -04:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-04-29 14:35:55 -04:00
|
|
|
export default withRouter(FileViewerEmbeddedEnded);
|