import { Component, OnInit, Input, EventEmitter, Output } from '@angular/core'; import { NavigationExtras, Router } from '@angular/router'; import { ModalController, PopoverController } from '@ionic/angular'; import { Event } from 'src/app/models/event.model'; import { AttachmentsService } from 'src/app/services/attachments.service'; import { ProcessesService } from 'src/app/services/processes.service'; import { EmendMessageModalPage } from 'src/app/pages/agenda/emend-message-modal/emend-message-modal.page'; import { EventActionsPopoverPage } from 'src/app/pages/agenda/event-actions-popover/event-actions-popover.page'; import { ToastService } from 'src/app/services/toast.service'; import { ViewDocumentPage } from 'src/app/modals/view-document/view-document.page'; import { ThemeService } from 'src/app/services/theme.service'; import { HttpErrorHandle } from 'src/app/services/http-error-handle.service'; import { TaskService } from 'src/app/services/task.service' @Component({ selector: 'app-approve-event', templateUrl: './approve-event.page.html', styleUrls: ['./approve-event.page.scss'], }) export class ApproveEventPage implements OnInit { event: Event; @Input() loadedEvent:any; loadedAttachments:any; customDate:any; today:any; show: boolean = false; months = ["Janeiro", "Fevereiro", "Março", "Abril", "Maio", "Junho", "Julho", "Agosto", "Setembro", "Outubro", "Novembro", "Dezembro"]; days = ["Domingo", "Segunda-feira", "Terça-feira", "Quarta-feira", "Quinta-feira", "Sexta-feira", "Sábado"]; @Input() serialNumber:string; @Input() showComponent:string; @Input() componentTransparent: any @Input() InstanceId:string; @Input() showAside:boolean; @Output() approveEventDismiss = new EventEmitter(); @Output() closeEventToApprove = new EventEmitter(); @Output() AproveEventEditEvent = new EventEmitter(); @Output() EditApproveEventDismiss = new EventEmitter(); constructor( private router: Router, private modalController: ModalController, private processes: ProcessesService, private attachmentsService: AttachmentsService, private popoverController: PopoverController, private toastService: ToastService, public ThemeService: ThemeService, private httpErroHandle: HttpErrorHandle, public TaskService: TaskService ) { // Event to approve list window['edit-approve-event-desktop'] = ()=> { this.getTask() } } toDateString(e) { return new Date(e).toDateString() } ngOnInit() { this.getTask(); this.getAttachments(); } close() { this.closeEventToApprove.emit(); this.modalController.dismiss(); } getTask() { this.processes.GetTask(this.serialNumber).subscribe(res => { this.loadedEvent = res; this.today = new Date(res.workflowInstanceDataFields.StartDate); // this.customDate = this.days[this.today.getDay()]+ ", " + this.today.getDate() +" de " + ( this.months[this.today.getMonth()]); }) } async approveTask(serialNumber:string) { let body = { "serialNumber": serialNumber, "action": "Aprovar" } const loader = this.toastService.loading() try { await this.processes.PostTaskAction(body).toPromise() this.modalController.dismiss(serialNumber); this.httpErroHandle.httpsSucessMessagge('Aprovar') this.TaskService.loadEventosParaAprovacao(); } catch (error) { this.httpErroHandle.httpStatusHandle(error) } finally { this.close() loader.remove() } } async rejectTask(serialNumber:string) { let body = { "serialNumber": serialNumber, "action": "Rejeitar" } const loader = this.toastService.loading() try { await this.processes.PostTaskAction(body).toPromise() this.httpErroHandle.httpsSucessMessagge('Rejeitar'); this.TaskService.loadEventosParaAprovacao(); } catch (error) { this.httpErroHandle.httpStatusHandle(error) } finally { loader.remove() this.close() } } async getAttachments() { try { this.loadedAttachments = await this.attachmentsService.getAttachmentsById(this.InstanceId).toPromise(); } catch (error) { console.error('getAttchaments',error) } } async viewDocument(DocId:string, Document) { const modal = await this.modalController.create({ component: ViewDocumentPage, componentProps: { trustedUrl: '', file: { title: Document.Description, url: '', title_link: '', }, Document, applicationId: Document.ApplicationId, docId: Document.DocId || Document.SourceId, folderId: this.loadedEvent.FolderId, task: this.loadedEvent }, cssClass: 'modal modal-desktop' }); await modal.present(); } async openOptions(ev:any) { const popover = await this.popoverController.create({ component: EventActionsPopoverPage, componentProps: { activityInstanceName: this.loadedEvent.activityInstanceName }, cssClass: 'event-actions-popover', event: ev, translucent: true }); return await popover.present().then(() =>{ this.TaskService.loadEventosParaAprovacao() this.getTask() }, (error) => { console.log(error) }) } async emendTask(serialNumber:string) { const modal = await this.modalController.create({ component: EmendMessageModalPage, componentProps:{ }, cssClass: 'emend-message-modal', backdropDismiss: false }); modal.onDidDismiss() .then( async (res) => { if(res.data.option == 'save') { let body = { "serialNumber": serialNumber, "action": "Emendar", "dataFields": { "ReviewUserComment": res.data, } } const loader = this.toastService.loading(); try { await this.processes.PostTaskAction(body).toPromise(); this.httpErroHandle.httpsSucessMessagge('Rever') this.TaskService.loadEventosParaAprovacao(); this.close(); } catch (error) { this.httpErroHandle.httpStatusHandle(error) } finally { loader.remove() } } else { } }, (error) => { console.log(error) }); await modal.present(); } goToEventsToApprove() { if(window.location.pathname.startsWith('/home/agenda')) { this.close() } else { let navigationExtras: NavigationExtras = { queryParams: { "eventos": true, } }; this.router.navigate(['/home/gabinete-digital'], navigationExtras); } } /** @description edit event to aprove */ async editar(serialNumber: string) { this.EditApproveEventDismiss.emit(); } }