import { Component } from "@angular/core"; import { FE_JitsiWidget } from "../../../shared/models/integration"; import { ToasterService } from "angular2-toaster"; import { DialogRef, ModalComponent } from "ngx-modialog"; import { WidgetConfigDialogContext } from "../widgets.component"; import { AdminIntegrationsApiService } from "../../../shared/services/admin/admin-integrations-api.service"; @Component({ templateUrl: "./jitsi.component.html", styleUrls: ["./jitsi.component.scss", "../config-dialog.scss"], }) export class AdminWidgetJitsiConfigComponent implements ModalComponent { public isUpdating = false; public widget: FE_JitsiWidget; private originalWidget: FE_JitsiWidget; constructor(public dialog: DialogRef, private adminIntegrationsApi: AdminIntegrationsApiService, private toaster: ToasterService) { this.originalWidget = dialog.context.widget; this.widget = JSON.parse(JSON.stringify(this.originalWidget)); // Fix the ui-switch not picking up a boolean value this.widget.options.useDomainAsDefault = !!this.widget.options.useDomainAsDefault; } public save() { this.isUpdating = true; this.adminIntegrationsApi.setIntegrationOptions(this.widget.category, this.widget.type, this.widget.options).then(() => { this.originalWidget.options = this.widget.options; this.toaster.pop("success", "Widget updated"); this.dialog.close(); }).catch(err => { this.isUpdating = false; console.error(err); this.toaster.pop("error", "Error updating widget"); }); } public toggleForcedJitsi() { this.widget.options.useDomainAsDefault = !this.widget.options.useDomainAsDefault; } }