@syncfusion/ej2-schedule 31.1.17 → 31.1.21

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 (168) hide show
  1. package/dist/ej2-schedule.min.js +2 -2
  2. package/dist/ej2-schedule.umd.min.js +2 -2
  3. package/dist/ej2-schedule.umd.min.js.map +1 -1
  4. package/dist/es6/ej2-schedule.es2015.js +7 -3
  5. package/dist/es6/ej2-schedule.es2015.js.map +1 -1
  6. package/dist/es6/ej2-schedule.es5.js +6 -2
  7. package/dist/es6/ej2-schedule.es5.js.map +1 -1
  8. package/dist/global/ej2-schedule.min.js +2 -2
  9. package/dist/global/ej2-schedule.min.js.map +1 -1
  10. package/dist/global/index.d.ts +1 -1
  11. package/package.json +18 -53
  12. package/src/schedule/actions/virtual-scroll.js +5 -1
  13. package/src/schedule/event-renderer/event-base.js +1 -1
  14. package/styles/bootstrap4-lite.css +8 -0
  15. package/styles/bootstrap4.css +8 -0
  16. package/styles/recurrence-editor/bootstrap4.css +8 -0
  17. package/styles/schedule/bootstrap4.css +8 -0
  18. package/dist/ts/common/calendar-util.d.ts +0 -92
  19. package/dist/ts/common/calendar-util.ts +0 -261
  20. package/dist/ts/common/index.d.ts +0 -4
  21. package/dist/ts/common/index.ts +0 -4
  22. package/dist/ts/components.d.ts +0 -5
  23. package/dist/ts/components.ts +0 -5
  24. package/dist/ts/index.d.ts +0 -6
  25. package/dist/ts/index.ts +0 -7
  26. package/dist/ts/recurrence-editor/date-generator.d.ts +0 -76
  27. package/dist/ts/recurrence-editor/date-generator.ts +0 -1699
  28. package/dist/ts/recurrence-editor/index.d.ts +0 -6
  29. package/dist/ts/recurrence-editor/index.ts +0 -6
  30. package/dist/ts/recurrence-editor/recurrence-editor-model.d.ts +0 -112
  31. package/dist/ts/recurrence-editor/recurrence-editor.d.ts +0 -245
  32. package/dist/ts/recurrence-editor/recurrence-editor.ts +0 -1257
  33. package/dist/ts/schedule/actions/action-base.d.ts +0 -44
  34. package/dist/ts/schedule/actions/action-base.ts +0 -493
  35. package/dist/ts/schedule/actions/crud.d.ts +0 -41
  36. package/dist/ts/schedule/actions/crud.ts +0 -784
  37. package/dist/ts/schedule/actions/data.d.ts +0 -63
  38. package/dist/ts/schedule/actions/data.ts +0 -128
  39. package/dist/ts/schedule/actions/drag.d.ts +0 -75
  40. package/dist/ts/schedule/actions/drag.ts +0 -1401
  41. package/dist/ts/schedule/actions/keyboard.d.ts +0 -100
  42. package/dist/ts/schedule/actions/keyboard.ts +0 -1435
  43. package/dist/ts/schedule/actions/resize.d.ts +0 -27
  44. package/dist/ts/schedule/actions/resize.ts +0 -602
  45. package/dist/ts/schedule/actions/scroll.d.ts +0 -69
  46. package/dist/ts/schedule/actions/scroll.ts +0 -105
  47. package/dist/ts/schedule/actions/touch.d.ts +0 -32
  48. package/dist/ts/schedule/actions/touch.ts +0 -314
  49. package/dist/ts/schedule/actions/virtual-scroll.d.ts +0 -55
  50. package/dist/ts/schedule/actions/virtual-scroll.ts +0 -596
  51. package/dist/ts/schedule/actions/work-cells.d.ts +0 -14
  52. package/dist/ts/schedule/actions/work-cells.ts +0 -151
  53. package/dist/ts/schedule/base/constant.d.ts +0 -102
  54. package/dist/ts/schedule/base/constant.ts +0 -103
  55. package/dist/ts/schedule/base/css-constant.d.ts +0 -475
  56. package/dist/ts/schedule/base/css-constant.ts +0 -475
  57. package/dist/ts/schedule/base/interface.d.ts +0 -673
  58. package/dist/ts/schedule/base/interface.ts +0 -738
  59. package/dist/ts/schedule/base/resource.d.ts +0 -59
  60. package/dist/ts/schedule/base/resource.ts +0 -1091
  61. package/dist/ts/schedule/base/schedule-model.d.ts +0 -930
  62. package/dist/ts/schedule/base/schedule.d.ts +0 -1967
  63. package/dist/ts/schedule/base/schedule.ts +0 -4221
  64. package/dist/ts/schedule/base/type.d.ts +0 -134
  65. package/dist/ts/schedule/base/type.ts +0 -142
  66. package/dist/ts/schedule/base/util.d.ts +0 -266
  67. package/dist/ts/schedule/base/util.ts +0 -492
  68. package/dist/ts/schedule/event-renderer/agenda-base.d.ts +0 -15
  69. package/dist/ts/schedule/event-renderer/agenda-base.ts +0 -423
  70. package/dist/ts/schedule/event-renderer/event-base.d.ts +0 -101
  71. package/dist/ts/schedule/event-renderer/event-base.ts +0 -1501
  72. package/dist/ts/schedule/event-renderer/inline-edit.d.ts +0 -23
  73. package/dist/ts/schedule/event-renderer/inline-edit.ts +0 -287
  74. package/dist/ts/schedule/event-renderer/month.d.ts +0 -60
  75. package/dist/ts/schedule/event-renderer/month.ts +0 -760
  76. package/dist/ts/schedule/event-renderer/timeline-view.d.ts +0 -51
  77. package/dist/ts/schedule/event-renderer/timeline-view.ts +0 -606
  78. package/dist/ts/schedule/event-renderer/vertical-view.d.ts +0 -57
  79. package/dist/ts/schedule/event-renderer/vertical-view.ts +0 -898
  80. package/dist/ts/schedule/event-renderer/year.d.ts +0 -27
  81. package/dist/ts/schedule/event-renderer/year.ts +0 -623
  82. package/dist/ts/schedule/exports/calendar-export.d.ts +0 -16
  83. package/dist/ts/schedule/exports/calendar-export.ts +0 -160
  84. package/dist/ts/schedule/exports/calendar-import.d.ts +0 -18
  85. package/dist/ts/schedule/exports/calendar-import.ts +0 -277
  86. package/dist/ts/schedule/exports/excel-export.d.ts +0 -14
  87. package/dist/ts/schedule/exports/excel-export.ts +0 -89
  88. package/dist/ts/schedule/exports/index.d.ts +0 -7
  89. package/dist/ts/schedule/exports/index.ts +0 -7
  90. package/dist/ts/schedule/exports/print.d.ts +0 -20
  91. package/dist/ts/schedule/exports/print.ts +0 -233
  92. package/dist/ts/schedule/index.d.ts +0 -26
  93. package/dist/ts/schedule/index.ts +0 -26
  94. package/dist/ts/schedule/models/event-settings-model.d.ts +0 -165
  95. package/dist/ts/schedule/models/event-settings.d.ts +0 -149
  96. package/dist/ts/schedule/models/event-settings.ts +0 -187
  97. package/dist/ts/schedule/models/field-options-model.d.ts +0 -37
  98. package/dist/ts/schedule/models/field-options.d.ts +0 -31
  99. package/dist/ts/schedule/models/field-options.ts +0 -41
  100. package/dist/ts/schedule/models/fields-model.d.ts +0 -129
  101. package/dist/ts/schedule/models/fields.d.ts +0 -117
  102. package/dist/ts/schedule/models/fields.ts +0 -149
  103. package/dist/ts/schedule/models/group-model.d.ts +0 -69
  104. package/dist/ts/schedule/models/group.d.ts +0 -60
  105. package/dist/ts/schedule/models/group.ts +0 -75
  106. package/dist/ts/schedule/models/header-rows-model.d.ts +0 -33
  107. package/dist/ts/schedule/models/header-rows.d.ts +0 -30
  108. package/dist/ts/schedule/models/header-rows.ts +0 -35
  109. package/dist/ts/schedule/models/models.d.ts +0 -14
  110. package/dist/ts/schedule/models/models.ts +0 -15
  111. package/dist/ts/schedule/models/quick-info-templates-model.d.ts +0 -52
  112. package/dist/ts/schedule/models/quick-info-templates.d.ts +0 -47
  113. package/dist/ts/schedule/models/quick-info-templates.ts +0 -56
  114. package/dist/ts/schedule/models/resources-model.d.ts +0 -122
  115. package/dist/ts/schedule/models/resources.d.ts +0 -106
  116. package/dist/ts/schedule/models/resources.ts +0 -138
  117. package/dist/ts/schedule/models/time-scale-model.d.ts +0 -57
  118. package/dist/ts/schedule/models/time-scale.d.ts +0 -50
  119. package/dist/ts/schedule/models/time-scale.ts +0 -61
  120. package/dist/ts/schedule/models/toolbar-model.d.ts +0 -196
  121. package/dist/ts/schedule/models/toolbar.d.ts +0 -176
  122. package/dist/ts/schedule/models/toolbar.ts +0 -196
  123. package/dist/ts/schedule/models/views-model.d.ts +0 -370
  124. package/dist/ts/schedule/models/views.d.ts +0 -335
  125. package/dist/ts/schedule/models/views.ts +0 -408
  126. package/dist/ts/schedule/models/work-hours-model.d.ts +0 -29
  127. package/dist/ts/schedule/models/work-hours.d.ts +0 -24
  128. package/dist/ts/schedule/models/work-hours.ts +0 -31
  129. package/dist/ts/schedule/popups/event-tooltip.d.ts +0 -16
  130. package/dist/ts/schedule/popups/event-tooltip.ts +0 -203
  131. package/dist/ts/schedule/popups/event-window.d.ts +0 -118
  132. package/dist/ts/schedule/popups/event-window.ts +0 -2055
  133. package/dist/ts/schedule/popups/form-validator.d.ts +0 -16
  134. package/dist/ts/schedule/popups/form-validator.ts +0 -110
  135. package/dist/ts/schedule/popups/quick-popups.d.ts +0 -78
  136. package/dist/ts/schedule/popups/quick-popups.ts +0 -1470
  137. package/dist/ts/schedule/renderer/agenda.d.ts +0 -45
  138. package/dist/ts/schedule/renderer/agenda.ts +0 -497
  139. package/dist/ts/schedule/renderer/day.d.ts +0 -20
  140. package/dist/ts/schedule/renderer/day.ts +0 -28
  141. package/dist/ts/schedule/renderer/header-renderer.d.ts +0 -48
  142. package/dist/ts/schedule/renderer/header-renderer.ts +0 -736
  143. package/dist/ts/schedule/renderer/month-agenda.d.ts +0 -29
  144. package/dist/ts/schedule/renderer/month-agenda.ts +0 -184
  145. package/dist/ts/schedule/renderer/month.d.ts +0 -61
  146. package/dist/ts/schedule/renderer/month.ts +0 -766
  147. package/dist/ts/schedule/renderer/renderer.d.ts +0 -13
  148. package/dist/ts/schedule/renderer/renderer.ts +0 -165
  149. package/dist/ts/schedule/renderer/timeline-header-row.d.ts +0 -15
  150. package/dist/ts/schedule/renderer/timeline-header-row.ts +0 -132
  151. package/dist/ts/schedule/renderer/timeline-month.d.ts +0 -29
  152. package/dist/ts/schedule/renderer/timeline-month.ts +0 -184
  153. package/dist/ts/schedule/renderer/timeline-view.d.ts +0 -31
  154. package/dist/ts/schedule/renderer/timeline-view.ts +0 -308
  155. package/dist/ts/schedule/renderer/timeline-year.d.ts +0 -22
  156. package/dist/ts/schedule/renderer/timeline-year.ts +0 -450
  157. package/dist/ts/schedule/renderer/vertical-view.d.ts +0 -63
  158. package/dist/ts/schedule/renderer/vertical-view.ts +0 -911
  159. package/dist/ts/schedule/renderer/view-base.d.ts +0 -83
  160. package/dist/ts/schedule/renderer/view-base.ts +0 -709
  161. package/dist/ts/schedule/renderer/week.d.ts +0 -22
  162. package/dist/ts/schedule/renderer/week.ts +0 -35
  163. package/dist/ts/schedule/renderer/work-week.d.ts +0 -22
  164. package/dist/ts/schedule/renderer/work-week.ts +0 -36
  165. package/dist/ts/schedule/renderer/year.d.ts +0 -46
  166. package/dist/ts/schedule/renderer/year.ts +0 -470
  167. package/dist/ts/schedule/timezone/timezone.d.ts +0 -16
  168. package/dist/ts/schedule/timezone/timezone.ts +0 -313
