@colijnit/sharedcomponents 258.1.3 → 258.1.5

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.
Files changed (31) hide show
  1. package/bundles/colijnit-sharedcomponents.umd.js +50 -11
  2. package/bundles/colijnit-sharedcomponents.umd.js.map +1 -1
  3. package/colijnit-sharedcomponents.metadata.json +1 -1
  4. package/esm2015/lib/components/activity-list/activity-list.component.js +18 -2
  5. package/esm2015/lib/components/activity-overview-component/component-activity-overview.component.js +23 -3
  6. package/esm2015/lib/components/stock/components/order-tab/order-tab.component.js +44 -6
  7. package/esm2015/lib/components/stock/stock-tabs/stock-tabs.component.js +5 -2
  8. package/esm2015/lib/components/stock/stock.component.js +4 -1
  9. package/esm2015/lib/res/dictionary/dictionaries.js +5 -5
  10. package/fesm2015/colijnit-sharedcomponents.js +93 -13
  11. package/fesm2015/colijnit-sharedcomponents.js.map +1 -1
  12. package/lib/components/activity-list/activity-list.component.d.ts +3 -0
  13. package/lib/components/activity-list/style/_layout.scss +18 -5
  14. package/lib/components/activity-overview-component/component-activity-overview.component.d.ts +3 -0
  15. package/lib/components/activity-overview-component/style/_layout.scss +41 -2
  16. package/lib/components/stock/components/order-tab/order-tab.component.d.ts +3 -0
  17. package/lib/components/stock/stock-tabs/stock-tabs.component.d.ts +1 -0
  18. package/lib/components/stock/stock.component.d.ts +1 -0
  19. package/lib/components/stock/style/_layout.scss +37 -1
  20. package/lib/res/dictionary/dictionaries.d.ts +67 -0
  21. package/package.json +1 -1
  22. package/358.645812766f7a400d0d38.js +0 -1
  23. package/3rdpartylicenses.txt +0 -2222
  24. package/863.171601b3075f2e971ba6.js +0 -1
  25. package/977.bd6291f9ee6f6ddf91f1.js +0 -1
  26. package/favicon.ico +0 -0
  27. package/index.html +0 -12
  28. package/main.40213c24ad994dd29dc7.js +0 -1
  29. package/polyfills.907fe9d1887c5de17993.js +0 -1
  30. package/runtime.f3719d23058f5b07c143.js +0 -1
  31. package/styles.9e6f1ab393c5fc104896.css +0 -1
@@ -20,6 +20,7 @@ export class ActivityListComponent {
20
20
  this.workIcon = Icon.PersonDiggingRegular;
21
21
  this.statusIcon = Icon.DiagramProjectRegular;
22
22
  this.taskIcon = Icon.Task;
23
+ this.activityColorMap = new Map();
23
24
  }
24
25
  showClass() {
25
26
  return true;
@@ -108,6 +109,18 @@ export class ActivityListComponent {
108
109
  this.showActivityPopup = true;
109
110
  this.currentActivityDocuments = activity.documents;
110
111
  }
112
+ getRandomColor() {
113
+ const r = Math.floor(180 + Math.random() * 75); // 180–255
114
+ const g = Math.floor(180 + Math.random() * 75);
115
+ const b = Math.floor(180 + Math.random() * 75);
116
+ return `rgb(${r},${g},${b})`;
117
+ }
118
+ getColorForActivity(activity) {
119
+ if (!this.activityColorMap.has(activity)) {
120
+ this.activityColorMap.set(activity, this.getRandomColor());
121
+ }
122
+ return this.activityColorMap.get(activity);
123
+ }
111
124
  }
