2016-09-16 09:22:47 +08:00
|
|
|
import React from 'react';
|
2017-09-27 02:42:18 +08:00
|
|
|
import { UpdateChannelStore } from 'mailspring-exports';
|
2016-09-16 09:22:47 +08:00
|
|
|
|
|
|
|
class UpdateChannelSection extends React.Component {
|
|
|
|
static displayName = 'UpdateChannelSection';
|
|
|
|
|
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
2016-10-19 03:39:05 +08:00
|
|
|
this.state = this.getStateFromStores();
|
2016-09-16 09:22:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
2016-10-19 03:39:05 +08:00
|
|
|
this._unsub = UpdateChannelStore.listen(() => {
|
2017-09-27 02:33:08 +08:00
|
|
|
this.setState(Object.assign(this.getStateFromStores(), { saving: false }));
|
2016-10-19 03:39:05 +08:00
|
|
|
});
|
|
|
|
UpdateChannelStore.refreshChannel();
|
2016-09-16 09:22:47 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
2016-10-19 03:39:05 +08:00
|
|
|
if (this._unsub) {
|
|
|
|
this._unsub();
|
|
|
|
}
|
2016-09-16 09:22:47 +08:00
|
|
|
}
|
|
|
|
|
2016-10-19 03:39:05 +08:00
|
|
|
getStateFromStores() {
|
|
|
|
return {
|
|
|
|
current: UpdateChannelStore.current(),
|
|
|
|
available: UpdateChannelStore.available(),
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-09-16 09:22:47 +08:00
|
|
|
}
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
_onSelectedChannel = event => {
|
|
|
|
this.setState({ saving: true });
|
2016-10-19 03:39:05 +08:00
|
|
|
UpdateChannelStore.setChannel(event.target.value);
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2016-09-16 09:22:47 +08:00
|
|
|
|
|
|
|
render() {
|
2017-09-27 02:33:08 +08:00
|
|
|
const { current, available, saving } = this.state;
|
2016-09-16 09:22:47 +08:00
|
|
|
|
2016-09-22 01:45:04 +08:00
|
|
|
// HACK: Temporarily do not allow users to move on to the Salesforce channel.
|
|
|
|
// In the future we could implement this server-side via a "public" flag.
|
2017-09-27 02:33:08 +08:00
|
|
|
const allowedNames = ['stable', 'nylas-mail', 'beta'];
|
2017-01-16 08:21:57 +08:00
|
|
|
|
2017-09-27 02:36:58 +08:00
|
|
|
if (AppEnv.config.get('salesforce')) {
|
2017-09-27 02:33:08 +08:00
|
|
|
allowedNames.push('salesforce');
|
2016-09-22 01:45:04 +08:00
|
|
|
}
|
2017-01-12 06:29:50 +08:00
|
|
|
|
2016-10-29 04:49:10 +08:00
|
|
|
const allowed = available.filter(c => {
|
2017-09-27 02:33:08 +08:00
|
|
|
return allowedNames.includes(c.name) || c.name === current.name;
|
2016-10-29 04:49:10 +08:00
|
|
|
});
|
2016-09-22 01:45:04 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const displayNameForChannel = channel => {
|
|
|
|
return channel.name[0].toUpperCase() + channel.name.substr(1);
|
|
|
|
};
|
2016-10-19 03:39:05 +08:00
|
|
|
|
2016-09-16 09:22:47 +08:00
|
|
|
return (
|
|
|
|
<section>
|
|
|
|
<h6>Updates</h6>
|
2016-10-18 08:59:33 +08:00
|
|
|
<label htmlFor="release-channel">Release channel: </label>
|
2016-09-16 09:22:47 +08:00
|
|
|
<select
|
2016-10-18 08:59:33 +08:00
|
|
|
id="release-channel"
|
2017-09-27 02:33:08 +08:00
|
|
|
style={{ minWidth: 130 }}
|
2016-09-16 09:22:47 +08:00
|
|
|
value={current.name}
|
|
|
|
onChange={this._onSelectedChannel}
|
|
|
|
disabled={saving}
|
|
|
|
>
|
2017-09-27 02:33:08 +08:00
|
|
|
{allowed.map(channel => {
|
|
|
|
return (
|
|
|
|
<option value={channel.name} key={channel.name}>
|
2016-10-19 03:39:05 +08:00
|
|
|
{displayNameForChannel(channel)}
|
2017-09-27 02:33:08 +08:00
|
|
|
</option>
|
|
|
|
);
|
|
|
|
})}
|
2016-09-16 09:22:47 +08:00
|
|
|
</select>
|
|
|
|
<p>
|
2017-09-27 02:33:08 +08:00
|
|
|
Subscribe to different update channels to receive previews of new features. Note that some
|
|
|
|
update channels may be less stable!
|
2016-09-16 09:22:47 +08:00
|
|
|
</p>
|
|
|
|
</section>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default UpdateChannelSection;
|