@colijnit/transaction 255.1.45 → 255.1.47
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-transaction.umd.js +595 -240
- package/bundles/colijnit-transaction.umd.js.map +1 -1
- package/colijnit-transaction.metadata.json +1 -1
- package/esm2015/lib/component/avatar/avatar.component.js +8 -3
- package/esm2015/lib/component/checkout/checkout-overview-delivery-edit/checkout-overview-delivery-edit.component.js +10 -1
- package/esm2015/lib/component/checkout/checkout.module.js +6 -2
- package/esm2015/lib/component/delivery-planning/service/delivery-planning.service.js +99 -33
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.js +39 -25
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-short-line/delivery-planning-overview-short-line.component.js +4 -4
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-tile-line/delivery-planning-overview-tile-line.component.js +29 -11
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-tile-status/delivery-planning-tile-status.component.js +67 -16
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.js +39 -17
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.js +56 -30
- package/esm2015/lib/component/delivery-planning-main/delivery-planning-main.component.js +59 -46
- package/esm2015/lib/component/transaction-card/transaction-card-planning/transaction-card-planning.component.js +18 -3
- package/esm2015/lib/component/transaction-card/transaction-card-purchase-confirmation/transaction-card-purchase-confirmation.component.js +101 -96
- package/esm2015/lib/component/transaction-cash-register-dialog/transaction-cash-register-dialog.component.js +4 -4
- package/esm2015/lib/component/transaction-header/transaction-header/transaction-header.component.js +13 -11
- package/esm2015/lib/component/transaction-header/transaction-header-delivery/transaction-header-delivery.component.js +2 -3
- package/esm2015/lib/component/transaction-header/transaction-header-popup/transaction-header-popup-order.component.js +7 -2
- package/esm2015/lib/component/transaction-internal/transaction-internal.component.js +3 -8
- package/esm2015/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.js +10 -4
- package/esm2015/lib/component/transaction-lines-side-panel/transaction-lines-side-panel-service-order/transaction-lines-side-panel-service-order.component.js +6 -4
- package/esm2015/lib/component/transaction-lines-side-panel/transaction-lines-side-panel-service-order/transaction-lines-side-panel-service-order.module.js +4 -3
- package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-planning/transaction-quick-access-planning.component.js +5 -2
- package/esm2015/lib/component/transaction-service-overview/components/transaction-service-message.component.js +3 -2
- package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.component.js +29 -20
- package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.module.js +4 -3
- package/esm2015/lib/enum/checkout-cfg-name.enum.js +3 -1
- package/esm2015/lib/enum/delivery-planning-update-actions.enum.js +8 -0
- package/esm2015/lib/enum/transaction-cfg-name.enum.js +12 -1
- package/esm2015/lib/service/transaction-connector-adapter.service.js +12 -1
- package/esm2015/lib/service/transaction-connector.service.js +6 -1
- package/esm2015/lib/service/transaction-payment.service.js +3 -3
- package/esm2015/lib/transaction-version.js +3 -3
- package/fesm2015/colijnit-transaction.js +622 -322
- package/fesm2015/colijnit-transaction.js.map +1 -1
- package/lib/component/delivery-planning/service/delivery-planning.service.d.ts +11 -7
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.d.ts +10 -7
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-short-line/delivery-planning-overview-short-line.component.d.ts +1 -1
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-tile-line/delivery-planning-overview-tile-line.component.d.ts +9 -2
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-tile-line/style/_layout.scss +6 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-tile-status/delivery-planning-tile-status.component.d.ts +18 -7
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-tile-status/style/_layout.scss +12 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.d.ts +20 -5
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/style/_layout.scss +2 -2
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/style/_material-definition.scss +1 -1
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.d.ts +23 -10
- package/lib/component/delivery-planning-main/delivery-planning-main.component.d.ts +14 -7
- package/lib/component/transaction-card/transaction-card/style/_layout.scss +14 -1
- package/lib/component/transaction-card/transaction-card-planning/transaction-card-planning.component.d.ts +2 -0
- package/lib/component/transaction-header/transaction-header/style/_layout.scss +4 -0
- package/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.d.ts +3 -2
- package/lib/component/transaction-lines-side-panel/transaction-lines-side-panel-service-order/transaction-lines-side-panel-service-order.component.d.ts +2 -0
- package/lib/component/transaction-quick-access/transaction-quick-access-planning/transaction-quick-access-planning.component.d.ts +1 -0
- package/lib/component/transaction-quick-access/transaction-quick-access-send-method-base.component.d.ts +1 -1
- package/lib/component/transaction-service-overview/style/_layout.scss +14 -6
- package/lib/enum/checkout-cfg-name.enum.d.ts +2 -0
- package/lib/enum/delivery-planning-update-actions.enum.d.ts +6 -0
- package/lib/enum/transaction-cfg-name.enum.d.ts +12 -1
- package/lib/service/transaction-connector-adapter.service.d.ts +1 -0
- package/lib/service/transaction-connector.service.d.ts +1 -0
- package/package.json +2 -2
|
@@ -11,13 +11,18 @@ export class DeliveryPlanningOverviewTileLineComponent {
|
|
|
11
11
|
this.orderLines = false;
|
|
12
12
|
this.order = new PlanOrder();
|
|
13
13
|
this.isActive = false;
|
|
14
|
-
this.
|
|
14
|
+
this.deleteOrderEvent = new EventEmitter();
|
|
15
|
+
this.deleteOrderLineEvent = new EventEmitter();
|
|
16
|
+
this.editOrderEvent = new EventEmitter();
|
|
15
17
|
}
|
|
16
18
|
showClass() {
|
|
17
19
|
return true;
|
|
18
20
|
}
|
|
19
|
-
|
|
20
|
-
this.
|
|
21
|
+
handleDeleteOrderClick(order) {
|
|
22
|
+
this.deleteOrderEvent.emit(order);
|
|
23
|
+
}
|
|
24
|
+
handleDeleteOrderLineClick(order, line) {
|
|
25
|
+
this.deleteOrderLineEvent.emit({ order: order, line: line });
|
|
21
26
|
}
|
|
22
27
|
setLinesActive() {
|
|
23
28
|
this.linesActive = !this.linesActive;
|
|
@@ -30,6 +35,9 @@ export class DeliveryPlanningOverviewTileLineComponent {
|
|
|
30
35
|
getPlannedLines(lines) {
|
|
31
36
|
return lines.filter(line => line.planned === true);
|
|
32
37
|
}
|
|
38
|
+
handleEditOrderEvent(planOrder) {
|
|
39
|
+
this.editOrderEvent.emit(planOrder);
|
|
40
|
+
}
|
|
33
41
|
}
|
|
34
42
|
DeliveryPlanningOverviewTileLineComponent.decorators = [
|
|
35
43
|
{ type: Component, args: [{
|
|
@@ -39,8 +47,10 @@ DeliveryPlanningOverviewTileLineComponent.decorators = [
|
|
|
39
47
|
<div class="planning-line-content">
|
|
40
48
|
<div class="planning-line-left">
|
|
41
49
|
<div class="planning-line-extend" *ngIf="linesActive || orderLines">
|
|
42
|
-
<co-icon *ngIf="!orderLines" (click)="showOrderLines($event)"
|
|
43
|
-
|
|
50
|
+
<co-icon *ngIf="!orderLines" (click)="showOrderLines($event)"
|
|
51
|
+
[iconData]="iconCacheService.getIcon(icons.ChevronDownRegular)"></co-icon>
|
|
52
|
+
<co-icon *ngIf="orderLines" (click)="showOrderLines($event)"
|
|
53
|
+
[iconData]="iconCacheService.getIcon(icons.ChevronUpRegular)"></co-icon>
|
|
44
54
|
</div>
|
|
45
55
|
<div class="line-content-left">
|
|
46
56
|
<div class="planning-relation">
|
|
@@ -54,15 +64,19 @@ DeliveryPlanningOverviewTileLineComponent.decorators = [
|
|
|
54
64
|
<div class="planning-line-right">
|
|
55
65
|
<div class="line-content-right">
|
|
56
66
|
<div class="planning-order">
|
|
57
|
-
<co-icon (click)="setLinesActive()"
|
|
58
|
-
|
|
67
|
+
<co-icon (click)="setLinesActive()"
|
|
68
|
+
[iconData]="iconCacheService.getIcon(icons.CartShoppingRegular)"></co-icon>
|
|
69
|
+
<a href="javascript:void(0)" [textContent]="order.transactionNr" (click)="handleEditOrderEvent(order)"></a>
|
|
70
|
+
|
|
59
71
|
</div>
|
|
60
72
|
<div class="planning-time" *ngIf="linesActive">
|
|
61
|
-
<span
|
|
73
|
+
<span
|
|
74
|
+
[textContent]="(order.startTime | date: 'HH:mm') + ' - ' + (order.endTime | date: 'HH:mm')"></span>
|
|
62
75
|
</div>
|
|
63
76
|
</div>
|
|
64
77
|
<div class="planning-line-actions">
|
|
65
|
-
<co-icon *ngIf="linesActive" (click)="
|
|
78
|
+
<co-icon *ngIf="linesActive" (click)="handleDeleteOrderClick(order)"
|
|
79
|
+
[iconData]="iconCacheService.getIcon(icons.TrashCanRegular)"></co-icon>
|
|
66
80
|
<co-icon *ngIf="!linesActive" [iconData]="iconCacheService.getIcon(icons.ChevronRightRegular)"></co-icon>
|
|
67
81
|
</div>
|
|
68
82
|
</div>
|
|
@@ -71,6 +85,8 @@ DeliveryPlanningOverviewTileLineComponent.decorators = [
|
|
|
71
85
|
<div class="order-lines" *ngFor="let line of getPlannedLines(order?.lines)">
|
|
72
86
|
<span [textContent]="line.articleNumber"></span>
|
|
73
87
|
<span [textContent]="line.description"></span>
|
|
88
|
+
<co-icon *ngIf="linesActive" (click)="handleDeleteOrderLineClick(order, line)"
|
|
89
|
+
[iconData]="iconCacheService.getIcon(icons.TrashCanRegular)"></co-icon>
|
|
74
90
|
</div>
|
|
75
91
|
</div>
|
|
76
92
|
</div>
|
|
@@ -84,7 +100,9 @@ DeliveryPlanningOverviewTileLineComponent.ctorParameters = () => [
|
|
|
84
100
|
DeliveryPlanningOverviewTileLineComponent.propDecorators = {
|
|
85
101
|
order: [{ type: Input }],
|
|
86
102
|
isActive: [{ type: Input }],
|
|
87
|
-
|
|
103
|
+
deleteOrderEvent: [{ type: Output }],
|
|
104
|
+
deleteOrderLineEvent: [{ type: Output }],
|
|
105
|
+
editOrderEvent: [{ type: Output }],
|
|
88
106
|
showClass: [{ type: HostBinding, args: ["class.co-delivery-planning-overview-tile-line",] }]
|
|
89
107
|
};
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-overview-tile-line.component.js","sourceRoot":"","sources":["../../../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-tile-line/delivery-planning-overview-tile-line.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACrG,OAAO,EAAC,gBAAgB,EAAC,MAAM,oDAAoD,CAAC;AACpF,OAAO,EAAC,IAAI,EAAC,MAAM,wCAAwC,CAAC;AAE5D,OAAO,EAAC,SAAS,EAAC,MAAM,oDAAoD,CAAC;AAwD7E,MAAM,OAAO,yCAAyC;IA0BpD,YAAmB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAzBrC,UAAK,GAAgB,IAAI,CAAC;QACnC,aAAQ,GAAY,KAAK,CAAC;QAC1B,gBAAW,GAAY,KAAK,CAAC;QAC7B,eAAU,GAAY,KAAK,CAAC;QAG5B,UAAK,GAAa,IAAI,SAAS,EAAE,CAAC;QAEhC,aAAQ,GAAY,KAAK,CAAC;QAG5B,qBAAgB,GAA4B,IAAI,YAAY,EAAa,CAAC;QAG1E,yBAAoB,GAA4D,IAAI,YAAY,EAA6C,CAAC;QAG9I,mBAAc,GAA4B,IAAI,YAAY,EAAa,CAAC;IAS/E,CAAC;IALM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAKM,sBAAsB,CAAC,KAAgB;QAC5C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAEM,0BAA0B,CAAC,KAAgB,EAAE,IAAmB;QACtE,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAC,CAAC,CAAC;IAC5D,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC;QACrC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;IACM,cAAc,CAAC,KAAY;QAChC,KAAK,CAAC,eAAe,EAAE,CAAC,CAAE,qDAAqD;QAC/E,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC;IACrC,CAAC;IAEM,eAAe,CAAC,KAAsB;QAC3C,OAAO,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC;IACrD,CAAC;IAEM,oBAAoB,CAAE,SAAoB;QAC/C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;;;YAzGF,SAAS,SAAC;gBACP,QAAQ,EAAE,yCAAyC;gBACnD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgDT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACxC;;;YA1DO,gBAAgB;;;oBAiErB,KAAK;uBAGL,KAAK;+BAEL,MAAM;mCAGN,MAAM;6BAGN,MAAM;wBAIN,WAAW,SAAC,+CAA+C","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {IconCacheService} from \"../../../../../../../../service/icon-cache.service\";\r\nimport {Icon} from \"../../../../../../../../enum/icon.enum\";\r\nimport {PlanOrderLine} from \"@colijnit/transactionapi/build/model/plan-order-line.bo\";\r\nimport {PlanOrder} from \"@colijnit/transactionapi/build/model/plan-order.bo\";\r\nimport {Line} from \"three\";\r\n\r\n@Component({\r\n    selector: \"co-delivery-planning-overview-tile-line\",\r\n    template: `\r\n      <div class=\"planning-line-wrapper\" (click)=\"setLinesActive()\" [class.active-lines]=\"linesActive\">\r\n        <div class=\"planning-line-content\">\r\n          <div class=\"planning-line-left\">\r\n            <div class=\"planning-line-extend\" *ngIf=\"linesActive || orderLines\">\r\n              <co-icon *ngIf=\"!orderLines\" (click)=\"showOrderLines($event)\"\r\n                       [iconData]=\"iconCacheService.getIcon(icons.ChevronDownRegular)\"></co-icon>\r\n              <co-icon *ngIf=\"orderLines\" (click)=\"showOrderLines($event)\"\r\n                       [iconData]=\"iconCacheService.getIcon(icons.ChevronUpRegular)\"></co-icon>\r\n            </div>\r\n            <div class=\"line-content-left\">\r\n              <div class=\"planning-relation\">\r\n                <span [textContent]=\"order.relationName\"></span>\r\n              </div>\r\n              <div class=\"planning-address\" *ngIf=\"linesActive\">\r\n                <span [textContent]=\"order.shortAddress\"></span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n          <div class=\"planning-line-right\">\r\n            <div class=\"line-content-right\">\r\n              <div class=\"planning-order\">\r\n                <co-icon (click)=\"setLinesActive()\"\r\n                         [iconData]=\"iconCacheService.getIcon(icons.CartShoppingRegular)\"></co-icon>\r\n                <a href=\"javascript:void(0)\" [textContent]=\"order.transactionNr\" (click)=\"handleEditOrderEvent(order)\"></a>\r\n\r\n              </div>\r\n              <div class=\"planning-time\" *ngIf=\"linesActive\">\r\n                <span\r\n                  [textContent]=\"(order.startTime | date: 'HH:mm') + ' - ' + (order.endTime | date: 'HH:mm')\"></span>\r\n              </div>\r\n            </div>\r\n            <div class=\"planning-line-actions\">\r\n              <co-icon *ngIf=\"linesActive\" (click)=\"handleDeleteOrderClick(order)\"\r\n                       [iconData]=\"iconCacheService.getIcon(icons.TrashCanRegular)\"></co-icon>\r\n              <co-icon *ngIf=\"!linesActive\" [iconData]=\"iconCacheService.getIcon(icons.ChevronRightRegular)\"></co-icon>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div class=\"order-line-list-wrapper\" *ngIf=\"orderLines\">\r\n          <div class=\"order-lines\" *ngFor=\"let line of getPlannedLines(order?.lines)\">\r\n            <span [textContent]=\"line.articleNumber\"></span>\r\n            <span [textContent]=\"line.description\"></span>\r\n            <co-icon *ngIf=\"linesActive\" (click)=\"handleDeleteOrderLineClick(order, line)\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.TrashCanRegular)\"></co-icon>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningOverviewTileLineComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n  public expanded: boolean = false;\r\n  public linesActive: boolean = false;\r\n  public orderLines: boolean = false;\r\n\r\n  @Input()\r\n  public order:PlanOrder = new PlanOrder();\r\n\r\n  @Input() isActive: boolean = false;\r\n\r\n  @Output()\r\n  public deleteOrderEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n  @Output()\r\n  public deleteOrderLineEvent: EventEmitter<{ order: PlanOrder, line: PlanOrderLine }> = new EventEmitter<{ order: PlanOrder, line: PlanOrderLine }>();\r\n\r\n  @Output()\r\n  public editOrderEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n\r\n  @HostBinding(\"class.co-delivery-planning-overview-tile-line\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(public iconCacheService: IconCacheService) {\r\n  }\r\n\r\n  public handleDeleteOrderClick(order: PlanOrder) {\r\n    this.deleteOrderEvent.emit(order);\r\n  }\r\n\r\n  public handleDeleteOrderLineClick(order: PlanOrder, line: PlanOrderLine) {\r\n   this.deleteOrderLineEvent.emit({order: order, line: line});\r\n  }\r\n\r\n  public setLinesActive() {\r\n    this.linesActive = !this.linesActive;\r\n    this.orderLines = false;\r\n  }\r\n  public showOrderLines(event: Event) {\r\n    event.stopPropagation();  // Stop the event from propagating to parent elements\r\n    this.orderLines = !this.orderLines;\r\n  }\r\n\r\n  public getPlannedLines(lines: PlanOrderLine[]) {\r\n    return lines.filter(line => line.planned === true);\r\n  }\r\n\r\n  public handleEditOrderEvent( planOrder: PlanOrder) {\r\n    this.editOrderEvent.emit(planOrder);\r\n  }\r\n}\r\n"]}
|
|
@@ -1,27 +1,76 @@
|
|
|
1
|
-
import { Input } from "@angular/core";
|
|
1
|
+
import { ChangeDetectorRef, Input } from "@angular/core";
|
|
2
2
|
import { Component, HostBinding, ViewEncapsulation } from "@angular/core";
|
|
3
3
|
export class DeliveryPlanningTileStatusComponent {
|
|
4
|
-
constructor() {
|
|
5
|
-
this.
|
|
6
|
-
this.timeTotal = 480;
|
|
7
|
-
this.currentVolume = 0;
|
|
8
|
-
this.currentTimeTotal = 0;
|
|
4
|
+
constructor(_changeDetector) {
|
|
5
|
+
this._changeDetector = _changeDetector;
|
|
9
6
|
this.volumePercent = 0;
|
|
10
7
|
this.timePercent = 0;
|
|
8
|
+
this._maxVolume = 0;
|
|
9
|
+
this._timeTotal = 0;
|
|
10
|
+
this._currentVolume = 0;
|
|
11
|
+
this._currentTimeTotal = 0;
|
|
12
|
+
}
|
|
13
|
+
get maxVolume() {
|
|
14
|
+
return this._maxVolume;
|
|
15
|
+
}
|
|
16
|
+
set maxVolume(value) {
|
|
17
|
+
if (value != this._maxVolume) {
|
|
18
|
+
this._maxVolume = value;
|
|
19
|
+
this.calculateVolumePercent();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
get timeTotal() {
|
|
23
|
+
return this._timeTotal;
|
|
24
|
+
}
|
|
25
|
+
set timeTotal(value) {
|
|
26
|
+
if (value != this._timeTotal) {
|
|
27
|
+
this._timeTotal = value;
|
|
28
|
+
this.calculateTimePercent();
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
get currentVolume() {
|
|
32
|
+
return this._currentVolume;
|
|
33
|
+
}
|
|
34
|
+
set currentVolume(value) {
|
|
35
|
+
if (value != this._currentVolume) {
|
|
36
|
+
this._currentVolume = value;
|
|
37
|
+
this.calculateVolumePercent();
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
get currentTimeTotal() {
|
|
41
|
+
return this._currentTimeTotal;
|
|
42
|
+
}
|
|
43
|
+
set currentTimeTotal(value) {
|
|
44
|
+
if (value != this._currentTimeTotal) {
|
|
45
|
+
this._currentTimeTotal = value;
|
|
46
|
+
this.calculateTimePercent();
|
|
47
|
+
}
|
|
11
48
|
}
|
|
12
49
|
showClass() {
|
|
13
50
|
return true;
|
|
14
51
|
}
|
|
15
52
|
ngOnInit() {
|
|
16
|
-
|
|
53
|
+
this.calculatePercentages();
|
|
54
|
+
}
|
|
55
|
+
calculateVolumePercent() {
|
|
56
|
+
if (this.currentVolume === 0) {
|
|
57
|
+
this.volumePercent = 0;
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
17
60
|
this.volumePercent = Math.round((this.currentVolume / this.maxVolume) * 100 * 100) / 100;
|
|
18
61
|
}
|
|
19
|
-
|
|
62
|
+
}
|
|
63
|
+
calculateTimePercent() {
|
|
64
|
+
if (this.currentTimeTotal === 0) {
|
|
65
|
+
this.timePercent = 0;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
20
68
|
this.timePercent = Math.round((this.currentTimeTotal / this.timeTotal) * 100 * 100) / 100;
|
|
21
69
|
}
|
|
22
70
|
}
|
|
23
|
-
|
|
24
|
-
|
|
71
|
+
calculatePercentages() {
|
|
72
|
+
this.calculateTimePercent();
|
|
73
|
+
this.calculateVolumePercent();
|
|
25
74
|
}
|
|
26
75
|
}
|
|
27
76
|
DeliveryPlanningTileStatusComponent.decorators = [
|
|
@@ -31,17 +80,17 @@ DeliveryPlanningTileStatusComponent.decorators = [
|
|
|
31
80
|
<div class="tile-status-wrapper row">
|
|
32
81
|
<div class="tile-wrapper-around">
|
|
33
82
|
<span class="tile-label" [textContent]="('TIME' | localize) + ': ' + currentTimeTotal + ' ' + ('AVAILABLE' | localize)"></span>
|
|
34
|
-
<div class="time-wrapper" [style.--percent]="timePercent">
|
|
83
|
+
<div class="time-wrapper" [style.--percent]="timePercent" [class.overload]="timePercent > 100">
|
|
35
84
|
<div class="row">
|
|
36
|
-
<span [textContent]="'%'
|
|
85
|
+
<span [textContent]="timePercent + '%'"></span>
|
|
37
86
|
</div>
|
|
38
87
|
</div>
|
|
39
88
|
</div>
|
|
40
89
|
<div class="tile-wrapper-around">
|
|
41
90
|
<span class="tile-label" [textContent]="('VOLUME' | localize) + ': ' + currentVolume + ' ' + ('AVAILABLE' | localize)"></span>
|
|
42
|
-
<div class="volume-wrapper"[style.--percent]="volumePercent">
|
|
91
|
+
<div class="volume-wrapper"[style.--percent]="volumePercent" [class.overload]="volumePercent > 100">
|
|
43
92
|
<div class="row">
|
|
44
|
-
<span [textContent]="'%'
|
|
93
|
+
<span [textContent]="volumePercent + '%'"></span>
|
|
45
94
|
</div>
|
|
46
95
|
</div>
|
|
47
96
|
</div>
|
|
@@ -50,7 +99,9 @@ DeliveryPlanningTileStatusComponent.decorators = [
|
|
|
50
99
|
encapsulation: ViewEncapsulation.None
|
|
51
100
|
},] }
|
|
52
101
|
];
|
|
53
|
-
DeliveryPlanningTileStatusComponent.ctorParameters = () => [
|
|
102
|
+
DeliveryPlanningTileStatusComponent.ctorParameters = () => [
|
|
103
|
+
{ type: ChangeDetectorRef }
|
|
104
|
+
];
|
|
54
105
|
DeliveryPlanningTileStatusComponent.propDecorators = {
|
|
55
106
|
maxVolume: [{ type: Input }],
|
|
56
107
|
timeTotal: [{ type: Input }],
|
|
@@ -58,4 +109,4 @@ DeliveryPlanningTileStatusComponent.propDecorators = {
|
|
|
58
109
|
currentTimeTotal: [{ type: Input }],
|
|
59
110
|
showClass: [{ type: HostBinding, args: ["class.co-delivery-planning-tile-status",] }]
|
|
60
111
|
};
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-tile-status.component.js","sourceRoot":"","sources":["../../../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-tile-status/delivery-planning-tile-status.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Input, OnInit} from \"@angular/core\";\r\nimport {Component, HostBinding, ViewEncapsulation} from \"@angular/core\";\r\n\r\n@Component({\r\n    selector: \"co-delivery-planning-tile-status\",\r\n    template: `\r\n      <div class=\"tile-status-wrapper row\">\r\n        <div class=\"tile-wrapper-around\">\r\n          <span class=\"tile-label\" [textContent]=\"('TIME' | localize) + ': '  + currentTimeTotal + ' ' + ('AVAILABLE' | localize)\"></span>\r\n          <div class=\"time-wrapper\" [style.--percent]=\"timePercent\"  [class.overload]=\"timePercent > 100\">\r\n            <div class=\"row\">\r\n              <span [textContent]=\"timePercent + '%'\"></span>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div class=\"tile-wrapper-around\">\r\n          <span class=\"tile-label\" [textContent]=\"('VOLUME' | localize) + ': '  + currentVolume + ' ' + ('AVAILABLE' | localize)\"></span>\r\n          <div class=\"volume-wrapper\"[style.--percent]=\"volumePercent\"  [class.overload]=\"volumePercent > 100\">\r\n            <div class=\"row\">\r\n              <span [textContent]=\"volumePercent + '%'\"></span>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    `,\r\n    encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningTileStatusComponent implements OnInit{\r\n  public volumePercent: number = 0;\r\n  public timePercent: number = 0;\r\n\r\n  private _maxVolume: number = 0;\r\n  private _timeTotal: number = 0;\r\n  private _currentVolume: number = 0;\r\n  private _currentTimeTotal: number = 0;\r\n\r\n\r\n  public get maxVolume() {\r\n    return this._maxVolume;\r\n  }\r\n\r\n  @Input()\r\n  public set maxVolume(value: number) {\r\n    if(value != this._maxVolume) {\r\n      this._maxVolume = value\r\n      this.calculateVolumePercent();\r\n    }\r\n  }\r\n\r\n  public get timeTotal() {\r\n    return this._timeTotal;\r\n  }\r\n  @Input()\r\n  public set timeTotal(value: number) {\r\n    if(value != this._timeTotal) {\r\n      this._timeTotal = value;\r\n      this.calculateTimePercent();\r\n    }\r\n  }\r\n\r\n  public get currentVolume() {\r\n    return this._currentVolume;\r\n  }\r\n  @Input()\r\n  public set currentVolume(value: number) {\r\n    if(value != this._currentVolume) {\r\n      this._currentVolume = value;\r\n      this.calculateVolumePercent();\r\n    }\r\n  }\r\n\r\n\r\n  public get currentTimeTotal() {\r\n    return this._currentTimeTotal;\r\n  }\r\n\r\n  @Input()\r\n  public set currentTimeTotal(value: number) {\r\n    if(value != this._currentTimeTotal) {\r\n      this._currentTimeTotal = value;\r\n      this.calculateTimePercent();\r\n    }\r\n  }\r\n\r\n  @HostBinding(\"class.co-delivery-planning-tile-status\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(private _changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.calculatePercentages();\r\n  }\r\n\r\n  public calculateVolumePercent() {\r\n    if(this.currentVolume === 0) {\r\n     this.volumePercent = 0;\r\n    } else {\r\n      this.volumePercent = Math.round((this.currentVolume / this.maxVolume) * 100 * 100) / 100;\r\n    }\r\n  }\r\n\r\n  public calculateTimePercent() {\r\n    if(this.currentTimeTotal === 0) {\r\n      this.timePercent = 0;\r\n    } else {\r\n      this.timePercent = Math.round((this.currentTimeTotal / this.timeTotal) * 100 * 100) / 100;\r\n    }\r\n  }\r\n\r\n  public calculatePercentages() {\r\n    this.calculateTimePercent();\r\n    this.calculateVolumePercent();\r\n  }\r\n\r\n\r\n\r\n\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from "@angular/core";
|
|
3
3
|
import { DatePipe } from "@angular/common";
|
|
4
4
|
import { DeliveryPlanningService } from "../../../../../delivery-planning/service/delivery-planning.service";
|
|
5
5
|
import { Icon } from "../../../../../../enum/icon.enum";
|
|
@@ -13,11 +13,14 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
13
13
|
this.icons = Icon;
|
|
14
14
|
this.tileModes = DeliveryPlanningTileModes;
|
|
15
15
|
this.ordersLoaded = false;
|
|
16
|
+
this._subs = [];
|
|
16
17
|
this.disabled = false;
|
|
17
18
|
this.expandedEvent = new EventEmitter();
|
|
18
|
-
this.
|
|
19
|
+
this.deleteOrderEvent = new EventEmitter();
|
|
20
|
+
this.deleteOrderLineEvent = new EventEmitter();
|
|
21
|
+
this.editOrderEvent = new EventEmitter();
|
|
19
22
|
this.getTransportOrdersEvent = new EventEmitter();
|
|
20
|
-
this.
|
|
23
|
+
this.timeChangeEvent = new EventEmitter();
|
|
21
24
|
this.openSettingsDialogEvent = new EventEmitter();
|
|
22
25
|
this.calendarPlanEvent = new EventEmitter();
|
|
23
26
|
}
|
|
@@ -34,6 +37,16 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
34
37
|
this.ordersLoaded = true;
|
|
35
38
|
this.getTransportOrdersEvent.emit(this.transportDay);
|
|
36
39
|
}
|
|
40
|
+
this._subs.push(this._deliveryPlanningService.reRenderHourScheduling.subscribe(event => {
|
|
41
|
+
this.hourSchedulingComp.generateScheduledObjects();
|
|
42
|
+
}));
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
ngOnDestroy() {
|
|
46
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
47
|
+
this._subs.forEach((sub) => {
|
|
48
|
+
sub.unsubscribe();
|
|
49
|
+
});
|
|
37
50
|
});
|
|
38
51
|
}
|
|
39
52
|
drop(event) {
|
|
@@ -54,8 +67,11 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
54
67
|
});
|
|
55
68
|
}
|
|
56
69
|
}
|
|
57
|
-
|
|
58
|
-
this.
|
|
70
|
+
handleDeleteOrderClick(order) {
|
|
71
|
+
this.deleteOrderEvent.emit([order, this.transportDay]);
|
|
72
|
+
}
|
|
73
|
+
handleDeleteOrderLineClick(data) {
|
|
74
|
+
this.deleteOrderLineEvent.emit(data);
|
|
59
75
|
}
|
|
60
76
|
handleSettingsSave() {
|
|
61
77
|
}
|
|
@@ -67,15 +83,14 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
67
83
|
this.openSettingsDialogEvent.emit(this.transportDay);
|
|
68
84
|
}
|
|
69
85
|
handleTimeChangeEvent(obj) {
|
|
70
|
-
|
|
71
|
-
let order = this.transportDay.plannedOrders.find(planOrder => planOrder.transactionNr === transNr);
|
|
72
|
-
order.startTime = new Date(obj['startTime']);
|
|
73
|
-
order.endTime = new Date(obj['endTime']);
|
|
74
|
-
this.updatePlanningTransportWeek.emit();
|
|
86
|
+
this.timeChangeEvent.emit(obj);
|
|
75
87
|
}
|
|
76
88
|
handleCalendarPlanEvent(data) {
|
|
77
89
|
this.calendarPlanEvent.emit(data);
|
|
78
90
|
}
|
|
91
|
+
handleEditOrderEvent(planOrder) {
|
|
92
|
+
this.editOrderEvent.emit(planOrder);
|
|
93
|
+
}
|
|
79
94
|
}
|
|
80
95
|
DeliveryPlanningOverviewTileComponent.decorators = [
|
|
81
96
|
{ type: Component, args: [{
|
|
@@ -108,7 +123,7 @@ DeliveryPlanningOverviewTileComponent.decorators = [
|
|
|
108
123
|
<div class="planning-short-line-wrapper" *ngIf="!expanded">
|
|
109
124
|
<co-delivery-planning-overview-short-line
|
|
110
125
|
*ngFor="let order of transportDay?.plannedOrders"
|
|
111
|
-
(
|
|
126
|
+
(deleteOrderEvent)="handleDeleteOrderClick($event)"
|
|
112
127
|
[order]="order">
|
|
113
128
|
</co-delivery-planning-overview-short-line>
|
|
114
129
|
</div>
|
|
@@ -120,7 +135,9 @@ DeliveryPlanningOverviewTileComponent.decorators = [
|
|
|
120
135
|
*ngIf="tileMode === tileModes.Normal">
|
|
121
136
|
<co-delivery-planning-overview-tile-line cdkDrag
|
|
122
137
|
*ngFor="let order of transportDay?.plannedOrders"
|
|
123
|
-
(
|
|
138
|
+
(deleteOrderEvent)="handleDeleteOrderClick($event)"
|
|
139
|
+
(deleteOrderLineEvent)="handleDeleteOrderLineClick($event)"
|
|
140
|
+
(editOrderEvent)="handleEditOrderEvent($event)"
|
|
124
141
|
[order]="order">
|
|
125
142
|
</co-delivery-planning-overview-tile-line>
|
|
126
143
|
</div>
|
|
@@ -135,14 +152,16 @@ DeliveryPlanningOverviewTileComponent.decorators = [
|
|
|
135
152
|
>
|
|
136
153
|
<co-delivery-planning-overview-tile-line cdkDrag
|
|
137
154
|
*ngFor="let obj of objects"
|
|
138
|
-
(
|
|
155
|
+
(deleteOrderEvent)="handleDeleteOrderClick($event)"
|
|
156
|
+
(deleteOrderLineEvent)="handleDeleteOrderLineClick($event)"
|
|
157
|
+
(editOrderEvent)="handleEditOrderEvent($event)"
|
|
139
158
|
[order]="obj">
|
|
140
159
|
</co-delivery-planning-overview-tile-line>
|
|
141
160
|
</div>
|
|
142
161
|
</div>
|
|
143
162
|
</ng-template>
|
|
144
163
|
|
|
145
|
-
<co-hour-scheduling *ngIf="ordersLoaded && tileMode === tileModes.Calendar"
|
|
164
|
+
<co-hour-scheduling #hourSchedulingComponent *ngIf="ordersLoaded && tileMode === tileModes.Calendar"
|
|
146
165
|
[schedule]="transportDay"
|
|
147
166
|
[startTimeProp]="'startTime'"
|
|
148
167
|
[endTimeProp]="'endTime'"
|
|
@@ -173,11 +192,14 @@ DeliveryPlanningOverviewTileComponent.propDecorators = {
|
|
|
173
192
|
disabled: [{ type: Input }],
|
|
174
193
|
transportDay: [{ type: Input }],
|
|
175
194
|
expandedEvent: [{ type: Output }],
|
|
176
|
-
|
|
195
|
+
deleteOrderEvent: [{ type: Output }],
|
|
196
|
+
deleteOrderLineEvent: [{ type: Output }],
|
|
197
|
+
editOrderEvent: [{ type: Output }],
|
|
177
198
|
getTransportOrdersEvent: [{ type: Output }],
|
|
178
|
-
|
|
199
|
+
timeChangeEvent: [{ type: Output }],
|
|
179
200
|
openSettingsDialogEvent: [{ type: Output }],
|
|
180
201
|
calendarPlanEvent: [{ type: Output }],
|
|
202
|
+
hourSchedulingComp: [{ type: ViewChild, args: ['hourSchedulingComponent',] }],
|
|
181
203
|
showClass: [{ type: HostBinding, args: ["class.co-delivery-planning-overview-tile",] }]
|
|
182
204
|
};
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-overview-tile.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CdkDragDrop} from '@angular/cdk/drag-drop';\r\nimport {PlanOrder} from \"@colijnit/transactionapi/build/model/plan-order.bo\";\r\nimport {PlanningTransportWeekDay} from \"@colijnit/transactionapi/build/model/planning-transport-week-day.bo\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {DeliveryPlanningService} from \"../../../../../delivery-planning/service/delivery-planning.service\";\r\nimport {Icon} from \"../../../../../../enum/icon.enum\";\r\nimport {IconCacheService} from \"../../../../../../service/icon-cache.service\";\r\nimport {DeliveryPlanningTileModes} from \"../../../../../../enum/delivery-planning-tile-modes.enum\";\r\n\r\n@Component({\r\n  selector: \"co-delivery-planning-overview-tile\",\r\n  template: `\r\n    <div class=\"delivery-planning-overview-tile-wrapper\">\r\n      <div class=\"header-tile-wrapper\">\r\n        <div class=\"header-title\" (click)=\"expandedChange()\">\r\n          <co-icon *ngIf=\"!expanded\" [iconData]=\"iconCacheService.getIcon(icons.CaretDownSolid)\"></co-icon>\r\n          <co-icon *ngIf=\"expanded\" [iconData]=\"iconCacheService.getIcon(icons.CaretUpSolid)\"></co-icon>\r\n          <span class=\"header-title\" [textContent]=\"transportDay?.transport.registrationNumber\"></span>\r\n        </div>\r\n        <div class=\"truck-header-tile\">\r\n          <co-icon\r\n            [iconData]=\"iconCacheService.getIcon(icons.TruckContainerDuo)\"></co-icon>\r\n          <co-icon class=\"small\" (click)=\"openSettingsDialog()\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.SlidersUpRegular)\"></co-icon>\r\n\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"planning-wrapper\">\r\n        <div class=\"status-wrapper row\">\r\n          <co-delivery-planning-tile-status\r\n            [currentVolume]=\"transportDay?.orderAmount\"\r\n            [maxVolume]=\"transportDay?.maxOrderAmount\"\r\n            [currentTimeTotal]=\"transportDay?.minutes\"\r\n            [timeTotal]=\"transportDay?.maxMinutes\">\r\n          </co-delivery-planning-tile-status>\r\n          <div class=\"planning-short-line-wrapper\" *ngIf=\"!expanded\">\r\n            <co-delivery-planning-overview-short-line\r\n              *ngFor=\"let order of transportDay?.plannedOrders\"\r\n              (deleteLineEvent)=\"handleDeleteLineClick($event)\"\r\n              [order]=\"order\">\r\n            </co-delivery-planning-overview-short-line>\r\n          </div>\r\n        </div>\r\n        <co-collapsible [expanded]=\"expanded\">\r\n          <div class=\"tile-content-wrapper column\">\r\n\r\n            <div class=\"planning-lines-wrapper\" cdkDropList (cdkDropListDropped)=\"drop($event)\"\r\n                 *ngIf=\"tileMode === tileModes.Normal\">\r\n              <co-delivery-planning-overview-tile-line cdkDrag\r\n                                                       *ngFor=\"let order of transportDay?.plannedOrders\"\r\n                                                       (deleteLineEvent)=\"handleDeleteLineClick($event)\"\r\n                                                       [order]=\"order\">\r\n              </co-delivery-planning-overview-tile-line>\r\n            </div>\r\n\r\n            <ng-template #customTemplate let-hour=\"hour\" let-objects=\"objects\">\r\n              <div>\r\n                <div\r\n                  *ngFor=\"let obj of objects\"\r\n                  class=\"custom-scheduled-object\"\r\n                  draggable=\"true\"\r\n                  (dragstart)=\"onCustomDragStart($event, obj)\"\r\n                >\r\n                  <co-delivery-planning-overview-tile-line cdkDrag\r\n                                                           *ngFor=\"let obj of objects\"\r\n                                                           (deleteLineEvent)=\"handleDeleteLineClick($event)\"\r\n                                                           [order]=\"obj\">\r\n                  </co-delivery-planning-overview-tile-line>\r\n                </div>\r\n              </div>\r\n            </ng-template>\r\n\r\n            <co-hour-scheduling *ngIf=\"ordersLoaded && tileMode === tileModes.Calendar\"\r\n                                [schedule]=\"transportDay\"\r\n                                [startTimeProp]=\"'startTime'\"\r\n                                [endTimeProp]=\"'endTime'\"\r\n                                [objectsProp]=\"'plannedOrders'\"\r\n                                [childProp]=\"'transport'\"\r\n                                [customTemplate]=\"customTemplate\"\r\n                                [customTemplateUsed]=\"true\"\r\n                                [idProp]=\"'transId'\"\r\n                                (timeChangeEvent)=\"handleTimeChangeEvent($event)\"\r\n                                (drop)=\"handleDrop($event)\"\r\n                                (newObjectPlanEvent)=\"handleCalendarPlanEvent($event)\"\r\n            ></co-hour-scheduling>\r\n          </div>\r\n        </co-collapsible>\r\n      </div>\r\n\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningOverviewTileComponent implements OnInit{\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly tileModes: typeof DeliveryPlanningTileModes = DeliveryPlanningTileModes;\r\n\r\n  public ordersLoaded: boolean = false;\r\n\r\n  @Input()\r\n  public disabled: boolean = false;\r\n\r\n  @Input()\r\n  public transportDay: PlanningTransportWeekDay;\r\n\r\n  @Output()\r\n  public expandedEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public deleteLineEvent: EventEmitter<[PlanOrder, PlanningTransportWeekDay]> = new EventEmitter<[PlanOrder, PlanningTransportWeekDay]>();\r\n\r\n  @Output()\r\n  public getTransportOrdersEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public updatePlanningTransportWeek: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public openSettingsDialogEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public calendarPlanEvent: EventEmitter<{currentHour: string, data: string}> = new EventEmitter<{currentHour: string, data: string}>();\r\n\r\n  public get tileMode() {\r\n    return this._deliveryPlanningService.currentTileMode;\r\n  }\r\n\r\n  public expanded: boolean;\r\n\r\n  @HostBinding(\"class.co-delivery-planning-overview-tile\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    private _datePipe: DatePipe,\r\n    private _deliveryPlanningService: DeliveryPlanningService,\r\n    public iconCacheService: IconCacheService) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n        if(this.transportDay) {\r\n          await this._deliveryPlanningService.getTransportOrders(this.transportDay);\r\n          this.ordersLoaded = true;\r\n          this.getTransportOrdersEvent.emit(this.transportDay);\r\n        }\r\n    }\r\n\r\n  public drop(event: CdkDragDrop<string[]>) {\r\n\r\n    // moveItemInArray(this.planningLines, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  public handleDrop(event: DragEvent) {\r\n    event.preventDefault()\r\n    event.stopPropagation();\r\n  }\r\n\r\n\r\n\r\n  public formattedDate(date: Date) {\r\n    return `${this._datePipe.transform(date, 'H:mm', \"GMT+1\")}`;\r\n  }\r\n\r\n  public expandedChange() {\r\n    this.expanded = !this.expanded;\r\n    if(this.expanded) {\r\n       this._deliveryPlanningService.getTransportOrders(this.transportDay).then( result => {\r\n         this.transportDay = result;\r\n       });\r\n    }\r\n  }\r\n\r\n  public handleDeleteLineClick(order: PlanOrder) {\r\n    this.deleteLineEvent.emit([order, this.transportDay]);\r\n  }\r\n\r\n  public handleSettingsSave() {\r\n\r\n  }\r\n\r\n  public onCustomDragStart(event: DragEvent, obj: PlanOrder) {\r\n    const currentHour = obj['startTime'] + \":00\"; // Assuming start hour is used\r\n    event.dataTransfer!.setData(\"text\", JSON.stringify({ obj, currentHour }));\r\n  }\r\n\r\n  public openSettingsDialog() {\r\n    this.openSettingsDialogEvent.emit(this.transportDay);\r\n  }\r\n\r\n  public handleTimeChangeEvent(obj: Object) {\r\n    let transNr = obj['transactionNr'];\r\n    let order = this.transportDay.plannedOrders.find( planOrder => planOrder.transactionNr === transNr);\r\n    order.startTime = new Date(obj['startTime']);\r\n    order.endTime = new Date(obj['endTime']);\r\n\r\n    this.updatePlanningTransportWeek.emit();\r\n  }\r\n\r\n  public handleCalendarPlanEvent(data:{currentHour: string, data: string}) {\r\n    this.calendarPlanEvent.emit(data);\r\n  }\r\n\r\n}\r\n\r\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-overview-tile.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport {CdkDragDrop} from '@angular/cdk/drag-drop';\r\nimport {PlanOrder} from \"@colijnit/transactionapi/build/model/plan-order.bo\";\r\nimport {PlanningTransportWeekDay} from \"@colijnit/transactionapi/build/model/planning-transport-week-day.bo\";\r\nimport {DatePipe} from \"@angular/common\";\r\nimport {DeliveryPlanningService} from \"../../../../../delivery-planning/service/delivery-planning.service\";\r\nimport {Icon} from \"../../../../../../enum/icon.enum\";\r\nimport {IconCacheService} from \"../../../../../../service/icon-cache.service\";\r\nimport {DeliveryPlanningTileModes} from \"../../../../../../enum/delivery-planning-tile-modes.enum\";\r\nimport {PlanningTransportWeek} from \"@colijnit/transactionapi/build/model/planning-transport-week.bo\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {HourSchedulingComponent} from \"@colijnit/corecomponents_v12\";\r\nimport {PlanOrderLine} from \"@colijnit/transactionapi/build/model/plan-order-line.bo\";\r\n\r\n@Component({\r\n  selector: \"co-delivery-planning-overview-tile\",\r\n  template: `\r\n    <div class=\"delivery-planning-overview-tile-wrapper\">\r\n      <div class=\"header-tile-wrapper\">\r\n        <div class=\"header-title\" (click)=\"expandedChange()\">\r\n          <co-icon *ngIf=\"!expanded\" [iconData]=\"iconCacheService.getIcon(icons.CaretDownSolid)\"></co-icon>\r\n          <co-icon *ngIf=\"expanded\" [iconData]=\"iconCacheService.getIcon(icons.CaretUpSolid)\"></co-icon>\r\n          <span class=\"header-title\" [textContent]=\"transportDay?.transport.registrationNumber\"></span>\r\n        </div>\r\n        <div class=\"truck-header-tile\">\r\n          <co-icon\r\n            [iconData]=\"iconCacheService.getIcon(icons.TruckContainerDuo)\"></co-icon>\r\n          <co-icon class=\"small\" (click)=\"openSettingsDialog()\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.SlidersUpRegular)\"></co-icon>\r\n\r\n        </div>\r\n\r\n      </div>\r\n      <div class=\"planning-wrapper\">\r\n        <div class=\"status-wrapper row\">\r\n          <co-delivery-planning-tile-status\r\n            [currentVolume]=\"transportDay?.orderAmount\"\r\n            [maxVolume]=\"transportDay?.maxOrderAmount\"\r\n            [currentTimeTotal]=\"transportDay?.minutes\"\r\n            [timeTotal]=\"transportDay?.maxMinutes\">\r\n          </co-delivery-planning-tile-status>\r\n          <div class=\"planning-short-line-wrapper\" *ngIf=\"!expanded\">\r\n            <co-delivery-planning-overview-short-line\r\n              *ngFor=\"let order of transportDay?.plannedOrders\"\r\n              (deleteOrderEvent)=\"handleDeleteOrderClick($event)\"\r\n              [order]=\"order\">\r\n            </co-delivery-planning-overview-short-line>\r\n          </div>\r\n        </div>\r\n        <co-collapsible [expanded]=\"expanded\">\r\n          <div class=\"tile-content-wrapper column\">\r\n\r\n            <div class=\"planning-lines-wrapper\" cdkDropList (cdkDropListDropped)=\"drop($event)\"\r\n                 *ngIf=\"tileMode === tileModes.Normal\">\r\n              <co-delivery-planning-overview-tile-line cdkDrag\r\n                                                       *ngFor=\"let order of transportDay?.plannedOrders\"\r\n                                                       (deleteOrderEvent)=\"handleDeleteOrderClick($event)\"\r\n                                                       (deleteOrderLineEvent)=\"handleDeleteOrderLineClick($event)\"\r\n                                                       (editOrderEvent)=\"handleEditOrderEvent($event)\"\r\n                                                       [order]=\"order\">\r\n              </co-delivery-planning-overview-tile-line>\r\n            </div>\r\n\r\n            <ng-template #customTemplate let-hour=\"hour\" let-objects=\"objects\">\r\n              <div>\r\n                <div\r\n                  *ngFor=\"let obj of objects\"\r\n                  class=\"custom-scheduled-object\"\r\n                  draggable=\"true\"\r\n                  (dragstart)=\"onCustomDragStart($event, obj)\"\r\n                >\r\n                  <co-delivery-planning-overview-tile-line cdkDrag\r\n                                                           *ngFor=\"let obj of objects\"\r\n                                                           (deleteOrderEvent)=\"handleDeleteOrderClick($event)\"\r\n                                                           (deleteOrderLineEvent)=\"handleDeleteOrderLineClick($event)\"\r\n                                                           (editOrderEvent)=\"handleEditOrderEvent($event)\"\r\n                                                           [order]=\"obj\">\r\n                  </co-delivery-planning-overview-tile-line>\r\n                </div>\r\n              </div>\r\n            </ng-template>\r\n\r\n            <co-hour-scheduling #hourSchedulingComponent *ngIf=\"ordersLoaded && tileMode === tileModes.Calendar\"\r\n                                [schedule]=\"transportDay\"\r\n                                [startTimeProp]=\"'startTime'\"\r\n                                [endTimeProp]=\"'endTime'\"\r\n                                [objectsProp]=\"'plannedOrders'\"\r\n                                [childProp]=\"'transport'\"\r\n                                [customTemplate]=\"customTemplate\"\r\n                                [customTemplateUsed]=\"true\"\r\n                                [idProp]=\"'transId'\"\r\n                                (timeChangeEvent)=\"handleTimeChangeEvent($event)\"\r\n                                (drop)=\"handleDrop($event)\"\r\n                                (newObjectPlanEvent)=\"handleCalendarPlanEvent($event)\"\r\n            ></co-hour-scheduling>\r\n          </div>\r\n        </co-collapsible>\r\n      </div>\r\n\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningOverviewTileComponent implements OnInit, OnDestroy{\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly tileModes: typeof DeliveryPlanningTileModes = DeliveryPlanningTileModes;\r\n\r\n  public ordersLoaded: boolean = false;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  @Input()\r\n  public disabled: boolean = false;\r\n\r\n  @Input()\r\n  public transportDay: PlanningTransportWeekDay;\r\n\r\n  @Output()\r\n  public expandedEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public deleteOrderEvent: EventEmitter<[PlanOrder, PlanningTransportWeekDay]> = new EventEmitter<[PlanOrder, PlanningTransportWeekDay]>();\r\n\r\n  @Output()\r\n  public deleteOrderLineEvent: EventEmitter<{order: PlanOrder, line: PlanOrderLine}> = new EventEmitter<{order: PlanOrder, line: PlanOrderLine}>();\r\n\r\n  @Output()\r\n  public editOrderEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n\r\n  @Output()\r\n  public getTransportOrdersEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n\r\n  @Output()\r\n  public timeChangeEvent: EventEmitter<Object> = new EventEmitter<Object>();\r\n\r\n  @Output()\r\n  public openSettingsDialogEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public calendarPlanEvent: EventEmitter<{currentHour: string, data: string}> = new EventEmitter<{currentHour: string, data: string}>();\r\n\r\n  @ViewChild('hourSchedulingComponent')\r\n  public hourSchedulingComp: HourSchedulingComponent;\r\n\r\n  public get tileMode() {\r\n    return this._deliveryPlanningService.currentTileMode;\r\n  }\r\n\r\n  public expanded: boolean;\r\n\r\n  @HostBinding(\"class.co-delivery-planning-overview-tile\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    private _datePipe: DatePipe,\r\n    private _deliveryPlanningService: DeliveryPlanningService,\r\n    public iconCacheService: IconCacheService) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n        if(this.transportDay) {\r\n          await this._deliveryPlanningService.getTransportOrders(this.transportDay);\r\n          this.ordersLoaded = true;\r\n          this.getTransportOrdersEvent.emit(this.transportDay);\r\n        }\r\n        this._subs.push( this._deliveryPlanningService.reRenderHourScheduling.subscribe( event => {\r\n          this.hourSchedulingComp.generateScheduledObjects();\r\n        }));\r\n\r\n    }\r\n\r\n    async ngOnDestroy(): Promise<void> {\r\n      this._subs.forEach( (sub: Subscription) => {\r\n        sub.unsubscribe();\r\n      });\r\n    }\r\n\r\n  public drop(event: CdkDragDrop<string[]>) {\r\n\r\n    // moveItemInArray(this.planningLines, event.previousIndex, event.currentIndex);\r\n  }\r\n\r\n  public handleDrop(event: DragEvent) {\r\n    event.preventDefault()\r\n    event.stopPropagation();\r\n  }\r\n\r\n\r\n\r\n  public formattedDate(date: Date) {\r\n    return `${this._datePipe.transform(date, 'H:mm', \"GMT+1\")}`;\r\n  }\r\n\r\n  public expandedChange() {\r\n    this.expanded = !this.expanded;\r\n    if(this.expanded) {\r\n       this._deliveryPlanningService.getTransportOrders(this.transportDay).then( result => {\r\n         this.transportDay = result;\r\n       });\r\n    }\r\n  }\r\n\r\n  public handleDeleteOrderClick(order: PlanOrder) {\r\n    this.deleteOrderEvent.emit([order, this.transportDay]);\r\n  }\r\n\r\n  public handleDeleteOrderLineClick(data:{order: PlanOrder, line: PlanOrderLine}) {\r\n    this.deleteOrderLineEvent.emit(data);\r\n  }\r\n\r\n\r\n  public handleSettingsSave() {\r\n\r\n  }\r\n\r\n  public onCustomDragStart(event: DragEvent, obj: PlanOrder) {\r\n    const currentHour = obj['startTime'] + \":00\"; // Assuming start hour is used\r\n    event.dataTransfer!.setData(\"text\", JSON.stringify({ obj, currentHour }));\r\n  }\r\n\r\n  public openSettingsDialog() {\r\n    this.openSettingsDialogEvent.emit(this.transportDay);\r\n  }\r\n\r\n  public handleTimeChangeEvent(obj: Object) {\r\n    this.timeChangeEvent.emit(obj);\r\n  }\r\n\r\n  public handleCalendarPlanEvent(data:{currentHour: string, data: string}) {\r\n    this.calendarPlanEvent.emit(data);\r\n  }\r\n\r\n  public handleEditOrderEvent(planOrder: PlanOrder) {\r\n    this.editOrderEvent.emit(planOrder);\r\n  }\r\n\r\n}\r\n\r\n"]}
|