@ctrl/ngx-emoji-mart 5.1.2 → 6.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/README.md +11 -19
  2. package/anchors.component.d.ts +3 -0
  3. package/category.component.d.ts +7 -2
  4. package/ctrl-ngx-emoji-mart.d.ts +1 -0
  5. package/emoji-frequently.service.d.ts +3 -0
  6. package/emoji-search.service.d.ts +3 -0
  7. package/esm2020/anchors.component.mjs +83 -0
  8. package/esm2020/category.component.mjs +386 -0
  9. package/{esm2015/ctrl-ngx-emoji-mart.js → esm2020/ctrl-ngx-emoji-mart.mjs} +0 -0
  10. package/{esm2015/emoji-frequently.service.js → esm2020/emoji-frequently.service.mjs} +10 -8
  11. package/esm2020/emoji-search.service.mjs +177 -0
  12. package/{esm2015/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.js → esm2020/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.mjs} +0 -0
  13. package/{esm2015/ngx-emoji/data/categories.js → esm2020/ngx-emoji/data/categories.mjs} +4 -4
  14. package/{esm2015/ngx-emoji/data/data.interfaces.js → esm2020/ngx-emoji/data/data.interfaces.mjs} +0 -0
  15. package/esm2020/ngx-emoji/data/emojis.mjs +29543 -0
  16. package/{esm2015/ngx-emoji/data/skins.js → esm2020/ngx-emoji/data/skins.mjs} +0 -0
  17. package/esm2020/ngx-emoji/emoji.component.mjs +236 -0
  18. package/esm2020/ngx-emoji/emoji.module.mjs +18 -0
  19. package/esm2020/ngx-emoji/emoji.service.mjs +144 -0
  20. package/{esm2015/ngx-emoji/index.js → esm2020/ngx-emoji/index.mjs} +0 -0
  21. package/esm2020/picker.component.mjs +505 -0
  22. package/esm2020/picker.module.mjs +49 -0
  23. package/esm2020/preview.component.mjs +187 -0
  24. package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
  25. package/esm2020/search.component.mjs +165 -0
  26. package/esm2020/skins.component.mjs +108 -0
  27. package/esm2020/svgs/index.mjs +18 -0
  28. package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
  29. package/fesm2015/{ctrl-ngx-emoji-mart-ngx-emoji.js → ctrl-ngx-emoji-mart-ngx-emoji.mjs} +24809 -18497
  30. package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -0
  31. package/fesm2015/{ctrl-ngx-emoji-mart.js → ctrl-ngx-emoji-mart.mjs} +676 -329
  32. package/fesm2015/ctrl-ngx-emoji-mart.mjs.map +1 -0
  33. package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs +31829 -0
  34. package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -0
  35. package/fesm2020/ctrl-ngx-emoji-mart.mjs +1757 -0
  36. package/fesm2020/ctrl-ngx-emoji-mart.mjs.map +1 -0
  37. package/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.d.ts +1 -0
  38. package/ngx-emoji/emoji.component.d.ts +3 -0
  39. package/ngx-emoji/emoji.module.d.ts +6 -0
  40. package/ngx-emoji/emoji.service.d.ts +3 -0
  41. package/ngx-emoji/package.json +6 -7
  42. package/package.json +29 -10
  43. package/picker.component.d.ts +3 -0
  44. package/picker.css +0 -1
  45. package/picker.module.d.ts +13 -0
  46. package/preview.component.d.ts +4 -1
  47. package/search.component.d.ts +3 -0
  48. package/skins.component.d.ts +6 -3
  49. package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.js +0 -25822
  50. package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.js.map +0 -1
  51. package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.min.js +0 -2
  52. package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.min.js.map +0 -1
  53. package/bundles/ctrl-ngx-emoji-mart.umd.js +0 -1695
  54. package/bundles/ctrl-ngx-emoji-mart.umd.js.map +0 -1
  55. package/bundles/ctrl-ngx-emoji-mart.umd.min.js +0 -2
  56. package/bundles/ctrl-ngx-emoji-mart.umd.min.js.map +0 -1
  57. package/ctrl-ngx-emoji-mart.metadata.json +0 -1
  58. package/esm2015/anchors.component.js +0 -54
  59. package/esm2015/category.component.js +0 -276
  60. package/esm2015/emoji-search.service.js +0 -179
  61. package/esm2015/ngx-emoji/data/emojis.js +0 -23289
  62. package/esm2015/ngx-emoji/emoji.component.js +0 -174
  63. package/esm2015/ngx-emoji/emoji.module.js +0 -13
  64. package/esm2015/ngx-emoji/emoji.service.js +0 -143
  65. package/esm2015/picker.component.js +0 -459
  66. package/esm2015/picker.module.js +0 -34
  67. package/esm2015/preview.component.js +0 -113
  68. package/esm2015/search.component.js +0 -115
  69. package/esm2015/skins.component.js +0 -76
  70. package/esm2015/svgs/index.js +0 -18
  71. package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.js.map +0 -1
  72. package/fesm2015/ctrl-ngx-emoji-mart.js.map +0 -1
  73. package/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.metadata.json +0 -1
