146 lines
11 KiB
JavaScript
Raw Normal View History

2019-02-14 10:36:20 +01:00
/*
*
* Row
*
*/
import React from 'react';
import PropTypes from 'prop-types';
import cn from 'classnames';
import PopUpVideo from 'components/PopUpVideo';
import styles from './styles.scss';
const videos = [
{
title: 'Create your first content-type',
id: 0,
url:
'https://s3.amazonaws.com/codecademy-content/courses/React/react_video-cute.mp4',
thumb:
'https://www.santevet.com/upload/admin/images/article/Chat%202/chaton_seul/santevet_chats_en_location.jpg',
time: '1:32min',
end: true,
},
{
title: 'Fill your content with data',
id: 1,
url:
'https://s3.amazonaws.com/codecademy-content/courses/React/react_video-eek.mp4',
thumb:
'
time: '1:32min',
end: false,
},
{
title: 'Manage the API access',
id: 2,
url:
'https://s3.amazonaws.com/codecademy-content/courses/React/react_video-slow.mp4',
thumb:
'https://www.santevet.com/upload/admin/images/article/Chat%202/chaton_seul/santevet_chats_en_location.jpg',
time: '1:32min',
end: false,
},
{
title: 'Fetch data through the API',
id: 3,
url:
'https://s3.amazonaws.com/codecademy-content/courses/React/react_video-fast.mp4',
thumb:
'https://www.santevet.com/upload/admin/images/article/Chat%202/chaton_seul/santevet_chats_en_location.jpg',
time: '1:15min',
end: false,
},
];
class OnboardingVideos extends React.Component {
state = { showVideos: false, showModal: false, video: '' };
// componentWillReceiveProps(nextProps) {
// //if (nextProps.pluginActionSucceeded !== this.props.pluginActionSucceeded) {
// this.setState({ showModal: false });
// //}
// }
componentDidMount() {
this.setState({ showVideos: true });
}
toggleVideos = e => {
this.setState({ showVideos: !this.state.showVideos });
};
displayModal = e => {
e.preventDefault();
let video = videos[e.currentTarget.parentNode.key];
console.log(e.currentTarget.parentNode);
console.log(video);
this.setState({ showModal: !this.state.showModal });
};
render() {
return (
<div className={styles.videosWrapper}>
<div
className={cn(
styles.videosContent,
this.state.showVideos ? styles.shown : styles.hide,
)}
>
<div className={styles.videosHeader}>
<p>Get started video</p>
<p>25% completed</p>
</div>
<ul>
{videos.map(video => {
return (
<li
key={video.id}
id={'nonProps.index.isOpen'}
className={video.end ? styles.finished : ''}
>
<a onClick={this.displayModal}>
<div className={styles.thumbWrapper}>
<img src={video.thumb} />
<div className={styles.play} />
</div>
<div className={styles.txtWrapper}>
<p className={styles.title}>{video.title}</p>
<p className={styles.time}>{video.time}</p>
</div>
</a>
</li>
);
})}
</ul>
</div>
<div className={styles.openBtn}>
<button
onClick={this.toggleVideos}
className={this.state.showVideos ? styles.active : ''}
>
<i className="fa fa-question" />
<i className="fa fa-times" />
<span />
</button>
</div>
<PopUpVideo
isOpen={this.state.showModal}
toggleModal={() =>
this.setState({ showModal: !this.state.showModal })
}
popUpWarningType="danger"
onConfirm={this.props.onDeleteConfirm}
src="https://s3.amazonaws.com/codecademy-content/courses/React/react_video-cute.mp4"
/>
</div>
);
}
}
OnboardingVideos.contextTypes = {};
OnboardingVideos.propTypes = {};
export default OnboardingVideos;