mirror of
https://github.com/strapi/strapi.git
synced 2025-09-09 08:39:45 +00:00
146 lines
11 KiB
JavaScript
146 lines
11 KiB
JavaScript
![]() |
/*
|
||
|
*
|
||
|
* 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;
|