@colijnit/transaction 12.1.142 → 12.1.143

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 (62) hide show
  1. package/bundles/colijnit-transaction.umd.js +516 -314
  2. package/bundles/colijnit-transaction.umd.js.map +1 -1
  3. package/colijnit-transaction.d.ts +78 -78
  4. package/colijnit-transaction.metadata.json +1 -1
  5. package/esm2015/colijnit-transaction.js +79 -79
  6. package/esm2015/lib/component/add-product/add-product.component.js +31 -2
  7. package/esm2015/lib/component/checkout/checkout-overview-relation-edit/checkout-overview-relation-edit.component.js +152 -20
  8. package/esm2015/lib/component/checkout/checkout.module.js +4 -2
  9. package/esm2015/lib/component/confirmation-dialog/confirmation-dialog.component.js +10 -4
  10. package/esm2015/lib/component/core/base/components/characteristic-answer/characteristic-answer.component.js +7 -2
  11. package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.js +63 -13
  12. package/esm2015/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.module.js +5 -3
  13. package/esm2015/lib/component/dialog/transaction-header/dialog-transaction-header-branch/dialog-transaction-header-branch.component.js +7 -2
  14. package/esm2015/lib/component/dialog/transaction-header/dialog-transaction-header-delivery-method/dialog-transaction-header-delivery-method.component.js +7 -2
  15. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-delivery-method/dialog-transaction-line-delivery-method.component.js +7 -2
  16. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-supplier/dialog-transaction-line-supplier.component.js +7 -2
  17. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-vat/dialog-transaction-line-vat.component.js +7 -2
  18. package/esm2015/lib/component/dialog/transaction-line/dialog-transaction-line-warehouse-cc/dialog-transaction-line-warehouse-cc.component.js +7 -2
  19. package/esm2015/lib/component/relation/relation-address/relation-address.component.js +35 -12
  20. package/esm2015/lib/component/relation/relation-addresses/relation-addresses.component.js +12 -4
  21. package/esm2015/lib/component/relation/relation-base.component.js +8 -5
  22. package/esm2015/lib/component/relation/relation-contact-details/relation-contact-details.component.js +28 -3
  23. package/esm2015/lib/component/relation/relation-general/relation-general.component.js +27 -113
  24. package/esm2015/lib/component/relation/relation-general/relation-general.module.js +6 -8
  25. package/esm2015/lib/component/shared/transaction-article-text/transaction-article-text.component.js +8 -3
  26. package/esm2015/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.js +2 -2
  27. package/esm2015/lib/component/transaction-lines/transaction-lines.component.js +2 -2
  28. package/esm2015/lib/interface/relation-suggestions-request.interface.js +2 -0
  29. package/esm2015/lib/res/dictionary/dictionaries.js +2 -2
  30. package/esm2015/lib/service/article-connector.service.js +20 -4
  31. package/esm2015/lib/service/pending-reason.service.js +3 -3
  32. package/esm2015/lib/service/transaction-connector-adapter.service.js +5 -5
  33. package/esm2015/lib/service/transaction-connector.service.js +3 -3
  34. package/esm2015/lib/service/transaction.service.js +14 -3
  35. package/esm2015/lib/transaction-version.js +3 -3
  36. package/fesm2015/colijnit-transaction.js +516 -262
  37. package/fesm2015/colijnit-transaction.js.map +1 -1
  38. package/lib/component/add-product/add-product.component.d.ts +1 -0
  39. package/lib/component/checkout/checkout-overview-relation-edit/checkout-overview-relation-edit.component.d.ts +31 -14
  40. package/lib/component/checkout/checkout-overview-relation-edit/style/_layout.scss +16 -0
  41. package/lib/component/checkout/checkout-overview-relation-edit/style/_material-definition.scss +8 -0
  42. package/lib/component/core/base/components/characteristic-answer/characteristic-answer.component.d.ts +3 -2
  43. package/lib/component/dialog/catalog/dialog-catalog/dialog-catalog.component.d.ts +9 -0
  44. package/lib/component/dialog/catalog/dialog-catalog/style/_layout.scss +19 -0
  45. package/lib/component/dialog/catalog/dialog-catalog/style/_material-definition.scss +2 -1
  46. package/lib/component/relation/relation-address/relation-address.component.d.ts +10 -7
  47. package/lib/component/relation/relation-addresses/relation-addresses.component.d.ts +3 -1
  48. package/lib/component/relation/relation-base.component.d.ts +7 -4
  49. package/lib/component/relation/relation-contact-details/relation-contact-details.component.d.ts +3 -0
  50. package/lib/component/relation/relation-general/relation-general.component.d.ts +0 -10
  51. package/lib/component/relation/relation-general/style/_layout.scss +0 -16
  52. package/lib/component/relation/relation-general/style/_material-definition.scss +0 -7
  53. package/lib/component/shared/transaction-article-text/style/_layout.scss +3 -2
  54. package/lib/component/transaction-header/transaction-header-popup/style/_layout.scss +3 -0
  55. package/lib/interface/relation-suggestions-request.interface.d.ts +13 -0
  56. package/lib/res/dictionary/dictionaries.d.ts +1 -0
  57. package/lib/service/article-connector.service.d.ts +5 -1
  58. package/lib/service/pending-reason.service.d.ts +1 -1
  59. package/lib/service/transaction-connector-adapter.service.d.ts +13 -13
  60. package/lib/service/transaction-connector.service.d.ts +12 -12
  61. package/lib/service/transaction.service.d.ts +14 -12
  62. package/package.json +1 -1
@@ -1,14 +1,10 @@
1
- import { __awaiter } from "tslib";
2
1
  import { Component, HostBinding, Input, ViewEncapsulation } from '@angular/core';
3
- import { RelationRequest } from '@colijnit/relationapi/build/model/relation-request';
4
2
  import { TransactionService } from '../../../service/transaction.service';
5
3
  import { animate, state, style, transition, trigger } from '@angular/animations';
6
4
  import { RelationBaseComponent } from '../relation-base.component';
7
5
  import { DialogService } from '../../../service/dialog.service';
8
6
  import { RelationNameKind } from '@colijnit/relationapi/build/enum/relation-name-kind.enum';
9
7
  import { GenderType } from '@colijnit/relationapi/build/enum/gender-type.enum';
10
- import { FunctionUtils } from '@colijnit/ioneconnector/build/utils/function-utils';
11
- import { ObjectUtils } from '@colijnit/ioneconnector/build/utils/object-utils';
12
8
  import { RelationService } from '../../../service/relation.service';
