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' @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 ) { // Event to approve list } 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; // console.log(this.loadedEvent); 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.toastService._successMessage() } catch (error) { this.toastService._badRequest() } 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.toastService._successMessage('Evento rejeitado') } catch (error) { this.toastService._badRequest('Processo não efectuado') } finally { loader.remove() this.close() } } async getAttachments() { this.loadedAttachments = await this.attachmentsService.getAttachmentsById(this.InstanceId).toPromise(); } async viewDocument(DocId:string, Document) { const modal = await this.modalController.create({ component: ViewDocumentPage, componentProps: { trustedUrl: '', file: { title: Document.Assunto, 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(); } async emendTask(serialNumber:string) { const modal = await this.modalController.create({ component: EmendMessageModalPage, componentProps:{ }, cssClass: 'emend-message-modal', backdropDismiss: false }); await modal.present(); modal.onDidDismiss() .then( async (res) => { if(res.data.note !== '') { let body = { "serialNumber": serialNumber, "action": "Emendar", "dataFields": { "ReviewUserComment": res.data, } } const loader = this.toastService.loading(); try { await this.processes.PostTaskAction(body).toPromise(); this.toastService._successMessage('Pedido enviado'); this.close(); } catch (error) { this.toastService._badRequest(); } finally { loader.remove() } } else { if(res.data.option == 'save') { this.toastService._badRequest('É necessário adicionar uma nota'); } } }); } 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(); } }