112
125
  ActivityListComponent.decorators = [
113
126
  { type: Component, args: [{
@@ -119,10 +132,13 @@ ActivityListComponent.decorators = [
119
132
  <div class="activity-display-title">
120
133
  <span>{{activity.author && (activity.author.initials || activity.author.familyName) ? (activity.author.initials || '') + ' ' + (activity.author.familyName || '') : ''}}</span>
121
134
  <span>{{getDateString(activity.lastActionDateTime)}}</span>
122
- <co-icon [iconData]="iconCacheService.getIcon(getActivityIcon(activity))"></co-icon>
123
135
  </div>
124
136
  <div class="activity-display-content" [class.customer-reply-content]="(getRelationKind(activity.author) === RelationKind.Customer)">
125
137
  <div class="activity-display-body">
138
+ <div class="activity-icon" [ngStyle]="{'background-color': getColorForActivity(activity)}">
139
+ <co-icon [iconData]="iconCacheService.getIcon(getActivityIcon(activity))"></co-icon>
140
+ </div>
141
+
126
142
  <span *ngIf="activity.activityType !== ActivityType.StateChange">{{activity.subDescription}}</span>
127
143
  <span *ngIf="activity.activityType === ActivityType.StateChange">{{activity.activityTitle}}</span>
128
144
  </div>
@@ -173,4 +189,4 @@ ActivityListComponent.propDecorators = {
173
189
  taskIcon: [{ type: Input }],
174
190
  hidden: [{ type: HostBinding, args: ['class.co-shared-hidden',] }]
175
191
  };
176
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-list/activity-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {RelationKind} from \"@colijnit/articleapi/build/enum/relation-kind.enum\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {ALL_MONTHS} from \"../../model/constant/all-months\";\r\nimport {TimeUtils} from \"@colijnit/mainapi/build/utils/time-utils\";\r\nimport {RelationSmallObject} from \"@colijnit/mainapi/build/model/relation-small-object.bo\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\nimport {\r\n  SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n  ScreenConfigAdapterComponent\r\n} from \"@colijnit/corecomponents_v12\";\r\n\r\n@Component({\r\n  selector: \"co-activity-list\",\r\n  template: `\r\n    <div class=\"activity-list-wrapper\">\r\n      <div class=\"activity-wrapper\" [class.customer-reply-wrapper]=\"(getRelationKind(activity.author) === RelationKind.Customer)\" *ngFor=\"let activity of activities\" >\r\n        <div class=\"activity-display\">\r\n          <div class=\"activity-display-title\">\r\n            <span>{{activity.author && (activity.author.initials || activity.author.familyName) ? (activity.author.initials || '') + ' ' + (activity.author.familyName || '') : ''}}</span>\r\n            <span>{{getDateString(activity.lastActionDateTime)}}</span>\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n          </div>\r\n          <div class=\"activity-display-content\" [class.customer-reply-content]=\"(getRelationKind(activity.author) === RelationKind.Customer)\">\r\n            <div class=\"activity-display-body\">\r\n              <span *ngIf=\"activity.activityType !== ActivityType.StateChange\">{{activity.subDescription}}</span>\r\n              <span *ngIf=\"activity.activityType === ActivityType.StateChange\">{{activity.activityTitle}}</span>\r\n            </div>\r\n            <div class=\"activity-display-footer\" [class.extra-height]=\"showTriggers(activity) || showAttachments(activity) || showWorkedTime(activity)\">\r\n              <div class=\"activity-fired-triggers\" *ngIf=\"showTriggers(activity)\" >\r\n                <div class=\"activity-fired-trigger\" *ngFor=\"let triggerName of activity.stateChange?.firedTriggerNames\">\r\n                  <span>{{triggerName}}</span>\r\n                </div>\r\n              </div>\r\n              <div class=\"icon-indicators\">\r\n                <co-icon *ngIf=\"showAttachments(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.PaperclipRegular)\" (click)=\"openActivityPopup(activity)\"></co-icon>\r\n                <co-icon *ngIf=\"showEmailHistory(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.EmailRegular)\"></co-icon>\r\n                <span *ngIf=\"showAttachments(activity)\">{{activity.documents.length}}</span>\r\n                <co-icon *ngIf=\"showWorkedTime(activity)\"\r\n                         [iconData]=\"iconCacheService.getIcon(Icon.ClockRegular)\"></co-icon>\r\n                <span *ngIf=\"showWorkedTime(activity)\" >\r\n                       {{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-dialog *ngIf=\"showActivityPopup\" (closeClick)=\"showActivityPopup = false\">\r\n      <co-files-upload [canAdd]=\"false\"  [documents]=\"currentActivityDocuments\">\r\n      </co-files-upload>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => ActivityListComponent)\r\n    }\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ActivityListComponent implements OnInit, ScreenConfigAdapterComponent {\r\n  public readonly Icon = Icon;\r\n  public readonly RelationKind = RelationKind;\r\n  public readonly ActivityType = ActivityType;\r\n  public readonly TimeUtils = TimeUtils;\r\n\r\n  @HostBinding(\"class.co-activity-list\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public set activities(value: Activity[]) {\r\n    if (value && value.length > 0) {\r\n      value.sort((a: Activity, b: Activity) => a.lastActionDateTime < b.lastActionDateTime ? 1: -1);\r\n    }\r\n    this._activities = value;\r\n  }\r\n\r\n  public get activities(): Activity[] {\r\n    return this._activities;\r\n  }\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.Task;\r\n\r\n  public objectConfigName: string;\r\n  @HostBinding('class.co-shared-hidden')\r\n  public hidden: boolean;\r\n  public required: boolean;\r\n  public forceReadonly: boolean;\r\n  public readonly: boolean;\r\n  public maxLength: number;\r\n  public decimals: number;\r\n  public redErrorBackground: boolean;\r\n\r\n  public showActivityPopup: Boolean;\r\n  public currentActivityDocuments: CoDocument[];\r\n\r\n  private _activities: Activity[]\r\n\r\n  constructor(public iconCacheService: IconCacheService,\r\n              private _dictionaryService: SharedComponentsDictionaryService\r\n  ) {\r\n  }\r\n\r\n  public async ngOnInit(): Promise<void> {\r\n  }\r\n\r\n  public getRelationKind(author: RelationSmallObject): RelationKind {\r\n    if (author) {\r\n      return author.relationType;\r\n    } else {\r\n      return null\r\n    }\r\n  }\r\n\r\n  public getDateString(date: Date): string {\r\n    const day = date.getDate();\r\n    const month = this._dictionaryService.get(ALL_MONTHS[date.getMonth()]);\r\n    const hours = date.getHours().toString().padStart(2, '0');\r\n    const minutes = date.getMinutes().toString().padStart(2, '0');\r\n    return `${day} ${month} ${hours}:${minutes}`;\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n      case ActivityType.Work:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.Form:\r\n        return this.workIcon;\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n\r\n  public showTriggers(activity: Activity): boolean {\r\n    if (activity.activityType === ActivityType.StateChange && activity.stateChange.firedTriggerNames &&\r\n                  activity.stateChange.firedTriggerNames.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showAttachments(activity: Activity): boolean {\r\n    if (activity.documents && activity.documents.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showEmailHistory(activity: Activity): boolean {\r\n    if ((activity.remark && activity.remark.emailHistory && activity.remark.emailHistory.length > 0) ||\r\n        (activity.work && activity.work.emailHistory && activity.work.emailHistory.length > 0) ||\r\n        (activity.task && activity.task.emailHistory && activity.task.emailHistory.length > 0)) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showWorkedTime(activity: Activity): boolean {\r\n    if ((activity.IsWork && activity.work && activity.work.workedTime) ||\r\n      (activity.IsTask && activity.task && activity.task.workedTime)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public getWorkedTime(activity: Activity): number {\r\n    if (activity.IsWork && activity.work && activity.work.workedTime) {\r\n      return activity.work.workedTime;\r\n    } else if (activity.IsTask && activity.task && activity.task.workedTime) {\r\n      return activity.task.workedTime;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public openActivityPopup(activity: Activity): void {\r\n    this.showActivityPopup = true;\r\n    this.currentActivityDocuments = activity.documents;\r\n  }\r\n}\r\n"]}
192
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-list.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-list/activity-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component, forwardRef,\r\n  HostBinding,\r\n  Input,\r\n  OnInit,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {RelationKind} from \"@colijnit/articleapi/build/enum/relation-kind.enum\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {ALL_MONTHS} from \"../../model/constant/all-months\";\r\nimport {TimeUtils} from \"@colijnit/mainapi/build/utils/time-utils\";\r\nimport {RelationSmallObject} from \"@colijnit/mainapi/build/model/relation-small-object.bo\";\r\nimport {CoDocument} from \"@colijnit/mainapi/build/model/co-document\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\nimport {\r\n  SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n  ScreenConfigAdapterComponent\r\n} from \"@colijnit/corecomponents_v12\";\r\n\r\n@Component({\r\n  selector: \"co-activity-list\",\r\n  template: `\r\n    <div class=\"activity-list-wrapper\">\r\n      <div class=\"activity-wrapper\" [class.customer-reply-wrapper]=\"(getRelationKind(activity.author) === RelationKind.Customer)\" *ngFor=\"let activity of activities\" >\r\n        <div class=\"activity-display\">\r\n          <div class=\"activity-display-title\">\r\n            <span>{{activity.author && (activity.author.initials || activity.author.familyName) ? (activity.author.initials || '') + ' ' + (activity.author.familyName || '') : ''}}</span>\r\n            <span>{{getDateString(activity.lastActionDateTime)}}</span>\r\n          </div>\r\n          <div class=\"activity-display-content\" [class.customer-reply-content]=\"(getRelationKind(activity.author) === RelationKind.Customer)\">\r\n            <div class=\"activity-display-body\">\r\n              <div class=\"activity-icon\" [ngStyle]=\"{'background-color': getColorForActivity(activity)}\">\r\n                <co-icon [iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n              </div>\r\n\r\n              <span *ngIf=\"activity.activityType !== ActivityType.StateChange\">{{activity.subDescription}}</span>\r\n              <span *ngIf=\"activity.activityType === ActivityType.StateChange\">{{activity.activityTitle}}</span>\r\n            </div>\r\n            <div class=\"activity-display-footer\" [class.extra-height]=\"showTriggers(activity) || showAttachments(activity) || showWorkedTime(activity)\">\r\n              <div class=\"activity-fired-triggers\" *ngIf=\"showTriggers(activity)\" >\r\n                <div class=\"activity-fired-trigger\" *ngFor=\"let triggerName of activity.stateChange?.firedTriggerNames\">\r\n                  <span>{{triggerName}}</span>\r\n                </div>\r\n              </div>\r\n              <div class=\"icon-indicators\">\r\n                <co-icon *ngIf=\"showAttachments(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.PaperclipRegular)\" (click)=\"openActivityPopup(activity)\"></co-icon>\r\n                <co-icon *ngIf=\"showEmailHistory(activity)\" [iconData]=\"iconCacheService.getIcon(Icon.EmailRegular)\"></co-icon>\r\n                <span *ngIf=\"showAttachments(activity)\">{{activity.documents.length}}</span>\r\n                <co-icon *ngIf=\"showWorkedTime(activity)\"\r\n                         [iconData]=\"iconCacheService.getIcon(Icon.ClockRegular)\"></co-icon>\r\n                <span *ngIf=\"showWorkedTime(activity)\" >\r\n                       {{TimeUtils.ConvertToDuration(getWorkedTime(activity))}}</span>\r\n              </div>\r\n            </div>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n    <co-dialog *ngIf=\"showActivityPopup\" (closeClick)=\"showActivityPopup = false\">\r\n      <co-files-upload [canAdd]=\"false\"  [documents]=\"currentActivityDocuments\">\r\n      </co-files-upload>\r\n    </co-dialog>\r\n  `,\r\n  providers: [\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => ActivityListComponent)\r\n    }\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class ActivityListComponent implements OnInit, ScreenConfigAdapterComponent {\r\n  public readonly Icon = Icon;\r\n  public readonly RelationKind = RelationKind;\r\n  public readonly ActivityType = ActivityType;\r\n  public readonly TimeUtils = TimeUtils;\r\n\r\n  @HostBinding(\"class.co-activity-list\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @Input()\r\n  public set activities(value: Activity[]) {\r\n    if (value && value.length > 0) {\r\n      value.sort((a: Activity, b: Activity) => a.lastActionDateTime < b.lastActionDateTime ? 1: -1);\r\n    }\r\n    this._activities = value;\r\n  }\r\n\r\n  public get activities(): Activity[] {\r\n    return this._activities;\r\n  }\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.Task;\r\n\r\n  public objectConfigName: string;\r\n  @HostBinding('class.co-shared-hidden')\r\n  public hidden: boolean;\r\n  public required: boolean;\r\n  public forceReadonly: boolean;\r\n  public readonly: boolean;\r\n  public maxLength: number;\r\n  public decimals: number;\r\n  public redErrorBackground: boolean;\r\n\r\n  public showActivityPopup: Boolean;\r\n  public currentActivityDocuments: CoDocument[];\r\n\r\n  private _activities: Activity[]\r\n  private activityColorMap: Map<Activity, string> = new Map();\r\n\r\n  constructor(public iconCacheService: IconCacheService,\r\n              private _dictionaryService: SharedComponentsDictionaryService\r\n  ) {\r\n  }\r\n\r\n  public async ngOnInit(): Promise<void> {\r\n  }\r\n\r\n  public getRelationKind(author: RelationSmallObject): RelationKind {\r\n    if (author) {\r\n      return author.relationType;\r\n    } else {\r\n      return null\r\n    }\r\n  }\r\n\r\n  public getDateString(date: Date): string {\r\n    const day = date.getDate();\r\n    const month = this._dictionaryService.get(ALL_MONTHS[date.getMonth()]);\r\n    const hours = date.getHours().toString().padStart(2, '0');\r\n    const minutes = date.getMinutes().toString().padStart(2, '0');\r\n    return `${day} ${month} ${hours}:${minutes}`;\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n      case ActivityType.Work:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.Form:\r\n        return this.workIcon;\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n\r\n  public showTriggers(activity: Activity): boolean {\r\n    if (activity.activityType === ActivityType.StateChange && activity.stateChange.firedTriggerNames &&\r\n                  activity.stateChange.firedTriggerNames.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showAttachments(activity: Activity): boolean {\r\n    if (activity.documents && activity.documents.length > 0) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showEmailHistory(activity: Activity): boolean {\r\n    if ((activity.remark && activity.remark.emailHistory && activity.remark.emailHistory.length > 0) ||\r\n        (activity.work && activity.work.emailHistory && activity.work.emailHistory.length > 0) ||\r\n        (activity.task && activity.task.emailHistory && activity.task.emailHistory.length > 0)) {\r\n      return true\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public showWorkedTime(activity: Activity): boolean {\r\n    if ((activity.IsWork && activity.work && activity.work.workedTime) ||\r\n      (activity.IsTask && activity.task && activity.task.workedTime)) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public getWorkedTime(activity: Activity): number {\r\n    if (activity.IsWork && activity.work && activity.work.workedTime) {\r\n      return activity.work.workedTime;\r\n    } else if (activity.IsTask && activity.task && activity.task.workedTime) {\r\n      return activity.task.workedTime;\r\n    }\r\n    return 0;\r\n  }\r\n\r\n  public openActivityPopup(activity: Activity): void {\r\n    this.showActivityPopup = true;\r\n    this.currentActivityDocuments = activity.documents;\r\n  }\r\n\r\n  public getRandomColor(): string {\r\n    const r = Math.floor(180 + Math.random() * 75); // 180–255\r\n    const g = Math.floor(180 + Math.random() * 75);\r\n    const b = Math.floor(180 + Math.random() * 75);\r\n    return `rgb(${r},${g},${b})`;\r\n  }\r\n\r\n  public getColorForActivity(activity: Activity): string {\r\n    if (!this.activityColorMap.has(activity)) {\r\n      this.activityColorMap.set(activity, this.getRandomColor());\r\n    }\r\n    return this.activityColorMap.get(activity);\r\n  }\r\n}\r\n"]}
@@ -20,6 +20,7 @@ export class ComponentActivityOverviewComponent extends BaseActivityOverviewComp
20
20
  this.workIcon = Icon.PersonDiggingRegular;
21
21
  this.statusIcon = Icon.DiagramProjectRegular;
22
22
  this.taskIcon = Icon.ListUlRegular;
23
+ this.activityColorMap = new Map();
23
24
  }
24
25
  showClass() {
25
26
  return true;
@@ -40,6 +41,18 @@ export class ComponentActivityOverviewComponent extends BaseActivityOverviewComp
40
41
  return this.taskIcon;
41
42
  }
42
43
  }
44
+ getRandomColor() {
45
+ const r = Math.floor(180 + Math.random() * 75); // 180–255
46
+ const g = Math.floor(180 + Math.random() * 75);
47
+ const b = Math.floor(180 + Math.random() * 75);
48
+ return `rgb(${r},${g},${b})`;
49
+ }
50
+ getColorForActivity(activity) {
51
+ if (!this.activityColorMap.has(activity)) {
52
+ this.activityColorMap.set(activity, this.getRandomColor());
53
+ }
54
+ return this.activityColorMap.get(activity);
55
+ }
43
56
  }
