@bryntum/calendar-angular-thin 7.1.1

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 (46) hide show
  1. package/README.md +44 -0
  2. package/bryntum-calendar-angular-thin.d.ts +5 -0
  3. package/bundles/bryntum-calendar-angular-thin.umd.js +22195 -0
  4. package/bundles/bryntum-calendar-angular-thin.umd.js.map +1 -0
  5. package/esm2015/bryntum-calendar-angular-thin.js +5 -0
  6. package/esm2015/lib/bryntum-agenda-view.component.js +2503 -0
  7. package/esm2015/lib/bryntum-calendar-date-picker.component.js +1045 -0
  8. package/esm2015/lib/bryntum-calendar-project-model.component.js +369 -0
  9. package/esm2015/lib/bryntum-calendar.component.js +2355 -0
  10. package/esm2015/lib/bryntum-day-agenda-view.component.js +1338 -0
  11. package/esm2015/lib/bryntum-day-resource-view.component.js +1347 -0
  12. package/esm2015/lib/bryntum-day-view.component.js +1323 -0
  13. package/esm2015/lib/bryntum-event-list.component.js +2453 -0
  14. package/esm2015/lib/bryntum-mode-selector.component.js +702 -0
  15. package/esm2015/lib/bryntum-month-agenda-view.component.js +1201 -0
  16. package/esm2015/lib/bryntum-month-grid.component.js +1262 -0
  17. package/esm2015/lib/bryntum-month-view.component.js +1337 -0
  18. package/esm2015/lib/bryntum-range-menu.component.js +884 -0
  19. package/esm2015/lib/bryntum-resource-view.component.js +1068 -0
  20. package/esm2015/lib/bryntum-week-view.component.js +1323 -0
  21. package/esm2015/lib/bryntum-year-view.component.js +1163 -0
  22. package/esm2015/lib/calendar.module.js +99 -0
  23. package/esm2015/lib/wrapper.helper.js +74 -0
  24. package/esm2015/public-api.js +21 -0
  25. package/fesm2015/bryntum-calendar-angular-thin.js +21714 -0
  26. package/fesm2015/bryntum-calendar-angular-thin.js.map +1 -0
  27. package/lib/bryntum-agenda-view.component.d.ts +2953 -0
  28. package/lib/bryntum-calendar-date-picker.component.d.ts +1525 -0
  29. package/lib/bryntum-calendar-project-model.component.d.ts +399 -0
  30. package/lib/bryntum-calendar.component.d.ts +2577 -0
  31. package/lib/bryntum-day-agenda-view.component.d.ts +1960 -0
  32. package/lib/bryntum-day-resource-view.component.d.ts +2025 -0
  33. package/lib/bryntum-day-view.component.d.ts +1980 -0
  34. package/lib/bryntum-event-list.component.d.ts +2888 -0
  35. package/lib/bryntum-mode-selector.component.d.ts +851 -0
  36. package/lib/bryntum-month-agenda-view.component.d.ts +1765 -0
  37. package/lib/bryntum-month-grid.component.d.ts +1731 -0
  38. package/lib/bryntum-month-view.component.d.ts +1897 -0
  39. package/lib/bryntum-range-menu.component.d.ts +1130 -0
  40. package/lib/bryntum-resource-view.component.d.ts +1512 -0
  41. package/lib/bryntum-week-view.component.d.ts +1980 -0
  42. package/lib/bryntum-year-view.component.d.ts +1661 -0
  43. package/lib/calendar.module.d.ts +22 -0
  44. package/lib/wrapper.helper.d.ts +26 -0
  45. package/package.json +33 -0
  46. package/public-api.d.ts +17 -0
