Merge branch 'developer-c' of https://bitbucket.org/equilibriumito/gabinete-digital into developer-c

This commit is contained in:
Eudes Inácio
2021-04-09 14:21:10 +01:00
15 changed files with 344 additions and 248 deletions
+4
View File
@@ -35,3 +35,7 @@ npm-debug.log*
# Custom # Custom
/android /android
/package-lock.json /package-lock.json
src/app/architect/
src/environments/environment.e2e.ts
+1 -1
View File
@@ -87,7 +87,7 @@ const routes: Routes = [
}, },
{ {
path: 'emend-message-modal', path: 'emend-message-modal',
loadChildren: () => import('../pages/agenda/emend-message-modal/emend-message-modal.module').then( m => m.EmendMessageModalPageModule) loadChildren: () => import('../pages/gabinete-digital/event-list/approve-event-modal/approve-event-modal.module').then( m => m.ApproveEventModalPageModule)
}, },
] ]
}, },
+2 -1
View File
@@ -58,7 +58,7 @@
<ion-icon class="right-icons" src="assets/images/icons-received-event.svg"></ion-icon> <ion-icon class="right-icons" src="assets/images/icons-received-event.svg"></ion-icon>
</button> </button>
<button class="btn-no-color" (click)="clearContact();openAddEvent()"> <button class="btn-no-color" (click)="clearContact();openAddEvent();">
<ion-icon class="right-icons" src="assets/images/icons-add-new-event.svg" ></ion-icon> <ion-icon class="right-icons" src="assets/images/icons-add-new-event.svg" ></ion-icon>
</button> </button>
@@ -372,6 +372,7 @@
(setIntervenient)="setIntervenient($event)" (setIntervenient)="setIntervenient($event)"
(setIntervenientCC)="setIntervenientCC($event)" (setIntervenientCC)="setIntervenientCC($event)"
></app-new-event> ></app-new-event>
<!-- Edit --> <!-- Edit -->
<app-edit-event *ngIf="mobileComponent.showEditEvent" <app-edit-event *ngIf="mobileComponent.showEditEvent"
[taskParticipants]="taskParticipants" [taskParticipants]="taskParticipants"
+7 -7
View File
@@ -113,7 +113,7 @@ export class AgendaPage implements OnInit {
// this will make toggle add event and. // this will make toggle add event and.
showEventEditOrOpen: "edit" | "add" | "" = "" showEventEditOrOpen: "edit" | "add" | "" = ""
prEventList: Event[]; prEventList: Event[];
mdEventList: Event[] mdEventList: Event[];
showLoader: boolean; showLoader: boolean;
@@ -383,7 +383,7 @@ export class AgendaPage implements OnInit {
const profile_ = profile == 'md'? 'mdgpr': 'pr'; const profile_ = profile == 'md'? 'mdgpr': 'pr';
return ` return `
<div class=" overflow-hidden timeline-box timeline-box-event-${eventIndex} timeline-${profile_}-box-${calendarName} calendar-top${top}"> <div class="overflow-hidden timeline-box timeline-box-event-${eventIndex} timeline-${profile_}-box-${calendarName} calendar-top${top}">
<div> <div>
<span class="timeline-start-time">${startHours.toString().padStart(2, '0')}:${startMinutos.toString().padStart(2, '0')}</span><span class="timeline-location">${eventlocation}</span> <span class="timeline-start-time">${startHours.toString().padStart(2, '0')}:${startMinutos.toString().padStart(2, '0')}</span><span class="timeline-location">${eventlocation}</span>
</div> </div>
@@ -474,9 +474,9 @@ export class AgendaPage implements OnInit {
this.showTimelineFilterState = false; this.showTimelineFilterState = false;
if( profile =='md'){ /* if( profile =='md'){
console.log('eventsList: ', eventsList); console.log('eventsList: ', eventsList);
} } */
eventsList.forEach((element, eventIndex) => { eventsList.forEach((element, eventIndex) => {
@@ -491,6 +491,7 @@ export class AgendaPage implements OnInit {
console.log('mdEvent:', element,eventIndex); console.log('mdEvent:', element,eventIndex);
} }
// console.log( element.CalendarName);
events.push({ events.push({
title: this.timeLineTemplate(startHours, element.Location, element.Body, element.CalendarName, element.Subject,startHoursOtherFormate,EndHoursOtherFormate, eventIndex, profile), title: this.timeLineTemplate(startHours, element.Location, element.Body, element.CalendarName, element.Subject,startHoursOtherFormate,EndHoursOtherFormate, eventIndex, profile),
start: setHours(setMinutes(new Date(element.StartDate), 0), parseInt(startHours)), start: setHours(setMinutes(new Date(element.StartDate), 0), parseInt(startHours)),
@@ -834,7 +835,7 @@ export class AgendaPage implements OnInit {
} }
async openAddEvent() { async openAddEvent() {
await this.cloneAllmobileComponent(); await this.cloneAllmobileComponent();
this.showEventEditOrOpen = 'add'; this.showEventEditOrOpen = 'add';
@@ -1063,5 +1064,4 @@ export class AgendaPage implements OnInit {
this.postEvent = false; this.postEvent = false;
} }
} }
@@ -39,7 +39,7 @@
<div class="upper-content"> <div class="upper-content">
<div class="content-location"> <div class="content-location">
<div class="location-detail"> <div class="location-detail">
<ion-label >{{loadedEvent.workflowInstanceDataFields.Location}}</ion-label> <ion-label >11{{loadedEvent.workflowInstanceDataFields.Location}}</ion-label>
</div> </div>
<div class="button-calendar-type"> <div class="button-calendar-type">
<ion-button class="button-calendar-type" slot="end">{{loadedEvent.workflowInstanceDataFields.Agenda}}</ion-button> <ion-button class="button-calendar-type" slot="end">{{loadedEvent.workflowInstanceDataFields.Agenda}}</ion-button>
@@ -8,202 +8,200 @@
<ion-header> <ion-header>
<div class="title-content"> <div class="title-content">
<div class="middle"> <div class="middle">
<ion-label class="title">Editar Evento inicio </ion-label> <ion-label class="title">Editar Evento</ion-label>
</div> </div>
</div> </div>
</ion-header> </ion-header>
</div> </div>
<ion-item-sliding class="overflow-y-auto"> <ion-item-sliding class="overflow-y-auto">
<div class="px-20"> <div class="px-20">
<div class="ion-item-container width-100"> <div class="ion-item-container width-100">
<ion-input placeholder="Assunto" [(ngModel)]="postEvent.Subject"></ion-input> <ion-input placeholder="Assunto" [(ngModel)]="postEvent.Subject"></ion-input>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-location.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-input placeholder="Localização" [(ngModel)]="postEvent.Location"></ion-input>
</div>
</div>
<!-- Error messages -->
<!-- <span class="error ion-padding" >
Campo obrigatório
</span> -->
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select disabled placeholder="Selecione agenda"
selectedText="{{postEvent.CalendarName}}"
[(ngModel)]="postEvent.CalendarName"
interface="action-sheet" Cancel-text="Cancelar"
required>
<ion-select-option value="Oficial">Oficial</ion-select-option>
<ion-select-option value="Pessoal">Pessoal</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select placeholder="Selecione tipo"
[(ngModel)]="postEvent.Categories[0]"
selectedText="{{postEvent.Categories[0]}}"
interface="action-sheet"
Cancel-text="Cancelar" required>
<ion-select-option value="Reunião">Reunião</ion-select-option>
<ion-select-option value="Viagem">Viagem</ion-select-option>
<ion-select-option value="Conferência">Conferência</ion-select-option>
<ion-select-option value="Encontro">Encontro</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2 width-100">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class width-100">
<ion-datetime
placeholder="Início"
[(ngModel)]="postEvent.StartDate"
displayFormat="D MMM YYYY H:mm"
minuteValues="0,15,30,45"
monthShortNames="Jan, Fev, Mar, Abr, Mai, Jun, Jul, Aug, Sep, Out, Nov, Dez"
min="2018"
max="2022"
>
</ion-datetime>
<!-- <ion-input placeholder="Data início" [(ngModel)]="postData.StartDate"></ion-input> -->
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-datetime
placeholder="Fim"
[(ngModel)]="postEvent.EndDate"
displayFormat="D MMM YYYY H:mm"
minuteValues="0,15,30,45"
monthShortNames="Jan, Fev, Mar, Abr, Mai, Jun, Jul, Aug, Sep, Out, Nov, Dez"
min="2018"
max="2022"
>
</ion-datetime>
<!-- <ion-input placeholder="Data fim" [(ngModel)]="postData.EndDate"></ion-input> -->
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-refresh.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select placeholder="Selecione repetição"
[(ngModel)]="postEvent.IsRecurring"
selectedText="{{isRecurring}}"
interface="action-sheet"
Cancel-text="Cancelar" required>
<ion-select-option value="false">Não se repete</ion-select-option>
<ion-select-option value="true">Repete</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="width-100">
<div class="container-div width-50">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-person.svg"></ion-icon>
</div>
<div class="ion-input-class-no-height d-flex">
<div class="list-people flex-grow-1">
<ion-item lines="none">
<ion-list>
<ion-label *ngIf="taskParticipants.length == 0" class="list-people-title">Adicionar intervenientes</ion-label>
<ion-label *ngFor="let participant of taskParticipants">{{participant.Name}}</ion-label>
</ion-list>
</ion-item>
</div>
<div class="add-people">
<ion-icon (click)="addParticipants()" slot="start" src="assets/images/icons-arrow-forward.svg"></ion-icon>
</div>
</div>
</div>
</div>
<div class="container-div width-50">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-person.svg"></ion-icon>
</div>
<div class="ion-input-class-no-height d-flex">
<div class="list-people flex-grow-1">
<ion-item lines="none">
<ion-list>
<ion-label *ngIf="taskParticipantsCc.length == 0" class="list-people-title">Adicionar intervenientes</ion-label>
<ion-label *ngFor="let participant of taskParticipantsCc">{{participant.Name}}</ion-label>
</ion-list>
</ion-item>
</div>
<div class="add-people">
<ion-icon (click)="addParticipantsCC()" slot="start" src="assets/images/icons-arrow-forward.svg"></ion-icon>
</div>
</div>
</div>
</div>
</div>
</div> </div>
<div class="container-div width-100">
<div class="container-div width-100 pb-20"> <div class="ion-item-class-2">
<div class="ion-item-class-2 d-flex">
<div class="ion-icon-class"> <div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-description.svg"></ion-icon> <ion-icon slot="start" src="assets/images/icons-location.svg"></ion-icon>
</div> </div>
<div class="ion-input-class-no-height width-100"> <div class="ion-input-class">
<ion-textarea placeholder="Detalhes" [(ngModel)]="postEvent.Body.Text" rows="6" cols="20"></ion-textarea> <ion-input placeholder="Localização" [(ngModel)]="postEvent.Location"></ion-input>
</div> </div>
</div> </div>
<!-- Error messages -->
<div hidden class="ion-item-container-no-border"> <!-- <span class="error ion-padding" >
<ion-label> Campo obrigatório
<div class="attach-icon"> </span> -->
<ion-icon src="assets/images/icons-attach-doc.svg"></ion-icon>
</div>
<div class="attach-document">
<ion-label>Anexar Documentos</ion-label>
</div>
</ion-label>
</div>
</div> </div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select disabled placeholder="Selecione agenda"
selectedText="{{postEvent.CalendarName}}"
[(ngModel)]="postEvent.CalendarName"
interface="action-sheet" Cancel-text="Cancelar"
required>
<ion-select-option value="Oficial">Oficial</ion-select-option>
<ion-select-option value="Pessoal">Pessoal</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select placeholder="Selecione tipo"
[(ngModel)]="postEvent.Categories[0]"
selectedText="{{postEvent.Categories[0]}}"
interface="action-sheet"
Cancel-text="Cancelar" required>
<ion-select-option value="Reunião">Reunião</ion-select-option>
<ion-select-option value="Viagem">Viagem</ion-select-option>
<ion-select-option value="Conferência">Conferência</ion-select-option>
<ion-select-option value="Encontro">Encontro</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2 width-100">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class width-100">
<ion-datetime
placeholder="Início"
[(ngModel)]="postEvent.StartDate"
displayFormat="D MMM YYYY H:mm"
minuteValues="0,15,30,45"
monthShortNames="Jan, Fev, Mar, Abr, Mai, Jun, Jul, Aug, Sep, Out, Nov, Dez"
min="2018"
max="2022"
>
</ion-datetime>
<!-- <ion-input placeholder="Data início" [(ngModel)]="postData.StartDate"></ion-input> -->
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-calendar.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-datetime
placeholder="Fim"
[(ngModel)]="postEvent.EndDate"
displayFormat="D MMM YYYY H:mm"
minuteValues="0,15,30,45"
monthShortNames="Jan, Fev, Mar, Abr, Mai, Jun, Jul, Aug, Sep, Out, Nov, Dez"
min="2018"
max="2022"
>
</ion-datetime>
<!-- <ion-input placeholder="Data fim" [(ngModel)]="postData.EndDate"></ion-input> -->
</div>
</div>
</div>
<div class="container-div width-100">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-refresh.svg"></ion-icon>
</div>
<div class="ion-input-class">
<ion-select placeholder="Selecione repetição"
[(ngModel)]="postEvent.IsRecurring"
selectedText="{{isRecurring}}"
interface="action-sheet"
Cancel-text="Cancelar" required>
<ion-select-option value="false">Não se repete</ion-select-option>
<ion-select-option value="true">Repete</ion-select-option>
</ion-select>
</div>
</div>
</div>
<div class="width-100">
<div class="container-div width-50">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-person.svg"></ion-icon>
</div>
<div class="ion-input-class-no-height d-flex">
<div class="list-people flex-grow-1">
<ion-item lines="none">
<ion-list>
<ion-label *ngIf="taskParticipants.length == 0" class="list-people-title">Adicionar intervenientes</ion-label>
<ion-label *ngFor="let participant of taskParticipants">{{participant.Name}}</ion-label>
</ion-list>
</ion-item>
</div>
<div class="add-people" (click)="addParticipants();showAttendees=true">
<ion-icon slot="start" src="assets/images/icons-arrow-forward.svg"></ion-icon>
</div>
</div>
</div>
</div>
<div class="container-div width-50">
<div class="ion-item-class-2">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-person.svg"></ion-icon>
</div>
<div class="ion-input-class-no-height d-flex">
<div class="list-people flex-grow-1">
<ion-item lines="none">
<ion-list>
<ion-label *ngIf="taskParticipantsCc.length == 0" class="list-people-title">Adicionar intervenientes</ion-label>
<ion-label *ngFor="let participant of taskParticipantsCc">{{participant.Name}}</ion-label>
</ion-list>
</ion-item>
</div>
<div class="add-people" (click)="addParticipantsCC();showAttendees=true">
<ion-icon slot="start" src="assets/images/icons-arrow-forward.svg"></ion-icon>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="container-div width-100 pb-20">
<div class="ion-item-class-2 d-flex">
<div class="ion-icon-class">
<ion-icon slot="start" src="assets/images/icons-description.svg"></ion-icon>
</div>
<div class="ion-input-class-no-height width-100">
<ion-textarea placeholder="Detalhes" [(ngModel)]="postEvent.Body.Text" rows="6" cols="20"></ion-textarea>
</div>
</div>
<div hidden class="ion-item-container-no-border">
<ion-label>
<div class="attach-icon">
<ion-icon src="assets/images/icons-attach-doc.svg"></ion-icon>
</div>
<div class="attach-document">
<ion-label>Anexar Documentos</ion-label>
</div>
</ion-label>
</div>
</div>
<div hidden> <div hidden>
<ion-item> <ion-item>
@@ -223,6 +221,7 @@
</div> </div>
<app-attendee-modal class="aside-right flex-column height-100 d-none d-md-flex pt-10" <app-attendee-modal class="aside-right flex-column height-100 d-none d-md-flex pt-10"
*ngIf="showAttendees"
[taskParticipants]="taskParticipants" [taskParticipants]="taskParticipants"
[taskParticipantsCc]="taskParticipantsCc" [taskParticipantsCc]="taskParticipantsCc"
[adding]="adding" [adding]="adding"
@@ -31,6 +31,9 @@ export class EditEventPage implements OnInit {
taskParticipantsCc: any = []; taskParticipantsCc: any = [];
adding: "intervenient" | "CC" = "intervenient"; adding: "intervenient" | "CC" = "intervenient";
showAttendees = false;
constructor( constructor(
private modalController: ModalController, private modalController: ModalController,
private navParams: NavParams, private navParams: NavParams,
@@ -31,8 +31,12 @@
<ion-label class="title">{{loadedEvent.Subject}}</ion-label> <ion-label class="title">{{loadedEvent.Subject}}</ion-label>
</div> </div>
<div class="div-icon"> <div class="div-icon">
<ion-icon class="edit" (click)="editEvent()" slot="end" src="assets/images/icons-edit.svg" ></ion-icon> <button class="btn-no-color" (click)="editEvent()">
<ion-icon class="delete" (click)="deleteEvent()" name="trash-sharp"></ion-icon> <ion-icon class="edit" slot="end" src="assets/images/icons-edit.svg" ></ion-icon>
</button>
<button class="btn-no-color" (click)="deleteEvent()">
<ion-icon class="delete" name="trash-sharp"></ion-icon>
</button>
</div> </div>
</div> </div>
</div> </div>
@@ -75,9 +79,10 @@
<div *ngIf="loadedAttachments" class="bottom-content width-100"> <div *ngIf="loadedAttachments" class="bottom-content width-100">
<ion-list> <ion-list>
<h5>Documentos Anexados</h5> <h5>Documentos Anexados</h5>
<ion-item class="ion-no-margin ion-no-padding"> <ion-item class="ion-no-margin ion-no-padding"
<ion-label *ngFor="let attach of loadedAttachments" *ngFor="let attach of loadedAttachments"
(click)="viewDocument(attach.SourceId)"> (click)="viewDocument(attach.SourceId)">
<ion-label>
<p class="attach-title-item">{{attach.SourceName}}</p> <p class="attach-title-item">{{attach.SourceName}}</p>
<p><span class="span-left">{{attach.Stakeholders}}</span><span class="span-right">{{ attach.CreateDate | date: 'dd-MM-yy' }}</span></p> <p><span class="span-left">{{attach.Stakeholders}}</span><span class="span-right">{{ attach.CreateDate | date: 'dd-MM-yy' }}</span></p>
</ion-label> </ion-label>
@@ -1,7 +1,9 @@
<ion-header class="ion-no-border"> <ion-header class="ion-no-border">
<div class="header-content mx-20 d-flex justify-start"> <div class="header-content mx-20 d-flex justify-start">
<div class="header-icon-left"> <div class="header-icon-left">
<ion-icon (click)="close()" src="assets/images/icons-arrow-arrow-left.svg"></ion-icon> <button class="btn-no-color" (click)="close()">
<ion-icon src="assets/images/icons-arrow-arrow-left.svg"></ion-icon>
</button>
</div> </div>
<div class="header-title flex-md-grow-1"> <div class="header-title flex-md-grow-1">
<label>{{loadedEvent.workflowInstanceDataFields.Subject}}</label> <label>{{loadedEvent.workflowInstanceDataFields.Subject}}</label>
@@ -48,22 +50,26 @@
<div class="content-details"> <div class="content-details">
<ion-label> <ion-label>
<p>{{customDate}}</p> <p>{{customDate}}</p>
<p>das {{loadedEvent.workflowInstanceDataFields.StartDate}} às {{loadedEvent.workflowInstanceDataFields.EndDate}}</p> <p>das {{loadedEvent.workflowInstanceDataFields.StartDate | date: 'hh:mm'}} às {{loadedEvent.workflowInstanceDataFields.EndDate | date: 'hh:mm'}}</p>
<p *ngIf="!loadedEvent.workflowInstanceDataFields.IsRecurring">(Não se repete)</p> <p *ngIf="!loadedEvent.workflowInstanceDataFields.IsRecurring">(Não se repete)</p>
<p *ngIf="loadedEvent.workflowInstanceDataFields.IsRecurring">Repete</p> <p *ngIf="loadedEvent.workflowInstanceDataFields.IsRecurring">Repete</p>
</ion-label> </ion-label>
</div> </div>
</div> </div>
<div class="middle-content"> <div class="middle-content">
<h5>Intervenientes</h5> <div *ngIf="loadedEvent.workflowInstanceDataFields.Participants">
<ion-item class="ion-no-padding ion-no-margin"> <h5>Intervenientes</h5>
<p>{{loadedEvent.workflowInstanceDataFields.Participants}}</p> <div *ngFor="let att of loadedEvent.workflowInstanceDataFields.ParticipantsList">
</ion-item> <ion-label>{{att.Name}}</ion-label>
</div>
</div>
<h5>Detalhes</h5> <h5>Detalhes</h5>
<ion-item class="ion-no-padding ion-no-margin"> <ion-item lines="none" class="ion-no-padding ion-no-margin">
<p>{{loadedEvent.workflowInstanceDataFields.Body}}</p> <div [innerHTML]="loadedEvent.workflowInstanceDataFields.Body"></div>
</ion-item> </ion-item>
</div> </div>
<div class="line"></div>
<div *ngIf="loadedAttachments" class="bottom-content"> <div *ngIf="loadedAttachments" class="bottom-content">
<ion-list> <ion-list>
@@ -1,7 +1,9 @@
<ion-header class="ion-no-border"> <ion-header class="ion-no-border">
<div class="header-content"> <div class="header-content">
<div class="header-icon-left"> <div class="header-icon-left">
<ion-icon (click)="close()" src="assets/images/icons-arrow-arrow-left.svg"></ion-icon> <button class="btn-no-color" (click)="close()">
<ion-icon src="assets/images/icons-arrow-arrow-left.svg"></ion-icon>
</button>
</div> </div>
<div class="header-title"> <div class="header-title">
<label>Eventos para Aprovação</label> <label>Eventos para Aprovação</label>
@@ -56,7 +56,7 @@
<div class="list-people"> <div class="list-people">
<ion-item lines="none"> <ion-item lines="none">
<ion-list> <ion-list>
<ion-label *ngIf="!taskParticipants && taskParticipants.length >= 1" class="list-people-title">Adicionar intervenientes</ion-label> <ion-label *ngIf="taskParticipants.length == 0" class="list-people-title">Adicionar intervenientes</ion-label>
<ion-label *ngFor="let participant of taskParticipants">{{participant.Name}}</ion-label> <ion-label *ngFor="let participant of taskParticipants">{{participant.Name}}</ion-label>
</ion-list> </ion-list>
</ion-item> </ion-item>
@@ -77,7 +77,7 @@
<div class="list-people"> <div class="list-people">
<ion-item lines="none"> <ion-item lines="none">
<ion-list> <ion-list>
<ion-label *ngIf="!taskParticipantsCc && taskParticipantsCc.length >= 1" class="list-people-title">Com conhecimento</ion-label> <ion-label *ngIf="taskParticipantsCc.length == 0" class="list-people-title">Com conhecimento</ion-label>
<ion-label *ngFor="let participant of taskParticipantsCc">{{participant.Name}}</ion-label> <ion-label *ngFor="let participant of taskParticipantsCc">{{participant.Name}}</ion-label>
</ion-list> </ion-list>
</ion-item> </ion-item>
@@ -72,12 +72,15 @@
<div *ngFor="let att of loadedEvent.workflowInstanceDataFields.ParticipantsList"> <div *ngFor="let att of loadedEvent.workflowInstanceDataFields.ParticipantsList">
<ion-label>{{att.Name}}</ion-label> <ion-label>{{att.Name}}</ion-label>
</div> </div>
<div class="line"></div>
</div>
<div *ngIf="loadedEvent.workflowInstanceDataFields.Body">
<h5>Detalhes</h5>
<ion-item lines="none" class="ion-no-margin ion-no-padding">
<p [innerHTML]="loadedEvent.workflowInstanceDataFields.Body"></p>
</ion-item>
<div class="line"></div>
</div> </div>
<div class="line"></div>
<h5>Detalhes</h5>
<ion-item class="ion-no-margin ion-no-padding">
<p [innerHTML]="loadedEvent.workflowInstanceDataFields.Body"></p>
</ion-item>
</div> </div>
<div *ngIf="loadedAttachments" class="bottom-content"> <div *ngIf="loadedAttachments" class="bottom-content">
@@ -23,10 +23,10 @@ export class EditEventComponent implements OnInit {
minDate: string; minDate: string;
@Input() taskParticipants: EventPerson[]; @Input() taskParticipants: EventPerson[];
@Input() taskParticipantsCc: any = []; @Input() taskParticipantsCc: EventPerson[];
@Input() profile:string; @Input() profile:string;
@Input() selectedSegment: string; @Input() selectedSegment: string;
@Input() postEvent: any; @Input() postEvent: Event;
@Output() clearContact = new EventEmitter<any>(); @Output() clearContact = new EventEmitter<any>();
@Output() openAttendeesComponent = new EventEmitter<any>(); @Output() openAttendeesComponent = new EventEmitter<any>();
@@ -45,32 +45,41 @@ export class EditEventComponent implements OnInit {
} }
ngOnInit() { ngOnInit() {
if(this.postEvent){
this.postEvent.Body.Text = this.postEvent.Body.Text.replace(/<[^>]+>/g, '');
}
// attendees list if(!this.restoreTemporaryData()){
if(this.postEvent.Attendees != null) {
this.postEvent.Attendees.forEach(e =>{ if(this.postEvent){
if(e.IsRequired) { this.postEvent.Body.Text = this.postEvent.Body.Text.replace(/<[^>]+>/g, '');
this.taskParticipants.push(e); }
} else {
this.taskParticipantsCc.push(e); // attendees list
} alert(JSON.stringify(this.postEvent.Attendees))
}) if(this.postEvent.Attendees != null) {
} this.postEvent.Attendees.forEach(e =>{
if(e.IsRequired) {
this.taskParticipants = removeDuplicate(this.taskParticipants); this.taskParticipants.push(e);
this.taskParticipantsCc = removeDuplicate(this.taskParticipantsCc); } else {
this.taskParticipantsCc.push(e);
}
})
}
this.taskParticipants = removeDuplicate(this.taskParticipants);
this.taskParticipantsCc = removeDuplicate(this.taskParticipantsCc);
this.isEventEdited = false; this.setIntervenient.emit(this.taskParticipants);
this.setIntervenientCC.emit(this.taskParticipantsCc);
if(this.postEvent.IsRecurring == false){
this.isRecurring = "Não se repete"; this.isEventEdited = false;
}
else{ if(this.postEvent.IsRecurring == false){
this.isRecurring = "Repete"; this.isRecurring = "Não se repete";
}
else{
this.isRecurring = "Repete";
}
} }
} }
close(){ close(){
@@ -78,6 +87,8 @@ export class EditEventComponent implements OnInit {
this.setIntervenient.emit([]); this.setIntervenient.emit([]);
this.setIntervenientCC.emit([]); this.setIntervenientCC.emit([]);
this.clearContact.emit(); this.clearContact.emit();
this.deleteTemporaryData();
} }
async save(){ async save(){
@@ -96,11 +107,14 @@ export class EditEventComponent implements OnInit {
}); });
this.clearPostEvent.emit(); this.clearPostEvent.emit();
this.deleteTemporaryData();
this.close(); this.close();
} }
async addParticipants() { async addParticipants() {
this.saveTemporaryData();
this.openAttendeesComponent.emit({ this.openAttendeesComponent.emit({
type: "intervenient" type: "intervenient"
}); });
@@ -109,6 +123,9 @@ export class EditEventComponent implements OnInit {
} }
async addParticipantsCc() { async addParticipantsCc() {
this.saveTemporaryData();
this.openAttendeesComponent.emit({ this.openAttendeesComponent.emit({
type: "CC" type: "CC"
}); });
@@ -116,4 +133,35 @@ export class EditEventComponent implements OnInit {
this.clearContact.emit(); this.clearContact.emit();
} }
saveTemporaryData(){
window['temp.path:/home/agenda/edit-event.component.ts'] = {
postEvent: this.postEvent,
eventBody: this.eventBody,
segment: this.segment
}
}
restoreTemporaryData(): boolean{
const restoredData = window['temp.path:/home/agenda/edit-event.component.ts']
if(JSON.stringify(restoredData) != "{}" && undefined != restoredData){
this.postEvent = restoredData.postEvent
this.eventBody = restoredData.eventBody
this.segment = restoredData.segment
return true;
} else {
return false;
}
}
deleteTemporaryData(){
window['temp.path:/home/agenda/edit-event.component.ts'] = {}
}
} }
@@ -4,7 +4,7 @@ import { EventPerson } from 'src/app/models/eventperson.model';
import { EventsService } from 'src/app/services/events.service'; import { EventsService } from 'src/app/services/events.service';
import { Event } from 'src/app/models/event.model'; import { Event } from 'src/app/models/event.model';
import { ModalController } from '@ionic/angular'; import { ModalController } from '@ionic/angular';
import { removeDuplicate } from 'src/plugin/removeDuplicate.js'
@Component({ @Component({
selector: 'app-new-event', selector: 'app-new-event',
templateUrl: './new-event.component.html', templateUrl: './new-event.component.html',
@@ -13,7 +13,6 @@ import { ModalController } from '@ionic/angular';
export class NewEventPage implements OnInit { export class NewEventPage implements OnInit {
postEvent: Event;
eventBody: EventBody; eventBody: EventBody;
segment:string = "true"; segment:string = "true";
@@ -27,6 +26,7 @@ export class NewEventPage implements OnInit {
@Output() setIntervenient = new EventEmitter<any>(); @Output() setIntervenient = new EventEmitter<any>();
@Output() setIntervenientCC = new EventEmitter<any>(); @Output() setIntervenientCC = new EventEmitter<any>();
@Input() postEvent: Event;
@Output() onAddEvent = new EventEmitter<any>(); @Output() onAddEvent = new EventEmitter<any>();
@Output() openAttendeesComponent = new EventEmitter<any>(); @Output() openAttendeesComponent = new EventEmitter<any>();
@Output() clearContact = new EventEmitter<any>(); @Output() clearContact = new EventEmitter<any>();
@@ -99,7 +99,24 @@ export class NewEventPage implements OnInit {
}; };
} }
if(this.postEvent.Attendees != null) {
this.postEvent.Attendees.forEach(e =>{
if(e.IsRequired) {
this.taskParticipants.push(e);
} else {
this.taskParticipantsCc.push(e);
}
})
}
this.taskParticipants = removeDuplicate(this.taskParticipants);
this.taskParticipantsCc = removeDuplicate(this.taskParticipantsCc);
this.setIntervenient.emit(this.taskParticipants);
this.setIntervenientCC.emit(this.taskParticipantsCc);
} }
} }
@@ -110,16 +127,18 @@ export class NewEventPage implements OnInit {
this.cloneAllmobileComponent.emit(); this.cloneAllmobileComponent.emit();
this.clearContact.emit(); this.clearContact.emit();
this.setIntervenient.emit([]);
this.setIntervenientCC.emit([]);
} }
save(){ save(){
this.postEvent.Attendees = this.taskParticipants; this.postEvent.Attendees = this.taskParticipants.concat(this.taskParticipantsCc);
if(this.profile=='mdgpr'){ if(this.profile=='mdgpr') {
this.eventService.postEventMd(this.postEvent, this.postEvent.CalendarName).subscribe(); this.eventService.postEventMd(this.postEvent, this.postEvent.CalendarName).subscribe();
} }
else if(this.profile=='pr'){ else if(this.profile=='pr') {
this.eventService.postEventPr(this.postEvent, this.postEvent.CalendarName).subscribe(); this.eventService.postEventPr(this.postEvent, this.postEvent.CalendarName).subscribe();
} }
@@ -134,6 +153,9 @@ export class NewEventPage implements OnInit {
async addParticipants() { async addParticipants() {
this.saveTemporaryData();
this.openAttendeesComponent.emit({ this.openAttendeesComponent.emit({
type: "intervenient" type: "intervenient"
}); });
@@ -142,6 +164,9 @@ export class NewEventPage implements OnInit {
} }
async addParticipantsCc() { async addParticipantsCc() {
this.saveTemporaryData();
this.openAttendeesComponent.emit({ this.openAttendeesComponent.emit({
type: "CC" type: "CC"
}); });
@@ -2,7 +2,7 @@ import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';
import { ModalController } from '@ionic/angular'; import { ModalController } from '@ionic/angular';
import { ContactsService } from 'src/app/services/contacts.service'; import { ContactsService } from 'src/app/services/contacts.service';
import { EventPerson } from 'src/app/models/eventperson.model'; import { EventPerson } from 'src/app/models/eventperson.model';
import { removeDuplicate } from 'src/plugin/removeDuplicate.js'
@Component({ @Component({
selector: 'app-attendee-modal', selector: 'app-attendee-modal',
templateUrl: './attendee-modal.page.html', templateUrl: './attendee-modal.page.html',
@@ -37,11 +37,11 @@ export class AttendeeModalPage implements OnInit {
this.fetchContacts(""); this.fetchContacts("");
if(this.taskParticipants == null || this.taskParticipants == undefined){ if(this.taskParticipants == null || this.taskParticipants == undefined) {
this.taskParticipants = []; this.taskParticipants = [];
} }
if(this.taskParticipantsCc == null || this.taskParticipantsCc == undefined){ if(this.taskParticipantsCc == null || this.taskParticipantsCc == undefined) {
this.taskParticipantsCc = []; this.taskParticipantsCc = [];
} }