@rangertechnologies/ngnxt 2.1.243-beta → 2.1.244

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.
Files changed (103) hide show
  1. package/esm2022/environments/version.mjs +15 -0
  2. package/esm2022/lib/ar.i18n.mjs +29 -0
  3. package/esm2022/lib/components/button/nxt-button.component.mjs +165 -0
  4. package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +361 -0
  5. package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +271 -0
  6. package/esm2022/lib/components/custom-model/custom-model.component.mjs +51 -0
  7. package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +156 -0
  8. package/esm2022/lib/components/datatable/datatable.component.mjs +1742 -0
  9. package/esm2022/lib/components/file-upload/file-upload.component.mjs +283 -0
  10. package/esm2022/lib/components/icon-selector/icon-selector.component.mjs +104 -0
  11. package/esm2022/lib/components/image-cropper/component/cropper.state.mjs +208 -0
  12. package/esm2022/lib/components/image-cropper/component/image-cropper.component.mjs +562 -0
  13. package/esm2022/lib/components/image-cropper/interfaces/basic-event.interface.mjs +2 -0
  14. package/esm2022/lib/components/image-cropper/interfaces/cropper-options.interface.mjs +2 -0
  15. package/esm2022/lib/components/image-cropper/interfaces/cropper-position.interface.mjs +2 -0
  16. package/esm2022/lib/components/image-cropper/interfaces/dimensions.interface.mjs +2 -0
  17. package/esm2022/lib/components/image-cropper/interfaces/exif-transform.interface.mjs +2 -0
  18. package/esm2022/lib/components/image-cropper/interfaces/image-cropped-event.interface.mjs +2 -0
  19. package/esm2022/lib/components/image-cropper/interfaces/image-transform.interface.mjs +2 -0
  20. package/esm2022/lib/components/image-cropper/interfaces/index.mjs +2 -0
  21. package/esm2022/lib/components/image-cropper/interfaces/loaded-image.interface.mjs +2 -0
  22. package/esm2022/lib/components/image-cropper/interfaces/move-start.interface.mjs +8 -0
  23. package/esm2022/lib/components/image-cropper/services/crop.service.mjs +139 -0
  24. package/esm2022/lib/components/image-cropper/services/load-image.service.mjs +194 -0
  25. package/esm2022/lib/components/image-cropper/utils/cropper-position.utils.mjs +239 -0
  26. package/esm2022/lib/components/image-cropper/utils/exif.utils.mjs +79 -0
  27. package/esm2022/lib/components/image-cropper/utils/keyboard.utils.mjs +40 -0
  28. package/esm2022/lib/components/image-cropper/utils/percentage.utils.mjs +4 -0
  29. package/esm2022/lib/components/image-cropper/utils/resize.utils.mjs +75 -0
  30. package/esm2022/lib/components/list-view-filter/list-view-filter.component.mjs +401 -0
  31. package/esm2022/lib/components/nxt-input/nxt-input.component.mjs +2936 -0
  32. package/esm2022/lib/components/pagination/pagination.component.mjs +101 -0
  33. package/esm2022/lib/components/pick-location/pick-location.component.mjs +227 -0
  34. package/esm2022/lib/components/search-box/search-box.component.mjs +417 -0
  35. package/esm2022/lib/country.json +43237 -0
  36. package/esm2022/lib/en.i18n.mjs +29 -0
  37. package/esm2022/lib/i18n-config.service.mjs +4 -0
  38. package/esm2022/lib/i18n.component.mjs +45 -0
  39. package/esm2022/lib/i18n.module.mjs +38 -0
  40. package/esm2022/lib/i18n.pipe.mjs +26 -0
  41. package/esm2022/lib/i18n.service.mjs +56 -0
  42. package/esm2022/lib/interfaces/actionMeta.mjs +2 -0
  43. package/esm2022/lib/interfaces/apimeta.mjs +2 -0
  44. package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -0
  45. package/esm2022/lib/model/bookletWrapper.mjs +9 -0
  46. package/esm2022/lib/model/changeWrapper.mjs +11 -0
  47. package/esm2022/lib/model/errorWrapper.mjs +6 -0
  48. package/esm2022/lib/nxt-app.component.mjs +22 -0
  49. package/esm2022/lib/nxt-app.module.mjs +139 -0
  50. package/esm2022/lib/nxt-app.service.mjs +14 -0
  51. package/esm2022/lib/pages/booklet/booklet.component.mjs +673 -0
  52. package/esm2022/lib/pages/builder/element/element.component.mjs +476 -0
  53. package/esm2022/lib/pages/builder/form/form.component.mjs +45 -0
  54. package/esm2022/lib/pages/builder/properties/common-fields.constants.mjs +89 -0
  55. package/esm2022/lib/pages/builder/properties/properties.component.mjs +944 -0
  56. package/esm2022/lib/pages/builder/templates/templates.component.mjs +34 -0
  57. package/esm2022/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.mjs +680 -0
  58. package/esm2022/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.mjs +1118 -0
  59. package/esm2022/lib/pages/questionbook/questionbook.component.mjs +838 -0
  60. package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2237 -0
  61. package/esm2022/lib/pipe/custom-translate.pipe.mjs +27 -0
  62. package/esm2022/lib/pipe/get-value.pipe.mjs +48 -0
  63. package/esm2022/lib/pipe/search-filter/search-filter.pipe.mjs +39 -0
  64. package/esm2022/lib/sample.mjs +3715 -0
  65. package/esm2022/lib/services/change.service.mjs +46 -0
  66. package/esm2022/lib/services/country.service.mjs +135 -0
  67. package/esm2022/lib/services/data.service.mjs +100 -0
  68. package/esm2022/lib/services/form-builder.service.mjs +385 -0
  69. package/esm2022/lib/services/pdf-designer.service.mjs +398 -0
  70. package/esm2022/lib/services/salesforce.service.mjs +41 -0
  71. package/esm2022/lib/services/shared.service.mjs +100 -0
  72. package/esm2022/lib/services/storage.service.mjs +43 -0
  73. package/esm2022/lib/services/template.service.mjs +351 -0
  74. package/esm2022/lib/services/translation.service.mjs +61 -0
  75. package/esm2022/lib/tam.i18n.mjs +29 -0
  76. package/esm2022/lib/wrapper.mjs +175 -0
  77. package/esm2022/public-api.mjs +25 -0
  78. package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
  79. package/fesm2022/rangertechnologies-ngnxt.mjs +7614 -7827
  80. package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
  81. package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +2 -1
  82. package/lib/components/datatable/datatable.component.d.ts +34 -28
  83. package/lib/components/file-upload/file-upload.component.d.ts +4 -3
  84. package/lib/components/image-cropper/component/image-cropper.component.d.ts +1 -1
  85. package/lib/components/list-view-filter/list-view-filter.component.d.ts +3 -3
  86. package/lib/components/nxt-input/nxt-input.component.d.ts +5 -1
  87. package/lib/components/pick-location/pick-location.component.d.ts +3 -1
  88. package/lib/components/search-box/search-box.component.d.ts +2 -1
  89. package/lib/pages/builder/element/element.component.d.ts +2 -15
  90. package/lib/pages/builder/properties/common-fields.constants.d.ts +4 -16
  91. package/lib/pages/builder/properties/properties.component.d.ts +95 -129
  92. package/lib/pipe/custom-translate.pipe.d.ts +3 -3
  93. package/lib/pipe/get-value.pipe.d.ts +4 -4
  94. package/lib/pipe/search-filter/search-filter.pipe.d.ts +3 -3
  95. package/lib/services/form-builder.service.d.ts +0 -1
  96. package/package.json +6 -4
  97. package/rangertechnologies-ngnxt-2.1.244.tgz +0 -0
  98. package/lib/pipe/date/date.pipe.d.ts +0 -7
  99. package/lib/pipe/editColumnCheck/edit-column-check.pipe.d.ts +0 -7
  100. package/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.d.ts +0 -7
  101. package/lib/pipe/editColumnType/edit-column-type.pipe.d.ts +0 -7
  102. package/lib/pipe/time/time.pipe.d.ts +0 -7
  103. package/rangertechnologies-ngnxt-2.1.243-beta.tgz +0 -0
