mirror of
https://code.equilibrium.co.ao/ITO/doneit-web.git
synced 2026-04-18 20:47:54 +00:00
198 lines
6.6 KiB
TypeScript
198 lines
6.6 KiB
TypeScript
import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';
|
|
import { NavigationEnd, NavigationExtras, NavigationStart, Router } from '@angular/router';
|
|
import { CalendarComponent } from 'ionic2-calendar';
|
|
|
|
import { DailyWorkTask, tasksList } from '../../../models/dailyworktask.model';
|
|
import { ProcessesService } from 'src/app/services/processes.service';
|
|
import { formatDate } from '@angular/common';
|
|
import { LoadingService } from 'src/app/services/loading.service';
|
|
import { ModalController, NavParams } from '@ionic/angular';
|
|
import { ExpedienteDetailPage } from 'src/app/pages/gabinete-digital/expediente/expediente-detail/expediente-detail.page';
|
|
import { AlertService } from 'src/app/services/alert.service';
|
|
import { PedidoPage } from 'src/app/pages/gabinete-digital/pedidos/pedido/pedido.page';
|
|
import { PendentesStore } from 'src/app/store/pendestes-store.service';
|
|
import { PedidosStore } from 'src/app/store/pedidos-store.service';
|
|
|
|
@Component({
|
|
selector: 'app-pedidos',
|
|
templateUrl: './pedidos.page.html',
|
|
styleUrls: ['./pedidos.page.scss'],
|
|
})
|
|
export class PedidosPage implements OnInit {
|
|
|
|
//profile:string;
|
|
|
|
@ViewChild(CalendarComponent) myCal: CalendarComponent;
|
|
|
|
taskslist:DailyWorkTask[] = [];
|
|
parecerList:any[] = [];
|
|
fulltask:any;
|
|
|
|
parecerListResult:tasksList[] = [];
|
|
deferimentoListResult:tasksList[] = [];
|
|
|
|
deferimentoList:any[] = [];
|
|
taskType: string;
|
|
|
|
@Input() serialNumber:string;
|
|
|
|
@Input() profile:string;
|
|
@Input() segment:string;
|
|
@Output() openPedido:EventEmitter<any> = new EventEmitter<any>();
|
|
skeletonLoader = true
|
|
pedidosstore = PedidosStore;
|
|
|
|
constructor(
|
|
private router: Router,
|
|
private processes:ProcessesService,
|
|
private modalController: ModalController,
|
|
private alertService: AlertService,
|
|
) {
|
|
this.profile = 'mdgpr';
|
|
}
|
|
|
|
ngOnInit() {
|
|
|
|
this.LoadList();
|
|
|
|
this.router.events.forEach((event) => {
|
|
if(event instanceof NavigationStart && '/home/gabinete-digital?parecer=true'.startsWith(event.url) ||
|
|
event instanceof NavigationStart && '/home/gabinete-digital?deferimento=true'.startsWith(event.url) ||
|
|
event instanceof NavigationStart && '/home/gabinete-digital?pedidos=true'.startsWith(event.url)
|
|
) {
|
|
|
|
if(window.location.pathname.split('/').length >= 4 && window.location.pathname.startsWith('/home/gabinete-digital')) {
|
|
this.doRefresh()
|
|
} else {
|
|
this.LoadList()
|
|
}
|
|
|
|
}
|
|
});
|
|
|
|
|
|
}
|
|
|
|
segmentChanged(ev: any) {
|
|
this.LoadList();
|
|
}
|
|
|
|
notImplemented(){
|
|
this.alertService.presentAlert('Funcionalidade em desenvolvimento');
|
|
}
|
|
|
|
openExpedientDetailPage(data){
|
|
console.log(data);
|
|
this.openPedido.emit(data);
|
|
}
|
|
|
|
async LoadList() {
|
|
|
|
this.skeletonLoader = true;
|
|
|
|
if(this.segment == 'parecer') {
|
|
this.taskType = "Pedido de Parecer";
|
|
|
|
let parecer = await this.processes.GetTasksList("Pedido de Parecer", false).toPromise();
|
|
let parecerPr = await this.processes.GetTasksList("Pedido de Parecer do Presidente", false).toPromise();
|
|
|
|
this.skeletonLoader = false
|
|
|
|
let allParecer = parecer.concat(parecerPr).reverse();
|
|
|
|
this.parecerList = new Array();
|
|
|
|
allParecer.filter(data => data.workflowInstanceDataFields.Status == "Active").forEach(element => {
|
|
|
|
let date = new Date(element.taskStartDate);
|
|
date.setMonth(date.getMonth() + 1);
|
|
let taskDate = date.getFullYear()+"-"+ date.getMonth()+"-"+date.getDate()+" "+date.getHours()+":"+date.getMinutes()+ ":"+date.getSeconds();
|
|
|
|
let task = {
|
|
"SerialNumber": element.serialNumber,
|
|
"Folio": element.workflowInstanceDataFields.Subject,
|
|
"Senders": element.workflowInstanceDataFields.Sender,
|
|
"CreateDate": taskDate,
|
|
"DocumentURL": element.workflowInstanceDataFields.ViewerRequest,
|
|
"Remetente": element.workflowInstanceDataFields.Remetente,
|
|
"DocumentsQty": 0,
|
|
"DocId": element.workflowInstanceDataFields.ParecerDocID,
|
|
"FolderID": element.workflowInstanceDataFields.FolderID,
|
|
"WorkflowName": element.workflowDisplayName,
|
|
"activityInstanceName": element.activityInstanceName,
|
|
"Status": element.workflowInstanceDataFields.Status,
|
|
}
|
|
this.parecerList.push(task);
|
|
});
|
|
this.pedidosstore.resetparecer(this.parecerList);
|
|
|
|
}
|
|
else if(this.segment == 'deferimento') {
|
|
this.taskType = "Pedido de Deferimento";
|
|
this.processes.GetTasksList("Pedido de Deferimento", false).subscribe(result => {
|
|
|
|
this.taskslist = result.filter(data => data.workflowInstanceDataFields.Status == "Active")
|
|
|
|
this.skeletonLoader = false
|
|
|
|
this.deferimentoList = new Array();
|
|
let res = result.reverse().filter(data => data.workflowInstanceDataFields.Status == "Active")
|
|
|
|
res.forEach(element => {
|
|
let date = new Date(element.taskStartDate);
|
|
date.setMonth(date.getMonth() + 1);
|
|
let taskDate = date.getFullYear()+"-"+ date.getMonth()+"-"+date.getDate()+" "+date.getHours()+":"+date.getMinutes()+ ":"+date.getSeconds();
|
|
|
|
let task = {
|
|
"SerialNumber": element.serialNumber,
|
|
"Folio": element.workflowInstanceDataFields.Subject,
|
|
"Senders": element.workflowInstanceDataFields.Sender,
|
|
"CreateDate": taskDate,
|
|
"DocumentURL": element.workflowInstanceDataFields.ViewerRequest,
|
|
"Remetente": element.workflowInstanceDataFields.Remetente,
|
|
"DocumentsQty": 0,
|
|
"DocId": element.workflowInstanceDataFields.DocIdDiferimento,
|
|
"FolderID": element.workflowInstanceDataFields.FolderID,
|
|
"WorkflowName": element.workflowDisplayName,
|
|
"activityInstanceName": element.activityInstanceName,
|
|
"Status": element.workflowInstanceDataFields.Status,
|
|
}
|
|
this.deferimentoList.push(task);
|
|
});
|
|
this.pedidosstore.resetdeferimento(this.deferimentoList);
|
|
|
|
});
|
|
}
|
|
}
|
|
|
|
doRefresh() {
|
|
setTimeout(() => {
|
|
this.LoadList();
|
|
}, 1000);
|
|
}
|
|
|
|
goToPedido(serialNumber:any) {
|
|
this.router.navigate(['/home/gabinete-digital/pedidos',serialNumber,'gabinete-digital']);
|
|
}
|
|
|
|
async viewPedidoDetail(serialNumber:any) {
|
|
|
|
const modal = await this.modalController.create({
|
|
component: PedidoPage,
|
|
componentProps:{
|
|
enterAnimation: "",
|
|
serialNumber: serialNumber,
|
|
profile: this.profile,
|
|
},
|
|
cssClass: 'modal modal-desktop',
|
|
});
|
|
await modal.present();
|
|
modal.onDidDismiss().then((res)=>{
|
|
console.log('refresh list');
|
|
this.LoadList();
|
|
});
|
|
}
|
|
|
|
|
|
}
|