matrix-dimension/web/app/admin/custom-bots/add/add.component.ts
2021-09-02 01:01:01 +02:00

112 lines
3.7 KiB
TypeScript

import { Component } from "@angular/core";
import { NgbActiveModal } from "@ng-bootstrap/ng-bootstrap";
import { ToasterService } from "angular2-toaster";
import { FE_CustomSimpleBot, FE_UserProfile } from "../../../shared/models/admin-responses";
import { AdminCustomSimpleBotsApiService } from "../../../shared/services/admin/admin-custom-simple-bots-api.service";
import { TranslateService } from "@ngx-translate/core";
export interface AddCustomBotDialogContext {
bot: FE_CustomSimpleBot;
isAdding: boolean;
}
@Component({
templateUrl: "./add.component.html",
styleUrls: ["./add.component.scss"],
})
export class AdminAddCustomBotComponent {
public bot = <FE_CustomSimpleBot>{};
public isAdding = true;
public isSaving = false;
private lastProfile: FE_UserProfile;
constructor(public modal: NgbActiveModal,
private botApi: AdminCustomSimpleBotsApiService,
private toaster: ToasterService,
public translate: TranslateService) {
this.translate = translate;
}
public loadProfile() {
this.botApi.getProfile(this.bot.userId).then(profile => {
if (!this.lastProfile || this.lastProfile.name === this.bot.name) {
this.bot.name = profile.name;
}
if (!this.lastProfile || this.lastProfile.avatarUrl === this.bot.avatarUrl) {
this.bot.avatarUrl = profile.avatarUrl;
}
this.lastProfile = profile;
}).catch(error => {
console.error(error);
// We don't need to alert the user - this is non-fatal
});
}
public add() {
if (!this.bot.name) {
this.translate.get('Please enter a name for the bot').subscribe((res: string) => {
this.toaster.pop("warning", res);
});
return;
}
if (!this.bot.avatarUrl) {
this.translate.get('Please enter an avatar URL for the bot').subscribe((res: string) => {
this.toaster.pop("warning", res);
});
return;
}
if (!this.bot.userId) {
this.translate.get('Please enter a user ID for the bot').subscribe((res: string) => {
this.toaster.pop("warning", res);
});
return;
}
if (!this.bot.description) {
this.translate.get('Please enter a description for the bot').subscribe((res: string) => {
this.toaster.pop("warning", res);
});
return;
}
if (!this.bot.accessToken) {
this.translate.get('Please enter an access token for the bot').subscribe((res: string) => {
this.toaster.pop("warning", res);
});
return;
}
this.isSaving = true;
const config = {
name: this.bot.name,
avatarUrl: this.bot.avatarUrl,
userId: this.bot.userId,
accessToken: this.bot.accessToken,
description: this.bot.description,
isEnabled: true,
isPublic: true,
};
let promise = null;
if (this.isAdding) {
promise = this.botApi.createBot(config);
} else {
promise = this.botApi.updateBot(this.bot.id, config);
}
promise.then(() => {
this.translate.get('Bot updated').subscribe((res: string) => {
this.toaster.pop("success", res);
});
this.modal.close();
}).catch(error => {
this.isSaving = false;
console.error(error);
this.translate.get('Error updating bot').subscribe((res: string) => {
this.toaster.pop("error", res);
});
});
}
}