@colijnit/transaction 256.1.38 → 256.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 +482 -248
- package/bundles/colijnit-transaction.umd.js.map +1 -1
- package/colijnit-transaction.metadata.json +1 -1
- package/esm2015/lib/component/delivery-planning/delivery-planning.component.js +8 -4
- package/esm2015/lib/component/delivery-planning/service/delivery-planning.service.js +15 -40
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.js +53 -53
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.js +48 -12
- 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 +96 -136
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.js +82 -60
- package/esm2015/lib/component/delivery-planning-main/component/delivery-planning-selection/delivery-planning-selection.component.js +36 -21
- package/esm2015/lib/component/delivery-planning-main/delivery-planning-main.component.js +8 -2
- package/esm2015/lib/component/transaction-cash-register-dialog/transaction-cash-register-dialog.component.js +31 -16
- package/esm2015/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.js +49 -35
- package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-overview/transaction-quick-access-overview.component.js +6 -2
- package/esm2015/lib/component/transaction-quick-access/transaction-quick-access-send-method-base.component.js +24 -1
- package/esm2015/lib/component/transaction-search/service/transaction-search.service.js +7 -2
- package/esm2015/lib/component/transaction-search/transaction-search-result/transaction-search-result.component.js +103 -89
- package/esm2015/lib/enum/transaction-cfg-name.enum.js +3 -1
- package/esm2015/lib/service/transaction-connector-adapter.service.js +13 -1
- package/esm2015/lib/service/transaction-connector.service.js +6 -1
- package/esm2015/lib/service/transaction.service.js +6 -1
- package/esm2015/lib/transaction-version.js +3 -3
- package/fesm2015/colijnit-transaction.js +523 -415
- package/fesm2015/colijnit-transaction.js.map +1 -1
- package/lib/component/delivery-planning/delivery-planning.component.d.ts +3 -0
- package/lib/component/delivery-planning/service/delivery-planning.service.d.ts +18 -20
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-popup/delivery-planning-overview-popup.component.d.ts +2 -2
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/component/delivery-planning-overview-tile/delivery-planning-overview-tile.component.d.ts +9 -4
- 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 +12 -16
- package/lib/component/delivery-planning-main/component/delivery-planning-overview/delivery-planning-overview.component.d.ts +27 -25
- package/lib/component/delivery-planning-main/component/delivery-planning-selection/delivery-planning-selection.component.d.ts +11 -6
- package/lib/component/delivery-planning-main/delivery-planning-main.component.d.ts +3 -1
- package/lib/component/transaction-cash-register-dialog/transaction-cash-register-dialog.component.d.ts +18 -3
- package/lib/component/transaction-line/transaction-planning-line/transaction-planning-line.component.d.ts +5 -2
- package/lib/component/transaction-quick-access/transaction-quick-access-send-method-base.component.d.ts +8 -1
- package/lib/component/transaction-search/service/transaction-search.service.d.ts +3 -2
- package/lib/component/transaction-search/transaction-search-result/transaction-search-result.component.d.ts +8 -6
- package/lib/enum/transaction-cfg-name.enum.d.ts +3 -1
- package/lib/service/transaction-connector-adapter.service.d.ts +1 -0
- package/lib/service/transaction-connector.service.d.ts +1 -0
- package/lib/service/transaction.service.d.ts +1 -0
- package/package.json +1 -1
|
@@ -4,9 +4,13 @@ import { DeliveryPlanningService } from '../../../../../delivery-planning/servic
|
|
|
4
4
|
import { Icon } from '../../../../../../enum/icon.enum';
|
|
5
5
|
import { IconCacheService } from '../../../../../../service/icon-cache.service';
|
|
6
6
|
import { DeliveryPlanningTileModes } from '../../../../../../enum/delivery-planning-tile-modes.enum';
|
|
7
|
+
import { TransactionService } from '../../../../../../service/transaction.service';
|
|
8
|
+
import { OrderLinesPlannedRequest } from '@colijnit/transactionapi/build/model/order-lines-planned-request.bo';
|
|
9
|
+
import { PlanningFilterObject } from '@colijnit/transactionapi/build/model/planning-filter-object.bo';
|
|
7
10
|
export class DeliveryPlanningOverviewTileComponent {
|
|
8
|
-
constructor(_deliveryPlanningService, _changeDetector, iconCacheService) {
|
|
11
|
+
constructor(_deliveryPlanningService, _transaction, _changeDetector, iconCacheService) {
|
|
9
12
|
this._deliveryPlanningService = _deliveryPlanningService;
|
|
13
|
+
this._transaction = _transaction;
|
|
10
14
|
this._changeDetector = _changeDetector;
|
|
11
15
|
this.iconCacheService = iconCacheService;
|
|
12
16
|
this.icons = Icon;
|
|
@@ -21,6 +25,7 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
21
25
|
this.getTransportOrdersEvent = new EventEmitter();
|
|
22
26
|
this.timeChangeEvent = new EventEmitter();
|
|
23
27
|
this.openSettingsDialogEvent = new EventEmitter();
|
|
28
|
+
this.availabilityChecked = new EventEmitter();
|
|
24
29
|
this.calendarPlanEvent = new EventEmitter();
|
|
25
30
|
this.moveEvent = new EventEmitter();
|
|
26
31
|
}
|
|
@@ -49,6 +54,9 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
49
54
|
this._changeDetector.markForCheck();
|
|
50
55
|
this._changeDetector.detectChanges();
|
|
51
56
|
}));
|
|
57
|
+
this._subs.push(this._deliveryPlanningService.availabilityCheckEvent.subscribe((transId) => __awaiter(this, void 0, void 0, function* () {
|
|
58
|
+
yield this.handleAvailabilityChecked(transId);
|
|
59
|
+
})));
|
|
52
60
|
});
|
|
53
61
|
}
|
|
54
62
|
ngOnDestroy() {
|
|
@@ -80,16 +88,6 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
80
88
|
handleDeleteOrderLineClick(data) {
|
|
81
89
|
this.deleteOrderLineEvent.emit(data);
|
|
82
90
|
}
|
|
83
|
-
handleSettingsSave() {
|
|
84
|
-
}
|
|
85
|
-
onCustomDragStart(event, obj) {
|
|
86
|
-
const currentHour = obj['startTime'] + ':00'; // Assuming start hour is used
|
|
87
|
-
event.dataTransfer.setData('text', JSON.stringify({ obj, currentHour }));
|
|
88
|
-
}
|
|
89
|
-
onExpandableDragStart(event, obj, onDragStartCustom) {
|
|
90
|
-
onDragStartCustom === null || onDragStartCustom === void 0 ? void 0 : onDragStartCustom.call(obj);
|
|
91
|
-
event.dataTransfer.setData('text', JSON.stringify({ obj }));
|
|
92
|
-
}
|
|
93
91
|
orderForObject(transId) {
|
|
94
92
|
return this.transportDay.plannedOrders.find(order => order.transId === transId);
|
|
95
93
|
}
|
|
@@ -115,6 +113,42 @@ export class DeliveryPlanningOverviewTileComponent {
|
|
|
115
113
|
}
|
|
116
114
|
});
|
|
117
115
|
}
|
|
116
|
+
handleAvailabilityChecked(transId) {
|
|
117
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
118
|
+
let planOrder = yield this._transaction.getPlanOrder(transId);
|
|
119
|
+
if (!planOrder.partDelivery) {
|
|
120
|
+
this._deliveryPlanningService.deliveryMethods.find(method => parseInt(method.code) === planOrder.deliveryMethod) ? this.availabilityChecked.emit({
|
|
121
|
+
transportDay: this.transportDay,
|
|
122
|
+
available: true
|
|
123
|
+
}) : this.availabilityChecked.emit({ transportDay: this.transportDay, available: false });
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
let available = true;
|
|
127
|
+
yield this.getOrderLinesPlanned(planOrder);
|
|
128
|
+
planOrder.lines.forEach((line) => {
|
|
129
|
+
if (!this.transportDay.deliveryMethods.find(method => method === line.deliveryMethod)) {
|
|
130
|
+
available = false;
|
|
131
|
+
}
|
|
132
|
+
});
|
|
133
|
+
this.availabilityChecked.emit({ transportDay: this.transportDay, available: available });
|
|
134
|
+
}
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
getOrderLinesPlanned(planOrder) {
|
|
138
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
139
|
+
let request = new OrderLinesPlannedRequest();
|
|
140
|
+
let filterObj = new PlanningFilterObject();
|
|
141
|
+
request.planned = true;
|
|
142
|
+
request.planningId = this._deliveryPlanningService.currentPlanning.planningId;
|
|
143
|
+
request.transId = planOrder.transId;
|
|
144
|
+
request.plannedLineId = planOrder.plannedLineId;
|
|
145
|
+
filterObj.onlyCurrentWeek = true;
|
|
146
|
+
filterObj.beginCurrentWeek = new Date();
|
|
147
|
+
filterObj.checkOrderLines = 1;
|
|
148
|
+
request.filterObject = filterObj;
|
|
149
|
+
planOrder.lines.push(...yield this._transaction.getOrderLinesPlanned(request));
|
|
150
|
+
});
|
|
151
|
+
}
|
|
118
152
|
}
|
|
119
153
|
DeliveryPlanningOverviewTileComponent.decorators = [
|
|
120
154
|
{ type: Component, args: [{
|
|
@@ -211,6 +245,7 @@ DeliveryPlanningOverviewTileComponent.decorators = [
|
|
|
211
245
|
];
|
|
212
246
|
DeliveryPlanningOverviewTileComponent.ctorParameters = () => [
|
|
213
247
|
{ type: DeliveryPlanningService },
|
|
248
|
+
{ type: TransactionService },
|
|
214
249
|
{ type: ChangeDetectorRef },
|
|
215
250
|
{ type: IconCacheService }
|
|
216
251
|
];
|
|
@@ -224,9 +259,10 @@ DeliveryPlanningOverviewTileComponent.propDecorators = {
|
|
|
224
259
|
getTransportOrdersEvent: [{ type: Output }],
|
|
225
260
|
timeChangeEvent: [{ type: Output }],
|
|
226
261
|
openSettingsDialogEvent: [{ type: Output }],
|
|
262
|
+
availabilityChecked: [{ type: Output }],
|
|
227
263
|
calendarPlanEvent: [{ type: Output }],
|
|
228
264
|
moveEvent: [{ type: Output }],
|
|
229
265
|
hourSchedulingComp: [{ type: ViewChild, args: ['hourSchedulingComponent',] }],
|
|
230
266
|
showClass: [{ type: HostBinding, args: ['class.co-delivery-planning-overview-tile',] }]
|
|
231
267
|
};
|
|
232
|
-
//# 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 {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\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 {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 {Subscription} from 'rxjs';\r\nimport {HourSchedulingExpandableComponent} 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\"\r\n                           *ngIf=\"tileMode === tileModes.Normal\">\r\n                          <co-delivery-planning-overview-tile-line class=\"normal-mode\"\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                                                                   [isActive]=\"true\"\r\n                                                                   [order]=\"order\"\r\n                                                                   [draggable]=\"true\"\r\n                                                                   (dragstart)=\"dragStart($event,order.transId)\">\r\n                          </co-delivery-planning-overview-tile-line>\r\n                      </div>\r\n\r\n                      <co-hour-scheduling-expandable #hourSchedulingComponent\r\n                                                     *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]=\"customExpandableTemplateSeparate\"\r\n                                                     [idProp]=\"'transId'\"\r\n                                                     (timeChangeEvent)=\"handleTimeChangeEvent($event)\"\r\n                                                     (drop)=\"handleDrop($event)\"\r\n                                                     (newObjectPlanEvent)=\"handleCalendarPlanEvent($event)\"\r\n                                                     (moveBetweenCalendarsEvent)=\"handleMoveBetweenCalendars($event)\"\r\n                      ></co-hour-scheduling-expandable>\r\n\r\n                      <ng-template #customExpandableTemplateSeparate let-onDragStartCustom=\"onDragStartCustom\"\r\n                                   let-onSelectBlock=\"onSelectBlock\" let-onResizeStart=\"onResizeStart\" let-objects=\"objects\">\r\n                          <co-hour-scheduling-expandable-template [objects]=\"objects\" [onSelectBlock]=\"onSelectBlock\"\r\n                                                                  [onResizeStart]=\"onResizeStart\"\r\n                                                                  [onDragStartCustom]=\"onDragStartCustom\"\r\n                                                                  [objectTemplate]=\"objectTemplate\">\r\n                              <ng-template #objectTemplate let-obj=\"object\">\r\n                                  <co-delivery-planning-overview-tile-line\r\n                                          (deleteOrderEvent)=\"handleDeleteOrderClick($event)\"\r\n                                          (deleteOrderLineEvent)=\"handleDeleteOrderLineClick($event)\"\r\n                                          (editOrderEvent)=\"handleEditOrderEvent($event)\"\r\n                                          [order]=\"orderForObject(obj.id)\">\r\n                                  </co-delivery-planning-overview-tile-line>\r\n                              </ng-template>\r\n                          </co-hour-scheduling-expandable-template>\r\n                      </ng-template>\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<{\r\n    order: PlanOrder,\r\n    line: PlanOrderLine\r\n  }>();\r\n\r\n  @Output()\r\n  public editOrderEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n  @Output()\r\n  public getTransportOrdersEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public timeChangeEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\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<{\r\n    currentHour: string,\r\n    data: string\r\n  }>();\r\n\r\n  @Output()\r\n  public moveEvent: EventEmitter<{ hour: string, scheduledObject: Object }> = new EventEmitter<{\r\n    hour: string;\r\n    scheduledObject: Object\r\n  }>();\r\n\r\n  @ViewChild('hourSchedulingComponent')\r\n  public hourSchedulingComp: HourSchedulingExpandableComponent;\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 _deliveryPlanningService: DeliveryPlanningService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public get employeeView(): boolean {\r\n    return this._deliveryPlanningService.employeeView;\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    if(this.employeeView) {\r\n      this.expandedChange();\r\n    }\r\n    this._subs.push(this._deliveryPlanningService.reRenderHourScheduling.subscribe(event => {\r\n      this.hourSchedulingComp?.renderObjects();\r\n      this._changeDetector.markForCheck();\r\n      this._changeDetector.detectChanges();\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 dragStart(dragEvent: DragEvent, transId: number) {\r\n    dragEvent.dataTransfer!.setData('text', JSON.stringify(transId));\r\n    this._deliveryPlanningService.movingTransId = transId;\r\n  }\r\n\r\n  public handleDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\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  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 onExpandableDragStart(event: DragEvent, obj: Object, onDragStartCustom: Function) {\r\n    onDragStartCustom?.call(obj);\r\n    event.dataTransfer!.setData('text', JSON.stringify({obj}));\r\n  }\r\n\r\n  public orderForObject(transId: number) {\r\n    return this.transportDay.plannedOrders.find(order => order.transId === transId);\r\n  }\r\n\r\n  public openSettingsDialog() {\r\n    this.openSettingsDialogEvent.emit(this.transportDay);\r\n  }\r\n\r\n  public handleTimeChangeEvent(obj: PlanOrder) {\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  public async handleMoveBetweenCalendars(moveData: { hour: string, data: Object }) {\r\n    if (moveData && moveData.data['obj']['id'] && moveData.data['obj']['height']) {\r\n      this.moveEvent.emit({\r\n        hour: moveData.hour,\r\n        scheduledObject: moveData?.data\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n}\r\n\r\n"]}
|
|
268
|
+
//# 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":";AAAA,OAAO,EAAC,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAqB,MAAM,EAAE,SAAS,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAGtJ,OAAO,EAAC,uBAAuB,EAAC,MAAM,oEAAoE,CAAC;AAC3G,OAAO,EAAC,IAAI,EAAC,MAAM,kCAAkC,CAAC;AACtD,OAAO,EAAC,gBAAgB,EAAC,MAAM,8CAA8C,CAAC;AAC9E,OAAO,EAAC,yBAAyB,EAAC,MAAM,0DAA0D,CAAC;AAInG,OAAO,EAAC,kBAAkB,EAAC,MAAM,+CAA+C,CAAC;AACjF,OAAO,EAAC,wBAAwB,EAAC,MAAM,qEAAqE,CAAC;AAC7G,OAAO,EAAC,oBAAoB,EAAC,MAAM,gEAAgE,CAAC;AA6FpG,MAAM,OAAO,qCAAqC;IAmEhD,YACU,wBAAiD,EACjD,YAAgC,EAChC,eAAkC,EACnC,gBAAkC;QAHjC,6BAAwB,GAAxB,wBAAwB,CAAyB;QACjD,iBAAY,GAAZ,YAAY,CAAoB;QAChC,oBAAe,GAAf,eAAe,CAAmB;QACnC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAtE3B,UAAK,GAAgB,IAAI,CAAC;QAC1B,cAAS,GAAqC,yBAAyB,CAAC;QAEjF,iBAAY,GAAY,KAAK,CAAC;QAE7B,UAAK,GAAmB,EAAE,CAAC;QAG5B,aAAQ,GAAY,KAAK,CAAC;QAM1B,kBAAa,GAA2C,IAAI,YAAY,EAA4B,CAAC;QAGrG,qBAAgB,GAAwD,IAAI,YAAY,EAAyC,CAAC;QAGlI,yBAAoB,GAA4D,IAAI,YAAY,EAGnG,CAAC;QAGE,mBAAc,GAA4B,IAAI,YAAY,EAAa,CAAC;QAGxE,4BAAuB,GAA2C,IAAI,YAAY,EAA4B,CAAC;QAG/G,oBAAe,GAA4B,IAAI,YAAY,EAAa,CAAC;QAGzE,4BAAuB,GAA2C,IAAI,YAAY,EAA4B,CAAC;QAG/G,wBAAmB,GAAiF,IAAI,YAAY,EAAkE,CAAC;QAGvL,sBAAiB,GAAwD,IAAI,YAAY,EAG5F,CAAC;QAGE,cAAS,GAA4D,IAAI,YAAY,EAGxF,CAAC;IAsBL,CAAC;IAjBD,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC;IACvD,CAAC;IAKM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAUD,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,wBAAwB,CAAC,YAAY,CAAC;IACpD,CAAC;IAEK,QAAQ;;YACZ,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,MAAM,IAAI,CAAC,wBAAwB,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC1E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;gBACzB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACtD;YACD,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;YACD,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,sBAAsB,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;;gBACrF,MAAA,IAAI,CAAC,kBAAkB,0CAAE,aAAa,EAAE,CAAC;gBACzC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;gBACpC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;YACvC,CAAC,CAAC,CAAC,CAAC;YAEJ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,wBAAwB,CAAC,sBAAsB,CAAC,SAAS,CAAC,CAAO,OAAe,EAAE,EAAE;gBACvG,MAAM,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC;YAChD,CAAC,CAAA,CAAC,CAAC,CAAC;QAEN,CAAC;KAAA;IAEK,WAAW;;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAiB,EAAE,EAAE;gBACvC,GAAG,CAAC,WAAW,EAAE,CAAC;YACpB,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;IAEM,SAAS,CAAC,SAAoB,EAAE,OAAe;QACpD,SAAS,CAAC,YAAa,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QACjE,IAAI,CAAC,wBAAwB,CAAC,aAAa,GAAG,OAAO,CAAC;IACxD,CAAC;IAEM,UAAU,CAAC,KAAgB;QAChC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC1B,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,wBAAwB,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAChF,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;YAC7B,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,sBAAsB,CAAC,KAAgB;QAC5C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;IACzD,CAAC;IAEM,0BAA0B,CAAC,IAA+C;QAC/E,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACvC,CAAC;IAEM,cAAc,CAAC,OAAe;QACnC,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,OAAO,KAAK,OAAO,CAAC,CAAC;IAClF,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACvD,CAAC;IAEM,qBAAqB,CAAC,GAAc;QACzC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACjC,CAAC;IAEM,uBAAuB,CAAC,IAA2C;QACxE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpC,CAAC;IAEM,oBAAoB,CAAC,SAAoB;QAC9C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACtC,CAAC;IAEY,0BAA0B,CAAC,QAAwC;;YAC9E,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,EAAE;gBAC5E,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;oBAClB,IAAI,EAAE,QAAQ,CAAC,IAAI;oBACnB,eAAe,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI;iBAChC,CAAC,CAAC;aACJ;QAEH,CAAC;KAAA;IAEY,yBAAyB,CAAC,OAAe;;YACpD,IAAI,SAAS,GAAc,MAAM,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;YACzE,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE;gBAC3B,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,SAAS,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC;oBAC/I,YAAY,EAAE,IAAI,CAAC,YAAY;oBAC/B,SAAS,EAAE,IAAI;iBAChB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,KAAK,EAAC,CAAC,CAAC;aACzF;iBAAM;gBACL,IAAI,SAAS,GAAY,IAAI,CAAC;gBAC9B,MAAM,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;gBAC3C,SAAS,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAmB,EAAE,EAAE;oBAC9C,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,cAAc,CAAC,EAAE;wBACrF,SAAS,GAAG,KAAK,CAAC;qBACnB;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAC,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,SAAS,EAAE,SAAS,EAAC,CAAC,CAAC;aACxF;QACH,CAAC;KAAA;IAEY,oBAAoB,CAAC,SAAoB;;YACpD,IAAI,OAAO,GAA6B,IAAI,wBAAwB,EAAE,CAAC;YACvE,IAAI,SAAS,GAAyB,IAAI,oBAAoB,EAAE,CAAC;YACjE,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;YACvB,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,wBAAwB,CAAC,eAAe,CAAC,UAAU,CAAC;YAC9E,OAAO,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;YACpC,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC,aAAa,CAAC;YAChD,SAAS,CAAC,eAAe,GAAG,IAAI,CAAC;YACjC,SAAS,CAAC,gBAAgB,GAAG,IAAI,IAAI,EAAE,CAAC;YACxC,SAAS,CAAC,eAAe,GAAG,CAAC,CAAC;YAC9B,OAAO,CAAC,YAAY,GAAG,SAAS,CAAC;YACjC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;QACjF,CAAC;KAAA;;;YA7RF,SAAS,SAAC;gBACT,QAAQ,EAAE,oCAAoC;gBAC9C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsFT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YArGO,uBAAuB;YAOvB,kBAAkB;YAVlB,iBAAiB;YAKjB,gBAAgB;;;uBA4GrB,KAAK;2BAGL,KAAK;4BAGL,MAAM;+BAGN,MAAM;mCAGN,MAAM;6BAMN,MAAM;sCAGN,MAAM;8BAGN,MAAM;sCAGN,MAAM;kCAGN,MAAM;gCAGN,MAAM;wBAMN,MAAM;iCAMN,SAAS,SAAC,yBAAyB;wBASnC,WAAW,SAAC,0CAA0C","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, HostBinding, Input, OnDestroy, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\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 {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 {Subscription} from 'rxjs';\r\nimport {HourSchedulingExpandableComponent} from '@colijnit/corecomponents_v12';\r\nimport {PlanOrderLine} from '@colijnit/transactionapi/build/model/plan-order-line.bo';\r\nimport {TransactionService} from '../../../../../../service/transaction.service';\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\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\"\r\n                           *ngIf=\"tileMode === tileModes.Normal\">\r\n                          <co-delivery-planning-overview-tile-line class=\"normal-mode\"\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                                                                   [isActive]=\"true\"\r\n                                                                   [order]=\"order\"\r\n                                                                   [draggable]=\"true\"\r\n                                                                   (dragstart)=\"dragStart($event,order.transId)\">\r\n                          </co-delivery-planning-overview-tile-line>\r\n                      </div>\r\n\r\n                      <co-hour-scheduling-expandable #hourSchedulingComponent\r\n                                                     *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]=\"customExpandableTemplateSeparate\"\r\n                                                     [idProp]=\"'transId'\"\r\n                                                     (timeChangeEvent)=\"handleTimeChangeEvent($event)\"\r\n                                                     (drop)=\"handleDrop($event)\"\r\n                                                     (newObjectPlanEvent)=\"handleCalendarPlanEvent($event)\"\r\n                                                     (moveBetweenCalendarsEvent)=\"handleMoveBetweenCalendars($event)\"\r\n                      ></co-hour-scheduling-expandable>\r\n\r\n                      <ng-template #customExpandableTemplateSeparate let-onDragStartCustom=\"onDragStartCustom\"\r\n                                   let-onSelectBlock=\"onSelectBlock\" let-onResizeStart=\"onResizeStart\" let-objects=\"objects\">\r\n                          <co-hour-scheduling-expandable-template [objects]=\"objects\" [onSelectBlock]=\"onSelectBlock\"\r\n                                                                  [onResizeStart]=\"onResizeStart\"\r\n                                                                  [onDragStartCustom]=\"onDragStartCustom\"\r\n                                                                  [objectTemplate]=\"objectTemplate\">\r\n                              <ng-template #objectTemplate let-obj=\"object\">\r\n                                  <co-delivery-planning-overview-tile-line\r\n                                          (deleteOrderEvent)=\"handleDeleteOrderClick($event)\"\r\n                                          (deleteOrderLineEvent)=\"handleDeleteOrderLineClick($event)\"\r\n                                          (editOrderEvent)=\"handleEditOrderEvent($event)\"\r\n                                          [order]=\"orderForObject(obj.id)\">\r\n                                  </co-delivery-planning-overview-tile-line>\r\n                              </ng-template>\r\n                          </co-hour-scheduling-expandable-template>\r\n                      </ng-template>\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<{\r\n    order: PlanOrder,\r\n    line: PlanOrderLine\r\n  }>();\r\n\r\n  @Output()\r\n  public editOrderEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n  @Output()\r\n  public getTransportOrdersEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public timeChangeEvent: EventEmitter<PlanOrder> = new EventEmitter<PlanOrder>();\r\n\r\n  @Output()\r\n  public openSettingsDialogEvent: EventEmitter<PlanningTransportWeekDay> = new EventEmitter<PlanningTransportWeekDay>();\r\n\r\n  @Output()\r\n  public availabilityChecked: EventEmitter<{ transportDay: PlanningTransportWeekDay, available: boolean }> = new EventEmitter<{ transportDay: PlanningTransportWeekDay, available: boolean }>();\r\n\r\n  @Output()\r\n  public calendarPlanEvent: EventEmitter<{ currentHour: string, data: string }> = new EventEmitter<{\r\n    currentHour: string,\r\n    data: string\r\n  }>();\r\n\r\n  @Output()\r\n  public moveEvent: EventEmitter<{ hour: string, scheduledObject: Object }> = new EventEmitter<{\r\n    hour: string;\r\n    scheduledObject: Object\r\n  }>();\r\n\r\n  @ViewChild('hourSchedulingComponent')\r\n  public hourSchedulingComp: HourSchedulingExpandableComponent;\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 _deliveryPlanningService: DeliveryPlanningService,\r\n    private _transaction: TransactionService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    public iconCacheService: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public get employeeView(): boolean {\r\n    return this._deliveryPlanningService.employeeView;\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    if (this.employeeView) {\r\n      this.expandedChange();\r\n    }\r\n    this._subs.push(this._deliveryPlanningService.reRenderHourScheduling.subscribe(event => {\r\n      this.hourSchedulingComp?.renderObjects();\r\n      this._changeDetector.markForCheck();\r\n      this._changeDetector.detectChanges();\r\n    }));\r\n\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\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 dragStart(dragEvent: DragEvent, transId: number) {\r\n    dragEvent.dataTransfer!.setData('text', JSON.stringify(transId));\r\n    this._deliveryPlanningService.movingTransId = transId;\r\n  }\r\n\r\n  public handleDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\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  public orderForObject(transId: number) {\r\n    return this.transportDay.plannedOrders.find(order => order.transId === transId);\r\n  }\r\n\r\n  public openSettingsDialog() {\r\n    this.openSettingsDialogEvent.emit(this.transportDay);\r\n  }\r\n\r\n  public handleTimeChangeEvent(obj: PlanOrder) {\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  public async handleMoveBetweenCalendars(moveData: { hour: string, data: Object }) {\r\n    if (moveData && moveData.data['obj']['id'] && moveData.data['obj']['height']) {\r\n      this.moveEvent.emit({\r\n        hour: moveData.hour,\r\n        scheduledObject: moveData?.data\r\n      });\r\n    }\r\n\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._deliveryPlanningService.deliveryMethods.find(method => parseInt(method.code) === planOrder.deliveryMethod) ? this.availabilityChecked.emit({\r\n        transportDay: this.transportDay,\r\n        available: true\r\n      }) : 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.transportDay.deliveryMethods.find(method => method === 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  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}\r\n\r\n"]}
|
|
@@ -1,11 +1,8 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
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";
|
|
1
|
+
import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { DeliveryPlanningService } from '../../../../../delivery-planning/service/delivery-planning.service';
|
|
3
|
+
import { Icon } from '../../../../../../enum/icon.enum';
|
|
4
|
+
import { IconCacheService } from '../../../../../../service/icon-cache.service';
|
|
5
|
+
import { TransactionConnectorService } from '../../../../../../service/transaction-connector.service';
|
|
9
6
|
export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
10
7
|
constructor(_deliveryPlanningService, iconCacheService, _transaction) {
|
|
11
8
|
this._deliveryPlanningService = _deliveryPlanningService;
|
|
@@ -36,11 +33,6 @@ export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
|
36
33
|
showClass() {
|
|
37
34
|
return true;
|
|
38
35
|
}
|
|
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
36
|
ngOnDestroy() {
|
|
45
37
|
this._subs.forEach(sub => {
|
|
46
38
|
sub.unsubscribe();
|
|
@@ -91,7 +83,7 @@ export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
|
91
83
|
handleDistrictsChange(event) {
|
|
92
84
|
event.forEach((district) => {
|
|
93
85
|
if (!this.transportDay.districts.find(dayDistrict => dayDistrict === district.districtId)) {
|
|
94
|
-
this.transportDay.
|
|
86
|
+
this.transportDay.districts.push(district.districtId);
|
|
95
87
|
}
|
|
96
88
|
});
|
|
97
89
|
if (!this.settingsChanged) {
|
|
@@ -103,143 +95,111 @@ export class DeliveryPlanningOverviewTileSettingsPopupComponent {
|
|
|
103
95
|
}
|
|
104
96
|
handleCommitClick() {
|
|
105
97
|
this.onSaveAction.emit(this.settingsChanged);
|
|
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
|
-
});
|
|
98
|
+
this.closeEvent.emit();
|
|
139
99
|
}
|
|
140
100
|
}
|
|
141
101
|
DeliveryPlanningOverviewTileSettingsPopupComponent.decorators = [
|
|
142
102
|
{ type: Component, args: [{
|
|
143
|
-
selector:
|
|
103
|
+
selector: 'co-delivery-planning-overview-tile-settings-popup',
|
|
144
104
|
template: `
|
|
145
|
-
|
|
146
|
-
|
|
105
|
+
<co-dialog [showCloseIcon]="true" (closeClick)="closePopup()" [headerTemplate]="headerTemplate"
|
|
106
|
+
[footerTemplate]="footerTemplate">
|
|
147
107
|
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
108
|
+
<div class="body-wrapper">
|
|
109
|
+
<div class="rules-wrapper">
|
|
110
|
+
<div class="row available">
|
|
111
|
+
<co-input-checkbox [(model)]="transportDay.availableOnDate"></co-input-checkbox>
|
|
112
|
+
<span [textContent]="'AVAILABLE' | localize"></span></div>
|
|
153
113
|
|
|
154
|
-
|
|
114
|
+
<div class="row available">
|
|
155
115
|
|
|
156
|
-
|
|
116
|
+
</div>
|
|
157
117
|
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
118
|
+
<div class="row">
|
|
119
|
+
<div class="column">
|
|
120
|
+
<co-list-of-values class="list" [collection]="districts"
|
|
121
|
+
[model]="districtsForTransportDay(transportDay)"
|
|
122
|
+
(modelChange)="handleDistrictsChange($event)"
|
|
123
|
+
[displayField]="'description'"
|
|
124
|
+
[label]="'DISTRICTS' | localize"
|
|
125
|
+
[multiselect]="true"
|
|
126
|
+
[searchDisabled]="false"
|
|
127
|
+
[searchPlaceholder]="'Zoeken...'"
|
|
168
128
|
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
129
|
+
></co-list-of-values>
|
|
130
|
+
<co-list-of-values class="list" [collection]="deliveryMethods"
|
|
131
|
+
[model]="deliveryMethodsForTransportDay(transportDay)"
|
|
132
|
+
(modelChange)="handleDeliveryMethodChange($event)"
|
|
133
|
+
[displayField]="'description'"
|
|
134
|
+
[label]="'DELIVERY_METHODS' | localize"
|
|
135
|
+
[multiselect]="true"
|
|
136
|
+
[searchDisabled]="false"
|
|
137
|
+
[searchPlaceholder]="'Zoeken...'"
|
|
138
|
+
></co-list-of-values>
|
|
139
|
+
</div>
|
|
180
140
|
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
141
|
+
<div class="column">
|
|
142
|
+
<co-list-of-values class="list" [collection]="skills"
|
|
143
|
+
[model]="skillsForTransportDay(transportDay)"
|
|
144
|
+
(modelChange)="handleSkillsChange($event)"
|
|
145
|
+
[displayField]="'description'"
|
|
146
|
+
[label]="'SKILLS' | localize"
|
|
147
|
+
[multiselect]="true"
|
|
148
|
+
[searchDisabled]="false"
|
|
149
|
+
[searchPlaceholder]="'Zoeken...'"
|
|
150
|
+
></co-list-of-values>
|
|
151
|
+
<co-list-of-values class="list" [collection]="employees"
|
|
152
|
+
[model]="transportDay.employees"
|
|
153
|
+
(modelChange)="handleEmployeeChange($event)"
|
|
154
|
+
[displayField]="'familyName'"
|
|
155
|
+
[label]="'EMPLOYEES' | localize"
|
|
156
|
+
[multiselect]="true"
|
|
157
|
+
[searchDisabled]="false"
|
|
158
|
+
[searchPlaceholder]="'Zoeken...'"
|
|
159
|
+
></co-list-of-values>
|
|
160
|
+
</div>
|
|
161
|
+
</div>
|
|
202
162
|
|
|
203
|
-
|
|
163
|
+
</div>
|
|
204
164
|
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
165
|
+
<div class="rules-wrapper">
|
|
166
|
+
<co-list-of-values class="list" [collection]="userGroups"
|
|
167
|
+
[displayField]="'description'"
|
|
168
|
+
[label]="'USER_GROUPS' | localize"
|
|
169
|
+
[multiselect]="true"
|
|
170
|
+
[searchDisabled]="false"
|
|
171
|
+
[searchPlaceholder]="'Zoeken...'"
|
|
172
|
+
></co-list-of-values>
|
|
173
|
+
</div>
|
|
174
|
+
</div>
|
|
175
|
+
</co-dialog>
|
|
216
176
|
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
177
|
+
<ng-template #headerTemplate>
|
|
178
|
+
<div class="dialog-header-wrapper">
|
|
179
|
+
<div class="row">
|
|
180
|
+
<co-icon class="small" [iconData]="iconCacheService.getIcon(icons.SlidersUpRegular)"></co-icon>
|
|
181
|
+
<span class="bold" [textContent]="'PLANNING_RULES' | localize"></span>
|
|
182
|
+
</div>
|
|
223
183
|
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
184
|
+
<div class="row">
|
|
185
|
+
<span class="footer-header-title bold" [textContent]="transportDay?.transport?.registrationNumber"></span>
|
|
186
|
+
<div class="icon">
|
|
187
|
+
<co-icon class=""
|
|
188
|
+
[iconData]="iconCacheService.getIcon(icons.TruckContainerDuo)"></co-icon>
|
|
189
|
+
</div>
|
|
190
|
+
</div>
|
|
229
191
|
</div>
|
|
230
|
-
|
|
231
|
-
</div>
|
|
232
|
-
</ng-template>
|
|
192
|
+
</ng-template>
|
|
233
193
|
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
194
|
+
<ng-template #footerTemplate>
|
|
195
|
+
<div class="co-dialog-footer-button-wrapper">
|
|
196
|
+
<co-button class="save-button"
|
|
197
|
+
(click)="handleCommitClick()"
|
|
198
|
+
[iconData]="iconCacheService.getIcon(icons.CheckDuotone)"></co-button>
|
|
199
|
+
<co-button class="close-button"
|
|
200
|
+
(click)="closePopup()" [iconData]="iconCacheService.getIcon(icons.Crossskinny)"></co-button>
|
|
201
|
+
</div>
|
|
202
|
+
</ng-template>
|
|
243
203
|
|
|
244
204
|
`,
|
|
245
205
|
encapsulation: ViewEncapsulation.None
|
|
@@ -255,6 +215,6 @@ DeliveryPlanningOverviewTileSettingsPopupComponent.propDecorators = {
|
|
|
255
215
|
closeEvent: [{ type: Output }],
|
|
256
216
|
onSaveAction: [{ type: Output }],
|
|
257
217
|
availabilityChecked: [{ type: Output }],
|
|
258
|
-
showClass: [{ type: HostBinding, args: [
|
|
218
|
+
showClass: [{ type: HostBinding, args: ['class.co-delivery-planning-overview-tile-settings-popup',] }]
|
|
259
219
|
};
|
|
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"]}
|
|
220
|
+
//# 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, 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\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 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  @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  @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  ngOnDestroy() {\r\n    this._subs.forEach(sub => {\r\n      sub.unsubscribe();\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  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.districts.push(district.districtId);\r\n      }\r\n    });\r\n    if (!this.settingsChanged) {\r\n      this.settingsChanged = true;\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    this.closeEvent.emit();\r\n  }\r\n\r\n}\r\n"]}
|