@@ -0,0 +1,361 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../services/change.service";
5
+ import * as i2 from "@angular/common";
6
+ export class CustomCalendarComponent {
7
+ changeService;
8
+ eventSelected = new EventEmitter();
9
+ // VD 06Sep24 calendar changes
10
+ dateSelected = new EventEmitter();
11
+ openModal = new EventEmitter();
12
+ closeModal = new EventEmitter();
13
+ allEvents = [];
14
+ question;
15
+ nxtId;
16
+ //@ViewChild(ComponenthostDirective, { static: true }) dynamicHost: ComponenthostDirective;
17
+ entries = [];
18
+ referenceQuestions = [];
19
+ qbRefrenceBook;
20
+ calendarQuestion = [];
21
+ calendar = {};
22
+ currentDate = new Date();
23
+ calendarDays = [];
24
+ daysOfWeek = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];
25
+ newEventTitle = '';
26
+ newEventTime = '';
27
+ newDescription = '';
28
+ newLink = '';
29
+ selectedDay = null;
30
+ isModalOpen = false;
31
+ modalTitle = 'Custom Modal';
32
+ modalSize = 'large';
33
+ saveButtonValue = 'Save';
34
+ modalFooter = true;
35
+ editingEventId;
36
+ editingEntryGroup;
37
+ showAppoinmentSection = true;
38
+ subscription;
39
+ constructor(changeService) {
40
+ this.changeService = changeService;
41
+ }
42
+ ngOnInit() {
43
+ if (this.question?.input) {
44
+ this.allEvents = this.question.input;
45
+ }
46
+ this.processQuestion();
47
+ this.generateCalendar();
48
+ this.subscription = this.changeService.customChange$.subscribe((changeValue) => {
49
+ if (changeValue == 'calendar-modal-save') {
50
+ this.onSave();
51
+ }
52
+ if (changeValue == 'dataBind') {
53
+ if (this.question?.input) {
54
+ this.allEvents = this.question.input;
55
+ }
56
+ this.processQuestion();
57
+ this.generateCalendar();
58
+ }
59
+ });
60
+ // this.dateSelected.emit(this.calendar);
61
+ //this.eventSelected.emit(this.allEvents);
62
+ }
63
+ // RS 09DEC24 Changed keys
64
+ processQuestion() {
65
+ // SKS20MAR25 check if question fieldsmeta is string
66
+ this.entries = typeof this.question['fieldsMeta'] === 'object' ? this.question['fieldsMeta'] || [] : JSON.parse(this.question['fieldsMeta']);
67
+ this.qbRefrenceBook = typeof this.question['qbReferenceQuestions'] === 'object' ? this.question['qbReferenceQuestions'] : JSON.parse(this.question['qbReferenceQuestions']);
68
+ let title = this.qbRefrenceBook?.questionbook?.title;
69
+ this.modalTitle = title;
70
+ this.referenceQuestions = [];
71
+ if (this.entries.length > 0) {
72
+ this.entries.forEach(element => {
73
+ if (element.questionReference) {
74
+ let qReference = JSON.parse(element.questionReference);
75
+ this.referenceQuestions.push(qReference?.question);
76
+ }
77
+ });
78
+ }
79
+ }
80
+ // sunday comment
81
+ // openQuestionBookModal() {
82
+ // const viewContainerRef = this.dynamicHost.viewContainerRef;
83
+ // viewContainerRef.clear();
84
+ // const componentRef = viewContainerRef.createComponent(QuestionbookComponent);
85
+ // componentRef.instance.qbItem = this.qbRefrenceBook;
86
+ // componentRef.instance.questions = this.referenceQuestions;
87
+ // componentRef.instance.handleQuestion.subscribe((event: any) => this.handleQuestionEvent(event));
88
+ // }
89
+ generateCalendar() {
90
+ const year = this.currentDate.getFullYear();
91
+ const month = this.currentDate.getMonth();
92
+ const startOfMonth = new Date(year, month, 1);
93
+ const endOfMonth = new Date(year, month + 1, 0);
94
+ const startDayOfWeek = startOfMonth.getDay();
95
+ const endDayOfWeek = endOfMonth.getDay();
96
+ const startDate = new Date(startOfMonth);
97
+ startDate.setDate(startDate.getDate() - startDayOfWeek);
98
+ const endDate = new Date(endOfMonth);
99
+ endDate.setDate(endDate.getDate() + (6 - endDayOfWeek));
100
+ const today = new Date(new Date().setHours(0, 0, 0, 0));
101
+ this.calendarDays = [];
102
+ for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) {
103
+ const date = new Date(d);
104
+ this.calendarDays.push({
105
+ date: date,
106
+ events: [],
107
+ isCurrentMonth: d.getMonth() === month,
108
+ isPast: date < today,
109
+ isToday: date.getTime() === today.getTime(),
110
+ isFuture: date > today,
111
+ });
112
+ }
113
+ // Populate calendar with events from allEvents array
114
+ this.calendarDays.forEach(day => {
115
+ day.events = this.allEvents?.filter(event => event?.date?.toDateString() === day.date.toDateString());
116
+ });
117
+ // VD 06Sep24 calendar changes
118
+ let cal = {};
119
+ cal['year'] = year;
120
+ cal['month'] = month + 1;
121
+ this.calendar = cal;
122
+ }
123
+ selectDay(day) {
124
+ // VD 06Sep24 calendar changes
125
+ this.showAppoinmentSection = true;
126
+ this.selectedDay = day;
127
+ // this.eventSelected.emit(day?.events);
128
+ const previouslySelectedDay = this.calendarDays.find(d => d.isSelected);
129
+ if (previouslySelectedDay) {
130
+ previouslySelectedDay.isSelected = false;
131
+ }
132
+ // Select the clicked day
133
+ day.isSelected = true;
134
+ // VD 09Sep24- setup the query param data for api call
135
+ let referenceData = [];
136
+ this.referenceQuestions.forEach(ques => {
137
+ // VD 09-09-24 get the selected date
138
+ // need to add in the document
139
+ // RS 09DEC24 Changed keys
140
+ if (ques.referenceField == 'selectedDate') {
141
+ ques.input = day.date.toISOString();
142
+ }
143
+ // VD 09-09-24 get the query refrence field data to pass the queryParam for api
144
+ ques['subText'] = typeof ques?.subText === 'object' ? ques?.subText : JSON.parse(ques['subText'] || {});
145
+ if (ques.subText) {
146
+ let subText = ques.subText;
147
+ if (subText.queryField && subText.queryValueReference) {
148
+ let currentQues = ques;
149
+ let queryReferences = subText.queryValueReference.split(',');
150
+ queryReferences.forEach(refField => {
151
+ let refQues = this.referenceQuestions.find(q => q.referenceField === refField);
152
+ if (refQues) {
153
+ referenceData.push(refQues);
154
+ }
155
+ });
156
+ // Add the referenceData array to the current question
157
+ currentQues.referenceQueryData = referenceData;
158
+ }
159
+ }
160
+ });
161
+ }
162
+ previousMonth() {
163
+ this.showAppoinmentSection = false;
164
+ this.currentDate.setMonth(this.currentDate.getMonth() - 1);
165
+ this.currentDate = new Date(this.currentDate); // Ensure the date object is updated
166
+ this.generateCalendar();
167
+ this.dateSelected.emit(this.calendar);
168
+ this.eventSelected.emit(this.allEvents);
169
+ }
170
+ nextMonth() {
171
+ // VD 06Sep24 calendar changes
172
+ this.showAppoinmentSection = false;
173
+ this.currentDate.setMonth(this.currentDate.getMonth() + 1);
174
+ this.currentDate = new Date(this.currentDate); // Ensure the date object is updated
175
+ this.generateCalendar();
176
+ this.dateSelected.emit(this.calendar);
177
+ this.eventSelected.emit(this.allEvents);
178
+ }
179
+ addAppointment() {
180
+ this.isModalOpen = true;
181
+ this.calendarQuestion = this.referenceQuestions.map(q => ({ ...q, input: '' }));
182
+ this.referenceQuestions.forEach(ques => {
183
+ // clear the input
184
+ if (ques.referenceField != 'selectedDate') {
185
+ if (ques.type == 'Dropdown') {
186
+ delete ques.input;
187
+ delete ques.selectedValue;
188
+ // VD 06Sep24 calendar changes
189
+ }
190
+ else {
191
+ delete ques.input;
192
+ }
193
+ }
194
+ });
195
+ this.editingEventId = null;
196
+ this.calendarQuestion = this.referenceQuestions;
197
+ this.openBookModel();
198
+ // sunday comment
199
+ //this.openQuestionBookModal();
200
+ }
201
+ openBookModel() {
202
+ this.openModal.emit({
203
+ qbRefrenceBook: this.qbRefrenceBook,
204
+ referenceQuestions: this.referenceQuestions,
205
+ modalTitle: this.modalTitle,
206
+ modalSize: this.modalSize,
207
+ saveButtonValue: this.saveButtonValue,
208
+ modalFooter: this.modalFooter,
209
+ });
210
+ }
211
+ closeCalendarModal() {
212
+ this.isModalOpen = false;
213
+ this.closeModal.emit(true);
214
+ }
215
+ // VD 06Sep24 calendar changes
216
+ editEvent(event, entryGroup) {
217
+ this.isModalOpen = true;
218
+ this.referenceQuestions = Object.values(entryGroup);
219
+ this.calendarQuestion = [...this.referenceQuestions]; // Make a copy of the current entries to edit
220
+ this.editingEventId = event.id;
221
+ this.editingEntryGroup = entryGroup; // Store the entry group being edited
222
+ this.generateCalendar(); // Regenerate the calendar to reflect changes
223
+ this.openBookModel();
224
+ // suday comment
225
+ // this.openQuestionBookModal();
226
+ }
227
+ deleteEvent(eventId, entryGroup) {
228
+ let event = this.allEvents?.find(e => e?.id === eventId);
229
+ if (event) {
230
+ // Find the index of the entryGroup to delete
231
+ const entryIndex = event.entries.indexOf(entryGroup);
232
+ if (entryIndex > -1) {
233
+ event.entries.splice(entryIndex, 1); // Remove the specific entry
234
+ }
235
+ // If the event has no more entries, remove the event entirely
236
+ if (event.entries.length === 0) {
237
+ const eventIndex = this.allEvents?.indexOf(event);
238
+ if (eventIndex > -1) {
239
+ this.allEvents?.splice(eventIndex, 1); // Remove the entire event
240
+ }
241
+ }
242
+ }
243
+ let eventData = {};
244
+ eventData['action'] = "delete";
245
+ eventData['data'] = event;
246
+ this.eventSelected.emit(eventData);
247
+ this.generateCalendar(); // Regenerate the calendar to reflect the changes
248
+ }
249
+ // VD 06Sep24 calendar changes
250
+ addEvent(day, entryQues) {
251
+ // Transform new entries into the desired format
252
+ const newEntries = entryQues.reduce((acc, q) => {
253
+ acc[q.id] = { ...q };
254
+ return acc;
255
+ }, {});
256
+ // Find an existing event for the given date
257
+ const existingEvent = day.events?.find(event => event.date === day.date);
258
+ if (existingEvent) {
259
+ // Merge new entries into the existing event's entries array
260
+ // Check if the entries array already contains an object with the same id
261
+ const existingEntries = existingEvent.entries.map(entry => ({ ...entry }));
262
+ // Append new entries to the existing entries
263
+ existingEntries.push(newEntries);
264
+ existingEvent.entries = existingEntries;
265
+ }
266
+ else {
267
+ // Create a new event if it doesn't exist for the given date
268
+ const newEvent = {
269
+ id: this.generateId(),
270
+ date: day.date,
271
+ entries: [newEntries] // Wrap the new entries in an array
272
+ };
273
+ day.events = day?.events || [];
274
+ day.events.push(newEvent);
275
+ this.allEvents?.push(newEvent);
276
+ //this.eventSelected.emit(this.allEvents);
277
+ let eventData = {};
278
+ eventData['action'] = "add";
279
+ eventData['data'] = newEvent;
280
+ this.eventSelected.emit(eventData);
281
+ }
282
+ this.generateCalendar();
283
+ }
284
+ // VD 06Sep24 calendar changes
285
+ onSave() {
286
+ if (this.editingEventId !== null) {
287
+ const event = this.allEvents?.find(e => e?.id === this.editingEventId);
288
+ if (event && this.editingEntryGroup) {
289
+ // Update the specific entry group within the event
290
+ const entryIndex = event.entries.findIndex(entryGroup => entryGroup === this.editingEntryGroup);
291
+ if (entryIndex > -1) {
292
+ event.entries[entryIndex] = this.calendarQuestion.reduce((acc, q) => {
293
+ acc[q.id] = { ...q };
294
+ return acc;
295
+ }, {});
296
+ }
297
+ }
298
+ // this.eventSelected.emit(this.allEvents);
299
+ let eventData = {};
300
+ eventData['action'] = "edit";
301
+ eventData['data'] = event;
302
+ this.eventSelected.emit(eventData);
303
+ }
304
+ else {
305
+ if (this.selectedDay) {
306
+ this.addEvent(this.selectedDay, this.calendarQuestion);
307
+ }
308
+ }
309
+ this.closeCalendarModal();
310
+ this.generateCalendar();
311
+ }
312
+ // onCancel() {
313
+ // this.closeCalendarModal();
314
+ // }
315
+ //this funtion need to be used
316
+ // handleQuestionEvent(ques){
317
+ // // Update the questions array with the new question
318
+ // const index = this.calendarQuestion.findIndex(q => q.id === ques.id);
319
+ // if (index > -1) {
320
+ // // If question already exists, update it
321
+ // this.calendarQuestion[index] = ques;
322
+ // } else {
323
+ // // If question doesn't exist, add it to the array
324
+ // this.calendarQuestion.push(ques);
325
+ // }
326
+ // }
327
+ // VD 06Sep24 calendar changes
328
+ generateId() {
329
+ return '_' + Math.random().toString(36).substr(2, 9);
330
+ }
331
+ getEntryKeys(entryGroup) {
332
+ return Object.keys(entryGroup);
333
+ }
334
+ removeCharacters(questionText) {
335
+ let updatedText = questionText?.replace(/<[^>]*>/g, '');
336
+ return updatedText;
337
+ }
338
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomCalendarComponent, deps: [{ token: i1.ChangeService }], target: i0.ɵɵFactoryTarget.Component });
339
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CustomCalendarComponent, isStandalone: true, selector: "app-custom-calendar", inputs: { allEvents: "allEvents", question: "question", nxtId: "nxtId" }, outputs: { eventSelected: "eventSelected", dateSelected: "dateSelected", openModal: "openModal", closeModal: "closeModal" }, 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 <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 == 'Time'\">\n {{ entryGroup[key].input?.value | date: 'shortTime' }}\n </div>\n <div *ngIf=\"entryGroup[key].type != '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 <!-- RS 09DEC24 Changed keys--> \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].questionText\" class=\"entry-text\">\n {{removeCharacters(entryGroup[key].questionText)}}:\n </div>\n <div class=\"entry-value\">\n <!-- VD 09Sep24- date type and link type updates -->\n <span *ngIf=\"entryGroup[key].type != 'Time' && entryGroup[key].type != 'Link'&& entryGroup[key].type != 'Date'\">{{ entryGroup[key].input }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Date'\">{{ entryGroup[key].input | date: 'mediumDate' }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Link'\">\n <a [href]=\"'//'+ entryGroup[key].input\" target=\"_blank\">{{removeCharacters(entryGroup[key].questionText)}}</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<lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook>\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model> -->", 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: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }] });
340
+ }
341
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomCalendarComponent, decorators: [{
342
+ type: Component,
343
+ args: [{ selector: 'app-custom-calendar', standalone: true, imports: [
344
+ CommonModule,
345
+ ], 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 <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 == 'Time'\">\n {{ entryGroup[key].input?.value | date: 'shortTime' }}\n </div>\n <div *ngIf=\"entryGroup[key].type != '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 <!-- RS 09DEC24 Changed keys--> \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].questionText\" class=\"entry-text\">\n {{removeCharacters(entryGroup[key].questionText)}}:\n </div>\n <div class=\"entry-value\">\n <!-- VD 09Sep24- date type and link type updates -->\n <span *ngIf=\"entryGroup[key].type != 'Time' && entryGroup[key].type != 'Link'&& entryGroup[key].type != 'Date'\">{{ entryGroup[key].input }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Date'\">{{ entryGroup[key].input | date: 'mediumDate' }}</span>\n <span *ngIf=\"entryGroup[key].type == 'Link'\">\n <a [href]=\"'//'+ entryGroup[key].input\" target=\"_blank\">{{removeCharacters(entryGroup[key].questionText)}}</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<lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook>\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model> -->", 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"] }]
346
+ }], ctorParameters: () => [{ type: i1.ChangeService }], propDecorators: { eventSelected: [{
347
+ type: Output
348
+ }], dateSelected: [{
349
+ type: Output
350
+ }], openModal: [{
351
+ type: Output
352
+ }], closeModal: [{
353
+ type: Output
354
+ }], allEvents: [{
355
+ type: Input
356
+ }], question: [{
357
+ type: Input
358
+ }], nxtId: [{
359
+ type: Input
360
+ }] } });
361
+ //# 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, SimpleChanges, ViewChild } from '@angular/core';\nimport { Question } from '../../wrapper';\n//import { QuestionbookComponent } from '../../pages/questionbook/questionbook.component';\n//import { ComponenthostDirective } from '../../directives/componenthost/componenthost.directive';\nimport { ChangeService } from '../../services/change.service';\nimport { CommonModule } from '@angular/common';\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@Component({\n  selector: 'app-custom-calendar',\n  standalone: true,\n  imports: [\n    CommonModule,\n  ],\n  templateUrl: './custom-calendar.component.html',\n  styleUrls: ['./custom-calendar.component.css'],\n})\nexport class CustomCalendarComponent implements OnInit {\n  @Output() eventSelected = new EventEmitter<any>();\n  // VD 06Sep24 calendar changes\n  @Output() dateSelected = new EventEmitter<any>();\n  @Output() openModal = new EventEmitter<any>();\n  @Output() closeModal = new EventEmitter<any>();\n  @Input() allEvents: any[] = []; \n  @Input() question: Question\n  @Input() nxtId: string;\n  //@ViewChild(ComponenthostDirective, { static: true }) dynamicHost: ComponenthostDirective;\n  entries = [];\n  referenceQuestions = [];\n  qbRefrenceBook:any;\n  calendarQuestion = [];\n  calendar = {};\n  currentDate: Date = new Date();\n  calendarDays: CalendarDay[] = [];\n  daysOfWeek: string[] = ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'];\n  newEventTitle: string = '';\n  newEventTime: string = '';\n  newDescription: string = '';\n  newLink: string = '';\n  selectedDay: CalendarDay | null = null;\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  subscription: any;\n  constructor( private changeService: ChangeService) { }\n  ngOnInit() {\n     if(this.question?.input){\n      this.allEvents = this.question.input;\n     }\n    this.processQuestion();\n    this.generateCalendar();\n    this.subscription = this.changeService.customChange$.subscribe(\n      (changeValue) => {\n          if(changeValue == 'calendar-modal-save') {\n            this.onSave();\n          }\n          if(changeValue == 'dataBind') {\n            if(this.question?.input){\n              this.allEvents = this.question.input;\n             }\n            this.processQuestion();\n            this.generateCalendar();\n          }\n      }\n    );\n   // this.dateSelected.emit(this.calendar);\n    //this.eventSelected.emit(this.allEvents);\n  }\n  // RS 09DEC24 Changed keys\n  processQuestion(){\n    // SKS20MAR25 check if question fieldsmeta is string\n    this.entries =  typeof this.question['fieldsMeta'] === 'object'  ?  this.question['fieldsMeta'] || [] : JSON.parse( this.question['fieldsMeta']) ;\n    this.qbRefrenceBook = typeof this.question['qbReferenceQuestions'] === 'object'  ?  this.question['qbReferenceQuestions'] : JSON.parse( this.question['qbReferenceQuestions']) ;\n    let title = this.qbRefrenceBook?.questionbook?.title;\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  }\n   // sunday comment\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     // VD 06Sep24 calendar changes\n    let cal = {}\n    cal['year'] = year;\n    cal['month'] = month + 1;\n    this.calendar = cal;\n  }\n\n  selectDay(day: CalendarDay) {\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   // VD 09Sep24- setup the query param data for api call\n    let referenceData = [];\n    this.referenceQuestions.forEach(ques => {\n      // VD 09-09-24 get the selected date\n      // need to add in the document\n      // RS 09DEC24 Changed keys\n       if(ques.referenceField == 'selectedDate'){\n          ques.input = day.date.toISOString();\n       }\n       // VD 09-09-24 get the query refrence  field data to pass the queryParam  for api\n      ques['subText'] = typeof ques?.subText === 'object' ? ques?.subText : JSON.parse(ques['subText'] || {});\n       if(ques.subText){\n        let subText = ques.subText;\n        if (subText.queryField && subText.queryValueReference) {\n            let currentQues = ques;\n            let queryReferences = subText.queryValueReference.split(',');   \n            queryReferences.forEach(refField => {\n                let refQues = this.referenceQuestions.find(q => q.referenceField === refField);\n                if (refQues) {\n                    referenceData.push(refQues);\n                }\n            });\n            // Add the referenceData array to the current question\n            currentQues.referenceQueryData = referenceData;\n        }\n       }\n    })\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    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\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    this.dateSelected.emit(this.calendar);\n    this.eventSelected.emit(this.allEvents);\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.referenceField != 'selectedDate'){\n        if(ques.type == 'Dropdown'){\n          delete ques.input;\n          delete ques.selectedValue;\n           // VD 06Sep24 calendar changes\n        }else {\n          delete ques.input;\n        }\n      }\n    });\n    this.editingEventId = null;\n    this.calendarQuestion = this.referenceQuestions;\n    this.openBookModel();\n    // sunday comment\n    //this.openQuestionBookModal();\n  }\n\n  openBookModel(){\n    this.openModal.emit({\n      qbRefrenceBook: this.qbRefrenceBook,\n      referenceQuestions: this.referenceQuestions,\n      modalTitle : this.modalTitle,\n      modalSize : this.modalSize,\n      saveButtonValue : this.saveButtonValue,\n      modalFooter : this.modalFooter,\n\n    });\n  }\n\n  closeCalendarModal() {\n    this.isModalOpen = false;\n    this.closeModal.emit(true);\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  this.openBookModel();\n  // suday comment\n // this.openQuestionBookModal();\n\n}\n\ndeleteEvent( eventId: number, entryGroup: any) {\n  let 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  let eventData = {};\n   eventData['action'] = \"delete\";\n   eventData['data'] = event;\n  this.eventSelected.emit(eventData);\n  this.generateCalendar(); // Regenerate the calendar to reflect the changes\n}\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        // 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 = day?.events || []\n        day.events.push(newEvent);\n        this.allEvents?.push(newEvent);\n        //this.eventSelected.emit(this.allEvents);\n        let eventData = {};\n        eventData['action'] = \"add\";\n        eventData['data'] = newEvent;\n        this.eventSelected.emit(eventData);\n    }\n    this.generateCalendar();\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     // this.eventSelected.emit(this.allEvents);\n      let eventData = {};\n      eventData['action'] = \"edit\";\n      eventData['data'] = event;\n      this.eventSelected.emit(eventData);\n    } else {\n        if (this.selectedDay) {\n            this.addEvent(this.selectedDay, this.calendarQuestion);\n        }\n    }\n    this.closeCalendarModal();\n    this.generateCalendar();\n}\n\n  // onCancel() {\n  //   this.closeCalendarModal();\n  // }\n  //this funtion need to be used\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  //   }\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\nremoveCharacters(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          <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 == 'Time'\">\n                              {{ entryGroup[key].input?.value | date: 'shortTime' }}\n                          </div>\n                          <div *ngIf=\"entryGroup[key].type != '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      <!-- RS 09DEC24 Changed keys--> \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].questionText\" class=\"entry-text\">\n                            {{removeCharacters(entryGroup[key].questionText)}}:\n                        </div>\n                        <div class=\"entry-value\">\n                            <!-- VD 09Sep24- date type and link type updates    -->\n                            <span *ngIf=\"entryGroup[key].type != 'Time' && entryGroup[key].type != 'Link'&& entryGroup[key].type != 'Date'\">{{ entryGroup[key].input }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Time'\">{{ entryGroup[key].input | date: 'shortTime' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Date'\">{{ entryGroup[key].input | date: 'mediumDate' }}</span>\n                            <span *ngIf=\"entryGroup[key].type == 'Link'\">\n                                <a [href]=\"'//'+ entryGroup[key].input\" target=\"_blank\">{{removeCharacters(entryGroup[key].questionText)}}</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<lib-questionbook [qbItem]=\"qbRefrenceBook\" [questions]=\"referenceQuestions\" (handleQuestion)=\"handleQuestionEvent($event)\"></lib-questionbook>\n<ng-template dynamicComponentHost ></ng-template>\n</app-custom-model> -->"]}