44
57
  ComponentActivityOverviewComponent.decorators = [
45
58
  { type: Component, args: [{
@@ -49,9 +62,15 @@ ComponentActivityOverviewComponent.decorators = [
49
62
  <div class="overview-wrapper" *ngIf="!isTask">
50
63
  <div class="overview-current">
51
64
  <div class="overview-wrapper-icons">
65
+ <div class="activity-icon" [ngStyle]="{'background-color': getColorForActivity(activity)}">
66
+ <co-icon [iconData]="iconCacheService.getIcon(getActivityIcon(activity))"></co-icon>
67
+ </div>
68
+ <!-- dunno if this needs to be saved, but according to the latest designs not anymore
52
69
  <co-icon *ngIf="userIsSupervisor && (!isTask || firstTriggerToCloseWF === undefined)" icon="supervisor"
53
70
  class="supervisor-icon big dark"
54
71
  [title]="'MY_TASKS_SUPERVISOR' | sharedLocalize"></co-icon>
72
+
73
+ -->
55
74
  </div>
56
75
  <div class="overview-wrapper-labels">
57
76
  <div class="activity-label">
@@ -74,7 +93,6 @@ ComponentActivityOverviewComponent.decorators = [
74
93
  <div class="date-divider" [textContent]="'-'"></div>
75
94
  </ng-container>
76
95
  <div class="date" [textContent]="deadlineDate | date:'dd-MM-YYYY'"></div>
77
- <co-icon class="activity-type-icon"[iconData]="iconCacheService.getIcon(getActivityIcon(activity))"></co-icon>
78
96
  </div>
79
97
  </div>
80
98
  </div>
@@ -109,6 +127,9 @@ ComponentActivityOverviewComponent.decorators = [
109
127
  </div>
110
128
  </div>
111
129
  <div class="overview-task-wrapper" *ngIf="isTask" (click)="handleOpenLink($event)">
130
+ <div class="activity-icon" [ngStyle]="{'background-color': getColorForActivity(activity)}">
131
+ <co-icon [iconData]="iconCacheService.getIcon(icon.ListUlRegular)"></co-icon>
132
+ </div>
112
133
  <div class="task-box">
113
134
  <div class="task-current-state">
114
135
  <div class="activity-title" [textContent]="activityTitle"></div>
@@ -122,7 +143,6 @@ ComponentActivityOverviewComponent.decorators = [
122
143
  <div class="date-divider" [textContent]="'-'"></div>
123
144
  </ng-container>
124
145
  <div class="date" [textContent]="deadlineDate | date:'dd-MM-YYYY'"></div>
125
- <co-icon class="activity-type-icon"[iconData]="iconCacheService.getIcon(icon.ListUlRegular)"></co-icon>
126
146
  </div>
127
147
  </div>
128
148
  <ng-container *ngIf="isTask && firstTriggerToCloseWF !== undefined">
@@ -192,4 +212,4 @@ ComponentActivityOverviewComponent.propDecorators = {
192
212
  taskIcon: [{ type: Input }],
193
213
  showClass: [{ type: HostBinding, args: ["class.co-component-activity-overview",] }]
194
214
  };
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component-activity-overview.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-overview-component/component-activity-overview.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input} from \"@angular/core\";\r\nimport {\r\n  CoreDialogService,\r\n  FormMasterService,\r\n  SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from \"@colijnit/corecomponents_v12\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {BaseActivityOverviewComponent} from \"./components/base-activity-overview.component\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {SharedService} from \"../../service/shared.service\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\n\r\n\r\n@Component({\r\n    selector: \"co-component-activity-overview\",\r\n    template: `\r\n      <div class=\"activity-task-wrapper\">\r\n        <div class=\"overview-wrapper\" *ngIf=\"!isTask\">\r\n          <div class=\"overview-current\">\r\n            <div class=\"overview-wrapper-icons\">\r\n              <co-icon *ngIf=\"userIsSupervisor && (!isTask || firstTriggerToCloseWF === undefined)\" icon=\"supervisor\"\r\n                       class=\"supervisor-icon big dark\"\r\n                       [title]=\"'MY_TASKS_SUPERVISOR' | sharedLocalize\"></co-icon>\r\n            </div>\r\n            <div class=\"overview-wrapper-labels\">\r\n              <div class=\"activity-label\">\r\n                <span class=\"label\" [textContent]=\"'CURRENT_STATE' | sharedLocalize\"></span>\r\n              </div>\r\n              <div class=\"activity-title\" [textContent]=\"activityTitle\"></div>\r\n              <!--seems unessecary for current usecases, but left in case this needs an input to switch on or off-->\r\n              <!--<div class=\"activity-context-title\" [textContent]=\"activityContextTitle\"></div>-->\r\n            </div>\r\n          </div>\r\n          <div class=\"overview-main\">\r\n            <div class=\"label-date-activity\">\r\n              <div class=\"activity-label\">\r\n                <span class=\"label\" [textContent]=\"'NEXT_STATE' | sharedLocalize\"></span>\r\n              </div>\r\n              <div class=\"overview-wrapper-date\">\r\n                <div class=\"date-wrapper\" [class.overdue]=\"overDue\">\r\n                  <ng-container *ngIf=\"!sameDates\">\r\n                    <div class=\"date\" [textContent]=\"targetDate | date:'dd-MM-YYYY'\"></div>\r\n                    <div class=\"date-divider\" [textContent]=\"'-'\"></div>\r\n                  </ng-container>\r\n                  <div class=\"date\" [textContent]=\"deadlineDate | date:'dd-MM-YYYY'\"></div>\r\n                  <co-icon class=\"activity-type-icon\"[iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n                </div>\r\n              </div>\r\n            </div>\r\n              <!--TODO reinstate this when we figure out how to trigger a screen change. -->\r\n              <!--<ng-container *ngIf=\"urls && urls.length > 0\">\r\n                  <button-colijn *ngFor=\"let url of urls\"\r\n                                 class=\"trans-green custom-text button-trigger-icon action-hover no-margin\"\r\n                                 [icon]=\"icon.DetailView\"\r\n                                 [label]=\"'OPEN_LINK' | sharedLocalize\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleOpenLink($event, url)\"></button-colijn>\r\n              </ng-container>-->\r\n            <div class=\"activity-buttons\">\r\n              <ng-container *ngIf=\"!isTask && hasTriggers\">\r\n                  <co-button     class=\"trans-green custom-text action-hover button-trigger no-margin\" *ngFor=\"let trigger of workFlow.manualGenericTriggers\"\r\n                                 [class.button-trigger-icon]=\"trigger.isTaskTrigger\"\r\n                                 [label]=\"trigger.triggerButtonName\"\r\n                                 [iconData]=\"trigger.isTaskTrigger ? iconCacheService.getIcon(icon.Account): null\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleGenericTriggerClick(trigger)\"\r\n                  ></co-button>\r\n                  <co-button     class=\"trans-green custom-text action-hover button-trigger no-margin\" *ngFor=\"let trigger of workFlow.manualTriggersWithoutTaskTriggers\"\r\n                                 [class.high-prio]=\"trigger.overDue\"\r\n                                 [class.button-trigger-icon]=\"trigger.isTaskTrigger\"\r\n                                 [label]=\"trigger.triggerButtonName\"\r\n                                 [iconData]=\"trigger.isTaskTrigger ? iconCacheService.getIcon(icon.DetailView): null\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleTriggerClick(trigger)\"\r\n                  ></co-button>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div class=\"overview-task-wrapper\" *ngIf=\"isTask\" (click)=\"handleOpenLink($event)\">\r\n          <div class=\"task-box\">\r\n            <div class=\"task-current-state\">\r\n              <div class=\"activity-title\" [textContent]=\"activityTitle\"></div>\r\n              <!--seems unessecary for current usecases, but left in case this needs an input to switch on or off-->\r\n              <!--<div class=\"activity-context-title\" [textContent]=\"activityContextTitle\"></div>-->\r\n            </div>\r\n            <div class=\"overview-wrapper-date\">\r\n              <div class=\"date-wrapper\" [class.overdue]=\"overDue\">\r\n                <ng-container *ngIf=\"!sameDates\">\r\n                  <div class=\"date\" [textContent]=\"targetDate | date:'dd-MM-YYYY'\"></div>\r\n                  <div class=\"date-divider\" [textContent]=\"'-'\"></div>\r\n                </ng-container>\r\n                <div class=\"date\" [textContent]=\"deadlineDate | date:'dd-MM-YYYY'\"></div>\r\n                <co-icon class=\"activity-type-icon\"[iconData]=\"iconCacheService.getIcon(icon.ListUlRegular)\"></co-icon>\r\n              </div>\r\n            </div>\r\n            <ng-container *ngIf=\"isTask && firstTriggerToCloseWF !== undefined\">\r\n              <co-button class=\"trans-green custom-text button-trigger no-margin\" [label]=\"firstTriggerToCloseWF.description\"\r\n                         (click)=\"handleButtonEndClick()\"></co-button>\r\n            </ng-container>\r\n            <!--ng-container *ngIf=\"openButtonLabel\">\r\n              <co-button class=\"trans-green default-bg custom-text button-trigger-icon action-hover no-margin\"\r\n                         iconClass=\"custom small\" [iconData]=\"iconCacheService.getIcon(icon.DetailView)\" [label]=\"openButtonLabel | sharedLocalize\"\r\n                         (click)=\"handleOpenLink($event)\"></co-button>\r\n            </ng-container-->\r\n          </div>\r\n\r\n        </div>\r\n      </div>\r\n        <!--TODO reinstate this when we figure out how to trigger a screen change. -->\r\n        <!-- <formbuilder-user-form *ngIf=\"showCreateForm\"\r\n                                 [showPopup]=\"showCreateForm\"\r\n                                 [table]=\"table\"\r\n                                 [key]=\"key\"\r\n                                 [form]=\"form\"\r\n                                 (cancelForm)=\"doCancelForm()\"\r\n                                 (saveForm)=\"doSaveForm($event)\"\r\n        ></formbuilder-user-form>-->\r\n        <co-task-modifier\r\n                [userGroupId]=\"userGroupId\"\r\n                [relationId]=\"userRelationId\"\r\n                (editingComplete)=\"onSaveActivity($event)\"\r\n                (activityDeleted)=\"onDeleteActivity($event)\"\r\n                (showWorkLog)=\"showTaskFormAndWorkLog()\"\r\n                (triggerFired)=\"handleFormTriggerFired()\"\r\n        ></co-task-modifier>\r\n\r\n    `,\r\n    animations: [\r\n        trigger(\"fadeInOut\", [\r\n          state(\"void\", style({opacity: 0})),\r\n          state(\"*\", style({opacity: 1})),\r\n          transition(\":enter, :leave\", animate(\"200ms ease-in-out\")),\r\n        ]),\r\n        trigger(\"showHideExtended\", [\r\n            state(\"void\", style({\"transform-origin\": \"top center\", transform: \"scaleY(0)\"})),\r\n            state(\"*\", style({\"transform-origin\": \"top center\", transform: \"scaleY(1)\"})),\r\n            transition(\":enter, :leave\", [\r\n                animate(\"200ms ease-in-out\")\r\n            ])\r\n        ])\r\n    ], providers: [\r\n    FormMasterService,\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => ComponentActivityOverviewComponent)\r\n    }\r\n  ],\r\n})\r\nexport class ComponentActivityOverviewComponent extends BaseActivityOverviewComponent {\r\n  public readonly Icon: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.ListUlRegular;\r\n\r\n  @HostBinding(\"class.co-component-activity-overview\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n  constructor(public iconCacheService: IconCacheService,\r\n              public dialogService: CoreDialogService,\r\n              public dictionaryService: SharedComponentsDictionaryService,\r\n              protected sharedService: SharedService\r\n              /*public router: Router*/) {\r\n    super(dialogService, dictionaryService, sharedService/*router*/);\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n        return this.workIcon;\r\n      case ActivityType.Work:\r\n        return this.workIcon;\r\n      case ActivityType.Form:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n}\r\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component-activity-overview.component.js","sourceRoot":"","sources":["../../../../../../projects/sharedcomponents/src/lib/components/activity-overview-component/component-activity-overview.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, forwardRef, HostBinding, Input} from \"@angular/core\";\r\nimport {\r\n  CoreDialogService,\r\n  FormMasterService,\r\n  SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME\r\n} from \"@colijnit/corecomponents_v12\";\r\nimport {animate, state, style, transition, trigger} from \"@angular/animations\";\r\nimport {BaseActivityOverviewComponent} from \"./components/base-activity-overview.component\";\r\nimport {Icon} from \"../../enum/icon.enum\";\r\nimport {IconCacheService} from \"../../service/icon-cache.service\";\r\nimport {SharedService} from \"../../service/shared.service\";\r\nimport {Activity} from \"@colijnit/mainapi/build/model/activity.bo\";\r\nimport {ActivityType} from \"@colijnit/mainapi/build/enum/activity-type\";\r\nimport {SharedComponentsDictionaryService} from '../../translation/shared-components-dictionary.service';\r\n\r\n\r\n@Component({\r\n    selector: \"co-component-activity-overview\",\r\n    template: `\r\n      <div class=\"activity-task-wrapper\">\r\n        <div class=\"overview-wrapper\" *ngIf=\"!isTask\">\r\n          <div class=\"overview-current\">\r\n            <div class=\"overview-wrapper-icons\">\r\n              <div class=\"activity-icon\" [ngStyle]=\"{'background-color': getColorForActivity(activity)}\">\r\n                <co-icon [iconData]=\"iconCacheService.getIcon(getActivityIcon(activity))\"></co-icon>\r\n              </div>\r\n              <!-- dunno if this needs to be saved, but according to the latest designs not anymore\r\n              <co-icon *ngIf=\"userIsSupervisor && (!isTask || firstTriggerToCloseWF === undefined)\" icon=\"supervisor\"\r\n                       class=\"supervisor-icon big dark\"\r\n                       [title]=\"'MY_TASKS_SUPERVISOR' | sharedLocalize\"></co-icon>\r\n\r\n              -->\r\n            </div>\r\n            <div class=\"overview-wrapper-labels\">\r\n              <div class=\"activity-label\">\r\n                <span class=\"label\" [textContent]=\"'CURRENT_STATE' | sharedLocalize\"></span>\r\n              </div>\r\n              <div class=\"activity-title\" [textContent]=\"activityTitle\"></div>\r\n              <!--seems unessecary for current usecases, but left in case this needs an input to switch on or off-->\r\n              <!--<div class=\"activity-context-title\" [textContent]=\"activityContextTitle\"></div>-->\r\n            </div>\r\n          </div>\r\n          <div class=\"overview-main\">\r\n            <div class=\"label-date-activity\">\r\n              <div class=\"activity-label\">\r\n                <span class=\"label\" [textContent]=\"'NEXT_STATE' | sharedLocalize\"></span>\r\n              </div>\r\n              <div class=\"overview-wrapper-date\">\r\n                <div class=\"date-wrapper\" [class.overdue]=\"overDue\">\r\n                  <ng-container *ngIf=\"!sameDates\">\r\n                    <div class=\"date\" [textContent]=\"targetDate | date:'dd-MM-YYYY'\"></div>\r\n                    <div class=\"date-divider\" [textContent]=\"'-'\"></div>\r\n                  </ng-container>\r\n                  <div class=\"date\" [textContent]=\"deadlineDate | date:'dd-MM-YYYY'\"></div>\r\n                </div>\r\n              </div>\r\n            </div>\r\n              <!--TODO reinstate this when we figure out how to trigger a screen change. -->\r\n              <!--<ng-container *ngIf=\"urls && urls.length > 0\">\r\n                  <button-colijn *ngFor=\"let url of urls\"\r\n                                 class=\"trans-green custom-text button-trigger-icon action-hover no-margin\"\r\n                                 [icon]=\"icon.DetailView\"\r\n                                 [label]=\"'OPEN_LINK' | sharedLocalize\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleOpenLink($event, url)\"></button-colijn>\r\n              </ng-container>-->\r\n            <div class=\"activity-buttons\">\r\n              <ng-container *ngIf=\"!isTask && hasTriggers\">\r\n                  <co-button     class=\"trans-green custom-text action-hover button-trigger no-margin\" *ngFor=\"let trigger of workFlow.manualGenericTriggers\"\r\n                                 [class.button-trigger-icon]=\"trigger.isTaskTrigger\"\r\n                                 [label]=\"trigger.triggerButtonName\"\r\n                                 [iconData]=\"trigger.isTaskTrigger ? iconCacheService.getIcon(icon.Account): null\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleGenericTriggerClick(trigger)\"\r\n                  ></co-button>\r\n                  <co-button     class=\"trans-green custom-text action-hover button-trigger no-margin\" *ngFor=\"let trigger of workFlow.manualTriggersWithoutTaskTriggers\"\r\n                                 [class.high-prio]=\"trigger.overDue\"\r\n                                 [class.button-trigger-icon]=\"trigger.isTaskTrigger\"\r\n                                 [label]=\"trigger.triggerButtonName\"\r\n                                 [iconData]=\"trigger.isTaskTrigger ? iconCacheService.getIcon(icon.DetailView): null\"\r\n                                 iconClass=\"custom small\"\r\n                                 (click)=\"handleTriggerClick(trigger)\"\r\n                  ></co-button>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div class=\"overview-task-wrapper\" *ngIf=\"isTask\" (click)=\"handleOpenLink($event)\">\r\n          <div class=\"activity-icon\" [ngStyle]=\"{'background-color': getColorForActivity(activity)}\">\r\n            <co-icon [iconData]=\"iconCacheService.getIcon(icon.ListUlRegular)\"></co-icon>\r\n          </div>\r\n          <div class=\"task-box\">\r\n            <div class=\"task-current-state\">\r\n              <div class=\"activity-title\" [textContent]=\"activityTitle\"></div>\r\n              <!--seems unessecary for current usecases, but left in case this needs an input to switch on or off-->\r\n              <!--<div class=\"activity-context-title\" [textContent]=\"activityContextTitle\"></div>-->\r\n            </div>\r\n            <div class=\"overview-wrapper-date\">\r\n              <div class=\"date-wrapper\" [class.overdue]=\"overDue\">\r\n                <ng-container *ngIf=\"!sameDates\">\r\n                  <div class=\"date\" [textContent]=\"targetDate | date:'dd-MM-YYYY'\"></div>\r\n                  <div class=\"date-divider\" [textContent]=\"'-'\"></div>\r\n                </ng-container>\r\n                <div class=\"date\" [textContent]=\"deadlineDate | date:'dd-MM-YYYY'\"></div>\r\n              </div>\r\n            </div>\r\n            <ng-container *ngIf=\"isTask && firstTriggerToCloseWF !== undefined\">\r\n              <co-button class=\"trans-green custom-text button-trigger no-margin\" [label]=\"firstTriggerToCloseWF.description\"\r\n                         (click)=\"handleButtonEndClick()\"></co-button>\r\n            </ng-container>\r\n            <!--ng-container *ngIf=\"openButtonLabel\">\r\n              <co-button class=\"trans-green default-bg custom-text button-trigger-icon action-hover no-margin\"\r\n                         iconClass=\"custom small\" [iconData]=\"iconCacheService.getIcon(icon.DetailView)\" [label]=\"openButtonLabel | sharedLocalize\"\r\n                         (click)=\"handleOpenLink($event)\"></co-button>\r\n            </ng-container-->\r\n          </div>\r\n\r\n        </div>\r\n      </div>\r\n        <!--TODO reinstate this when we figure out how to trigger a screen change. -->\r\n        <!-- <formbuilder-user-form *ngIf=\"showCreateForm\"\r\n                                 [showPopup]=\"showCreateForm\"\r\n                                 [table]=\"table\"\r\n                                 [key]=\"key\"\r\n                                 [form]=\"form\"\r\n                                 (cancelForm)=\"doCancelForm()\"\r\n                                 (saveForm)=\"doSaveForm($event)\"\r\n        ></formbuilder-user-form>-->\r\n        <co-task-modifier\r\n                [userGroupId]=\"userGroupId\"\r\n                [relationId]=\"userRelationId\"\r\n                (editingComplete)=\"onSaveActivity($event)\"\r\n                (activityDeleted)=\"onDeleteActivity($event)\"\r\n                (showWorkLog)=\"showTaskFormAndWorkLog()\"\r\n                (triggerFired)=\"handleFormTriggerFired()\"\r\n        ></co-task-modifier>\r\n\r\n    `,\r\n    animations: [\r\n        trigger(\"fadeInOut\", [\r\n          state(\"void\", style({opacity: 0})),\r\n          state(\"*\", style({opacity: 1})),\r\n          transition(\":enter, :leave\", animate(\"200ms ease-in-out\")),\r\n        ]),\r\n        trigger(\"showHideExtended\", [\r\n            state(\"void\", style({\"transform-origin\": \"top center\", transform: \"scaleY(0)\"})),\r\n            state(\"*\", style({\"transform-origin\": \"top center\", transform: \"scaleY(1)\"})),\r\n            transition(\":enter, :leave\", [\r\n                animate(\"200ms ease-in-out\")\r\n            ])\r\n        ])\r\n    ], providers: [\r\n    FormMasterService,\r\n    {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => ComponentActivityOverviewComponent)\r\n    }\r\n  ],\r\n})\r\nexport class ComponentActivityOverviewComponent extends BaseActivityOverviewComponent {\r\n  public readonly Icon: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public remarkIcon: Icon = Icon.CommentRegular;\r\n\r\n  @Input()\r\n  public workIcon: Icon = Icon.PersonDiggingRegular;\r\n\r\n  @Input()\r\n  public statusIcon: Icon = Icon.DiagramProjectRegular;\r\n\r\n  @Input()\r\n  public taskIcon: Icon = Icon.ListUlRegular;\r\n\r\n  @HostBinding(\"class.co-component-activity-overview\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  private activityColorMap: Map<Activity, string> = new Map();\r\n\r\n  constructor(public iconCacheService: IconCacheService,\r\n              public dialogService: CoreDialogService,\r\n              public dictionaryService: SharedComponentsDictionaryService,\r\n              protected sharedService: SharedService\r\n              /*public router: Router*/) {\r\n    super(dialogService, dictionaryService, sharedService/*router*/);\r\n  }\r\n\r\n  public getActivityIcon(activity: Activity): Icon {\r\n    switch (activity.activityType) {\r\n      case ActivityType.Remark:\r\n        return this.remarkIcon;\r\n      case ActivityType.WorkflowStatus:\r\n        return this.workIcon;\r\n      case ActivityType.Work:\r\n        return this.workIcon;\r\n      case ActivityType.Form:\r\n      case ActivityType.WorkflowTask:\r\n      case ActivityType.StateChange:\r\n        return this.statusIcon;\r\n      case ActivityType.Task:\r\n        return this.taskIcon;\r\n    }\r\n  }\r\n\r\n  public getRandomColor(): string {\r\n    const r = Math.floor(180 + Math.random() * 75); // 180–255\r\n    const g = Math.floor(180 + Math.random() * 75);\r\n    const b = Math.floor(180 + Math.random() * 75);\r\n    return `rgb(${r},${g},${b})`;\r\n  }\r\n\r\n  public getColorForActivity(activity: Activity): string {\r\n    if (!this.activityColorMap.has(activity)) {\r\n      this.activityColorMap.set(activity, this.getRandomColor());\r\n    }\r\n    return this.activityColorMap.get(activity);\r\n  }\r\n}\r\n"]}
@@ -18,6 +18,7 @@ export class OrderTabComponent extends BaseStockComponent {
18
18
  this.sendMethodDialogClicked = new EventEmitter();
19
19
  this.handleStickerClicked = new EventEmitter();
20
20
  this.showStockTransferChange = new EventEmitter();
21
+ this.handleTransactionClick = new EventEmitter();
21
22
  this.data = [];
22
23
  this.selectedRow = null;
23
24
  this.showSendMethodDialog = false;
@@ -47,6 +48,13 @@ export class OrderTabComponent extends BaseStockComponent {
47
48
  });
48
49
  });
49
50
  }
51
+ handleTransactionNavigationClick(event, transNr) {
52
+ event.stopPropagation();
53
+ this.handleTransactionNavigation(transNr);
54
+ }
55
+ handleTransactionNavigation(transNr) {
56
+ this.handleTransactionClick.emit(transNr);
57
+ }
50
58
  }
51
59
  OrderTabComponent.decorators = [
52
60
  { type: Component, args: [{
@@ -75,18 +83,47 @@ OrderTabComponent.decorators = [
75
83
  [rowsPerPage]="20"
76
84
  [showAdd]="false"
77
85
  [inlineEdit]="false"
86
+ [showGridSettings]="false"
87
+ [showColumnSort]="true"
78
88
  [showToolbar]="true"
79
89
  (selectRow)="onRowSelected($event)">
80
- <co-simple-grid-column [headerText]="'IN_ORDER' | sharedLocalize" [field]="'transactionNr'"></co-simple-grid-column>
90
+ <co-simple-grid-column [headerText]="'ORDER' | sharedLocalize" [field]="'transactionNr'">
91
+ <ng-template #template let-row="row">
92
+ <div class="double-data link">
93
+ <co-icon
94
+ [iconData]="iconCacheService.getIcon(icons.DetailView)"
95
+ (click)="handleTransactionNavigationClick($event, row.transactionNr.toString())"
96
+ ></co-icon>
97
+ <span
98
+ [textContent]="row.transactionNr"
99
+ (click)="handleTransactionNavigationClick($event, row.transactionNr.toString())">
100
+ </span>
101
+ </div>
102
+ </ng-template>
103
+ </co-simple-grid-column>
81
104
  <co-simple-grid-column [headerText]="'CUSTOMER' | sharedLocalize" [field]="'customerName'"></co-simple-grid-column>
82
- <co-simple-grid-column [headerText]="'DATE' | sharedLocalize">
105
+ <co-simple-grid-column [headerText]="'ORDER_DATE' | sharedLocalize" [field]="'transactionDate'">
83
106
  <ng-template #template let-row="row">
84
107
  <span [textContent]="row.transactionDate | date:'dd-MM-yyyy'"></span>
85
108
  </ng-template>
86
109
  </co-simple-grid-column>
110
+ <co-simple-grid-column [headerText]="'DELIVERY_DATE' | sharedLocalize" [field]="'deliveryDate'">
111
+ <ng-template #template let-row="row">
112
+ <span [textContent]="row.deliveryDate | date:'dd-MM-yyyy'"></span>
113
+ </ng-template>
114
+ </co-simple-grid-column>
115
+ <co-simple-grid-column [headerText]="'SERIAL_NO' | sharedLocalize" [field]="'serialNo'"></co-simple-grid-column>
116
+ <co-simple-grid-column [headerText]="'BATCH_NO' | sharedLocalize" [field]="'batchNo'"></co-simple-grid-column>
87
117
  <co-simple-grid-column [headerText]="'AMOUNT' | sharedLocalize" [field]="'amountInOrder'"></co-simple-grid-column>
88
- <co-simple-grid-column [headerText]="'WAREHOUSE' | sharedLocalize" [field]="'warehouseNumber'"></co-simple-grid-column>
89
- <co-simple-grid-column [headerText]="'DESCRIPTION' | sharedLocalize" [field]="'warehouseDescription'"></co-simple-grid-column>
118
+ <co-simple-grid-column [headerText]="'ALLOCATED' | sharedLocalize" [field]="'reserved'"></co-simple-grid-column>
119
+ <co-simple-grid-column [headerText]="'WAREHOUSE' | sharedLocalize" [field]="'warehouseNumber'">
120
+ <ng-template #template let-row="row">
121
+ <div class="double-data">
122
+ <span [textContent]="row.warehouseNumber"></span>
123
+ <span [textContent]="row.warehouseDescription"></span>
124
+ </div>
125
+ </ng-template>
126
+ </co-simple-grid-column>
90
127
  </co-simple-grid>
91
128
  <co-send-method-dialog *ngIf="showSendMethodDialog"
92
129
  (closeClick)="showSendMethodDialog = false">
@@ -108,6 +145,7 @@ OrderTabComponent.propDecorators = {
108
145
  transferIconClicked: [{ type: Output }],
109
146
  sendMethodDialogClicked: [{ type: Output }],
110
147
  handleStickerClicked: [{ type: Output }],
111
- showStockTransferChange: [{ type: Output }]
148
+ showStockTransferChange: [{ type: Output }],
149
+ handleTransactionClick: [{ type: Output }]
112
150
  };
113
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-tab.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/stock/components/order-tab/order-tab.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAExF,OAAO,EAAC,gBAAgB,EAAC,MAAM,wCAAwC,CAAC;AACxE,OAAO,EAAC,IAAI,EAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,YAAY,EAAC,MAAM,mCAAmC,CAAC;AAG/D,OAAO,EAAC,kBAAkB,EAAC,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAC,kBAAkB,EAAC,MAAM,sDAAsD,CAAC;AAmDxF,MAAM,OAAO,iBAAkB,SAAQ,kBAAkB;IAkCvD,YACS,gBAAkC,EACjC,aAA2B;QAEnC,KAAK,EAAE,CAAC;QAHD,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,kBAAa,GAAb,aAAa,CAAc;QAnCrB,UAAK,GAAgB,IAAI,CAAC;QAEnC,mBAAc,GAAoB,EAAE,CAAC;QAMrC,kBAAa,GAAU,EAAE,CAAC;QAM1B,oBAAe,GAAiC,IAAI,YAAY,EAAkB,CAAC;QAG1E,wBAAmB,GAAiC,IAAI,YAAY,EAAE,CAAC;QAGvE,4BAAuB,GAAqC,IAAI,YAAY,EAAE,CAAC;QAGxF,yBAAoB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAE1D,4BAAuB,GAAG,IAAI,YAAY,EAAW,CAAC;QAEzD,SAAI,GAA2B,EAAE,CAAC;QAElC,gBAAW,GAA4B,IAAI,CAAC;QAE5C,yBAAoB,GAAY,KAAK,CAAC;IAO7C,CAAC;IAEM,oBAAoB,CAAC,IAAI;QAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAEM,wBAAwB,CAAC,KAAuB;QACrD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,aAAa,CAAC,GAAqB;QACxC,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC;IACzB,CAAC;IAEM,yBAAyB,CAAC,IAAa;QAC5C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC5D,CAAC;IACe,OAAO;;YACrB,MAAM,WAAW,GAAuB,IAAI,kBAAkB,EAAE,CAAC;YACjE,WAAW,CAAC,IAAI,GAAG,GAAG,CAAC;YACvB,WAAW,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC5C,IAAI,CAAC,aAAa,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;gBAClE,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;YACrB,CAAC,CAAC,CAAC;QACL,CAAC;KAAA;;;YAhHF,SAAS,SAAC;gBACT,QAAQ,EAAE,cAAc;gBACxB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAyCT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAxDO,gBAAgB;YAEhB,YAAY;;;gCA4DjB,KAAK;4BAGL,KAAK;0BAGL,KAAK;8BAGL,MAAM;kCAGN,MAAM;sCAGN,MAAM;mCAGN,MAAM;sCAGN,MAAM","sourcesContent":["import {Component, EventEmitter, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {ArticleStock as ArticleStockBo} from \"@colijnit/articleapi/build/model/article-stock.bo\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {StockService} from \"../../../../service/stock.service\";\r\nimport {ArticleTransaction as ArticleTransactionBo} from \"@colijnit/articleapi/build/model/article-transaction.bo\";\r\nimport {PrintPriceStickers} from \"@colijnit/sharedapi/build/model/print-price-stickers.bo\";\r\nimport {BaseStockComponent} from '../../base/base-stock.component';\r\nimport {ArticleTransaction} from '@colijnit/articleapi/build/model/article-transaction';\r\nimport {ArticleDetailsBo} from \"@colijnit/articleapi/build/model/article-details.bo\";\r\nimport {StockLocation} from \"@colijnit/articleapi/build/model/stock-location.bo\";\r\nimport {ArticleFlat} from \"@colijnit/articleapi/build/model/article-flat.bo\";\r\n\r\n@Component({\r\n  selector: \"co-order-tab\",\r\n  template: `\r\n    <div class=\"stock-transfer-wrapper\">\r\n      <co-stock-transfer *ngIf=\"showStockTransfer\"\r\n                         class=\"stock-transfer-dialog\"\r\n                         [articleToTransfer]=\"articleDetails\"\r\n                         (handleStickerClicked)=\"handleStickerClicked.emit($event)\"\r\n                         [allWarehouses]=\"allWarehouses\"\r\n                         [stockLocations]=\"stockLocations\"\r\n                         [articleFlat]=\"articleFlat\"\r\n                         [showStockTransfer]=\"showStockTransfer\"\r\n                         (showStockTransferChange)=\"onShowStockTransferChange($event)\">\r\n      </co-stock-transfer>\r\n    </div>\r\n    <div class=\"stock-transfer-add\">\r\n      <co-icon *ngIf=\"selectedRow\" class=\"menu-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowRightArrowLeftRegular)\"\r\n               (click)=\"handleStockTransferClick(selectedRow)\"></co-icon>\r\n      <co-icon *ngIf=\"selectedRow\" class=\"menu-icon\" [iconData]=\"iconCacheService.getIcon(icons.SolidBarcodeReadTag)\"\r\n               (click)=\"openSendMethodDialog(selectedRow)\"></co-icon>\r\n    </div>\r\n    <co-simple-grid [data]=\"data\"\r\n                    class=\"simple-grid\"\r\n                    [rowsPerPage]=\"20\"\r\n                    [showAdd]=\"false\"\r\n                    [inlineEdit]=\"false\"\r\n                    [showToolbar]=\"true\"\r\n                    (selectRow)=\"onRowSelected($event)\">\r\n      <co-simple-grid-column [headerText]=\"'IN_ORDER' | sharedLocalize\" [field]=\"'transactionNr'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'CUSTOMER' | sharedLocalize\" [field]=\"'customerName'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'DATE' | sharedLocalize\">\r\n        <ng-template #template let-row=\"row\">\r\n          <span [textContent]=\"row.transactionDate | date:'dd-MM-yyyy'\"></span>\r\n        </ng-template>\r\n      </co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'AMOUNT' | sharedLocalize\" [field]=\"'amountInOrder'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'WAREHOUSE' | sharedLocalize\" [field]=\"'warehouseNumber'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'DESCRIPTION' | sharedLocalize\" [field]=\"'warehouseDescription'\"></co-simple-grid-column>\r\n    </co-simple-grid>\r\n    <co-send-method-dialog *ngIf=\"showSendMethodDialog\"\r\n                           (closeClick)=\"showSendMethodDialog = false\">\r\n\r\n    </co-send-method-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class OrderTabComponent extends BaseStockComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  public stockLocations: StockLocation[] = [];\r\n\r\n  @Input()\r\n  public showStockTransfer: boolean;\r\n\r\n  @Input()\r\n  public allWarehouses: any[] = [];\r\n\r\n  @Input()\r\n  public articleFlat: ArticleFlat;\r\n\r\n  @Output()\r\n  public locationClicked: EventEmitter<ArticleStockBo> = new EventEmitter<ArticleStockBo>();\r\n\r\n  @Output()\r\n  public readonly transferIconClicked: EventEmitter<ArticleStockBo> = new EventEmitter();\r\n\r\n  @Output()\r\n  public readonly sendMethodDialogClicked: EventEmitter<PrintPriceStickers> = new EventEmitter();\r\n\r\n  @Output()\r\n  public handleStickerClicked: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() showStockTransferChange = new EventEmitter<boolean>();\r\n\r\n  public data: ArticleTransactionBo[] = [];\r\n\r\n  public selectedRow: ArticleDetailsBo | null = null;\r\n  public articleDetails: ArticleDetailsBo;\r\n  public showSendMethodDialog: boolean = false;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _stockService: StockService,\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public openSendMethodDialog(data): void {\r\n    this.showSendMethodDialog = true;\r\n    this.sendMethodDialogClicked.emit(data);\r\n  }\r\n\r\n  public handleStockTransferClick(event: ArticleDetailsBo): void {\r\n    this.articleDetails = event;\r\n    this.showStockTransfer = true;\r\n  }\r\n\r\n  public onRowSelected(row: ArticleDetailsBo): void {\r\n    this.selectedRow = row;\r\n  }\r\n\r\n  public onShowStockTransferChange(show: boolean) {\r\n    this.showStockTransfer = show;\r\n    this.showStockTransferChange.emit(this.showStockTransfer);\r\n  }\r\n  protected async getData(): Promise<void> {\r\n    const inOrderData: ArticleTransaction = new ArticleTransaction();\r\n    inOrderData.type = \"V\";\r\n    inOrderData.goodId = this.goodId.toString();\r\n    this._stockService.getArticleTransaction(inOrderData).then(result => {\r\n      this.data = result;\r\n    });\r\n  }\r\n}\r\n"]}
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"order-tab.component.js","sourceRoot":"","sources":["../../../../../../../../projects/sharedcomponents/src/lib/components/stock/components/order-tab/order-tab.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {ArticleStock as ArticleStockBo} from \"@colijnit/articleapi/build/model/article-stock.bo\";\r\nimport {IconCacheService} from \"../../../../service/icon-cache.service\";\r\nimport {Icon} from \"../../../../enum/icon.enum\";\r\nimport {StockService} from \"../../../../service/stock.service\";\r\nimport {ArticleTransaction as ArticleTransactionBo} from \"@colijnit/articleapi/build/model/article-transaction.bo\";\r\nimport {PrintPriceStickers} from \"@colijnit/sharedapi/build/model/print-price-stickers.bo\";\r\nimport {BaseStockComponent} from '../../base/base-stock.component';\r\nimport {ArticleTransaction} from '@colijnit/articleapi/build/model/article-transaction';\r\nimport {ArticleDetailsBo} from \"@colijnit/articleapi/build/model/article-details.bo\";\r\nimport {StockLocation} from \"@colijnit/articleapi/build/model/stock-location.bo\";\r\nimport {ArticleFlat} from \"@colijnit/articleapi/build/model/article-flat.bo\";\r\n\r\n@Component({\r\n  selector: \"co-order-tab\",\r\n  template: `\r\n    <div class=\"stock-transfer-wrapper\">\r\n      <co-stock-transfer *ngIf=\"showStockTransfer\"\r\n                         class=\"stock-transfer-dialog\"\r\n                         [articleToTransfer]=\"articleDetails\"\r\n                         (handleStickerClicked)=\"handleStickerClicked.emit($event)\"\r\n                         [allWarehouses]=\"allWarehouses\"\r\n                         [stockLocations]=\"stockLocations\"\r\n                         [articleFlat]=\"articleFlat\"\r\n                         [showStockTransfer]=\"showStockTransfer\"\r\n                         (showStockTransferChange)=\"onShowStockTransferChange($event)\">\r\n      </co-stock-transfer>\r\n    </div>\r\n    <div class=\"stock-transfer-add\">\r\n      <co-icon *ngIf=\"selectedRow\" class=\"menu-icon\" [iconData]=\"iconCacheService.getIcon(icons.ArrowRightArrowLeftRegular)\"\r\n               (click)=\"handleStockTransferClick(selectedRow)\"></co-icon>\r\n      <co-icon *ngIf=\"selectedRow\" class=\"menu-icon\" [iconData]=\"iconCacheService.getIcon(icons.SolidBarcodeReadTag)\"\r\n               (click)=\"openSendMethodDialog(selectedRow)\"></co-icon>\r\n    </div>\r\n    <co-simple-grid [data]=\"data\"\r\n                    class=\"simple-grid\"\r\n                    [rowsPerPage]=\"20\"\r\n                    [showAdd]=\"false\"\r\n                    [inlineEdit]=\"false\"\r\n                    [showGridSettings]=\"false\"\r\n                    [showColumnSort]=\"true\"\r\n                    [showToolbar]=\"true\"\r\n                    (selectRow)=\"onRowSelected($event)\">\r\n      <co-simple-grid-column [headerText]=\"'ORDER' | sharedLocalize\" [field]=\"'transactionNr'\">\r\n        <ng-template #template let-row=\"row\">\r\n          <div class=\"double-data link\">\r\n            <co-icon\r\n              [iconData]=\"iconCacheService.getIcon(icons.DetailView)\"\r\n              (click)=\"handleTransactionNavigationClick($event, row.transactionNr.toString())\"\r\n            ></co-icon>\r\n            <span\r\n              [textContent]=\"row.transactionNr\"\r\n              (click)=\"handleTransactionNavigationClick($event, row.transactionNr.toString())\">\r\n            </span>\r\n          </div>\r\n        </ng-template>\r\n      </co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'CUSTOMER' | sharedLocalize\" [field]=\"'customerName'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'ORDER_DATE' | sharedLocalize\" [field]=\"'transactionDate'\">\r\n        <ng-template #template let-row=\"row\">\r\n          <span [textContent]=\"row.transactionDate | date:'dd-MM-yyyy'\"></span>\r\n        </ng-template>\r\n      </co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'DELIVERY_DATE' | sharedLocalize\" [field]=\"'deliveryDate'\">\r\n        <ng-template #template let-row=\"row\">\r\n          <span [textContent]=\"row.deliveryDate | date:'dd-MM-yyyy'\"></span>\r\n        </ng-template>\r\n      </co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'SERIAL_NO' | sharedLocalize\" [field]=\"'serialNo'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'BATCH_NO' | sharedLocalize\" [field]=\"'batchNo'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'AMOUNT' | sharedLocalize\" [field]=\"'amountInOrder'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'ALLOCATED' | sharedLocalize\" [field]=\"'reserved'\"></co-simple-grid-column>\r\n      <co-simple-grid-column [headerText]=\"'WAREHOUSE' | sharedLocalize\" [field]=\"'warehouseNumber'\">\r\n        <ng-template #template let-row=\"row\">\r\n          <div class=\"double-data\">\r\n            <span [textContent]=\"row.warehouseNumber\"></span>\r\n            <span [textContent]=\"row.warehouseDescription\"></span>\r\n          </div>\r\n        </ng-template>\r\n      </co-simple-grid-column>\r\n    </co-simple-grid>\r\n    <co-send-method-dialog *ngIf=\"showSendMethodDialog\"\r\n                           (closeClick)=\"showSendMethodDialog = false\">\r\n\r\n    </co-send-method-dialog>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class OrderTabComponent extends BaseStockComponent {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  public stockLocations: StockLocation[] = [];\r\n\r\n  @Input()\r\n  public showStockTransfer: boolean;\r\n\r\n  @Input()\r\n  public allWarehouses: any[] = [];\r\n\r\n  @Input()\r\n  public articleFlat: ArticleFlat;\r\n\r\n  @Output()\r\n  public locationClicked: EventEmitter<ArticleStockBo> = new EventEmitter<ArticleStockBo>();\r\n\r\n  @Output()\r\n  public readonly transferIconClicked: EventEmitter<ArticleStockBo> = new EventEmitter();\r\n\r\n  @Output()\r\n  public readonly sendMethodDialogClicked: EventEmitter<PrintPriceStickers> = new EventEmitter();\r\n\r\n  @Output()\r\n  public handleStickerClicked: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output() showStockTransferChange = new EventEmitter<boolean>();\r\n\r\n  @Output()\r\n  public handleTransactionClick: EventEmitter<any> = new EventEmitter();\r\n\r\n  public data: ArticleTransactionBo[] = [];\r\n\r\n  public selectedRow: ArticleDetailsBo | null = null;\r\n  public articleDetails: ArticleDetailsBo;\r\n  public showSendMethodDialog: boolean = false;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _stockService: StockService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public openSendMethodDialog(data): void {\r\n    this.showSendMethodDialog = true;\r\n    this.sendMethodDialogClicked.emit(data);\r\n  }\r\n\r\n  public handleStockTransferClick(event: ArticleDetailsBo): void {\r\n    this.articleDetails = event;\r\n    this.showStockTransfer = true;\r\n  }\r\n\r\n  public onRowSelected(row: ArticleDetailsBo): void {\r\n    this.selectedRow = row;\r\n  }\r\n\r\n  public onShowStockTransferChange(show: boolean) {\r\n    this.showStockTransfer = show;\r\n    this.showStockTransferChange.emit(this.showStockTransfer);\r\n  }\r\n  protected async getData(): Promise<void> {\r\n    const inOrderData: ArticleTransaction = new ArticleTransaction();\r\n    inOrderData.type = \"V\";\r\n    inOrderData.goodId = this.goodId.toString();\r\n    this._stockService.getArticleTransaction(inOrderData).then(result => {\r\n      this.data = result;\r\n    });\r\n  }\r\n  public handleTransactionNavigationClick(event: Event, transNr: string): void {\r\n    event.stopPropagation();\r\n    this.handleTransactionNavigation(transNr);\r\n  }\r\n\r\n  public handleTransactionNavigation(transNr: string): void {\r\n    this.handleTransactionClick.emit(transNr);\r\n  }\r\n}\r\n"]}
@@ -14,6 +14,7 @@ export class StockTabsComponent {
14
14
  this.warehouses = [];
15
15
  this.transferIconClicked = new EventEmitter();
16
16
  this.sendMethodDialogClicked = new EventEmitter();
17
+ this.handleTransactionClick = new EventEmitter();
17
18
  this.selectedWarehouse = new StockManagementWarehouses();
18
19
  this.tabs = [];
19
20
  this.historyTabs = [];
@@ -112,6 +113,7 @@ StockTabsComponent.decorators = [
112
113
  [goodId]="article.goodId"
113
114
  (transferIconClicked)="transferIconClicked.emit($event)"
114
115
  (sendMethodDialogClicked)="sendMethodDialogClicked.emit($event)"
116
+ (handleTransactionClick)="handleTransactionClick.emit($event)"
115
117
  ></co-order-tab>
116
118
 
117
119
  <co-order-stock-tab *ngIf="tabs[4].active"
@@ -154,6 +156,7 @@ StockTabsComponent.propDecorators = {
154
156
  showStockTransfer: [{ type: Input }],
155
157
  warehouses: [{ type: Input }],
156
158
  transferIconClicked: [{ type: Output }],
157
- sendMethodDialogClicked: [{ type: Output }]
159
+ sendMethodDialogClicked: [{ type: Output }],
160
+ handleTransactionClick: [{ type: Output }]
158
161
  };
159
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stock-tabs.component.js","sourceRoot":"","sources":["../../../../../../../projects/sharedcomponents/src/lib/components/stock/stock-tabs/stock-tabs.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {ArticleStock as ArticleStockBo} from '@colijnit/articleapi/build/model/article-stock.bo';\r\nimport {StockService} from '../../../service/stock.service';\r\nimport {Tab} from '../../tab-bar/tab.interface';\r\nimport {StockManagementWarehouses} from '@colijnit/articleapi/build/model/stock-management-warehouses.bo';\r\nimport {PrintPriceStickers} from '@colijnit/sharedapi/build/model/print-price-stickers.bo';\r\nimport {ArticleExtended} from '@colijnit/articleapi/build/model/article-extended.bo';\r\nimport {ArticleFlat} from '@colijnit/articleapi/build/model/article-flat.bo';\r\nimport {SharedCfgName} from '../../../enum/shared-cfg-name.enum';\r\nimport {SharedComponentsDictionaryService} from '../../../translation/shared-components-dictionary.service';\r\n\r\n@Component({\r\n  selector: \"co-stock-tabs\",\r\n  template: `\r\n    <co-tab-bar [wareHouseLabel]=\"'CHOICES' | sharedLocalize\"\r\n                [wareHouseSearchLabel]=\"'SEARCH' | sharedLocalize\"\r\n                [tabs]=\"tabs\"\r\n                [dataWareHouseCode]=\"warehouses\"\r\n                [selectedWarehouse]=\"selectedWarehouse\"\r\n                [secondaryTabs]=\"historyTabs\"\r\n                [ActivateSecondaryTabs]=\"tabs[5].active\"\r\n                [showWarehouseSelection]=\"tabs[1].active || tabs[2].active\"\r\n                (warehouseSelected)=\"handleWarehouseSelected($event)\"\r\n    ></co-tab-bar>\r\n\r\n    <co-stock-tab *ngIf=\"tabs[0].active\"\r\n                  [articleStockInformation]=\"stockInformation\"\r\n                  (locationClicked)=\"handleLocationClicked($event)\"\r\n    ></co-stock-tab>\r\n\r\n    <co-stock-prognose *ngIf=\"tabs[1].active\"\r\n                       [goodId]=\"article.goodId\"\r\n                       [warehouseNo]=\"selectedWarehouse.warehouseNo\"\r\n    ></co-stock-prognose>\r\n\r\n    <co-stock-location *ngIf=\"tabs[2].active\"\r\n                       [articleStockInformation]=\"stockInformation\"\r\n                       [goodId]=\"article.goodId\"\r\n                       [warehouseNo]=\"selectedWarehouse.warehouseNo\"\r\n                       [articleFlat]=\"articleFlat\"\r\n                       [dataWareHouseCode]=\"warehouses\"\r\n                       [showStockTransfer]=\"showStockTransfer\"\r\n                       [selectedWarehouse]=\"selectedWarehouse\"\r\n                       (transferIconClicked)=\"transferIconClicked.emit($event)\"\r\n                       (sendMethodDialogClicked)=\"sendMethodDialogClicked.emit($event)\"\r\n                       (showStockTransferChange)=\"onShowStockTransferChange($event)\"\r\n    ></co-stock-location>\r\n\r\n    <co-order-tab *ngIf=\"tabs[3].active\"\r\n                  [goodId]=\"article.goodId\"\r\n                  (transferIconClicked)=\"transferIconClicked.emit($event)\"\r\n                  (sendMethodDialogClicked)=\"sendMethodDialogClicked.emit($event)\"\r\n    ></co-order-tab>\r\n\r\n    <co-order-stock-tab *ngIf=\"tabs[4].active\"\r\n                        [goodId]=\"article.goodId\"\r\n    ></co-order-stock-tab>\r\n\r\n    <co-stock-history *ngIf=\"historyTabs[0].active && tabs[5].active\"\r\n                      [goodId]=\"article.goodId\"\r\n    ></co-stock-history>\r\n\r\n    <co-order-supply-stock-history *ngIf=\"historyTabs[1].active && tabs[5].active\"\r\n                                   [goodId]=\"article.goodId\"\r\n    ></co-order-supply-stock-history>\r\n\r\n    <co-order-stock-commission-history *ngIf=\"historyTabs[2].active && tabs[5].active\"\r\n                                       [goodId]=\"article.goodId\"\r\n    ></co-order-stock-commission-history>\r\n\r\n    <co-order-stock-history *ngIf=\"historyTabs[3].active && tabs[5].active\"\r\n                            [goodId]=\"article.goodId\"\r\n    ></co-order-stock-history>\r\n\r\n    <co-allocation-stock-history *ngIf=\"historyTabs[4].active && tabs[5].active\"\r\n                                 [goodId]=\"article.goodId\"\r\n    ></co-allocation-stock-history>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class StockTabsComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public stockInformation: ArticleStockBo[] = [];\r\n\r\n  @Input()\r\n  public article: ArticleExtended;\r\n\r\n  @Input()\r\n  public articleFlat: ArticleFlat;\r\n\r\n  @Input()\r\n  public showStockTransfer: boolean;\r\n\r\n  @Input()\r\n  public warehouses: StockManagementWarehouses[] = [];\r\n\r\n  @Output()\r\n  public readonly transferIconClicked: EventEmitter<ArticleStockBo> = new EventEmitter();\r\n\r\n  @Output()\r\n  public readonly sendMethodDialogClicked: EventEmitter<PrintPriceStickers> = new EventEmitter();\r\n\r\n  public selectedWarehouse: StockManagementWarehouses = new StockManagementWarehouses();\r\n  public tabs: Tab[] = [];\r\n  public historyTabs: Tab[] = [];\r\n\r\n  constructor(\r\n    private _stockService: StockService,\r\n    private _dictionaryService: SharedComponentsDictionaryService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.tabs = [\r\n      {title: this._dictionaryService.get('OVERVIEW'), active: true, cfg: SharedCfgName.Overview},\r\n      {title: this._dictionaryService.get('STOCK_FORECAST'), active: false, cfg: SharedCfgName.InventoryForecast},\r\n      {title: this._dictionaryService.get('STOCK_DETAILS'), active: false, cfg: SharedCfgName.InventoryDetails},\r\n      {title: this._dictionaryService.get('ALREADY_IN_ORDER'), active: false, cfg: SharedCfgName.OverviewDetails},\r\n      {title: this._dictionaryService.get('IN_ORDER'), active: false, cfg: SharedCfgName.InOrder},\r\n      {title: this._dictionaryService.get('HISTORY'), active: false, cfg: SharedCfgName.History},\r\n    ];\r\n\r\n    this.historyTabs = [\r\n      {title: this._dictionaryService.get('STOCK'), active: true, cfg: SharedCfgName.HistoryStock},\r\n      {\r\n        title: this._dictionaryService.get('ORDER_STOCK'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryOrderStock\r\n      },\r\n      {\r\n        title: this._dictionaryService.get('ORDER_COMMISSION'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryOrderCommission\r\n      },\r\n      {title: this._dictionaryService.get('ORDER'), active: false, cfg: SharedCfgName.HistoryOrder},\r\n      {\r\n        title: this._dictionaryService.get('ALLOCATION'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryAssign\r\n      },\r\n    ];\r\n  }\r\n\r\n  public onShowStockTransferChange(show: boolean): void {\r\n    this.showStockTransfer = show;\r\n  }\r\n\r\n  public handleLocationClicked(data: string): void {\r\n    this.tabs[0].active = false;\r\n    this.tabs[2].active = true;\r\n    let warehouse: StockManagementWarehouses = this.wareHouseForCode(parseInt(data));\r\n    this.selectedWarehouse = warehouse;\r\n    this.handleWarehouseSelected(this.selectedWarehouse);\r\n    this.getStockData(this.selectedWarehouse);\r\n  }\r\n\r\n  public handleWarehouseSelected(event: StockManagementWarehouses): void {\r\n    this.selectedWarehouse = event;\r\n  }\r\n\r\n  public getStockData(warehouse: StockManagementWarehouses): void {\r\n    this.handleWarehouseSelected(warehouse);\r\n    this._changeDetector.markForCheck();\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  public wareHouseForCode(code: number) {\r\n    return this.warehouses.find(warehouse => warehouse.warehouseNo === code);\r\n  }\r\n}\r\n"]}
162
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stock-tabs.component.js","sourceRoot":"","sources":["../../../../../../../projects/sharedcomponents/src/lib/components/stock/stock-tabs/stock-tabs.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,iBAAiB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AACnH,OAAO,EAAC,IAAI,EAAC,MAAM,yBAAyB,CAAC;AAE7C,OAAO,EAAC,YAAY,EAAC,MAAM,gCAAgC,CAAC;AAE5D,OAAO,EAAC,yBAAyB,EAAC,MAAM,iEAAiE,CAAC;AAI1G,OAAO,EAAC,aAAa,EAAC,MAAM,oCAAoC,CAAC;AACjE,OAAO,EAAC,iCAAiC,EAAC,MAAM,2DAA2D,CAAC;AAyE5G,MAAM,OAAO,kBAAkB;IA+B7B,YACU,aAA2B,EAC3B,kBAAqD,EACrD,eAAkC;QAFlC,kBAAa,GAAb,aAAa,CAAc;QAC3B,uBAAkB,GAAlB,kBAAkB,CAAmC;QACrD,oBAAe,GAAf,eAAe,CAAmB;QAjC5B,UAAK,GAAgB,IAAI,CAAC;QAGnC,qBAAgB,GAAqB,EAAE,CAAC;QAYxC,eAAU,GAAgC,EAAE,CAAC;QAGpC,wBAAmB,GAAiC,IAAI,YAAY,EAAE,CAAC;QAGvE,4BAAuB,GAAqC,IAAI,YAAY,EAAE,CAAC;QAGxF,2BAAsB,GAAsB,IAAI,YAAY,EAAE,CAAC;QAE/D,sBAAiB,GAA8B,IAAI,yBAAyB,EAAE,CAAC;QAC/E,SAAI,GAAU,EAAE,CAAC;QACjB,gBAAW,GAAU,EAAE,CAAC;IAO/B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG;YACV,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,aAAa,CAAC,QAAQ,EAAC;YAC3F,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,iBAAiB,EAAC;YAC3G,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,eAAe,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,gBAAgB,EAAC;YACzG,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,kBAAkB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,eAAe,EAAC;YAC3G,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,OAAO,EAAC;YAC3F,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,OAAO,EAAC;SAC3F,CAAC;QAEF,IAAI,CAAC,WAAW,GAAG;YACjB,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,aAAa,CAAC,YAAY,EAAC;YAC5F;gBACE,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,aAAa,CAAC;gBACjD,MAAM,EAAE,KAAK;gBACb,GAAG,EAAE,aAAa,CAAC,iBAAiB;aACrC;YACD;gBACE,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,kBAAkB,CAAC;gBACtD,MAAM,EAAE,KAAK;gBACb,GAAG,EAAE,aAAa,CAAC,sBAAsB;aAC1C;YACD,EAAC,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,YAAY,EAAC;YAC7F;gBACE,KAAK,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,YAAY,CAAC;gBAChD,MAAM,EAAE,KAAK;gBACb,GAAG,EAAE,aAAa,CAAC,aAAa;aACjC;SACF,CAAC;IACJ,CAAC;IAEM,yBAAyB,CAAC,IAAa;QAC5C,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAEM,qBAAqB,CAAC,IAAY;QACvC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;QAC3B,IAAI,SAAS,GAA8B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;QACnC,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACrD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC5C,CAAC;IAEM,uBAAuB,CAAC,KAAgC;QAC7D,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAEM,YAAY,CAAC,SAAoC;QACtD,IAAI,CAAC,uBAAuB,CAAC,SAAS,CAAC,CAAC;QACxC,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC;QACpC,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;IAEM,gBAAgB,CAAC,IAAY;QAClC,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,SAAS,CAAC,WAAW,KAAK,IAAI,CAAC,CAAC;IAC3E,CAAC;;;YArKF,SAAS,SAAC;gBACT,QAAQ,EAAE,eAAe;gBACzB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkET;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA/EO,YAAY;YAOZ,iCAAiC;YAVjC,iBAAiB;;;+BAsFtB,KAAK;sBAGL,KAAK;0BAGL,KAAK;gCAGL,KAAK;yBAGL,KAAK;kCAGL,MAAM;sCAGN,MAAM;qCAGN,MAAM","sourcesContent":["import {ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {ArticleStock as ArticleStockBo} from '@colijnit/articleapi/build/model/article-stock.bo';\r\nimport {StockService} from '../../../service/stock.service';\r\nimport {Tab} from '../../tab-bar/tab.interface';\r\nimport {StockManagementWarehouses} from '@colijnit/articleapi/build/model/stock-management-warehouses.bo';\r\nimport {PrintPriceStickers} from '@colijnit/sharedapi/build/model/print-price-stickers.bo';\r\nimport {ArticleExtended} from '@colijnit/articleapi/build/model/article-extended.bo';\r\nimport {ArticleFlat} from '@colijnit/articleapi/build/model/article-flat.bo';\r\nimport {SharedCfgName} from '../../../enum/shared-cfg-name.enum';\r\nimport {SharedComponentsDictionaryService} from '../../../translation/shared-components-dictionary.service';\r\n\r\n@Component({\r\n  selector: \"co-stock-tabs\",\r\n  template: `\r\n    <co-tab-bar [wareHouseLabel]=\"'CHOICES' | sharedLocalize\"\r\n                [wareHouseSearchLabel]=\"'SEARCH' | sharedLocalize\"\r\n                [tabs]=\"tabs\"\r\n                [dataWareHouseCode]=\"warehouses\"\r\n                [selectedWarehouse]=\"selectedWarehouse\"\r\n                [secondaryTabs]=\"historyTabs\"\r\n                [ActivateSecondaryTabs]=\"tabs[5].active\"\r\n                [showWarehouseSelection]=\"tabs[1].active || tabs[2].active\"\r\n                (warehouseSelected)=\"handleWarehouseSelected($event)\"\r\n    ></co-tab-bar>\r\n\r\n    <co-stock-tab *ngIf=\"tabs[0].active\"\r\n                  [articleStockInformation]=\"stockInformation\"\r\n                  (locationClicked)=\"handleLocationClicked($event)\"\r\n    ></co-stock-tab>\r\n\r\n    <co-stock-prognose *ngIf=\"tabs[1].active\"\r\n                       [goodId]=\"article.goodId\"\r\n                       [warehouseNo]=\"selectedWarehouse.warehouseNo\"\r\n    ></co-stock-prognose>\r\n\r\n    <co-stock-location *ngIf=\"tabs[2].active\"\r\n                       [articleStockInformation]=\"stockInformation\"\r\n                       [goodId]=\"article.goodId\"\r\n                       [warehouseNo]=\"selectedWarehouse.warehouseNo\"\r\n                       [articleFlat]=\"articleFlat\"\r\n                       [dataWareHouseCode]=\"warehouses\"\r\n                       [showStockTransfer]=\"showStockTransfer\"\r\n                       [selectedWarehouse]=\"selectedWarehouse\"\r\n                       (transferIconClicked)=\"transferIconClicked.emit($event)\"\r\n                       (sendMethodDialogClicked)=\"sendMethodDialogClicked.emit($event)\"\r\n                       (showStockTransferChange)=\"onShowStockTransferChange($event)\"\r\n    ></co-stock-location>\r\n\r\n    <co-order-tab *ngIf=\"tabs[3].active\"\r\n                  [goodId]=\"article.goodId\"\r\n                  (transferIconClicked)=\"transferIconClicked.emit($event)\"\r\n                  (sendMethodDialogClicked)=\"sendMethodDialogClicked.emit($event)\"\r\n                  (handleTransactionClick)=\"handleTransactionClick.emit($event)\"\r\n    ></co-order-tab>\r\n\r\n    <co-order-stock-tab *ngIf=\"tabs[4].active\"\r\n                        [goodId]=\"article.goodId\"\r\n    ></co-order-stock-tab>\r\n\r\n    <co-stock-history *ngIf=\"historyTabs[0].active && tabs[5].active\"\r\n                      [goodId]=\"article.goodId\"\r\n    ></co-stock-history>\r\n\r\n    <co-order-supply-stock-history *ngIf=\"historyTabs[1].active && tabs[5].active\"\r\n                                   [goodId]=\"article.goodId\"\r\n    ></co-order-supply-stock-history>\r\n\r\n    <co-order-stock-commission-history *ngIf=\"historyTabs[2].active && tabs[5].active\"\r\n                                       [goodId]=\"article.goodId\"\r\n    ></co-order-stock-commission-history>\r\n\r\n    <co-order-stock-history *ngIf=\"historyTabs[3].active && tabs[5].active\"\r\n                            [goodId]=\"article.goodId\"\r\n    ></co-order-stock-history>\r\n\r\n    <co-allocation-stock-history *ngIf=\"historyTabs[4].active && tabs[5].active\"\r\n                                 [goodId]=\"article.goodId\"\r\n    ></co-allocation-stock-history>\r\n\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class StockTabsComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @Input()\r\n  public stockInformation: ArticleStockBo[] = [];\r\n\r\n  @Input()\r\n  public article: ArticleExtended;\r\n\r\n  @Input()\r\n  public articleFlat: ArticleFlat;\r\n\r\n  @Input()\r\n  public showStockTransfer: boolean;\r\n\r\n  @Input()\r\n  public warehouses: StockManagementWarehouses[] = [];\r\n\r\n  @Output()\r\n  public readonly transferIconClicked: EventEmitter<ArticleStockBo> = new EventEmitter();\r\n\r\n  @Output()\r\n  public readonly sendMethodDialogClicked: EventEmitter<PrintPriceStickers> = new EventEmitter();\r\n\r\n  @Output()\r\n  public handleTransactionClick: EventEmitter<any> = new EventEmitter();\r\n\r\n  public selectedWarehouse: StockManagementWarehouses = new StockManagementWarehouses();\r\n  public tabs: Tab[] = [];\r\n  public historyTabs: Tab[] = [];\r\n\r\n  constructor(\r\n    private _stockService: StockService,\r\n    private _dictionaryService: SharedComponentsDictionaryService,\r\n    private _changeDetector: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.tabs = [\r\n      {title: this._dictionaryService.get('OVERVIEW'), active: true, cfg: SharedCfgName.Overview},\r\n      {title: this._dictionaryService.get('STOCK_FORECAST'), active: false, cfg: SharedCfgName.InventoryForecast},\r\n      {title: this._dictionaryService.get('STOCK_DETAILS'), active: false, cfg: SharedCfgName.InventoryDetails},\r\n      {title: this._dictionaryService.get('ALREADY_IN_ORDER'), active: false, cfg: SharedCfgName.OverviewDetails},\r\n      {title: this._dictionaryService.get('IN_ORDER'), active: false, cfg: SharedCfgName.InOrder},\r\n      {title: this._dictionaryService.get('HISTORY'), active: false, cfg: SharedCfgName.History},\r\n    ];\r\n\r\n    this.historyTabs = [\r\n      {title: this._dictionaryService.get('STOCK'), active: true, cfg: SharedCfgName.HistoryStock},\r\n      {\r\n        title: this._dictionaryService.get('ORDER_STOCK'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryOrderStock\r\n      },\r\n      {\r\n        title: this._dictionaryService.get('ORDER_COMMISSION'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryOrderCommission\r\n      },\r\n      {title: this._dictionaryService.get('ORDER'), active: false, cfg: SharedCfgName.HistoryOrder},\r\n      {\r\n        title: this._dictionaryService.get('ALLOCATION'),\r\n        active: false,\r\n        cfg: SharedCfgName.HistoryAssign\r\n      },\r\n    ];\r\n  }\r\n\r\n  public onShowStockTransferChange(show: boolean): void {\r\n    this.showStockTransfer = show;\r\n  }\r\n\r\n  public handleLocationClicked(data: string): void {\r\n    this.tabs[0].active = false;\r\n    this.tabs[2].active = true;\r\n    let warehouse: StockManagementWarehouses = this.wareHouseForCode(parseInt(data));\r\n    this.selectedWarehouse = warehouse;\r\n    this.handleWarehouseSelected(this.selectedWarehouse);\r\n    this.getStockData(this.selectedWarehouse);\r\n  }\r\n\r\n  public handleWarehouseSelected(event: StockManagementWarehouses): void {\r\n    this.selectedWarehouse = event;\r\n  }\r\n\r\n  public getStockData(warehouse: StockManagementWarehouses): void {\r\n    this.handleWarehouseSelected(warehouse);\r\n    this._changeDetector.markForCheck();\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  public wareHouseForCode(code: number) {\r\n    return this.warehouses.find(warehouse => warehouse.warehouseNo === code);\r\n  }\r\n}\r\n"]}