mirror of
https://code.equilibrium.co.ao/ITO/doneit-web.git
synced 2026-04-20 21:35:50 +00:00
268 lines
7.2 KiB
TypeScript
268 lines
7.2 KiB
TypeScript
import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';
|
|
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 { ModalController } 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 { ExpedientTaskModalPage } from 'src/app/pages/gabinete-digital/expediente/expedient-task-modal/expedient-task-modal.page';
|
|
import { BookMeetingModalPage } from 'src/app/pages/gabinete-digital/expediente/book-meeting-modal/book-meeting-modal.page';
|
|
import { DiscartExpedientModalPage } from 'src/app/pages/gabinete-digital/discart-expedient-modal/discart-expedient-modal.page';
|
|
|
|
import { AuthService } from 'src/app/services/auth.service';
|
|
import { DespachoPage } from 'src/app/pages/gabinete-digital/despachos/despacho/despacho.page';
|
|
|
|
@Component({
|
|
selector: 'app-despachos',
|
|
templateUrl: './despachos.page.html',
|
|
styleUrls: ['./despachos.page.scss'],
|
|
})
|
|
|
|
export class DespachosPage implements OnInit {
|
|
//profile:string;
|
|
|
|
@ViewChild(CalendarComponent) myCal: CalendarComponent;
|
|
|
|
taskslist:DailyWorkTask[];
|
|
despachoList:any[] = [];
|
|
deferimentoList:DailyWorkTask[] = [];
|
|
|
|
taskList:tasksList[] = [];
|
|
|
|
taskType: string;
|
|
serialNumber:string;
|
|
totalDocs:any;
|
|
|
|
@Input() profile:string;
|
|
segment:string;
|
|
@Output() openExpedientDetail:EventEmitter<any> = new EventEmitter<any>();
|
|
|
|
loadedAttachments:any;
|
|
dicIndex = 0;
|
|
inicial = false
|
|
|
|
constructor (
|
|
private processes:ProcessesService,
|
|
private modalController: ModalController,
|
|
private alertService: AlertService,
|
|
private authService: AuthService,
|
|
) {
|
|
this.profile = 'mdgpr';
|
|
// alert('nice!')
|
|
}
|
|
|
|
ngOnInit() {
|
|
//Inicializar segment
|
|
this.segment = "despachos";
|
|
this.LoadList();
|
|
this.authService.userData$.subscribe((res:any)=>{
|
|
console.log(res);
|
|
});
|
|
}
|
|
segmentChanged(ev: any) {
|
|
this.LoadList();
|
|
}
|
|
|
|
notImplemented(){
|
|
this.alertService.presentAlert('Funcionalidade em desenvolvimento');
|
|
}
|
|
|
|
openExpedientDetailPage(data){
|
|
console.log(data);
|
|
this.openExpedientDetail.emit(data);
|
|
}
|
|
|
|
async LoadList() {
|
|
|
|
let result = await this.processes.GetTasksList("Despacho", false).toPromise();
|
|
//let despachos = result.reverse().filter(data => data.activityInstanceName == "Despacho (Paralelo)");
|
|
this.despachoList = new Array();
|
|
|
|
console.log(result);
|
|
|
|
await result.forEach( (element, index) => {
|
|
|
|
let task = {
|
|
"SerialNumber": element.serialNumber,
|
|
"Folio": element.workflowInstanceDataFields.Subject,
|
|
"Senders": element.workflowInstanceDataFields.Sender,
|
|
"CreateDate": formatDate(new Date(element.taskStartDate), 'yyyy-MM-dd HH:mm', 'pt'),
|
|
"DocumentURL": element.workflowInstanceDataFields.ViewerRequest,
|
|
"Remetente": element.workflowInstanceDataFields.Remetente,
|
|
"DocumentsQty": '',
|
|
"DocId": element.workflowInstanceDataFields.DocId,
|
|
"WorkflowName": element.workflowDisplayName,
|
|
"FolderID": element.workflowInstanceDataFields.FolderID,
|
|
"activityInstanceName": element.activityInstanceName,
|
|
}
|
|
|
|
this.despachoList.push(task)
|
|
|
|
});
|
|
|
|
this.despachoList = this.sortArrayISODate(this.despachoList).reverse()
|
|
|
|
this.despachoList.forEach( (element, index) => {
|
|
// let aplicationId = element.workflowInstanceDataFields.SourceSecFsID;
|
|
let FolderID = element['FolderID'];
|
|
|
|
this.processes.GetDocumentDetails(FolderID, '361').subscribe(res=>{
|
|
element.DocumentsQty = res.DocumentsTotal
|
|
})
|
|
|
|
});
|
|
|
|
}
|
|
|
|
sortArrayISODate(myArray: any){
|
|
return myArray.sort(function(a, b) {
|
|
return (a.CreateDate < b.CreateDate) ? -1 : ((a.CreateDate > b.CreateDate) ? 1 : 0);
|
|
});
|
|
}
|
|
|
|
doRefresh(event) {
|
|
this.LoadList();
|
|
|
|
setTimeout(() => {
|
|
event.target.complete();
|
|
}, 2000);
|
|
}
|
|
|
|
async viewExpedientDetail(serialNumber:any) {
|
|
console.log(this.profile);
|
|
|
|
const modal = await this.modalController.create({
|
|
component: DespachoPage,
|
|
componentProps:{
|
|
enterAnimation: "",
|
|
serialNumber: serialNumber,
|
|
profile: this.profile,
|
|
},
|
|
cssClass: 'modal modal-desktop',
|
|
});
|
|
await modal.present();
|
|
modal.onDidDismiss().then((res)=>{
|
|
console.log('refresh list');
|
|
this.LoadList();
|
|
});
|
|
}
|
|
|
|
// old
|
|
async openExpedientActionsModal(taskAction: any, task: any) {
|
|
//this.modalController.dismiss();
|
|
let classs;
|
|
if( window.innerWidth <= 800){
|
|
classs = 'modal modal-desktop'
|
|
} else {
|
|
classs = 'modal modal-desktop showAsideOptions'
|
|
}
|
|
|
|
const doc = this.loadedAttachments[ this.dicIndex];
|
|
|
|
task = {
|
|
serialNumber: doc.SourceId,
|
|
taskStartDate: doc.CreateDate,
|
|
isEvent: true,
|
|
workflowInstanceDataFields: {
|
|
FsId: doc.ApplicationId,
|
|
FolderID: null,
|
|
DocId: doc.SourceId,
|
|
Subject: doc.SourceName
|
|
},
|
|
}
|
|
|
|
const modal = await this.modalController.create({
|
|
component: ExpedientTaskModalPage,
|
|
componentProps: {
|
|
taskAction: taskAction,
|
|
task: task,
|
|
profile: this.profile,
|
|
},
|
|
cssClass: classs,
|
|
});
|
|
await modal.present();
|
|
modal.onDidDismiss().then(res=>{
|
|
console.log(res['data']);
|
|
if(res['data']=='openDiscart'){
|
|
console.log('open discart');
|
|
|
|
// this.distartExpedientModal();
|
|
|
|
}
|
|
|
|
});
|
|
}
|
|
|
|
async openBookMeetingModal(task: any) {
|
|
|
|
const doc = this.loadedAttachments[ this.dicIndex];
|
|
|
|
task = {
|
|
serialNumber: doc.SourceId,
|
|
taskStartDate: doc.CreateDate,
|
|
isEvent: true,
|
|
workflowInstanceDataFields: {
|
|
FsId: doc.ApplicationId,
|
|
FolderID: null,
|
|
DocId: doc.SourceId,
|
|
Subject: doc.SourceName
|
|
},
|
|
}
|
|
|
|
let classs;
|
|
if( window.innerWidth <= 800){
|
|
classs = 'book-meeting-modal modal modal-desktop'
|
|
} else {
|
|
classs = 'modal modal-desktop showAsideOptions'
|
|
}
|
|
const modal = await this.modalController.create({
|
|
component: BookMeetingModalPage,
|
|
componentProps: {
|
|
task: task,
|
|
},
|
|
cssClass: classs,
|
|
backdropDismiss: false
|
|
});
|
|
await modal.present();
|
|
modal.onDidDismiss();
|
|
}
|
|
|
|
|
|
async distartExpedientModal() {
|
|
|
|
const doc = this.taskList[ this.dicIndex];
|
|
|
|
console.log(doc, this.dicIndex, this.taskList)
|
|
|
|
const modal = await this.modalController.create({
|
|
component: DiscartExpedientModalPage,
|
|
componentProps: {
|
|
serialNumber: doc.serialNumber,
|
|
folderId: doc.workflowInstanceDataFields.FolderID,
|
|
action: 'complete',
|
|
},
|
|
cssClass: 'discart-expedient-modal',
|
|
backdropDismiss: false
|
|
});
|
|
|
|
await modal.present();
|
|
modal.onDidDismiss().then(res=>{
|
|
if(res['data']=='close'){
|
|
// this.close();
|
|
/* console.log('2Expedient Discard closed2');
|
|
this.close();
|
|
this.openMenu(); */
|
|
}
|
|
|
|
});
|
|
}
|
|
|
|
docIndex(index: number) {
|
|
this.dicIndex = index;
|
|
}
|
|
|
|
}
|