@@ -0,0 +1,386 @@
1
+ import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@ctrl/ngx-emoji-mart/ngx-emoji";
5
+ import * as i2 from "./emoji-frequently.service";
6
+ import * as i3 from "@angular/common";
7
+ export class CategoryComponent {
8
+ constructor(ref, emojiService, frequently) {
9
+ this.ref = ref;
10
+ this.emojiService = emojiService;
11
+ this.frequently = frequently;
12
+ this.emojis = null;
13
+ this.hasStickyPosition = true;
14
+ this.name = '';
15
+ this.perLine = 9;
16
+ this.totalFrequentLines = 4;
17
+ this.recent = [];
18
+ this.custom = [];
19
+ this.hideObsolete = true;
20
+ this.virtualize = false;
21
+ this.virtualizeOffset = 0;
22
+ this.emojiOver = new EventEmitter();
23
+ this.emojiLeave = new EventEmitter();
24
+ this.emojiClick = new EventEmitter();
25
+ this.containerStyles = {};
26
+ this.emojisToDisplay = [];
27
+ this.filteredEmojisSubject = new Subject();
28
+ this.filteredEmojis$ = this.filteredEmojisSubject.asObservable();
29
+ this.labelStyles = {};
30
+ this.labelSpanStyles = {};
31
+ this.margin = 0;
32
+ this.minMargin = 0;
33
+ this.maxMargin = 0;
34
+ this.top = 0;
35
+ this.rows = 0;
36
+ }
37
+ ngOnInit() {
38
+ this.updateRecentEmojis();
39
+ this.emojisToDisplay = this.filterEmojis();
40
+ if (this.noEmojiToDisplay) {
41
+ this.containerStyles = { display: 'none' };
42
+ }
43
+ if (!this.hasStickyPosition) {
44
+ this.labelStyles = { height: 28 };
45
+ // this.labelSpanStyles = { position: 'absolute' };
46
+ }
47
+ }
48
+ ngOnChanges(changes) {
49
+ if (changes.emojis?.currentValue?.length !== changes.emojis?.previousValue?.length) {
50
+ this.emojisToDisplay = this.filterEmojis();
51
+ this.ngAfterViewInit();
52
+ }
53
+ }
54
+ ngAfterViewInit() {
55
+ if (!this.virtualize) {
56
+ return;
57
+ }
58
+ const { width } = this.container.nativeElement.getBoundingClientRect();
59
+ const perRow = Math.floor(width / (this.emojiSize + 12));
60
+ this.rows = Math.ceil(this.emojisToDisplay.length / perRow);
61
+ this.containerStyles = {
62
+ ...this.containerStyles,
63
+ minHeight: `${this.rows * (this.emojiSize + 12) + 28}px`,
64
+ };
65
+ this.ref?.detectChanges();
66
+ this.handleScroll(this.container.nativeElement.parentNode.parentNode.scrollTop);
67
+ }
68
+ get noEmojiToDisplay() {
69
+ return this.emojisToDisplay.length === 0;
70
+ }
71
+ memoizeSize() {
72
+ const parent = this.container.nativeElement.parentNode.parentNode;
73
+ const { top, height } = this.container.nativeElement.getBoundingClientRect();
74
+ const parentTop = parent.getBoundingClientRect().top;
75
+ const labelHeight = this.label.nativeElement.getBoundingClientRect().height;
76
+ this.top = top - parentTop + parent.scrollTop;
77
+ if (height === 0) {
78
+ this.maxMargin = 0;
79
+ }
80
+ else {
81
+ this.maxMargin = height - labelHeight;
82
+ }
83
+ }
84
+ handleScroll(scrollTop) {
85
+ let margin = scrollTop - this.top;
86
+ margin = margin < this.minMargin ? this.minMargin : margin;
87
+ margin = margin > this.maxMargin ? this.maxMargin : margin;
88
+ if (this.virtualize) {
89
+ const { top, height } = this.container.nativeElement.getBoundingClientRect();
90
+ const parentHeight = this.container.nativeElement.parentNode.parentNode.clientHeight;
91
+ if (parentHeight + (parentHeight + this.virtualizeOffset) >= top && -height - (parentHeight + this.virtualizeOffset) <= top) {
92
+ this.filteredEmojisSubject.next(this.emojisToDisplay);
93
+ }
94
+ else {
95
+ this.filteredEmojisSubject.next([]);
96
+ }
97
+ }
98
+ if (margin === this.margin) {
99
+ this.ref.detectChanges();
100
+ return false;
101
+ }
102
+ if (!this.hasStickyPosition) {
103
+ this.label.nativeElement.style.top = `${margin}px`;
104
+ }
105
+ this.margin = margin;
106
+ this.ref.detectChanges();
107
+ return true;
108
+ }
109
+ updateRecentEmojis() {
110
+ if (this.name !== 'Recent') {
111
+ return;
112
+ }
113
+ let frequentlyUsed = this.recent || this.frequently.get(this.perLine, this.totalFrequentLines);
114
+ if (!frequentlyUsed || !frequentlyUsed.length) {
115
+ frequentlyUsed = this.frequently.get(this.perLine, this.totalFrequentLines);
116
+ }
117
+ if (!frequentlyUsed.length) {
118
+ return;
119
+ }
120
+ this.emojis = frequentlyUsed
121
+ .map(id => {
122
+ const emoji = this.custom.filter((e) => e.id === id)[0];
123
+ if (emoji) {
124
+ return emoji;
125
+ }
126
+ return id;
127
+ })
128
+ .filter(id => !!this.emojiService.getData(id));
129
+ }
130
+ updateDisplay(display) {
131
+ this.containerStyles.display = display;
132
+ this.updateRecentEmojis();
133
+ this.ref.detectChanges();
134
+ }
135
+ trackById(index, item) {
136
+ return item;
137
+ }
138
+ filterEmojis() {
139
+ const newEmojis = [];
140
+ for (const emoji of this.emojis || []) {
141
+ if (!emoji) {
142
+ continue;
143
+ }
144
+ const data = this.emojiService.getData(emoji);
145
+ if (!data || (data.obsoletedBy && this.hideObsolete) || (!data.unified && !data.custom)) {
146
+ continue;
147
+ }
148
+ newEmojis.push(emoji);
149
+ }
150
+ return newEmojis;
151
+ }
152
+ }
153
+ CategoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.1", ngImport: i0, type: CategoryComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EmojiService }, { token: i2.EmojiFrequentlyService }], target: i0.ɵɵFactoryTarget.Component });
154
+ CategoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.1", type: CategoryComponent, selector: "emoji-category", inputs: { emojis: "emojis", hasStickyPosition: "hasStickyPosition", name: "name", perLine: "perLine", totalFrequentLines: "totalFrequentLines", recent: "recent", custom: "custom", i18n: "i18n", id: "id", hideObsolete: "hideObsolete", notFoundEmoji: "notFoundEmoji", virtualize: "virtualize", virtualizeOffset: "virtualizeOffset", emojiIsNative: "emojiIsNative", emojiSkin: "emojiSkin", emojiSize: "emojiSize", emojiSet: "emojiSet", emojiSheetSize: "emojiSheetSize", emojiForceSize: "emojiForceSize", emojiTooltip: "emojiTooltip", emojiBackgroundImageFn: "emojiBackgroundImageFn", emojiImageUrlFn: "emojiImageUrlFn", emojiUseButton: "emojiUseButton" }, outputs: { emojiOver: "emojiOver", emojiLeave: "emojiLeave", emojiClick: "emojiClick" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, static: true }, { propertyName: "label", first: true, predicate: ["label"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: `
155
+ <section
156
+ #container
157
+ class="emoji-mart-category"
158
+ [attr.aria-label]="i18n.categories[id]"
159
+ [class.emoji-mart-no-results]="noEmojiToDisplay"
160
+ [ngStyle]="containerStyles"
161
+ >
162
+ <div class="emoji-mart-category-label" [ngStyle]="labelStyles" [attr.data-name]="name">
163
+ <!-- already labeled by the section aria-label -->
164
+ <span #label [ngStyle]="labelSpanStyles" aria-hidden="true">
165
+ {{ i18n.categories[id] }}
166
+ </span>
167
+ </div>
168
+
169
+ <div
170
+ *ngIf="virtualize; else normalRenderTemplate"
171
+ >
172
+ <div *ngIf="filteredEmojis$ | async as filteredEmojis">
173
+ <ngx-emoji
174
+ *ngFor="let emoji of filteredEmojis; trackBy: trackById"
175
+ [emoji]="emoji"
176
+ [size]="emojiSize"
177
+ [skin]="emojiSkin"
178
+ [isNative]="emojiIsNative"
179
+ [set]="emojiSet"
180
+ [sheetSize]="emojiSheetSize"
181
+ [forceSize]="emojiForceSize"
182
+ [tooltip]="emojiTooltip"
183
+ [backgroundImageFn]="emojiBackgroundImageFn"
184
+ [imageUrlFn]="emojiImageUrlFn"
185
+ [hideObsolete]="hideObsolete"
186
+ [useButton]="emojiUseButton"
187
+ (emojiOver)="emojiOver.emit($event)"
188
+ (emojiLeave)="emojiLeave.emit($event)"
189
+ (emojiClick)="emojiClick.emit($event)"
190
+ ></ngx-emoji>
191
+ </div>
192
+ </div>
193
+
194
+ <div *ngIf="noEmojiToDisplay">
195
+ <div>
196
+ <ngx-emoji
197
+ [emoji]="notFoundEmoji"
198
+ [size]="38"
199
+ [skin]="emojiSkin"
200
+ [isNative]="emojiIsNative"
201
+ [set]="emojiSet"
202
+ [sheetSize]="emojiSheetSize"
203
+ [forceSize]="emojiForceSize"
204
+ [tooltip]="emojiTooltip"
205
+ [backgroundImageFn]="emojiBackgroundImageFn"
206
+ [useButton]="emojiUseButton"
207
+ ></ngx-emoji>
208
+ </div>
209
+
210
+ <div class="emoji-mart-no-results-label">
211
+ {{ i18n.notfound }}
212
+ </div>
213
+ </div>
214
+ </section>
215
+
216
+ <ng-template #normalRenderTemplate>
217
+ <ngx-emoji
218
+ *ngFor="let emoji of emojisToDisplay; trackBy: trackById"
219
+ [emoji]="emoji"
220
+ [size]="emojiSize"
221
+ [skin]="emojiSkin"
222
+ [isNative]="emojiIsNative"
223
+ [set]="emojiSet"
224
+ [sheetSize]="emojiSheetSize"
225
+ [forceSize]="emojiForceSize"
226
+ [tooltip]="emojiTooltip"
227
+ [backgroundImageFn]="emojiBackgroundImageFn"
228
+ [imageUrlFn]="emojiImageUrlFn"
229
+ [hideObsolete]="hideObsolete"
230
+ [useButton]="emojiUseButton"
231
+ (emojiOver)="emojiOver.emit($event)"
232
+ (emojiLeave)="emojiLeave.emit($event)"
233
+ (emojiClick)="emojiClick.emit($event)"
234
+ ></ngx-emoji>
235
+ </ng-template>
236
+ `, isInline: true, components: [{ type: i1.EmojiComponent, selector: "ngx-emoji", inputs: ["skin", "set", "sheetSize", "isNative", "forceSize", "tooltip", "size", "emoji", "fallback", "hideObsolete", "sheetRows", "sheetColumns", "useButton", "backgroundImageFn", "imageUrlFn"], outputs: ["emojiOver", "emojiLeave", "emojiClick"] }], directives: [{ type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "async": i3.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
237
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.1", ngImport: i0, type: CategoryComponent, decorators: [{
238
+ type: Component,
239
+ args: [{
240
+ selector: 'emoji-category',
241
+ template: `
242
+ <section
243
+ #container
244
+ class="emoji-mart-category"
245
+ [attr.aria-label]="i18n.categories[id]"
246
+ [class.emoji-mart-no-results]="noEmojiToDisplay"
247
+ [ngStyle]="containerStyles"
248
+ >
249
+ <div class="emoji-mart-category-label" [ngStyle]="labelStyles" [attr.data-name]="name">
250
+ <!-- already labeled by the section aria-label -->
251
+ <span #label [ngStyle]="labelSpanStyles" aria-hidden="true">
252
+ {{ i18n.categories[id] }}
253
+ </span>
254
+ </div>
255
+
256
+ <div
257
+ *ngIf="virtualize; else normalRenderTemplate"
258
+ >
259
+ <div *ngIf="filteredEmojis$ | async as filteredEmojis">
260
+ <ngx-emoji
261
+ *ngFor="let emoji of filteredEmojis; trackBy: trackById"
262
+ [emoji]="emoji"
263
+ [size]="emojiSize"
264
+ [skin]="emojiSkin"
265
+ [isNative]="emojiIsNative"
266
+ [set]="emojiSet"
267
+ [sheetSize]="emojiSheetSize"
268
+ [forceSize]="emojiForceSize"
269
+ [tooltip]="emojiTooltip"
270
+ [backgroundImageFn]="emojiBackgroundImageFn"
271
+ [imageUrlFn]="emojiImageUrlFn"
272
+ [hideObsolete]="hideObsolete"
273
+ [useButton]="emojiUseButton"
274
+ (emojiOver)="emojiOver.emit($event)"
275
+ (emojiLeave)="emojiLeave.emit($event)"
276
+ (emojiClick)="emojiClick.emit($event)"
277
+ ></ngx-emoji>
278
+ </div>
279
+ </div>
280
+
281
+ <div *ngIf="noEmojiToDisplay">
282
+ <div>
283
+ <ngx-emoji
284
+ [emoji]="notFoundEmoji"
285
+ [size]="38"
286
+ [skin]="emojiSkin"
287
+ [isNative]="emojiIsNative"
288
+ [set]="emojiSet"
289
+ [sheetSize]="emojiSheetSize"
290
+ [forceSize]="emojiForceSize"
291
+ [tooltip]="emojiTooltip"
292
+ [backgroundImageFn]="emojiBackgroundImageFn"
293
+ [useButton]="emojiUseButton"
294
+ ></ngx-emoji>
295
+ </div>
296
+
297
+ <div class="emoji-mart-no-results-label">
298
+ {{ i18n.notfound }}
299
+ </div>
300
+ </div>
301
+ </section>
302
+
303
+ <ng-template #normalRenderTemplate>
304
+ <ngx-emoji
305
+ *ngFor="let emoji of emojisToDisplay; trackBy: trackById"
306
+ [emoji]="emoji"
307
+ [size]="emojiSize"
308
+ [skin]="emojiSkin"
309
+ [isNative]="emojiIsNative"
310
+ [set]="emojiSet"
311
+ [sheetSize]="emojiSheetSize"
312
+ [forceSize]="emojiForceSize"
313
+ [tooltip]="emojiTooltip"
314
+ [backgroundImageFn]="emojiBackgroundImageFn"
315
+ [imageUrlFn]="emojiImageUrlFn"
316
+ [hideObsolete]="hideObsolete"
317
+ [useButton]="emojiUseButton"
318
+ (emojiOver)="emojiOver.emit($event)"
319
+ (emojiLeave)="emojiLeave.emit($event)"
320
+ (emojiClick)="emojiClick.emit($event)"
321
+ ></ngx-emoji>
322
+ </ng-template>
323
+ `,
324
+ changeDetection: ChangeDetectionStrategy.OnPush,
325
+ preserveWhitespaces: false,
326
+ }]
327
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.EmojiService }, { type: i2.EmojiFrequentlyService }]; }, propDecorators: { emojis: [{
328
+ type: Input
329
+ }], hasStickyPosition: [{
330
+ type: Input
331
+ }], name: [{
332
+ type: Input
333
+ }], perLine: [{
334
+ type: Input
335
+ }], totalFrequentLines: [{
336
+ type: Input
337
+ }], recent: [{
338
+ type: Input
339
+ }], custom: [{
340
+ type: Input
341
+ }], i18n: [{
342
+ type: Input
343
+ }], id: [{
344
+ type: Input
345
+ }], hideObsolete: [{
346
+ type: Input
347
+ }], notFoundEmoji: [{
348
+ type: Input
349
+ }], virtualize: [{
350
+ type: Input
351
+ }], virtualizeOffset: [{
352
+ type: Input
353
+ }], emojiIsNative: [{
354
+ type: Input
355
+ }], emojiSkin: [{
356
+ type: Input
357
+ }], emojiSize: [{
358
+ type: Input
359
+ }], emojiSet: [{
360
+ type: Input
361
+ }], emojiSheetSize: [{
362
+ type: Input
363
+ }], emojiForceSize: [{
364
+ type: Input
365
+ }], emojiTooltip: [{
366
+ type: Input
367
+ }], emojiBackgroundImageFn: [{
368
+ type: Input
369
+ }], emojiImageUrlFn: [{
370
+ type: Input
371
+ }], emojiUseButton: [{
372
+ type: Input
373
+ }], emojiOver: [{
374
+ type: Output
375
+ }], emojiLeave: [{
376
+ type: Output
377
+ }], emojiClick: [{
378
+ type: Output
379
+ }], container: [{
380
+ type: ViewChild,
381
+ args: ['container', { static: true }]
382
+ }], label: [{
383
+ type: ViewChild,
384
+ args: ['label', { static: true }]
385
+ }] } });
386
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category.component.js","sourceRoot":"","sources":["../../src/lib/picker/category.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Emoji, EmojiService } from '@ctrl/ngx-emoji-mart/ngx-emoji';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { Observable, Subject } from 'rxjs';\nimport { EmojiFrequentlyService } from './emoji-frequently.service';\n\n\n@Component({\n  selector: 'emoji-category',\n  template: `\n    <section\n      #container\n      class=\"emoji-mart-category\"\n      [attr.aria-label]=\"i18n.categories[id]\"\n      [class.emoji-mart-no-results]=\"noEmojiToDisplay\"\n      [ngStyle]=\"containerStyles\"\n    >\n      <div class=\"emoji-mart-category-label\" [ngStyle]=\"labelStyles\" [attr.data-name]=\"name\">\n        <!-- already labeled by the section aria-label -->\n        <span #label [ngStyle]=\"labelSpanStyles\" aria-hidden=\"true\">\n          {{ i18n.categories[id] }}\n        </span>\n      </div>\n\n      <div\n        *ngIf=\"virtualize; else normalRenderTemplate\"\n      >\n        <div *ngIf=\"filteredEmojis$ | async as filteredEmojis\">\n          <ngx-emoji\n            *ngFor=\"let emoji of filteredEmojis; trackBy: trackById\"\n            [emoji]=\"emoji\"\n            [size]=\"emojiSize\"\n            [skin]=\"emojiSkin\"\n            [isNative]=\"emojiIsNative\"\n            [set]=\"emojiSet\"\n            [sheetSize]=\"emojiSheetSize\"\n            [forceSize]=\"emojiForceSize\"\n            [tooltip]=\"emojiTooltip\"\n            [backgroundImageFn]=\"emojiBackgroundImageFn\"\n            [imageUrlFn]=\"emojiImageUrlFn\"\n            [hideObsolete]=\"hideObsolete\"\n            [useButton]=\"emojiUseButton\"\n            (emojiOver)=\"emojiOver.emit($event)\"\n            (emojiLeave)=\"emojiLeave.emit($event)\"\n            (emojiClick)=\"emojiClick.emit($event)\"\n          ></ngx-emoji>\n        </div>\n      </div>\n\n      <div *ngIf=\"noEmojiToDisplay\">\n        <div>\n          <ngx-emoji\n            [emoji]=\"notFoundEmoji\"\n            [size]=\"38\"\n            [skin]=\"emojiSkin\"\n            [isNative]=\"emojiIsNative\"\n            [set]=\"emojiSet\"\n            [sheetSize]=\"emojiSheetSize\"\n            [forceSize]=\"emojiForceSize\"\n            [tooltip]=\"emojiTooltip\"\n            [backgroundImageFn]=\"emojiBackgroundImageFn\"\n            [useButton]=\"emojiUseButton\"\n          ></ngx-emoji>\n        </div>\n\n        <div class=\"emoji-mart-no-results-label\">\n          {{ i18n.notfound }}\n        </div>\n      </div>\n    </section>\n\n    <ng-template #normalRenderTemplate>\n        <ngx-emoji\n          *ngFor=\"let emoji of emojisToDisplay; trackBy: trackById\"\n          [emoji]=\"emoji\"\n          [size]=\"emojiSize\"\n          [skin]=\"emojiSkin\"\n          [isNative]=\"emojiIsNative\"\n          [set]=\"emojiSet\"\n          [sheetSize]=\"emojiSheetSize\"\n          [forceSize]=\"emojiForceSize\"\n          [tooltip]=\"emojiTooltip\"\n          [backgroundImageFn]=\"emojiBackgroundImageFn\"\n          [imageUrlFn]=\"emojiImageUrlFn\"\n          [hideObsolete]=\"hideObsolete\"\n          [useButton]=\"emojiUseButton\"\n          (emojiOver)=\"emojiOver.emit($event)\"\n          (emojiLeave)=\"emojiLeave.emit($event)\"\n          (emojiClick)=\"emojiClick.emit($event)\"\n        ></ngx-emoji>\n    </ng-template>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class CategoryComponent implements OnChanges, OnInit, AfterViewInit {\n  @Input() emojis: any[] | null = null\n  @Input() hasStickyPosition = true;\n  @Input() name = '';\n  @Input() perLine = 9;\n  @Input() totalFrequentLines = 4;\n  @Input() recent: string[] = [];\n  @Input() custom: any[] = [];\n  @Input() i18n: any;\n  @Input() id: any;\n  @Input() hideObsolete = true;\n  @Input() notFoundEmoji?: string;\n  @Input() virtualize = false;\n  @Input() virtualizeOffset = 0;\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() emojiForceSize!: Emoji['forceSize'];\n  @Input() emojiTooltip!: Emoji['tooltip'];\n  @Input() emojiBackgroundImageFn?: Emoji['backgroundImageFn'];\n  @Input() emojiImageUrlFn?: Emoji['imageUrlFn'];\n  @Input() emojiUseButton?: boolean;\n  @Output() emojiOver: Emoji['emojiOver'] = new EventEmitter();\n  @Output() emojiLeave: Emoji['emojiLeave'] = new EventEmitter();\n  @Output() emojiClick: Emoji['emojiClick'] = new EventEmitter();\n  @ViewChild('container', { static: true }) container!: ElementRef;\n  @ViewChild('label', { static: true }) label!: ElementRef;\n  containerStyles: any = {};\n  emojisToDisplay: any[]  = []\n  private filteredEmojisSubject = new Subject<any[] | null | undefined>();\n  filteredEmojis$: Observable<any[] | null | undefined> = this.filteredEmojisSubject.asObservable();\n  labelStyles: any = {};\n  labelSpanStyles: any = {};\n  margin = 0;\n  minMargin = 0;\n  maxMargin = 0;\n  top = 0;\n  rows = 0;\n\n  constructor(\n    public ref: ChangeDetectorRef,\n    private emojiService: EmojiService,\n    private frequently: EmojiFrequentlyService,\n  ) {}\n\n  ngOnInit() {\n    this.updateRecentEmojis();\n    this.emojisToDisplay = this.filterEmojis();\n\n    if (this.noEmojiToDisplay) {\n      this.containerStyles = { display: 'none' };\n    }\n\n    if (!this.hasStickyPosition) {\n      this.labelStyles = { height: 28 };\n      // this.labelSpanStyles = { position: 'absolute' };\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes.emojis?.currentValue?.length !== changes.emojis?.previousValue?.length) {\n      this.emojisToDisplay = this.filterEmojis();\n      this.ngAfterViewInit();\n    }\n  }\n\n  ngAfterViewInit() {\n    if (!this.virtualize) {\n      return;\n    }\n\n    const { width } = this.container.nativeElement.getBoundingClientRect();\n\n    const perRow = Math.floor(width / (this.emojiSize + 12));\n    this.rows = Math.ceil(this.emojisToDisplay.length / perRow);\n\n    this.containerStyles = {\n      ...this.containerStyles,\n      minHeight: `${this.rows * (this.emojiSize + 12) + 28}px`,\n    };\n\n    this.ref?.detectChanges();\n\n    this.handleScroll(this.container.nativeElement.parentNode.parentNode.scrollTop);\n  }\n\n\n  get noEmojiToDisplay():boolean{\n    return this.emojisToDisplay.length === 0;\n  }\n\n  memoizeSize() {\n    const parent = this.container.nativeElement.parentNode.parentNode;\n    const { top, height } = this.container.nativeElement.getBoundingClientRect();\n    const parentTop = parent.getBoundingClientRect().top;\n    const labelHeight = this.label.nativeElement.getBoundingClientRect().height;\n\n    this.top = top - parentTop + parent.scrollTop;\n\n    if (height === 0) {\n      this.maxMargin = 0;\n    } else {\n      this.maxMargin = height - labelHeight;\n    }\n  }\n\n  handleScroll(scrollTop: number): boolean {\n    let margin = scrollTop - this.top;\n    margin = margin < this.minMargin ? this.minMargin : margin;\n    margin = margin > this.maxMargin ? this.maxMargin : margin;\n\n    if (this.virtualize) {\n      const { top, height } = this.container.nativeElement.getBoundingClientRect();\n      const parentHeight = this.container.nativeElement.parentNode.parentNode.clientHeight;\n\n      if (parentHeight + (parentHeight + this.virtualizeOffset) >= top && -height - (parentHeight + this.virtualizeOffset) <= top) {\n        this.filteredEmojisSubject.next(this.emojisToDisplay);\n      } else {\n        this.filteredEmojisSubject.next([]);\n      }\n    }\n\n    if (margin === this.margin) {\n      this.ref.detectChanges();\n      return false;\n    }\n\n    if (!this.hasStickyPosition) {\n      this.label.nativeElement.style.top = `${margin}px`;\n    }\n\n    this.margin = margin;\n    this.ref.detectChanges();\n    return true;\n  }\n\n  updateRecentEmojis() {\n    if (this.name !== 'Recent') {\n      return;\n    }\n\n    let frequentlyUsed =\n      this.recent || this.frequently.get(this.perLine, this.totalFrequentLines);\n    if (!frequentlyUsed || !frequentlyUsed.length) {\n      frequentlyUsed = this.frequently.get(this.perLine, this.totalFrequentLines);\n    }\n    if (!frequentlyUsed.length) {\n      return\n    }\n    this.emojis = frequentlyUsed\n      .map(id => {\n        const emoji = this.custom.filter((e: any) => e.id === id)[0];\n        if (emoji) {\n          return emoji;\n        }\n\n        return id;\n      })\n      .filter(id => !!this.emojiService.getData(id));\n\n  }\n\n  updateDisplay(display: 'none' | 'block') {\n    this.containerStyles.display = display;\n    this.updateRecentEmojis();\n    this.ref.detectChanges();\n  }\n\n  trackById(index: number, item: any) {\n    return item;\n  }\n\n  private filterEmojis(): any[] {\n    const newEmojis = [];\n    for (const emoji of this.emojis || []) {\n      if (!emoji) {\n        continue;\n      }\n      const data = this.emojiService.getData(emoji);\n      if (!data || (data.obsoletedBy && this.hideObsolete) || (!data.unified && !data.custom)) {\n        continue;\n      }\n      newEmojis.push(emoji);\n    }\n    return newEmojis;\n  }\n}\n"]}
@@ -76,11 +76,13 @@ export class EmojiFrequentlyService {
76
76
  return sliced;
77
77
  }