@@ -0,0 +1,2355 @@
1
+ /* eslint-disable @typescript-eslint/no-unused-vars */
2
+ /**
3
+ * Angular wrapper for Bryntum Calendar
4
+ */
5
+ import { Component, EventEmitter, Output, Input } from '@angular/core';
6
+ import WrapperHelper from './wrapper.helper';
7
+ import { Widget } from '@bryntum/core-thin';
8
+ import { Calendar } from '@bryntum/calendar-thin';
9
+ import { StringHelper } from '@bryntum/core-thin';
10
+ import * as i0 from "@angular/core";
11
+ export class BryntumCalendarComponent {
12
+ constructor(element) {
13
+ this.bryntumConfig = {
14
+ adopt: undefined,
15
+ appendTo: undefined,
16
+ href: undefined,
17
+ angularComponent: this,
18
+ features: {},
19
+ listeners: {}
20
+ };
21
+ // Events emitters
22
+ /**
23
+ * Fired when a change of view (Calendar mode) has completed. By default, view changes are animated and this
24
+ * event fires when the view is fully visible.
25
+ * @param {object} event Event object
26
+ * @param {Calendar.view.Calendar} event.source This Calendar instance.
27
+ * @param {CalendarView} event.prevActiveItem The previously active view.
28
+ * @param {CalendarView} event.activeItem The new active view.
29
+ * @param {boolean} event.containedFocus `true` if the outgoing view contained focus.
30
+ */
31
+ this.onActiveItemChange = new EventEmitter();
32
+ /**
33
+ * Fires on the owning Scheduler after editor is closed by any action - save, delete or cancel
34
+ * @param {object} event Event object
35
+ * @param {Scheduler.view.Scheduler} event.source The scheduler
36
+ * @param {'save','delete','cancel'} event.action The action that was taken to end the edit. One of 'save', 'delete' or 'cancel'
37
+ * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature
38
+ * @param {Scheduler.model.EventModel} event.eventRecord The record that has been edited.
39
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.
40
+ * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.
41
+ * @param {Core.widget.Popup} event.editor The editor
42
+ */
43
+ this.onAfterEventEdit = new EventEmitter();
44
+ /**
45
+ * Fires on the owning Scheduler after an event is successfully saved
46
+ * @param {object} event Event object
47
+ * @param {Scheduler.view.Scheduler} event.source The scheduler instance
48
+ * @param {Scheduler.model.EventModel} event.eventRecord The record about to be saved
49
+ */
50
+ this.onAfterEventSave = new EventEmitter();
51
+ /**
52
+ * Fired before a change of view (Calendar mode) is initiated.
53
+ * @param {object} event Event object
54
+ * @param {Calendar.view.Calendar} event.source This Calendar instance.
55
+ * @param {CalendarView} event.prevActiveItem The previously active view.
56
+ * @param {CalendarView} event.activeItem The new active view.
57
+ */
58
+ this.onBeforeActiveItemChange = new EventEmitter();
59
+ /**
60
+ * Fires before an assignment is removed. Can be triggered by user pressing [DELETE] or [BACKSPACE] or
61
+ * by the event editor. Can for example be used to display a custom dialog to confirm deletion, in which
62
+ * case records should be "manually" removed after confirmation:
63
+ * ...
64
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeAssignmentDelete)
65
+ * @param {object} event Event object
66
+ * @param {Scheduler.view.Scheduler} event.source The Scheduler instance
67
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be deleted
68
+ * @param {object} event.context Additional removal context:
69
+ * @param {Function} event.context.finalize Function to call to finalize the removal. Used to asynchronously decide to remove the records or not. Provide `false` to the function to prevent the removal.
70
+ * @param {boolean} event.context.finalize.removeRecords Provide `false` to the function to prevent the removal.
71
+ */
72
+ this.onBeforeAssignmentDelete = new EventEmitter();
73
+ /**
74
+ * Fired any time there is going to be a change to the assignments selected in the Scheduler.
75
+ * Returning `false` prevents the change
76
+ * @param {object} event Event object
77
+ * @param {Scheduler.view.Scheduler} event.source This Scheduler instance.
78
+ * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'
79
+ * @param {Scheduler.model.AssignmentModel[]} event.selected An array of assignments that will be added to the selection.
80
+ * @param {Scheduler.model.AssignmentModel[]} event.deselected An array of assignments that will be removed from the selection.
81
+ * @param {Scheduler.model.AssignmentModel[]} event.selection The currently selected assignments, before applying `selected` and `deselected`.
82
+ */
83
+ this.onBeforeAssignmentSelectionChange = new EventEmitter();
84
+ /**
85
+ * This event fires whenever a child view's [autoCreate gesture](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate) is detected and also when a [drag-create](#Calendar/feature/CalendarDrag) gesture is detected.
86
+ * ...
87
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeAutoCreate)
88
+ * @param {object} event Event object
89
+ * @param {CalendarView} event.source The child view on which the event was initiated.
90
+ * @param {Event} event.domEvent The DOM event which initiated the creation.
91
+ * @param {Date} event.date *DEPRECATED in favour of `startDate`.* The starting time of the event to be created. If this is in a `DayView`, this will be snapped according to the specification in [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate)
92
+ * @param {Date} event.startDate The starting time of the event to be created. If this is in a `DayView`, this will be snapped according to the specification in [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate)
93
+ * @param {Date} event.endDate The ending time of the event to be created.
94
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.
95
+ */
96
+ this.onBeforeAutoCreate = new EventEmitter();
97
+ /**
98
+ * Fires on the owning Scheduler before a copy action is performed, return `false` to prevent the action
99
+ * @param {object} event Event object
100
+ * @param {Scheduler.view.Scheduler} event.source Owner scheduler
101
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The event records about to be copied
102
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be copied
103
+ * @param {boolean} event.isCut `true` if this is a cut action
104
+ * @param {string} event.entityName 'event' to distinguish this event from other beforeCopy events
105
+ */
106
+ this.onBeforeCopy = new EventEmitter();
107
+ /**
108
+ * Fires before a mode is created. The configuration block is passed to the handler for possible modification.
109
+ * @param {object} event Event object
110
+ * @param {Calendar.view.Calendar} event.source This Calendar
111
+ * @param {AgendaViewConfig,DayResourceViewConfig,DayViewConfig,EventListConfig,MonthViewConfig,ResourceViewConfig,WeekViewConfig,YearViewConfig,DayAgendaViewConfig,MonthAgendaViewConfig,CalendarContainerItemConfig} event.config The configuration block of the mode about to be created. Any property, including the `type` may be changed.
112
+ */
113
+ this.onBeforeCreateMode = new EventEmitter();
114
+ /**
115
+ * Fires on the owning Grid before CSV export starts. Return `false` to cancel the export.
116
+ * @param {object} event Event object
117
+ * @param {ExportConfig} event.config Export config
118
+ * @param {Grid.column.Column[]} event.columns An array of columns to export
119
+ * @param {Core.data.Model[]} event.rows An array of records to export
120
+ * @param {string} event.lineDelimiter The CSV delimiter to separate lines
121
+ * @param {string} event.columnDelimiter The CSV delimiter to separate values on one line
122
+ */
123
+ this.onBeforeCSVExport = new EventEmitter();
124
+ /**
125
+ * Fires before an object is destroyed.
126
+ * @param {object} event Event object
127
+ * @param {Core.Base} event.source The Object that is being destroyed.
128
+ */
129
+ this.onBeforeDestroy = new EventEmitter();
130
+ /**
131
+ * This event fires on the owning Calendar before a drag creation gesture is started. Return `false` to
132
+ * veto the operation.
133
+ * @param {object} event Event object
134
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
135
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
136
+ * @param {Event} event.domEvent The browser event.
137
+ * @param {Date} event.date The date at the drag DOM event position.
138
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
139
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
140
+ * @param {CalendarView} event.view The Calendar widget in which the drag is being started.
141
+ */
142
+ this.onBeforeDragCreate = new EventEmitter();
143
+ /**
144
+ * This event fires on the owning Calendar before a drag creation gesture is completed. Return `false` to
145
+ * immediately veto the operation or a Promise yielding `true` or `false` for async vetoing.
146
+ * @param {object} event Event object
147
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
148
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
149
+ * @param {Event} event.event The browser event.
150
+ * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being created that has not yet been added in the store.
151
+ * @param {Date} event.newStartDate The new start date.
152
+ * @param {Date} event.newEndDate The new end date.
153
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
154
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
155
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateCreateFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateCreateFn) if one was provided.
156
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
157
+ */
158
+ this.onBeforeDragCreateEnd = new EventEmitter();
159
+ /**
160
+ * This event fires on the owning Calendar before a drag move gesture is started. Return `false` to
161
+ * veto the operation.
162
+ * @param {object} event Event object
163
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
164
+ * @param {Core.util.drag.DragContext} event.drag The drag move context.
165
+ * @param {Event} event.domEvent The browser event.
166
+ * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being moved.
167
+ * @param {Date} event.date The date at the drag DOM event position.
168
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
169
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
170
+ * @param {CalendarView} event.view The Calendar widget in which the drag is being started.
171
+ */
172
+ this.onBeforeDragMove = new EventEmitter();
173
+ /**
174
+ * This event fires on the owning Calendar before a drag move gesture is completed. Return `false` to immediately veto the operation
175
+ * or a Promise yielding `true` or `false` for async vetoing.
176
+ * @param {object} event Event object
177
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
178
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
179
+ * @param {Event} event.event The browser event.
180
+ * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record that has *not yet been updated* in the store.
181
+ * @param {Scheduler.model.EventModel} event.proxyEventRecord The `EventModel` record that is being used as a proxy for the drag operation and being updated on every pointer move. This will contain changed values based on the drag position.
182
+ * @param {Date} event.newStartDate The new start date.
183
+ * @param {Date} event.newEndDate The new end date.
184
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
185
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
186
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateMoveFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateMoveFn) if one was provided.
187
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
188
+ */
189
+ this.onBeforeDragMoveEnd = new EventEmitter();
190
+ /**
191
+ * This event fires on the owning Calendar before a drag resize gesture is started. Return `false` to
192
+ * veto the operation.
193
+ * @param {object} event Event object
194
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
195
+ * @param {Core.util.drag.DragContext} event.drag The drag resize context.
196
+ * @param {Event} event.domEvent The browser event.
197
+ * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being resized.
198
+ * @param {Date} event.date The date at the drag DOM event position.
199
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
200
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
201
+ * @param {CalendarView} event.view The Calendar widget in which the drag is being started.
202
+ */
203
+ this.onBeforeDragResize = new EventEmitter();
204
+ /**
205
+ * This event fires on the owning Calendar before a drag resize gesture is completed. Return `false` to immediately veto the operation
206
+ * or a Promise yielding `true` or `false` for async vetoing.
207
+ * @param {object} event Event object
208
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
209
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
210
+ * @param {Event} event.event The browser event.
211
+ * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record that has *not yet been updated* in the store.
212
+ * @param {Scheduler.model.EventModel} event.proxyEventRecord The `EventModel` record that is being used as a proxy for the drag operation and being updated on every pointer move. This will contain changed values based on the drag position.
213
+ * @param {Date} event.newStartDate The new start date.
214
+ * @param {Date} event.newEndDate The new end date.
215
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
216
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateResizeFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateResizeFn) if one was provided.
217
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
218
+ */
219
+ this.onBeforeDragResizeEnd = new EventEmitter();
220
+ /**
221
+ * This event is fired on the owning Calendar when dropping an event from the calendar on the
222
+ * external source <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>. Returning `false`
223
+ * prevents the gesture from being completed.
224
+ * ...
225
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeDropExternal)
226
+ * @param {object} event Event object
227
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record being dragged.
228
+ * @param {boolean} event.dropOnCalendar `true` if the drop gesture is over the client Calendar. This feature also allows drag *out* of the Calendar and onto the external event source if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) config is set.
229
+ * @param {HTMLElement} event.itemElement The element in which the drag gesture started.
230
+ * @param {HTMLElement} event.targetElement The current over element.
231
+ * @param {Event} event.domEvent The pointer event associated with the drag point.
232
+ * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;
233
+ * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;
234
+ * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.
235
+ * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.
236
+ * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.
237
+ * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.
238
+ * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.
239
+ */
240
+ this.onBeforeDropExternal = new EventEmitter();
241
+ /**
242
+ * Fires before an event is removed. Can be triggered by user pressing [DELETE] or [BACKSPACE] or by the
243
+ * event editor. Can for example be used to display a custom dialog to confirm deletion, in which case
244
+ * records should be "manually" removed after confirmation:
245
+ * ...
246
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventDelete)
247
+ * @param {object} event Event object
248
+ * @param {Calendar.view.Calendar} event.source The Calendar instance
249
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The records about to be deleted
250
+ * @param {object} event.context Additional removal context:
251
+ * @param {Function} event.context.finalize Function to call to finalize the removal. Used to asynchronously decide to remove the records or not. Provide `false` to the function to prevent the removal.
252
+ * @param {boolean} event.context.finalize.removeRecords Provide `false` to the function to prevent the removal.
253
+ */
254
+ this.onBeforeEventDelete = new EventEmitter();
255
+ /**
256
+ * Fires on the owning Scheduler before an event is displayed in an editor.
257
+ * This may be listened for to allow an application to take over event editing duties. Returning `false`
258
+ * stops the default editing UI from being shown.
259
+ * ...
260
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventEdit)
261
+ * @param {object} event Event object
262
+ * @param {Scheduler.view.Scheduler} event.source The scheduler
263
+ * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature
264
+ * @param {Scheduler.model.EventModel} event.eventRecord The record about to be shown in the event editor.
265
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.
266
+ * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.
267
+ */
268
+ this.onBeforeEventEdit = new EventEmitter();
269
+ /**
270
+ * Fires on the owning Scheduler when the editor for an event is available but before it is populated with
271
+ * data and shown. Allows manipulating fields etc.
272
+ * @param {object} event Event object
273
+ * @param {Scheduler.view.Scheduler} event.source The scheduler
274
+ * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature
275
+ * @param {Scheduler.model.EventModel} event.eventRecord The record about to be shown in the event editor.
276
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.
277
+ * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.
278
+ * @param {Core.widget.Popup} event.editor The editor
279
+ */
280
+ this.onBeforeEventEditShow = new EventEmitter();
281
+ /**
282
+ * Fires on the owning Scheduler before an event is saved.
283
+ * Return `false` to immediately prevent saving
284
+ * ...
285
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventSave)
286
+ * @param {object} event Event object
287
+ * @param {Scheduler.view.Scheduler} event.source The scheduler instance
288
+ * @param {Scheduler.model.EventModel} event.eventRecord The record about to be saved
289
+ * @param {Scheduler.model.ResourceModel[]} event.resourceRecords The resources to which the event is assigned
290
+ * @param {object} event.values The new values
291
+ * @param {object} event.context Extended save context:
292
+ * @param {boolean} event.context.async Set this to `true` in a listener to indicate that the listener will asynchronously decide to prevent or not the event save.
293
+ * @param {Function} event.context.finalize Function to call to finalize the save. Used when `async` is `true`. Provide `false` to the function to prevent the save.
294
+ */
295
+ this.onBeforeEventSave = new EventEmitter();
296
+ /**
297
+ * Fired any time there is going to be a change to the events selected in the Scheduler.
298
+ * Returning `false` prevents the change
299
+ * @param {object} event Event object
300
+ * @param {Scheduler.view.Scheduler} event.source This Scheduler instance.
301
+ * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'
302
+ * @param {Scheduler.model.EventModel[]} event.selected An array of events that will be added to the selection.
303
+ * @param {Scheduler.model.EventModel[]} event.deselected An array of events that will be removed from the selection.
304
+ * @param {Scheduler.model.EventModel[]} event.selection The currently selected events, before applying `selected` and `deselected`.
305
+ */
306
+ this.onBeforeEventSelectionChange = new EventEmitter();
307
+ /**
308
+ * Fires on the owning Grid before Excel export starts. Return `false` to cancel the export.
309
+ * @param {object} event Event object
310
+ * @param {ExportConfig} event.config Export config
311
+ * @param {XLSColumn[]} event.columns An array of columns to export
312
+ * @param {any[][]} event.rows An array of records to export
313
+ */
314
+ this.onBeforeExcelExport = new EventEmitter();
315
+ /**
316
+ * Triggered before a widget is hidden. Return `false` to prevent the action.
317
+ * @param {object} event Event object
318
+ * @param {Core.widget.Widget} event.source The widget being hidden.
319
+ */
320
+ this.onBeforeHide = new EventEmitter();
321
+ /**
322
+ * Fires on the owning Scheduler before a paste action is performed, return `false` to prevent the action.
323
+ * Depending on if the EventStore is using [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the
324
+ * configuration of [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param
325
+ * will be populated with record copies.
326
+ * @param {object} event Event object
327
+ * @param {Scheduler.view.Scheduler} event.source Owner scheduler
328
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The events about to be pasted
329
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignments about to be pasted
330
+ * @param {Scheduler.model.EventModel[]} event.originalEventRecords The original event records
331
+ * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The original assignment record
332
+ * @param {Date} event.date The date when the pasted events will be scheduled
333
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record, the clipboard event records will be assigned to this resource.
334
+ * @param {boolean} event.isCut `true` if this is a cut action
335
+ * @param {string} event.entityName 'event' to distinguish this event from other beforePaste events
336
+ */
337
+ this.onBeforePaste = new EventEmitter();
338
+ /**
339
+ * Fires on the owning Calendar before print starts. Return `false` to cancel the print.
340
+ * @param {object} event Event object
341
+ * @param {object} event.config Print config
342
+ */
343
+ this.onBeforePrint = new EventEmitter();
344
+ /**
345
+ * Triggered before a new [responsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveState) is applied.
346
+ * @param {object} event Event object
347
+ * @param {Core.widget.Widget} event.source The widget whose `responsiveState` is to be changed
348
+ * @param {string} event.state The new value for the widget's `responsiveState`
349
+ * @param {string} event.oldState The previous value for the widget's `responsiveState`
350
+ */
351
+ this.onBeforeResponsiveStateChange = new EventEmitter();
352
+ /**
353
+ * Fired before this container will load record values into its child fields. This is useful if you
354
+ * want to modify the UI before data is loaded (e.g. set some input field to be readonly)
355
+ * @param {object} event Event object
356
+ * @param {Core.widget.Container} event.source The container
357
+ * @param {Core.data.Model} event.record The record
358
+ */
359
+ this.onBeforeSetRecord = new EventEmitter();
360
+ /**
361
+ * Triggered before a widget is shown. Return `false` to prevent the action.
362
+ * @param {object} event Event object
363
+ * @param {Core.widget.Widget,any} event.source The widget being shown
364
+ */
365
+ this.onBeforeShow = new EventEmitter();
366
+ /**
367
+ * Fired before state is applied to the source. Allows editing the state object or preventing the operation.
368
+ * @param {object} event Event object
369
+ * @param {any} event.state State object config
370
+ */
371
+ this.onBeforeStateApply = new EventEmitter();
372
+ /**
373
+ * Fired before state is saved by the StateProvider. Allows editing the state object or preventing the operation.
374
+ * @param {object} event Event object
375
+ * @param {any} event.state State object config
376
+ */
377
+ this.onBeforeStateSave = new EventEmitter();
378
+ /**
379
+ * Fires when any other event is fired from the object.
380
+ * ...
381
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-catchAll)
382
+ * @param {object} event Event object
383
+ * @param {{[key: string]: any, type: string}} event.event The Object that contains event details
384
+ * @param {string} event.event.type The type of the event which is caught by the listener
385
+ */
386
+ this.onCatchAll = new EventEmitter();
387
+ /**
388
+ * Fires when a cell overflow indicator is clicked or activated by the <kbd>ENTER</kbd> key in any view. This will include
389
+ * the cells of a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView) and the `+ n more` overflow
390
+ * indicator of cells in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView), and "all day" events section
391
+ * of a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView).
392
+ * @param {object} event Event object
393
+ * @param {CalendarView} event.source The view which triggered the event.
394
+ * @param {Event} event.domEvent The initiating DOM event.
395
+ * @param {Date} event.date The date clicked on.
396
+ */
397
+ this.onCellOverflowClick = new EventEmitter();
398
+ /**
399
+ * Fires when a Panel is collapsed using the [collapsible](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsible) setting.
400
+ * @param {object} event Event object
401
+ * @param {Core.widget.Panel} event.source This Panel.
402
+ */
403
+ this.onCollapse = new EventEmitter();
404
+ /**
405
+ * This event fires on the owning widget when an item is selected in the context menu.
406
+ * @param {object} event Event object
407
+ * @param {Core.widget.Widget} event.source The owning widget
408
+ * @param {Core.widget.Menu} event.menu The menu
409
+ * @param {Core.widget.MenuItem} event.item Selected menu item
410
+ */
411
+ this.onContextMenuItem = new EventEmitter();
412
+ /**
413
+ * This event fires on the owning widget when a check item is toggled in the context menu.
414
+ * @param {object} event Event object
415
+ * @param {Core.widget.Widget} event.source The owning widget
416
+ * @param {Core.widget.Menu} event.menu The menu
417
+ * @param {Core.widget.MenuItem} event.item Selected menu item
418
+ * @param {boolean} event.checked Checked or not
419
+ */
420
+ this.onContextMenuToggleItem = new EventEmitter();
421
+ /**
422
+ * Fires on the owning Scheduler after a copy action is performed. Depending on if the EventStore is using
423
+ * [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the configuration of
424
+ * [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param will be populated
425
+ * with record copies.
426
+ * @param {object} event Event object
427
+ * @param {Scheduler.view.Scheduler} event.source Owner scheduler
428
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The event record copies
429
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment record copies
430
+ * @param {Scheduler.model.EventModel[]} event.originalEventRecords The event records that were copied
431
+ * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecord The assignment records that were copied
432
+ * @param {boolean} event.isCut `true` if this is a cut action
433
+ * @param {string} event.entityName 'event' to distinguish this event from other copy events
434
+ */
435
+ this.onCopy = new EventEmitter();
436
+ /**
437
+ * Fires on the owning Scheduler/Gantt when the line indicating the current time is updated (see [currentTimeLineUpdateInterval](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/TimeRanges#config-currentTimeLineUpdateInterval)).
438
+ * @param {object} event Event object
439
+ * @param {Scheduler.view.Scheduler} event.source The scheduler
440
+ * @param {Date} event.date The current date
441
+ */
442
+ this.onCurrentTimelineUpdate = new EventEmitter();
443
+ /**
444
+ * Fired when data in any of the projects stores changes.
445
+ * ...
446
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dataChange)
447
+ * @param {object} event Event object
448
+ * @param {typeof Scheduler.data.mixin.ProjectConsumer,any} event.source Owning component
449
+ * @param {typeof Scheduler.model.mixin.ProjectModelMixin,any} event.project Project model
450
+ * @param {Core.data.Store} event.store Affected store
451
+ * @param {'remove','removeAll','add','clearchanges','filter','update','dataset','replace'} event.action Name of action which triggered the change. May be one of: * `'remove'` * `'removeAll'` * `'add'` * `'clearchanges'` * `'filter'` * `'update'` * `'dataset'` * `'replace'`
452
+ * @param {Core.data.Model} event.record Changed record, for actions that affects exactly one record (`'update'`)
453
+ * @param {Core.data.Model[]} event.records Changed records, passed for all actions except `'removeAll'`
454
+ * @param {object} event.changes Passed for the `'update'` action, info on which record fields changed
455
+ */
456
+ this.onDataChange = new EventEmitter();
457
+ /**
458
+ * Fires when the calendar changes the date that it orientates its views around.
459
+ * ...
460
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateChange)
461
+ * @param {object} event Event object
462
+ * @param {Calendar.view.Calendar} event.source This Calendar.
463
+ * @param {Date} event.oldDate The previous Calendar date.
464
+ * @param {Date} event.date The new Calendar date.
465
+ */
466
+ this.onDateChange = new EventEmitter();
467
+ /**
468
+ * Fired when the eventStore is queried for events by date range, and the date range
469
+ * requested is different from the last time the store was queried.
470
+ * ...
471
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateRangeChange)
472
+ * @param {object} event Event object
473
+ * @param {Calendar.view.Calendar} event.source This Calendar instance
474
+ * @param {object} event.old The old date range
475
+ * @param {Date} event.old.startDate the old start date
476
+ * @param {Date} event.old.endDate the old end date
477
+ * @param {object} event.new The new date range
478
+ * @param {Date} event.new.startDate the new start date
479
+ * @param {Date} event.new.endDate the new end date
480
+ */
481
+ this.onDateRangeChange = new EventEmitter();
482
+ /**
483
+ * Fires when the [LoadOnDemand](https://bryntum.com/products/calendar/docs/api/Calendar/feature/LoadOnDemand) feature has loaded a range of events.
484
+ * @param {object} event Event object
485
+ * @param {object} event.response The decoded JSON response.
486
+ * @param {object} event.options The options object passed into the CrudManager [CrudManager](https://bryntum.com/products/calendar/docs/api/Scheduler/data/CrudManager) [load](https://bryntum.com/products/calendar/docs/api/Scheduler/crud/AbstractCrudManagerMixin#function-load) method.
487
+ * @param {Date} event.startDate The start date of the range to request.
488
+ * @param {Date} event.endDate The end date of the range to request. <strong>Note that Dates are timestamps</strong>.
489
+ */
490
+ this.onDateRangeLoad = new EventEmitter();
491
+ /**
492
+ * Fired <strong>every</strong> time the eventStore is queried for events by date range.
493
+ * ...
494
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateRangeRequested)
495
+ * @param {object} event Event object
496
+ * @param {Calendar.view.Calendar} event.source This Calendar instance
497
+ * @param {object} event.old The old date range
498
+ * @param {Date} event.old.startDate the old start date
499
+ * @param {Date} event.old.endDate the old end date
500
+ * @param {object} event.new The new date range
501
+ * @param {Date} event.new.startDate the new start date
502
+ * @param {Date} event.new.endDate the new end date
503
+ * @param {boolean} event.changed `true` if the date range is different from the last time a request was made
504
+ */
505
+ this.onDateRangeRequested = new EventEmitter();
506
+ /**
507
+ * Fired by the active view after one day cell's events are collected in sorted order according to the
508
+ * [eventSorter](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-eventSorter)
509
+ * ...
510
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dayCellPopulated)
511
+ * @param {object} event Event object
512
+ * @param {CalendarView} event.source The view which triggered the event.
513
+ * @param {Scheduler.model.EventModel[]} event.events The events to be shown for the passed date
514
+ * @param {Date} event.The date the events are to be shown in.
515
+ */
516
+ this.onDayCellPopulated = new EventEmitter();
517
+ /**
518
+ * Fires when a day number is clicked or activated by the <kbd>ENTER</kbd> key in a view which shows day numbers.
519
+ * This will include the cells of a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView), the cell header of cells
520
+ * in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView), and the day header in a [DayView](#Calendar/widget/DayView).
521
+ * ...
522
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dayNumberClick)
523
+ * @param {object} event Event object
524
+ * @param {CalendarView} event.source The view which triggered the event.
525
+ * @param {Event} event.domEvent The initiating DOM event.
526
+ * @param {Date} event.date The date clicked on.
527
+ * @param {DayCell} event.cellData An object that contains data about the calendar cell for the date.
528
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
529
+ */
530
+ this.onDayNumberClick = new EventEmitter();
531
+ /**
532
+ * Fires when an object is destroyed.
533
+ * @param {object} event Event object
534
+ * @param {Core.Base} event.source The Object that is being destroyed.
535
+ */
536
+ this.onDestroy = new EventEmitter();
537
+ /**
538
+ * Fires when a field is mutated and the state of the [hasChanges](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#property-hasChanges) property changes
539
+ * @param {object} event Event object
540
+ * @param {Core.widget.Container} event.source The container.
541
+ * @param {boolean} event.dirty The dirty state of the Container - `true` if there are any fields which have been changed since initial load.
542
+ */
543
+ this.onDirtyStateChange = new EventEmitter();
544
+ /**
545
+ * This event fires on the owning Calendar when a drag creation gesture is completed.
546
+ * @param {object} event Event object
547
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
548
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
549
+ * @param {Event} event.event The browser event.
550
+ * @param {Scheduler.model.EventModel} event.eventRecord The new `EventModel` record added in the store.
551
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
552
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
553
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateCreateFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateCreateFn) if one was provided.
554
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
555
+ */
556
+ this.onDragCreateEnd = new EventEmitter();
557
+ /**
558
+ * This event fires on the owning Calendar when a drag move gesture is completed. The `eventRecord` has already been added
559
+ * to the `eventStore` of the owning calendar.
560
+ * @param {object} event Event object
561
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
562
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
563
+ * @param {Event} event.event The browser event.
564
+ * @param {Scheduler.model.EventModel} event.eventRecord The updated `EventModel` record.
565
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.
566
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
567
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateMoveFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateMoveFn) if one was provided.
568
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
569
+ */
570
+ this.onDragMoveEnd = new EventEmitter();
571
+ /**
572
+ * This event is fired on the owning Calendar when dragging an event from the calendar over the
573
+ * external source <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>.
574
+ * ...
575
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dragMoveExternal)
576
+ * @param {object} event Event object
577
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record being dragged.
578
+ * @param {HTMLElement} event.itemElement The element in which the drag gesture started.
579
+ * @param {HTMLElement} event.targetElement The current over element.
580
+ * @param {Event} event.domEvent The pointer event associated with the drag point.
581
+ * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;
582
+ * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;
583
+ * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.
584
+ * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.
585
+ * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.
586
+ * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.
587
+ * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.
588
+ */
589
+ this.onDragMoveExternal = new EventEmitter();
590
+ /**
591
+ * This event fires on the owning Calendar when a drag resize gesture is completed.
592
+ * @param {object} event Event object
593
+ * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.
594
+ * @param {Core.util.drag.DragContext} event.drag The drag create context.
595
+ * @param {Event} event.event The browser event.
596
+ * @param {Scheduler.model.EventModel} event.eventRecord The updated `EventModel` record.
597
+ * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.
598
+ * @param {boolean,ValidateCreateResult} event.validation The result of the [validateResizeFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateResizeFn) if one was provided.
599
+ * @param {CalendarView} event.view The Calendar widget in which the drag completed.
600
+ */
601
+ this.onDragResizeEnd = new EventEmitter();
602
+ /**
603
+ * This event is fired on the owning Calendar after dropping an event from the calendar on the
604
+ * external source has been completed <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>.
605
+ * ...
606
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dropExternal)
607
+ * @param {object} event Event object
608
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record that was dropped.
609
+ * @param {boolean} event.dropOnCalendar `true` if the drop gesture is over the client Calendar. This feature also allows drag *out* of the Calendar and onto the external event source if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) config is set.
610
+ * @param {HTMLElement} event.itemElement The element in which the drag gesture started.
611
+ * @param {HTMLElement} event.targetElement The current over element.
612
+ * @param {Event} event.domEvent The pointer event associated with the drag point.
613
+ * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;
614
+ * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;
615
+ * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.
616
+ * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.
617
+ * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.
618
+ * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.
619
+ * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.
620
+ */
621
+ this.onDropExternal = new EventEmitter();
622
+ /**
623
+ * Triggered when a widget's [element](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-element) is available.
624
+ * @param {object} event Event object
625
+ * @param {HTMLElement} event.element The Widget's element.
626
+ */
627
+ this.onElementCreated = new EventEmitter();
628
+ /**
629
+ * Fired when an empty cell content area is clicked on in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView) or a
630
+ * [CalendarRow](https://bryntum.com/products/calendar/docs/api/Calendar/widget/CalendarRow).
631
+ * @param {object} event Event object
632
+ * @param {CalendarView} event.source The child view on which the event was initiated.
633
+ * @param {Event} event.domEvent The triggering DOM event.
634
+ * @param {Date} event.date The date which has no visible events
635
+ */
636
+ this.onEmptyCellClick = new EventEmitter();
637
+ /**
638
+ * Fired when an [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate) gesture has
639
+ * created a new event and added it to the event store.
640
+ * ...
641
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-eventAutoCreated)
642
+ * @param {object} event Event object
643
+ * @param {CalendarView} event.source The child view on which the event was initiated.
644
+ * @param {Scheduler.model.EventModel} event.eventRecord The new event record.
645
+ */
646
+ this.onEventAutoCreated = new EventEmitter();
647
+ /**
648
+ * Fires when an event bar is clicked in any view.
649
+ * @param {object} event Event object
650
+ * @param {CalendarView} event.source The view which triggered the event.
651
+ * @param {Event} event.domEvent The initiating DOM event.
652
+ * @param {Date} event.date The date of the UI element which contains the event.
653
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
654
+ * @param {Scheduler.model.EventModel} event.eventRecord The event clicked on.
655
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource clicked on if the UI includes a resource.
656
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
657
+ */
658
+ this.onEventClick = new EventEmitter();
659
+ /**
660
+ * Fires when an event bar is right-clicked in any view.
661
+ * @param {object} event Event object
662
+ * @param {CalendarView} event.source The view which triggered the event.
663
+ * @param {Event} event.domEvent The initiating DOM event.
664
+ * @param {Date} event.date The date of the UI element which contains the event.
665
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
666
+ * @param {Scheduler.model.EventModel} event.eventRecord The event right-clicked on.
667
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource right-clicked on if the UI includes a resource.
668
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
669
+ */
670
+ this.onEventContextMenu = new EventEmitter();
671
+ /**
672
+ * Fires when an event bar is double clicked in any view.
673
+ * @param {object} event Event object
674
+ * @param {CalendarView} event.source The view which triggered the event.
675
+ * @param {Event} event.domEvent The initiating DOM event.
676
+ * @param {Date} event.date The date of the UI element which contains the event.
677
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
678
+ * @param {Scheduler.model.EventModel} event.eventRecord The event double clicked on.
679
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource double clicked on if the UI includes a resource.
680
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
681
+ */
682
+ this.onEventDblClick = new EventEmitter();
683
+ /**
684
+ * Fired before the editor will load the event record data into its input fields. This is useful if you
685
+ * want to modify the fields before data is loaded (e.g. set some input field to be readonly)
686
+ * @param {object} event Event object
687
+ * @param {Core.widget.Container} event.source The editor widget
688
+ * @param {Scheduler.model.EventModel} event.record The record
689
+ */
690
+ this.onEventEditBeforeSetRecord = new EventEmitter();
691
+ /**
692
+ * Fires when a key is pressed while an event bar is focused.
693
+ * @param {object} event Event object
694
+ * @param {CalendarView} event.source The view which triggered the event.
695
+ * @param {Event} event.domEvent The initiating DOM event.
696
+ * @param {Date} event.date The date of the UI element which contains the event.
697
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
698
+ * @param {Scheduler.model.EventModel} event.eventRecord The event in which the key event was detected.
699
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource in which the key event was detected if the UI includes a resource.
700
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
701
+ */
702
+ this.onEventKeyDown = new EventEmitter();
703
+ /**
704
+ * This event fires on the owning Scheduler before the context menu is shown for an event. Allows manipulation of the items
705
+ * to show in the same way as in `processItems`. Returning `false` from a listener prevents the menu from
706
+ * being shown.
707
+ * @param {object} event Event object
708
+ * @param {Scheduler.view.Scheduler} event.source
709
+ * @param {Record<string, MenuItemEntry>} event.items Menu item configs
710
+ * @param {Scheduler.model.EventModel} event.eventRecord Event record for which the menu was triggered
711
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record
712
+ * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used
713
+ * @param {HTMLElement} event.eventElement
714
+ * @param {MouseEvent} event.event Pointer event which triggered the context menu (if any)
715
+ */
716
+ this.onEventMenuBeforeShow = new EventEmitter();
717
+ /**
718
+ * This event fires on the owning Scheduler when an item is selected in the context menu.
719
+ * @param {object} event Event object
720
+ * @param {Scheduler.view.Scheduler} event.source
721
+ * @param {Core.widget.MenuItem} event.item
722
+ * @param {Scheduler.model.EventModel} event.eventRecord
723
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord
724
+ * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used
725
+ * @param {HTMLElement} event.eventElement
726
+ */
727
+ this.onEventMenuItem = new EventEmitter();
728
+ /**
729
+ * This event fires on the owning Scheduler after showing the context menu for an event
730
+ * @param {object} event Event object
731
+ * @param {Scheduler.view.Scheduler} event.source
732
+ * @param {Core.widget.Menu} event.menu The menu
733
+ * @param {Scheduler.model.EventModel} event.eventRecord Event record for which the menu was triggered
734
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record
735
+ * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used
736
+ * @param {HTMLElement} event.eventElement
737
+ */
738
+ this.onEventMenuShow = new EventEmitter();
739
+ /**
740
+ * Fires when an event bar is mousedowned in any view.
741
+ * @param {object} event Event object
742
+ * @param {CalendarView} event.source The view which triggered the event.
743
+ * @param {Event} event.domEvent The initiating DOM event.
744
+ * @param {Date} event.date The date of the UI element which contains the event.
745
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
746
+ * @param {Scheduler.model.EventModel} event.eventRecord The event mousedowned on.
747
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mousedowned on if the UI includes a resource.
748
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
749
+ */
750
+ this.onEventMouseDown = new EventEmitter();
751
+ /**
752
+ * Fires when cursor enters an event bar in any view.
753
+ * @param {object} event Event object
754
+ * @param {CalendarView} event.source The view which triggered the event.
755
+ * @param {Event} event.domEvent The initiating DOM event.
756
+ * @param {Date} event.date The date of the UI element which contains the event.
757
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
758
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record.
759
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.
760
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
761
+ */
762
+ this.onEventMouseEnter = new EventEmitter();
763
+ /**
764
+ * Fires when cursor leaves an event bar in any view.
765
+ * @param {object} event Event object
766
+ * @param {CalendarView} event.source The view which triggered the event.
767
+ * @param {Event} event.domEvent The initiating DOM event.
768
+ * @param {Date} event.date The date of the UI element which contains the event.
769
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
770
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record.
771
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.
772
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
773
+ */
774
+ this.onEventMouseLeave = new EventEmitter();
775
+ /**
776
+ * Fires when an event bar is mouseouted in any view.
777
+ * @param {object} event Event object
778
+ * @param {CalendarView} event.source The view which triggered the event.
779
+ * @param {Event} event.domEvent The initiating DOM event.
780
+ * @param {Date} event.date The date of the UI element which contains the event.
781
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
782
+ * @param {Scheduler.model.EventModel} event.eventRecord The event mouseouted.
783
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseouted if the UI includes a resource.
784
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
785
+ */
786
+ this.onEventMouseOut = new EventEmitter();
787
+ /**
788
+ * Fires when an event bar is mouseovered in any view.
789
+ * @param {object} event Event object
790
+ * @param {CalendarView} event.source The view which triggered the event.
791
+ * @param {Event} event.domEvent The initiating DOM event.
792
+ * @param {Date} event.date The date of the UI element which contains the event.
793
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
794
+ * @param {Scheduler.model.EventModel} event.eventRecord The event mouseovered.
795
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseovered if the UI includes a resource.
796
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
797
+ */
798
+ this.onEventMouseOver = new EventEmitter();
799
+ /**
800
+ * Fires when an event bar is mouseupped in any view.
801
+ * @param {object} event Event object
802
+ * @param {CalendarView} event.source The view which triggered the event.
803
+ * @param {Event} event.domEvent The initiating DOM event.
804
+ * @param {Date} event.date The date of the UI element which contains the event.
805
+ * @param {HTMLElement} event.eventElement The UI element which represents the event.
806
+ * @param {Scheduler.model.EventModel} event.eventRecord The event mouseupped.
807
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseupped if the UI includes a resource.
808
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
809
+ */
810
+ this.onEventMouseUp = new EventEmitter();
811
+ /**
812
+ * Fires when a day spanning event is found, and the date to which its encapsulating event bar
813
+ * extends has been calculated.
814
+ * ...
815
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-eventPropagate)
816
+ * @param {object} event Event object
817
+ * @param {CalendarView} event.source The view which triggered the event.
818
+ * @param {Date} event.eventEndDate The end date for which to calculate the propagate end date.
819
+ * @param {Date} event.propagateEndDate The system-calculated end point of the event bar.
820
+ * @param {boolean} event.isAllDay `true` if the event is an all day event, or spans multiple days.
821
+ * @param {boolean} event.isOverflow `true` if this is being called as part of further propagation.
822
+ * @param {boolean} event.overflows `true` if the event extends into future cells.
823
+ * @param {Scheduler.model.EventModel} event.eventRecord The event record being propagated.
824
+ * @param {Date} event.date The date from which the event is being propagated.
825
+ */
826
+ this.onEventPropagate = new EventEmitter();
827
+ /**
828
+ * Fires when a Panel is expanded using the [collapsible](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsible) setting.
829
+ * @param {object} event Event object
830
+ * @param {Core.widget.Panel} event.source This Panel.
831
+ */
832
+ this.onExpand = new EventEmitter();
833
+ /**
834
+ * Fired when focus enters this Widget.
835
+ * @param {object} event Event object
836
+ * @param {Core.widget.Widget} event.source This Widget
837
+ * @param {HTMLElement} event.fromElement The element which lost focus.
838
+ * @param {HTMLElement} event.toElement The element which gained focus.
839
+ * @param {Core.widget.Widget} event.fromWidget The widget which lost focus.
840
+ * @param {Core.widget.Widget} event.toWidget The widget which gained focus.
841
+ * @param {boolean} event.backwards `true` if the `toElement` is before the `fromElement` in document order.
842
+ */
843
+ this.onFocusIn = new EventEmitter();
844
+ /**
845
+ * Fired when focus exits this Widget's ownership tree. This is different from a `blur` event.
846
+ * focus moving from within this Widget's ownership tree, even if there are floating widgets
847
+ * will not trigger this event. This is when focus exits this widget completely.
848
+ * @param {object} event Event object
849
+ * @param {Core.widget.Widget} event.source This Widget
850
+ * @param {HTMLElement} event.fromElement The element which lost focus.
851
+ * @param {HTMLElement} event.toElement The element which gained focus.
852
+ * @param {Core.widget.Widget} event.fromWidget The widget which lost focus.
853
+ * @param {Core.widget.Widget} event.toWidget The widget which gained focus.
854
+ * @param {boolean} event.backwards `true` if the `toElement` is before the `fromElement` in document order.
855
+ */
856
+ this.onFocusOut = new EventEmitter();
857
+ /**
858
+ * Triggered after a widget was hidden
859
+ * @param {object} event Event object
860
+ * @param {Core.widget.Widget} event.source The widget
861
+ */
862
+ this.onHide = new EventEmitter();
863
+ /**
864
+ * Fires when the [LoadOnDemand](https://bryntum.com/products/calendar/docs/api/Calendar/feature/LoadOnDemand) feature detects that a request
865
+ * for data from the server has failed.
866
+ * ...
867
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-loadOnDemandFail)
868
+ * @param {object} event Event object
869
+ * @param {Response} event.rawResponse The HTTP `fetch` response object.
870
+ * @param {object} event.request The CrudManager load data block.
871
+ * @param {object} event.response The decoded JSON response.
872
+ */
873
+ this.onLoadOnDemandFail = new EventEmitter();
874
+ /**
875
+ * Fires when a month name header in a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView) or a [MonthGrid](#Calendar/widget/MonthGrid) is clicked
876
+ * or activated by the <kbd>ENTER</kbd> key.
877
+ * ...
878
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-monthNameClick)
879
+ * @param {object} event Event object
880
+ * @param {CalendarView} event.source The view which triggered the event.
881
+ * @param {Event} event.domEvent The initiating DOM event.
882
+ * @param {number} event.month The month index *(zero based)* clicked on.
883
+ * @param {Date} event.date The date of the first of the month clicked on.
884
+ */
885
+ this.onMonthNameClick = new EventEmitter();
886
+ /**
887
+ * Fired when a user gesture causes the active item to change.
888
+ * @param {object} event Event object
889
+ * @param {Event} event.event The browser event which instigated navigation. May be a click or key or focus event.
890
+ * @param {HTMLElement,null} event.item The newly active item, or `null` if focus moved out.
891
+ * @param {HTMLElement,null} event.oldItem The previously active item, or `null` if focus is moving in.
892
+ */
893
+ this.onNavigate = new EventEmitter();
894
+ /**
895
+ * Triggered when a widget which had been in a non-visible state for any reason
896
+ * achieves visibility.
897
+ * ...
898
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-paint)
899
+ * @param {object} event Event object
900
+ * @param {Core.widget.Widget} event.source The widget being painted.
901
+ * @param {boolean} event.firstPaint `true` if this is the first paint.
902
+ */
903
+ this.onPaint = new EventEmitter();
904
+ /**
905
+ * Fires on the owning Scheduler after a paste action is performed.
906
+ * @param {object} event Event object
907
+ * @param {Scheduler.view.Scheduler} event.source Owner scheduler
908
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The pasted event records
909
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The pasted assignment records
910
+ * @param {Scheduler.model.EventModel[]} event.pastedEventRecords (DEPRECATED) Use eventRecords instead
911
+ * @param {Scheduler.model.EventModel[]} event.originalEventRecords The original copied event records
912
+ * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The original copied assignment records
913
+ * @param {Date} event.date date Pasted to this date
914
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record
915
+ * @param {boolean} event.isCut `true` if this is a cut action
916
+ * @param {string} event.entityName 'event' to distinguish this event from other paste events
917
+ */
918
+ this.onPaste = new EventEmitter();
919
+ /**
920
+ * Fires on the owning Scheduler if a paste action is not allowed. Depending on if the EventStore is using
921
+ * [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the configuration of
922
+ * [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param will be populated
923
+ * with record copies.
924
+ * @param {object} event Event object
925
+ * @param {Scheduler.view.Scheduler} event.source Owner scheduler
926
+ * @param {Scheduler.model.EventModel[]} event.eventRecords The event records about to be pasted
927
+ * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be pasted
928
+ * @param {Scheduler.model.EventModel[]} event.originalEventRecords The event records that were copied
929
+ * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The assignment records that were copied
930
+ * @param {Date} event.date The paste date
931
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record
932
+ * @param {boolean} event.isCut `true` if this is a cut action
933
+ * @param {string} event.entityName 'event' to distinguish this event from other `pasteNotAllowed` events
934
+ * @param {'overlappingEvents','resourceReadOnly'} event.reason A string id to use for displaying an error message to the user.
935
+ */
936
+ this.onPasteNotAllowed = new EventEmitter();
937
+ /**
938
+ * Fired when a Widget's read only state is toggled
939
+ * @param {object} event Event object
940
+ * @param {boolean} event.readOnly Read only or not
941
+ */
942
+ this.onReadOnly = new EventEmitter();
943
+ /**
944
+ * This event is fired after a widget's elements have been synchronized due to a direct or indirect call
945
+ * to [recompose](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#function-recompose), if this results in some change to the widget's rendered DOM elements.
946
+ */
947
+ this.onRecompose = new EventEmitter();
948
+ /**
949
+ * Fires when one of the views in this Calendar refreshes.
950
+ * @param {object} event Event object
951
+ * @param {CalendarView} event.source The view which refreshed.
952
+ */
953
+ this.onRefresh = new EventEmitter();
954
+ /**
955
+ * Fired when the encapsulating element of a Widget resizes *only when [monitorResize](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-monitorResize) is `true`*.
956
+ * @param {object} event Event object
957
+ * @param {Core.widget.Widget} event.source This Widget
958
+ * @param {number} event.width The new width
959
+ * @param {number} event.height The new height
960
+ * @param {number} event.oldWidth The old width
961
+ * @param {number} event.oldHeight The old height
962
+ */
963
+ this.onResize = new EventEmitter();
964
+ /**
965
+ * Fires when a click event is received by a view which supports resources.
966
+ * ...
967
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-resourceClick)
968
+ * @param {object} event Event object
969
+ * @param {CalendarView} event.source The view which triggered the event.
970
+ * @param {Event} event.domEvent The initiating DOM event.
971
+ * @param {Date} event.date The date of the UI element which contains the event.
972
+ * @param {HTMLElement} event.eventElement *If* an event was interacted with, the UI element which represents the event.
973
+ * @param {Scheduler.model.EventModel} event.eventRecord *If* an event was interacted with.
974
+ * @param {HTMLElement} event.resourceElement The UI element which encapsulates the resource.
975
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the target element.
976
+ * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).
977
+ */
978
+ this.onResourceClick = new EventEmitter();
979
+ /**
980
+ * Triggered when a new [responsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveState) is applied.
981
+ * @param {object} event Event object
982
+ * @param {Core.widget.Widget} event.source The widget whose `responsiveState` has changed
983
+ * @param {string} event.state The new value for the widget's `responsiveState`
984
+ * @param {string} event.oldState The previous value for the widget's `responsiveState`
985
+ */
986
+ this.onResponsiveStateChange = new EventEmitter();
987
+ /**
988
+ * Fires when a click made its way through to an empty part of any view.
989
+ * @param {object} event Event object
990
+ * @param {CalendarView} event.source The view which triggered the event.
991
+ * @param {Event} event.domEvent The initiating DOM event.
992
+ * @param {Date} event.date The date clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
993
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
994
+ */
995
+ this.onScheduleClick = new EventEmitter();
996
+ /**
997
+ * Fires when a context menu made its way through to an empty part of any view.
998
+ * @param {object} event Event object
999
+ * @param {CalendarView} event.source The view which triggered the event.
1000
+ * @param {Event} event.domEvent The initiating DOM event.
1001
+ * @param {Date} event.date The date clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1002
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1003
+ */
1004
+ this.onScheduleContextMenu = new EventEmitter();
1005
+ /**
1006
+ * Fires when a dblclick made its way through to an empty part of any view.
1007
+ * @param {object} event Event object
1008
+ * @param {CalendarView} event.source The view which triggered the event.
1009
+ * @param {Event} event.domEvent The initiating DOM event.
1010
+ * @param {Date} event.date The date double clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1011
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1012
+ */
1013
+ this.onScheduleDblClick = new EventEmitter();
1014
+ /**
1015
+ * This event fires on the owning Scheduler or Gantt widget before the context menu is shown for the schedule.
1016
+ * Allows manipulation of the items to show in the same way as in `processItems`. Returning `false` from a listener
1017
+ * prevents the menu from being shown.
1018
+ * @param {object} event Event object
1019
+ * @param {Scheduler.view.Scheduler} event.source
1020
+ * @param {Record<string, MenuItemEntry>} event.items Menu item configs
1021
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record
1022
+ * @param {Date} event.date Clicked date, rounded according to viewPreset's settings
1023
+ * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used
1024
+ * @param {HTMLElement} event.eventElement
1025
+ */
1026
+ this.onScheduleMenuBeforeShow = new EventEmitter();
1027
+ /**
1028
+ * This event fires on the owning Scheduler or Gantt widget when an item is selected in the context menu.
1029
+ * @param {object} event Event object
1030
+ * @param {Scheduler.view.Scheduler} event.source
1031
+ * @param {Core.widget.MenuItem} event.item
1032
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord
1033
+ * @param {Date} event.date Clicked date, rounded according to viewPreset's settings
1034
+ * @param {HTMLElement} event.element
1035
+ */
1036
+ this.onScheduleMenuItem = new EventEmitter();
1037
+ /**
1038
+ * This event fires on the owning Scheduler or Gantt widget after showing the context menu for the schedule.
1039
+ * @param {object} event Event object
1040
+ * @param {Scheduler.view.Scheduler} event.source
1041
+ * @param {Record<string, MenuItemEntry>} event.items Menu item configs
1042
+ * @param {Core.widget.Menu} event.menu The menu
1043
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord
1044
+ * @param {Date} event.date Clicked date, rounded according to viewPreset's settings
1045
+ * @param {HTMLElement} event.targetElement
1046
+ */
1047
+ this.onScheduleMenuShow = new EventEmitter();
1048
+ /**
1049
+ * Fires when a mousedown made its way through to an empty part of any view.
1050
+ * @param {object} event Event object
1051
+ * @param {CalendarView} event.source The view which triggered the event.
1052
+ * @param {Event} event.domEvent The initiating DOM event.
1053
+ * @param {Date} event.date The date mousedowned on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1054
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1055
+ */
1056
+ this.onScheduleMouseDown = new EventEmitter();
1057
+ /**
1058
+ * Fires when a mouseout made it's way through to an empty part of any view.
1059
+ * @param {object} event Event object
1060
+ * @param {CalendarView} event.source The view which triggered the event.
1061
+ * @param {Event} event.domEvent The initiating DOM event.
1062
+ * @param {Date} event.date The date mouseouted. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1063
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1064
+ */
1065
+ this.onScheduleMouseOut = new EventEmitter();
1066
+ /**
1067
+ * Fires when a mouseover made its way through to an empty part of any view.
1068
+ * @param {object} event Event object
1069
+ * @param {CalendarView} event.source The view which triggered the event.
1070
+ * @param {Event} event.domEvent The initiating DOM event.
1071
+ * @param {Date} event.date The date mouseovered. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1072
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1073
+ */
1074
+ this.onScheduleMouseOver = new EventEmitter();
1075
+ /**
1076
+ * Fires when a mouseup made its way through to an empty part of any view.
1077
+ * @param {object} event Event object
1078
+ * @param {CalendarView} event.source The view which triggered the event.
1079
+ * @param {Event} event.domEvent The initiating DOM event.
1080
+ * @param {Date} event.date The date mouseupped on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.
1081
+ * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.
1082
+ */
1083
+ this.onScheduleMouseUp = new EventEmitter();
1084
+ /**
1085
+ * Fired any time there is a change to the events selected in the Calendar.
1086
+ * @param {object} event Event object
1087
+ * @param {Calendar.view.Calendar} event.source The Calendar instance.
1088
+ * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'
1089
+ * @param {Scheduler.model.EventModel[]} event.selected An array of the Events added to the selection.
1090
+ * @param {Scheduler.model.EventModel[]} event.deselected An array of the Event removed from the selection.
1091
+ * @param {Scheduler.model.EventModel[]} event.selection The new selection.
1092
+ */
1093
+ this.onSelectionChange = new EventEmitter();
1094
+ /**
1095
+ * Triggered after a widget is shown.
1096
+ * @param {object} event Event object
1097
+ * @param {Core.widget.Widget} event.source The widget
1098
+ */
1099
+ this.onShow = new EventEmitter();
1100
+ /**
1101
+ * Fired when the sidebar is collapsed either through the UI or programatically.
1102
+ * @param {object} event Event object
1103
+ * @param {Calendar.view.Calendar} event.source This Calendar instance
1104
+ */
1105
+ this.onSidebarCollapse = new EventEmitter();
1106
+ /**
1107
+ * Fired when the sidebar is expanded either through the UI or programatically.
1108
+ * @param {object} event Event object
1109
+ * @param {Calendar.view.Calendar} event.source This Calendar instance
1110
+ */
1111
+ this.onSidebarExpand = new EventEmitter();
1112
+ /**
1113
+ * Fired when a time axis of a DayView or WeekView is clicked on. If the handler returns
1114
+ * `false` the current pointer event is not processed further.
1115
+ * @param {object} event Event object
1116
+ * @param {CalendarView} event.source The view which triggered the event.
1117
+ * @param {Event} event.domEvent The triggering DOM event.
1118
+ * @param {Date} event.preciseTime The exact date and time at the clicked position
1119
+ * @param {Date} event.time The date and time at the clicked position snapped according to the [increment](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView#config-increment) and [timeSnapType](#Calendar/widget/DayView#config-timeSnapType)
1120
+ */
1121
+ this.onTimeAxisClick = new EventEmitter();
1122
+ /**
1123
+ * Fired on the owning Scheduler or Gantt widget when a click happens on a time range header element
1124
+ * @param {object} event Event object
1125
+ * @param {Scheduler.view.Scheduler} event.source Scheduler instance
1126
+ * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record
1127
+ * @param {MouseEvent} event.domEvent Browser event
1128
+ */
1129
+ this.onTimeRangeHeaderClick = new EventEmitter();
1130
+ /**
1131
+ * Fired on the owning Scheduler or Gantt widget when a right click happens on a time range header element
1132
+ * @param {object} event Event object
1133
+ * @param {Scheduler.view.Scheduler} event.source Scheduler instance
1134
+ * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record
1135
+ * @param {MouseEvent} event.domEvent Browser event
1136
+ */
1137
+ this.onTimeRangeHeaderContextMenu = new EventEmitter();
1138
+ /**
1139
+ * Fired on the owning Scheduler or Gantt widget when a double click happens on a time range header element
1140
+ * @param {object} event Event object
1141
+ * @param {Scheduler.view.Scheduler} event.source Scheduler instance
1142
+ * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record
1143
+ * @param {MouseEvent} event.domEvent Browser event
1144
+ */
1145
+ this.onTimeRangeHeaderDblClick = new EventEmitter();
1146
+ /**
1147
+ * A header [tool](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-tools) has been clicked.
1148
+ * @param {object} event Event object
1149
+ * @param {Core.widget.Tool} event.source This Panel.
1150
+ * @param {Core.widget.Tool} event.tool The tool which is being clicked.
1151
+ */
1152
+ this.onToolClick = new EventEmitter();
1153
+ /**
1154
+ * Fires when one of the child views is painted. That is when it becomes visible.
1155
+ * Note that due to the slide-in animation, while the view is visible, it will not
1156
+ * yet be in its final position.
1157
+ * @param {object} event Event object
1158
+ * @param {CalendarView} event.source The widget being painted
1159
+ * @param {boolean} event.firstPaint `true` if this is the first paint
1160
+ */
1161
+ this.onViewPaint = new EventEmitter();
1162
+ /**
1163
+ * Fires when a week number is clicked or activated by the <kbd>ENTER</kbd> key. This will include the week number cells of a
1164
+ * [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView), the week number in the first cell
1165
+ * in each row of a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView)
1166
+ * ...
1167
+ * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-weekNumberClick)
1168
+ * @param {object} event Event object
1169
+ * @param {CalendarView} event.source The view which triggered the event.
1170
+ * @param {Event} event.domEvent The initiating DOM event.
1171
+ * @param {number[]} event.week The `[year, week]` clicked on.
1172
+ * @param {Date} event.date The date clicked on.
1173
+ */
1174
+ this.onWeekNumberClick = new EventEmitter();
1175
+ this.elementRef = element;
1176
+ }
1177
+ /**
1178
+ * Create and append the underlying widget
1179
+ */
1180
+ ngOnInit() {
1181
+ const me = this, { elementRef, bryntumConfig } = me, { instanceClass, instanceName, bryntumConfigs, bryntumEvents } = BryntumCalendarComponent;
1182
+ bryntumConfigs.filter(prop => prop in this).forEach(prop => {
1183
+ // @ts-ignore
1184
+ WrapperHelper.applyPropValue(bryntumConfig, prop, this[prop]);
1185
+ if (['features', 'config'].includes(prop)) {
1186
+ WrapperHelper.devWarningConfigProp(instanceName, prop);
1187
+ }
1188
+ });
1189
+ // @ts-ignore
1190
+ bryntumEvents.filter(event => this[event] && this[event].observers.length > 0).forEach(event => {
1191
+ const uncapitalize = (str) => str.charAt(0).toLowerCase() + str.slice(1), eventName = (str) => uncapitalize(str.slice(2));
1192
+ // @ts-ignore
1193
+ bryntumConfig.listeners[eventName(event)] = e => {
1194
+ // @ts-ignore
1195
+ me[event].emit(e);
1196
+ // EventEmitter does not return values in the normal way, work around it by setting `returnValue` flag
1197
+ // in Angular listeners
1198
+ return e.returnValue;
1199
+ };
1200
+ });
1201
+ // If component has no container specified in config then use adopt to Wrapper's element
1202
+ const containerParam = [
1203
+ 'adopt',
1204
+ 'appendTo',
1205
+ 'insertAfter',
1206
+ 'insertBefore'
1207
+ // @ts-ignore
1208
+ ].find(prop => bryntumConfig[prop]);
1209
+ if (!containerParam) {
1210
+ if (instanceName === 'Button' || elementRef.nativeElement.getRootNode() instanceof ShadowRoot) {
1211
+ // Button should always be <a> or <button> inside owner element
1212
+ bryntumConfig.appendTo = elementRef.nativeElement;
1213
+ }
1214
+ else {
1215
+ bryntumConfig.adopt = elementRef.nativeElement;
1216
+ }
1217
+ }
1218
+ else {
1219
+ WrapperHelper.devWarningContainer(instanceName, containerParam);
1220
+ }
1221
+ // @ts-ignore
1222
+ me.instance = instanceName === 'Widget' ? Widget.create(bryntumConfig) : new instanceClass(bryntumConfig);
1223
+ // Backwards compatibility for gridInstance, schedulerInstance etc.
1224
+ // @ts-ignore
1225
+ me[StringHelper.uncapitalize(instanceName) + 'Instance'] = me.instance;
1226
+ //
1227
+ }
1228
+ /**
1229
+ * Watch for changes
1230
+ * @param changes
1231
+ */
1232
+ ngOnChanges(changes) {
1233
+ const { instance } = this, { instanceName } = BryntumCalendarComponent;
1234
+ if (!instance) {
1235
+ return;
1236
+ }
1237
+ // Iterate over all changes
1238
+ Object.entries(changes).forEach(([prop, change]) => {
1239
+ const newValue = change.currentValue, { instance } = this, { bryntumConfigsOnly, bryntumProps } = BryntumCalendarComponent;
1240
+ if (bryntumProps.includes(prop)) {
1241
+ WrapperHelper.applyPropValue(instance, prop, newValue, false);
1242
+ if (bryntumConfigsOnly.includes(prop)) {
1243
+ WrapperHelper.devWarningUpdateProp(instanceName, prop);
1244
+ }
1245
+ }
1246
+ });
1247
+ }
1248
+ /**
1249
+ * Destroy the component
1250
+ */
1251
+ ngOnDestroy() {
1252
+ // @ts-ignore
1253
+ if (this.instance && this.instance.destroy) {
1254
+ this.instance.destroy();
1255
+ }
1256
+ }
1257
+ }
1258
+ BryntumCalendarComponent.instanceClass = Calendar;
1259
+ BryntumCalendarComponent.instanceName = 'Calendar';
1260
+ BryntumCalendarComponent.bryntumEvents = [
1261
+ 'onActiveItemChange',
1262
+ 'onAfterEventEdit',
1263
+ 'onAfterEventSave',
1264
+ 'onBeforeActiveItemChange',
1265
+ 'onBeforeAssignmentDelete',
1266
+ 'onBeforeAssignmentSelectionChange',
1267
+ 'onBeforeAutoCreate',
1268
+ 'onBeforeCopy',
1269
+ 'onBeforeCreateMode',
1270
+ 'onBeforeCSVExport',
1271
+ 'onBeforeDestroy',
1272
+ 'onBeforeDragCreate',
1273
+ 'onBeforeDragCreateEnd',
1274
+ 'onBeforeDragMove',
1275
+ 'onBeforeDragMoveEnd',
1276
+ 'onBeforeDragResize',
1277
+ 'onBeforeDragResizeEnd',
1278
+ 'onBeforeDropExternal',
1279
+ 'onBeforeEventDelete',
1280
+ 'onBeforeEventEdit',
1281
+ 'onBeforeEventEditShow',
1282
+ 'onBeforeEventSave',
1283
+ 'onBeforeEventSelectionChange',
1284
+ 'onBeforeExcelExport',
1285
+ 'onBeforeHide',
1286
+ 'onBeforePaste',
1287
+ 'onBeforePrint',
1288
+ 'onBeforeResponsiveStateChange',
1289
+ 'onBeforeSetRecord',
1290
+ 'onBeforeShow',
1291
+ 'onBeforeStateApply',
1292
+ 'onBeforeStateSave',
1293
+ 'onCatchAll',
1294
+ 'onCellOverflowClick',
1295
+ 'onCollapse',
1296
+ 'onContextMenuItem',
1297
+ 'onContextMenuToggleItem',
1298
+ 'onCopy',
1299
+ 'onCurrentTimelineUpdate',
1300
+ 'onDataChange',
1301
+ 'onDateChange',
1302
+ 'onDateRangeChange',
1303
+ 'onDateRangeLoad',
1304
+ 'onDateRangeRequested',
1305
+ 'onDayCellPopulated',
1306
+ 'onDayNumberClick',
1307
+ 'onDestroy',
1308
+ 'onDirtyStateChange',
1309
+ 'onDragCreateEnd',
1310
+ 'onDragMoveEnd',
1311
+ 'onDragMoveExternal',
1312
+ 'onDragResizeEnd',
1313
+ 'onDropExternal',
1314
+ 'onElementCreated',
1315
+ 'onEmptyCellClick',
1316
+ 'onEventAutoCreated',
1317
+ 'onEventClick',
1318
+ 'onEventContextMenu',
1319
+ 'onEventDblClick',
1320
+ 'onEventEditBeforeSetRecord',
1321
+ 'onEventKeyDown',
1322
+ 'onEventMenuBeforeShow',
1323
+ 'onEventMenuItem',
1324
+ 'onEventMenuShow',
1325
+ 'onEventMouseDown',
1326
+ 'onEventMouseEnter',
1327
+ 'onEventMouseLeave',
1328
+ 'onEventMouseOut',
1329
+ 'onEventMouseOver',
1330
+ 'onEventMouseUp',
1331
+ 'onEventPropagate',
1332
+ 'onExpand',
1333
+ 'onFocusIn',
1334
+ 'onFocusOut',
1335
+ 'onHide',
1336
+ 'onLoadOnDemandFail',
1337
+ 'onMonthNameClick',
1338
+ 'onNavigate',
1339
+ 'onPaint',
1340
+ 'onPaste',
1341
+ 'onPasteNotAllowed',
1342
+ 'onReadOnly',
1343
+ 'onRecompose',
1344
+ 'onRefresh',
1345
+ 'onResize',
1346
+ 'onResourceClick',
1347
+ 'onResponsiveStateChange',
1348
+ 'onScheduleClick',
1349
+ 'onScheduleContextMenu',
1350
+ 'onScheduleDblClick',
1351
+ 'onScheduleMenuBeforeShow',
1352
+ 'onScheduleMenuItem',
1353
+ 'onScheduleMenuShow',
1354
+ 'onScheduleMouseDown',
1355
+ 'onScheduleMouseOut',
1356
+ 'onScheduleMouseOver',
1357
+ 'onScheduleMouseUp',
1358
+ 'onSelectionChange',
1359
+ 'onShow',
1360
+ 'onSidebarCollapse',
1361
+ 'onSidebarExpand',
1362
+ 'onTimeAxisClick',
1363
+ 'onTimeRangeHeaderClick',
1364
+ 'onTimeRangeHeaderContextMenu',
1365
+ 'onTimeRangeHeaderDblClick',
1366
+ 'onToolClick',
1367
+ 'onViewPaint',
1368
+ 'onWeekNumberClick'
1369
+ ];
1370
+ BryntumCalendarComponent.bryntumFeatureNames = [
1371
+ 'dragFeature',
1372
+ 'eventBufferFeature',
1373
+ 'eventCopyPasteFeature',
1374
+ 'eventEditFeature',
1375
+ 'eventMenuFeature',
1376
+ 'eventTooltipFeature',
1377
+ 'excelExporterFeature',
1378
+ 'externalEventSourceFeature',
1379
+ 'loadOnDemandFeature',
1380
+ 'printFeature',
1381
+ 'scheduleMenuFeature',
1382
+ 'scheduleTooltipFeature',
1383
+ 'timeRangesFeature',
1384
+ 'weekExpanderFeature'
1385
+ ];
1386
+ BryntumCalendarComponent.bryntumConfigs = BryntumCalendarComponent.bryntumFeatureNames.concat([
1387
+ 'activeDateCls',
1388
+ 'adopt',
1389
+ 'align',
1390
+ 'alignSelf',
1391
+ 'anchor',
1392
+ 'appendTo',
1393
+ 'ariaDescription',
1394
+ 'ariaLabel',
1395
+ 'assignments',
1396
+ 'assignmentStore',
1397
+ 'autoCreate',
1398
+ 'bbar',
1399
+ 'bodyCls',
1400
+ 'bubbleEvents',
1401
+ 'callOnFunctions',
1402
+ 'catchEventHandlerExceptions',
1403
+ 'centered',
1404
+ 'cls',
1405
+ 'collapsed',
1406
+ 'collapsible',
1407
+ 'color',
1408
+ 'column',
1409
+ 'config',
1410
+ 'constrainTo',
1411
+ 'contentElementCls',
1412
+ 'contextMenuTriggerEvent',
1413
+ 'crudManager',
1414
+ 'crudManagerClass',
1415
+ 'dataField',
1416
+ 'dataset',
1417
+ 'date',
1418
+ 'dateFormat',
1419
+ 'datePicker',
1420
+ 'defaultBindProperty',
1421
+ 'defaultCalendar',
1422
+ 'defaultFocus',
1423
+ 'defaults',
1424
+ 'deselectAllOnScheduleClick',
1425
+ 'deselectOnClick',
1426
+ 'destroyStores',
1427
+ 'detectCSSCompatibilityIssues',
1428
+ 'disabled',
1429
+ 'dock',
1430
+ 'draggable',
1431
+ 'drawer',
1432
+ 'elementAttributes',
1433
+ 'enableDeleteKey',
1434
+ 'enableRecurringEvents',
1435
+ 'enableUndoRedoKeys',
1436
+ 'events',
1437
+ 'eventSelectionDisabled',
1438
+ 'eventStore',
1439
+ 'extraData',
1440
+ 'filterEventResources',
1441
+ 'flex',
1442
+ 'floating',
1443
+ 'footer',
1444
+ 'header',
1445
+ 'height',
1446
+ 'hidden',
1447
+ 'hideAnimation',
1448
+ 'hideNonWorkingDays',
1449
+ 'hideWhenEmpty',
1450
+ 'highlightDate',
1451
+ 'highlightPredecessors',
1452
+ 'highlightSuccessors',
1453
+ 'icon',
1454
+ 'id',
1455
+ 'ignoreParentReadOnly',
1456
+ 'includeWeekendsButton',
1457
+ 'inputFieldAlign',
1458
+ 'insertBefore',
1459
+ 'insertFirst',
1460
+ 'isEventSelectable',
1461
+ 'itemCls',
1462
+ 'items',
1463
+ 'keyMap',
1464
+ 'labelPosition',
1465
+ 'layout',
1466
+ 'layoutStyle',
1467
+ 'lazyItems',
1468
+ 'listeners',
1469
+ 'loadMask',
1470
+ 'loadMaskDefaults',
1471
+ 'loadMaskError',
1472
+ 'localeClass',
1473
+ 'localizable',
1474
+ 'localizableProperties',
1475
+ 'maintainSelectionOnDatasetChange',
1476
+ 'margin',
1477
+ 'maskDefaults',
1478
+ 'masked',
1479
+ 'maxDate',
1480
+ 'maxHeight',
1481
+ 'maximizeOnMobile',
1482
+ 'maxWidth',
1483
+ 'minDate',
1484
+ 'minHeight',
1485
+ 'minWidth',
1486
+ 'mode',
1487
+ 'modeDefaults',
1488
+ 'modes',
1489
+ 'monitorResize',
1490
+ 'multiEventSelect',
1491
+ 'namedItems',
1492
+ 'navigatorPlacement',
1493
+ 'nonWorkingDays',
1494
+ 'overlaySidebar',
1495
+ 'owner',
1496
+ 'positioned',
1497
+ 'preventTooltipOnTouch',
1498
+ 'project',
1499
+ 'propagatedConfigs',
1500
+ 'readOnly',
1501
+ 'recurrenceConfirmationPopup',
1502
+ 'relayStoreEvents',
1503
+ 'rendition',
1504
+ 'resourceImagePath',
1505
+ 'resources',
1506
+ 'resourceStore',
1507
+ 'resourceTimeRanges',
1508
+ 'resourceTimeRangeStore',
1509
+ 'responsive',
1510
+ 'responsiveRoot',
1511
+ 'responsiveState',
1512
+ 'responsiveTarget',
1513
+ 'ripple',
1514
+ 'rootElement',
1515
+ 'rtl',
1516
+ 'scrollable',
1517
+ 'scrollAction',
1518
+ 'selectResourceOnEventNavigate',
1519
+ 'selectResourceOnScheduleClick',
1520
+ 'showAnimation',
1521
+ 'showRecurringUI',
1522
+ 'showTooltipWhenDisabled',
1523
+ 'sidebar',
1524
+ 'span',
1525
+ 'stateful',
1526
+ 'statefulEvents',
1527
+ 'stateId',
1528
+ 'stateProvider',
1529
+ 'strictRecordMapping',
1530
+ 'strips',
1531
+ 'syncMask',
1532
+ 'tab',
1533
+ 'tabBarItems',
1534
+ 'tag',
1535
+ 'tbar',
1536
+ 'textAlign',
1537
+ 'timeRanges',
1538
+ 'timeRangeStore',
1539
+ 'timeZone',
1540
+ 'title',
1541
+ 'tools',
1542
+ 'tooltip',
1543
+ 'trapFocus',
1544
+ 'triggerSelectionChangeOnRemove',
1545
+ 'type',
1546
+ 'ui',
1547
+ 'useContextualRecurrenceRules',
1548
+ 'viewContainer',
1549
+ 'weekStartDay',
1550
+ 'weight',
1551
+ 'width',
1552
+ 'x',
1553
+ 'y'
1554
+ ]);
1555
+ BryntumCalendarComponent.bryntumConfigsOnly = [
1556
+ 'adopt',
1557
+ 'align',
1558
+ 'anchor',
1559
+ 'ariaDescription',
1560
+ 'ariaLabel',
1561
+ 'assignmentStore',
1562
+ 'autoCreate',
1563
+ 'bbar',
1564
+ 'bodyCls',
1565
+ 'bubbleEvents',
1566
+ 'centered',
1567
+ 'collapsible',
1568
+ 'color',
1569
+ 'config',
1570
+ 'constrainTo',
1571
+ 'contentElementCls',
1572
+ 'contextMenuTriggerEvent',
1573
+ 'crudManagerClass',
1574
+ 'dataField',
1575
+ 'datePicker',
1576
+ 'defaultBindProperty',
1577
+ 'defaultFocus',
1578
+ 'defaults',
1579
+ 'deselectOnClick',
1580
+ 'destroyStores',
1581
+ 'detectCSSCompatibilityIssues',
1582
+ 'dock',
1583
+ 'draggable',
1584
+ 'drawer',
1585
+ 'elementAttributes',
1586
+ 'enableDeleteKey',
1587
+ 'enableRecurringEvents',
1588
+ 'enableUndoRedoKeys',
1589
+ 'eventSelectionDisabled',
1590
+ 'eventStore',
1591
+ 'filterEventResources',
1592
+ 'floating',
1593
+ 'footer',
1594
+ 'header',
1595
+ 'hideAnimation',
1596
+ 'hideWhenEmpty',
1597
+ 'highlightDate',
1598
+ 'highlightPredecessors',
1599
+ 'highlightSuccessors',
1600
+ 'icon',
1601
+ 'ignoreParentReadOnly',
1602
+ 'includeWeekendsButton',
1603
+ 'itemCls',
1604
+ 'lazyItems',
1605
+ 'listeners',
1606
+ 'loadMask',
1607
+ 'loadMaskDefaults',
1608
+ 'loadMaskError',
1609
+ 'localeClass',
1610
+ 'localizable',
1611
+ 'localizableProperties',
1612
+ 'maintainSelectionOnDatasetChange',
1613
+ 'maskDefaults',
1614
+ 'masked',
1615
+ 'monitorResize',
1616
+ 'multiEventSelect',
1617
+ 'namedItems',
1618
+ 'navigatorPlacement',
1619
+ 'overlaySidebar',
1620
+ 'owner',
1621
+ 'positioned',
1622
+ 'preventTooltipOnTouch',
1623
+ 'propagatedConfigs',
1624
+ 'relayStoreEvents',
1625
+ 'resourceImagePath',
1626
+ 'resourceStore',
1627
+ 'resourceTimeRangeStore',
1628
+ 'responsive',
1629
+ 'responsiveRoot',
1630
+ 'responsiveState',
1631
+ 'responsiveTarget',
1632
+ 'ripple',
1633
+ 'rootElement',
1634
+ 'scrollAction',
1635
+ 'showAnimation',
1636
+ 'showRecurringUI',
1637
+ 'showTooltipWhenDisabled',
1638
+ 'sidebar',
1639
+ 'stateful',
1640
+ 'statefulEvents',
1641
+ 'stateId',
1642
+ 'stateProvider',
1643
+ 'strips',
1644
+ 'syncMask',
1645
+ 'tab',
1646
+ 'tabBarItems',
1647
+ 'tag',
1648
+ 'tbar',
1649
+ 'textAlign',
1650
+ 'timeRangeStore',
1651
+ 'timeZone',
1652
+ 'trapFocus',
1653
+ 'triggerSelectionChangeOnRemove',
1654
+ 'type',
1655
+ 'ui',
1656
+ 'viewContainer',
1657
+ 'weekStartDay',
1658
+ 'weight'
1659
+ ];
1660
+ BryntumCalendarComponent.bryntumProps = BryntumCalendarComponent.bryntumFeatureNames.concat([
1661
+ 'activeDateCls',
1662
+ 'activeSubView',
1663
+ 'activeView',
1664
+ 'alignSelf',
1665
+ 'anchorSize',
1666
+ 'appendTo',
1667
+ 'assignments',
1668
+ 'callOnFunctions',
1669
+ 'catchEventHandlerExceptions',
1670
+ 'cls',
1671
+ 'collapsed',
1672
+ 'column',
1673
+ 'crudManager',
1674
+ 'dataset',
1675
+ 'date',
1676
+ 'dateFormat',
1677
+ 'defaultCalendar',
1678
+ 'deselectAllOnScheduleClick',
1679
+ 'disabled',
1680
+ 'events',
1681
+ 'extraData',
1682
+ 'flex',
1683
+ 'focusVisible',
1684
+ 'hasChanges',
1685
+ 'height',
1686
+ 'hidden',
1687
+ 'hideNonWorkingDays',
1688
+ 'id',
1689
+ 'inputFieldAlign',
1690
+ 'insertBefore',
1691
+ 'insertFirst',
1692
+ 'isEngineReady',
1693
+ 'isEventSelectable',
1694
+ 'isSettingValues',
1695
+ 'isValid',
1696
+ 'items',
1697
+ 'keyMap',
1698
+ 'labelPosition',
1699
+ 'layout',
1700
+ 'layoutStyle',
1701
+ 'margin',
1702
+ 'maxDate',
1703
+ 'maxHeight',
1704
+ 'maximizeOnMobile',
1705
+ 'maxWidth',
1706
+ 'minDate',
1707
+ 'minHeight',
1708
+ 'minWidth',
1709
+ 'mode',
1710
+ 'modeDefaults',
1711
+ 'modes',
1712
+ 'nonWorkingDays',
1713
+ 'parent',
1714
+ 'project',
1715
+ 'readOnly',
1716
+ 'record',
1717
+ 'recurrenceConfirmationPopup',
1718
+ 'rendition',
1719
+ 'resources',
1720
+ 'resourceTimeRanges',
1721
+ 'rtl',
1722
+ 'scrollable',
1723
+ 'selectedEvents',
1724
+ 'selectResourceOnEventNavigate',
1725
+ 'selectResourceOnScheduleClick',
1726
+ 'span',
1727
+ 'state',
1728
+ 'strictRecordMapping',
1729
+ 'timeRanges',
1730
+ 'title',
1731
+ 'tools',
1732
+ 'tooltip',
1733
+ 'useContextualRecurrenceRules',
1734
+ 'values',
1735
+ 'views',
1736
+ 'width',
1737
+ 'x',
1738
+ 'y'
1739
+ ]);
1740
+ BryntumCalendarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: BryntumCalendarComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
1741
+ BryntumCalendarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.0", type: BryntumCalendarComponent, selector: "bryntum-calendar", inputs: { adopt: "adopt", align: "align", anchor: "anchor", ariaDescription: "ariaDescription", ariaLabel: "ariaLabel", assignmentStore: "assignmentStore", autoCreate: "autoCreate", bbar: "bbar", bodyCls: "bodyCls", bubbleEvents: "bubbleEvents", centered: "centered", collapsible: "collapsible", color: "color", config: "config", constrainTo: "constrainTo", contentElementCls: "contentElementCls", contextMenuTriggerEvent: "contextMenuTriggerEvent", crudManagerClass: "crudManagerClass", dataField: "dataField", datePicker: "datePicker", defaultBindProperty: "defaultBindProperty", defaultFocus: "defaultFocus", defaults: "defaults", deselectOnClick: "deselectOnClick", destroyStores: "destroyStores", detectCSSCompatibilityIssues: "detectCSSCompatibilityIssues", dock: "dock", draggable: "draggable", drawer: "drawer", elementAttributes: "elementAttributes", enableDeleteKey: "enableDeleteKey", enableRecurringEvents: "enableRecurringEvents", enableUndoRedoKeys: "enableUndoRedoKeys", eventSelectionDisabled: "eventSelectionDisabled", eventStore: "eventStore", filterEventResources: "filterEventResources", floating: "floating", footer: "footer", header: "header", hideAnimation: "hideAnimation", hideWhenEmpty: "hideWhenEmpty", highlightDate: "highlightDate", highlightPredecessors: "highlightPredecessors", highlightSuccessors: "highlightSuccessors", icon: "icon", ignoreParentReadOnly: "ignoreParentReadOnly", includeWeekendsButton: "includeWeekendsButton", itemCls: "itemCls", lazyItems: "lazyItems", listeners: "listeners", loadMask: "loadMask", loadMaskDefaults: "loadMaskDefaults", loadMaskError: "loadMaskError", localeClass: "localeClass", localizable: "localizable", localizableProperties: "localizableProperties", maintainSelectionOnDatasetChange: "maintainSelectionOnDatasetChange", maskDefaults: "maskDefaults", masked: "masked", monitorResize: "monitorResize", multiEventSelect: "multiEventSelect", namedItems: "namedItems", navigatorPlacement: "navigatorPlacement", overlaySidebar: "overlaySidebar", owner: "owner", positioned: "positioned", preventTooltipOnTouch: "preventTooltipOnTouch", propagatedConfigs: "propagatedConfigs", relayStoreEvents: "relayStoreEvents", resourceImagePath: "resourceImagePath", resourceStore: "resourceStore", resourceTimeRangeStore: "resourceTimeRangeStore", responsive: "responsive", responsiveRoot: "responsiveRoot", responsiveState: "responsiveState", responsiveTarget: "responsiveTarget", ripple: "ripple", rootElement: "rootElement", scrollAction: "scrollAction", showAnimation: "showAnimation", showRecurringUI: "showRecurringUI", showTooltipWhenDisabled: "showTooltipWhenDisabled", sidebar: "sidebar", stateful: "stateful", statefulEvents: "statefulEvents", stateId: "stateId", stateProvider: "stateProvider", strips: "strips", syncMask: "syncMask", tab: "tab", tabBarItems: "tabBarItems", tag: "tag", tbar: "tbar", textAlign: "textAlign", timeRangeStore: "timeRangeStore", timeZone: "timeZone", trapFocus: "trapFocus", triggerSelectionChangeOnRemove: "triggerSelectionChangeOnRemove", type: "type", ui: "ui", viewContainer: "viewContainer", weekStartDay: "weekStartDay", weight: "weight", activeDateCls: "activeDateCls", alignSelf: "alignSelf", appendTo: "appendTo", assignments: "assignments", callOnFunctions: "callOnFunctions", catchEventHandlerExceptions: "catchEventHandlerExceptions", cls: "cls", collapsed: "collapsed", column: "column", crudManager: "crudManager", dataset: "dataset", date: "date", dateFormat: "dateFormat", defaultCalendar: "defaultCalendar", deselectAllOnScheduleClick: "deselectAllOnScheduleClick", disabled: "disabled", events: "events", extraData: "extraData", flex: "flex", height: "height", hidden: "hidden", hideNonWorkingDays: "hideNonWorkingDays", id: "id", inputFieldAlign: "inputFieldAlign", insertBefore: "insertBefore", insertFirst: "insertFirst", isEventSelectable: "isEventSelectable", items: "items", keyMap: "keyMap", labelPosition: "labelPosition", layout: "layout", layoutStyle: "layoutStyle", margin: "margin", maxDate: "maxDate", maxHeight: "maxHeight", maximizeOnMobile: "maximizeOnMobile", maxWidth: "maxWidth", minDate: "minDate", minHeight: "minHeight", minWidth: "minWidth", mode: "mode", modeDefaults: "modeDefaults", modes: "modes", nonWorkingDays: "nonWorkingDays", project: "project", readOnly: "readOnly", recurrenceConfirmationPopup: "recurrenceConfirmationPopup", rendition: "rendition", resources: "resources", resourceTimeRanges: "resourceTimeRanges", rtl: "rtl", scrollable: "scrollable", selectResourceOnEventNavigate: "selectResourceOnEventNavigate", selectResourceOnScheduleClick: "selectResourceOnScheduleClick", span: "span", strictRecordMapping: "strictRecordMapping", timeRanges: "timeRanges", title: "title", tools: "tools", tooltip: "tooltip", useContextualRecurrenceRules: "useContextualRecurrenceRules", width: "width", x: "x", y: "y", activeSubView: "activeSubView", activeView: "activeView", anchorSize: "anchorSize", focusVisible: "focusVisible", hasChanges: "hasChanges", isEngineReady: "isEngineReady", isSettingValues: "isSettingValues", isValid: "isValid", parent: "parent", record: "record", selectedEvents: "selectedEvents", state: "state", values: "values", views: "views", dragFeature: "dragFeature", eventBufferFeature: "eventBufferFeature", eventCopyPasteFeature: "eventCopyPasteFeature", eventEditFeature: "eventEditFeature", eventMenuFeature: "eventMenuFeature", eventTooltipFeature: "eventTooltipFeature", excelExporterFeature: "excelExporterFeature", externalEventSourceFeature: "externalEventSourceFeature", loadOnDemandFeature: "loadOnDemandFeature", printFeature: "printFeature", scheduleMenuFeature: "scheduleMenuFeature", scheduleTooltipFeature: "scheduleTooltipFeature", timeRangesFeature: "timeRangesFeature", weekExpanderFeature: "weekExpanderFeature" }, outputs: { onActiveItemChange: "onActiveItemChange", onAfterEventEdit: "onAfterEventEdit", onAfterEventSave: "onAfterEventSave", onBeforeActiveItemChange: "onBeforeActiveItemChange", onBeforeAssignmentDelete: "onBeforeAssignmentDelete", onBeforeAssignmentSelectionChange: "onBeforeAssignmentSelectionChange", onBeforeAutoCreate: "onBeforeAutoCreate", onBeforeCopy: "onBeforeCopy", onBeforeCreateMode: "onBeforeCreateMode", onBeforeCSVExport: "onBeforeCSVExport", onBeforeDestroy: "onBeforeDestroy", onBeforeDragCreate: "onBeforeDragCreate", onBeforeDragCreateEnd: "onBeforeDragCreateEnd", onBeforeDragMove: "onBeforeDragMove", onBeforeDragMoveEnd: "onBeforeDragMoveEnd", onBeforeDragResize: "onBeforeDragResize", onBeforeDragResizeEnd: "onBeforeDragResizeEnd", onBeforeDropExternal: "onBeforeDropExternal", onBeforeEventDelete: "onBeforeEventDelete", onBeforeEventEdit: "onBeforeEventEdit", onBeforeEventEditShow: "onBeforeEventEditShow", onBeforeEventSave: "onBeforeEventSave", onBeforeEventSelectionChange: "onBeforeEventSelectionChange", onBeforeExcelExport: "onBeforeExcelExport", onBeforeHide: "onBeforeHide", onBeforePaste: "onBeforePaste", onBeforePrint: "onBeforePrint", onBeforeResponsiveStateChange: "onBeforeResponsiveStateChange", onBeforeSetRecord: "onBeforeSetRecord", onBeforeShow: "onBeforeShow", onBeforeStateApply: "onBeforeStateApply", onBeforeStateSave: "onBeforeStateSave", onCatchAll: "onCatchAll", onCellOverflowClick: "onCellOverflowClick", onCollapse: "onCollapse", onContextMenuItem: "onContextMenuItem", onContextMenuToggleItem: "onContextMenuToggleItem", onCopy: "onCopy", onCurrentTimelineUpdate: "onCurrentTimelineUpdate", onDataChange: "onDataChange", onDateChange: "onDateChange", onDateRangeChange: "onDateRangeChange", onDateRangeLoad: "onDateRangeLoad", onDateRangeRequested: "onDateRangeRequested", onDayCellPopulated: "onDayCellPopulated", onDayNumberClick: "onDayNumberClick", onDestroy: "onDestroy", onDirtyStateChange: "onDirtyStateChange", onDragCreateEnd: "onDragCreateEnd", onDragMoveEnd: "onDragMoveEnd", onDragMoveExternal: "onDragMoveExternal", onDragResizeEnd: "onDragResizeEnd", onDropExternal: "onDropExternal", onElementCreated: "onElementCreated", onEmptyCellClick: "onEmptyCellClick", onEventAutoCreated: "onEventAutoCreated", onEventClick: "onEventClick", onEventContextMenu: "onEventContextMenu", onEventDblClick: "onEventDblClick", onEventEditBeforeSetRecord: "onEventEditBeforeSetRecord", onEventKeyDown: "onEventKeyDown", onEventMenuBeforeShow: "onEventMenuBeforeShow", onEventMenuItem: "onEventMenuItem", onEventMenuShow: "onEventMenuShow", onEventMouseDown: "onEventMouseDown", onEventMouseEnter: "onEventMouseEnter", onEventMouseLeave: "onEventMouseLeave", onEventMouseOut: "onEventMouseOut", onEventMouseOver: "onEventMouseOver", onEventMouseUp: "onEventMouseUp", onEventPropagate: "onEventPropagate", onExpand: "onExpand", onFocusIn: "onFocusIn", onFocusOut: "onFocusOut", onHide: "onHide", onLoadOnDemandFail: "onLoadOnDemandFail", onMonthNameClick: "onMonthNameClick", onNavigate: "onNavigate", onPaint: "onPaint", onPaste: "onPaste", onPasteNotAllowed: "onPasteNotAllowed", onReadOnly: "onReadOnly", onRecompose: "onRecompose", onRefresh: "onRefresh", onResize: "onResize", onResourceClick: "onResourceClick", onResponsiveStateChange: "onResponsiveStateChange", onScheduleClick: "onScheduleClick", onScheduleContextMenu: "onScheduleContextMenu", onScheduleDblClick: "onScheduleDblClick", onScheduleMenuBeforeShow: "onScheduleMenuBeforeShow", onScheduleMenuItem: "onScheduleMenuItem", onScheduleMenuShow: "onScheduleMenuShow", onScheduleMouseDown: "onScheduleMouseDown", onScheduleMouseOut: "onScheduleMouseOut", onScheduleMouseOver: "onScheduleMouseOver", onScheduleMouseUp: "onScheduleMouseUp", onSelectionChange: "onSelectionChange", onShow: "onShow", onSidebarCollapse: "onSidebarCollapse", onSidebarExpand: "onSidebarExpand", onTimeAxisClick: "onTimeAxisClick", onTimeRangeHeaderClick: "onTimeRangeHeaderClick", onTimeRangeHeaderContextMenu: "onTimeRangeHeaderContextMenu", onTimeRangeHeaderDblClick: "onTimeRangeHeaderDblClick", onToolClick: "onToolClick", onViewPaint: "onViewPaint", onWeekNumberClick: "onWeekNumberClick" }, usesOnChanges: true, ngImport: i0, template: '', isInline: true });
1742
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.0", ngImport: i0, type: BryntumCalendarComponent, decorators: [{
1743
+ type: Component,
1744
+ args: [{
1745
+ selector: 'bryntum-calendar',
1746
+ template: ''
1747
+ }]
1748
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { adopt: [{
1749
+ type: Input
1750
+ }], align: [{
1751
+ type: Input
1752
+ }], anchor: [{
1753
+ type: Input
1754
+ }], ariaDescription: [{
1755
+ type: Input
1756
+ }], ariaLabel: [{
1757
+ type: Input
1758
+ }], assignmentStore: [{
1759
+ type: Input
1760
+ }], autoCreate: [{
1761
+ type: Input
1762
+ }], bbar: [{
1763
+ type: Input
1764
+ }], bodyCls: [{
1765
+ type: Input
1766
+ }], bubbleEvents: [{
1767
+ type: Input
1768
+ }], centered: [{
1769
+ type: Input
1770
+ }], collapsible: [{
1771
+ type: Input
1772
+ }], color: [{
1773
+ type: Input
1774
+ }], config: [{
1775
+ type: Input
1776
+ }], constrainTo: [{
1777
+ type: Input
1778
+ }], contentElementCls: [{
1779
+ type: Input
1780
+ }], contextMenuTriggerEvent: [{
1781
+ type: Input
1782
+ }], crudManagerClass: [{
1783
+ type: Input
1784
+ }], dataField: [{
1785
+ type: Input
1786
+ }], datePicker: [{
1787
+ type: Input
1788
+ }], defaultBindProperty: [{
1789
+ type: Input
1790
+ }], defaultFocus: [{
1791
+ type: Input
1792
+ }], defaults: [{
1793
+ type: Input
1794
+ }], deselectOnClick: [{
1795
+ type: Input
1796
+ }], destroyStores: [{
1797
+ type: Input
1798
+ }], detectCSSCompatibilityIssues: [{
1799
+ type: Input
1800
+ }], dock: [{
1801
+ type: Input
1802
+ }], draggable: [{
1803
+ type: Input
1804
+ }], drawer: [{
1805
+ type: Input
1806
+ }], elementAttributes: [{
1807
+ type: Input
1808
+ }], enableDeleteKey: [{
1809
+ type: Input
1810
+ }], enableRecurringEvents: [{
1811
+ type: Input
1812
+ }], enableUndoRedoKeys: [{
1813
+ type: Input
1814
+ }], eventSelectionDisabled: [{
1815
+ type: Input
1816
+ }], eventStore: [{
1817
+ type: Input
1818
+ }], filterEventResources: [{
1819
+ type: Input
1820
+ }], floating: [{
1821
+ type: Input
1822
+ }], footer: [{
1823
+ type: Input
1824
+ }], header: [{
1825
+ type: Input
1826
+ }], hideAnimation: [{
1827
+ type: Input
1828
+ }], hideWhenEmpty: [{
1829
+ type: Input
1830
+ }], highlightDate: [{
1831
+ type: Input
1832
+ }], highlightPredecessors: [{
1833
+ type: Input
1834
+ }], highlightSuccessors: [{
1835
+ type: Input
1836
+ }], icon: [{
1837
+ type: Input
1838
+ }], ignoreParentReadOnly: [{
1839
+ type: Input
1840
+ }], includeWeekendsButton: [{
1841
+ type: Input
1842
+ }], itemCls: [{
1843
+ type: Input
1844
+ }], lazyItems: [{
1845
+ type: Input
1846
+ }], listeners: [{
1847
+ type: Input
1848
+ }], loadMask: [{
1849
+ type: Input
1850
+ }], loadMaskDefaults: [{
1851
+ type: Input
1852
+ }], loadMaskError: [{
1853
+ type: Input
1854
+ }], localeClass: [{
1855
+ type: Input
1856
+ }], localizable: [{
1857
+ type: Input
1858
+ }], localizableProperties: [{
1859
+ type: Input
1860
+ }], maintainSelectionOnDatasetChange: [{
1861
+ type: Input
1862
+ }], maskDefaults: [{
1863
+ type: Input
1864
+ }], masked: [{
1865
+ type: Input
1866
+ }], monitorResize: [{
1867
+ type: Input
1868
+ }], multiEventSelect: [{
1869
+ type: Input
1870
+ }], namedItems: [{
1871
+ type: Input
1872
+ }], navigatorPlacement: [{
1873
+ type: Input
1874
+ }], overlaySidebar: [{
1875
+ type: Input
1876
+ }], owner: [{
1877
+ type: Input
1878
+ }], positioned: [{
1879
+ type: Input
1880
+ }], preventTooltipOnTouch: [{
1881
+ type: Input
1882
+ }], propagatedConfigs: [{
1883
+ type: Input
1884
+ }], relayStoreEvents: [{
1885
+ type: Input
1886
+ }], resourceImagePath: [{
1887
+ type: Input
1888
+ }], resourceStore: [{
1889
+ type: Input
1890
+ }], resourceTimeRangeStore: [{
1891
+ type: Input
1892
+ }], responsive: [{
1893
+ type: Input
1894
+ }], responsiveRoot: [{
1895
+ type: Input
1896
+ }], responsiveState: [{
1897
+ type: Input
1898
+ }], responsiveTarget: [{
1899
+ type: Input
1900
+ }], ripple: [{
1901
+ type: Input
1902
+ }], rootElement: [{
1903
+ type: Input
1904
+ }], scrollAction: [{
1905
+ type: Input
1906
+ }], showAnimation: [{
1907
+ type: Input
1908
+ }], showRecurringUI: [{
1909
+ type: Input
1910
+ }], showTooltipWhenDisabled: [{
1911
+ type: Input
1912
+ }], sidebar: [{
1913
+ type: Input
1914
+ }], stateful: [{
1915
+ type: Input
1916
+ }], statefulEvents: [{
1917
+ type: Input
1918
+ }], stateId: [{
1919
+ type: Input
1920
+ }], stateProvider: [{
1921
+ type: Input
1922
+ }], strips: [{
1923
+ type: Input
1924
+ }], syncMask: [{
1925
+ type: Input
1926
+ }], tab: [{
1927
+ type: Input
1928
+ }], tabBarItems: [{
1929
+ type: Input
1930
+ }], tag: [{
1931
+ type: Input
1932
+ }], tbar: [{
1933
+ type: Input
1934
+ }], textAlign: [{
1935
+ type: Input
1936
+ }], timeRangeStore: [{
1937
+ type: Input
1938
+ }], timeZone: [{
1939
+ type: Input
1940
+ }], trapFocus: [{
1941
+ type: Input
1942
+ }], triggerSelectionChangeOnRemove: [{
1943
+ type: Input
1944
+ }], type: [{
1945
+ type: Input
1946
+ }], ui: [{
1947
+ type: Input
1948
+ }], viewContainer: [{
1949
+ type: Input
1950
+ }], weekStartDay: [{
1951
+ type: Input
1952
+ }], weight: [{
1953
+ type: Input
1954
+ }], activeDateCls: [{
1955
+ type: Input
1956
+ }], alignSelf: [{
1957
+ type: Input
1958
+ }], appendTo: [{
1959
+ type: Input
1960
+ }], assignments: [{
1961
+ type: Input
1962
+ }], callOnFunctions: [{
1963
+ type: Input
1964
+ }], catchEventHandlerExceptions: [{
1965
+ type: Input
1966
+ }], cls: [{
1967
+ type: Input
1968
+ }], collapsed: [{
1969
+ type: Input
1970
+ }], column: [{
1971
+ type: Input
1972
+ }], crudManager: [{
1973
+ type: Input
1974
+ }], dataset: [{
1975
+ type: Input
1976
+ }], date: [{
1977
+ type: Input
1978
+ }], dateFormat: [{
1979
+ type: Input
1980
+ }], defaultCalendar: [{
1981
+ type: Input
1982
+ }], deselectAllOnScheduleClick: [{
1983
+ type: Input
1984
+ }], disabled: [{
1985
+ type: Input
1986
+ }], events: [{
1987
+ type: Input
1988
+ }], extraData: [{
1989
+ type: Input
1990
+ }], flex: [{
1991
+ type: Input
1992
+ }], height: [{
1993
+ type: Input
1994
+ }], hidden: [{
1995
+ type: Input
1996
+ }], hideNonWorkingDays: [{
1997
+ type: Input
1998
+ }], id: [{
1999
+ type: Input
2000
+ }], inputFieldAlign: [{
2001
+ type: Input
2002
+ }], insertBefore: [{
2003
+ type: Input
2004
+ }], insertFirst: [{
2005
+ type: Input
2006
+ }], isEventSelectable: [{
2007
+ type: Input
2008
+ }], items: [{
2009
+ type: Input
2010
+ }], keyMap: [{
2011
+ type: Input
2012
+ }], labelPosition: [{
2013
+ type: Input
2014
+ }], layout: [{
2015
+ type: Input
2016
+ }], layoutStyle: [{
2017
+ type: Input
2018
+ }], margin: [{
2019
+ type: Input
2020
+ }], maxDate: [{
2021
+ type: Input
2022
+ }], maxHeight: [{
2023
+ type: Input
2024
+ }], maximizeOnMobile: [{
2025
+ type: Input
2026
+ }], maxWidth: [{
2027
+ type: Input
2028
+ }], minDate: [{
2029
+ type: Input
2030
+ }], minHeight: [{
2031
+ type: Input
2032
+ }], minWidth: [{
2033
+ type: Input
2034
+ }], mode: [{
2035
+ type: Input
2036
+ }], modeDefaults: [{
2037
+ type: Input
2038
+ }], modes: [{
2039
+ type: Input
2040
+ }], nonWorkingDays: [{
2041
+ type: Input
2042
+ }], project: [{
2043
+ type: Input
2044
+ }], readOnly: [{
2045
+ type: Input
2046
+ }], recurrenceConfirmationPopup: [{
2047
+ type: Input
2048
+ }], rendition: [{
2049
+ type: Input
2050
+ }], resources: [{
2051
+ type: Input
2052
+ }], resourceTimeRanges: [{
2053
+ type: Input
2054
+ }], rtl: [{
2055
+ type: Input
2056
+ }], scrollable: [{
2057
+ type: Input
2058
+ }], selectResourceOnEventNavigate: [{
2059
+ type: Input
2060
+ }], selectResourceOnScheduleClick: [{
2061
+ type: Input
2062
+ }], span: [{
2063
+ type: Input
2064
+ }], strictRecordMapping: [{
2065
+ type: Input
2066
+ }], timeRanges: [{
2067
+ type: Input
2068
+ }], title: [{
2069
+ type: Input
2070
+ }], tools: [{
2071
+ type: Input
2072
+ }], tooltip: [{
2073
+ type: Input
2074
+ }], useContextualRecurrenceRules: [{
2075
+ type: Input
2076
+ }], width: [{
2077
+ type: Input
2078
+ }], x: [{
2079
+ type: Input
2080
+ }], y: [{
2081
+ type: Input
2082
+ }], activeSubView: [{
2083
+ type: Input
2084
+ }], activeView: [{
2085
+ type: Input
2086
+ }], anchorSize: [{
2087
+ type: Input
2088
+ }], focusVisible: [{
2089
+ type: Input
2090
+ }], hasChanges: [{
2091
+ type: Input
2092
+ }], isEngineReady: [{
2093
+ type: Input
2094
+ }], isSettingValues: [{
2095
+ type: Input
2096
+ }], isValid: [{
2097
+ type: Input
2098
+ }], parent: [{
2099
+ type: Input
2100
+ }], record: [{
2101
+ type: Input
2102
+ }], selectedEvents: [{
2103
+ type: Input
2104
+ }], state: [{
2105
+ type: Input
2106
+ }], values: [{
2107
+ type: Input
2108
+ }], views: [{
2109
+ type: Input
2110
+ }], dragFeature: [{
2111
+ type: Input
2112
+ }], eventBufferFeature: [{
2113
+ type: Input
2114
+ }], eventCopyPasteFeature: [{
2115
+ type: Input
2116
+ }], eventEditFeature: [{
2117
+ type: Input
2118
+ }], eventMenuFeature: [{
2119
+ type: Input
2120
+ }], eventTooltipFeature: [{
2121
+ type: Input
2122
+ }], excelExporterFeature: [{
2123
+ type: Input
2124
+ }], externalEventSourceFeature: [{
2125
+ type: Input
2126
+ }], loadOnDemandFeature: [{
2127
+ type: Input
2128
+ }], printFeature: [{
2129
+ type: Input
2130
+ }], scheduleMenuFeature: [{
2131
+ type: Input
2132
+ }], scheduleTooltipFeature: [{
2133
+ type: Input
2134
+ }], timeRangesFeature: [{
2135
+ type: Input
2136
+ }], weekExpanderFeature: [{
2137
+ type: Input
2138
+ }], onActiveItemChange: [{
2139
+ type: Output
2140
+ }], onAfterEventEdit: [{
2141
+ type: Output
2142
+ }], onAfterEventSave: [{
2143
+ type: Output
2144
+ }], onBeforeActiveItemChange: [{
2145
+ type: Output
2146
+ }], onBeforeAssignmentDelete: [{
2147
+ type: Output
2148
+ }], onBeforeAssignmentSelectionChange: [{
2149
+ type: Output
2150
+ }], onBeforeAutoCreate: [{
2151
+ type: Output
2152
+ }], onBeforeCopy: [{
2153
+ type: Output
2154
+ }], onBeforeCreateMode: [{
2155
+ type: Output
2156
+ }], onBeforeCSVExport: [{
2157
+ type: Output
2158
+ }], onBeforeDestroy: [{
2159
+ type: Output
2160
+ }], onBeforeDragCreate: [{
2161
+ type: Output
2162
+ }], onBeforeDragCreateEnd: [{
2163
+ type: Output
2164
+ }], onBeforeDragMove: [{
2165
+ type: Output
2166
+ }], onBeforeDragMoveEnd: [{
2167
+ type: Output
2168
+ }], onBeforeDragResize: [{
2169
+ type: Output
2170
+ }], onBeforeDragResizeEnd: [{
2171
+ type: Output
2172
+ }], onBeforeDropExternal: [{
2173
+ type: Output
2174
+ }], onBeforeEventDelete: [{
2175
+ type: Output
2176
+ }], onBeforeEventEdit: [{
2177
+ type: Output
2178
+ }], onBeforeEventEditShow: [{
2179
+ type: Output
2180
+ }], onBeforeEventSave: [{
2181
+ type: Output
2182
+ }], onBeforeEventSelectionChange: [{
2183
+ type: Output
2184
+ }], onBeforeExcelExport: [{
2185
+ type: Output
2186
+ }], onBeforeHide: [{
2187
+ type: Output
2188
+ }], onBeforePaste: [{
2189
+ type: Output
2190
+ }], onBeforePrint: [{
2191
+ type: Output
2192
+ }], onBeforeResponsiveStateChange: [{
2193
+ type: Output
2194
+ }], onBeforeSetRecord: [{
2195
+ type: Output
2196
+ }], onBeforeShow: [{
2197
+ type: Output
2198
+ }], onBeforeStateApply: [{
2199
+ type: Output
2200
+ }], onBeforeStateSave: [{
2201
+ type: Output
2202
+ }], onCatchAll: [{
2203
+ type: Output
2204
+ }], onCellOverflowClick: [{
2205
+ type: Output
2206
+ }], onCollapse: [{
2207
+ type: Output
2208
+ }], onContextMenuItem: [{
2209
+ type: Output
2210
+ }], onContextMenuToggleItem: [{
2211
+ type: Output
2212
+ }], onCopy: [{
2213
+ type: Output
2214
+ }], onCurrentTimelineUpdate: [{
2215
+ type: Output
2216
+ }], onDataChange: [{
2217
+ type: Output
2218
+ }], onDateChange: [{
2219
+ type: Output
2220
+ }], onDateRangeChange: [{
2221
+ type: Output
2222
+ }], onDateRangeLoad: [{
2223
+ type: Output
2224
+ }], onDateRangeRequested: [{
2225
+ type: Output
2226
+ }], onDayCellPopulated: [{
2227
+ type: Output
2228
+ }], onDayNumberClick: [{
2229
+ type: Output
2230
+ }], onDestroy: [{
2231
+ type: Output
2232
+ }], onDirtyStateChange: [{
2233
+ type: Output
2234
+ }], onDragCreateEnd: [{
2235
+ type: Output
2236
+ }], onDragMoveEnd: [{
2237
+ type: Output
2238
+ }], onDragMoveExternal: [{
2239
+ type: Output
2240
+ }], onDragResizeEnd: [{
2241
+ type: Output
2242
+ }], onDropExternal: [{
2243
+ type: Output
2244
+ }], onElementCreated: [{
2245
+ type: Output
2246
+ }], onEmptyCellClick: [{
2247
+ type: Output
2248
+ }], onEventAutoCreated: [{
2249
+ type: Output
2250
+ }], onEventClick: [{
2251
+ type: Output
2252
+ }], onEventContextMenu: [{
2253
+ type: Output
2254
+ }], onEventDblClick: [{
2255
+ type: Output
2256
+ }], onEventEditBeforeSetRecord: [{
2257
+ type: Output
2258
+ }], onEventKeyDown: [{
2259
+ type: Output
2260
+ }], onEventMenuBeforeShow: [{
2261
+ type: Output
2262
+ }], onEventMenuItem: [{
2263
+ type: Output
2264
+ }], onEventMenuShow: [{
2265
+ type: Output
2266
+ }], onEventMouseDown: [{
2267
+ type: Output
2268
+ }], onEventMouseEnter: [{
2269
+ type: Output
2270
+ }], onEventMouseLeave: [{
2271
+ type: Output
2272
+ }], onEventMouseOut: [{
2273
+ type: Output
2274
+ }], onEventMouseOver: [{
2275
+ type: Output
2276
+ }], onEventMouseUp: [{
2277
+ type: Output
2278
+ }], onEventPropagate: [{
2279
+ type: Output
2280
+ }], onExpand: [{
2281
+ type: Output
2282
+ }], onFocusIn: [{
2283
+ type: Output
2284
+ }], onFocusOut: [{
2285
+ type: Output
2286
+ }], onHide: [{
2287
+ type: Output
2288
+ }], onLoadOnDemandFail: [{
2289
+ type: Output
2290
+ }], onMonthNameClick: [{
2291
+ type: Output
2292
+ }], onNavigate: [{
2293
+ type: Output
2294
+ }], onPaint: [{
2295
+ type: Output
2296
+ }], onPaste: [{
2297
+ type: Output
2298
+ }], onPasteNotAllowed: [{
2299
+ type: Output
2300
+ }], onReadOnly: [{
2301
+ type: Output
2302
+ }], onRecompose: [{
2303
+ type: Output
2304
+ }], onRefresh: [{
2305
+ type: Output
2306
+ }], onResize: [{
2307
+ type: Output
2308
+ }], onResourceClick: [{
2309
+ type: Output
2310
+ }], onResponsiveStateChange: [{
2311
+ type: Output
2312
+ }], onScheduleClick: [{
2313
+ type: Output
2314
+ }], onScheduleContextMenu: [{
2315
+ type: Output
2316
+ }], onScheduleDblClick: [{
2317
+ type: Output
2318
+ }], onScheduleMenuBeforeShow: [{
2319
+ type: Output
2320
+ }], onScheduleMenuItem: [{
2321
+ type: Output
2322
+ }], onScheduleMenuShow: [{
2323
+ type: Output
2324
+ }], onScheduleMouseDown: [{
2325
+ type: Output
2326
+ }], onScheduleMouseOut: [{
2327
+ type: Output
2328
+ }], onScheduleMouseOver: [{
2329
+ type: Output
2330
+ }], onScheduleMouseUp: [{
2331
+ type: Output
2332
+ }], onSelectionChange: [{
2333
+ type: Output
2334
+ }], onShow: [{
2335
+ type: Output
2336
+ }], onSidebarCollapse: [{
2337
+ type: Output
2338
+ }], onSidebarExpand: [{
2339
+ type: Output
2340
+ }], onTimeAxisClick: [{
2341
+ type: Output
2342
+ }], onTimeRangeHeaderClick: [{
2343
+ type: Output
2344
+ }], onTimeRangeHeaderContextMenu: [{
2345
+ type: Output
2346
+ }], onTimeRangeHeaderDblClick: [{
2347
+ type: Output
2348
+ }], onToolClick: [{
2349
+ type: Output
2350
+ }], onViewPaint: [{
2351
+ type: Output
2352
+ }], onWeekNumberClick: [{
2353
+ type: Output
2354
+ }] } });
2355
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bryntum-calendar.component.js","sourceRoot":"","sources":["../../../component/src/lib/bryntum-calendar.component.ts"],"names":[],"mappings":"AAAA,sDAAsD;AACtD;;GAEG;AAEH,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,MAAM,EAAE,KAAK,EAAkD,MAAM,eAAe,CAAC;AAEnI,OAAO,aAAa,MAAM,kBAAkB,CAAC;AAE7C,OAAO,EAA6b,MAAM,EAAgB,MAAM,oBAAoB,CAAC;AAGrf,OAAO,EAAoB,QAAQ,EAA+7B,MAAM,wBAAwB,CAAC;AAEjgC,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;;AAqnClD,MAAM,OAAO,wBAAwB;IAufjC,YAAY,OAAmB;QATvB,kBAAa,GAAG;YACpB,KAAK,EAAc,SAAS;YAC5B,QAAQ,EAAW,SAAS;YAC5B,IAAI,EAAe,SAAS;YAC5B,gBAAgB,EAAG,IAAI;YACvB,QAAQ,EAAW,EAAE;YACrB,SAAS,EAAU,EAAE;SACxB,CAAC;QA0OF,kBAAkB;QAClB;;;;;;;;WAQG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAmI,CAAC;QACxL;;;;;;;;;;WAUG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAsN,CAAC;QACzQ;;;;;WAKG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAA4E,CAAC;QAC/H;;;;;;WAMG;QACO,6BAAwB,GAAQ,IAAI,YAAY,EAAmI,CAAC;QAC9L;;;;;;;;;;;;WAYG;QACO,6BAAwB,GAAQ,IAAI,YAAY,EAAsK,CAAC;QACjO;;;;;;;;;WASG;QACO,sCAAiC,GAAQ,IAAI,YAAY,EAAoN,CAAC;QACxR;;;;;;;;;;;WAWG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAA2K,CAAC;QAChO;;;;;;;;WAQG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAAkL,CAAC;QACjO;;;;;WAKG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAgS,CAAC;QACrV;;;;;;;;WAQG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAiK,CAAC;QACrN;;;;WAIG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAA8C,CAAC;QAChG;;;;;;;;;;;WAWG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAsM,CAAC;QAC3P;;;;;;;;;;;;;;WAcG;QACO,0BAAqB,GAAQ,IAAI,YAAY,EAAgS,CAAC;QACxV;;;;;;;;;;;;WAYG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAA+N,CAAC;QAClR;;;;;;;;;;;;;;;WAeG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAA8T,CAAC;QACpX;;;;;;;;;;;;WAYG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAA+N,CAAC;QACpR;;;;;;;;;;;;;;WAcG;QACO,0BAAqB,GAAQ,IAAI,YAAY,EAA8R,CAAC;QACtV;;;;;;;;;;;;;;;;;;;WAmBG;QACO,yBAAoB,GAAQ,IAAI,YAAY,EAAkT,CAAC;QACzW;;;;;;;;;;;;WAYG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAA2J,CAAC;QACjN;;;;;;;;;;;;WAYG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAA8L,CAAC;QAClP;;;;;;;;;;WAUG;QACO,0BAAqB,GAAQ,IAAI,YAAY,EAAoL,CAAC;QAC5O;;;;;;;;;;;;;WAaG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAyM,CAAC;QAC7P;;;;;;;;;WASG;QACO,iCAA4B,GAAQ,IAAI,YAAY,EAAqM,CAAC;QACpQ;;;;;;WAMG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACxK;;;;WAIG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAAyE,CAAC;QACxH;;;;;;;;;;;;;;;WAeG;QACO,kBAAa,GAAQ,IAAI,YAAY,EAA+S,CAAC;QAC/V;;;;WAIG;QACO,kBAAa,GAAQ,IAAI,YAAY,EAAyE,CAAC;QACzH;;;;;;WAMG;QACO,kCAA6B,GAAQ,IAAI,YAAY,EAAiF,CAAC;QACjJ;;;;;;WAMG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAkE,CAAC;QACtH;;;;WAIG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAA6E,CAAC;QAC5H;;;;WAIG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAqE,CAAC;QAC1H;;;;WAIG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAqE,CAAC;QACzH;;;;;;;WAOG;QACO,eAAU,GAAQ,IAAI,YAAY,EAAgE,CAAC;QAC7G;;;;;;;;;WASG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAAmF,CAAC;QACzI;;;;WAIG;QACO,eAAU,GAAQ,IAAI,YAAY,EAA+C,CAAC;QAC5F;;;;;;WAMG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAA4E,CAAC;QAChI;;;;;;;WAOG;QACO,4BAAuB,GAAQ,IAAI,YAAY,EAA8F,CAAC;QACxJ;;;;;;;;;;;;;WAaG;QACO,WAAM,GAAQ,IAAI,YAAY,EAA0O,CAAC;QACnR;;;;;WAKG;QACO,4BAAuB,GAAQ,IAAI,YAAY,EAA+D,CAAC;QACzH;;;;;;;;;;;;WAYG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAAoQ,CAAC;QACnT;;;;;;;;WAQG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAA6E,CAAC;QAC5H;;;;;;;;;;;;;WAaG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAoI,CAAC;QACxL;;;;;;;WAOG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAmG,CAAC;QACrJ;;;;;;;;;;;;;WAaG;QACO,yBAAoB,GAAQ,IAAI,YAAY,EAAsJ,CAAC;QAC7M;;;;;;;;;WASG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAuF,CAAC;QAC5I;;;;;;;;;;;;WAYG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAA2J,CAAC;QAC9M;;;;WAIG;QACO,cAAS,GAAQ,IAAI,YAAY,EAA8C,CAAC;QAC1F;;;;;WAKG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAmE,CAAC;QACxH;;;;;;;;;;;WAWG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAiO,CAAC;QACnR;;;;;;;;;;;;WAYG;QACO,kBAAa,GAAQ,IAAI,YAAY,EAAiO,CAAC;QACjR;;;;;;;;;;;;;;;;;WAiBG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAgQ,CAAC;QACrT;;;;;;;;;;WAUG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAiM,CAAC;QACnP;;;;;;;;;;;;;;;;;;WAkBG;QACO,mBAAc,GAAQ,IAAI,YAAY,EAAyR,CAAC;QAC1U;;;;WAIG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAsD,CAAC;QACzG;;;;;;;WAOG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAmF,CAAC;QACtI;;;;;;;;WAQG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAA+E,CAAC;QACpI;;;;;;;;;;WAUG;QACO,iBAAY,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACjP;;;;;;;;;;WAUG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACvP;;;;;;;;;;WAUG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACpP;;;;;;WAMG;QACO,+BAA0B,GAAQ,IAAI,YAAY,EAAuE,CAAC;QACpI;;;;;;;;;;WAUG;QACO,mBAAc,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACnP;;;;;;;;;;;;WAYG;QACO,0BAAqB,GAAQ,IAAI,YAAY,EAA4P,CAAC;QACpT;;;;;;;;;WASG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAyL,CAAC;QAC3O;;;;;;;;;WASG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAqL,CAAC;QACvO;;;;;;;;;;WAUG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACrP;;;;;;;;;;WAUG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACtP;;;;;;;;;;WAUG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACtP;;;;;;;;;;WAUG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACpP;;;;;;;;;;WAUG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACrP;;;;;;;;;;WAUG;QACO,mBAAc,GAAQ,IAAI,YAAY,EAAkM,CAAC;QACnP;;;;;;;;;;;;;;WAcG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAAmM,CAAC;QACtP;;;;WAIG;QACO,aAAQ,GAAQ,IAAI,YAAY,EAA+C,CAAC;QAC1F;;;;;;;;;WASG;QACO,cAAS,GAAQ,IAAI,YAAY,EAA4J,CAAC;QACxM;;;;;;;;;;;WAWG;QACO,eAAU,GAAQ,IAAI,YAAY,EAA4J,CAAC;QACzM;;;;WAIG;QACO,WAAM,GAAQ,IAAI,YAAY,EAAgD,CAAC;QACzF;;;;;;;;;WASG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAqF,CAAC;QAC1I;;;;;;;;;;WAUG;QACO,qBAAgB,GAAQ,IAAI,YAAY,EAA2H,CAAC;QAC9K;;;;;;WAMG;QACO,eAAU,GAAQ,IAAI,YAAY,EAAiG,CAAC;QAC9I;;;;;;;;WAQG;QACO,YAAO,GAAQ,IAAI,YAAY,EAAqE,CAAC;QAC/G;;;;;;;;;;;;;WAaG;QACO,YAAO,GAAQ,IAAI,YAAY,EAAwT,CAAC;QAClW;;;;;;;;;;;;;;;;WAgBG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAsU,CAAC;QAC1X;;;;WAIG;QACO,eAAU,GAAQ,IAAI,YAAY,EAAmD,CAAC;QAChG;;;WAGG;QACO,gBAAW,GAAQ,IAAI,YAAY,EAAuB,CAAC;QACrE;;;;WAIG;QACO,cAAS,GAAQ,IAAI,YAAY,EAAsD,CAAC;QAClG;;;;;;;;WAQG;QACO,aAAQ,GAAQ,IAAI,YAAY,EAAoH,CAAC;QAC/J;;;;;;;;;;;;;WAaG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAgO,CAAC;QAClR;;;;;;WAMG;QACO,4BAAuB,GAAQ,IAAI,YAAY,EAAiF,CAAC;QAC3I;;;;;;;WAOG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACpK;;;;;;;WAOG;QACO,0BAAqB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QAC1K;;;;;;;WAOG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACvK;;;;;;;;;;;WAWG;QACO,6BAAwB,GAAQ,IAAI,YAAY,EAA2N,CAAC;QACtR;;;;;;;;WAQG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAoI,CAAC;QACzL;;;;;;;;;WASG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAA4K,CAAC;QACjO;;;;;;;WAOG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACxK;;;;;;;WAOG;QACO,uBAAkB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACvK;;;;;;;WAOG;QACO,wBAAmB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACxK;;;;;;;WAOG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAkH,CAAC;QACtK;;;;;;;;WAQG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAA2K,CAAC;QAC/N;;;;WAIG;QACO,WAAM,GAAQ,IAAI,YAAY,EAAgD,CAAC;QACzF;;;;WAIG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAAkD,CAAC;QACtG;;;;WAIG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAkD,CAAC;QACpG;;;;;;;;WAQG;QACO,oBAAe,GAAQ,IAAI,YAAY,EAAsG,CAAC;QACxJ;;;;;;WAMG;QACO,2BAAsB,GAAQ,IAAI,YAAY,EAAoG,CAAC;QAC7J;;;;;;WAMG;QACO,iCAA4B,GAAQ,IAAI,YAAY,EAAoG,CAAC;QACnK;;;;;;WAMG;QACO,8BAAyB,GAAQ,IAAI,YAAY,EAAoG,CAAC;QAChK;;;;;WAKG;QACO,gBAAW,GAAQ,IAAI,YAAY,EAA0D,CAAC;QACxG;;;;;;;WAOG;QACO,gBAAW,GAAQ,IAAI,YAAY,EAA2E,CAAC;QACzH;;;;;;;;;;;WAWG;QACO,sBAAiB,GAAQ,IAAI,YAAY,EAA4H,CAAC;QAx2C5K,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;IAC9B,CAAC;IAy2CD;;OAEG;IACH,QAAQ;QACJ,MACI,EAAE,GAAG,IAAI,EACT,EACI,UAAU,EACV,aAAa,EAChB,GAAG,EAAE,EACN,EACI,aAAa,EACb,YAAY,EACZ,cAAc,EACd,aAAa,EAChB,GAAG,wBAAwB,CAAC;QAEjC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,IAAI,IAAI,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACvD,aAAa;YACb,aAAa,CAAC,cAAc,CAAC,aAAa,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YAC9D,IAAI,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBACvC,aAAa,CAAC,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;aAC1D;QACL,CAAC,CAAC,CAAC;QACH,aAAa;QACb,aAAa,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAC3F,MACI,YAAY,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAC1E,SAAS,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAE5D,aAAa;YACb,aAAa,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE;gBAC5C,aAAa;gBACb,EAAE,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAClB,sGAAsG;gBACtG,uBAAuB;gBACvB,OAAO,CAAC,CAAC,WAAW,CAAC;YACzB,CAAC,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,wFAAwF;QACxF,MACI,cAAc,GAAG;YACb,OAAO;YACP,UAAU;YACV,aAAa;YACb,cAAc;YACd,aAAa;SAChB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,cAAc,EAAE;YACjB,IAAI,YAAY,KAAK,QAAQ,IAAI,UAAU,CAAC,aAAa,CAAC,WAAW,EAAE,YAAY,UAAU,EAAE;gBAC3F,+DAA+D;gBAC/D,aAAa,CAAC,QAAQ,GAAG,UAAU,CAAC,aAAa,CAAC;aACrD;iBACI;gBACD,aAAa,CAAC,KAAK,GAAG,UAAU,CAAC,aAAa,CAAC;aAClD;SACJ;aACI;YACD,aAAa,CAAC,mBAAmB,CAAC,YAAY,EAAE,cAAc,CAAC,CAAC;SACnE;QAED,aAAa;QACb,EAAE,CAAC,QAAQ,GAAG,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,aAAa,CAAC,aAAa,CAAC,CAAC;QAE1G,mEAAmE;QACnE,aAAa;QACb,EAAE,CAAC,YAAY,CAAC,YAAY,CAAC,YAAY,CAAC,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC;QACvE,GAAG;IACP,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,OAAsB;QAC9B,MACI,EAAE,QAAQ,EAAE,GAAG,IAAI,EACnB,EAAE,YAAY,EAAE,GAAG,wBAAwB,CAAC;QAChD,IAAI,CAAC,QAAQ,EAAE;YACX,OAAO;SACV;QACD,2BAA2B;QAC3B,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE;YAC/C,MACI,QAAQ,GAAI,MAAuB,CAAC,YAAY,EAChD,EAAE,QAAQ,EAAE,GAAG,IAAI,EACnB,EAAE,kBAAkB,EAAE,YAAY,EAAE,GAAG,wBAAwB,CAAC;YACpE,IAAI,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBAC7B,aAAa,CAAC,cAAc,CAAC,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;gBAC9D,IAAI,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;oBACnC,aAAa,CAAC,oBAAoB,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;iBAC1D;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACH,WAAW;QACP,aAAa;QACb,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;YACxC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;SAC3B;IACL,CAAC;;AAz8Da,sCAAa,GAAG,QAAQ,CAAC;AAEzB,qCAAY,GAAG,UAAU,CAAC;AAEzB,sCAAa,GAAa;IACrC,oBAAoB;IACpB,kBAAkB;IAClB,kBAAkB;IAClB,0BAA0B;IAC1B,0BAA0B;IAC1B,mCAAmC;IACnC,oBAAoB;IACpB,cAAc;IACd,oBAAoB;IACpB,mBAAmB;IACnB,iBAAiB;IACjB,oBAAoB;IACpB,uBAAuB;IACvB,kBAAkB;IAClB,qBAAqB;IACrB,oBAAoB;IACpB,uBAAuB;IACvB,sBAAsB;IACtB,qBAAqB;IACrB,mBAAmB;IACnB,uBAAuB;IACvB,mBAAmB;IACnB,8BAA8B;IAC9B,qBAAqB;IACrB,cAAc;IACd,eAAe;IACf,eAAe;IACf,+BAA+B;IAC/B,mBAAmB;IACnB,cAAc;IACd,oBAAoB;IACpB,mBAAmB;IACnB,YAAY;IACZ,qBAAqB;IACrB,YAAY;IACZ,mBAAmB;IACnB,yBAAyB;IACzB,QAAQ;IACR,yBAAyB;IACzB,cAAc;IACd,cAAc;IACd,mBAAmB;IACnB,iBAAiB;IACjB,sBAAsB;IACtB,oBAAoB;IACpB,kBAAkB;IAClB,WAAW;IACX,oBAAoB;IACpB,iBAAiB;IACjB,eAAe;IACf,oBAAoB;IACpB,iBAAiB;IACjB,gBAAgB;IAChB,kBAAkB;IAClB,kBAAkB;IAClB,oBAAoB;IACpB,cAAc;IACd,oBAAoB;IACpB,iBAAiB;IACjB,4BAA4B;IAC5B,gBAAgB;IAChB,uBAAuB;IACvB,iBAAiB;IACjB,iBAAiB;IACjB,kBAAkB;IAClB,mBAAmB;IACnB,mBAAmB;IACnB,iBAAiB;IACjB,kBAAkB;IAClB,gBAAgB;IAChB,kBAAkB;IAClB,UAAU;IACV,WAAW;IACX,YAAY;IACZ,QAAQ;IACR,oBAAoB;IACpB,kBAAkB;IAClB,YAAY;IACZ,SAAS;IACT,SAAS;IACT,mBAAmB;IACnB,YAAY;IACZ,aAAa;IACb,WAAW;IACX,UAAU;IACV,iBAAiB;IACjB,yBAAyB;IACzB,iBAAiB;IACjB,uBAAuB;IACvB,oBAAoB;IACpB,0BAA0B;IAC1B,oBAAoB;IACpB,oBAAoB;IACpB,qBAAqB;IACrB,oBAAoB;IACpB,qBAAqB;IACrB,mBAAmB;IACnB,mBAAmB;IACnB,QAAQ;IACR,mBAAmB;IACnB,iBAAiB;IACjB,iBAAiB;IACjB,wBAAwB;IACxB,8BAA8B;IAC9B,2BAA2B;IAC3B,aAAa;IACb,aAAa;IACb,mBAAmB;CACtB,CAAC;AAEa,4CAAmB,GAAa;IAC3C,aAAa;IACb,oBAAoB;IACpB,uBAAuB;IACvB,kBAAkB;IAClB,kBAAkB;IAClB,qBAAqB;IACrB,sBAAsB;IACtB,4BAA4B;IAC5B,qBAAqB;IACrB,cAAc;IACd,qBAAqB;IACrB,wBAAwB;IACxB,mBAAmB;IACnB,qBAAqB;CACxB,CAAC;AAEa,uCAAc,GAAa,wBAAwB,CAAC,mBAAmB,CAAC,MAAM,CAAC;IAC1F,eAAe;IACf,OAAO;IACP,OAAO;IACP,WAAW;IACX,QAAQ;IACR,UAAU;IACV,iBAAiB;IACjB,WAAW;IACX,aAAa;IACb,iBAAiB;IACjB,YAAY;IACZ,MAAM;IACN,SAAS;IACT,cAAc;IACd,iBAAiB;IACjB,6BAA6B;IAC7B,UAAU;IACV,KAAK;IACL,WAAW;IACX,aAAa;IACb,OAAO;IACP,QAAQ;IACR,QAAQ;IACR,aAAa;IACb,mBAAmB;IACnB,yBAAyB;IACzB,aAAa;IACb,kBAAkB;IAClB,WAAW;IACX,SAAS;IACT,MAAM;IACN,YAAY;IACZ,YAAY;IACZ,qBAAqB;IACrB,iBAAiB;IACjB,cAAc;IACd,UAAU;IACV,4BAA4B;IAC5B,iBAAiB;IACjB,eAAe;IACf,8BAA8B;IAC9B,UAAU;IACV,MAAM;IACN,WAAW;IACX,QAAQ;IACR,mBAAmB;IACnB,iBAAiB;IACjB,uBAAuB;IACvB,oBAAoB;IACpB,QAAQ;IACR,wBAAwB;IACxB,YAAY;IACZ,WAAW;IACX,sBAAsB;IACtB,MAAM;IACN,UAAU;IACV,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,QAAQ;IACR,eAAe;IACf,oBAAoB;IACpB,eAAe;IACf,eAAe;IACf,uBAAuB;IACvB,qBAAqB;IACrB,MAAM;IACN,IAAI;IACJ,sBAAsB;IACtB,uBAAuB;IACvB,iBAAiB;IACjB,cAAc;IACd,aAAa;IACb,mBAAmB;IACnB,SAAS;IACT,OAAO;IACP,QAAQ;IACR,eAAe;IACf,QAAQ;IACR,aAAa;IACb,WAAW;IACX,WAAW;IACX,UAAU;IACV,kBAAkB;IAClB,eAAe;IACf,aAAa;IACb,aAAa;IACb,uBAAuB;IACvB,kCAAkC;IAClC,QAAQ;IACR,cAAc;IACd,QAAQ;IACR,SAAS;IACT,WAAW;IACX,kBAAkB;IAClB,UAAU;IACV,SAAS;IACT,WAAW;IACX,UAAU;IACV,MAAM;IACN,cAAc;IACd,OAAO;IACP,eAAe;IACf,kBAAkB;IAClB,YAAY;IACZ,oBAAoB;IACpB,gBAAgB;IAChB,gBAAgB;IAChB,OAAO;IACP,YAAY;IACZ,uBAAuB;IACvB,SAAS;IACT,mBAAmB;IACnB,UAAU;IACV,6BAA6B;IAC7B,kBAAkB;IAClB,WAAW;IACX,mBAAmB;IACnB,WAAW;IACX,eAAe;IACf,oBAAoB;IACpB,wBAAwB;IACxB,YAAY;IACZ,gBAAgB;IAChB,iBAAiB;IACjB,kBAAkB;IAClB,QAAQ;IACR,aAAa;IACb,KAAK;IACL,YAAY;IACZ,cAAc;IACd,+BAA+B;IAC/B,+BAA+B;IAC/B,eAAe;IACf,iBAAiB;IACjB,yBAAyB;IACzB,SAAS;IACT,MAAM;IACN,UAAU;IACV,gBAAgB;IAChB,SAAS;IACT,eAAe;IACf,qBAAqB;IACrB,QAAQ;IACR,UAAU;IACV,KAAK;IACL,aAAa;IACb,KAAK;IACL,MAAM;IACN,WAAW;IACX,YAAY;IACZ,gBAAgB;IAChB,UAAU;IACV,OAAO;IACP,OAAO;IACP,SAAS;IACT,WAAW;IACX,gCAAgC;IAChC,MAAM;IACN,IAAI;IACJ,8BAA8B;IAC9B,eAAe;IACf,cAAc;IACd,QAAQ;IACR,OAAO;IACP,GAAG;IACH,GAAG;CACN,CAAC,CAAC;AAEY,2CAAkB,GAAa;IAC1C,OAAO;IACP,OAAO;IACP,QAAQ;IACR,iBAAiB;IACjB,WAAW;IACX,iBAAiB;IACjB,YAAY;IACZ,MAAM;IACN,SAAS;IACT,cAAc;IACd,UAAU;IACV,aAAa;IACb,OAAO;IACP,QAAQ;IACR,aAAa;IACb,mBAAmB;IACnB,yBAAyB;IACzB,kBAAkB;IAClB,WAAW;IACX,YAAY;IACZ,qBAAqB;IACrB,cAAc;IACd,UAAU;IACV,iBAAiB;IACjB,eAAe;IACf,8BAA8B;IAC9B,MAAM;IACN,WAAW;IACX,QAAQ;IACR,mBAAmB;IACnB,iBAAiB;IACjB,uBAAuB;IACvB,oBAAoB;IACpB,wBAAwB;IACxB,YAAY;IACZ,sBAAsB;IACtB,UAAU;IACV,QAAQ;IACR,QAAQ;IACR,eAAe;IACf,eAAe;IACf,eAAe;IACf,uBAAuB;IACvB,qBAAqB;IACrB,MAAM;IACN,sBAAsB;IACtB,uBAAuB;IACvB,SAAS;IACT,WAAW;IACX,WAAW;IACX,UAAU;IACV,kBAAkB;IAClB,eAAe;IACf,aAAa;IACb,aAAa;IACb,uBAAuB;IACvB,kCAAkC;IAClC,cAAc;IACd,QAAQ;IACR,eAAe;IACf,kBAAkB;IAClB,YAAY;IACZ,oBAAoB;IACpB,gBAAgB;IAChB,OAAO;IACP,YAAY;IACZ,uBAAuB;IACvB,mBAAmB;IACnB,kBAAkB;IAClB,mBAAmB;IACnB,eAAe;IACf,wBAAwB;IACxB,YAAY;IACZ,gBAAgB;IAChB,iBAAiB;IACjB,kBAAkB;IAClB,QAAQ;IACR,aAAa;IACb,cAAc;IACd,eAAe;IACf,iBAAiB;IACjB,yBAAyB;IACzB,SAAS;IACT,UAAU;IACV,gBAAgB;IAChB,SAAS;IACT,eAAe;IACf,QAAQ;IACR,UAAU;IACV,KAAK;IACL,aAAa;IACb,KAAK;IACL,MAAM;IACN,WAAW;IACX,gBAAgB;IAChB,UAAU;IACV,WAAW;IACX,gCAAgC;IAChC,MAAM;IACN,IAAI;IACJ,eAAe;IACf,cAAc;IACd,QAAQ;CACX,CAAC;AAEa,qCAAY,GAAa,wBAAwB,CAAC,mBAAmB,CAAC,MAAM,CAAC;IACxF,eAAe;IACf,eAAe;IACf,YAAY;IACZ,WAAW;IACX,YAAY;IACZ,UAAU;IACV,aAAa;IACb,iBAAiB;IACjB,6BAA6B;IAC7B,KAAK;IACL,WAAW;IACX,QAAQ;IACR,aAAa;IACb,SAAS;IACT,MAAM;IACN,YAAY;IACZ,iBAAiB;IACjB,4BAA4B;IAC5B,UAAU;IACV,QAAQ;IACR,WAAW;IACX,MAAM;IACN,cAAc;IACd,YAAY;IACZ,QAAQ;IACR,QAAQ;IACR,oBAAoB;IACpB,IAAI;IACJ,iBAAiB;IACjB,cAAc;IACd,aAAa;IACb,eAAe;IACf,mBAAmB;IACnB,iBAAiB;IACjB,SAAS;IACT,OAAO;IACP,QAAQ;IACR,eAAe;IACf,QAAQ;IACR,aAAa;IACb,QAAQ;IACR,SAAS;IACT,WAAW;IACX,kBAAkB;IAClB,UAAU;IACV,SAAS;IACT,WAAW;IACX,UAAU;IACV,MAAM;IACN,cAAc;IACd,OAAO;IACP,gBAAgB;IAChB,QAAQ;IACR,SAAS;IACT,UAAU;IACV,QAAQ;IACR,6BAA6B;IAC7B,WAAW;IACX,WAAW;IACX,oBAAoB;IACpB,KAAK;IACL,YAAY;IACZ,gBAAgB;IAChB,+BAA+B;IAC/B,+BAA+B;IAC/B,MAAM;IACN,OAAO;IACP,qBAAqB;IACrB,YAAY;IACZ,OAAO;IACP,OAAO;IACP,SAAS;IACT,8BAA8B;IAC9B,QAAQ;IACR,OAAO;IACP,OAAO;IACP,GAAG;IACH,GAAG;CACN,CAAC,CAAC;qHAzeM,wBAAwB;yGAAxB,wBAAwB,k2TAFtB,EAAE;2FAEJ,wBAAwB;kBAJpC,SAAS;mBAAC;oBACP,QAAQ,EAAG,kBAAkB;oBAC7B,QAAQ,EAAG,EAAE;iBAChB;iGA6fY,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,uBAAuB;sBAA/B,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,4BAA4B;sBAApC,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBAGG,kBAAkB;sBAA1B,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAKG,MAAM;sBAAd,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,gCAAgC;sBAAxC,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAGG,gBAAgB;sBAAxB,KAAK;gBAKG,UAAU;sBAAlB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAMG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,uBAAuB;sBAA/B,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,8BAA8B;sBAAtC,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,EAAE;sBAAV,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,2BAA2B;sBAAnC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,GAAG;sBAAX,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,6BAA6B;sBAArC,KAAK;gBACG,6BAA6B;sBAArC,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,4BAA4B;sBAApC,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,CAAC;sBAAT,KAAK;gBACG,CAAC;sBAAT,KAAK;gBAGG,aAAa;sBAArB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,KAAK;sBAAb,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,qBAAqB;sBAA7B,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,oBAAoB;sBAA5B,KAAK;gBACG,0BAA0B;sBAAlC,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,iBAAiB;sBAAzB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAYI,kBAAkB;sBAA3B,MAAM;gBAYG,gBAAgB;sBAAzB,MAAM;gBAOG,gBAAgB;sBAAzB,MAAM;gBAQG,wBAAwB;sBAAjC,MAAM;gBAcG,wBAAwB;sBAAjC,MAAM;gBAWG,iCAAiC;sBAA1C,MAAM;gBAaG,kBAAkB;sBAA3B,MAAM;gBAUG,YAAY;sBAArB,MAAM;gBAOG,kBAAkB;sBAA3B,MAAM;gBAUG,iBAAiB;sBAA1B,MAAM;gBAMG,eAAe;sBAAxB,MAAM;gBAaG,kBAAkB;sBAA3B,MAAM;gBAgBG,qBAAqB;sBAA9B,MAAM;gBAcG,gBAAgB;sBAAzB,MAAM;gBAiBG,mBAAmB;sBAA5B,MAAM;gBAcG,kBAAkB;sBAA3B,MAAM;gBAgBG,qBAAqB;sBAA9B,MAAM;gBAqBG,oBAAoB;sBAA7B,MAAM;gBAcG,mBAAmB;sBAA5B,MAAM;gBAcG,iBAAiB;sBAA1B,MAAM;gBAYG,qBAAqB;sBAA9B,MAAM;gBAeG,iBAAiB;sBAA1B,MAAM;gBAWG,4BAA4B;sBAArC,MAAM;gBAQG,mBAAmB;sBAA5B,MAAM;gBAMG,YAAY;sBAArB,MAAM;gBAiBG,aAAa;sBAAtB,MAAM;gBAMG,aAAa;sBAAtB,MAAM;gBAQG,6BAA6B;sBAAtC,MAAM;gBAQG,iBAAiB;sBAA1B,MAAM;gBAMG,YAAY;sBAArB,MAAM;gBAMG,kBAAkB;sBAA3B,MAAM;gBAMG,iBAAiB;sBAA1B,MAAM;gBASG,UAAU;sBAAnB,MAAM;gBAWG,mBAAmB;sBAA5B,MAAM;gBAMG,UAAU;sBAAnB,MAAM;gBAQG,iBAAiB;sBAA1B,MAAM;gBASG,uBAAuB;sBAAhC,MAAM;gBAeG,MAAM;sBAAf,MAAM;gBAOG,uBAAuB;sBAAhC,MAAM;gBAcG,YAAY;sBAArB,MAAM;gBAUG,YAAY;sBAArB,MAAM;gBAeG,iBAAiB;sBAA1B,MAAM;gBASG,eAAe;sBAAxB,MAAM;gBAeG,oBAAoB;sBAA7B,MAAM;gBAWG,kBAAkB;sBAA3B,MAAM;gBAcG,gBAAgB;sBAAzB,MAAM;gBAMG,SAAS;sBAAlB,MAAM;gBAOG,kBAAkB;sBAA3B,MAAM;gBAaG,eAAe;sBAAxB,MAAM;gBAcG,aAAa;sBAAtB,MAAM;gBAmBG,kBAAkB;sBAA3B,MAAM;gBAYG,eAAe;sBAAxB,MAAM;gBAoBG,cAAc;sBAAvB,MAAM;gBAMG,gBAAgB;sBAAzB,MAAM;gBASG,gBAAgB;sBAAzB,MAAM;gBAUG,kBAAkB;sBAA3B,MAAM;gBAYG,YAAY;sBAArB,MAAM;gBAYG,kBAAkB;sBAA3B,MAAM;gBAYG,eAAe;sBAAxB,MAAM;gBAQG,0BAA0B;sBAAnC,MAAM;gBAYG,cAAc;sBAAvB,MAAM;gBAcG,qBAAqB;sBAA9B,MAAM;gBAWG,eAAe;sBAAxB,MAAM;gBAWG,eAAe;sBAAxB,MAAM;gBAYG,gBAAgB;sBAAzB,MAAM;gBAYG,iBAAiB;sBAA1B,MAAM;gBAYG,iBAAiB;sBAA1B,MAAM;gBAYG,eAAe;sBAAxB,MAAM;gBAYG,gBAAgB;sBAAzB,MAAM;gBAYG,cAAc;sBAAvB,MAAM;gBAgBG,gBAAgB;sBAAzB,MAAM;gBAMG,QAAQ;sBAAjB,MAAM;gBAWG,SAAS;sBAAlB,MAAM;gBAaG,UAAU;sBAAnB,MAAM;gBAMG,MAAM;sBAAf,MAAM;gBAWG,kBAAkB;sBAA3B,MAAM;gBAYG,gBAAgB;sBAAzB,MAAM;gBAQG,UAAU;sBAAnB,MAAM;gBAUG,OAAO;sBAAhB,MAAM;gBAeG,OAAO;sBAAhB,MAAM;gBAkBG,iBAAiB;sBAA1B,MAAM;gBAMG,UAAU;sBAAnB,MAAM;gBAKG,WAAW;sBAApB,MAAM;gBAMG,SAAS;sBAAlB,MAAM;gBAUG,QAAQ;sBAAjB,MAAM;gBAeG,eAAe;sBAAxB,MAAM;gBAQG,uBAAuB;sBAAhC,MAAM;gBASG,eAAe;sBAAxB,MAAM;gBASG,qBAAqB;sBAA9B,MAAM;gBASG,kBAAkB;sBAA3B,MAAM;gBAaG,wBAAwB;sBAAjC,MAAM;gBAUG,kBAAkB;sBAA3B,MAAM;gBAWG,kBAAkB;sBAA3B,MAAM;gBASG,mBAAmB;sBAA5B,MAAM;gBASG,kBAAkB;sBAA3B,MAAM;gBASG,mBAAmB;sBAA5B,MAAM;gBASG,iBAAiB;sBAA1B,MAAM;gBAUG,iBAAiB;sBAA1B,MAAM;gBAMG,MAAM;sBAAf,MAAM;gBAMG,iBAAiB;sBAA1B,MAAM;gBAMG,eAAe;sBAAxB,MAAM;gBAUG,eAAe;sBAAxB,MAAM;gBAQG,sBAAsB;sBAA/B,MAAM;gBAQG,4BAA4B;sBAArC,MAAM;gBAQG,yBAAyB;sBAAlC,MAAM;gBAOG,WAAW;sBAApB,MAAM;gBASG,WAAW;sBAApB,MAAM;gBAaG,iBAAiB;sBAA1B,MAAM","sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n/**\n * Angular wrapper for Bryntum Calendar\n */\n\nimport { Component, ElementRef, EventEmitter, Output, Input, SimpleChange, SimpleChanges, OnDestroy, OnInit } from '@angular/core';\n\nimport WrapperHelper from './wrapper.helper';\n\nimport { AlignSpec, Base, ButtonConfig, Container, ContainerConfig, DatePickerConfig, DomConfig, DragContext, KeyMapConfig, Layout, Mask, MaskConfig, Menu, MenuItem, MenuItemConfig, MenuItemEntry, Model, PagingToolbarConfig, Panel, PanelCollapserConfig, PanelCollapserOverlayConfig, PanelHeader, Popup, Rectangle, Scroller, ScrollerConfig, StateProvider, Store, TabConfig, TextFieldConfig, Tool, ToolConfig, ToolbarConfig, ToolbarItems, TooltipConfig, Widget, WidgetConfig } from '@bryntum/core-thin';\nimport { Column, ExportConfig, XLSColumn } from '@bryntum/grid-thin';\nimport { AssignmentModel, AssignmentModelConfig, AssignmentStore, AssignmentStoreConfig, CrudManager as SchedulerCrudManager, EventEdit as SchedulerEventEdit, EventModel, EventModelConfig, EventStore, EventStoreConfig, ProjectConsumer, ProjectModelMixin, RecurrenceConfirmationPopup, RecurrenceConfirmationPopupConfig, ResourceFilterConfig, ResourceModel, ResourceModelConfig, ResourceStore, ResourceStoreConfig, ResourceTimeRangeModel, ResourceTimeRangeModelConfig, ResourceTimeRangeStore, ResourceTimeRangeStoreConfig, Scheduler, TimeSpan } from '@bryntum/scheduler-thin';\nimport { AgendaViewConfig, Calendar, CalendarDatePickerConfig, CalendarDrag, CalendarDragConfig, CalendarListeners, CalendarToolbarConfig, CalendarView, CalendarContainerItemConfig, CalendarContainerLayoutConfig, CrudManagerConfig, DayAgendaViewConfig, DayCell, DayResourceViewConfig, DayViewConfig, EventBuffer, EventBufferConfig, EventCopyPaste, EventCopyPasteConfig, EventEdit, EventEditConfig, EventListConfig, EventMenu, EventMenuConfig, EventTooltip, EventTooltipConfig, ExcelExporter, ExcelExporterConfig, ExternalEventSource, ExternalEventSourceConfig, LoadOnDemand, LoadOnDemandConfig, MonthAgendaViewConfig, MonthGridConfig, MonthViewConfig, Print, PrintConfig, ProjectModel, ProjectModelConfig, ResourceViewConfig, ScheduleMenu, ScheduleMenuConfig, ScheduleTooltip, ScheduleTooltipConfig, TimeRangeModel, TimeRangeModelConfig, TimeRangeStore, TimeRangeStoreConfig, TimeRanges, TimeRangesConfig, ValidateCreateResult, WeekExpander, WeekExpanderConfig, WeekViewConfig, YearViewConfig } from '@bryntum/calendar-thin';\n\nimport { StringHelper } from '@bryntum/core-thin';\n\nexport type BryntumCalendarProps = {\n    // Configs\n    /**\n     * An optional CSS class name to add to calendar date cells which encapsulate the calendar's\n     * active [date](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#property-date).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-activeDateCls)\n     */\n    activeDateCls ? : string\n    /**\n     * Element (or element id) to adopt as this Widget's encapsulating element. The widget's\n     * content will be placed inside this element.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-adopt)\n     */\n    adopt ? : HTMLElement|string\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-align)\n     */\n    align ? : AlignSpec|string\n    /**\n     * When this widget is a child of a [Container](https://bryntum.com/products/calendar/docs/api/Core/widget/Container), it will by default be participating in a\n     * flexbox layout. This config allows you to set this widget's\n     * [align-self](https://developer.mozilla.org/en-US/docs/Web/CSS/align-self) style.\n     */\n    alignSelf ? : string\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating) and being shown through [showBy](#Core/widget/Widget#function-showBy).*\n     * `true` to show a connector arrow pointing to the align target.\n     */\n    anchor ? : boolean\n    /**\n     * Element (or the id of an element) to append this widget's element to. Can be configured, or set once at\n     * runtime. To access the element of a rendered widget, see [element](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-element).\n     */\n    appendTo ? : HTMLElement|string\n    /**\n     * A localizable string (May contain `'L{}'` tokens which resolve in the locale file) to inject\n     * into an element which will be linked using the `aria-describedby` attribute.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-ariaDescription)\n     */\n    ariaDescription ? : string\n    /**\n     * A localizable string (May contain `'L{}'` tokens which resolve in the locale file) to inject as\n     * the `aria-label` attribute.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-ariaLabel)\n     */\n    ariaLabel ? : string\n    /**\n     * Inline assignments, will be loaded into the [assignmentStore](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#property-assignmentStore).\n     */\n    assignments ? : AssignmentModel[]|AssignmentModelConfig[]\n    /**\n     * The [AssignmentStore](https://bryntum.com/products/calendar/docs/api/Scheduler/data/AssignmentStore) or a reconfiguring object for a store which will hold assignments linking resources to events.\n     */\n    assignmentStore ? : AssignmentStore|AssignmentStoreConfig\n    /**\n     * If this config is set, then the `gesture` configured (which defaults to `dblclick`) creates a\n     * new event at the mouse or touch event's time point.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-autoCreate)\n     */\n    autoCreate ? : {\n        gesture?: string\n        newName?: Function|string\n        step?: string\n        duration?: string\n        startHour?: number|string\n    }|string|boolean\n    /**\n     * A Config object representing the configuration of a [Toolbar](https://bryntum.com/products/calendar/docs/api/Core/widget/Toolbar),\n     * or array of config objects representing the child items of a Toolbar. Another way to add a bbar is to use [strips](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-strips).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-bbar)\n     */\n    bbar ? : (CalendarContainerItemConfig|string)[]|ToolbarConfig|PagingToolbarConfig|null\n    /**\n     * Custom CSS classes to add to the panel's body element.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-bodyCls)\n     */\n    bodyCls ? : string|object\n    /**\n     * An object where property names with a truthy value indicate which events should bubble up the ownership\n     * hierarchy when triggered.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-bubbleEvents)\n     */\n    bubbleEvents ? : object\n    /**\n     * Set to `false` to not call onXXX method names (e.g. `onShow`, `onClick`), as an easy way to listen for events.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-callOnFunctions)\n     */\n    callOnFunctions ? : boolean\n    /**\n     * By default, if an event handler throws an exception, the error propagates up the stack and the\n     * application state is undefined. Code which follows the event handler will *not* be executed.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-catchEventHandlerExceptions)\n     */\n    catchEventHandlerExceptions ? : boolean\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * Set to `true` to centre the Widget in browser viewport space.\n     */\n    centered ? : boolean\n    /**\n     * Custom CSS classes to add to element.\n     * May be specified as a space separated string, or as an object in which property names\n     * with truthy values are used as the class names:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-cls)\n     */\n    cls ? : string|object\n    /**\n     * Controls whether the panel is collapsed (the body of the panel is hidden while only the header is\n     * visible). Only valid if the panel is [collapsible](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsible).\n     */\n    collapsed ? : boolean\n    /**\n     * This config enables collapsibility for the panel. See [collapsed](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsed).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-collapsible)\n     */\n    collapsible ? : boolean|PanelCollapserConfig|PanelCollapserOverlayConfig\n    /**\n     * Applies the specified color to the widget, by setting the `--b-primary` CSS variable in the widgets\n     * `style` block.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-color)\n     */\n    color ? : string\n    /**\n     * Programmatic control over which column to start in when used in a grid layout.\n     */\n    column ? : number\n    config ? : object\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating) or [positioned](#Core/widget/Widget#config-positioned).*\n     * Element, Widget or Rectangle to which this Widget is constrained.\n     */\n    constrainTo ? : HTMLElement|Widget|Rectangle\n    /**\n     * Custom CSS classes to add to the [contentElement](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-contentElement).\n     * May be specified as a space separated string, or as an object in which property names\n     * with truthy values are used as the class names:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-contentElementCls)\n     */\n    contentElementCls ? : string|object\n    /**\n     * Event which is used to show context menus via the context menu features\n     * [EventMenu](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventMenu) and [ScheduleMenu](#Calendar/feature/ScheduleMenu).\n     * Available options are: 'contextmenu', 'click', 'dblclick'.\n     */\n    contextMenuTriggerEvent ? : 'contextmenu'|'click'|'dblclick'\n    /**\n     * Supply a [CrudManager](https://bryntum.com/products/calendar/docs/api/Scheduler/data/CrudManager) instance or a config object if you want to use\n     * CrudManager for handling data.\n     */\n    crudManager ? : CrudManagerConfig|SchedulerCrudManager\n    /**\n     * Class that should be used to instantiate a CrudManager in case it's provided as a simple object to\n     * [crudManager](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#config-crudManager) config.\n     */\n    crudManagerClass ? : SchedulerCrudManager\n    /**\n     * When this Widget configuration is used in the Grid's RowExpander feature's `widget` config, provide the\n     * field on the expanded record to use for populating this widget's store (if applicable)\n     */\n    dataField ? : string\n    /**\n     * Object to apply to elements dataset (each key will be used as a data-attribute on the element)\n     */\n    dataset ? : Record<string, string>\n    /**\n     * The date which the Calendar, its [sidebar](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#property-sidebar)'s date picker, and\n     * its active view should encapsulate upon creation.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-date)\n     */\n    date ? : Date|string\n    /**\n     * A [DateHelper](https://bryntum.com/products/calendar/docs/api/Core/helper/DateHelper) format string to use to create date output for\n     * view descriptions.\n     */\n    dateFormat ? : string\n    /**\n     * An optional config object to configure the [CalendarDatePicker](https://bryntum.com/products/calendar/docs/api/Calendar/widget/CalendarDatePicker) which is\n     * shown in the [sidebar](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#property-sidebar) next to the calendar views.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-datePicker)\n     * @param {boolean,'count','dots'} datePicker.showEvents Displays the presence of events in each cell. values may be:  * `false` - Do not show events in cells. * `true` - Show a themeable bullet to indicate the presence of events for a date. * `'count'` - Show a themeable badge containing the event count for a date. * '`dots'` - Show small event-coloured bullets (to a maximum of three) below the date.\n     * @param {boolean} datePicker.collapsible `true` to enable collapse into a header.\n     * @param {string} datePicker.title The text to place in a header above the picker.\n     * @param {boolean} datePicker.editMonth `true` to enable setting the date using the controls in the DatePicker header.\n     * @param {boolean,'range'} multiSelect The DatePicker can select [multiple dates](https://bryntum.com/products/calendar/docs/api/Core/widget/DatePicker#config-multiSelect) in two modes:  * `true` to mean many discontiguous dates may be selected. * `'range'` to mean that a start date and end date may be selected.  If set up to multi select, views which are not fixed to a date duration will obey the date selection by using a [dateFilter](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView#property-dateFilter) to skip days which are not selected. These include:  * AgendaView      (mode type `'agenda'`) * DayViews        (view type `'dayview'`) which you add to the modes - The default `day` and `week` modes have a fixed duration. * ResourceView    (view type `'resourceview'`) * DayResourceView (view type `'dayresourceview'`)  The `MonthView`, and the `WeekView` and the built-in single day `DayView` <strong>mode</strong> all have fixed duration and will not participate in this. If you select a discontiguous range, then the views which are amenable to being controlled in this way will switch their range to encompass what you have selected. For example, if you select the first to the last days of a month, the view's [range](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DateRangeOwner#property-range) will be set to `'1 month'`. This choice will be maintained, and by navigating using the next and previous tbar buttons, the views will move by exactly one month. If your set of selected dates is enclosed within a two week block, then the [range](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DateRangeOwner#property-range) of the views will be set to `{ unit : 'week', magnitude : 2 }`. If you select the 1st, 3th and 5th of the month, and those days are all on one week row, the [range](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DateRangeOwner#property-range) of the views will be set to `{ unit : 'week', magnitude : 1 }`. For selection ranges other than exactly one month, navigation in time will be in increments of one week for intuitive navigation up and down the date picker. When navigating in time, the selected block of dates moves and *follows the time navigation* so that there are always dates in view, even if they are empty.\n     */\n    datePicker ? : CalendarDatePickerConfig|boolean|null\n    /**\n     * The name of the property to set when a single value is to be applied to this Widget. Such as when used\n     * in a grid WidgetColumn, this is the property to which the column's `field` is applied.\n     */\n    defaultBindProperty ? : string\n    /**\n     * The calendar ([Resource](https://bryntum.com/products/calendar/docs/api/Scheduler/model/ResourceModel)), (or its `id`) to use as the\n     * default calendar for new events created using [dblclick](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-autoCreate)\n     * or [drag-create](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag), or [dragging in](#Calendar/feature/ExternalEventSource).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-defaultCalendar)\n     */\n    defaultCalendar ? : string|ResourceModel\n    /**\n     * A [query](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#function-query) selector function which can identify the descendant widget to which\n     * focus should be directed by default.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-defaultFocus)\n     * @param {Core.widget.Widget} widget Widget passed to method\n     * @returns {boolean} truthy value if widget is the default one\n     */\n    defaultFocus ? : ((widget: Widget) => boolean)|string\n    /**\n     * A config object containing default settings to apply to all child widgets.\n     */\n    defaults ? : CalendarContainerItemConfig\n    /**\n     * Configure as `false` to preserve selection when clicking the empty schedule area.\n     */\n    deselectAllOnScheduleClick ? : boolean\n    /**\n     * Configure as `true` to deselect a selected event upon click.\n     */\n    deselectOnClick ? : boolean\n    /**\n     * Configure as `true` to destroy the Project and stores when `this` is destroyed.\n     */\n    destroyStores ? : boolean\n    /**\n     * Check for CSS compatibility issues when upgrading to v7. Performs the following checks:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-detectCSSCompatibilityIssues)\n     */\n    detectCSSCompatibilityIssues ? : boolean\n    /**\n     * Disable or enable the widget. It is similar to [readOnly](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-readOnly) except a disabled widget\n     * cannot be focused, uses a different rendition (usually greyish) and does not allow selecting its value.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-disabled)\n     */\n    disabled ? : boolean|'inert'\n    /**\n     * Controls the placement of this widget when it is added to a [panel's ](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel)\n     * [strips collection](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-strips). Typical values for this config are `'top'`,\n     * `'bottom'`, `'left'`, or `'right'`, which cause the widget to be placed on that side of the panel's\n     * body. Such widgets are called \"edge strips\".\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-dock)\n     */\n    dock ? : 'top'|'bottom'|'left'|'right'|'start'|'end'|'header'|'pre-header'|object\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * Set to `true` to be able to drag a widget freely on the page. Or set to an object with a ´handleSelector´\n     * property which controls when a drag should start.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-draggable)\n     */\n    draggable ? : boolean|{\n        handleSelector?: string\n    }\n    /**\n     * Make this Panel a docked drawer which slides out from one side of the browser viewport by default.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-drawer)\n     * @param {'start','left','end','right','top','bottom'} side The side of the viewport to dock the drawer to.  * `'start'` means the `inline-start` side. * `'end'` means the `inline-end` side.\n     * @param {string,number} size The size of the drawer in its collapsible axis.\n     * @param {boolean} inline If using the [appendTo](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-appendTo) config to place the drawer inside a host widget, this may be set to `true` to make the drawer inline within that host. Note that, if using this, the layout of the host element must have `flex-direction` set appropriately.\n     * @param {boolean,object} autoClose Specifies what user actions should automatically close the drawer. Defaults to closing when the user clicks outside of the drawer or when focus moves outside of the drawer.\n     * @param {boolean,string} autoClose.mousedown If the user clicks outside of the drawer, the drawer will automatically be hidden. If the value is a string, it is used as a CSS selector to filter clicks which should close the drawer.\n     * @param {boolean,string} autoClose.focusout If focus moves outside of the drawer, the drawer will automatically be hidden.\n     * @param {string} autoClose.mouseout Hides the drawer when the mouse leaves the drawer after the `autoCloseDelay` period.\n     * @param {number} autoCloseDelay When using `mouseout`, this is the delay in milliseconds\n     */\n    drawer ? : boolean|{side?: 'start'|'left'|'end'|'right'|'top'|'bottom', size?: string|number, inline?: boolean, autoClose: { mousedown?: boolean|string, focusout?: boolean|string, mouseout?: string }, autoCloseDelay?: number}\n    /**\n     * An object specifying attributes to assign to the root element of this widget.\n     * Set `null` value to attribute to remove it.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-elementAttributes)\n     */\n    elementAttributes ? : Record<string, string|null>\n    /**\n     * Allow using [Delete] and [Backspace] to remove events/assignments\n     */\n    enableDeleteKey ? : boolean\n    /**\n     * Enables events being recurring and also adds extra recurrence UI fields in the built-in event editor.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-enableRecurringEvents)\n     */\n    enableRecurringEvents ? : boolean|{\n        defaultAction?: 'single'|'future'\n    }\n    /**\n     * Set to `true` to listen for CTRL-Z (CMD-Z on Mac OS) keyboard event and trigger undo (redo when SHIFT is pressed).\n     * Only applicable when using a [StateTrackingManager](https://bryntum.com/products/calendar/docs/api/Core/data/stm/StateTrackingManager).\n     */\n    enableUndoRedoKeys ? : boolean\n    /**\n     * Inline events, will be loaded into the [eventStore](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#property-eventStore).\n     */\n    events ? : EventModel[]|EventModelConfig[]\n    /**\n     * Configure as `true`, or set property to `true` to disable event selection.\n     */\n    eventSelectionDisabled ? : boolean\n    /**\n     * The [EventStore](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore) or a reconfiguring object for a store which will hold\n     * the events to be rendered into the Calendar.\n     */\n    eventStore ? : EventStore|EventStoreConfig\n    extraData ? : any\n    /**\n     * If this is set to `true`, then when determining which assigned resource of a multi assigned event\n     * to use to create the event UI, the first resource which is still selected in the\n     * [resourceFilter](https://bryntum.com/products/calendar/docs/api/Calendar/widget/Sidebar#property-resourceFilter) is used.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-filterEventResources)\n     */\n    filterEventResources ? : boolean\n    /**\n     * When this widget is a child of a [Container](https://bryntum.com/products/calendar/docs/api/Core/widget/Container), it will by default be participating in a\n     * flexbox layout. This config allows you to set this widget's\n     * [flex](https://developer.mozilla.org/en-US/docs/Web/CSS/flex) style.\n     * This may be configured as a single number or a `&lt;flex-grow&gt; &lt;flex-shrink&gt; &lt;flex-basis&gt;` format string.\n     * numeric-only values are interpreted as the `flex-grow` value.\n     */\n    flex ? : number|string\n    /**\n     * Set to `true` to move the widget out of the document flow and position it\n     * absolutely in browser viewport space.\n     */\n    floating ? : boolean\n    /**\n     * Config object of a footer. May contain a `dock`, `html` and a `cls` property. A footer is not a widget,\n     * but rather plain HTML that follows the last element of the panel's body and [strips](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-strips).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-footer)\n     */\n    footer ? : {\n        dock?: 'top'|'right'|'bottom'|'left'|'start'|'end'\n        html?: string\n        cls?: string\n    }|string\n    /**\n     * A config [object](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#typedef-PanelHeader) for the panel's header or a string in place of a `title`.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-header)\n     */\n    header ? : string|boolean|PanelHeader\n    /**\n     * Widget's height, used to set element `style.height`. Either specify a valid height string or a number,\n     * which will get 'px' appended. We recommend using CSS as the primary way to control height, but in some\n     * cases this config is convenient.\n     */\n    height ? : string|number\n    /**\n     * Configure with true to make widget initially hidden.\n     */\n    hidden ? : boolean\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-hideAnimation)\n     */\n    hideAnimation ? : boolean|object\n    /**\n     * Configure as `true` to hide [nonWorkingDays](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-nonWorkingDays) for each calendar view\n     */\n    hideNonWorkingDays ? : boolean\n    /**\n     * Specify `true` to make this container hide when it has no visible children (Either empty\n     * or all children hidden).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-hideWhenEmpty)\n     */\n    hideWhenEmpty ? : boolean\n    /**\n     * Configure this as `true` to make picking a date in the [sidebar](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-sidebar)'s\n     * date picker highlight the date cell in the active view.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-highlightDate)\n     * @param {Date} date Cell date\n     * @returns {boolean} Returns `true` to make picking a date in a date picker\n     */\n    highlightDate ? : boolean|((date: Date) => boolean)\n    /**\n     * Configure as `true`, or set property to `true` to highlight dependent events as well when selecting an event.\n     */\n    highlightPredecessors ? : boolean\n    /**\n     * Configure as `true`, or set property to `true` to highlight dependent events as well when selecting an event.\n     */\n    highlightSuccessors ? : boolean\n    /**\n     * An icon to show before the [title](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-title). Either pass a CSS class as a string, or pass a\n     * [DomConfig](https://bryntum.com/products/calendar/docs/api/Core/helper/DomHelper#typedef-DomConfig) object describing an element to represent the icon.\n     */\n    icon ? : string|DomConfig\n    /**\n     * Widget id, if not specified one will be generated. Also used for lookups through Widget.getById\n     */\n    id ? : string\n    /**\n     * Determines if the widgets read-only state should be controlled by its parent.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-ignoreParentReadOnly)\n     */\n    ignoreParentReadOnly ? : boolean\n    /**\n     * Set to `true` to show the \"Weekends\" toggle button of the mode selector. Alternatively, this config\n     * can be a [Button](https://bryntum.com/products/calendar/docs/api/Core/widget/Button) config object to configure the button.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-includeWeekendsButton)\n     */\n    includeWeekendsButton ? : boolean|ButtonConfig\n    /**\n     * Convenience setting to align input fields of child widgets. By default, the Field input element is\n     * placed immediately following the `label`. If you prefer to have all input fields aligned to the\n     * right, set this config to `'end'`.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-inputFieldAlign)\n     */\n    inputFieldAlign ? : 'start'|'end'\n    /**\n     * Element (or element id) to insert this widget before. If provided, [appendTo](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-appendTo) config is ignored.\n     */\n    insertBefore ? : HTMLElement|string\n    /**\n     * Element (or element id) to append this widget element to, as a first child. If provided, [appendTo](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-appendTo) config is ignored.\n     */\n    insertFirst ? : HTMLElement|string\n    /**\n     * A template method (empty by default) allowing you to control if an event can be selected or not.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-isEventSelectable)\n     * @param {Scheduler.model.EventModel} event The event record\n     * @returns {boolean} true if event can be selected, otherwise false\n     */\n    isEventSelectable ? : (event: EventModel) => boolean\n    /**\n     * An optional CSS class to add to child items of this container.\n     */\n    itemCls ? : string\n    /**\n     * The child items of the Calendar view.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-items)\n     */\n    items ? : object\n    /**\n     * The default key shortcuts for the Calendar.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-keyMap)\n     */\n    keyMap ? : Record<string, KeyMapConfig>\n    /**\n     * Convenience setting to use same label placement on all child widgets.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-labelPosition)\n     */\n    labelPosition ? : 'before'|'above'|'align-before'|'auto'|null\n    /**\n     * The short name of a helper class which manages rendering and styling of child items.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-layout)\n     */\n    layout ? : string|CalendarContainerLayoutConfig\n    /**\n     * The CSS style properties to apply to the [contentElement](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-contentElement).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-layoutStyle)\n     */\n    layoutStyle ? : object\n    /**\n     * An array of [child item](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#config-items) *config objects* which is to be converted into\n     * instances only when this Container is rendered, rather than eagerly at construct time.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-lazyItems)\n     */\n    lazyItems ? : Record<string, CalendarContainerItemConfig>|CalendarContainerItemConfig[]|Widget[]\n    /**\n     * The listener set for this object.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-listeners)\n     */\n    listeners ? : CalendarListeners\n    /**\n     * A [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) config object, or a message to be shown when a store is performing a remote\n     * operation, or Crud Manager is loading data from the sever. Set to `null` to disable default load mask.\n     */\n    loadMask ? : string|MaskConfig|null\n    /**\n     * A [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) config object to adjust the [maskDefaults](#Core/widget/Widget#config-maskDefaults)\n     * when data is loading. The message and optional configuration from the\n     * [loadMask](https://bryntum.com/products/calendar/docs/api/Core/mixin/LoadMaskable#config-loadMask) config take priority over these options, just as they do\n     * for `maskDefaults`, respectively.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-loadMaskDefaults)\n     */\n    loadMaskDefaults ? : MaskConfig\n    /**\n     * A [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) config object to adjust the [maskDefaults](#Core/widget/Widget#config-maskDefaults)\n     * when an error occurs loading data.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-loadMaskError)\n     */\n    loadMaskError ? : MaskConfig|Mask|boolean\n    /**\n     * A class translations of which are used for translating this entity.\n     * This is often used when translations of an item are defined on its container class.\n     * For example:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-localeClass)\n     */\n    localeClass ? : typeof Base\n    /**\n     * Set to `false` to disable localization of this object.\n     */\n    localizable ? : boolean\n    /**\n     * List of properties which values should be translated automatically upon a locale applying.\n     * In case there is a need to localize not typical value (not a String value or a field with re-defined setter/getter),\n     * you could use 'localeKey' meta configuration.\n     * Example:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-localizableProperties)\n     */\n    localizableProperties ? : string[]\n    /**\n     * This flag controls whether Scheduler should preserve its selection of events when loading a new dataset\n     * (if selected event ids are included in the newly loaded dataset).\n     */\n    maintainSelectionOnDatasetChange ? : boolean\n    /**\n     * Widget's margin. This may be configured as a single number or a `TRBL` format string.\n     * numeric-only values are interpreted as pixels.\n     */\n    margin ? : number|string\n    /**\n     * This config object contains the defaults for the [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) created for the\n     * [masked](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-masked) config. Any properties specified in the `masked` config will override these\n     * values.\n     */\n    maskDefaults ? : MaskConfig\n    /**\n     * Set to `true` to apply the default mask to the widget. Alternatively, this can be the mask message or a\n     * [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) config object.\n     */\n    masked ? : boolean|string|MaskConfig\n    /**\n     * The maximum date to which the `endDate` of any child view may be navigated.\n     */\n    maxDate ? : Date|string\n    /**\n     * The element's maxHeight. Can be either a String or a Number (which will have 'px' appended). Note that\n     * like [height](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-height), *reading* the value will return the numeric value in pixels.\n     */\n    maxHeight ? : string|number\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-maximizeOnMobile)\n     */\n    maximizeOnMobile ? : number|string\n    /**\n     * The elements maxWidth. Can be either a String or a Number (which will have 'px' appended). Note that\n     * like [width](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-width), *reading* the value will return the numeric value in pixels.\n     */\n    maxWidth ? : string|number\n    /**\n     * The minimum date to which the `startDate` of any child view may be navigated.\n     */\n    minDate ? : Date|string\n    /**\n     * The element's minHeight. Can be either a String or a Number (which will have 'px' appended). Note that\n     * like [height](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-height), *reading* the value will return the numeric value in pixels.\n     */\n    minHeight ? : string|number\n    /**\n     * The elements minWidth. Can be either a String or a Number (which will have 'px' appended). Note that\n     * like [width](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-width), *reading* the value will return the numeric value in pixels.\n     */\n    minWidth ? : string|number\n    /**\n     * Which of the built-in [modes](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-modes) should be the initially active view.\n     */\n    mode ? : 'agenda'|'year'|'month'|'week'|'day'|'list'|'resource'|'dayresource'|'dayagenda'|'monthagenda'|'monthgrid'|string\n    /**\n     * An object to use to configure common properties for all [modes](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-modes) prior to their construction.\n     */\n    modeDefaults ? : object\n    /**\n     * Configures the view modes which are to be available in this Calendar.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-modes)\n     */\n    modes ? : {\n        [mode: string]: CalendarContainerItemConfig|boolean|null|undefined\n        agenda?: AgendaViewConfig|boolean|null\n        year?: YearViewConfig|boolean|null\n        month?: MonthViewConfig|boolean|null\n        week?: WeekViewConfig|boolean|null\n        day?: DayViewConfig|boolean|null\n        list?: EventListConfig|boolean|null\n        resource?: ResourceViewConfig|boolean|null\n        dayresourceview?: DayResourceViewConfig|boolean|null\n        dayagenda?: DayAgendaViewConfig|boolean|null\n        monthagenda?: MonthAgendaViewConfig|boolean|null\n        monthgrid?: MonthGridConfig|boolean|null\n    }\n    /**\n     * When this is configured as `true` a [ResizeObserver](https://developer.mozilla.org/en-US/docs/Web/API/ResizeObserver)\n     * is used to monitor this element for size changes caused by either style manipulation, or by CSS\n     * layout.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-monitorResize)\n     */\n    monitorResize ? : boolean|{\n        immediate?: boolean\n    }\n    /**\n     * Configure as `true` to allow `CTRL/CMD+click` to select multiple events in the scheduler.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-multiEventSelect)\n     */\n    multiEventSelect ? : boolean|{\n        ctrlKey?: boolean\n        altKey?: boolean\n        shiftKey?: boolean\n    }\n    /**\n     * An object containing default config objects which may be referenced by name in the [items](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#config-items)\n     * config. For example, a specialized [Menu](https://bryntum.com/products/calendar/docs/api/Core/widget/Menu) subclass may have a `namedItems` default\n     * value defined like this:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-namedItems)\n     */\n    namedItems ? : Record<string, CalendarContainerItemConfig>\n    /**\n     * Indicates where the Next/Previous/Today buttons should be placed.\n     */\n    navigatorPlacement ? : 'toolbar'|'sidebar'\n    /**\n     * Non-working days as an object where keys are day indices, 0-6 (Sunday-Saturday), and the value is `true`.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-nonWorkingDays)\n     */\n    nonWorkingDays ? : Record<number, boolean>\n    /**\n     * By default, the [sidebar](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#property-sidebar) expands and collapses taking width from the\n     * calendar UI. Configure `overlaySidebar` as `true` to have it start collapsed, and then\n     * <strong>overlay</strong> the calendar UI when the expand/collapse button is toggled.\n     */\n    overlaySidebar ? : boolean\n    /**\n     * The owning Widget of this Widget. If this Widget is directly contained (that is, it is one of the\n     * [items](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#property-items) of a Container), this config will be ignored. In this case\n     * the owner is <strong>always</strong> the encapsulating Container.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-owner)\n     */\n    owner ? : Widget|any\n    /**\n     * Set to `true` when a widget is rendered into another widget's [contentElement](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-contentElement), but must\n     * not participate in the standard layout of that widget, and must be positioned relatively to that\n     * widget's [contentElement](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-contentElement).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-positioned)\n     */\n    positioned ? : boolean\n    /**\n     * Prevent tooltip from being displayed on touch devices. Useful for example for buttons that display a\n     * menu on click etc, since the tooltip would be displayed at the same time.\n     */\n    preventTooltipOnTouch ? : boolean\n    /**\n     * A [ProjectModel](https://bryntum.com/products/calendar/docs/api/Scheduler/model/ProjectModel) instance or a config object. The project holds all Scheduler data.\n     * Can be omitted in favor of individual store configs or [crudManager](https://bryntum.com/products/calendar/docs/api/Scheduler/view/mixin/SchedulerStores#config-crudManager) config.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-project)\n     */\n    project ? : ProjectModel|ProjectModelConfig|object\n    /**\n     * The names of properties which are propagated down from the Calendar to child views\n     * unless the view has its own value for that property.\n     */\n    propagatedConfigs ? : string[]\n    /**\n     * Configure as `true` to make the calendar read-only, by disabling any UIs for modifying data.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-readOnly)\n     */\n    readOnly ? : boolean\n    /**\n     * The confirmation dialog shown when a recurring event is edited.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-recurrenceConfirmationPopup)\n     */\n    recurrenceConfirmationPopup ? : RecurrenceConfirmationPopupConfig|RecurrenceConfirmationPopup\n    relayStoreEvents ? : boolean\n    /**\n     * Either a default `rendition` to apply to all child widgets, or a map of renditions keyed by child widget\n     * `type`.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-rendition)\n     */\n    rendition ? : string|Record<string, string>|null\n    /**\n     * Path to load resource images from. Used by the resource headers in ResourceView and by\n     * [showResourceAvatars](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-showResourceAvatars) in event-displaying\n     * modes.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-resourceImagePath)\n     */\n    resourceImagePath ? : string\n    /**\n     * Inline resources, will be loaded into the [resourceStore](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#property-resourceStore).\n     */\n    resources ? : ResourceModel[]|ResourceModelConfig[]\n    /**\n     * The [ResourceStore](https://bryntum.com/products/calendar/docs/api/Scheduler/data/ResourceStore) or a reconfiguring object for a store which will hold the resources to be rendered into the Calendar.\n     */\n    resourceStore ? : ResourceStore|ResourceStoreConfig\n    /**\n     * Inline resource time ranges, will be loaded into [resourceTimeRangeStore](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#property-resourceTimeRangeStore).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-resourceTimeRanges)\n     */\n    resourceTimeRanges ? : ResourceTimeRangeModel[]|ResourceTimeRangeModelConfig[]\n    /**\n     * The [ResourceTimeRangeStore](https://bryntum.com/products/calendar/docs/api/Scheduler/data/ResourceTimeRangeStore) or a reconfiguring object for a store which will hold resource time ranges.\n     * These may be used by the [TimeRanges](https://bryntum.com/products/calendar/docs/api/Calendar/feature/TimeRanges) feature.\n     */\n    resourceTimeRangeStore ? : ResourceTimeRangeStore|ResourceTimeRangeStoreConfig\n    /**\n     * Specifies the various responsive state objects keyed by their name. Each key (except `'*'`, see below) in\n     * this object is a state name (see [responsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveState)) and its corresponding value is the\n     * associated [ResponsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#typedef-ResponsiveState) object.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-responsive)\n     */\n    responsive ? : object\n    /**\n     * Set to `true` to mark this instance as the default [responsiveTarget](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveTarget) for descendants that do\n     * not specify an explicit [responsiveTarget](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveTarget) of their own.\n     */\n    responsiveRoot ? : boolean\n    /**\n     * The name of the active state of the [responsive](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsive) config. This is assigned internally\n     * and should not be assigned directly.\n     */\n    responsiveState ? : string\n    /**\n     * The widget whose size and other properties drive this object's responsive behavior. If this config is not\n     * specified, the closest ancestor that specified [responsiveRoot=true](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveRoot) will be\n     * used. If there is no such ancestor, then the instance using this mixin is used.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-responsiveTarget)\n     */\n    responsiveTarget ? : string|Widget\n    /**\n     * Configure as `true` to have the component display a translucent ripple when its\n     * [focusElement](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-focusElement), or [element](#Core/widget/Widget#property-element) is tapped <em>if the\n     * current theme supports ripples</em>. Out of the box, only the Material theme supports ripples.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-ripple)\n     */\n    ripple ? : boolean|{\n        delegate?: string\n        color?: string\n        radius?: number\n        clip?: string\n    }\n    /**\n     * If you are rendering this widget to a shadow root inside a web component, set this config to the shadowRoot. If not inside a web component, set it to `document.body`\n     */\n    rootElement ? : ShadowRoot|HTMLElement\n    /**\n     * This may be configured as `true` to make the widget's element use the `direction:rtl` style.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-rtl)\n     */\n    rtl ? : boolean\n    /**\n     * Specifies whether (and optionally in which axes) a Widget may scroll. `true` means this widget may scroll\n     * in both axes. May be an object containing boolean `overflowX` and `overflowY` properties which are\n     * applied to CSS style properties `overflowX` and `overflowY`. If they are boolean, they are translated to\n     * CSS overflow properties thus:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-scrollable)\n     */\n    scrollable ? : boolean|ScrollerConfig|Scroller\n    /**\n     * Defines what to do if document is scrolled while Widget is visible (only relevant when floating is set to `true`).\n     * Valid values: ´null´: do nothing, ´hide´: hide the widget or ´realign´: realign to the target if possible.\n     */\n    scrollAction ? : 'hide'|'realign'|null\n    /**\n     * Set to `false` to not select the resource of the event when clicking an event bar.\n     */\n    selectResourceOnEventNavigate ? : boolean\n    /**\n     * Set to `false` to not select the row/resource when clicking the empty area in a time axis cell.\n     */\n    selectResourceOnScheduleClick ? : boolean\n    /**\n     * *Only valid if this Widget is [floating](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-floating).*\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-showAnimation)\n     */\n    showAnimation ? : boolean|object\n    /**\n     * Set to `false` to hide recurring fields in event editor, even if the\n     * [Recurring Events](https://bryntum.com/products/calendar/docs/api/Scheduler/view/mixin/RecurringEvents#config-enableRecurringEvents) is `true`\n     * and a recurring event is being edited.\n     */\n    showRecurringUI ? : boolean\n    /**\n     * Set to `false` to not show the tooltip when this widget is [disabled](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-disabled)\n     */\n    showTooltipWhenDisabled ? : boolean\n    /**\n     * An optional config object to configure the [Sidebar](https://bryntum.com/products/calendar/docs/api/Calendar/widget/Sidebar) which is\n     * shown next to the calendar views specified by the [modes](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-modes).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-sidebar)\n     * @param {'left','right'} side Which [side](https://bryntum.com/products/calendar/docs/api/Calendar/widget/Sidebar#config-side) to dock to.\n     * @param {boolean} collapsed May be initially [collapsed](https://bryntum.com/products/calendar/docs/api/Calendar/widget/Sidebar#config-collapsed).\n     * @param {Record<string, CalendarContainerItemConfig>} items Reconfigure or add to the sidebar UI.\n     * @param {CalendarContainerItemConfig} items.custom Settings specific to custom item.\n     * @param {DatePickerConfig} items.datePicker The [DatePicker](https://bryntum.com/products/calendar/docs/api/Core/widget/DatePicker) may be reconfigured using an object, or configured away using `null`. Its default [weight](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-weight) is 100.\n     * @param {TextFieldConfig} items.eventFilter The eventFilter is a [TextField](https://bryntum.com/products/calendar/docs/api/Core/widget/TextField) which may be used to filter the events by matched name. It may be reconfigured using an object, or configured away using `null`. Its default [weight](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-weight) is 150.\n     * @param {ResourceFilterConfig} items.resourceFilter The [ResourceFilter](https://bryntum.com/products/calendar/docs/api/Scheduler/widget/ResourceFilter) may be reconfigured using an object, or configured away using `null`. Its default [weight](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-weight) is 200.\n     */\n    sidebar ? : {side?: 'left'|'right', collapsed?: boolean, items: { [mode: string]: CalendarContainerItemConfig|null|undefined, datePicker?: DatePickerConfig, eventFilter?: TextFieldConfig, resourceFilter?: ResourceFilterConfig }}|boolean\n    /**\n     * Programmatic control over how many columns to span when used in a grid layout.\n     */\n    span ? : number\n    /**\n     * This value can be one of the following:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-stateful)\n     */\n    stateful ? : boolean|object|string[]\n    /**\n     * The events that, when fired by this component, should trigger it to save its state by calling\n     * [saveState](https://bryntum.com/products/calendar/docs/api/Core/mixin/State#function-saveState).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-statefulEvents)\n     */\n    statefulEvents ? : object|string[]\n    /**\n     * The key to use when saving this object's state in the [stateProvider](https://bryntum.com/products/calendar/docs/api/Core/mixin/State#config-stateProvider). If this config is\n     * not assigned, and [stateful](https://bryntum.com/products/calendar/docs/api/Core/mixin/State#config-stateful) is not set to `false`, the [id](#Core/widget/Widget#config-id)\n     * (if explicitly specified) will be used as the `stateId`.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-stateId)\n     */\n    stateId ? : string\n    /**\n     * The `StateProvider` to use to save and restore this object's [state](https://bryntum.com/products/calendar/docs/api/Core/mixin/State#property-state). By default, `state`\n     * will be saved using the [default state provider](https://bryntum.com/products/calendar/docs/api/Core/state/StateProvider#property-instance-static).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-stateProvider)\n     */\n    stateProvider ? : StateProvider\n    /**\n     * Specify `true` to match fields by their `name` property only when assigning a [record](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#config-record),\n     * without falling back to `ref`.\n     */\n    strictRecordMapping ? : boolean\n    /**\n     * An object containing widgets keyed by name. By default (when no `type` is given), strips are\n     * [toolbars](https://bryntum.com/products/calendar/docs/api/Core/widget/Toolbar). If you want to pass an array, you can use\n     * the toolbar's [items](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#config-items).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-strips)\n     */\n    strips ? : Record<string, CalendarContainerItemConfig>\n    /**\n     * A [Mask](https://bryntum.com/products/calendar/docs/api/Core/widget/Mask) config object, or a message to be shown when Crud Manager\n     * is persisting changes on the server. Set to `null` to disable default sync mask.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-syncMask)\n     */\n    syncMask ? : string|MaskConfig|null\n    /**\n     * A configuration for the [tab](https://bryntum.com/products/calendar/docs/api/Core/widget/Tab) created for this widget when it is placed in a\n     * [TabPanel](https://bryntum.com/products/calendar/docs/api/Core/widget/TabPanel). For example, this config can be used to control the icon of the `tab` for\n     * this widget:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-tab)\n     */\n    tab ? : boolean|TabConfig\n    /**\n     * When this container is used as a tab in a TabPanel, these items are added to the\n     * [TabBar](https://bryntum.com/products/calendar/docs/api/Core/widget/TabBar) when this container is the active tab.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-tabBarItems)\n     */\n    tabBarItems ? : ToolbarItems[]|Widget[]\n    /**\n     * The tag name of this Widget's root element\n     */\n    tag ? : string\n    /**\n     * A config object containing definitions of the toolbar of the Calendar.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-tbar)\n     */\n    tbar ? : (CalendarContainerItemConfig|string)[]|ToolbarConfig|CalendarToolbarConfig|null\n    /**\n     * Text alignment: 'left', 'center' or 'right'. Also accepts direction neutral 'start' and 'end'.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-textAlign)\n     */\n    textAlign ? : 'left'|'center'|'right'|'start'|'end'\n    /**\n     * Inline time ranges, will be loaded into the [timeRangeStore](https://bryntum.com/products/calendar/docs/api/Calendar/mixin/CalendarStores#property-timeRangeStore).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-timeRanges)\n     */\n    timeRanges ? : TimeRangeModel[]|TimeRangeModelConfig[]\n    /**\n     * The [TimeRangeStore](https://bryntum.com/products/calendar/docs/api/Calendar/data/TimeRangeStore) or a reconfiguring object for a store which will hold time ranges.\n     * These may be used by the [TimeRanges](https://bryntum.com/products/calendar/docs/api/Calendar/feature/TimeRanges) feature.\n     */\n    timeRangeStore ? : TimeRangeStore|TimeRangeStoreConfig\n    /**\n     * Set to a time zone or a UTC offset. This will set the project's\n     * [timeZone](https://bryntum.com/products/calendar/docs/api/Scheduler/model/ProjectModel#config-timeZone) config accordingly. As this config is only a referer,\n     * please see project's config [documentation](https://bryntum.com/products/calendar/docs/api/Scheduler/model/ProjectModel#config-timeZone) for more\n     * information.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-timeZone)\n     */\n    timeZone ? : string|number\n    /**\n     * A title to display in the header or owning TabPanel. Causes creation and docking of a header\n     * to the top if no header is configured.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-title)\n     */\n    title ? : string\n    /**\n     * The [tools](https://bryntum.com/products/calendar/docs/api/Core/widget/Tool) to add either before or after the `title` in the Panel header. Each\n     * property name is the reference by which an instantiated tool may be retrieved from the live\n     * `[tools](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Toolable#property-tools)` property.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-tools)\n     */\n    tools ? : Record<string, ToolConfig>|null\n    /**\n     * Tooltip for the widget, either as a string or as a Tooltip config object.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-tooltip)\n     */\n    tooltip ? : string|TooltipConfig|null\n    /**\n     * By default, tabbing within a Panel is not contained, ie you can TAB out of the Panel\n     * forwards or backwards.\n     * Configure this as `true` to disallow tabbing out of the Panel, and make tabbing circular within this Panel.\n     */\n    trapFocus ? : boolean\n    /**\n     * Configure as `true` to trigger `selectionChange` when removing a selected event/assignment.\n     */\n    triggerSelectionChangeOnRemove ? : boolean\n    type ? : 'calendar'\n    /**\n     * Custom CSS class name suffixes to apply to the elements rendered by this widget. This may be specified\n     * as a space separated string, an array of strings, or as an object in which property names with truthy\n     * values are used as the class names.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-ui)\n     */\n    ui ? : 'plain'|'toolbar'|string|object\n    /**\n     * By default, the day of week and week of month of the event's start date are used to create\n     * helpful contextual recurrence types when editing a non-recurring event record and choosing\n     * an initial recurrence type.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-useContextualRecurrenceRules)\n     */\n    useContextualRecurrenceRules ? : boolean\n    /**\n     * Configuration options to change how the subordinate [Container](https://bryntum.com/products/calendar/docs/api/Core/widget/Container) which contains\n     * the calendar's child views is created.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-viewContainer)\n     */\n    viewContainer ? : ContainerConfig\n    /**\n     * The week start day to be used throughout this Calendar, 0 meaning Sunday, 6 meaning Saturday.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-weekStartDay)\n     */\n    weekStartDay ? : number\n    /**\n     * A widgets weight determines its position among siblings when added to a [Container](https://bryntum.com/products/calendar/docs/api/Core/widget/Container).\n     * Higher weights go further down.\n     */\n    weight ? : number\n    /**\n     * Widget's width, used to set element `style.width`. Either specify a valid width string or a number, which\n     * will get 'px' appended. We recommend using CSS as the primary way to control width, but in some cases\n     * this config is convenient.\n     */\n    width ? : string|number\n    /**\n     * The x position for the widget.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-x)\n     */\n    x ? : number\n    /**\n     * The y position for the widget.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#config-y)\n     */\n    y ? : number\n\n    // Features\n    /**\n     * This feature provides drag-based event creation and modification for Calendars. When enabled (which is the default\n     * for calendars), the user can do the following via the mouse or touch screen:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag)\n     */\n    dragFeature ? : object|boolean|string|CalendarDrag|CalendarDragConfig\n    /**\n     * A Feature that allows showing additional time before &amp; after an event, to visualize things like travel time - or the time you\n     * need to prepare a room for a meeting + clean it up after.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventBuffer)\n     */\n    eventBufferFeature ? : object|boolean|string|EventBuffer|EventBufferConfig\n    /**\n     * Allow using [Ctrl/CMD + C/X/V] to copy/cut-and-paste events.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventCopyPaste)\n     */\n    eventCopyPasteFeature ? : object|boolean|string|EventCopyPaste|EventCopyPasteConfig\n    /**\n     * Feature that displays a popup containing fields for editing event data.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventEdit)\n     */\n    eventEditFeature ? : object|boolean|string|EventEdit|EventEditConfig\n    /**\n     * A feature which shows a context menu when right-clicking events in the calendar.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventMenu)\n     */\n    eventMenuFeature ? : object|boolean|string|EventMenu|EventMenuConfig\n    /**\n     * A feature which displays a [tooltip](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventTooltip#config-tooltip) containing extra information. The tooltip can\n     * be triggered by clicking or hovering an event bar element (see [showOn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventTooltip#config-showOn)).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/EventTooltip)\n     */\n    eventTooltipFeature ? : object|boolean|string|EventTooltip|EventTooltipConfig\n    /**\n     * A feature that allows exporting Calendar data to Excel or CSV without involving the server. It uses\n     * [TableExporter](https://bryntum.com/products/calendar/docs/api/Grid/util/TableExporter) class as data provider, 3rd party provider to generate XLS files, and\n     * [Microsoft XML specification](https://msdn.microsoft.com/en-us/library/office/documentformat.openxml.spreadsheet.aspx).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/experimental/ExcelExporter)\n     */\n    excelExporterFeature ? : object|boolean|string|ExcelExporter|ExcelExporterConfig\n    /**\n     * A Calendar feature which allows new events to be dragged into the Calendar from an external source.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource)\n     */\n    externalEventSourceFeature ? : object|boolean|string|ExternalEventSource|ExternalEventSourceConfig\n    /**\n     * Loads the host Calendar's [CrudManager](https://bryntum.com/products/calendar/docs/api/Scheduler/view/mixin/SchedulerStores#config-crudManager) on demand\n     * as the date range required to produce the UI changes.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/LoadOnDemand)\n     */\n    loadOnDemandFeature ? : object|boolean|string|LoadOnDemand|LoadOnDemandConfig\n    /**\n     * This feature enables printing of the current Calendar mode.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/print/Print)\n     */\n    printFeature ? : object|boolean|string|Print|PrintConfig\n    /**\n     * A feature which adds a context menu to the unoccupied parts of calendar views.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ScheduleMenu)\n     */\n    scheduleMenuFeature ? : object|boolean|string|ScheduleMenu|ScheduleMenuConfig\n    /**\n     * A feature that displays a tooltip containing the time at the mouse position when hovering empty parts of the schedule.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ScheduleTooltip)\n     */\n    scheduleTooltipFeature ? : object|boolean|string|ScheduleTooltip|ScheduleTooltipConfig\n    /**\n     * This feature provides an easy way to highlight ranges of time in a calendar's day and week views. Each time range is\n     * represented using the [TimeRangeModel](https://bryntum.com/products/calendar/docs/api/Calendar/model/TimeRangeModel).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/TimeRanges)\n     */\n    timeRangesFeature ? : object|boolean|string|TimeRanges|TimeRangesConfig\n    /**\n     * A Feature which, when present, adds a week row expansion tool to week rows in\n     * [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView)s so that a row which contains overflowing cells\n     * can be expanded to show all events with no overflow.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/feature/WeekExpander)\n     */\n    weekExpanderFeature ? : object|boolean|string|WeekExpander|WeekExpanderConfig\n\n}\n\n@Component({\n    selector : 'bryntum-calendar',\n    template : ''\n})\nexport class BryntumCalendarComponent implements OnInit, OnDestroy {\n\n    public static instanceClass = Calendar;\n\n    public static instanceName = 'Calendar';\n\n    private static bryntumEvents: string[] = [\n        'onActiveItemChange',\n        'onAfterEventEdit',\n        'onAfterEventSave',\n        'onBeforeActiveItemChange',\n        'onBeforeAssignmentDelete',\n        'onBeforeAssignmentSelectionChange',\n        'onBeforeAutoCreate',\n        'onBeforeCopy',\n        'onBeforeCreateMode',\n        'onBeforeCSVExport',\n        'onBeforeDestroy',\n        'onBeforeDragCreate',\n        'onBeforeDragCreateEnd',\n        'onBeforeDragMove',\n        'onBeforeDragMoveEnd',\n        'onBeforeDragResize',\n        'onBeforeDragResizeEnd',\n        'onBeforeDropExternal',\n        'onBeforeEventDelete',\n        'onBeforeEventEdit',\n        'onBeforeEventEditShow',\n        'onBeforeEventSave',\n        'onBeforeEventSelectionChange',\n        'onBeforeExcelExport',\n        'onBeforeHide',\n        'onBeforePaste',\n        'onBeforePrint',\n        'onBeforeResponsiveStateChange',\n        'onBeforeSetRecord',\n        'onBeforeShow',\n        'onBeforeStateApply',\n        'onBeforeStateSave',\n        'onCatchAll',\n        'onCellOverflowClick',\n        'onCollapse',\n        'onContextMenuItem',\n        'onContextMenuToggleItem',\n        'onCopy',\n        'onCurrentTimelineUpdate',\n        'onDataChange',\n        'onDateChange',\n        'onDateRangeChange',\n        'onDateRangeLoad',\n        'onDateRangeRequested',\n        'onDayCellPopulated',\n        'onDayNumberClick',\n        'onDestroy',\n        'onDirtyStateChange',\n        'onDragCreateEnd',\n        'onDragMoveEnd',\n        'onDragMoveExternal',\n        'onDragResizeEnd',\n        'onDropExternal',\n        'onElementCreated',\n        'onEmptyCellClick',\n        'onEventAutoCreated',\n        'onEventClick',\n        'onEventContextMenu',\n        'onEventDblClick',\n        'onEventEditBeforeSetRecord',\n        'onEventKeyDown',\n        'onEventMenuBeforeShow',\n        'onEventMenuItem',\n        'onEventMenuShow',\n        'onEventMouseDown',\n        'onEventMouseEnter',\n        'onEventMouseLeave',\n        'onEventMouseOut',\n        'onEventMouseOver',\n        'onEventMouseUp',\n        'onEventPropagate',\n        'onExpand',\n        'onFocusIn',\n        'onFocusOut',\n        'onHide',\n        'onLoadOnDemandFail',\n        'onMonthNameClick',\n        'onNavigate',\n        'onPaint',\n        'onPaste',\n        'onPasteNotAllowed',\n        'onReadOnly',\n        'onRecompose',\n        'onRefresh',\n        'onResize',\n        'onResourceClick',\n        'onResponsiveStateChange',\n        'onScheduleClick',\n        'onScheduleContextMenu',\n        'onScheduleDblClick',\n        'onScheduleMenuBeforeShow',\n        'onScheduleMenuItem',\n        'onScheduleMenuShow',\n        'onScheduleMouseDown',\n        'onScheduleMouseOut',\n        'onScheduleMouseOver',\n        'onScheduleMouseUp',\n        'onSelectionChange',\n        'onShow',\n        'onSidebarCollapse',\n        'onSidebarExpand',\n        'onTimeAxisClick',\n        'onTimeRangeHeaderClick',\n        'onTimeRangeHeaderContextMenu',\n        'onTimeRangeHeaderDblClick',\n        'onToolClick',\n        'onViewPaint',\n        'onWeekNumberClick'\n    ];\n\n    private static bryntumFeatureNames: string[] = [\n        'dragFeature',\n        'eventBufferFeature',\n        'eventCopyPasteFeature',\n        'eventEditFeature',\n        'eventMenuFeature',\n        'eventTooltipFeature',\n        'excelExporterFeature',\n        'externalEventSourceFeature',\n        'loadOnDemandFeature',\n        'printFeature',\n        'scheduleMenuFeature',\n        'scheduleTooltipFeature',\n        'timeRangesFeature',\n        'weekExpanderFeature'\n    ];\n\n    private static bryntumConfigs: string[] = BryntumCalendarComponent.bryntumFeatureNames.concat([\n        'activeDateCls',\n        'adopt',\n        'align',\n        'alignSelf',\n        'anchor',\n        'appendTo',\n        'ariaDescription',\n        'ariaLabel',\n        'assignments',\n        'assignmentStore',\n        'autoCreate',\n        'bbar',\n        'bodyCls',\n        'bubbleEvents',\n        'callOnFunctions',\n        'catchEventHandlerExceptions',\n        'centered',\n        'cls',\n        'collapsed',\n        'collapsible',\n        'color',\n        'column',\n        'config',\n        'constrainTo',\n        'contentElementCls',\n        'contextMenuTriggerEvent',\n        'crudManager',\n        'crudManagerClass',\n        'dataField',\n        'dataset',\n        'date',\n        'dateFormat',\n        'datePicker',\n        'defaultBindProperty',\n        'defaultCalendar',\n        'defaultFocus',\n        'defaults',\n        'deselectAllOnScheduleClick',\n        'deselectOnClick',\n        'destroyStores',\n        'detectCSSCompatibilityIssues',\n        'disabled',\n        'dock',\n        'draggable',\n        'drawer',\n        'elementAttributes',\n        'enableDeleteKey',\n        'enableRecurringEvents',\n        'enableUndoRedoKeys',\n        'events',\n        'eventSelectionDisabled',\n        'eventStore',\n        'extraData',\n        'filterEventResources',\n        'flex',\n        'floating',\n        'footer',\n        'header',\n        'height',\n        'hidden',\n        'hideAnimation',\n        'hideNonWorkingDays',\n        'hideWhenEmpty',\n        'highlightDate',\n        'highlightPredecessors',\n        'highlightSuccessors',\n        'icon',\n        'id',\n        'ignoreParentReadOnly',\n        'includeWeekendsButton',\n        'inputFieldAlign',\n        'insertBefore',\n        'insertFirst',\n        'isEventSelectable',\n        'itemCls',\n        'items',\n        'keyMap',\n        'labelPosition',\n        'layout',\n        'layoutStyle',\n        'lazyItems',\n        'listeners',\n        'loadMask',\n        'loadMaskDefaults',\n        'loadMaskError',\n        'localeClass',\n        'localizable',\n        'localizableProperties',\n        'maintainSelectionOnDatasetChange',\n        'margin',\n        'maskDefaults',\n        'masked',\n        'maxDate',\n        'maxHeight',\n        'maximizeOnMobile',\n        'maxWidth',\n        'minDate',\n        'minHeight',\n        'minWidth',\n        'mode',\n        'modeDefaults',\n        'modes',\n        'monitorResize',\n        'multiEventSelect',\n        'namedItems',\n        'navigatorPlacement',\n        'nonWorkingDays',\n        'overlaySidebar',\n        'owner',\n        'positioned',\n        'preventTooltipOnTouch',\n        'project',\n        'propagatedConfigs',\n        'readOnly',\n        'recurrenceConfirmationPopup',\n        'relayStoreEvents',\n        'rendition',\n        'resourceImagePath',\n        'resources',\n        'resourceStore',\n        'resourceTimeRanges',\n        'resourceTimeRangeStore',\n        'responsive',\n        'responsiveRoot',\n        'responsiveState',\n        'responsiveTarget',\n        'ripple',\n        'rootElement',\n        'rtl',\n        'scrollable',\n        'scrollAction',\n        'selectResourceOnEventNavigate',\n        'selectResourceOnScheduleClick',\n        'showAnimation',\n        'showRecurringUI',\n        'showTooltipWhenDisabled',\n        'sidebar',\n        'span',\n        'stateful',\n        'statefulEvents',\n        'stateId',\n        'stateProvider',\n        'strictRecordMapping',\n        'strips',\n        'syncMask',\n        'tab',\n        'tabBarItems',\n        'tag',\n        'tbar',\n        'textAlign',\n        'timeRanges',\n        'timeRangeStore',\n        'timeZone',\n        'title',\n        'tools',\n        'tooltip',\n        'trapFocus',\n        'triggerSelectionChangeOnRemove',\n        'type',\n        'ui',\n        'useContextualRecurrenceRules',\n        'viewContainer',\n        'weekStartDay',\n        'weight',\n        'width',\n        'x',\n        'y'\n    ]);\n\n    private static bryntumConfigsOnly: string[] = [\n        'adopt',\n        'align',\n        'anchor',\n        'ariaDescription',\n        'ariaLabel',\n        'assignmentStore',\n        'autoCreate',\n        'bbar',\n        'bodyCls',\n        'bubbleEvents',\n        'centered',\n        'collapsible',\n        'color',\n        'config',\n        'constrainTo',\n        'contentElementCls',\n        'contextMenuTriggerEvent',\n        'crudManagerClass',\n        'dataField',\n        'datePicker',\n        'defaultBindProperty',\n        'defaultFocus',\n        'defaults',\n        'deselectOnClick',\n        'destroyStores',\n        'detectCSSCompatibilityIssues',\n        'dock',\n        'draggable',\n        'drawer',\n        'elementAttributes',\n        'enableDeleteKey',\n        'enableRecurringEvents',\n        'enableUndoRedoKeys',\n        'eventSelectionDisabled',\n        'eventStore',\n        'filterEventResources',\n        'floating',\n        'footer',\n        'header',\n        'hideAnimation',\n        'hideWhenEmpty',\n        'highlightDate',\n        'highlightPredecessors',\n        'highlightSuccessors',\n        'icon',\n        'ignoreParentReadOnly',\n        'includeWeekendsButton',\n        'itemCls',\n        'lazyItems',\n        'listeners',\n        'loadMask',\n        'loadMaskDefaults',\n        'loadMaskError',\n        'localeClass',\n        'localizable',\n        'localizableProperties',\n        'maintainSelectionOnDatasetChange',\n        'maskDefaults',\n        'masked',\n        'monitorResize',\n        'multiEventSelect',\n        'namedItems',\n        'navigatorPlacement',\n        'overlaySidebar',\n        'owner',\n        'positioned',\n        'preventTooltipOnTouch',\n        'propagatedConfigs',\n        'relayStoreEvents',\n        'resourceImagePath',\n        'resourceStore',\n        'resourceTimeRangeStore',\n        'responsive',\n        'responsiveRoot',\n        'responsiveState',\n        'responsiveTarget',\n        'ripple',\n        'rootElement',\n        'scrollAction',\n        'showAnimation',\n        'showRecurringUI',\n        'showTooltipWhenDisabled',\n        'sidebar',\n        'stateful',\n        'statefulEvents',\n        'stateId',\n        'stateProvider',\n        'strips',\n        'syncMask',\n        'tab',\n        'tabBarItems',\n        'tag',\n        'tbar',\n        'textAlign',\n        'timeRangeStore',\n        'timeZone',\n        'trapFocus',\n        'triggerSelectionChangeOnRemove',\n        'type',\n        'ui',\n        'viewContainer',\n        'weekStartDay',\n        'weight'\n    ];\n\n    private static bryntumProps: string[] = BryntumCalendarComponent.bryntumFeatureNames.concat([\n        'activeDateCls',\n        'activeSubView',\n        'activeView',\n        'alignSelf',\n        'anchorSize',\n        'appendTo',\n        'assignments',\n        'callOnFunctions',\n        'catchEventHandlerExceptions',\n        'cls',\n        'collapsed',\n        'column',\n        'crudManager',\n        'dataset',\n        'date',\n        'dateFormat',\n        'defaultCalendar',\n        'deselectAllOnScheduleClick',\n        'disabled',\n        'events',\n        'extraData',\n        'flex',\n        'focusVisible',\n        'hasChanges',\n        'height',\n        'hidden',\n        'hideNonWorkingDays',\n        'id',\n        'inputFieldAlign',\n        'insertBefore',\n        'insertFirst',\n        'isEngineReady',\n        'isEventSelectable',\n        'isSettingValues',\n        'isValid',\n        'items',\n        'keyMap',\n        'labelPosition',\n        'layout',\n        'layoutStyle',\n        'margin',\n        'maxDate',\n        'maxHeight',\n        'maximizeOnMobile',\n        'maxWidth',\n        'minDate',\n        'minHeight',\n        'minWidth',\n        'mode',\n        'modeDefaults',\n        'modes',\n        'nonWorkingDays',\n        'parent',\n        'project',\n        'readOnly',\n        'record',\n        'recurrenceConfirmationPopup',\n        'rendition',\n        'resources',\n        'resourceTimeRanges',\n        'rtl',\n        'scrollable',\n        'selectedEvents',\n        'selectResourceOnEventNavigate',\n        'selectResourceOnScheduleClick',\n        'span',\n        'state',\n        'strictRecordMapping',\n        'timeRanges',\n        'title',\n        'tools',\n        'tooltip',\n        'useContextualRecurrenceRules',\n        'values',\n        'views',\n        'width',\n        'x',\n        'y'\n    ]);\n\n    private elementRef: ElementRef;\n    public instance!: Calendar;\n\n    private bryntumConfig = {\n        adopt            : undefined,\n        appendTo         : undefined,\n        href             : undefined,\n        angularComponent : this,\n        features         : {},\n        listeners        : {}\n    };\n\n    constructor(element: ElementRef) {\n        this.elementRef = element;\n    }\n\n    // Configs only\n    @Input() adopt                            ! : HTMLElement|string;\n    @Input() align                            ! : AlignSpec|string;\n    @Input() anchor                           ! : boolean;\n    @Input() ariaDescription                  ! : string;\n    @Input() ariaLabel                        ! : string;\n    @Input() assignmentStore                  ! : AssignmentStore|AssignmentStoreConfig;\n    @Input() autoCreate                       ! : {\n        gesture?: string\n        newName?: Function|string\n        step?: string\n        duration?: string\n        startHour?: number|string\n    }|string|boolean;\n    @Input() bbar                             ! : (CalendarContainerItemConfig|string)[]|ToolbarConfig|PagingToolbarConfig|null;\n    @Input() bodyCls                          ! : string|object;\n    @Input() bubbleEvents                     ! : object;\n    @Input() centered                         ! : boolean;\n    @Input() collapsible                      ! : boolean|PanelCollapserConfig|PanelCollapserOverlayConfig;\n    @Input() color                            ! : string;\n    @Input() config                           ! : object;\n    @Input() constrainTo                      ! : HTMLElement|Widget|Rectangle;\n    @Input() contentElementCls                ! : string|object;\n    @Input() contextMenuTriggerEvent          ! : 'contextmenu'|'click'|'dblclick';\n    @Input() crudManagerClass                 ! : SchedulerCrudManager;\n    @Input() dataField                        ! : string;\n    @Input() datePicker                       ! : CalendarDatePickerConfig|boolean|null;\n    @Input() defaultBindProperty              ! : string;\n    @Input() defaultFocus                     ! : ((widget: Widget) => boolean)|string;\n    @Input() defaults                         ! : CalendarContainerItemConfig;\n    @Input() deselectOnClick                  ! : boolean;\n    @Input() destroyStores                    ! : boolean;\n    @Input() detectCSSCompatibilityIssues     ! : boolean;\n    @Input() dock                             ! : 'top'|'bottom'|'left'|'right'|'start'|'end'|'header'|'pre-header'|object;\n    @Input() draggable                        ! : boolean|{\n        handleSelector?: string\n    };\n    @Input() drawer                           ! : boolean|{side?: 'start'|'left'|'end'|'right'|'top'|'bottom', size?: string|number, inline?: boolean, autoClose: { mousedown?: boolean|string, focusout?: boolean|string, mouseout?: string }, autoCloseDelay?: number};\n    @Input() elementAttributes                ! : Record<string, string|null>;\n    @Input() enableDeleteKey                  ! : boolean;\n    @Input() enableRecurringEvents            ! : boolean|{\n        defaultAction?: 'single'|'future'\n    };\n    @Input() enableUndoRedoKeys               ! : boolean;\n    @Input() eventSelectionDisabled           ! : boolean;\n    @Input() eventStore                       ! : EventStore|EventStoreConfig;\n    @Input() filterEventResources             ! : boolean;\n    @Input() floating                         ! : boolean;\n    @Input() footer                           ! : {\n        dock?: 'top'|'right'|'bottom'|'left'|'start'|'end'\n        html?: string\n        cls?: string\n    }|string;\n    @Input() header                           ! : string|boolean|PanelHeader;\n    @Input() hideAnimation                    ! : boolean|object;\n    @Input() hideWhenEmpty                    ! : boolean;\n    @Input() highlightDate                    ! : boolean|((date: Date) => boolean);\n    @Input() highlightPredecessors            ! : boolean;\n    @Input() highlightSuccessors              ! : boolean;\n    @Input() icon                             ! : string|DomConfig;\n    @Input() ignoreParentReadOnly             ! : boolean;\n    @Input() includeWeekendsButton            ! : boolean|ButtonConfig;\n    @Input() itemCls                          ! : string;\n    @Input() lazyItems                        ! : Record<string, CalendarContainerItemConfig>|CalendarContainerItemConfig[]|Widget[];\n    @Input() listeners                        ! : CalendarListeners;\n    @Input() loadMask                         ! : string|MaskConfig|null;\n    @Input() loadMaskDefaults                 ! : MaskConfig;\n    @Input() loadMaskError                    ! : MaskConfig|Mask|boolean;\n    @Input() localeClass                      ! : typeof Base;\n    @Input() localizable                      ! : boolean;\n    @Input() localizableProperties            ! : string[];\n    @Input() maintainSelectionOnDatasetChange ! : boolean;\n    @Input() maskDefaults                     ! : MaskConfig;\n    @Input() masked                           ! : boolean|string|MaskConfig;\n    @Input() monitorResize                    ! : boolean|{\n        immediate?: boolean\n    };\n    @Input() multiEventSelect                 ! : boolean|{\n        ctrlKey?: boolean\n        altKey?: boolean\n        shiftKey?: boolean\n    };\n    @Input() namedItems                       ! : Record<string, CalendarContainerItemConfig>;\n    @Input() navigatorPlacement               ! : 'toolbar'|'sidebar';\n    @Input() overlaySidebar                   ! : boolean;\n    @Input() owner                            ! : Widget|any;\n    @Input() positioned                       ! : boolean;\n    @Input() preventTooltipOnTouch            ! : boolean;\n    @Input() propagatedConfigs                ! : string[];\n    @Input() relayStoreEvents                 ! : boolean;\n    @Input() resourceImagePath                ! : string;\n    @Input() resourceStore                    ! : ResourceStore|ResourceStoreConfig;\n    @Input() resourceTimeRangeStore           ! : ResourceTimeRangeStore|ResourceTimeRangeStoreConfig;\n    @Input() responsive                       ! : object;\n    @Input() responsiveRoot                   ! : boolean;\n    @Input() responsiveState                  ! : string;\n    @Input() responsiveTarget                 ! : string|Widget;\n    @Input() ripple                           ! : boolean|{\n        delegate?: string\n        color?: string\n        radius?: number\n        clip?: string\n    };\n    @Input() rootElement                      ! : ShadowRoot|HTMLElement;\n    @Input() scrollAction                     ! : 'hide'|'realign'|null;\n    @Input() showAnimation                    ! : boolean|object;\n    @Input() showRecurringUI                  ! : boolean;\n    @Input() showTooltipWhenDisabled          ! : boolean;\n    @Input() sidebar                          ! : {side?: 'left'|'right', collapsed?: boolean, items: { [mode: string]: CalendarContainerItemConfig|null|undefined, datePicker?: DatePickerConfig, eventFilter?: TextFieldConfig, resourceFilter?: ResourceFilterConfig }}|boolean;\n    @Input() stateful                         ! : boolean|object|string[];\n    @Input() statefulEvents                   ! : object|string[];\n    @Input() stateId                          ! : string;\n    @Input() stateProvider                    ! : StateProvider;\n    @Input() strips                           ! : Record<string, CalendarContainerItemConfig>;\n    @Input() syncMask                         ! : string|MaskConfig|null;\n    @Input() tab                              ! : boolean|TabConfig;\n    @Input() tabBarItems                      ! : ToolbarItems[]|Widget[];\n    @Input() tag                              ! : string;\n    @Input() tbar                             ! : (CalendarContainerItemConfig|string)[]|ToolbarConfig|CalendarToolbarConfig|null;\n    @Input() textAlign                        ! : 'left'|'center'|'right'|'start'|'end';\n    @Input() timeRangeStore                   ! : TimeRangeStore|TimeRangeStoreConfig;\n    @Input() timeZone                         ! : string|number;\n    @Input() trapFocus                        ! : boolean;\n    @Input() triggerSelectionChangeOnRemove   ! : boolean;\n    @Input() type                             ! : 'calendar';\n    @Input() ui                               ! : 'plain'|'toolbar'|string|object;\n    @Input() viewContainer                    ! : ContainerConfig;\n    @Input() weekStartDay                     ! : number;\n    @Input() weight                           ! : number;\n\n    // Configs and properties\n    @Input() activeDateCls                 ! : string;\n    @Input() alignSelf                     ! : string;\n    @Input() appendTo                      ! : HTMLElement|string;\n    @Input() assignments                   ! : AssignmentModel[]|AssignmentModelConfig[];\n    @Input() callOnFunctions               ! : boolean;\n    @Input() catchEventHandlerExceptions   ! : boolean;\n    @Input() cls                           ! : string|object;\n    @Input() collapsed                     ! : boolean;\n    @Input() column                        ! : number;\n    @Input() crudManager                   ! : SchedulerCrudManager|CrudManagerConfig;\n    @Input() dataset                       ! : object|Record<string, string>;\n    @Input() date                          ! : Date|string;\n    @Input() dateFormat                    ! : string;\n    @Input() defaultCalendar               ! : ResourceModel|string;\n    @Input() deselectAllOnScheduleClick    ! : boolean;\n    @Input() disabled                      ! : boolean|'inert';\n    @Input() events                        ! : EventModel[]|EventModelConfig[];\n    @Input() extraData                     ! : any;\n    @Input() flex                          ! : number|string;\n    @Input() height                        ! : number|string;\n    @Input() hidden                        ! : boolean;\n    @Input() hideNonWorkingDays            ! : boolean;\n    @Input() id                            ! : string;\n    @Input() inputFieldAlign               ! : 'start'|'end';\n    @Input() insertBefore                  ! : HTMLElement|string;\n    @Input() insertFirst                   ! : HTMLElement|string;\n    @Input() isEventSelectable             ! : (event: EventModel) => boolean;\n    @Input() items                         ! : (CalendarContainerItemConfig|MenuItemConfig|Widget)[]|Record<string, CalendarContainerItemConfig|MenuItemConfig>|Widget[]|object|WidgetConfig;\n    @Input() keyMap                        ! : Record<string, KeyMapConfig>;\n    @Input() labelPosition                 ! : 'before'|'above'|'align-before'|'auto'|null;\n    @Input() layout                        ! : Layout|string|CalendarContainerLayoutConfig;\n    @Input() layoutStyle                   ! : object;\n    @Input() margin                        ! : number|string;\n    @Input() maxDate                       ! : Date|string;\n    @Input() maxHeight                     ! : string|number;\n    @Input() maximizeOnMobile              ! : number|string;\n    @Input() maxWidth                      ! : string|number;\n    @Input() minDate                       ! : Date|string;\n    @Input() minHeight                     ! : string|number;\n    @Input() minWidth                      ! : string|number;\n    @Input() mode                          ! : string|'agenda'|'year'|'month'|'week'|'day'|'list'|'resource'|'dayresource'|'dayagenda'|'monthagenda'|'monthgrid';\n    @Input() modeDefaults                  ! : object;\n    @Input() modes                         ! : Record<string, CalendarView>|object;\n    @Input() nonWorkingDays                ! : Record<number, boolean>;\n    @Input() project                       ! : ProjectModel|ProjectModelConfig|object;\n    @Input() readOnly                      ! : boolean;\n    @Input() recurrenceConfirmationPopup   ! : RecurrenceConfirmationPopupConfig|RecurrenceConfirmationPopup;\n    @Input() rendition                     ! : string|Record<string, string>|null;\n    @Input() resources                     ! : ResourceModel[]|ResourceModelConfig[];\n    @Input() resourceTimeRanges            ! : ResourceTimeRangeModel[]|ResourceTimeRangeModelConfig[];\n    @Input() rtl                           ! : boolean;\n    @Input() scrollable                    ! : Scroller|boolean|ScrollerConfig;\n    @Input() selectResourceOnEventNavigate ! : boolean;\n    @Input() selectResourceOnScheduleClick ! : boolean;\n    @Input() span                          ! : number;\n    @Input() strictRecordMapping           ! : boolean;\n    @Input() timeRanges                    ! : TimeRangeModel[]|TimeRangeModelConfig[];\n    @Input() title                         ! : string;\n    @Input() tools                         ! : Record<string, Tool|ToolConfig>|null|Record<string, Tool>|Record<string, ToolConfig>;\n    @Input() tooltip                       ! : string|TooltipConfig|null;\n    @Input() useContextualRecurrenceRules  ! : boolean;\n    @Input() width                         ! : number|string;\n    @Input() x                             ! : number;\n    @Input() y                             ! : number;\n\n    // Properties only\n    @Input() activeSubView   ! : CalendarView;\n    @Input() activeView      ! : CalendarView;\n    @Input() anchorSize      ! : number[];\n    @Input() focusVisible    ! : boolean;\n    @Input() hasChanges      ! : boolean;\n    @Input() isEngineReady   ! : boolean;\n    @Input() isSettingValues ! : boolean;\n    @Input() isValid         ! : boolean;\n    @Input() parent          ! : Widget;\n    @Input() record          ! : Model;\n    @Input() selectedEvents  ! : EventModel[];\n    @Input() state           ! : any;\n    @Input() values          ! : Record<string, object>;\n    @Input() views           ! : CalendarView[];\n\n    // Features\n    @Input() dragFeature                 ! : object|boolean|string|CalendarDrag|CalendarDragConfig;\n    @Input() eventBufferFeature          ! : object|boolean|string|EventBuffer|EventBufferConfig;\n    @Input() eventCopyPasteFeature       ! : object|boolean|string|EventCopyPaste|EventCopyPasteConfig;\n    @Input() eventEditFeature            ! : object|boolean|string|EventEdit|EventEditConfig;\n    @Input() eventMenuFeature            ! : object|boolean|string|EventMenu|EventMenuConfig;\n    @Input() eventTooltipFeature         ! : object|boolean|string|EventTooltip|EventTooltipConfig;\n    @Input() excelExporterFeature        ! : object|boolean|string|ExcelExporter|ExcelExporterConfig;\n    @Input() externalEventSourceFeature  ! : object|boolean|string|ExternalEventSource|ExternalEventSourceConfig;\n    @Input() loadOnDemandFeature         ! : object|boolean|string|LoadOnDemand|LoadOnDemandConfig;\n    @Input() printFeature                ! : object|boolean|string|Print|PrintConfig;\n    @Input() scheduleMenuFeature         ! : object|boolean|string|ScheduleMenu|ScheduleMenuConfig;\n    @Input() scheduleTooltipFeature      ! : object|boolean|string|ScheduleTooltip|ScheduleTooltipConfig;\n    @Input() timeRangesFeature           ! : object|boolean|string|TimeRanges|TimeRangesConfig;\n    @Input() weekExpanderFeature         ! : object|boolean|string|WeekExpander|WeekExpanderConfig;\n\n    // Events emitters\n    /**\n     * Fired when a change of view (Calendar mode) has completed. By default, view changes are animated and this\n     * event fires when the view is fully visible.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance.\n     * @param {CalendarView} event.prevActiveItem The previously active view.\n     * @param {CalendarView} event.activeItem The new active view.\n     * @param {boolean} event.containedFocus `true` if the outgoing view contained focus.\n     */\n    @Output() onActiveItemChange: any = new EventEmitter<((event: { source: Calendar, prevActiveItem: CalendarView, activeItem: CalendarView, containedFocus: boolean }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler after editor is closed by any action - save, delete or cancel\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler\n     * @param {'save','delete','cancel'} event.action The action that was taken to end the edit. One of 'save', 'delete' or 'cancel'\n     * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature\n     * @param {Scheduler.model.EventModel} event.eventRecord The record that has been edited.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.\n     * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.\n     * @param {Core.widget.Popup} event.editor The editor\n     */\n    @Output() onAfterEventEdit: any = new EventEmitter<((event: { source: Scheduler, action: 'save'|'delete'|'cancel', eventEdit: SchedulerEventEdit, eventRecord: EventModel, resourceRecord: ResourceModel, eventElement: HTMLElement, editor: Popup }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler after an event is successfully saved\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler instance\n     * @param {Scheduler.model.EventModel} event.eventRecord The record about to be saved\n     */\n    @Output() onAfterEventSave: any = new EventEmitter<((event: { source: Scheduler, eventRecord: EventModel }) => void)|string>();\n    /**\n     * Fired before a change of view (Calendar mode) is initiated.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance.\n     * @param {CalendarView} event.prevActiveItem The previously active view.\n     * @param {CalendarView} event.activeItem The new active view.\n     */\n    @Output() onBeforeActiveItemChange: any = new EventEmitter<((event: { source: Calendar, prevActiveItem: CalendarView, activeItem: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires before an assignment is removed. Can be triggered by user pressing [DELETE] or [BACKSPACE] or\n     * by the event editor. Can for example be used to display a custom dialog to confirm deletion, in which\n     * case records should be \"manually\" removed after confirmation:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeAssignmentDelete)\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The Scheduler instance\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be deleted\n     * @param {object} event.context Additional removal context:\n     * @param {Function} event.context.finalize Function to call to finalize the removal. Used to asynchronously decide to remove the records or not. Provide `false` to the function to prevent the removal.\n     * @param {boolean} event.context.finalize.removeRecords Provide `false` to the function to prevent the removal.\n     */\n    @Output() onBeforeAssignmentDelete: any = new EventEmitter<((event: { source: Scheduler, assignmentRecords: AssignmentModel[], context: { finalize: { removeRecords?: boolean } } }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fired any time there is going to be a change to the assignments selected in the Scheduler.\n     * Returning `false` prevents the change\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source This Scheduler instance.\n     * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'\n     * @param {Scheduler.model.AssignmentModel[]} event.selected An array of assignments that will be added to the selection.\n     * @param {Scheduler.model.AssignmentModel[]} event.deselected An array of assignments that will be removed from the selection.\n     * @param {Scheduler.model.AssignmentModel[]} event.selection The currently selected assignments, before applying `selected` and `deselected`.\n     */\n    @Output() onBeforeAssignmentSelectionChange: any = new EventEmitter<((event: { source: Scheduler, action: 'select'|'deselect'|'update'|'clear', selected: AssignmentModel[], deselected: AssignmentModel[], selection: AssignmentModel[] }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires whenever a child view's [autoCreate gesture](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate) is detected and also when a [drag-create](#Calendar/feature/CalendarDrag) gesture is detected.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeAutoCreate)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The child view on which the event was initiated.\n     * @param {Event} event.domEvent The DOM event which initiated the creation.\n     * @param {Date} event.date *DEPRECATED in favour of `startDate`.* The starting time of the event to be created. If this is in a `DayView`, this will be snapped according to the specification in [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate)\n     * @param {Date} event.startDate The starting time of the event to be created. If this is in a `DayView`, this will be snapped according to the specification in [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate)\n     * @param {Date} event.endDate The ending time of the event to be created.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.\n     */\n    @Output() onBeforeAutoCreate: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, startDate: Date, endDate: Date, resourceRecord: ResourceModel }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Scheduler before a copy action is performed, return `false` to prevent the action\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Owner scheduler\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The event records about to be copied\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be copied\n     * @param {boolean} event.isCut `true` if this is a cut action\n     * @param {string} event.entityName 'event' to distinguish this event from other beforeCopy events\n     */\n    @Output() onBeforeCopy: any = new EventEmitter<((event: { source: Scheduler, eventRecords: EventModel[], assignmentRecords: AssignmentModel[], isCut: boolean, entityName: string }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires before a mode is created. The configuration block is passed to the handler for possible modification.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar\n     * @param {AgendaViewConfig,DayResourceViewConfig,DayViewConfig,EventListConfig,MonthViewConfig,ResourceViewConfig,WeekViewConfig,YearViewConfig,DayAgendaViewConfig,MonthAgendaViewConfig,CalendarContainerItemConfig} event.config The configuration block of the mode about to be created. Any property, including the `type` may be changed.\n     */\n    @Output() onBeforeCreateMode: any = new EventEmitter<((event: { source: Calendar, config: AgendaViewConfig|DayResourceViewConfig|DayViewConfig|EventListConfig|MonthViewConfig|ResourceViewConfig|WeekViewConfig|YearViewConfig|DayAgendaViewConfig|MonthAgendaViewConfig|CalendarContainerItemConfig }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Grid before CSV export starts. Return `false` to cancel the export.\n     * @param {object} event Event object\n     * @param {ExportConfig} event.config Export config\n     * @param {Grid.column.Column[]} event.columns An array of columns to export\n     * @param {Core.data.Model[]} event.rows An array of records to export\n     * @param {string} event.lineDelimiter The CSV delimiter to separate lines\n     * @param {string} event.columnDelimiter The CSV delimiter to separate values on one line\n     */\n    @Output() onBeforeCSVExport: any = new EventEmitter<((event: { config: ExportConfig, columns: Column[], rows: Model[], lineDelimiter: string, columnDelimiter: string }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires before an object is destroyed.\n     * @param {object} event Event object\n     * @param {Core.Base} event.source The Object that is being destroyed.\n     */\n    @Output() onBeforeDestroy: any = new EventEmitter<((event: { source: Base }) => void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag creation gesture is started. Return `false` to\n     * veto the operation.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.domEvent The browser event.\n     * @param {Date} event.date The date at the drag DOM event position.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {CalendarView} event.view The Calendar widget in which the drag is being started.\n     */\n    @Output() onBeforeDragCreate: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, domEvent: Event, date: Date, resourceRecord?: ResourceModel, feature: CalendarDrag, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag creation gesture is completed. Return `false` to\n     * immediately veto the operation or a Promise yielding `true` or `false` for async vetoing.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being created that has not yet been added in the store.\n     * @param {Date} event.newStartDate The new start date.\n     * @param {Date} event.newEndDate The new end date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateCreateFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateCreateFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onBeforeDragCreateEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, newStartDate: Date, newEndDate: Date, resourceRecord?: ResourceModel, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag move gesture is started. Return `false` to\n     * veto the operation.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag move context.\n     * @param {Event} event.domEvent The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being moved.\n     * @param {Date} event.date The date at the drag DOM event position.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {CalendarView} event.view The Calendar widget in which the drag is being started.\n     */\n    @Output() onBeforeDragMove: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, domEvent: Event, eventRecord: EventModel, date: Date, resourceRecord?: ResourceModel, feature: CalendarDrag, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag move gesture is completed. Return `false` to immediately veto the operation\n     * or a Promise yielding `true` or `false` for async vetoing.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record that has *not yet been updated* in the store.\n     * @param {Scheduler.model.EventModel} event.proxyEventRecord The `EventModel` record that is being used as a proxy for the drag operation and being updated on every pointer move. This will contain changed values based on the drag position.\n     * @param {Date} event.newStartDate The new start date.\n     * @param {Date} event.newEndDate The new end date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateMoveFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateMoveFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onBeforeDragMoveEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, proxyEventRecord: EventModel, newStartDate: Date, newEndDate: Date, resourceRecord?: ResourceModel, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag resize gesture is started. Return `false` to\n     * veto the operation.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag resize context.\n     * @param {Event} event.domEvent The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record being resized.\n     * @param {Date} event.date The date at the drag DOM event position.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {CalendarView} event.view The Calendar widget in which the drag is being started.\n     */\n    @Output() onBeforeDragResize: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, domEvent: Event, eventRecord: EventModel, date: Date, resourceRecord?: ResourceModel, feature: CalendarDrag, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Calendar before a drag resize gesture is completed. Return `false` to immediately veto the operation\n     * or a Promise yielding `true` or `false` for async vetoing.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The `EventModel` record that has *not yet been updated* in the store.\n     * @param {Scheduler.model.EventModel} event.proxyEventRecord The `EventModel` record that is being used as a proxy for the drag operation and being updated on every pointer move. This will contain changed values based on the drag position.\n     * @param {Date} event.newStartDate The new start date.\n     * @param {Date} event.newEndDate The new end date.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateResizeFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateResizeFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onBeforeDragResizeEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, proxyEventRecord: EventModel, newStartDate: Date, newEndDate: Date, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event is fired on the owning Calendar when dropping an event from the calendar on the\n     * external source <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>. Returning `false`\n     * prevents the gesture from being completed.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeDropExternal)\n     * @param {object} event Event object\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record being dragged.\n     * @param {boolean} event.dropOnCalendar `true` if the drop gesture is over the client Calendar. This feature also allows drag *out* of the Calendar and onto the external event source if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) config is set.\n     * @param {HTMLElement} event.itemElement The element in which the drag gesture started.\n     * @param {HTMLElement} event.targetElement The current over element.\n     * @param {Event} event.domEvent The pointer event associated with the drag point.\n     * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;\n     * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;\n     * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.\n     * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.\n     * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.\n     * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.\n     * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.\n     */\n    @Output() onBeforeDropExternal: any = new EventEmitter<((event: { eventRecord: EventModel, dropOnCalendar: boolean, itemElement: HTMLElement, targetElement: HTMLElement, domEvent: Event, overIndex: number, overRecord: Model, isAbove: boolean, altKey: boolean, ctrlKey: boolean, metaKey: boolean, shiftKey: boolean }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires before an event is removed. Can be triggered by user pressing [DELETE] or [BACKSPACE] or by the\n     * event editor. Can for example be used to display a custom dialog to confirm deletion, in which case\n     * records should be \"manually\" removed after confirmation:\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventDelete)\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The records about to be deleted\n     * @param {object} event.context Additional removal context:\n     * @param {Function} event.context.finalize Function to call to finalize the removal. Used to asynchronously decide to remove the records or not. Provide `false` to the function to prevent the removal.\n     * @param {boolean} event.context.finalize.removeRecords Provide `false` to the function to prevent the removal.\n     */\n    @Output() onBeforeEventDelete: any = new EventEmitter<((event: { source: Calendar, eventRecords: EventModel[], context: { finalize: { removeRecords?: boolean } } }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Scheduler before an event is displayed in an editor.\n     * This may be listened for to allow an application to take over event editing duties. Returning `false`\n     * stops the default editing UI from being shown.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventEdit)\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler\n     * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature\n     * @param {Scheduler.model.EventModel} event.eventRecord The record about to be shown in the event editor.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.\n     * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.\n     */\n    @Output() onBeforeEventEdit: any = new EventEmitter<((event: { source: Scheduler, eventEdit: SchedulerEventEdit, eventRecord: EventModel, resourceRecord: ResourceModel, eventElement: HTMLElement }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Scheduler when the editor for an event is available but before it is populated with\n     * data and shown. Allows manipulating fields etc.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler\n     * @param {Scheduler.feature.SchedulerEventEdit} event.eventEdit The eventEdit feature\n     * @param {Scheduler.model.EventModel} event.eventRecord The record about to be shown in the event editor.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The Resource record for the event. If the event is being created, it will not contain a resource, so this parameter specifies the resource the event is being created for.\n     * @param {HTMLElement} event.eventElement The element which represents the event in the scheduler display.\n     * @param {Core.widget.Popup} event.editor The editor\n     */\n    @Output() onBeforeEventEditShow: any = new EventEmitter<((event: { source: Scheduler, eventEdit: SchedulerEventEdit, eventRecord: EventModel, resourceRecord: ResourceModel, eventElement: HTMLElement, editor: Popup }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler before an event is saved.\n     * Return `false` to immediately prevent saving\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-beforeEventSave)\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler instance\n     * @param {Scheduler.model.EventModel} event.eventRecord The record about to be saved\n     * @param {Scheduler.model.ResourceModel[]} event.resourceRecords The resources to which the event is assigned\n     * @param {object} event.values The new values\n     * @param {object} event.context Extended save context:\n     * @param {boolean} event.context.async Set this to `true` in a listener to indicate that the listener will asynchronously decide to prevent or not the event save.\n     * @param {Function} event.context.finalize Function to call to finalize the save. Used when `async` is `true`. Provide `false` to the function to prevent the save.\n     */\n    @Output() onBeforeEventSave: any = new EventEmitter<((event: { source: Scheduler, eventRecord: EventModel, resourceRecords: ResourceModel[], values: object, context: { async?: boolean, finalize: Function } }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fired any time there is going to be a change to the events selected in the Scheduler.\n     * Returning `false` prevents the change\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source This Scheduler instance.\n     * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'\n     * @param {Scheduler.model.EventModel[]} event.selected An array of events that will be added to the selection.\n     * @param {Scheduler.model.EventModel[]} event.deselected An array of events that will be removed from the selection.\n     * @param {Scheduler.model.EventModel[]} event.selection The currently selected events, before applying `selected` and `deselected`.\n     */\n    @Output() onBeforeEventSelectionChange: any = new EventEmitter<((event: { source: Scheduler, action: 'select'|'deselect'|'update'|'clear', selected: EventModel[], deselected: EventModel[], selection: EventModel[] }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Grid before Excel export starts. Return `false` to cancel the export.\n     * @param {object} event Event object\n     * @param {ExportConfig} event.config Export config\n     * @param {XLSColumn[]} event.columns An array of columns to export\n     * @param {any[][]} event.rows An array of records to export\n     */\n    @Output() onBeforeExcelExport: any = new EventEmitter<((event: { config: ExportConfig, columns: XLSColumn[], rows: any[] }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Triggered before a widget is hidden. Return `false` to prevent the action.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget being hidden.\n     */\n    @Output() onBeforeHide: any = new EventEmitter<((event: { source: Widget }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Scheduler before a paste action is performed, return `false` to prevent the action.\n     * Depending on if the EventStore is using [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the\n     * configuration of [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param\n     * will be populated with record copies.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Owner scheduler\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The events about to be pasted\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignments about to be pasted\n     * @param {Scheduler.model.EventModel[]} event.originalEventRecords The original event records\n     * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The original assignment record\n     * @param {Date} event.date The date when the pasted events will be scheduled\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record, the clipboard event records will be assigned to this resource.\n     * @param {boolean} event.isCut `true` if this is a cut action\n     * @param {string} event.entityName 'event' to distinguish this event from other beforePaste events\n     */\n    @Output() onBeforePaste: any = new EventEmitter<((event: { source: Scheduler, eventRecords: EventModel[], assignmentRecords: AssignmentModel[], originalEventRecords: EventModel[], originalAssignmentRecords: AssignmentModel[], date: Date, resourceRecord: ResourceModel, isCut: boolean, entityName: string }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires on the owning Calendar before print starts. Return `false` to cancel the print.\n     * @param {object} event Event object\n     * @param {object} event.config Print config\n     */\n    @Output() onBeforePrint: any = new EventEmitter<((event: { config: object }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Triggered before a new [responsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveState) is applied.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget whose `responsiveState` is to be changed\n     * @param {string} event.state The new value for the widget's `responsiveState`\n     * @param {string} event.oldState The previous value for the widget's `responsiveState`\n     */\n    @Output() onBeforeResponsiveStateChange: any = new EventEmitter<((event: { source: Widget, state: string, oldState: string }) => void)|string>();\n    /**\n     * Fired before this container will load record values into its child fields. This is useful if you\n     * want to modify the UI before data is loaded (e.g. set some input field to be readonly)\n     * @param {object} event Event object\n     * @param {Core.widget.Container} event.source The container\n     * @param {Core.data.Model} event.record The record\n     */\n    @Output() onBeforeSetRecord: any = new EventEmitter<((event: { source: Container, record: Model }) => void)|string>();\n    /**\n     * Triggered before a widget is shown. Return `false` to prevent the action.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget,any} event.source The widget being shown\n     */\n    @Output() onBeforeShow: any = new EventEmitter<((event: { source: Widget|any }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fired before state is applied to the source. Allows editing the state object or preventing the operation.\n     * @param {object} event Event object\n     * @param {any} event.state State object config\n     */\n    @Output() onBeforeStateApply: any = new EventEmitter<((event: { state: any }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fired before state is saved by the StateProvider. Allows editing the state object or preventing the operation.\n     * @param {object} event Event object\n     * @param {any} event.state State object config\n     */\n    @Output() onBeforeStateSave: any = new EventEmitter<((event: { state: any }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires when any other event is fired from the object.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-catchAll)\n     * @param {object} event Event object\n     * @param {{[key: string]: any, type: string}} event.event The Object that contains event details\n     * @param {string} event.event.type The type of the event which is caught by the listener\n     */\n    @Output() onCatchAll: any = new EventEmitter<((event: {[key: string]: any, type: string}) => void)|string>();\n    /**\n     * Fires when a cell overflow indicator is clicked or activated by the <kbd>ENTER</kbd> key in any view. This will include\n     * the cells of a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView) and the `+ n more` overflow\n     * indicator of cells in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView), and \"all day\" events section\n     * of a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView).\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date clicked on.\n     */\n    @Output() onCellOverflowClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date }) => void)|string>();\n    /**\n     * Fires when a Panel is collapsed using the [collapsible](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsible) setting.\n     * @param {object} event Event object\n     * @param {Core.widget.Panel} event.source This Panel.\n     */\n    @Output() onCollapse: any = new EventEmitter<((event: { source: Panel }) => void)|string>();\n    /**\n     * This event fires on the owning widget when an item is selected in the context menu.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The owning widget\n     * @param {Core.widget.Menu} event.menu The menu\n     * @param {Core.widget.MenuItem} event.item Selected menu item\n     */\n    @Output() onContextMenuItem: any = new EventEmitter<((event: { source: Widget, menu: Menu, item: MenuItem }) => void)|string>();\n    /**\n     * This event fires on the owning widget when a check item is toggled in the context menu.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The owning widget\n     * @param {Core.widget.Menu} event.menu The menu\n     * @param {Core.widget.MenuItem} event.item Selected menu item\n     * @param {boolean} event.checked Checked or not\n     */\n    @Output() onContextMenuToggleItem: any = new EventEmitter<((event: { source: Widget, menu: Menu, item: MenuItem, checked: boolean }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler after a copy action is performed. Depending on if the EventStore is using\n     * [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the configuration of\n     * [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param will be populated\n     * with record copies.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Owner scheduler\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The event record copies\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment record copies\n     * @param {Scheduler.model.EventModel[]} event.originalEventRecords The event records that were copied\n     * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecord The assignment records that were copied\n     * @param {boolean} event.isCut `true` if this is a cut action\n     * @param {string} event.entityName 'event' to distinguish this event from other copy events\n     */\n    @Output() onCopy: any = new EventEmitter<((event: { source: Scheduler, eventRecords: EventModel[], assignmentRecords: AssignmentModel[], originalEventRecords: EventModel[], originalAssignmentRecord: AssignmentModel[], isCut: boolean, entityName: string }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler/Gantt when the line indicating the current time is updated (see [currentTimeLineUpdateInterval](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/TimeRanges#config-currentTimeLineUpdateInterval)).\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source The scheduler\n     * @param {Date} event.date The current date\n     */\n    @Output() onCurrentTimelineUpdate: any = new EventEmitter<((event: { source: Scheduler, date: Date }) => void)|string>();\n    /**\n     * Fired when data in any of the projects stores changes.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dataChange)\n     * @param {object} event Event object\n     * @param {typeof Scheduler.data.mixin.ProjectConsumer,any} event.source Owning component\n     * @param {typeof Scheduler.model.mixin.ProjectModelMixin,any} event.project Project model\n     * @param {Core.data.Store} event.store Affected store\n     * @param {'remove','removeAll','add','clearchanges','filter','update','dataset','replace'} event.action Name of action which triggered the change. May be one of:  * `'remove'` * `'removeAll'` * `'add'` * `'clearchanges'` * `'filter'` * `'update'` * `'dataset'` * `'replace'`\n     * @param {Core.data.Model} event.record Changed record, for actions that affects exactly one record (`'update'`)\n     * @param {Core.data.Model[]} event.records Changed records, passed for all actions except `'removeAll'`\n     * @param {object} event.changes Passed for the `'update'` action, info on which record fields changed\n     */\n    @Output() onDataChange: any = new EventEmitter<((event: { source: typeof ProjectConsumer|any, project: typeof ProjectModelMixin|any, store: Store, action: 'remove'|'removeAll'|'add'|'clearchanges'|'filter'|'update'|'dataset'|'replace', record: Model, records: Model[], changes: object }) => void)|string>();\n    /**\n     * Fires when the calendar changes the date that it orientates its views around.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateChange)\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar.\n     * @param {Date} event.oldDate The previous Calendar date.\n     * @param {Date} event.date The new Calendar date.\n     */\n    @Output() onDateChange: any = new EventEmitter<((event: { source: Calendar, oldDate: Date, date: Date }) => void)|string>();\n    /**\n     * Fired when the eventStore is queried for events by date range, and the date range\n     * requested is different from the last time the store was queried.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateRangeChange)\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance\n     * @param {object} event.old The old date range\n     * @param {Date} event.old.startDate the old start date\n     * @param {Date} event.old.endDate the old end date\n     * @param {object} event.new The new date range\n     * @param {Date} event.new.startDate the new start date\n     * @param {Date} event.new.endDate the new end date\n     */\n    @Output() onDateRangeChange: any = new EventEmitter<((event: { source: Calendar, old: { startDate: Date, endDate: Date }, new: { startDate: Date, endDate: Date } }) => void)|string>();\n    /**\n     * Fires when the [LoadOnDemand](https://bryntum.com/products/calendar/docs/api/Calendar/feature/LoadOnDemand) feature has loaded a range of events.\n     * @param {object} event Event object\n     * @param {object} event.response The decoded JSON response.\n     * @param {object} event.options The options object passed into the CrudManager [CrudManager](https://bryntum.com/products/calendar/docs/api/Scheduler/data/CrudManager) [load](https://bryntum.com/products/calendar/docs/api/Scheduler/crud/AbstractCrudManagerMixin#function-load) method.\n     * @param {Date} event.startDate The start date of the range to request.\n     * @param {Date} event.endDate The end date of the range to request. <strong>Note that Dates are timestamps</strong>.\n     */\n    @Output() onDateRangeLoad: any = new EventEmitter<((event: { response: object, options: object, startDate: Date, endDate: Date }) => void)|string>();\n    /**\n     * Fired <strong>every</strong> time the eventStore is queried for events by date range.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dateRangeRequested)\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance\n     * @param {object} event.old The old date range\n     * @param {Date} event.old.startDate the old start date\n     * @param {Date} event.old.endDate the old end date\n     * @param {object} event.new The new date range\n     * @param {Date} event.new.startDate the new start date\n     * @param {Date} event.new.endDate the new end date\n     * @param {boolean} event.changed `true` if the date range is different from the last time a request was made\n     */\n    @Output() onDateRangeRequested: any = new EventEmitter<((event: { source: Calendar, old: { startDate: Date, endDate: Date }, new: { startDate: Date, endDate: Date }, changed: boolean }) => void)|string>();\n    /**\n     * Fired by the active view after one day cell's events are collected in sorted order according to the\n     * [eventSorter](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-eventSorter)\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dayCellPopulated)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Scheduler.model.EventModel[]} event.events The events to be shown for the passed date\n     * @param {Date} event.The date the events are to be shown in.\n     */\n    @Output() onDayCellPopulated: any = new EventEmitter<((event: { source: CalendarView, events: EventModel[], The: Date }) => void)|string>();\n    /**\n     * Fires when a day number is clicked or activated by the <kbd>ENTER</kbd> key in a view which shows day numbers.\n     * This will include the cells of a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView), the cell header of cells\n     * in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView), and the day header in a [DayView](#Calendar/widget/DayView).\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dayNumberClick)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date clicked on.\n     * @param {DayCell} event.cellData An object that contains data about the calendar cell for the date.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onDayNumberClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, cellData: DayCell, fromOverflowPopup: boolean }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fires when an object is destroyed.\n     * @param {object} event Event object\n     * @param {Core.Base} event.source The Object that is being destroyed.\n     */\n    @Output() onDestroy: any = new EventEmitter<((event: { source: Base }) => void)|string>();\n    /**\n     * Fires when a field is mutated and the state of the [hasChanges](https://bryntum.com/products/calendar/docs/api/Core/widget/Container#property-hasChanges) property changes\n     * @param {object} event Event object\n     * @param {Core.widget.Container} event.source The container.\n     * @param {boolean} event.dirty The dirty state of the Container - `true` if there are any fields which have been changed since initial load.\n     */\n    @Output() onDirtyStateChange: any = new EventEmitter<((event: { source: Container, dirty: boolean }) => void)|string>();\n    /**\n     * This event fires on the owning Calendar when a drag creation gesture is completed.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The new `EventModel` record added in the store.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateCreateFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateCreateFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onDragCreateEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, resourceRecord?: ResourceModel, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => void)|string>();\n    /**\n     * This event fires on the owning Calendar when a drag move gesture is completed. The `eventRecord` has already been added\n     * to the `eventStore` of the owning calendar.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The updated `EventModel` record.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The `ResourceModel` record if the gesture was performed in a resource-type view.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateMoveFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateMoveFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onDragMoveEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, resourceRecord?: ResourceModel, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => void)|string>();\n    /**\n     * This event is fired on the owning Calendar when dragging an event from the calendar over the\n     * external source <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dragMoveExternal)\n     * @param {object} event Event object\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record being dragged.\n     * @param {HTMLElement} event.itemElement The element in which the drag gesture started.\n     * @param {HTMLElement} event.targetElement The current over element.\n     * @param {Event} event.domEvent The pointer event associated with the drag point.\n     * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;\n     * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;\n     * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.\n     * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.\n     * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.\n     * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.\n     * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.\n     */\n    @Output() onDragMoveExternal: any = new EventEmitter<((event: { eventRecord: EventModel, itemElement: HTMLElement, targetElement: HTMLElement, domEvent: Event, overIndex: number, overRecord: Model, isAbove: boolean, altKey: boolean, ctrlKey: boolean, metaKey: boolean, shiftKey: boolean }) => void)|string>();\n    /**\n     * This event fires on the owning Calendar when a drag resize gesture is completed.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance that fired the event.\n     * @param {Core.util.drag.DragContext} event.drag The drag create context.\n     * @param {Event} event.event The browser event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The updated `EventModel` record.\n     * @param {Calendar.feature.CalendarDrag} event.feature The Calendar drag feature instance.\n     * @param {boolean,ValidateCreateResult} event.validation The result of the [validateResizeFn](https://bryntum.com/products/calendar/docs/api/Calendar/feature/CalendarDrag#config-validateResizeFn) if one was provided.\n     * @param {CalendarView} event.view The Calendar widget in which the drag completed.\n     */\n    @Output() onDragResizeEnd: any = new EventEmitter<((event: { source: Calendar, drag: DragContext, event: Event, eventRecord: EventModel, feature: CalendarDrag, validation: boolean|ValidateCreateResult, view: CalendarView }) => void)|string>();\n    /**\n     * This event is fired on the owning Calendar after dropping an event from the calendar on the\n     * external source has been completed <strong>if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) was configured</strong>.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-dropExternal)\n     * @param {object} event Event object\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record that was dropped.\n     * @param {boolean} event.dropOnCalendar `true` if the drop gesture is over the client Calendar. This feature also allows drag *out* of the Calendar and onto the external event source if the [droppable](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-droppable) config is set.\n     * @param {HTMLElement} event.itemElement The element in which the drag gesture started.\n     * @param {HTMLElement} event.targetElement The current over element.\n     * @param {Event} event.domEvent The pointer event associated with the drag point.\n     * @param {number} event.overIndex *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the index of the row being moved over;\n     * @param {Core.data.Model} event.overRecord *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, the record being moved over;\n     * @param {boolean} event.isAbove *If [grid](https://bryntum.com/products/calendar/docs/api/Calendar/feature/ExternalEventSource#config-grid) was specified*, `true` if the pointer position is above the halfway line of the over row.\n     * @param {boolean} event.altKey `true` if the Alt key was down when the last event was processed.\n     * @param {boolean} event.ctrlKey `true` if the Ctrl key was down when the last event was processed.\n     * @param {boolean} event.metaKey `true` if the Meta key was down when the last event was processed.\n     * @param {boolean} event.shiftKey `true` if the Shift key was down when the last event was processed.\n     */\n    @Output() onDropExternal: any = new EventEmitter<((event: { eventRecord: EventModel, dropOnCalendar: boolean, itemElement: HTMLElement, targetElement: HTMLElement, domEvent: Event, overIndex: number, overRecord: Model, isAbove: boolean, altKey: boolean, ctrlKey: boolean, metaKey: boolean, shiftKey: boolean }) => void)|string>();\n    /**\n     * Triggered when a widget's [element](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#property-element) is available.\n     * @param {object} event Event object\n     * @param {HTMLElement} event.element The Widget's element.\n     */\n    @Output() onElementCreated: any = new EventEmitter<((event: { element: HTMLElement }) => void)|string>();\n    /**\n     * Fired when an empty cell content area is clicked on in a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView) or a\n     * [CalendarRow](https://bryntum.com/products/calendar/docs/api/Calendar/widget/CalendarRow).\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The child view on which the event was initiated.\n     * @param {Event} event.domEvent The triggering DOM event.\n     * @param {Date} event.date The date which has no visible events\n     */\n    @Output() onEmptyCellClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date }) => void)|string>();\n    /**\n     * Fired when an [autoCreate](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/CalendarMixin#config-autoCreate) gesture has\n     * created a new event and added it to the event store.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-eventAutoCreated)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The child view on which the event was initiated.\n     * @param {Scheduler.model.EventModel} event.eventRecord The new event record.\n     */\n    @Output() onEventAutoCreated: any = new EventEmitter<((event: { source: CalendarView, eventRecord: EventModel }) => void)|string>();\n    /**\n     * Fires when an event bar is clicked in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event clicked on.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource clicked on if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when an event bar is right-clicked in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event right-clicked on.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource right-clicked on if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventContextMenu: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when an event bar is double clicked in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event double clicked on.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource double clicked on if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventDblClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fired before the editor will load the event record data into its input fields. This is useful if you\n     * want to modify the fields before data is loaded (e.g. set some input field to be readonly)\n     * @param {object} event Event object\n     * @param {Core.widget.Container} event.source The editor widget\n     * @param {Scheduler.model.EventModel} event.record The record\n     */\n    @Output() onEventEditBeforeSetRecord: any = new EventEmitter<((event: { source: Container, record: EventModel }) => void)|string>();\n    /**\n     * Fires when a key is pressed while an event bar is focused.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event in which the key event was detected.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource in which the key event was detected if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventKeyDown: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * This event fires on the owning Scheduler before the context menu is shown for an event. Allows manipulation of the items\n     * to show in the same way as in `processItems`. Returning `false` from a listener prevents the menu from\n     * being shown.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Record<string, MenuItemEntry>} event.items Menu item configs\n     * @param {Scheduler.model.EventModel} event.eventRecord Event record for which the menu was triggered\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record\n     * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used\n     * @param {HTMLElement} event.eventElement\n     * @param {MouseEvent} event.event Pointer event which triggered the context menu (if any)\n     */\n    @Output() onEventMenuBeforeShow: any = new EventEmitter<((event: { source: Scheduler, items: Record<string, MenuItemEntry>, eventRecord: EventModel, resourceRecord: ResourceModel, assignmentRecord: AssignmentModel, eventElement: HTMLElement, event?: MouseEvent }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Scheduler when an item is selected in the context menu.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Core.widget.MenuItem} event.item\n     * @param {Scheduler.model.EventModel} event.eventRecord\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord\n     * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used\n     * @param {HTMLElement} event.eventElement\n     */\n    @Output() onEventMenuItem: any = new EventEmitter<((event: { source: Scheduler, item: MenuItem, eventRecord: EventModel, resourceRecord: ResourceModel, assignmentRecord: AssignmentModel, eventElement: HTMLElement }) => void)|string>();\n    /**\n     * This event fires on the owning Scheduler after showing the context menu for an event\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Core.widget.Menu} event.menu The menu\n     * @param {Scheduler.model.EventModel} event.eventRecord Event record for which the menu was triggered\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record\n     * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used\n     * @param {HTMLElement} event.eventElement\n     */\n    @Output() onEventMenuShow: any = new EventEmitter<((event: { source: Scheduler, menu: Menu, eventRecord: EventModel, resourceRecord: ResourceModel, assignmentRecord: AssignmentModel, eventElement: HTMLElement }) => void)|string>();\n    /**\n     * Fires when an event bar is mousedowned in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event mousedowned on.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mousedowned on if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseDown: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when cursor enters an event bar in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseEnter: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when cursor leaves an event bar in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseLeave: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when an event bar is mouseouted in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event mouseouted.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseouted if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseOut: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when an event bar is mouseovered in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event mouseovered.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseovered if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseOver: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when an event bar is mouseupped in any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement The UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event mouseupped.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource mouseupped if the UI includes a resource.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onEventMouseUp: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Fires when a day spanning event is found, and the date to which its encapsulating event bar\n     * extends has been calculated.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-eventPropagate)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Date} event.eventEndDate The end date for which to calculate the propagate end date.\n     * @param {Date} event.propagateEndDate The system-calculated end point of the event bar.\n     * @param {boolean} event.isAllDay `true` if the event is an all day event, or spans multiple days.\n     * @param {boolean} event.isOverflow `true` if this is being called as part of further propagation.\n     * @param {boolean} event.overflows `true` if the event extends into future cells.\n     * @param {Scheduler.model.EventModel} event.eventRecord The event record being propagated.\n     * @param {Date} event.date The date from which the event is being propagated.\n     */\n    @Output() onEventPropagate: any = new EventEmitter<((event: { source: CalendarView, eventEndDate: Date, propagateEndDate: Date, isAllDay: boolean, isOverflow: boolean, overflows: boolean, eventRecord: EventModel, date: Date }) => void)|string>();\n    /**\n     * Fires when a Panel is expanded using the [collapsible](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-collapsible) setting.\n     * @param {object} event Event object\n     * @param {Core.widget.Panel} event.source This Panel.\n     */\n    @Output() onExpand: any = new EventEmitter<((event: { source: Panel }) => void)|string>();\n    /**\n     * Fired when focus enters this Widget.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source This Widget\n     * @param {HTMLElement} event.fromElement The element which lost focus.\n     * @param {HTMLElement} event.toElement The element which gained focus.\n     * @param {Core.widget.Widget} event.fromWidget The widget which lost focus.\n     * @param {Core.widget.Widget} event.toWidget The widget which gained focus.\n     * @param {boolean} event.backwards `true` if the `toElement` is before the `fromElement` in document order.\n     */\n    @Output() onFocusIn: any = new EventEmitter<((event: { source: Widget, fromElement: HTMLElement, toElement: HTMLElement, fromWidget: Widget, toWidget: Widget, backwards: boolean }) => void)|string>();\n    /**\n     * Fired when focus exits this Widget's ownership tree. This is different from a `blur` event.\n     * focus moving from within this Widget's ownership tree, even if there are floating widgets\n     * will not trigger this event. This is when focus exits this widget completely.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source This Widget\n     * @param {HTMLElement} event.fromElement The element which lost focus.\n     * @param {HTMLElement} event.toElement The element which gained focus.\n     * @param {Core.widget.Widget} event.fromWidget The widget which lost focus.\n     * @param {Core.widget.Widget} event.toWidget The widget which gained focus.\n     * @param {boolean} event.backwards `true` if the `toElement` is before the `fromElement` in document order.\n     */\n    @Output() onFocusOut: any = new EventEmitter<((event: { source: Widget, fromElement: HTMLElement, toElement: HTMLElement, fromWidget: Widget, toWidget: Widget, backwards: boolean }) => void)|string>();\n    /**\n     * Triggered after a widget was hidden\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget\n     */\n    @Output() onHide: any = new EventEmitter<((event: { source: Widget }) => void)|string>();\n    /**\n     * Fires when the [LoadOnDemand](https://bryntum.com/products/calendar/docs/api/Calendar/feature/LoadOnDemand) feature detects that a request\n     * for data from the server has failed.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-loadOnDemandFail)\n     * @param {object} event Event object\n     * @param {Response} event.rawResponse The HTTP `fetch` response object.\n     * @param {object} event.request The CrudManager load data block.\n     * @param {object} event.response The decoded JSON response.\n     */\n    @Output() onLoadOnDemandFail: any = new EventEmitter<((event: { rawResponse: any, request: object, response: object }) => void)|string>();\n    /**\n     * Fires when a month name header in a [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView) or a [MonthGrid](#Calendar/widget/MonthGrid) is clicked\n     * or activated by the <kbd>ENTER</kbd> key.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-monthNameClick)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {number} event.month The month index *(zero based)* clicked on.\n     * @param {Date} event.date The date of the first of the month clicked on.\n     */\n    @Output() onMonthNameClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, month: number, date: Date }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * Fired when a user gesture causes the active item to change.\n     * @param {object} event Event object\n     * @param {Event} event.event The browser event which instigated navigation. May be a click or key or focus event.\n     * @param {HTMLElement,null} event.item The newly active item, or `null` if focus moved out.\n     * @param {HTMLElement,null} event.oldItem The previously active item, or `null` if focus is moving in.\n     */\n    @Output() onNavigate: any = new EventEmitter<((event: { event: Event, item: HTMLElement|null, oldItem: HTMLElement|null }) => void)|string>();\n    /**\n     * Triggered when a widget which had been in a non-visible state for any reason\n     * achieves visibility.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-paint)\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget being painted.\n     * @param {boolean} event.firstPaint `true` if this is the first paint.\n     */\n    @Output() onPaint: any = new EventEmitter<((event: { source: Widget, firstPaint: boolean }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler after a paste action is performed.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Owner scheduler\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The pasted event records\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The pasted assignment records\n     * @param {Scheduler.model.EventModel[]} event.pastedEventRecords (DEPRECATED) Use eventRecords instead\n     * @param {Scheduler.model.EventModel[]} event.originalEventRecords The original copied event records\n     * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The original copied assignment records\n     * @param {Date} event.date date Pasted to this date\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record\n     * @param {boolean} event.isCut `true` if this is a cut action\n     * @param {string} event.entityName 'event' to distinguish this event from other paste events\n     */\n    @Output() onPaste: any = new EventEmitter<((event: { source: Scheduler, eventRecords: EventModel[], assignmentRecords: AssignmentModel[], pastedEventRecords: EventModel[], originalEventRecords: EventModel[], originalAssignmentRecords: AssignmentModel[], date: Date, resourceRecord: ResourceModel, isCut: boolean, entityName: string }) => void)|string>();\n    /**\n     * Fires on the owning Scheduler if a paste action is not allowed. Depending on if the EventStore is using\n     * [singleAssignment](https://bryntum.com/products/calendar/docs/api/Scheduler/data/EventStore#config-singleAssignment) or the configuration of\n     * [copyPasteAction](https://bryntum.com/products/calendar/docs/api/Scheduler/feature/EventCopyPaste#config-copyPasteAction), either the `eventRecords` or the `assignmentRecords` param will be populated\n     * with record copies.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Owner scheduler\n     * @param {Scheduler.model.EventModel[]} event.eventRecords The event records about to be pasted\n     * @param {Scheduler.model.AssignmentModel[]} event.assignmentRecords The assignment records about to be pasted\n     * @param {Scheduler.model.EventModel[]} event.originalEventRecords The event records that were copied\n     * @param {Scheduler.model.AssignmentModel[]} event.originalAssignmentRecords The assignment records that were copied\n     * @param {Date} event.date The paste date\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The target resource record\n     * @param {boolean} event.isCut `true` if this is a cut action\n     * @param {string} event.entityName 'event' to distinguish this event from other `pasteNotAllowed` events\n     * @param {'overlappingEvents','resourceReadOnly'} event.reason A string id to use for displaying an error message to the user.\n     */\n    @Output() onPasteNotAllowed: any = new EventEmitter<((event: { source: Scheduler, eventRecords: EventModel[], assignmentRecords: AssignmentModel[], originalEventRecords: EventModel[], originalAssignmentRecords: AssignmentModel[], date: Date, resourceRecord: ResourceModel, isCut: boolean, entityName: string, reason: 'overlappingEvents'|'resourceReadOnly' }) => void)|string>();\n    /**\n     * Fired when a Widget's read only state is toggled\n     * @param {object} event Event object\n     * @param {boolean} event.readOnly Read only or not\n     */\n    @Output() onReadOnly: any = new EventEmitter<((event: { readOnly: boolean }) => void)|string>();\n    /**\n     * This event is fired after a widget's elements have been synchronized due to a direct or indirect call\n     * to [recompose](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#function-recompose), if this results in some change to the widget's rendered DOM elements.\n     */\n    @Output() onRecompose: any = new EventEmitter<(() => void)|string>();\n    /**\n     * Fires when one of the views in this Calendar refreshes.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which refreshed.\n     */\n    @Output() onRefresh: any = new EventEmitter<((event: { source: CalendarView }) => void)|string>();\n    /**\n     * Fired when the encapsulating element of a Widget resizes *only when [monitorResize](https://bryntum.com/products/calendar/docs/api/Core/widget/Widget#config-monitorResize) is `true`*.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source This Widget\n     * @param {number} event.width The new width\n     * @param {number} event.height The new height\n     * @param {number} event.oldWidth The old width\n     * @param {number} event.oldHeight The old height\n     */\n    @Output() onResize: any = new EventEmitter<((event: { source: Widget, width: number, height: number, oldWidth: number, oldHeight: number }) => void)|string>();\n    /**\n     * Fires when a click event is received by a view which supports resources.\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-resourceClick)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date of the UI element which contains the event.\n     * @param {HTMLElement} event.eventElement *If* an event was interacted with, the UI element which represents the event.\n     * @param {Scheduler.model.EventModel} event.eventRecord *If* an event was interacted with.\n     * @param {HTMLElement} event.resourceElement The UI element which encapsulates the resource.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the target element.\n     * @param {boolean} event.fromOverflowPopup `true` if the interaction was through the source view's [overflowPopup](https://bryntum.com/products/calendar/docs/api/Calendar/widget/mixin/DayCellRenderer#property-overflowPopup).\n     */\n    @Output() onResourceClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, eventElement: HTMLElement, eventRecord: EventModel, resourceElement: HTMLElement, resourceRecord: ResourceModel, fromOverflowPopup: boolean }) => void)|string>();\n    /**\n     * Triggered when a new [responsiveState](https://bryntum.com/products/calendar/docs/api/Core/widget/mixin/Responsive#config-responsiveState) is applied.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget whose `responsiveState` has changed\n     * @param {string} event.state The new value for the widget's `responsiveState`\n     * @param {string} event.oldState The previous value for the widget's `responsiveState`\n     */\n    @Output() onResponsiveStateChange: any = new EventEmitter<((event: { source: Widget, state: string, oldState: string }) => void)|string>();\n    /**\n     * Fires when a click made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fires when a context menu made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleContextMenu: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fires when a dblclick made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date double clicked on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleDblClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * This event fires on the owning Scheduler or Gantt widget before the context menu is shown for the schedule.\n     * Allows manipulation of the items to show in the same way as in `processItems`. Returning `false` from a listener\n     * prevents the menu from being shown.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Record<string, MenuItemEntry>} event.items Menu item configs\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord Resource record\n     * @param {Date} event.date Clicked date, rounded according to viewPreset's settings\n     * @param {Scheduler.model.AssignmentModel} event.assignmentRecord Assignment record, if assignments are used\n     * @param {HTMLElement} event.eventElement\n     */\n    @Output() onScheduleMenuBeforeShow: any = new EventEmitter<((event: { source: Scheduler, items: Record<string, MenuItemEntry>, resourceRecord: ResourceModel, date: Date, assignmentRecord: AssignmentModel, eventElement: HTMLElement }) => Promise<boolean>|boolean|void)|string>();\n    /**\n     * This event fires on the owning Scheduler or Gantt widget when an item is selected in the context menu.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Core.widget.MenuItem} event.item\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord\n     * @param {Date} event.date Clicked date, rounded according to viewPreset's settings\n     * @param {HTMLElement} event.element\n     */\n    @Output() onScheduleMenuItem: any = new EventEmitter<((event: { source: Scheduler, item: MenuItem, resourceRecord: ResourceModel, date: Date, element: HTMLElement }) => void)|string>();\n    /**\n     * This event fires on the owning Scheduler or Gantt widget after showing the context menu for the schedule.\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source\n     * @param {Record<string, MenuItemEntry>} event.items Menu item configs\n     * @param {Core.widget.Menu} event.menu The menu\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord\n     * @param {Date} event.date Clicked date, rounded according to viewPreset's settings\n     * @param {HTMLElement} event.targetElement\n     */\n    @Output() onScheduleMenuShow: any = new EventEmitter<((event: { source: Scheduler, items: Record<string, MenuItemEntry>, menu: Menu, resourceRecord: ResourceModel, date: Date, targetElement: HTMLElement }) => void)|string>();\n    /**\n     * Fires when a mousedown made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date mousedowned on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleMouseDown: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fires when a mouseout made it's way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date mouseouted. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleMouseOut: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fires when a mouseover made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date mouseovered. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleMouseOver: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fires when a mouseup made its way through to an empty part of any view.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {Date} event.date The date mouseupped on. _Note that in a [DayView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView), this will include granular time information. For other views, this is the *start* of the date.\n     * @param {Scheduler.model.ResourceModel} event.resourceRecord The resource associated with the view if any. Only [ResourceView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/ResourceView) or a [DayResourceView](#Calendar/widget/DayResourceView) will include this.\n     */\n    @Output() onScheduleMouseUp: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, date: Date, resourceRecord: ResourceModel }) => void)|string>();\n    /**\n     * Fired any time there is a change to the events selected in the Calendar.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source The Calendar instance.\n     * @param {'select','deselect','update','clear'} event.action One of the actions 'select', 'deselect', 'update', 'clear'\n     * @param {Scheduler.model.EventModel[]} event.selected An array of the Events added to the selection.\n     * @param {Scheduler.model.EventModel[]} event.deselected An array of the Event removed from the selection.\n     * @param {Scheduler.model.EventModel[]} event.selection The new selection.\n     */\n    @Output() onSelectionChange: any = new EventEmitter<((event: { source: Calendar, action: 'select'|'deselect'|'update'|'clear', selected: EventModel[], deselected: EventModel[], selection: EventModel[] }) => void)|string>();\n    /**\n     * Triggered after a widget is shown.\n     * @param {object} event Event object\n     * @param {Core.widget.Widget} event.source The widget\n     */\n    @Output() onShow: any = new EventEmitter<((event: { source: Widget }) => void)|string>();\n    /**\n     * Fired when the sidebar is collapsed either through the UI or programatically.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance\n     */\n    @Output() onSidebarCollapse: any = new EventEmitter<((event: { source: Calendar }) => void)|string>();\n    /**\n     * Fired when the sidebar is expanded either through the UI or programatically.\n     * @param {object} event Event object\n     * @param {Calendar.view.Calendar} event.source This Calendar instance\n     */\n    @Output() onSidebarExpand: any = new EventEmitter<((event: { source: Calendar }) => void)|string>();\n    /**\n     * Fired when a time axis of a DayView or WeekView is clicked on. If the handler returns\n     * `false` the current pointer event is not processed further.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The triggering DOM event.\n     * @param {Date} event.preciseTime The exact date and time at the clicked position\n     * @param {Date} event.time The date and time at the clicked position snapped according to the [increment](https://bryntum.com/products/calendar/docs/api/Calendar/widget/DayView#config-increment) and [timeSnapType](#Calendar/widget/DayView#config-timeSnapType)\n     */\n    @Output() onTimeAxisClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, preciseTime: Date, time: Date }) => void)|string>();\n    /**\n     * Fired on the owning Scheduler or Gantt widget when a click happens on a time range header element\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Scheduler instance\n     * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record\n     * @param {MouseEvent} event.domEvent Browser event\n     */\n    @Output() onTimeRangeHeaderClick: any = new EventEmitter<((event: { source: Scheduler, timeRangeRecord: TimeSpan, domEvent: MouseEvent }) => void)|string>();\n    /**\n     * Fired on the owning Scheduler or Gantt widget when a right click happens on a time range header element\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Scheduler instance\n     * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record\n     * @param {MouseEvent} event.domEvent Browser event\n     */\n    @Output() onTimeRangeHeaderContextMenu: any = new EventEmitter<((event: { source: Scheduler, timeRangeRecord: TimeSpan, domEvent: MouseEvent }) => void)|string>();\n    /**\n     * Fired on the owning Scheduler or Gantt widget when a double click happens on a time range header element\n     * @param {object} event Event object\n     * @param {Scheduler.view.Scheduler} event.source Scheduler instance\n     * @param {Scheduler.model.TimeSpan} event.timeRangeRecord The record\n     * @param {MouseEvent} event.domEvent Browser event\n     */\n    @Output() onTimeRangeHeaderDblClick: any = new EventEmitter<((event: { source: Scheduler, timeRangeRecord: TimeSpan, domEvent: MouseEvent }) => void)|string>();\n    /**\n     * A header [tool](https://bryntum.com/products/calendar/docs/api/Core/widget/Panel#config-tools) has been clicked.\n     * @param {object} event Event object\n     * @param {Core.widget.Tool} event.source This Panel.\n     * @param {Core.widget.Tool} event.tool The tool which is being clicked.\n     */\n    @Output() onToolClick: any = new EventEmitter<((event: { source: Tool, tool: Tool }) => void)|string>();\n    /**\n     * Fires when one of the child views is painted. That is when it becomes visible.\n     * Note that due to the slide-in animation, while the view is visible, it will not\n     * yet be in its final position.\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The widget being painted\n     * @param {boolean} event.firstPaint `true` if this is the first paint\n     */\n    @Output() onViewPaint: any = new EventEmitter<((event: { source: CalendarView, firstPaint: boolean }) => void)|string>();\n    /**\n     * Fires when a week number is clicked or activated by the <kbd>ENTER</kbd> key. This will include the week number cells of a\n     * [YearView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/YearView), the week number in the first cell\n     * in each row of a [MonthView](https://bryntum.com/products/calendar/docs/api/Calendar/widget/MonthView)\n     * ...\n     * [View online docs...](https://bryntum.com/products/calendar/docs/api/Calendar/view/Calendar#event-weekNumberClick)\n     * @param {object} event Event object\n     * @param {CalendarView} event.source The view which triggered the event.\n     * @param {Event} event.domEvent The initiating DOM event.\n     * @param {number[]} event.week The `[year, week]` clicked on.\n     * @param {Date} event.date The date clicked on.\n     */\n    @Output() onWeekNumberClick: any = new EventEmitter<((event: { source: CalendarView, domEvent: Event, week: number[], date: Date }) => Promise<boolean>|boolean|void)|string>();\n\n    /**\n     * Create and append the underlying widget\n     */\n    ngOnInit(): void {\n        const\n            me = this,\n            {\n                elementRef,\n                bryntumConfig\n            } = me,\n            {\n                instanceClass,\n                instanceName,\n                bryntumConfigs,\n                bryntumEvents\n            } = BryntumCalendarComponent;\n\n        bryntumConfigs.filter(prop => prop in this).forEach(prop => {\n            // @ts-ignore\n            WrapperHelper.applyPropValue(bryntumConfig, prop, this[prop]);\n            if (['features', 'config'].includes(prop)) {\n                WrapperHelper.devWarningConfigProp(instanceName, prop);\n            }\n        });\n        // @ts-ignore\n        bryntumEvents.filter(event => this[event] && this[event].observers.length > 0).forEach(event => {\n            const\n                uncapitalize = (str: string) => str.charAt(0).toLowerCase() + str.slice(1),\n                eventName = (str: string) => uncapitalize(str.slice(2));\n\n            // @ts-ignore\n            bryntumConfig.listeners[eventName(event)] = e => {\n                // @ts-ignore\n                me[event].emit(e);\n                // EventEmitter does not return values in the normal way, work around it by setting `returnValue` flag\n                // in Angular listeners\n                return e.returnValue;\n            };\n        });\n\n        // If component has no container specified in config then use adopt to Wrapper's element\n        const\n            containerParam = [\n                'adopt',\n                'appendTo',\n                'insertAfter',\n                'insertBefore'\n                // @ts-ignore\n            ].find(prop => bryntumConfig[prop]);\n        if (!containerParam) {\n            if (instanceName === 'Button' || elementRef.nativeElement.getRootNode() instanceof ShadowRoot) {\n                // Button should always be <a> or <button> inside owner element\n                bryntumConfig.appendTo = elementRef.nativeElement;\n            }\n            else {\n                bryntumConfig.adopt = elementRef.nativeElement;\n            }\n        }\n        else {\n            WrapperHelper.devWarningContainer(instanceName, containerParam);\n        }\n\n        // @ts-ignore\n        me.instance = instanceName === 'Widget' ? Widget.create(bryntumConfig) : new instanceClass(bryntumConfig);\n\n        // Backwards compatibility for gridInstance, schedulerInstance etc.\n        // @ts-ignore\n        me[StringHelper.uncapitalize(instanceName) + 'Instance'] = me.instance;\n        // \n    }\n\n    /**\n     * Watch for changes\n     * @param changes\n     */\n    ngOnChanges(changes: SimpleChanges): void {\n        const\n            { instance } = this,\n            { instanceName } = BryntumCalendarComponent;\n        if (!instance) {\n            return;\n        }\n        // Iterate over all changes\n        Object.entries(changes).forEach(([prop, change]) => {\n            const\n                newValue = (change as SimpleChange).currentValue,\n                { instance } = this,\n                { bryntumConfigsOnly, bryntumProps } = BryntumCalendarComponent;\n            if (bryntumProps.includes(prop)) {\n                WrapperHelper.applyPropValue(instance, prop, newValue, false);\n                if (bryntumConfigsOnly.includes(prop)) {\n                    WrapperHelper.devWarningUpdateProp(instanceName, prop);\n                }\n            }\n        });\n    }\n\n    /**\n     * Destroy the component\n     */\n    ngOnDestroy(): void {\n        // @ts-ignore\n        if (this.instance && this.instance.destroy) {\n            this.instance.destroy();\n        }\n    }\n}\n"]}