scratch-www/src/views/download/download.jsx

279 lines
15 KiB
React
Raw Normal View History

2018-01-19 14:06:26 -05:00
const FormattedHTMLMessage = require('react-intl').FormattedHTMLMessage;
const FormattedMessage = require('react-intl').FormattedMessage;
const injectIntl = require('react-intl').injectIntl;
const intlShape = require('react-intl').intlShape;
const React = require('react');
2017-03-31 19:35:33 -04:00
2018-01-19 14:06:26 -05:00
const api = require('../../lib/api');
const FlexRow = require('../../components/flex-row/flex-row.jsx');
const SubNavigation = require('../../components/subnavigation/subnavigation.jsx');
const TitleBanner = require('../../components/title-banner/title-banner.jsx');
2017-03-31 19:35:33 -04:00
2018-01-19 14:06:26 -05:00
const Page = require('../../components/page/www/page.jsx');
const render = require('../../lib/render.jsx');
2017-04-06 10:40:46 -04:00
require('./download.scss');
2017-05-03 16:19:56 -04:00
require('../../components/forms/button.scss');
2017-04-01 10:55:47 -04:00
2018-01-19 14:06:26 -05:00
class Download extends React.Component {
constructor (props) {
super(props);
this.state = {
swfVersion: ''
};
2018-01-19 14:06:26 -05:00
}
componentDidMount () {
let uri = '/scratchr2/static/sa/version.xml';
if (this.props.intl.locale === 'pt-br') {
uri = '/scratchr2/static/sa/pt-br/version.xml';
}
2018-01-19 14:06:26 -05:00
api({
host: '',
uri: uri,
responseType: 'string'
2018-01-19 14:06:26 -05:00
}, (err, body, res) => {
if (err || res.statusCode >= 400) {
return this.setState({
swfVersion: -1
});
}
2018-01-19 14:06:26 -05:00
const doc = new DOMParser().parseFromString(body, 'text/xml');
return this.setState({
swfVersion: doc.getElementsByTagName('versionNumber')[0].childNodes[0].nodeValue
});
2018-01-19 14:06:26 -05:00
});
}
render () {
let downloadPath = '/scratchr2/static/sa/Scratch-';
let downloadUrls = null;
if (this.props.intl.locale === 'pt-br') {
downloadPath = '/scratchr2/static/sa/pt-br/Scratch-';
}
if (this.state.swfVersion.length > 0 && this.state.swfVersion !== -1) {
2018-01-19 14:06:26 -05:00
downloadUrls = {
mac: `${downloadPath}${this.state.swfVersion}.dmg`,
mac105: `${downloadPath}${this.state.swfVersion}.air`,
windows: `${downloadPath}${this.state.swfVersion}.exe`,
linux: `${downloadPath}${this.state.swfVersion}.air`
};
}
2017-04-01 10:55:47 -04:00
return (
<div className="download">
<TitleBanner className="masthead">
<div className="inner">
<h1 className="title-banner-h1">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.title" />
2017-04-01 10:55:47 -04:00
</h1>
<p className="title-banner-p intro">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.intro" />
2017-04-01 10:55:47 -04:00
</p>
</div>
<div className="band">
<SubNavigation className="inner">
2018-01-19 14:06:26 -05:00
<a
className="sub-nav-item"
href="#installation"
>
2017-04-01 10:55:47 -04:00
<li>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.installation" />
2017-04-01 10:55:47 -04:00
</li>
</a>
2018-01-19 14:06:26 -05:00
<a
className="sub-nav-item"
href="#updates"
>
2017-04-01 10:55:47 -04:00
<li>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.updatesTitle" />
2017-04-01 10:55:47 -04:00
</li>
</a>
2018-01-19 14:06:26 -05:00
<a
className="sub-nav-item"
href="#other"
>
2017-04-01 10:55:47 -04:00
<li>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.otherVersionsTitle" />
2017-04-01 10:55:47 -04:00
</li>
</a>
2018-01-19 14:06:26 -05:00
<a
className="sub-nav-item"
href="#issues"
>
2017-04-01 10:55:47 -04:00
<li>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.knownIssuesTitle" />
2017-04-01 10:55:47 -04:00
</li>
</a>
</SubNavigation>
</div>
</TitleBanner>
2017-05-20 00:24:18 -04:00
<div className="download-content">
2018-01-19 14:06:26 -05:00
<section
className="installation"
id="installation"
>
<div className="inner">
<p className="callout">
2018-01-19 14:06:26 -05:00
<FormattedHTMLMessage id="download.introMac" />
</p>
<FlexRow className="three-col-row">
<div className="installation-column">
<div className="installation-column-number">
<h2 className="installation-column-number-text">{'1'}</h2>
</div>
2018-01-19 14:06:26 -05:00
<h3><FormattedMessage id="download.airTitle" /></h3>
<p><FormattedHTMLMessage id="download.airBody" /></p>
2017-05-20 00:24:18 -04:00
<ul className="installation-downloads">
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.macOSX" /> -
{' '}<a href="http://get.adobe.com/air/">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
2017-05-20 00:24:18 -04:00
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.macOlder" /> -
{' '}<a href="http://airdownload.adobe.com/air/mac/download/2.6/AdobeAIR.zip">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
2017-05-20 00:24:18 -04:00
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.windows" /> -
{' '}<a href="http://get.adobe.com/air/">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
2017-05-20 00:24:18 -04:00
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.linux" /> -
{' '}<a href="http://airdownload.adobe.com/air/lin/download/2.6/AdobeAIRInstaller.bin">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
</ul>
</div>
<div className="installation-column">
<div className="installation-column-number">
<h2 className="installation-column-number-text">{'2'}</h2>
</div>
2018-01-19 14:06:26 -05:00
<h3><FormattedMessage id="download.offlineEditorTitle" /></h3>
<p><FormattedMessage id="download.offlineEditorBody" /></p>
{downloadUrls === null ? [] : [
<ul
className="installation-downloads"
key="installation-downloads"
>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.macOSX" /> -
{' '}<a href={downloadUrls.mac}>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.macOlder" /> -
{' '}<a href={downloadUrls.mac105}>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.windows" /> -
{' '}<a href={downloadUrls.windows}>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.linux" /> -
{' '}<a href={downloadUrls.linux}>
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
</ul>
2018-01-19 14:06:26 -05:00
]}
{this.state.swfVersion === -1 ? [
2018-01-19 14:06:26 -05:00
<p key="not-available">
<i><FormattedMessage id="download.notAvailable" /></i>
</p>
] : []}
</div>
<div className="installation-column">
<div className="installation-column-number">
<h2 className="installation-column-number-text">{'3'}</h2>
</div>
2018-01-19 14:06:26 -05:00
<h3><FormattedMessage id="download.supportMaterialsTitle" /></h3>
<p><FormattedMessage id="download.supportMaterialsBody" /></p>
<ul className="installation-downloads">
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.starterProjects" /> -
{' '}<a href="https://scratch.mit.edu/scratchr2/static/sa/Scratch2StarterProjects.zip">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.gettingStarted" /> -
{' '}<a href="https://cdn.scratch.mit.edu/scratchr2/static/__709da8e5f3d72129538a4ccdbcbf5f2a__/pdfs/help/Getting-Started-Guide-Scratch2.pdf">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
</a>
</li>
<li className="installation-downloads-item">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.scratchCards" /> -
{' '}<a href="https://cdn.scratch.mit.edu/scratchr2/static/__709da8e5f3d72129538a4ccdbcbf5f2a__/pdfs/help/Scratch2Cards.pdf">
2018-01-19 14:06:26 -05:00
<FormattedMessage id="download.download" />
2017-05-20 00:24:18 -04:00
</a>
</li>
</ul>
</div>
</FlexRow>
</div>
</section>
<div className="inner">
2017-05-20 00:24:18 -04:00
<section id="updates">
2018-01-19 14:06:26 -05:00
<span className="nav-spacer" />
<h2><FormattedMessage id="download.updatesTitle" /></h2>
<p><FormattedMessage id="download.updatesBody" /></p>
{this.state.swfVersion === -1 ? [] : [
<p key="current-version">
<FormattedMessage
2018-01-19 14:06:26 -05:00
id="download.currentVersion"
values={{
version: this.state.swfVersion
}}
/>
</p>
2018-01-19 14:06:26 -05:00
]}
2017-05-20 00:24:18 -04:00
</section>
<section id="other">
2018-01-19 14:06:26 -05:00
<span className="nav-spacer" />
<h2><FormattedMessage id="download.otherVersionsTitle" /></h2>
<p><FormattedHTMLMessage id="download.otherVersionsOlder" /></p>
<p><FormattedHTMLMessage id="download.otherVersionsAdmin" /></p>
2017-05-20 00:24:18 -04:00
</section>
<section id="issues">
2018-01-19 14:06:26 -05:00
<span className="nav-spacer" />
<h2><FormattedMessage id="download.knownIssuesTitle" /></h2>
<p><FormattedMessage id="download.knownIssuesOne" /></p>
<p><FormattedMessage id="download.knownIssuesTwo" /></p>
<p><FormattedHTMLMessage id="download.knownIssuesThree" /></p>
<p><FormattedMessage id="download.knownIssuesFour" /></p>
<a
className="button mod-link"
href="https://scratch.mit.edu/discuss/3/"
>
<FormattedMessage id="download.reportBugs" />
2017-05-20 00:24:18 -04:00
</a>
</section>
</div>
2017-04-01 10:55:47 -04:00
</div>
</div>
);
}
2018-01-19 14:06:26 -05:00
}
Download.propTypes = {
intl: intlShape
};
const WrappedDownload = injectIntl(Download);
2017-04-01 10:55:47 -04:00
2018-01-19 14:06:26 -05:00
render(<Page><WrappedDownload /></Page>, document.getElementById('app'));