@colijnit/corecomponents_v12 255.1.6 → 255.1.7
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 +55 -18
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/hour-scheduling/hour-scheduling.component.js +76 -29
- package/esm2015/lib/components/hour-scheduling/hour-scheduling.module.js +4 -3
- package/fesm2015/colijnit-corecomponents_v12.js +76 -29
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/hour-scheduling/hour-scheduling.component.d.ts +14 -4
- package/package.json +1 -1
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { Component, Input, HostBinding, ViewEncapsulation, ChangeDetectorRef } from '@angular/core';
|
|
1
|
+
import { Component, Input, HostBinding, ViewEncapsulation, ChangeDetectorRef, } from '@angular/core';
|
|
2
|
+
import { DatePipe } from '@angular/common';
|
|
2
3
|
export class HourSchedulingComponent {
|
|
3
|
-
constructor(cdRef) {
|
|
4
|
+
constructor(cdRef, _datepipe) {
|
|
4
5
|
this.cdRef = cdRef;
|
|
6
|
+
this._datepipe = _datepipe;
|
|
5
7
|
this.showClass = true;
|
|
6
8
|
this.customTemplateUsed = false;
|
|
7
9
|
this.hours = [];
|
|
@@ -9,21 +11,27 @@ export class HourSchedulingComponent {
|
|
|
9
11
|
this.draggedObject = null;
|
|
10
12
|
}
|
|
11
13
|
ngOnInit() {
|
|
14
|
+
if (!this.childProp) {
|
|
15
|
+
this.startTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.startTimeProp]).toISOString(), 'H:mm'));
|
|
16
|
+
this.endTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.endTimeProp]).toISOString(), 'H:mm'));
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
this.startTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.childProp][this.startTimeProp]).toISOString(), 'H:mm'));
|
|
20
|
+
this.endTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.childProp][this.endTimeProp]).toISOString(), 'H:mm'));
|
|
21
|
+
}
|
|
12
22
|
this.generateTimeBlocks();
|
|
13
23
|
}
|
|
14
24
|
generateTimeBlocks() {
|
|
15
|
-
const startTime = this.schedule[this.startTimeProp];
|
|
16
|
-
const endTime = this.schedule[this.endTimeProp];
|
|
17
25
|
const objectsList = this.schedule[this.objectsProp];
|
|
18
|
-
for (let hour = startTime; hour <= endTime; hour++) {
|
|
26
|
+
for (let hour = this.startTime; hour <= this.endTime; hour++) {
|
|
19
27
|
this.hours.push(this.formatHour(hour));
|
|
20
|
-
this.scheduledObjects[this.formatHour(hour)] = this.
|
|
28
|
+
this.scheduledObjects[this.formatHour(hour)] = this._getObjectsForHour(hour, objectsList);
|
|
21
29
|
}
|
|
22
30
|
}
|
|
23
|
-
|
|
31
|
+
_getObjectsForHour(hour, objectsList) {
|
|
24
32
|
const objectsForHour = [];
|
|
25
|
-
objectsList.forEach(obj => {
|
|
26
|
-
if (obj.
|
|
33
|
+
objectsList.forEach((obj) => {
|
|
34
|
+
if (this.convertToHourNotation(obj[this.startTimeProp]) === hour) {
|
|
27
35
|
objectsForHour.push(Object.assign({}, obj));
|
|
28
36
|
}
|
|
29
37
|
});
|
|
@@ -37,28 +45,52 @@ export class HourSchedulingComponent {
|
|
|
37
45
|
const currentHourSpan = currentTarget.parentElement.parentElement.querySelector('.hour-label span');
|
|
38
46
|
const currentHour = currentHourSpan.textContent;
|
|
39
47
|
this.draggedObject = obj;
|
|
40
|
-
event.dataTransfer.setData('text', JSON.stringify({ obj, currentHour }));
|
|
48
|
+
event.dataTransfer.setData('text', JSON.stringify({ obj: this.draggedObject, currentHour }));
|
|
49
|
+
}
|
|
50
|
+
onCustomDragStart(event, obj) {
|
|
51
|
+
this.onDragStart(event, obj);
|
|
41
52
|
}
|
|
42
53
|
onDragOver(event) {
|
|
43
54
|
event.preventDefault();
|
|
44
55
|
}
|
|
45
56
|
onDrop(event, hour) {
|
|
46
57
|
event.preventDefault();
|
|
58
|
+
event.stopPropagation();
|
|
47
59
|
const data = JSON.parse(event.dataTransfer.getData('text'));
|
|
60
|
+
if (!data || !data.obj) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
48
63
|
const newStartHour = parseInt(hour.split(':')[0], 10);
|
|
49
64
|
const newEndHour = newStartHour + 1;
|
|
50
|
-
data.obj.
|
|
51
|
-
|
|
52
|
-
const
|
|
53
|
-
|
|
65
|
+
const originalStartHour = this.convertToHourNotation(data.obj[this.startTimeProp]);
|
|
66
|
+
// Get the unique identifier value from the object using the `idProp`
|
|
67
|
+
const objId = data.obj[this.idProp];
|
|
68
|
+
// Ensure we create a new object to avoid mutation issues
|
|
69
|
+
const updatedObject = Object.assign(Object.assign({}, data.obj), { start: newStartHour, end: newEndHour });
|
|
70
|
+
const updatedObject2 = Object.assign(Object.assign({}, data.obj), { [this.startTimeProp]: this.createDate(newStartHour), [this.endTimeProp]: this.createDate(newEndHour) });
|
|
71
|
+
// Remove the object from its old hour block using its unique id
|
|
72
|
+
const originalHourBlock = this.formatHour(originalStartHour);
|
|
73
|
+
this.scheduledObjects[originalHourBlock] = this.scheduledObjects[originalHourBlock].filter(o => o[this.idProp] !== objId);
|
|
74
|
+
// Add the object to the new hour block
|
|
54
75
|
const newHourBlock = this.formatHour(newStartHour);
|
|
55
76
|
if (!this.scheduledObjects[newHourBlock]) {
|
|
56
77
|
this.scheduledObjects[newHourBlock] = [];
|
|
57
78
|
}
|
|
58
|
-
this.scheduledObjects[newHourBlock].push(
|
|
79
|
+
this.scheduledObjects[newHourBlock].push(updatedObject2);
|
|
80
|
+
// Clear the dragged object
|
|
59
81
|
this.draggedObject = null;
|
|
82
|
+
// Trigger change detection to update the view
|
|
60
83
|
this.cdRef.detectChanges();
|
|
61
84
|
}
|
|
85
|
+
convertToHourNotation(date) {
|
|
86
|
+
return parseInt(this._datepipe.transform(new Date(date).toISOString(), 'H:mm'));
|
|
87
|
+
}
|
|
88
|
+
createDate(hours) {
|
|
89
|
+
let date = new Date();
|
|
90
|
+
date.setHours(hours);
|
|
91
|
+
date.setMinutes(0, 0, 0);
|
|
92
|
+
return date;
|
|
93
|
+
}
|
|
62
94
|
}
|
|
63
95
|
HourSchedulingComponent.decorators = [
|
|
64
96
|
{ type: Component, args: [{
|
|
@@ -66,23 +98,35 @@ HourSchedulingComponent.decorators = [
|
|
|
66
98
|
template: `
|
|
67
99
|
<div class="time-block" *ngFor="let hour of hours">
|
|
68
100
|
<div class="hour-label"><span [textContent]="hour"></span></div>
|
|
69
|
-
<div
|
|
70
|
-
|
|
71
|
-
|
|
101
|
+
<div
|
|
102
|
+
class="object-display"
|
|
103
|
+
(dragover)="onDragOver($event)"
|
|
104
|
+
(drop)="onDrop($event, hour)"
|
|
105
|
+
>
|
|
72
106
|
<ng-container *ngIf="!customTemplateUsed">
|
|
73
107
|
<ng-container *ngIf="scheduledObjects[hour]">
|
|
74
|
-
<div
|
|
75
|
-
|
|
76
|
-
|
|
108
|
+
<div
|
|
109
|
+
*ngFor="let obj of scheduledObjects[hour]"
|
|
110
|
+
class="scheduled-object"
|
|
111
|
+
[draggable]="true"
|
|
112
|
+
(dragstart)="onDragStart($event, obj)"
|
|
113
|
+
>
|
|
77
114
|
<span class="title" [textContent]="obj.title"></span>
|
|
78
115
|
<span class="sub-title" [textContent]="obj.subTitle"></span>
|
|
79
116
|
</div>
|
|
80
117
|
</ng-container>
|
|
81
118
|
</ng-container>
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
119
|
+
|
|
120
|
+
<ng-container *ngIf="customTemplateUsed">
|
|
121
|
+
<ng-template
|
|
122
|
+
[ngTemplateOutlet]="customTemplate"
|
|
123
|
+
[ngTemplateOutletContext]="{
|
|
124
|
+
hour: hour,
|
|
125
|
+
objects: scheduledObjects[hour]
|
|
126
|
+
}"
|
|
127
|
+
>
|
|
128
|
+
</ng-template>
|
|
129
|
+
</ng-container>
|
|
86
130
|
</div>
|
|
87
131
|
</div>
|
|
88
132
|
`,
|
|
@@ -90,15 +134,18 @@ HourSchedulingComponent.decorators = [
|
|
|
90
134
|
},] }
|
|
91
135
|
];
|
|
92
136
|
HourSchedulingComponent.ctorParameters = () => [
|
|
93
|
-
{ type: ChangeDetectorRef }
|
|
137
|
+
{ type: ChangeDetectorRef },
|
|
138
|
+
{ type: DatePipe }
|
|
94
139
|
];
|
|
95
140
|
HourSchedulingComponent.propDecorators = {
|
|
96
|
-
showClass: [{ type: HostBinding, args: ['class.co-hour-scheduling',] }],
|
|
97
141
|
schedule: [{ type: Input }],
|
|
98
142
|
startTimeProp: [{ type: Input }],
|
|
99
143
|
endTimeProp: [{ type: Input }],
|
|
100
144
|
objectsProp: [{ type: Input }],
|
|
145
|
+
childProp: [{ type: Input }],
|
|
101
146
|
customTemplate: [{ type: Input }],
|
|
102
|
-
customTemplateUsed: [{ type: Input }]
|
|
147
|
+
customTemplateUsed: [{ type: Input }],
|
|
148
|
+
idProp: [{ type: Input }],
|
|
149
|
+
generateTimeBlocks: [{ type: HostBinding, args: ['class.co-hour-scheduling',] }]
|
|
103
150
|
};
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hour-scheduling.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/hour-scheduling/hour-scheduling.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit, HostBinding, ViewEncapsulation, ChangeDetectorRef, TemplateRef } from '@angular/core';\r\n\r\ninterface SchedulingObject {\r\n  start: number;\r\n  end: number;\r\n  title?: string;\r\n  subTitle?: string;\r\n}\r\n\r\n@Component({\r\n  selector: 'co-hour-scheduling',\r\n  template: `\r\n    <div class=\"time-block\" *ngFor=\"let hour of hours\">\r\n      <div class=\"hour-label\"><span [textContent]=\"hour\"></span></div>\r\n      <div class=\"object-display\"\r\n           (dragover)=\"onDragOver($event)\"\r\n           (drop)=\"onDrop($event, hour)\">\r\n        <ng-container *ngIf=\"!customTemplateUsed\">\r\n          <ng-container *ngIf=\"scheduledObjects[hour]\">\r\n            <div *ngFor=\"let obj of scheduledObjects[hour]\" class=\"scheduled-object\"\r\n                 [draggable]=\"true\"\r\n                 (dragstart)=\"onDragStart($event, obj)\">\r\n              <span class=\"title\" [textContent]=\"obj.title\"></span>\r\n              <span class=\"sub-title\" [textContent]=\"obj.subTitle\"></span>\r\n            </div>\r\n          </ng-container>\r\n        </ng-container>\r\n        <ng-template #customContent *ngIf=\"customTemplateUsed\">\r\n          <ng-container *ngTemplateOutlet=\"customTemplate; context: { objects: scheduledObjects[hour] }\">\r\n          </ng-container>\r\n        </ng-template>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class HourSchedulingComponent implements OnInit {\r\n\r\n  @HostBinding('class.co-hour-scheduling')\r\n  public showClass = true;\r\n\r\n  @Input() schedule: any;\r\n  @Input() startTimeProp: string;\r\n  @Input() endTimeProp: string;\r\n  @Input() objectsProp: string;\r\n  @Input() customTemplate: TemplateRef<any>; // Input for custom template\r\n  @Input() customTemplateUsed: boolean = false;\r\n\r\n  public hours: string[] = [];\r\n  public scheduledObjects: { [hour: string]: SchedulingObject[] } = {};\r\n\r\n  private draggedObject: SchedulingObject | null = null;\r\n\r\n  constructor(private cdRef: ChangeDetectorRef) {}\r\n\r\n  ngOnInit() {\r\n    this.generateTimeBlocks();\r\n  }\r\n\r\n  private generateTimeBlocks() {\r\n    const startTime = this.schedule[this.startTimeProp];\r\n    const endTime = this.schedule[this.endTimeProp];\r\n    const objectsList: any[] = this.schedule[this.objectsProp];\r\n\r\n    for (let hour = startTime; hour <= endTime; hour++) {\r\n      this.hours.push(this.formatHour(hour));\r\n      this.scheduledObjects[this.formatHour(hour)] = this.getObjectsForHour(hour, objectsList);\r\n    }\r\n  }\r\n\r\n  private getObjectsForHour(hour: number, objectsList: any[]): SchedulingObject[] {\r\n    const objectsForHour: SchedulingObject[] = [];\r\n\r\n    objectsList.forEach(obj => {\r\n      if (obj.start === hour) {\r\n        objectsForHour.push({ ...obj });\r\n      }\r\n    });\r\n\r\n    return objectsForHour;\r\n  }\r\n\r\n  public formatHour(hour: number): string {\r\n    return `${hour}:00`;\r\n  }\r\n\r\n  public onDragStart(event: DragEvent, obj: SchedulingObject) {\r\n    const currentTarget = event.currentTarget as HTMLElement;\r\n    const currentHourSpan = currentTarget.parentElement!.parentElement!.querySelector('.hour-label span')!;\r\n    const currentHour = currentHourSpan.textContent!;\r\n\r\n    this.draggedObject = obj;\r\n\r\n    event.dataTransfer!.setData('text', JSON.stringify({ obj, currentHour }));\r\n  }\r\n\r\n  public onDragOver(event: DragEvent) {\r\n    event.preventDefault();\r\n  }\r\n\r\n  public onDrop(event: DragEvent, hour: string) {\r\n    event.preventDefault();\r\n    const data = JSON.parse(event.dataTransfer!.getData('text')) as { obj: SchedulingObject, currentHour: string };\r\n\r\n    const newStartHour = parseInt(hour.split(':')[0], 10);\r\n    const newEndHour = newStartHour + 1;\r\n\r\n    data.obj.start = newStartHour;\r\n    data.obj.end = newEndHour;\r\n\r\n    const currentHourBlock = data.currentHour;\r\n    this.scheduledObjects[currentHourBlock] = this.scheduledObjects[currentHourBlock].filter(o => o !== this.draggedObject);\r\n\r\n    const newHourBlock = this.formatHour(newStartHour);\r\n    if (!this.scheduledObjects[newHourBlock]) {\r\n      this.scheduledObjects[newHourBlock] = [];\r\n    }\r\n    this.scheduledObjects[newHourBlock].push(data.obj);\r\n\r\n    this.draggedObject = null;\r\n\r\n    this.cdRef.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
151
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hour-scheduling.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/hour-scheduling/hour-scheduling.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  OnInit,\r\n  HostBinding,\r\n  ViewEncapsulation,\r\n  ChangeDetectorRef,\r\n  TemplateRef,\r\n} from '@angular/core';\r\nimport { DatePipe } from '@angular/common';\r\n\r\ninterface SchedulingObject {\r\n  start: number;\r\n  end: number;\r\n  title?: string;\r\n  subTitle?: string;\r\n  [key: string]: any; // Allows dynamic properties including unique identifiers\r\n}\r\n\r\n@Component({\r\n  selector: 'co-hour-scheduling',\r\n  template: `\r\n    <div class=\"time-block\" *ngFor=\"let hour of hours\">\r\n      <div class=\"hour-label\"><span [textContent]=\"hour\"></span></div>\r\n      <div\r\n        class=\"object-display\"\r\n        (dragover)=\"onDragOver($event)\"\r\n        (drop)=\"onDrop($event, hour)\"\r\n      >\r\n        <ng-container *ngIf=\"!customTemplateUsed\">\r\n          <ng-container *ngIf=\"scheduledObjects[hour]\">\r\n            <div\r\n              *ngFor=\"let obj of scheduledObjects[hour]\"\r\n              class=\"scheduled-object\"\r\n              [draggable]=\"true\"\r\n              (dragstart)=\"onDragStart($event, obj)\"\r\n            >\r\n              <span class=\"title\" [textContent]=\"obj.title\"></span>\r\n              <span class=\"sub-title\" [textContent]=\"obj.subTitle\"></span>\r\n            </div>\r\n          </ng-container>\r\n        </ng-container>\r\n\r\n        <ng-container *ngIf=\"customTemplateUsed\">\r\n          <ng-template\r\n            [ngTemplateOutlet]=\"customTemplate\"\r\n            [ngTemplateOutletContext]=\"{\r\n              hour: hour,\r\n              objects: scheduledObjects[hour]\r\n            }\"\r\n          >\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HourSchedulingComponent implements OnInit {\r\n\r\n  public showClass = true;\r\n  public startTime: number;\r\n  public endTime: number;\r\n\r\n  @Input() schedule: any;\r\n  @Input() startTimeProp: string;\r\n  @Input() endTimeProp: string;\r\n  @Input() objectsProp: string;\r\n  @Input() childProp: string;\r\n  @Input() customTemplate: TemplateRef<any>;\r\n  @Input() customTemplateUsed: boolean = false;\r\n  @Input() idProp: string;  // Input for unique identifier property\r\n\r\n  public hours: string[] = [];\r\n  public scheduledObjects: { [hour: string]: SchedulingObject[] } = {};\r\n\r\n  private draggedObject: any | null = null;\r\n\r\n  constructor(private cdRef: ChangeDetectorRef, private _datepipe: DatePipe) {}\r\n\r\n  ngOnInit() {\r\n    if (!this.childProp) {\r\n      this.startTime = parseInt(\r\n        this._datepipe.transform(\r\n          new Date(this.schedule[this.startTimeProp]).toISOString(),\r\n          'H:mm'\r\n        )\r\n      );\r\n      this.endTime = parseInt(\r\n        this._datepipe.transform(\r\n          new Date(this.schedule[this.endTimeProp]).toISOString(),\r\n          'H:mm'\r\n        )\r\n      );\r\n    } else {\r\n      this.startTime = parseInt(\r\n        this._datepipe.transform(\r\n          new Date(this.schedule[this.childProp][this.startTimeProp]).toISOString(),\r\n          'H:mm'\r\n        )\r\n      );\r\n      this.endTime = parseInt(\r\n        this._datepipe.transform(\r\n          new Date(this.schedule[this.childProp][this.endTimeProp]).toISOString(),\r\n          'H:mm'\r\n        )\r\n      );\r\n    }\r\n    this.generateTimeBlocks();\r\n  }\r\n\r\n  @HostBinding('class.co-hour-scheduling')\r\n\r\n  public generateTimeBlocks() {\r\n    const objectsList = this.schedule[this.objectsProp];\r\n\r\n    for (let hour = this.startTime; hour <= this.endTime; hour++) {\r\n      this.hours.push(this.formatHour(hour));\r\n      this.scheduledObjects[this.formatHour(hour)] = this._getObjectsForHour(\r\n        hour,\r\n        objectsList\r\n      );\r\n    }\r\n  }\r\n\r\n  private _getObjectsForHour(\r\n    hour: number,\r\n    objectsList: any[]\r\n  ): SchedulingObject[] {\r\n    const objectsForHour: SchedulingObject[] = [];\r\n\r\n    objectsList.forEach((obj) => {\r\n      if (this.convertToHourNotation(obj[this.startTimeProp]) === hour) {\r\n        objectsForHour.push({ ...obj });\r\n      }\r\n    });\r\n\r\n    return objectsForHour;\r\n  }\r\n\r\n  public formatHour(hour: number): string {\r\n    return `${hour}:00`;\r\n  }\r\n\r\n  public onDragStart(event: DragEvent, obj: any) {\r\n    const currentTarget = event.currentTarget as HTMLElement;\r\n    const currentHourSpan =\r\n      currentTarget.parentElement!.parentElement!.querySelector(\r\n        '.hour-label span'\r\n      )!;\r\n    const currentHour = currentHourSpan.textContent!;\r\n\r\n    this.draggedObject = obj;\r\n    event.dataTransfer!.setData(\r\n      'text',\r\n      JSON.stringify({ obj: this.draggedObject, currentHour })\r\n    );\r\n  }\r\n\r\n  public onCustomDragStart(event: DragEvent, obj: SchedulingObject) {\r\n    this.onDragStart(event, obj);\r\n  }\r\n\r\n  public onDragOver(event: DragEvent) {\r\n    event.preventDefault();\r\n  }\r\n\r\n  public onDrop(event: DragEvent, hour: string) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n\r\n    const data = JSON.parse(event.dataTransfer!.getData('text')) as {\r\n      obj: any;\r\n      currentHour: string;\r\n    };\r\n\r\n    if (!data || !data.obj) {\r\n      return;\r\n    }\r\n\r\n    const newStartHour = parseInt(hour.split(':')[0], 10);\r\n    const newEndHour = newStartHour + 1;\r\n\r\n    const originalStartHour = this.convertToHourNotation(data.obj[this.startTimeProp]);\r\n\r\n    // Get the unique identifier value from the object using the `idProp`\r\n    const objId = data.obj[this.idProp];\r\n\r\n    // Ensure we create a new object to avoid mutation issues\r\n    const updatedObject = { ...data.obj, start: newStartHour, end: newEndHour };\r\n\r\n    const updatedObject2 = { ...data.obj, [this.startTimeProp]:this.createDate(newStartHour), [this.endTimeProp]:this.createDate(newEndHour)};\r\n\r\n\r\n    // Remove the object from its old hour block using its unique id\r\n    const originalHourBlock = this.formatHour(originalStartHour);\r\n    this.scheduledObjects[originalHourBlock] = this.scheduledObjects[originalHourBlock].filter(o => o[this.idProp] !== objId);\r\n\r\n    // Add the object to the new hour block\r\n    const newHourBlock = this.formatHour(newStartHour);\r\n    if (!this.scheduledObjects[newHourBlock]) {\r\n      this.scheduledObjects[newHourBlock] = [];\r\n    }\r\n    this.scheduledObjects[newHourBlock].push(updatedObject2);\r\n\r\n    // Clear the dragged object\r\n    this.draggedObject = null;\r\n\r\n    // Trigger change detection to update the view\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  public convertToHourNotation(date: Date): number {\r\n    return parseInt(this._datepipe.transform(new Date(date).toISOString(), 'H:mm' ));\r\n  }\r\n\r\n  public createDate(hours: number) {\r\n    let date = new Date();\r\n    date.setHours(hours);\r\n    date.setMinutes(0, 0, 0);\r\n    return date;\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { NgModule } from "@angular/core";
|
|
2
|
-
import { CommonModule } from "@angular/common";
|
|
2
|
+
import { CommonModule, DatePipe } from "@angular/common";
|
|
3
3
|
import { HourSchedulingComponent } from "./hour-scheduling.component";
|
|
4
4
|
import { HourSchedulingTestObjectComponent } from "./components/hour-scheduling-test-object/hour-scheduling-test-object.component";
|
|
5
5
|
export class HourSchedulingComponentModule {
|
|
@@ -16,7 +16,8 @@ HourSchedulingComponentModule.decorators = [
|
|
|
16
16
|
exports: [
|
|
17
17
|
HourSchedulingComponent,
|
|
18
18
|
HourSchedulingTestObjectComponent
|
|
19
|
-
]
|
|
19
|
+
],
|
|
20
|
+
providers: [DatePipe]
|
|
20
21
|
},] }
|
|
21
22
|
];
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG91ci1zY2hlZHVsaW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9ob3VyLXNjaGVkdWxpbmcvaG91ci1zY2hlZHVsaW5nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxZQUFZLEVBQUUsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdkQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDcEUsT0FBTyxFQUNMLGlDQUFpQyxFQUNsQyxNQUFNLGdGQUFnRixDQUFDO0FBa0J4RixNQUFNLE9BQU8sNkJBQTZCOzs7WUFmekMsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO2lCQUNmO2dCQUNELFlBQVksRUFBRTtvQkFDVix1QkFBdUI7b0JBQ3pCLGlDQUFpQztpQkFDbEM7Z0JBQ0gsT0FBTyxFQUFFO29CQUNQLHVCQUF1QjtvQkFDdkIsaUNBQWlDO2lCQUNsQztnQkFDRCxTQUFTLEVBQUUsQ0FBRSxRQUFRLENBQUM7YUFFdkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZSwgRGF0ZVBpcGV9IGZyb20gXCJAYW5ndWxhci9jb21tb25cIjtcclxuaW1wb3J0IHtIb3VyU2NoZWR1bGluZ0NvbXBvbmVudH0gZnJvbSBcIi4vaG91ci1zY2hlZHVsaW5nLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1xyXG4gIEhvdXJTY2hlZHVsaW5nVGVzdE9iamVjdENvbXBvbmVudFxyXG59IGZyb20gXCIuL2NvbXBvbmVudHMvaG91ci1zY2hlZHVsaW5nLXRlc3Qtb2JqZWN0L2hvdXItc2NoZWR1bGluZy10ZXN0LW9iamVjdC5jb21wb25lbnRcIjtcclxuXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgaW1wb3J0czogW1xyXG4gICAgICAgIENvbW1vbk1vZHVsZVxyXG4gICAgXSxcclxuICAgIGRlY2xhcmF0aW9uczogW1xyXG4gICAgICAgIEhvdXJTY2hlZHVsaW5nQ29tcG9uZW50LFxyXG4gICAgICBIb3VyU2NoZWR1bGluZ1Rlc3RPYmplY3RDb21wb25lbnQsXHJcbiAgICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEhvdXJTY2hlZHVsaW5nQ29tcG9uZW50LFxyXG4gICAgSG91clNjaGVkdWxpbmdUZXN0T2JqZWN0Q29tcG9uZW50XHJcbiAgXSxcclxuICBwcm92aWRlcnM6IFsgRGF0ZVBpcGVdXHJcblxyXG59KVxyXG5leHBvcnQgY2xhc3MgSG91clNjaGVkdWxpbmdDb21wb25lbnRNb2R1bGUge1xyXG59XHJcbiJdfQ==
|
|
@@ -5,7 +5,7 @@ import { NgModel, FormGroup, FormsModule } from '@angular/forms';
|
|
|
5
5
|
import { Subject, merge, fromEvent, BehaviorSubject } from 'rxjs';
|
|
6
6
|
import { DomSanitizer, HammerGestureConfig, HammerModule, HAMMER_GESTURE_CONFIG } from '@angular/platform-browser';
|
|
7
7
|
import { trigger, state, style, transition, animate, query, animateChild } from '@angular/animations';
|
|
8
|
-
import { CommonModule } from '@angular/common';
|
|
8
|
+
import { CommonModule, DatePipe } from '@angular/common';
|
|
9
9
|
import { HttpClientModule } from '@angular/common/http';
|
|
10
10
|
import { auditTime } from 'rxjs/operators';
|
|
11
11
|
import { PlaneGeometry, Mesh, Vector2, Vector3, MeshPhongMaterial, SpotLight, PerspectiveCamera, Scene, Color, AmbientLight, Fog, WebGLRenderer, Box3 } from 'three';
|
|
@@ -13685,8 +13685,9 @@ ColorSequenceService.decorators = [
|
|
|
13685
13685
|
];
|
|
13686
13686
|
|
|
13687
13687
|
class HourSchedulingComponent {
|
|
13688
|
-
constructor(cdRef) {
|
|
13688
|
+
constructor(cdRef, _datepipe) {
|
|
13689
13689
|
this.cdRef = cdRef;
|
|
13690
|
+
this._datepipe = _datepipe;
|
|
13690
13691
|
this.showClass = true;
|
|
13691
13692
|
this.customTemplateUsed = false;
|
|
13692
13693
|
this.hours = [];
|
|
@@ -13694,21 +13695,27 @@ class HourSchedulingComponent {
|
|
|
13694
13695
|
this.draggedObject = null;
|
|
13695
13696
|
}
|
|
13696
13697
|
ngOnInit() {
|
|
13698
|
+
if (!this.childProp) {
|
|
13699
|
+
this.startTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.startTimeProp]).toISOString(), 'H:mm'));
|
|
13700
|
+
this.endTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.endTimeProp]).toISOString(), 'H:mm'));
|
|
13701
|
+
}
|
|
13702
|
+
else {
|
|
13703
|
+
this.startTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.childProp][this.startTimeProp]).toISOString(), 'H:mm'));
|
|
13704
|
+
this.endTime = parseInt(this._datepipe.transform(new Date(this.schedule[this.childProp][this.endTimeProp]).toISOString(), 'H:mm'));
|
|
13705
|
+
}
|
|
13697
13706
|
this.generateTimeBlocks();
|
|
13698
13707
|
}
|
|
13699
13708
|
generateTimeBlocks() {
|
|
13700
|
-
const startTime = this.schedule[this.startTimeProp];
|
|
13701
|
-
const endTime = this.schedule[this.endTimeProp];
|
|
13702
13709
|
const objectsList = this.schedule[this.objectsProp];
|
|
13703
|
-
for (let hour = startTime; hour <= endTime; hour++) {
|
|
13710
|
+
for (let hour = this.startTime; hour <= this.endTime; hour++) {
|
|
13704
13711
|
this.hours.push(this.formatHour(hour));
|
|
13705
|
-
this.scheduledObjects[this.formatHour(hour)] = this.
|
|
13712
|
+
this.scheduledObjects[this.formatHour(hour)] = this._getObjectsForHour(hour, objectsList);
|
|
13706
13713
|
}
|
|
13707
13714
|
}
|
|
13708
|
-
|
|
13715
|
+
_getObjectsForHour(hour, objectsList) {
|
|
13709
13716
|
const objectsForHour = [];
|
|
13710
|
-
objectsList.forEach(obj => {
|
|
13711
|
-
if (obj.
|
|
13717
|
+
objectsList.forEach((obj) => {
|
|
13718
|
+
if (this.convertToHourNotation(obj[this.startTimeProp]) === hour) {
|
|
13712
13719
|
objectsForHour.push(Object.assign({}, obj));
|
|
13713
13720
|
}
|
|
13714
13721
|
});
|
|
@@ -13722,28 +13729,52 @@ class HourSchedulingComponent {
|
|
|
13722
13729
|
const currentHourSpan = currentTarget.parentElement.parentElement.querySelector('.hour-label span');
|
|
13723
13730
|
const currentHour = currentHourSpan.textContent;
|
|
13724
13731
|
this.draggedObject = obj;
|
|
13725
|
-
event.dataTransfer.setData('text', JSON.stringify({ obj, currentHour }));
|
|
13732
|
+
event.dataTransfer.setData('text', JSON.stringify({ obj: this.draggedObject, currentHour }));
|
|
13733
|
+
}
|
|
13734
|
+
onCustomDragStart(event, obj) {
|
|
13735
|
+
this.onDragStart(event, obj);
|
|
13726
13736
|
}
|
|
13727
13737
|
onDragOver(event) {
|
|
13728
13738
|
event.preventDefault();
|
|
13729
13739
|
}
|
|
13730
13740
|
onDrop(event, hour) {
|
|
13731
13741
|
event.preventDefault();
|
|
13742
|
+
event.stopPropagation();
|
|
13732
13743
|
const data = JSON.parse(event.dataTransfer.getData('text'));
|
|
13744
|
+
if (!data || !data.obj) {
|
|
13745
|
+
return;
|
|
13746
|
+
}
|
|
13733
13747
|
const newStartHour = parseInt(hour.split(':')[0], 10);
|
|
13734
13748
|
const newEndHour = newStartHour + 1;
|
|
13735
|
-
data.obj.
|
|
13736
|
-
|
|
13737
|
-
const
|
|
13738
|
-
|
|
13749
|
+
const originalStartHour = this.convertToHourNotation(data.obj[this.startTimeProp]);
|
|
13750
|
+
// Get the unique identifier value from the object using the `idProp`
|
|
13751
|
+
const objId = data.obj[this.idProp];
|
|
13752
|
+
// Ensure we create a new object to avoid mutation issues
|
|
13753
|
+
const updatedObject = Object.assign(Object.assign({}, data.obj), { start: newStartHour, end: newEndHour });
|
|
13754
|
+
const updatedObject2 = Object.assign(Object.assign({}, data.obj), { [this.startTimeProp]: this.createDate(newStartHour), [this.endTimeProp]: this.createDate(newEndHour) });
|
|
13755
|
+
// Remove the object from its old hour block using its unique id
|
|
13756
|
+
const originalHourBlock = this.formatHour(originalStartHour);
|
|
13757
|
+
this.scheduledObjects[originalHourBlock] = this.scheduledObjects[originalHourBlock].filter(o => o[this.idProp] !== objId);
|
|
13758
|
+
// Add the object to the new hour block
|
|
13739
13759
|
const newHourBlock = this.formatHour(newStartHour);
|
|
13740
13760
|
if (!this.scheduledObjects[newHourBlock]) {
|
|
13741
13761
|
this.scheduledObjects[newHourBlock] = [];
|
|
13742
13762
|
}
|
|
13743
|
-
this.scheduledObjects[newHourBlock].push(
|
|
13763
|
+
this.scheduledObjects[newHourBlock].push(updatedObject2);
|
|
13764
|
+
// Clear the dragged object
|
|
13744
13765
|
this.draggedObject = null;
|
|
13766
|
+
// Trigger change detection to update the view
|
|
13745
13767
|
this.cdRef.detectChanges();
|
|
13746
13768
|
}
|
|
13769
|
+
convertToHourNotation(date) {
|
|
13770
|
+
return parseInt(this._datepipe.transform(new Date(date).toISOString(), 'H:mm'));
|
|
13771
|
+
}
|
|
13772
|
+
createDate(hours) {
|
|
13773
|
+
let date = new Date();
|
|
13774
|
+
date.setHours(hours);
|
|
13775
|
+
date.setMinutes(0, 0, 0);
|
|
13776
|
+
return date;
|
|
13777
|
+
}
|
|
13747
13778
|
}
|
|
13748
13779
|
HourSchedulingComponent.decorators = [
|
|
13749
13780
|
{ type: Component, args: [{
|
|
@@ -13751,23 +13782,35 @@ HourSchedulingComponent.decorators = [
|
|
|
13751
13782
|
template: `
|
|
13752
13783
|
<div class="time-block" *ngFor="let hour of hours">
|
|
13753
13784
|
<div class="hour-label"><span [textContent]="hour"></span></div>
|
|
13754
|
-
<div
|
|
13755
|
-
|
|
13756
|
-
|
|
13785
|
+
<div
|
|
13786
|
+
class="object-display"
|
|
13787
|
+
(dragover)="onDragOver($event)"
|
|
13788
|
+
(drop)="onDrop($event, hour)"
|
|
13789
|
+
>
|
|
13757
13790
|
<ng-container *ngIf="!customTemplateUsed">
|
|
13758
13791
|
<ng-container *ngIf="scheduledObjects[hour]">
|
|
13759
|
-
<div
|
|
13760
|
-
|
|
13761
|
-
|
|
13792
|
+
<div
|
|
13793
|
+
*ngFor="let obj of scheduledObjects[hour]"
|
|
13794
|
+
class="scheduled-object"
|
|
13795
|
+
[draggable]="true"
|
|
13796
|
+
(dragstart)="onDragStart($event, obj)"
|
|
13797
|
+
>
|
|
13762
13798
|
<span class="title" [textContent]="obj.title"></span>
|
|
13763
13799
|
<span class="sub-title" [textContent]="obj.subTitle"></span>
|
|
13764
13800
|
</div>
|
|
13765
13801
|
</ng-container>
|
|
13766
13802
|
</ng-container>
|
|
13767
|
-
|
|
13768
|
-
|
|
13769
|
-
|
|
13770
|
-
|
|
13803
|
+
|
|
13804
|
+
<ng-container *ngIf="customTemplateUsed">
|
|
13805
|
+
<ng-template
|
|
13806
|
+
[ngTemplateOutlet]="customTemplate"
|
|
13807
|
+
[ngTemplateOutletContext]="{
|
|
13808
|
+
hour: hour,
|
|
13809
|
+
objects: scheduledObjects[hour]
|
|
13810
|
+
}"
|
|
13811
|
+
>
|
|
13812
|
+
</ng-template>
|
|
13813
|
+
</ng-container>
|
|
13771
13814
|
</div>
|
|
13772
13815
|
</div>
|
|
13773
13816
|
`,
|
|
@@ -13775,16 +13818,19 @@ HourSchedulingComponent.decorators = [
|
|
|
13775
13818
|
},] }
|
|
13776
13819
|
];
|
|
13777
13820
|
HourSchedulingComponent.ctorParameters = () => [
|
|
13778
|
-
{ type: ChangeDetectorRef }
|
|
13821
|
+
{ type: ChangeDetectorRef },
|
|
13822
|
+
{ type: DatePipe }
|
|
13779
13823
|
];
|
|
13780
13824
|
HourSchedulingComponent.propDecorators = {
|
|
13781
|
-
showClass: [{ type: HostBinding, args: ['class.co-hour-scheduling',] }],
|
|
13782
13825
|
schedule: [{ type: Input }],
|
|
13783
13826
|
startTimeProp: [{ type: Input }],
|
|
13784
13827
|
endTimeProp: [{ type: Input }],
|
|
13785
13828
|
objectsProp: [{ type: Input }],
|
|
13829
|
+
childProp: [{ type: Input }],
|
|
13786
13830
|
customTemplate: [{ type: Input }],
|
|
13787
|
-
customTemplateUsed: [{ type: Input }]
|
|
13831
|
+
customTemplateUsed: [{ type: Input }],
|
|
13832
|
+
idProp: [{ type: Input }],
|
|
13833
|
+
generateTimeBlocks: [{ type: HostBinding, args: ['class.co-hour-scheduling',] }]
|
|
13788
13834
|
};
|
|
13789
13835
|
|
|
13790
13836
|
class HourSchedulingTestObjectComponent {
|
|
@@ -13822,7 +13868,8 @@ HourSchedulingComponentModule.decorators = [
|
|
|
13822
13868
|
exports: [
|
|
13823
13869
|
HourSchedulingComponent,
|
|
13824
13870
|
HourSchedulingTestObjectComponent
|
|
13825
|
-
]
|
|
13871
|
+
],
|
|
13872
|
+
providers: [DatePipe]
|
|
13826
13873
|
},] }
|
|
13827
13874
|
];
|
|
13828
13875
|
|