Small cleanup around the room status bar and auxpanel to prevent redundant state updates
							parent
							
								
									e3a6ce13cd
								
							
						
					
					
						commit
						d87325ae6a
					
				|  | @ -41,7 +41,7 @@ export function getUnsentMessages(room) { | |||
| } | ||||
| 
 | ||||
| @replaceableComponent("structures.RoomStatusBar") | ||||
| export default class RoomStatusBar extends React.Component { | ||||
| export default class RoomStatusBar extends React.PureComponent { | ||||
|     static propTypes = { | ||||
|         // the room this statusbar is representing.
 | ||||
|         room: PropTypes.object.isRequired, | ||||
|  |  | |||
|  | @ -1633,7 +1633,7 @@ export default class RoomView extends React.Component<IProps, IState> { | |||
|         let auxPanelMaxHeight = UIStore.instance.windowHeight - | ||||
|                 (54 + // height of RoomHeader
 | ||||
|                  36 + // height of the status area
 | ||||
|                  51 + // minimum height of the message compmoser
 | ||||
|                  51 + // minimum height of the message composer
 | ||||
|                  120); // amount of desired scrollback
 | ||||
| 
 | ||||
|         // XXX: this is a bit of a hack and might possibly cause the video to push out the page anyway
 | ||||
|  | @ -1644,18 +1644,14 @@ export default class RoomView extends React.Component<IProps, IState> { | |||
|     }; | ||||
| 
 | ||||
|     private onStatusBarVisible = () => { | ||||
|         if (this.unmounted) return; | ||||
|         this.setState({ | ||||
|             statusBarVisible: true, | ||||
|         }); | ||||
|         if (this.unmounted || this.state.statusBarVisible) return; | ||||
|         this.setState({ statusBarVisible: true }); | ||||
|     }; | ||||
| 
 | ||||
|     private onStatusBarHidden = () => { | ||||
|         // This is currently not desired as it is annoying if it keeps expanding and collapsing
 | ||||
|         if (this.unmounted) return; | ||||
|         this.setState({ | ||||
|             statusBarVisible: false, | ||||
|         }); | ||||
|         if (this.unmounted || !this.state.statusBarVisible) return; | ||||
|         this.setState({ statusBarVisible: false }); | ||||
|     }; | ||||
| 
 | ||||
|     /** | ||||
|  |  | |||
|  | @ -82,13 +82,6 @@ export default class AppsDrawer extends React.Component { | |||
|         this.props.resizeNotifier.off("isResizing", this.onIsResizing); | ||||
|     } | ||||
| 
 | ||||
|     // TODO: [REACT-WARNING] Replace with appropriate lifecycle event
 | ||||
|     // eslint-disable-next-line camelcase
 | ||||
|     UNSAFE_componentWillReceiveProps(newProps) { | ||||
|         // Room has changed probably, update apps
 | ||||
|         this._updateApps(); | ||||
|     } | ||||
| 
 | ||||
|     onIsResizing = (resizing) => { | ||||
|         // This one is the vertical, ie. change height of apps drawer
 | ||||
|         this.setState({ resizingVertical: resizing }); | ||||
|  | @ -141,7 +134,10 @@ export default class AppsDrawer extends React.Component { | |||
|     _getAppsHash = (apps) => apps.map(app => app.id).join("~"); | ||||
| 
 | ||||
|     componentDidUpdate(prevProps, prevState) { | ||||
|         if (this._getAppsHash(this.state.apps) !== this._getAppsHash(prevState.apps)) { | ||||
|         if (prevProps.userId !== this.props.userId || prevProps.room !== this.props.room) { | ||||
|             // Room has changed, update apps
 | ||||
|             this._updateApps(); | ||||
|         } else if (this._getAppsHash(this.state.apps) !== this._getAppsHash(prevState.apps)) { | ||||
|             this._loadResizerPreferences(); | ||||
|         } | ||||
|     } | ||||
|  |  | |||
|  | @ -17,7 +17,6 @@ limitations under the License. | |||
| import React from 'react'; | ||||
| import {MatrixClientPeg} from "../../../MatrixClientPeg"; | ||||
| import { Room } from 'matrix-js-sdk/src/models/room' | ||||
| import dis from "../../../dispatcher/dispatcher"; | ||||
| import AppsDrawer from './AppsDrawer'; | ||||
| import classNames from 'classnames'; | ||||
| import RateLimitedFunc from '../../../ratelimitedfunc'; | ||||
|  | @ -75,12 +74,14 @@ export default class AuxPanel extends React.Component<IProps, IState> { | |||
| 
 | ||||
|     componentDidMount() { | ||||
|         const cli = MatrixClientPeg.get(); | ||||
|         cli.on("RoomState.events", this._rateLimitedUpdate); | ||||
|         if (SettingsStore.getValue("feature_state_counters")) { | ||||
|             cli.on("RoomState.events", this._rateLimitedUpdate); | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     componentWillUnmount() { | ||||
|         const cli = MatrixClientPeg.get(); | ||||
|         if (cli) { | ||||
|         if (cli && SettingsStore.getValue("feature_state_counters")) { | ||||
|             cli.removeListener("RoomState.events", this._rateLimitedUpdate); | ||||
|         } | ||||
|     } | ||||
|  | @ -97,9 +98,7 @@ export default class AuxPanel extends React.Component<IProps, IState> { | |||
|     } | ||||
| 
 | ||||
|     _rateLimitedUpdate = new RateLimitedFunc(() => { | ||||
|         if (SettingsStore.getValue("feature_state_counters")) { | ||||
|             this.setState({counters: this._computeCounters()}); | ||||
|         } | ||||
|         this.setState({ counters: this._computeCounters() }); | ||||
|     }, 500); | ||||
| 
 | ||||
|     _computeCounters() { | ||||
|  | @ -215,7 +214,7 @@ export default class AuxPanel extends React.Component<IProps, IState> { | |||
|         } | ||||
| 
 | ||||
|         return ( | ||||
|             <AutoHideScrollbar className={classes} style={style} > | ||||
|             <AutoHideScrollbar className={classes} style={style}> | ||||
|                 { stateViews } | ||||
|                 { appsDrawer } | ||||
|                 { callView } | ||||
|  |  | |||
|  | @ -24,7 +24,7 @@ import {MatrixClientPeg} from "../../../MatrixClientPeg"; | |||
| import {replaceableComponent} from "../../../utils/replaceableComponent"; | ||||
| 
 | ||||
| @replaceableComponent("views.rooms.RoomUpgradeWarningBar") | ||||
| export default class RoomUpgradeWarningBar extends React.Component { | ||||
| export default class RoomUpgradeWarningBar extends React.PureComponent { | ||||
|     static propTypes = { | ||||
|         room: PropTypes.object.isRequired, | ||||
|         recommendation: PropTypes.object.isRequired, | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 Michael Telatynski
						Michael Telatynski