2018-07-19 18:08:44 -04:00
|
|
|
const injectIntl = require('react-intl').injectIntl;
|
2018-08-02 13:09:55 -04:00
|
|
|
const intlShape = require('react-intl').intlShape;
|
2018-07-19 18:08:44 -04:00
|
|
|
const FormattedMessage = require('react-intl').FormattedMessage;
|
|
|
|
const React = require('react');
|
|
|
|
|
|
|
|
|
|
|
|
const Page = require('../../components/page/www/page.jsx');
|
|
|
|
const render = require('../../lib/render.jsx');
|
|
|
|
|
|
|
|
const FlexRow = require('../../components/flex-row/flex-row.jsx');
|
2018-08-02 13:09:55 -04:00
|
|
|
|
2018-07-19 18:08:44 -04:00
|
|
|
const OSChooser = require('../../components/os-chooser/os-chooser.jsx');
|
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
const ExtensionLanding = require('../../components/extension-landing/extension-landing.jsx');
|
|
|
|
const ExtensionHeader = require('../../components/extension-landing/extension-header.jsx');
|
|
|
|
const ExtensionRequirements = require('../../components/extension-landing/extension-requirements.jsx');
|
|
|
|
const ExtensionSection = require('../../components/extension-landing/extension-section.jsx');
|
|
|
|
const InstallScratchLink = require('../../components/extension-landing/install-scratch-link.jsx');
|
|
|
|
const TipBox = require('../../components/extension-landing/tip-box.jsx');
|
|
|
|
const ProjectCard = require('../../components/extension-landing/project-card.jsx');
|
2018-07-19 18:08:44 -04:00
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
const Steps = require('../../components/steps/steps.jsx');
|
|
|
|
const Step = require('../../components/steps/step.jsx');
|
2018-07-19 18:08:44 -04:00
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
const OS_ENUM = require('../../components/extension-landing/os-enum.js');
|
2018-07-19 18:08:44 -04:00
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
require('../../components/extension-landing/extension-landing.scss');
|
|
|
|
require('./ev3.scss');
|
2018-07-19 18:08:44 -04:00
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
class EV3 extends ExtensionLanding {
|
2018-07-19 18:08:44 -04:00
|
|
|
render () {
|
|
|
|
return (
|
2018-08-02 13:09:55 -04:00
|
|
|
<div className="extension-landing ev3">
|
|
|
|
<ExtensionHeader imageSrc="/images/ev3/ev3-illustration.png">
|
|
|
|
<FlexRow className="column extension-copy">
|
|
|
|
<h2><img src="/images/ev3/ev3.svg" />LEGO MINDSTORMS EV3</h2>
|
|
|
|
<FormattedMessage
|
|
|
|
id="ev3.headerText"
|
|
|
|
values={{
|
|
|
|
ev3Link: (
|
|
|
|
<a
|
|
|
|
href="https://shop.lego.com/en-US/LEGO-MINDSTORMS-EV3-31313"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
target="_blank"
|
|
|
|
>
|
2018-07-19 18:08:44 -04:00
|
|
|
LEGO MINDSTORMS EV3
|
2018-08-02 13:09:55 -04:00
|
|
|
</a>
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</FlexRow>
|
|
|
|
<ExtensionRequirements>
|
|
|
|
<span>
|
|
|
|
<img src="/svgs/extensions/windows.svg" />
|
2018-07-19 18:08:44 -04:00
|
|
|
Windows 10+
|
2018-08-02 13:09:55 -04:00
|
|
|
</span>
|
|
|
|
<span>
|
|
|
|
<img src="/svgs/extensions/mac.svg" />
|
2018-07-19 18:08:44 -04:00
|
|
|
macOS 10.13+
|
2018-08-02 13:09:55 -04:00
|
|
|
</span>
|
|
|
|
<span>
|
|
|
|
<img src="/svgs/extensions/bluetooth.svg" />
|
2018-07-19 18:08:44 -04:00
|
|
|
Bluetooth
|
2018-08-02 13:09:55 -04:00
|
|
|
</span>
|
|
|
|
<span>
|
|
|
|
<img src="/svgs/extensions/scratch-link.svg" />
|
2018-07-19 18:08:44 -04:00
|
|
|
Scratch Link
|
2018-08-02 13:09:55 -04:00
|
|
|
</span>
|
|
|
|
</ExtensionRequirements>
|
|
|
|
</ExtensionHeader>
|
2018-07-19 18:08:44 -04:00
|
|
|
<OSChooser
|
|
|
|
currentOS={this.state.OS}
|
|
|
|
handleSetOS={this.onSetOS}
|
|
|
|
/>
|
2018-08-02 13:09:55 -04:00
|
|
|
<InstallScratchLink
|
|
|
|
currentOS={this.state.OS}
|
|
|
|
/>
|
|
|
|
<ExtensionSection className="getting-started">
|
|
|
|
<h2><FormattedMessage id="ev3.gettingStarted" /></h2>
|
|
|
|
<FlexRow className="column getting-started-section">
|
|
|
|
<h3><FormattedMessage id="ev3.connectingEV3" /></h3>
|
|
|
|
<Steps>
|
|
|
|
<Step number={1}>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-connect-1.png" />
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
2018-08-02 13:09:55 -04:00
|
|
|
<p><FormattedMessage id="ev3.turnOnEV3" /></p>
|
|
|
|
</Step>
|
|
|
|
<Step number={2}>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-connect-2.png" />
|
|
|
|
</div>
|
|
|
|
<p>
|
|
|
|
<FormattedMessage
|
|
|
|
id="ev3.useScratch3"
|
|
|
|
values={{
|
|
|
|
scratch3Link: (
|
|
|
|
<a
|
|
|
|
href="https://beta.scratch.mit.edu/"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
target="_blank"
|
|
|
|
>
|
2018-07-19 18:08:44 -04:00
|
|
|
Scratch 3.0
|
2018-08-02 13:09:55 -04:00
|
|
|
</a>
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</p>
|
|
|
|
</Step>
|
|
|
|
<Step number={3}>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-connect-3.png" />
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
2018-08-02 13:09:55 -04:00
|
|
|
<p><FormattedMessage id="ev3.addExtension" /></p>
|
|
|
|
</Step>
|
|
|
|
</Steps>
|
|
|
|
<TipBox title={this.props.intl.formatMessage({id: 'ev3.firstTimeConnecting'})}>
|
|
|
|
<p><FormattedMessage id="ev3.pairingDescription" /></p>
|
|
|
|
<Steps>
|
|
|
|
<Step>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-accept-connection.png" />
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
2018-08-02 13:09:55 -04:00
|
|
|
<p><FormattedMessage id="ev3.acceptConnection" /></p>
|
|
|
|
</Step>
|
|
|
|
<Step>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-pin.png" />
|
|
|
|
</div>
|
|
|
|
<p><FormattedMessage id="ev3.acceptPasscode" /></p>
|
|
|
|
</Step>
|
|
|
|
<Step>
|
|
|
|
<div className="step-image">
|
|
|
|
<img
|
|
|
|
className="screenshot"
|
|
|
|
src={`/images/ev3/${
|
|
|
|
this.state.OS === OS_ENUM.WINDOWS ?
|
|
|
|
'win-device-ready.png' :
|
|
|
|
'mac-enter-passcode.png'
|
|
|
|
}`}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<p>
|
|
|
|
{this.state.OS === OS_ENUM.WINDOWS ?
|
|
|
|
<FormattedMessage id="ev3.windowsFinalizePairing" /> :
|
|
|
|
<FormattedMessage id="ev3.macosFinalizePairing" />
|
|
|
|
}
|
|
|
|
</p>
|
|
|
|
</Step>
|
|
|
|
</Steps>
|
|
|
|
</TipBox>
|
2018-07-19 18:08:44 -04:00
|
|
|
</FlexRow>
|
2018-08-02 13:09:55 -04:00
|
|
|
</ExtensionSection>
|
|
|
|
<ExtensionSection className="blue things-to-try">
|
|
|
|
<h2><FormattedMessage id="ev3.thingsToTry" /></h2>
|
|
|
|
<h3>Make a motor move</h3>
|
|
|
|
<Steps>
|
|
|
|
<Step
|
|
|
|
compact
|
|
|
|
number={1}
|
|
|
|
>
|
|
|
|
<span className="step-description">
|
|
|
|
Plug a motor into <strong>port A</strong> on the EV3 hub
|
|
|
|
</span>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/ev3-motor-port-a.png" />
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
2018-08-02 13:09:55 -04:00
|
|
|
</Step>
|
|
|
|
<Step
|
|
|
|
compact
|
|
|
|
number={2}
|
|
|
|
>
|
|
|
|
<span className="step-description">
|
2018-07-19 18:08:44 -04:00
|
|
|
Find the <strong>“motor A turn this way”</strong> block
|
|
|
|
and click on it.
|
2018-08-02 13:09:55 -04:00
|
|
|
</span>
|
|
|
|
<div className="step-image">
|
|
|
|
<img src="/images/ev3/motor-turn-block.png" />
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
2018-08-02 13:09:55 -04:00
|
|
|
</Step>
|
|
|
|
</Steps>
|
|
|
|
<hr />
|
|
|
|
<h3>Starter Projects</h3>
|
|
|
|
<Steps>
|
|
|
|
<ProjectCard
|
|
|
|
cardUrl="https://downloads.scratch.mit.edu/ev3/ev3-wave-hello.sb3"
|
|
|
|
description="Make a puppet robot and have a friendly chat."
|
|
|
|
imageSrc="/images/ev3/starter-wave-hello.png"
|
|
|
|
title="Wave Hello"
|
|
|
|
/>
|
|
|
|
<ProjectCard
|
|
|
|
cardUrl="https://downloads.scratch.mit.edu/ev3/ev3-distance-instrument.sb3"
|
|
|
|
description="Move your body in front of the sensor to make music."
|
|
|
|
imageSrc="/images/ev3/starter-distance-instrument.png"
|
|
|
|
title="Distance Instrument"
|
|
|
|
/>
|
|
|
|
<ProjectCard
|
|
|
|
cardUrl="https://downloads.scratch.mit.edu/ev3/ev3-space-tacos.sb3"
|
|
|
|
description="Build your own controller to catch tacos in space."
|
|
|
|
imageSrc="/images/ev3/starter-flying-game.png"
|
|
|
|
title="Space Tacos"
|
|
|
|
/>
|
|
|
|
</Steps>
|
|
|
|
</ExtensionSection>
|
|
|
|
<ExtensionSection className="faq">
|
2018-07-19 18:08:44 -04:00
|
|
|
<h2><FormattedMessage id="ev3.troubleshootingTitle" /></h2>
|
|
|
|
<h3 className="faq-title"><FormattedMessage id="ev3.makeSurePairedTitle" /></h3>
|
|
|
|
<p>
|
|
|
|
<FormattedMessage
|
|
|
|
id="ev3.makeSurePairedText"
|
|
|
|
values={{
|
|
|
|
pairingInstructionLink: (
|
|
|
|
<a
|
|
|
|
href="https://www.lego.com/en-us/service/help/products/themes-sets/mindstorms/connecting-your-lego-mindstorms-ev3-to-bluetooth-408100000007886"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
target="_blank"
|
|
|
|
>
|
|
|
|
<FormattedMessage id="ev3.pairingInstructionText" />
|
|
|
|
</a>
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</p>
|
|
|
|
<h3 className="faq-title"><FormattedMessage id="ev3.closeScratchCopiesTitle" /></h3>
|
|
|
|
<p>
|
|
|
|
<FormattedMessage id="ev3.closeScratchCopiesText" />
|
|
|
|
</p>
|
|
|
|
<h3 className="faq-title"><FormattedMessage id="ev3.otherComputerConnectedTitle" /></h3>
|
|
|
|
<p>
|
|
|
|
<FormattedMessage id="ev3.otherComputerConnectedText" />
|
|
|
|
</p>
|
|
|
|
<h3 className="faq-title"><FormattedMessage id="ev3.updateFirmwareTitle" /></h3>
|
|
|
|
<p>
|
|
|
|
<FormattedMessage
|
|
|
|
id="ev3.updateFirmwareText"
|
|
|
|
values={{
|
|
|
|
firmwareUpdateLink: (
|
|
|
|
<a
|
|
|
|
href="https://education.lego.com/en-us/support/mindstorms-ev3/firmware-update"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
target="_blank"
|
|
|
|
>
|
|
|
|
<FormattedMessage id="ev3.firmwareUpdateText" />
|
|
|
|
</a>
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</p>
|
2018-08-02 13:09:55 -04:00
|
|
|
</ExtensionSection>
|
2018-07-19 18:08:44 -04:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-02 13:09:55 -04:00
|
|
|
EV3.propTypes = {
|
|
|
|
intl: intlShape.isRequired
|
|
|
|
};
|
|
|
|
|
2018-07-19 18:08:44 -04:00
|
|
|
const WrappedEV3 = injectIntl(EV3);
|
|
|
|
|
|
|
|
render(<Page><WrappedEV3 /></Page>, document.getElementById('app'));
|