Merge pull request #2897 from matrix-org/travis/upgrades/touchups
Fix room upgrade warnings popping up in upgraded roomspull/21833/head
						commit
						35a20143ba
					
				|  | @ -47,7 +47,9 @@ export default React.createClass({ | |||
| 
 | ||||
|     _onUpgradeClick: function() { | ||||
|         this.setState({busy: true}); | ||||
|         MatrixClientPeg.get().upgradeRoom(this.props.room.roomId, this._targetVersion).catch((err) => { | ||||
|         MatrixClientPeg.get().upgradeRoom(this.props.room.roomId, this._targetVersion).then(() => { | ||||
|             this.props.onFinished(true); | ||||
|         }).catch((err) => { | ||||
|             const ErrorDialog = sdk.getComponent("dialogs.ErrorDialog"); | ||||
|             Modal.createTrackedDialog('Failed to upgrade room', '', ErrorDialog, { | ||||
|                 title: _t("Failed to upgrade room"), | ||||
|  | @ -82,10 +84,9 @@ export default React.createClass({ | |||
| 
 | ||||
|         return ( | ||||
|             <BaseDialog className="mx_RoomUpgradeDialog" | ||||
|                 onFinished={this.onCancelled} | ||||
|                 onFinished={this.props.onFinished} | ||||
|                 title={_t("Upgrade Room Version")} | ||||
|                 contentId='mx_Dialog_content' | ||||
|                 onFinished={this.props.onFinished} | ||||
|                 hasCancel={true} | ||||
|             > | ||||
|                 <p> | ||||
|  |  | |||
|  | @ -20,6 +20,7 @@ import sdk from '../../../index'; | |||
| import Modal from '../../../Modal'; | ||||
| 
 | ||||
| import { _t } from '../../../languageHandler'; | ||||
| import MatrixClientPeg from "../../../MatrixClientPeg"; | ||||
| 
 | ||||
| module.exports = React.createClass({ | ||||
|     displayName: 'RoomUpgradeWarningBar', | ||||
|  | @ -29,6 +30,24 @@ module.exports = React.createClass({ | |||
|         recommendation: PropTypes.object.isRequired, | ||||
|     }, | ||||
| 
 | ||||
|     componentWillMount: function() { | ||||
|         const tombstone = this.props.room.currentState.getStateEvents("m.room.tombstone", ""); | ||||
|         this.setState({upgraded: tombstone && tombstone.getContent().replacement_room}); | ||||
| 
 | ||||
|         MatrixClientPeg.get().on("RoomState.events", this._onStateEvents); | ||||
|     }, | ||||
| 
 | ||||
|     _onStateEvents: function(event, state) { | ||||
|         if (!this.props.room || event.getRoomId() !== this.props.room.roomId) { | ||||
|             return; | ||||
|         } | ||||
| 
 | ||||
|         if (event.getType() !== "m.room.tombstone") return; | ||||
| 
 | ||||
|         const tombstone = this.props.room.currentState.getStateEvents("m.room.tombstone", ""); | ||||
|         this.setState({upgraded: tombstone && tombstone.getContent().replacement_room}); | ||||
|     }, | ||||
| 
 | ||||
|     onUpgradeClick: function() { | ||||
|         const RoomUpgradeDialog = sdk.getComponent('dialogs.RoomUpgradeDialog'); | ||||
|         Modal.createTrackedDialog('Upgrade Room Version', '', RoomUpgradeDialog, {room: this.props.room}); | ||||
|  | @ -37,19 +56,8 @@ module.exports = React.createClass({ | |||
|     render: function() { | ||||
|         const AccessibleButton = sdk.getComponent('elements.AccessibleButton'); | ||||
| 
 | ||||
|         return ( | ||||
|             <div className="mx_RoomUpgradeWarningBar"> | ||||
|                 <div className="mx_RoomUpgradeWarningBar_header"> | ||||
|                     {_t( | ||||
|                         "This room is running room version <roomVersion />, which this homeserver has " + | ||||
|                         "marked as <i>unstable</i>.", | ||||
|                         {}, | ||||
|                         { | ||||
|                             "roomVersion": () => <code>{this.props.room.getVersion()}</code>, | ||||
|                             "i": (sub) => <i>{sub}</i>, | ||||
|                         }, | ||||
|                     )} | ||||
|                 </div> | ||||
|         let doUpgradeWarnings = ( | ||||
|             <div> | ||||
|                 <div className="mx_RoomUpgradeWarningBar_body"> | ||||
|                     <p> | ||||
|                         {_t( | ||||
|  | @ -74,6 +82,33 @@ module.exports = React.createClass({ | |||
|                         {_t("Upgrade this room to the recommended room version")} | ||||
|                     </AccessibleButton> | ||||
|                 </p> | ||||
|             </div> | ||||
|         ); | ||||
| 
 | ||||
|         if (this.state.upgraded) { | ||||
|             doUpgradeWarnings = ( | ||||
|                 <div className="mx_RoomUpgradeWarningBar_body"> | ||||
|                     <p> | ||||
|                         {_t("This room has already been upgraded.")} | ||||
|                     </p> | ||||
|                 </div> | ||||
|             ); | ||||
|         } | ||||
| 
 | ||||
|         return ( | ||||
|             <div className="mx_RoomUpgradeWarningBar"> | ||||
|                 <div className="mx_RoomUpgradeWarningBar_header"> | ||||
|                     {_t( | ||||
|                         "This room is running room version <roomVersion />, which this homeserver has " + | ||||
|                         "marked as <i>unstable</i>.", | ||||
|                         {}, | ||||
|                         { | ||||
|                             "roomVersion": () => <code>{this.props.room.getVersion()}</code>, | ||||
|                             "i": (sub) => <i>{sub}</i>, | ||||
|                         }, | ||||
|                     )} | ||||
|                 </div> | ||||
|                 {doUpgradeWarnings} | ||||
|                 <div className="mx_RoomUpgradeWarningBar_small"> | ||||
|                     {_t("Only room administrators will see this warning")} | ||||
|                 </div> | ||||
|  |  | |||
|  | @ -38,8 +38,13 @@ export default class AdvancedRoomSettingsTab extends React.Component { | |||
| 
 | ||||
|     componentWillMount() { | ||||
|         // we handle lack of this object gracefully later, so don't worry about it failing here.
 | ||||
|         MatrixClientPeg.get().getRoom(this.props.roomId).getRecommendedVersion().then((v) => { | ||||
|             this.setState({upgradeRecommendation: v}); | ||||
|         const room = MatrixClientPeg.get().getRoom(this.props.roomId); | ||||
|         room.getRecommendedVersion().then((v) => { | ||||
|             const tombstone = room.currentState.getStateEvents("m.room.tombstone", ""); | ||||
|             this.setState({ | ||||
|                 upgraded: tombstone && tombstone.getContent().replacement_room, | ||||
|                 upgradeRecommendation: v, | ||||
|             }); | ||||
|         }); | ||||
|     } | ||||
| 
 | ||||
|  | @ -65,7 +70,7 @@ export default class AdvancedRoomSettingsTab extends React.Component { | |||
|         } | ||||
| 
 | ||||
|         let roomUpgradeButton; | ||||
|         if (this.state.upgradeRecommendation && this.state.upgradeRecommendation.needsUpgrade) { | ||||
|         if (this.state.upgradeRecommendation && this.state.upgradeRecommendation.needsUpgrade && !this.state.upgraded) { | ||||
|             roomUpgradeButton = ( | ||||
|                 <div> | ||||
|                     <p className='mx_SettingsTab_warningText'> | ||||
|  |  | |||
|  | @ -812,8 +812,9 @@ | |||
|     "Not now": "Not now", | ||||
|     "Don't ask me again": "Don't ask me again", | ||||
|     "Add a topic": "Add a topic", | ||||
|     "This room is running room version <roomVersion />, which this homeserver has marked as <i>unstable</i>.": "This room is running room version <roomVersion />, which this homeserver has marked as <i>unstable</i>.", | ||||
|     "Upgrading this room will shut down the current instance of the room and create an upgraded room with the same name.": "Upgrading this room will shut down the current instance of the room and create an upgraded room with the same name.", | ||||
|     "This room has already been upgraded.": "This room has already been upgraded.", | ||||
|     "This room is running room version <roomVersion />, which this homeserver has marked as <i>unstable</i>.": "This room is running room version <roomVersion />, which this homeserver has marked as <i>unstable</i>.", | ||||
|     "Only room administrators will see this warning": "Only room administrators will see this warning", | ||||
|     "This Room": "This Room", | ||||
|     "All Rooms": "All Rooms", | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Travis Ralston
						Travis Ralston