2016-03-18 11:51:22 -04:00
|
|
|
var connect = require('react-redux').connect;
|
2015-10-20 19:28:28 -04:00
|
|
|
var omit = require('lodash.omit');
|
2015-09-09 22:16:03 -04:00
|
|
|
var React = require('react');
|
2015-10-21 14:12:34 -04:00
|
|
|
|
2016-05-19 11:34:28 -04:00
|
|
|
var actions = require('../../redux/auth.js');
|
2016-03-18 11:51:22 -04:00
|
|
|
|
2015-09-09 22:16:03 -04:00
|
|
|
var Modal = require('../modal/modal.jsx');
|
2015-10-23 08:32:56 -04:00
|
|
|
var Registration = require('../registration/registration.jsx');
|
2015-09-09 22:16:03 -04:00
|
|
|
|
|
|
|
require('./intro.scss');
|
|
|
|
|
|
|
|
Modal.setAppElement(document.getElementById('view'));
|
|
|
|
|
2015-10-08 16:18:12 -04:00
|
|
|
var Intro = React.createClass({
|
2015-10-09 16:16:37 -04:00
|
|
|
type: 'Intro',
|
2015-09-10 15:00:07 -04:00
|
|
|
getDefaultProps: function () {
|
2015-09-09 22:16:03 -04:00
|
|
|
return {
|
2016-01-07 09:57:34 -05:00
|
|
|
messages: {
|
|
|
|
'intro.aboutScratch': 'ABOUT SCRATCH',
|
|
|
|
'intro.forEducators': 'FOR EDUCATORS',
|
|
|
|
'intro.forParents': 'FOR PARENTS',
|
|
|
|
'intro.joinScratch': 'JOIN SCRATCH',
|
|
|
|
'intro.seeExamples': 'SEE EXAMPLES',
|
|
|
|
'intro.tagLine': 'Create stories, games, and animations<br /> Share with others around the world',
|
2016-03-22 11:00:37 -04:00
|
|
|
'intro.tryItOut': 'TRY IT OUT',
|
|
|
|
'intro.description': 'A creative learning community with <span class="project-count"> ' +
|
2016-04-22 14:16:59 -04:00
|
|
|
'over 14 million </span>projects shared'
|
2016-03-18 11:51:22 -04:00
|
|
|
},
|
|
|
|
session: {}
|
2015-09-09 22:16:03 -04:00
|
|
|
};
|
|
|
|
},
|
|
|
|
getInitialState: function () {
|
|
|
|
return {
|
|
|
|
videoOpen: false
|
|
|
|
};
|
|
|
|
},
|
|
|
|
showVideo: function () {
|
|
|
|
this.setState({videoOpen: true});
|
|
|
|
},
|
|
|
|
closeVideo: function () {
|
|
|
|
this.setState({videoOpen: false});
|
|
|
|
},
|
2015-10-23 08:32:56 -04:00
|
|
|
handleJoinClick: function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
this.setState({'registrationOpen': true});
|
|
|
|
},
|
|
|
|
closeRegistration: function () {
|
|
|
|
this.setState({'registrationOpen': false});
|
|
|
|
},
|
|
|
|
completeRegistration: function () {
|
2016-03-18 11:51:22 -04:00
|
|
|
this.props.dispatch(actions.refreshSession());
|
2015-10-23 08:32:56 -04:00
|
|
|
this.closeRegistration();
|
|
|
|
},
|
2015-09-09 22:16:03 -04:00
|
|
|
render: function () {
|
2015-10-24 17:11:44 -04:00
|
|
|
var frameProps = {
|
2015-10-20 19:28:28 -04:00
|
|
|
width: 570,
|
|
|
|
height: 357,
|
|
|
|
padding: 15
|
|
|
|
};
|
2015-09-09 22:16:03 -04:00
|
|
|
return (
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="intro">
|
2015-09-09 22:16:03 -04:00
|
|
|
<div className="content">
|
2016-01-07 09:57:34 -05:00
|
|
|
<h1 dangerouslySetInnerHTML={{__html: this.props.messages['intro.tagLine']}}>
|
2015-09-09 22:16:03 -04:00
|
|
|
</h1>
|
|
|
|
<div className="sprites">
|
2015-09-11 09:43:10 -04:00
|
|
|
<a className="sprite sprite-1" href="/projects/editor/?tip_bar=getStarted">
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-1"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/cat-a.png"
|
|
|
|
alt="Scratch Cat" />
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-2"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/cat-b.png"
|
|
|
|
alt="Scratch Cat" />
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="circle"></div>
|
2015-10-16 11:04:01 -04:00
|
|
|
<div className="text">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.tryItOut']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</div>
|
2015-09-09 22:16:03 -04:00
|
|
|
</a>
|
2015-09-11 09:43:10 -04:00
|
|
|
<a className="sprite sprite-2" href="/starter_projects/">
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-1"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/tera-a.png"
|
|
|
|
alt="Tera" />
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-2"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/tera-b.png"
|
|
|
|
alt="Tera" />
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="circle"></div>
|
2015-10-16 11:04:01 -04:00
|
|
|
<div className="text">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.seeExamples']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</div>
|
2015-09-09 22:16:03 -04:00
|
|
|
</a>
|
2015-10-23 08:32:56 -04:00
|
|
|
<a className="sprite sprite-3" href="#" onClick={this.handleJoinClick}>
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-1"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/gobo-a.png"
|
|
|
|
alt="Gobo" />
|
2015-09-09 22:16:03 -04:00
|
|
|
<img
|
2015-09-11 09:43:10 -04:00
|
|
|
className="costume costume-2"
|
2016-01-25 08:30:10 -05:00
|
|
|
src="//cdn.scratch.mit.edu/scratchr2/static/images/gobo-b.png"
|
|
|
|
alt="Gobo" />
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="circle"></div>
|
2015-10-16 11:04:01 -04:00
|
|
|
<div className="text">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.joinScratch']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</div>
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="text subtext">( it’s free )</div>
|
2015-09-09 22:16:03 -04:00
|
|
|
</a>
|
2015-10-23 08:32:56 -04:00
|
|
|
<Registration key="registration"
|
|
|
|
isOpen={this.state.registrationOpen}
|
|
|
|
onRequestClose={this.closeRegistration}
|
|
|
|
onRegistrationDone={this.completeRegistration} />
|
2015-09-09 22:16:03 -04:00
|
|
|
</div>
|
2016-03-22 11:00:37 -04:00
|
|
|
<div className="description"
|
|
|
|
dangerouslySetInnerHTML={{__html: this.props.messages['intro.description']}}></div>
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="links">
|
2015-10-16 11:04:01 -04:00
|
|
|
<a href="/about/">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.aboutScratch']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</a>
|
|
|
|
<a href="/educators/">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.forEducators']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</a>
|
|
|
|
<a className="last" href="/parents/">
|
2016-01-07 09:57:34 -05:00
|
|
|
{this.props.messages['intro.forParents']}
|
2015-10-16 11:04:01 -04:00
|
|
|
</a>
|
2015-09-09 22:16:03 -04:00
|
|
|
</div>
|
|
|
|
</div>
|
2015-09-11 09:43:10 -04:00
|
|
|
<div className="video">
|
|
|
|
<div className="play-button" onClick={this.showVideo}></div>
|
2016-01-25 09:07:55 -05:00
|
|
|
<img src="//cdn.scratch.mit.edu/scratchr2/static/images/hp-video-screenshot.png"
|
|
|
|
alt="Intro Video" />
|
2015-09-09 22:16:03 -04:00
|
|
|
</div>
|
|
|
|
<Modal
|
2015-10-20 19:35:19 -04:00
|
|
|
className="video-modal"
|
|
|
|
isOpen={this.state.videoOpen}
|
|
|
|
onRequestClose={this.closeVideo}
|
2015-10-24 17:11:44 -04:00
|
|
|
style={{content:frameProps}}>
|
2015-10-20 19:35:19 -04:00
|
|
|
<iframe
|
|
|
|
src="//player.vimeo.com/video/65583694?title=0&byline=0&portrait=0"
|
2015-10-24 17:11:44 -04:00
|
|
|
{...omit(frameProps, 'padding')} />
|
2015-09-09 22:16:03 -04:00
|
|
|
</Modal>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
});
|
2015-10-08 16:18:12 -04:00
|
|
|
|
2016-03-18 11:51:22 -04:00
|
|
|
var mapStateToProps = function (state) {
|
|
|
|
return {
|
|
|
|
session: state.session
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
var ConnectedIntro = connect(mapStateToProps)(Intro);
|
|
|
|
|
|
|
|
module.exports = ConnectedIntro;
|