@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.
- package/esm2022/environments/version.mjs +15 -0
- package/esm2022/lib/ar.i18n.mjs +29 -0
- package/esm2022/lib/components/button/nxt-button.component.mjs +165 -0
- package/esm2022/lib/components/custom-calendar/custom-calendar.component.mjs +361 -0
- package/esm2022/lib/components/custom-dropdown/custom-dropdown.component.mjs +271 -0
- package/esm2022/lib/components/custom-model/custom-model.component.mjs +51 -0
- package/esm2022/lib/components/custom-radio/custom-radio.component.mjs +156 -0
- package/esm2022/lib/components/datatable/datatable.component.mjs +1742 -0
- package/esm2022/lib/components/file-upload/file-upload.component.mjs +283 -0
- package/esm2022/lib/components/icon-selector/icon-selector.component.mjs +104 -0
- package/esm2022/lib/components/image-cropper/component/cropper.state.mjs +208 -0
- package/esm2022/lib/components/image-cropper/component/image-cropper.component.mjs +562 -0
- package/esm2022/lib/components/image-cropper/interfaces/basic-event.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/cropper-options.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/cropper-position.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/dimensions.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/exif-transform.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/image-cropped-event.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/image-transform.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/index.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/loaded-image.interface.mjs +2 -0
- package/esm2022/lib/components/image-cropper/interfaces/move-start.interface.mjs +8 -0
- package/esm2022/lib/components/image-cropper/services/crop.service.mjs +139 -0
- package/esm2022/lib/components/image-cropper/services/load-image.service.mjs +194 -0
- package/esm2022/lib/components/image-cropper/utils/cropper-position.utils.mjs +239 -0
- package/esm2022/lib/components/image-cropper/utils/exif.utils.mjs +79 -0
- package/esm2022/lib/components/image-cropper/utils/keyboard.utils.mjs +40 -0
- package/esm2022/lib/components/image-cropper/utils/percentage.utils.mjs +4 -0
- package/esm2022/lib/components/image-cropper/utils/resize.utils.mjs +75 -0
- package/esm2022/lib/components/list-view-filter/list-view-filter.component.mjs +401 -0
- package/esm2022/lib/components/nxt-input/nxt-input.component.mjs +2936 -0
- package/esm2022/lib/components/pagination/pagination.component.mjs +101 -0
- package/esm2022/lib/components/pick-location/pick-location.component.mjs +227 -0
- package/esm2022/lib/components/search-box/search-box.component.mjs +417 -0
- package/esm2022/lib/country.json +43237 -0
- package/esm2022/lib/en.i18n.mjs +29 -0
- package/esm2022/lib/i18n-config.service.mjs +4 -0
- package/esm2022/lib/i18n.component.mjs +45 -0
- package/esm2022/lib/i18n.module.mjs +38 -0
- package/esm2022/lib/i18n.pipe.mjs +26 -0
- package/esm2022/lib/i18n.service.mjs +56 -0
- package/esm2022/lib/interfaces/actionMeta.mjs +2 -0
- package/esm2022/lib/interfaces/apimeta.mjs +2 -0
- package/esm2022/lib/interfaces/dependencyMeta.mjs +2 -0
- package/esm2022/lib/model/bookletWrapper.mjs +9 -0
- package/esm2022/lib/model/changeWrapper.mjs +11 -0
- package/esm2022/lib/model/errorWrapper.mjs +6 -0
- package/esm2022/lib/nxt-app.component.mjs +22 -0
- package/esm2022/lib/nxt-app.module.mjs +139 -0
- package/esm2022/lib/nxt-app.service.mjs +14 -0
- package/esm2022/lib/pages/booklet/booklet.component.mjs +673 -0
- package/esm2022/lib/pages/builder/element/element.component.mjs +476 -0
- package/esm2022/lib/pages/builder/form/form.component.mjs +45 -0
- package/esm2022/lib/pages/builder/properties/common-fields.constants.mjs +89 -0
- package/esm2022/lib/pages/builder/properties/properties.component.mjs +944 -0
- package/esm2022/lib/pages/builder/templates/templates.component.mjs +34 -0
- package/esm2022/lib/pages/pdfDesigner/pdf-designer/pdf-designer.component.mjs +680 -0
- package/esm2022/lib/pages/pdfDesigner/pdf-properties/pdf-properties.component.mjs +1118 -0
- package/esm2022/lib/pages/questionbook/questionbook.component.mjs +838 -0
- package/esm2022/lib/pages/questionnaire/questionnaire.component.mjs +2237 -0
- package/esm2022/lib/pipe/custom-translate.pipe.mjs +27 -0
- package/esm2022/lib/pipe/get-value.pipe.mjs +48 -0
- package/esm2022/lib/pipe/search-filter/search-filter.pipe.mjs +39 -0
- package/esm2022/lib/sample.mjs +3715 -0
- package/esm2022/lib/services/change.service.mjs +46 -0
- package/esm2022/lib/services/country.service.mjs +135 -0
- package/esm2022/lib/services/data.service.mjs +100 -0
- package/esm2022/lib/services/form-builder.service.mjs +385 -0
- package/esm2022/lib/services/pdf-designer.service.mjs +398 -0
- package/esm2022/lib/services/salesforce.service.mjs +41 -0
- package/esm2022/lib/services/shared.service.mjs +100 -0
- package/esm2022/lib/services/storage.service.mjs +43 -0
- package/esm2022/lib/services/template.service.mjs +351 -0
- package/esm2022/lib/services/translation.service.mjs +61 -0
- package/esm2022/lib/tam.i18n.mjs +29 -0
- package/esm2022/lib/wrapper.mjs +175 -0
- package/esm2022/public-api.mjs +25 -0
- package/esm2022/rangertechnologies-ngnxt.mjs +5 -0
- package/fesm2022/rangertechnologies-ngnxt.mjs +7614 -7827
- package/fesm2022/rangertechnologies-ngnxt.mjs.map +1 -1
- package/lib/components/custom-dropdown/custom-dropdown.component.d.ts +2 -1
- package/lib/components/datatable/datatable.component.d.ts +34 -28
- package/lib/components/file-upload/file-upload.component.d.ts +4 -3
- package/lib/components/image-cropper/component/image-cropper.component.d.ts +1 -1
- package/lib/components/list-view-filter/list-view-filter.component.d.ts +3 -3
- package/lib/components/nxt-input/nxt-input.component.d.ts +5 -1
- package/lib/components/pick-location/pick-location.component.d.ts +3 -1
- package/lib/components/search-box/search-box.component.d.ts +2 -1
- package/lib/pages/builder/element/element.component.d.ts +2 -15
- package/lib/pages/builder/properties/common-fields.constants.d.ts +4 -16
- package/lib/pages/builder/properties/properties.component.d.ts +95 -129
- package/lib/pipe/custom-translate.pipe.d.ts +3 -3
- package/lib/pipe/get-value.pipe.d.ts +4 -4
- package/lib/pipe/search-filter/search-filter.pipe.d.ts +3 -3
- package/lib/services/form-builder.service.d.ts +0 -1
- package/package.json +6 -4
- package/rangertechnologies-ngnxt-2.1.244.tgz +0 -0
- package/lib/pipe/date/date.pipe.d.ts +0 -7
- package/lib/pipe/editColumnCheck/edit-column-check.pipe.d.ts +0 -7
- package/lib/pipe/editColumnDropdown/edit-column-dropdown.pipe.d.ts +0 -7
- package/lib/pipe/editColumnType/edit-column-type.pipe.d.ts +0 -7
- package/lib/pipe/time/time.pipe.d.ts +0 -7
- 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> -->"]}
|