@colijnit/corecomponents_v12 255.1.11 → 255.1.13

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (32) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +376 -17
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.metadata.json +1 -1
  4. package/esm2015/lib/components/calendar/calendar-template.component.js +6 -4
  5. package/esm2015/lib/components/hour-scheduling/components/hour-scheduling-test-object/hour-scheduling-test-object.component.js +2 -2
  6. package/esm2015/lib/components/hour-scheduling/hour-scheduling.component.js +24 -12
  7. package/esm2015/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component.js +55 -0
  8. package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.component.js +316 -0
  9. package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.module.js +25 -0
  10. package/esm2015/lib/components/input-number-picker/input-number-picker.component.js +2 -1
  11. package/esm2015/lib/core/enum/core-components-icon.enum.js +1 -1
  12. package/esm2015/lib/core/enum/filterItem-mode.enum.js +3 -3
  13. package/esm2015/public-api.js +5 -1
  14. package/fesm2015/colijnit-corecomponents_v12.js +420 -17
  15. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  16. package/lib/components/hour-scheduling/components/hour-scheduling-test-object/style/_layout.scss +2 -0
  17. package/lib/components/hour-scheduling/components/hour-scheduling-test-object/style/_theme.scss +2 -2
  18. package/lib/components/hour-scheduling/hour-scheduling.component.d.ts +4 -3
  19. package/lib/components/hour-scheduling/style/_layout.scss +2 -0
  20. package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component.d.ts +10 -0
  21. package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/style/_layout.scss +4 -0
  22. package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/style/_material-definition.scss +0 -0
  23. package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/style/_theme.scss +4 -0
  24. package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/style/material.scss +4 -0
  25. package/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.component.d.ts +76 -0
  26. package/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.module.d.ts +2 -0
  27. package/lib/components/hour-scheduling-expandable/style/_layout.scss +103 -0
  28. package/lib/components/hour-scheduling-expandable/style/_material-definition.scss +0 -0
  29. package/lib/components/hour-scheduling-expandable/style/_theme.scss +4 -0
  30. package/lib/components/hour-scheduling-expandable/style/material.scss +4 -0
  31. package/package.json +1 -1
  32. package/public-api.d.ts +4 -0
