@ctrl/ngx-emoji-mart 8.2.0 → 9.1.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.
Files changed (54) hide show
  1. package/README.md +42 -17
  2. package/anchors.component.d.ts +1 -1
  3. package/category.component.d.ts +1 -1
  4. package/esm2022/anchors.component.mjs +100 -0
  5. package/esm2022/category.component.mjs +409 -0
  6. package/esm2022/emoji-frequently.service.mjs +90 -0
  7. package/esm2022/emoji-search.service.mjs +178 -0
  8. package/esm2022/ngx-emoji/emoji.component.mjs +299 -0
  9. package/esm2022/ngx-emoji/emoji.module.mjs +17 -0
  10. package/esm2022/ngx-emoji/emoji.service.mjs +145 -0
  11. package/esm2022/picker.component.mjs +522 -0
  12. package/esm2022/picker.module.mjs +40 -0
  13. package/esm2022/preview.component.mjs +206 -0
  14. package/esm2022/search.component.mjs +175 -0
  15. package/esm2022/skins.component.mjs +107 -0
  16. package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart-ngx-emoji.mjs +64 -56
  17. package/{fesm2015 → fesm2022}/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -1
  18. package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart.mjs +320 -254
  19. package/fesm2022/ctrl-ngx-emoji-mart.mjs.map +1 -0
  20. package/ngx-emoji/emoji.component.d.ts +1 -1
  21. package/ngx-emoji/emoji.module.d.ts +1 -2
  22. package/package.json +8 -16
  23. package/picker.component.d.ts +2 -2
  24. package/picker.module.d.ts +1 -4
  25. package/preview.component.d.ts +2 -2
  26. package/search.component.d.ts +1 -1
  27. package/skins.component.d.ts +2 -2
  28. package/esm2020/anchors.component.mjs +0 -83
  29. package/esm2020/category.component.mjs +0 -386
  30. package/esm2020/emoji-frequently.service.mjs +0 -88
  31. package/esm2020/emoji-search.service.mjs +0 -177
  32. package/esm2020/ngx-emoji/emoji.component.mjs +0 -288
  33. package/esm2020/ngx-emoji/emoji.module.mjs +0 -18
  34. package/esm2020/ngx-emoji/emoji.service.mjs +0 -144
  35. package/esm2020/picker.component.mjs +0 -508
  36. package/esm2020/picker.module.mjs +0 -49
  37. package/esm2020/preview.component.mjs +0 -187
  38. package/esm2020/search.component.mjs +0 -165
  39. package/esm2020/skins.component.mjs +0 -108
  40. package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.mjs +0 -34330
  41. package/fesm2015/ctrl-ngx-emoji-mart.mjs +0 -1763
  42. package/fesm2015/ctrl-ngx-emoji-mart.mjs.map +0 -1
  43. package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +0 -1
  44. package/fesm2020/ctrl-ngx-emoji-mart.mjs.map +0 -1
  45. /package/{esm2020 → esm2022}/ctrl-ngx-emoji-mart.mjs +0 -0
  46. /package/{esm2020 → esm2022}/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.mjs +0 -0
  47. /package/{esm2020 → esm2022}/ngx-emoji/data/categories.mjs +0 -0
  48. /package/{esm2020 → esm2022}/ngx-emoji/data/data.interfaces.mjs +0 -0
  49. /package/{esm2020 → esm2022}/ngx-emoji/data/emojis.mjs +0 -0
  50. /package/{esm2020 → esm2022}/ngx-emoji/data/skins.mjs +0 -0
  51. /package/{esm2020 → esm2022}/ngx-emoji/index.mjs +0 -0
  52. /package/{esm2020 → esm2022}/public_api.mjs +0 -0
  53. /package/{esm2020 → esm2022}/svgs/index.mjs +0 -0
  54. /package/{esm2020 → esm2022}/utils/index.mjs +0 -0
