2021-06-10 23:24:42 +01:00
|
|
|
import { Component, OnInit, LOCALE_ID, EventEmitter, Output, Renderer2, ElementRef } from '@angular/core';
|
2020-08-18 23:32:12 +01:00
|
|
|
|
|
|
|
|
import { Event } from '../../models/event.model';
|
|
|
|
|
import { EventsService } from 'src/app/services/events.service';
|
2021-03-31 16:47:14 +01:00
|
|
|
import { NavigationExtras, Router } from '@angular/router';
|
2020-08-21 18:26:03 +01:00
|
|
|
import { ActivatedRoute, NavigationEnd } from '@angular/router';
|
2020-08-28 11:37:28 +01:00
|
|
|
import { AlertService } from 'src/app/services/alert.service';
|
2020-08-28 15:28:38 +01:00
|
|
|
import { AuthService } from 'src/app/services/auth.service';
|
2020-11-24 13:46:13 +01:00
|
|
|
import { StorageService } from 'src/app/services/storage.service';
|
|
|
|
|
import { ModalController } from '@ionic/angular';
|
|
|
|
|
import { EventDetailPage } from './event-detail/event-detail.page';
|
|
|
|
|
import { EventDetailModalPage } from './event-detail-modal/event-detail-modal.page';
|
2021-01-04 10:37:13 +01:00
|
|
|
import { ProcessesService } from '../../services/processes.service';
|
2021-01-05 09:24:16 +01:00
|
|
|
import { DailyWorkTask } from '../../models/dailyworktask.model';
|
2021-01-31 16:14:42 +01:00
|
|
|
import { ViewEventPage } from '../agenda/view-event/view-event.page';
|
2021-02-01 09:17:38 +01:00
|
|
|
import { ExpedientePage } from '../gabinete-digital/expediente/expediente.page';
|
2021-02-01 13:21:41 +01:00
|
|
|
import { ExpedienteDetailPage } from '../gabinete-digital/expediente/expediente-detail/expediente-detail.page';
|
2021-06-03 15:03:23 +01:00
|
|
|
import { EditEventPage as EventEditPage } from './edit-event/edit-event.page';
|
2021-03-31 13:52:40 +01:00
|
|
|
import { GabineteDigitalPage } from '../gabinete-digital/gabinete-digital.page';
|
2021-05-21 10:38:55 +01:00
|
|
|
import { User } from 'src/app/models/user.model';
|
2020-08-18 23:32:12 +01:00
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
|
selector: 'app-events',
|
|
|
|
|
templateUrl: './events.page.html',
|
|
|
|
|
styleUrls: ['./events.page.scss'],
|
|
|
|
|
})
|
|
|
|
|
export class EventsPage implements OnInit {
|
2020-08-21 16:18:37 +01:00
|
|
|
/* Get current system date */
|
|
|
|
|
today = new Date();
|
|
|
|
|
|
|
|
|
|
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"];
|
2020-08-18 23:32:12 +01:00
|
|
|
|
2020-08-21 16:18:37 +01:00
|
|
|
customDate = this.days[this.today.getDay()]+ ", " + this.today.getDate() +" de " + ( this.months[this.today.getMonth()]);
|
2020-08-18 23:32:12 +01:00
|
|
|
|
2020-08-21 16:18:37 +01:00
|
|
|
/* Setting appropriate greeting according to the time */
|
|
|
|
|
grettings = ["Bom dia", "Boa tarde", "Boa noite"];
|
|
|
|
|
greetting='';
|
2020-08-18 23:32:12 +01:00
|
|
|
|
2020-08-21 16:18:37 +01:00
|
|
|
timeDate = this.today.getHours() + ":" + this.today.getMinutes();
|
|
|
|
|
/* Set segment variable */
|
|
|
|
|
segment:string;
|
2020-11-20 13:36:35 +01:00
|
|
|
public profile:string;
|
2021-01-05 13:58:15 +01:00
|
|
|
currentEvent: any;
|
2020-08-18 23:32:12 +01:00
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
eventsList: Event[];
|
|
|
|
|
officialeventsList: Event[];
|
|
|
|
|
personaleventsList: Event[];
|
|
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
prEventList: Event[];
|
|
|
|
|
mdEventList: Event[];
|
|
|
|
|
|
|
|
|
|
combinedEvents: Event[];
|
|
|
|
|
|
2020-08-28 10:10:46 +01:00
|
|
|
customText = false;
|
2021-01-04 10:37:13 +01:00
|
|
|
totalEvent=0;
|
2021-02-10 03:26:26 +01:00
|
|
|
currentHoursMinutes: Date;
|
2020-08-28 10:10:46 +01:00
|
|
|
|
2020-08-28 11:45:50 +01:00
|
|
|
showLoader: boolean;
|
2021-01-05 09:24:16 +01:00
|
|
|
|
|
|
|
|
taskslist:DailyWorkTask[];
|
2021-02-10 16:02:38 +01:00
|
|
|
expedientList:any;
|
2020-08-18 23:32:12 +01:00
|
|
|
|
2021-03-31 13:52:40 +01:00
|
|
|
@Output() openExpedientListPage:EventEmitter<any> = new EventEmitter<any>();
|
|
|
|
|
|
2021-05-21 10:38:55 +01:00
|
|
|
loggeduser: User;
|
|
|
|
|
|
2021-06-10 23:24:42 +01:00
|
|
|
constructor(
|
|
|
|
|
private eventService: EventsService,
|
2020-08-28 11:37:28 +01:00
|
|
|
private router: Router,
|
2020-11-24 13:46:13 +01:00
|
|
|
private storageService:StorageService,
|
2020-08-28 11:37:28 +01:00
|
|
|
public activatedRoute: ActivatedRoute,
|
2020-08-28 15:28:38 +01:00
|
|
|
private alertController: AlertService,
|
2021-01-05 09:24:16 +01:00
|
|
|
private authService: AuthService,
|
2021-02-18 12:44:35 +01:00
|
|
|
private processes:ProcessesService,
|
2021-03-31 14:50:04 +01:00
|
|
|
/* private gabineteService: GabineteDigitalPage, */
|
2021-06-10 23:24:42 +01:00
|
|
|
private modalController:ModalController,
|
|
|
|
|
) {
|
2021-05-21 10:38:55 +01:00
|
|
|
|
|
|
|
|
this.loggeduser = authService.ValidatedUser;
|
|
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
this.prEventList = null;
|
2021-01-04 11:34:43 +01:00
|
|
|
|
2021-01-05 09:24:16 +01:00
|
|
|
// list
|
|
|
|
|
this.LoadList();
|
2021-01-04 11:34:43 +01:00
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
}
|
2020-08-21 16:18:37 +01:00
|
|
|
|
|
|
|
|
ngOnInit() {
|
|
|
|
|
//Inicializar segment
|
2020-08-21 18:26:03 +01:00
|
|
|
this.segment = "Combinada";
|
2020-11-20 10:55:51 +01:00
|
|
|
//Initialize profile as mdgpr
|
2021-02-11 15:23:03 +01:00
|
|
|
this.profile = "mdgpr";
|
2021-03-30 15:38:57 +01:00
|
|
|
/* console.log(this.profile); */
|
2021-01-04 10:37:13 +01:00
|
|
|
|
2020-08-21 16:18:37 +01:00
|
|
|
this.showGreeting();
|
|
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
this.router.events.forEach((event) => {
|
|
|
|
|
if(event instanceof NavigationEnd && event.url == this.router.url) {
|
|
|
|
|
this.RefreshEvents();
|
2021-04-07 09:32:17 +01:00
|
|
|
this.LoadList();
|
2020-08-21 18:26:03 +01:00
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
doRefresh(event) {
|
|
|
|
|
this.RefreshEvents();
|
2021-04-06 16:25:20 +01:00
|
|
|
this.LoadList();
|
2021-04-07 09:32:17 +01:00
|
|
|
event.target.complete();
|
2020-08-21 18:26:03 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
onSegmentChange(){
|
|
|
|
|
this.RefreshEvents();
|
|
|
|
|
}
|
|
|
|
|
|
2021-06-15 17:42:51 +01:00
|
|
|
async RefreshEvents(){
|
2021-04-01 10:34:41 +01:00
|
|
|
this.currentEvent = "";
|
2020-08-21 18:26:03 +01:00
|
|
|
this.showLoader = true;
|
2021-02-10 03:26:26 +01:00
|
|
|
|
2021-02-09 15:39:39 +01:00
|
|
|
let date = new Date();
|
|
|
|
|
date.setMonth(date.getMonth() + 1);
|
|
|
|
|
let start = date.getFullYear()+"-"+ date.getMonth()+"-"+date.getDate()+" "+date.getHours()+":"+date.getMinutes()+ ":"+date.getSeconds();
|
|
|
|
|
let end = date.getFullYear()+"-"+ date.getMonth()+"-"+date.getDate()+" 23:59:59";
|
2020-11-20 10:55:51 +01:00
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
switch (this.segment)
|
|
|
|
|
{
|
|
|
|
|
case "Combinada":
|
2021-05-21 10:38:55 +01:00
|
|
|
if(this.loggeduser.Profile == 'MDGPR'){
|
2021-06-15 17:42:51 +01:00
|
|
|
|
|
|
|
|
let mdOficialEvents = await this.eventService.getAllPrOficialEvents(start, end).toPromise();
|
|
|
|
|
let mdPessoalEvents = await this.eventService.getAllPrPessoalEvents(start, end).toPromise();
|
|
|
|
|
|
|
|
|
|
this.eventsList = mdOficialEvents.concat(mdPessoalEvents);
|
2021-01-19 08:52:43 +01:00
|
|
|
|
2021-06-15 17:42:51 +01:00
|
|
|
if(this.eventsList.length > 0){
|
|
|
|
|
this.currentEvent = this.eventsList[0].Subject;
|
|
|
|
|
this.currentHoursMinutes = this.eventsList[0].StartDate;
|
2021-01-13 10:02:30 +01:00
|
|
|
}
|
2021-01-19 08:52:43 +01:00
|
|
|
|
2021-01-05 13:58:15 +01:00
|
|
|
this.totalEvent = this.eventsList.length;
|
2020-08-28 11:45:50 +01:00
|
|
|
this.showLoader = false;
|
2021-06-15 17:42:51 +01:00
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
|
|
|
|
|
let prOficialEvents= await this.eventService.getAllPrOficialEvents(start, end).toPromise();
|
|
|
|
|
let prPessoalEvents= await this.eventService.getAllPrPessoalEvents(start, end).toPromise();
|
|
|
|
|
this.eventsList = prOficialEvents.concat(prPessoalEvents);
|
|
|
|
|
console.log(this.eventsList);
|
|
|
|
|
console.log(this.eventsList);
|
|
|
|
|
|
|
|
|
|
if(this.eventsList.length > 0){
|
|
|
|
|
this.currentEvent = this.eventsList[0].Subject;
|
|
|
|
|
this.currentHoursMinutes = this.eventsList[0].StartDate;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
this.totalEvent = this.eventsList.length;
|
|
|
|
|
this.showLoader = false;
|
|
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
}
|
|
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
break;
|
|
|
|
|
case "Pessoal":
|
2021-05-21 10:38:55 +01:00
|
|
|
if(this.loggeduser.Profile == 'MDGPR'){
|
2021-06-15 17:42:51 +01:00
|
|
|
this.eventService.getAllMdPessoalEvents(start, end).subscribe(res => {
|
2020-11-20 13:36:35 +01:00
|
|
|
this.personaleventsList = res.filter(data => data.CalendarName == "Pessoal");
|
|
|
|
|
this.showLoader = false;
|
|
|
|
|
});
|
2021-06-15 17:42:51 +01:00
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
this.eventService.getAllPrPessoalEvents(start, end).subscribe(res => {
|
2020-11-20 17:02:48 +01:00
|
|
|
this.personaleventsList = res.filter(data => data.CalendarName == "Pessoal");
|
|
|
|
|
this.showLoader = false;
|
|
|
|
|
});
|
2020-11-20 10:55:51 +01:00
|
|
|
}
|
|
|
|
|
|
2020-08-21 18:26:03 +01:00
|
|
|
break;
|
|
|
|
|
case "Oficial":
|
2021-05-21 10:38:55 +01:00
|
|
|
if(this.loggeduser.Profile == 'MDGPR'){
|
2021-06-15 17:42:51 +01:00
|
|
|
this.eventService.getAllMdOficialEvents(start, end).subscribe(res => {
|
2020-11-20 13:36:35 +01:00
|
|
|
this.officialeventsList = res.filter(data => data.CalendarName == "Oficial");;
|
|
|
|
|
this.showLoader = false;
|
|
|
|
|
});
|
2021-06-15 17:42:51 +01:00
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
this.eventService.getAllPrOficialEvents(start, end).subscribe(res => {
|
2020-11-20 17:02:48 +01:00
|
|
|
this.officialeventsList = res.filter(data => data.CalendarName == "Oficial");;
|
|
|
|
|
this.showLoader = false;
|
|
|
|
|
});
|
2020-11-20 10:55:51 +01:00
|
|
|
}
|
2020-08-21 18:26:03 +01:00
|
|
|
break;
|
|
|
|
|
}
|
2020-08-18 23:32:12 +01:00
|
|
|
}
|
2020-08-21 16:18:37 +01:00
|
|
|
|
|
|
|
|
showGreeting(){
|
|
|
|
|
if(this.today.getHours() >= 6 && this.today.getHours() < 12){
|
|
|
|
|
this.greetting = this.grettings[0];
|
|
|
|
|
}
|
|
|
|
|
else if(this.today.getHours() >= 12 && this.today.getHours() < 18){
|
|
|
|
|
this.greetting = this.grettings[1];
|
|
|
|
|
}
|
|
|
|
|
else /* if(this.today.getHours() < 6 && this.today.getHours() >= 18) */{
|
|
|
|
|
this.greetting = this.grettings[2];
|
|
|
|
|
}
|
2020-08-18 23:32:12 +01:00
|
|
|
}
|
|
|
|
|
|
2020-08-21 16:18:37 +01:00
|
|
|
gotTo(){
|
|
|
|
|
this.router.navigate(['/home/events']);
|
2020-08-18 23:32:12 +01:00
|
|
|
}
|
|
|
|
|
|
2020-11-20 10:55:51 +01:00
|
|
|
changeProfile(){
|
|
|
|
|
if(this.profile == "mdgpr"){
|
|
|
|
|
console.log('pr');
|
|
|
|
|
this.profile ="pr";
|
|
|
|
|
this.RefreshEvents();
|
|
|
|
|
}
|
|
|
|
|
else{
|
|
|
|
|
console.log('mdgpr');
|
|
|
|
|
this.profile ="mdgpr";
|
|
|
|
|
this.RefreshEvents();
|
|
|
|
|
}
|
2020-08-28 11:37:28 +01:00
|
|
|
}
|
|
|
|
|
|
2020-08-28 15:28:38 +01:00
|
|
|
logout()
|
|
|
|
|
{
|
|
|
|
|
this.authService.ValidatedUser.BasicAuthKey = "";
|
|
|
|
|
this.router.navigate(['/home/login']);
|
|
|
|
|
}
|
|
|
|
|
|
2020-11-24 13:46:13 +01:00
|
|
|
async openEventDetail1(id:any){
|
|
|
|
|
console.log(id);
|
|
|
|
|
|
|
|
|
|
const modal = await this.modalController.create({
|
|
|
|
|
component: EventDetailPage,
|
|
|
|
|
componentProps: {
|
|
|
|
|
eventId: id,
|
|
|
|
|
},
|
|
|
|
|
cssClass: 'event-detail',
|
|
|
|
|
backdropDismiss: false
|
|
|
|
|
});
|
|
|
|
|
await modal.present();
|
|
|
|
|
modal.onDidDismiss();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
2021-03-31 13:52:40 +01:00
|
|
|
LoadList(){
|
2021-05-26 08:53:26 +01:00
|
|
|
switch (this.loggeduser.Profile) {
|
|
|
|
|
case 'MDGPR':
|
|
|
|
|
this.processes.GetTasksList("Expediente", false).subscribe(result => {
|
|
|
|
|
this.expedientList = result.reverse();
|
|
|
|
|
console.log(this.expedientList);
|
|
|
|
|
});
|
|
|
|
|
break;
|
|
|
|
|
case 'PR':
|
|
|
|
|
this.processes.GetTasksList("Expediente do Presidente", false).subscribe(result => {
|
|
|
|
|
this.expedientList = result.reverse();
|
|
|
|
|
console.log(this.expedientList);
|
|
|
|
|
});
|
2021-06-11 10:47:18 +01:00
|
|
|
break;
|
2021-05-26 08:53:26 +01:00
|
|
|
default:
|
|
|
|
|
break;
|
|
|
|
|
}
|
2021-01-05 09:24:16 +01:00
|
|
|
}
|
2021-01-19 08:52:43 +01:00
|
|
|
|
|
|
|
|
sortArrayISODate(myArray: any){
|
|
|
|
|
return myArray.sort(function(a, b) {
|
|
|
|
|
return (a.CreateDate < b.CreateDate) ? -1 : ((a.CreateDate > b.CreateDate) ? 1 : 0);
|
2021-01-05 09:24:16 +01:00
|
|
|
});
|
|
|
|
|
}
|
2021-01-19 16:44:39 +01:00
|
|
|
|
2021-06-10 15:38:08 +01:00
|
|
|
goToEvent(eventId:any){
|
2021-06-10 23:24:42 +01:00
|
|
|
this.router.navigate(['/home/events', eventId, 'events']);
|
2021-01-31 16:14:42 +01:00
|
|
|
}
|
|
|
|
|
|
2021-06-10 23:24:42 +01:00
|
|
|
goToExpediente(SerialNumber:any){
|
|
|
|
|
this.router.navigate(['/home/events/expediente', SerialNumber, 'events']);
|
2021-05-24 11:37:50 +01:00
|
|
|
}
|
|
|
|
|
|
2021-03-31 13:52:40 +01:00
|
|
|
viewExpedientListPage(){
|
|
|
|
|
if( window.innerWidth <= 1024){
|
2021-06-11 10:47:18 +01:00
|
|
|
this.router.navigate(['/home/gabinete-digital/expediente']);
|
2021-03-31 13:52:40 +01:00
|
|
|
}
|
|
|
|
|
else{
|
2021-05-20 11:51:27 +01:00
|
|
|
let navigationExtras: NavigationExtras = { queryParams: {"expedientes": true,} };
|
2021-03-31 16:47:14 +01:00
|
|
|
this.router.navigate(['/home/gabinete-digital'], navigationExtras);
|
2021-03-31 13:52:40 +01:00
|
|
|
}
|
|
|
|
|
}
|
2021-01-19 08:52:43 +01:00
|
|
|
|
2020-08-18 23:32:12 +01:00
|
|
|
}
|
|
|
|
|
|