@@ -0,0 +1,316 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostBinding, HostListener, Input, Output, ViewEncapsulation, } from '@angular/core';
2
+ import { DatePipe } from '@angular/common';
3
+ export class HourSchedulingExpandableComponent {
4
+ constructor(cdRef, datePipe, eRef) {
5
+ this.cdRef = cdRef;
6
+ this.datePipe = datePipe;
7
+ this.eRef = eRef;
8
+ this.hourLabels = [];
9
+ this.scheduledObjects = [];
10
+ this.resizing = false;
11
+ this.currentResizingObject = null;
12
+ this.currentDraggingObject = null;
13
+ this.MIN_HEIGHT = 30;
14
+ this._schedule = {};
15
+ this.timeChangeEvent = new EventEmitter();
16
+ this.newObjectPlanEvent = new EventEmitter();
17
+ this.showClass = true;
18
+ }
19
+ set schedule(value) {
20
+ if (value && value !== this._schedule) {
21
+ this.renderObjects();
22
+ }
23
+ this._schedule = value;
24
+ }
25
+ get schedule() {
26
+ return this._schedule;
27
+ }
28
+ onResize(event) {
29
+ event.target.innerWidth;
30
+ }
31
+ clickOut(event) {
32
+ if (!this.eRef.nativeElement.contains(event.target)) {
33
+ this.handleDeselectAll();
34
+ }
35
+ }
36
+ ngOnInit() {
37
+ this.generateTimeBlocks();
38
+ if (this.schedule) {
39
+ this.renderObjects();
40
+ }
41
+ this._calculateSchedulingObjectProperties();
42
+ }
43
+ // Calculate properties for each scheduled object to determine resizer visibility
44
+ _calculateSchedulingObjectProperties() {
45
+ const scheduleStart = this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]);
46
+ const scheduleEnd = this.convertDateToEuropean(this.schedule[this.childProp][this.endTimeProp]);
47
+ this.scheduledObjects.forEach(obj => {
48
+ obj.showTopResizer = this.timeDifference(scheduleStart, obj.start) > 0; // Show top resizer if the start time differs
49
+ obj.showBottomResizer = this.timeDifference(scheduleEnd, obj.end) > 0; // Show bottom resizer if the end time differs
50
+ });
51
+ }
52
+ // Find the next object in the scheduledObjects list
53
+ _findNextObject(currentObject) {
54
+ const currentIndex = this.scheduledObjects.indexOf(currentObject);
55
+ if (currentIndex >= 0 && currentIndex < this.scheduledObjects.length - 1) {
56
+ return this.scheduledObjects[currentIndex + 1]; // The next object in the list
57
+ }
58
+ return null; // No next object (it's the last one)
59
+ }
60
+ // Find the previous object in the scheduledObjects list
61
+ _findPreviousObject(currentObject) {
62
+ const currentIndex = this.scheduledObjects.indexOf(currentObject);
63
+ if (currentIndex > 0) {
64
+ return this.scheduledObjects[currentIndex - 1]; // The previous object in the list
65
+ }
66
+ return null; // No previous object (it's the first one)
67
+ }
68
+ renderObjects() {
69
+ if (this.schedule) {
70
+ if (this.scheduledObjects.length > 1) {
71
+ this.scheduledObjects = [];
72
+ }
73
+ let objects = this.schedule[this.objectsProp];
74
+ let schedulingObjects = [];
75
+ if (objects && objects.length > 0) {
76
+ objects.forEach(object => {
77
+ let topDifference = this.timeDifference(this.schedule[this.childProp][this.startTimeProp], object[this.startTimeProp]);
78
+ schedulingObjects.push({
79
+ title: object['title'],
80
+ subTitle: object['subTitle'],
81
+ start: this.convertDateToEuropean(object[this.startTimeProp]),
82
+ end: this.convertDateToEuropean(object[this.endTimeProp]),
83
+ id: object[this.idProp],
84
+ height: this.timeDifference(object[this.startTimeProp], object[this.endTimeProp]),
85
+ top: topDifference,
86
+ selected: false
87
+ });
88
+ });
89
+ }
90
+ this.scheduledObjects = schedulingObjects;
91
+ }
92
+ }
93
+ onSelectBlock(obj) {
94
+ this.scheduledObjects.filter(obj => obj.selected).forEach(selectedObj => {
95
+ selectedObj.selected = false;
96
+ });
97
+ obj.selected = true;
98
+ this.currentResizingObject = obj;
99
+ }
100
+ onDragStartCustom(obj) {
101
+ this.currentDraggingObject = obj;
102
+ }
103
+ handleDrop(dragEvent, hour) {
104
+ if (this.currentDraggingObject) {
105
+ //The order was scheduled and needs to be moved
106
+ let start = this.currentDraggingObject.start;
107
+ let hourSplit = hour.split(":");
108
+ start.setHours(parseInt(hourSplit[0]));
109
+ start.setMinutes(parseInt(hourSplit[1]));
110
+ let scheduledObject = this.scheduledObjects.find(scheduledObject => scheduledObject.id === this.currentDraggingObject.id);
111
+ scheduledObject.start = start;
112
+ let originalObject = this.schedule[this.objectsProp].find((object) => object[this.idProp] === this.currentDraggingObject.id);
113
+ originalObject[this.startTimeProp] = start;
114
+ let end = this.addMinutes(originalObject[this.startTimeProp], this.currentDraggingObject.height);
115
+ originalObject[this.endTimeProp] = end;
116
+ scheduledObject.end = end;
117
+ scheduledObject.top = this.timeDifference(this.schedule[this.childProp][this.startTimeProp], scheduledObject.start);
118
+ scheduledObject.height = this.timeDifference(scheduledObject.start, scheduledObject.end);
119
+ this.timeChangeEvent.emit(originalObject);
120
+ this.currentDraggingObject = undefined;
121
+ }
122
+ else {
123
+ let parsed = this.tryParseJSONObject(dragEvent.dataTransfer.getData("text"));
124
+ if (!parsed) {
125
+ this.newObjectPlanEvent.emit({ currentHour: hour, data: parsed.toString() });
126
+ }
127
+ }
128
+ }
129
+ allowDrop(event, hour) {
130
+ event.preventDefault();
131
+ event.stopPropagation();
132
+ if (this.currentDraggingObject) {
133
+ let newStartDate = this.convertDateToEuropean(this.currentDraggingObject.start);
134
+ let hourSplit = hour.split(":");
135
+ newStartDate.setHours(parseInt(hourSplit[0]));
136
+ newStartDate.setHours(parseInt(hourSplit[1]));
137
+ if (this.scheduledObjects.find((scheduledObject) => scheduledObject.start === newStartDate)) {
138
+ return false;
139
+ }
140
+ else {
141
+ return true;
142
+ }
143
+ }
144
+ }
145
+ // Triggered when resizing starts
146
+ onResizeStart(event, obj, direction) {
147
+ this.resizing = true;
148
+ this.resizeDirection = direction;
149
+ this.currentResizingObject = obj;
150
+ this.initialY = event.clientY;
151
+ this.initialHeight = obj.height || 0;
152
+ this.initialTop = obj.top || 0;
153
+ // Listen to mousemove and mouseup events globally
154
+ document.addEventListener('mousemove', this.onResizing.bind(this));
155
+ document.addEventListener('mouseup', this.onResizeEnd.bind(this));
156
+ }
157
+ // Handle resizing with snapping to 30px increments and minimum height restriction
158
+ onResizing(event) {
159
+ if (!this.resizing || !this.currentResizingObject)
160
+ return;
161
+ const deltaY = event.clientY - this.initialY;
162
+ const snappedDeltaY = Math.round(deltaY / 30) * 30;
163
+ if (this.resizeDirection === 'bottom') {
164
+ const nextObject = this._findNextObject(this.currentResizingObject);
165
+ const maxHeight = nextObject ? nextObject.top - this.currentResizingObject.top : Infinity;
166
+ // Block expanding beyond the next object and shrinking below 30px
167
+ const newHeight = Math.max(this.initialHeight + snappedDeltaY, this.MIN_HEIGHT);
168
+ this.currentResizingObject.height = Math.min(newHeight, maxHeight);
169
+ }
170
+ else if (this.resizeDirection === 'top') {
171
+ const previousObject = this._findPreviousObject(this.currentResizingObject);
172
+ const minTop = previousObject ? previousObject.top + previousObject.height : 0;
173
+ const newHeight = Math.max(this.initialHeight - snappedDeltaY, this.MIN_HEIGHT);
174
+ const newTop = this.initialTop + (this.initialHeight - newHeight);
175
+ // Block moving above the previous object's bottom and shrinking below MIN_HEIGHT
176
+ if (newHeight >= this.MIN_HEIGHT && newTop >= minTop) {
177
+ this.currentResizingObject.top = newTop;
178
+ this.currentResizingObject.height = newHeight;
179
+ }
180
+ }
181
+ // Ensure change detection happens
182
+ this.cdRef.detectChanges();
183
+ }
184
+ // Triggered when resizing ends
185
+ onResizeEnd(event) {
186
+ let object = this.currentResizingObject;
187
+ if (object && object.selected) {
188
+ let originalObject = this.schedule[this.objectsProp].find((scheduledObject) => scheduledObject[this.idProp] === object.id);
189
+ if (originalObject) {
190
+ // Start date calculation first
191
+ originalObject[this.startTimeProp] = this.addMinutes(this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]), object.top);
192
+ // Then end date calculation based on the height of the object
193
+ originalObject[this.endTimeProp] = this.addMinutes(this.convertDateToEuropean(originalObject[this.startTimeProp]), object.height);
194
+ }
195
+ this.timeChangeEvent.emit(originalObject);
196
+ this.resizing = false;
197
+ this.currentResizingObject.selected = false;
198
+ this.currentResizingObject = null;
199
+ }
200
+ // Remove global event listeners
201
+ document.removeEventListener('mousemove', this.onResizing.bind(this));
202
+ document.removeEventListener('mouseup', this.onResizeEnd.bind(this));
203
+ }
204
+ timeDifference(date1, date2) {
205
+ let difference = this.convertDateToEuropean(date1).getTime() / 1000 - this.convertDateToEuropean(date2).getTime() / 1000;
206
+ return Math.abs(difference / 60);
207
+ }
208
+ generateTimeBlocks() {
209
+ let startUnix = !this.childProp ? this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.startTimeProp])) : this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]));
210
+ let endUnix = !this.childProp ? this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.endTimeProp])) : this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.childProp][this.endTimeProp]));
211
+ let interval = 60 * 60;
212
+ for (let hourCount = startUnix; hourCount <= endUnix; hourCount += interval) {
213
+ let hour = new Date(hourCount * 1000);
214
+ let hourString = `${hour.getHours()}:${hour.getMinutes() === 0 ? '00' : hour.getMinutes()}`;
215
+ this.hourLabels.push(hourString);
216
+ }
217
+ }
218
+ dateToUnixEpoch(date) {
219
+ return Math.floor(date.getTime()) / 1000;
220
+ }
221
+ addMinutes(date, minutes) {
222
+ return new Date(date.getTime() + minutes * 60000);
223
+ }
224
+ tryParseJSONObject(jsonString) {
225
+ try {
226
+ let o = JSON.parse(jsonString);
227
+ if (o && typeof o === "object") {
228
+ return o;
229
+ }
230
+ }
231
+ catch (e) {
232
+ }
233
+ return false;
234
+ }
235
+ addHalfHour(hour) {
236
+ let split = hour.split(":");
237
+ split[1] = "30";
238
+ return split.join(':');
239
+ }
240
+ convertTZ(date, tzString) {
241
+ return new Date((typeof date === "string" ? new Date(date) : date).toLocaleString("en-US", { timeZone: tzString }));
242
+ }
243
+ convertDateToEuropean(date) {
244
+ return this.convertTZ(date, 'Europe/Amsterdam');
245
+ }
246
+ handleDeselectAll() {
247
+ this.scheduledObjects.forEach((scheduledObject) => {
248
+ if (scheduledObject.selected) {
249
+ scheduledObject.selected = false;
250
+ }
251
+ });
252
+ }
253
+ }
254
+ HourSchedulingExpandableComponent.decorators = [
255
+ { type: Component, args: [{
256
+ selector: 'co-hour-scheduling-expandable',
257
+ template: `
258
+ <div class="wrapper">
259
+ <div class="time-block" *ngFor="let hour of hourLabels">
260
+ <div class="hour-label"><span [textContent]="hour"></span></div>
261
+
262
+ <div class="object-display">
263
+ <div class="first-half-hour object-half" (dragover)="allowDrop($event, hour)"
264
+ (drop)="handleDrop($event, hour)">
265
+ </div>
266
+
267
+ <div class="second-half-hour object-half" (dragover)="allowDrop($event, addHalfHour(hour))"
268
+ (drop)="handleDrop($event, addHalfHour(hour))">
269
+ </div>
270
+ </div>
271
+ </div>
272
+
273
+ <div class="scheduled-objects" >
274
+ <ng-container>
275
+ <ng-template
276
+ [ngTemplateOutlet]="customTemplate"
277
+ [ngTemplateOutletContext]="{
278
+ objects: scheduledObjects,
279
+ onSelectBlock: this.onSelectBlock.bind(this),
280
+ onResizeStart: this.onResizeStart.bind(this),
281
+ onDragStartCustom: this.onDragStartCustom.bind(this)
282
+
283
+ }"
284
+ >
285
+ <ng-content></ng-content>
286
+ </ng-template>
287
+ </ng-container>
288
+ </div>
289
+
290
+ </div>
291
+
292
+ `,
293
+ changeDetection: ChangeDetectionStrategy.OnPush,
294
+ encapsulation: ViewEncapsulation.None
295
+ },] }
296
+ ];
297
+ HourSchedulingExpandableComponent.ctorParameters = () => [
298
+ { type: ChangeDetectorRef },
299
+ { type: DatePipe },
300
+ { type: ElementRef }
301
+ ];
302
+ HourSchedulingExpandableComponent.propDecorators = {
303
+ schedule: [{ type: Input }],
304
+ startTimeProp: [{ type: Input }],
305
+ endTimeProp: [{ type: Input }],
306
+ objectsProp: [{ type: Input }],
307
+ childProp: [{ type: Input }],
308
+ customTemplate: [{ type: Input }],
309
+ idProp: [{ type: Input }],
310
+ timeChangeEvent: [{ type: Output }],
311
+ newObjectPlanEvent: [{ type: Output }],
312
+ showClass: [{ type: HostBinding, args: ['class.co-hour-scheduling-expandable',] }],
313
+ onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }],
314
+ clickOut: [{ type: HostListener, args: ['document:click', ['$event'],] }]
315
+ };
316
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hour-scheduling-expandable.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component, ElementRef,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  TemplateRef,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport {DatePipe} from '@angular/common';\r\n\r\ninterface SchedulingObject {\r\n  start: Date;\r\n  end: Date;\r\n  title?: string;\r\n  subTitle?: string;\r\n  height?: number;\r\n  top?: number;\r\n  id: number | string;\r\n  selected: boolean;\r\n  showTopResizer?: boolean;\r\n  showBottomResizer?: boolean;\r\n\r\n\r\n  [key: string]: any; // Allows dynamic properties including unique identifiers\r\n}\r\n\r\n@Component({\r\n  selector: 'co-hour-scheduling-expandable',\r\n  template: `\r\n    <div class=\"wrapper\">\r\n      <div class=\"time-block\" *ngFor=\"let hour of hourLabels\">\r\n        <div class=\"hour-label\"><span [textContent]=\"hour\"></span></div>\r\n\r\n        <div class=\"object-display\">\r\n          <div class=\"first-half-hour object-half\" (dragover)=\"allowDrop($event, hour)\"\r\n               (drop)=\"handleDrop($event, hour)\">\r\n          </div>\r\n\r\n          <div class=\"second-half-hour object-half\" (dragover)=\"allowDrop($event, addHalfHour(hour))\"\r\n               (drop)=\"handleDrop($event, addHalfHour(hour))\">\r\n          </div>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"scheduled-objects\" >\r\n        <ng-container>\r\n          <ng-template\r\n            [ngTemplateOutlet]=\"customTemplate\"\r\n            [ngTemplateOutletContext]=\"{\r\n              objects: scheduledObjects,\r\n              onSelectBlock: this.onSelectBlock.bind(this),\r\n              onResizeStart: this.onResizeStart.bind(this),\r\n              onDragStartCustom: this.onDragStartCustom.bind(this)\r\n\r\n            }\"\r\n          >\r\n            <ng-content></ng-content>\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n\r\n    </div>\r\n\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HourSchedulingExpandableComponent implements OnInit {\r\n\r\n  public hourLabels: string[] = [];\r\n  public scheduledObjects: SchedulingObject[] = [];\r\n\r\n\r\n  private resizing: boolean = false;\r\n  private resizeDirection: 'top' | 'bottom';\r\n  private initialY: number;\r\n  private initialHeight: number;\r\n  private initialTop: number;\r\n  private currentResizingObject: SchedulingObject | null = null;\r\n  private currentDraggingObject: SchedulingObject | null = null;\r\n  private MIN_HEIGHT = 30;\r\n  private _schedule: Object = {};\r\n\r\n\r\n  @Input() public set schedule( value: Object) {\r\n    if(value && value !== this._schedule) {\r\n      this.renderObjects();\r\n    }\r\n    this._schedule = value;\r\n  }\r\n\r\n  public get schedule(): Object {\r\n    return this._schedule;\r\n  }\r\n\r\n\r\n  @Input() public startTimeProp: string;\r\n  @Input() public endTimeProp: string;\r\n  @Input() public objectsProp: string;\r\n  @Input() public childProp: string;\r\n  @Input() public customTemplate: TemplateRef<any>;\r\n  @Input() public idProp: string;  // Input for unique identifier property\r\n\r\n  @Output() public timeChangeEvent: EventEmitter<Object> = new EventEmitter<Object>();\r\n  @Output() public newObjectPlanEvent: EventEmitter<{ currentHour: string, data: string }> = new EventEmitter<{\r\n    currentHour: string,\r\n    data: string\r\n  }>();\r\n\r\n  @HostBinding('class.co-hour-scheduling-expandable')\r\n  public showClass: boolean = true;\r\n\r\n  @HostListener('window:resize', ['$event'])\r\n  public onResize(event: { target: { innerWidth: any; }; }) {\r\n    event.target.innerWidth;\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  public clickOut(event: { target: any; }) {\r\n    if(!this.eRef.nativeElement.contains(event.target)) {\r\n      this.handleDeselectAll();\r\n    }\r\n  }\r\n\r\n\r\n  constructor(\r\n    private cdRef: ChangeDetectorRef,\r\n    private datePipe: DatePipe,\r\n    private eRef: ElementRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.generateTimeBlocks();\r\n    if(this.schedule) {\r\n      this.renderObjects();\r\n    }\r\n\r\n\r\n    this._calculateSchedulingObjectProperties();\r\n  }\r\n\r\n  // Calculate properties for each scheduled object to determine resizer visibility\r\n  private _calculateSchedulingObjectProperties() {\r\n    const scheduleStart = this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]);\r\n    const scheduleEnd = this.convertDateToEuropean(this.schedule[this.childProp][this.endTimeProp]);\r\n\r\n    this.scheduledObjects.forEach(obj => {\r\n      obj.showTopResizer = this.timeDifference(scheduleStart, obj.start) > 0; // Show top resizer if the start time differs\r\n      obj.showBottomResizer = this.timeDifference(scheduleEnd, obj.end) > 0; // Show bottom resizer if the end time differs\r\n    });\r\n  }\r\n\r\n  // Find the next object in the scheduledObjects list\r\n  private _findNextObject(currentObject: SchedulingObject): SchedulingObject | null {\r\n    const currentIndex = this.scheduledObjects.indexOf(currentObject);\r\n    if (currentIndex >= 0 && currentIndex < this.scheduledObjects.length - 1) {\r\n      return this.scheduledObjects[currentIndex + 1]; // The next object in the list\r\n    }\r\n    return null; // No next object (it's the last one)\r\n  }\r\n\r\n  // Find the previous object in the scheduledObjects list\r\n  private _findPreviousObject(currentObject: SchedulingObject): SchedulingObject | null {\r\n    const currentIndex = this.scheduledObjects.indexOf(currentObject);\r\n    if (currentIndex > 0) {\r\n      return this.scheduledObjects[currentIndex - 1]; // The previous object in the list\r\n    }\r\n    return null; // No previous object (it's the first one)\r\n  }\r\n\r\n\r\n  public renderObjects() {\r\n    if(this.schedule) {\r\n      if (this.scheduledObjects.length > 1) {\r\n        this.scheduledObjects = [];\r\n      }\r\n      let objects: Object[] = this.schedule[this.objectsProp];\r\n\r\n      let schedulingObjects: SchedulingObject[] = [];\r\n\r\n\r\n      if (objects && objects.length > 0) {\r\n        objects.forEach(object => {\r\n          let topDifference: number = this.timeDifference(this.schedule[this.childProp][this.startTimeProp], object[this.startTimeProp]);\r\n          schedulingObjects.push(\r\n            {\r\n              title: object['title'],\r\n              subTitle: object['subTitle'],\r\n\r\n              start: this.convertDateToEuropean(object[this.startTimeProp]),\r\n              end: this.convertDateToEuropean(object[this.endTimeProp]),\r\n              id: object[this.idProp],\r\n              height: this.timeDifference(object[this.startTimeProp], object[this.endTimeProp]),\r\n              top: topDifference,\r\n              selected: false\r\n            });\r\n        });\r\n      }\r\n\r\n      this.scheduledObjects = schedulingObjects;\r\n    }\r\n  }\r\n\r\n  public onSelectBlock(obj: SchedulingObject) {\r\n    this.scheduledObjects.filter(obj => obj.selected).forEach(selectedObj => {\r\n      selectedObj.selected = false;\r\n    })\r\n    obj.selected = true;\r\n    this.currentResizingObject = obj;\r\n  }\r\n\r\n  public onDragStartCustom(obj: SchedulingObject) {\r\n    this.currentDraggingObject = obj;\r\n  }\r\n\r\n\r\n  public handleDrop(dragEvent: DragEvent, hour: string) {\r\n\r\n    if (this.currentDraggingObject) {\r\n      //The order was scheduled and needs to be moved\r\n\r\n      let start: Date = this.currentDraggingObject.start;\r\n      let hourSplit = hour.split(\":\")\r\n      start.setHours(parseInt(hourSplit[0]));\r\n      start.setMinutes(parseInt(hourSplit[1]));\r\n      let scheduledObject = this.scheduledObjects.find( scheduledObject => scheduledObject.id === this.currentDraggingObject.id);\r\n      scheduledObject.start = start;\r\n\r\n      let originalObject: Object = this.schedule[this.objectsProp].find( (object: Object) => object[this.idProp] === this.currentDraggingObject.id);\r\n      originalObject[this.startTimeProp] = start;\r\n      let end: Date = this.addMinutes(originalObject[this.startTimeProp], this.currentDraggingObject.height);\r\n      originalObject[this.endTimeProp] = end;\r\n      scheduledObject.end = end;\r\n      scheduledObject.top = this.timeDifference(this.schedule[this.childProp][this.startTimeProp], scheduledObject.start);\r\n      scheduledObject.height = this.timeDifference(scheduledObject.start, scheduledObject.end);\r\n\r\n      this.timeChangeEvent.emit(originalObject);\r\n      this.currentDraggingObject = undefined;\r\n\r\n\r\n    } else {\r\n\r\n      let parsed: Object = this.tryParseJSONObject(dragEvent.dataTransfer!.getData(\"text\"));\r\n\r\n      if (!parsed) {\r\n        this.newObjectPlanEvent.emit({currentHour: hour, data: parsed.toString()});\r\n      }\r\n\r\n\r\n    }\r\n\r\n  }\r\n\r\n\r\n  public allowDrop(event: DragEvent, hour: string) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    if(this.currentDraggingObject) {\r\n      let newStartDate: Date = this.convertDateToEuropean(this.currentDraggingObject.start);\r\n      let hourSplit: string[] = hour.split(\":\");\r\n      newStartDate.setHours(parseInt(hourSplit[0]));\r\n      newStartDate.setHours(parseInt(hourSplit[1]));\r\n\r\n      if(this.scheduledObjects.find( (scheduledObject: SchedulingObject) => scheduledObject.start === newStartDate )) {\r\n        return false;\r\n      } else {\r\n        return true;\r\n      }\r\n    }\r\n\r\n  }\r\n  // Triggered when resizing starts\r\n\r\n  public onResizeStart(event: MouseEvent, obj: SchedulingObject, direction: 'top' | 'bottom') {\r\n    this.resizing = true;\r\n    this.resizeDirection = direction;\r\n    this.currentResizingObject = obj;\r\n    this.initialY = event.clientY;\r\n    this.initialHeight = obj.height || 0;\r\n    this.initialTop = obj.top || 0;\r\n\r\n    // Listen to mousemove and mouseup events globally\r\n    document.addEventListener('mousemove', this.onResizing.bind(this));\r\n    document.addEventListener('mouseup', this.onResizeEnd.bind(this));\r\n  }\r\n  // Handle resizing with snapping to 30px increments and minimum height restriction\r\n\r\n  public onResizing(event: MouseEvent) {\r\n    if (!this.resizing || !this.currentResizingObject) return;\r\n\r\n    const deltaY = event.clientY - this.initialY;\r\n    const snappedDeltaY = Math.round(deltaY / 30) * 30;\r\n\r\n    if (this.resizeDirection === 'bottom') {\r\n      const nextObject = this._findNextObject(this.currentResizingObject);\r\n      const maxHeight = nextObject ? nextObject.top - this.currentResizingObject.top : Infinity;\r\n\r\n      // Block expanding beyond the next object and shrinking below 30px\r\n      const newHeight = Math.max(this.initialHeight + snappedDeltaY, this.MIN_HEIGHT);\r\n      this.currentResizingObject.height = Math.min(newHeight, maxHeight);\r\n\r\n    } else if (this.resizeDirection === 'top') {\r\n      const previousObject = this._findPreviousObject(this.currentResizingObject);\r\n      const minTop = previousObject ? previousObject.top + previousObject.height : 0;\r\n\r\n      const newHeight = Math.max(this.initialHeight - snappedDeltaY, this.MIN_HEIGHT);\r\n      const newTop = this.initialTop + (this.initialHeight - newHeight);\r\n\r\n      // Block moving above the previous object's bottom and shrinking below MIN_HEIGHT\r\n      if (newHeight >= this.MIN_HEIGHT && newTop >= minTop) {\r\n        this.currentResizingObject.top = newTop;\r\n        this.currentResizingObject.height = newHeight;\r\n      }\r\n    }\r\n\r\n    // Ensure change detection happens\r\n    this.cdRef.detectChanges();\r\n  }\r\n  // Triggered when resizing ends\r\n\r\n  public onResizeEnd(event: MouseEvent) {\r\n    let object: SchedulingObject = this.currentResizingObject;\r\n\r\n    if(object && object.selected) {\r\n      let originalObject = this.schedule[this.objectsProp].find((scheduledObject: Object) => scheduledObject[this.idProp] === object.id);\r\n\r\n      if (originalObject) {\r\n        // Start date calculation first\r\n        originalObject[this.startTimeProp] = this.addMinutes(this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]), object.top);\r\n\r\n        // Then  end date calculation based on the height of the object\r\n        originalObject[this.endTimeProp] = this.addMinutes(this.convertDateToEuropean(originalObject[this.startTimeProp]), object.height);\r\n\r\n      }\r\n      this.timeChangeEvent.emit(originalObject);\r\n\r\n      this.resizing = false;\r\n      this.currentResizingObject.selected = false;\r\n      this.currentResizingObject = null;\r\n\r\n\r\n    }\r\n\r\n\r\n    // Remove global event listeners\r\n    document.removeEventListener('mousemove', this.onResizing.bind(this));\r\n    document.removeEventListener('mouseup', this.onResizeEnd.bind(this));\r\n  }\r\n\r\n  public timeDifference(date1: Date, date2: Date) {\r\n    let difference = this.convertDateToEuropean(date1).getTime() / 1000 - this.convertDateToEuropean(date2).getTime() / 1000;\r\n    return Math.abs(difference / 60);\r\n  }\r\n\r\n\r\n  public generateTimeBlocks() {\r\n    let startUnix: number = !this.childProp ? this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.startTimeProp])) : this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.childProp][this.startTimeProp]));\r\n    let endUnix: number = !this.childProp ? this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.endTimeProp])) : this.dateToUnixEpoch(this.convertDateToEuropean(this.schedule[this.childProp][this.endTimeProp]));\r\n\r\n    let interval = 60 * 60;\r\n\r\n    for (let hourCount = startUnix; hourCount <= endUnix; hourCount += interval) {\r\n      let hour = new Date(hourCount * 1000)\r\n      let hourString = `${hour.getHours()}:${hour.getMinutes() === 0 ? '00' : hour.getMinutes()}`;\r\n      this.hourLabels.push(hourString);\r\n    }\r\n  }\r\n\r\n  public dateToUnixEpoch(date: Date): number {\r\n    return Math.floor(date.getTime()) / 1000;\r\n  }\r\n\r\n  public addMinutes(date: Date, minutes: number): Date {\r\n    return new Date(date.getTime() + minutes * 60000);\r\n  }\r\n\r\n  public tryParseJSONObject(jsonString: string) {\r\n    try {\r\n      let o = JSON.parse(jsonString);\r\n      if (o && typeof o === \"object\") {\r\n        return o;\r\n      }\r\n    } catch (e) {\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  public addHalfHour(hour: string) {\r\n    let split = hour.split(\":\");\r\n    split[1] = \"30\";\r\n    return split.join(':');\r\n  }\r\n\r\n  public convertTZ(date, tzString) {\r\n    return new Date((typeof date === \"string\" ? new Date(date) : date).toLocaleString(\"en-US\", {timeZone: tzString}));\r\n  }\r\n\r\n  public convertDateToEuropean(date: Date): Date {\r\n    return this.convertTZ(date, 'Europe/Amsterdam')\r\n  }\r\n\r\n  public handleDeselectAll() {\r\n    this.scheduledObjects.forEach( (scheduledObject: SchedulingObject) => {\r\n      if(scheduledObject.selected) {\r\n        scheduledObject.selected = false;\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { NgModule } from "@angular/core";
2
+ import { CommonModule, DatePipe } from "@angular/common";
3
+ import { HourSchedulingExpandableComponent } from "./hour-scheduling-expandable.component";
4
+ import { HourSchedulingComponentModule } from "../hour-scheduling/hour-scheduling.module";
5
+ import { HourSchedulingExpandableTemplateComponent } from "./components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component";
6
+ export class HourSchedulingExpandableComponentModule {
7
+ }
8
+ HourSchedulingExpandableComponentModule.decorators = [
9
+ { type: NgModule, args: [{
10
+ imports: [
11
+ CommonModule,
12
+ HourSchedulingComponentModule,
13
+ ],
14
+ declarations: [
15
+ HourSchedulingExpandableComponent,
16
+ HourSchedulingExpandableTemplateComponent
17
+ ],
18
+ exports: [
19
+ HourSchedulingExpandableComponent,
20
+ HourSchedulingExpandableTemplateComponent
21
+ ],
22
+ providers: [DatePipe]
23
+ },] }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUUsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGlDQUFpQyxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDekYsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDeEYsT0FBTyxFQUNMLHlDQUF5QyxFQUMxQyxNQUFNLGdHQUFnRyxDQUFDO0FBb0J4RyxNQUFNLE9BQU8sdUNBQXVDOzs7WUFoQm5ELFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWiw2QkFBNkI7aUJBQzlCO2dCQUNDLFlBQVksRUFBRTtvQkFDVixpQ0FBaUM7b0JBQ25DLHlDQUF5QztpQkFDMUM7Z0JBQ0gsT0FBTyxFQUFFO29CQUNQLGlDQUFpQztvQkFDakMseUNBQXlDO2lCQUMxQztnQkFDRCxTQUFTLEVBQUUsQ0FBRSxRQUFRLENBQUM7YUFFdkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZSwgRGF0ZVBpcGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtIb3VyU2NoZWR1bGluZ0V4cGFuZGFibGVDb21wb25lbnR9IGZyb20gXCIuL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0hvdXJTY2hlZHVsaW5nQ29tcG9uZW50TW9kdWxlfSBmcm9tIFwiLi4vaG91ci1zY2hlZHVsaW5nL2hvdXItc2NoZWR1bGluZy5tb2R1bGVcIjtcclxuaW1wb3J0IHtcclxuICBIb3VyU2NoZWR1bGluZ0V4cGFuZGFibGVUZW1wbGF0ZUNvbXBvbmVudFxyXG59IGZyb20gXCIuL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUuY29tcG9uZW50XCI7XHJcblxyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgSG91clNjaGVkdWxpbmdDb21wb25lbnRNb2R1bGUsXHJcbiAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIEhvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZUNvbXBvbmVudCxcclxuICAgICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlVGVtcGxhdGVDb21wb25lbnRcclxuICAgIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlQ29tcG9uZW50LFxyXG4gICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlVGVtcGxhdGVDb21wb25lbnRcclxuICBdLFxyXG4gIHByb3ZpZGVyczogWyBEYXRlUGlwZV1cclxuXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBIb3VyU2NoZWR1bGluZ0V4cGFuZGFibGVDb21wb25lbnRNb2R1bGV7XHJcbn1cclxuIl19
@@ -255,6 +255,7 @@ InputNumberPickerComponent.decorators = [
255
255
  [readonly]="readonly"
256
256
  [disabled]="disabled"
257
257
  [required]="required"
258
+ [placeholder]="label"
258
259
  (ngModelChange)="handleChangeModel($event)"
259
260
  (keydown)="handleInputKeyDown($event)"
260
261
  (blur)="handleBlur()"/>
@@ -311,4 +312,4 @@ InputNumberPickerComponent.propDecorators = {
311
312
  __decorate([
312
313
  InputBoolean()
313
314
  ], InputNumberPickerComponent.prototype, "noValidation", void 0);
314
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-number-picker/input-number-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver, ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport {BaseInputComponent} from '../base/base-input.component';\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\nimport {Subscription} from 'rxjs';\nimport {BoundsConstrainedNumberValue} from '../../core/model/bounds-constrained-number-value';\nimport {NUMBER_INPUTS_KEY_DOWN_WHITE_LIST} from '../../core/constant/number-inputs-key-down-white-list';\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\nimport {InputTextComponent} from '../input-text/input-text.component';\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\nimport {InputNumberPickerButtonShowMode} from '../../core/enum/input-number-picker-show-mode.enum';\nimport {IconCacheService} from '../icon/icon-cache.service';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {FormComponent} from '../form/form.component';\nimport {OverlayService} from '../../service/overlay.service';\nimport {SafeHtml} from '@angular/platform-browser';\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\n\n@Component({\n    selector: 'co-input-number-picker',\n    template: `\n        <div class=\"icon-wrapper\" *ngIf=\"leftIconData\">\n            <co-icon class=\"input-number-picker-icon\" [iconData]=\"leftIconData\" (click)=\"iconClick.emit($event)\"></co-icon>\n            <div class=\"spacer\"></div>\n        </div>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"minus-operator\" [class.select]=\"minSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(minusIcon)\"\n                       (mousedown)=\"onMinusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n        <input type=\"text\"\n               [tabIndex]=\"readonly ? -1 : 0\"\n               [ngModel]=\"model\"\n               [readonly]=\"readonly\"\n               [disabled]=\"disabled\"\n               [required]=\"required\"\n               (ngModelChange)=\"handleChangeModel($event)\"\n               (keydown)=\"handleInputKeyDown($event)\"\n               (blur)=\"handleBlur()\"/>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"plus-operator\" [class.select]=\"plusSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(plusIcon)\"\n                       (mousedown)=\"onPlusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n    `,\n    providers: [\n        OverlayService, {\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputNumberPickerComponent)\n        }, {\n            provide: BaseInputComponent,\n            useExisting: InputNumberPickerComponent\n        }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n// A component that lets users pick a number by increasing and decreasing it with buttons, or by typing.\nexport class InputNumberPickerComponent extends BaseInputComponent<number> implements OnInit, OnDestroy {\n\n    // @override\n    @Input()\n    public set model(model: number) {\n        this.setValue(model, true);\n        super.model = model;\n    }\n\n    public get model(): number {\n        return super.model;\n    }\n\n    @Input()\n    public modelChangeOnEnter: boolean = true;\n\n    @HostBinding('class.has-icon')\n    @Input()\n    public leftIconData: SafeHtml | undefined;\n\n    @Input()\n    public set min(min: number) {\n        this.numberLogic.min = min;\n    }\n\n    @Input()\n    public set step(step: number) {\n        this.numberLogic.step = step;\n    }\n\n    @Input()\n    public set max(max: number) {\n        this.numberLogic.max = max;\n    }\n\n    @Input()\n    public ngModelOptions: any;\n\n    @Input()\n    public minusIcon: CoreComponentsIcon = CoreComponentsIcon.MinusSimple;\n\n    @Input()\n    public plusIcon: CoreComponentsIcon = CoreComponentsIcon.PlusSimple;\n\n    // Whether to show buttons 'always', 'onFocusOnly', or 'never'\n    @Input()\n    public buttonShowMode: InputNumberPickerButtonShowMode = InputNumberPickerButtonShowMode.Always;\n\n    // @override Default true for us.\n    @Input() @InputBoolean()\n    public noValidation: boolean = true;\n\n    @Input()\n    public set decimals(decimals: number) {\n        this.numberLogic.decimals = decimals;\n    }\n\n    // @override\n    @Output()\n    public readonly modelChange: EventEmitter<number> = new EventEmitter<number>();\n\n    @Output()\n    public readonly iconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.show-buttons-on-focus-only')\n    public get showButtonsOnFocusOnly(): boolean {\n        return this.buttonShowMode === InputNumberPickerButtonShowMode.OnFocusOnly;\n    }\n\n    @HostBinding('class.has-label')\n    public get hasLabel(): boolean {\n        return !!this.label;\n    }\n\n    @HostBinding('class.co-input-number-picker')\n    public showClass(): boolean {\n        return true;\n    }\n\n    public showButtons: boolean;\n\n    public readonly myKeyDownWhiteList: KeyboardCode[] = NUMBER_INPUTS_KEY_DOWN_WHITE_LIST;\n\n    public readonly numberLogic: BoundsConstrainedNumberValue = new BoundsConstrainedNumberValue();\n\n    public minSelected: boolean = false;\n    public plusSelected: boolean = false;\n\n    private _numberInputHasFocus: boolean = false;\n    private _changeFromButton: boolean = false;\n\n    private _numberLogicValueChangeSub: Subscription;\n    private readonly _delayBeforeStartAutoCountMs: number = 666;\n    // the 'speed gears' for auto counting\n    private readonly _stepFactors: number[] = [1, 10, 20];\n    // increase step size timing\n    private readonly _msChangeStepFactor: number = 1000;\n    // step speed\n    private readonly _msDoStep: number = 5;\n    // hold the mouse down and this increases for a faster auto increment\n    private _stepFactor: number = this._stepFactors[0];\n    private _mayAutoCount: boolean = false;\n\n    private _autoCountTimeout: number;\n    private _stepIncrementTimeout: number;\n    private _startAutocountTimeout: number;\n\n    constructor(\n        @Optional() public formComponent: FormComponent,\n        @Inject(IconCacheService) public iconCacheService: IconCacheService,\n        protected overlayService: OverlayService,\n        private _ngZone: NgZone,\n        protected componentFactoryResolver: ComponentFactoryResolver,\n        changeDetector: ChangeDetectorRef,\n        formUserChangeListener: FormInputUserModelChangeListenerService,\n        protected ngZoneWrapper?: NgZoneWrapperService,\n        public elementRef?: ElementRef,\n    ) {\n        super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\n\n        this._numberLogicValueChangeSub = this.numberLogic.valueChange.subscribe((value: number) => {\n            if (!this._mayAutoCount) {\n                this.model = value;\n                if (!this.modelChangeOnEnter || this._changeFromButton) {\n                    this.modelChange.emit(value);\n                }\n                // custom form user chagne listener .next because we don't user super.updateModel() which normally does that for us\n                if (this._markedAsUserTouched) {\n                    this.formUserChangeListener.userModelChange.next(value);\n                    this.userModelChange.next(value);\n                }\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        // this.numberLogic.setValue(this.model, true);\n        // this.numberLogic.init(true);\n        this._updateButtonsShowState();\n    }\n\n    ngOnDestroy(): void {\n        this._numberLogicValueChangeSub.unsubscribe();\n        clearTimeout(this._autoCountTimeout);\n        clearTimeout(this._stepIncrementTimeout);\n        clearTimeout(this._startAutocountTimeout);\n    }\n\n    // Note: recursive through setTimeout().\n    public doIncrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.increment(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doIncrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\n        // event.preventDefault();\n        if (event.code === 'Enter' || event.code === 'NumpadEnter') {\n            this.modelChange.next(this.model);\n            return false;\n        }\n        if (this.myKeyDownWhiteList.find((k) => k === event.keyCode) === undefined) {\n            return false;\n        }\n    }\n\n    public handleBlur(): void {\n        this.modelChange.next(this.model);\n    }\n\n    public handleChangeModel(value: number): void {\n        this._changeFromButton = false;\n        this.numberLogic.setValue(value);\n    }\n\n    // Note: recursive through setTimeout().\n    public doDecrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.decrement(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doDecrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public stopAutoCounting(): void {\n        this.minSelected = false;\n        this.plusSelected = false;\n        this._mayAutoCount = false;\n        this._stepFactor = this._stepFactors[0];\n    }\n\n    // Sets the current number value with given newValue, optionally silent (no valueChange event fired).\n    public setValue(newValue: number, silent: boolean = false): void {\n        this.numberLogic.setValue(newValue, silent);\n    }\n\n    public increment(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.increment(steps);\n    }\n\n    public decrement(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.decrement(steps);\n    }\n\n    public onPlusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.plusSelected = true;\n        this._markedAsUserTouched = true;\n\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.increment();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doIncrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    public onMinusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.minSelected = true;\n        this._markedAsUserTouched = true;\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.decrement();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doDecrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    // Note: recursive.\n    private _doIncreaseStepFactor(): void {\n        this._stepIncrementTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this._stepFactor = this._getNextStepFactorMouseDown();\n                this._doIncreaseStepFactor();\n            }\n        }, this._msChangeStepFactor);\n    }\n\n    private _getNextStepFactorMouseDown(): number {\n        const curIdx: number = this._stepFactors.indexOf(this._stepFactor);\n        if (curIdx < this._stepFactors.length - 1) {\n            return this._stepFactors[curIdx + 1];\n        }\n        return this._stepFactor;\n    }\n\n    // Show or hide + and - buttons. Might hide buttons if number input lost focus and button show mode is on focus only.\n    private _updateButtonsShowState(): void {\n        switch (this.buttonShowMode) {\n            case InputNumberPickerButtonShowMode.Always:\n            default:\n                this.showButtons = true;\n                break;\n            case InputNumberPickerButtonShowMode.OnFocusOnly:\n                this.showButtons = this._numberInputHasFocus;\n                break;\n            case InputNumberPickerButtonShowMode.Never:\n                this.showButtons = false;\n                break;\n        }\n    }\n}\n"]}
315
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-number-picker/input-number-picker.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,wBAAwB,EAAE,UAAU,EACpC,YAAY,EACZ,UAAU,EACV,WAAW,EACX,MAAM,EACN,KAAK,EACL,MAAM,EAGN,QAAQ,EACR,MAAM,EAEN,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,kBAAkB,EAAC,MAAM,8BAA8B,CAAC;AAChE,OAAO,EAAC,YAAY,EAAC,MAAM,8CAA8C,CAAC;AAE1E,OAAO,EAAC,4BAA4B,EAAC,MAAM,kDAAkD,CAAC;AAC9F,OAAO,EAAC,iCAAiC,EAAC,MAAM,uDAAuD,CAAC;AAGxG,OAAO,EAAC,uCAAuC,EAAC,MAAM,4DAA4D,CAAC;AACnH,OAAO,EAAC,+BAA+B,EAAC,MAAM,oDAAoD,CAAC;AACnG,OAAO,EAAC,gBAAgB,EAAC,MAAM,4BAA4B,CAAC;AAC5D,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,8CAA8C,EAAC,MAAM,iEAAiE,CAAC;AAC/H,OAAO,EAAC,aAAa,EAAC,MAAM,wBAAwB,CAAC;AACrD,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;AAE7D,OAAO,EAAC,oBAAoB,EAAC,MAAM,4CAA4C,CAAC;AA4ChF,wGAAwG;AACxG,MAAM,OAAO,0BAA2B,SAAQ,kBAA0B;IA2GtE,YACuB,aAA4B,EACd,gBAAkC,EACzD,cAA8B,EAChC,OAAe,EACb,wBAAkD,EAC5D,cAAiC,EACjC,sBAA+D,EACrD,aAAoC,EACvC,UAAuB;QAE9B,KAAK,CAAC,cAAc,EAAE,wBAAwB,EAAE,cAAc,EAAE,sBAAsB,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;QAVhG,kBAAa,GAAb,aAAa,CAAe;QACd,qBAAgB,GAAhB,gBAAgB,CAAkB;QACzD,mBAAc,GAAd,cAAc,CAAgB;QAChC,YAAO,GAAP,OAAO,CAAQ;QACb,6BAAwB,GAAxB,wBAAwB,CAA0B;QAGlD,kBAAa,GAAb,aAAa,CAAuB;QACvC,eAAU,GAAV,UAAU,CAAa;QAtG3B,uBAAkB,GAAY,IAAI,CAAC;QAyBnC,cAAS,GAAuB,kBAAkB,CAAC,WAAW,CAAC;QAG/D,aAAQ,GAAuB,kBAAkB,CAAC,UAAU,CAAC;QAEpE,8DAA8D;QAEvD,mBAAc,GAAoC,+BAA+B,CAAC,MAAM,CAAC;QAEhG,iCAAiC;QAE1B,iBAAY,GAAY,IAAI,CAAC;QAOpC,YAAY;QAEI,gBAAW,GAAyB,IAAI,YAAY,EAAU,CAAC;QAG/D,cAAS,GAA6B,IAAI,YAAY,EAAc,CAAC;QAmBrE,uBAAkB,GAAmB,iCAAiC,CAAC;QAEvE,gBAAW,GAAiC,IAAI,4BAA4B,EAAE,CAAC;QAExF,gBAAW,GAAY,KAAK,CAAC;QAC7B,iBAAY,GAAY,KAAK,CAAC;QAE7B,yBAAoB,GAAY,KAAK,CAAC;QACtC,sBAAiB,GAAY,KAAK,CAAC;QAG1B,iCAA4B,GAAW,GAAG,CAAC;QAC5D,sCAAsC;QACrB,iBAAY,GAAa,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACtD,4BAA4B;QACX,wBAAmB,GAAW,IAAI,CAAC;QACpD,aAAa;QACI,cAAS,GAAW,CAAC,CAAC;QACvC,qEAAqE;QAC7D,gBAAW,GAAW,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC3C,kBAAa,GAAY,KAAK,CAAC;QAmBnC,IAAI,CAAC,0BAA0B,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,KAAa,EAAE,EAAE;YACvF,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;gBACnB,IAAI,CAAC,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,iBAAiB,EAAE;oBACpD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAChC;gBACD,mHAAmH;gBACnH,IAAI,IAAI,CAAC,oBAAoB,EAAE;oBAC3B,IAAI,CAAC,sBAAsB,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACxD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACpC;aACJ;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAnID,YAAY;IACZ,IACW,KAAK,CAAC,KAAa;QAC1B,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC3B,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,KAAK,CAAC,KAAK,CAAC;IACvB,CAAC;IASD,IACW,GAAG,CAAC,GAAW;QACtB,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,GAAG,CAAC;IAC/B,CAAC;IAED,IACW,IAAI,CAAC,IAAY;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,GAAG,IAAI,CAAC;IACjC,CAAC;IAED,IACW,GAAG,CAAC,GAAW;QACtB,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,GAAG,CAAC;IAC/B,CAAC;IAmBD,IACW,QAAQ,CAAC,QAAgB;QAChC,IAAI,CAAC,WAAW,CAAC,QAAQ,GAAG,QAAQ,CAAC;IACzC,CAAC;IASD,IACW,sBAAsB;QAC7B,OAAO,IAAI,CAAC,cAAc,KAAK,+BAA+B,CAAC,WAAW,CAAC;IAC/E,CAAC;IAED,IACW,QAAQ;QACf,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IACxB,CAAC;IAGM,SAAS;QACZ,OAAO,IAAI,CAAC;IAChB,CAAC;IA0DD,QAAQ;QACJ,+CAA+C;QAC/C,+BAA+B;QAC/B,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACnC,CAAC;IAED,WAAW;QACP,IAAI,CAAC,0BAA0B,CAAC,WAAW,EAAE,CAAC;QAC9C,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACrC,YAAY,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QACzC,YAAY,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9C,CAAC;IAED,wCAAwC;IACjC,eAAe;QAClB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEjC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC5C,IAAI,IAAI,CAAC,aAAa,EAAE;oBACpB,IAAI,CAAC,eAAe,EAAE,CAAC;oBACvB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;iBACvC;YACL,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,kBAAkB,CAAC,KAAoB;QAC1C,0BAA0B;QAC1B,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,EAAE;YACxD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAClC,OAAO,KAAK,CAAC;SAChB;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,OAAO,CAAC,KAAK,SAAS,EAAE;YACxE,OAAO,KAAK,CAAC;SAChB;IACL,CAAC;IAEM,UAAU;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,iBAAiB,CAAC,KAAa;QAClC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACrC,CAAC;IAED,wCAAwC;IACjC,eAAe;QAClB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAEjC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,iBAAiB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBAC5C,IAAI,IAAI,CAAC,aAAa,EAAE;oBACpB,IAAI,CAAC,eAAe,EAAE,CAAC;oBACvB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;iBACvC;YACL,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;QACvB,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,gBAAgB;QACnB,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;QACzB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,qGAAqG;IAC9F,QAAQ,CAAC,QAAgB,EAAE,SAAkB,KAAK;QACrD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAChD,CAAC;IAEM,SAAS,CAAC,QAAgB,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,SAAS,CAAC,QAAgB,CAAC;QAC9B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACtC,CAAC;IAEM,eAAe,CAAC,KAAY;QAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QAEjC,8CAA8C;QAC9C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,YAAY,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAC1C,IAAI,CAAC,sBAAsB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YACjD,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAChC;QACL,CAAC,EAAE,IAAI,CAAC,4BAA4B,CAAC,CAAC;IAC1C,CAAC;IAEM,gBAAgB,CAAC,KAAY;QAChC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,OAAO;SACV;QACD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,8CAA8C;QAC9C,KAAK,CAAC,cAAc,EAAE,CAAC;QAEvB,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAE1B,YAAY,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;QAC1C,IAAI,CAAC,sBAAsB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YACjD,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAChC;QACL,CAAC,EAAE,IAAI,CAAC,4BAA4B,CAAC,CAAC;IAC1C,CAAC;IAED,mBAAmB;IACX,qBAAqB;QACzB,IAAI,CAAC,qBAAqB,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAChD,IAAI,IAAI,CAAC,aAAa,EAAE;gBACpB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,2BAA2B,EAAE,CAAC;gBACtD,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAChC;QACL,CAAC,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACjC,CAAC;IAEO,2BAA2B;QAC/B,MAAM,MAAM,GAAW,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACnE,IAAI,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,EAAE;YACvC,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SACxC;QACD,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED,qHAAqH;IAC7G,uBAAuB;QAC3B,QAAQ,IAAI,CAAC,cAAc,EAAE;YACzB,KAAK,+BAA+B,CAAC,MAAM,CAAC;YAC5C;gBACI,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;gBACxB,MAAM;YACV,KAAK,+BAA+B,CAAC,WAAW;gBAC5C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBAC7C,MAAM;YACV,KAAK,+BAA+B,CAAC,KAAK;gBACtC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,MAAM;SACb;IACL,CAAC;;;YAtVJ,SAAS,SAAC;gBACP,QAAQ,EAAE,wBAAwB;gBAClC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KA6BT;gBACD,SAAS,EAAE;oBACP,cAAc,EAAE;wBACZ,OAAO,EAAE,8CAA8C,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;qBACrH,EAAE;wBACC,OAAO,EAAE,kBAAkB;wBAC3B,WAAW,EAAE,0BAA0B;qBAC1C;iBAAC;gBACN,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YA9CO,aAAa,uBA4JZ,QAAQ;YA/JT,gBAAgB,uBAgKf,MAAM,SAAC,gBAAgB;YA5JxB,cAAc;YArBlB,MAAM;YANN,wBAAwB;YAFxB,iBAAiB;YAuBb,uCAAuC;YAQvC,oBAAoB;YA7BE,UAAU;;;oBA6EnC,KAAK;iCAUL,KAAK;2BAGL,WAAW,SAAC,gBAAgB,cAC5B,KAAK;kBAGL,KAAK;mBAKL,KAAK;kBAKL,KAAK;6BAKL,KAAK;wBAGL,KAAK;uBAGL,KAAK;6BAIL,KAAK;2BAIL,KAAK;uBAGL,KAAK;0BAML,MAAM;wBAGN,MAAM;qCAGN,WAAW,SAAC,kCAAkC;uBAK9C,WAAW,SAAC,iBAAiB;wBAK7B,WAAW,SAAC,8BAA8B;;AAxB3C;IADU,YAAY,EAAE;gEACY","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver, ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Inject,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    ViewEncapsulation\n} from '@angular/core';\nimport {BaseInputComponent} from '../base/base-input.component';\nimport {InputBoolean} from '../../core/decorator/input-boolean.decorator';\nimport {Subscription} from 'rxjs';\nimport {BoundsConstrainedNumberValue} from '../../core/model/bounds-constrained-number-value';\nimport {NUMBER_INPUTS_KEY_DOWN_WHITE_LIST} from '../../core/constant/number-inputs-key-down-white-list';\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\nimport {InputTextComponent} from '../input-text/input-text.component';\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\nimport {InputNumberPickerButtonShowMode} from '../../core/enum/input-number-picker-show-mode.enum';\nimport {IconCacheService} from '../icon/icon-cache.service';\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\nimport {FormComponent} from '../form/form.component';\nimport {OverlayService} from '../../service/overlay.service';\nimport {SafeHtml} from '@angular/platform-browser';\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\n\n@Component({\n    selector: 'co-input-number-picker',\n    template: `\n        <div class=\"icon-wrapper\" *ngIf=\"leftIconData\">\n            <co-icon class=\"input-number-picker-icon\" [iconData]=\"leftIconData\" (click)=\"iconClick.emit($event)\"></co-icon>\n            <div class=\"spacer\"></div>\n        </div>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"minus-operator\" [class.select]=\"minSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(minusIcon)\"\n                       (mousedown)=\"onMinusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n        <input type=\"text\"\n               [tabIndex]=\"readonly ? -1 : 0\"\n               [ngModel]=\"model\"\n               [readonly]=\"readonly\"\n               [disabled]=\"disabled\"\n               [required]=\"required\"\n               [placeholder]=\"label\"\n               (ngModelChange)=\"handleChangeModel($event)\"\n               (keydown)=\"handleInputKeyDown($event)\"\n               (blur)=\"handleBlur()\"/>\n        <div class=\"button-wrapper\">\n            <co-button *ngIf=\"showButtons\" class=\"plus-operator\" [class.select]=\"plusSelected\" tabindex=\"-1\"\n                       [disabled]=\"readonly\"\n                       [iconData]=\"iconCacheService.getIcon(plusIcon)\"\n                       (mousedown)=\"onPlusMouseDown($event)\"\n                       (mouseup)=\"stopAutoCounting()\" (mouseleave)=\"stopAutoCounting()\"></co-button>\n        </div>\n    `,\n    providers: [\n        OverlayService, {\n            provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME, useExisting: forwardRef(() => InputNumberPickerComponent)\n        }, {\n            provide: BaseInputComponent,\n            useExisting: InputNumberPickerComponent\n        }],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n})\n// A component that lets users pick a number by increasing and decreasing it with buttons, or by typing.\nexport class InputNumberPickerComponent extends BaseInputComponent<number> implements OnInit, OnDestroy {\n\n    // @override\n    @Input()\n    public set model(model: number) {\n        this.setValue(model, true);\n        super.model = model;\n    }\n\n    public get model(): number {\n        return super.model;\n    }\n\n    @Input()\n    public modelChangeOnEnter: boolean = true;\n\n    @HostBinding('class.has-icon')\n    @Input()\n    public leftIconData: SafeHtml | undefined;\n\n    @Input()\n    public set min(min: number) {\n        this.numberLogic.min = min;\n    }\n\n    @Input()\n    public set step(step: number) {\n        this.numberLogic.step = step;\n    }\n\n    @Input()\n    public set max(max: number) {\n        this.numberLogic.max = max;\n    }\n\n    @Input()\n    public ngModelOptions: any;\n\n    @Input()\n    public minusIcon: CoreComponentsIcon = CoreComponentsIcon.MinusSimple;\n\n    @Input()\n    public plusIcon: CoreComponentsIcon = CoreComponentsIcon.PlusSimple;\n\n    // Whether to show buttons 'always', 'onFocusOnly', or 'never'\n    @Input()\n    public buttonShowMode: InputNumberPickerButtonShowMode = InputNumberPickerButtonShowMode.Always;\n\n    // @override Default true for us.\n    @Input() @InputBoolean()\n    public noValidation: boolean = true;\n\n    @Input()\n    public set decimals(decimals: number) {\n        this.numberLogic.decimals = decimals;\n    }\n\n    // @override\n    @Output()\n    public readonly modelChange: EventEmitter<number> = new EventEmitter<number>();\n\n    @Output()\n    public readonly iconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\n\n    @HostBinding('class.show-buttons-on-focus-only')\n    public get showButtonsOnFocusOnly(): boolean {\n        return this.buttonShowMode === InputNumberPickerButtonShowMode.OnFocusOnly;\n    }\n\n    @HostBinding('class.has-label')\n    public get hasLabel(): boolean {\n        return !!this.label;\n    }\n\n    @HostBinding('class.co-input-number-picker')\n    public showClass(): boolean {\n        return true;\n    }\n\n    public showButtons: boolean;\n\n    public readonly myKeyDownWhiteList: KeyboardCode[] = NUMBER_INPUTS_KEY_DOWN_WHITE_LIST;\n\n    public readonly numberLogic: BoundsConstrainedNumberValue = new BoundsConstrainedNumberValue();\n\n    public minSelected: boolean = false;\n    public plusSelected: boolean = false;\n\n    private _numberInputHasFocus: boolean = false;\n    private _changeFromButton: boolean = false;\n\n    private _numberLogicValueChangeSub: Subscription;\n    private readonly _delayBeforeStartAutoCountMs: number = 666;\n    // the 'speed gears' for auto counting\n    private readonly _stepFactors: number[] = [1, 10, 20];\n    // increase step size timing\n    private readonly _msChangeStepFactor: number = 1000;\n    // step speed\n    private readonly _msDoStep: number = 5;\n    // hold the mouse down and this increases for a faster auto increment\n    private _stepFactor: number = this._stepFactors[0];\n    private _mayAutoCount: boolean = false;\n\n    private _autoCountTimeout: number;\n    private _stepIncrementTimeout: number;\n    private _startAutocountTimeout: number;\n\n    constructor(\n        @Optional() public formComponent: FormComponent,\n        @Inject(IconCacheService) public iconCacheService: IconCacheService,\n        protected overlayService: OverlayService,\n        private _ngZone: NgZone,\n        protected componentFactoryResolver: ComponentFactoryResolver,\n        changeDetector: ChangeDetectorRef,\n        formUserChangeListener: FormInputUserModelChangeListenerService,\n        protected ngZoneWrapper?: NgZoneWrapperService,\n        public elementRef?: ElementRef,\n    ) {\n        super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\n\n        this._numberLogicValueChangeSub = this.numberLogic.valueChange.subscribe((value: number) => {\n            if (!this._mayAutoCount) {\n                this.model = value;\n                if (!this.modelChangeOnEnter || this._changeFromButton) {\n                    this.modelChange.emit(value);\n                }\n                // custom form user chagne listener .next because we don't user super.updateModel() which normally does that for us\n                if (this._markedAsUserTouched) {\n                    this.formUserChangeListener.userModelChange.next(value);\n                    this.userModelChange.next(value);\n                }\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        // this.numberLogic.setValue(this.model, true);\n        // this.numberLogic.init(true);\n        this._updateButtonsShowState();\n    }\n\n    ngOnDestroy(): void {\n        this._numberLogicValueChangeSub.unsubscribe();\n        clearTimeout(this._autoCountTimeout);\n        clearTimeout(this._stepIncrementTimeout);\n        clearTimeout(this._startAutocountTimeout);\n    }\n\n    // Note: recursive through setTimeout().\n    public doIncrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.increment(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doIncrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public handleInputKeyDown(event: KeyboardEvent): boolean {\n        // event.preventDefault();\n        if (event.code === 'Enter' || event.code === 'NumpadEnter') {\n            this.modelChange.next(this.model);\n            return false;\n        }\n        if (this.myKeyDownWhiteList.find((k) => k === event.keyCode) === undefined) {\n            return false;\n        }\n    }\n\n    public handleBlur(): void {\n        this.modelChange.next(this.model);\n    }\n\n    public handleChangeModel(value: number): void {\n        this._changeFromButton = false;\n        this.numberLogic.setValue(value);\n    }\n\n    // Note: recursive through setTimeout().\n    public doDecrementAuto(): void {\n        this._mayAutoCount = true;\n\n        this.decrement(this._stepFactor);\n\n        this._ngZone.runOutsideAngular(() => {\n            this._autoCountTimeout = window.setTimeout(() => {\n                if (this._mayAutoCount) {\n                    this.doDecrementAuto();\n                    this.changeDetector.detectChanges();\n                }\n            }, this._msDoStep);\n        });\n    }\n\n    public stopAutoCounting(): void {\n        this.minSelected = false;\n        this.plusSelected = false;\n        this._mayAutoCount = false;\n        this._stepFactor = this._stepFactors[0];\n    }\n\n    // Sets the current number value with given newValue, optionally silent (no valueChange event fired).\n    public setValue(newValue: number, silent: boolean = false): void {\n        this.numberLogic.setValue(newValue, silent);\n    }\n\n    public increment(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.increment(steps);\n    }\n\n    public decrement(steps: number = 1): void {\n        this._changeFromButton = true;\n        this.numberLogic.decrement(steps);\n    }\n\n    public onPlusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.plusSelected = true;\n        this._markedAsUserTouched = true;\n\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.increment();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doIncrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    public onMinusMouseDown(event: Event): void {\n        if (this.readonly) {\n            event.preventDefault();\n            return;\n        }\n        this.minSelected = true;\n        this._markedAsUserTouched = true;\n        // keeps focus on input text instead of button\n        event.preventDefault();\n\n        this.decrement();\n        this._mayAutoCount = true;\n\n        clearTimeout(this._startAutocountTimeout);\n        this._startAutocountTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this.doDecrementAuto();\n                this._doIncreaseStepFactor();\n            }\n        }, this._delayBeforeStartAutoCountMs);\n    }\n\n    // Note: recursive.\n    private _doIncreaseStepFactor(): void {\n        this._stepIncrementTimeout = window.setTimeout(() => {\n            if (this._mayAutoCount) {\n                this._stepFactor = this._getNextStepFactorMouseDown();\n                this._doIncreaseStepFactor();\n            }\n        }, this._msChangeStepFactor);\n    }\n\n    private _getNextStepFactorMouseDown(): number {\n        const curIdx: number = this._stepFactors.indexOf(this._stepFactor);\n        if (curIdx < this._stepFactors.length - 1) {\n            return this._stepFactors[curIdx + 1];\n        }\n        return this._stepFactor;\n    }\n\n    // Show or hide + and - buttons. Might hide buttons if number input lost focus and button show mode is on focus only.\n    private _updateButtonsShowState(): void {\n        switch (this.buttonShowMode) {\n            case InputNumberPickerButtonShowMode.Always:\n            default:\n                this.showButtons = true;\n                break;\n            case InputNumberPickerButtonShowMode.OnFocusOnly:\n                this.showButtons = this._numberInputHasFocus;\n                break;\n            case InputNumberPickerButtonShowMode.Never:\n                this.showButtons = false;\n                break;\n        }\n    }\n}\n"]}