87 lines
2.5 KiB
JavaScript
Raw Normal View History

import React from 'react';
import style from './RandomPage.module.css';
import SideBar, {SideBarTitle} from '../../elements/SideBar/SideBar';
import Tag from '../../elements/Tag/Tag';
import PageTitle from '../../elements/PageTitle/PageTitle';
import VideoContainer from '../../elements/VideoContainer/VideoContainer';
2020-06-01 20:46:28 +02:00
/**
* Randompage shuffles random viedeopreviews and provides a shuffle btn
*/
2020-06-01 20:46:28 +02:00
class RandomPage extends React.Component {
2020-06-01 21:36:55 +02:00
constructor(props, context) {
2020-06-01 20:46:28 +02:00
super(props, context);
this.state = {
videos: [],
tags: []
2020-06-01 20:46:28 +02:00
};
}
componentDidMount() {
this.loadShuffledvideos(4);
2020-06-01 20:46:28 +02:00
}
render() {
return (
<div>
<PageTitle title='Random Videos'
subtitle='4pc'/>
<SideBar>
<SideBarTitle>Visible Tags:</SideBarTitle>
{this.state.tags.map((m) => (
<Tag key={m.tag_name}>{m.tag_name}</Tag>
))}
</SideBar>
2020-06-01 20:46:28 +02:00
{this.state.videos.length !== 0 ?
<VideoContainer
data={this.state.videos}>
<div className={style.Shufflebutton}>
<button onClick={() => this.shuffleclick()} className={style.btnshuffle}>Shuffle</button>
</div>
</VideoContainer>
:
<div>No Data found!</div>}
</div>
);
2020-06-01 20:46:28 +02:00
}
/**
* click handler for shuffle btn
*/
2020-06-01 20:46:28 +02:00
shuffleclick() {
this.loadShuffledvideos(4);
2020-06-01 20:46:28 +02:00
}
/**
* load random videos from backend
* @param nr number of videos to load
*/
2020-06-01 20:46:28 +02:00
loadShuffledvideos(nr) {
const updateRequest = new FormData();
updateRequest.append('action', 'getRandomMovies');
updateRequest.append('number', nr);
// fetch all videos available
fetch('/api/video.php', {method: 'POST', body: updateRequest})
2020-06-01 20:46:28 +02:00
.then((response) => response.json()
.then((result) => {
console.log(result);
this.setState({videos: []}); // needed to trigger rerender of main videoview
this.setState({
videos: result.rows,
tags: result.tags
});
2020-06-01 20:46:28 +02:00
}))
.catch(() => {
console.log('no connection to backend');
2020-06-01 20:46:28 +02:00
});
}
}
2020-06-01 21:36:55 +02:00
export default RandomPage;