@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.
- package/README.md +44 -0
- package/bryntum-calendar-angular-thin.d.ts +5 -0
- package/bundles/bryntum-calendar-angular-thin.umd.js +22195 -0
- package/bundles/bryntum-calendar-angular-thin.umd.js.map +1 -0
- package/esm2015/bryntum-calendar-angular-thin.js +5 -0
- package/esm2015/lib/bryntum-agenda-view.component.js +2503 -0
- package/esm2015/lib/bryntum-calendar-date-picker.component.js +1045 -0
- package/esm2015/lib/bryntum-calendar-project-model.component.js +369 -0
- package/esm2015/lib/bryntum-calendar.component.js +2355 -0
- package/esm2015/lib/bryntum-day-agenda-view.component.js +1338 -0
- package/esm2015/lib/bryntum-day-resource-view.component.js +1347 -0
- package/esm2015/lib/bryntum-day-view.component.js +1323 -0
- package/esm2015/lib/bryntum-event-list.component.js +2453 -0
- package/esm2015/lib/bryntum-mode-selector.component.js +702 -0
- package/esm2015/lib/bryntum-month-agenda-view.component.js +1201 -0
- package/esm2015/lib/bryntum-month-grid.component.js +1262 -0
- package/esm2015/lib/bryntum-month-view.component.js +1337 -0
- package/esm2015/lib/bryntum-range-menu.component.js +884 -0
- package/esm2015/lib/bryntum-resource-view.component.js +1068 -0
- package/esm2015/lib/bryntum-week-view.component.js +1323 -0
- package/esm2015/lib/bryntum-year-view.component.js +1163 -0
- package/esm2015/lib/calendar.module.js +99 -0
- package/esm2015/lib/wrapper.helper.js +74 -0
- package/esm2015/public-api.js +21 -0
- package/fesm2015/bryntum-calendar-angular-thin.js +21714 -0
- package/fesm2015/bryntum-calendar-angular-thin.js.map +1 -0
- package/lib/bryntum-agenda-view.component.d.ts +2953 -0
- package/lib/bryntum-calendar-date-picker.component.d.ts +1525 -0
- package/lib/bryntum-calendar-project-model.component.d.ts +399 -0
- package/lib/bryntum-calendar.component.d.ts +2577 -0
- package/lib/bryntum-day-agenda-view.component.d.ts +1960 -0
- package/lib/bryntum-day-resource-view.component.d.ts +2025 -0
- package/lib/bryntum-day-view.component.d.ts +1980 -0
- package/lib/bryntum-event-list.component.d.ts +2888 -0
- package/lib/bryntum-mode-selector.component.d.ts +851 -0
- package/lib/bryntum-month-agenda-view.component.d.ts +1765 -0
- package/lib/bryntum-month-grid.component.d.ts +1731 -0
- package/lib/bryntum-month-view.component.d.ts +1897 -0
- package/lib/bryntum-range-menu.component.d.ts +1130 -0
- package/lib/bryntum-resource-view.component.d.ts +1512 -0
- package/lib/bryntum-week-view.component.d.ts +1980 -0
- package/lib/bryntum-year-view.component.d.ts +1661 -0
- package/lib/calendar.module.d.ts +22 -0
- package/lib/wrapper.helper.d.ts +26 -0
- package/package.json +33 -0
- 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":"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","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"]}
|