mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-10 20:17:32 +01:00
use logAndCatch in RoomViewModel, everything reporting errors also logs
This commit is contained in:
parent
a2c44484b2
commit
0dbb7d4e50
@ -74,9 +74,9 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
async load() {
|
async load() {
|
||||||
this._room.on("change", this._onRoomChange);
|
this.logAndCatch("Room.load", async log => {
|
||||||
try {
|
this._room.on("change", this._onRoomChange);
|
||||||
const timeline = await this._room.openTimeline();
|
const timeline = await this._room.openTimeline(log);
|
||||||
this._tileOptions = this.childOptions({
|
this._tileOptions = this.childOptions({
|
||||||
session: this.getOption("session"),
|
session: this.getOption("session"),
|
||||||
roomVM: this,
|
roomVM: this,
|
||||||
@ -88,13 +88,11 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
timeline,
|
timeline,
|
||||||
})));
|
})));
|
||||||
this.emitChange("timelineViewModel");
|
this.emitChange("timelineViewModel");
|
||||||
} catch (error) {
|
await this._clearUnreadAfterDelay(log);
|
||||||
this.reportError(error);
|
});
|
||||||
}
|
|
||||||
this._clearUnreadAfterDelay();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async _clearUnreadAfterDelay() {
|
async _clearUnreadAfterDelay(log) {
|
||||||
if (this._room.isArchived || this._clearUnreadTimout) {
|
if (this._room.isArchived || this._clearUnreadTimout) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -104,7 +102,9 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
await this._room.clearUnread();
|
await this._room.clearUnread();
|
||||||
this._clearUnreadTimout = null;
|
this._clearUnreadTimout = null;
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
if (err.name !== "AbortError") {
|
if (err.name === "AbortError") {
|
||||||
|
log.set("clearUnreadCancelled", true);
|
||||||
|
} else {
|
||||||
throw err;
|
throw err;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -190,62 +190,61 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async _sendMessage(message, replyingTo) {
|
_sendMessage(message, replyingTo) {
|
||||||
if (!this._room.isArchived && message) {
|
return this.logAndCatch("sendMessage", async log => {
|
||||||
try {
|
let success = false;
|
||||||
|
if (!this._room.isArchived && message) {
|
||||||
let msgtype = "m.text";
|
let msgtype = "m.text";
|
||||||
if (message.startsWith("/me ")) {
|
if (message.startsWith("/me ")) {
|
||||||
message = message.substr(4).trim();
|
message = message.substr(4).trim();
|
||||||
msgtype = "m.emote";
|
msgtype = "m.emote";
|
||||||
}
|
}
|
||||||
if (replyingTo) {
|
if (replyingTo) {
|
||||||
|
log.set("replyingTo", replyingTo.eventId);
|
||||||
|
// TODO: reply should not send? it should just return the content for the reply and we send it ourselves
|
||||||
await replyingTo.reply(msgtype, message);
|
await replyingTo.reply(msgtype, message);
|
||||||
} else {
|
} else {
|
||||||
await this._room.sendEvent("m.room.message", {msgtype, body: message});
|
await this._room.sendEvent("m.room.message", {msgtype, body: message}, undefined, log);
|
||||||
}
|
}
|
||||||
} catch (error) {
|
success = true;
|
||||||
this.reportError(error);
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
return true;
|
log.set("success", success);
|
||||||
}
|
return success;
|
||||||
return false;
|
}, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
async _pickAndSendFile() {
|
_pickAndSendFile() {
|
||||||
try {
|
return this.logAndCatch("sendFile", async log => {
|
||||||
const file = await this.platform.openFile();
|
const file = await this.platform.openFile();
|
||||||
if (!file) {
|
if (!file) {
|
||||||
|
log.set("cancelled", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
return this._sendFile(file);
|
return this._sendFile(file, log);
|
||||||
} catch (err) {
|
});
|
||||||
console.error(err);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async _sendFile(file) {
|
async _sendFile(file, log) {
|
||||||
const content = {
|
const content = {
|
||||||
body: file.name,
|
body: file.name,
|
||||||
msgtype: "m.file"
|
msgtype: "m.file"
|
||||||
};
|
};
|
||||||
await this._room.sendEvent("m.room.message", content, {
|
await this._room.sendEvent("m.room.message", content, {
|
||||||
"url": this._room.createAttachment(file.blob, file.name)
|
"url": this._room.createAttachment(file.blob, file.name)
|
||||||
});
|
}, log);
|
||||||
}
|
}
|
||||||
|
|
||||||
async _pickAndSendVideo() {
|
_pickAndSendVideo() {
|
||||||
try {
|
return this.logAndCatch("sendVideo", async log => {
|
||||||
if (!this.platform.hasReadPixelPermission()) {
|
if (!this.platform.hasReadPixelPermission()) {
|
||||||
alert("Please allow canvas image data access, so we can scale your images down.");
|
throw new Error("Please allow canvas image data access, so we can scale your images down.");
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
const file = await this.platform.openFile("video/*");
|
const file = await this.platform.openFile("video/*");
|
||||||
if (!file) {
|
if (!file) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!file.blob.mimeType.startsWith("video/")) {
|
if (!file.blob.mimeType.startsWith("video/")) {
|
||||||
return this._sendFile(file);
|
return this._sendFile(file, log);
|
||||||
}
|
}
|
||||||
let video;
|
let video;
|
||||||
try {
|
try {
|
||||||
@ -273,24 +272,23 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
content.info.thumbnail_info = imageToInfo(thumbnail);
|
content.info.thumbnail_info = imageToInfo(thumbnail);
|
||||||
attachments["info.thumbnail_url"] =
|
attachments["info.thumbnail_url"] =
|
||||||
this._room.createAttachment(thumbnail.blob, file.name);
|
this._room.createAttachment(thumbnail.blob, file.name);
|
||||||
await this._room.sendEvent("m.room.message", content, attachments);
|
await this._room.sendEvent("m.room.message", content, attachments, log);
|
||||||
} catch (error) {
|
});
|
||||||
this.reportError(error);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
async _pickAndSendPicture() {
|
async _pickAndSendPicture() {
|
||||||
try {
|
this.logAndCatch("sendPicture", async log => {
|
||||||
if (!this.platform.hasReadPixelPermission()) {
|
if (!this.platform.hasReadPixelPermission()) {
|
||||||
alert("Please allow canvas image data access, so we can scale your images down.");
|
alert("Please allow canvas image data access, so we can scale your images down.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const file = await this.platform.openFile("image/*");
|
const file = await this.platform.openFile("image/*");
|
||||||
if (!file) {
|
if (!file) {
|
||||||
|
log.set("cancelled", true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!file.blob.mimeType.startsWith("image/")) {
|
if (!file.blob.mimeType.startsWith("image/")) {
|
||||||
return this._sendFile(file);
|
return this._sendFile(file, log);
|
||||||
}
|
}
|
||||||
let image = await this.platform.loadImage(file.blob);
|
let image = await this.platform.loadImage(file.blob);
|
||||||
const limit = await this.platform.settingsStorage.getInt("sentImageSizeLimit");
|
const limit = await this.platform.settingsStorage.getInt("sentImageSizeLimit");
|
||||||
@ -313,10 +311,8 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
attachments["info.thumbnail_url"] =
|
attachments["info.thumbnail_url"] =
|
||||||
this._room.createAttachment(thumbnail.blob, file.name);
|
this._room.createAttachment(thumbnail.blob, file.name);
|
||||||
}
|
}
|
||||||
await this._room.sendEvent("m.room.message", content, attachments);
|
await this._room.sendEvent("m.room.message", content, attachments, log);
|
||||||
} catch (error) {
|
});
|
||||||
this.reportError(error);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
get room() {
|
get room() {
|
||||||
@ -344,30 +340,29 @@ export class RoomViewModel extends ErrorReportViewModel {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async startCall() {
|
startCall() {
|
||||||
let localMedia;
|
return this.logAndCatch("startCall", async log => {
|
||||||
try {
|
let localMedia;
|
||||||
const stream = await this.platform.mediaDevices.getMediaTracks(false, true);
|
try {
|
||||||
localMedia = new LocalMedia().withUserMedia(stream);
|
const stream = await this.platform.mediaDevices.getMediaTracks(false, true);
|
||||||
} catch (err) {
|
localMedia = new LocalMedia().withUserMedia(stream);
|
||||||
this.reportError(new Error(`Could not get local audio and/or video stream: ${err.message}`));
|
} catch (err) {
|
||||||
return;
|
throw new Error(`Could not get local audio and/or video stream: ${err.message}`);
|
||||||
}
|
}
|
||||||
const session = this.getOption("session");
|
const session = this.getOption("session");
|
||||||
let call;
|
let call;
|
||||||
try {
|
try {
|
||||||
// this will set the callViewModel above as a call will be added to callHandler.calls
|
// this will set the callViewModel above as a call will be added to callHandler.calls
|
||||||
call = await session.callHandler.createCall(this._room.id, "m.video", "A call " + Math.round(this.platform.random() * 100));
|
call = await session.callHandler.createCall(this._room.id, "m.video", "A call " + Math.round(this.platform.random() * 100));
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
this.reportError(new Error(`Could not create call: ${err.message}`));
|
throw new Error(`Could not create call: ${err.message}`);
|
||||||
return;
|
}
|
||||||
}
|
try {
|
||||||
try {
|
await call.join(localMedia);
|
||||||
await call.join(localMedia);
|
} catch (err) {
|
||||||
} catch (err) {
|
throw new Error(`Could not join call: ${err.message}`);
|
||||||
this.reportError(new Error(`Could not join call: ${err.message}`));
|
}
|
||||||
return;
|
});
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user