@rangertechnologies/ngnxt 2.1.48 → 2.1.50
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +114 -26
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +3 -3
- package/esm2022/lib/components/custom-time/custom-time.component.mjs +3 -2
- package/esm2022/lib/directives/componenthost/componenthost.directive.mjs +19 -0
- package/esm2022/lib/nxt-app.module.mjs +4 -1
- package/esm2022/lib/pages/booklet/booklet.component.mjs +82 -4
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +120 -86
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/rangertechnologies-ngnxt.mjs +324 -110
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-calendar/custom-calendar.component.d.ts +11 -3
- package/lib/directives/componenthost/componenthost.directive.d.ts +8 -0
- package/lib/nxt-app.module.d.ts +9 -8
- package/lib/pages/booklet/booklet.component.d.ts +5 -1
- package/lib/pages/questionbook/questionbook.component.d.ts +12 -4
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/rangertechnologies-ngnxt-2.1.50.tgz +0 -0
- package/rangertechnologies-ngnxt-2.1.48.tgz +0 -0
|
@@ -1,11 +1,17 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { QuestionbookComponent } from '../../pages/questionbook/questionbook.component';
|
|
3
|
+
import { ComponenthostDirective } from '../../directives/componenthost/componenthost.directive';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "@angular/common";
|
|
4
|
-
import * as i2 from "
|
|
6
|
+
import * as i2 from "../../directives/componenthost/componenthost.directive";
|
|
7
|
+
import * as i3 from "../custom-model/custom-model.component";
|
|
5
8
|
export class CustomCalendarComponent {
|
|
6
9
|
eventSelected = new EventEmitter();
|
|
10
|
+
// VD 06Sep24 calendar changes
|
|
11
|
+
dateSelected = new EventEmitter();
|
|
7
12
|
allEvents = [];
|
|
8
13
|
question;
|
|
14
|
+
dynamicHost;
|
|
9
15
|
entries = [];
|
|
10
16
|
referenceQuestions = [];
|
|
11
17
|
qbRefrenceBook;
|
|
@@ -24,6 +30,8 @@ export class CustomCalendarComponent {
|
|
|
24
30
|
saveButtonValue = 'Save';
|
|
25
31
|
modalFooter = true;
|
|
26
32
|
editingEventId;
|
|
33
|
+
editingEntryGroup;
|
|
34
|
+
showAppoinmentSection = true;
|
|
27
35
|
ngOnInit() {
|
|
28
36
|
if (this.question?.input) {
|
|
29
37
|
this.allEvents = this.question.input;
|
|
@@ -50,6 +58,15 @@ export class CustomCalendarComponent {
|
|
|
50
58
|
console.log(this.entries);
|
|
51
59
|
console.log(this.referenceQuestions);
|
|
52
60
|
}
|
|
61
|
+
// VD 06-09-24 to call the quetionbook component
|
|
62
|
+
openQuestionBookModal() {
|
|
63
|
+
const viewContainerRef = this.dynamicHost.viewContainerRef;
|
|
64
|
+
viewContainerRef.clear();
|
|
65
|
+
const componentRef = viewContainerRef.createComponent(QuestionbookComponent);
|
|
66
|
+
componentRef.instance.qbItem = this.qbRefrenceBook;
|
|
67
|
+
componentRef.instance.questions = this.referenceQuestions;
|
|
68
|
+
componentRef.instance.handleQuestion.subscribe((event) => this.handleQuestionEvent(event));
|
|
69
|
+
}
|
|
53
70
|
generateCalendar() {
|
|
54
71
|
const year = this.currentDate.getFullYear();
|
|
55
72
|
const month = this.currentDate.getMonth();
|
|
@@ -79,9 +96,17 @@ export class CustomCalendarComponent {
|
|
|
79
96
|
day.events = this.allEvents.filter(event => event.date.toDateString() === day.date.toDateString());
|
|
80
97
|
});
|
|
81
98
|
this.eventSelected.emit(this.allEvents);
|
|
99
|
+
// VD 06Sep24 calendar changes
|
|
100
|
+
let calendar = {};
|
|
101
|
+
calendar['year'] = year;
|
|
102
|
+
calendar['month'] = month + 1;
|
|
103
|
+
console.log(calendar);
|
|
104
|
+
this.dateSelected.emit(calendar);
|
|
82
105
|
}
|
|
83
106
|
selectDay(day) {
|
|
84
107
|
console.log(day);
|
|
108
|
+
// VD 06Sep24 calendar changes
|
|
109
|
+
this.showAppoinmentSection = true;
|
|
85
110
|
this.selectedDay = day;
|
|
86
111
|
// this.eventSelected.emit(day?.events);
|
|
87
112
|
const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);
|
|
@@ -92,11 +117,14 @@ export class CustomCalendarComponent {
|
|
|
92
117
|
day.isSelected = true;
|
|
93
118
|
}
|
|
94
119
|
previousMonth() {
|
|
120
|
+
this.showAppoinmentSection = false;
|
|
95
121
|
this.currentDate.setMonth(this.currentDate.getMonth() - 1);
|
|
96
122
|
this.currentDate = new Date(this.currentDate); // Ensure the date object is updated
|
|
97
123
|
this.generateCalendar();
|
|
98
124
|
}
|
|
99
125
|
nextMonth() {
|
|
126
|
+
// VD 06Sep24 calendar changes
|
|
127
|
+
this.showAppoinmentSection = false;
|
|
100
128
|
this.currentDate.setMonth(this.currentDate.getMonth() + 1);
|
|
101
129
|
this.currentDate = new Date(this.currentDate); // Ensure the date object is updated
|
|
102
130
|
this.generateCalendar();
|
|
@@ -106,47 +134,94 @@ export class CustomCalendarComponent {
|
|
|
106
134
|
this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));
|
|
107
135
|
this.referenceQuestions.forEach(ques => {
|
|
108
136
|
// clear the input
|
|
109
|
-
if (ques.
|
|
137
|
+
if (ques.Type__c == 'Dropdown') {
|
|
138
|
+
delete ques.input;
|
|
139
|
+
delete ques.selectedValue;
|
|
140
|
+
// VD 06Sep24 calendar changes
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
110
143
|
delete ques.input;
|
|
111
144
|
}
|
|
112
145
|
});
|
|
113
146
|
console.log(' console.log(this.referenceQuestions);');
|
|
114
147
|
console.log(this.referenceQuestions);
|
|
115
148
|
this.editingEventId = null;
|
|
149
|
+
// Dynamically load the QuestionBookComponent
|
|
150
|
+
this.openQuestionBookModal();
|
|
116
151
|
}
|
|
117
|
-
|
|
152
|
+
// VD 06Sep24 calendar changes
|
|
153
|
+
editEvent(event, entryGroup) {
|
|
118
154
|
this.isModalOpen = true;
|
|
119
|
-
|
|
120
|
-
this.
|
|
155
|
+
this.referenceQuestions = Object.values(entryGroup);
|
|
156
|
+
this.calendarQuestion = [...this.referenceQuestions]; // Make a copy of the current entries to edit
|
|
121
157
|
this.editingEventId = event.id;
|
|
122
|
-
this.
|
|
158
|
+
this.editingEntryGroup = entryGroup; // Store the entry group being edited
|
|
159
|
+
this.generateCalendar(); // Regenerate the calendar to reflect changes
|
|
123
160
|
}
|
|
124
|
-
deleteEvent(
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
161
|
+
deleteEvent(eventId, entryGroup) {
|
|
162
|
+
const event = this.allEvents.find(e => e.id === eventId);
|
|
163
|
+
if (event) {
|
|
164
|
+
// Find the index of the entryGroup to delete
|
|
165
|
+
const entryIndex = event.entries.indexOf(entryGroup);
|
|
166
|
+
if (entryIndex > -1) {
|
|
167
|
+
event.entries.splice(entryIndex, 1); // Remove the specific entry
|
|
168
|
+
}
|
|
169
|
+
// If the event has no more entries, remove the event entirely
|
|
170
|
+
if (event.entries.length === 0) {
|
|
171
|
+
const eventIndex = this.allEvents.indexOf(event);
|
|
172
|
+
if (eventIndex > -1) {
|
|
173
|
+
this.allEvents.splice(eventIndex, 1); // Remove the entire event
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
this.generateCalendar(); // Regenerate the calendar to reflect the changes
|
|
128
178
|
}
|
|
129
179
|
closeModal() {
|
|
130
180
|
this.isModalOpen = false;
|
|
131
181
|
}
|
|
182
|
+
// VD 06Sep24 calendar changes
|
|
132
183
|
addEvent(day, entryQues) {
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
};
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
184
|
+
// Transform new entries into the desired format
|
|
185
|
+
const newEntries = entryQues.reduce((acc, q) => {
|
|
186
|
+
acc[q.Id] = { ...q };
|
|
187
|
+
return acc;
|
|
188
|
+
}, {});
|
|
189
|
+
// Find an existing event for the given date
|
|
190
|
+
const existingEvent = day.events.find(event => event.date === day.date);
|
|
191
|
+
if (existingEvent) {
|
|
192
|
+
// Merge new entries into the existing event's entries array
|
|
193
|
+
// Check if the entries array already contains an object with the same ID
|
|
194
|
+
const existingEntries = existingEvent.entries.map(entry => ({ ...entry }));
|
|
195
|
+
// Append new entries to the existing entries
|
|
196
|
+
existingEntries.push(newEntries);
|
|
197
|
+
existingEvent.entries = existingEntries;
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
// Create a new event if it doesn't exist for the given date
|
|
201
|
+
const newEvent = {
|
|
202
|
+
id: this.generateId(),
|
|
203
|
+
date: day.date,
|
|
204
|
+
entries: [newEntries] // Wrap the new entries in an array
|
|
205
|
+
};
|
|
206
|
+
day.events.push(newEvent);
|
|
207
|
+
this.allEvents.push(newEvent);
|
|
208
|
+
}
|
|
143
209
|
this.generateCalendar();
|
|
210
|
+
console.log('allEvents', this.allEvents);
|
|
144
211
|
}
|
|
212
|
+
// VD 06Sep24 calendar changes
|
|
145
213
|
onSave() {
|
|
146
214
|
if (this.editingEventId !== null) {
|
|
147
215
|
const event = this.allEvents.find(e => e.id === this.editingEventId);
|
|
148
|
-
if (event) {
|
|
149
|
-
|
|
216
|
+
if (event && this.editingEntryGroup) {
|
|
217
|
+
// Update the specific entry group within the event
|
|
218
|
+
const entryIndex = event.entries.findIndex(entryGroup => entryGroup === this.editingEntryGroup);
|
|
219
|
+
if (entryIndex > -1) {
|
|
220
|
+
event.entries[entryIndex] = this.calendarQuestion.reduce((acc, q) => {
|
|
221
|
+
acc[q.Id] = { ...q };
|
|
222
|
+
return acc;
|
|
223
|
+
}, {});
|
|
224
|
+
}
|
|
150
225
|
}
|
|
151
226
|
}
|
|
152
227
|
else {
|
|
@@ -175,20 +250,33 @@ export class CustomCalendarComponent {
|
|
|
175
250
|
console.log('calender question');
|
|
176
251
|
console.log(this.calendarQuestion);
|
|
177
252
|
}
|
|
253
|
+
// VD 06Sep24 calendar changes
|
|
178
254
|
generateId() {
|
|
179
255
|
return '_' + Math.random().toString(36).substr(2, 9);
|
|
180
256
|
}
|
|
257
|
+
getEntryKeys(entryGroup) {
|
|
258
|
+
return Object.keys(entryGroup);
|
|
259
|
+
}
|
|
260
|
+
removeCharacters(questionText) {
|
|
261
|
+
let updatedText = questionText?.replace(/<[^>]*>/g, '');
|
|
262
|
+
return updatedText;
|
|
263
|
+
}
|
|
181
264
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomCalendarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
182
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomCalendarComponent, selector: "app-custom-calendar", inputs: { allEvents: "allEvents", question: "question" }, outputs: { eventSelected: "eventSelected" }, ngImport: i0, template: "<div class=\"align-calendar\">\n <div class=\"calendar-container\">\n
|
|
265
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomCalendarComponent, selector: "app-custom-calendar", inputs: { allEvents: "allEvents", question: "question" }, outputs: { eventSelected: "eventSelected", dateSelected: "dateSelected" }, viewQueries: [{ propertyName: "dynamicHost", first: true, predicate: ComponenthostDirective, descendants: true, static: true }], ngImport: i0, template: "<div class=\"align-calendar\">\n <div class=\"calendar-container\">\n <div class=\"calendar-header\">\n <button (click)=\"previousMonth()\"><< Previous >></button>\n <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n <button (click)=\"nextMonth()\"><< Next >></button>\n </div>\n <div class=\"calendar-grid\">\n <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n\n <div\n class=\"calendar-day\"\n *ngFor=\"let day of calendarDays\"\n [class.not-current-month]=\"!day.isCurrentMonth\"\n [class.past]=\"day.isPast\"\n [class.today]=\"day.isToday\"\n [class.future]=\"day.isFuture\"\n [class.selected]=\"day.isSelected\"\n (click)=\"selectDay(day)\"\n >\n <div class=\"day-number\">{{ day.date.getDate() }}\n <span *ngIf=\"day.events.length > 0\" class=\"entry-indicator\" [class.select]=\"day.isSelected\"></span>\n </div>\n <!-- <div *ngFor=\"let event of day.events\" >\n <div *ngFor=\"let entryGroup of event.entries\" class=\"event\">\n <div *ngFor=\"let key of getEntryKeys(entryGroup)\">\n <div *ngIf=\"entryGroup[key].Type__c == 'Time'\">\n {{ entryGroup[key].input?.value | date: 'shortTime' }}\n </div>\n <div *ngIf=\"entryGroup[key].Type__c != 'Time'\">\n {{ entryGroup[key].input }}\n </div>\n </div>\n </div>\n </div> -->\n </div>\n </div>\n </div>\n <div class=\"appoinappointment\">\n <div class=\"appointments-container\">\n <h4>Add Appointment</h4>\n <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n </div>\n <!--VD 06Sep24 calendar updates--> \n <div *ngIf=\"showAppoinmentSection && selectedDay?.events.length > 0\" class=\"appointments-container\">\n <h4>Appointments</h4>\n <div *ngFor=\"let event of selectedDay?.events\">\n <div class=\"event\" *ngFor=\"let entryGroup of event.entries\">\n <div class=\"event-info\">\n <div *ngFor=\"let key of getEntryKeys(entryGroup)\" class=\"entry-row\">\n <div *ngIf=\"entryGroup[key].Question_Text__c\" class=\"entry-text\">\n {{removeCharacters(entryGroup[key].Question_Text__c)}}:\n </div>\n <div class=\"entry-value\">\n <span *ngIf=\"entryGroup[key].Type__c != 'Time' && entryGroup[key].Type__c != 'Link'\">{{ entryGroup[key].input }}</span>\n <span *ngIf=\"entryGroup[key].Type__c == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n <span *ngIf=\"entryGroup[key].Type__c == 'Link'\">\n <a href=\"{{entryGroup[key].input}}\">{{removeCharacters(entryGroup[key].Question_Text__c)}}</a>\n </span>\n </div>\n </div>\n <div class=\"event-actions\">\n <button (click)=\"editEvent(event,entryGroup)\">Edit</button>\n <button (click)=\"deleteEvent(event.id,entryGroup)\">Delete</button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<app-custom-model\n [modalTitle]=\"modalTitle\"\n [isModalOpen]=\"isModalOpen\"\n [modalSize]=\"modalSize\"\n [saveButtonValue]=\"saveButtonValue\"\n [modalFooter]=\"modalFooter\"\n (saveButtonEmit)=\"onSave()\"\n (cancelButtonEmit)=\"onCancel()\"\n>\n<!-- VD 06-09-24 used directive file to call the questionbook beacasue to avoid cirecular issue-->\n<!-- <lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook> -->\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model>\n\n\n \n \n ", styles: [".calendar-container{flex:1}.appoinappointment{flex:1;margin-left:10px}.calendar-header{display:flex;justify-content:space-between;align-items:center}.selected{box-shadow:0 0 5px #00000080;background-color:green!important;color:#fff!important}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.day-of-week{text-align:center;font-weight:700;padding:5px;background-color:#f0f0f0;border:1px solid #ccc}.calendar-day{border:1px solid #ccc;padding:5px;display:flex;flex-direction:column;align-items:flex-start;background-color:#fff;position:relative;cursor:pointer}.calendar-day.not-current-month{background-color:#f0f0f0}.calendar-day.past{color:#aaa}.calendar-day.today{background-color:#e6ffe6;font-weight:700}.calendar-day.future{color:#000}.day-number{font-size:1.2em;margin-bottom:5px}.event{background-color:#d1e7dd;border-left:4px solid #0f5132;margin:5px 0;padding:2px 5px;border-radius:3px}.event-title{font-weight:700}.event-time{font-size:.8em}input[type=text],input[type=time]{width:100%;margin-top:5px;box-sizing:border-box}button{margin-top:5px;align-self:stretch;margin-left:0!important}.calendar-header button{margin-top:5px;align-self:stretch;margin-left:0!important;border:none;background:none}.align-calendar{display:flex;width:100%}.form-group.content-box{padding-bottom:0!important}.entry-indicator{position:absolute;top:5px;right:5px;width:10px;height:10px;background-color:#0f5132;border-radius:50%}.select{background-color:#fff}.entry-row{display:flex;align-items:center;margin-bottom:5px}.entry-text{font-weight:700;margin-right:10px;white-space:nowrap}.entry-value{flex:1;word-break:break-word}.entry-value a{color:#4caf50}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ComponenthostDirective, selector: "[dynamicComponentHost]" }, { kind: "component", type: i3.CustomModelComponent, selector: "app-custom-model", inputs: ["modalTitle", "isModalOpen", "modalSize", "saveButtonValue", "modalFooter"], outputs: ["saveButtonEmit", "cancelButtonEmit"] }, { kind: "pipe", type: i1.DatePipe, name: "date" }] });
|
|
183
266
|
}
|
|
184
267
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomCalendarComponent, decorators: [{
|
|
185
268
|
type: Component,
|
|
186
|
-
args: [{ selector: 'app-custom-calendar', template: "<div class=\"align-calendar\">\n <div class=\"calendar-container\">\n
|
|
269
|
+
args: [{ selector: 'app-custom-calendar', template: "<div class=\"align-calendar\">\n <div class=\"calendar-container\">\n <div class=\"calendar-header\">\n <button (click)=\"previousMonth()\"><< Previous >></button>\n <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n <button (click)=\"nextMonth()\"><< Next >></button>\n </div>\n <div class=\"calendar-grid\">\n <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n\n <div\n class=\"calendar-day\"\n *ngFor=\"let day of calendarDays\"\n [class.not-current-month]=\"!day.isCurrentMonth\"\n [class.past]=\"day.isPast\"\n [class.today]=\"day.isToday\"\n [class.future]=\"day.isFuture\"\n [class.selected]=\"day.isSelected\"\n (click)=\"selectDay(day)\"\n >\n <div class=\"day-number\">{{ day.date.getDate() }}\n <span *ngIf=\"day.events.length > 0\" class=\"entry-indicator\" [class.select]=\"day.isSelected\"></span>\n </div>\n <!-- <div *ngFor=\"let event of day.events\" >\n <div *ngFor=\"let entryGroup of event.entries\" class=\"event\">\n <div *ngFor=\"let key of getEntryKeys(entryGroup)\">\n <div *ngIf=\"entryGroup[key].Type__c == 'Time'\">\n {{ entryGroup[key].input?.value | date: 'shortTime' }}\n </div>\n <div *ngIf=\"entryGroup[key].Type__c != 'Time'\">\n {{ entryGroup[key].input }}\n </div>\n </div>\n </div>\n </div> -->\n </div>\n </div>\n </div>\n <div class=\"appoinappointment\">\n <div class=\"appointments-container\">\n <h4>Add Appointment</h4>\n <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n </div>\n <!--VD 06Sep24 calendar updates--> \n <div *ngIf=\"showAppoinmentSection && selectedDay?.events.length > 0\" class=\"appointments-container\">\n <h4>Appointments</h4>\n <div *ngFor=\"let event of selectedDay?.events\">\n <div class=\"event\" *ngFor=\"let entryGroup of event.entries\">\n <div class=\"event-info\">\n <div *ngFor=\"let key of getEntryKeys(entryGroup)\" class=\"entry-row\">\n <div *ngIf=\"entryGroup[key].Question_Text__c\" class=\"entry-text\">\n {{removeCharacters(entryGroup[key].Question_Text__c)}}:\n </div>\n <div class=\"entry-value\">\n <span *ngIf=\"entryGroup[key].Type__c != 'Time' && entryGroup[key].Type__c != 'Link'\">{{ entryGroup[key].input }}</span>\n <span *ngIf=\"entryGroup[key].Type__c == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n <span *ngIf=\"entryGroup[key].Type__c == 'Link'\">\n <a href=\"{{entryGroup[key].input}}\">{{removeCharacters(entryGroup[key].Question_Text__c)}}</a>\n </span>\n </div>\n </div>\n <div class=\"event-actions\">\n <button (click)=\"editEvent(event,entryGroup)\">Edit</button>\n <button (click)=\"deleteEvent(event.id,entryGroup)\">Delete</button>\n </div>\n </div>\n </div>\n </div>\n </div>\n </div>\n</div>\n\n<app-custom-model\n [modalTitle]=\"modalTitle\"\n [isModalOpen]=\"isModalOpen\"\n [modalSize]=\"modalSize\"\n [saveButtonValue]=\"saveButtonValue\"\n [modalFooter]=\"modalFooter\"\n (saveButtonEmit)=\"onSave()\"\n (cancelButtonEmit)=\"onCancel()\"\n>\n<!-- VD 06-09-24 used directive file to call the questionbook beacasue to avoid cirecular issue-->\n<!-- <lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook> -->\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model>\n\n\n \n \n ", styles: [".calendar-container{flex:1}.appoinappointment{flex:1;margin-left:10px}.calendar-header{display:flex;justify-content:space-between;align-items:center}.selected{box-shadow:0 0 5px #00000080;background-color:green!important;color:#fff!important}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}.day-of-week{text-align:center;font-weight:700;padding:5px;background-color:#f0f0f0;border:1px solid #ccc}.calendar-day{border:1px solid #ccc;padding:5px;display:flex;flex-direction:column;align-items:flex-start;background-color:#fff;position:relative;cursor:pointer}.calendar-day.not-current-month{background-color:#f0f0f0}.calendar-day.past{color:#aaa}.calendar-day.today{background-color:#e6ffe6;font-weight:700}.calendar-day.future{color:#000}.day-number{font-size:1.2em;margin-bottom:5px}.event{background-color:#d1e7dd;border-left:4px solid #0f5132;margin:5px 0;padding:2px 5px;border-radius:3px}.event-title{font-weight:700}.event-time{font-size:.8em}input[type=text],input[type=time]{width:100%;margin-top:5px;box-sizing:border-box}button{margin-top:5px;align-self:stretch;margin-left:0!important}.calendar-header button{margin-top:5px;align-self:stretch;margin-left:0!important;border:none;background:none}.align-calendar{display:flex;width:100%}.form-group.content-box{padding-bottom:0!important}.entry-indicator{position:absolute;top:5px;right:5px;width:10px;height:10px;background-color:#0f5132;border-radius:50%}.select{background-color:#fff}.entry-row{display:flex;align-items:center;margin-bottom:5px}.entry-text{font-weight:700;margin-right:10px;white-space:nowrap}.entry-value{flex:1;word-break:break-word}.entry-value a{color:#4caf50}\n"] }]
|
|
187
270
|
}], propDecorators: { eventSelected: [{
|
|
188
271
|
type: Output
|
|
272
|
+
}], dateSelected: [{
|
|
273
|
+
type: Output
|
|
189
274
|
}], allEvents: [{
|
|
190
275
|
type: Input
|
|
191
276
|
}], question: [{
|
|
192
277
|
type: Input
|
|
278
|
+
}], dynamicHost: [{
|
|
279
|
+
type: ViewChild,
|
|
280
|
+
args: [ComponenthostDirective, { static: true }]
|
|
193
281
|
}] } });
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { Question } from '../../wrapper';\ninterface CalendarDay {\n  date: Date;\n  events: any[];\n  isCurrentMonth: boolean;\n  isPast: boolean;\n  isToday: boolean;\n  isFuture: boolean;\n  isSelected?: boolean;\n}\n\n@Component({\n  selector: 'app-custom-calendar',\n  templateUrl: './custom-calendar.component.html',\n  styleUrls: ['./custom-calendar.component.css']\n})\nexport class CustomCalendarComponent implements OnInit {\n\n  @Output() eventSelected = new EventEmitter<any>();\n  @Input() allEvents: any[] = []; \n  @Input() question: Question\n\n  entries = [];\n  referenceQuestions = [];\n  qbRefrenceBook:any;\n  calendarQuestion = [];\n\n  currentDate: Date = new Date();\n  calendarDays: CalendarDay[] = [];\n  daysOfWeek: string[] = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n\n  newEventTitle: string = '';\n  newEventTime: string = '';\n  newDescription: string = '';\n  newLink: string = '';\n  selectedDay: CalendarDay | null = null;\n\n  isModalOpen = false;\n  modalTitle = 'Custom Modal';\n  modalSize = 'large';\n  saveButtonValue = 'Save';\n  modalFooter = true;\n  editingEventId: number;\n\n  ngOnInit() {\n     if(this.question?.input){\n      this.allEvents = this.question.input;\n     }\n    this.processQuestion();\n    this.generateCalendar();\n  }\n\n  processQuestion(){\n    this.entries = JSON.parse(this.question['Fields_Meta__c']);\n    this.qbRefrenceBook = JSON.parse(this.question['QB_Reference_Questions__c']);\n    let title = this.qbRefrenceBook?.questionbook?.Title__c;\n    this.modalTitle = title;\n    this.referenceQuestions = [];\n    if(this.entries.length > 0){\n       this.entries.forEach(element => {\n           if(element.questionReference){\n             let qReference = JSON.parse(element.questionReference);\n             this.referenceQuestions.push(qReference?.question);\n           }\n       });\n    }\n    console.log('entries-->');\n    console.log('question-->');\n    console.log(this.entries);\n    console.log(this.referenceQuestions);\n  }\n\n  generateCalendar() {\n    const year = this.currentDate.getFullYear();\n    const month = this.currentDate.getMonth();\n\n    const startOfMonth = new Date(year, month, 1);\n    const endOfMonth = new Date(year, month + 1, 0);\n\n    const startDayOfWeek = startOfMonth.getDay();\n    const endDayOfWeek = endOfMonth.getDay();\n\n    const startDate = new Date(startOfMonth);\n    startDate.setDate(startDate.getDate() - startDayOfWeek);\n\n    const endDate = new Date(endOfMonth);\n    endDate.setDate(endDate.getDate() + (6 - endDayOfWeek));\n\n    const today = new Date(new Date().setHours(0, 0, 0, 0));\n    \n      this.calendarDays = [];\n      for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {\n        const date = new Date(d);\n        this.calendarDays.push({\n          date: date,\n          events: [],\n          isCurrentMonth: d.getMonth() === month,\n          isPast: date < today,\n          isToday: date.getTime() === today.getTime(),\n          isFuture: date > today,\n        });\n      }\n\n    // Populate calendar with events from allEvents array\n    this.calendarDays.forEach(day => {\n      day.events = this.allEvents.filter(event => event.date.toDateString() === day.date.toDateString());\n    });\n    this.eventSelected.emit(this.allEvents);\n  }\n\n\n  selectDay(day: CalendarDay) {\n    console.log(day);\n    this.selectedDay = day;\n   // this.eventSelected.emit(day?.events);\n    const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);\n    if (previouslySelectedDay) {\n      previouslySelectedDay.isSelected = false;\n    }\n    // Select the clicked day\n    day.isSelected = true;\n  }\n\n  previousMonth() {\n    this.currentDate.setMonth(this.currentDate.getMonth() - 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n  }\n\n  nextMonth() {\n    this.currentDate.setMonth(this.currentDate.getMonth() + 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n  }\n\n  addAppointment() {\n    this.isModalOpen = true;\n     this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));\n    this.referenceQuestions.forEach(ques => {\n      // clear the input\n      if(ques.input){\n        delete ques.input;\n      }\n    });\n    console.log(' console.log(this.referenceQuestions);');\n    console.log(this.referenceQuestions);\n    this.editingEventId = null;\n  }\n\n  editEvent(event) {\n    this.isModalOpen = true;\n   // this.calendarQuestion = event.entries.map(q => ({ ...q }));\n    this.referenceQuestions = event.entries.map(q => ({ ...q }));\n    this.editingEventId = event.id;\n    this.generateCalendar();\n  }\n  \n  deleteEvent(day: CalendarDay, eventId: string) {\n    day.events = day.events.filter(event => event.id !== eventId);\n    this.allEvents = this.allEvents.filter(event => event.id !== eventId);\n    this.generateCalendar();\n  }\n\n  closeModal() {\n    this.isModalOpen = false;\n  }\n\n  addEvent(day: CalendarDay,entryQues) {\n    const newEvent  = {\n      id: this.generateId(),\n      date: day.date,\n      entries: entryQues.map(q => ({ ...q }))\n    };\n    day.events.push(newEvent);\n    this.allEvents.push(newEvent);\n    this.generateCalendar();\n    console.log('allEvents');\n    console.log(this.allEvents);\n    this.generateCalendar();\n\n  }\n\n  onSave() {\n    if (this.editingEventId !== null) {\n      const event = this.allEvents.find(e => e.id === this.editingEventId);\n      if (event) {\n        event.entries = this.calendarQuestion.map(q => ({ ...q }));\n      }\n    } else {\n      if (this.selectedDay) {\n        this.addEvent(this.selectedDay, this.calendarQuestion);\n      }\n    }\n    this.closeModal();\n    this.generateCalendar();\n  }\n\n  onCancel() {\n    console.log('Cancel button clicked');\n    this.closeModal();\n  }\n\n  handleQuestionEvent(ques){\n      // Update the questions array with the new question\n      const index = this.calendarQuestion.findIndex(q => q.Id === ques.Id);\n      if (index > -1) {\n        // If question already exists, update it\n        this.calendarQuestion[index] = ques;\n      } else {\n        // If question doesn't exist, add it to the array\n        this.calendarQuestion.push(ques);\n      }\n      console.log('calender question');\n      console.log(this.calendarQuestion);\n    }\n\n    generateId() {\n      return '_' + Math.random().toString(36).substr(2, 9);\n    }\n\n}\n","<div class=\"align-calendar\">\n    <div class=\"calendar-container\">\n        <div class=\"calendar-header\">\n          <button (click)=\"previousMonth()\"><< Previous >></button>\n          <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n          <button (click)=\"nextMonth()\"><< Next >></button>\n        </div>\n        <div class=\"calendar-grid\">\n          <!-- Days of the Week Header -->\n          <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n      \n          <!-- Calendar Days -->\n          <div\n            class=\"calendar-day\"\n            *ngFor=\"let day of calendarDays\"\n            [class.not-current-month]=\"!day.isCurrentMonth\"\n            [class.past]=\"day.isPast\"\n            [class.today]=\"day.isToday\"\n            [class.future]=\"day.isFuture\"\n            [class.selected]=\"day.isSelected\" \n            (click)=\"selectDay(day)\"\n          >\n            <div class=\"day-number\">{{ day.date.getDate() }}</div>\n            <div *ngFor=\"let event of day.events\" class=\"event\">\n              <div  *ngFor=\"let entry of event?.entries\">\n                <div *ngIf=\"entry.Type__c == 'Time'\">{{ entry.input?.value | date: 'shortTime'  }}</div>\n              </div>\n            </div>\n          </div>\n        </div>\n    </div>\n    <div class=\"appoinappointment\">\n        <div class=\"appointments-container\">\n            <h4>Add Appointment</h4>\n            <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n          </div>\n          <div class=\"appointments-container\">\n            <h4 *ngIf=\"selectedDay?.events.length > 0\">Appointments</h4>\n            <div class=\"event\" *ngFor=\"let event of selectedDay?.events\">\n                <div class=\"event-info\">\n                  <div>\n                    <div  *ngFor=\"let entry of event?.entries\">\n                      <div *ngIf=\"entry.Type__c != 'Time'\">{{ entry.input }}</div>\n                      <div *ngIf=\"entry.Type__c == 'Time'\">{{ entry.input?.value | date: 'mediumDate'  }}</div>\n                    </div>\n                  </div>\n                </div>\n                <div class=\"event-actions\">\n                  <button  (click)=\"editEvent(event)\">Edit</button>\n                  <button (click)=\"deleteEvent(selectedDay, event.id)\">Delete</button>\n                </div>\n              </div>          \n          </div>\n    </div>\n</div>\n\n<app-custom-model\n  [modalTitle]=\"modalTitle\"\n  [isModalOpen]=\"isModalOpen\"\n  [modalSize]=\"modalSize\"\n  [saveButtonValue]=\"saveButtonValue\"\n  [modalFooter]=\"modalFooter\"\n  (saveButtonEmit)=\"onSave()\"\n  (cancelButtonEmit)=\"onCancel()\"\n>\n<app-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></app-questionbook>\n</app-custom-model>\n\n\n  \n  \n  "]}
|
|
282
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-calendar.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-calendar/custom-calendar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { Question } from '../../wrapper';\nimport { QuestionbookComponent } from '../../pages/questionbook/questionbook.component';\nimport { ComponenthostDirective } from '../../directives/componenthost/componenthost.directive';\ninterface CalendarDay {\n  date: Date;\n  events: any[];\n  isCurrentMonth: boolean;\n  isPast: boolean;\n  isToday: boolean;\n  isFuture: boolean;\n  isSelected?: boolean;\n}\n\n@Component({\n  selector: 'app-custom-calendar',\n  templateUrl: './custom-calendar.component.html',\n  styleUrls: ['./custom-calendar.component.css'],\n})\nexport class CustomCalendarComponent implements OnInit {\n\n  @Output() eventSelected = new EventEmitter<any>();\n  // VD 06Sep24 calendar changes\n  @Output() dateSelected = new EventEmitter<any>();\n  @Input() allEvents: any[] = []; \n  @Input() question: Question\n  @ViewChild(ComponenthostDirective, { static: true }) dynamicHost: ComponenthostDirective;\n  entries = [];\n  referenceQuestions = [];\n  qbRefrenceBook:any;\n  calendarQuestion = [];\n\n  currentDate: Date = new Date();\n  calendarDays: CalendarDay[] = [];\n  daysOfWeek: string[] = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n\n  newEventTitle: string = '';\n  newEventTime: string = '';\n  newDescription: string = '';\n  newLink: string = '';\n  selectedDay: CalendarDay | null = null;\n\n  isModalOpen = false;\n  modalTitle = 'Custom Modal';\n  modalSize = 'large';\n  saveButtonValue = 'Save';\n  modalFooter = true;\n  editingEventId: number;\n  editingEntryGroup: any;\n  showAppoinmentSection: boolean = true;\n\n  ngOnInit() {\n     if(this.question?.input){\n      this.allEvents = this.question.input;\n     }\n    this.processQuestion();\n    this.generateCalendar();\n  }\n\n  processQuestion(){\n    this.entries = JSON.parse(this.question['Fields_Meta__c']);\n    this.qbRefrenceBook = JSON.parse(this.question['QB_Reference_Questions__c']);\n    let title = this.qbRefrenceBook?.questionbook?.Title__c;\n    this.modalTitle = title;\n    this.referenceQuestions = [];\n    if(this.entries.length > 0){\n       this.entries.forEach(element => {\n           if(element.questionReference){\n             let qReference = JSON.parse(element.questionReference);\n             this.referenceQuestions.push(qReference?.question);\n           }\n       });\n    }\n    console.log('entries-->');\n    console.log('question-->');\n    console.log(this.entries);\n    console.log(this.referenceQuestions);\n  }\n\n  // VD 06-09-24 to call the quetionbook component\n  openQuestionBookModal() {\n    const viewContainerRef = this.dynamicHost.viewContainerRef;\n    viewContainerRef.clear();\n    const componentRef = viewContainerRef.createComponent(QuestionbookComponent);\n    componentRef.instance.qbItem = this.qbRefrenceBook;\n    componentRef.instance.questions = this.referenceQuestions;\n    componentRef.instance.handleQuestion.subscribe((event: any) => this.handleQuestionEvent(event));\n  }\n\n  generateCalendar() {\n    const year = this.currentDate.getFullYear();\n    const month = this.currentDate.getMonth();\n\n    const startOfMonth = new Date(year, month, 1);\n    const endOfMonth = new Date(year, month + 1, 0);\n\n    const startDayOfWeek = startOfMonth.getDay();\n    const endDayOfWeek = endOfMonth.getDay();\n\n    const startDate = new Date(startOfMonth);\n    startDate.setDate(startDate.getDate() - startDayOfWeek);\n\n    const endDate = new Date(endOfMonth);\n    endDate.setDate(endDate.getDate() + (6 - endDayOfWeek));\n\n    const today = new Date(new Date().setHours(0, 0, 0, 0));\n    \n      this.calendarDays = [];\n      for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {\n        const date = new Date(d);\n        this.calendarDays.push({\n          date: date,\n          events: [],\n          isCurrentMonth: d.getMonth() === month,\n          isPast: date < today,\n          isToday: date.getTime() === today.getTime(),\n          isFuture: date > today,\n        });\n      }\n\n    // Populate calendar with events from allEvents array\n    this.calendarDays.forEach(day => {\n      day.events = this.allEvents.filter(event => event.date.toDateString() === day.date.toDateString());\n    });\n    this.eventSelected.emit(this.allEvents);\n     // VD 06Sep24 calendar changes\n    let calendar = {}\n    calendar['year'] = year;\n    calendar['month'] = month + 1;\n    console.log(calendar);\n    this.dateSelected.emit(calendar);\n  }\n\n\n  selectDay(day: CalendarDay) {\n    console.log(day);\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = true;\n    this.selectedDay = day;\n   // this.eventSelected.emit(day?.events);\n    const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);\n    if (previouslySelectedDay) {\n      previouslySelectedDay.isSelected = false;\n    }\n    // Select the clicked day\n    day.isSelected = true;\n  }\n\n  previousMonth() {\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() - 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n  }\n\n  nextMonth() {\n     // VD 06Sep24 calendar changes\n    this.showAppoinmentSection = false;\n    this.currentDate.setMonth(this.currentDate.getMonth() + 1);\n    this.currentDate = new Date(this.currentDate); // Ensure the date object is updated\n    this.generateCalendar();\n  }\n\n  addAppointment() {\n    this.isModalOpen = true;\n     this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));\n    this.referenceQuestions.forEach(ques => {\n      // clear the input\n      if(ques.Type__c == 'Dropdown'){\n        delete ques.input;\n        delete ques.selectedValue;\n         // VD 06Sep24 calendar changes\n      }else {\n        delete ques.input;\n      }\n    });\n    console.log(' console.log(this.referenceQuestions);');\n    console.log(this.referenceQuestions);\n    this.editingEventId = null;\n\n    // Dynamically load the QuestionBookComponent\n    this.openQuestionBookModal();\n  }\n // VD 06Sep24 calendar changes\n\neditEvent(event: any, entryGroup: any) {\n  this.isModalOpen = true;\n  this.referenceQuestions = Object.values(entryGroup);\n  this.calendarQuestion = [...this.referenceQuestions]; // Make a copy of the current entries to edit\n  this.editingEventId = event.id;\n  this.editingEntryGroup = entryGroup; // Store the entry group being edited\n  this.generateCalendar(); // Regenerate the calendar to reflect changes\n}\n\n\ndeleteEvent( eventId: number, entryGroup: any) {\n  const event = this.allEvents.find(e => e.id === eventId);\n  if (event) {\n      // Find the index of the entryGroup to delete\n      const entryIndex = event.entries.indexOf(entryGroup);\n      if (entryIndex > -1) {\n          event.entries.splice(entryIndex, 1); // Remove the specific entry\n      }\n\n      // If the event has no more entries, remove the event entirely\n      if (event.entries.length === 0) {\n          const eventIndex = this.allEvents.indexOf(event);\n          if (eventIndex > -1) {\n              this.allEvents.splice(eventIndex, 1); // Remove the entire event\n          }\n      }\n  }\n  this.generateCalendar(); // Regenerate the calendar to reflect the changes\n}\n\n\n  closeModal() {\n    this.isModalOpen = false;\n  }\n // VD 06Sep24 calendar changes\n  addEvent(day: CalendarDay, entryQues) {\n    // Transform new entries into the desired format\n    const newEntries = entryQues.reduce((acc, q) => {\n        acc[q.Id] = { ...q };\n        return acc;\n    }, {});\n\n    // Find an existing event for the given date\n    const existingEvent = day.events.find(event => event.date === day.date);\n\n    if (existingEvent) {\n        // Merge new entries into the existing event's entries array\n        // Check if the entries array already contains an object with the same ID\n        const existingEntries = existingEvent.entries.map(entry => ({ ...entry }));\n\n        // Append new entries to the existing entries\n        existingEntries.push(newEntries);\n        existingEvent.entries = existingEntries;\n    } else {\n        // Create a new event if it doesn't exist for the given date\n        const newEvent = {\n            id: this.generateId(),\n            date: day.date,\n            entries: [newEntries] // Wrap the new entries in an array\n        };\n        day.events.push(newEvent);\n        this.allEvents.push(newEvent);\n    }\n\n    this.generateCalendar();\n    console.log('allEvents', this.allEvents);\n}\n // VD 06Sep24 calendar changes\n  onSave() {\n    if (this.editingEventId !== null) {\n        const event = this.allEvents.find(e => e.id === this.editingEventId);\n        if (event && this.editingEntryGroup) {\n            // Update the specific entry group within the event\n            const entryIndex = event.entries.findIndex(entryGroup => entryGroup === this.editingEntryGroup);\n            if (entryIndex > -1) {\n                event.entries[entryIndex] = this.calendarQuestion.reduce((acc, q) => {\n                    acc[q.Id] = { ...q };\n                    return acc;\n                }, {});\n            }\n        }\n    } else {\n        if (this.selectedDay) {\n            this.addEvent(this.selectedDay, this.calendarQuestion);\n        }\n    }\n    this.closeModal();\n    this.generateCalendar();\n}\n\n  onCancel() {\n    console.log('Cancel button clicked');\n    this.closeModal();\n  }\n\n  handleQuestionEvent(ques){\n      // Update the questions array with the new question\n      const index = this.calendarQuestion.findIndex(q => q.Id === ques.Id);\n      if (index > -1) {\n        // If question already exists, update it\n        this.calendarQuestion[index] = ques;\n      } else {\n        // If question doesn't exist, add it to the array\n        this.calendarQuestion.push(ques);\n      }\n      console.log('calender question');\n      console.log(this.calendarQuestion);\n    }\n // VD 06Sep24 calendar changes\n    generateId() {\n      return '_' + Math.random().toString(36).substr(2, 9);\n    }\n\n    getEntryKeys(entryGroup: any): string[] {\n      return Object.keys(entryGroup);\n  }\n\n  removeCharacters(questionText:string){\n    let updatedText = questionText?.replace(/<[^>]*>/g, '');\n    return updatedText;\n }\n\n}\n","<div class=\"align-calendar\">\n    <div class=\"calendar-container\">\n      <div class=\"calendar-header\">\n          <button (click)=\"previousMonth()\"><< Previous >></button>\n          <h3>{{ currentDate | date: 'MMMM yyyy' }}</h3>\n          <button (click)=\"nextMonth()\"><< Next >></button>\n      </div>\n      <div class=\"calendar-grid\">\n          <div class=\"day-of-week\" *ngFor=\"let day of daysOfWeek\">{{ day }}</div>\n\n          <div\n              class=\"calendar-day\"\n              *ngFor=\"let day of calendarDays\"\n              [class.not-current-month]=\"!day.isCurrentMonth\"\n              [class.past]=\"day.isPast\"\n              [class.today]=\"day.isToday\"\n              [class.future]=\"day.isFuture\"\n              [class.selected]=\"day.isSelected\"\n              (click)=\"selectDay(day)\"\n          >\n              <div class=\"day-number\">{{ day.date.getDate() }}\n                <span *ngIf=\"day.events.length > 0\" class=\"entry-indicator\" [class.select]=\"day.isSelected\"></span>\n              </div>\n              <!-- <div *ngFor=\"let event of day.events\" >\n                  <div *ngFor=\"let entryGroup of event.entries\" class=\"event\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\">\n                          <div *ngIf=\"entryGroup[key].Type__c == 'Time'\">\n                              {{ entryGroup[key].input?.value | date: 'shortTime' }}\n                          </div>\n                          <div *ngIf=\"entryGroup[key].Type__c != 'Time'\">\n                              {{ entryGroup[key].input }}\n                          </div>\n                      </div>\n                  </div>\n              </div> -->\n          </div>\n      </div>\n  </div>\n    <div class=\"appoinappointment\">\n      <div class=\"appointments-container\">\n          <h4>Add Appointment</h4>\n          <button *ngIf=\"selectedDay\" (click)=\"addAppointment()\">Add</button>\n      </div>\n      <!--VD 06Sep24 calendar updates--> \n      <div *ngIf=\"showAppoinmentSection && selectedDay?.events.length > 0\" class=\"appointments-container\">\n          <h4>Appointments</h4>\n          <div  *ngFor=\"let event of selectedDay?.events\">\n              <div class=\"event\" *ngFor=\"let entryGroup of event.entries\">\n                    <div class=\"event-info\">\n                      <div *ngFor=\"let key of getEntryKeys(entryGroup)\" class=\"entry-row\">\n                        <div *ngIf=\"entryGroup[key].Question_Text__c\" class=\"entry-text\">\n                            {{removeCharacters(entryGroup[key].Question_Text__c)}}:\n                        </div>\n                        <div class=\"entry-value\">\n                            <span *ngIf=\"entryGroup[key].Type__c != 'Time' && entryGroup[key].Type__c != 'Link'\">{{ entryGroup[key].input }}</span>\n                            <span *ngIf=\"entryGroup[key].Type__c == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n                            <span *ngIf=\"entryGroup[key].Type__c == 'Link'\">\n                                <a href=\"{{entryGroup[key].input}}\">{{removeCharacters(entryGroup[key].Question_Text__c)}}</a>\n                            </span>\n                        </div>\n                    </div>\n                      <div class=\"event-actions\">\n                        <button (click)=\"editEvent(event,entryGroup)\">Edit</button>\n                        <button (click)=\"deleteEvent(event.id,entryGroup)\">Delete</button>\n                     </div>\n                  </div>\n              </div>\n          </div>\n      </div>\n  </div>\n</div>\n\n<app-custom-model\n  [modalTitle]=\"modalTitle\"\n  [isModalOpen]=\"isModalOpen\"\n  [modalSize]=\"modalSize\"\n  [saveButtonValue]=\"saveButtonValue\"\n  [modalFooter]=\"modalFooter\"\n  (saveButtonEmit)=\"onSave()\"\n  (cancelButtonEmit)=\"onCancel()\"\n>\n<!-- VD 06-09-24 used directive file to call the questionbook beacasue to avoid cirecular issue-->\n<!-- <lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook> -->\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model>\n\n\n  \n  \n  "]}
|
|
@@ -25,11 +25,11 @@ export class CustomModelComponent {
|
|
|
25
25
|
this.saveButtonEmit.emit();
|
|
26
26
|
}
|
|
27
27
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomModelComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomModelComponent, selector: "app-custom-model", inputs: { modalTitle: "modalTitle", isModalOpen: "isModalOpen", modalSize: "modalSize", saveButtonValue: "saveButtonValue", modalFooter: "modalFooter" }, outputs: { saveButtonEmit: "saveButtonEmit", cancelButtonEmit: "cancelButtonEmit" }, ngImport: i0, template: "<div *ngIf=\"isModalOpen\" class=\"modal\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <span class=\"close\" (click)=\"onCancel()\">×</span>\n <h2>{{ modalTitle }}</h2>\n </div>\n <div class=\"modal-body\">\n <ng-content></ng-content>\n </div>\n <div class=\"modal-footer\" *ngIf=\"modalFooter\">\n <button (click)=\"
|
|
28
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomModelComponent, selector: "app-custom-model", inputs: { modalTitle: "modalTitle", isModalOpen: "isModalOpen", modalSize: "modalSize", saveButtonValue: "saveButtonValue", modalFooter: "modalFooter" }, outputs: { saveButtonEmit: "saveButtonEmit", cancelButtonEmit: "cancelButtonEmit" }, ngImport: i0, template: "<div *ngIf=\"isModalOpen\" class=\"modal\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <span class=\"close\" (click)=\"onCancel()\">×</span>\n <h2>{{ modalTitle }}</h2>\n </div>\n <div class=\"modal-body\">\n <ng-content></ng-content>\n </div>\n <!-- /* VD 06Sep24 styling changes */-->\n <div class=\"modal-footer\" *ngIf=\"modalFooter\">\n <button (click)=\"onCancel()\">Cancel</button>\n <button (click)=\"onSave()\">{{ saveButtonValue }}</button>\n </div>\n </div>\n</div>\n ", styles: [".modal{display:block;position:fixed;z-index:1;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0006}.modal-content{background-color:#fefefe;margin:5% auto;padding:20px;border:1px solid #888;width:70%;max-width:90%;max-height:80vh;overflow-y:auto}.modal-header,.modal-footer{padding:10px;text-align:center;display:block}.modal-body{max-height:60vh;overflow-y:auto}.close{color:#aaa;float:right;font-size:28px;font-weight:700}.close:hover,.close:focus{color:#000;text-decoration:none;cursor:pointer}.modal-footer button{padding:10px 20px;margin:5px;font-size:16px;border:1px solid #ccc;border-radius:4px;cursor:pointer;background-color:#f5f5f5;color:#333}.modal-footer button:hover{background-color:#e0e0e0;border-color:#bbb}@media (max-width: 768px){.modal-content{width:90%;margin:10% auto}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
29
29
|
}
|
|
30
30
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomModelComponent, decorators: [{
|
|
31
31
|
type: Component,
|
|
32
|
-
args: [{ selector: 'app-custom-model', template: "<div *ngIf=\"isModalOpen\" class=\"modal\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <span class=\"close\" (click)=\"onCancel()\">×</span>\n <h2>{{ modalTitle }}</h2>\n </div>\n <div class=\"modal-body\">\n <ng-content></ng-content>\n </div>\n <div class=\"modal-footer\" *ngIf=\"modalFooter\">\n <button (click)=\"
|
|
32
|
+
args: [{ selector: 'app-custom-model', template: "<div *ngIf=\"isModalOpen\" class=\"modal\" [ngClass]=\"modalSize\">\n <div class=\"modal-content\">\n <div class=\"modal-header\">\n <span class=\"close\" (click)=\"onCancel()\">×</span>\n <h2>{{ modalTitle }}</h2>\n </div>\n <div class=\"modal-body\">\n <ng-content></ng-content>\n </div>\n <!-- /* VD 06Sep24 styling changes */-->\n <div class=\"modal-footer\" *ngIf=\"modalFooter\">\n <button (click)=\"onCancel()\">Cancel</button>\n <button (click)=\"onSave()\">{{ saveButtonValue }}</button>\n </div>\n </div>\n</div>\n ", styles: [".modal{display:block;position:fixed;z-index:1;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0006}.modal-content{background-color:#fefefe;margin:5% auto;padding:20px;border:1px solid #888;width:70%;max-width:90%;max-height:80vh;overflow-y:auto}.modal-header,.modal-footer{padding:10px;text-align:center;display:block}.modal-body{max-height:60vh;overflow-y:auto}.close{color:#aaa;float:right;font-size:28px;font-weight:700}.close:hover,.close:focus{color:#000;text-decoration:none;cursor:pointer}.modal-footer button{padding:10px 20px;margin:5px;font-size:16px;border:1px solid #ccc;border-radius:4px;cursor:pointer;background-color:#f5f5f5;color:#333}.modal-footer button:hover{background-color:#e0e0e0;border-color:#bbb}@media (max-width: 768px){.modal-content{width:90%;margin:10% auto}}\n"] }]
|
|
33
33
|
}], ctorParameters: function () { return []; }, propDecorators: { modalTitle: [{
|
|
34
34
|
type: Input
|
|
35
35
|
}], isModalOpen: [{
|
|
@@ -45,4 +45,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
45
45
|
}], cancelButtonEmit: [{
|
|
46
46
|
type: Output
|
|
47
47
|
}] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLW1vZGVsLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL254dC1hcHAvc3JjL2xpYi9jb21wb25lbnRzL2N1c3RvbS1tb2RlbC9jdXN0b20tbW9kZWwuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLW1vZGVsL2N1c3RvbS1tb2RlbC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFjLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFhLE1BQU0sZUFBZSxDQUFDOzs7QUFPdEcsTUFBTSxPQUFPLG9CQUFvQjtJQUUvQixnQkFBZ0IsQ0FBQztJQUNSLFVBQVUsQ0FBTTtJQUNoQixXQUFXLEdBQUcsS0FBSyxDQUFDO0lBQ3BCLFNBQVMsR0FBRyxFQUFFLENBQUM7SUFDZixlQUFlLEdBQUcsTUFBTSxDQUFDO0lBQ3pCLFdBQVcsR0FBRyxJQUFJLENBQUM7SUFDbEIsY0FBYyxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7SUFDekMsZ0JBQWdCLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUVyRCxNQUFNO1FBQ0osSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUM3QixDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUMvQixDQUFDO0lBR0QsUUFBUTtJQUNSLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsU0FBUztRQUNQLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDN0IsQ0FBQzt3R0E3QlUsb0JBQW9COzRGQUFwQixvQkFBb0IsdVNDUGpDLGttQkFnQkU7OzRGRFRXLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxrQkFBa0I7MEVBT25CLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSztnQkFDSSxjQUFjO3NCQUF2QixNQUFNO2dCQUNHLGdCQUFnQjtzQkFBekIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFZpZXdDaGlsZCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtY3VzdG9tLW1vZGVsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2N1c3RvbS1tb2RlbC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2N1c3RvbS1tb2RlbC5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3VzdG9tTW9kZWxDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG4gIEBJbnB1dCgpIG1vZGFsVGl0bGU6IGFueTtcbiAgQElucHV0KCkgaXNNb2RhbE9wZW4gPSBmYWxzZTtcbiAgQElucHV0KCkgbW9kYWxTaXplID0gJyc7XG4gIEBJbnB1dCgpIHNhdmVCdXR0b25WYWx1ZSA9ICdTYXZlJztcbiAgQElucHV0KCkgbW9kYWxGb290ZXIgPSB0cnVlO1xuICBAT3V0cHV0KCkgc2F2ZUJ1dHRvbkVtaXQgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcbiAgQE91dHB1dCgpIGNhbmNlbEJ1dHRvbkVtaXQgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcblxuICBvblNhdmUoKSB7XG4gICAgdGhpcy5zYXZlQnV0dG9uRW1pdC5lbWl0KCk7XG4gIH1cblxuICBvbkNhbmNlbCgpIHtcbiAgICB0aGlzLmNhbmNlbEJ1dHRvbkVtaXQuZW1pdCgpO1xuICB9XG5cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgfVxuXG4gIGNsb3NlTW9kYWwoKSB7XG4gICAgdGhpcy5jYW5jZWxCdXR0b25FbWl0LmVtaXQoZmFsc2UpO1xuICB9XG5cbiAgc2F2ZU1vZGFsKCkge1xuICAgIHRoaXMuc2F2ZUJ1dHRvbkVtaXQuZW1pdCgpO1xuICB9XG5cbn1cbiIsIjxkaXYgKm5nSWY9XCJpc01vZGFsT3BlblwiIGNsYXNzPVwibW9kYWxcIiBbbmdDbGFzc109XCJtb2RhbFNpemVcIj5cbiAgICA8ZGl2IGNsYXNzPVwibW9kYWwtY29udGVudFwiPlxuICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWhlYWRlclwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImNsb3NlXCIgKGNsaWNrKT1cIm9uQ2FuY2VsKClcIj4mdGltZXM7PC9zcGFuPlxuICAgICAgICA8aDI+e3sgbW9kYWxUaXRsZSB9fTwvaDI+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxkaXYgY2xhc3M9XCJtb2RhbC1ib2R5XCI+XG4gICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgIDwvZGl2PlxuICAgICAgPCEtLSAvKiBWRCAwNlNlcDI0IHN0eWxpbmcgY2hhbmdlcyAqLy0tPlxuICAgICAgPGRpdiBjbGFzcz1cIm1vZGFsLWZvb3RlclwiICpuZ0lmPVwibW9kYWxGb290ZXJcIj5cbiAgICAgICAgPGJ1dHRvbiAoY2xpY2spPVwib25DYW5jZWwoKVwiPkNhbmNlbDwvYnV0dG9uPlxuICAgICAgICA8YnV0dG9uIChjbGljayk9XCJvblNhdmUoKVwiPnt7IHNhdmVCdXR0b25WYWx1ZSB9fTwvYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG48L2Rpdj5cbiAgIl19
|
|
@@ -37,8 +37,9 @@ export class CustomTimeComponent {
|
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
|
+
// VD 06Sep24 emit exact time object
|
|
40
41
|
onTimeChange(event) {
|
|
41
|
-
this.timeChange.emit(event);
|
|
42
|
+
this.timeChange.emit(event?.value);
|
|
42
43
|
}
|
|
43
44
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: CustomTimeComponent, deps: [{ token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
44
45
|
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: CustomTimeComponent, selector: "app-custom-time", inputs: { time: "time", readOnly: "readOnly", error: "error", errorMessage: "errorMessage" }, outputs: { timeChange: "timeChange" }, usesOnChanges: true, ngImport: i0, template: "<!-- time component -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n <p>\n <input\n [class]=\"error ? 'invalid' : ''\"\n [(ngModel)]=\"timeSelected\"\n [owlDateTimeTrigger]=\"dt2\"\n [owlDateTime]=\"dt2\"\n placeholder=\"HH:MM\"\n [readOnly]=\"readOnly\" \n style=\"width: 100%; height: 35px; border: none; box-shadow: none; border-bottom: 1px solid #ccc;\"\n (dateTimeChange)=\"onTimeChange($event)\"\n >\n <owl-date-time [pickerType]=\"'timer'\" #dt2></owl-date-time>\n </p>\n <span *ngIf=\"error\" class=\"error-msg\">{{errorMessage}}</span>", styles: [".invalid{border-color:red!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.OwlDateTimeTriggerDirective, selector: "[owlDateTimeTrigger]", inputs: ["disabled", "owlDateTimeTrigger"] }, { kind: "directive", type: i4.OwlDateTimeInputDirective, selector: "input[owlDateTime]", inputs: ["rangeSeparator", "owlDateTime", "owlDateTimeFilter", "min", "max", "selectMode", "value", "values", "_disabled"], outputs: ["dateTimeChange", "dateTimeInput"], exportAs: ["owlDateTimeInput"] }, { kind: "component", type: i4.OwlDateTimeComponent, selector: "owl-date-time", inputs: ["startAt", "pickerType", "pickerMode", "disabled", "opened", "backdropClass", "panelClass", "scrollStrategy"], outputs: ["afterPickerClosed", "afterPickerOpen", "yearSelected", "monthSelected"], exportAs: ["owlDateTime"] }] });
|
|
@@ -57,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
57
58
|
}], timeChange: [{
|
|
58
59
|
type: Output
|
|
59
60
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VzdG9tLXRpbWUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLXRpbWUvY3VzdG9tLXRpbWUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbnh0LWFwcC9zcmMvbGliL2NvbXBvbmVudHMvY3VzdG9tLXRpbWUvY3VzdG9tLXRpbWUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBaUIsTUFBTSxlQUFlLENBQUM7Ozs7OztBQVE5RixNQUFNLE9BQU8sbUJBQW1CO0lBUVg7SUFQVixJQUFJLENBQVM7SUFDYixRQUFRLEdBQUcsS0FBSyxDQUFDLENBQUMsK0JBQStCO0lBQ2pELEtBQUssQ0FBSztJQUNWLFlBQVksQ0FBUztJQUNwQixVQUFVLEdBQXNCLElBQUksWUFBWSxFQUFPLENBQUM7SUFDbEUsWUFBWSxDQUFNO0lBRWxCLFlBQW1CLFdBQXdCO1FBQXhCLGdCQUFXLEdBQVgsV0FBVyxDQUFhO0lBQUksQ0FBQztJQUVoRCxRQUFRO1FBQ04sSUFBRyxJQUFJLENBQUMsSUFBSSxFQUFDO1lBQ1gsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO1lBQ2hFLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3pDO2FBQUs7WUFDSiw0QkFBNEI7WUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUM7U0FDMUI7SUFDSCxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXFCO1FBQy9CLG9CQUFvQjtRQUNwQixJQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsRUFBQztZQUNqQixJQUFHLElBQUksQ0FBQyxJQUFJLEVBQUM7Z0JBQ1gsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2dCQUNoRSxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUN6QztpQkFBSztnQkFDSixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQzthQUMxQjtTQUNGO0lBQ0gsQ0FBQztJQUNELG9DQUFvQztJQUNwQyxZQUFZLENBQUMsS0FBVTtRQUNyQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQzt3R0FsQ1UsbUJBQW1COzRGQUFuQixtQkFBbUIsaU5DUmhDLDRuQkFnQitEOzs0RkRSbEQsbUJBQW1CO2tCQUwvQixTQUFTOytCQUNFLGlCQUFpQjtrR0FLbEIsSUFBSTtzQkFBWixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0ksVUFBVTtzQkFBbkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFNpbXBsZUNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEkxOG5TZXJ2aWNlIH0gZnJvbSAnLi4vLi4vaTE4bi5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWN1c3RvbS10aW1lJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2N1c3RvbS10aW1lLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY3VzdG9tLXRpbWUuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEN1c3RvbVRpbWVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKSB0aW1lOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHJlYWRPbmx5ID0gZmFsc2U7IC8vIFZEIDEySnVuMjQgLSByZWFkb25seSBjaGFuZ2VcbiAgQElucHV0KCkgZXJyb3I6YW55O1xuICBASW5wdXQoKSBlcnJvck1lc3NhZ2U6IHN0cmluZztcbiAgQE91dHB1dCgpIHRpbWVDaGFuZ2U6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XG4gIHRpbWVTZWxlY3RlZDogYW55O1xuXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyBpMThuU2VydmljZTogSTE4blNlcnZpY2UpIHsgfVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmKHRoaXMudGltZSl7XG4gICAgICB0aGlzLnRpbWUgPSB0aGlzLnRpbWVbJ3ZhbHVlJ10gPyB0aGlzLnRpbWVbJ3ZhbHVlJ10gOiB0aGlzLnRpbWU7XG4gICAgICB0aGlzLnRpbWVTZWxlY3RlZCA9IG5ldyBEYXRlKHRoaXMudGltZSk7XG4gICAgfWVsc2Uge1xuICAgICAgLy8gaWYgbm8gdGltZSBzZXQgbnVsbCB2YWx1ZVxuICAgICAgdGhpcy50aW1lU2VsZWN0ZWQgPSBudWxsO1xuICAgIH1cbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6U2ltcGxlQ2hhbmdlcyl7XG4gICAgLy8gdXBkYXRlIG9uIGNoYW5nZXNcbiAgICBpZihjaGFuZ2VzWyd0aW1lJ10pe1xuICAgICAgaWYodGhpcy50aW1lKXtcbiAgICAgICAgdGhpcy50aW1lID0gdGhpcy50aW1lWyd2YWx1ZSddID8gdGhpcy50aW1lWyd2YWx1ZSddIDogdGhpcy50aW1lO1xuICAgICAgICB0aGlzLnRpbWVTZWxlY3RlZCA9IG5ldyBEYXRlKHRoaXMudGltZSk7XG4gICAgICB9ZWxzZSB7XG4gICAgICAgIHRoaXMudGltZVNlbGVjdGVkID0gbnVsbDtcbiAgICAgIH1cbiAgICB9XG4gIH1cbiAgLy8gVkQgMDZTZXAyNCBlbWl0IGV4YWN0IHRpbWUgb2JqZWN0XG4gIG9uVGltZUNoYW5nZShldmVudDogYW55KSB7XG4gICAgdGhpcy50aW1lQ2hhbmdlLmVtaXQoZXZlbnQ/LnZhbHVlKTtcbiAgfVxufVxuIiwiPCEtLSB0aW1lIGNvbXBvbmVudCAtLT5cbjwhLS0gLy8gVkQgMTJKdW4yNCAtIHJlYWRvbmx5IGNoYW5nZS0tPlxuPCEtLSBWRCAwMUF1ZzI0IC0gdmFsaWRhdGlvbiBjaGFuZ2UtLT5cbiAgPHA+XG4gICAgPGlucHV0XG4gICAgICBbY2xhc3NdPVwiZXJyb3IgPyAnaW52YWxpZCcgOiAnJ1wiXG4gICAgICBbKG5nTW9kZWwpXT1cInRpbWVTZWxlY3RlZFwiXG4gICAgICBbb3dsRGF0ZVRpbWVUcmlnZ2VyXT1cImR0MlwiXG4gICAgICBbb3dsRGF0ZVRpbWVdPVwiZHQyXCJcbiAgICAgIHBsYWNlaG9sZGVyPVwiSEg6TU1cIlxuICAgICAgW3JlYWRPbmx5XT1cInJlYWRPbmx5XCIgXG4gICAgICBzdHlsZT1cIndpZHRoOiAxMDAlOyBoZWlnaHQ6IDM1cHg7IGJvcmRlcjogbm9uZTsgYm94LXNoYWRvdzogbm9uZTsgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNjY2M7XCJcbiAgICAgIChkYXRlVGltZUNoYW5nZSk9XCJvblRpbWVDaGFuZ2UoJGV2ZW50KVwiXG4gICAgPlxuICAgIDxvd2wtZGF0ZS10aW1lIFtwaWNrZXJUeXBlXT1cIid0aW1lcidcIiAjZHQyPjwvb3dsLWRhdGUtdGltZT5cbiAgPC9wPlxuICA8c3BhbiAqbmdJZj1cImVycm9yXCIgY2xhc3M9XCJlcnJvci1tc2dcIj57e2Vycm9yTWVzc2FnZX19PC9zcGFuPiJdfQ==
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
// VD 06-09-24 directive file to call component dynamically
|
|
2
|
+
import { Directive } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ComponenthostDirective {
|
|
5
|
+
viewContainerRef;
|
|
6
|
+
constructor(viewContainerRef) {
|
|
7
|
+
this.viewContainerRef = viewContainerRef;
|
|
8
|
+
}
|
|
9
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ComponenthostDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
10
|
+
static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.12", type: ComponenthostDirective, isStandalone: true, selector: "[dynamicComponentHost]", ngImport: i0 });
|
|
11
|
+
}
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: ComponenthostDirective, decorators: [{
|
|
13
|
+
type: Directive,
|
|
14
|
+
args: [{
|
|
15
|
+
selector: '[dynamicComponentHost]',
|
|
16
|
+
standalone: true
|
|
17
|
+
}]
|
|
18
|
+
}], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50aG9zdC5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ueHQtYXBwL3NyYy9saWIvZGlyZWN0aXZlcy9jb21wb25lbnRob3N0L2NvbXBvbmVudGhvc3QuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLDREQUE0RDtBQUM1RCxPQUFPLEVBQUUsU0FBUyxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFNNUQsTUFBTSxPQUFPLHNCQUFzQjtJQUNkO0lBQW5CLFlBQW1CLGdCQUFrQztRQUFsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO0lBQUcsQ0FBQzt3R0FEOUMsc0JBQXNCOzRGQUF0QixzQkFBc0I7OzRGQUF0QixzQkFBc0I7a0JBSmxDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLHdCQUF3QjtvQkFDbEMsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gVkQgMDYtMDktMjQgZGlyZWN0aXZlIGZpbGUgdG8gY2FsbCBjb21wb25lbnQgZHluYW1pY2FsbHkgXG5pbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW2R5bmFtaWNDb21wb25lbnRIb3N0XScsXG4gIHN0YW5kYWxvbmU6IHRydWVcbn0pXG5leHBvcnQgY2xhc3MgQ29tcG9uZW50aG9zdERpcmVjdGl2ZSB7XG4gIGNvbnN0cnVjdG9yKHB1YmxpYyB2aWV3Q29udGFpbmVyUmVmOiBWaWV3Q29udGFpbmVyUmVmKSB7fVxufVxuIl19
|