@@ -1,784 +0,0 @@
1
- /* eslint-disable @typescript-eslint/no-explicit-any */
2
- /* eslint-disable max-len */
3
- import { isNullOrUndefined, extend, removeClass } from '@syncfusion/ej2-base';
4
- import { Query } from '@syncfusion/ej2-data';
5
- import { getRecurrenceStringFromDate, generate } from '../../recurrence-editor/date-generator';
6
- import { ActionEventArgs, EventFieldsMapping, SaveChanges, CrudArgs, CrudAction, TdData } from '../base/interface';
7
- import { ReturnType, CurrentAction } from '../base/type';
8
- import { Schedule } from '../base/schedule';
9
- import * as events from '../base/constant';
10
- import * as util from '../base/util';
11
-
12
- /**
13
- * Schedule CRUD operations
14
- */
15
-
16
- export class Crud {
17
- private parent: Schedule;
18
- public crudObj: CrudAction;
19
-
20
- constructor(parent: Schedule) {
21
- this.parent = parent;
22
- this.crudObj = { sourceEvent: null, targetEvent: null, isCrudAction: false };
23
- }
24
-
25
- private getQuery(): Query {
26
- const start: Date = this.parent.activeView.startDate();
27
- const end: Date = this.parent.activeView.endDate();
28
- return this.parent.dataModule.generateQuery(start, end);
29
- }
30
-
31
- private getTable(): string {
32
- if (this.parent.eventSettings.query) {
33
- const query: Query = this.parent.eventSettings.query.clone();
34
- return query.fromTable;
35
- }
36
- return null;
37
- }
38
-
39
- public refreshDataManager(): void {
40
- if (!this.parent.activeView) {
41
- return;
42
- }
43
-
44
- if (this.parent.uiStateValues && this.parent.uiStateValues.isPreventEventRefresh) {
45
- this.parent.uiStateValues.isPreventEventRefresh = false;
46
- this.parent.refreshEvents(false);
47
- this.parent.hideSpinner();
48
- return;
49
- }
50
- const start: Date = this.parent.activeView.startDate();
51
- const end: Date = this.parent.activeView.endDate();
52
- const dataManager: Promise<any> = this.parent.dataModule.getData(this.parent.dataModule.generateQuery(start, end));
53
- dataManager.then((e: ReturnType) => this.dataManagerSuccess(e)).catch((e: ReturnType) => this.dataManagerFailure(e));
54
- }
55
-
56
- private dataManagerSuccess(e: ReturnType): void {
57
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
58
- this.parent.trigger(events.dataBinding, e, (args: ReturnType) => {
59
- if (args.cancel) { return; }
60
- const resultData: Record<string, any>[] = extend([], args.result, null, true) as Record<string, any>[];
61
- this.parent.eventsData = resultData.filter((data: Record<string, any>) => !data[this.parent.eventFields.isBlock]);
62
- this.parent.blockData = resultData.filter((data: Record<string, any>) => data[this.parent.eventFields.isBlock]);
63
- this.refreshProcessedData();
64
- if (this.parent.dragAndDropModule && this.parent.dragAndDropModule.actionObj.action === 'drag') {
65
- this.parent.dragAndDropModule.navigationWrapper();
66
- }
67
- this.parent.trigger(events.dataBound, null, () => {
68
- this.parent.hideSpinner();
69
- if (this.parent.isPrinting) {
70
- setTimeout(() => {
71
- this.parent.notify(events.print, {});
72
- }, 100);
73
- }
74
- });
75
- });
76
- }
77
-
78
- public dataManagerFailure(e: ReturnType): void {
79
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
80
- this.parent.trigger(events.actionFailure, { error: e }, () => this.parent.hideSpinner());
81
- }
82
-
83
- public refreshProcessedData(isVirtualScrollAction: boolean = false, dynamicEvents?: Record<string, any>[]): void {
84
- if (this.parent.dragAndDropModule) {
85
- this.parent.dragAndDropModule.actionObj.action = '';
86
- removeClass([this.parent.element], 'e-event-action');
87
- }
88
- if (this.parent.activeViewOptions && this.parent.activeViewOptions.eventTemplate) {
89
- let templateNames: string[] = ['eventTemplate'];
90
- if (this.crudObj.isCrudAction &&
91
- ['Agenda', 'MonthAgenda', 'Year', 'TimelineYear'].indexOf(this.parent.currentView) === -1) {
92
- templateNames = [];
93
- for (let i: number = 0, len: number = this.crudObj.sourceEvent.length; i < len; i++) {
94
- templateNames.push('eventTemplate_' + this.crudObj.sourceEvent[parseInt(i.toString(), 10)].groupIndex);
95
- if (this.crudObj.targetEvent[parseInt(i.toString(), 10)] && this.crudObj.sourceEvent[parseInt(i.toString(), 10)].groupIndex !==
96
- this.crudObj.targetEvent[parseInt(i.toString(), 10)].groupIndex) {
97
- templateNames.push('eventTemplate_' + this.crudObj.targetEvent[parseInt(i.toString(), 10)].groupIndex);
98
- }
99
- }
100
- }
101
- if (templateNames.length > 0) {
102
- this.parent.resetTemplates(templateNames);
103
- }
104
- }
105
- if (isVirtualScrollAction) {
106
- this.parent.notify(events.dataReady, { processedData: dynamicEvents ? this.parent.eventBase.processData(dynamicEvents) : this.parent.eventsProcessed });
107
- return;
108
- }
109
- const eventsData: Record<string, any>[] = this.parent.eventsData || [];
110
- const blockData: Record<string, any>[] = this.parent.blockData || [];
111
- const data: Record<string, any>[] = eventsData.concat(blockData);
112
- this.parent.notify(events.dataReady, { processedData: this.parent.eventBase ? this.parent.eventBase.processData(data) : [] });
113
- }
114
-
115
- private refreshData(args: CrudArgs): void {
116
- const actionArgs: ActionEventArgs = {
117
- requestType: args.requestType, cancel: false, data: args.data,
118
- addedRecords: args.editParams.addedRecords, changedRecords: args.editParams.changedRecords,
119
- deletedRecords: args.editParams.deletedRecords
120
- };
121
- if (this.parent.dragAndDropModule && this.parent.dragAndDropModule.actionObj && this.parent.dragAndDropModule.actionObj.element && this.parent.dragAndDropModule.actionObj.action) {
122
- this.parent.dragAndDropModule.actionObj.element.style.display = 'none';
123
- }
124
- if (this.parent.resizeModule && this.parent.resizeModule.actionObj && this.parent.resizeModule.actionObj.element && this.parent.resizeModule.actionObj.action) {
125
- this.parent.resizeModule.actionObj.element.style.display = 'none';
126
- }
127
- if (this.parent.isSpecificResourceEvents()) {
128
- if (args.requestType === 'eventCreated' || args.requestType === 'eventRemoved') {
129
- this.crudObj.isCrudAction = true;
130
- this.crudObj.sourceEvent = [];
131
- const crudData: Record<string, any>[] = args.data instanceof Array ? (args.data.length === 0 &&
132
- args.requestType === 'eventRemoved' ? args.editParams.deletedRecords : args.data) :
133
- ((typeof args.data === 'string' || typeof args.data === 'number') && args.requestType === 'eventRemoved') ?
134
- args.editParams.deletedRecords : [args.data];
135
- for (const data of crudData) {
136
- this.crudObj.isCrudAction = !(args.requestType === 'eventRemoved' && !isNullOrUndefined(data.parent));
137
- const groupIndex: number = this.parent.eventBase.getGroupIndexFromEvent(data);
138
- if (groupIndex > -1 && this.parent.crudModule.crudObj.sourceEvent.filter((tdData: TdData) => tdData.groupIndex === groupIndex).length === 0
139
- && this.crudObj.isCrudAction) {
140
- this.crudObj.sourceEvent.push(this.parent.resourceBase.lastResourceLevel[parseInt(groupIndex.toString(), 10)]);
141
- }
142
- }
143
- this.crudObj.targetEvent = this.crudObj.sourceEvent;
144
- }
145
- }
146
- if (this.parent.dataModule.dataManager.dataSource.offline) {
147
- this.parent.trigger(events.actionComplete, actionArgs, (offlineArgs: ActionEventArgs) => {
148
- if (!offlineArgs.cancel) {
149
- this.refreshDataManager();
150
- }
151
- });
152
- } else {
153
- args.promise.then(() => {
154
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
155
- this.parent.trigger(events.actionComplete, actionArgs, (onlineArgs: ActionEventArgs) => {
156
- if (!onlineArgs.cancel) {
157
- this.refreshDataManager();
158
- }
159
- });
160
- }).catch((e: ReturnType) => {
161
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
162
- this.parent.trigger(events.actionFailure, { error: e });
163
- });
164
- }
165
- }
166
-
167
- private processAddEvent(addArgs: ActionEventArgs): void {
168
- const fields: EventFieldsMapping = this.parent.eventFields;
169
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
170
- let promise: Promise<any>;
171
- if (addArgs.addedRecords instanceof Array) {
172
- for (let event of addArgs.addedRecords) {
173
- event = this.parent.eventBase.updateEventDateTime(event);
174
- const eventData: Record<string, any> = <Record<string, any>>extend({}, this.parent.eventBase.processTimezone(event, true), null, true);
175
- editParams.addedRecords.push(eventData);
176
- }
177
- promise = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
178
- } else {
179
- const event: Record<string, any> = this.parent.eventBase.processTimezone(addArgs.addedRecords, true);
180
- editParams.addedRecords.push(event);
181
- promise = this.parent.dataModule.dataManager.insert(event, this.getTable(), this.getQuery()) as Promise<any>;
182
- }
183
- const crudArgs: CrudArgs = {
184
- requestType: 'eventCreated', cancel: false, data: addArgs.addedRecords, promise: promise, editParams: editParams
185
- };
186
- this.refreshData(crudArgs);
187
- }
188
-
189
- private processSaveEvent(saveArgs: ActionEventArgs): void {
190
- let promise: Promise<any>;
191
- const fields: EventFieldsMapping = this.parent.eventFields;
192
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
193
- if (saveArgs.changedRecords instanceof Array) {
194
- for (let event of saveArgs.changedRecords) {
195
- event = this.parent.eventBase.updateEventDateTime(event);
196
- const eventData: Record<string, any> = <Record<string, any>>extend({}, this.parent.eventBase.processTimezone(event, true), null, true);
197
- editParams.changedRecords.push(eventData);
198
- }
199
- promise = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
200
- } else {
201
- const event: Record<string, any> = this.parent.eventBase.processTimezone(saveArgs.changedRecords, true);
202
- editParams.changedRecords.push(event);
203
- promise = this.parent.dataModule.dataManager.update(fields.id, event, this.getTable(), this.getQuery()) as Promise<any>;
204
- }
205
- const cloneEvent: Record<string, any> = extend({}, saveArgs.changedRecords[saveArgs.changedRecords.length - 1], null, true) as Record<string, any>;
206
- this.parent.eventBase.selectWorkCellByTime([this.parent.eventBase.processTimezone(cloneEvent)]);
207
- const crudArgs: CrudArgs = {
208
- requestType: 'eventChanged', cancel: false,
209
- data: saveArgs.changedRecords, promise: promise, editParams: editParams
210
- };
211
- this.refreshData(crudArgs);
212
- }
213
-
214
- private processDeleteEvent(deleteArgs: ActionEventArgs): void {
215
- let promise: Promise<any>;
216
- const fields: EventFieldsMapping = this.parent.eventFields;
217
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
218
- if (deleteArgs.deletedRecords.length > 1) {
219
- editParams.deletedRecords = editParams.deletedRecords.concat(deleteArgs.deletedRecords);
220
- promise = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
221
- } else {
222
- editParams.deletedRecords.push(deleteArgs.deletedRecords[0]);
223
- promise = this.parent.dataModule.dataManager.remove(fields.id, deleteArgs.deletedRecords[0], this.getTable(), this.getQuery()) as Promise<any>;
224
- }
225
- this.parent.eventBase.selectWorkCellByTime(deleteArgs.deletedRecords);
226
- const crudArgs: CrudArgs = {
227
- requestType: 'eventRemoved', cancel: false,
228
- data: deleteArgs.deletedRecords, promise: promise, editParams: editParams
229
- };
230
- this.refreshData(crudArgs);
231
- }
232
-
233
- public addEvent(eventData: Record<string, any> | Record<string, any>[]): void {
234
- if (this.parent.eventSettings.allowAdding && !this.parent.activeViewOptions.readonly) {
235
- if (!this.isBlockEvent(eventData) && this.parent.eventBase.isBlockRange(eventData)) {
236
- this.parent.quickPopup.openValidationError('blockAlert', eventData);
237
- return;
238
- }
239
- if (this.parent.eventBase.checkOverlap(eventData)) {
240
- return;
241
- }
242
- const addEvents: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
243
- if (addEvents.length === 0) {
244
- return;
245
- }
246
- const args: ActionEventArgs = {
247
- requestType: 'eventCreate', cancel: false, data: addEvents,
248
- addedRecords: addEvents, changedRecords: [], deletedRecords: []
249
- };
250
- this.parent.trigger(events.actionBegin, args, (addArgs: ActionEventArgs) => {
251
- if (!addArgs.cancel) {
252
- if (addArgs.promise) {
253
- addArgs.promise.then((hasContinue: boolean) => {
254
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
255
- if (hasContinue) {
256
- this.processAddEvent(addArgs);
257
- }
258
- }).catch((e: ReturnType) => {
259
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
260
- this.parent.trigger(events.actionFailure, { error: e });
261
- });
262
- } else {
263
- this.processAddEvent(addArgs);
264
- }
265
- }
266
- });
267
- }
268
- }
269
-
270
- public saveEvent(eventData: Record<string, any> | Record<string, any>[], action: CurrentAction): void {
271
- if (this.parent.eventSettings.allowEditing && !this.parent.activeViewOptions.readonly) {
272
- if (this.parent.currentAction !== 'EditFollowingEvents' && !this.isBlockEvent(eventData)
273
- && this.parent.eventBase.isBlockRange(eventData)) {
274
- this.parent.quickPopup.openValidationError('blockAlert', eventData);
275
- this.parent.crudModule.crudObj.isCrudAction = false;
276
- return;
277
- }
278
- const updateEvents: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
279
- if (updateEvents.length === 0) {
280
- return;
281
- }
282
- this.parent.currentAction = action;
283
- if (action) {
284
- switch (action) {
285
- case 'Save':
286
- this.processSave(eventData);
287
- break;
288
- case 'EditOccurrence':
289
- this.processOccurrences(eventData, action);
290
- break;
291
- case 'EditFollowingEvents':
292
- this.processFollowSeries(eventData, action);
293
- break;
294
- case 'EditSeries':
295
- this.processEntireSeries(eventData, action);
296
- break;
297
- }
298
- } else {
299
- if (this.parent.eventBase.checkOverlap(eventData)) {
300
- return;
301
- }
302
- const args: ActionEventArgs = {
303
- requestType: 'eventChange', cancel: false, data: eventData,
304
- addedRecords: [], changedRecords: updateEvents, deletedRecords: []
305
- };
306
- this.parent.trigger(events.actionBegin, args, (saveArgs: ActionEventArgs) => {
307
- if (!saveArgs.cancel) {
308
- if (saveArgs.promise) {
309
- saveArgs.promise.then((hasContinue: boolean) => {
310
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
311
- if (hasContinue) {
312
- this.processSaveEvent(saveArgs);
313
- }
314
- }).catch((e: ReturnType) => {
315
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
316
- this.parent.trigger(events.actionFailure, { error: e });
317
- });
318
- } else {
319
- this.processSaveEvent(saveArgs);
320
- }
321
- }
322
- });
323
- }
324
- }
325
- }
326
-
327
- public deleteEvent(eventData: string | number | Record<string, any> | Record<string, any>[], action: CurrentAction): void {
328
- if (this.parent.eventSettings.allowDeleting && !this.parent.activeViewOptions.readonly) {
329
- this.parent.currentAction = action;
330
- let deleteEvents: Record<string, any>[] = [];
331
- if (typeof eventData === 'string' || typeof eventData === 'number') {
332
- deleteEvents = this.parent.eventsData.filter((eventObj: Record<string, any>) =>
333
- eventObj[this.parent.eventFields.id] === eventData) as Record<string, any>[];
334
- } else {
335
- deleteEvents = (eventData instanceof Array ? eventData : [eventData]) as Record<string, any>[];
336
- }
337
- if (deleteEvents.length === 0) {
338
- return;
339
- }
340
- if (action) {
341
- switch (action) {
342
- case 'Delete':
343
- this.processDelete(deleteEvents);
344
- break;
345
- case 'DeleteOccurrence':
346
- this.processOccurrences(deleteEvents, action);
347
- break;
348
- case 'DeleteFollowingEvents':
349
- this.processFollowSeries(deleteEvents, action);
350
- break;
351
- case 'DeleteSeries':
352
- this.processEntireSeries(deleteEvents, action);
353
- break;
354
- }
355
- } else {
356
- const args: ActionEventArgs = {
357
- requestType: 'eventRemove', cancel: false, data: eventData as Record<string, any>,
358
- addedRecords: [], changedRecords: [], deletedRecords: deleteEvents
359
- };
360
- this.parent.trigger(events.actionBegin, args, (deleteArgs: ActionEventArgs) => {
361
- if (!deleteArgs.cancel) {
362
- if (deleteArgs.promise) {
363
- deleteArgs.promise.then((hasContinue: boolean) => {
364
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
365
- if (hasContinue) {
366
- this.processDeleteEvent(deleteArgs);
367
- }
368
- }).catch((e: ReturnType) => {
369
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
370
- this.parent.trigger(events.actionFailure, { error: e });
371
- });
372
- } else {
373
- this.processDeleteEvent(deleteArgs);
374
- }
375
- }
376
- });
377
- }
378
- }
379
- }
380
-
381
- private processOccurrences(eventData: Record<string, any> | Record<string, any>[], action: CurrentAction): void {
382
- let occurrenceData: Record<string, any> | Record<string, any>[] = [];
383
- let isDeletedRecords: boolean = false;
384
- if (eventData instanceof Array) {
385
- for (const event of eventData) {
386
- occurrenceData.push({ occurrence: event, parent: this.getParentEvent(event) });
387
- }
388
- } else {
389
- occurrenceData = { occurrence: eventData, parent: this.getParentEvent(eventData) };
390
- }
391
- const updateEvents: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
392
- const args: ActionEventArgs = {
393
- requestType: action === 'EditOccurrence' ? 'eventChange' : 'eventRemove',
394
- cancel: false,
395
- addedRecords: [], changedRecords: updateEvents, deletedRecords: []
396
- };
397
- args.data = occurrenceData;
398
- this.parent.trigger(events.actionBegin, args, (occurrenceArgs: ActionEventArgs) => {
399
- if (!occurrenceArgs.cancel) {
400
- const fields: EventFieldsMapping = this.parent.eventFields;
401
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
402
- const occurrenceEvents: Record<string, any>[] = (occurrenceData instanceof Array ? occurrenceData : [occurrenceData]);
403
- for (let a: number = 0, count: number = occurrenceArgs.changedRecords.length; a < count; a++) {
404
- const childEvent: Record<string, any> = occurrenceArgs.changedRecords[parseInt(a.toString(), 10)];
405
- const parentEvent: Record<string, any> = occurrenceEvents[parseInt(a.toString(), 10)].parent as Record<string, any>;
406
- const parentException: string = parentEvent[fields.recurrenceException] as string;
407
- let editedData: Record<string, Date>;
408
- let exceptionDate: string;
409
- switch (action) {
410
- case 'EditOccurrence':
411
- editedData = this.parent.eventsProcessed.filter((event: Record<string, any>) => event.Guid === childEvent.Guid)[0] as Record<string, Date>;
412
- exceptionDate = this.excludeDateCheck(editedData[fields.startTime], parentException);
413
- if (exceptionDate !== parentEvent[fields.recurrenceException]) {
414
- parentEvent[fields.recurrenceException] = exceptionDate;
415
- childEvent[fields.recurrenceException] = getRecurrenceStringFromDate(editedData[fields.startTime] as Date);
416
- childEvent[fields.recurrenceID] = parentEvent[fields.id];
417
- childEvent[fields.followingID] = null;
418
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEvent, true));
419
- editParams.addedRecords.push(this.parent.eventBase.processTimezone(childEvent, true));
420
- } else {
421
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(childEvent, true));
422
- }
423
- break;
424
- case 'DeleteOccurrence':
425
- if (!childEvent[fields.recurrenceException]) {
426
- parentEvent[fields.recurrenceException] =
427
- this.excludeDateCheck(<Date>childEvent[fields.startTime], parentException);
428
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEvent, true));
429
- }
430
- if (childEvent[fields.id] !== parentEvent[fields.id]) {
431
- editParams.deletedRecords.push(this.parent.eventBase.processTimezone(childEvent, true));
432
- isDeletedRecords = true;
433
- }
434
- break;
435
- }
436
- }
437
- const promise: Promise<any> = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
438
- const cloneEvent: Record<string, any> = extend({}, occurrenceArgs.changedRecords[occurrenceArgs.changedRecords.length - 1], null, true) as Record<string, any>;
439
- this.parent.eventBase.selectWorkCellByTime(action === 'EditOccurrence' ? [this.parent.eventBase.processTimezone(cloneEvent)] : [cloneEvent]);
440
- const crudArgs: CrudArgs = {
441
- requestType: action === 'EditOccurrence' ? 'eventChanged' : 'eventRemoved',
442
- cancel: false, data: isDeletedRecords ? occurrenceArgs.deletedRecords : occurrenceArgs.changedRecords,
443
- promise: promise, editParams: editParams
444
- };
445
- this.refreshData(crudArgs);
446
- }
447
- });
448
- }
449
-
450
- private processFollowSeries(eventData: Record<string, any> | Record<string, any>[], action: CurrentAction): void {
451
- let followData: Record<string, any> | Record<string, any>[] = [];
452
- if (eventData instanceof Array) {
453
- for (const event of eventData) {
454
- followData.push({ occurrence: event, parent: this.getParentEvent(event) });
455
- }
456
- } else {
457
- followData = { occurrence: eventData, parent: this.getParentEvent(eventData) };
458
- }
459
- const updateFollowEvents: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
460
- const args: ActionEventArgs = {
461
- requestType: action === 'EditFollowingEvents' ? 'eventChange' : 'eventRemove', cancel: false,
462
- addedRecords: [], changedRecords: updateFollowEvents, deletedRecords: []
463
- };
464
- args.data = followData;
465
- this.parent.trigger(events.actionBegin, args, (followArgs: ActionEventArgs) => {
466
- if (!followArgs.cancel) {
467
- const fields: EventFieldsMapping = this.parent.eventFields;
468
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
469
- const followEvents: Record<string, any>[] = followData instanceof Array ? followData : [followData];
470
- for (let a: number = 0, count: number = followArgs.changedRecords.length; a < count; a++) {
471
- const childEvent: Record<string, any> = followArgs.changedRecords[parseInt(a.toString(), 10)];
472
- const parentEvent: Record<string, any> = followEvents[parseInt(a.toString(), 10)].parent as Record<string, any>;
473
- const followData: { [key: string]: Record<string, any>[] } = this.parent.eventBase.getEventCollections(parentEvent, childEvent) as { [key: string]: Record<string, any>[] };
474
- let isSpanned: boolean;
475
- switch (action) {
476
- case 'EditFollowingEvents':
477
- this.processRecurrenceRule(parentEvent, childEvent);
478
- isSpanned = !this.parent.eventBase.isFollowingEvent(parentEvent, childEvent);
479
- childEvent[fields.followingID] = isSpanned ? null : parentEvent[fields.id];
480
- childEvent[fields.recurrenceID] = null;
481
- editParams.addedRecords.push(this.parent.eventBase.processTimezone(childEvent, true));
482
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEvent, true));
483
- if (!this.parent.uiStateValues.isIgnoreOccurrence) {
484
- childEvent[fields.recurrenceException] = null;
485
- if (followData.occurrence.length > 0) {
486
- const rule: string = followData.occurrence.slice(-1)[0][fields.recurrenceRule] as string;
487
- if (rule.indexOf('COUNT') === -1) {
488
- childEvent[fields.recurrenceRule] = rule;
489
- }
490
- }
491
- if (followData.follow.length > 0) {
492
- childEvent[fields.recurrenceRule] = followData.follow.slice(-1)[0][fields.recurrenceRule];
493
- editParams.deletedRecords = editParams.deletedRecords.concat(followData.follow);
494
- }
495
- if (isSpanned) {
496
- followData.occurrence = followData.occurrence.filter((eventObj: Record<string, any>) =>
497
- eventObj[fields.recurrenceID] === parentEvent[fields.id]);
498
- }
499
- editParams.deletedRecords = editParams.deletedRecords.concat(followData.occurrence);
500
- }
501
- break;
502
- case 'DeleteFollowingEvents':
503
- this.processRecurrenceRule(parentEvent, childEvent[fields.startTime] as Date);
504
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEvent, true));
505
- editParams.deletedRecords = editParams.deletedRecords.concat(followData.occurrence).concat(followData.follow);
506
- break;
507
- }
508
- }
509
- const promise: Promise<any> = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
510
- const cloneEvent: Record<string, any> = extend({}, followArgs.changedRecords[followArgs.changedRecords.length - 1], null, true) as Record<string, any>;
511
- this.parent.eventBase.selectWorkCellByTime(action === 'EditFollowingEvents' ? [this.parent.eventBase.processTimezone(cloneEvent)] : [cloneEvent]);
512
- const crudArgs: CrudArgs = {
513
- requestType: action === 'EditFollowingEvents' ? 'eventChanged' : 'eventRemoved',
514
- cancel: false, data: followArgs.changedRecords, promise: promise, editParams: editParams
515
- };
516
- this.refreshData(crudArgs);
517
- }
518
- });
519
- }
520
-
521
- private processEntireSeries(eventData: Record<string, any> | Record<string, any>[], action: CurrentAction): void {
522
- let seriesData: Record<string, any> | Record<string, any>[] = [];
523
- let isDeletedRecords: boolean = false;
524
- if (eventData instanceof Array) {
525
- for (const event of eventData) {
526
- seriesData.push(this.getParentEvent(event, true));
527
- }
528
- } else {
529
- seriesData = this.getParentEvent(eventData, true);
530
- }
531
- const updateSeriesEvents: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
532
- const args: ActionEventArgs = {
533
- requestType: action === 'EditSeries' ? 'eventChange' : 'eventRemove', cancel: false,
534
- addedRecords: [], changedRecords: [], deletedRecords: []
535
- };
536
- args.data = seriesData;
537
- if (action === 'EditSeries') {
538
- args.changedRecords = updateSeriesEvents;
539
- } else {
540
- args.deletedRecords = updateSeriesEvents;
541
- }
542
- if (action === 'EditSeries' && !this.parent.uiStateValues.isIgnoreOccurrence) {
543
- const seriesEvents: Record<string, any>[] = seriesData instanceof Array ? seriesData : [seriesData];
544
- for (let a: number = 0, count: number = args.changedRecords.length; a < count; a++) {
545
- const parentEvent: Record<string, any> = seriesEvents[parseInt(a.toString(), 10)];
546
- const eventCollections: { [key: string]: Record<string, any>[] } = this.parent.eventBase.getEventCollections(parentEvent);
547
- const deletedEvents: Record<string, any>[] = eventCollections.follow.concat(eventCollections.occurrence);
548
- args.deletedRecords = args.deletedRecords.concat(deletedEvents);
549
- }
550
- }
551
- this.parent.trigger(events.actionBegin, args, (seriesArgs: ActionEventArgs) => {
552
- if (!seriesArgs.cancel) {
553
- const fields: EventFieldsMapping = this.parent.eventFields;
554
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
555
- const seriesEvents: Record<string, any>[] = seriesData instanceof Array ? seriesData : [seriesData];
556
- const records: Record<string, any>[] = action === 'EditSeries' ? seriesArgs.changedRecords : seriesArgs.deletedRecords;
557
- for (let a: number = 0, count: number = records.length; a < count; a++) {
558
- const childEvent: Record<string, any> = records[parseInt(a.toString(), 10)];
559
- const parentEvent: Record<string, any> = seriesEvents[parseInt(a.toString(), 10)];
560
- const eventCollections: { [key: string]: Record<string, any>[] } = this.parent.eventBase.getEventCollections(parentEvent);
561
- const deletedEvents: Record<string, any>[] = eventCollections.follow.concat(eventCollections.occurrence);
562
- switch (action) {
563
- case 'EditSeries':
564
- childEvent[fields.id] = parentEvent[fields.id];
565
- childEvent[fields.recurrenceID] = null;
566
- childEvent[fields.followingID] = null;
567
- if (this.parent.uiStateValues.isIgnoreOccurrence && childEvent[fields.recurrenceException]) {
568
- const originalParent: Record<string, any>[] = this.parent.eventsData.filter((eventObj: Record<string, any>) =>
569
- eventObj[fields.id] === childEvent[fields.id]) as Record<string, any>[];
570
- if (originalParent.length > 0) {
571
- childEvent[fields.recurrenceRule] = originalParent[0][fields.recurrenceRule];
572
- }
573
- } else {
574
- childEvent[fields.recurrenceException] = null;
575
- editParams.deletedRecords = editParams.deletedRecords.concat(deletedEvents);
576
- }
577
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(childEvent, true));
578
- this.parent.uiStateValues.isIgnoreOccurrence = false;
579
- break;
580
- case 'DeleteSeries':
581
- editParams.deletedRecords = editParams.deletedRecords.concat(deletedEvents.concat(
582
- this.parent.eventBase.processTimezone(parentEvent, true)
583
- ));
584
- isDeletedRecords = true;
585
- break;
586
- }
587
- }
588
- const promise: Promise<any> = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
589
- const cloneEvent: Record<string, any> = extend({}, records[records.length - 1], null, true) as Record<string, any>;
590
- this.parent.eventBase.selectWorkCellByTime(action === 'EditSeries' ? [this.parent.eventBase.processTimezone(cloneEvent)] : [cloneEvent]);
591
- const crudArgs: CrudArgs = {
592
- requestType: action === 'EditSeries' ? 'eventChanged' : 'eventRemoved',
593
- cancel: false, data: isDeletedRecords ? seriesArgs.deletedRecords : seriesArgs.changedRecords,
594
- promise: promise, editParams: editParams
595
- };
596
- this.refreshData(crudArgs);
597
- }
598
- });
599
- }
600
-
601
- private processDelete(eventData: Record<string, any>[]): void {
602
- const deleteData: Record<string, any>[] = [];
603
- for (const eventObj of eventData) {
604
- if (eventObj[this.parent.eventFields.recurrenceRule]) {
605
- deleteData.push({ occurrence: eventObj, parent: this.getParentEvent(eventObj) });
606
- } else {
607
- deleteData.push(eventObj);
608
- }
609
- }
610
- const args: ActionEventArgs = {
611
- requestType: 'eventRemove', cancel: false,
612
- addedRecords: [], changedRecords: [], deletedRecords: eventData
613
- };
614
- args.data = deleteData;
615
- this.parent.trigger(events.actionBegin, args, (deleteArgs: ActionEventArgs) => {
616
- if (!deleteArgs.cancel) {
617
- const fields: EventFieldsMapping = this.parent.eventFields;
618
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
619
- const cloneEvents: Record<string, any>[] = extend([], deleteArgs.deletedRecords, null, true) as Record<string, any>[];
620
- for (let a: number = 0, count: number = deleteArgs.deletedRecords.length; a < count; a++) {
621
- let isDelete: boolean = isNullOrUndefined(deleteArgs.deletedRecords[parseInt(a.toString(), 10)][this.parent.eventFields.recurrenceRule]);
622
- if (!isDelete) {
623
- const parentEvent: Record<string, any> = deleteData[parseInt(a.toString(), 10)].parent as Record<string, any>;
624
- const isEdited: Record<string, any>[] = editParams.changedRecords.filter((obj: Record<string, any>) =>
625
- obj[fields.id] === parentEvent[fields.id]) as Record<string, any>[];
626
- const editedDate: Date = deleteArgs.deletedRecords[parseInt(a.toString(), 10)][fields.startTime] as Date;
627
- if (isEdited.length > 0) {
628
- const editedData: Record<string, any> = isEdited[0];
629
- editedData[fields.recurrenceException] =
630
- this.excludeDateCheck(editedDate, <string>editedData[fields.recurrenceException]);
631
- } else {
632
- parentEvent[fields.recurrenceException] =
633
- this.excludeDateCheck(editedDate, <string>parentEvent[fields.recurrenceException]);
634
- }
635
- if (isEdited.length === 0) {
636
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEvent, true));
637
- }
638
- isDelete = deleteArgs.deletedRecords[parseInt(a.toString(), 10)][fields.id] !== parentEvent[fields.id];
639
- }
640
- if (isDelete) {
641
- if (deleteArgs.deletedRecords instanceof Array) {
642
- for (const event of deleteArgs.deletedRecords) {
643
- this.parent.eventBase.processTimezone(event, true);
644
- }
645
- }
646
- editParams.deletedRecords.push(deleteArgs.deletedRecords[parseInt(a.toString(), 10)]);
647
- }
648
- }
649
- const promise: Promise<any> = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
650
- this.parent.eventBase.selectWorkCellByTime(cloneEvents);
651
- const crudArgs: CrudArgs = {
652
- requestType: 'eventRemoved', cancel: false, data: deleteArgs.deletedRecords, promise: promise, editParams: editParams
653
- };
654
- this.refreshData(crudArgs);
655
- }
656
- });
657
- }
658
-
659
- private processSave(data: Record<string, any> | Record<string, any>[]): void {
660
- const eventData: Record<string, any>[] = (data instanceof Array) ? data : [data];
661
- const editData: Record<string, any>[] = [];
662
- for (const eventObj of eventData) {
663
- if (eventObj[this.parent.eventFields.recurrenceRule]) {
664
- editData.push({ occurrence: eventObj, parent: this.getParentEvent(eventObj) });
665
- } else {
666
- editData.push(eventObj);
667
- }
668
- }
669
- const args: ActionEventArgs = { requestType: 'eventChange', cancel: false, addedRecords: [], changedRecords: eventData, deletedRecords: [] };
670
- args.data = editData;
671
- this.parent.trigger(events.actionBegin, args, (editArgs: ActionEventArgs) => {
672
- if (!editArgs.cancel) {
673
- const fields: EventFieldsMapping = this.parent.eventFields;
674
- const editParams: SaveChanges = { addedRecords: [], changedRecords: [], deletedRecords: [] };
675
- for (const record of editArgs.changedRecords) {
676
- if (!isNullOrUndefined(record[fields.recurrenceRule]) && isNullOrUndefined(record[fields.recurrenceException])) {
677
- const exceptionString: string = getRecurrenceStringFromDate(record[fields.startTime]);
678
- const parentEle: Record<string, any> = this.getParentEvent(record);
679
- parentEle[fields.recurrenceException] = isNullOrUndefined(parentEle[fields.recurrenceException]) ?
680
- exceptionString : parentEle[fields.recurrenceException].concat(',' + exceptionString);
681
- record[fields.id] = this.parent.getEventMaxID();
682
- record[fields.recurrenceException] = exceptionString;
683
- editParams.addedRecords.push(this.parent.eventBase.processTimezone(record, true));
684
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(parentEle, true));
685
- } else {
686
- editParams.changedRecords.push(this.parent.eventBase.processTimezone(record, true));
687
- }
688
- }
689
- const promise: Promise<any> = this.parent.dataModule.dataManager.saveChanges(editParams, fields.id, this.getTable(), this.getQuery()) as Promise<any>;
690
- const cloneEvent: Record<string, any> = extend({}, editArgs.changedRecords[editArgs.changedRecords.length - 1], null, true) as Record<string, any>;
691
- this.parent.eventBase.selectWorkCellByTime([this.parent.eventBase.processTimezone(cloneEvent)]);
692
- const crudArgs: CrudArgs = { requestType: 'eventChanged', cancel: false, data: editArgs.changedRecords, promise: promise, editParams: editParams };
693
- this.refreshData(crudArgs);
694
- }
695
- });
696
- }
697
-
698
- private getParentEvent(event: Record<string, any>, isParent: boolean = false): Record<string, any> {
699
- const parentEvent: Record<string, any> = this.parent.eventBase.getParentEvent(event, isParent) || event;
700
- if (parentEvent[this.parent.eventFields.startTimezone] || parentEvent[this.parent.eventFields.endTimezone]) {
701
- this.parent.eventBase.timezoneConvert(parentEvent);
702
- }
703
- return parentEvent;
704
- }
705
-
706
- private excludeDateCheck(eventStartTime: Date, exceptionDateList: string): string {
707
- const timezone: string = this.parent.timezone || this.parent.tzModule.getLocalTimezoneName();
708
- if (timezone) {
709
- eventStartTime = this.parent.tzModule.remove(new Date(+eventStartTime.getTime()), timezone);
710
- }
711
- const exDate: string = getRecurrenceStringFromDate(eventStartTime);
712
- if (!isNullOrUndefined(exceptionDateList)) {
713
- if (exceptionDateList.indexOf(exDate) === -1) {
714
- exceptionDateList = !(isNullOrUndefined(exceptionDateList)) ? exceptionDateList + ',' + exDate : exDate;
715
- }
716
- } else {
717
- exceptionDateList = exDate;
718
- }
719
- return exceptionDateList;
720
- }
721
-
722
- private processRecurrenceRule(parentEvent: Record<string, any>, followEvent?: Record<string, any> | Date): void {
723
- const fields: EventFieldsMapping = this.parent.eventFields;
724
- const recurrenceRule: string = parentEvent[fields.recurrenceRule] as string;
725
- let endDate: Date;
726
- if (followEvent instanceof Date) {
727
- endDate = new Date(+followEvent);
728
- } else {
729
- endDate = new Date(+followEvent[fields.startTime]);
730
- const newRecurrenceRule: string = followEvent[fields.recurrenceRule] as string;
731
- if (newRecurrenceRule) {
732
- const startDate: Date = parentEvent[fields.startTime] as Date;
733
- const ruleException: string = (this.parent.currentAction === 'DeleteFollowingEvents') ? followEvent[fields.recurrenceException] as string : null;
734
- const dateCollection: number[] = generate(startDate, newRecurrenceRule, ruleException, this.parent.activeViewOptions.firstDayOfWeek);
735
- const untilDate: Date = new Date(dateCollection.slice(-1)[0]);
736
- untilDate.setHours(endDate.getHours(), endDate.getMinutes(), endDate.getSeconds());
737
- endDate.setHours(startDate.getHours(), startDate.getMinutes(), startDate.getSeconds());
738
- followEvent[fields.recurrenceRule] = this.getUpdatedRecurrenceRule(newRecurrenceRule, new Date(+untilDate), false);
739
- }
740
- }
741
- parentEvent[fields.recurrenceRule] = this.getUpdatedRecurrenceRule(recurrenceRule, util.addDays(new Date(endDate.getTime()), -1), true);
742
- }
743
-
744
- private getUpdatedRecurrenceRule(recurrenceRule: string, untilDate: Date, isParent: boolean): string {
745
- const splitRule: string[] = recurrenceRule.split(';');
746
- let updatedRule: string = '';
747
- for (let rule of splitRule) {
748
- if (rule !== '') {
749
- const ruleKey: string = rule.split('=')[0];
750
- let ruleValue: string = rule.split('=')[1];
751
- if (ruleKey === 'COUNT' || ruleKey === 'UNTIL') {
752
- ruleValue = getRecurrenceStringFromDate(untilDate);
753
- rule = rule.replace(rule, 'UNTIL=' + ruleValue);
754
- }
755
- updatedRule += rule + ';';
756
- }
757
- }
758
- if (isParent && updatedRule.indexOf('UNTIL') === -1) {
759
- updatedRule += 'UNTIL=' + getRecurrenceStringFromDate(untilDate);
760
- }
761
- return updatedRule;
762
- }
763
-
764
- private isBlockEvent(eventData: Record<string, any> | Record<string, any>[]): boolean {
765
- const eventCollection: Record<string, any>[] = (eventData instanceof Array) ? eventData : [eventData];
766
- let value: boolean = false;
767
- for (const event of eventCollection) {
768
- value = event[this.parent.eventFields.isBlock] as boolean || false;
769
- }
770
- return value;
771
- }
772
-
773
- /**
774
- * To destroy the crud module.
775
- *
776
- * @returns {void}
777
- * @private
778
- */
779
- public destroy(): void {
780
- this.crudObj = null;
781
- this.parent = null;
782
- }
783
-
784
- }