@ctrl/ngx-emoji-mart 8.2.0 → 9.0.0
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 +39 -14
- package/anchors.component.d.ts +1 -1
- package/category.component.d.ts +1 -1
- package/esm2022/anchors.component.mjs +100 -0
- package/esm2022/category.component.mjs +409 -0
- package/esm2022/emoji-frequently.service.mjs +90 -0
- package/esm2022/emoji-search.service.mjs +178 -0
- package/esm2022/ngx-emoji/emoji.component.mjs +299 -0
- package/esm2022/ngx-emoji/emoji.module.mjs +17 -0
- package/esm2022/ngx-emoji/emoji.service.mjs +145 -0
- package/esm2022/picker.component.mjs +522 -0
- package/esm2022/picker.module.mjs +40 -0
- package/esm2022/preview.component.mjs +206 -0
- package/esm2022/search.component.mjs +175 -0
- package/esm2022/skins.component.mjs +107 -0
- package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart-ngx-emoji.mjs +62 -54
- package/{fesm2015 → fesm2022}/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -1
- package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart.mjs +320 -254
- package/fesm2022/ctrl-ngx-emoji-mart.mjs.map +1 -0
- package/ngx-emoji/emoji.component.d.ts +1 -1
- package/ngx-emoji/emoji.module.d.ts +1 -2
- package/package.json +8 -16
- package/picker.component.d.ts +2 -2
- package/picker.module.d.ts +1 -4
- package/preview.component.d.ts +2 -2
- package/search.component.d.ts +1 -1
- package/skins.component.d.ts +2 -2
- package/esm2020/anchors.component.mjs +0 -83
- package/esm2020/category.component.mjs +0 -386
- package/esm2020/emoji-frequently.service.mjs +0 -88
- package/esm2020/emoji-search.service.mjs +0 -177
- package/esm2020/ngx-emoji/emoji.component.mjs +0 -288
- package/esm2020/ngx-emoji/emoji.module.mjs +0 -18
- package/esm2020/ngx-emoji/emoji.service.mjs +0 -144
- package/esm2020/picker.component.mjs +0 -508
- package/esm2020/picker.module.mjs +0 -49
- package/esm2020/preview.component.mjs +0 -187
- package/esm2020/search.component.mjs +0 -165
- package/esm2020/skins.component.mjs +0 -108
- package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.mjs +0 -34330
- package/fesm2015/ctrl-ngx-emoji-mart.mjs +0 -1763
- package/fesm2015/ctrl-ngx-emoji-mart.mjs.map +0 -1
- package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +0 -1
- package/fesm2020/ctrl-ngx-emoji-mart.mjs.map +0 -1
- /package/{esm2020 → esm2022}/ctrl-ngx-emoji-mart.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/data/categories.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/data/data.interfaces.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/data/emojis.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/data/skins.mjs +0 -0
- /package/{esm2020 → esm2022}/ngx-emoji/index.mjs +0 -0
- /package/{esm2020 → esm2022}/public_api.mjs +0 -0
- /package/{esm2020 → esm2022}/svgs/index.mjs +0 -0
- /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
@@ -0,0 +1,40 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { AnchorsComponent } from './anchors.component';
|
3
|
+
import { CategoryComponent } from './category.component';
|
4
|
+
import { PickerComponent } from './picker.component';
|
5
|
+
import { PreviewComponent } from './preview.component';
|
6
|
+
import { SearchComponent } from './search.component';
|
7
|
+
import { SkinComponent } from './skins.component';
|
8
|
+
import * as i0 from "@angular/core";
|
9
|
+
const components = [
|
10
|
+
PickerComponent,
|
11
|
+
AnchorsComponent,
|
12
|
+
CategoryComponent,
|
13
|
+
SearchComponent,
|
14
|
+
PreviewComponent,
|
15
|
+
SkinComponent,
|
16
|
+
];
|
17
|
+
class PickerModule {
|
18
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PickerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
19
|
+
static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.0.0", ngImport: i0, type: PickerModule, imports: [PickerComponent,
|
20
|
+
AnchorsComponent,
|
21
|
+
CategoryComponent,
|
22
|
+
SearchComponent,
|
23
|
+
PreviewComponent,
|
24
|
+
SkinComponent], exports: [PickerComponent,
|
25
|
+
AnchorsComponent,
|
26
|
+
CategoryComponent,
|
27
|
+
SearchComponent,
|
28
|
+
PreviewComponent,
|
29
|
+
SkinComponent] });
|
30
|
+
static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PickerModule, imports: [components] });
|
31
|
+
}
|
32
|
+
export { PickerModule };
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PickerModule, decorators: [{
|
34
|
+
type: NgModule,
|
35
|
+
args: [{
|
36
|
+
imports: components,
|
37
|
+
exports: components,
|
38
|
+
}]
|
39
|
+
}] });
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcGlja2VyL3BpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQzs7QUFFbEQsTUFBTSxVQUFVLEdBQUc7SUFDakIsZUFBZTtJQUNmLGdCQUFnQjtJQUNoQixpQkFBaUI7SUFDakIsZUFBZTtJQUNmLGdCQUFnQjtJQUNoQixhQUFhO0NBQ2QsQ0FBQztBQUVGLE1BSWEsWUFBWTt1R0FBWixZQUFZO3dHQUFaLFlBQVksWUFadkIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixhQUFhLGFBTGIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixhQUFhO3dHQU9GLFlBQVksWUFIZCxVQUFVOztTQUdSLFlBQVk7MkZBQVosWUFBWTtrQkFKeEIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsVUFBVTtvQkFDbkIsT0FBTyxFQUFFLFVBQVU7aUJBQ3BCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgQW5jaG9yc0NvbXBvbmVudCB9IGZyb20gJy4vYW5jaG9ycy5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2F0ZWdvcnlDb21wb25lbnQgfSBmcm9tICcuL2NhdGVnb3J5LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL3BpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgUHJldmlld0NvbXBvbmVudCB9IGZyb20gJy4vcHJldmlldy5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VhcmNoQ29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2guY29tcG9uZW50JztcbmltcG9ydCB7IFNraW5Db21wb25lbnQgfSBmcm9tICcuL3NraW5zLmNvbXBvbmVudCc7XG5cbmNvbnN0IGNvbXBvbmVudHMgPSBbXG4gIFBpY2tlckNvbXBvbmVudCxcbiAgQW5jaG9yc0NvbXBvbmVudCxcbiAgQ2F0ZWdvcnlDb21wb25lbnQsXG4gIFNlYXJjaENvbXBvbmVudCxcbiAgUHJldmlld0NvbXBvbmVudCxcbiAgU2tpbkNvbXBvbmVudCxcbl07XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IGNvbXBvbmVudHMsXG59KVxuZXhwb3J0IGNsYXNzIFBpY2tlck1vZHVsZSB7fVxuIl19
|
@@ -0,0 +1,206 @@
|
|
1
|
+
import { EmojiComponent } from '@ctrl/ngx-emoji-mart/ngx-emoji';
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
3
|
+
import { CommonModule } from '@angular/common';
|
4
|
+
import { SkinComponent } from './skins.component';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
import * as i1 from "@ctrl/ngx-emoji-mart/ngx-emoji";
|
7
|
+
import * as i2 from "@angular/common";
|
8
|
+
class PreviewComponent {
|
9
|
+
ref;
|
10
|
+
emojiService;
|
11
|
+
title;
|
12
|
+
emoji;
|
13
|
+
idleEmoji;
|
14
|
+
i18n;
|
15
|
+
emojiIsNative;
|
16
|
+
emojiSkin;
|
17
|
+
emojiSize;
|
18
|
+
emojiSet;
|
19
|
+
emojiSheetSize;
|
20
|
+
emojiBackgroundImageFn;
|
21
|
+
emojiImageUrlFn;
|
22
|
+
skinChange = new EventEmitter();
|
23
|
+
emojiData = {};
|
24
|
+
listedEmoticons;
|
25
|
+
constructor(ref, emojiService) {
|
26
|
+
this.ref = ref;
|
27
|
+
this.emojiService = emojiService;
|
28
|
+
}
|
29
|
+
ngOnChanges() {
|
30
|
+
if (!this.emoji) {
|
31
|
+
return;
|
32
|
+
}
|
33
|
+
this.emojiData = this.emojiService.getData(this.emoji, this.emojiSkin, this.emojiSet);
|
34
|
+
const knownEmoticons = [];
|
35
|
+
const listedEmoticons = [];
|
36
|
+
const emoitcons = this.emojiData.emoticons || [];
|
37
|
+
emoitcons.forEach((emoticon) => {
|
38
|
+
if (knownEmoticons.indexOf(emoticon.toLowerCase()) >= 0) {
|
39
|
+
return;
|
40
|
+
}
|
41
|
+
knownEmoticons.push(emoticon.toLowerCase());
|
42
|
+
listedEmoticons.push(emoticon);
|
43
|
+
});
|
44
|
+
this.listedEmoticons = listedEmoticons;
|
45
|
+
this.ref?.detectChanges();
|
46
|
+
}
|
47
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PreviewComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EmojiService }], target: i0.ɵɵFactoryTarget.Component });
|
48
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: PreviewComponent, isStandalone: true, selector: "emoji-preview", inputs: { title: "title", emoji: "emoji", idleEmoji: "idleEmoji", i18n: "i18n", emojiIsNative: "emojiIsNative", emojiSkin: "emojiSkin", emojiSize: "emojiSize", emojiSet: "emojiSet", emojiSheetSize: "emojiSheetSize", emojiBackgroundImageFn: "emojiBackgroundImageFn", emojiImageUrlFn: "emojiImageUrlFn" }, outputs: { skinChange: "skinChange" }, usesOnChanges: true, ngImport: i0, template: `
|
49
|
+
<div class="emoji-mart-preview" *ngIf="emoji && emojiData">
|
50
|
+
<div class="emoji-mart-preview-emoji">
|
51
|
+
<ngx-emoji
|
52
|
+
[emoji]="emoji"
|
53
|
+
[size]="38"
|
54
|
+
[isNative]="emojiIsNative"
|
55
|
+
[skin]="emojiSkin"
|
56
|
+
[size]="emojiSize"
|
57
|
+
[set]="emojiSet"
|
58
|
+
[sheetSize]="emojiSheetSize"
|
59
|
+
[backgroundImageFn]="emojiBackgroundImageFn"
|
60
|
+
[imageUrlFn]="emojiImageUrlFn"
|
61
|
+
></ngx-emoji>
|
62
|
+
</div>
|
63
|
+
|
64
|
+
<div class="emoji-mart-preview-data">
|
65
|
+
<div class="emoji-mart-preview-name">{{ emojiData.name }}</div>
|
66
|
+
<div class="emoji-mart-preview-shortname">
|
67
|
+
<span
|
68
|
+
class="emoji-mart-preview-shortname"
|
69
|
+
*ngFor="let short_name of emojiData.shortNames"
|
70
|
+
>
|
71
|
+
:{{ short_name }}:
|
72
|
+
</span>
|
73
|
+
</div>
|
74
|
+
<div class="emoji-mart-preview-emoticons">
|
75
|
+
<span class="emoji-mart-preview-emoticon" *ngFor="let emoticon of listedEmoticons">
|
76
|
+
{{ emoticon }}
|
77
|
+
</span>
|
78
|
+
</div>
|
79
|
+
</div>
|
80
|
+
</div>
|
81
|
+
|
82
|
+
<div class="emoji-mart-preview" [hidden]="emoji">
|
83
|
+
<div class="emoji-mart-preview-emoji">
|
84
|
+
<ngx-emoji
|
85
|
+
*ngIf="idleEmoji && idleEmoji.length"
|
86
|
+
[isNative]="emojiIsNative"
|
87
|
+
[skin]="emojiSkin"
|
88
|
+
[set]="emojiSet"
|
89
|
+
[emoji]="idleEmoji"
|
90
|
+
[backgroundImageFn]="emojiBackgroundImageFn"
|
91
|
+
[size]="38"
|
92
|
+
[imageUrlFn]="emojiImageUrlFn"
|
93
|
+
></ngx-emoji>
|
94
|
+
</div>
|
95
|
+
|
96
|
+
<div class="emoji-mart-preview-data">
|
97
|
+
<span class="emoji-mart-title-label">{{ title }}</span>
|
98
|
+
</div>
|
99
|
+
|
100
|
+
<div class="emoji-mart-preview-skins">
|
101
|
+
<emoji-skins
|
102
|
+
[skin]="emojiSkin"
|
103
|
+
(changeSkin)="skinChange.emit($event)"
|
104
|
+
[i18n]="i18n"
|
105
|
+
></emoji-skins>
|
106
|
+
</div>
|
107
|
+
</div>
|
108
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: EmojiComponent, selector: "ngx-emoji", inputs: ["skin", "set", "sheetSize", "isNative", "forceSize", "tooltip", "size", "emoji", "fallback", "hideObsolete", "sheetRows", "sheetColumns", "useButton", "backgroundImageFn", "imageUrlFn"], outputs: ["emojiClick", "emojiOver", "emojiOverOutsideAngular", "emojiLeave", "emojiLeaveOutsideAngular"] }, { kind: "component", type: SkinComponent, selector: "emoji-skins", inputs: ["skin", "i18n"], outputs: ["changeSkin"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
109
|
+
}
|
110
|
+
export { PreviewComponent };
|
111
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: PreviewComponent, decorators: [{
|
112
|
+
type: Component,
|
113
|
+
args: [{
|
114
|
+
selector: 'emoji-preview',
|
115
|
+
template: `
|
116
|
+
<div class="emoji-mart-preview" *ngIf="emoji && emojiData">
|
117
|
+
<div class="emoji-mart-preview-emoji">
|
118
|
+
<ngx-emoji
|
119
|
+
[emoji]="emoji"
|
120
|
+
[size]="38"
|
121
|
+
[isNative]="emojiIsNative"
|
122
|
+
[skin]="emojiSkin"
|
123
|
+
[size]="emojiSize"
|
124
|
+
[set]="emojiSet"
|
125
|
+
[sheetSize]="emojiSheetSize"
|
126
|
+
[backgroundImageFn]="emojiBackgroundImageFn"
|
127
|
+
[imageUrlFn]="emojiImageUrlFn"
|
128
|
+
></ngx-emoji>
|
129
|
+
</div>
|
130
|
+
|
131
|
+
<div class="emoji-mart-preview-data">
|
132
|
+
<div class="emoji-mart-preview-name">{{ emojiData.name }}</div>
|
133
|
+
<div class="emoji-mart-preview-shortname">
|
134
|
+
<span
|
135
|
+
class="emoji-mart-preview-shortname"
|
136
|
+
*ngFor="let short_name of emojiData.shortNames"
|
137
|
+
>
|
138
|
+
:{{ short_name }}:
|
139
|
+
</span>
|
140
|
+
</div>
|
141
|
+
<div class="emoji-mart-preview-emoticons">
|
142
|
+
<span class="emoji-mart-preview-emoticon" *ngFor="let emoticon of listedEmoticons">
|
143
|
+
{{ emoticon }}
|
144
|
+
</span>
|
145
|
+
</div>
|
146
|
+
</div>
|
147
|
+
</div>
|
148
|
+
|
149
|
+
<div class="emoji-mart-preview" [hidden]="emoji">
|
150
|
+
<div class="emoji-mart-preview-emoji">
|
151
|
+
<ngx-emoji
|
152
|
+
*ngIf="idleEmoji && idleEmoji.length"
|
153
|
+
[isNative]="emojiIsNative"
|
154
|
+
[skin]="emojiSkin"
|
155
|
+
[set]="emojiSet"
|
156
|
+
[emoji]="idleEmoji"
|
157
|
+
[backgroundImageFn]="emojiBackgroundImageFn"
|
158
|
+
[size]="38"
|
159
|
+
[imageUrlFn]="emojiImageUrlFn"
|
160
|
+
></ngx-emoji>
|
161
|
+
</div>
|
162
|
+
|
163
|
+
<div class="emoji-mart-preview-data">
|
164
|
+
<span class="emoji-mart-title-label">{{ title }}</span>
|
165
|
+
</div>
|
166
|
+
|
167
|
+
<div class="emoji-mart-preview-skins">
|
168
|
+
<emoji-skins
|
169
|
+
[skin]="emojiSkin"
|
170
|
+
(changeSkin)="skinChange.emit($event)"
|
171
|
+
[i18n]="i18n"
|
172
|
+
></emoji-skins>
|
173
|
+
</div>
|
174
|
+
</div>
|
175
|
+
`,
|
176
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
177
|
+
preserveWhitespaces: false,
|
178
|
+
standalone: true,
|
179
|
+
imports: [CommonModule, EmojiComponent, SkinComponent],
|
180
|
+
}]
|
181
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.EmojiService }]; }, propDecorators: { title: [{
|
182
|
+
type: Input
|
183
|
+
}], emoji: [{
|
184
|
+
type: Input
|
185
|
+
}], idleEmoji: [{
|
186
|
+
type: Input
|
187
|
+
}], i18n: [{
|
188
|
+
type: Input
|
189
|
+
}], emojiIsNative: [{
|
190
|
+
type: Input
|
191
|
+
}], emojiSkin: [{
|
192
|
+
type: Input
|
193
|
+
}], emojiSize: [{
|
194
|
+
type: Input
|
195
|
+
}], emojiSet: [{
|
196
|
+
type: Input
|
197
|
+
}], emojiSheetSize: [{
|
198
|
+
type: Input
|
199
|
+
}], emojiBackgroundImageFn: [{
|
200
|
+
type: Input
|
201
|
+
}], emojiImageUrlFn: [{
|
202
|
+
type: Input
|
203
|
+
}], skinChange: [{
|
204
|
+
type: Output
|
205
|
+
}] } });
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview.component.js","sourceRoot":"","sources":["../../src/lib/picker/preview.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAS,cAAc,EAA2B,MAAM,gCAAgC,CAAC;AAChG,OAAO,EACL,uBAAuB,EAEvB,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;;;;AAElD,MAoEa,gBAAgB;IAgBR;IAAgC;IAf1C,KAAK,CAAU;IACf,KAAK,CAAM;IACX,SAAS,CAAM;IACf,IAAI,CAAM;IACV,aAAa,CAAqB;IAClC,SAAS,CAAiB;IAC1B,SAAS,CAAiB;IAC1B,QAAQ,CAAgB;IACxB,cAAc,CAAsB;IACpC,sBAAsB,CAA8B;IACpD,eAAe,CAAuB;IACrC,UAAU,GAAG,IAAI,YAAY,EAAiB,CAAC;IACzD,SAAS,GAAuB,EAAE,CAAC;IACnC,eAAe,CAAY;IAE3B,YAAmB,GAAsB,EAAU,YAA0B;QAA1D,QAAG,GAAH,GAAG,CAAmB;QAAU,iBAAY,GAAZ,YAAY,CAAc;IAAG,CAAC;IAEjF,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACf,OAAO;SACR;QACD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CACxC,IAAI,CAAC,KAAK,EACV,IAAI,CAAC,SAAS,EACd,IAAI,CAAC,QAAQ,CACD,CAAC;QACf,MAAM,cAAc,GAAa,EAAE,CAAC;QACpC,MAAM,eAAe,GAAa,EAAE,CAAC;QACrC,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,SAAS,IAAI,EAAE,CAAC;QACjD,SAAS,CAAC,OAAO,CAAC,CAAC,QAAgB,EAAE,EAAE;YACrC,IAAI,cAAc,CAAC,OAAO,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE;gBACvD,OAAO;aACR;YACD,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,CAAC;YAC5C,eAAe,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;QACvC,IAAI,CAAC,GAAG,EAAE,aAAa,EAAE,CAAC;IAC5B,CAAC;uGAvCU,gBAAgB;2FAAhB,gBAAgB,qbAlEjB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4DT,2DAIS,YAAY,gQAAE,cAAc,qWAAE,aAAa;;SAE1C,gBAAgB;2FAAhB,gBAAgB;kBApE5B,SAAS;mBAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4DT;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,mBAAmB,EAAE,KAAK;oBAC1B,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,YAAY,EAAE,cAAc,EAAE,aAAa,CAAC;iBACvD;mIAEU,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACI,UAAU;sBAAnB,MAAM","sourcesContent":["import { Emoji, EmojiComponent, EmojiData, EmojiService } from '@ctrl/ngx-emoji-mart/ngx-emoji';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnChanges,\n  Output,\n} from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nimport { SkinComponent } from './skins.component';\n\n@Component({\n  selector: 'emoji-preview',\n  template: `\n    <div class=\"emoji-mart-preview\" *ngIf=\"emoji && emojiData\">\n      <div class=\"emoji-mart-preview-emoji\">\n        <ngx-emoji\n          [emoji]=\"emoji\"\n          [size]=\"38\"\n          [isNative]=\"emojiIsNative\"\n          [skin]=\"emojiSkin\"\n          [size]=\"emojiSize\"\n          [set]=\"emojiSet\"\n          [sheetSize]=\"emojiSheetSize\"\n          [backgroundImageFn]=\"emojiBackgroundImageFn\"\n          [imageUrlFn]=\"emojiImageUrlFn\"\n        ></ngx-emoji>\n      </div>\n\n      <div class=\"emoji-mart-preview-data\">\n        <div class=\"emoji-mart-preview-name\">{{ emojiData.name }}</div>\n        <div class=\"emoji-mart-preview-shortname\">\n          <span\n            class=\"emoji-mart-preview-shortname\"\n            *ngFor=\"let short_name of emojiData.shortNames\"\n          >\n            :{{ short_name }}:\n          </span>\n        </div>\n        <div class=\"emoji-mart-preview-emoticons\">\n          <span class=\"emoji-mart-preview-emoticon\" *ngFor=\"let emoticon of listedEmoticons\">\n            {{ emoticon }}\n          </span>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"emoji-mart-preview\" [hidden]=\"emoji\">\n      <div class=\"emoji-mart-preview-emoji\">\n        <ngx-emoji\n          *ngIf=\"idleEmoji && idleEmoji.length\"\n          [isNative]=\"emojiIsNative\"\n          [skin]=\"emojiSkin\"\n          [set]=\"emojiSet\"\n          [emoji]=\"idleEmoji\"\n          [backgroundImageFn]=\"emojiBackgroundImageFn\"\n          [size]=\"38\"\n          [imageUrlFn]=\"emojiImageUrlFn\"\n        ></ngx-emoji>\n      </div>\n\n      <div class=\"emoji-mart-preview-data\">\n        <span class=\"emoji-mart-title-label\">{{ title }}</span>\n      </div>\n\n      <div class=\"emoji-mart-preview-skins\">\n        <emoji-skins\n          [skin]=\"emojiSkin\"\n          (changeSkin)=\"skinChange.emit($event)\"\n          [i18n]=\"i18n\"\n        ></emoji-skins>\n      </div>\n    </div>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n  standalone: true,\n  imports: [CommonModule, EmojiComponent, SkinComponent],\n})\nexport class PreviewComponent implements OnChanges {\n  @Input() title?: string;\n  @Input() emoji: any;\n  @Input() idleEmoji: any;\n  @Input() i18n: any;\n  @Input() emojiIsNative?: Emoji['isNative'];\n  @Input() emojiSkin?: Emoji['skin'];\n  @Input() emojiSize?: Emoji['size'];\n  @Input() emojiSet?: Emoji['set'];\n  @Input() emojiSheetSize?: Emoji['sheetSize'];\n  @Input() emojiBackgroundImageFn?: Emoji['backgroundImageFn'];\n  @Input() emojiImageUrlFn?: Emoji['imageUrlFn'];\n  @Output() skinChange = new EventEmitter<Emoji['skin']>();\n  emojiData: Partial<EmojiData> = {};\n  listedEmoticons?: string[];\n\n  constructor(public ref: ChangeDetectorRef, private emojiService: EmojiService) {}\n\n  ngOnChanges() {\n    if (!this.emoji) {\n      return;\n    }\n    this.emojiData = this.emojiService.getData(\n      this.emoji,\n      this.emojiSkin,\n      this.emojiSet,\n    ) as EmojiData;\n    const knownEmoticons: string[] = [];\n    const listedEmoticons: string[] = [];\n    const emoitcons = this.emojiData.emoticons || [];\n    emoitcons.forEach((emoticon: string) => {\n      if (knownEmoticons.indexOf(emoticon.toLowerCase()) >= 0) {\n        return;\n      }\n      knownEmoticons.push(emoticon.toLowerCase());\n      listedEmoticons.push(emoticon);\n    });\n    this.listedEmoticons = listedEmoticons;\n    this.ref?.detectChanges();\n  }\n}\n"]}
|
@@ -0,0 +1,175 @@
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
2
|
+
import { FormsModule } from '@angular/forms';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "./emoji-search.service";
|
5
|
+
import * as i2 from "@angular/forms";
|
6
|
+
let id = 0;
|
7
|
+
class SearchComponent {
|
8
|
+
emojiSearch;
|
9
|
+
maxResults = 75;
|
10
|
+
autoFocus = false;
|
11
|
+
i18n;
|
12
|
+
include = [];
|
13
|
+
exclude = [];
|
14
|
+
custom = [];
|
15
|
+
icons;
|
16
|
+
emojisToShowFilter;
|
17
|
+
searchResults = new EventEmitter();
|
18
|
+
enterKey = new EventEmitter();
|
19
|
+
inputRef;
|
20
|
+
isSearching = false;
|
21
|
+
icon;
|
22
|
+
query = '';
|
23
|
+
inputId = `emoji-mart-search-${++id}`;
|
24
|
+
constructor(emojiSearch) {
|
25
|
+
this.emojiSearch = emojiSearch;
|
26
|
+
}
|
27
|
+
ngOnInit() {
|
28
|
+
this.icon = this.icons.search;
|
29
|
+
}
|
30
|
+
ngAfterViewInit() {
|
31
|
+
if (this.autoFocus) {
|
32
|
+
this.inputRef.nativeElement.focus();
|
33
|
+
}
|
34
|
+
}
|
35
|
+
clear() {
|
36
|
+
this.query = '';
|
37
|
+
this.handleSearch('');
|
38
|
+
this.inputRef.nativeElement.focus();
|
39
|
+
}
|
40
|
+
handleEnterKey($event) {
|
41
|
+
if (!this.query) {
|
42
|
+
return;
|
43
|
+
}
|
44
|
+
this.enterKey.emit($event);
|
45
|
+
$event.preventDefault();
|
46
|
+
}
|
47
|
+
handleSearch(value) {
|
48
|
+
if (value === '') {
|
49
|
+
this.icon = this.icons.search;
|
50
|
+
this.isSearching = false;
|
51
|
+
}
|
52
|
+
else {
|
53
|
+
this.icon = this.icons.delete;
|
54
|
+
this.isSearching = true;
|
55
|
+
}
|
56
|
+
const emojis = this.emojiSearch.search(this.query, this.emojisToShowFilter, this.maxResults, this.include, this.exclude, this.custom);
|
57
|
+
this.searchResults.emit(emojis);
|
58
|
+
}
|
59
|
+
handleChange() {
|
60
|
+
this.handleSearch(this.query);
|
61
|
+
}
|
62
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SearchComponent, deps: [{ token: i1.EmojiSearch }], target: i0.ɵɵFactoryTarget.Component });
|
63
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: SearchComponent, isStandalone: true, selector: "emoji-search", inputs: { maxResults: "maxResults", autoFocus: "autoFocus", i18n: "i18n", include: "include", exclude: "exclude", custom: "custom", icons: "icons", emojisToShowFilter: "emojisToShowFilter" }, outputs: { searchResults: "searchResults", enterKey: "enterKey" }, viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true, static: true }], ngImport: i0, template: `
|
64
|
+
<div class="emoji-mart-search">
|
65
|
+
<input
|
66
|
+
[id]="inputId"
|
67
|
+
#inputRef
|
68
|
+
type="search"
|
69
|
+
(keyup.enter)="handleEnterKey($event)"
|
70
|
+
[placeholder]="i18n.search"
|
71
|
+
[autofocus]="autoFocus"
|
72
|
+
[(ngModel)]="query"
|
73
|
+
(ngModelChange)="handleChange()"
|
74
|
+
/>
|
75
|
+
<!--
|
76
|
+
Use a <label> in addition to the placeholder for accessibility, but place it off-screen
|
77
|
+
http://www.maxability.co.in/2016/01/placeholder-attribute-and-why-it-is-not-accessible/
|
78
|
+
-->
|
79
|
+
<label class="emoji-mart-sr-only" [htmlFor]="inputId">
|
80
|
+
{{ i18n.search }}
|
81
|
+
</label>
|
82
|
+
<button
|
83
|
+
type="button"
|
84
|
+
class="emoji-mart-search-icon"
|
85
|
+
(click)="clear()"
|
86
|
+
(keyup.enter)="clear()"
|
87
|
+
[disabled]="!isSearching"
|
88
|
+
[attr.aria-label]="i18n.clear"
|
89
|
+
>
|
90
|
+
<svg
|
91
|
+
xmlns="http://www.w3.org/2000/svg"
|
92
|
+
viewBox="0 0 20 20"
|
93
|
+
width="13"
|
94
|
+
height="13"
|
95
|
+
opacity="0.5"
|
96
|
+
>
|
97
|
+
<path [attr.d]="icon" />
|
98
|
+
</svg>
|
99
|
+
</button>
|
100
|
+
</div>
|
101
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
|
102
|
+
}
|
103
|
+
export { SearchComponent };
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SearchComponent, decorators: [{
|
105
|
+
type: Component,
|
106
|
+
args: [{
|
107
|
+
selector: 'emoji-search',
|
108
|
+
template: `
|
109
|
+
<div class="emoji-mart-search">
|
110
|
+
<input
|
111
|
+
[id]="inputId"
|
112
|
+
#inputRef
|
113
|
+
type="search"
|
114
|
+
(keyup.enter)="handleEnterKey($event)"
|
115
|
+
[placeholder]="i18n.search"
|
116
|
+
[autofocus]="autoFocus"
|
117
|
+
[(ngModel)]="query"
|
118
|
+
(ngModelChange)="handleChange()"
|
119
|
+
/>
|
120
|
+
<!--
|
121
|
+
Use a <label> in addition to the placeholder for accessibility, but place it off-screen
|
122
|
+
http://www.maxability.co.in/2016/01/placeholder-attribute-and-why-it-is-not-accessible/
|
123
|
+
-->
|
124
|
+
<label class="emoji-mart-sr-only" [htmlFor]="inputId">
|
125
|
+
{{ i18n.search }}
|
126
|
+
</label>
|
127
|
+
<button
|
128
|
+
type="button"
|
129
|
+
class="emoji-mart-search-icon"
|
130
|
+
(click)="clear()"
|
131
|
+
(keyup.enter)="clear()"
|
132
|
+
[disabled]="!isSearching"
|
133
|
+
[attr.aria-label]="i18n.clear"
|
134
|
+
>
|
135
|
+
<svg
|
136
|
+
xmlns="http://www.w3.org/2000/svg"
|
137
|
+
viewBox="0 0 20 20"
|
138
|
+
width="13"
|
139
|
+
height="13"
|
140
|
+
opacity="0.5"
|
141
|
+
>
|
142
|
+
<path [attr.d]="icon" />
|
143
|
+
</svg>
|
144
|
+
</button>
|
145
|
+
</div>
|
146
|
+
`,
|
147
|
+
preserveWhitespaces: false,
|
148
|
+
standalone: true,
|
149
|
+
imports: [FormsModule],
|
150
|
+
}]
|
151
|
+
}], ctorParameters: function () { return [{ type: i1.EmojiSearch }]; }, propDecorators: { maxResults: [{
|
152
|
+
type: Input
|
153
|
+
}], autoFocus: [{
|
154
|
+
type: Input
|
155
|
+
}], i18n: [{
|
156
|
+
type: Input
|
157
|
+
}], include: [{
|
158
|
+
type: Input
|
159
|
+
}], exclude: [{
|
160
|
+
type: Input
|
161
|
+
}], custom: [{
|
162
|
+
type: Input
|
163
|
+
}], icons: [{
|
164
|
+
type: Input
|
165
|
+
}], emojisToShowFilter: [{
|
166
|
+
type: Input
|
167
|
+
}], searchResults: [{
|
168
|
+
type: Output
|
169
|
+
}], enterKey: [{
|
170
|
+
type: Output
|
171
|
+
}], inputRef: [{
|
172
|
+
type: ViewChild,
|
173
|
+
args: ['inputRef', { static: true }]
|
174
|
+
}] } });
|
175
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcGlja2VyL3NlYXJjaC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVMLFNBQVMsRUFFVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFDTixTQUFTLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7O0FBSTdDLElBQUksRUFBRSxHQUFHLENBQUMsQ0FBQztBQUVYLE1BNkNhLGVBQWU7SUFpQk47SUFoQlgsVUFBVSxHQUFHLEVBQUUsQ0FBQztJQUNoQixTQUFTLEdBQUcsS0FBSyxDQUFDO0lBQ2xCLElBQUksQ0FBTTtJQUNWLE9BQU8sR0FBYSxFQUFFLENBQUM7SUFDdkIsT0FBTyxHQUFhLEVBQUUsQ0FBQztJQUN2QixNQUFNLEdBQVUsRUFBRSxDQUFDO0lBQ25CLEtBQUssQ0FBNkI7SUFDbEMsa0JBQWtCLENBQXVCO0lBQ3hDLGFBQWEsR0FBRyxJQUFJLFlBQVksRUFBUyxDQUFDO0lBQzFDLFFBQVEsR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0lBQ0ksUUFBUSxDQUFjO0lBQ3ZFLFdBQVcsR0FBRyxLQUFLLENBQUM7SUFDcEIsSUFBSSxDQUFVO0lBQ2QsS0FBSyxHQUFHLEVBQUUsQ0FBQztJQUNYLE9BQU8sR0FBRyxxQkFBcUIsRUFBRSxFQUFFLEVBQUUsQ0FBQztJQUV0QyxZQUFvQixXQUF3QjtRQUF4QixnQkFBVyxHQUFYLFdBQVcsQ0FBYTtJQUFHLENBQUM7SUFFaEQsUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUM7SUFDaEMsQ0FBQztJQUNELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDbEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDckM7SUFDSCxDQUFDO0lBQ0QsS0FBSztRQUNILElBQUksQ0FBQyxLQUFLLEdBQUcsRUFBRSxDQUFDO1FBQ2hCLElBQUksQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUFDLENBQUM7UUFDdEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDdEMsQ0FBQztJQUNELGNBQWMsQ0FBQyxNQUFhO1FBQzFCLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQ2YsT0FBTztTQUNSO1FBQ0QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDM0IsTUFBTSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFDRCxZQUFZLENBQUMsS0FBYTtRQUN4QixJQUFJLEtBQUssS0FBSyxFQUFFLEVBQUU7WUFDaEIsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQztZQUM5QixJQUFJLENBQUMsV0FBVyxHQUFHLEtBQUssQ0FBQztTQUMxQjthQUFNO1lBQ0wsSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQztZQUM5QixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztTQUN6QjtRQUNELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUNwQyxJQUFJLENBQUMsS0FBSyxFQUNWLElBQUksQ0FBQyxrQkFBa0IsRUFDdkIsSUFBSSxDQUFDLFVBQVUsRUFDZixJQUFJLENBQUMsT0FBTyxFQUNaLElBQUksQ0FBQyxPQUFPLEVBQ1osSUFBSSxDQUFDLE1BQU0sQ0FDSCxDQUFDO1FBQ1gsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUNELFlBQVk7UUFDVixJQUFJLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNoQyxDQUFDO3VHQTNEVSxlQUFlOzJGQUFmLGVBQWUsK2JBM0NoQjs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FzQ1QsMkRBR1MsV0FBVzs7U0FFVixlQUFlOzJGQUFmLGVBQWU7a0JBN0MzQixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO29CQUN4QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBc0NUO29CQUNELG1CQUFtQixFQUFFLEtBQUs7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxXQUFXLENBQUM7aUJBQ3ZCO2tHQUVVLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDSSxhQUFhO3NCQUF0QixNQUFNO2dCQUNHLFFBQVE7c0JBQWpCLE1BQU07Z0JBQzBDLFFBQVE7c0JBQXhELFNBQVM7dUJBQUMsVUFBVSxFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEFmdGVyVmlld0luaXQsXG4gIENvbXBvbmVudCxcbiAgRWxlbWVudFJlZixcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG4gIFZpZXdDaGlsZCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHsgRW1vamlTZWFyY2ggfSBmcm9tICcuL2Vtb2ppLXNlYXJjaC5zZXJ2aWNlJztcblxubGV0IGlkID0gMDtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW1vamktc2VhcmNoJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8ZGl2IGNsYXNzPVwiZW1vamktbWFydC1zZWFyY2hcIj5cbiAgICAgIDxpbnB1dFxuICAgICAgICBbaWRdPVwiaW5wdXRJZFwiXG4gICAgICAgICNpbnB1dFJlZlxuICAgICAgICB0eXBlPVwic2VhcmNoXCJcbiAgICAgICAgKGtleXVwLmVudGVyKT1cImhhbmRsZUVudGVyS2V5KCRldmVudClcIlxuICAgICAgICBbcGxhY2Vob2xkZXJdPVwiaTE4bi5zZWFyY2hcIlxuICAgICAgICBbYXV0b2ZvY3VzXT1cImF1dG9Gb2N1c1wiXG4gICAgICAgIFsobmdNb2RlbCldPVwicXVlcnlcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJoYW5kbGVDaGFuZ2UoKVwiXG4gICAgICAvPlxuICAgICAgPCEtLVxuICAgICAgVXNlIGEgPGxhYmVsPiBpbiBhZGRpdGlvbiB0byB0aGUgcGxhY2Vob2xkZXIgZm9yIGFjY2Vzc2liaWxpdHksIGJ1dCBwbGFjZSBpdCBvZmYtc2NyZWVuXG4gICAgICBodHRwOi8vd3d3Lm1heGFiaWxpdHkuY28uaW4vMjAxNi8wMS9wbGFjZWhvbGRlci1hdHRyaWJ1dGUtYW5kLXdoeS1pdC1pcy1ub3QtYWNjZXNzaWJsZS9cbiAgICAgIC0tPlxuICAgICAgPGxhYmVsIGNsYXNzPVwiZW1vamktbWFydC1zci1vbmx5XCIgW2h0bWxGb3JdPVwiaW5wdXRJZFwiPlxuICAgICAgICB7eyBpMThuLnNlYXJjaCB9fVxuICAgICAgPC9sYWJlbD5cbiAgICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIGNsYXNzPVwiZW1vamktbWFydC1zZWFyY2gtaWNvblwiXG4gICAgICAgIChjbGljayk9XCJjbGVhcigpXCJcbiAgICAgICAgKGtleXVwLmVudGVyKT1cImNsZWFyKClcIlxuICAgICAgICBbZGlzYWJsZWRdPVwiIWlzU2VhcmNoaW5nXCJcbiAgICAgICAgW2F0dHIuYXJpYS1sYWJlbF09XCJpMThuLmNsZWFyXCJcbiAgICAgID5cbiAgICAgICAgPHN2Z1xuICAgICAgICAgIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIlxuICAgICAgICAgIHZpZXdCb3g9XCIwIDAgMjAgMjBcIlxuICAgICAgICAgIHdpZHRoPVwiMTNcIlxuICAgICAgICAgIGhlaWdodD1cIjEzXCJcbiAgICAgICAgICBvcGFjaXR5PVwiMC41XCJcbiAgICAgICAgPlxuICAgICAgICAgIDxwYXRoIFthdHRyLmRdPVwiaWNvblwiIC8+XG4gICAgICAgIDwvc3ZnPlxuICAgICAgPC9idXR0b24+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbRm9ybXNNb2R1bGVdLFxufSlcbmV4cG9ydCBjbGFzcyBTZWFyY2hDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkluaXQge1xuICBASW5wdXQoKSBtYXhSZXN1bHRzID0gNzU7XG4gIEBJbnB1dCgpIGF1dG9Gb2N1cyA9IGZhbHNlO1xuICBASW5wdXQoKSBpMThuOiBhbnk7XG4gIEBJbnB1dCgpIGluY2x1ZGU6IHN0cmluZ1tdID0gW107XG4gIEBJbnB1dCgpIGV4Y2x1ZGU6IHN0cmluZ1tdID0gW107XG4gIEBJbnB1dCgpIGN1c3RvbTogYW55W10gPSBbXTtcbiAgQElucHV0KCkgaWNvbnMhOiB7IFtrZXk6IHN0cmluZ106IHN0cmluZyB9O1xuICBASW5wdXQoKSBlbW9qaXNUb1Nob3dGaWx0ZXI/OiAoeDogYW55KSA9PiBib29sZWFuO1xuICBAT3V0cHV0KCkgc2VhcmNoUmVzdWx0cyA9IG5ldyBFdmVudEVtaXR0ZXI8YW55W10+KCk7XG4gIEBPdXRwdXQoKSBlbnRlcktleSA9IG5ldyBFdmVudEVtaXR0ZXI8YW55PigpO1xuICBAVmlld0NoaWxkKCdpbnB1dFJlZicsIHsgc3RhdGljOiB0cnVlIH0pIHByaXZhdGUgaW5wdXRSZWYhOiBFbGVtZW50UmVmO1xuICBpc1NlYXJjaGluZyA9IGZhbHNlO1xuICBpY29uPzogc3RyaW5nO1xuICBxdWVyeSA9ICcnO1xuICBpbnB1dElkID0gYGVtb2ppLW1hcnQtc2VhcmNoLSR7KytpZH1gO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZW1vamlTZWFyY2g6IEVtb2ppU2VhcmNoKSB7fVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuaWNvbiA9IHRoaXMuaWNvbnMuc2VhcmNoO1xuICB9XG4gIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICBpZiAodGhpcy5hdXRvRm9jdXMpIHtcbiAgICAgIHRoaXMuaW5wdXRSZWYubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICAgIH1cbiAgfVxuICBjbGVhcigpIHtcbiAgICB0aGlzLnF1ZXJ5ID0gJyc7XG4gICAgdGhpcy5oYW5kbGVTZWFyY2goJycpO1xuICAgIHRoaXMuaW5wdXRSZWYubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICB9XG4gIGhhbmRsZUVudGVyS2V5KCRldmVudDogRXZlbnQpIHtcbiAgICBpZiAoIXRoaXMucXVlcnkpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgdGhpcy5lbnRlcktleS5lbWl0KCRldmVudCk7XG4gICAgJGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gIH1cbiAgaGFuZGxlU2VhcmNoKHZhbHVlOiBzdHJpbmcpIHtcbiAgICBpZiAodmFsdWUgPT09ICcnKSB7XG4gICAgICB0aGlzLmljb24gPSB0aGlzLmljb25zLnNlYXJjaDtcbiAgICAgIHRoaXMuaXNTZWFyY2hpbmcgPSBmYWxzZTtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5pY29uID0gdGhpcy5pY29ucy5kZWxldGU7XG4gICAgICB0aGlzLmlzU2VhcmNoaW5nID0gdHJ1ZTtcbiAgICB9XG4gICAgY29uc3QgZW1vamlzID0gdGhpcy5lbW9qaVNlYXJjaC5zZWFyY2goXG4gICAgICB0aGlzLnF1ZXJ5LFxuICAgICAgdGhpcy5lbW9qaXNUb1Nob3dGaWx0ZXIsXG4gICAgICB0aGlzLm1heFJlc3VsdHMsXG4gICAgICB0aGlzLmluY2x1ZGUsXG4gICAgICB0aGlzLmV4Y2x1ZGUsXG4gICAgICB0aGlzLmN1c3RvbSxcbiAgICApIGFzIGFueVtdO1xuICAgIHRoaXMuc2VhcmNoUmVzdWx0cy5lbWl0KGVtb2ppcyk7XG4gIH1cbiAgaGFuZGxlQ2hhbmdlKCkge1xuICAgIHRoaXMuaGFuZGxlU2VhcmNoKHRoaXMucXVlcnkpO1xuICB9XG59XG4iXX0=
|
@@ -0,0 +1,107 @@
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
3
|
+
import * as i0 from "@angular/core";
|
4
|
+
import * as i1 from "@angular/common";
|
5
|
+
class SkinComponent {
|
6
|
+
/** currently selected skin */
|
7
|
+
skin;
|
8
|
+
i18n;
|
9
|
+
changeSkin = new EventEmitter();
|
10
|
+
opened = false;
|
11
|
+
skinTones = [1, 2, 3, 4, 5, 6];
|
12
|
+
toggleOpen() {
|
13
|
+
this.opened = !this.opened;
|
14
|
+
}
|
15
|
+
isSelected(skinTone) {
|
16
|
+
return skinTone === this.skin;
|
17
|
+
}
|
18
|
+
isVisible(skinTone) {
|
19
|
+
return this.opened || this.isSelected(skinTone);
|
20
|
+
}
|
21
|
+
pressed(skinTone) {
|
22
|
+
return this.opened ? !!this.isSelected(skinTone) : '';
|
23
|
+
}
|
24
|
+
tabIndex(skinTone) {
|
25
|
+
return this.isVisible(skinTone) ? '0' : '';
|
26
|
+
}
|
27
|
+
expanded(skinTone) {
|
28
|
+
return this.isSelected(skinTone) ? this.opened : '';
|
29
|
+
}
|
30
|
+
handleClick(skin) {
|
31
|
+
if (!this.opened) {
|
32
|
+
this.opened = true;
|
33
|
+
return;
|
34
|
+
}
|
35
|
+
this.opened = false;
|
36
|
+
if (skin !== this.skin) {
|
37
|
+
this.changeSkin.emit(skin);
|
38
|
+
}
|
39
|
+
}
|
40
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SkinComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
41
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.0.0", type: SkinComponent, isStandalone: true, selector: "emoji-skins", inputs: { skin: "skin", i18n: "i18n" }, outputs: { changeSkin: "changeSkin" }, ngImport: i0, template: `
|
42
|
+
<section class="emoji-mart-skin-swatches" [class.opened]="opened">
|
43
|
+
<span
|
44
|
+
*ngFor="let skinTone of skinTones"
|
45
|
+
class="emoji-mart-skin-swatch"
|
46
|
+
[class.selected]="skinTone === skin"
|
47
|
+
>
|
48
|
+
<span
|
49
|
+
(click)="handleClick(skinTone)"
|
50
|
+
(keyup.enter)="handleClick(skinTone)"
|
51
|
+
(keyup.space)="handleClick(skinTone)"
|
52
|
+
class="emoji-mart-skin emoji-mart-skin-tone-{{ skinTone }}"
|
53
|
+
role="button"
|
54
|
+
[tabIndex]="tabIndex(skinTone)"
|
55
|
+
[attr.aria-hidden]="!isVisible(skinTone)"
|
56
|
+
[attr.aria-pressed]="pressed(skinTone)"
|
57
|
+
[attr.aria-haspopup]="!!isSelected(skinTone)"
|
58
|
+
[attr.aria-expanded]="expanded(skinTone)"
|
59
|
+
[attr.aria-label]="i18n.skintones[skinTone]"
|
60
|
+
[attr.title]="i18n.skintones[skinTone]"
|
61
|
+
></span>
|
62
|
+
</span>
|
63
|
+
</section>
|
64
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
65
|
+
}
|
66
|
+
export { SkinComponent };
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.0", ngImport: i0, type: SkinComponent, decorators: [{
|
68
|
+
type: Component,
|
69
|
+
args: [{
|
70
|
+
selector: 'emoji-skins',
|
71
|
+
template: `
|
72
|
+
<section class="emoji-mart-skin-swatches" [class.opened]="opened">
|
73
|
+
<span
|
74
|
+
*ngFor="let skinTone of skinTones"
|
75
|
+
class="emoji-mart-skin-swatch"
|
76
|
+
[class.selected]="skinTone === skin"
|
77
|
+
>
|
78
|
+
<span
|
79
|
+
(click)="handleClick(skinTone)"
|
80
|
+
(keyup.enter)="handleClick(skinTone)"
|
81
|
+
(keyup.space)="handleClick(skinTone)"
|
82
|
+
class="emoji-mart-skin emoji-mart-skin-tone-{{ skinTone }}"
|
83
|
+
role="button"
|
84
|
+
[tabIndex]="tabIndex(skinTone)"
|
85
|
+
[attr.aria-hidden]="!isVisible(skinTone)"
|
86
|
+
[attr.aria-pressed]="pressed(skinTone)"
|
87
|
+
[attr.aria-haspopup]="!!isSelected(skinTone)"
|
88
|
+
[attr.aria-expanded]="expanded(skinTone)"
|
89
|
+
[attr.aria-label]="i18n.skintones[skinTone]"
|
90
|
+
[attr.title]="i18n.skintones[skinTone]"
|
91
|
+
></span>
|
92
|
+
</span>
|
93
|
+
</section>
|
94
|
+
`,
|
95
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
96
|
+
preserveWhitespaces: false,
|
97
|
+
standalone: true,
|
98
|
+
imports: [CommonModule],
|
99
|
+
}]
|
100
|
+
}], propDecorators: { skin: [{
|
101
|
+
type: Input
|
102
|
+
}], i18n: [{
|
103
|
+
type: Input
|
104
|
+
}], changeSkin: [{
|
105
|
+
type: Output
|
106
|
+
}] } });
|
107
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2tpbnMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9waWNrZXIvc2tpbnMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7QUFJaEcsTUErQmEsYUFBYTtJQUN4Qiw4QkFBOEI7SUFDckIsSUFBSSxDQUFpQjtJQUNyQixJQUFJLENBQU07SUFDVCxVQUFVLEdBQUcsSUFBSSxZQUFZLEVBQWlCLENBQUM7SUFDekQsTUFBTSxHQUFHLEtBQUssQ0FBQztJQUNmLFNBQVMsR0FBb0IsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0lBRWhELFVBQVU7UUFDUixJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUM3QixDQUFDO0lBRUQsVUFBVSxDQUFDLFFBQXVCO1FBQ2hDLE9BQU8sUUFBUSxLQUFLLElBQUksQ0FBQyxJQUFJLENBQUM7SUFDaEMsQ0FBQztJQUVELFNBQVMsQ0FBQyxRQUF1QjtRQUMvQixPQUFPLElBQUksQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztJQUNsRCxDQUFDO0lBRUQsT0FBTyxDQUFDLFFBQXVCO1FBQzdCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUN4RCxDQUFDO0lBRUQsUUFBUSxDQUFDLFFBQXVCO1FBQzlCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7SUFDN0MsQ0FBQztJQUVELFFBQVEsQ0FBQyxRQUF1QjtRQUM5QixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztJQUN0RCxDQUFDO0lBRUQsV0FBVyxDQUFDLElBQW1CO1FBQzdCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDO1lBQ25CLE9BQU87U0FDUjtRQUNELElBQUksQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFDO1FBQ3BCLElBQUksSUFBSSxLQUFLLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDdEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDNUI7SUFDSCxDQUFDO3VHQXpDVSxhQUFhOzJGQUFiLGFBQWEsc0pBN0JkOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVCVCwyREFJUyxZQUFZOztTQUVYLGFBQWE7MkZBQWIsYUFBYTtrQkEvQnpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGFBQWE7b0JBQ3ZCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0F1QlQ7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLG1CQUFtQixFQUFFLEtBQUs7b0JBQzFCLFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7aUJBQ3hCOzhCQUdVLElBQUk7c0JBQVosS0FBSztnQkFDRyxJQUFJO3NCQUFaLEtBQUs7Z0JBQ0ksVUFBVTtzQkFBbkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRW1vamkgfSBmcm9tICdAY3RybC9uZ3gtZW1vamktbWFydC9uZ3gtZW1vamknO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdlbW9qaS1za2lucycsXG4gIHRlbXBsYXRlOiBgXG4gICAgPHNlY3Rpb24gY2xhc3M9XCJlbW9qaS1tYXJ0LXNraW4tc3dhdGNoZXNcIiBbY2xhc3Mub3BlbmVkXT1cIm9wZW5lZFwiPlxuICAgICAgPHNwYW5cbiAgICAgICAgKm5nRm9yPVwibGV0IHNraW5Ub25lIG9mIHNraW5Ub25lc1wiXG4gICAgICAgIGNsYXNzPVwiZW1vamktbWFydC1za2luLXN3YXRjaFwiXG4gICAgICAgIFtjbGFzcy5zZWxlY3RlZF09XCJza2luVG9uZSA9PT0gc2tpblwiXG4gICAgICA+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgKGNsaWNrKT1cImhhbmRsZUNsaWNrKHNraW5Ub25lKVwiXG4gICAgICAgICAgKGtleXVwLmVudGVyKT1cImhhbmRsZUNsaWNrKHNraW5Ub25lKVwiXG4gICAgICAgICAgKGtleXVwLnNwYWNlKT1cImhhbmRsZUNsaWNrKHNraW5Ub25lKVwiXG4gICAgICAgICAgY2xhc3M9XCJlbW9qaS1tYXJ0LXNraW4gZW1vamktbWFydC1za2luLXRvbmUte3sgc2tpblRvbmUgfX1cIlxuICAgICAgICAgIHJvbGU9XCJidXR0b25cIlxuICAgICAgICAgIFt0YWJJbmRleF09XCJ0YWJJbmRleChza2luVG9uZSlcIlxuICAgICAgICAgIFthdHRyLmFyaWEtaGlkZGVuXT1cIiFpc1Zpc2libGUoc2tpblRvbmUpXCJcbiAgICAgICAgICBbYXR0ci5hcmlhLXByZXNzZWRdPVwicHJlc3NlZChza2luVG9uZSlcIlxuICAgICAgICAgIFthdHRyLmFyaWEtaGFzcG9wdXBdPVwiISFpc1NlbGVjdGVkKHNraW5Ub25lKVwiXG4gICAgICAgICAgW2F0dHIuYXJpYS1leHBhbmRlZF09XCJleHBhbmRlZChza2luVG9uZSlcIlxuICAgICAgICAgIFthdHRyLmFyaWEtbGFiZWxdPVwiaTE4bi5za2ludG9uZXNbc2tpblRvbmVdXCJcbiAgICAgICAgICBbYXR0ci50aXRsZV09XCJpMThuLnNraW50b25lc1tza2luVG9uZV1cIlxuICAgICAgICA+PC9zcGFuPlxuICAgICAgPC9zcGFuPlxuICAgIDwvc2VjdGlvbj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHByZXNlcnZlV2hpdGVzcGFjZXM6IGZhbHNlLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgU2tpbkNvbXBvbmVudCB7XG4gIC8qKiBjdXJyZW50bHkgc2VsZWN0ZWQgc2tpbiAqL1xuICBASW5wdXQoKSBza2luPzogRW1vamlbJ3NraW4nXTtcbiAgQElucHV0KCkgaTE4bjogYW55O1xuICBAT3V0cHV0KCkgY2hhbmdlU2tpbiA9IG5ldyBFdmVudEVtaXR0ZXI8RW1vamlbJ3NraW4nXT4oKTtcbiAgb3BlbmVkID0gZmFsc2U7XG4gIHNraW5Ub25lczogRW1vamlbJ3NraW4nXVtdID0gWzEsIDIsIDMsIDQsIDUsIDZdO1xuXG4gIHRvZ2dsZU9wZW4oKSB7XG4gICAgdGhpcy5vcGVuZWQgPSAhdGhpcy5vcGVuZWQ7XG4gIH1cblxuICBpc1NlbGVjdGVkKHNraW5Ub25lOiBFbW9qaVsnc2tpbiddKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHNraW5Ub25lID09PSB0aGlzLnNraW47XG4gIH1cblxuICBpc1Zpc2libGUoc2tpblRvbmU6IEVtb2ppWydza2luJ10pOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy5vcGVuZWQgfHwgdGhpcy5pc1NlbGVjdGVkKHNraW5Ub25lKTtcbiAgfVxuXG4gIHByZXNzZWQoc2tpblRvbmU6IEVtb2ppWydza2luJ10pIHtcbiAgICByZXR1cm4gdGhpcy5vcGVuZWQgPyAhIXRoaXMuaXNTZWxlY3RlZChza2luVG9uZSkgOiAnJztcbiAgfVxuXG4gIHRhYkluZGV4KHNraW5Ub25lOiBFbW9qaVsnc2tpbiddKSB7XG4gICAgcmV0dXJuIHRoaXMuaXNWaXNpYmxlKHNraW5Ub25lKSA/ICcwJyA6ICcnO1xuICB9XG5cbiAgZXhwYW5kZWQoc2tpblRvbmU6IEVtb2ppWydza2luJ10pIHtcbiAgICByZXR1cm4gdGhpcy5pc1NlbGVjdGVkKHNraW5Ub25lKSA/IHRoaXMub3BlbmVkIDogJyc7XG4gIH1cblxuICBoYW5kbGVDbGljayhza2luOiBFbW9qaVsnc2tpbiddKSB7XG4gICAgaWYgKCF0aGlzLm9wZW5lZCkge1xuICAgICAgdGhpcy5vcGVuZWQgPSB0cnVlO1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICB0aGlzLm9wZW5lZCA9IGZhbHNlO1xuICAgIGlmIChza2luICE9PSB0aGlzLnNraW4pIHtcbiAgICAgIHRoaXMuY2hhbmdlU2tpbi5lbWl0KHNraW4pO1xuICAgIH1cbiAgfVxufVxuIl19
|