13
9
  export class RelationGeneralComponent extends RelationBaseComponent {
14
10
  constructor(_service, _dialogService, _relationService) {
@@ -19,15 +15,7 @@ export class RelationGeneralComponent extends RelationBaseComponent {
19
15
  this.relType = RelationNameKind;
20
16
  this.genderType = GenderType;
21
17
  this.readonly = false;
22
- this.useSuggestions = true;
23
18
  this.relationType = RelationNameKind.Private;
24
- this.relationSuggestions = [];
25
- this.showSuggestionsSidebar = false;
26
- // fetches relation suggestions
27
- this._relationNameChangeHandler = FunctionUtils.Throttle(() => {
28
- return this._relationNameChangedHandlerFn();
29
- // eslint-disable-next-line no-magic-numbers
30
- }, 600);
31
19
  }
32
20
  showClass() {
33
21
  return true;
@@ -37,54 +25,21 @@ export class RelationGeneralComponent extends RelationBaseComponent {
37
25
  this.relation.firstName = firstName;
38
26
  this.relationChange.emit(this.relation);
39
27
  }
40
- this._relationNameChangeHandler.call(this);
28
+ this.suggestionRequest.firstName = firstName;
29
+ this.inputChangeForSuggestions.next(this.suggestionRequest);
41
30
  }
42
31
  familyNameChange(familyName) {
43
32
  if (this.relation) {
44
33
  this.relation.familyName = familyName;
45
34
  this.relationChange.emit(this.relation);
46
35
  }
47
- this._relationNameChangeHandler.call(this);
36
+ this.suggestionRequest.familyName = familyName;
37
+ this.inputChangeForSuggestions.next(this.suggestionRequest);
48
38
  }
49
39
  changeGenderType(value) {
50
40
  this.relation.gender = value;
51
41
  this.relationChange.emit(this.relation);
52
42
  }
53
- checkVisibilitySuggestions() {
54
- if (this.relation.firstName && this.relation.familyName) {
55
- this.hideSidebar();
56
- }
57
- }
58
- showSidebar() {
59
- if (!this.readonly) {
60
- this.showSuggestionsSidebar = true;
61
- }
62
- }
63
- // Hide sidebar with a little timeout to prevent missing the click
64
- hideSidebar() {
65
- setTimeout(() => {
66
- this.showSuggestionsSidebar = false;
67
- }, 200);
68
- }
69
- onRelationSuggestionClick(relationSuggested) {
70
- return __awaiter(this, void 0, void 0, function* () {
71
- if (relationSuggested) {
72
- const lockResult = yield this._relationService.lockRelation(relationSuggested.relationType, parseInt(relationSuggested.relationNr, 0));
73
- if (!lockResult.success) {
74
- this._dialogService.showError("RELATION_ALREADY_LOCKED", true, lockResult.messages[0].message);
75
- }
76
- else {
77
- this.hideSidebar();
78
- const suggestedRelation = yield this._relationService.getRelation(relationSuggested.relationType, parseInt(relationSuggested.relationNr));
79
- if (suggestedRelation && suggestedRelation.addresses && suggestedRelation.addresses.length > 0) {
80
- suggestedRelation.addresses.sort((a, b) => a.sequence < b.sequence ? -1 : 1);
81
- }
82
- this.relation = suggestedRelation;
83
- this.relationChange.next(this.relation);
84
- }
85
- }
86
- });
87
- }
88
43
  relationSet() {
89
44
  super.relationSet();
90
45
  if (!this.relation.type) {
@@ -92,38 +47,6 @@ export class RelationGeneralComponent extends RelationBaseComponent {
92
47
  this.relation.gender = GenderType.Unspecified;
93
48
  }
94
49
  }
95
- // load suggestions
96
- _relationNameChangedHandlerFn() {
97
- return __awaiter(this, void 0, void 0, function* () {
98
- if (!this.useSuggestions) {
99
- return;
100
- }
101
- const firstName = ObjectUtils.ValueOrDefault(this.relation.firstName);
102
- const secondName = ObjectUtils.ValueOrDefault(this.relation.familyName);
103
- if (!firstName && !secondName) {
104
- this.relationSuggestions = [];
105
- this.hideSidebar();
106
- return;
107
- }
108
- const relationRequest = new RelationRequest();
109
- relationRequest.relationType = this._service.getRelationKindFromTransactionKind();
110
- if (firstName) {
111
- relationRequest.firstName = firstName;
112
- }
113
- if (secondName) {
114
- relationRequest.familyName = secondName;
115
- }
116
- this._relationService.getRelationListObjects(relationRequest).then((relations) => {
117
- this.relationSuggestions = relations;
118
- if (relations && relations.length > 0) {
119
- this.showSidebar();
120
- }
121
- else {
122
- this.hideSidebar();
123
- }
124
- });
125
- });
126
- }
127
50
  }
128
51
  RelationGeneralComponent.decorators = [
129
52
  { type: Component, args: [{
@@ -132,28 +55,26 @@ RelationGeneralComponent.decorators = [
132
55
  <div *ngIf="relationType === relType.Private" class="collapseable" @showHidePrivateRelationFields>
133
56
  <div class="default-data-row">
134
57
  <co-input-text
135
- class="checkout-first-name"
136
- [readonly]="readonly"
137
- [(model)]="relation.firstName"
138
- [placeholder]="'FIRST_NAME' | localize"
139
- (modelChange)="firstNameChange($event)"
140
- (blur)="checkVisibilitySuggestions()"
141
- [required]="true"
58
+ class="checkout-first-name"
59
+ [readonly]="readonly"
60
+ [(model)]="relation.firstName"
61
+ [placeholder]="'FIRST_NAME' | localize"
62
+ (modelChange)="firstNameChange($event)"
63
+ [required]="true"
142
64
  ></co-input-text>
143
65
  <co-input-text
144
- class="checkout-prefix-name default-width"
145
- [readonly]="readonly"
146
- [(model)]="relation.prefix"
147
- [placeholder]="'PREFIX' | localize"
66
+ class="checkout-prefix-name default-width"
67
+ [readonly]="readonly"
68
+ [(model)]="relation.prefix"
69
+ [placeholder]="'PREFIX' | localize"
148
70
  ></co-input-text>
149
71
  <co-input-text
150
- class="checkout-last-name"
151
- [readonly]="readonly"
152
- [(model)]="relation.familyName"
153
- [placeholder]="'LAST_NAME' | localize"
154
- (modelChange)="familyNameChange($event)"
155
- (blur)="checkVisibilitySuggestions()"
156
- [required]="true"></co-input-text>
72
+ class="checkout-last-name"
73
+ [readonly]="readonly"
74
+ [(model)]="relation.familyName"
75
+ [placeholder]="'LAST_NAME' | localize"
76
+ (modelChange)="familyNameChange($event)"
77
+ [required]="true"></co-input-text>
157
78
  </div>
158
79
  <div class="default-data-row">
159
80
  <co-input-radio-button class="default-width"
@@ -175,7 +96,12 @@ RelationGeneralComponent.decorators = [
175
96
  (modelChange)="changeGenderType(genderType.Unspecified)"
176
97
  ></co-input-radio-button>
177
98
  </div>
178
- <co-relation-contact-details [readonly]="readonly" [relation]="relation" [relationKind]="relationKind"></co-relation-contact-details>
99
+ <co-relation-contact-details
100
+ [readonly]="readonly"
101
+ [relation]="relation"
102
+ [relationKind]="relationKind"
103
+ (inputChangeForSuggestions)="inputChangeForSuggestions.emit($event)"
104
+ ></co-relation-contact-details>
179
105
  <!--
180
106
  <div class="default-data-row">
181
107
  <co-input-date [readonly]="readonly" [placeholder]="'DATE_OF_BIRTH' | localize " [(model)]="dateOfBirth"></co-input-date>
@@ -188,19 +114,8 @@ RelationGeneralComponent.decorators = [
188
114
  [placeholder]="'COMPANY_NAME' | localize"
189
115
  [required]="true"
190
116
  (modelChange)="familyNameChange($event)"
191
- (blur)="checkVisibilitySuggestions()"
192
117
  ></co-input-text>
193
118
  </div>
194
-
195
- <div class="suggestions-sidebar" *ngIf="showSuggestionsSidebar" @showHideSidebar>
196
- <div class="relation-sidebar-header">
197
- <label class="checkout-label-h3" [textContent]="'SUGGESTIONS' | localize"></label>
198
- </div>
199
- <co-relation-suggestions-list
200
- [suggestions]="relationSuggestions"
201
- (suggestionSelected)="onRelationSuggestionClick($event)"
202
- ></co-relation-suggestions-list>
203
- </div>
204
119
  `,
205
120
  animations: [
206
121
  trigger("showHidePrivateRelationFields", [
@@ -231,9 +146,8 @@ RelationGeneralComponent.ctorParameters = () => [
231
146
  ];
232
147
  RelationGeneralComponent.propDecorators = {
233
148
  readonly: [{ type: Input }],
234
- useSuggestions: [{ type: Input }],
235
149
  relationKind: [{ type: Input }],
236
150
  relationType: [{ type: Input }],
237
151
  showClass: [{ type: HostBinding, args: ["class.co-relation-general",] }]
238
152
  };
239
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-general.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-general/relation-general.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {RelationRequest} from '@colijnit/relationapi/build/model/relation-request';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {ValidationResult} from '@colijnit/ioneconnector/build/model/validation-result';\r\nimport {DialogService} from '../../../service/dialog.service';\r\nimport {RelationNameKind} from '@colijnit/relationapi/build/enum/relation-name-kind.enum';\r\nimport {GenderType} from '@colijnit/relationapi/build/enum/gender-type.enum';\r\nimport {RelationListObject} from '@colijnit/relationapi/build/model/relation-list-object.bo';\r\nimport {FunctionUtils} from '@colijnit/ioneconnector/build/utils/function-utils';\r\nimport {ObjectUtils} from '@colijnit/ioneconnector/build/utils/object-utils';\r\nimport {RelationService} from '../../../service/relation.service';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\n\r\n@Component({\r\n  selector: \"co-relation-general\",\r\n  template: `\r\n    <div *ngIf=\"relationType === relType.Private\" class=\"collapseable\" @showHidePrivateRelationFields>\r\n      <div class=\"default-data-row\">\r\n        <co-input-text\r\n          class=\"checkout-first-name\"\r\n          [readonly]=\"readonly\"\r\n          [(model)]=\"relation.firstName\"\r\n          [placeholder]=\"'FIRST_NAME' | localize\"\r\n          (modelChange)=\"firstNameChange($event)\"\r\n          (blur)=\"checkVisibilitySuggestions()\"\r\n          [required]=\"true\"\r\n        ></co-input-text>\r\n        <co-input-text\r\n          class=\"checkout-prefix-name default-width\"\r\n          [readonly]=\"readonly\"\r\n          [(model)]=\"relation.prefix\"\r\n          [placeholder]=\"'PREFIX' | localize\"\r\n        ></co-input-text>\r\n        <co-input-text\r\n          class=\"checkout-last-name\"\r\n          [readonly]=\"readonly\"\r\n          [(model)]=\"relation.familyName\"\r\n          [placeholder]=\"'LAST_NAME' | localize\"\r\n          (modelChange)=\"familyNameChange($event)\"\r\n          (blur)=\"checkVisibilitySuggestions()\"\r\n          [required]=\"true\"></co-input-text>\r\n      </div>\r\n      <div class=\"default-data-row\">\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'MALE' | localize\"\r\n                               [model]=\"relation.gender === genderType.Male\"\r\n                               (modelChange)=\"changeGenderType(genderType.Male)\"\r\n        ></co-input-radio-button>\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'FEMALE' | localize\"\r\n                               [model]=\"relation.gender === genderType.Female\"\r\n                               (modelChange)=\"changeGenderType(genderType.Female)\"\r\n        ></co-input-radio-button>\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'UNKNOWN' | localize\"\r\n                               [model]=\"relation.gender === genderType.Unspecified\"\r\n                               (modelChange)=\"changeGenderType(genderType.Unspecified)\"\r\n        ></co-input-radio-button>\r\n      </div>\r\n      <co-relation-contact-details [readonly]=\"readonly\" [relation]=\"relation\" [relationKind]=\"relationKind\"></co-relation-contact-details>\r\n      <!--\r\n            <div class=\"default-data-row\">\r\n              <co-input-date [readonly]=\"readonly\" [placeholder]=\"'DATE_OF_BIRTH' | localize \" [(model)]=\"dateOfBirth\"></co-input-date>\r\n            </div>\r\n      -->\r\n    </div>\r\n    <div *ngIf=\"relationType === relType.Company\" class=\"default-data-row collapseable\" @showHideCompanyRelationFields>\r\n      <co-input-text [readonly]=\"readonly\"\r\n                     [(model)]=\"relation.familyName\"\r\n                     [placeholder]=\"'COMPANY_NAME' | localize\"\r\n                     [required]=\"true\"\r\n                     (modelChange)=\"familyNameChange($event)\"\r\n                     (blur)=\"checkVisibilitySuggestions()\"\r\n      ></co-input-text>\r\n    </div>\r\n\r\n    <div class=\"suggestions-sidebar\" *ngIf=\"showSuggestionsSidebar\" @showHideSidebar>\r\n      <div class=\"relation-sidebar-header\">\r\n        <label class=\"checkout-label-h3\" [textContent]=\"'SUGGESTIONS' | localize\"></label>\r\n      </div>\r\n      <co-relation-suggestions-list\r\n        [suggestions]=\"relationSuggestions\"\r\n        (suggestionSelected)=\"onRelationSuggestionClick($event)\"\r\n      ></co-relation-suggestions-list>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHidePrivateRelationFields\", [\r\n      state(\"void\", style({height: 0})),\r\n      state(\"*\", style({height: \"*\"})),\r\n      transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n      transition(\"* => void\", animate(\"200ms ease-out\"))\r\n    ]),\r\n    trigger(\"showHideCompanyRelationFields\", [\r\n      state(\"void\", style({height: 0})),\r\n      state(\"*\", style({height: \"*\"})),\r\n      transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n      transition(\"* => void\", animate(\"200ms ease-out\"))\r\n    ]),\r\n    trigger(\"showHideSidebar\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationGeneralComponent extends RelationBaseComponent {\r\n  public readonly relType: typeof RelationNameKind = RelationNameKind;\r\n  public readonly genderType: typeof GenderType = GenderType;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public useSuggestions: boolean = true;\r\n\r\n  @Input()\r\n  public relationKind: RelationKind;\r\n\r\n  @Input()\r\n  public relationType: RelationNameKind = RelationNameKind.Private;\r\n\r\n  @HostBinding(\"class.co-relation-general\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public relationSuggestions: RelationListObject[] = [];\r\n  public showSuggestionsSidebar: boolean = false;\r\n  public dateOfBirth: Date; // todo: this needs to be on the relation object\r\n\r\n  constructor(\r\n    private _service: TransactionService,\r\n    private _dialogService: DialogService,\r\n    private _relationService: RelationService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public firstNameChange(firstName: string): void {\r\n    if (this.relation) {\r\n      this.relation.firstName = firstName;\r\n      this.relationChange.emit(this.relation);\r\n    }\r\n    this._relationNameChangeHandler.call(this);\r\n  }\r\n\r\n  public familyNameChange(familyName: string): void {\r\n    if (this.relation) {\r\n      this.relation.familyName = familyName;\r\n      this.relationChange.emit(this.relation);\r\n    }\r\n    this._relationNameChangeHandler.call(this);\r\n  }\r\n\r\n  public changeGenderType(value: GenderType): void {\r\n    this.relation.gender = value;\r\n    this.relationChange.emit(this.relation);\r\n  }\r\n\r\n  public checkVisibilitySuggestions(): void {\r\n    if (this.relation.firstName && this.relation.familyName) {\r\n      this.hideSidebar();\r\n    }\r\n  }\r\n\r\n  public showSidebar(): void {\r\n    if (!this.readonly) {\r\n      this.showSuggestionsSidebar = true;\r\n    }\r\n  }\r\n\r\n  // Hide sidebar with a little timeout to prevent missing the click\r\n  public hideSidebar(): void {\r\n    setTimeout(() => {\r\n      this.showSuggestionsSidebar = false;\r\n    }, 200);\r\n  }\r\n\r\n  public async onRelationSuggestionClick(relationSuggested: RelationListObject): Promise<void> {\r\n    if (relationSuggested) {\r\n      const lockResult: ValidationResult = await this._relationService.lockRelation(relationSuggested.relationType, parseInt(relationSuggested.relationNr, 0));\r\n      if (!lockResult.success) {\r\n        this._dialogService.showError(\"RELATION_ALREADY_LOCKED\", true, lockResult.messages[0].message);\r\n      } else {\r\n        this.hideSidebar();\r\n        const suggestedRelation: RelationAnyType = await this._relationService.getRelation(relationSuggested.relationType, parseInt(relationSuggested.relationNr));\r\n        if (suggestedRelation && suggestedRelation.addresses && suggestedRelation.addresses.length > 0) {\r\n          suggestedRelation.addresses.sort((a, b) => a.sequence < b.sequence ? -1 : 1);\r\n        }\r\n        this.relation = suggestedRelation;\r\n        this.relationChange.next(this.relation);\r\n      }\r\n    }\r\n  }\r\n\r\n  protected relationSet(): void {\r\n    super.relationSet();\r\n    if (!this.relation.type) {\r\n      this.relation.type = RelationNameKind.Private;\r\n      this.relation.gender = GenderType.Unspecified;\r\n    }\r\n  }\r\n\r\n  // fetches relation suggestions\r\n  private _relationNameChangeHandler: Function = FunctionUtils.Throttle(() => {\r\n    return this._relationNameChangedHandlerFn();\r\n    // eslint-disable-next-line no-magic-numbers\r\n  }, 600);\r\n\r\n  // load suggestions\r\n  private async _relationNameChangedHandlerFn(): Promise<any> {\r\n    if (!this.useSuggestions) {\r\n      return;\r\n    }\r\n    const firstName: string = ObjectUtils.ValueOrDefault(this.relation.firstName);\r\n    const secondName: string = ObjectUtils.ValueOrDefault(this.relation.familyName);\r\n\r\n    if (!firstName && !secondName) {\r\n      this.relationSuggestions = [];\r\n      this.hideSidebar();\r\n      return;\r\n    }\r\n\r\n    const relationRequest: RelationRequest = new RelationRequest();\r\n    relationRequest.relationType = this._service.getRelationKindFromTransactionKind();\r\n    if (firstName) {\r\n      relationRequest.firstName = firstName;\r\n    }\r\n\r\n    if (secondName) {\r\n      relationRequest.familyName = secondName;\r\n    }\r\n\r\n    this._relationService.getRelationListObjects(relationRequest).then((relations: RelationListObject[]) => {\r\n      this.relationSuggestions = relations;\r\n      if (relations && relations.length > 0) {\r\n        this.showSidebar();\r\n      } else {\r\n        this.hideSidebar();\r\n      }\r\n    });\r\n  }\r\n}\r\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-general.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/relation/relation-general/relation-general.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, HostBinding, Input, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {RelationBaseComponent} from '../relation-base.component';\r\nimport {DialogService} from '../../../service/dialog.service';\r\nimport {RelationNameKind} from '@colijnit/relationapi/build/enum/relation-name-kind.enum';\r\nimport {GenderType} from '@colijnit/relationapi/build/enum/gender-type.enum';\r\nimport {RelationService} from '../../../service/relation.service';\r\nimport {RelationKind} from '@colijnit/relationapi/build/enum/relation-kind.enum';\r\n\r\n@Component({\r\n  selector: \"co-relation-general\",\r\n  template: `\r\n    <div *ngIf=\"relationType === relType.Private\" class=\"collapseable\" @showHidePrivateRelationFields>\r\n      <div class=\"default-data-row\">\r\n        <co-input-text\r\n            class=\"checkout-first-name\"\r\n            [readonly]=\"readonly\"\r\n            [(model)]=\"relation.firstName\"\r\n            [placeholder]=\"'FIRST_NAME' | localize\"\r\n            (modelChange)=\"firstNameChange($event)\"\r\n            [required]=\"true\"\r\n        ></co-input-text>\r\n        <co-input-text\r\n            class=\"checkout-prefix-name default-width\"\r\n            [readonly]=\"readonly\"\r\n            [(model)]=\"relation.prefix\"\r\n            [placeholder]=\"'PREFIX' | localize\"\r\n        ></co-input-text>\r\n        <co-input-text\r\n            class=\"checkout-last-name\"\r\n            [readonly]=\"readonly\"\r\n            [(model)]=\"relation.familyName\"\r\n            [placeholder]=\"'LAST_NAME' | localize\"\r\n            (modelChange)=\"familyNameChange($event)\"\r\n            [required]=\"true\"></co-input-text>\r\n      </div>\r\n      <div class=\"default-data-row\">\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'MALE' | localize\"\r\n                               [model]=\"relation.gender === genderType.Male\"\r\n                               (modelChange)=\"changeGenderType(genderType.Male)\"\r\n        ></co-input-radio-button>\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'FEMALE' | localize\"\r\n                               [model]=\"relation.gender === genderType.Female\"\r\n                               (modelChange)=\"changeGenderType(genderType.Female)\"\r\n        ></co-input-radio-button>\r\n        <co-input-radio-button class=\"default-width\"\r\n                               [readonly]=\"readonly\"\r\n                               [label]=\"'UNKNOWN' | localize\"\r\n                               [model]=\"relation.gender === genderType.Unspecified\"\r\n                               (modelChange)=\"changeGenderType(genderType.Unspecified)\"\r\n        ></co-input-radio-button>\r\n      </div>\r\n      <co-relation-contact-details\r\n          [readonly]=\"readonly\"\r\n          [relation]=\"relation\"\r\n          [relationKind]=\"relationKind\"\r\n          (inputChangeForSuggestions)=\"inputChangeForSuggestions.emit($event)\"\r\n      ></co-relation-contact-details>\r\n      <!--\r\n            <div class=\"default-data-row\">\r\n              <co-input-date [readonly]=\"readonly\" [placeholder]=\"'DATE_OF_BIRTH' | localize \" [(model)]=\"dateOfBirth\"></co-input-date>\r\n            </div>\r\n      -->\r\n    </div>\r\n    <div *ngIf=\"relationType === relType.Company\" class=\"default-data-row collapseable\" @showHideCompanyRelationFields>\r\n      <co-input-text [readonly]=\"readonly\"\r\n                     [(model)]=\"relation.familyName\"\r\n                     [placeholder]=\"'COMPANY_NAME' | localize\"\r\n                     [required]=\"true\"\r\n                     (modelChange)=\"familyNameChange($event)\"\r\n      ></co-input-text>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHidePrivateRelationFields\", [\r\n      state(\"void\", style({height: 0})),\r\n      state(\"*\", style({height: \"*\"})),\r\n      transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n      transition(\"* => void\", animate(\"200ms ease-out\"))\r\n    ]),\r\n    trigger(\"showHideCompanyRelationFields\", [\r\n      state(\"void\", style({height: 0})),\r\n      state(\"*\", style({height: \"*\"})),\r\n      transition(\"void => *\", animate(\"200ms ease-in-out\")),\r\n      transition(\"* => void\", animate(\"200ms ease-out\"))\r\n    ]),\r\n    trigger(\"showHideSidebar\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationGeneralComponent extends RelationBaseComponent {\r\n  public readonly relType: typeof RelationNameKind = RelationNameKind;\r\n  public readonly genderType: typeof GenderType = GenderType;\r\n\r\n  @Input()\r\n  public readonly: boolean = false;\r\n\r\n  @Input()\r\n  public relationKind: RelationKind;\r\n\r\n  @Input()\r\n  public relationType: RelationNameKind = RelationNameKind.Private;\r\n\r\n  @HostBinding(\"class.co-relation-general\")\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public dateOfBirth: Date; // todo: this needs to be on the relation object\r\n\r\n  constructor(\r\n    private _service: TransactionService,\r\n    private _dialogService: DialogService,\r\n    private _relationService: RelationService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public firstNameChange(firstName: string): void {\r\n    if (this.relation) {\r\n      this.relation.firstName = firstName;\r\n      this.relationChange.emit(this.relation);\r\n    }\r\n    this.suggestionRequest.firstName = firstName;\r\n    this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n  }\r\n\r\n  public familyNameChange(familyName: string): void {\r\n    if (this.relation) {\r\n      this.relation.familyName = familyName;\r\n      this.relationChange.emit(this.relation);\r\n    }\r\n    this.suggestionRequest.familyName = familyName;\r\n    this.inputChangeForSuggestions.next(this.suggestionRequest);\r\n  }\r\n\r\n  public changeGenderType(value: GenderType): void {\r\n    this.relation.gender = value;\r\n    this.relationChange.emit(this.relation);\r\n  }\r\n\r\n  protected relationSet(): void {\r\n    super.relationSet();\r\n    if (!this.relation.type) {\r\n      this.relation.type = RelationNameKind.Private;\r\n      this.relation.gender = GenderType.Unspecified;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -1,9 +1,8 @@
1
- import { NgModule } from "@angular/core";
2
- import { CommonModule } from "@angular/common";
3
- import { RelationGeneralComponent } from "./relation-general.component";
4
- import { InputDatePickerModule, InputRadioButtonModule, InputTextModule } from "@colijnit/corecomponents_v12";
5
- import { PipeModule } from "../../../pipe/pipe.module";
6
- import { RelationSuggestionsListModule } from "../relation-suggestions-list/relation-suggestions-list.module";
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { RelationGeneralComponent } from './relation-general.component';
4
+ import { InputDatePickerModule, InputRadioButtonModule, InputTextModule } from '@colijnit/corecomponents_v12';
5
+ import { PipeModule } from '../../../pipe/pipe.module';
7
6
  import { RelationContactDetailsModule } from '../relation-contact-details/relation-contact-details.module';
8
7
  export class RelationGeneralModule {
9
8
  }
@@ -15,7 +14,6 @@ RelationGeneralModule.decorators = [
15
14
  PipeModule,
16
15
  InputRadioButtonModule,
17
16
  InputDatePickerModule,
18
- RelationSuggestionsListModule,
19
17
  RelationContactDetailsModule
20
18
  ],
21
19
  declarations: [
@@ -26,4 +24,4 @@ RelationGeneralModule.decorators = [
26
24
  ]
27
25
  },] }
28
26
  ];
29
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tZ2VuZXJhbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9yZWxhdGlvbi9yZWxhdGlvbi1nZW5lcmFsL3JlbGF0aW9uLWdlbmVyYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3RFLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUM1RyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDckQsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sK0RBQStELENBQUM7QUFDNUcsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sNkRBQTZELENBQUM7QUFtQnpHLE1BQU0sT0FBTyxxQkFBcUI7OztZQWpCakMsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLGVBQWU7b0JBQ2YsVUFBVTtvQkFDVixzQkFBc0I7b0JBQ3RCLHFCQUFxQjtvQkFDckIsNkJBQTZCO29CQUM3Qiw0QkFBNEI7aUJBQy9CO2dCQUNILFlBQVksRUFBRTtvQkFDWix3QkFBd0I7aUJBQ3pCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCx3QkFBd0I7aUJBQ3pCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSBcIkBhbmd1bGFyL2NvbW1vblwiO1xyXG5pbXBvcnQge1JlbGF0aW9uR2VuZXJhbENvbXBvbmVudH0gZnJvbSBcIi4vcmVsYXRpb24tZ2VuZXJhbC5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtJbnB1dERhdGVQaWNrZXJNb2R1bGUsIElucHV0UmFkaW9CdXR0b25Nb2R1bGUsIElucHV0VGV4dE1vZHVsZX0gZnJvbSBcIkBjb2xpam5pdC9jb3JlY29tcG9uZW50c192MTJcIjtcclxuaW1wb3J0IHtQaXBlTW9kdWxlfSBmcm9tIFwiLi4vLi4vLi4vcGlwZS9waXBlLm1vZHVsZVwiO1xyXG5pbXBvcnQge1JlbGF0aW9uU3VnZ2VzdGlvbnNMaXN0TW9kdWxlfSBmcm9tIFwiLi4vcmVsYXRpb24tc3VnZ2VzdGlvbnMtbGlzdC9yZWxhdGlvbi1zdWdnZXN0aW9ucy1saXN0Lm1vZHVsZVwiO1xyXG5pbXBvcnQge1JlbGF0aW9uQ29udGFjdERldGFpbHNNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWNvbnRhY3QtZGV0YWlscy9yZWxhdGlvbi1jb250YWN0LWRldGFpbHMubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgICAgICBQaXBlTW9kdWxlLFxyXG4gICAgICAgIElucHV0UmFkaW9CdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgSW5wdXREYXRlUGlja2VyTW9kdWxlLFxyXG4gICAgICAgIFJlbGF0aW9uU3VnZ2VzdGlvbnNMaXN0TW9kdWxlLFxyXG4gICAgICAgIFJlbGF0aW9uQ29udGFjdERldGFpbHNNb2R1bGVcclxuICAgIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZWxhdGlvbkdlbmVyYWxDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFJlbGF0aW9uR2VuZXJhbENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFJlbGF0aW9uR2VuZXJhbE1vZHVsZSB7XHJcbn1cclxuIl19
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tZ2VuZXJhbC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2NvbXBvbmVudC9yZWxhdGlvbi9yZWxhdGlvbi1nZW5lcmFsL3JlbGF0aW9uLWdlbmVyYWwubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ3RFLE9BQU8sRUFBQyxxQkFBcUIsRUFBRSxzQkFBc0IsRUFBRSxlQUFlLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUM1RyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDckQsT0FBTyxFQUFDLDRCQUE0QixFQUFDLE1BQU0sNkRBQTZELENBQUM7QUFrQnpHLE1BQU0sT0FBTyxxQkFBcUI7OztZQWhCakMsUUFBUSxTQUFDO2dCQUNOLE9BQU8sRUFBRTtvQkFDTCxZQUFZO29CQUNaLGVBQWU7b0JBQ2YsVUFBVTtvQkFDVixzQkFBc0I7b0JBQ3RCLHFCQUFxQjtvQkFDckIsNEJBQTRCO2lCQUMvQjtnQkFDSCxZQUFZLEVBQUU7b0JBQ1osd0JBQXdCO2lCQUN6QjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1Asd0JBQXdCO2lCQUN6QjthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQge1JlbGF0aW9uR2VuZXJhbENvbXBvbmVudH0gZnJvbSAnLi9yZWxhdGlvbi1nZW5lcmFsLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7SW5wdXREYXRlUGlja2VyTW9kdWxlLCBJbnB1dFJhZGlvQnV0dG9uTW9kdWxlLCBJbnB1dFRleHRNb2R1bGV9IGZyb20gJ0Bjb2xpam5pdC9jb3JlY29tcG9uZW50c192MTInO1xyXG5pbXBvcnQge1BpcGVNb2R1bGV9IGZyb20gJy4uLy4uLy4uL3BpcGUvcGlwZS5tb2R1bGUnO1xyXG5pbXBvcnQge1JlbGF0aW9uQ29udGFjdERldGFpbHNNb2R1bGV9IGZyb20gJy4uL3JlbGF0aW9uLWNvbnRhY3QtZGV0YWlscy9yZWxhdGlvbi1jb250YWN0LWRldGFpbHMubW9kdWxlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBpbXBvcnRzOiBbXHJcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgICAgIElucHV0VGV4dE1vZHVsZSxcclxuICAgICAgICBQaXBlTW9kdWxlLFxyXG4gICAgICAgIElucHV0UmFkaW9CdXR0b25Nb2R1bGUsXHJcbiAgICAgICAgSW5wdXREYXRlUGlja2VyTW9kdWxlLFxyXG4gICAgICAgIFJlbGF0aW9uQ29udGFjdERldGFpbHNNb2R1bGVcclxuICAgIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZWxhdGlvbkdlbmVyYWxDb21wb25lbnRcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIFJlbGF0aW9uR2VuZXJhbENvbXBvbmVudFxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIFJlbGF0aW9uR2VuZXJhbE1vZHVsZSB7XHJcbn1cclxuIl19
@@ -146,7 +146,7 @@ TransactionArticleTextComponent.decorators = [
146
146
  </div>
147
147
  <div class="option-wrapper">
148
148
  <co-input-checkbox class="select-all-checkbox" [model]="selectAll" (modelChange)="handleSelectAll($event)"></co-input-checkbox>
149
- <div class="article-text-documents-wrapper co-small-scrollbar">
149
+ <div class="article-text-documents-wrapper">
150
150
  <span [textContent]="'FOR_DOCUMENTS' | localize"></span>
151
151
  <co-input-checkbox *ngFor="let document of documents" [label]="document.description" (modelChange)="handleDocumentsChange($event, document)"></co-input-checkbox>
152
152
  </div>
@@ -159,7 +159,12 @@ TransactionArticleTextComponent.decorators = [
159
159
  </ng-template>
160
160
  <ng-template #footerTemplate>
161
161
  <div class="co-dialog-footer-button-wrapper">
162
- <co-button [label]="'OK' | localize" (click)="onOkClick($event)"></co-button>
162
+ <co-button class="save-button"
163
+ [iconData]="iconCacheService.getIcon(icon.CheckDuotone)"
164
+ (click)="onOkClick($event)"></co-button>
165
+ <co-button class="close-button"
166
+ [iconData]="iconCacheService.getIcon(icon.Crossskinny)"
167
+ (click)="closeClick.emit($event)"></co-button>
163
168
  </div>
164
169
  </ng-template>
165
170
  `,
@@ -185,4 +190,4 @@ TransactionArticleTextComponent.propDecorators = {
185
190
  saveClick: [{ type: Output }],
186
191
  showClass: [{ type: HostBinding, args: ["class.co-transaction-article-text",] }]
187
192
  };
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-article-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/shared/transaction-article-text/transaction-article-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {StandardText} from '../../../model/standard-text';\r\nimport {TransactionAddTextLineRequest} from '@colijnit/transactionapi/build/model/transaction-add-text-line-request.bo';\r\nimport {CoDomainValue} from '@colijnit/mainapi/build/model/co-domain-value.bo';\r\n\r\n@Component({\r\n  selector: \"co-transaction-article-text\",\r\n  template: `\r\n    <co-dialog (closeClick)=\"closeClick.emit($event)\" [headerTemplate]=\"headerTemplate\"\r\n               [footerTemplate]=\"footerTemplate\">\r\n      <div *ngIf=\"showArticleImageDescription\" class=\"article-image-description-wrapper\">\r\n        <span [textContent]=\"'Productomschrijving'\" class=\"dialog-label\"></span>\r\n        <co-transaction-line-description class=\"transaction-line-description-description\"\r\n                                         [transactionInfo]=\"transactionService.currentTransaction.transactionInfo\"\r\n                                         [transactionLine]=\"transactionLine\"\r\n                                         [defaultEditMode]=\"false\"\r\n                                         [showLabel]=\"false\"\r\n        ></co-transaction-line-description>\r\n      </div>\r\n\r\n      <div class=\"standard-texts-dropdown-wrapper\">\r\n        <co-list-of-values\r\n          [collection]=\"standardTexts\"\r\n          [displayField]=\"'description'\"\r\n          [label]=\"'STANDARD_TEXTS' | localize\"\r\n          (modelChange)=\"onSelectStandardText($event)\"\r\n        ></co-list-of-values>\r\n      </div>\r\n\r\n      <div class=\"article-text-content-wrapper\">\r\n        <div class=\"editor-wrapper\">\r\n          <textarea class=\"article-text\"\r\n                    [placeholder]=\"textAreaPlaceholder\"\r\n                    [(ngModel)]=\"transactionAddTextLineRequest.text\"\r\n          ></textarea>\r\n        </div>\r\n        <div class=\"option-wrapper\">\r\n          <co-input-checkbox class=\"select-all-checkbox\" [model]=\"selectAll\" (modelChange)=\"handleSelectAll($event)\"></co-input-checkbox>\r\n          <div class=\"article-text-documents-wrapper co-small-scrollbar\">\r\n            <span [textContent]=\"'FOR_DOCUMENTS' | localize\"></span>\r\n            <co-input-checkbox *ngFor=\"let document of documents\" [label]=\"document.description\"  (modelChange)=\"handleDocumentsChange($event, document)\"></co-input-checkbox>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n\r\n    <ng-template #headerTemplate>\r\n      <span class=\"co-dialog-header-title\" [textContent]=\"header\"></span>\r\n    </ng-template>\r\n    <ng-template #footerTemplate>\r\n      <div class=\"co-dialog-footer-button-wrapper\">\r\n        <co-button [label]=\"'OK' | localize\" (click)=\"onOkClick($event)\"></co-button>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionArticleTextComponent implements OnInit {\r\n\r\n  @Input()\r\n  public header: string;\r\n\r\n  @Input()\r\n  public transactionUuid: string;\r\n\r\n  @Input()\r\n  public set transactionLine(value: TransactionLineInfo) {\r\n    if (value) {\r\n      this._transactionLine = value;\r\n      this.transactionAddTextLineRequest.text = value.text;\r\n    }\r\n  }\r\n\r\n  public get transactionLine() {\r\n    return this._transactionLine;\r\n  }\r\n\r\n  @Input()\r\n  public set articleRef(value: string) {\r\n    if (value) {\r\n      this._articleRef = value;\r\n    }\r\n  }\r\n\r\n  public get articleRef(): string {\r\n    return this._articleRef;\r\n  }\r\n\r\n  @Input()\r\n  public set editText(value: string) {\r\n    this.new = value === undefined || value === null;\r\n    this.transactionAddTextLineRequest.text = value;\r\n  }\r\n\r\n  @Input()\r\n  public set articleLineNr(value: number) {\r\n    if (value) {\r\n      this.transactionAddTextLineRequest.refArticleLineNr = value;\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public showArticleImageDescription: boolean = false;\r\n\r\n  @Input()\r\n  public showImage: boolean = true;\r\n\r\n  @Output()\r\n  public closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public saveClick: EventEmitter<{ request: TransactionAddTextLineRequest, new: boolean }> = new EventEmitter<{ request: TransactionAddTextLineRequest, new: boolean }>();\r\n\r\n  @HostBinding(\"class.co-transaction-article-text\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public readonly icon: typeof Icon = Icon;\r\n  private _transactionLine: TransactionLineInfo;\r\n  public standardTexts: StandardText[] = [];\r\n  public documents: CoDomainValue[] = [];\r\n  public showOnDocuments: number[] = [];\r\n  public selectAll: boolean = false;\r\n  public fields: Object = {text: \"description\", value: \"textId\"};\r\n  public fieldsDocuments: Object = {text: \"description\", value: \"code\"};\r\n  public textAreaPlaceholder: string = this._dictionaryService.get(\"TYPE_TEXT\", true);\r\n  public new: boolean = true;\r\n\r\n  public transactionAddTextLineRequest: TransactionAddTextLineRequest = new TransactionAddTextLineRequest();\r\n\r\n  private _articleRef: string;\r\n\r\n  constructor(\r\n    public transactionService: TransactionService,\r\n    public iconCacheService: IconCacheService,\r\n    private _dictionaryService: DictionaryService\r\n  ) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.standardTexts = await this.transactionService.getStandardTexts(\"NL\");\r\n    this.documents = await this.transactionService.getTextTypes(\"NL\");\r\n    this._setShowOnDocuments();\r\n  }\r\n\r\n  public onOkClick(event: MouseEvent): void {\r\n    this.transactionAddTextLineRequest.transactionUuid = this.transactionUuid;\r\n    this.transactionAddTextLineRequest.showOnDocuments = this._getShowOnDocuments();\r\n    this.saveClick.next({request: this.transactionAddTextLineRequest, new: this.new});\r\n  }\r\n\r\n  public onCancelClick(event: MouseEvent): void {\r\n    this.cancelClick.next(event);\r\n  }\r\n\r\n  public onSelectStandardText(value: StandardText): void {\r\n    const standardText: StandardText = this.standardTexts.find(x => x.textId === value.textId);\r\n    this.transactionAddTextLineRequest.text = standardText ? standardText.text : \"\";\r\n  }\r\n\r\n  public handleDocumentsChange(checked: boolean, document: CoDomainValue): void {\r\n    if (checked) {\r\n      this.showOnDocuments.push(document.codeAsNumber);\r\n    } else {\r\n      const idx: number = this.showOnDocuments.indexOf(document.codeAsNumber);\r\n      this.showOnDocuments.splice(idx, 1);\r\n    }\r\n  }\r\n\r\n  public handleSelectAll(select: boolean): void {\r\n    if (select) {\r\n      this.showOnDocuments = [];\r\n      this.documents.forEach(d => this.showOnDocuments.push(d.codeAsNumber));\r\n    } else {\r\n      this.showOnDocuments = [];\r\n    }\r\n  }\r\n\r\n  private _setShowOnDocuments(): void {\r\n    this.showOnDocuments.length = 0;\r\n    if (this.transactionLine && (this.transactionLine.showOnDocuments || this.transactionLine.showOnDocuments === 0)) {\r\n      this.documents.forEach(d => {\r\n        if (d.codeAsNumber & this.transactionLine.showOnDocuments) {\r\n          this.showOnDocuments.push(d.codeAsNumber);\r\n        }\r\n      });\r\n    } else { // creating new text, check all documents\r\n      this.documents.forEach(d => this.showOnDocuments.push(d.codeAsNumber));\r\n      this.selectAll = true;\r\n    }\r\n  }\r\n\r\n  private _getShowOnDocuments(): number {\r\n    let result: number = 0;\r\n    this.showOnDocuments.forEach(d => result = result + d);\r\n    return result;\r\n  }\r\n}\r\n"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-article-text.component.js","sourceRoot":"","sources":["../../../../../../../projects/transaction/src/lib/component/shared/transaction-article-text/transaction-article-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {Icon} from '../../../enum/icon.enum';\r\nimport {DictionaryService} from '../../../service/dictionary.service';\r\nimport {IconCacheService} from '../../../service/icon-cache.service';\r\nimport {TransactionService} from '../../../service/transaction.service';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {StandardText} from '../../../model/standard-text';\r\nimport {TransactionAddTextLineRequest} from '@colijnit/transactionapi/build/model/transaction-add-text-line-request.bo';\r\nimport {CoDomainValue} from '@colijnit/mainapi/build/model/co-domain-value.bo';\r\n\r\n@Component({\r\n  selector: \"co-transaction-article-text\",\r\n  template: `\r\n    <co-dialog (closeClick)=\"closeClick.emit($event)\" [headerTemplate]=\"headerTemplate\"\r\n               [footerTemplate]=\"footerTemplate\">\r\n      <div *ngIf=\"showArticleImageDescription\" class=\"article-image-description-wrapper\">\r\n        <span [textContent]=\"'Productomschrijving'\" class=\"dialog-label\"></span>\r\n        <co-transaction-line-description class=\"transaction-line-description-description\"\r\n                                         [transactionInfo]=\"transactionService.currentTransaction.transactionInfo\"\r\n                                         [transactionLine]=\"transactionLine\"\r\n                                         [defaultEditMode]=\"false\"\r\n                                         [showLabel]=\"false\"\r\n        ></co-transaction-line-description>\r\n      </div>\r\n\r\n      <div class=\"standard-texts-dropdown-wrapper\">\r\n        <co-list-of-values\r\n          [collection]=\"standardTexts\"\r\n          [displayField]=\"'description'\"\r\n          [label]=\"'STANDARD_TEXTS' | localize\"\r\n          (modelChange)=\"onSelectStandardText($event)\"\r\n        ></co-list-of-values>\r\n      </div>\r\n\r\n      <div class=\"article-text-content-wrapper\">\r\n        <div class=\"editor-wrapper\">\r\n          <textarea class=\"article-text\"\r\n                    [placeholder]=\"textAreaPlaceholder\"\r\n                    [(ngModel)]=\"transactionAddTextLineRequest.text\"\r\n          ></textarea>\r\n        </div>\r\n        <div class=\"option-wrapper\">\r\n          <co-input-checkbox class=\"select-all-checkbox\" [model]=\"selectAll\" (modelChange)=\"handleSelectAll($event)\"></co-input-checkbox>\r\n          <div class=\"article-text-documents-wrapper\">\r\n            <span [textContent]=\"'FOR_DOCUMENTS' | localize\"></span>\r\n            <co-input-checkbox *ngFor=\"let document of documents\" [label]=\"document.description\"  (modelChange)=\"handleDocumentsChange($event, document)\"></co-input-checkbox>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </co-dialog>\r\n\r\n    <ng-template #headerTemplate>\r\n      <span class=\"co-dialog-header-title\" [textContent]=\"header\"></span>\r\n    </ng-template>\r\n    <ng-template #footerTemplate>\r\n      <div class=\"co-dialog-footer-button-wrapper\">\r\n        <co-button class=\"save-button\"\r\n                   [iconData]=\"iconCacheService.getIcon(icon.CheckDuotone)\"\r\n                   (click)=\"onOkClick($event)\"></co-button>\r\n        <co-button class=\"close-button\"\r\n                   [iconData]=\"iconCacheService.getIcon(icon.Crossskinny)\"\r\n                   (click)=\"closeClick.emit($event)\"></co-button>\r\n      </div>\r\n    </ng-template>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionArticleTextComponent implements OnInit {\r\n\r\n  @Input()\r\n  public header: string;\r\n\r\n  @Input()\r\n  public transactionUuid: string;\r\n\r\n  @Input()\r\n  public set transactionLine(value: TransactionLineInfo) {\r\n    if (value) {\r\n      this._transactionLine = value;\r\n      this.transactionAddTextLineRequest.text = value.text;\r\n    }\r\n  }\r\n\r\n  public get transactionLine() {\r\n    return this._transactionLine;\r\n  }\r\n\r\n  @Input()\r\n  public set articleRef(value: string) {\r\n    if (value) {\r\n      this._articleRef = value;\r\n    }\r\n  }\r\n\r\n  public get articleRef(): string {\r\n    return this._articleRef;\r\n  }\r\n\r\n  @Input()\r\n  public set editText(value: string) {\r\n    this.new = value === undefined || value === null;\r\n    this.transactionAddTextLineRequest.text = value;\r\n  }\r\n\r\n  @Input()\r\n  public set articleLineNr(value: number) {\r\n    if (value) {\r\n      this.transactionAddTextLineRequest.refArticleLineNr = value;\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public showArticleImageDescription: boolean = false;\r\n\r\n  @Input()\r\n  public showImage: boolean = true;\r\n\r\n  @Output()\r\n  public closeClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public saveClick: EventEmitter<{ request: TransactionAddTextLineRequest, new: boolean }> = new EventEmitter<{ request: TransactionAddTextLineRequest, new: boolean }>();\r\n\r\n  @HostBinding(\"class.co-transaction-article-text\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public readonly icon: typeof Icon = Icon;\r\n  private _transactionLine: TransactionLineInfo;\r\n  public standardTexts: StandardText[] = [];\r\n  public documents: CoDomainValue[] = [];\r\n  public showOnDocuments: number[] = [];\r\n  public selectAll: boolean = false;\r\n  public fields: Object = {text: \"description\", value: \"textId\"};\r\n  public fieldsDocuments: Object = {text: \"description\", value: \"code\"};\r\n  public textAreaPlaceholder: string = this._dictionaryService.get(\"TYPE_TEXT\", true);\r\n  public new: boolean = true;\r\n\r\n  public transactionAddTextLineRequest: TransactionAddTextLineRequest = new TransactionAddTextLineRequest();\r\n\r\n  private _articleRef: string;\r\n\r\n  constructor(\r\n    public transactionService: TransactionService,\r\n    public iconCacheService: IconCacheService,\r\n    private _dictionaryService: DictionaryService\r\n  ) {\r\n  }\r\n\r\n  async ngOnInit(): Promise<void> {\r\n    this.standardTexts = await this.transactionService.getStandardTexts(\"NL\");\r\n    this.documents = await this.transactionService.getTextTypes(\"NL\");\r\n    this._setShowOnDocuments();\r\n  }\r\n\r\n  public onOkClick(event: MouseEvent): void {\r\n    this.transactionAddTextLineRequest.transactionUuid = this.transactionUuid;\r\n    this.transactionAddTextLineRequest.showOnDocuments = this._getShowOnDocuments();\r\n    this.saveClick.next({request: this.transactionAddTextLineRequest, new: this.new});\r\n  }\r\n\r\n  public onCancelClick(event: MouseEvent): void {\r\n    this.cancelClick.next(event);\r\n  }\r\n\r\n  public onSelectStandardText(value: StandardText): void {\r\n    const standardText: StandardText = this.standardTexts.find(x => x.textId === value.textId);\r\n    this.transactionAddTextLineRequest.text = standardText ? standardText.text : \"\";\r\n  }\r\n\r\n  public handleDocumentsChange(checked: boolean, document: CoDomainValue): void {\r\n    if (checked) {\r\n      this.showOnDocuments.push(document.codeAsNumber);\r\n    } else {\r\n      const idx: number = this.showOnDocuments.indexOf(document.codeAsNumber);\r\n      this.showOnDocuments.splice(idx, 1);\r\n    }\r\n  }\r\n\r\n  public handleSelectAll(select: boolean): void {\r\n    if (select) {\r\n      this.showOnDocuments = [];\r\n      this.documents.forEach(d => this.showOnDocuments.push(d.codeAsNumber));\r\n    } else {\r\n      this.showOnDocuments = [];\r\n    }\r\n  }\r\n\r\n  private _setShowOnDocuments(): void {\r\n    this.showOnDocuments.length = 0;\r\n    if (this.transactionLine && (this.transactionLine.showOnDocuments || this.transactionLine.showOnDocuments === 0)) {\r\n      this.documents.forEach(d => {\r\n        if (d.codeAsNumber & this.transactionLine.showOnDocuments) {\r\n          this.showOnDocuments.push(d.codeAsNumber);\r\n        }\r\n      });\r\n    } else { // creating new text, check all documents\r\n      this.documents.forEach(d => this.showOnDocuments.push(d.codeAsNumber));\r\n      this.selectAll = true;\r\n    }\r\n  }\r\n\r\n  private _getShowOnDocuments(): number {\r\n    let result: number = 0;\r\n    this.showOnDocuments.forEach(d => result = result + d);\r\n    return result;\r\n  }\r\n}\r\n"]}
@@ -46,7 +46,7 @@ TransactionLineSidePanelComponent.decorators = [
46
46
  (buttonClicked)="updateActiveCategory($event)"
47
47
  ></co-transaction-button-bar>
48
48
  </div>
49
- <div class="transaction-line-side-panel-content">
49
+ <div class="transaction-line-side-panel-content co-small-scrollbar">
50
50
  <ng-container [ngSwitch]="transactionInfo.transactionKind">
51
51
  <ng-container *ngSwitchCase="transactionTypes.PurchaseOrder">
52
52
  <co-transaction-line-side-panel-purchase
@@ -96,4 +96,4 @@ TransactionLineSidePanelComponent.propDecorators = {
96
96
  cancelClick: [{ type: Output }],
97
97
  showClass: [{ type: HostBinding, args: ["class.co-transaction-line-side-panel",] }]
98
98
  };
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAC1C,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAC,eAAe,EAAC,MAAM,2DAA2D,CAAC;AAC1F,OAAO,EAAC,uBAAuB,EAAC,MAAM,2CAA2C,CAAC;AAClF,OAAO,EAAC,kBAAkB,EAAC,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAEhF,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAC,yBAAyB,EAAC,MAAM,2CAA2C,CAAC;AAsDpF,MAAM,OAAO,iCAAiC;IAwB5C,YACS,WAA6B,EAC5B,QAA4B,EAC5B,wBAAiD,EACjD,0BAAqD;QAHtD,gBAAW,GAAX,WAAW,CAAkB;QAC5B,aAAQ,GAAR,QAAQ,CAAoB;QAC5B,6BAAwB,GAAxB,wBAAwB,CAAyB;QACjD,+BAA0B,GAA1B,0BAA0B,CAA2B;QA3B/C,UAAK,GAAgB,IAAI,CAAC;QAC1B,eAAU,GAAmC,uBAAuB,CAAC;QACrE,qBAAgB,GAA2B,eAAe,CAAC;QAYpE,gBAAW,GAA6B,IAAI,YAAY,EAAc,CAAC;IAe9E,CAAC;IAVM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAUM,QAAQ;QACb,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC;aAC3G,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/D,CAAC;IAEM,oBAAoB,CAAC,MAA4B;QACtD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,oBAAoB,GAAG,MAAM,CAAC;IACrC,CAAC;;;YA3FF,SAAS,SAAC;gBACT,QAAQ,EAAE,gCAAgC;gBAC1C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCT;gBACD,UAAU,EAAE;oBACV,OAAO,CAAC,mBAAmB,EAAE;wBAC3B,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAC,SAAS,EAAE,kBAAkB,EAAC,CAAC,CAAC;wBACrD,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,EAAC,SAAS,EAAE,eAAe,EAAC,CAAC,CAAC;wBAC/C,UAAU,CAAC,YAAY,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC;qBACvD,CAAC;iBACH;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA5DO,gBAAgB;YAGhB,kBAAkB;YAClB,uBAAuB;YAGvB,yBAAyB;;;8BA2D9B,KAAK;8BAGL,KAAK;6BAGL,KAAK;0BAGL,MAAM;wBAKN,WAAW,SAAC,sCAAsC","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionKind} from '@colijnit/transactionapi/build/enum/transaction-kind.enum';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionInfo} from '@colijnit/transactionapi/build/model/transaction-info.bo';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {TransactionMappingService} from '../../service/transaction-mapping.service';\r\nimport {TransactionBarButton} from '../../model/transaction-bar-button';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-wrapper\" @showHideSidePanel>\r\n      <icon (click)=\"cancelClick.emit($event)\" [icon]=\"icons.Cancel\" class=\"close-button\"></icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <icon [icon]=\"activeCategoryButton.icon\"></icon>\r\n        <span [textContent]=\"activeCategoryButton.title | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-nav-bar\">\r\n        <co-transaction-button-bar\r\n          [selectedCategory]=\"activeCategory\"\r\n          (buttonClicked)=\"updateActiveCategory($event)\"\r\n        ></co-transaction-button-bar>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content\">\r\n        <ng-container [ngSwitch]=\"transactionInfo.transactionKind\">\r\n          <ng-container *ngSwitchCase=\"transactionTypes.PurchaseOrder\">\r\n            <co-transaction-line-side-panel-purchase\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n          <ng-container *ngSwitchCase=\"transactionTypes.SalesOrder\">\r\n            <co-transaction-line-side-panel-sales\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-sales>\r\n          </ng-container>\r\n          <ng-container *ngSwitchDefault>\r\n            <co-transaction-line-side-panel-purchase\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideSidePanel\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly categories: typeof TransactionTypeCategory = TransactionTypeCategory;\r\n  public readonly transactionTypes: typeof TransactionKind = TransactionKind;\r\n\r\n  @Input()\r\n  public transactionLine: TransactionLineInfo;\r\n\r\n  @Input()\r\n  public transactionInfo: TransactionInfo;\r\n\r\n  @Input()\r\n  public activeCategory: TransactionTypeCategory;\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  public activeCategoryButton: TransactionBarButton;\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public iconService: IconCacheService,\r\n    private _service: TransactionService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _transactionMappingService: TransactionMappingService\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.activeCategoryButton = this._transactionMappingService.getButtonBar(this.transactionInfo.transactionKind)\r\n      .find((button) => button.category === this.activeCategory);\r\n  }\r\n\r\n  public updateActiveCategory(button: TransactionBarButton): void {\r\n    this.activeCategory = button.category;\r\n    this.activeCategoryButton = button;\r\n  }\r\n}\r\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-line-side-panel.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-line-side-panel/transaction-line-side-panel.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAE7G,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAC1C,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAC,eAAe,EAAC,MAAM,2DAA2D,CAAC;AAC1F,OAAO,EAAC,uBAAuB,EAAC,MAAM,2CAA2C,CAAC;AAClF,OAAO,EAAC,kBAAkB,EAAC,MAAM,mCAAmC,CAAC;AACrE,OAAO,EAAC,uBAAuB,EAAC,MAAM,yCAAyC,CAAC;AAEhF,OAAO,EAAC,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAC,MAAM,qBAAqB,CAAC;AAC/E,OAAO,EAAC,yBAAyB,EAAC,MAAM,2CAA2C,CAAC;AAsDpF,MAAM,OAAO,iCAAiC;IAwB5C,YACS,WAA6B,EAC5B,QAA4B,EAC5B,wBAAiD,EACjD,0BAAqD;QAHtD,gBAAW,GAAX,WAAW,CAAkB;QAC5B,aAAQ,GAAR,QAAQ,CAAoB;QAC5B,6BAAwB,GAAxB,wBAAwB,CAAyB;QACjD,+BAA0B,GAA1B,0BAA0B,CAA2B;QA3B/C,UAAK,GAAgB,IAAI,CAAC;QAC1B,eAAU,GAAmC,uBAAuB,CAAC;QACrE,qBAAgB,GAA2B,eAAe,CAAC;QAYpE,gBAAW,GAA6B,IAAI,YAAY,EAAc,CAAC;IAe9E,CAAC;IAVM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAUM,QAAQ;QACb,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,0BAA0B,CAAC,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC;aAC3G,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,IAAI,CAAC,cAAc,CAAC,CAAC;IAC/D,CAAC;IAEM,oBAAoB,CAAC,MAA4B;QACtD,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC;QACtC,IAAI,CAAC,oBAAoB,GAAG,MAAM,CAAC;IACrC,CAAC;;;YA3FF,SAAS,SAAC;gBACT,QAAQ,EAAE,gCAAgC;gBAC1C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCT;gBACD,UAAU,EAAE;oBACV,OAAO,CAAC,mBAAmB,EAAE;wBAC3B,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,EAAC,SAAS,EAAE,kBAAkB,EAAC,CAAC,CAAC;wBACrD,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,EAAC,SAAS,EAAE,eAAe,EAAC,CAAC,CAAC;wBAC/C,UAAU,CAAC,YAAY,EAAE,OAAO,CAAC,mBAAmB,CAAC,CAAC;qBACvD,CAAC;iBACH;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA5DO,gBAAgB;YAGhB,kBAAkB;YAClB,uBAAuB;YAGvB,yBAAyB;;;8BA2D9B,KAAK;8BAGL,KAAK;6BAGL,KAAK;0BAGL,MAAM;wBAKN,WAAW,SAAC,sCAAsC","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {TransactionKind} from '@colijnit/transactionapi/build/enum/transaction-kind.enum';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionService} from '../../service/transaction.service';\r\nimport {TransactionEventService} from '../../service/transaction-event.service';\r\nimport {TransactionInfo} from '@colijnit/transactionapi/build/model/transaction-info.bo';\r\nimport {animate, state, style, transition, trigger} from '@angular/animations';\r\nimport {TransactionMappingService} from '../../service/transaction-mapping.service';\r\nimport {TransactionBarButton} from '../../model/transaction-bar-button';\r\n\r\n@Component({\r\n  selector: \"co-transaction-line-side-panel\",\r\n  template: `\r\n    <div class=\"transaction-line-side-panel-wrapper\" @showHideSidePanel>\r\n      <icon (click)=\"cancelClick.emit($event)\" [icon]=\"icons.Cancel\" class=\"close-button\"></icon>\r\n      <div class=\"transaction-line-side-panel-header\">\r\n        <icon [icon]=\"activeCategoryButton.icon\"></icon>\r\n        <span [textContent]=\"activeCategoryButton.title | localize\"></span>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-nav-bar\">\r\n        <co-transaction-button-bar\r\n          [selectedCategory]=\"activeCategory\"\r\n          (buttonClicked)=\"updateActiveCategory($event)\"\r\n        ></co-transaction-button-bar>\r\n      </div>\r\n      <div class=\"transaction-line-side-panel-content co-small-scrollbar\">\r\n        <ng-container [ngSwitch]=\"transactionInfo.transactionKind\">\r\n          <ng-container *ngSwitchCase=\"transactionTypes.PurchaseOrder\">\r\n            <co-transaction-line-side-panel-purchase\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n          <ng-container *ngSwitchCase=\"transactionTypes.SalesOrder\">\r\n            <co-transaction-line-side-panel-sales\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-sales>\r\n          </ng-container>\r\n          <ng-container *ngSwitchDefault>\r\n            <co-transaction-line-side-panel-purchase\r\n              [transactionLine]=\"transactionLine\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [categoryType]=\"activeCategory\"\r\n            ></co-transaction-line-side-panel-purchase>\r\n          </ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  `,\r\n  animations: [\r\n    trigger(\"showHideSidePanel\", [\r\n      state(\"void\", style({transform: \"translateX(100%)\"})),\r\n      state(\"*\", style({transform: \"translateX(0)\"})),\r\n      transition(\"void <=> *\", animate(\"200ms ease-in-out\"))\r\n    ])\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TransactionLineSidePanelComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n  public readonly categories: typeof TransactionTypeCategory = TransactionTypeCategory;\r\n  public readonly transactionTypes: typeof TransactionKind = TransactionKind;\r\n\r\n  @Input()\r\n  public transactionLine: TransactionLineInfo;\r\n\r\n  @Input()\r\n  public transactionInfo: TransactionInfo;\r\n\r\n  @Input()\r\n  public activeCategory: TransactionTypeCategory;\r\n\r\n  @Output()\r\n  public cancelClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  public activeCategoryButton: TransactionBarButton;\r\n\r\n  @HostBinding(\"class.co-transaction-line-side-panel\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  constructor(\r\n    public iconService: IconCacheService,\r\n    private _service: TransactionService,\r\n    private _transactionEventService: TransactionEventService,\r\n    private _transactionMappingService: TransactionMappingService\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    this.activeCategoryButton = this._transactionMappingService.getButtonBar(this.transactionInfo.transactionKind)\r\n      .find((button) => button.category === this.activeCategory);\r\n  }\r\n\r\n  public updateActiveCategory(button: TransactionBarButton): void {\r\n    this.activeCategory = button.category;\r\n    this.activeCategoryButton = button;\r\n  }\r\n}\r\n"]}
@@ -74,7 +74,7 @@ TransactionLinesComponent.decorators = [
74
74
  template: `
75
75
  <div cdkDropListGroup class="drop-list-group">
76
76
  <div #dropList cdkDropList cdkDropListOrientation="vertical"
77
- class="transaction-lines-drag-drop-list narrow-scrollbar"
77
+ class="transaction-lines-drag-drop-list"
78
78
  [cdkDropListDisabled]="preview || userActionRequired || historicTransactionLines !== null"
79
79
  [cdkDropListData]="transactionLines"
80
80
  [cdkDropListEnterPredicate]="handleCanDragDrop"
@@ -134,4 +134,4 @@ TransactionLinesComponent.propDecorators = {
134
134
  saveTransactionLine: [{ type: Output }],
135
135
  showClass: [{ type: HostBinding, args: ["class.co-transaction-lines",] }]
136
136
  };
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-lines.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-lines/transaction-lines.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\nimport {TransactionArticleTextComponent} from '../shared/transaction-article-text/transaction-article-text.component';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {TransactionAddTextLineRequest} from '@colijnit/transactionapi/build/model/transaction-add-text-line-request.bo';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionBaseComponent} from '../core/base/transaction-base.component';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n  selector: \"co-transaction-lines\",\r\n  template: `\r\n    <div cdkDropListGroup class=\"drop-list-group\">\r\n      <div #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n           class=\"transaction-lines-drag-drop-list narrow-scrollbar\"\r\n           [cdkDropListDisabled]=\"preview || userActionRequired || historicTransactionLines !== null\"\r\n           [cdkDropListData]=\"transactionLines\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n        <div class=\"draggable-transaction-line\" *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines); trackBy:trackByFn;\" cdkDrag>\r\n          <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                   [class.show]=\"line === selectedTransactionLine && transactionLines.length > 1\" cdkDragHandle\r\n                   [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n          </co-icon>\r\n          <co-transaction-line\r\n            [transaction]=\"transaction\"\r\n            [transactionInfo]=\"transactionInfo\"\r\n            [transactionLine]=\"line\"\r\n            [activeCategory]=\"activeCategory\"\r\n            [preview]=\"preview\"\r\n            [readonly]=\"historicTransactionLines !== null\"\r\n            [selected]=\"line === selectedTransactionLine\"\r\n            (waitingForUserAction)=\"userActionRequired = $event\"\r\n            (click)=\"selectedTransactionLine = line\"\r\n            (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n          ></co-transaction-line>\r\n        </div>\r\n        <ng-container *ngIf=\"activeCategory === category.SalesOrderDeliveryNote\">\r\n          <div class=\"draggable-transaction-line\" *ngFor=\"let line of deliveryCostLines; trackBy:trackByFn;\" cdkDrag>\r\n            <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                     [class.show]=\"line === selectedTransactionLine\" cdkDragHandle\r\n                     [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n            </co-icon>\r\n            <co-transaction-line\r\n              [transaction]=\"transaction\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [transactionLine]=\"line\"\r\n              [activeCategory]=\"activeCategory\"\r\n              [preview]=\"preview\"\r\n              [readonly]=\"historicTransactionLines !== null\"\r\n              [selected]=\"line === selectedTransactionLine\"\r\n              (waitingForUserAction)=\"userActionRequired = $event\"\r\n              (click)=\"selectedTransactionLine = line\"\r\n              (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n            ></co-transaction-line>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n    <co-button *ngIf=\"!preview && transactionLines.length === 0\" class=\"add-text-button circle\"\r\n               [iconData]=\"iconCacheService.getIcon(icons.TextSolid)\"\r\n               (click)=\"handleTransactionText()\"></co-button>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLinesComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n\r\n  @ViewChild(TransactionArticleTextComponent)\r\n  public transactionArticleText: TransactionArticleTextComponent;\r\n\r\n  @Input()\r\n  public set activeCategory(value: TransactionTypeCategory) {\r\n    this._activeCategory = value;\r\n  }\r\n\r\n  public get activeCategory(): TransactionTypeCategory {\r\n    return this._activeCategory;\r\n  }\r\n\r\n  @Output()\r\n  public saveTransactionLine: EventEmitter<TransactionAddTextLineRequest> = new EventEmitter<TransactionAddTextLineRequest>();\r\n\r\n  @HostBinding(\"class.co-transaction-lines\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public userActionRequired: boolean = false;\r\n  public selectedTransactionLine: TransactionLineInfo;\r\n  public hasComponent: boolean = true;\r\n  public historicTransactionLines: TransactionLineInfo[] | null;\r\n\r\n  private _activeCategory: TransactionTypeCategory = TransactionTypeCategory.SalesOrderOverview;\r\n  private _subscriptions: Subscription[] = [];\r\n\r\n  public ngOnInit(): void {\r\n    this._subscriptions.push(\r\n      this.transactionEventService.historicReportLinesToShow\r\n        .subscribe((lines) => this.historicTransactionLines = lines)\r\n    );\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._subscriptions.forEach((subscription: Subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public trackByFn(index: number, line: TransactionLineInfo): any {\r\n    return line.lineNr;\r\n  }\r\n\r\n  public handleCanDragDrop(drag: CdkDrag, drop: CdkDropList): boolean {\r\n    return drag.data instanceof TransactionLineInfo;\r\n  }\r\n\r\n  public async handleDrop(event: CdkDragDrop<TransactionLineInfo[]>): Promise<void> {\r\n    if (await this.lockTransaction()) {\r\n      try {\r\n        const from: number = event.previousIndex;\r\n        const to: number = event.currentIndex;\r\n        if (from === to) {\r\n          return;\r\n        }\r\n        const beingDropped: TransactionLineInfo = this.transactionLines[from];\r\n        const target: TransactionLineInfo = this.transactionLines[to];\r\n        // set items in correct order\r\n        moveItemInArray(this.transactionLines, from, to);\r\n        this.transactionService.changeLineSequence(beingDropped.uuid, from > to ? target.lineNr : null, from < to ? target.lineNr : null).catch(() => {\r\n          // something went wrong, reset drop\r\n          moveItemInArray(this.transactionLines, to, from);\r\n        });\r\n      } catch (e) {\r\n        console.error(e);\r\n      }\r\n    }\r\n  }\r\n\r\n  public onDescriptionDblClick(line: TransactionLineInfo): void {\r\n    this.transactionEventService.editTransactionText.next(line);\r\n  }\r\n\r\n  public handleTransactionText(): void {\r\n    this.transactionEventService.addTransactionText.next(this.transactionLine);\r\n  }\r\n}\r\n\r\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"transaction-lines.component.js","sourceRoot":"","sources":["../../../../../../projects/transaction/src/lib/component/transaction-lines/transaction-lines.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\nimport {TransactionArticleTextComponent} from '../shared/transaction-article-text/transaction-article-text.component';\r\nimport {TransactionLineInfo} from '@colijnit/transactionapi/build/model/transaction-line-info.bo';\r\nimport {TransactionAddTextLineRequest} from '@colijnit/transactionapi/build/model/transaction-add-text-line-request.bo';\r\nimport {TransactionTypeCategory} from '../../enum/transaction-type-category.enum';\r\nimport {TransactionBaseComponent} from '../core/base/transaction-base.component';\r\nimport {Subscription} from 'rxjs';\r\n\r\n@Component({\r\n  selector: \"co-transaction-lines\",\r\n  template: `\r\n    <div cdkDropListGroup class=\"drop-list-group\">\r\n      <div #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n           class=\"transaction-lines-drag-drop-list\"\r\n           [cdkDropListDisabled]=\"preview || userActionRequired || historicTransactionLines !== null\"\r\n           [cdkDropListData]=\"transactionLines\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n        <div class=\"draggable-transaction-line\" *ngFor=\"let line of (historicTransactionLines ? historicTransactionLines : transactionLines); trackBy:trackByFn;\" cdkDrag>\r\n          <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                   [class.show]=\"line === selectedTransactionLine && transactionLines.length > 1\" cdkDragHandle\r\n                   [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n          </co-icon>\r\n          <co-transaction-line\r\n            [transaction]=\"transaction\"\r\n            [transactionInfo]=\"transactionInfo\"\r\n            [transactionLine]=\"line\"\r\n            [activeCategory]=\"activeCategory\"\r\n            [preview]=\"preview\"\r\n            [readonly]=\"historicTransactionLines !== null\"\r\n            [selected]=\"line === selectedTransactionLine\"\r\n            (waitingForUserAction)=\"userActionRequired = $event\"\r\n            (click)=\"selectedTransactionLine = line\"\r\n            (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n          ></co-transaction-line>\r\n        </div>\r\n        <ng-container *ngIf=\"activeCategory === category.SalesOrderDeliveryNote\">\r\n          <div class=\"draggable-transaction-line\" *ngFor=\"let line of deliveryCostLines; trackBy:trackByFn;\" cdkDrag>\r\n            <co-icon *ngIf=\"!preview\" class=\"transaction-line-drag-handle\"\r\n                     [class.show]=\"line === selectedTransactionLine\" cdkDragHandle\r\n                     [iconData]=\"iconCacheService.getIcon(icons.GripDotsVerticalSolid)\">\r\n            </co-icon>\r\n            <co-transaction-line\r\n              [transaction]=\"transaction\"\r\n              [transactionInfo]=\"transactionInfo\"\r\n              [transactionLine]=\"line\"\r\n              [activeCategory]=\"activeCategory\"\r\n              [preview]=\"preview\"\r\n              [readonly]=\"historicTransactionLines !== null\"\r\n              [selected]=\"line === selectedTransactionLine\"\r\n              (waitingForUserAction)=\"userActionRequired = $event\"\r\n              (click)=\"selectedTransactionLine = line\"\r\n              (descriptionDblClick)=\"onDescriptionDblClick(line)\"\r\n            ></co-transaction-line>\r\n          </div>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n    <co-button *ngIf=\"!preview && transactionLines.length === 0\" class=\"add-text-button circle\"\r\n               [iconData]=\"iconCacheService.getIcon(icons.TextSolid)\"\r\n               (click)=\"handleTransactionText()\"></co-button>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class TransactionLinesComponent extends TransactionBaseComponent implements OnInit, OnDestroy {\r\n\r\n  @ViewChild(TransactionArticleTextComponent)\r\n  public transactionArticleText: TransactionArticleTextComponent;\r\n\r\n  @Input()\r\n  public set activeCategory(value: TransactionTypeCategory) {\r\n    this._activeCategory = value;\r\n  }\r\n\r\n  public get activeCategory(): TransactionTypeCategory {\r\n    return this._activeCategory;\r\n  }\r\n\r\n  @Output()\r\n  public saveTransactionLine: EventEmitter<TransactionAddTextLineRequest> = new EventEmitter<TransactionAddTextLineRequest>();\r\n\r\n  @HostBinding(\"class.co-transaction-lines\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  public userActionRequired: boolean = false;\r\n  public selectedTransactionLine: TransactionLineInfo;\r\n  public hasComponent: boolean = true;\r\n  public historicTransactionLines: TransactionLineInfo[] | null;\r\n\r\n  private _activeCategory: TransactionTypeCategory = TransactionTypeCategory.SalesOrderOverview;\r\n  private _subscriptions: Subscription[] = [];\r\n\r\n  public ngOnInit(): void {\r\n    this._subscriptions.push(\r\n      this.transactionEventService.historicReportLinesToShow\r\n        .subscribe((lines) => this.historicTransactionLines = lines)\r\n    );\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    super.ngOnDestroy();\r\n    this._subscriptions.forEach((subscription: Subscription) => subscription.unsubscribe());\r\n  }\r\n\r\n  public trackByFn(index: number, line: TransactionLineInfo): any {\r\n    return line.lineNr;\r\n  }\r\n\r\n  public handleCanDragDrop(drag: CdkDrag, drop: CdkDropList): boolean {\r\n    return drag.data instanceof TransactionLineInfo;\r\n  }\r\n\r\n  public async handleDrop(event: CdkDragDrop<TransactionLineInfo[]>): Promise<void> {\r\n    if (await this.lockTransaction()) {\r\n      try {\r\n        const from: number = event.previousIndex;\r\n        const to: number = event.currentIndex;\r\n        if (from === to) {\r\n          return;\r\n        }\r\n        const beingDropped: TransactionLineInfo = this.transactionLines[from];\r\n        const target: TransactionLineInfo = this.transactionLines[to];\r\n        // set items in correct order\r\n        moveItemInArray(this.transactionLines, from, to);\r\n        this.transactionService.changeLineSequence(beingDropped.uuid, from > to ? target.lineNr : null, from < to ? target.lineNr : null).catch(() => {\r\n          // something went wrong, reset drop\r\n          moveItemInArray(this.transactionLines, to, from);\r\n        });\r\n      } catch (e) {\r\n        console.error(e);\r\n      }\r\n    }\r\n  }\r\n\r\n  public onDescriptionDblClick(line: TransactionLineInfo): void {\r\n    this.transactionEventService.editTransactionText.next(line);\r\n  }\r\n\r\n  public handleTransactionText(): void {\r\n    this.transactionEventService.addTransactionText.next(this.transactionLine);\r\n  }\r\n}\r\n\r\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tc3VnZ2VzdGlvbnMtcmVxdWVzdC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90cmFuc2FjdGlvbi9zcmMvbGliL2ludGVyZmFjZS9yZWxhdGlvbi1zdWdnZXN0aW9ucy1yZXF1ZXN0LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBSZWxhdGlvblN1Z2dlc3Rpb25zUmVxdWVzdCB7XHJcbiAgICBmaXJzdE5hbWU/OiBzdHJpbmc7XHJcbiAgICBmYW1pbHlOYW1lPzogc3RyaW5nO1xyXG4gICAgZ2VuZXJhbD86IHN0cmluZztcclxuICAgIHBob25lPzogc3RyaW5nO1xyXG4gICAgZW1haWw/OiBzdHJpbmc7XHJcbiAgICBjb3VudHJ5Pzogc3RyaW5nO1xyXG4gICAgcG9zdGFsQ29kZT86IHN0cmluZztcclxuICAgIGhvdXNlTnI/OiBudW1iZXI7XHJcbiAgICBob3VzZU5yQWRkaXRpb24/OiBzdHJpbmc7XHJcbiAgICBzdHJlZXQ/OiBzdHJpbmc7XHJcbiAgICBjaXR5Pzogc3RyaW5nO1xyXG59XHJcbiJdfQ==