Small cleanup around the room status bar and auxpanel to prevent redundant state updates
This commit is contained in:
parent
e3a6ce13cd
commit
d87325ae6a
5 changed files with 17 additions and 26 deletions
|
@ -41,7 +41,7 @@ export function getUnsentMessages(room) {
|
||||||
}
|
}
|
||||||
|
|
||||||
@replaceableComponent("structures.RoomStatusBar")
|
@replaceableComponent("structures.RoomStatusBar")
|
||||||
export default class RoomStatusBar extends React.Component {
|
export default class RoomStatusBar extends React.PureComponent {
|
||||||
static propTypes = {
|
static propTypes = {
|
||||||
// the room this statusbar is representing.
|
// the room this statusbar is representing.
|
||||||
room: PropTypes.object.isRequired,
|
room: PropTypes.object.isRequired,
|
||||||
|
|
|
@ -1633,7 +1633,7 @@ export default class RoomView extends React.Component<IProps, IState> {
|
||||||
let auxPanelMaxHeight = UIStore.instance.windowHeight -
|
let auxPanelMaxHeight = UIStore.instance.windowHeight -
|
||||||
(54 + // height of RoomHeader
|
(54 + // height of RoomHeader
|
||||||
36 + // height of the status area
|
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
|
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
|
// 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 = () => {
|
private onStatusBarVisible = () => {
|
||||||
if (this.unmounted) return;
|
if (this.unmounted || this.state.statusBarVisible) return;
|
||||||
this.setState({
|
this.setState({ statusBarVisible: true });
|
||||||
statusBarVisible: true,
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
private onStatusBarHidden = () => {
|
private onStatusBarHidden = () => {
|
||||||
// This is currently not desired as it is annoying if it keeps expanding and collapsing
|
// This is currently not desired as it is annoying if it keeps expanding and collapsing
|
||||||
if (this.unmounted) return;
|
if (this.unmounted || !this.state.statusBarVisible) return;
|
||||||
this.setState({
|
this.setState({ statusBarVisible: false });
|
||||||
statusBarVisible: false,
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -82,13 +82,6 @@ export default class AppsDrawer extends React.Component {
|
||||||
this.props.resizeNotifier.off("isResizing", this.onIsResizing);
|
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) => {
|
onIsResizing = (resizing) => {
|
||||||
// This one is the vertical, ie. change height of apps drawer
|
// This one is the vertical, ie. change height of apps drawer
|
||||||
this.setState({ resizingVertical: resizing });
|
this.setState({ resizingVertical: resizing });
|
||||||
|
@ -141,7 +134,10 @@ export default class AppsDrawer extends React.Component {
|
||||||
_getAppsHash = (apps) => apps.map(app => app.id).join("~");
|
_getAppsHash = (apps) => apps.map(app => app.id).join("~");
|
||||||
|
|
||||||
componentDidUpdate(prevProps, prevState) {
|
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();
|
this._loadResizerPreferences();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,6 @@ limitations under the License.
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import {MatrixClientPeg} from "../../../MatrixClientPeg";
|
import {MatrixClientPeg} from "../../../MatrixClientPeg";
|
||||||
import { Room } from 'matrix-js-sdk/src/models/room'
|
import { Room } from 'matrix-js-sdk/src/models/room'
|
||||||
import dis from "../../../dispatcher/dispatcher";
|
|
||||||
import AppsDrawer from './AppsDrawer';
|
import AppsDrawer from './AppsDrawer';
|
||||||
import classNames from 'classnames';
|
import classNames from 'classnames';
|
||||||
import RateLimitedFunc from '../../../ratelimitedfunc';
|
import RateLimitedFunc from '../../../ratelimitedfunc';
|
||||||
|
@ -75,12 +74,14 @@ export default class AuxPanel extends React.Component<IProps, IState> {
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
const cli = MatrixClientPeg.get();
|
const cli = MatrixClientPeg.get();
|
||||||
cli.on("RoomState.events", this._rateLimitedUpdate);
|
if (SettingsStore.getValue("feature_state_counters")) {
|
||||||
|
cli.on("RoomState.events", this._rateLimitedUpdate);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
const cli = MatrixClientPeg.get();
|
const cli = MatrixClientPeg.get();
|
||||||
if (cli) {
|
if (cli && SettingsStore.getValue("feature_state_counters")) {
|
||||||
cli.removeListener("RoomState.events", this._rateLimitedUpdate);
|
cli.removeListener("RoomState.events", this._rateLimitedUpdate);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -97,9 +98,7 @@ export default class AuxPanel extends React.Component<IProps, IState> {
|
||||||
}
|
}
|
||||||
|
|
||||||
_rateLimitedUpdate = new RateLimitedFunc(() => {
|
_rateLimitedUpdate = new RateLimitedFunc(() => {
|
||||||
if (SettingsStore.getValue("feature_state_counters")) {
|
this.setState({ counters: this._computeCounters() });
|
||||||
this.setState({counters: this._computeCounters()});
|
|
||||||
}
|
|
||||||
}, 500);
|
}, 500);
|
||||||
|
|
||||||
_computeCounters() {
|
_computeCounters() {
|
||||||
|
@ -215,7 +214,7 @@ export default class AuxPanel extends React.Component<IProps, IState> {
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<AutoHideScrollbar className={classes} style={style} >
|
<AutoHideScrollbar className={classes} style={style}>
|
||||||
{ stateViews }
|
{ stateViews }
|
||||||
{ appsDrawer }
|
{ appsDrawer }
|
||||||
{ callView }
|
{ callView }
|
||||||
|
|
|
@ -24,7 +24,7 @@ import {MatrixClientPeg} from "../../../MatrixClientPeg";
|
||||||
import {replaceableComponent} from "../../../utils/replaceableComponent";
|
import {replaceableComponent} from "../../../utils/replaceableComponent";
|
||||||
|
|
||||||
@replaceableComponent("views.rooms.RoomUpgradeWarningBar")
|
@replaceableComponent("views.rooms.RoomUpgradeWarningBar")
|
||||||
export default class RoomUpgradeWarningBar extends React.Component {
|
export default class RoomUpgradeWarningBar extends React.PureComponent {
|
||||||
static propTypes = {
|
static propTypes = {
|
||||||
room: PropTypes.object.isRequired,
|
room: PropTypes.object.isRequired,
|
||||||
recommendation: PropTypes.object.isRequired,
|
recommendation: PropTypes.object.isRequired,
|
||||||
|
|
Loading…
Reference in a new issue