@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.
- package/README.md +11 -19
- package/anchors.component.d.ts +3 -0
- package/category.component.d.ts +7 -2
- package/ctrl-ngx-emoji-mart.d.ts +1 -0
- package/emoji-frequently.service.d.ts +3 -0
- package/emoji-search.service.d.ts +3 -0
- package/esm2020/anchors.component.mjs +83 -0
- package/esm2020/category.component.mjs +386 -0
- package/{esm2015/ctrl-ngx-emoji-mart.js → esm2020/ctrl-ngx-emoji-mart.mjs} +0 -0
- package/{esm2015/emoji-frequently.service.js → esm2020/emoji-frequently.service.mjs} +10 -8
- package/esm2020/emoji-search.service.mjs +177 -0
- package/{esm2015/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.js → esm2020/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.mjs} +0 -0
- package/{esm2015/ngx-emoji/data/categories.js → esm2020/ngx-emoji/data/categories.mjs} +4 -4
- package/{esm2015/ngx-emoji/data/data.interfaces.js → esm2020/ngx-emoji/data/data.interfaces.mjs} +0 -0
- package/esm2020/ngx-emoji/data/emojis.mjs +29543 -0
- package/{esm2015/ngx-emoji/data/skins.js → esm2020/ngx-emoji/data/skins.mjs} +0 -0
- package/esm2020/ngx-emoji/emoji.component.mjs +236 -0
- package/esm2020/ngx-emoji/emoji.module.mjs +18 -0
- package/esm2020/ngx-emoji/emoji.service.mjs +144 -0
- package/{esm2015/ngx-emoji/index.js → esm2020/ngx-emoji/index.mjs} +0 -0
- package/esm2020/picker.component.mjs +505 -0
- package/esm2020/picker.module.mjs +49 -0
- package/esm2020/preview.component.mjs +187 -0
- package/{esm2015/public_api.js → esm2020/public_api.mjs} +0 -0
- package/esm2020/search.component.mjs +165 -0
- package/esm2020/skins.component.mjs +108 -0
- package/esm2020/svgs/index.mjs +18 -0
- package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
- package/fesm2015/{ctrl-ngx-emoji-mart-ngx-emoji.js → ctrl-ngx-emoji-mart-ngx-emoji.mjs} +24809 -18497
- package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -0
- package/fesm2015/{ctrl-ngx-emoji-mart.js → ctrl-ngx-emoji-mart.mjs} +676 -329
- package/fesm2015/ctrl-ngx-emoji-mart.mjs.map +1 -0
- package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs +31829 -0
- package/fesm2020/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -0
- package/fesm2020/ctrl-ngx-emoji-mart.mjs +1757 -0
- package/fesm2020/ctrl-ngx-emoji-mart.mjs.map +1 -0
- package/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.d.ts +1 -0
- package/ngx-emoji/emoji.component.d.ts +3 -0
- package/ngx-emoji/emoji.module.d.ts +6 -0
- package/ngx-emoji/emoji.service.d.ts +3 -0
- package/ngx-emoji/package.json +6 -7
- package/package.json +29 -10
- package/picker.component.d.ts +3 -0
- package/picker.css +0 -1
- package/picker.module.d.ts +13 -0
- package/preview.component.d.ts +4 -1
- package/search.component.d.ts +3 -0
- package/skins.component.d.ts +6 -3
- package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.js +0 -25822
- package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.js.map +0 -1
- package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.min.js +0 -2
- package/bundles/ctrl-ngx-emoji-mart-ngx-emoji.umd.min.js.map +0 -1
- package/bundles/ctrl-ngx-emoji-mart.umd.js +0 -1695
- package/bundles/ctrl-ngx-emoji-mart.umd.js.map +0 -1
- package/bundles/ctrl-ngx-emoji-mart.umd.min.js +0 -2
- package/bundles/ctrl-ngx-emoji-mart.umd.min.js.map +0 -1
- package/ctrl-ngx-emoji-mart.metadata.json +0 -1
- package/esm2015/anchors.component.js +0 -54
- package/esm2015/category.component.js +0 -276
- package/esm2015/emoji-search.service.js +0 -179
- package/esm2015/ngx-emoji/data/emojis.js +0 -23289
- package/esm2015/ngx-emoji/emoji.component.js +0 -174
- package/esm2015/ngx-emoji/emoji.module.js +0 -13
- package/esm2015/ngx-emoji/emoji.service.js +0 -143
- package/esm2015/picker.component.js +0 -459
- package/esm2015/picker.module.js +0 -34
- package/esm2015/preview.component.js +0 -113
- package/esm2015/search.component.js +0 -115
- package/esm2015/skins.component.js +0 -76
- package/esm2015/svgs/index.js +0 -18
- package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.js.map +0 -1
- package/fesm2015/ctrl-ngx-emoji-mart.js.map +0 -1
- package/ngx-emoji/ctrl-ngx-emoji-mart-ngx-emoji.metadata.json +0 -1
@@ -1,459 +0,0 @@
|
|
1
|
-
import { isPlatformBrowser } from '@angular/common';
|
2
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Inject, Input, NgZone, Output, PLATFORM_ID, Renderer2, ViewChild, ViewChildren, } from '@angular/core';
|
3
|
-
import { categories, } from '@ctrl/ngx-emoji-mart/ngx-emoji';
|
4
|
-
import { CategoryComponent } from './category.component';
|
5
|
-
import { EmojiFrequentlyService } from './emoji-frequently.service';
|
6
|
-
import { PreviewComponent } from './preview.component';
|
7
|
-
import { SearchComponent } from './search.component';
|
8
|
-
import * as icons from './svgs';
|
9
|
-
import { measureScrollbar } from './utils';
|
10
|
-
const I18N = {
|
11
|
-
search: 'Search',
|
12
|
-
emojilist: 'List of emoji',
|
13
|
-
notfound: 'No Emoji Found',
|
14
|
-
clear: 'Clear',
|
15
|
-
categories: {
|
16
|
-
search: 'Search Results',
|
17
|
-
recent: 'Frequently Used',
|
18
|
-
people: 'Smileys & People',
|
19
|
-
nature: 'Animals & Nature',
|
20
|
-
foods: 'Food & Drink',
|
21
|
-
activity: 'Activity',
|
22
|
-
places: 'Travel & Places',
|
23
|
-
objects: 'Objects',
|
24
|
-
symbols: 'Symbols',
|
25
|
-
flags: 'Flags',
|
26
|
-
custom: 'Custom',
|
27
|
-
},
|
28
|
-
skintones: {
|
29
|
-
1: 'Default Skin Tone',
|
30
|
-
2: 'Light Skin Tone',
|
31
|
-
3: 'Medium-Light Skin Tone',
|
32
|
-
4: 'Medium Skin Tone',
|
33
|
-
5: 'Medium-Dark Skin Tone',
|
34
|
-
6: 'Dark Skin Tone',
|
35
|
-
},
|
36
|
-
};
|
37
|
-
export class PickerComponent {
|
38
|
-
constructor(ngZone, renderer, ref, frequently, platformId) {
|
39
|
-
this.ngZone = ngZone;
|
40
|
-
this.renderer = renderer;
|
41
|
-
this.ref = ref;
|
42
|
-
this.frequently = frequently;
|
43
|
-
this.platformId = platformId;
|
44
|
-
this.perLine = 9;
|
45
|
-
this.totalFrequentLines = 4;
|
46
|
-
this.i18n = {};
|
47
|
-
this.style = {};
|
48
|
-
this.title = 'Emoji Mart™';
|
49
|
-
this.emoji = 'department_store';
|
50
|
-
this.darkMode = !!(typeof matchMedia === 'function' && matchMedia('(prefers-color-scheme: dark)').matches);
|
51
|
-
this.color = '#ae65c5';
|
52
|
-
this.hideObsolete = true;
|
53
|
-
/** all categories shown */
|
54
|
-
this.categories = [];
|
55
|
-
/** used to temporarily draw categories */
|
56
|
-
this.activeCategories = [];
|
57
|
-
this.set = 'apple';
|
58
|
-
this.skin = 1;
|
59
|
-
/** Renders the native unicode emoji */
|
60
|
-
this.isNative = false;
|
61
|
-
this.emojiSize = 24;
|
62
|
-
this.sheetSize = 64;
|
63
|
-
this.showPreview = true;
|
64
|
-
this.emojiTooltip = false;
|
65
|
-
this.autoFocus = false;
|
66
|
-
this.custom = [];
|
67
|
-
this.hideRecent = true;
|
68
|
-
this.notFoundEmoji = 'sleuth_or_spy';
|
69
|
-
this.categoriesIcons = icons.categories;
|
70
|
-
this.searchIcons = icons.search;
|
71
|
-
this.useButton = false;
|
72
|
-
this.enableFrequentEmojiSort = false;
|
73
|
-
this.enableSearch = true;
|
74
|
-
this.showSingleCategory = false;
|
75
|
-
this.virtualize = false;
|
76
|
-
this.virtualizeOffset = 0;
|
77
|
-
this.emojiClick = new EventEmitter();
|
78
|
-
this.emojiSelect = new EventEmitter();
|
79
|
-
this.skinChange = new EventEmitter();
|
80
|
-
this.scrollHeight = 0;
|
81
|
-
this.clientHeight = 0;
|
82
|
-
this.clientWidth = 0;
|
83
|
-
this.firstRender = true;
|
84
|
-
this.animationFrameRequestId = null;
|
85
|
-
this.NAMESPACE = 'emoji-mart';
|
86
|
-
this.measureScrollbar = 0;
|
87
|
-
this.RECENT_CATEGORY = {
|
88
|
-
id: 'recent',
|
89
|
-
name: 'Recent',
|
90
|
-
emojis: null,
|
91
|
-
};
|
92
|
-
this.SEARCH_CATEGORY = {
|
93
|
-
id: 'search',
|
94
|
-
name: 'Search',
|
95
|
-
emojis: null,
|
96
|
-
anchor: false,
|
97
|
-
};
|
98
|
-
this.CUSTOM_CATEGORY = {
|
99
|
-
id: 'custom',
|
100
|
-
name: 'Custom',
|
101
|
-
emojis: [],
|
102
|
-
};
|
103
|
-
this.backgroundImageFn = (set, sheetSize) => `https://unpkg.com/emoji-datasource-${this.set}@6.0.0/img/${this.set}/sheets-256/${this.sheetSize}.png`;
|
104
|
-
}
|
105
|
-
ngOnInit() {
|
106
|
-
// measure scroll
|
107
|
-
this.measureScrollbar = measureScrollbar();
|
108
|
-
this.i18n = Object.assign(Object.assign({}, I18N), this.i18n);
|
109
|
-
this.i18n.categories = Object.assign(Object.assign({}, I18N.categories), this.i18n.categories);
|
110
|
-
this.skin =
|
111
|
-
JSON.parse((isPlatformBrowser(this.platformId) && localStorage.getItem(`${this.NAMESPACE}.skin`)) ||
|
112
|
-
'null') || this.skin;
|
113
|
-
const allCategories = [...categories];
|
114
|
-
if (this.custom.length > 0) {
|
115
|
-
this.CUSTOM_CATEGORY.emojis = this.custom.map(emoji => {
|
116
|
-
return Object.assign(Object.assign({}, emoji), {
|
117
|
-
// `<Category />` expects emoji to have an `id`.
|
118
|
-
id: emoji.shortNames[0], custom: true });
|
119
|
-
});
|
120
|
-
allCategories.push(this.CUSTOM_CATEGORY);
|
121
|
-
}
|
122
|
-
if (this.include !== undefined) {
|
123
|
-
allCategories.sort((a, b) => {
|
124
|
-
if (this.include.indexOf(a.id) > this.include.indexOf(b.id)) {
|
125
|
-
return 1;
|
126
|
-
}
|
127
|
-
return -1;
|
128
|
-
});
|
129
|
-
}
|
130
|
-
for (const category of allCategories) {
|
131
|
-
const isIncluded = this.include && this.include.length ? this.include.indexOf(category.id) > -1 : true;
|
132
|
-
const isExcluded = this.exclude && this.exclude.length ? this.exclude.indexOf(category.id) > -1 : false;
|
133
|
-
if (!isIncluded || isExcluded) {
|
134
|
-
continue;
|
135
|
-
}
|
136
|
-
if (this.emojisToShowFilter) {
|
137
|
-
const newEmojis = [];
|
138
|
-
const { emojis } = category;
|
139
|
-
// tslint:disable-next-line: prefer-for-of
|
140
|
-
for (let emojiIndex = 0; emojiIndex < emojis.length; emojiIndex++) {
|
141
|
-
const emoji = emojis[emojiIndex];
|
142
|
-
if (this.emojisToShowFilter(emoji)) {
|
143
|
-
newEmojis.push(emoji);
|
144
|
-
}
|
145
|
-
}
|
146
|
-
if (newEmojis.length) {
|
147
|
-
const newCategory = {
|
148
|
-
emojis: newEmojis,
|
149
|
-
name: category.name,
|
150
|
-
id: category.id,
|
151
|
-
};
|
152
|
-
this.categories.push(newCategory);
|
153
|
-
}
|
154
|
-
}
|
155
|
-
else {
|
156
|
-
this.categories.push(category);
|
157
|
-
}
|
158
|
-
this.categoriesIcons = Object.assign(Object.assign({}, icons.categories), this.categoriesIcons);
|
159
|
-
this.searchIcons = Object.assign(Object.assign({}, icons.search), this.searchIcons);
|
160
|
-
}
|
161
|
-
const includeRecent = this.include && this.include.length
|
162
|
-
? this.include.indexOf(this.RECENT_CATEGORY.id) > -1
|
163
|
-
: true;
|
164
|
-
const excludeRecent = this.exclude && this.exclude.length
|
165
|
-
? this.exclude.indexOf(this.RECENT_CATEGORY.id) > -1
|
166
|
-
: false;
|
167
|
-
if (includeRecent && !excludeRecent) {
|
168
|
-
this.hideRecent = false;
|
169
|
-
this.categories.unshift(this.RECENT_CATEGORY);
|
170
|
-
}
|
171
|
-
if (this.categories[0]) {
|
172
|
-
this.categories[0].first = true;
|
173
|
-
}
|
174
|
-
this.categories.unshift(this.SEARCH_CATEGORY);
|
175
|
-
this.selected = this.categories.filter(category => category.first)[0].name;
|
176
|
-
// Need to be careful if small number of categories
|
177
|
-
const categoriesToLoadFirst = Math.min(this.categories.length, 3);
|
178
|
-
this.setActiveCategories((this.activeCategories = this.categories.slice(0, categoriesToLoadFirst)));
|
179
|
-
// Trim last active category
|
180
|
-
const lastActiveCategoryEmojis = this.categories[categoriesToLoadFirst - 1].emojis.slice();
|
181
|
-
this.categories[categoriesToLoadFirst - 1].emojis = lastActiveCategoryEmojis.slice(0, 60);
|
182
|
-
setTimeout(() => {
|
183
|
-
// Restore last category
|
184
|
-
this.categories[categoriesToLoadFirst - 1].emojis = lastActiveCategoryEmojis;
|
185
|
-
this.setActiveCategories(this.categories);
|
186
|
-
// The `setTimeout` will trigger the change detection, but since we're inside
|
187
|
-
// the OnPush component we can run change detection locally starting from this
|
188
|
-
// component and going down to the children.
|
189
|
-
this.ref.detectChanges();
|
190
|
-
// tslint:disable-next-line: no-unused-expression
|
191
|
-
isPlatformBrowser(this.platformId) &&
|
192
|
-
this.ngZone.runOutsideAngular(() => {
|
193
|
-
// The `updateCategoriesSize` doesn't change properties that are used
|
194
|
-
// in templates, thus this is run in the context of the root zone to avoid
|
195
|
-
// running change detection.
|
196
|
-
requestAnimationFrame(() => {
|
197
|
-
this.updateCategoriesSize();
|
198
|
-
});
|
199
|
-
});
|
200
|
-
});
|
201
|
-
this.ngZone.runOutsideAngular(() => {
|
202
|
-
// DOM events that are listened by Angular inside the template trigger change detection
|
203
|
-
// and also wrapped into additional functions that call `markForCheck()`. We listen `scroll`
|
204
|
-
// in the context of the root zone since it will not trigger change detection each time
|
205
|
-
// the `scroll` event is dispatched.
|
206
|
-
this.scrollListener = this.renderer.listen(this.scrollRef.nativeElement, 'scroll', () => {
|
207
|
-
this.handleScroll();
|
208
|
-
});
|
209
|
-
});
|
210
|
-
}
|
211
|
-
ngOnDestroy() {
|
212
|
-
this.scrollListener();
|
213
|
-
// This is called here because the component might be destroyed
|
214
|
-
// but there will still be a `requestAnimationFrame` callback in the queue
|
215
|
-
// that calls `detectChanges()` on the `ViewRef`. This will lead to a runtime
|
216
|
-
// exception if the `detectChanges()` is called after the `ViewRef` is destroyed.
|
217
|
-
this.cancelAnimationFrame();
|
218
|
-
}
|
219
|
-
setActiveCategories(categoriesToMakeActive) {
|
220
|
-
if (this.showSingleCategory) {
|
221
|
-
this.activeCategories = categoriesToMakeActive.filter(x => x.name === this.selected || x === this.SEARCH_CATEGORY);
|
222
|
-
}
|
223
|
-
else {
|
224
|
-
this.activeCategories = categoriesToMakeActive;
|
225
|
-
}
|
226
|
-
}
|
227
|
-
updateCategoriesSize() {
|
228
|
-
this.categoryRefs.forEach(component => component.memoizeSize());
|
229
|
-
if (this.scrollRef) {
|
230
|
-
const target = this.scrollRef.nativeElement;
|
231
|
-
this.scrollHeight = target.scrollHeight;
|
232
|
-
this.clientHeight = target.clientHeight;
|
233
|
-
this.clientWidth = target.clientWidth;
|
234
|
-
}
|
235
|
-
}
|
236
|
-
handleAnchorClick($event) {
|
237
|
-
var _a;
|
238
|
-
this.updateCategoriesSize();
|
239
|
-
this.selected = $event.category.name;
|
240
|
-
this.setActiveCategories(this.categories);
|
241
|
-
if (this.SEARCH_CATEGORY.emojis) {
|
242
|
-
this.handleSearch(null);
|
243
|
-
(_a = this.searchRef) === null || _a === void 0 ? void 0 : _a.clear();
|
244
|
-
this.handleAnchorClick($event);
|
245
|
-
return;
|
246
|
-
}
|
247
|
-
const component = this.categoryRefs.find(n => n.id === $event.category.id);
|
248
|
-
if (component) {
|
249
|
-
let { top } = component;
|
250
|
-
if ($event.category.first) {
|
251
|
-
top = 0;
|
252
|
-
}
|
253
|
-
else {
|
254
|
-
top += 1;
|
255
|
-
}
|
256
|
-
this.scrollRef.nativeElement.scrollTop = top;
|
257
|
-
}
|
258
|
-
this.nextScroll = $event.category.name;
|
259
|
-
// handle component scrolling to load emojis
|
260
|
-
for (const category of this.categories) {
|
261
|
-
const componentToScroll = this.categoryRefs.find(({ id }) => id === category.id);
|
262
|
-
componentToScroll === null || componentToScroll === void 0 ? void 0 : componentToScroll.handleScroll(this.scrollRef.nativeElement.scrollTop);
|
263
|
-
}
|
264
|
-
}
|
265
|
-
categoryTrack(index, item) {
|
266
|
-
return item.id;
|
267
|
-
}
|
268
|
-
handleScroll(noSelectionChange = false) {
|
269
|
-
if (this.nextScroll) {
|
270
|
-
this.selected = this.nextScroll;
|
271
|
-
this.nextScroll = undefined;
|
272
|
-
this.ref.detectChanges();
|
273
|
-
return;
|
274
|
-
}
|
275
|
-
if (!this.scrollRef) {
|
276
|
-
return;
|
277
|
-
}
|
278
|
-
if (this.showSingleCategory) {
|
279
|
-
return;
|
280
|
-
}
|
281
|
-
let activeCategory;
|
282
|
-
if (this.SEARCH_CATEGORY.emojis) {
|
283
|
-
activeCategory = this.SEARCH_CATEGORY;
|
284
|
-
}
|
285
|
-
else {
|
286
|
-
const target = this.scrollRef.nativeElement;
|
287
|
-
// check scroll is not at bottom
|
288
|
-
if (target.scrollTop === 0) {
|
289
|
-
// hit the TOP
|
290
|
-
activeCategory = this.categories.find(n => n.first === true);
|
291
|
-
}
|
292
|
-
else if (target.scrollHeight - target.scrollTop === this.clientHeight) {
|
293
|
-
// scrolled to bottom activate last category
|
294
|
-
activeCategory = this.categories[this.categories.length - 1];
|
295
|
-
}
|
296
|
-
else {
|
297
|
-
// scrolling
|
298
|
-
for (const category of this.categories) {
|
299
|
-
const component = this.categoryRefs.find(({ id }) => id === category.id);
|
300
|
-
const active = component === null || component === void 0 ? void 0 : component.handleScroll(target.scrollTop);
|
301
|
-
if (active) {
|
302
|
-
activeCategory = category;
|
303
|
-
}
|
304
|
-
}
|
305
|
-
}
|
306
|
-
this.scrollTop = target.scrollTop;
|
307
|
-
}
|
308
|
-
// This will allow us to run the change detection only when the category changes.
|
309
|
-
if (!noSelectionChange && activeCategory && activeCategory.name !== this.selected) {
|
310
|
-
this.selected = activeCategory.name;
|
311
|
-
this.ref.detectChanges();
|
312
|
-
}
|
313
|
-
else if (noSelectionChange) {
|
314
|
-
this.ref.detectChanges();
|
315
|
-
}
|
316
|
-
}
|
317
|
-
handleSearch($emojis) {
|
318
|
-
this.SEARCH_CATEGORY.emojis = $emojis;
|
319
|
-
for (const component of this.categoryRefs.toArray()) {
|
320
|
-
if (component.name === 'Search') {
|
321
|
-
component.emojis = $emojis;
|
322
|
-
component.updateDisplay($emojis ? 'block' : 'none');
|
323
|
-
}
|
324
|
-
else {
|
325
|
-
component.updateDisplay($emojis ? 'none' : 'block');
|
326
|
-
}
|
327
|
-
}
|
328
|
-
this.scrollRef.nativeElement.scrollTop = 0;
|
329
|
-
this.handleScroll();
|
330
|
-
}
|
331
|
-
handleEnterKey($event, emoji) {
|
332
|
-
if (!emoji) {
|
333
|
-
if (this.SEARCH_CATEGORY.emojis !== null && this.SEARCH_CATEGORY.emojis.length) {
|
334
|
-
emoji = this.SEARCH_CATEGORY.emojis[0];
|
335
|
-
if (emoji) {
|
336
|
-
this.emojiSelect.emit({ $event, emoji });
|
337
|
-
}
|
338
|
-
else {
|
339
|
-
return;
|
340
|
-
}
|
341
|
-
}
|
342
|
-
}
|
343
|
-
if (!this.hideRecent && !this.recent && emoji) {
|
344
|
-
this.frequently.add(emoji);
|
345
|
-
}
|
346
|
-
const component = this.categoryRefs.toArray()[1];
|
347
|
-
if (component && this.enableFrequentEmojiSort) {
|
348
|
-
component.getEmojis();
|
349
|
-
component.ref.markForCheck();
|
350
|
-
}
|
351
|
-
}
|
352
|
-
handleEmojiOver($event) {
|
353
|
-
var _a;
|
354
|
-
if (!this.showPreview || !this.previewRef) {
|
355
|
-
return;
|
356
|
-
}
|
357
|
-
const emojiData = this.CUSTOM_CATEGORY.emojis.find((customEmoji) => customEmoji.id === $event.emoji.id);
|
358
|
-
if (emojiData) {
|
359
|
-
$event.emoji = Object.assign({}, emojiData);
|
360
|
-
}
|
361
|
-
this.previewEmoji = $event.emoji;
|
362
|
-
this.cancelAnimationFrame();
|
363
|
-
(_a = this.ref) === null || _a === void 0 ? void 0 : _a.detectChanges();
|
364
|
-
}
|
365
|
-
handleEmojiLeave() {
|
366
|
-
if (!this.showPreview || !this.previewRef) {
|
367
|
-
return;
|
368
|
-
}
|
369
|
-
this.ngZone.runOutsideAngular(() => {
|
370
|
-
this.animationFrameRequestId = requestAnimationFrame(() => {
|
371
|
-
this.previewEmoji = null;
|
372
|
-
this.ref.detectChanges();
|
373
|
-
});
|
374
|
-
});
|
375
|
-
}
|
376
|
-
handleEmojiClick($event) {
|
377
|
-
this.emojiClick.emit($event);
|
378
|
-
this.emojiSelect.emit($event);
|
379
|
-
this.handleEnterKey($event.$event, $event.emoji);
|
380
|
-
}
|
381
|
-
handleSkinChange(skin) {
|
382
|
-
this.skin = skin;
|
383
|
-
localStorage.setItem(`${this.NAMESPACE}.skin`, String(skin));
|
384
|
-
this.skinChange.emit(skin);
|
385
|
-
}
|
386
|
-
getWidth() {
|
387
|
-
if (this.style && this.style.width) {
|
388
|
-
return this.style.width;
|
389
|
-
}
|
390
|
-
return this.perLine * (this.emojiSize + 12) + 12 + 2 + this.measureScrollbar + 'px';
|
391
|
-
}
|
392
|
-
cancelAnimationFrame() {
|
393
|
-
if (this.animationFrameRequestId !== null) {
|
394
|
-
cancelAnimationFrame(this.animationFrameRequestId);
|
395
|
-
this.animationFrameRequestId = null;
|
396
|
-
}
|
397
|
-
}
|
398
|
-
}
|
399
|
-
PickerComponent.decorators = [
|
400
|
-
{ type: Component, args: [{
|
401
|
-
selector: 'emoji-mart',
|
402
|
-
template: "<section\n class=\"emoji-mart {{ darkMode ? 'emoji-mart-dark' : '' }}\"\n [style.width]=\"getWidth()\"\n [ngStyle]=\"style\"\n>\n <div class=\"emoji-mart-bar\">\n <emoji-mart-anchors\n [categories]=\"categories\"\n (anchorClick)=\"handleAnchorClick($event)\"\n [color]=\"color\"\n [selected]=\"selected\"\n [i18n]=\"i18n\"\n [icons]=\"categoriesIcons\"\n ></emoji-mart-anchors>\n </div>\n <emoji-search\n *ngIf=\"enableSearch\"\n [i18n]=\"i18n\"\n (searchResults)=\"handleSearch($event)\"\n (enterKey)=\"handleEnterKey($event)\"\n [include]=\"include\"\n [exclude]=\"exclude\"\n [custom]=\"custom\"\n [autoFocus]=\"autoFocus\"\n [icons]=\"searchIcons\"\n [emojisToShowFilter]=\"emojisToShowFilter\"\n ></emoji-search>\n <section #scrollRef class=\"emoji-mart-scroll\" [attr.aria-label]=\"i18n.emojilist\">\n <emoji-category\n *ngFor=\"let category of activeCategories; let idx = index; trackBy: categoryTrack\"\n [id]=\"category.id\"\n [name]=\"category.name\"\n [emojis]=\"category.emojis\"\n [perLine]=\"perLine\"\n [totalFrequentLines]=\"totalFrequentLines\"\n [hasStickyPosition]=\"isNative\"\n [i18n]=\"i18n\"\n [hideObsolete]=\"hideObsolete\"\n [notFoundEmoji]=\"notFoundEmoji\"\n [custom]=\"category.id == RECENT_CATEGORY.id ? CUSTOM_CATEGORY.emojis : undefined\"\n [recent]=\"category.id == RECENT_CATEGORY.id ? recent : undefined\"\n [virtualize]=\"virtualize\"\n [virtualizeOffset]=\"virtualizeOffset\"\n [emojiIsNative]=\"isNative\"\n [emojiSkin]=\"skin\"\n [emojiSize]=\"emojiSize\"\n [emojiSet]=\"set\"\n [emojiSheetSize]=\"sheetSize\"\n [emojiForceSize]=\"isNative\"\n [emojiTooltip]=\"emojiTooltip\"\n [emojiBackgroundImageFn]=\"backgroundImageFn\"\n [emojiImageUrlFn]=\"imageUrlFn\"\n [emojiUseButton]=\"useButton\"\n (emojiOver)=\"handleEmojiOver($event)\"\n (emojiLeave)=\"handleEmojiLeave()\"\n (emojiClick)=\"handleEmojiClick($event)\"\n ></emoji-category>\n </section>\n <div class=\"emoji-mart-bar\" *ngIf=\"showPreview\">\n <emoji-preview\n [title]=\"title\"\n [emoji]=\"previewEmoji\"\n [idleEmoji]=\"emoji\"\n [emojiIsNative]=\"isNative\"\n [emojiSize]=\"38\"\n [emojiSkin]=\"skin\"\n [emojiSet]=\"set\"\n [i18n]=\"i18n\"\n [emojiSheetSize]=\"sheetSize\"\n [emojiBackgroundImageFn]=\"backgroundImageFn\"\n [emojiImageUrlFn]=\"imageUrlFn\"\n (skinChange)=\"handleSkinChange($event)\"\n ></emoji-preview>\n </div>\n</section>\n",
|
403
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
404
|
-
preserveWhitespaces: false
|
405
|
-
},] }
|
406
|
-
];
|
407
|
-
PickerComponent.ctorParameters = () => [
|
408
|
-
{ type: NgZone },
|
409
|
-
{ type: Renderer2 },
|
410
|
-
{ type: ChangeDetectorRef },
|
411
|
-
{ type: EmojiFrequentlyService },
|
412
|
-
{ type: String, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
|
413
|
-
];
|
414
|
-
PickerComponent.propDecorators = {
|
415
|
-
perLine: [{ type: Input }],
|
416
|
-
totalFrequentLines: [{ type: Input }],
|
417
|
-
i18n: [{ type: Input }],
|
418
|
-
style: [{ type: Input }],
|
419
|
-
title: [{ type: Input }],
|
420
|
-
emoji: [{ type: Input }],
|
421
|
-
darkMode: [{ type: Input }],
|
422
|
-
color: [{ type: Input }],
|
423
|
-
hideObsolete: [{ type: Input }],
|
424
|
-
categories: [{ type: Input }],
|
425
|
-
activeCategories: [{ type: Input }],
|
426
|
-
set: [{ type: Input }],
|
427
|
-
skin: [{ type: Input }],
|
428
|
-
isNative: [{ type: Input }],
|
429
|
-
emojiSize: [{ type: Input }],
|
430
|
-
sheetSize: [{ type: Input }],
|
431
|
-
emojisToShowFilter: [{ type: Input }],
|
432
|
-
showPreview: [{ type: Input }],
|
433
|
-
emojiTooltip: [{ type: Input }],
|
434
|
-
autoFocus: [{ type: Input }],
|
435
|
-
custom: [{ type: Input }],
|
436
|
-
hideRecent: [{ type: Input }],
|
437
|
-
imageUrlFn: [{ type: Input }],
|
438
|
-
include: [{ type: Input }],
|
439
|
-
exclude: [{ type: Input }],
|
440
|
-
notFoundEmoji: [{ type: Input }],
|
441
|
-
categoriesIcons: [{ type: Input }],
|
442
|
-
searchIcons: [{ type: Input }],
|
443
|
-
useButton: [{ type: Input }],
|
444
|
-
enableFrequentEmojiSort: [{ type: Input }],
|
445
|
-
enableSearch: [{ type: Input }],
|
446
|
-
showSingleCategory: [{ type: Input }],
|
447
|
-
virtualize: [{ type: Input }],
|
448
|
-
virtualizeOffset: [{ type: Input }],
|
449
|
-
recent: [{ type: Input }],
|
450
|
-
emojiClick: [{ type: Output }],
|
451
|
-
emojiSelect: [{ type: Output }],
|
452
|
-
skinChange: [{ type: Output }],
|
453
|
-
scrollRef: [{ type: ViewChild, args: ['scrollRef', { static: true },] }],
|
454
|
-
previewRef: [{ type: ViewChild, args: [PreviewComponent, { static: false },] }],
|
455
|
-
searchRef: [{ type: ViewChild, args: [SearchComponent, { static: false },] }],
|
456
|
-
categoryRefs: [{ type: ViewChildren, args: [CategoryComponent,] }],
|
457
|
-
backgroundImageFn: [{ type: Input }]
|
458
|
-
};
|
459
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"picker.component.js","sourceRoot":"","sources":["../../src/lib/picker/picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  PLATFORM_ID,\n  QueryList,\n  Renderer2,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\n\nimport {\n  categories,\n  Emoji,\n  EmojiCategory,\n  EmojiData,\n  EmojiEvent,\n} from '@ctrl/ngx-emoji-mart/ngx-emoji';\nimport { CategoryComponent } from './category.component';\nimport { EmojiFrequentlyService } from './emoji-frequently.service';\nimport { PreviewComponent } from './preview.component';\nimport { SearchComponent } from './search.component';\nimport * as icons from './svgs';\nimport { measureScrollbar } from './utils';\n\nconst I18N: any = {\n  search: 'Search',\n  emojilist: 'List of emoji',\n  notfound: 'No Emoji Found',\n  clear: 'Clear',\n  categories: {\n    search: 'Search Results',\n    recent: 'Frequently Used',\n    people: 'Smileys & People',\n    nature: 'Animals & Nature',\n    foods: 'Food & Drink',\n    activity: 'Activity',\n    places: 'Travel & Places',\n    objects: 'Objects',\n    symbols: 'Symbols',\n    flags: 'Flags',\n    custom: 'Custom',\n  },\n  skintones: {\n    1: 'Default Skin Tone',\n    2: 'Light Skin Tone',\n    3: 'Medium-Light Skin Tone',\n    4: 'Medium Skin Tone',\n    5: 'Medium-Dark Skin Tone',\n    6: 'Dark Skin Tone',\n  },\n};\n\n@Component({\n  selector: 'emoji-mart',\n  templateUrl: './picker.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class PickerComponent implements OnInit, OnDestroy {\n  @Input() perLine = 9;\n  @Input() totalFrequentLines = 4;\n  @Input() i18n: any = {};\n  @Input() style: any = {};\n  @Input() title = 'Emoji Mart™';\n  @Input() emoji = 'department_store';\n  @Input() darkMode = !!(\n    typeof matchMedia === 'function' && matchMedia('(prefers-color-scheme: dark)').matches\n  );\n  @Input() color = '#ae65c5';\n  @Input() hideObsolete = true;\n  /** all categories shown */\n  @Input() categories: EmojiCategory[] = [];\n  /** used to temporarily draw categories */\n  @Input() activeCategories: EmojiCategory[] = [];\n  @Input() set: Emoji['set'] = 'apple';\n  @Input() skin: Emoji['skin'] = 1;\n  /** Renders the native unicode emoji */\n  @Input() isNative: Emoji['isNative'] = false;\n  @Input() emojiSize: Emoji['size'] = 24;\n  @Input() sheetSize: Emoji['sheetSize'] = 64;\n  @Input() emojisToShowFilter?: (x: string) => boolean;\n  @Input() showPreview = true;\n  @Input() emojiTooltip = false;\n  @Input() autoFocus = false;\n  @Input() custom: any[] = [];\n  @Input() hideRecent = true;\n  @Input() imageUrlFn: Emoji['imageUrlFn'];\n  @Input() include?: string[];\n  @Input() exclude?: string[];\n  @Input() notFoundEmoji = 'sleuth_or_spy';\n  @Input() categoriesIcons = icons.categories;\n  @Input() searchIcons = icons.search;\n  @Input() useButton = false;\n  @Input() enableFrequentEmojiSort = false;\n  @Input() enableSearch = true;\n  @Input() showSingleCategory = false;\n  @Input() virtualize = false;\n  @Input() virtualizeOffset = 0;\n  @Input() recent?: string[];\n  @Output() emojiClick = new EventEmitter<any>();\n  @Output() emojiSelect = new EventEmitter<any>();\n  @Output() skinChange = new EventEmitter<Emoji['skin']>();\n  @ViewChild('scrollRef', { static: true }) private scrollRef!: ElementRef;\n  @ViewChild(PreviewComponent, { static: false }) previewRef?: PreviewComponent;\n  @ViewChild(SearchComponent, { static: false }) searchRef?: SearchComponent;\n  @ViewChildren(CategoryComponent) categoryRefs!: QueryList<CategoryComponent>;\n  scrollHeight = 0;\n  clientHeight = 0;\n  clientWidth = 0;\n  selected?: string;\n  nextScroll?: string;\n  scrollTop?: number;\n  firstRender = true;\n  previewEmoji: any;\n  animationFrameRequestId: number | null = null;\n  NAMESPACE = 'emoji-mart';\n  measureScrollbar = 0;\n  RECENT_CATEGORY: EmojiCategory = {\n    id: 'recent',\n    name: 'Recent',\n    emojis: null,\n  };\n  SEARCH_CATEGORY: EmojiCategory = {\n    id: 'search',\n    name: 'Search',\n    emojis: null,\n    anchor: false,\n  };\n  CUSTOM_CATEGORY: EmojiCategory = {\n    id: 'custom',\n    name: 'Custom',\n    emojis: [],\n  };\n  private scrollListener!: () => void;\n\n  @Input()\n  backgroundImageFn: Emoji['backgroundImageFn'] = (set: string, sheetSize: number) =>\n    `https://unpkg.com/emoji-datasource-${this.set}@6.0.0/img/${this.set}/sheets-256/${this.sheetSize}.png`\n\n  constructor(\n    private ngZone: NgZone,\n    private renderer: Renderer2,\n    private ref: ChangeDetectorRef,\n    private frequently: EmojiFrequentlyService,\n    @Inject(PLATFORM_ID) private platformId: string,\n  ) {}\n\n  ngOnInit() {\n    // measure scroll\n    this.measureScrollbar = measureScrollbar();\n\n    this.i18n = { ...I18N, ...this.i18n };\n    this.i18n.categories = { ...I18N.categories, ...this.i18n.categories };\n    this.skin =\n      JSON.parse(\n        (isPlatformBrowser(this.platformId) && localStorage.getItem(`${this.NAMESPACE}.skin`)) ||\n          'null',\n      ) || this.skin;\n\n    const allCategories = [...categories];\n\n    if (this.custom.length > 0) {\n      this.CUSTOM_CATEGORY.emojis = this.custom.map(emoji => {\n        return {\n          ...emoji,\n          // `<Category />` expects emoji to have an `id`.\n          id: emoji.shortNames[0],\n          custom: true,\n        };\n      });\n\n      allCategories.push(this.CUSTOM_CATEGORY);\n    }\n\n    if (this.include !== undefined) {\n      allCategories.sort((a, b) => {\n        if (this.include!.indexOf(a.id) > this.include!.indexOf(b.id)) {\n          return 1;\n        }\n        return -1;\n      });\n    }\n\n    for (const category of allCategories) {\n      const isIncluded =\n        this.include && this.include.length ? this.include.indexOf(category.id) > -1 : true;\n      const isExcluded =\n        this.exclude && this.exclude.length ? this.exclude.indexOf(category.id) > -1 : false;\n      if (!isIncluded || isExcluded) {\n        continue;\n      }\n\n      if (this.emojisToShowFilter) {\n        const newEmojis = [];\n\n        const { emojis } = category;\n        // tslint:disable-next-line: prefer-for-of\n        for (let emojiIndex = 0; emojiIndex < emojis!.length; emojiIndex++) {\n          const emoji = emojis![emojiIndex];\n          if (this.emojisToShowFilter(emoji)) {\n            newEmojis.push(emoji);\n          }\n        }\n\n        if (newEmojis.length) {\n          const newCategory = {\n            emojis: newEmojis,\n            name: category.name,\n            id: category.id,\n          };\n\n          this.categories.push(newCategory);\n        }\n      } else {\n        this.categories.push(category);\n      }\n\n      this.categoriesIcons = { ...icons.categories, ...this.categoriesIcons };\n      this.searchIcons = { ...icons.search, ...this.searchIcons };\n    }\n\n    const includeRecent =\n      this.include && this.include.length\n        ? this.include.indexOf(this.RECENT_CATEGORY.id) > -1\n        : true;\n    const excludeRecent =\n      this.exclude && this.exclude.length\n        ? this.exclude.indexOf(this.RECENT_CATEGORY.id) > -1\n        : false;\n    if (includeRecent && !excludeRecent) {\n      this.hideRecent = false;\n      this.categories.unshift(this.RECENT_CATEGORY);\n    }\n\n    if (this.categories[0]) {\n      this.categories[0].first = true;\n    }\n\n    this.categories.unshift(this.SEARCH_CATEGORY);\n    this.selected = this.categories.filter(category => category.first)[0].name;\n\n    // Need to be careful if small number of categories\n    const categoriesToLoadFirst = Math.min(this.categories.length, 3);\n    this.setActiveCategories(\n      (this.activeCategories = this.categories.slice(0, categoriesToLoadFirst)),\n    );\n\n    // Trim last active category\n    const lastActiveCategoryEmojis = this.categories[categoriesToLoadFirst - 1].emojis!.slice();\n    this.categories[categoriesToLoadFirst - 1].emojis = lastActiveCategoryEmojis.slice(0, 60);\n\n    setTimeout(() => {\n      // Restore last category\n      this.categories[categoriesToLoadFirst - 1].emojis = lastActiveCategoryEmojis;\n      this.setActiveCategories(this.categories);\n      // The `setTimeout` will trigger the change detection, but since we're inside\n      // the OnPush component we can run change detection locally starting from this\n      // component and going down to the children.\n      this.ref.detectChanges();\n\n      // tslint:disable-next-line: no-unused-expression\n      isPlatformBrowser(this.platformId) &&\n        this.ngZone.runOutsideAngular(() => {\n          // The `updateCategoriesSize` doesn't change properties that are used\n          // in templates, thus this is run in the context of the root zone to avoid\n          // running change detection.\n          requestAnimationFrame(() => {\n            this.updateCategoriesSize();\n          });\n        });\n    });\n\n    this.ngZone.runOutsideAngular(() => {\n      // DOM events that are listened by Angular inside the template trigger change detection\n      // and also wrapped into additional functions that call `markForCheck()`. We listen `scroll`\n      // in the context of the root zone since it will not trigger change detection each time\n      // the `scroll` event is dispatched.\n      this.scrollListener = this.renderer.listen(this.scrollRef.nativeElement, 'scroll', () => {\n        this.handleScroll();\n      });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this.scrollListener();\n    // This is called here because the component might be destroyed\n    // but there will still be a `requestAnimationFrame` callback in the queue\n    // that calls `detectChanges()` on the `ViewRef`. This will lead to a runtime\n    // exception if the `detectChanges()` is called after the `ViewRef` is destroyed.\n    this.cancelAnimationFrame();\n  }\n\n  setActiveCategories(categoriesToMakeActive: Array<EmojiCategory>) {\n    if (this.showSingleCategory) {\n      this.activeCategories = categoriesToMakeActive.filter(\n        x => x.name === this.selected || x === this.SEARCH_CATEGORY,\n      );\n    } else {\n      this.activeCategories = categoriesToMakeActive;\n    }\n  }\n  updateCategoriesSize() {\n    this.categoryRefs.forEach(component => component.memoizeSize());\n\n    if (this.scrollRef) {\n      const target = this.scrollRef.nativeElement;\n      this.scrollHeight = target.scrollHeight;\n      this.clientHeight = target.clientHeight;\n      this.clientWidth = target.clientWidth;\n    }\n  }\n  handleAnchorClick($event: { category: EmojiCategory; index: number }) {\n    this.updateCategoriesSize();\n    this.selected = $event.category.name;\n    this.setActiveCategories(this.categories);\n\n    if (this.SEARCH_CATEGORY.emojis) {\n      this.handleSearch(null);\n      this.searchRef?.clear();\n      this.handleAnchorClick($event);\n      return;\n    }\n\n    const component = this.categoryRefs.find(n => n.id === $event.category.id);\n    if (component) {\n      let { top } = component;\n\n      if ($event.category.first) {\n        top = 0;\n      } else {\n        top += 1;\n      }\n      this.scrollRef.nativeElement.scrollTop = top;\n    }\n    this.nextScroll = $event.category.name;\n\n    // handle component scrolling to load emojis\n    for (const category of this.categories) {\n      const componentToScroll = this.categoryRefs.find(({ id }) => id === category.id);\n      componentToScroll?.handleScroll(this.scrollRef.nativeElement.scrollTop);\n    }\n  }\n  categoryTrack(index: number, item: any) {\n    return item.id;\n  }\n  handleScroll(noSelectionChange = false) {\n    if (this.nextScroll) {\n      this.selected = this.nextScroll;\n      this.nextScroll = undefined;\n      this.ref.detectChanges();\n      return;\n    }\n    if (!this.scrollRef) {\n      return;\n    }\n    if (this.showSingleCategory) {\n      return;\n    }\n\n    let activeCategory: EmojiCategory | undefined;\n    if (this.SEARCH_CATEGORY.emojis) {\n      activeCategory = this.SEARCH_CATEGORY;\n    } else {\n      const target = this.scrollRef.nativeElement;\n      // check scroll is not at bottom\n      if (target.scrollTop === 0) {\n        // hit the TOP\n        activeCategory = this.categories.find(n => n.first === true);\n      } else if (target.scrollHeight - target.scrollTop === this.clientHeight) {\n        // scrolled to bottom activate last category\n        activeCategory = this.categories[this.categories.length - 1];\n      } else {\n        // scrolling\n        for (const category of this.categories) {\n          const component = this.categoryRefs.find(({ id }) => id === category.id);\n          const active: boolean | undefined = component?.handleScroll(target.scrollTop);\n          if (active) {\n            activeCategory = category;\n          }\n        }\n      }\n\n      this.scrollTop = target.scrollTop;\n    }\n    // This will allow us to run the change detection only when the category changes.\n    if (!noSelectionChange && activeCategory && activeCategory.name !== this.selected) {\n      this.selected = activeCategory.name;\n      this.ref.detectChanges();\n    } else if (noSelectionChange) {\n      this.ref.detectChanges();\n    }\n  }\n  handleSearch($emojis: any[] | null) {\n    this.SEARCH_CATEGORY.emojis = $emojis;\n    for (const component of this.categoryRefs.toArray()) {\n      if (component.name === 'Search') {\n        component.emojis = $emojis;\n        component.updateDisplay($emojis ? 'block' : 'none');\n      } else {\n        component.updateDisplay($emojis ? 'none' : 'block');\n      }\n    }\n\n    this.scrollRef.nativeElement.scrollTop = 0;\n    this.handleScroll();\n  }\n\n  handleEnterKey($event: Event, emoji?: EmojiData) {\n    if (!emoji) {\n      if (this.SEARCH_CATEGORY.emojis !== null && this.SEARCH_CATEGORY.emojis.length) {\n        emoji = this.SEARCH_CATEGORY.emojis[0];\n        if (emoji) {\n          this.emojiSelect.emit({ $event, emoji });\n        } else {\n          return;\n        }\n      }\n    }\n\n    if (!this.hideRecent && !this.recent && emoji) {\n      this.frequently.add(emoji);\n    }\n\n    const component = this.categoryRefs.toArray()[1];\n    if (component && this.enableFrequentEmojiSort) {\n      component.getEmojis();\n      component.ref.markForCheck();\n    }\n  }\n  handleEmojiOver($event: EmojiEvent) {\n    if (!this.showPreview || !this.previewRef) {\n      return;\n    }\n\n    const emojiData = this.CUSTOM_CATEGORY.emojis!.find(\n      (customEmoji: any) => customEmoji.id === $event.emoji.id,\n    );\n    if (emojiData) {\n      $event.emoji = { ...emojiData };\n    }\n\n    this.previewEmoji = $event.emoji;\n    this.cancelAnimationFrame();\n    this.ref?.detectChanges();\n  }\n  handleEmojiLeave() {\n    if (!this.showPreview || !this.previewRef) {\n      return;\n    }\n\n    this.ngZone.runOutsideAngular(() => {\n      this.animationFrameRequestId = requestAnimationFrame(() => {\n        this.previewEmoji = null;\n        this.ref.detectChanges();\n      });\n    });\n  }\n  handleEmojiClick($event: EmojiEvent) {\n    this.emojiClick.emit($event);\n    this.emojiSelect.emit($event);\n    this.handleEnterKey($event.$event, $event.emoji);\n  }\n  handleSkinChange(skin: Emoji['skin']) {\n    this.skin = skin;\n    localStorage.setItem(`${this.NAMESPACE}.skin`, String(skin));\n    this.skinChange.emit(skin);\n  }\n  getWidth(): string {\n    if (this.style && this.style.width) {\n      return this.style.width;\n    }\n    return this.perLine * (this.emojiSize + 12) + 12 + 2 + this.measureScrollbar + 'px';\n  }\n\n  private cancelAnimationFrame(): void {\n    if (this.animationFrameRequestId !== null) {\n      cancelAnimationFrame(this.animationFrameRequestId);\n      this.animationFrameRequestId = null;\n    }\n  }\n}\n"]}
|
package/esm2015/picker.module.js
DELETED
@@ -1,34 +0,0 @@
|
|
1
|
-
import { CommonModule } from '@angular/common';
|
2
|
-
import { NgModule } from '@angular/core';
|
3
|
-
import { FormsModule } from '@angular/forms';
|
4
|
-
import { EmojiModule } from '@ctrl/ngx-emoji-mart/ngx-emoji';
|
5
|
-
import { AnchorsComponent } from './anchors.component';
|
6
|
-
import { CategoryComponent } from './category.component';
|
7
|
-
import { PickerComponent } from './picker.component';
|
8
|
-
import { PreviewComponent } from './preview.component';
|
9
|
-
import { SearchComponent } from './search.component';
|
10
|
-
import { SkinComponent } from './skins.component';
|
11
|
-
export class PickerModule {
|
12
|
-
}
|
13
|
-
PickerModule.decorators = [
|
14
|
-
{ type: NgModule, args: [{
|
15
|
-
imports: [CommonModule, FormsModule, EmojiModule],
|
16
|
-
exports: [
|
17
|
-
PickerComponent,
|
18
|
-
AnchorsComponent,
|
19
|
-
CategoryComponent,
|
20
|
-
SearchComponent,
|
21
|
-
PreviewComponent,
|
22
|
-
SkinComponent,
|
23
|
-
],
|
24
|
-
declarations: [
|
25
|
-
PickerComponent,
|
26
|
-
AnchorsComponent,
|
27
|
-
CategoryComponent,
|
28
|
-
SearchComponent,
|
29
|
-
PreviewComponent,
|
30
|
-
SkinComponent,
|
31
|
-
],
|
32
|
-
},] }
|
33
|
-
];
|
34
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9saWIvcGlja2VyL3BpY2tlci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTdDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM3RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN2RCxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDckQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQXFCbEQsTUFBTSxPQUFPLFlBQVk7OztZQW5CeEIsUUFBUSxTQUFDO2dCQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxXQUFXLEVBQUUsV0FBVyxDQUFDO2dCQUNqRCxPQUFPLEVBQUU7b0JBQ1AsZUFBZTtvQkFDZixnQkFBZ0I7b0JBQ2hCLGlCQUFpQjtvQkFDakIsZUFBZTtvQkFDZixnQkFBZ0I7b0JBQ2hCLGFBQWE7aUJBQ2Q7Z0JBQ0QsWUFBWSxFQUFFO29CQUNaLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixpQkFBaUI7b0JBQ2pCLGVBQWU7b0JBQ2YsZ0JBQWdCO29CQUNoQixhQUFhO2lCQUNkO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBFbW9qaU1vZHVsZSB9IGZyb20gJ0BjdHJsL25neC1lbW9qaS1tYXJ0L25neC1lbW9qaSc7XG5pbXBvcnQgeyBBbmNob3JzQ29tcG9uZW50IH0gZnJvbSAnLi9hbmNob3JzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDYXRlZ29yeUNvbXBvbmVudCB9IGZyb20gJy4vY2F0ZWdvcnkuY29tcG9uZW50JztcbmltcG9ydCB7IFBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBQcmV2aWV3Q29tcG9uZW50IH0gZnJvbSAnLi9wcmV2aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTZWFyY2hDb21wb25lbnQgfSBmcm9tICcuL3NlYXJjaC5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2tpbkNvbXBvbmVudCB9IGZyb20gJy4vc2tpbnMuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIEVtb2ppTW9kdWxlXSxcbiAgZXhwb3J0czogW1xuICAgIFBpY2tlckNvbXBvbmVudCxcbiAgICBBbmNob3JzQ29tcG9uZW50LFxuICAgIENhdGVnb3J5Q29tcG9uZW50LFxuICAgIFNlYXJjaENvbXBvbmVudCxcbiAgICBQcmV2aWV3Q29tcG9uZW50LFxuICAgIFNraW5Db21wb25lbnQsXG4gIF0sXG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFBpY2tlckNvbXBvbmVudCxcbiAgICBBbmNob3JzQ29tcG9uZW50LFxuICAgIENhdGVnb3J5Q29tcG9uZW50LFxuICAgIFNlYXJjaENvbXBvbmVudCxcbiAgICBQcmV2aWV3Q29tcG9uZW50LFxuICAgIFNraW5Db21wb25lbnQsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIFBpY2tlck1vZHVsZSB7fVxuIl19
|