@colijnit/corecomponents_v12 259.1.20 → 259.1.22
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/bundles/colijnit-corecomponents_v12.umd.js +78 -39
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component.js +36 -33
- package/esm2015/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.module.js +20 -0
- package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.component.js +10 -5
- package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.module.js +3 -4
- package/esm2015/lib/components/list-of-icons/list-of-icons.component.js +29 -32
- package/esm2015/lib/components/list-of-values/list-of-values-popup.component.js +61 -32
- package/esm2015/lib/components/list-of-values/list-of-values.component.js +4 -1
- package/esm2015/lib/components/list-of-values/list-of-values.module.js +4 -2
- package/esm2015/lib/components/simple-grid/simple-grid.component.js +28 -28
- package/esm2015/lib/model/icon-list-item.js +1 -1
- package/esm2015/public-api.js +2 -1
- package/fesm2015/colijnit-corecomponents_v12.js +182 -140
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component.d.ts +1 -1
- package/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.module.d.ts +2 -0
- package/lib/components/hour-scheduling-expandable/style/_layout.scss +1 -0
- package/lib/components/list-of-icons/list-of-icons.component.d.ts +1 -3
- package/lib/components/list-of-icons/style/_layout.scss +3 -2
- package/lib/components/list-of-values/list-of-values-popup.component.d.ts +4 -0
- package/lib/components/list-of-values/list-of-values.component.d.ts +1 -0
- package/lib/components/list-of-values/style/_layout.scss +7 -0
- package/lib/components/simple-grid/style/_layout.scss +47 -8
- package/lib/model/icon-list-item.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2015/lib/core/enum/batch-delivery-category.enum.js +0 -13
- package/lib/core/enum/batch-delivery-category.enum.d.ts +0 -10
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, HostBinding, Input, ViewEncapsulation } from
|
|
1
|
+
import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
export class HourSchedulingExpandableTemplateComponent {
|
|
3
3
|
constructor() {
|
|
4
4
|
this.layouts = [];
|
|
@@ -14,8 +14,10 @@ export class HourSchedulingExpandableTemplateComponent {
|
|
|
14
14
|
return true;
|
|
15
15
|
}
|
|
16
16
|
onExpandableDragStart(event, obj, onDragStartCustom) {
|
|
17
|
-
|
|
18
|
-
|
|
17
|
+
event.dataTransfer.setData('text', JSON.stringify({ obj }));
|
|
18
|
+
if (onDragStartCustom) {
|
|
19
|
+
onDragStartCustom === null || onDragStartCustom === void 0 ? void 0 : onDragStartCustom.call(obj);
|
|
20
|
+
}
|
|
19
21
|
}
|
|
20
22
|
calculateLeftAndWidthOfObjects() {
|
|
21
23
|
const layoutData = new Array(this._objects.length);
|
|
@@ -27,8 +29,9 @@ export class HourSchedulingExpandableTemplateComponent {
|
|
|
27
29
|
const overlapGroups = [];
|
|
28
30
|
const processed = new Set();
|
|
29
31
|
for (let i = 0; i < this._objects.length; i++) {
|
|
30
|
-
if (processed.has(i))
|
|
32
|
+
if (processed.has(i)) {
|
|
31
33
|
continue;
|
|
34
|
+
}
|
|
32
35
|
const group = [i];
|
|
33
36
|
const objA = this._objects[i];
|
|
34
37
|
const startA = new Date(objA.start);
|
|
@@ -61,37 +64,37 @@ export class HourSchedulingExpandableTemplateComponent {
|
|
|
61
64
|
}
|
|
62
65
|
HourSchedulingExpandableTemplateComponent.decorators = [
|
|
63
66
|
{ type: Component, args: [{
|
|
64
|
-
selector:
|
|
67
|
+
selector: 'co-hour-scheduling-expandable-template',
|
|
65
68
|
template: `
|
|
66
|
-
|
|
67
|
-
<div
|
|
68
|
-
*ngFor="let obj of objects"
|
|
69
|
-
[class]="'custom-scheduled-object'"
|
|
70
|
-
[class.selected]="obj.selected"
|
|
71
|
-
[draggable]="!obj.selected"
|
|
72
|
-
[style.--height]="obj.height + 'px'"
|
|
73
|
-
[style.--top]="obj.top + 'px'"
|
|
74
|
-
[style.--left]="layouts[objects.indexOf(obj)].leftPercent + '%'"
|
|
75
|
-
[style.--width]="layouts[objects.indexOf(obj)].widthPercent + '%'"
|
|
76
|
-
(click)="onSelectBlock(obj)"
|
|
77
|
-
(dragstart)="onExpandableDragStart($event, obj, onDragStartCustom(obj) )">
|
|
78
69
|
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
70
|
+
<div
|
|
71
|
+
*ngFor="let obj of objects"
|
|
72
|
+
[class]="'custom-scheduled-object'"
|
|
73
|
+
[class.selected]="obj.selected"
|
|
74
|
+
[draggable]="!obj.selected"
|
|
75
|
+
[style.--height]="obj.height + 'px'"
|
|
76
|
+
[style.--top]="obj.top + 'px'"
|
|
77
|
+
[style.--left]="layouts[objects.indexOf(obj)].leftPercent + '%'"
|
|
78
|
+
[style.--width]="layouts[objects.indexOf(obj)].widthPercent + '%'"
|
|
79
|
+
(click)="onSelectBlock(obj)"
|
|
80
|
+
(dragstart)="onExpandableDragStart($event, obj, onDragStartCustom(obj) )">
|
|
81
|
+
|
|
82
|
+
<div
|
|
83
|
+
*ngIf="obj.selected"
|
|
84
|
+
class="top-resizer"
|
|
85
|
+
(mousedown)="onResizeStart($event, obj, 'top')"></div>
|
|
86
|
+
<ng-template
|
|
87
|
+
[ngTemplateOutlet]="objectTemplate"
|
|
88
|
+
[ngTemplateOutletContext]="{
|
|
86
89
|
object: obj
|
|
87
90
|
}"
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
91
|
+
>
|
|
92
|
+
</ng-template>
|
|
93
|
+
<div *ngIf="obj.selected"
|
|
94
|
+
class="bottom-resizer"
|
|
95
|
+
(mousedown)="onResizeStart($event, obj, 'bottom')"></div>
|
|
96
|
+
</div>
|
|
97
|
+
`,
|
|
95
98
|
encapsulation: ViewEncapsulation.None
|
|
96
99
|
},] }
|
|
97
100
|
];
|
|
@@ -103,6 +106,6 @@ HourSchedulingExpandableTemplateComponent.propDecorators = {
|
|
|
103
106
|
onSelectBlock: [{ type: Input }],
|
|
104
107
|
startTimeProp: [{ type: Input }],
|
|
105
108
|
endTimeProp: [{ type: Input }],
|
|
106
|
-
showClass: [{ type: HostBinding, args: [
|
|
109
|
+
showClass: [{ type: HostBinding, args: ['class.co-hour-scheduling-expandable-template',] }]
|
|
107
110
|
};
|
|
108
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hour-scheduling-expandable-template.component.js","sourceRoot":"","sources":["../../../../../../../../projects/corecomponents/src/lib/components/hour-scheduling-expandable/components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, TemplateRef, ViewEncapsulation} from '@angular/core';\r\nimport {SchedulingObject} from '../../../hour-scheduling/model/enum/scheduling-object.interface';\r\n\r\n@Component({\r\n  selector: 'co-hour-scheduling-expandable-template',\r\n  template: `\r\n\r\n      <div\r\n              *ngFor=\"let obj of objects\"\r\n              [class]=\"'custom-scheduled-object'\"\r\n              [class.selected]=\"obj.selected\"\r\n              [draggable]=\"!obj.selected\"\r\n              [style.--height]=\"obj.height + 'px'\"\r\n              [style.--top]=\"obj.top + 'px'\"\r\n              [style.--left]=\"layouts[objects.indexOf(obj)].leftPercent + '%'\"\r\n              [style.--width]=\"layouts[objects.indexOf(obj)].widthPercent + '%'\"\r\n              (click)=\"onSelectBlock(obj)\"\r\n              (dragstart)=\"onExpandableDragStart($event, obj, onDragStartCustom(obj) )\">\r\n\r\n          <div\r\n                  *ngIf=\"obj.selected\"\r\n                  class=\"top-resizer\"\r\n                  (mousedown)=\"onResizeStart($event, obj, 'top')\"></div>\r\n          <ng-template\r\n                  [ngTemplateOutlet]=\"objectTemplate\"\r\n                  [ngTemplateOutletContext]=\"{\r\n              object: obj\r\n            }\"\r\n          >\r\n          </ng-template>\r\n          <div *ngIf=\"obj.selected\"\r\n               class=\"bottom-resizer\"\r\n               (mousedown)=\"onResizeStart($event, obj, 'bottom')\"></div>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class HourSchedulingExpandableTemplateComponent {\r\n\r\n  private _objects: SchedulingObject[];\r\n  public layouts: { leftPercent: number; widthPercent: number }[] = [];\r\n\r\n  @Input()\r\n  public objectTemplate: TemplateRef<any>;\r\n\r\n  @Input()\r\n  public set objects(objects: SchedulingObject[]) {\r\n    this._objects = objects;\r\n    this.layouts = this.calculateLeftAndWidthOfObjects();\r\n  }\r\n\r\n  public get objects() {\r\n    return this._objects;\r\n  }\r\n\r\n  @Input()\r\n  public onDragStartCustom: Function;\r\n\r\n  @Input()\r\n  public onResizeStart: Function;\r\n\r\n  @Input()\r\n  public onSelectBlock: Function;\r\n\r\n  @Input()\r\n  public startTimeProp: string;\r\n\r\n  @Input()\r\n  public endTimeProp: string;\r\n\r\n  @HostBinding('class.co-hour-scheduling-expandable-template')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public onExpandableDragStart(event: DragEvent, obj: Object, onDragStartCustom: Function) {\r\n    event.dataTransfer!.setData('text', JSON.stringify({obj}));\r\n    if (onDragStartCustom) {\r\n      onDragStartCustom?.call(obj);\r\n    }\r\n  }\r\n\r\n  public calculateLeftAndWidthOfObjects(): { leftPercent: number; widthPercent: number }[] {\r\n    const layoutData: { leftPercent: number; widthPercent: number }[] = new Array(this._objects.length);\r\n\r\n    // Helper: check if two time ranges overlap\r\n    const isOverlapping = (startA: Date, endA: Date, startB: Date, endB: Date): boolean => {\r\n      return startA < endB && startB < endA;\r\n    };\r\n\r\n    // Step 1: build overlap groups\r\n    const overlapGroups: number[][] = [];\r\n\r\n    const processed = new Set<number>();\r\n\r\n    for (let i = 0; i < this._objects.length; i++) {\r\n      if (processed.has(i)) {\r\n        continue;\r\n      }\r\n\r\n      const group: number[] = [i];\r\n      const objA = this._objects[i];\r\n      const startA = new Date(objA.start);\r\n      const endA = new Date(objA.end);\r\n\r\n      for (let j = i + 1; j < this._objects.length; j++) {\r\n        const objB = this._objects[j];\r\n        const startB = new Date(objB.start);\r\n        const endB = new Date(objB.end);\r\n\r\n        if (isOverlapping(startA, endA, startB, endB)) {\r\n          group.push(j);\r\n          processed.add(j);\r\n        }\r\n      }\r\n\r\n      group.forEach(index => processed.add(index));\r\n      overlapGroups.push(group);\r\n    }\r\n\r\n    // Step 2: assign layout per group\r\n    overlapGroups.forEach(group => {\r\n      const total = group.length;\r\n      const width = 100 / total;\r\n\r\n      group.forEach((objectIndex, i) => {\r\n        layoutData[objectIndex] = {\r\n          leftPercent: i * width,\r\n          widthPercent: width\r\n        };\r\n      });\r\n    });\r\n\r\n    return layoutData;\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { NgModule } from "@angular/core";
|
|
2
|
+
import { CommonModule, DatePipe } from "@angular/common";
|
|
3
|
+
import { HourSchedulingExpandableTemplateComponent } from './hour-scheduling-expandable-template.component';
|
|
4
|
+
export class HourSchedulingExpandableTemplateModule {
|
|
5
|
+
}
|
|
6
|
+
HourSchedulingExpandableTemplateModule.decorators = [
|
|
7
|
+
{ type: NgModule, args: [{
|
|
8
|
+
imports: [
|
|
9
|
+
CommonModule,
|
|
10
|
+
],
|
|
11
|
+
declarations: [
|
|
12
|
+
HourSchedulingExpandableTemplateComponent
|
|
13
|
+
],
|
|
14
|
+
exports: [
|
|
15
|
+
HourSchedulingExpandableTemplateComponent
|
|
16
|
+
],
|
|
17
|
+
providers: [DatePipe]
|
|
18
|
+
},] }
|
|
19
|
+
];
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBRSxRQUFRLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUN2RCxPQUFPLEVBQUMseUNBQXlDLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQWdCMUcsTUFBTSxPQUFPLHNDQUFzQzs7O1lBYmxELFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtpQkFDYjtnQkFDQyxZQUFZLEVBQUU7b0JBQ1oseUNBQXlDO2lCQUMxQztnQkFDSCxPQUFPLEVBQUU7b0JBQ1AseUNBQXlDO2lCQUMxQztnQkFDRCxTQUFTLEVBQUUsQ0FBRSxRQUFRLENBQUM7YUFFdkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZSwgRGF0ZVBpcGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtIb3VyU2NoZWR1bGluZ0V4cGFuZGFibGVUZW1wbGF0ZUNvbXBvbmVudH0gZnJvbSAnLi9ob3VyLXNjaGVkdWxpbmctZXhwYW5kYWJsZS10ZW1wbGF0ZS5jb21wb25lbnQnO1xyXG5cclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgaW1wb3J0czogW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gIF0sXHJcbiAgICBkZWNsYXJhdGlvbnM6IFtcclxuICAgICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlVGVtcGxhdGVDb21wb25lbnRcclxuICAgIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlVGVtcGxhdGVDb21wb25lbnRcclxuICBdLFxyXG4gIHByb3ZpZGVyczogWyBEYXRlUGlwZV1cclxuXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBIb3VyU2NoZWR1bGluZ0V4cGFuZGFibGVUZW1wbGF0ZU1vZHVsZXtcclxufVxyXG4iXX0=
|
package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.component.js
CHANGED
|
@@ -97,6 +97,11 @@ export class HourSchedulingExpandableComponent {
|
|
|
97
97
|
this.currentDraggingObject = obj;
|
|
98
98
|
}
|
|
99
99
|
handleDrop(dragEvent, hour) {
|
|
100
|
+
dragEvent.preventDefault();
|
|
101
|
+
dragEvent.stopPropagation();
|
|
102
|
+
if (!this.schedule[this.objectsProp] || !this.schedule[this.objectsProp].find((object) => { var _a; return object[this.idProp] === this.currentDraggingObject && ((_a = this.currentDraggingObject) === null || _a === void 0 ? void 0 : _a.id); })) {
|
|
103
|
+
this.currentDraggingObject = undefined;
|
|
104
|
+
}
|
|
100
105
|
if (this.currentDraggingObject) {
|
|
101
106
|
//The order was scheduled and needs to be moved
|
|
102
107
|
let start = this.currentDraggingObject.start;
|
|
@@ -114,17 +119,17 @@ export class HourSchedulingExpandableComponent {
|
|
|
114
119
|
scheduledObject.top = this.timeDifference(this.schedule[this.childProp][this.startTimeProp], scheduledObject.start);
|
|
115
120
|
scheduledObject.height = this.timeDifference(scheduledObject.start, scheduledObject.end);
|
|
116
121
|
this.timeChangeEvent.emit(originalObject);
|
|
117
|
-
this.currentDraggingObject = undefined;
|
|
118
122
|
}
|
|
123
|
+
this.currentDraggingObject = undefined;
|
|
119
124
|
}
|
|
120
125
|
else {
|
|
121
126
|
let parsed = this.tryParseJSONObject(dragEvent.dataTransfer.getData("text"));
|
|
122
127
|
if (!parsed) {
|
|
123
128
|
this.newObjectPlanEvent.emit({ currentHour: hour, data: parsed.toString() });
|
|
124
|
-
return;
|
|
125
129
|
}
|
|
126
|
-
|
|
127
|
-
|
|
130
|
+
else {
|
|
131
|
+
this.moveBetweenCalendarsEvent.emit({ hour: hour, data: parsed });
|
|
132
|
+
}
|
|
128
133
|
}
|
|
129
134
|
}
|
|
130
135
|
allowDrop(event, hour) {
|
|
@@ -328,4 +333,4 @@ HourSchedulingExpandableComponent.propDecorators = {
|
|
|
328
333
|
onResize: [{ type: HostListener, args: ['window:resize', ['$event'],] }],
|
|
329
334
|
clickOut: [{ type: HostListener, args: ['document:click', ['$event'],] }]
|
|
330
335
|
};
|
|
331
|
-
//# 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\"\r\n               (dragover)=\"allowDrop($event, hour)\"\r\n               (dragleave)=\"handleDragLeave($event)\"\r\n               (drop)=\"handleDrop($event, hour)\">\r\n          </div>\r\n\r\n          <div class=\"second-half-hour object-half\"\r\n               (dragover)=\"allowDrop($event, addHalfHour(hour))\"\r\n               (dragleave)=\"handleDragLeave($event)\"\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    }\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  @Output() public moveBetweenCalendarsEvent: EventEmitter<{hour: string, data:SchedulingObject}> = new EventEmitter<{hour: string, data:SchedulingObject}>();\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 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\r\n  }\r\n\r\n  // Calculate properties for each scheduled object to determine resizer visibility\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      this.cdRef.markForCheck();\r\n      this.cdRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  public onSelectBlock(obj: SchedulingObject) {\r\n    obj.selected = !obj.selected;\r\n    if(obj.selected) {\r\n      this.scheduledObjects.forEach((scheduledObject: SchedulingObject) => {\r\n        if (scheduledObject.selected && scheduledObject !== obj) {\r\n          scheduledObject.selected = false;\r\n        }\r\n      });\r\n    }\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      if(scheduledObject) {\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\r\n    } else {\r\n\r\n      let parsed: SchedulingObject = this.tryParseJSONObject(dragEvent.dataTransfer!.getData(\"text\"));\r\n\r\n      if (!parsed) {\r\n        this.newObjectPlanEvent.emit({currentHour: hour, data: parsed.toString()});\r\n        return;\r\n      }\r\n\r\n      //Move between calendars is still too buggy\r\n      // this.moveBetweenCalendarsEvent.emit({hour: hour, data: parsed});\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    const target = event.target as HTMLElement;\r\n    if (!target.classList.contains('drag-over')) {\r\n      target.classList.add('drag-over');\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  public handleDragLeave(event: DragEvent): void {\r\n    const target = event.target as HTMLElement;\r\n    if (target.classList.contains('drag-over')) {\r\n      target.classList.remove('drag-over');\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"]}
|
|
336
|
+
//# 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":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EAAE,UAAU,EACrB,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,KAAK,EAEL,MAAM,EAEN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAgEvB,MAAM,OAAO,iCAAiC;IA6D5C,YACU,KAAwB,EACxB,IAAgB;QADhB,UAAK,GAAL,KAAK,CAAmB;QACxB,SAAI,GAAJ,IAAI,CAAY;QA7DnB,eAAU,GAAa,EAAE,CAAC;QAC1B,qBAAgB,GAAuB,EAAE,CAAC;QAGzC,aAAQ,GAAY,KAAK,CAAC;QAK1B,0BAAqB,GAA4B,IAAI,CAAC;QACtD,0BAAqB,GAA4B,IAAI,CAAC;QACtD,eAAU,GAAG,EAAE,CAAC;QAChB,cAAS,GAAW,EAAE,CAAC;QAuBd,oBAAe,GAAyB,IAAI,YAAY,EAAU,CAAC;QACnE,uBAAkB,GAAwD,IAAI,YAAY,EAGvG,CAAC;QAEY,8BAAyB,GAAwD,IAAI,YAAY,EAAyC,CAAC;QAGrJ,cAAS,GAAY,IAAI,CAAC;IAmBjC,CAAC;IAhDD,IAAoB,QAAQ,CAAE,KAAa;QACzC,IAAG,KAAK,IAAI,KAAK,KAAK,IAAI,CAAC,SAAS,EAAE;YACpC,IAAI,CAAC,aAAa,EAAE,CAAC;SAEtB;QACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAsBM,QAAQ,CAAC,KAAwC;QACtD,KAAK,CAAC,MAAM,CAAC,UAAU,CAAC;IAC1B,CAAC;IAGM,QAAQ,CAAC,KAAuB;QACrC,IAAG,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE;YAClD,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;IACH,CAAC;IASD,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAG,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IAIH,CAAC;IAED,iFAAiF;IAGjF,oDAAoD;IAC5C,eAAe,CAAC,aAA+B;QACrD,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClE,IAAI,YAAY,IAAI,CAAC,IAAI,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;YACxE,OAAO,IAAI,CAAC,gBAAgB,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,8BAA8B;SAC/E;QACD,OAAO,IAAI,CAAC,CAAC,qCAAqC;IACpD,CAAC;IAED,wDAAwD;IAChD,mBAAmB,CAAC,aAA+B;QACzD,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAClE,IAAI,YAAY,GAAG,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC,gBAAgB,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,kCAAkC;SACnF;QACD,OAAO,IAAI,CAAC,CAAC,0CAA0C;IACzD,CAAC;IAGM,aAAa;QAClB,IAAG,IAAI,CAAC,QAAQ,EAAE;YAChB,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE;gBACpC,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;aAC5B;YACD,IAAI,OAAO,GAAa,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;YAExD,IAAI,iBAAiB,GAAuB,EAAE,CAAC;YAG/C,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;oBACvB,IAAI,aAAa,GAAW,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;oBAC/H,iBAAiB,CAAC,IAAI,CACpB;wBACE,KAAK,EAAE,MAAM,CAAC,OAAO,CAAC;wBACtB,QAAQ,EAAE,MAAM,CAAC,UAAU,CAAC;wBAE5B,KAAK,EAAE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;wBAC7D,GAAG,EAAE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBACzD,EAAE,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;wBACvB,MAAM,EAAE,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;wBACjF,GAAG,EAAE,aAAa;wBAClB,QAAQ,EAAE,KAAK;qBAChB,CAAC,CAAC;gBACP,CAAC,CAAC,CAAC;aACJ;YAED,IAAI,CAAC,gBAAgB,GAAG,iBAAiB,CAAC;YAE1C,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;YAC1B,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;SAC5B;IACH,CAAC;IAEM,aAAa,CAAC,GAAqB;QACxC,GAAG,CAAC,QAAQ,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC;QAC7B,IAAG,GAAG,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,eAAiC,EAAE,EAAE;gBAClE,IAAI,eAAe,CAAC,QAAQ,IAAI,eAAe,KAAK,GAAG,EAAE;oBACvD,eAAe,CAAC,QAAQ,GAAG,KAAK,CAAC;iBAClC;YACH,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,qBAAqB,GAAG,GAAG,CAAC;IACnC,CAAC;IAEM,iBAAiB,CAAC,GAAqB;QAC5C,IAAI,CAAC,qBAAqB,GAAG,GAAG,CAAC;IACnC,CAAC;IAGM,UAAU,CAAC,SAAoB,EAAE,IAAY;QAClD,SAAS,CAAC,cAAc,EAAE,CAAC;QAC3B,SAAS,CAAC,eAAe,EAAE,CAAC;QAE5B,IAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,MAAc,EAAE,EAAE,WAAC,OAAA,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,qBAAqB,KAAI,MAAA,IAAI,CAAC,qBAAqB,0CAAE,EAAE,CAAA,CAAA,EAAA,CAAC,EAAE;YACtL,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;SACxC;QAED,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,+CAA+C;YAE/C,IAAI,KAAK,GAAS,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC;YACnD,IAAI,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAA;YAC/B,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACzC,IAAI,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAE,eAAe,CAAC,EAAE,CAAC,eAAe,CAAC,EAAE,KAAK,IAAI,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;YAC3H,IAAG,eAAe,EAAE;gBAClB,eAAe,CAAC,KAAK,GAAG,KAAK,CAAC;gBAE9B,IAAI,cAAc,GAAW,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,MAAc,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;gBAC7I,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC;gBAC3C,IAAI,GAAG,GAAS,IAAI,CAAC,UAAU,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;gBACvG,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC;gBACvC,eAAe,CAAC,GAAG,GAAG,GAAG,CAAC;gBAC1B,eAAe,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,eAAe,CAAC,KAAK,CAAC,CAAC;gBACpH,eAAe,CAAC,MAAM,GAAG,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,KAAK,EAAE,eAAe,CAAC,GAAG,CAAC,CAAC;gBAEzF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;aAC3C;YACD,IAAI,CAAC,qBAAqB,GAAG,SAAS,CAAC;SACxC;aAAM;YAEL,IAAI,MAAM,GAAqB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,YAAa,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC;YAEhG,IAAI,CAAC,MAAM,EAAE;gBACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAC,CAAC,CAAC;aAC5E;iBAAM;gBACL,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAC,CAAC,CAAC;aACjE;SACF;IACH,CAAC;IAGM,SAAS,CAAC,KAAgB,EAAE,IAAY;QAC7C,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;YAC3C,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;SACnC;QACD,IAAG,IAAI,CAAC,qBAAqB,EAAE;YAC7B,IAAI,YAAY,GAAS,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;YACtF,IAAI,SAAS,GAAa,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC1C,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC9C,YAAY,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE9C,IAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAE,CAAC,eAAiC,EAAE,EAAE,CAAC,eAAe,CAAC,KAAK,KAAK,YAAY,CAAE,EAAE;gBAC9G,OAAO,KAAK,CAAC;aACd;iBAAM;gBACL,OAAO,IAAI,CAAC;aACb;SACF;IAEH,CAAC;IACM,eAAe,CAAC,KAAgB;QACrC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;QAC3C,IAAI,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE;YAC1C,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;SACtC;IACH,CAAC;IACD,iCAAiC;IAE1B,aAAa,CAAC,KAAiB,EAAE,GAAqB,EAAE,SAA2B;QACxF,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;QACjC,IAAI,CAAC,qBAAqB,GAAG,GAAG,CAAC;QACjC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC,MAAM,IAAI,CAAC,CAAC;QACrC,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QAE/B,kDAAkD;QAClD,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACnE,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACpE,CAAC;IACD,kFAAkF;IAE3E,UAAU,CAAC,KAAiB;QACjC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,qBAAqB;YAAE,OAAO;QAE1D,MAAM,MAAM,GAAG,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;QAC7C,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,EAAE,CAAC,GAAG,EAAE,CAAC;QAEnD,IAAI,IAAI,CAAC,eAAe,KAAK,QAAQ,EAAE;YACrC,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACpE,MAAM,SAAS,GAAG,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC;YAE1F,kEAAkE;YAClE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAChF,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;SAEpE;aAAM,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE;YACzC,MAAM,cAAc,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;YAC5E,MAAM,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC,GAAG,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YAE/E,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,aAAa,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YAChF,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,CAAC;YAElE,iFAAiF;YACjF,IAAI,SAAS,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,IAAI,MAAM,EAAE;gBACpD,IAAI,CAAC,qBAAqB,CAAC,GAAG,GAAG,MAAM,CAAC;gBACxC,IAAI,CAAC,qBAAqB,CAAC,MAAM,GAAG,SAAS,CAAC;aAC/C;SACF;QAED,kCAAkC;QAClC,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IACD,+BAA+B;IAExB,WAAW,CAAC,KAAiB;QAClC,IAAI,MAAM,GAAqB,IAAI,CAAC,qBAAqB,CAAC;QAE1D,IAAG,MAAM,IAAI,MAAM,CAAC,QAAQ,EAAE;YAC5B,IAAI,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,CAAC,eAAuB,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,MAAM,CAAC,EAAE,CAAC,CAAC;YAEnI,IAAI,cAAc,EAAE;gBAClB,+BAA+B;gBAC/B,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;gBAEhJ,+DAA+D;gBAC/D,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;aAEnI;YACD,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAE1C,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,qBAAqB,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC5C,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;SAGnC;QAGD,gCAAgC;QAChC,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACtE,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACvE,CAAC;IAEM,cAAc,CAAC,KAAW,EAAE,KAAW;QAC5C,IAAI,UAAU,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC;QACzH,OAAO,IAAI,CAAC,GAAG,CAAC,UAAU,GAAG,EAAE,CAAC,CAAC;IACnC,CAAC;IAGM,kBAAkB;QACvB,IAAI,SAAS,GAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACpO,IAAI,OAAO,GAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;QAE9N,IAAI,QAAQ,GAAG,EAAE,GAAG,EAAE,CAAC;QAEvB,KAAK,IAAI,SAAS,GAAG,SAAS,EAAE,SAAS,IAAI,OAAO,EAAE,SAAS,IAAI,QAAQ,EAAE;YAC3E,IAAI,IAAI,GAAG,IAAI,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,CAAA;YACrC,IAAI,UAAU,GAAG,GAAG,IAAI,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YAC5F,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAClC;IACH,CAAC;IAEM,eAAe,CAAC,IAAU;QAC/B,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC;IAC3C,CAAC;IAEM,UAAU,CAAC,IAAU,EAAE,OAAe;QAC3C,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,GAAG,OAAO,GAAG,KAAK,CAAC,CAAC;IACpD,CAAC;IAEM,kBAAkB,CAAC,UAAkB;QAC1C,IAAI;YACF,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;YAC/B,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE;gBAC9B,OAAO,CAAC,CAAC;aACV;SACF;QAAC,OAAO,CAAC,EAAE;SACX;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,WAAW,CAAC,IAAY;QAC7B,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC5B,KAAK,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC;QAChB,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC;IAEM,SAAS,CAAC,IAAI,EAAE,QAAQ;QAC7B,OAAO,IAAI,IAAI,CAAC,CAAC,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,OAAO,EAAE,EAAC,QAAQ,EAAE,QAAQ,EAAC,CAAC,CAAC,CAAC;IACpH,CAAC;IAEM,qBAAqB,CAAC,IAAU;QACrC,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,kBAAkB,CAAC,CAAA;IACjD,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAE,CAAC,eAAiC,EAAE,EAAE;YACnE,IAAG,eAAe,CAAC,QAAQ,EAAE;gBAC3B,eAAe,CAAC,QAAQ,GAAG,KAAK,CAAC;aAClC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;;;YAnZF,SAAS,SAAC;gBACT,QAAQ,EAAE,+BAA+B;gBACzC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCT;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAzEC,iBAAiB;YACN,UAAU;;;uBA0FpB,KAAK;4BAaL,KAAK;0BACL,KAAK;0BACL,KAAK;wBACL,KAAK;6BACL,KAAK;qBACL,KAAK;8BAEL,MAAM;iCACN,MAAM;wCAKN,MAAM;wBAEN,WAAW,SAAC,qCAAqC;uBAGjD,YAAY,SAAC,eAAe,EAAE,CAAC,QAAQ,CAAC;uBAKxC,YAAY,SAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","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\"\r\n               (dragover)=\"allowDrop($event, hour)\"\r\n               (dragleave)=\"handleDragLeave($event)\"\r\n               (drop)=\"handleDrop($event, hour)\">\r\n          </div>\r\n\r\n          <div class=\"second-half-hour object-half\"\r\n               (dragover)=\"allowDrop($event, addHalfHour(hour))\"\r\n               (dragleave)=\"handleDragLeave($event)\"\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    }\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  @Output() public moveBetweenCalendarsEvent: EventEmitter<{hour: string, data:SchedulingObject}> = new EventEmitter<{hour: string, data:SchedulingObject}>();\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 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\r\n  }\r\n\r\n  // Calculate properties for each scheduled object to determine resizer visibility\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      this.cdRef.markForCheck();\r\n      this.cdRef.detectChanges();\r\n    }\r\n  }\r\n\r\n  public onSelectBlock(obj: SchedulingObject) {\r\n    obj.selected = !obj.selected;\r\n    if(obj.selected) {\r\n      this.scheduledObjects.forEach((scheduledObject: SchedulingObject) => {\r\n        if (scheduledObject.selected && scheduledObject !== obj) {\r\n          scheduledObject.selected = false;\r\n        }\r\n      });\r\n    }\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    dragEvent.preventDefault();\r\n    dragEvent.stopPropagation();\r\n\r\n    if(!this.schedule[this.objectsProp] || !this.schedule[this.objectsProp].find((object: Object) => object[this.idProp] === this.currentDraggingObject && this.currentDraggingObject?.id)) {\r\n      this.currentDraggingObject = undefined;\r\n    }\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      if(scheduledObject) {\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      }\r\n      this.currentDraggingObject = undefined;\r\n    } else {\r\n\r\n      let parsed: SchedulingObject = this.tryParseJSONObject(dragEvent.dataTransfer!.getData(\"text\"));\r\n\r\n      if (!parsed) {\r\n        this.newObjectPlanEvent.emit({currentHour: hour, data: parsed.toString()});\r\n      } else {\r\n        this.moveBetweenCalendarsEvent.emit({hour: hour, data: parsed});\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    const target = event.target as HTMLElement;\r\n    if (!target.classList.contains('drag-over')) {\r\n      target.classList.add('drag-over');\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  public handleDragLeave(event: DragEvent): void {\r\n    const target = event.target as HTMLElement;\r\n    if (target.classList.contains('drag-over')) {\r\n      target.classList.remove('drag-over');\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"]}
|
package/esm2015/lib/components/hour-scheduling-expandable/hour-scheduling-expandable.module.js
CHANGED
|
@@ -2,7 +2,7 @@ import { NgModule } from "@angular/core";
|
|
|
2
2
|
import { CommonModule, DatePipe } from "@angular/common";
|
|
3
3
|
import { HourSchedulingExpandableComponent } from "./hour-scheduling-expandable.component";
|
|
4
4
|
import { HourSchedulingComponentModule } from "../hour-scheduling/hour-scheduling.module";
|
|
5
|
-
import {
|
|
5
|
+
import { HourSchedulingExpandableTemplateModule } from './components/hour-scheduling-expandable-template/hour-scheduling-expandable-template.module';
|
|
6
6
|
export class HourSchedulingExpandableComponentModule {
|
|
7
7
|
}
|
|
8
8
|
HourSchedulingExpandableComponentModule.decorators = [
|
|
@@ -10,16 +10,15 @@ HourSchedulingExpandableComponentModule.decorators = [
|
|
|
10
10
|
imports: [
|
|
11
11
|
CommonModule,
|
|
12
12
|
HourSchedulingComponentModule,
|
|
13
|
+
HourSchedulingExpandableTemplateModule
|
|
13
14
|
],
|
|
14
15
|
declarations: [
|
|
15
16
|
HourSchedulingExpandableComponent,
|
|
16
|
-
HourSchedulingExpandableTemplateComponent
|
|
17
17
|
],
|
|
18
18
|
exports: [
|
|
19
19
|
HourSchedulingExpandableComponent,
|
|
20
|
-
HourSchedulingExpandableTemplateComponent
|
|
21
20
|
],
|
|
22
21
|
providers: [DatePipe]
|
|
23
22
|
},] }
|
|
24
23
|
];
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlL2hvdXItc2NoZWR1bGluZy1leHBhbmRhYmxlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUUsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLGlDQUFpQyxFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDekYsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sMkNBQTJDLENBQUM7QUFDeEYsT0FBTyxFQUFDLHNDQUFzQyxFQUFDLE1BQU0sNkZBQTZGLENBQUM7QUFtQm5KLE1BQU0sT0FBTyx1Q0FBdUM7OztZQWZuRCxRQUFRLFNBQUM7Z0JBQ1IsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osNkJBQTZCO29CQUM3QixzQ0FBc0M7aUJBQ3ZDO2dCQUNDLFlBQVksRUFBRTtvQkFDVixpQ0FBaUM7aUJBQ3BDO2dCQUNILE9BQU8sRUFBRTtvQkFDUCxpQ0FBaUM7aUJBQ2xDO2dCQUNELFNBQVMsRUFBRSxDQUFFLFFBQVEsQ0FBQzthQUV2QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlLCBEYXRlUGlwZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge0hvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZUNvbXBvbmVudH0gZnJvbSBcIi4vaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7SG91clNjaGVkdWxpbmdDb21wb25lbnRNb2R1bGV9IGZyb20gXCIuLi9ob3VyLXNjaGVkdWxpbmcvaG91ci1zY2hlZHVsaW5nLm1vZHVsZVwiO1xyXG5pbXBvcnQge0hvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZVRlbXBsYXRlTW9kdWxlfSBmcm9tICcuL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUvaG91ci1zY2hlZHVsaW5nLWV4cGFuZGFibGUtdGVtcGxhdGUubW9kdWxlJztcclxuXHJcblxyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBIb3VyU2NoZWR1bGluZ0NvbXBvbmVudE1vZHVsZSxcclxuICAgIEhvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZVRlbXBsYXRlTW9kdWxlXHJcbiAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIEhvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZUNvbXBvbmVudCxcclxuICAgIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgSG91clNjaGVkdWxpbmdFeHBhbmRhYmxlQ29tcG9uZW50LFxyXG4gIF0sXHJcbiAgcHJvdmlkZXJzOiBbIERhdGVQaXBlXVxyXG5cclxufSlcclxuZXhwb3J0IGNsYXNzIEhvdXJTY2hlZHVsaW5nRXhwYW5kYWJsZUNvbXBvbmVudE1vZHVsZXtcclxufVxyXG4iXX0=
|
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
2
|
import { CoreComponentsIcon } from "../../core/enum/core-components-icon.enum";
|
|
3
3
|
import { IconCacheService } from "../icon/icon-cache.service";
|
|
4
|
-
import { BatchDeliveryCategory } from '../../core/enum/batch-delivery-category.enum';
|
|
5
4
|
export class ListOfIconsComponent {
|
|
6
|
-
constructor(
|
|
7
|
-
this.iconCacheService = iconCacheService;
|
|
5
|
+
constructor(icons) {
|
|
8
6
|
this.icons = icons;
|
|
9
7
|
this.iconSize = 25;
|
|
10
8
|
this.itemSelected = new EventEmitter();
|
|
@@ -12,10 +10,6 @@ export class ListOfIconsComponent {
|
|
|
12
10
|
this.showMenu = false;
|
|
13
11
|
this.showSubCategories = false;
|
|
14
12
|
this._collection = [];
|
|
15
|
-
this.subCategories = [
|
|
16
|
-
{ icon: this.iconCacheService.getIcon(this.Icon.BoxesPackingRegular), label: BatchDeliveryCategory.ToPick },
|
|
17
|
-
{ icon: this.iconCacheService.getIcon(this.Icon.RegularBoxesPackingCircleCheck), label: BatchDeliveryCategory.Picked }
|
|
18
|
-
];
|
|
19
13
|
}
|
|
20
14
|
set collection(value) {
|
|
21
15
|
this._collection = value || [];
|
|
@@ -36,7 +30,7 @@ export class ListOfIconsComponent {
|
|
|
36
30
|
this.showMenu = !this.showMenu;
|
|
37
31
|
}
|
|
38
32
|
selectItem(item) {
|
|
39
|
-
if (item.
|
|
33
|
+
if (item.children) {
|
|
40
34
|
this.showSubCategories = !this.showSubCategories;
|
|
41
35
|
return;
|
|
42
36
|
}
|
|
@@ -45,8 +39,9 @@ export class ListOfIconsComponent {
|
|
|
45
39
|
this.itemSelected.emit(this.activeItem);
|
|
46
40
|
}
|
|
47
41
|
handlePickingCategoryClicked(subCategory) {
|
|
48
|
-
this.
|
|
42
|
+
this.activeItem = subCategory;
|
|
49
43
|
this.showMenu = false;
|
|
44
|
+
this.itemSelected.emit(subCategory);
|
|
50
45
|
this.showSubCategories = false;
|
|
51
46
|
}
|
|
52
47
|
onClickOutside() {
|
|
@@ -58,35 +53,37 @@ ListOfIconsComponent.decorators = [
|
|
|
58
53
|
{ type: Component, args: [{
|
|
59
54
|
selector: 'co-list-of-icons',
|
|
60
55
|
template: `
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
</div>
|
|
66
|
-
<div class="dropdown-menu" *ngIf="showMenu" (clickOutside)="onClickOutside()">
|
|
67
|
-
<div class="icon-item" *ngFor="let item of collection" (click)="selectItem(item)"
|
|
68
|
-
[class.active]="item === activeItem">
|
|
69
|
-
<co-icon [iconData]="item.icon" [style.width.px]="iconSize" [style.height.px]="iconSize"></co-icon>
|
|
70
|
-
<div class="label" [textContent]="item.label | coreLocalize"></div>
|
|
56
|
+
<div class="icon-item active" [class.menu-opened]="showMenu" (click)="toggleMenu()">
|
|
57
|
+
<co-icon [iconData]="activeItem.icon" [style.width.px]="iconSize" [style.height.px]="iconSize"></co-icon>
|
|
58
|
+
<co-icon *ngIf="!showMenu" class="drop-arrow" [iconData]="icons.getIcon(Icon.CaretDownSolid)"></co-icon>
|
|
59
|
+
<co-icon *ngIf="showMenu" class="drop-arrow" [iconData]="icons.getIcon(Icon.CaretUpSolid)"></co-icon>
|
|
71
60
|
</div>
|
|
72
|
-
<div class="
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
61
|
+
<div class="dropdown-menu" *ngIf="showMenu" (clickOutside)="onClickOutside()">
|
|
62
|
+
<div class="icon-item" *ngFor="let item of collection" (click)="selectItem(item)"
|
|
63
|
+
[class.active]="item === activeItem">
|
|
64
|
+
<co-icon [iconData]="item.icon" [style.width.px]="iconSize" [style.height.px]="iconSize"></co-icon>
|
|
65
|
+
<div class="label" [textContent]="item.label | coreLocalize"></div>
|
|
66
|
+
<div class="picking-type-wrapper" *ngIf="showSubCategories && item.children?.length > 0">
|
|
67
|
+
<div
|
|
68
|
+
class="button-wrapper"
|
|
69
|
+
*ngFor="let subCategory of item.children"
|
|
70
|
+
(click)="handlePickingCategoryClicked(subCategory)">
|
|
71
|
+
<co-icon
|
|
72
|
+
class="co-transaction-button-bar-icon"
|
|
73
|
+
[iconData]="subCategory.icon"
|
|
74
|
+
[style.width.px]="iconSize"
|
|
75
|
+
[style.height.px]="iconSize">
|
|
76
|
+
</co-icon>
|
|
77
|
+
<span class="button-title" [textContent]="subCategory.label | coreLocalize"></span>
|
|
78
|
+
</div>
|
|
79
|
+
</div>
|
|
80
|
+
</div>
|
|
82
81
|
</div>
|
|
83
|
-
</div>
|
|
84
82
|
`,
|
|
85
83
|
encapsulation: ViewEncapsulation.None
|
|
86
84
|
},] }
|
|
87
85
|
];
|
|
88
86
|
ListOfIconsComponent.ctorParameters = () => [
|
|
89
|
-
{ type: IconCacheService },
|
|
90
87
|
{ type: IconCacheService }
|
|
91
88
|
];
|
|
92
89
|
ListOfIconsComponent.propDecorators = {
|
|
@@ -96,4 +93,4 @@ ListOfIconsComponent.propDecorators = {
|
|
|
96
93
|
itemSelected: [{ type: Output }],
|
|
97
94
|
showClass: [{ type: HostBinding, args: ['class.co-list-of-icons',] }]
|
|
98
95
|
};
|
|
99
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdC1vZi1pY29ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvbGlzdC1vZi1pY29ucy9saXN0LW9mLWljb25zLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM3RyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQW1DNUQsTUFBTSxPQUFPLG9CQUFvQjtJQThCL0IsWUFDUyxLQUF1QjtRQUF2QixVQUFLLEdBQUwsS0FBSyxDQUFrQjtRQW5CekIsYUFBUSxHQUFXLEVBQUUsQ0FBQztRQU10QixpQkFBWSxHQUErQixJQUFJLFlBQVksRUFBZ0IsQ0FBQztRQU9uRSxTQUFJLEdBQVEsa0JBQWtCLENBQUM7UUFDeEMsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUMxQixzQkFBaUIsR0FBWSxLQUFLLENBQUM7UUFDbEMsZ0JBQVcsR0FBbUIsRUFBRSxDQUFDO0lBS3pDLENBQUM7SUFoQ0QsSUFDVyxVQUFVLENBQUMsS0FBcUI7UUFDekMsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLElBQUksRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsSUFBVyxVQUFVO1FBQ25CLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUMxQixDQUFDO0lBWU0sU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQztJQVlNLFFBQVE7UUFDYixJQUFJLElBQUksQ0FBQyxVQUFVLEtBQUssU0FBUyxFQUFFO1lBQ2pDLElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUN0QztJQUNILENBQUM7SUFFTSxVQUFVO1FBQ2YsSUFBSSxDQUFDLFFBQVEsR0FBRyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDakMsQ0FBQztJQUVNLFVBQVUsQ0FBQyxJQUFrQjtRQUNsQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUU7WUFDakIsSUFBSSxDQUFDLGlCQUFpQixHQUFHLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDO1lBQ2pELE9BQU87U0FDUjtRQUVELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBRU0sNEJBQTRCLENBQUMsV0FBeUI7UUFDM0QsSUFBSSxDQUFDLFVBQVUsR0FBRyxXQUFXLENBQUM7UUFDOUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDdEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLEtBQUssQ0FBQztJQUNqQyxDQUFDO0lBRU0sY0FBYztRQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssQ0FBQztRQUN0QixJQUFJLENBQUMsaUJBQWlCLEdBQUcsS0FBSyxDQUFDO0lBQ2pDLENBQUM7OztZQWxHRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLGtCQUFrQjtnQkFDNUIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0EyQlQ7Z0JBQ0QsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7YUFDdEM7OztZQWxDTyxnQkFBZ0I7Ozt5QkFvQ3JCLEtBQUs7dUJBVUwsS0FBSzt5QkFHTCxLQUFLOzJCQUdMLE1BQU07d0JBR04sV0FBVyxTQUFDLHdCQUF3QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIEhvc3RCaW5kaW5nLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQsIFZpZXdFbmNhcHN1bGF0aW9ufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvcmVDb21wb25lbnRzSWNvbn0gZnJvbSBcIi4uLy4uL2NvcmUvZW51bS9jb3JlLWNvbXBvbmVudHMtaWNvbi5lbnVtXCI7XHJcbmltcG9ydCB7SWNvbkNhY2hlU2VydmljZX0gZnJvbSBcIi4uL2ljb24vaWNvbi1jYWNoZS5zZXJ2aWNlXCI7XHJcbmltcG9ydCB7SWNvbkxpc3RJdGVtfSBmcm9tIFwiLi4vLi4vbW9kZWwvaWNvbi1saXN0LWl0ZW1cIjtcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY28tbGlzdC1vZi1pY29ucycsXHJcbiAgdGVtcGxhdGU6IGBcclxuICAgICAgPGRpdiBjbGFzcz1cImljb24taXRlbSBhY3RpdmVcIiBbY2xhc3MubWVudS1vcGVuZWRdPVwic2hvd01lbnVcIiAoY2xpY2spPVwidG9nZ2xlTWVudSgpXCI+XHJcbiAgICAgICAgICA8Y28taWNvbiBbaWNvbkRhdGFdPVwiYWN0aXZlSXRlbS5pY29uXCIgW3N0eWxlLndpZHRoLnB4XT1cImljb25TaXplXCIgW3N0eWxlLmhlaWdodC5weF09XCJpY29uU2l6ZVwiPjwvY28taWNvbj5cclxuICAgICAgICAgIDxjby1pY29uICpuZ0lmPVwiIXNob3dNZW51XCIgY2xhc3M9XCJkcm9wLWFycm93XCIgW2ljb25EYXRhXT1cImljb25zLmdldEljb24oSWNvbi5DYXJldERvd25Tb2xpZClcIj48L2NvLWljb24+XHJcbiAgICAgICAgICA8Y28taWNvbiAqbmdJZj1cInNob3dNZW51XCIgY2xhc3M9XCJkcm9wLWFycm93XCIgW2ljb25EYXRhXT1cImljb25zLmdldEljb24oSWNvbi5DYXJldFVwU29saWQpXCI+PC9jby1pY29uPlxyXG4gICAgICA8L2Rpdj5cclxuICAgICAgPGRpdiBjbGFzcz1cImRyb3Bkb3duLW1lbnVcIiAqbmdJZj1cInNob3dNZW51XCIgKGNsaWNrT3V0c2lkZSk9XCJvbkNsaWNrT3V0c2lkZSgpXCI+XHJcbiAgICAgICAgICA8ZGl2IGNsYXNzPVwiaWNvbi1pdGVtXCIgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29sbGVjdGlvblwiIChjbGljayk9XCJzZWxlY3RJdGVtKGl0ZW0pXCJcclxuICAgICAgICAgICAgICAgW2NsYXNzLmFjdGl2ZV09XCJpdGVtID09PSBhY3RpdmVJdGVtXCI+XHJcbiAgICAgICAgICAgICAgPGNvLWljb24gW2ljb25EYXRhXT1cIml0ZW0uaWNvblwiIFtzdHlsZS53aWR0aC5weF09XCJpY29uU2l6ZVwiIFtzdHlsZS5oZWlnaHQucHhdPVwiaWNvblNpemVcIj48L2NvLWljb24+XHJcbiAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImxhYmVsXCIgW3RleHRDb250ZW50XT1cIml0ZW0ubGFiZWwgfCBjb3JlTG9jYWxpemVcIj48L2Rpdj5cclxuICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicGlja2luZy10eXBlLXdyYXBwZXJcIiAqbmdJZj1cInNob3dTdWJDYXRlZ29yaWVzICYmIGl0ZW0uY2hpbGRyZW4/Lmxlbmd0aCA+IDBcIj5cclxuICAgICAgICAgICAgICAgICAgPGRpdlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiYnV0dG9uLXdyYXBwZXJcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICpuZ0Zvcj1cImxldCBzdWJDYXRlZ29yeSBvZiBpdGVtLmNoaWxkcmVuXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwiaGFuZGxlUGlja2luZ0NhdGVnb3J5Q2xpY2tlZChzdWJDYXRlZ29yeSlcIj5cclxuICAgICAgICAgICAgICAgICAgICAgIDxjby1pY29uXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsYXNzPVwiY28tdHJhbnNhY3Rpb24tYnV0dG9uLWJhci1pY29uXCJcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgW2ljb25EYXRhXT1cInN1YkNhdGVnb3J5Lmljb25cIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUud2lkdGgucHhdPVwiaWNvblNpemVcIlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICBbc3R5bGUuaGVpZ2h0LnB4XT1cImljb25TaXplXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICA8L2NvLWljb24+XHJcbiAgICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImJ1dHRvbi10aXRsZVwiIFt0ZXh0Q29udGVudF09XCJzdWJDYXRlZ29yeS5sYWJlbCB8IGNvcmVMb2NhbGl6ZVwiPjwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICA8L2Rpdj5cclxuICAgICAgPC9kaXY+XHJcbiAgYCxcclxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgTGlzdE9mSWNvbnNDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNldCBjb2xsZWN0aW9uKHZhbHVlOiBJY29uTGlzdEl0ZW1bXSkge1xyXG4gICAgdGhpcy5fY29sbGVjdGlvbiA9IHZhbHVlIHx8IFtdO1xyXG4gICAgdGhpcy5hY3RpdmVJdGVtID0gdGhpcy5jb2xsZWN0aW9uWzBdO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBjb2xsZWN0aW9uKCk6IEljb25MaXN0SXRlbVtdIHtcclxuICAgIHJldHVybiB0aGlzLl9jb2xsZWN0aW9uO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaWNvblNpemU6IG51bWJlciA9IDI1O1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBhY3RpdmVJdGVtPzogSWNvbkxpc3RJdGVtO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgaXRlbVNlbGVjdGVkOiBFdmVudEVtaXR0ZXI8SWNvbkxpc3RJdGVtPiA9IG5ldyBFdmVudEVtaXR0ZXI8SWNvbkxpc3RJdGVtPigpO1xyXG5cclxuICBASG9zdEJpbmRpbmcoJ2NsYXNzLmNvLWxpc3Qtb2YtaWNvbnMnKVxyXG4gIHB1YmxpYyBzaG93Q2xhc3MoKSB7XHJcbiAgICByZXR1cm4gdHJ1ZTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyByZWFkb25seSBJY29uOiBhbnkgPSBDb3JlQ29tcG9uZW50c0ljb247XHJcbiAgcHVibGljIHNob3dNZW51OiBib29sZWFuID0gZmFsc2U7XHJcbiAgcHVibGljIHNob3dTdWJDYXRlZ29yaWVzOiBib29sZWFuID0gZmFsc2U7XHJcbiAgcHJpdmF0ZSBfY29sbGVjdGlvbjogSWNvbkxpc3RJdGVtW10gPSBbXTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgaWNvbnM6IEljb25DYWNoZVNlcnZpY2VcclxuICApIHtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIGlmICh0aGlzLmFjdGl2ZUl0ZW0gPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICB0aGlzLmFjdGl2ZUl0ZW0gPSB0aGlzLmNvbGxlY3Rpb25bMF07XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgdG9nZ2xlTWVudSgpOiB2b2lkIHtcclxuICAgIHRoaXMuc2hvd01lbnUgPSAhdGhpcy5zaG93TWVudTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBzZWxlY3RJdGVtKGl0ZW06IEljb25MaXN0SXRlbSk6IHZvaWQge1xyXG4gICAgaWYgKGl0ZW0uY2hpbGRyZW4pIHtcclxuICAgICAgdGhpcy5zaG93U3ViQ2F0ZWdvcmllcyA9ICF0aGlzLnNob3dTdWJDYXRlZ29yaWVzO1xyXG4gICAgICByZXR1cm47XHJcbiAgICB9XHJcblxyXG4gICAgdGhpcy5hY3RpdmVJdGVtID0gaXRlbTtcclxuICAgIHRoaXMuc2hvd01lbnUgPSBmYWxzZTtcclxuICAgIHRoaXMuaXRlbVNlbGVjdGVkLmVtaXQodGhpcy5hY3RpdmVJdGVtKTtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBoYW5kbGVQaWNraW5nQ2F0ZWdvcnlDbGlja2VkKHN1YkNhdGVnb3J5OiBJY29uTGlzdEl0ZW0pOiB2b2lkIHtcclxuICAgIHRoaXMuYWN0aXZlSXRlbSA9IHN1YkNhdGVnb3J5O1xyXG4gICAgdGhpcy5zaG93TWVudSA9IGZhbHNlO1xyXG4gICAgdGhpcy5pdGVtU2VsZWN0ZWQuZW1pdChzdWJDYXRlZ29yeSk7XHJcbiAgICB0aGlzLnNob3dTdWJDYXRlZ29yaWVzID0gZmFsc2U7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgb25DbGlja091dHNpZGUoKTogdm9pZCB7XHJcbiAgICB0aGlzLnNob3dNZW51ID0gZmFsc2U7XHJcbiAgICB0aGlzLnNob3dTdWJDYXRlZ29yaWVzID0gZmFsc2U7XHJcbiAgfVxyXG59XHJcbiJdfQ==
|