@colijnit/relation 12.1.1

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 (188) hide show
  1. package/README.md +24 -0
  2. package/bundles/colijnit-relation.umd.js +4832 -0
  3. package/bundles/colijnit-relation.umd.js.map +1 -0
  4. package/colijnit-relation.d.ts +21 -0
  5. package/colijnit-relation.metadata.json +1 -0
  6. package/esm2015/colijnit-relation.js +22 -0
  7. package/esm2015/lib/component/base/relation-base.component.js +52 -0
  8. package/esm2015/lib/component/base/relation-loader.component.js +50 -0
  9. package/esm2015/lib/component/base/relation-screen-config-base.component.js +16 -0
  10. package/esm2015/lib/component/relation/relation.component.js +100 -0
  11. package/esm2015/lib/component/relation/relation.module.js +58 -0
  12. package/esm2015/lib/component/relation-address/relation-address.component.js +166 -0
  13. package/esm2015/lib/component/relation-address/relation-address.module.js +24 -0
  14. package/esm2015/lib/component/relation-address-tile/relation-address-tile.component.js +72 -0
  15. package/esm2015/lib/component/relation-address-tile/relation-address-tile.module.js +25 -0
  16. package/esm2015/lib/component/relation-addresses/relation-addresses.component.js +158 -0
  17. package/esm2015/lib/component/relation-addresses/relation-addresses.module.js +31 -0
  18. package/esm2015/lib/component/relation-avatar/relation-avatar.component.js +222 -0
  19. package/esm2015/lib/component/relation-avatar/relation-avatar.module.js +22 -0
  20. package/esm2015/lib/component/relation-contact-options/relation-contact-option-list.component.js +101 -0
  21. package/esm2015/lib/component/relation-contact-options/relation-contact-option.component.js +100 -0
  22. package/esm2015/lib/component/relation-contact-options/relation-contact-options-other-types-popup.component.js +44 -0
  23. package/esm2015/lib/component/relation-contact-options/relation-contact-options.component.js +154 -0
  24. package/esm2015/lib/component/relation-contact-options/relation-contact-options.module.js +34 -0
  25. package/esm2015/lib/component/relation-first-name/relation-first-name.component.js +25 -0
  26. package/esm2015/lib/component/relation-first-name/relation-first-name.module.js +24 -0
  27. package/esm2015/lib/component/relation-gender/relation-gender.component.js +45 -0
  28. package/esm2015/lib/component/relation-gender/relation-gender.module.js +23 -0
  29. package/esm2015/lib/component/relation-initials/relation-initials.component.js +24 -0
  30. package/esm2015/lib/component/relation-initials/relation-initials.module.js +24 -0
  31. package/esm2015/lib/component/relation-language/relation-language.component.js +56 -0
  32. package/esm2015/lib/component/relation-language/relation-language.module.js +24 -0
  33. package/esm2015/lib/component/relation-last-name/relation-last-name.component.js +23 -0
  34. package/esm2015/lib/component/relation-last-name/relation-last-name.module.js +24 -0
  35. package/esm2015/lib/component/relation-preferences/relation-preferences.component.js +69 -0
  36. package/esm2015/lib/component/relation-preferences/relation-preferences.module.js +23 -0
  37. package/esm2015/lib/component/relation-prefix-name/relation-prefix-name.component.js +24 -0
  38. package/esm2015/lib/component/relation-prefix-name/relation-prefix-name.module.js +24 -0
  39. package/esm2015/lib/component/relation-title/relation-title.component.js +56 -0
  40. package/esm2015/lib/component/relation-title/relation-title.module.js +24 -0
  41. package/esm2015/lib/enum/icon.enum.js +16 -0
  42. package/esm2015/lib/enum/language-code.enum.js +8 -0
  43. package/esm2015/lib/enum/relman-cfg-name.enum.js +862 -0
  44. package/esm2015/lib/enum/relman-contact-options-cfg-names.js +2 -0
  45. package/esm2015/lib/enum/relman-sub-category.enum.js +13 -0
  46. package/esm2015/lib/interface/relation-address-cfg-names.interface.js +2 -0
  47. package/esm2015/lib/model/icon-svg.js +15 -0
  48. package/esm2015/lib/model/relation-settings-options.js +7 -0
  49. package/esm2015/lib/model/relation-settings.js +9 -0
  50. package/esm2015/lib/relation-version.js +10 -0
  51. package/esm2015/lib/res/dictionary/dictionaries.js +9 -0
  52. package/esm2015/lib/service/dictionary.service.js +68 -0
  53. package/esm2015/lib/service/error.service.js +75 -0
  54. package/esm2015/lib/service/icon-cache.service.js +51 -0
  55. package/esm2015/lib/service/relation-base.service.js +268 -0
  56. package/esm2015/lib/service/relation-connector-adapter.service.js +401 -0
  57. package/esm2015/lib/service/relation-connector.service.js +155 -0
  58. package/esm2015/lib/service/relation-event.service.js +16 -0
  59. package/esm2015/lib/service/relation-screen-configuration.service.js +51 -0
  60. package/esm2015/lib/service/relation-settings.service.js +65 -0
  61. package/esm2015/lib/service/relation.service.js +42 -0
  62. package/esm2015/lib/translation/relation-dictionary.service.js +77 -0
  63. package/esm2015/lib/translation/relation-localize.pipe.js +26 -0
  64. package/esm2015/lib/translation/relation-translation.module.js +29 -0
  65. package/esm2015/lib/translation/relation-translation.service.js +17 -0
  66. package/esm2015/public_api.js +33 -0
  67. package/fesm2015/colijnit-relation.js +3980 -0
  68. package/fesm2015/colijnit-relation.js.map +1 -0
  69. package/lib/component/base/relation-base.component.d.ts +24 -0
  70. package/lib/component/base/relation-loader.component.d.ts +12 -0
  71. package/lib/component/base/relation-screen-config-base.component.d.ts +14 -0
  72. package/lib/component/relation/relation.component.d.ts +21 -0
  73. package/lib/component/relation/relation.module.d.ts +2 -0
  74. package/lib/component/relation/style/_layout.scss +46 -0
  75. package/lib/component/relation/style/_material-definition.scss +15 -0
  76. package/lib/component/relation/style/_theme.scss +12 -0
  77. package/lib/component/relation/style/material.scss +4 -0
  78. package/lib/component/relation-address/relation-address.component.d.ts +35 -0
  79. package/lib/component/relation-address/relation-address.module.d.ts +2 -0
  80. package/lib/component/relation-address/style/_layout.scss +16 -0
  81. package/lib/component/relation-address/style/_material-definition.scss +5 -0
  82. package/lib/component/relation-address/style/_theme.scss +5 -0
  83. package/lib/component/relation-address/style/material.scss +4 -0
  84. package/lib/component/relation-address-tile/relation-address-tile.component.d.ts +19 -0
  85. package/lib/component/relation-address-tile/relation-address-tile.module.d.ts +2 -0
  86. package/lib/component/relation-address-tile/style/_layout.scss +46 -0
  87. package/lib/component/relation-address-tile/style/_material-definition.scss +18 -0
  88. package/lib/component/relation-address-tile/style/_theme.scss +19 -0
  89. package/lib/component/relation-address-tile/style/material.scss +4 -0
  90. package/lib/component/relation-addresses/relation-addresses.component.d.ts +31 -0
  91. package/lib/component/relation-addresses/relation-addresses.module.d.ts +2 -0
  92. package/lib/component/relation-addresses/style/_layout.scss +26 -0
  93. package/lib/component/relation-addresses/style/_material-definition.scss +12 -0
  94. package/lib/component/relation-addresses/style/_theme.scss +20 -0
  95. package/lib/component/relation-addresses/style/material.scss +4 -0
  96. package/lib/component/relation-avatar/relation-avatar.component.d.ts +47 -0
  97. package/lib/component/relation-avatar/relation-avatar.module.d.ts +2 -0
  98. package/lib/component/relation-avatar/style/_layout.scss +44 -0
  99. package/lib/component/relation-avatar/style/_material-definition.scss +4 -0
  100. package/lib/component/relation-avatar/style/_theme.scss +9 -0
  101. package/lib/component/relation-avatar/style/material.scss +4 -0
  102. package/lib/component/relation-contact-options/relation-contact-option-list.component.d.ts +22 -0
  103. package/lib/component/relation-contact-options/relation-contact-option.component.d.ts +30 -0
  104. package/lib/component/relation-contact-options/relation-contact-options-other-types-popup.component.d.ts +22 -0
  105. package/lib/component/relation-contact-options/relation-contact-options.component.d.ts +40 -0
  106. package/lib/component/relation-contact-options/relation-contact-options.module.d.ts +2 -0
  107. package/lib/component/relation-contact-options/style/_layout.scss +113 -0
  108. package/lib/component/relation-contact-options/style/_material-definition.scss +35 -0
  109. package/lib/component/relation-contact-options/style/_theme.scss +48 -0
  110. package/lib/component/relation-contact-options/style/material.scss +4 -0
  111. package/lib/component/relation-first-name/relation-first-name.component.d.ts +4 -0
  112. package/lib/component/relation-first-name/relation-first-name.module.d.ts +2 -0
  113. package/lib/component/relation-first-name/style/_layout.scss +9 -0
  114. package/lib/component/relation-first-name/style/_material-definition.scss +3 -0
  115. package/lib/component/relation-first-name/style/_theme.scss +5 -0
  116. package/lib/component/relation-first-name/style/material.scss +4 -0
  117. package/lib/component/relation-gender/relation-gender.component.d.ts +7 -0
  118. package/lib/component/relation-gender/relation-gender.module.d.ts +2 -0
  119. package/lib/component/relation-gender/style/_layout.scss +8 -0
  120. package/lib/component/relation-gender/style/_material-definition.scss +4 -0
  121. package/lib/component/relation-gender/style/_theme.scss +5 -0
  122. package/lib/component/relation-gender/style/material.scss +4 -0
  123. package/lib/component/relation-initials/relation-initials.component.d.ts +4 -0
  124. package/lib/component/relation-initials/relation-initials.module.d.ts +2 -0
  125. package/lib/component/relation-initials/style/_layout.scss +9 -0
  126. package/lib/component/relation-initials/style/_material-definition.scss +3 -0
  127. package/lib/component/relation-initials/style/_theme.scss +5 -0
  128. package/lib/component/relation-initials/style/material.scss +4 -0
  129. package/lib/component/relation-language/relation-language.component.d.ts +12 -0
  130. package/lib/component/relation-language/relation-language.module.d.ts +2 -0
  131. package/lib/component/relation-language/style/_layout.scss +9 -0
  132. package/lib/component/relation-language/style/_material-definition.scss +3 -0
  133. package/lib/component/relation-language/style/_theme.scss +5 -0
  134. package/lib/component/relation-language/style/material.scss +4 -0
  135. package/lib/component/relation-last-name/relation-last-name.component.d.ts +4 -0
  136. package/lib/component/relation-last-name/relation-last-name.module.d.ts +2 -0
  137. package/lib/component/relation-last-name/style/_layout.scss +9 -0
  138. package/lib/component/relation-last-name/style/_material-definition.scss +3 -0
  139. package/lib/component/relation-last-name/style/_theme.scss +5 -0
  140. package/lib/component/relation-last-name/style/material.scss +4 -0
  141. package/lib/component/relation-preferences/relation-preferences.component.d.ts +13 -0
  142. package/lib/component/relation-preferences/relation-preferences.module.d.ts +2 -0
  143. package/lib/component/relation-preferences/style/_layout.scss +16 -0
  144. package/lib/component/relation-preferences/style/_material-definition.scss +8 -0
  145. package/lib/component/relation-preferences/style/_theme.scss +5 -0
  146. package/lib/component/relation-preferences/style/material.scss +4 -0
  147. package/lib/component/relation-prefix-name/relation-prefix-name.component.d.ts +4 -0
  148. package/lib/component/relation-prefix-name/relation-prefix-name.module.d.ts +2 -0
  149. package/lib/component/relation-prefix-name/style/_layout.scss +9 -0
  150. package/lib/component/relation-prefix-name/style/_material-definition.scss +3 -0
  151. package/lib/component/relation-prefix-name/style/_theme.scss +5 -0
  152. package/lib/component/relation-prefix-name/style/material.scss +4 -0
  153. package/lib/component/relation-title/relation-title.component.d.ts +13 -0
  154. package/lib/component/relation-title/relation-title.module.d.ts +2 -0
  155. package/lib/component/relation-title/style/_layout.scss +9 -0
  156. package/lib/component/relation-title/style/_material-definition.scss +3 -0
  157. package/lib/component/relation-title/style/_theme.scss +5 -0
  158. package/lib/component/relation-title/style/material.scss +4 -0
  159. package/lib/enum/icon.enum.d.ts +14 -0
  160. package/lib/enum/language-code.enum.d.ts +6 -0
  161. package/lib/enum/relman-cfg-name.enum.d.ts +857 -0
  162. package/lib/enum/relman-contact-options-cfg-names.d.ts +6 -0
  163. package/lib/enum/relman-sub-category.enum.d.ts +10 -0
  164. package/lib/interface/relation-address-cfg-names.interface.d.ts +8 -0
  165. package/lib/model/icon-svg.d.ts +4 -0
  166. package/lib/model/relation-settings-options.d.ts +4 -0
  167. package/lib/model/relation-settings.d.ts +5 -0
  168. package/lib/relation-version.d.ts +6 -0
  169. package/lib/res/dictionary/dictionaries.d.ts +17184 -0
  170. package/lib/service/dictionary.service.d.ts +18 -0
  171. package/lib/service/error.service.d.ts +11 -0
  172. package/lib/service/icon-cache.service.d.ts +18 -0
  173. package/lib/service/relation-base.service.d.ts +64 -0
  174. package/lib/service/relation-connector-adapter.service.d.ts +66 -0
  175. package/lib/service/relation-connector.service.d.ts +51 -0
  176. package/lib/service/relation-event.service.d.ts +6 -0
  177. package/lib/service/relation-screen-configuration.service.d.ts +13 -0
  178. package/lib/service/relation-settings.service.d.ts +16 -0
  179. package/lib/service/relation.service.d.ts +10 -0
  180. package/lib/style/_mixin.scss +15 -0
  181. package/lib/style/_variables.scss +15 -0
  182. package/lib/style/relation-globals.scss +7 -0
  183. package/lib/translation/relation-dictionary.service.d.ts +19 -0
  184. package/lib/translation/relation-localize.pipe.d.ts +7 -0
  185. package/lib/translation/relation-translation.module.d.ts +4 -0
  186. package/lib/translation/relation-translation.service.d.ts +6 -0
  187. package/package.json +30 -0
  188. package/public_api.d.ts +32 -0
