@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.
- package/README.md +24 -0
- package/bundles/colijnit-relation.umd.js +4832 -0
- package/bundles/colijnit-relation.umd.js.map +1 -0
- package/colijnit-relation.d.ts +21 -0
- package/colijnit-relation.metadata.json +1 -0
- package/esm2015/colijnit-relation.js +22 -0
- package/esm2015/lib/component/base/relation-base.component.js +52 -0
- package/esm2015/lib/component/base/relation-loader.component.js +50 -0
- package/esm2015/lib/component/base/relation-screen-config-base.component.js +16 -0
- package/esm2015/lib/component/relation/relation.component.js +100 -0
- package/esm2015/lib/component/relation/relation.module.js +58 -0
- package/esm2015/lib/component/relation-address/relation-address.component.js +166 -0
- package/esm2015/lib/component/relation-address/relation-address.module.js +24 -0
- package/esm2015/lib/component/relation-address-tile/relation-address-tile.component.js +72 -0
- package/esm2015/lib/component/relation-address-tile/relation-address-tile.module.js +25 -0
- package/esm2015/lib/component/relation-addresses/relation-addresses.component.js +158 -0
- package/esm2015/lib/component/relation-addresses/relation-addresses.module.js +31 -0
- package/esm2015/lib/component/relation-avatar/relation-avatar.component.js +222 -0
- package/esm2015/lib/component/relation-avatar/relation-avatar.module.js +22 -0
- package/esm2015/lib/component/relation-contact-options/relation-contact-option-list.component.js +101 -0
- package/esm2015/lib/component/relation-contact-options/relation-contact-option.component.js +100 -0
- package/esm2015/lib/component/relation-contact-options/relation-contact-options-other-types-popup.component.js +44 -0
- package/esm2015/lib/component/relation-contact-options/relation-contact-options.component.js +154 -0
- package/esm2015/lib/component/relation-contact-options/relation-contact-options.module.js +34 -0
- package/esm2015/lib/component/relation-first-name/relation-first-name.component.js +25 -0
- package/esm2015/lib/component/relation-first-name/relation-first-name.module.js +24 -0
- package/esm2015/lib/component/relation-gender/relation-gender.component.js +45 -0
- package/esm2015/lib/component/relation-gender/relation-gender.module.js +23 -0
- package/esm2015/lib/component/relation-initials/relation-initials.component.js +24 -0
- package/esm2015/lib/component/relation-initials/relation-initials.module.js +24 -0
- package/esm2015/lib/component/relation-language/relation-language.component.js +56 -0
- package/esm2015/lib/component/relation-language/relation-language.module.js +24 -0
- package/esm2015/lib/component/relation-last-name/relation-last-name.component.js +23 -0
- package/esm2015/lib/component/relation-last-name/relation-last-name.module.js +24 -0
- package/esm2015/lib/component/relation-preferences/relation-preferences.component.js +69 -0
- package/esm2015/lib/component/relation-preferences/relation-preferences.module.js +23 -0
- package/esm2015/lib/component/relation-prefix-name/relation-prefix-name.component.js +24 -0
- package/esm2015/lib/component/relation-prefix-name/relation-prefix-name.module.js +24 -0
- package/esm2015/lib/component/relation-title/relation-title.component.js +56 -0
- package/esm2015/lib/component/relation-title/relation-title.module.js +24 -0
- package/esm2015/lib/enum/icon.enum.js +16 -0
- package/esm2015/lib/enum/language-code.enum.js +8 -0
- package/esm2015/lib/enum/relman-cfg-name.enum.js +862 -0
- package/esm2015/lib/enum/relman-contact-options-cfg-names.js +2 -0
- package/esm2015/lib/enum/relman-sub-category.enum.js +13 -0
- package/esm2015/lib/interface/relation-address-cfg-names.interface.js +2 -0
- package/esm2015/lib/model/icon-svg.js +15 -0
- package/esm2015/lib/model/relation-settings-options.js +7 -0
- package/esm2015/lib/model/relation-settings.js +9 -0
- package/esm2015/lib/relation-version.js +10 -0
- package/esm2015/lib/res/dictionary/dictionaries.js +9 -0
- package/esm2015/lib/service/dictionary.service.js +68 -0
- package/esm2015/lib/service/error.service.js +75 -0
- package/esm2015/lib/service/icon-cache.service.js +51 -0
- package/esm2015/lib/service/relation-base.service.js +268 -0
- package/esm2015/lib/service/relation-connector-adapter.service.js +401 -0
- package/esm2015/lib/service/relation-connector.service.js +155 -0
- package/esm2015/lib/service/relation-event.service.js +16 -0
- package/esm2015/lib/service/relation-screen-configuration.service.js +51 -0
- package/esm2015/lib/service/relation-settings.service.js +65 -0
- package/esm2015/lib/service/relation.service.js +42 -0
- package/esm2015/lib/translation/relation-dictionary.service.js +77 -0
- package/esm2015/lib/translation/relation-localize.pipe.js +26 -0
- package/esm2015/lib/translation/relation-translation.module.js +29 -0
- package/esm2015/lib/translation/relation-translation.service.js +17 -0
- package/esm2015/public_api.js +33 -0
- package/fesm2015/colijnit-relation.js +3980 -0
- package/fesm2015/colijnit-relation.js.map +1 -0
- package/lib/component/base/relation-base.component.d.ts +24 -0
- package/lib/component/base/relation-loader.component.d.ts +12 -0
- package/lib/component/base/relation-screen-config-base.component.d.ts +14 -0
- package/lib/component/relation/relation.component.d.ts +21 -0
- package/lib/component/relation/relation.module.d.ts +2 -0
- package/lib/component/relation/style/_layout.scss +46 -0
- package/lib/component/relation/style/_material-definition.scss +15 -0
- package/lib/component/relation/style/_theme.scss +12 -0
- package/lib/component/relation/style/material.scss +4 -0
- package/lib/component/relation-address/relation-address.component.d.ts +35 -0
- package/lib/component/relation-address/relation-address.module.d.ts +2 -0
- package/lib/component/relation-address/style/_layout.scss +16 -0
- package/lib/component/relation-address/style/_material-definition.scss +5 -0
- package/lib/component/relation-address/style/_theme.scss +5 -0
- package/lib/component/relation-address/style/material.scss +4 -0
- package/lib/component/relation-address-tile/relation-address-tile.component.d.ts +19 -0
- package/lib/component/relation-address-tile/relation-address-tile.module.d.ts +2 -0
- package/lib/component/relation-address-tile/style/_layout.scss +46 -0
- package/lib/component/relation-address-tile/style/_material-definition.scss +18 -0
- package/lib/component/relation-address-tile/style/_theme.scss +19 -0
- package/lib/component/relation-address-tile/style/material.scss +4 -0
- package/lib/component/relation-addresses/relation-addresses.component.d.ts +31 -0
- package/lib/component/relation-addresses/relation-addresses.module.d.ts +2 -0
- package/lib/component/relation-addresses/style/_layout.scss +26 -0
- package/lib/component/relation-addresses/style/_material-definition.scss +12 -0
- package/lib/component/relation-addresses/style/_theme.scss +20 -0
- package/lib/component/relation-addresses/style/material.scss +4 -0
- package/lib/component/relation-avatar/relation-avatar.component.d.ts +47 -0
- package/lib/component/relation-avatar/relation-avatar.module.d.ts +2 -0
- package/lib/component/relation-avatar/style/_layout.scss +44 -0
- package/lib/component/relation-avatar/style/_material-definition.scss +4 -0
- package/lib/component/relation-avatar/style/_theme.scss +9 -0
- package/lib/component/relation-avatar/style/material.scss +4 -0
- package/lib/component/relation-contact-options/relation-contact-option-list.component.d.ts +22 -0
- package/lib/component/relation-contact-options/relation-contact-option.component.d.ts +30 -0
- package/lib/component/relation-contact-options/relation-contact-options-other-types-popup.component.d.ts +22 -0
- package/lib/component/relation-contact-options/relation-contact-options.component.d.ts +40 -0
- package/lib/component/relation-contact-options/relation-contact-options.module.d.ts +2 -0
- package/lib/component/relation-contact-options/style/_layout.scss +113 -0
- package/lib/component/relation-contact-options/style/_material-definition.scss +35 -0
- package/lib/component/relation-contact-options/style/_theme.scss +48 -0
- package/lib/component/relation-contact-options/style/material.scss +4 -0
- package/lib/component/relation-first-name/relation-first-name.component.d.ts +4 -0
- package/lib/component/relation-first-name/relation-first-name.module.d.ts +2 -0
- package/lib/component/relation-first-name/style/_layout.scss +9 -0
- package/lib/component/relation-first-name/style/_material-definition.scss +3 -0
- package/lib/component/relation-first-name/style/_theme.scss +5 -0
- package/lib/component/relation-first-name/style/material.scss +4 -0
- package/lib/component/relation-gender/relation-gender.component.d.ts +7 -0
- package/lib/component/relation-gender/relation-gender.module.d.ts +2 -0
- package/lib/component/relation-gender/style/_layout.scss +8 -0
- package/lib/component/relation-gender/style/_material-definition.scss +4 -0
- package/lib/component/relation-gender/style/_theme.scss +5 -0
- package/lib/component/relation-gender/style/material.scss +4 -0
- package/lib/component/relation-initials/relation-initials.component.d.ts +4 -0
- package/lib/component/relation-initials/relation-initials.module.d.ts +2 -0
- package/lib/component/relation-initials/style/_layout.scss +9 -0
- package/lib/component/relation-initials/style/_material-definition.scss +3 -0
- package/lib/component/relation-initials/style/_theme.scss +5 -0
- package/lib/component/relation-initials/style/material.scss +4 -0
- package/lib/component/relation-language/relation-language.component.d.ts +12 -0
- package/lib/component/relation-language/relation-language.module.d.ts +2 -0
- package/lib/component/relation-language/style/_layout.scss +9 -0
- package/lib/component/relation-language/style/_material-definition.scss +3 -0
- package/lib/component/relation-language/style/_theme.scss +5 -0
- package/lib/component/relation-language/style/material.scss +4 -0
- package/lib/component/relation-last-name/relation-last-name.component.d.ts +4 -0
- package/lib/component/relation-last-name/relation-last-name.module.d.ts +2 -0
- package/lib/component/relation-last-name/style/_layout.scss +9 -0
- package/lib/component/relation-last-name/style/_material-definition.scss +3 -0
- package/lib/component/relation-last-name/style/_theme.scss +5 -0
- package/lib/component/relation-last-name/style/material.scss +4 -0
- package/lib/component/relation-preferences/relation-preferences.component.d.ts +13 -0
- package/lib/component/relation-preferences/relation-preferences.module.d.ts +2 -0
- package/lib/component/relation-preferences/style/_layout.scss +16 -0
- package/lib/component/relation-preferences/style/_material-definition.scss +8 -0
- package/lib/component/relation-preferences/style/_theme.scss +5 -0
- package/lib/component/relation-preferences/style/material.scss +4 -0
- package/lib/component/relation-prefix-name/relation-prefix-name.component.d.ts +4 -0
- package/lib/component/relation-prefix-name/relation-prefix-name.module.d.ts +2 -0
- package/lib/component/relation-prefix-name/style/_layout.scss +9 -0
- package/lib/component/relation-prefix-name/style/_material-definition.scss +3 -0
- package/lib/component/relation-prefix-name/style/_theme.scss +5 -0
- package/lib/component/relation-prefix-name/style/material.scss +4 -0
- package/lib/component/relation-title/relation-title.component.d.ts +13 -0
- package/lib/component/relation-title/relation-title.module.d.ts +2 -0
- package/lib/component/relation-title/style/_layout.scss +9 -0
- package/lib/component/relation-title/style/_material-definition.scss +3 -0
- package/lib/component/relation-title/style/_theme.scss +5 -0
- package/lib/component/relation-title/style/material.scss +4 -0
- package/lib/enum/icon.enum.d.ts +14 -0
- package/lib/enum/language-code.enum.d.ts +6 -0
- package/lib/enum/relman-cfg-name.enum.d.ts +857 -0
- package/lib/enum/relman-contact-options-cfg-names.d.ts +6 -0
- package/lib/enum/relman-sub-category.enum.d.ts +10 -0
- package/lib/interface/relation-address-cfg-names.interface.d.ts +8 -0
- package/lib/model/icon-svg.d.ts +4 -0
- package/lib/model/relation-settings-options.d.ts +4 -0
- package/lib/model/relation-settings.d.ts +5 -0
- package/lib/relation-version.d.ts +6 -0
- package/lib/res/dictionary/dictionaries.d.ts +17184 -0
- package/lib/service/dictionary.service.d.ts +18 -0
- package/lib/service/error.service.d.ts +11 -0
- package/lib/service/icon-cache.service.d.ts +18 -0
- package/lib/service/relation-base.service.d.ts +64 -0
- package/lib/service/relation-connector-adapter.service.d.ts +66 -0
- package/lib/service/relation-connector.service.d.ts +51 -0
- package/lib/service/relation-event.service.d.ts +6 -0
- package/lib/service/relation-screen-configuration.service.d.ts +13 -0
- package/lib/service/relation-settings.service.d.ts +16 -0
- package/lib/service/relation.service.d.ts +10 -0
- package/lib/style/_mixin.scss +15 -0
- package/lib/style/_variables.scss +15 -0
- package/lib/style/relation-globals.scss +7 -0
- package/lib/translation/relation-dictionary.service.d.ts +19 -0
- package/lib/translation/relation-localize.pipe.d.ts +7 -0
- package/lib/translation/relation-translation.module.d.ts +4 -0
- package/lib/translation/relation-translation.service.d.ts +6 -0
- package/package.json +30 -0
- 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":"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","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
|
package/esm2015/lib/component/relation-contact-options/relation-contact-option-list.component.js
ADDED
|
@@ -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=
|