import React from 'react'; import { UpdateChannelStore } from 'mailspring-exports'; class UpdateChannelSection extends React.Component { static displayName = 'UpdateChannelSection'; constructor(props) { super(props); this.state = this.getStateFromStores(); } componentDidMount() { this._unsub = UpdateChannelStore.listen(() => { this.setState(Object.assign(this.getStateFromStores(), { saving: false })); }); UpdateChannelStore.refreshChannel(); } componentWillUnmount() { if (this._unsub) { this._unsub(); } } getStateFromStores() { return { current: UpdateChannelStore.current(), available: UpdateChannelStore.available(), }; } _onSelectedChannel = event => { this.setState({ saving: true }); UpdateChannelStore.setChannel(event.target.value); }; render() { const { current, available, saving } = this.state; // 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. const allowedNames = ['stable', 'nylas-mail', 'beta']; if (AppEnv.config.get('salesforce')) { allowedNames.push('salesforce'); } const allowed = available.filter(c => { return allowedNames.includes(c.name) || c.name === current.name; }); const displayNameForChannel = channel => { return channel.name[0].toUpperCase() + channel.name.substr(1); }; return (
Updates

Subscribe to different update channels to receive previews of new features. Note that some update channels may be less stable!

); } } export default UpdateChannelSection;