@@ -0,0 +1,222 @@
1
+ import { __awaiter } from "tslib";
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
3
+ import { RelationConnectorService } from '../../service/relation-connector.service';
4
+ import { ColorSequenceService, CoreDialogService } from '@colijnit/corecomponents_v12';
5
+ import { FileUtils } from '@colijnit/mainapi/build/utils/file-utils';
6
+ import { StringUtils } from '@colijnit/ioneconnector/build/utils/string-utils';
7
+ import { CoDocumentImageDisplayKind } from '@colijnit/mainapi/build/enum/co-document-image-display-kind.enum';
8
+ import { IconCacheService } from '../../service/icon-cache.service';
9
+ import { Icon } from '../../enum/icon.enum';
10
+ export class RelationAvatarComponent {
11
+ constructor(iconCacheService, _relationConnectorService, _colorSequenceService, _changeDetector, _dialogService) {
12
+ this.iconCacheService = iconCacheService;
13
+ this._relationConnectorService = _relationConnectorService;
14
+ this._colorSequenceService = _colorSequenceService;
15
+ this._changeDetector = _changeDetector;
16
+ this._dialogService = _dialogService;
17
+ this.icons = Icon;
18
+ this.canChangeAvatar = false;
19
+ this.maxUploadSizeInMb = 3;
20
+ this.maxAvatarSize = 200;
21
+ }
22
+ set image(value) {
23
+ this._image = value;
24
+ this._setImageForAvatar();
25
+ }
26
+ get image() {
27
+ return this._image;
28
+ }
29
+ set relationId(value) {
30
+ if (this.relationId !== value) {
31
+ this._image = undefined;
32
+ this._relation = undefined;
33
+ this._relationId = value;
34
+ this._setImageForAvatar();
35
+ }
36
+ }
37
+ get relationId() {
38
+ return this._relationId;
39
+ }
40
+ set relation(value) {
41
+ if (!this._relation || (this._relation && value && this._relation.relationId !== value.relationId)) {
42
+ this._image = undefined;
43
+ this._relationId = undefined;
44
+ this._relation = value;
45
+ this._setImageForAvatar();
46
+ }
47
+ }
48
+ get relation() {
49
+ return this._relation;
50
+ }
51
+ showClass() {
52
+ return true;
53
+ }
54
+ onClick() {
55
+ this.uploadTheAvatar();
56
+ }
57
+ set initials(value) {
58
+ this._initials = value;
59
+ this._setBackgroundColor();
60
+ }
61
+ get initials() {
62
+ return this._initials;
63
+ }
64
+ ngOnInit() {
65
+ this._setImageForAvatar();
66
+ }
67
+ ngOnDestroy() {
68
+ this.input = undefined;
69
+ }
70
+ uploadTheAvatar() {
71
+ if (this.canChangeAvatar && this.input) {
72
+ this.input.nativeElement.click();
73
+ }
74
+ }
75
+ // Take File from event and save it internally as a CoDocument.
76
+ onFileChangeEvent(event) {
77
+ if (event && event.target && event.target.files && event.target.files.length > 0) {
78
+ const fileToUpload = event.target.files[0];
79
+ if (!FileUtils.CheckMaxUploadSize(fileToUpload)) {
80
+ this._dialogService.showWarning(StringUtils.Format("File is to large to upload. Maximum file size is {0} Mb", [this.maxUploadSizeInMb]));
81
+ }
82
+ else if (!FileUtils.IsImageFile(fileToUpload)) {
83
+ this._dialogService.showWarning("Please select an image");
84
+ }
85
+ else {
86
+ this._setFileAsAvatarToCurrentRelation(fileToUpload);
87
+ }
88
+ if (this.input && this.input.nativeElement) {
89
+ this.input.nativeElement.value = null;
90
+ }
91
+ }
92
+ }
93
+ _setFileAsAvatarToCurrentRelation(file) {
94
+ return __awaiter(this, void 0, void 0, function* () {
95
+ const document = yield FileUtils.ReadFileAsNewCoDocument(file, true, this.maxAvatarSize);
96
+ yield this.setDocProperties(document);
97
+ });
98
+ }
99
+ setDocProperties(document) {
100
+ return __awaiter(this, void 0, void 0, function* () {
101
+ document.thumbnailBody = document.documentBody;
102
+ document.creationDate = new Date();
103
+ document.creationUser = this._relationConnectorService.loginResponse.userName;
104
+ document.imageDisplayKind = CoDocumentImageDisplayKind.Avatar;
105
+ if (this._relation) {
106
+ this._relation.avatarImage = document;
107
+ }
108
+ this.imageSrc = document.thumbnailBodyAsDataUri;
109
+ this._changeDetector.detectChanges();
110
+ });
111
+ }
112
+ _setImageForAvatar() {
113
+ return __awaiter(this, void 0, void 0, function* () {
114
+ if (this.image && this.image.documentId) {
115
+ if (!(yield this._getImageContent(this.image.documentId))) {
116
+ this._setImageFromRelation();
117
+ }
118
+ }
119
+ else {
120
+ this._setImageFromRelation();
121
+ }
122
+ this._changeDetector.detectChanges();
123
+ });
124
+ }
125
+ _setImageFromRelation() {
126
+ return __awaiter(this, void 0, void 0, function* () {
127
+ if (this.relation) {
128
+ if (this.relation.avatarImage && this.relation.avatarImage.documentId) {
129
+ this._image = this.relation.avatarImage;
130
+ if (!(yield this._getImageContent(this.image.documentId))) {
131
+ this._setRelationInitials();
132
+ }
133
+ }
134
+ else {
135
+ this._setRelationInitials();
136
+ }
137
+ }
138
+ else if (this.relationId) {
139
+ this._relationConnectorService.getRelationSmallObject(this.relationId).then((relationSmallObject) => __awaiter(this, void 0, void 0, function* () {
140
+ if (relationSmallObject) {
141
+ if (relationSmallObject.avatarImage && relationSmallObject.avatarImage.documentId) {
142
+ this._image = relationSmallObject.avatarImage;
143
+ if (!(yield this._getImageContent(this.image.documentId))) {
144
+ this._setRelationInitials();
145
+ }
146
+ }
147
+ else {
148
+ this._setRelationInitials();
149
+ }
150
+ }
151
+ }));
152
+ }
153
+ });
154
+ }
155
+ _setRelationInitials() {
156
+ if (this.relation) {
157
+ this.initials = this.relation.displayInitials;
158
+ }
159
+ }
160
+ _getImageContent(docId) {
161
+ return __awaiter(this, void 0, void 0, function* () {
162
+ const content = yield this._relationConnectorService.getDocumentContent(docId);
163
+ if (content && this._image) {
164
+ this._image.thumbnailBody = content;
165
+ this.imageSrc = this.image.thumbnailBodyAsDataUri;
166
+ this._changeDetector.detectChanges();
167
+ return true;
168
+ }
169
+ else {
170
+ return false;
171
+ }
172
+ });
173
+ }
174
+ _setBackgroundColor() {
175
+ this.imageSrc = "";
176
+ if (this.relation) {
177
+ this.backgroundColor = this._colorSequenceService.getRandomColor(this.relation.relationId);
178
+ }
179
+ this._changeDetector.detectChanges();
180
+ }
181
+ }
182
+ RelationAvatarComponent.decorators = [
183
+ { type: Component, args: [{
184
+ selector: 'co-relation-avatar',
185
+ template: `
186
+ <co-image [source]="imageSrc" *ngIf="imageSrc; else showInitials"></co-image>
187
+ <ng-template #showInitials>
188
+ <svg viewBox="0 0 30 30">
189
+ <text x="50%" y="50%" dominant-baseline="central" text-anchor="middle">{{ initials }}</text>
190
+ </svg>
191
+ </ng-template>
192
+ <ng-container *ngIf="canChangeAvatar">
193
+ <div class="relation-avatar-pencil-wrapper">
194
+ <co-icon [iconData]="iconCacheService.getIcon(icons.PencilRoundOpen)" class="pencil-icon"></co-icon>
195
+ </div>
196
+ <input #uploadAvatar class="value-text" type="file" (change)="onFileChangeEvent($event)" accept=".jpg, .png, .jpeg">
197
+ </ng-container>
198
+ `,
199
+ changeDetection: ChangeDetectionStrategy.OnPush,
200
+ encapsulation: ViewEncapsulation.None
201
+ },] }
202
+ ];
203
+ RelationAvatarComponent.ctorParameters = () => [
204
+ { type: IconCacheService },
205
+ { type: RelationConnectorService },
206
+ { type: ColorSequenceService },
207
+ { type: ChangeDetectorRef },
208
+ { type: CoreDialogService }
209
+ ];
210
+ RelationAvatarComponent.propDecorators = {
211
+ input: [{ type: ViewChild, args: ["uploadAvatar",] }],
212
+ image: [{ type: Input }],
213
+ relationId: [{ type: Input }],
214
+ relation: [{ type: Input }],
215
+ canChangeAvatar: [{ type: Input }, { type: HostBinding, args: ["class.can-change",] }],
216
+ maxUploadSizeInMb: [{ type: Input }],
217
+ maxAvatarSize: [{ type: Input }],
218
+ showClass: [{ type: HostBinding, args: ['class.co-relation-avatar',] }],
219
+ backgroundColor: [{ type: HostBinding, args: ["style.background-color",] }],
220
+ onClick: [{ type: HostListener, args: ["click",] }]
221
+ };
222
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-avatar/relation-avatar.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,YAAY,EACZ,KAAK,EACG,SAAS,EACjB,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAC,wBAAwB,EAAC,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAC,oBAAoB,EAAE,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AAGrF,OAAO,EAAC,SAAS,EAAC,MAAM,0CAA0C,CAAC;AACnE,OAAO,EAAC,WAAW,EAAC,MAAM,kDAAkD,CAAC;AAC7E,OAAO,EAAC,0BAA0B,EAAC,MAAM,kEAAkE,CAAC;AAC5G,OAAO,EAAC,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAC,IAAI,EAAC,MAAM,sBAAsB,CAAC;AAqB1C,MAAM,OAAO,uBAAuB;IAkFlC,YACS,gBAAkC,EACjC,yBAAmD,EACnD,qBAA2C,EAC3C,eAAkC,EAClC,cAAiC;QAJlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QACjC,8BAAyB,GAAzB,yBAAyB,CAA0B;QACnD,0BAAqB,GAArB,qBAAqB,CAAsB;QAC3C,oBAAe,GAAf,eAAe,CAAmB;QAClC,mBAAc,GAAd,cAAc,CAAmB;QAtF3B,UAAK,GAAgB,IAAI,CAAC;QA4CnC,oBAAe,GAAY,KAAK,CAAC;QAGjC,sBAAiB,GAAW,CAAC,CAAC;QAG9B,kBAAa,GAAW,GAAG,CAAC;IAsCnC,CAAC;IAnFD,IACW,KAAK,CAAC,KAAiB;QAChC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED,IACW,UAAU,CAAC,KAAa;QACjC,IAAI,IAAI,CAAC,UAAU,KAAK,KAAK,EAAE;YAC7B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;YACxB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IACW,QAAQ,CAAC,KAAsB;QACxC,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,UAAU,KAAK,KAAK,CAAC,UAAU,CAAC,EAAE;YAClG,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;YACxB,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;YAC7B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAYM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAQM,OAAO;QACZ,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAED,IAAW,QAAQ,CAAC,KAAa;QAC/B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAgBD,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,KAAK,GAAG,SAAS,CAAC;IACzB,CAAC;IAEM,eAAe;QACpB,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,KAAK,EAAE;YACtC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAClC;IACH,CAAC;IAED,+DAA+D;IACxD,iBAAiB,CAAC,KAAU;QACjC,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAChF,MAAM,YAAY,GAAS,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,CAAC,SAAS,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,WAAW,CAAC,MAAM,CAChD,yDAAyD,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;aACzF;iBAAM,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,YAAY,CAAC,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,wBAAwB,CAAC,CAAC;aAC3D;iBAAM;gBACL,IAAI,CAAC,iCAAiC,CAAC,YAAY,CAAC,CAAC;aACtD;YACD,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;gBAC1C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC;aACvC;SACF;IACH,CAAC;IAEa,iCAAiC,CAAC,IAAU;;YACxD,MAAM,QAAQ,GAAe,MAAM,SAAS,CAAC,uBAAuB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;YACrG,MAAM,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;QACxC,CAAC;KAAA;IAEa,gBAAgB,CAAC,QAAoB;;YACjD,QAAQ,CAAC,aAAa,GAAG,QAAQ,CAAC,YAAY,CAAC;YAC/C,QAAQ,CAAC,YAAY,GAAG,IAAI,IAAI,EAAE,CAAC;YACnC,QAAQ,CAAC,YAAY,GAAG,IAAI,CAAC,yBAAyB,CAAC,aAAa,CAAC,QAAQ,CAAC;YAC9E,QAAQ,CAAC,gBAAgB,GAAG,0BAA0B,CAAC,MAAM,CAAC;YAC9D,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,SAAS,CAAC,WAAW,GAAG,QAAQ,CAAC;aACvC;YACD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,CAAC;YAChD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC;KAAA;IAEa,kBAAkB;;YAC9B,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE;gBACvC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;oBACvD,IAAI,CAAC,qBAAqB,EAAE,CAAC;iBAC9B;aACF;iBAAM;gBACL,IAAI,CAAC,qBAAqB,EAAE,CAAC;aAC9B;YACD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;QACvC,CAAC;KAAA;IAEa,qBAAqB;;YACjC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,UAAU,EAAE;oBACrE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC;oBACxC,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;wBACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;qBAC7B;iBACF;qBAAM;oBACL,IAAI,CAAC,oBAAoB,EAAE,CAAC;iBAC7B;aACF;iBAAM,IAAI,IAAI,CAAC,UAAU,EAAE;gBAC1B,IAAI,CAAC,yBAAyB,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,CAAO,mBAAwC,EAAE,EAAE;oBAC7H,IAAI,mBAAmB,EAAE;wBACvB,IAAI,mBAAmB,CAAC,WAAW,IAAI,mBAAmB,CAAC,WAAW,CAAC,UAAU,EAAE;4BACjF,IAAI,CAAC,MAAM,GAAG,mBAAmB,CAAC,WAAW,CAAC;4BAC9C,IAAI,CAAC,CAAA,MAAM,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAA,EAAE;gCACvD,IAAI,CAAC,oBAAoB,EAAE,CAAC;6BAC7B;yBACF;6BAAM;4BACL,IAAI,CAAC,oBAAoB,EAAE,CAAC;yBAC7B;qBACF;gBACH,CAAC,CAAA,CAAC,CAAC;aACJ;QACH,CAAC;KAAA;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,eAAe,CAAC;SAC/C;IACH,CAAC;IAEa,gBAAgB,CAAC,KAAa;;YAC1C,MAAM,OAAO,GAAW,MAAM,IAAI,CAAC,yBAAyB,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;YACvF,IAAI,OAAO,IAAI,IAAI,CAAC,MAAM,EAAE;gBAC1B,IAAI,CAAC,MAAM,CAAC,aAAa,GAAG,OAAO,CAAC;gBACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,sBAAsB,CAAC;gBAClD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;gBACrC,OAAO,IAAI,CAAC;aACb;iBAAM;gBACL,OAAO,KAAK,CAAC;aACd;QACH,CAAC;KAAA;IAEO,mBAAmB;QACzB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,qBAAqB,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;SAC5F;QACD,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;;;YA7NF,SAAS,SAAC;gBACT,QAAQ,EAAE,oBAAoB;gBAC9B,QAAQ,EAAE;;;;;;;;;;;;;GAaT;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YArBO,gBAAgB;YAPhB,wBAAwB;YACxB,oBAAoB;YAV1B,iBAAiB;YAUW,iBAAiB;;;oBA+B5C,SAAS,SAAC,cAAc;oBAGxB,KAAK;yBAUL,KAAK;uBAcL,KAAK;8BAcL,KAAK,YAAI,WAAW,SAAC,kBAAkB;gCAGvC,KAAK;4BAGL,KAAK;wBAGL,WAAW,SAAC,0BAA0B;8BAOtC,WAAW,SAAC,wBAAwB;sBAGpC,YAAY,SAAC,OAAO","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component, ElementRef,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnDestroy,\r\n  OnInit, ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {CoDocument} from '@colijnit/mainapi/build/model/co-document';\r\nimport {RelationConnectorService} from '../../service/relation-connector.service';\r\nimport {ColorSequenceService, CoreDialogService} from '@colijnit/corecomponents_v12';\r\nimport {RelationAnyType} from '@colijnit/relationapi/build/model/relation-any-type';\r\nimport {RelationSmallObject} from '@colijnit/relationapi/build/model/relation-small-object.bo';\r\nimport {FileUtils} from '@colijnit/mainapi/build/utils/file-utils';\r\nimport {StringUtils} from '@colijnit/ioneconnector/build/utils/string-utils';\r\nimport {CoDocumentImageDisplayKind} from '@colijnit/mainapi/build/enum/co-document-image-display-kind.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {Icon} from '../../enum/icon.enum';\r\n\r\n@Component({\r\n  selector: 'co-relation-avatar',\r\n  template: `\r\n      <co-image [source]=\"imageSrc\" *ngIf=\"imageSrc; else showInitials\"></co-image>\r\n      <ng-template #showInitials>\r\n          <svg viewBox=\"0 0 30 30\">\r\n              <text x=\"50%\" y=\"50%\" dominant-baseline=\"central\" text-anchor=\"middle\">{{ initials }}</text>\r\n          </svg>\r\n      </ng-template>\r\n      <ng-container *ngIf=\"canChangeAvatar\">\r\n          <div class=\"relation-avatar-pencil-wrapper\">\r\n              <co-icon [iconData]=\"iconCacheService.getIcon(icons.PencilRoundOpen)\" class=\"pencil-icon\"></co-icon>\r\n          </div>\r\n          <input #uploadAvatar class=\"value-text\" type=\"file\" (change)=\"onFileChangeEvent($event)\" accept=\".jpg, .png, .jpeg\">\r\n      </ng-container>\r\n  `,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationAvatarComponent implements OnInit, OnDestroy {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild(\"uploadAvatar\")\r\n  public input: ElementRef;\r\n\r\n  @Input()\r\n  public set image(value: CoDocument) {\r\n    this._image = value;\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  public get image(): CoDocument {\r\n    return this._image;\r\n  }\r\n\r\n  @Input()\r\n  public set relationId(value: number) {\r\n    if (this.relationId !== value) {\r\n      this._image = undefined;\r\n      this._relation = undefined;\r\n      this._relationId = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relationId(): number {\r\n    return this._relationId;\r\n  }\r\n\r\n  @Input()\r\n  public set relation(value: RelationAnyType) {\r\n    if (!this._relation || (this._relation && value && this._relation.relationId !== value.relationId)) {\r\n      this._image = undefined;\r\n      this._relationId = undefined;\r\n      this._relation = value;\r\n      this._setImageForAvatar();\r\n    }\r\n  }\r\n\r\n  public get relation(): RelationAnyType {\r\n    return this._relation;\r\n  }\r\n\r\n  @Input() @HostBinding(\"class.can-change\")\r\n  public canChangeAvatar: boolean = false;\r\n\r\n  @Input()\r\n  public maxUploadSizeInMb: number = 3;\r\n\r\n  @Input()\r\n  public maxAvatarSize: number = 200;\r\n\r\n  @HostBinding('class.co-relation-avatar')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public imageSrc: string;\r\n\r\n  @HostBinding(\"style.background-color\")\r\n  public backgroundColor: string;\r\n\r\n  @HostListener(\"click\")\r\n  public onClick(): void {\r\n    this.uploadTheAvatar();\r\n  }\r\n\r\n  public set initials(value: string) {\r\n    this._initials = value;\r\n    this._setBackgroundColor();\r\n  }\r\n\r\n  public get initials(): string {\r\n    return this._initials;\r\n  }\r\n\r\n  private _initials: string;\r\n  private _relationId: number;\r\n  private _relation: RelationAnyType;\r\n  private _image: CoDocument;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationConnectorService: RelationConnectorService,\r\n    private _colorSequenceService: ColorSequenceService,\r\n    private _changeDetector: ChangeDetectorRef,\r\n    private _dialogService: CoreDialogService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._setImageForAvatar();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.input = undefined;\r\n  }\r\n\r\n  public uploadTheAvatar(): void {\r\n    if (this.canChangeAvatar && this.input) {\r\n      this.input.nativeElement.click();\r\n    }\r\n  }\r\n\r\n  // Take File from event and save it internally as a CoDocument.\r\n  public onFileChangeEvent(event: any): void {\r\n    if (event && event.target && event.target.files && event.target.files.length > 0) {\r\n      const fileToUpload: File = event.target.files[0];\r\n\r\n      if (!FileUtils.CheckMaxUploadSize(fileToUpload)) {\r\n        this._dialogService.showWarning(StringUtils.Format(\r\n          \"File is to large to upload. Maximum file size is {0} Mb\", [this.maxUploadSizeInMb]));\r\n      } else if (!FileUtils.IsImageFile(fileToUpload)) {\r\n        this._dialogService.showWarning(\"Please select an image\");\r\n      } else {\r\n        this._setFileAsAvatarToCurrentRelation(fileToUpload);\r\n      }\r\n      if (this.input && this.input.nativeElement) {\r\n        this.input.nativeElement.value = null;\r\n      }\r\n    }\r\n  }\r\n\r\n  private async _setFileAsAvatarToCurrentRelation(file: File): Promise<void> {\r\n    const document: CoDocument = await FileUtils.ReadFileAsNewCoDocument(file, true, this.maxAvatarSize);\r\n    await this.setDocProperties(document);\r\n  }\r\n\r\n  private async setDocProperties(document: CoDocument): Promise<void> {\r\n    document.thumbnailBody = document.documentBody;\r\n    document.creationDate = new Date();\r\n    document.creationUser = this._relationConnectorService.loginResponse.userName;\r\n    document.imageDisplayKind = CoDocumentImageDisplayKind.Avatar;\r\n    if (this._relation) {\r\n      this._relation.avatarImage = document;\r\n    }\r\n    this.imageSrc = document.thumbnailBodyAsDataUri;\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageForAvatar(): Promise<void> {\r\n    if (this.image && this.image.documentId) {\r\n      if (!await this._getImageContent(this.image.documentId)) {\r\n        this._setImageFromRelation();\r\n      }\r\n    } else {\r\n      this._setImageFromRelation();\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n\r\n  private async _setImageFromRelation(): Promise<void> {\r\n    if (this.relation) {\r\n      if (this.relation.avatarImage && this.relation.avatarImage.documentId) {\r\n        this._image = this.relation.avatarImage;\r\n        if (!await this._getImageContent(this.image.documentId)) {\r\n          this._setRelationInitials();\r\n        }\r\n      } else {\r\n        this._setRelationInitials();\r\n      }\r\n    } else if (this.relationId) {\r\n      this._relationConnectorService.getRelationSmallObject(this.relationId).then(async (relationSmallObject: RelationSmallObject) => {\r\n        if (relationSmallObject) {\r\n          if (relationSmallObject.avatarImage && relationSmallObject.avatarImage.documentId) {\r\n            this._image = relationSmallObject.avatarImage;\r\n            if (!await this._getImageContent(this.image.documentId)) {\r\n              this._setRelationInitials();\r\n            }\r\n          } else {\r\n            this._setRelationInitials();\r\n          }\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  private _setRelationInitials(): void {\r\n    if (this.relation) {\r\n      this.initials = this.relation.displayInitials;\r\n    }\r\n  }\r\n\r\n  private async _getImageContent(docId: number): Promise<boolean> {\r\n    const content: string = await this._relationConnectorService.getDocumentContent(docId);\r\n    if (content && this._image) {\r\n      this._image.thumbnailBody = content;\r\n      this.imageSrc = this.image.thumbnailBodyAsDataUri;\r\n      this._changeDetector.detectChanges();\r\n      return true;\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  private _setBackgroundColor(): void {\r\n    this.imageSrc = \"\";\r\n    if (this.relation) {\r\n      this.backgroundColor = this._colorSequenceService.getRandomColor(this.relation.relationId);\r\n    }\r\n    this._changeDetector.detectChanges();\r\n  }\r\n} \r\n"]}
@@ -0,0 +1,22 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { RelationAvatarComponent } from './relation-avatar.component';
4
+ import { IconModule, ImageModule } from '@colijnit/corecomponents_v12';
5
+ export class RelationAvatarModule {
6
+ }
7
+ RelationAvatarModule.decorators = [
8
+ { type: NgModule, args: [{
9
+ imports: [
10
+ CommonModule,
11
+ ImageModule,
12
+ IconModule
13
+ ],
14
+ declarations: [
15
+ RelationAvatarComponent
16
+ ],
17
+ exports: [
18
+ RelationAvatarComponent
19
+ ]
20
+ },] }
21
+ ];
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvY29tcG9uZW50L3JlbGF0aW9uLWF2YXRhci9yZWxhdGlvbi1hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLDZCQUE2QixDQUFDO0FBQ3BFLE9BQU8sRUFBQyxVQUFVLEVBQUUsV0FBVyxFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFlckUsTUFBTSxPQUFPLG9CQUFvQjs7O1lBYmhDLFFBQVEsU0FBQztnQkFDUixPQUFPLEVBQUU7b0JBQ1AsWUFBWTtvQkFDWixXQUFXO29CQUNYLFVBQVU7aUJBQ1g7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLHVCQUF1QjtpQkFDeEI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHVCQUF1QjtpQkFDeEI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHtSZWxhdGlvbkF2YXRhckNvbXBvbmVudH0gZnJvbSAnLi9yZWxhdGlvbi1hdmF0YXIuY29tcG9uZW50JztcclxuaW1wb3J0IHtJY29uTW9kdWxlLCBJbWFnZU1vZHVsZX0gZnJvbSAnQGNvbGlqbml0L2NvcmVjb21wb25lbnRzX3YxMic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEltYWdlTW9kdWxlLFxyXG4gICAgSWNvbk1vZHVsZVxyXG4gIF0sXHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBSZWxhdGlvbkF2YXRhckNvbXBvbmVudFxyXG4gIF0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgUmVsYXRpb25BdmF0YXJDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSZWxhdGlvbkF2YXRhck1vZHVsZSB7XHJcbn1cclxuIl19
@@ -0,0 +1,101 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewEncapsulation } from '@angular/core';
3
+ import { CDK_DRAG_CONFIG, moveItemInArray } from '@angular/cdk/drag-drop';
4
+ const DragConfig = {
5
+ dragStartThreshold: 0,
6
+ pointerDirectionChangeThreshold: 5,
7
+ zIndex: 10000
8
+ };
9
+ const ɵ0 = DragConfig;
10
+ export class RelationContactOptionListComponent {
11
+ constructor() {
12
+ this.dragDropDisabled = false;
13
+ this.collection = [];
14
+ this.deleteClick = new EventEmitter();
15
+ this.showClass = true;
16
+ this.dragStartDelay = 500;
17
+ this.handleCanDragDrop = (drag, drop) => {
18
+ return (drag.data.type === this.type);
19
+ };
20
+ }
21
+ handleDrop(event) {
22
+ return __awaiter(this, void 0, void 0, function* () {
23
+ try {
24
+ const from = event.previousIndex;
25
+ const to = event.currentIndex;
26
+ if (from === to) {
27
+ return;
28
+ }
29
+ // set items in correct order
30
+ moveItemInArray(this.collection, from, to);
31
+ this._reArrangeSequences();
32
+ }
33
+ catch (e) {
34
+ console.error(e);
35
+ }
36
+ });
37
+ }
38
+ /**
39
+ * Hack to make sure that dragged item has the right css when not moving the mouse
40
+ * @param event
41
+ */
42
+ handleOptionMouseDown(event) {
43
+ clearTimeout(this._mouseDownTimeout);
44
+ this._mouseDownTimeout = setTimeout(() => {
45
+ let mouseMoveEvent;
46
+ if ("createEvent" in document) {
47
+ mouseMoveEvent = document.createEvent("Event");
48
+ mouseMoveEvent.initEvent('mousemove', true, true);
49
+ }
50
+ else if ("Event" in window) {
51
+ mouseMoveEvent = new Event('mousemove', { bubbles: true, cancelable: true });
52
+ }
53
+ // @ts-ignore
54
+ mouseMoveEvent.pageX = event.pageX;
55
+ // @ts-ignore
56
+ mouseMoveEvent.pageY = event.pageY;
57
+ document.dispatchEvent(mouseMoveEvent);
58
+ }, this.dragStartDelay);
59
+ }
60
+ handleOptionMouseUp(event) {
61
+ clearTimeout(this._mouseDownTimeout);
62
+ }
63
+ _reArrangeSequences() {
64
+ for (let i = 0; i < this.collection.length; i++) {
65
+ this.collection[i].sequence = i;
66
+ }
67
+ }
68
+ }
69
+ RelationContactOptionListComponent.decorators = [
70
+ { type: Component, args: [{
71
+ selector: 'co-relation-contact-option-list',
72
+ template: `
73
+ <div #dropListContactOptions class="contact-option-wrapper drag-drop-list" cdkDropList cdkDropListOrientation="vertical"
74
+ [cdkDropListDisabled]="dragDropDisabled"
75
+ [cdkDropListData]="collection"
76
+ [cdkDropListEnterPredicate]="handleCanDragDrop"
77
+ (cdkDropListDropped)="handleDrop($event)"
78
+ >
79
+ <co-relation-contact-option class="draggable-contact-option" *ngFor="let option of collection" [model]="option"
80
+ cdkDrag [cdkDragStartDelay]="dragStartDelay"
81
+ (mousedown)="handleOptionMouseDown($event)"
82
+ (mouseup)="handleOptionMouseUp($event)"
83
+ (deleteClick)="deleteClick.emit($event)"
84
+ ></co-relation-contact-option>
85
+ </div>
86
+ `,
87
+ providers: [
88
+ { provide: CDK_DRAG_CONFIG, useValue: ɵ0 }
89
+ ],
90
+ encapsulation: ViewEncapsulation.None
91
+ },] }
92
+ ];
93
+ RelationContactOptionListComponent.propDecorators = {
94
+ dragDropDisabled: [{ type: Input }],
95
+ type: [{ type: Input }],
96
+ collection: [{ type: Input }],
97
+ deleteClick: [{ type: Output }],
98
+ showClass: [{ type: HostBinding, args: ['class.co-relation-contact-option-list',] }]
99
+ };
100
+ export { ɵ0 };
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option-list.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from '@angular/core';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {CDK_DRAG_CONFIG, CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from '@angular/cdk/drag-drop';\r\n\r\nconst DragConfig = {\r\n  dragStartThreshold: 0,\r\n  pointerDirectionChangeThreshold: 5,\r\n  zIndex: 10000\r\n};\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option-list',\r\n  template: `\r\n      <div #dropListContactOptions class=\"contact-option-wrapper drag-drop-list\" cdkDropList cdkDropListOrientation=\"vertical\"\r\n           [cdkDropListDisabled]=\"dragDropDisabled\"\r\n           [cdkDropListData]=\"collection\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n          <co-relation-contact-option class=\"draggable-contact-option\" *ngFor=\"let option of collection\" [model]=\"option\"\r\n                                      cdkDrag [cdkDragStartDelay]=\"dragStartDelay\"\r\n                                      (mousedown)=\"handleOptionMouseDown($event)\" \r\n                                      (mouseup)=\"handleOptionMouseUp($event)\"\r\n                                      (deleteClick)=\"deleteClick.emit($event)\"\r\n          ></co-relation-contact-option>\r\n      </div>\r\n  `,\r\n  providers: [\r\n    {provide: CDK_DRAG_CONFIG, useValue: DragConfig}\r\n  ],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionListComponent {\r\n  @Input()\r\n  public dragDropDisabled: boolean = false;\r\n\r\n  @Input()\r\n  public type: CommunicationType;\r\n\r\n  @Input()\r\n  public collection: ContactOption[] = [];\r\n\r\n  @Output()\r\n  public deleteClick: EventEmitter<ContactOption> = new EventEmitter<ContactOption>();\r\n\r\n  @HostBinding('class.co-relation-contact-option-list')\r\n  public showClass: boolean = true;\r\n\r\n  public dragStartDelay: number = 500;\r\n\r\n  private _mouseDownTimeout: any;\r\n\r\n  public handleCanDragDrop = (drag: CdkDrag, drop: CdkDropList) => {\r\n    return (drag.data.type === this.type);\r\n  }\r\n\r\n  public async handleDrop(event: CdkDragDrop<ContactOption[]>): Promise<void> {\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      // set items in correct order\r\n      moveItemInArray(this.collection, from, to);\r\n      this._reArrangeSequences();\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Hack to make sure that dragged item has the right css when not moving the mouse\r\n   * @param event\r\n   */\r\n  public handleOptionMouseDown(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout);\r\n    this._mouseDownTimeout = setTimeout(() => {\r\n      let mouseMoveEvent: Event;\r\n      if (\"createEvent\" in document) {\r\n        mouseMoveEvent = document.createEvent(\"Event\");\r\n        mouseMoveEvent.initEvent('mousemove', true, true);\r\n      } else if (\"Event\" in window) {\r\n        mouseMoveEvent = new Event('mousemove', { bubbles: true, cancelable: true });\r\n      }\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageX = event.pageX;\r\n      // @ts-ignore\r\n      mouseMoveEvent.pageY = event.pageY;\r\n      document.dispatchEvent(mouseMoveEvent);\r\n    }, this.dragStartDelay);\r\n  }\r\n\r\n  public handleOptionMouseUp(event: MouseEvent): void {\r\n    clearTimeout(this._mouseDownTimeout)\r\n  }\r\n\r\n  private _reArrangeSequences(): void {\r\n    for (let i = 0; i < this.collection.length; i++) {\r\n      this.collection[i].sequence = i;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,100 @@
1
+ import { __awaiter } from "tslib";
2
+ import { Component, EventEmitter, HostBinding, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
3
+ import { CommunicationType } from '@colijnit/relationapi/build/enum/communication-type.enum';
4
+ import { Icon } from '../../enum/icon.enum';
5
+ import { IconCacheService } from '../../service/icon-cache.service';
6
+ import { ContactOption } from '@colijnit/relationapi/build/model/contact-option.bo';
7
+ import { InputTextComponent } from '@colijnit/corecomponents_v12';
8
+ import { RelationService } from '../../service/relation.service';
9
+ export class RelationContactOptionComponent {
10
+ constructor(iconCacheService, _relationService) {
11
+ this.iconCacheService = iconCacheService;
12
+ this._relationService = _relationService;
13
+ this.icons = Icon;
14
+ this.saveClick = new EventEmitter();
15
+ this.deleteClick = new EventEmitter();
16
+ this.showClass = true;
17
+ this.iconType = Icon.Email;
18
+ this.label = 'EMAIL';
19
+ this.shouldFocus = false;
20
+ this._type = CommunicationType.Email;
21
+ }
22
+ set child(content) {
23
+ if (content) {
24
+ this.input = content;
25
+ this.input.commit = (value) => this.handleCommit(value);
26
+ if (this.shouldFocus) {
27
+ setTimeout(() => {
28
+ this.input.requestFocus();
29
+ });
30
+ }
31
+ }
32
+ }
33
+ set model(value) {
34
+ this._model = value;
35
+ if (this._model) {
36
+ this.type = this._model.type;
37
+ }
38
+ }
39
+ get model() {
40
+ return this._model;
41
+ }
42
+ set type(value) {
43
+ this._type = value;
44
+ this._prepareType(this._type);
45
+ }
46
+ get type() {
47
+ return this._type;
48
+ }
49
+ ngOnInit() {
50
+ if (this.type && !this.model) {
51
+ const newOption = new ContactOption();
52
+ newOption.type = this.type;
53
+ this.model = newOption;
54
+ this.shouldFocus = true;
55
+ }
56
+ }
57
+ handleCommit(value) {
58
+ return __awaiter(this, void 0, void 0, function* () {
59
+ this.model.value = value;
60
+ this.saveClick.next(this.model);
61
+ return true;
62
+ });
63
+ }
64
+ _prepareType(type) {
65
+ if (type) {
66
+ this.iconType = this._relationService.communicationTypeIcon.get(type);
67
+ this.label = this._relationService.communicationTypeLabel.get(type);
68
+ }
69
+ }
70
+ }
71
+ RelationContactOptionComponent.decorators = [
72
+ { type: Component, args: [{
73
+ selector: 'co-relation-contact-option',
74
+ template: `
75
+ <div class="relation-contact-option-sequence" *ngIf="model.sequence !== null && model.sequence !== undefined"
76
+ [textContent]="model.sequence"></div>
77
+ <co-input-text #input
78
+ [placeholder]="label | reLocalize"
79
+ [model]="model.value"
80
+ [leftIconData]="iconCacheService.getIcon(iconType)"
81
+ [showSaveCancel]="true"
82
+ ></co-input-text>
83
+ <co-icon [iconData]="iconCacheService.getIcon(icons.TrashBin)" (click)="deleteClick.emit(model)"></co-icon>
84
+ `,
85
+ encapsulation: ViewEncapsulation.None
86
+ },] }
87
+ ];
88
+ RelationContactOptionComponent.ctorParameters = () => [
89
+ { type: IconCacheService },
90
+ { type: RelationService }
91
+ ];
92
+ RelationContactOptionComponent.propDecorators = {
93
+ child: [{ type: ViewChild, args: ['input', { read: InputTextComponent },] }],
94
+ model: [{ type: Input }],
95
+ type: [{ type: Input }],
96
+ saveClick: [{ type: Output }],
97
+ deleteClick: [{ type: Output }],
98
+ showClass: [{ type: HostBinding, args: ['class.co-relation-contact-option',] }]
99
+ };
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"relation-contact-option.component.js","sourceRoot":"","sources":["../../../../../../projects/relation/src/lib/component/relation-contact-options/relation-contact-option.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewChild, ViewEncapsulation} from '@angular/core';\r\nimport {CommunicationType} from '@colijnit/relationapi/build/enum/communication-type.enum';\r\nimport {Icon} from '../../enum/icon.enum';\r\nimport {IconCacheService} from '../../service/icon-cache.service';\r\nimport {ContactOption} from '@colijnit/relationapi/build/model/contact-option.bo';\r\nimport {InputTextComponent} from '@colijnit/corecomponents_v12';\r\nimport {RelationService} from '../../service/relation.service';\r\n\r\n@Component({\r\n  selector: 'co-relation-contact-option',\r\n  template: `\r\n      <div class=\"relation-contact-option-sequence\" *ngIf=\"model.sequence !== null && model.sequence !== undefined\"\r\n           [textContent]=\"model.sequence\"></div>\r\n      <co-input-text #input\r\n                     [placeholder]=\"label | reLocalize\"\r\n                     [model]=\"model.value\"\r\n                     [leftIconData]=\"iconCacheService.getIcon(iconType)\"\r\n                     [showSaveCancel]=\"true\"\r\n      ></co-input-text>\r\n      <co-icon [iconData]=\"iconCacheService.getIcon(icons.TrashBin)\" (click)=\"deleteClick.emit(model)\"></co-icon>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class RelationContactOptionComponent implements OnInit {\r\n  public readonly icons: typeof Icon = Icon;\r\n\r\n  @ViewChild('input', { read: InputTextComponent }) set child(content) {\r\n    if (content) {\r\n      this.input = content;\r\n      this.input.commit = (value) => this.handleCommit(value);\r\n      if (this.shouldFocus) {\r\n        setTimeout(() => {\r\n          this.input.requestFocus();\r\n        })\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: ContactOption) {\r\n    this._model = value;\r\n    if (this._model) {\r\n      this.type = this._model.type;\r\n    }\r\n  }\r\n\r\n  public get model(): ContactOption {\r\n    return this._model;\r\n  }\r\n\r\n  @Input()\r\n  public set type(value: CommunicationType) {\r\n    this._type = value;\r\n    this._prepareType(this._type);\r\n  }\r\n\r\n  public get type(): CommunicationType {\r\n    return this._type;\r\n  }\r\n\r\n  @Output()\r\n  public saveClick: EventEmitter<ContactOption> = new EventEmitter<ContactOption>();\r\n\r\n  @Output()\r\n  public deleteClick: EventEmitter<ContactOption> = new EventEmitter<ContactOption>();\r\n\r\n  @HostBinding('class.co-relation-contact-option')\r\n  public showClass: boolean = true;\r\n\r\n  public iconType: Icon = Icon.Email;\r\n  public label: string = 'EMAIL';\r\n  public input: InputTextComponent;\r\n  public shouldFocus: boolean = false;\r\n\r\n  private _model: ContactOption;\r\n  private _type: CommunicationType = CommunicationType.Email;\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    private _relationService: RelationService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.type && !this.model) {\r\n      const newOption: ContactOption = new ContactOption();\r\n      newOption.type = this.type;\r\n      this.model = newOption;\r\n      this.shouldFocus = true;\r\n    }\r\n  }\r\n\r\n  public async handleCommit(value: string): Promise<boolean> {\r\n    this.model.value = value;\r\n    this.saveClick.next(this.model);\r\n    return true;\r\n  }\r\n\r\n  private _prepareType(type: CommunicationType): void {\r\n    if (type) {\r\n      this.iconType = this._relationService.communicationTypeIcon.get(type);\r\n      this.label = this._relationService.communicationTypeLabel.get(type);\r\n    }\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,44 @@
1
+ import { Component, EventEmitter, HostBinding, Input, Output } from '@angular/core';
2
+ import { CommunicationType } from '@colijnit/relationapi/build/enum/communication-type.enum';
3
+ import { Icon } from '../../enum/icon.enum';
4
+ import { RelationService } from '../../service/relation.service';
5
+ import { IconCacheService } from '../../service/icon-cache.service';
6
+ export class RelationContactOptionsOtherTypesPopupComponent {
7
+ constructor(iconCacheService, _relationService) {
8
+ this.iconCacheService = iconCacheService;
9
+ this._relationService = _relationService;
10
+ this.icons = Icon;
11
+ this.typeClick = new EventEmitter();
12
+ this.clickedOutside = new EventEmitter();
13
+ this.showClass = true;
14
+ this.types = [];
15
+ }
16
+ ngOnInit() {
17
+ this.types.length = 0;
18
+ this.types.push({ type: CommunicationType.Email, icon: this._relationService.communicationTypeIcon.get(CommunicationType.Email), label: this._relationService.communicationTypeLabel.get(CommunicationType.Email) }, { type: CommunicationType.Telephone, icon: this._relationService.communicationTypeIcon.get(CommunicationType.Telephone), label: this._relationService.communicationTypeLabel.get(CommunicationType.Telephone) }, { type: CommunicationType.Mobile, icon: this._relationService.communicationTypeIcon.get(CommunicationType.Mobile), label: this._relationService.communicationTypeLabel.get(CommunicationType.Mobile) }, { type: CommunicationType.Website, icon: this._relationService.communicationTypeIcon.get(CommunicationType.Website), label: this._relationService.communicationTypeLabel.get(CommunicationType.Website) }, { type: CommunicationType.Fax, icon: this._relationService.communicationTypeIcon.get(CommunicationType.Fax), label: this._relationService.communicationTypeLabel.get(CommunicationType.Fax) });
19
+ }
20
+ }
21
+ RelationContactOptionsOtherTypesPopupComponent.decorators = [
22
+ { type: Component, args: [{
23
+ selector: 'co-relation-contact-options-other-types-popup',
24
+ template: `
25
+ <div class="relation-contact-options-other-types-popup-content" [overlay]="parentForOverlay" [rightAlign]="true" [keepInView]="true">
26
+ <div class="other-types-wrapper" *ngFor="let type of types" (click)="typeClick.emit(type.type)" [clickOutside]="true" (clickOutside)="clickedOutside.emit()">
27
+ <co-icon [iconData]="iconCacheService.getIcon(type.icon)"></co-icon>
28
+ <div class="other-type-label" [textContent]="type.label | reLocalize"></div>
29
+ </div>
30
+ </div>
31
+ `
32
+ },] }
33
+ ];
34
+ RelationContactOptionsOtherTypesPopupComponent.ctorParameters = () => [
35
+ { type: IconCacheService },
36
+ { type: RelationService }
37
+ ];
38
+ RelationContactOptionsOtherTypesPopupComponent.propDecorators = {
39
+ parentForOverlay: [{ type: Input }],
40
+ typeClick: [{ type: Output }],
41
+ clickedOutside: [{ type: Output }],
42
+ showClass: [{ type: HostBinding, args: ['class.co-relation-contact-options-other-types-popup',] }]
43
+ };
44
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3JlbGF0aW9uL3NyYy9saWIvY29tcG9uZW50L3JlbGF0aW9uLWNvbnRhY3Qtb3B0aW9ucy9yZWxhdGlvbi1jb250YWN0LW9wdGlvbnMtb3RoZXItdHlwZXMtcG9wdXAuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQWMsWUFBWSxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBQyxpQkFBaUIsRUFBQyxNQUFNLDBEQUEwRCxDQUFDO0FBQzNGLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxQyxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDL0QsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFtQmxFLE1BQU0sT0FBTyw4Q0FBOEM7SUFpQnpELFlBQ1MsZ0JBQWtDLEVBQ2pDLGdCQUFpQztRQURsQyxxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQWtCO1FBQ2pDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBaUI7UUFsQjNCLFVBQUssR0FBZ0IsSUFBSSxDQUFDO1FBTW5DLGNBQVMsR0FBb0MsSUFBSSxZQUFZLEVBQXFCLENBQUM7UUFHbkYsbUJBQWMsR0FBdUIsSUFBSSxZQUFZLEVBQVEsQ0FBQztRQUc5RCxjQUFTLEdBQVksSUFBSSxDQUFDO1FBRTFCLFVBQUssR0FBZ0IsRUFBRSxDQUFDO0lBTS9CLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDO1FBQ3RCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNiLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHNCQUFzQixDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUNuTSxFQUFFLElBQUksRUFBRSxpQkFBaUIsQ0FBQyxTQUFTLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxxQkFBcUIsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsU0FBUyxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxzQkFBc0IsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsU0FBUyxDQUFDLEVBQUUsRUFDL00sRUFBRSxJQUFJLEVBQUUsaUJBQWlCLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMscUJBQXFCLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsZ0JBQWdCLENBQUMsc0JBQXNCLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQ3RNLEVBQUUsSUFBSSxFQUFFLGlCQUFpQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHFCQUFxQixDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsRUFBRSxLQUFLLEVBQUUsSUFBSSxDQUFDLGdCQUFnQixDQUFDLHNCQUFzQixDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsRUFBRSxFQUN6TSxFQUFFLElBQUksRUFBRSxpQkFBaUIsQ0FBQyxHQUFHLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxxQkFBcUIsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxzQkFBc0IsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FDOUwsQ0FBQTtJQUNILENBQUM7OztZQTNDRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLCtDQUErQztnQkFDekQsUUFBUSxFQUFFOzs7Ozs7O0dBT1Q7YUFDRjs7O1lBbEJPLGdCQUFnQjtZQURoQixlQUFlOzs7K0JBdUJwQixLQUFLO3dCQUdMLE1BQU07NkJBR04sTUFBTTt3QkFHTixXQUFXLFNBQUMscURBQXFEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSG9zdEJpbmRpbmcsIElucHV0LCBPbkluaXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7Q29tbXVuaWNhdGlvblR5cGV9IGZyb20gJ0Bjb2xpam5pdC9yZWxhdGlvbmFwaS9idWlsZC9lbnVtL2NvbW11bmljYXRpb24tdHlwZS5lbnVtJztcclxuaW1wb3J0IHtJY29ufSBmcm9tICcuLi8uLi9lbnVtL2ljb24uZW51bSc7XHJcbmltcG9ydCB7UmVsYXRpb25TZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlL3JlbGF0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQge0ljb25DYWNoZVNlcnZpY2V9IGZyb20gJy4uLy4uL3NlcnZpY2UvaWNvbi1jYWNoZS5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2Ugb3RoZXJUeXBlIHtcclxuICB0eXBlOiBDb21tdW5pY2F0aW9uVHlwZSxcclxuICBpY29uOiBJY29uO1xyXG4gIGxhYmVsOiBzdHJpbmc7XHJcbn1cclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY28tcmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwJyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgICA8ZGl2IGNsYXNzPVwicmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwLWNvbnRlbnRcIiBbb3ZlcmxheV09XCJwYXJlbnRGb3JPdmVybGF5XCIgW3JpZ2h0QWxpZ25dPVwidHJ1ZVwiIFtrZWVwSW5WaWV3XT1cInRydWVcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwib3RoZXItdHlwZXMtd3JhcHBlclwiICpuZ0Zvcj1cImxldCB0eXBlIG9mIHR5cGVzXCIgKGNsaWNrKT1cInR5cGVDbGljay5lbWl0KHR5cGUudHlwZSlcIiBbY2xpY2tPdXRzaWRlXT1cInRydWVcIiAoY2xpY2tPdXRzaWRlKT1cImNsaWNrZWRPdXRzaWRlLmVtaXQoKVwiPlxyXG4gICAgICAgICAgICA8Y28taWNvbiBbaWNvbkRhdGFdPVwiaWNvbkNhY2hlU2VydmljZS5nZXRJY29uKHR5cGUuaWNvbilcIj48L2NvLWljb24+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJvdGhlci10eXBlLWxhYmVsXCIgW3RleHRDb250ZW50XT1cInR5cGUubGFiZWwgfCByZUxvY2FsaXplXCI+PC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gIGBcclxufSlcclxuZXhwb3J0IGNsYXNzIFJlbGF0aW9uQ29udGFjdE9wdGlvbnNPdGhlclR5cGVzUG9wdXBDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIHB1YmxpYyByZWFkb25seSBpY29uczogdHlwZW9mIEljb24gPSBJY29uO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBwYXJlbnRGb3JPdmVybGF5OiBFbGVtZW50UmVmO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgdHlwZUNsaWNrOiBFdmVudEVtaXR0ZXI8Q29tbXVuaWNhdGlvblR5cGU+ID0gbmV3IEV2ZW50RW1pdHRlcjxDb21tdW5pY2F0aW9uVHlwZT4oKTtcclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIGNsaWNrZWRPdXRzaWRlOiBFdmVudEVtaXR0ZXI8dm9pZD4gPSBuZXcgRXZlbnRFbWl0dGVyPHZvaWQ+KCk7XHJcblxyXG4gIEBIb3N0QmluZGluZygnY2xhc3MuY28tcmVsYXRpb24tY29udGFjdC1vcHRpb25zLW90aGVyLXR5cGVzLXBvcHVwJylcclxuICBwdWJsaWMgc2hvd0NsYXNzOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgcHVibGljIHR5cGVzOiBvdGhlclR5cGVbXSA9IFtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHB1YmxpYyBpY29uQ2FjaGVTZXJ2aWNlOiBJY29uQ2FjaGVTZXJ2aWNlLFxyXG4gICAgcHJpdmF0ZSBfcmVsYXRpb25TZXJ2aWNlOiBSZWxhdGlvblNlcnZpY2VcclxuICApIHtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy50eXBlcy5sZW5ndGggPSAwO1xyXG4gICAgdGhpcy50eXBlcy5wdXNoKFxyXG4gICAgICB7IHR5cGU6IENvbW11bmljYXRpb25UeXBlLkVtYWlsLCBpY29uOiB0aGlzLl9yZWxhdGlvblNlcnZpY2UuY29tbXVuaWNhdGlvblR5cGVJY29uLmdldChDb21tdW5pY2F0aW9uVHlwZS5FbWFpbCksIGxhYmVsOiB0aGlzLl9yZWxhdGlvblNlcnZpY2UuY29tbXVuaWNhdGlvblR5cGVMYWJlbC5nZXQoQ29tbXVuaWNhdGlvblR5cGUuRW1haWwpIH0sXHJcbiAgICAgIHsgdHlwZTogQ29tbXVuaWNhdGlvblR5cGUuVGVsZXBob25lLCBpY29uOiB0aGlzLl9yZWxhdGlvblNlcnZpY2UuY29tbXVuaWNhdGlvblR5cGVJY29uLmdldChDb21tdW5pY2F0aW9uVHlwZS5UZWxlcGhvbmUpLCBsYWJlbDogdGhpcy5fcmVsYXRpb25TZXJ2aWNlLmNvbW11bmljYXRpb25UeXBlTGFiZWwuZ2V0KENvbW11bmljYXRpb25UeXBlLlRlbGVwaG9uZSkgfSxcclxuICAgICAgeyB0eXBlOiBDb21tdW5pY2F0aW9uVHlwZS5Nb2JpbGUsIGljb246IHRoaXMuX3JlbGF0aW9uU2VydmljZS5jb21tdW5pY2F0aW9uVHlwZUljb24uZ2V0KENvbW11bmljYXRpb25UeXBlLk1vYmlsZSksIGxhYmVsOiB0aGlzLl9yZWxhdGlvblNlcnZpY2UuY29tbXVuaWNhdGlvblR5cGVMYWJlbC5nZXQoQ29tbXVuaWNhdGlvblR5cGUuTW9iaWxlKSB9LFxyXG4gICAgICB7IHR5cGU6IENvbW11bmljYXRpb25UeXBlLldlYnNpdGUsIGljb246IHRoaXMuX3JlbGF0aW9uU2VydmljZS5jb21tdW5pY2F0aW9uVHlwZUljb24uZ2V0KENvbW11bmljYXRpb25UeXBlLldlYnNpdGUpLCBsYWJlbDogdGhpcy5fcmVsYXRpb25TZXJ2aWNlLmNvbW11bmljYXRpb25UeXBlTGFiZWwuZ2V0KENvbW11bmljYXRpb25UeXBlLldlYnNpdGUpIH0sXHJcbiAgICAgIHsgdHlwZTogQ29tbXVuaWNhdGlvblR5cGUuRmF4LCBpY29uOiB0aGlzLl9yZWxhdGlvblNlcnZpY2UuY29tbXVuaWNhdGlvblR5cGVJY29uLmdldChDb21tdW5pY2F0aW9uVHlwZS5GYXgpLCBsYWJlbDogdGhpcy5fcmVsYXRpb25TZXJ2aWNlLmNvbW11bmljYXRpb25UeXBlTGFiZWwuZ2V0KENvbW11bmljYXRpb25UeXBlLkZheCkgfVxyXG4gICAgKVxyXG4gIH1cclxufVxyXG4iXX0=