78
78
  }
79
- EmojiFrequentlyService.ɵprov = i0.ɵɵdefineInjectable({ factory: function EmojiFrequentlyService_Factory() { return new EmojiFrequentlyService(i0.ɵɵinject(i0.PLATFORM_ID)); }, token: EmojiFrequentlyService, providedIn: "root" });
80
- EmojiFrequentlyService.decorators = [
81
- { type: Injectable, args: [{ providedIn: 'root' },] }
82
- ];
83
- EmojiFrequentlyService.ctorParameters = () => [
84
- { type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
85
- ];
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktZnJlcXVlbnRseS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9waWNrZXIvZW1vamktZnJlcXVlbnRseS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLaEUsTUFBTSxPQUFPLHNCQUFzQjtJQXVCakMsWUFBeUMsVUFBa0I7UUFBbEIsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQXRCM0QsY0FBUyxHQUFHLFlBQVksQ0FBQztRQUN6QixlQUFVLEdBQXFDLElBQUksQ0FBQztRQUNwRCxhQUFRLEdBQThCLEVBQUUsQ0FBQztRQUN6QyxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixhQUFRLEdBQUc7WUFDVCxJQUFJO1lBQ0osVUFBVTtZQUNWLGVBQWU7WUFDZixZQUFZO1lBQ1osVUFBVTtZQUNWLDhCQUE4QjtZQUM5QixhQUFhO1lBQ2IsS0FBSztZQUNMLFFBQVE7WUFDUixjQUFjO1lBQ2QsVUFBVTtZQUNWLE9BQU87WUFDUCxLQUFLO1lBQ0wsWUFBWTtZQUNaLE9BQU87WUFDUCxNQUFNO1NBQ1AsQ0FBQztJQUM0RCxDQUFDO0lBQy9ELElBQUk7UUFDRixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQzFCLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUNqQyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsYUFBYSxDQUFDLENBQUM7WUFDckQsTUFBTSxDQUNULENBQUM7UUFDRixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDO0lBQ0QsR0FBRyxDQUFDLEtBQWdCO1FBQ2xCLElBQUksQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFO1lBQ3JCLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztTQUNiO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO1NBQ2pDO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxFQUFFO1lBQzlCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQztTQUMvQjtRQUNELElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUUvQixJQUFJLGlCQUFpQixDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUN0QyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsT0FBTyxFQUFFLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztZQUN6RCxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsYUFBYSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7U0FDdkY7SUFDSCxDQUFDO0lBQ0QsR0FBRyxDQUFDLE9BQWUsRUFBRSxVQUFrQjtRQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNyQixJQUFJLENBQUMsSUFBSSxFQUFFLENBQUM7U0FDYjtRQUNELElBQUksSUFBSSxDQUFDLFVBQVUsS0FBSyxJQUFJLEVBQUU7WUFDNUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxFQUFFLENBQUM7WUFDbkIsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDO1lBRWxCLEtBQUssSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsR0FBRyxPQUFPLEVBQUUsQ0FBQyxFQUFFLEVBQUU7Z0JBQ2hDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLE9BQU8sR0FBRyxDQUFDLENBQUM7Z0JBQzlDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQy9CO1lBQ0QsT0FBTyxNQUFNLENBQUM7U0FDZjtRQUVELE1BQU0sUUFBUSxHQUFHLE9BQU8sR0FBRyxVQUFVLENBQUM7UUFDdEMsTUFBTSxjQUFjLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFcEQsTUFBTSxNQUFNLEdBQUcsY0FBYzthQUMxQixJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxVQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDekQsT0FBTyxFQUFFLENBQUM7UUFDYixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUMsQ0FBQztRQUV6QyxNQUFNLElBQUksR0FDUixpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQyxTQUFTLE9BQU8sQ0FBQyxDQUFDO1FBRXZGLElBQUksSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsRUFBRTtZQUNsQyxNQUFNLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDYixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ25CO1FBQ0QsT0FBTyxNQUFNLENBQUM7SUFDaEIsQ0FBQzs7OztZQWpGRixVQUFVLFNBQUMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFOzs7eUNBd0JuQixNQUFNLFNBQUMsV0FBVyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzUGxhdGZvcm1Ccm93c2VyIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSwgUExBVEZPUk1fSUQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRW1vamlEYXRhIH0gZnJvbSAnQGN0cmwvbmd4LWVtb2ppLW1hcnQvbmd4LWVtb2ppJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBFbW9qaUZyZXF1ZW50bHlTZXJ2aWNlIHtcbiAgTkFNRVNQQUNFID0gJ2Vtb2ppLW1hcnQnO1xuICBmcmVxdWVudGx5OiB7IFtrZXk6IHN0cmluZ106IG51bWJlciB9IHwgbnVsbCA9IG51bGw7XG4gIGRlZmF1bHRzOiB7IFtrZXk6IHN0cmluZ106IG51bWJlciB9ID0ge307XG4gIGluaXRpYWxpemVkID0gZmFsc2U7XG4gIERFRkFVTFRTID0gW1xuICAgICcrMScsXG4gICAgJ2dyaW5uaW5nJyxcbiAgICAna2lzc2luZ19oZWFydCcsXG4gICAgJ2hlYXJ0X2V5ZXMnLFxuICAgICdsYXVnaGluZycsXG4gICAgJ3N0dWNrX291dF90b25ndWVfd2lua2luZ19leWUnLFxuICAgICdzd2VhdF9zbWlsZScsXG4gICAgJ2pveScsXG4gICAgJ3NjcmVhbScsXG4gICAgJ2Rpc2FwcG9pbnRlZCcsXG4gICAgJ3VuYW11c2VkJyxcbiAgICAnd2VhcnknLFxuICAgICdzb2InLFxuICAgICdzdW5nbGFzc2VzJyxcbiAgICAnaGVhcnQnLFxuICAgICdwb29wJyxcbiAgXTtcbiAgY29uc3RydWN0b3IoQEluamVjdChQTEFURk9STV9JRCkgcHJpdmF0ZSBwbGF0Zm9ybUlkOiBzdHJpbmcpIHt9XG4gIGluaXQoKSB7XG4gICAgdGhpcy5mcmVxdWVudGx5ID0gSlNPTi5wYXJzZShcbiAgICAgIChpc1BsYXRmb3JtQnJvd3Nlcih0aGlzLnBsYXRmb3JtSWQpICYmXG4gICAgICAgIGxvY2FsU3RvcmFnZS5nZXRJdGVtKGAke3RoaXMuTkFNRVNQQUNFfS5mcmVxdWVudGx5YCkpIHx8XG4gICAgICAgICdudWxsJyxcbiAgICApO1xuICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlO1xuICB9XG4gIGFkZChlbW9qaTogRW1vamlEYXRhKSB7XG4gICAgaWYgKCF0aGlzLmluaXRpYWxpemVkKSB7XG4gICAgICB0aGlzLmluaXQoKTtcbiAgICB9XG4gICAgaWYgKCF0aGlzLmZyZXF1ZW50bHkpIHtcbiAgICAgIHRoaXMuZnJlcXVlbnRseSA9IHRoaXMuZGVmYXVsdHM7XG4gICAgfVxuICAgIGlmICghdGhpcy5mcmVxdWVudGx5W2Vtb2ppLmlkXSkge1xuICAgICAgdGhpcy5mcmVxdWVudGx5W2Vtb2ppLmlkXSA9IDA7XG4gICAgfVxuICAgIHRoaXMuZnJlcXVlbnRseVtlbW9qaS5pZF0gKz0gMTtcblxuICAgIGlmIChpc1BsYXRmb3JtQnJvd3Nlcih0aGlzLnBsYXRmb3JtSWQpKSB7XG4gICAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbShgJHt0aGlzLk5BTUVTUEFDRX0ubGFzdGAsIGVtb2ppLmlkKTtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGAke3RoaXMuTkFNRVNQQUNFfS5mcmVxdWVudGx5YCwgSlNPTi5zdHJpbmdpZnkodGhpcy5mcmVxdWVudGx5KSk7XG4gICAgfVxuICB9XG4gIGdldChwZXJMaW5lOiBudW1iZXIsIHRvdGFsTGluZXM6IG51bWJlcikge1xuICAgIGlmICghdGhpcy5pbml0aWFsaXplZCkge1xuICAgICAgdGhpcy5pbml0KCk7XG4gICAgfVxuICAgIGlmICh0aGlzLmZyZXF1ZW50bHkgPT09IG51bGwpIHtcbiAgICAgIHRoaXMuZGVmYXVsdHMgPSB7fTtcbiAgICAgIGNvbnN0IHJlc3VsdCA9IFtdO1xuXG4gICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHBlckxpbmU7IGkrKykge1xuICAgICAgICB0aGlzLmRlZmF1bHRzW3RoaXMuREVGQVVMVFNbaV1dID0gcGVyTGluZSAtIGk7XG4gICAgICAgIHJlc3VsdC5wdXNoKHRoaXMuREVGQVVMVFNbaV0pO1xuICAgICAgfVxuICAgICAgcmV0dXJuIHJlc3VsdDtcbiAgICB9XG5cbiAgICBjb25zdCBxdWFudGl0eSA9IHBlckxpbmUgKiB0b3RhbExpbmVzO1xuICAgIGNvbnN0IGZyZXF1ZW50bHlLZXlzID0gT2JqZWN0LmtleXModGhpcy5mcmVxdWVudGx5KTtcblxuICAgIGNvbnN0IHNvcnRlZCA9IGZyZXF1ZW50bHlLZXlzXG4gICAgICAuc29ydCgoYSwgYikgPT4gdGhpcy5mcmVxdWVudGx5IVthXSAtIHRoaXMuZnJlcXVlbnRseSFbYl0pXG4gICAgICAucmV2ZXJzZSgpO1xuICAgIGNvbnN0IHNsaWNlZCA9IHNvcnRlZC5zbGljZSgwLCBxdWFudGl0eSk7XG5cbiAgICBjb25zdCBsYXN0ID1cbiAgICAgIGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkgJiYgbG9jYWxTdG9yYWdlLmdldEl0ZW0oYCR7dGhpcy5OQU1FU1BBQ0V9Lmxhc3RgKTtcblxuICAgIGlmIChsYXN0ICYmICFzbGljZWQuaW5jbHVkZXMobGFzdCkpIHtcbiAgICAgIHNsaWNlZC5wb3AoKTtcbiAgICAgIHNsaWNlZC5wdXNoKGxhc3QpO1xuICAgIH1cbiAgICByZXR1cm4gc2xpY2VkO1xuICB9XG59XG4iXX0=
79
+ EmojiFrequentlyService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.1", ngImport: i0, type: EmojiFrequentlyService, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable });
80
+ EmojiFrequentlyService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.1", ngImport: i0, type: EmojiFrequentlyService, providedIn: 'root' });
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.1", ngImport: i0, type: EmojiFrequentlyService, decorators: [{
82
+ type: Injectable,
83
+ args: [{ providedIn: 'root' }]
84
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
85
+ type: Inject,
86
+ args: [PLATFORM_ID]
87
+ }] }]; } });
88
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamktZnJlcXVlbnRseS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2xpYi9waWNrZXIvZW1vamktZnJlcXVlbnRseS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLaEUsTUFBTSxPQUFPLHNCQUFzQjtJQXVCakMsWUFBeUMsVUFBa0I7UUFBbEIsZUFBVSxHQUFWLFVBQVUsQ0FBUTtRQXRCM0QsY0FBUyxHQUFHLFlBQVksQ0FBQztRQUN6QixlQUFVLEdBQXFDLElBQUksQ0FBQztRQUNwRCxhQUFRLEdBQThCLEVBQUUsQ0FBQztRQUN6QyxnQkFBVyxHQUFHLEtBQUssQ0FBQztRQUNwQixhQUFRLEdBQUc7WUFDVCxJQUFJO1lBQ0osVUFBVTtZQUNWLGVBQWU7WUFDZixZQUFZO1lBQ1osVUFBVTtZQUNWLDhCQUE4QjtZQUM5QixhQUFhO1lBQ2IsS0FBSztZQUNMLFFBQVE7WUFDUixjQUFjO1lBQ2QsVUFBVTtZQUNWLE9BQU87WUFDUCxLQUFLO1lBQ0wsWUFBWTtZQUNaLE9BQU87WUFDUCxNQUFNO1NBQ1AsQ0FBQztJQUM0RCxDQUFDO0lBQy9ELElBQUk7UUFDRixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxLQUFLLENBQzFCLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQztZQUNqQyxZQUFZLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLFNBQVMsYUFBYSxDQUFDLENBQUM7WUFDckQsTUFBTSxDQUNULENBQUM7UUFDRixJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDO0lBQ0QsR0FBRyxDQUFDLEtBQWdCO1FBQ2xCLElBQUksQ0FBQyxJQUFJLENB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cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNQbGF0Zm9ybUJyb3dzZXIgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgSW5qZWN0LCBJbmplY3RhYmxlLCBQTEFURk9STV9JRCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBFbW9qaURhdGEgfSBmcm9tICdAY3RybC9uZ3gtZW1vamktbWFydC9uZ3gtZW1vamknO1xuXG5ASW5qZWN0YWJsZSh7IHByb3ZpZGVkSW46ICdyb290JyB9KVxuZXhwb3J0IGNsYXNzIEVtb2ppRnJlcXVlbnRseVNlcnZpY2Uge1xuICBOQU1FU1BBQ0UgPSAnZW1vamktbWFydCc7XG4gIGZyZXF1ZW50bHk6IHsgW2tleTogc3RyaW5nXTogbnVtYmVyIH0gfCBudWxsID0gbnVsbDtcbiAgZGVmYXVsdHM6IHsgW2tleTogc3RyaW5nXTogbnVtYmVyIH0gPSB7fTtcbiAgaW5pdGlhbGl6ZWQgPSBmYWxzZTtcbiAgREVGQVVMVFMgPSBbXG4gICAgJysxJyxcbiAgICAnZ3Jpbm5pbmcnLFxuICAgICdraXNzaW5nX2hlYXJ0JyxcbiAgICAnaGVhcnRfZXllcycsXG4gICAgJ2xhdWdoaW5nJyxcbiAgICAnc3R1Y2tfb3V0X3Rvbmd1ZV93aW5raW5nX2V5ZScsXG4gICAgJ3N3ZWF0X3NtaWxlJyxcbiAgICAnam95JyxcbiAgICAnc2NyZWFtJyxcbiAgICAnZGlzYXBwb2ludGVkJyxcbiAgICAndW5hbXVzZWQnLFxuICAgICd3ZWFyeScsXG4gICAgJ3NvYicsXG4gICAgJ3N1bmdsYXNzZXMnLFxuICAgICdoZWFydCcsXG4gICAgJ3Bvb3AnLFxuICBdO1xuICBjb25zdHJ1Y3RvcihASW5qZWN0KFBMQVRGT1JNX0lEKSBwcml2YXRlIHBsYXRmb3JtSWQ6IHN0cmluZykge31cbiAgaW5pdCgpIHtcbiAgICB0aGlzLmZyZXF1ZW50bHkgPSBKU09OLnBhcnNlKFxuICAgICAgKGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkgJiZcbiAgICAgICAgbG9jYWxTdG9yYWdlLmdldEl0ZW0oYCR7dGhpcy5OQU1FU1BBQ0V9LmZyZXF1ZW50bHlgKSkgfHxcbiAgICAgICAgJ251bGwnLFxuICAgICk7XG4gICAgdGhpcy5pbml0aWFsaXplZCA9IHRydWU7XG4gIH1cbiAgYWRkKGVtb2ppOiBFbW9qaURhdGEpIHtcbiAgICBpZiAoIXRoaXMuaW5pdGlhbGl6ZWQpIHtcbiAgICAgIHRoaXMuaW5pdCgpO1xuICAgIH1cbiAgICBpZiAoIXRoaXMuZnJlcXVlbnRseSkge1xuICAgICAgdGhpcy5mcmVxdWVudGx5ID0gdGhpcy5kZWZhdWx0cztcbiAgICB9XG4gICAgaWYgKCF0aGlzLmZyZXF1ZW50bHlbZW1vamkuaWRdKSB7XG4gICAgICB0aGlzLmZyZXF1ZW50bHlbZW1vamkuaWRdID0gMDtcbiAgICB9XG4gICAgdGhpcy5mcmVxdWVudGx5W2Vtb2ppLmlkXSArPSAxO1xuXG4gICAgaWYgKGlzUGxhdGZvcm1Ccm93c2VyKHRoaXMucGxhdGZvcm1JZCkpIHtcbiAgICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGAke3RoaXMuTkFNRVNQQUNFfS5sYXN0YCwgZW1vamkuaWQpO1xuICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oYCR7dGhpcy5OQU1FU1BBQ0V9LmZyZXF1ZW50bHlgLCBKU09OLnN0cmluZ2lmeSh0aGlzLmZyZXF1ZW50bHkpKTtcbiAgICB9XG4gIH1cbiAgZ2V0KHBlckxpbmU6IG51bWJlciwgdG90YWxMaW5lczogbnVtYmVyKSB7XG4gICAgaWYgKCF0aGlzLmluaXRpYWxpemVkKSB7XG4gICAgICB0aGlzLmluaXQoKTtcbiAgICB9XG4gICAgaWYgKHRoaXMuZnJlcXVlbnRseSA9PT0gbnVsbCkge1xuICAgICAgdGhpcy5kZWZhdWx0cyA9IHt9O1xuICAgICAgY29uc3QgcmVzdWx0ID0gW107XG5cbiAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcGVyTGluZTsgaSsrKSB7XG4gICAgICAgIHRoaXMuZGVmYXVsdHNbdGhpcy5ERUZBVUxUU1tpXV0gPSBwZXJMaW5lIC0gaTtcbiAgICAgICAgcmVzdWx0LnB1c2godGhpcy5ERUZBVUxUU1tpXSk7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVzdWx0O1xuICAgIH1cblxuICAgIGNvbnN0IHF1YW50aXR5ID0gcGVyTGluZSAqIHRvdGFsTGluZXM7XG4gICAgY29uc3QgZnJlcXVlbnRseUtleXMgPSBPYmplY3Qua2V5cyh0aGlzLmZyZXF1ZW50bHkpO1xuXG4gICAgY29uc3Qgc29ydGVkID0gZnJlcXVlbnRseUtleXNcbiAgICAgIC5zb3J0KChhLCBiKSA9PiB0aGlzLmZyZXF1ZW50bHkhW2FdIC0gdGhpcy5mcmVxdWVudGx5IVtiXSlcbiAgICAgIC5yZXZlcnNlKCk7XG4gICAgY29uc3Qgc2xpY2VkID0gc29ydGVkLnNsaWNlKDAsIHF1YW50aXR5KTtcblxuICAgIGNvbnN0IGxhc3QgPVxuICAgICAgaXNQbGF0Zm9ybUJyb3dzZXIodGhpcy5wbGF0Zm9ybUlkKSAmJiBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShgJHt0aGlzLk5BTUVTUEFDRX0ubGFzdGApO1xuXG4gICAgaWYgKGxhc3QgJiYgIXNsaWNlZC5pbmNsdWRlcyhsYXN0KSkge1xuICAgICAgc2xpY2VkLnBvcCgpO1xuICAgICAgc2xpY2VkLnB1c2gobGFzdCk7XG4gICAgfVxuICAgIHJldHVybiBzbGljZWQ7XG4gIH1cbn1cbiJdfQ==