@colijnit/transaction 255.1.38 → 255.1.40
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 +414 -91
- package/bundles/colijnit-transaction.umd.js.map +1 -1
- package/colijnit-transaction-255.1.39.tgz +0 -0
- package/colijnit-transaction.metadata.json +1 -1
- package/esm2015/lib/component/core/base/transaction-payment-base.component.js +12 -4
- package/esm2015/lib/component/delivery-planning/service/delivery-planning.service.js +18 -1
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.js +53 -33
- 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 +21 -11
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.js +12 -2
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile-settings-popup/delivery-planning-overview-tile-settings-popup.component.js +53 -3
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.js +79 -24
- package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.component.js +2 -1
- package/esm2015/lib/component/transaction/transaction.component.js +4 -1
- package/esm2015/lib/component/transaction-card/transaction-card-planning/transaction-card-planning.component.js +33 -4
- package/esm2015/lib/component/transaction-internal/transaction-internal.component.js +7 -4
- package/esm2015/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.js +2 -1
- package/esm2015/lib/component/transaction-line-fields/transaction-line-warehouse.component.js +2 -2
- package/esm2015/lib/component/transaction-line-side-panel-planning/transaction-line-side-panel-planning.component.js +2 -2
- package/esm2015/lib/component/transaction-line-side-panel-sales/transaction-line-side-panel-sales-reservation/transaction-line-side-panel-sales-reservation/transaction-line-side-panel-sales-reservation.component.js +21 -8
- package/esm2015/lib/component/transaction-line-side-panel-sales/transaction-line-side-panel-sales.module.js +3 -2
- package/esm2015/lib/component/transaction-lines-side-panel/transaction-lines-side-panel-cash-desk/transaction-lines-side-panel-cash-desk.component.js +22 -7
- package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.component.js +2 -1
- package/esm2015/lib/component/transaction-search/transaction-search-tile/transaction-purchase-reservation-order-tile/transaction-purchase-reservation-order-tile.component.js +4 -14
- package/esm2015/lib/component/transaction-service-overview/components/transaction-service-message.component.js +3 -3
- package/esm2015/lib/component/transaction-service-overview/components/transaction-service-message.module.js +4 -3
- package/esm2015/lib/component/transaction-service-overview/transaction-service-overview.component.js +5 -3
- package/esm2015/lib/enum/icon.enum.js +7 -1
- package/esm2015/lib/enum/transaction-cfg-name.enum.js +3 -1
- package/esm2015/lib/model/icon-svg.js +7 -1
- package/esm2015/lib/service/transaction-create.service.js +12 -1
- package/esm2015/lib/service/transaction-payment.service.js +9 -3
- package/esm2015/lib/service/transaction.service.js +11 -4
- package/esm2015/lib/transaction-version.js +3 -3
- package/fesm2015/colijnit-transaction.js +368 -117
- package/fesm2015/colijnit-transaction.js.map +1 -1
- package/lib/component/core/base/transaction-payment-base.component.d.ts +5 -2
- package/lib/component/delivery-planning/service/delivery-planning.service.d.ts +4 -0
- package/lib/component/delivery-planning/style/_layout.scss +22 -1
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.d.ts +9 -6
- 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 +3 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/component/delivery-planning-overview-tile-line/style/_layout.scss +25 -10
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.d.ts +9 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/style/_layout.scss +13 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile-settings-popup/delivery-planning-overview-tile-settings-popup.component.d.ts +14 -3
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.d.ts +16 -0
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/style/_layout.scss +9 -6
- package/lib/component/delivery-planning-main/style/_layout.scss +0 -1
- package/lib/component/transaction/transaction.component.d.ts +1 -0
- package/lib/component/transaction-card/transaction-card-planning/transaction-card-planning.component.d.ts +19 -0
- package/lib/component/transaction-internal/style/_layout.scss +6 -0
- package/lib/component/transaction-internal/transaction-internal.component.d.ts +1 -0
- package/lib/component/transaction-line-side-panel-planning/style/_layout.scss +20 -17
- package/lib/component/transaction-line-side-panel-sales/transaction-line-side-panel-sales-reservation/transaction-line-side-panel-sales-reservation/style/_layout.scss +16 -4
- package/lib/component/transaction-line-side-panel-sales/transaction-line-side-panel-sales-reservation/transaction-line-side-panel-sales-reservation/transaction-line-side-panel-sales-reservation.component.d.ts +5 -1
- package/lib/component/transaction-lines-side-panel/transaction-lines-side-panel-cash-desk/transaction-lines-side-panel-cash-desk.component.d.ts +2 -1
- package/lib/component/transaction-search/transaction-search-tile/transaction-purchase-reservation-order-tile/style/_layout.scss +26 -20
- package/lib/component/transaction-service-overview/transaction-service-overview.component.d.ts +2 -0
- package/lib/enum/icon.enum.d.ts +6 -0
- package/lib/enum/transaction-cfg-name.enum.d.ts +2 -1
- package/lib/service/transaction-create.service.d.ts +2 -0
- package/lib/service/transaction-payment.service.d.ts +3 -1
- package/lib/service/transaction.service.d.ts +2 -1
- package/package.json +1 -1
|
@@ -19,6 +19,7 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
19
19
|
this.getTransportOrdersEvent = new EventEmitter();
|
|
20
20
|
this.updatePlanningTransportWeek = new EventEmitter();
|
|
21
21
|
this.openSettingsDialogEvent = new EventEmitter();
|
|
22
|
+
this.calendarPlanEvent = new EventEmitter();
|
|
22
23
|
}
|
|
23
24
|
get tileMode() {
|
|
24
25
|
return this._deliveryPlanningService.currentTileMode;
|
|
@@ -38,6 +39,10 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
38
39
|
drop(event) {
|
|
39
40
|
// moveItemInArray(this.planningLines, event.previousIndex, event.currentIndex);
|
|
40
41
|
}
|
|
42
|
+
handleDrop(event) {
|
|
43
|
+
event.preventDefault();
|
|
44
|
+
event.stopPropagation();
|
|
45
|
+
}
|
|
41
46
|
formattedDate(date) {
|
|
42
47
|
return `${this._datePipe.transform(date, 'H:mm', "GMT+1")}`;
|
|
43
48
|
}
|
|
@@ -68,6 +73,9 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
68
73
|
order.endTime = new Date(obj['endTime']);
|
|
69
74
|
this.updatePlanningTransportWeek.emit();
|
|
70
75
|
}
|
|
76
|
+
handleCalendarPlanEvent(data) {
|
|
77
|
+
this.calendarPlanEvent.emit(data);
|
|
78
|
+
}
|
|
71
79
|
}
|
|
72
80
|
DeliveryPlanningOverviewTileComponent.decorators = [
|
|
73
81
|
{ type: Component, args: [{
|
|
@@ -144,7 +152,8 @@ DeliveryPlanningOverviewTileComponent.decorators = [
|
|
|
144
152
|
[customTemplateUsed]="true"
|
|
145
153
|
[idProp]="'transId'"
|
|
146
154
|
(timeChangeEvent)="handleTimeChangeEvent($event)"
|
|
147
|
-
|
|
155
|
+
(drop)="handleDrop($event)"
|
|
156
|
+
(newObjectPlanEvent)="handleCalendarPlanEvent($event)"
|
|
148
157
|
></co-hour-scheduling>
|
|
149
158
|
</div>
|
|
150
159
|
</co-collapsible>
|
|
@@ -168,6 +177,7 @@ DeliveryPlanningOverviewTileComponent.propDecorators = {
|
|
|
168
177
|
getTransportOrdersEvent: [{ type: Output }],
|
|
169
178
|
updatePlanningTransportWeek: [{ type: Output }],
|
|
170
179
|
openSettingsDialogEvent: [{ type: Output }],
|
|
180
|
+
calendarPlanEvent: [{ type: Output }],
|
|
171
181
|
showClass: [{ type: HostBinding, args: ["class.co-delivery-planning-overview-tile",] }]
|
|
172
182
|
};
|
|
173
|
-
//# 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\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  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    // moveItemInArray(this.planningLines, event.previousIndex, event.currentIndex);\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}\r\n\r\n"]}
|
|
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"]}
|
|
@@ -1,15 +1,22 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
1
2
|
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
3
|
import { DeliveryPlanningService } from "../../../../../delivery-planning/service/delivery-planning.service";
|
|
3
4
|
import { Icon } from "../../../../../../enum/icon.enum";
|
|
4
5
|
import { IconCacheService } from "../../../../../../service/icon-cache.service";
|
|
6
|
+
import { TransactionConnectorService } from "../../../../../../service/transaction-connector.service";
|
|
7
|
+
import { OrderLinesPlannedRequest } from "@colijnit/transactionapi/build/model/order-lines-planned-request.bo";
|
|
8
|
+
import { PlanningFilterObject } from "@colijnit/transactionapi/build/model/planning-filter-object.bo";
|
|
5
9
|
export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
6
|
-
constructor(_deliveryPlanningService, iconCacheService) {
|
|
10
|
+
constructor(_deliveryPlanningService, iconCacheService, _transaction) {
|
|
7
11
|
this._deliveryPlanningService = _deliveryPlanningService;
|
|
8
12
|
this.iconCacheService = iconCacheService;
|
|
13
|
+
this._transaction = _transaction;
|
|
9
14
|
this.icons = Icon;
|
|
10
15
|
this.settingsChanged = false;
|
|
16
|
+
this._subs = [];
|
|
11
17
|
this.closeEvent = new EventEmitter();
|
|
12
18
|
this.onSaveAction = new EventEmitter();
|
|
19
|
+
this.availabilityChecked = new EventEmitter();
|
|
13
20
|
}
|
|
14
21
|
get districts() {
|
|
15
22
|
return this._deliveryPlanningService.districts;
|
|
@@ -30,6 +37,14 @@ export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
|
30
37
|
return true;
|
|
31
38
|
}
|
|
32
39
|
ngOnInit() {
|
|
40
|
+
this._subs.push(this._deliveryPlanningService.availabilityCheckEvent.subscribe((transId) => __awaiter(this, void 0, void 0, function* () {
|
|
41
|
+
yield this.handleAvailabilityChecked(transId);
|
|
42
|
+
})));
|
|
43
|
+
}
|
|
44
|
+
ngOnDestroy() {
|
|
45
|
+
this._subs.forEach(sub => {
|
|
46
|
+
sub.unsubscribe();
|
|
47
|
+
});
|
|
33
48
|
}
|
|
34
49
|
districtsForTransportDay(transportDay) {
|
|
35
50
|
var _a;
|
|
@@ -89,6 +104,39 @@ export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
|
89
104
|
handleCommitClick() {
|
|
90
105
|
this.onSaveAction.emit(this.settingsChanged);
|
|
91
106
|
}
|
|
107
|
+
handleAvailabilityChecked(transId) {
|
|
108
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
109
|
+
let planOrder = yield this._transaction.getPlanOrder(transId);
|
|
110
|
+
if (!planOrder.partDelivery) {
|
|
111
|
+
this.deliveryMethods.find(method => parseInt(method.code) === planOrder.deliveryMethod) ? this.availabilityChecked.emit({ transportDay: this.transportDay, available: true }) : this.availabilityChecked.emit({ transportDay: this.transportDay, available: false });
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
let available = true;
|
|
115
|
+
yield this.getOrderLinesPlanned(planOrder);
|
|
116
|
+
planOrder.lines.forEach((line) => {
|
|
117
|
+
if (!this.deliveryMethods.find(method => method.code === line.deliveryMethod)) {
|
|
118
|
+
available = false;
|
|
119
|
+
}
|
|
120
|
+
});
|
|
121
|
+
this.availabilityChecked.emit({ transportDay: this.transportDay, available: available });
|
|
122
|
+
}
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
getOrderLinesPlanned(planOrder) {
|
|
126
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
127
|
+
let request = new OrderLinesPlannedRequest();
|
|
128
|
+
let filterObj = new PlanningFilterObject();
|
|
129
|
+
request.planned = true;
|
|
130
|
+
request.planningId = this._deliveryPlanningService.currentPlanning.planningId;
|
|
131
|
+
request.transId = planOrder.transId;
|
|
132
|
+
request.plannedLineId = planOrder.plannedLineId;
|
|
133
|
+
filterObj.onlyCurrentWeek = true;
|
|
134
|
+
filterObj.beginCurrentWeek = new Date();
|
|
135
|
+
filterObj.checkOrderLines = 1;
|
|
136
|
+
request.filterObject = filterObj;
|
|
137
|
+
planOrder.lines.push(...yield this._transaction.getOrderLinesPlanned(request));
|
|
138
|
+
});
|
|
139
|
+
}
|
|
92
140
|
}
|
|
93
141
|
DeliveryPlanningOverviewTileSettingsPopupComponent.decorators = [
|
|
94
142
|
{ type: Component, args: [{
|
|
@@ -199,12 +247,14 @@ DeliveryPlanningOverviewTileSettingsPopupComponent.decorators = [
|
|
|
199
247
|
];
|
|
200
248
|
DeliveryPlanningOverviewTileSettingsPopupComponent.ctorParameters = () => [
|
|
201
249
|
{ type: DeliveryPlanningService },
|
|
202
|
-
{ type: IconCacheService }
|
|
250
|
+
{ type: IconCacheService },
|
|
251
|
+
{ type: TransactionConnectorService }
|
|
203
252
|
];
|
|
204
253
|
DeliveryPlanningOverviewTileSettingsPopupComponent.propDecorators = {
|
|
205
254
|
transportDay: [{ type: Input }],
|
|
206
255
|
closeEvent: [{ type: Output }],
|
|
207
256
|
onSaveAction: [{ type: Output }],
|
|
257
|
+
availabilityChecked: [{ type: Output }],
|
|
208
258
|
showClass: [{ type: HostBinding, args: ["class.co-delivery-planning-overview-tile-settings-popup",] }]
|
|
209
259
|
};
|
|
210
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-overview-tile-settings-popup.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile-settings-popup/delivery-planning-overview-tile-settings-popup.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAO7G,OAAO,EAAC,uBAAuB,EAAC,MAAM,oEAAoE,CAAC;AAC3G,OAAO,EAAC,IAAI,EAAC,MAAM,kCAAkC,CAAC;AACtD,OAAO,EAAC,gBAAgB,EAAC,MAAM,8CAA8C,CAAC;AA4G9E,MAAM,OAAO,kDAAkD;IA0C7D,YAAoB,wBAAiD,EAAS,gBAAkC;QAA5F,6BAAwB,GAAxB,wBAAwB,CAAyB;QAAS,qBAAgB,GAAhB,gBAAgB,CAAkB;QAxChG,UAAK,GAAgB,IAAI,CAAC;QACnC,oBAAe,GAAY,KAAK,CAAC;QAOjC,eAAU,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAG1D,iBAAY,GAA0B,IAAI,YAAY,EAAW,CAAC;IA8BzE,CAAC;IA1BD,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC;IACjD,CAAC;IAED,IAAW,eAAe;QACxB,OAAO,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC;IACvD,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,IAAI,CAAC,wBAAwB,CAAC,SAAS,CAAC;IACjD,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,wBAAwB,CAAC,MAAM,CAAC;IAC9C,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,wBAAwB,CAAC,UAAU,CAAC;IAClD,CAAC;IAGM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAKD,QAAQ;IAER,CAAC;IAKM,wBAAwB,CAAC,YAAsC;;QACpE,OAAO,MAAA,IAAI,CAAC,SAAS,0CAAE,MAAM,CAAC,CAAC,QAAkB,EAAE,EAAE,CACnD,YAAY,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,UAAU,CAAC,CACtD,CAAC;IACJ,CAAC;IAEM,8BAA8B,CAAC,YAAsC;;QAC1E,OAAO,MAAA,IAAI,CAAC,eAAe,0CAAE,MAAM,CAAC,CAAC,cAA8B,EAAE,EAAE,CACrE,YAAY,CAAC,eAAe,CAAC,QAAQ,CAAC,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,IAAI,CAAC,CAC5D,CAAC;IACJ,CAAC;IAGM,qBAAqB,CAAC,YAAsC;;QACjE,OAAO,MAAA,IAAI,CAAC,MAAM,0CAAE,MAAM,CAAC,CAAC,KAAY,EAAE,EAAE,CAC1C,YAAY,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,CAAC,CAC7C,CAAC;IACJ,CAAC;IAEM,oBAAoB,CAAC,KAA2B;QACrD,KAAK,CAAC,OAAO,CAAE,QAAQ,CAAC,EAAE;YACxB,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,KAAK,QAAQ,CAAC,EAAE;gBACxE,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAE,QAAQ,CAAC,CAAC;aAC7C;QACH,CAAC,CAAC,CAAC;QACH,IAAG,CAAC,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;IAEM,kBAAkB,CAAC,KAAc;QACtC,KAAK,CAAC,OAAO,CAAE,CAAC,KAAY,EAAE,EAAE;YAC9B,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAE,QAAQ,CAAC,EAAE,CAAC,QAAQ,KAAK,KAAK,CAAC,OAAO,CAAC,EAAE;gBAC1E,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aAC9C;QACH,CAAC,CAAC,CAAC;QACH,IAAG,CAAC,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;IAEM,0BAA0B,CAAC,KAAuB;QACvD,KAAK,CAAC,OAAO,CAAE,CAAC,MAAsB,EAAE,EAAE;YACxC,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAE,cAAc,CAAC,EAAE,CAAC,cAAc,KAAK,MAAM,CAAC,IAAI,CAAC,EAAE;gBAC7F,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;aACrD;QACH,CAAC,CAAC,CAAC;QACH,IAAG,CAAC,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;IAEM,qBAAqB,CAAC,KAAiB;QAC5C,KAAK,CAAC,OAAO,CAAE,CAAC,QAAkB,EAAE,EAAE;YACpC,IAAG,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAE,WAAW,CAAC,EAAE,CAAC,WAAW,KAAK,QAAQ,CAAC,UAAU,CAAC,EAAE;gBACzF,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,CAAC;aACxE;QACH,CAAC,CAAC,CAAC;QACH,IAAG,CAAC,IAAI,CAAC,eAAe,EAAE;YACxB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;IAIM,UAAU;QACf,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAA;IACxB,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC/C,CAAC;;;YApOF,SAAS,SAAC;gBACT,QAAQ,EAAE,mDAAmD;gBAC7D,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAoGT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA7GO,uBAAuB;YAEvB,gBAAgB;;;2BAiHrB,KAAK;yBAIL,MAAM;2BAGN,MAAM;wBAyBN,WAAW,SAAC,yDAAyD","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {PlanningTransportWeekDay} from \"@colijnit/transactionapi/build/model/planning-transport-week-day.bo\";\r\nimport {District} from \"@colijnit/transactionapi/build/model/district.bo\";\r\nimport {DeliveryMethod} from \"@colijnit/transactionapi/build/model/delivery-method.bo\";\r\nimport {Skill} from \"@colijnit/transactionapi/build/model/skill.bo\";\r\nimport {RelationListObject} from \"@colijnit/transactionapi/build/model/relation-list-object.bo\";\r\nimport {UserGroup} from \"@colijnit/transactionapi/build/model/user-group.bo\";\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\n\r\n\r\n@Component({\r\n  selector: \"co-delivery-planning-overview-tile-settings-popup\",\r\n  template: `\r\n    <co-dialog [showCloseIcon]=\"true\" (closeClick)=\"closePopup()\" [headerTemplate]=\"headerTemplate\"\r\n               [footerTemplate]=\"footerTemplate\">\r\n\r\n      <div class=\"body-wrapper\">\r\n        <div class=\"rules-wrapper\">\r\n          <div class=\"row available\">\r\n            <co-input-checkbox [(model)]=\"transportDay.availableOnDate\"></co-input-checkbox>\r\n            <span [textContent]=\"'AVAILABLE' | localize\"></span></div>\r\n\r\n          <div class=\"row available\">\r\n\r\n          </div>\r\n\r\n          <div class=\"row\">\r\n            <div class=\"column\">\r\n              <co-list-of-values class=\"list\" [collection]=\"districts\"\r\n                                 [model]=\"districtsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleDistrictsChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'DISTRICTS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n\r\n              ></co-list-of-values>\r\n              <co-list-of-values class=\"list\" [collection]=\"deliveryMethods\"\r\n                                 [model]=\"deliveryMethodsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleDeliveryMethodChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'DELIVERY_METHODS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n            </div>\r\n\r\n            <div class=\"column\">\r\n              <co-list-of-values class=\"list\" [collection]=\"skills\"\r\n                                 [model]=\"skillsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleSkillsChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'SKILLS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n              <co-list-of-values class=\"list\" [collection]=\"employees\"\r\n                                 [model]=\"transportDay.employees\"\r\n                                 (modelChange)=\"handleEmployeeChange($event)\"\r\n                                 [displayField]=\"'familyName'\"\r\n                                 [label]=\"'EMPLOYEES' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n            </div>\r\n          </div>\r\n\r\n        </div>\r\n\r\n        <div class=\"rules-wrapper\">\r\n          <co-list-of-values class=\"list\" [collection]=\"userGroups\"\r\n                             [displayField]=\"'description'\"\r\n                             [label]=\"'USER_GROUPS' | localize\"\r\n                             [multiselect]=\"true\"\r\n                             [searchDisabled]=\"false\"\r\n                             [searchPlaceholder]=\"'Zoeken...'\"\r\n          ></co-list-of-values>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n\r\n    <ng-template #headerTemplate>\r\n      <div class=\"dialog-header-wrapper\">\r\n        <div class=\"row\">\r\n          <co-icon class=\"small\" [iconData]=\"iconCacheService.getIcon(icons.SlidersUpRegular)\"></co-icon>\r\n          <span class=\"bold\" [textContent]=\"'PLANNING_RULES' | localize\"></span>\r\n        </div>\r\n\r\n        <div class=\"row\">\r\n          <span class=\"footer-header-title bold\" [textContent]=\"transportDay?.transport?.registrationNumber\"></span>\r\n          <div class=\"icon\">\r\n            <co-icon class=\"\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.TruckContainerDuo)\"></co-icon>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template #footerTemplate>\r\n      <div class=\"co-dialog-footer-button-wrapper\">\r\n        <co-button class=\"save-button\"\r\n                   (click)=\"handleCommitClick()\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"></co-button>\r\n        <co-button class=\"close-button\"\r\n                   (click)=\"closePopup()\" [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"></co-button>\r\n      </div>\r\n    </ng-template>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningOverviewTileSettingsPopupComponent implements OnInit {\r\n\r\n  public readonly icons: typeof Icon = Icon;\r\n  public settingsChanged: boolean = false;\r\n\r\n  @Input()\r\n  public transportDay: PlanningTransportWeekDay;\r\n\r\n\r\n  @Output()\r\n  public closeEvent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public onSaveAction: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n\r\n\r\n  public get districts(): District[] {\r\n    return this._deliveryPlanningService.districts;\r\n  }\r\n\r\n  public get deliveryMethods(): DeliveryMethod[] {\r\n    return this._deliveryPlanningService.deliveryMethods;\r\n  }\r\n\r\n  public get employees(): RelationListObject[] {\r\n    return this._deliveryPlanningService.employees;\r\n  }\r\n\r\n  public get skills(): Skill[] {\r\n    return this._deliveryPlanningService.skills;\r\n  }\r\n\r\n  public get userGroups(): UserGroup[] {\r\n    return this._deliveryPlanningService.userGroups;\r\n  }\r\n\r\n  @HostBinding(\"class.co-delivery-planning-overview-tile-settings-popup\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(private _deliveryPlanningService: DeliveryPlanningService, public iconCacheService: IconCacheService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n  }\r\n\r\n\r\n\r\n\r\n  public districtsForTransportDay(transportDay: PlanningTransportWeekDay): District[] {\r\n    return this.districts?.filter((district: District) =>\r\n      transportDay.districts.includes(district?.districtId)\r\n    );\r\n  }\r\n\r\n  public deliveryMethodsForTransportDay(transportDay: PlanningTransportWeekDay): DeliveryMethod[] {\r\n    return this.deliveryMethods?.filter((deliveryMethod: DeliveryMethod) =>\r\n      transportDay.deliveryMethods.includes(deliveryMethod?.code)\r\n    );\r\n  }\r\n\r\n\r\n  public skillsForTransportDay(transportDay: PlanningTransportWeekDay): Skill[] {\r\n    return this.skills?.filter((skill: Skill) =>\r\n      transportDay.skills.includes(skill?.skillId)\r\n    );\r\n  }\r\n\r\n  public handleEmployeeChange(event: RelationListObject[]) {\r\n    event.forEach( relation => {\r\n      if(!this.transportDay.employees.find( employee => employee === relation)) {\r\n        this.transportDay.employees.push( relation);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleSkillsChange(event: Skill[]) {\r\n    event.forEach( (skill: Skill) => {\r\n      if(!this.transportDay.skills.find( daySkill => daySkill === skill.skillId)) {\r\n        this.transportDay.skills.push(skill.skillId);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleDeliveryMethodChange(event: DeliveryMethod[]) {\r\n    event.forEach( (method: DeliveryMethod) => {\r\n      if(!this.transportDay.deliveryMethods.find( deliveryMethod => deliveryMethod === method.code)) {\r\n        this.transportDay.deliveryMethods.push(method.code);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleDistrictsChange(event: District[]) {\r\n    event.forEach( (district: District) => {\r\n      if(!this.transportDay.districts.find( dayDistrict => dayDistrict === district.districtId)) {\r\n        this.transportDay.deliveryMethods.push(district.districtId.toString());\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n\r\n\r\n  public closePopup() {\r\n    this.closeEvent.emit()\r\n  }\r\n\r\n  public handleCommitClick() {\r\n    this.onSaveAction.emit(this.settingsChanged);\r\n  }\r\n}\r\n"]}
|
|
260
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"delivery-planning-overview-tile-settings-popup.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/transaction/src/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile-settings-popup/delivery-planning-overview-tile-settings-popup.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {PlanningTransportWeekDay} from \"@colijnit/transactionapi/build/model/planning-transport-week-day.bo\";\r\nimport {District} from \"@colijnit/transactionapi/build/model/district.bo\";\r\nimport {DeliveryMethod} from \"@colijnit/transactionapi/build/model/delivery-method.bo\";\r\nimport {Skill} from \"@colijnit/transactionapi/build/model/skill.bo\";\r\nimport {RelationListObject} from \"@colijnit/transactionapi/build/model/relation-list-object.bo\";\r\nimport {UserGroup} from \"@colijnit/transactionapi/build/model/user-group.bo\";\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 {Subscription} from \"rxjs\";\r\nimport {TransactionConnectorService} from \"../../../../../../service/transaction-connector.service\";\r\nimport {TransactionInfoResponse} from \"@colijnit/transactionapi/build/model/transaction-info-response.bo\";\r\nimport {PlanOrder} from \"@colijnit/transactionapi/build/model/plan-order.bo\";\r\nimport {OrderLinesPlannedRequest} from \"@colijnit/transactionapi/build/model/order-lines-planned-request.bo\";\r\nimport {PlanningFilterObject} from \"@colijnit/transactionapi/build/model/planning-filter-object.bo\";\r\nimport {PlanOrderLine} from \"@colijnit/transactionapi/build/model/plan-order-line.bo\";\r\nimport {Planning} from \"@colijnit/transactionapi/build/model/planning.bo\";\r\n\r\n\r\n@Component({\r\n  selector: \"co-delivery-planning-overview-tile-settings-popup\",\r\n  template: `\r\n    <co-dialog [showCloseIcon]=\"true\" (closeClick)=\"closePopup()\" [headerTemplate]=\"headerTemplate\"\r\n               [footerTemplate]=\"footerTemplate\">\r\n\r\n      <div class=\"body-wrapper\">\r\n        <div class=\"rules-wrapper\">\r\n          <div class=\"row available\">\r\n            <co-input-checkbox [(model)]=\"transportDay.availableOnDate\"></co-input-checkbox>\r\n            <span [textContent]=\"'AVAILABLE' | localize\"></span></div>\r\n\r\n          <div class=\"row available\">\r\n\r\n          </div>\r\n\r\n          <div class=\"row\">\r\n            <div class=\"column\">\r\n              <co-list-of-values class=\"list\" [collection]=\"districts\"\r\n                                 [model]=\"districtsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleDistrictsChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'DISTRICTS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n\r\n              ></co-list-of-values>\r\n              <co-list-of-values class=\"list\" [collection]=\"deliveryMethods\"\r\n                                 [model]=\"deliveryMethodsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleDeliveryMethodChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'DELIVERY_METHODS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n            </div>\r\n\r\n            <div class=\"column\">\r\n              <co-list-of-values class=\"list\" [collection]=\"skills\"\r\n                                 [model]=\"skillsForTransportDay(transportDay)\"\r\n                                 (modelChange)=\"handleSkillsChange($event)\"\r\n                                 [displayField]=\"'description'\"\r\n                                 [label]=\"'SKILLS' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n              <co-list-of-values class=\"list\" [collection]=\"employees\"\r\n                                 [model]=\"transportDay.employees\"\r\n                                 (modelChange)=\"handleEmployeeChange($event)\"\r\n                                 [displayField]=\"'familyName'\"\r\n                                 [label]=\"'EMPLOYEES' | localize\"\r\n                                 [multiselect]=\"true\"\r\n                                 [searchDisabled]=\"false\"\r\n                                 [searchPlaceholder]=\"'Zoeken...'\"\r\n              ></co-list-of-values>\r\n            </div>\r\n          </div>\r\n\r\n        </div>\r\n\r\n        <div class=\"rules-wrapper\">\r\n          <co-list-of-values class=\"list\" [collection]=\"userGroups\"\r\n                             [displayField]=\"'description'\"\r\n                             [label]=\"'USER_GROUPS' | localize\"\r\n                             [multiselect]=\"true\"\r\n                             [searchDisabled]=\"false\"\r\n                             [searchPlaceholder]=\"'Zoeken...'\"\r\n          ></co-list-of-values>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n\r\n    <ng-template #headerTemplate>\r\n      <div class=\"dialog-header-wrapper\">\r\n        <div class=\"row\">\r\n          <co-icon class=\"small\" [iconData]=\"iconCacheService.getIcon(icons.SlidersUpRegular)\"></co-icon>\r\n          <span class=\"bold\" [textContent]=\"'PLANNING_RULES' | localize\"></span>\r\n        </div>\r\n\r\n        <div class=\"row\">\r\n          <span class=\"footer-header-title bold\" [textContent]=\"transportDay?.transport?.registrationNumber\"></span>\r\n          <div class=\"icon\">\r\n            <co-icon class=\"\"\r\n                     [iconData]=\"iconCacheService.getIcon(icons.TruckContainerDuo)\"></co-icon>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n\r\n    <ng-template #footerTemplate>\r\n      <div class=\"co-dialog-footer-button-wrapper\">\r\n        <co-button class=\"save-button\"\r\n                   (click)=\"handleCommitClick()\"\r\n                   [iconData]=\"iconCacheService.getIcon(icons.CheckDuotone)\"></co-button>\r\n        <co-button class=\"close-button\"\r\n                   (click)=\"closePopup()\" [iconData]=\"iconCacheService.getIcon(icons.Crossskinny)\"></co-button>\r\n      </div>\r\n    </ng-template>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class DeliveryPlanningOverviewTileSettingsPopupComponent implements OnInit, OnDestroy {\r\n\r\n  public readonly icons: typeof Icon = Icon;\r\n  public settingsChanged: boolean = false;\r\n\r\n  private _subs: Subscription[] = [];\r\n\r\n  @Input()\r\n  public transportDay: PlanningTransportWeekDay;\r\n\r\n\r\n  @Output()\r\n  public closeEvent: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public onSaveAction: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n\r\n  @Output()\r\n  public availabilityChecked: EventEmitter<{transportDay: PlanningTransportWeekDay, available: boolean}> = new EventEmitter<{transportDay: PlanningTransportWeekDay, available: boolean}>();\r\n\r\n  public get districts(): District[] {\r\n    return this._deliveryPlanningService.districts;\r\n  }\r\n\r\n  public get deliveryMethods(): DeliveryMethod[] {\r\n    return this._deliveryPlanningService.deliveryMethods;\r\n  }\r\n\r\n  public get employees(): RelationListObject[] {\r\n    return this._deliveryPlanningService.employees;\r\n  }\r\n\r\n  public get skills(): Skill[] {\r\n    return this._deliveryPlanningService.skills;\r\n  }\r\n\r\n  public get userGroups(): UserGroup[] {\r\n    return this._deliveryPlanningService.userGroups;\r\n  }\r\n\r\n  @HostBinding(\"class.co-delivery-planning-overview-tile-settings-popup\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  constructor(private _deliveryPlanningService: DeliveryPlanningService, public iconCacheService: IconCacheService, private _transaction: TransactionConnectorService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._subs.push(this._deliveryPlanningService.availabilityCheckEvent.subscribe( async(transId: number) => {\r\n      await this.handleAvailabilityChecked(transId);\r\n    }));\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._subs.forEach( sub => {\r\n      sub.unsubscribe()\r\n    });\r\n  }\r\n\r\n\r\n\r\n\r\n  public districtsForTransportDay(transportDay: PlanningTransportWeekDay): District[] {\r\n    return this.districts?.filter((district: District) =>\r\n      transportDay.districts.includes(district?.districtId)\r\n    );\r\n  }\r\n\r\n  public deliveryMethodsForTransportDay(transportDay: PlanningTransportWeekDay): DeliveryMethod[] {\r\n    return this.deliveryMethods?.filter((deliveryMethod: DeliveryMethod) =>\r\n      transportDay.deliveryMethods.includes(deliveryMethod?.code)\r\n    );\r\n  }\r\n\r\n\r\n  public skillsForTransportDay(transportDay: PlanningTransportWeekDay): Skill[] {\r\n    return this.skills?.filter((skill: Skill) =>\r\n      transportDay.skills.includes(skill?.skillId)\r\n    );\r\n  }\r\n\r\n  public handleEmployeeChange(event: RelationListObject[]) {\r\n    event.forEach( relation => {\r\n      if(!this.transportDay.employees.find( employee => employee === relation)) {\r\n        this.transportDay.employees.push( relation);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleSkillsChange(event: Skill[]) {\r\n    event.forEach( (skill: Skill) => {\r\n      if(!this.transportDay.skills.find( daySkill => daySkill === skill.skillId)) {\r\n        this.transportDay.skills.push(skill.skillId);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleDeliveryMethodChange(event: DeliveryMethod[]) {\r\n    event.forEach( (method: DeliveryMethod) => {\r\n      if(!this.transportDay.deliveryMethods.find( deliveryMethod => deliveryMethod === method.code)) {\r\n        this.transportDay.deliveryMethods.push(method.code);\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n  public handleDistrictsChange(event: District[]) {\r\n    event.forEach( (district: District) => {\r\n      if(!this.transportDay.districts.find( dayDistrict => dayDistrict === district.districtId)) {\r\n        this.transportDay.deliveryMethods.push(district.districtId.toString());\r\n      }\r\n    });\r\n    if(!this.settingsChanged) {\r\n      this.settingsChanged = true;\r\n    }\r\n  }\r\n\r\n\r\n\r\n  public closePopup() {\r\n    this.closeEvent.emit()\r\n  }\r\n\r\n  public handleCommitClick() {\r\n    this.onSaveAction.emit(this.settingsChanged);\r\n  }\r\n\r\n  public async handleAvailabilityChecked(transId: number) {\r\n    let planOrder: PlanOrder = await this._transaction.getPlanOrder(transId);\r\n    if(!planOrder.partDelivery) {\r\n      this.deliveryMethods.find( method => parseInt(method.code) === planOrder.deliveryMethod) ? this.availabilityChecked.emit({transportDay: this.transportDay, available: true}) : this.availabilityChecked.emit({transportDay: this.transportDay, available: false});\r\n    } else {\r\n      let available: boolean = true;\r\n      await this.getOrderLinesPlanned(planOrder);\r\n      planOrder.lines.forEach( (line: PlanOrderLine) => {\r\n        if(!this.deliveryMethods.find( method => method.code === line.deliveryMethod)) {\r\n          available = false;\r\n        }\r\n      });\r\n      this.availabilityChecked.emit({transportDay: this.transportDay, available: available});\r\n    }\r\n  }\r\n\r\n\r\n  public async getOrderLinesPlanned(planOrder: PlanOrder) {\r\n    let request: OrderLinesPlannedRequest = new OrderLinesPlannedRequest();\r\n    let filterObj: PlanningFilterObject = new PlanningFilterObject();\r\n    request.planned = true;\r\n    request.planningId = this._deliveryPlanningService.currentPlanning.planningId;\r\n    request.transId = planOrder.transId;\r\n    request.plannedLineId = planOrder.plannedLineId;\r\n    filterObj.onlyCurrentWeek = true;\r\n    filterObj.beginCurrentWeek = new Date();\r\n    filterObj.checkOrderLines = 1;\r\n    request.filterObject = filterObj;\r\n    planOrder.lines.push(...await this._transaction.getOrderLinesPlanned(request));\r\n  }\r\n}\r\n"]}
|