You've already forked matrix-react-sdk
mirror of
https://github.com/matrix-org/matrix-react-sdk.git
synced 2025-11-17 17:42:41 +03:00
Merge pull request #3943 from matrix-org/dbkr/kill_lingering_verification_toast
Stop rogue verification toast if you verify during login
This commit is contained in:
@@ -23,9 +23,11 @@ export default class ToastContainer extends React.Component {
|
|||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
this.state = {toasts: ToastStore.sharedInstance().getToasts()};
|
this.state = {toasts: ToastStore.sharedInstance().getToasts()};
|
||||||
}
|
|
||||||
|
|
||||||
componentDidMount() {
|
// Start listening here rather than in componentDidMount because
|
||||||
|
// toasts may dismiss themselves in their didMount if they find
|
||||||
|
// they're already irrelevant by the time they're mounted, and
|
||||||
|
// our own componentDidMount is too late.
|
||||||
ToastStore.sharedInstance().on('update', this._onToastStoreUpdate);
|
ToastStore.sharedInstance().on('update', this._onToastStoreUpdate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -39,6 +39,13 @@ export default class VerificationRequestToast extends React.PureComponent {
|
|||||||
this.setState({counter});
|
this.setState({counter});
|
||||||
}, 1000);
|
}, 1000);
|
||||||
request.on("change", this._checkRequestIsPending);
|
request.on("change", this._checkRequestIsPending);
|
||||||
|
// We should probably have a separate class managing the active verification toasts,
|
||||||
|
// rather than monitoring this in the toast component itself, since we'll get problems
|
||||||
|
// like the toasdt not going away when the verification is cancelled unless it's the
|
||||||
|
// one on the top (ie. the one that's mounted).
|
||||||
|
// As a quick & dirty fix, check the toast is still relevant when it mounts (this prevents
|
||||||
|
// a toast hanging around after logging in if you did a verification as part of login).
|
||||||
|
this._checkRequestIsPending();
|
||||||
}
|
}
|
||||||
|
|
||||||
componentWillUnmount() {
|
componentWillUnmount() {
|
||||||
|
|||||||
Reference in New Issue
Block a user