make the verif toast work with to_device request that do .request/.ready

This commit is contained in:
Bruno Windels 2020-01-30 18:50:44 +01:00
parent 720450f372
commit fa13bb9689

View file

@ -58,10 +58,7 @@ export default class VerificationRequestToast extends React.PureComponent {
_checkRequestIsPending = () => { _checkRequestIsPending = () => {
const {request} = this.props; const {request} = this.props;
const isPendingInRoomRequest = request.channel.roomId && if (request.done || request.cancelled || request.observeOnly) {
!(request.ready || request.started || request.done || request.cancelled || request.observeOnly);
const isPendingDeviceRequest = request.channel.deviceId && request.started;
if (!isPendingInRoomRequest && !isPendingDeviceRequest) {
ToastStore.sharedInstance().dismissToast(this.props.toastKey); ToastStore.sharedInstance().dismissToast(this.props.toastKey);
} }
}; };
@ -79,6 +76,7 @@ export default class VerificationRequestToast extends React.PureComponent {
ToastStore.sharedInstance().dismissToast(this.props.toastKey); ToastStore.sharedInstance().dismissToast(this.props.toastKey);
const {request} = this.props; const {request} = this.props;
// no room id for to_device requests // no room id for to_device requests
const cli = MatrixClientPeg.get();
try { try {
if (request.channel.roomId) { if (request.channel.roomId) {
dis.dispatch({ dis.dispatch({
@ -86,8 +84,14 @@ export default class VerificationRequestToast extends React.PureComponent {
room_id: request.channel.roomId, room_id: request.channel.roomId,
should_peek: false, should_peek: false,
}); });
} else {
dis.dispatch({
action: 'view_room',
room_id: cli.getRooms()[0].roomId,
should_peek: false,
});
}
await request.accept(); await request.accept();
const cli = MatrixClientPeg.get();
dis.dispatch({ dis.dispatch({
action: "set_right_panel_phase", action: "set_right_panel_phase",
phase: RIGHT_PANEL_PHASES.EncryptionPanel, phase: RIGHT_PANEL_PHASES.EncryptionPanel,
@ -96,13 +100,13 @@ export default class VerificationRequestToast extends React.PureComponent {
member: cli.getUser(request.otherUserId), member: cli.getUser(request.otherUserId),
}, },
}); });
} else if (request.channel.deviceId && request.verifier) { // } else if (request.channel.deviceId && request.verifier) {
// show to_device verifications in dialog still // // show to_device verifications in dialog still
const IncomingSasDialog = sdk.getComponent("views.dialogs.IncomingSasDialog"); // const IncomingSasDialog = sdk.getComponent("views.dialogs.IncomingSasDialog");
Modal.createTrackedDialog('Incoming Verification', '', IncomingSasDialog, { // Modal.createTrackedDialog('Incoming Verification', '', IncomingSasDialog, {
verifier: request.verifier, // verifier: request.verifier,
}, null, /* priority = */ false, /* static = */ true); // }, null, /* priority = */ false, /* static = */ true);
} // }
} catch (err) { } catch (err) {
console.error(err.message); console.error(err.message);
} }