@syncfusion/ej2-schedule 31.1.17 → 31.1.20

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 (167) 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 +1 -1
  5. package/dist/es6/ej2-schedule.es2015.js.map +1 -1
  6. package/dist/es6/ej2-schedule.es5.js +1 -1
  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 +17 -52
  12. package/src/schedule/event-renderer/event-base.js +1 -1
  13. package/styles/bootstrap4-lite.css +8 -0
  14. package/styles/bootstrap4.css +8 -0
  15. package/styles/recurrence-editor/bootstrap4.css +8 -0
  16. package/styles/schedule/bootstrap4.css +8 -0
  17. package/dist/ts/common/calendar-util.d.ts +0 -92
  18. package/dist/ts/common/calendar-util.ts +0 -261
  19. package/dist/ts/common/index.d.ts +0 -4
  20. package/dist/ts/common/index.ts +0 -4
  21. package/dist/ts/components.d.ts +0 -5
  22. package/dist/ts/components.ts +0 -5
  23. package/dist/ts/index.d.ts +0 -6
  24. package/dist/ts/index.ts +0 -7
  25. package/dist/ts/recurrence-editor/date-generator.d.ts +0 -76
  26. package/dist/ts/recurrence-editor/date-generator.ts +0 -1699
  27. package/dist/ts/recurrence-editor/index.d.ts +0 -6
  28. package/dist/ts/recurrence-editor/index.ts +0 -6
  29. package/dist/ts/recurrence-editor/recurrence-editor-model.d.ts +0 -112
  30. package/dist/ts/recurrence-editor/recurrence-editor.d.ts +0 -245
  31. package/dist/ts/recurrence-editor/recurrence-editor.ts +0 -1257
  32. package/dist/ts/schedule/actions/action-base.d.ts +0 -44
  33. package/dist/ts/schedule/actions/action-base.ts +0 -493
  34. package/dist/ts/schedule/actions/crud.d.ts +0 -41
  35. package/dist/ts/schedule/actions/crud.ts +0 -784
  36. package/dist/ts/schedule/actions/data.d.ts +0 -63
  37. package/dist/ts/schedule/actions/data.ts +0 -128
  38. package/dist/ts/schedule/actions/drag.d.ts +0 -75
  39. package/dist/ts/schedule/actions/drag.ts +0 -1401
  40. package/dist/ts/schedule/actions/keyboard.d.ts +0 -100
  41. package/dist/ts/schedule/actions/keyboard.ts +0 -1435
  42. package/dist/ts/schedule/actions/resize.d.ts +0 -27
  43. package/dist/ts/schedule/actions/resize.ts +0 -602
  44. package/dist/ts/schedule/actions/scroll.d.ts +0 -69
  45. package/dist/ts/schedule/actions/scroll.ts +0 -105
  46. package/dist/ts/schedule/actions/touch.d.ts +0 -32
  47. package/dist/ts/schedule/actions/touch.ts +0 -314
  48. package/dist/ts/schedule/actions/virtual-scroll.d.ts +0 -55
  49. package/dist/ts/schedule/actions/virtual-scroll.ts +0 -596
  50. package/dist/ts/schedule/actions/work-cells.d.ts +0 -14
  51. package/dist/ts/schedule/actions/work-cells.ts +0 -151
  52. package/dist/ts/schedule/base/constant.d.ts +0 -102
  53. package/dist/ts/schedule/base/constant.ts +0 -103
  54. package/dist/ts/schedule/base/css-constant.d.ts +0 -475
  55. package/dist/ts/schedule/base/css-constant.ts +0 -475
  56. package/dist/ts/schedule/base/interface.d.ts +0 -673
  57. package/dist/ts/schedule/base/interface.ts +0 -738
  58. package/dist/ts/schedule/base/resource.d.ts +0 -59
  59. package/dist/ts/schedule/base/resource.ts +0 -1091
  60. package/dist/ts/schedule/base/schedule-model.d.ts +0 -930
  61. package/dist/ts/schedule/base/schedule.d.ts +0 -1967
  62. package/dist/ts/schedule/base/schedule.ts +0 -4221
  63. package/dist/ts/schedule/base/type.d.ts +0 -134
  64. package/dist/ts/schedule/base/type.ts +0 -142
  65. package/dist/ts/schedule/base/util.d.ts +0 -266
  66. package/dist/ts/schedule/base/util.ts +0 -492
  67. package/dist/ts/schedule/event-renderer/agenda-base.d.ts +0 -15
  68. package/dist/ts/schedule/event-renderer/agenda-base.ts +0 -423
  69. package/dist/ts/schedule/event-renderer/event-base.d.ts +0 -101
  70. package/dist/ts/schedule/event-renderer/event-base.ts +0 -1501
  71. package/dist/ts/schedule/event-renderer/inline-edit.d.ts +0 -23
  72. package/dist/ts/schedule/event-renderer/inline-edit.ts +0 -287
  73. package/dist/ts/schedule/event-renderer/month.d.ts +0 -60
  74. package/dist/ts/schedule/event-renderer/month.ts +0 -760
  75. package/dist/ts/schedule/event-renderer/timeline-view.d.ts +0 -51
  76. package/dist/ts/schedule/event-renderer/timeline-view.ts +0 -606
  77. package/dist/ts/schedule/event-renderer/vertical-view.d.ts +0 -57
  78. package/dist/ts/schedule/event-renderer/vertical-view.ts +0 -898
  79. package/dist/ts/schedule/event-renderer/year.d.ts +0 -27
  80. package/dist/ts/schedule/event-renderer/year.ts +0 -623
  81. package/dist/ts/schedule/exports/calendar-export.d.ts +0 -16
  82. package/dist/ts/schedule/exports/calendar-export.ts +0 -160
  83. package/dist/ts/schedule/exports/calendar-import.d.ts +0 -18
  84. package/dist/ts/schedule/exports/calendar-import.ts +0 -277
  85. package/dist/ts/schedule/exports/excel-export.d.ts +0 -14
  86. package/dist/ts/schedule/exports/excel-export.ts +0 -89
  87. package/dist/ts/schedule/exports/index.d.ts +0 -7
  88. package/dist/ts/schedule/exports/index.ts +0 -7
  89. package/dist/ts/schedule/exports/print.d.ts +0 -20
  90. package/dist/ts/schedule/exports/print.ts +0 -233
  91. package/dist/ts/schedule/index.d.ts +0 -26
  92. package/dist/ts/schedule/index.ts +0 -26
  93. package/dist/ts/schedule/models/event-settings-model.d.ts +0 -165
  94. package/dist/ts/schedule/models/event-settings.d.ts +0 -149
  95. package/dist/ts/schedule/models/event-settings.ts +0 -187
  96. package/dist/ts/schedule/models/field-options-model.d.ts +0 -37
  97. package/dist/ts/schedule/models/field-options.d.ts +0 -31
  98. package/dist/ts/schedule/models/field-options.ts +0 -41
  99. package/dist/ts/schedule/models/fields-model.d.ts +0 -129
  100. package/dist/ts/schedule/models/fields.d.ts +0 -117
  101. package/dist/ts/schedule/models/fields.ts +0 -149
  102. package/dist/ts/schedule/models/group-model.d.ts +0 -69
  103. package/dist/ts/schedule/models/group.d.ts +0 -60
  104. package/dist/ts/schedule/models/group.ts +0 -75
  105. package/dist/ts/schedule/models/header-rows-model.d.ts +0 -33
  106. package/dist/ts/schedule/models/header-rows.d.ts +0 -30
  107. package/dist/ts/schedule/models/header-rows.ts +0 -35
  108. package/dist/ts/schedule/models/models.d.ts +0 -14
  109. package/dist/ts/schedule/models/models.ts +0 -15
  110. package/dist/ts/schedule/models/quick-info-templates-model.d.ts +0 -52
  111. package/dist/ts/schedule/models/quick-info-templates.d.ts +0 -47
  112. package/dist/ts/schedule/models/quick-info-templates.ts +0 -56
  113. package/dist/ts/schedule/models/resources-model.d.ts +0 -122
  114. package/dist/ts/schedule/models/resources.d.ts +0 -106
  115. package/dist/ts/schedule/models/resources.ts +0 -138
  116. package/dist/ts/schedule/models/time-scale-model.d.ts +0 -57
  117. package/dist/ts/schedule/models/time-scale.d.ts +0 -50
  118. package/dist/ts/schedule/models/time-scale.ts +0 -61
  119. package/dist/ts/schedule/models/toolbar-model.d.ts +0 -196
  120. package/dist/ts/schedule/models/toolbar.d.ts +0 -176
  121. package/dist/ts/schedule/models/toolbar.ts +0 -196
  122. package/dist/ts/schedule/models/views-model.d.ts +0 -370
  123. package/dist/ts/schedule/models/views.d.ts +0 -335
  124. package/dist/ts/schedule/models/views.ts +0 -408
  125. package/dist/ts/schedule/models/work-hours-model.d.ts +0 -29
  126. package/dist/ts/schedule/models/work-hours.d.ts +0 -24
  127. package/dist/ts/schedule/models/work-hours.ts +0 -31
  128. package/dist/ts/schedule/popups/event-tooltip.d.ts +0 -16
  129. package/dist/ts/schedule/popups/event-tooltip.ts +0 -203
  130. package/dist/ts/schedule/popups/event-window.d.ts +0 -118
  131. package/dist/ts/schedule/popups/event-window.ts +0 -2055
  132. package/dist/ts/schedule/popups/form-validator.d.ts +0 -16
  133. package/dist/ts/schedule/popups/form-validator.ts +0 -110
  134. package/dist/ts/schedule/popups/quick-popups.d.ts +0 -78
  135. package/dist/ts/schedule/popups/quick-popups.ts +0 -1470
  136. package/dist/ts/schedule/renderer/agenda.d.ts +0 -45
  137. package/dist/ts/schedule/renderer/agenda.ts +0 -497
  138. package/dist/ts/schedule/renderer/day.d.ts +0 -20
  139. package/dist/ts/schedule/renderer/day.ts +0 -28
  140. package/dist/ts/schedule/renderer/header-renderer.d.ts +0 -48
  141. package/dist/ts/schedule/renderer/header-renderer.ts +0 -736
  142. package/dist/ts/schedule/renderer/month-agenda.d.ts +0 -29
  143. package/dist/ts/schedule/renderer/month-agenda.ts +0 -184
  144. package/dist/ts/schedule/renderer/month.d.ts +0 -61
  145. package/dist/ts/schedule/renderer/month.ts +0 -766
  146. package/dist/ts/schedule/renderer/renderer.d.ts +0 -13
  147. package/dist/ts/schedule/renderer/renderer.ts +0 -165
  148. package/dist/ts/schedule/renderer/timeline-header-row.d.ts +0 -15
  149. package/dist/ts/schedule/renderer/timeline-header-row.ts +0 -132
  150. package/dist/ts/schedule/renderer/timeline-month.d.ts +0 -29
  151. package/dist/ts/schedule/renderer/timeline-month.ts +0 -184
  152. package/dist/ts/schedule/renderer/timeline-view.d.ts +0 -31
  153. package/dist/ts/schedule/renderer/timeline-view.ts +0 -308
  154. package/dist/ts/schedule/renderer/timeline-year.d.ts +0 -22
  155. package/dist/ts/schedule/renderer/timeline-year.ts +0 -450
  156. package/dist/ts/schedule/renderer/vertical-view.d.ts +0 -63
  157. package/dist/ts/schedule/renderer/vertical-view.ts +0 -911
  158. package/dist/ts/schedule/renderer/view-base.d.ts +0 -83
  159. package/dist/ts/schedule/renderer/view-base.ts +0 -709
  160. package/dist/ts/schedule/renderer/week.d.ts +0 -22
  161. package/dist/ts/schedule/renderer/week.ts +0 -35
  162. package/dist/ts/schedule/renderer/work-week.d.ts +0 -22
  163. package/dist/ts/schedule/renderer/work-week.ts +0 -36
  164. package/dist/ts/schedule/renderer/year.d.ts +0 -46
  165. package/dist/ts/schedule/renderer/year.ts +0 -470
  166. package/dist/ts/schedule/timezone/timezone.d.ts +0 -16
  167. package/dist/ts/schedule/timezone/timezone.ts +0 -313
