2018-01-30 11:53:12 -05:00
|
|
|
const bindAll = require('lodash.bindall');
|
|
|
|
const connect = require('react-redux').connect;
|
|
|
|
const PropTypes = require('prop-types');
|
|
|
|
const React = require('react');
|
2015-10-21 14:12:34 -04:00
|
|
|
|
2018-09-24 11:04:30 -04:00
|
|
|
const navigationActions = require('../../redux/navigation.js');
|
2016-03-18 11:51:22 -04:00
|
|
|
|
2018-12-20 07:32:03 -05:00
|
|
|
const Video = require('../video/video.jsx');
|
|
|
|
const FlexRow = require('../flex-row/flex-row.jsx');
|
|
|
|
const TitleBanner = require('../title-banner/title-banner.jsx');
|
2015-09-09 22:16:03 -04:00
|
|
|
|
|
|
|
require('./intro.scss');
|
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
class Intro extends React.Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
bindAll(this, [
|
2019-10-01 17:59:09 -04:00
|
|
|
'handleClickRegistration',
|
2018-12-20 07:32:03 -05:00
|
|
|
'handleShowVideo'
|
2018-01-30 11:53:12 -05:00
|
|
|
]);
|
|
|
|
this.state = {
|
2015-09-09 22:16:03 -04:00
|
|
|
videoOpen: false
|
|
|
|
};
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
2019-10-01 17:59:09 -04:00
|
|
|
handleClickRegistration (event) {
|
|
|
|
if (this.props.useScratch3Registration) {
|
|
|
|
this.props.navigateToRegistration(event);
|
|
|
|
} else {
|
|
|
|
this.props.handleOpenRegistration(event);
|
|
|
|
}
|
|
|
|
}
|
2018-01-30 11:53:12 -05:00
|
|
|
handleShowVideo () {
|
2015-09-09 22:16:03 -04:00
|
|
|
this.setState({videoOpen: true});
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
|
|
|
render () {
|
2015-09-09 22:16:03 -04:00
|
|
|
return (
|
2018-12-20 07:32:03 -05:00
|
|
|
<TitleBanner className="intro-banner">
|
|
|
|
<FlexRow className="intro-container">
|
|
|
|
<FlexRow className="intro-content column">
|
|
|
|
<h1 className="intro-header">
|
|
|
|
<span>{this.props.messages['intro.tagLine1']}</span>
|
|
|
|
<br />
|
|
|
|
<span>{this.props.messages['intro.tagLine2']}</span>
|
|
|
|
</h1>
|
|
|
|
<FlexRow className="intro-buttons">
|
|
|
|
<a
|
|
|
|
className="intro-button create-button button"
|
|
|
|
href="/create"
|
|
|
|
>
|
|
|
|
{this.props.messages['intro.startCreating']}
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
className="intro-button join-button button"
|
|
|
|
href="#"
|
2019-10-01 17:59:09 -04:00
|
|
|
onClick={this.handleClickRegistration}
|
2018-12-20 07:32:03 -05:00
|
|
|
>
|
|
|
|
{this.props.messages['intro.join']}
|
|
|
|
</a>
|
|
|
|
</FlexRow>
|
2019-10-01 17:59:09 -04:00
|
|
|
|
2018-12-20 07:32:03 -05:00
|
|
|
</FlexRow>
|
|
|
|
<FlexRow className="intro-video-container">
|
|
|
|
{this.state.videoOpen ?
|
|
|
|
(
|
|
|
|
<Video
|
|
|
|
className="intro-video"
|
|
|
|
videoId="joal01i8b1"
|
|
|
|
/>
|
|
|
|
) : (
|
|
|
|
<div
|
|
|
|
className="video-image"
|
|
|
|
onClick={this.handleShowVideo}
|
|
|
|
>
|
|
|
|
<img src="/svgs/intro/video-image.svg" />
|
|
|
|
<a
|
|
|
|
href="#"
|
|
|
|
onClick={this.handleShowVideo}
|
|
|
|
>
|
|
|
|
<div className="watch-button button">
|
|
|
|
{this.props.messages['intro.watchVideo']}
|
|
|
|
</div>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
</FlexRow>
|
|
|
|
</FlexRow>
|
2019-10-01 17:59:09 -04:00
|
|
|
|
2018-12-20 07:32:03 -05:00
|
|
|
<FlexRow className="intro-subnav">
|
|
|
|
<a
|
|
|
|
href="/about"
|
|
|
|
>
|
|
|
|
<div className="subnav-button button">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.aboutScratch']}
|
2018-12-20 07:32:03 -05:00
|
|
|
</div>
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
href="/parents"
|
|
|
|
>
|
|
|
|
<div className="subnav-button button">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.forParents']}
|
2018-12-20 07:32:03 -05:00
|
|
|
</div>
|
|
|
|
</a>
|
|
|
|
<a
|
|
|
|
href="/educators"
|
|
|
|
>
|
|
|
|
<div className="subnav-button button">
|
|
|
|
{this.props.messages['intro.forEducators']}
|
|
|
|
</div>
|
|
|
|
</a>
|
|
|
|
</FlexRow>
|
|
|
|
</TitleBanner>
|
2015-09-09 22:16:03 -04:00
|
|
|
);
|
|
|
|
}
|
2018-01-30 11:53:12 -05:00
|
|
|
}
|
2016-03-18 11:51:22 -04:00
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
Intro.propTypes = {
|
2018-09-24 11:04:30 -04:00
|
|
|
handleOpenRegistration: PropTypes.func,
|
2018-01-30 11:53:12 -05:00
|
|
|
messages: PropTypes.shape({
|
|
|
|
'intro.aboutScratch': PropTypes.string,
|
|
|
|
'intro.forEducators': PropTypes.string,
|
|
|
|
'intro.forParents': PropTypes.string,
|
2018-12-20 07:32:03 -05:00
|
|
|
'intro.join': PropTypes.string,
|
|
|
|
'intro.startCreating': PropTypes.string,
|
|
|
|
'intro.tagLine1': PropTypes.string,
|
|
|
|
'intro.tagLine2': PropTypes.string,
|
|
|
|
'intro.watchVideo': PropTypes.string
|
2019-10-01 17:59:09 -04:00
|
|
|
}),
|
|
|
|
navigateToRegistration: PropTypes.func,
|
|
|
|
useScratch3Registration: PropTypes.bool
|
2018-01-19 14:06:26 -05:00
|
|
|
};
|
|
|
|
|
2018-01-30 11:53:12 -05:00
|
|
|
Intro.defaultProps = {
|
|
|
|
messages: {
|
2018-12-20 07:32:03 -05:00
|
|
|
'intro.aboutScratch': 'About Scratch',
|
|
|
|
'intro.forEducators': 'For Educators',
|
|
|
|
'intro.forParents': 'For Parents',
|
|
|
|
'intro.join': 'Join',
|
|
|
|
'intro.startCreating': 'Start Creating',
|
|
|
|
'intro.tagLine1': 'Create stories, games, and animations',
|
|
|
|
'intro.tagLine2': 'Share with others around the world',
|
|
|
|
'intro.watchVideo': 'Watch Video'
|
2018-01-30 11:53:12 -05:00
|
|
|
},
|
|
|
|
session: {}
|
|
|
|
};
|
|
|
|
|
|
|
|
const mapStateToProps = state => ({
|
2019-10-01 17:59:09 -04:00
|
|
|
session: state.session,
|
|
|
|
useScratch3Registration: state.navigation.useScratch3Registration
|
2018-01-30 11:53:12 -05:00
|
|
|
});
|
|
|
|
|
2018-09-24 11:04:30 -04:00
|
|
|
const mapDispatchToProps = dispatch => ({
|
|
|
|
handleOpenRegistration: event => {
|
|
|
|
event.preventDefault();
|
2018-12-20 07:32:03 -05:00
|
|
|
dispatch(navigationActions.setRegistrationOpen(true));
|
2019-10-01 17:59:09 -04:00
|
|
|
},
|
|
|
|
navigateToRegistration: event => {
|
|
|
|
event.preventDefault();
|
|
|
|
navigationActions.navigateToRegistration();
|
2018-09-24 11:04:30 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
const ConnectedIntro = connect(
|
|
|
|
mapStateToProps,
|
|
|
|
mapDispatchToProps
|
|
|
|
)(Intro);
|
2016-03-18 11:51:22 -04:00
|
|
|
|
|
|
|
module.exports = ConnectedIntro;
|