@@ -1,386 +0,0 @@
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.emojiClick = new EventEmitter();
23
- /**
24
- * Note: the suffix is added explicitly so we know the event is dispatched outside of the Angular zone.
25
- */
26
- this.emojiOverOutsideAngular = new EventEmitter();
27
- this.emojiLeaveOutsideAngular = new EventEmitter();
28
- this.containerStyles = {};
29
- this.emojisToDisplay = [];
30
- this.filteredEmojisSubject = new Subject();
31
- this.filteredEmojis$ = this.filteredEmojisSubject.asObservable();
32
- this.labelStyles = {};
33
- this.labelSpanStyles = {};
34
- this.margin = 0;
35
- this.minMargin = 0;
36
- this.maxMargin = 0;
37
- this.top = 0;
38
- this.rows = 0;
39
- }
40
- ngOnInit() {
41
- this.updateRecentEmojis();
42
- this.emojisToDisplay = this.filterEmojis();
43
- if (this.noEmojiToDisplay) {
44
- this.containerStyles = { display: 'none' };
45
- }
46
- if (!this.hasStickyPosition) {
47
- this.labelStyles = { height: 28 };
48
- // this.labelSpanStyles = { position: 'absolute' };
49
- }
50
- }
51
- ngOnChanges(changes) {
52
- if (changes.emojis?.currentValue?.length !== changes.emojis?.previousValue?.length) {
53
- this.emojisToDisplay = this.filterEmojis();
54
- this.ngAfterViewInit();
55
- }
56
- }
57
- ngAfterViewInit() {
58
- if (!this.virtualize) {
59
- return;
60
- }
61
- const { width } = this.container.nativeElement.getBoundingClientRect();
62
- const perRow = Math.floor(width / (this.emojiSize + 12));
63
- this.rows = Math.ceil(this.emojisToDisplay.length / perRow);
64
- this.containerStyles = {
65
- ...this.containerStyles,
66
- minHeight: `${this.rows * (this.emojiSize + 12) + 28}px`,
67
- };
68
- this.ref.detectChanges();
69
- this.handleScroll(this.container.nativeElement.parentNode.parentNode.scrollTop);
70
- }
71
- get noEmojiToDisplay() {
72
- return this.emojisToDisplay.length === 0;
73
- }
74
- memoizeSize() {
75
- const parent = this.container.nativeElement.parentNode.parentNode;
76
- const { top, height } = this.container.nativeElement.getBoundingClientRect();
77
- const parentTop = parent.getBoundingClientRect().top;
78
- const labelHeight = this.label.nativeElement.getBoundingClientRect().height;
79
- this.top = top - parentTop + parent.scrollTop;
80
- if (height === 0) {
81
- this.maxMargin = 0;
82
- }
83
- else {
84
- this.maxMargin = height - labelHeight;
85
- }
86
- }
87
- handleScroll(scrollTop) {
88
- let margin = scrollTop - this.top;
89
- margin = margin < this.minMargin ? this.minMargin : margin;
90
- margin = margin > this.maxMargin ? this.maxMargin : margin;
91
- if (this.virtualize) {
92
- const { top, height } = this.container.nativeElement.getBoundingClientRect();
93
- const parentHeight = this.container.nativeElement.parentNode.parentNode.clientHeight;
94
- if (parentHeight + (parentHeight + this.virtualizeOffset) >= top &&
95
- -height - (parentHeight + this.virtualizeOffset) <= top) {
96
- this.filteredEmojisSubject.next(this.emojisToDisplay);
97
- }
98
- else {
99
- this.filteredEmojisSubject.next([]);
100
- }
101
- }
102
- if (margin === this.margin) {
103
- this.ref.detectChanges();
104
- return false;
105
- }
106
- if (!this.hasStickyPosition) {
107
- this.label.nativeElement.style.top = `${margin}px`;
108
- }
109
- this.margin = margin;
110
- this.ref.detectChanges();
111
- return true;
112
- }
113
- updateRecentEmojis() {
114
- if (this.name !== 'Recent') {
115
- return;
116
- }
117
- let frequentlyUsed = this.recent || this.frequently.get(this.perLine, this.totalFrequentLines);
118
- if (!frequentlyUsed || !frequentlyUsed.length) {
119
- frequentlyUsed = this.frequently.get(this.perLine, this.totalFrequentLines);
120
- }
121
- if (!frequentlyUsed.length) {
122
- return;
123
- }
124
- this.emojis = frequentlyUsed
125
- .map(id => {
126
- const emoji = this.custom.filter((e) => e.id === id)[0];
127
- if (emoji) {
128
- return emoji;
129
- }
130
- return id;
131
- })
132
- .filter(id => !!this.emojiService.getData(id));
133
- }
134
- updateDisplay(display) {
135
- this.containerStyles.display = display;
136
- this.updateRecentEmojis();
137
- this.ref.detectChanges();
138
- }
139
- trackById(index, item) {
140
- return item;
141
- }
142
- filterEmojis() {
143
- const newEmojis = [];
144
- for (const emoji of this.emojis || []) {
145
- if (!emoji) {
146
- continue;
147
- }
148
- const data = this.emojiService.getData(emoji);
149
- if (!data || (data.obsoletedBy && this.hideObsolete) || (!data.unified && !data.custom)) {
150
- continue;
151
- }
152
- newEmojis.push(emoji);
153
- }
154
- return newEmojis;
155
- }
156
- }
157
- CategoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CategoryComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EmojiService }, { token: i2.EmojiFrequentlyService }], target: i0.ɵɵFactoryTarget.Component });
158
- CategoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", 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: { emojiClick: "emojiClick", emojiOverOutsideAngular: "emojiOverOutsideAngular", emojiLeaveOutsideAngular: "emojiLeaveOutsideAngular" }, 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: `
159
- <section
160
- #container
161
- class="emoji-mart-category"
162
- [attr.aria-label]="i18n.categories[id]"
163
- [class.emoji-mart-no-results]="noEmojiToDisplay"
164
- [ngStyle]="containerStyles"
165
- >
166
- <div class="emoji-mart-category-label" [ngStyle]="labelStyles" [attr.data-name]="name">
167
- <!-- already labeled by the section aria-label -->
168
- <span #label [ngStyle]="labelSpanStyles" aria-hidden="true">
169
- {{ i18n.categories[id] }}
170
- </span>
171
- </div>
172
-
173
- <div *ngIf="virtualize; else normalRenderTemplate">
174
- <div *ngIf="filteredEmojis$ | async as filteredEmojis">
175
- <ngx-emoji
176
- *ngFor="let emoji of filteredEmojis; trackBy: trackById"
177
- [emoji]="emoji"
178
- [size]="emojiSize"
179
- [skin]="emojiSkin"
180
- [isNative]="emojiIsNative"
181
- [set]="emojiSet"
182
- [sheetSize]="emojiSheetSize"
183
- [forceSize]="emojiForceSize"
184
- [tooltip]="emojiTooltip"
185
- [backgroundImageFn]="emojiBackgroundImageFn"
186
- [imageUrlFn]="emojiImageUrlFn"
187
- [hideObsolete]="hideObsolete"
188
- [useButton]="emojiUseButton"
189
- (emojiOverOutsideAngular)="emojiOverOutsideAngular.emit($event)"
190
- (emojiLeaveOutsideAngular)="emojiLeaveOutsideAngular.emit($event)"
191
- (emojiClick)="emojiClick.emit($event)"
192
- ></ngx-emoji>
193
- </div>
194
- </div>
195
-
196
- <div *ngIf="noEmojiToDisplay">
197
- <div>
198
- <ngx-emoji
199
- [emoji]="notFoundEmoji"
200
- [size]="38"
201
- [skin]="emojiSkin"
202
- [isNative]="emojiIsNative"
203
- [set]="emojiSet"
204
- [sheetSize]="emojiSheetSize"
205
- [forceSize]="emojiForceSize"
206
- [tooltip]="emojiTooltip"
207
- [backgroundImageFn]="emojiBackgroundImageFn"
208
- [useButton]="emojiUseButton"
209
- ></ngx-emoji>
210
- </div>
211
-
212
- <div class="emoji-mart-no-results-label">
213
- {{ i18n.notfound }}
214
- </div>
215
- </div>
216
- </section>
217
-
218
- <ng-template #normalRenderTemplate>
219
- <ngx-emoji
220
- *ngFor="let emoji of emojisToDisplay; trackBy: trackById"
221
- [emoji]="emoji"
222
- [size]="emojiSize"
223
- [skin]="emojiSkin"
224
- [isNative]="emojiIsNative"
225
- [set]="emojiSet"
226
- [sheetSize]="emojiSheetSize"
227
- [forceSize]="emojiForceSize"
228
- [tooltip]="emojiTooltip"
229
- [backgroundImageFn]="emojiBackgroundImageFn"
230
- [imageUrlFn]="emojiImageUrlFn"
231
- [hideObsolete]="hideObsolete"
232
- [useButton]="emojiUseButton"
233
- (emojiOverOutsideAngular)="emojiOverOutsideAngular.emit($event)"
234
- (emojiLeaveOutsideAngular)="emojiLeaveOutsideAngular.emit($event)"
235
- (emojiClick)="emojiClick.emit($event)"
236
- ></ngx-emoji>
237
- </ng-template>
238
- `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i1.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: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
239
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: CategoryComponent, decorators: [{
240
- type: Component,
241
- args: [{
242
- selector: 'emoji-category',
243
- template: `
244
- <section
245
- #container
246
- class="emoji-mart-category"
247
- [attr.aria-label]="i18n.categories[id]"
248
- [class.emoji-mart-no-results]="noEmojiToDisplay"
249
- [ngStyle]="containerStyles"
250
- >
251
- <div class="emoji-mart-category-label" [ngStyle]="labelStyles" [attr.data-name]="name">
252
- <!-- already labeled by the section aria-label -->
253
- <span #label [ngStyle]="labelSpanStyles" aria-hidden="true">
254
- {{ i18n.categories[id] }}
255
- </span>
256
- </div>
257
-
258
- <div *ngIf="virtualize; else normalRenderTemplate">
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
- (emojiOverOutsideAngular)="emojiOverOutsideAngular.emit($event)"
275
- (emojiLeaveOutsideAngular)="emojiLeaveOutsideAngular.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
- (emojiOverOutsideAngular)="emojiOverOutsideAngular.emit($event)"
319
- (emojiLeaveOutsideAngular)="emojiLeaveOutsideAngular.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
- }], emojiClick: [{
374
- type: Output
375
- }], emojiOverOutsideAngular: [{
376
- type: Output
377
- }], emojiLeaveOutsideAngular: [{
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@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 *ngIf=\"virtualize; else normalRenderTemplate\">\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            (emojiOverOutsideAngular)=\"emojiOverOutsideAngular.emit($event)\"\n            (emojiLeaveOutsideAngular)=\"emojiLeaveOutsideAngular.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        (emojiOverOutsideAngular)=\"emojiOverOutsideAngular.emit($event)\"\n        (emojiLeaveOutsideAngular)=\"emojiLeaveOutsideAngular.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() emojiClick: Emoji['emojiClick'] = new EventEmitter();\n  /**\n   * Note: the suffix is added explicitly so we know the event is dispatched outside of the Angular zone.\n   */\n  @Output() emojiOverOutsideAngular: Emoji['emojiOver'] = new EventEmitter();\n  @Output() emojiLeaveOutsideAngular: Emoji['emojiLeave'] = 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  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 (\n        parentHeight + (parentHeight + this.virtualizeOffset) >= top &&\n        -height - (parentHeight + this.virtualizeOffset) <= top\n      ) {\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 = 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  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"]}
@@ -1,88 +0,0 @@
1
- import { isPlatformBrowser } from '@angular/common';
2
- import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
3
- import * as i0 from "@angular/core";
4
- export class EmojiFrequentlyService {
5
- constructor(platformId) {
6
- this.platformId = platformId;
7
- this.NAMESPACE = 'emoji-mart';
8
- this.frequently = null;
9
- this.defaults = {};
10
- this.initialized = false;
11
- this.DEFAULTS = [
12
- '+1',
13
- 'grinning',
14
- 'kissing_heart',
15
- 'heart_eyes',
16
- 'laughing',
17
- 'stuck_out_tongue_winking_eye',
18
- 'sweat_smile',
19
- 'joy',
20
- 'scream',
21
- 'disappointed',
22
- 'unamused',
23
- 'weary',
24
- 'sob',
25
- 'sunglasses',
26
- 'heart',
27
- 'poop',
28
- ];
29
- }
30
- init() {
31
- this.frequently = JSON.parse((isPlatformBrowser(this.platformId) &&
32
- localStorage.getItem(`${this.NAMESPACE}.frequently`)) ||
33
- 'null');
34
- this.initialized = true;
35
- }
36
- add(emoji) {
37
- if (!this.initialized) {
38
- this.init();
39
- }
40
- if (!this.frequently) {
41
- this.frequently = this.defaults;
42
- }
43
- if (!this.frequently[emoji.id]) {
44
- this.frequently[emoji.id] = 0;
45
- }
46
- this.frequently[emoji.id] += 1;
47
- if (isPlatformBrowser(this.platformId)) {
48
- localStorage.setItem(`${this.NAMESPACE}.last`, emoji.id);
49
- localStorage.setItem(`${this.NAMESPACE}.frequently`, JSON.stringify(this.frequently));
50
- }
51
- }
52
- get(perLine, totalLines) {
53
- if (!this.initialized) {
54
- this.init();
55
- }
56
- if (this.frequently === null) {
57
- this.defaults = {};
58
- const result = [];
59
- for (let i = 0; i < perLine; i++) {
60
- this.defaults[this.DEFAULTS[i]] = perLine - i;
61
- result.push(this.DEFAULTS[i]);
62
- }
63
- return result;
64
- }
65
- const quantity = perLine * totalLines;
66
- const frequentlyKeys = Object.keys(this.frequently);
67
- const sorted = frequentlyKeys
68
- .sort((a, b) => this.frequently[a] - this.frequently[b])
69
- .reverse();
70
- const sliced = sorted.slice(0, quantity);
71
- const last = isPlatformBrowser(this.platformId) && localStorage.getItem(`${this.NAMESPACE}.last`);
72
- if (last && !sliced.includes(last)) {
73
- sliced.pop();
74
- sliced.push(last);
75
- }
76
- return sliced;
77
- }
78
- }
79
- EmojiFrequentlyService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiFrequentlyService, deps: [{ token: PLATFORM_ID }], target: i0.ɵɵFactoryTarget.Injectable });
80
- EmojiFrequentlyService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiFrequentlyService, providedIn: 'root' });
81
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", 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==