1
0
Fork 0
mirror of https://github.com/muerwre/vault-frontend.git synced 2025-04-25 04:46:40 +07:00

youtube titles

This commit is contained in:
Fedor Katurov 2020-04-19 12:16:38 +07:00
parent c74ab01927
commit 2579f31c10
3 changed files with 48 additions and 13 deletions

View file

@ -1,10 +1,11 @@
import React, { FC, memo, useMemo } from 'react';
import React, { FC, memo, useMemo, useEffect } from 'react';
import { ICommentBlock } from '~/constants/comment';
import styles from './styles.scss';
import { getYoutubeThumb } from '~/utils/dom';
import { selectPlayer } from '~/redux/player/selectors';
import { connect } from 'react-redux';
import * as PLAYER_ACTIONS from '~/redux/player/actions';
import { Icon } from '~/components/input/Icon';
const mapStateToProps = state => ({
youtubes: selectPlayer(state).youtubes,
@ -31,11 +32,16 @@ const CommentEmbedBlockUnconnected: FC<Props> = memo(
const preview = useMemo(() => getYoutubeThumb(block.content), [block.content]);
useMemo(() => {
useEffect(() => {
if (!link[5] || youtubes[link[5]]) return;
playerGetYoutubeInfo(link[5]);
}, [playerGetYoutubeInfo]);
}, [link, playerGetYoutubeInfo]);
const title = useMemo(
() =>
(youtubes[link[5]] && youtubes[link[5]].metadata && youtubes[link[5]].metadata.title) || '',
[link, youtubes]
);
return (
<div className={styles.embed}>
@ -43,7 +49,13 @@ const CommentEmbedBlockUnconnected: FC<Props> = memo(
<div className={styles.preview}>
<div style={{ backgroundImage: `url("${preview}")` }}>
<div className={styles.backdrop}>{link[0]}</div>
<div className={styles.backdrop}>
<div className={styles.play}>
<Icon icon="play" size={32} />
</div>
<div className={styles.title}>{title || link[0]}</div>
</div>
</div>
</div>
</div>