@@ -1,308 +0,0 @@
1
- import { isNullOrUndefined, createElement, prepend, extend, formatUnit, append, setStyleAttribute } from '@syncfusion/ej2-base';
2
- import { Schedule } from '../base/schedule';
3
- import { VerticalView } from './vertical-view';
4
- import { TimelineEvent } from '../event-renderer/timeline-view';
5
- import { CallbackFunction, TdData, TimeSlotData } from '../base/interface';
6
- import { TimelineHeaderRow } from './timeline-header-row';
7
- import * as event from '../base/constant';
8
- import * as cls from '../base/css-constant';
9
- import * as util from '../base/util';
10
-
11
- /**
12
- * timeline views
13
- */
14
- export class TimelineViews extends VerticalView {
15
- private timelineAppointment: TimelineEvent = null;
16
-
17
- constructor(parent: Schedule) {
18
- super(parent);
19
- this.baseCssClass = 'e-timeline-view';
20
- }
21
-
22
- protected getModuleName(): string {
23
- return 'timelineViews';
24
- }
25
-
26
- public getLeftPanelElement(): HTMLElement {
27
- return this.element.querySelector('.' + cls.RESOURCE_COLUMN_WRAP_CLASS) as HTMLElement;
28
- }
29
-
30
- public scrollTopPanel(target: HTMLElement): void {
31
- super.scrollTopPanel(target);
32
- this.scrollHeaderLabels(target);
33
- }
34
-
35
- public scrollToWorkHour(): void {
36
- const start: Date = this.parent.getStartEndTime(this.parent.workHours.start);
37
- const currDateTime: number = this.isWorkDay(this.parent.selectedDate) && this.parent.workHours.highlight &&
38
- !isNullOrUndefined(start) ? new Date(+this.parent.selectedDate).setHours(start.getHours(), start.getMinutes(), 0, 0)
39
- : new Date(+this.parent.selectedDate).setHours(0, 0, 0, 0);
40
- const queryString: string = '[data-date="' + new Date(currDateTime).getTime().toString() + '"]';
41
- const firstWorkHourCell: HTMLElement = this.element.querySelector(queryString) as HTMLElement;
42
- if (firstWorkHourCell) {
43
- this.getContentAreaElement().scrollLeft = !this.parent.enableRtl ? firstWorkHourCell.offsetLeft :
44
- -(this.parent.getContentTable().offsetWidth - firstWorkHourCell.offsetLeft - firstWorkHourCell.offsetWidth);
45
- }
46
- }
47
-
48
- public scrollToHour(hour: string, scrollDate: Date): void {
49
- let date: Date;
50
- let index: number;
51
- if (scrollDate) {
52
- index = this.parent.getIndexOfDate(this.renderDates, util.resetTime(scrollDate));
53
- if (index >= 0) {
54
- date = scrollDate;
55
- if (!isNullOrUndefined(hour)) {
56
- const timeString: string[] = hour.split(':');
57
- if (timeString.length === 2) {
58
- date = new Date(scrollDate.setHours(parseInt(timeString[0], 10), parseInt(timeString[1], 10), 0));
59
- }
60
- }
61
- }
62
- }
63
- date = isNullOrUndefined(scrollDate) ? this.parent.getStartEndTime(hour) : date;
64
- if (isNullOrUndefined(date)) {
65
- return;
66
- }
67
- let scrollLeft: number;
68
- if (isNullOrUndefined(hour) || !this.parent.activeViewOptions.timeScale.enable) {
69
- scrollLeft = index * this.parent.getElementWidth(this.element.querySelector('.e-work-cells'));
70
- } else {
71
- scrollLeft = isNullOrUndefined(scrollDate) ? this.getLeftFromDateTime(null, date) :
72
- this.getLeftFromDateTime([index], date);
73
- }
74
- this.getScrollableElement().scrollLeft = !this.parent.enableRtl ? scrollLeft : -scrollLeft;
75
- }
76
-
77
- public generateColumnLevels(): TdData[][] {
78
- let levels: TdData[][] = [];
79
- const dateSlots: TdData[] = this.getDateSlots(this.renderDates, this.parent.activeViewOptions.workDays);
80
- levels.push(dateSlots);
81
- if (this.parent.activeViewOptions.group.resources.length > 0) {
82
- this.parent.resourceBase.generateResourceLevels(dateSlots, !this.parent.uiStateValues.isGroupAdaptive);
83
- }
84
- let hourSlots: TdData[] = [];
85
- if (this.parent.activeViewOptions.timeScale.enable) {
86
- hourSlots = this.generateTimeSlots(levels[levels.length - 1]);
87
- levels.push(hourSlots);
88
- }
89
- if (this.parent.activeViewOptions.headerRows.length > 0) {
90
- const renderGn: TimelineHeaderRow = new TimelineHeaderRow(this.parent, this.renderDates);
91
- levels = renderGn.generateColumnLevels(dateSlots, hourSlots);
92
- }
93
- return levels;
94
- }
95
-
96
- private generateTimeSlots(dateSlots: TdData[]): TdData[] {
97
- const handler: CallbackFunction = (r: TimeSlotData): TimeSlotData => {
98
- r.type = r.first ? 'majorSlot' : 'minorSlot';
99
- r.className = r.first ? [cls.TIME_SLOT_CLASS] : [cls.TIME_SLOT_CLASS, cls.TIME_CELLS_CLASS];
100
- r.workDays = this.parent.activeViewOptions.workDays;
101
- return r;
102
- };
103
- const timeSlotData: TimeSlotData[] = this.getTimeSlotRows(handler);
104
- const slots: TdData[] = [];
105
- for (const data of dateSlots) {
106
- data.colSpan = timeSlotData.length;
107
- const tempTimeSlots: TdData[] = <TdData[]>extend([], timeSlotData, null, true);
108
- for (const slot of tempTimeSlots) {
109
- const cellDate: Date = util.resetTime(new Date('' + data.date));
110
- slot.date = util.setTime(cellDate, util.getDateInMs(slot.date));
111
- slots.push(slot);
112
- }
113
- }
114
- return slots;
115
- }
116
-
117
- public changeCurrentTimePosition(): void {
118
- if (!this.parent || this.parent && this.parent.isDestroyed) { return; }
119
- this.removeCurrentTimeIndicatorElements();
120
- const currentDateIndex: number[] = this.getCurrentTimeIndicatorIndex();
121
- const left: number = this.getLeftFromDateTime(currentDateIndex, this.parent.getCurrentTime());
122
- const height: number = (this.element.querySelector('.' + cls.CONTENT_TABLE_CLASS) as HTMLElement).offsetHeight;
123
- const headerWrap: Element = this.element.querySelector('.' + cls.DATE_HEADER_WRAP_CLASS);
124
- const contentWrap: Element = this.element.querySelector('.' + cls.CONTENT_WRAP_CLASS);
125
- contentWrap.appendChild(createElement('div', {
126
- className: cls.CURRENT_TIMELINE_CLASS,
127
- styles: (this.parent.enableRtl ? 'right' : 'left') + ':' + formatUnit(left) + '; height:' + formatUnit(height)
128
- }));
129
- if (this.parent.virtualScrollModule) {
130
- const timeIndicator: HTMLElement = this.parent.element.querySelector('.' + cls.CURRENT_TIMELINE_CLASS) as HTMLElement;
131
- const element: HTMLElement = this.parent.element.querySelector('.' + cls.CONTENT_WRAP_CLASS + ' table');
132
- setStyleAttribute(timeIndicator, {
133
- transform: element.style.transform
134
- });
135
- }
136
- const currentTimeEle: HTMLElement = createElement('div', {
137
- innerHTML: this.parent.getTimeString(this.parent.getCurrentTime()),
138
- className: cls.CURRENT_TIME_CLASS
139
- });
140
- headerWrap.appendChild(currentTimeEle);
141
- currentTimeEle.style[this.parent.enableRtl ? 'right' : 'left'] = formatUnit(left - (currentTimeEle.offsetWidth / 2));
142
- }
143
-
144
- private getLeftFromDateTime(currentDateIndex: number[], date: Date): number {
145
- const startHour: Date = this.getStartHour();
146
- const endHour: Date = this.getEndHour();
147
- let diffInDates: number = 0;
148
- let diffInMinutes: number = ((date.getHours() - startHour.getHours()) * 60) + (date.getMinutes() - startHour.getMinutes());
149
- const hoursRange: { [key: string]: Date } =
150
- util.getStartEndHours(util.resetTime(new Date(date.getTime())), startHour, endHour);
151
- const totalMinutes: number = (hoursRange.endHour.getTime() - hoursRange.startHour.getTime()) / util.MS_PER_MINUTE;
152
- const timescaleInterval: number = this.parent.activeViewOptions.timeScale.interval;
153
- let interval: number = 0;
154
- if (startHour.getHours() === 0 && startHour.getMinutes() === 0 && endHour.getHours() === 0 && endHour.getMinutes() === 0) {
155
- interval = timescaleInterval;
156
- } else {
157
- interval = (this.parent.activeViewOptions.timeScale.slotCount !== 1) ? timescaleInterval :
158
- (timescaleInterval > totalMinutes ? totalMinutes : timescaleInterval);
159
- }
160
- if (!isNullOrUndefined(currentDateIndex)) {
161
- if (currentDateIndex[0] !== 0) {
162
- const index: number = this.parent.activeView.colLevels.findIndex((level: TdData[]) => level[0].type === 'dateHeader');
163
- if (this.parent.activeView.colLevels[parseInt(index.toString(), 10)] &&
164
- this.parent.activeView.colLevels[parseInt(index.toString(), 10)][0].colSpan) {
165
- diffInDates = currentDateIndex[0] * this.parent.activeView.colLevels[parseInt(index.toString(), 10)][0].colSpan *
166
- this.parent.getElementWidth(this.element.querySelector('.e-work-cells'));
167
- }
168
- else {
169
- const endHour: Date = this.getEndHour();
170
- const end: number = (endHour.getHours() === 0) ? 24 : endHour.getHours();
171
- diffInMinutes = diffInMinutes + ((currentDateIndex[0]) * (((end - startHour.getHours()) * 60) +
172
- (endHour.getMinutes() - startHour.getMinutes())));
173
- }
174
- }
175
- }
176
- return diffInDates + ((diffInMinutes * this.parent.getElementWidth(this.element.querySelector('.e-work-cells'))
177
- * this.parent.activeViewOptions.timeScale.slotCount) / interval);
178
- }
179
-
180
- public renderHeader(): void {
181
- const tr: Element = createElement('tr');
182
- if (this.parent.activeViewOptions.group.resources.length > 0 && !this.parent.uiStateValues.isGroupAdaptive) {
183
- this.parent.resourceBase.renderResourceHeaderIndent(tr);
184
- }
185
- const dateTd: Element = createElement('td');
186
- dateTd.appendChild(this.renderDatesHeader());
187
- tr.appendChild(dateTd);
188
- prepend([tr], this.element.querySelector('tbody'));
189
- }
190
-
191
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
192
- public createAllDayRow(table: Element, tdData: TdData[]): void { /** */ }
193
-
194
- public getCurrentTimeIndicatorIndex(): number[] {
195
- const currentDateIndex: number[] = [];
196
- const index: number = this.parent.getIndexOfDate(this.renderDates, util.resetTime(this.parent.getCurrentTime()));
197
- if (index >= 0) {
198
- currentDateIndex.push(index);
199
- }
200
- return currentDateIndex;
201
- }
202
-
203
- public renderContent(): void {
204
- const tr: Element = createElement('tr');
205
- if (this.parent.activeViewOptions.group.resources.length > 0 && !this.parent.uiStateValues.isGroupAdaptive) {
206
- const resTd: Element = createElement('td');
207
- resTd.appendChild(this.parent.resourceBase.createResourceColumn());
208
- tr.appendChild(resTd);
209
- }
210
- const workTd: Element = createElement('td');
211
- const wrap: Element = this.renderContentArea();
212
- wrap.appendChild(this.createEventTable(this.getRowCount()));
213
- this.collapseRows(wrap);
214
- workTd.appendChild(wrap);
215
- tr.appendChild(workTd);
216
- if (this.parent.virtualScrollModule) {
217
- this.parent.virtualScrollModule.renderVirtualTrack(wrap);
218
- }
219
- this.element.querySelector('tbody').appendChild(tr);
220
- }
221
-
222
- private getRowCount(): number {
223
- if (this.parent.activeViewOptions.group.resources.length > 0 && !this.parent.uiStateValues.isGroupAdaptive) {
224
- return this.parent.resourceBase.renderedResources.length;
225
- }
226
- return 1;
227
- }
228
-
229
- private getResourceTdData(i: number, tdData: TdData): TdData {
230
- const resLevel: TdData = this.parent.resourceBase.renderedResources[parseInt(i.toString(), 10)];
231
- const resSHr: string = (resLevel.resourceData[resLevel.resource.startHourField] as string) || this.parent.workHours.start;
232
- const resEHr: string = (resLevel.resourceData[resLevel.resource.endHourField] as string) || this.parent.workHours.end;
233
- tdData.startHour = this.parent.getStartEndTime(resSHr);
234
- tdData.endHour = this.parent.getStartEndTime(resEHr);
235
- tdData.workDays = (resLevel.resourceData[resLevel.resource.workDaysField] as number[]) || this.parent.workDays;
236
- tdData.className = resLevel.className;
237
- tdData.groupIndex = resLevel.groupIndex;
238
- tdData.groupOrder = resLevel.groupOrder;
239
- return tdData;
240
- }
241
-
242
- public renderContentTable(table: Element): void {
243
- const tBody: Element = table.querySelector('tbody');
244
- append(this.getContentRows(), tBody);
245
- }
246
-
247
- public getContentRows(): Element[] {
248
- const rows: Element[] = [];
249
- const tr: Element = createElement('tr');
250
- const td: Element = createElement('td');
251
- const trCount: number = this.getRowCount();
252
- const existingGroupIndices: number[] = this.getGroupIndices();
253
- for (let i: number = 0; i < trCount; i++) {
254
- if (existingGroupIndices.length > 0 &&
255
- existingGroupIndices.indexOf(this.parent.resourceBase.renderedResources[parseInt(i.toString(), 10)].groupIndex) > -1) {
256
- continue;
257
- }
258
- const ntr: Element = tr.cloneNode() as Element;
259
- for (let tdData of this.colLevels[this.colLevels.length - 1]) {
260
- if (this.parent.activeViewOptions.group.resources.length > 0 && !this.parent.uiStateValues.isGroupAdaptive) {
261
- tdData = this.getResourceTdData(i, tdData);
262
- }
263
- const ntd: Element = this.createContentTd(tdData, <TimeSlotData>tdData, td);
264
- ntr.appendChild(ntd);
265
- }
266
- rows.push(ntr);
267
- }
268
- return rows;
269
- }
270
-
271
- public getContentTdClass(r: TimeSlotData): string[] {
272
- return (r.first || !this.parent.activeViewOptions.timeScale.enable) ? [cls.WORK_CELLS_CLASS] :
273
- [cls.WORK_CELLS_CLASS, cls.ALTERNATE_CELLS_CLASS];
274
- }
275
-
276
- public renderEvents(): void {
277
- this.timelineAppointment = new TimelineEvent(this.parent, this.parent.activeViewOptions.timeScale.enable ? 'hour' : 'day');
278
- this.timelineAppointment.renderAppointments();
279
- this.parent.notify(event.eventsLoaded, {});
280
- }
281
-
282
- public getAdjustedDate(date: Date): Date {
283
- if (!this.parent.activeViewOptions.timeScale.enable) {
284
- return new Date(date.setHours(0, 0, 0, 0));
285
- } else {
286
- const timeSlots: TdData[] = this.colLevels[this.colLevels.length - 1];
287
- for (let i: number = 0; i < timeSlots.length; i++) {
288
- if (timeSlots[parseInt(i.toString(), 10)].date.getTime() > date.getTime()) {
289
- return timeSlots[i - 1].date;
290
- }
291
- }
292
- }
293
- return null;
294
- }
295
-
296
- public destroy(): void {
297
- if (!this.parent || this.parent && this.parent.isDestroyed) {
298
- this.parent = null;
299
- return;
300
- }
301
- if (this.timelineAppointment) {
302
- this.timelineAppointment.destroy();
303
- this.timelineAppointment = null;
304
- }
305
- super.destroy();
306
- }
307
-
308
- }
@@ -1,22 +0,0 @@
1
- import { Schedule } from '../base/schedule';
2
- import { Year } from './year';
3
- /**
4
- * timeline year view
5
- */
6
- export declare class TimelineYear extends Year {
7
- viewClass: string;
8
- isInverseTableSelect: boolean;
9
- constructor(parent: Schedule);
10
- protected getModuleName(): string;
11
- renderHeader(headerWrapper: HTMLElement): void;
12
- private renderResourceHeader;
13
- renderContent(contentWrapper: HTMLElement): void;
14
- private renderDefaultContent;
15
- getContentRows(): Element[];
16
- renderResourceContent(wrapper: HTMLElement, monthBody: HTMLTableSectionElement, contentBody: HTMLTableSectionElement): void;
17
- private renderDayMonthHeaderTemplate;
18
- private renderCellTemplate;
19
- scrollToDate(scrollDate: Date): void;
20
- getScrollableElement(): Element;
21
- private wireEvents;
22
- }