import React from 'react'; import style from './Preview.module.css'; import {Spinner} from 'react-bootstrap'; import {Link} from 'react-router-dom'; import GlobalInfos from '../../utils/GlobalInfos'; import {callAPIPlain} from '../../utils/Api'; interface PreviewProps { name: string; movie_id: number; } interface PreviewState { previewpicture: string | null; } /** * Component for single preview tile * floating side by side */ class Preview extends React.Component { constructor(props: PreviewProps) { super(props); this.state = { previewpicture: null }; } componentDidMount(): void { callAPIPlain('video.php', {action: 'readThumbnail', movieid: this.props.movie_id}, (result) => { this.setState({ previewpicture: result }); }); } render(): JSX.Element { const themeStyle = GlobalInfos.getThemeStyle(); return (
{this.props.name}
{this.state.previewpicture !== null ? Pic loading. : }
); } } /** * Component for a Tag-name tile (used in category page) */ export class TagPreview extends React.Component<{ name: string }> { render(): JSX.Element { const themeStyle = GlobalInfos.getThemeStyle(); return (
{this.props.name}
); } } export default Preview;