@ctrl/ngx-emoji-mart 8.2.0 → 9.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/README.md +39 -14
  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 +62 -54
  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,177 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { categories } from '@ctrl/ngx-emoji-mart/ngx-emoji';
3
- import { intersect } from './utils';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@ctrl/ngx-emoji-mart/ngx-emoji";
6
- export class EmojiSearch {
7
- constructor(emojiService) {
8
- this.emojiService = emojiService;
9
- this.originalPool = {};
10
- this.index = {};
11
- this.emojisList = {};
12
- this.emoticonsList = {};
13
- this.emojiSearch = {};
14
- for (const emojiData of this.emojiService.emojis) {
15
- const { shortNames, emoticons } = emojiData;
16
- const id = shortNames[0];
17
- for (const emoticon of emoticons) {
18
- if (this.emoticonsList[emoticon]) {
19
- continue;
20
- }
21
- this.emoticonsList[emoticon] = id;
22
- }
23
- this.emojisList[id] = this.emojiService.getSanitizedData(id);
24
- this.originalPool[id] = emojiData;
25
- }
26
- }
27
- addCustomToPool(custom, pool) {
28
- for (const emoji of custom) {
29
- const emojiId = emoji.id || emoji.shortNames[0];
30
- if (emojiId && !pool[emojiId]) {
31
- pool[emojiId] = this.emojiService.getData(emoji);
32
- this.emojisList[emojiId] = this.emojiService.getSanitizedData(emoji);
33
- }
34
- }
35
- }
36
- search(value, emojisToShowFilter, maxResults = 75, include = [], exclude = [], custom = []) {
37
- this.addCustomToPool(custom, this.originalPool);
38
- let results;
39
- let pool = this.originalPool;
40
- if (value.length) {
41
- if (value === '-' || value === '-1') {
42
- return [this.emojisList['-1']];
43
- }
44
- if (value === '+' || value === '+1') {
45
- return [this.emojisList['+1']];
46
- }
47
- let values = value.toLowerCase().split(/[\s|,|\-|_]+/);
48
- let allResults = [];
49
- if (values.length > 2) {
50
- values = [values[0], values[1]];
51
- }
52
- if (include.length || exclude.length) {
53
- pool = {};
54
- for (const category of categories || []) {
55
- const isIncluded = include && include.length ? include.indexOf(category.id) > -1 : true;
56
- const isExcluded = exclude && exclude.length ? exclude.indexOf(category.id) > -1 : false;
57
- if (!isIncluded || isExcluded) {
58
- continue;
59
- }
60
- for (const emojiId of category.emojis || []) {
61
- // Need to make sure that pool gets keyed
62
- // with the correct id, which is why we call emojiService.getData below
63
- const emoji = this.emojiService.getData(emojiId);
64
- pool[emoji?.id ?? ''] = emoji;
65
- }
66
- }
67
- if (custom.length) {
68
- const customIsIncluded = include && include.length ? include.indexOf('custom') > -1 : true;
69
- const customIsExcluded = exclude && exclude.length ? exclude.indexOf('custom') > -1 : false;
70
- if (customIsIncluded && !customIsExcluded) {
71
- this.addCustomToPool(custom, pool);
72
- }
73
- }
74
- }
75
- allResults = values
76
- .map(v => {
77
- let aPool = pool;
78
- let aIndex = this.index;
79
- let length = 0;
80
- // eslint-disable-next-line @typescript-eslint/prefer-for-of
81
- for (let charIndex = 0; charIndex < v.length; charIndex++) {
82
- const char = v[charIndex];
83
- length++;
84
- if (!aIndex[char]) {
85
- aIndex[char] = {};
86
- }
87
- aIndex = aIndex[char];
88
- if (!aIndex.results) {
89
- const scores = {};
90
- aIndex.results = [];
91
- aIndex.pool = {};
92
- for (const id of Object.keys(aPool)) {
93
- const emoji = aPool[id];
94
- if (!this.emojiSearch[id]) {
95
- this.emojiSearch[id] = this.buildSearch(emoji.short_names, emoji.name, emoji.id, emoji.keywords, emoji.emoticons);
96
- }
97
- const query = this.emojiSearch[id];
98
- const sub = v.substr(0, length);
99
- const subIndex = query.indexOf(sub);
100
- if (subIndex !== -1) {
101
- let score = subIndex + 1;
102
- if (sub === id) {
103
- score = 0;
104
- }
105
- aIndex.results.push(this.emojisList[id]);
106
- aIndex.pool[id] = emoji;
107
- scores[id] = score;
108
- }
109
- }
110
- aIndex.results.sort((a, b) => {
111
- const aScore = scores[a.id];
112
- const bScore = scores[b.id];
113
- return aScore - bScore;
114
- });
115
- }
116
- aPool = aIndex.pool;
117
- }
118
- return aIndex.results;
119
- })
120
- .filter(a => a);
121
- if (allResults.length > 1) {
122
- results = intersect.apply(null, allResults);
123
- }
124
- else if (allResults.length) {
125
- results = allResults[0];
126
- }
127
- else {
128
- results = [];
129
- }
130
- }
131
- if (results) {
132
- if (emojisToShowFilter) {
133
- results = results.filter((result) => {
134
- if (result && result.id) {
135
- return emojisToShowFilter(this.emojiService.names[result.id]);
136
- }
137
- return false;
138
- });
139
- }
140
- if (results && results.length > maxResults) {
141
- results = results.slice(0, maxResults);
142
- }
143
- }
144
- return results || null;
145
- }
146
- buildSearch(shortNames, name, id, keywords, emoticons) {
147
- const search = [];
148
- const addToSearch = (strings, split) => {
149
- if (!strings) {
150
- return;
151
- }
152
- const arr = Array.isArray(strings) ? strings : [strings];
153
- for (const str of arr) {
154
- const substrings = split ? str.split(/[-|_|\s]+/) : [str];
155
- for (let s of substrings) {
156
- s = s.toLowerCase();
157
- if (!search.includes(s)) {
158
- search.push(s);
159
- }
160
- }
161
- }
162
- };
163
- addToSearch(shortNames, true);
164
- addToSearch(name, true);
165
- addToSearch(id, true);
166
- addToSearch(keywords, true);
167
- addToSearch(emoticons, false);
168
- return search.join(',');
169
- }
170
- }
171
- EmojiSearch.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiSearch, deps: [{ token: i1.EmojiService }], target: i0.ɵɵFactoryTarget.Injectable });
172
- EmojiSearch.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiSearch, providedIn: 'root' });
173
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiSearch, decorators: [{
174
- type: Injectable,
175
- args: [{ providedIn: 'root' }]
176
- }], ctorParameters: function () { return [{ type: i1.EmojiService }]; } });
177
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji-search.service.js","sourceRoot":"","sources":["../../src/lib/picker/emoji-search.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\n\nimport { categories, EmojiData, EmojiService } from '@ctrl/ngx-emoji-mart/ngx-emoji';\nimport { intersect } from './utils';\n\n@Injectable({ providedIn: 'root' })\nexport class EmojiSearch {\n  originalPool: any = {};\n  index: {\n    results?: EmojiData[];\n    pool?: { [key: string]: EmojiData };\n    [key: string]: any;\n  } = {};\n  emojisList: any = {};\n  emoticonsList: { [key: string]: string } = {};\n  emojiSearch: { [key: string]: string } = {};\n\n  constructor(private emojiService: EmojiService) {\n    for (const emojiData of this.emojiService.emojis) {\n      const { shortNames, emoticons } = emojiData;\n      const id = shortNames[0];\n\n      for (const emoticon of emoticons) {\n        if (this.emoticonsList[emoticon]) {\n          continue;\n        }\n\n        this.emoticonsList[emoticon] = id;\n      }\n\n      this.emojisList[id] = this.emojiService.getSanitizedData(id);\n      this.originalPool[id] = emojiData;\n    }\n  }\n\n  addCustomToPool(custom: any, pool: any) {\n    for (const emoji of custom) {\n      const emojiId = emoji.id || emoji.shortNames[0];\n\n      if (emojiId && !pool[emojiId]) {\n        pool[emojiId] = this.emojiService.getData(emoji);\n        this.emojisList[emojiId] = this.emojiService.getSanitizedData(emoji);\n      }\n    }\n  }\n\n  search(\n    value: string,\n    emojisToShowFilter?: (x: any) => boolean,\n    maxResults = 75,\n    include: any[] = [],\n    exclude: any[] = [],\n    custom: any[] = [],\n  ): EmojiData[] | null {\n    this.addCustomToPool(custom, this.originalPool);\n\n    let results: EmojiData[] | undefined;\n    let pool = this.originalPool;\n\n    if (value.length) {\n      if (value === '-' || value === '-1') {\n        return [this.emojisList['-1']];\n      }\n      if (value === '+' || value === '+1') {\n        return [this.emojisList['+1']];\n      }\n\n      let values = value.toLowerCase().split(/[\\s|,|\\-|_]+/);\n      let allResults = [];\n\n      if (values.length > 2) {\n        values = [values[0], values[1]];\n      }\n\n      if (include.length || exclude.length) {\n        pool = {};\n\n        for (const category of categories || []) {\n          const isIncluded = include && include.length ? include.indexOf(category.id) > -1 : true;\n          const isExcluded = exclude && exclude.length ? exclude.indexOf(category.id) > -1 : false;\n\n          if (!isIncluded || isExcluded) {\n            continue;\n          }\n\n          for (const emojiId of category.emojis || []) {\n            // Need to make sure that pool gets keyed\n            // with the correct id, which is why we call emojiService.getData below\n            const emoji = this.emojiService.getData(emojiId);\n            pool[emoji?.id ?? ''] = emoji;\n          }\n        }\n\n        if (custom.length) {\n          const customIsIncluded =\n            include && include.length ? include.indexOf('custom') > -1 : true;\n          const customIsExcluded =\n            exclude && exclude.length ? exclude.indexOf('custom') > -1 : false;\n          if (customIsIncluded && !customIsExcluded) {\n            this.addCustomToPool(custom, pool);\n          }\n        }\n      }\n\n      allResults = values\n        .map(v => {\n          let aPool = pool;\n          let aIndex = this.index;\n          let length = 0;\n\n          // eslint-disable-next-line @typescript-eslint/prefer-for-of\n          for (let charIndex = 0; charIndex < v.length; charIndex++) {\n            const char = v[charIndex];\n            length++;\n            if (!aIndex[char]) {\n              aIndex[char] = {};\n            }\n            aIndex = aIndex[char];\n\n            if (!aIndex.results) {\n              const scores: { [key: string]: number } = {};\n\n              aIndex.results = [];\n              aIndex.pool = {};\n\n              for (const id of Object.keys(aPool)) {\n                const emoji = aPool[id];\n                if (!this.emojiSearch[id]) {\n                  this.emojiSearch[id] = this.buildSearch(\n                    emoji.short_names,\n                    emoji.name,\n                    emoji.id,\n                    emoji.keywords,\n                    emoji.emoticons,\n                  );\n                }\n                const query = this.emojiSearch[id];\n                const sub = v.substr(0, length);\n                const subIndex = query.indexOf(sub);\n\n                if (subIndex !== -1) {\n                  let score = subIndex + 1;\n                  if (sub === id) {\n                    score = 0;\n                  }\n\n                  aIndex.results.push(this.emojisList[id]);\n                  aIndex.pool[id] = emoji;\n\n                  scores[id] = score;\n                }\n              }\n\n              aIndex.results.sort((a, b) => {\n                const aScore = scores[a.id];\n                const bScore = scores[b.id];\n\n                return aScore - bScore;\n              });\n            }\n\n            aPool = aIndex.pool;\n          }\n\n          return aIndex.results;\n        })\n        .filter(a => a);\n\n      if (allResults.length > 1) {\n        results = intersect.apply(null, allResults as any);\n      } else if (allResults.length) {\n        results = allResults[0];\n      } else {\n        results = [];\n      }\n    }\n\n    if (results) {\n      if (emojisToShowFilter) {\n        results = results.filter((result: EmojiData) => {\n          if (result && result.id) {\n            return emojisToShowFilter(this.emojiService.names[result.id]);\n          }\n          return false;\n        });\n      }\n\n      if (results && results.length > maxResults) {\n        results = results.slice(0, maxResults);\n      }\n    }\n    return results || null;\n  }\n\n  buildSearch(\n    shortNames: string[],\n    name: string,\n    id: string,\n    keywords: string[],\n    emoticons: string[],\n  ) {\n    const search: string[] = [];\n\n    const addToSearch = (strings: string | string[], split: boolean) => {\n      if (!strings) {\n        return;\n      }\n\n      const arr = Array.isArray(strings) ? strings : [strings];\n\n      for (const str of arr) {\n        const substrings = split ? str.split(/[-|_|\\s]+/) : [str];\n\n        for (let s of substrings) {\n          s = s.toLowerCase();\n\n          if (!search.includes(s)) {\n            search.push(s);\n          }\n        }\n      }\n    };\n\n    addToSearch(shortNames, true);\n    addToSearch(name, true);\n    addToSearch(id, true);\n    addToSearch(keywords, true);\n    addToSearch(emoticons, false);\n\n    return search.join(',');\n  }\n}\n"]}
@@ -1,288 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, NgZone, Output, ViewChild, inject, } from '@angular/core';
2
- import { EMPTY, Subject, fromEvent, switchMap, takeUntil } from 'rxjs';
3
- import { DEFAULT_BACKGROUNDFN, EmojiService } from './emoji.service';
4
- import * as i0 from "@angular/core";
5
- import * as i1 from "@angular/common";
6
- export class EmojiComponent {
7
- set button(button) {
8
- // Note: `runOutsideAngular` is used to trigger `addEventListener` outside of the Angular zone
9
- // too. See `setupMouseEnterListener`. The `switchMap` will subscribe to `fromEvent` considering
10
- // the context where the factory is called in.
11
- this.ngZone.runOutsideAngular(() => this.button$.next(button?.nativeElement));
12
- }
13
- constructor() {
14
- this.skin = 1;
15
- this.set = 'apple';
16
- this.sheetSize = 64;
17
- /** Renders the native unicode emoji */
18
- this.isNative = false;
19
- this.forceSize = false;
20
- this.tooltip = false;
21
- this.size = 24;
22
- this.emoji = '';
23
- this.hideObsolete = false;
24
- this.emojiClick = new EventEmitter();
25
- /**
26
- * Note: `emojiOver` and `emojiOverOutsideAngular` are dispatched on the same event (`mouseenter`), but
27
- * for different purposes. The `emojiOverOutsideAngular` event is listened only in `emoji-category`
28
- * component and the category component doesn't care about zone context the callback is being called in.
29
- * The `emojiOver` is for backwards compatibility if anyone is listening to this event explicitly in their code.
30
- */
31
- this.emojiOver = new EventEmitter();
32
- this.emojiOverOutsideAngular = new EventEmitter();
33
- /** See comments above, this serves the same purpose. */
34
- this.emojiLeave = new EventEmitter();
35
- this.emojiLeaveOutsideAngular = new EventEmitter();
36
- this.title = undefined;
37
- this.label = '';
38
- this.custom = false;
39
- this.isVisible = true;
40
- // TODO: replace 4.0.3 w/ dynamic get verison from emoji-datasource in package.json
41
- this.backgroundImageFn = DEFAULT_BACKGROUNDFN;
42
- /**
43
- * The subject used to emit whenever view queries are run and `button` or `span` is set/removed.
44
- * We use subject to keep the reactive behavior so we don't have to add and remove event listeners manually.
45
- */
46
- this.button$ = new Subject();
47
- this.destroy$ = new Subject();
48
- this.ngZone = inject(NgZone);
49
- this.emojiService = inject(EmojiService);
50
- this.setupMouseListeners();
51
- }
52
- ngOnChanges() {
53
- if (!this.emoji) {
54
- return (this.isVisible = false);
55
- }
56
- const data = this.getData();
57
- if (!data) {
58
- return (this.isVisible = false);
59
- }
60
- // const children = this.children;
61
- this.unified = data.native || null;
62
- if (data.custom) {
63
- this.custom = data.custom;
64
- }
65
- if (!data.unified && !data.custom) {
66
- return (this.isVisible = false);
67
- }
68
- if (this.tooltip) {
69
- this.title = data.shortNames[0];
70
- }
71
- if (data.obsoletedBy && this.hideObsolete) {
72
- return (this.isVisible = false);
73
- }
74
- this.label = [data.native].concat(data.shortNames).filter(Boolean).join(', ');
75
- if (this.isNative && data.unified && data.native) {
76
- // hide older emoji before the split into gendered emoji
77
- this.style = { fontSize: `${this.size}px` };
78
- if (this.forceSize) {
79
- this.style.display = 'inline-block';
80
- this.style.width = `${this.size}px`;
81
- this.style.height = `${this.size}px`;
82
- this.style['word-break'] = 'keep-all';
83
- }
84
- }
85
- else if (data.custom) {
86
- this.style = {
87
- width: `${this.size}px`,
88
- height: `${this.size}px`,
89
- display: 'inline-block',
90
- };
91
- if (data.spriteUrl && this.sheetRows && this.sheetColumns) {
92
- this.style = {
93
- ...this.style,
94
- backgroundImage: `url(${data.spriteUrl})`,
95
- backgroundSize: `${100 * this.sheetColumns}% ${100 * this.sheetRows}%`,
96
- backgroundPosition: this.emojiService.getSpritePosition(data.sheet, this.sheetColumns),
97
- };
98
- }
99
- else {
100
- this.style = {
101
- ...this.style,
102
- backgroundImage: `url(${data.imageUrl})`,
103
- backgroundSize: 'contain',
104
- };
105
- }
106
- }
107
- else {
108
- if (data.hidden.length && data.hidden.includes(this.set)) {
109
- if (this.fallback) {
110
- this.style = { fontSize: `${this.size}px` };
111
- this.unified = this.fallback(data, this);
112
- }
113
- else {
114
- return (this.isVisible = false);
115
- }
116
- }
117
- else {
118
- this.style = this.emojiService.emojiSpriteStyles(data.sheet, this.set, this.size, this.sheetSize, this.sheetRows, this.backgroundImageFn, this.sheetColumns, this.imageUrlFn?.(this.getData()));
119
- }
120
- }
121
- return (this.isVisible = true);
122
- }
123
- ngOnDestroy() {
124
- this.destroy$.next();
125
- }
126
- getData() {
127
- return this.emojiService.getData(this.emoji, this.skin, this.set);
128
- }
129
- getSanitizedData() {
130
- return this.emojiService.getSanitizedData(this.emoji, this.skin, this.set);
131
- }
132
- handleClick($event) {
133
- const emoji = this.getSanitizedData();
134
- this.emojiClick.emit({ emoji, $event });
135
- }
136
- setupMouseListeners() {
137
- const eventListener$ = (eventName) => this.button$.pipe(
138
- // Note: `EMPTY` is used to remove event listener once the DOM node is removed.
139
- switchMap(button => (button ? fromEvent(button, eventName) : EMPTY)), takeUntil(this.destroy$));
140
- eventListener$('mouseenter').subscribe($event => {
141
- const emoji = this.getSanitizedData();
142
- this.emojiOverOutsideAngular.emit({ emoji, $event });
143
- // Note: this is done for backwards compatibility. We run change detection if developers
144
- // are listening to `emojiOver` in their code. For instance:
145
- // `<ngx-emoji (emojiOver)="..."></ngx-emoji>`.
146
- if (this.emojiOver.observed) {
147
- this.ngZone.run(() => this.emojiOver.emit({ emoji, $event }));
148
- }
149
- });
150
- eventListener$('mouseleave').subscribe($event => {
151
- const emoji = this.getSanitizedData();
152
- this.emojiLeaveOutsideAngular.emit({ emoji, $event });
153
- // Note: this is done for backwards compatibility. We run change detection if developers
154
- // are listening to `emojiLeave` in their code. For instance:
155
- // `<ngx-emoji (emojiLeave)="..."></ngx-emoji>`.
156
- if (this.emojiLeave.observed) {
157
- this.ngZone.run(() => this.emojiLeave.emit({ emoji, $event }));
158
- }
159
- });
160
- }
161
- }
162
- EmojiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
163
- EmojiComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: EmojiComponent, selector: "ngx-emoji", inputs: { skin: "skin", set: "set", sheetSize: "sheetSize", isNative: "isNative", forceSize: "forceSize", tooltip: "tooltip", size: "size", emoji: "emoji", fallback: "fallback", hideObsolete: "hideObsolete", sheetRows: "sheetRows", sheetColumns: "sheetColumns", useButton: "useButton", backgroundImageFn: "backgroundImageFn", imageUrlFn: "imageUrlFn" }, outputs: { emojiClick: "emojiClick", emojiOver: "emojiOver", emojiOverOutsideAngular: "emojiOverOutsideAngular", emojiLeave: "emojiLeave", emojiLeaveOutsideAngular: "emojiLeaveOutsideAngular" }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
164
- <ng-template [ngIf]="isVisible">
165
- <button
166
- *ngIf="useButton; else spanTpl"
167
- #button
168
- type="button"
169
- (click)="handleClick($event)"
170
- [attr.title]="title"
171
- [attr.aria-label]="label"
172
- class="emoji-mart-emoji"
173
- [class.emoji-mart-emoji-native]="isNative"
174
- [class.emoji-mart-emoji-custom]="custom"
175
- >
176
- <span [ngStyle]="style">
177
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
178
- <ng-content></ng-content>
179
- </span>
180
- </button>
181
- </ng-template>
182
-
183
- <ng-template #spanTpl>
184
- <span
185
- #button
186
- (click)="handleClick($event)"
187
- [attr.title]="title"
188
- [attr.aria-label]="label"
189
- class="emoji-mart-emoji"
190
- [class.emoji-mart-emoji-native]="isNative"
191
- [class.emoji-mart-emoji-custom]="custom"
192
- >
193
- <span [ngStyle]="style">
194
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
195
- <ng-content></ng-content>
196
- </span>
197
- </span>
198
- </ng-template>
199
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
200
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiComponent, decorators: [{
201
- type: Component,
202
- args: [{
203
- selector: 'ngx-emoji',
204
- template: `
205
- <ng-template [ngIf]="isVisible">
206
- <button
207
- *ngIf="useButton; else spanTpl"
208
- #button
209
- type="button"
210
- (click)="handleClick($event)"
211
- [attr.title]="title"
212
- [attr.aria-label]="label"
213
- class="emoji-mart-emoji"
214
- [class.emoji-mart-emoji-native]="isNative"
215
- [class.emoji-mart-emoji-custom]="custom"
216
- >
217
- <span [ngStyle]="style">
218
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
219
- <ng-content></ng-content>
220
- </span>
221
- </button>
222
- </ng-template>
223
-
224
- <ng-template #spanTpl>
225
- <span
226
- #button
227
- (click)="handleClick($event)"
228
- [attr.title]="title"
229
- [attr.aria-label]="label"
230
- class="emoji-mart-emoji"
231
- [class.emoji-mart-emoji-native]="isNative"
232
- [class.emoji-mart-emoji-custom]="custom"
233
- >
234
- <span [ngStyle]="style">
235
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
236
- <ng-content></ng-content>
237
- </span>
238
- </span>
239
- </ng-template>
240
- `,
241
- changeDetection: ChangeDetectionStrategy.OnPush,
242
- preserveWhitespaces: false,
243
- }]
244
- }], ctorParameters: function () { return []; }, propDecorators: { skin: [{
245
- type: Input
246
- }], set: [{
247
- type: Input
248
- }], sheetSize: [{
249
- type: Input
250
- }], isNative: [{
251
- type: Input
252
- }], forceSize: [{
253
- type: Input
254
- }], tooltip: [{
255
- type: Input
256
- }], size: [{
257
- type: Input
258
- }], emoji: [{
259
- type: Input
260
- }], fallback: [{
261
- type: Input
262
- }], hideObsolete: [{
263
- type: Input
264
- }], sheetRows: [{
265
- type: Input
266
- }], sheetColumns: [{
267
- type: Input
268
- }], useButton: [{
269
- type: Input
270
- }], emojiClick: [{
271
- type: Output
272
- }], emojiOver: [{
273
- type: Output
274
- }], emojiOverOutsideAngular: [{
275
- type: Output
276
- }], emojiLeave: [{
277
- type: Output
278
- }], emojiLeaveOutsideAngular: [{
279
- type: Output
280
- }], backgroundImageFn: [{
281
- type: Input
282
- }], imageUrlFn: [{
283
- type: Input
284
- }], button: [{
285
- type: ViewChild,
286
- args: ['button', { static: false }]
287
- }] } });
288
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"emoji.component.js","sourceRoot":"","sources":["../../../src/lib/picker/ngx-emoji/emoji.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  Output,\n  ViewChild,\n  inject,\n} from '@angular/core';\nimport { EMPTY, Subject, fromEvent, switchMap, takeUntil } from 'rxjs';\n\nimport { EmojiData } from './data/data.interfaces';\nimport { DEFAULT_BACKGROUNDFN, EmojiService } from './emoji.service';\n\nexport interface Emoji {\n  /** Renders the native unicode emoji */\n  isNative: boolean;\n  forceSize: boolean;\n  tooltip: boolean;\n  skin: 1 | 2 | 3 | 4 | 5 | 6;\n  sheetSize: 16 | 20 | 32 | 64 | 72;\n  sheetRows?: number;\n  set: 'apple' | 'google' | 'twitter' | 'facebook' | '';\n  size: number;\n  emoji: string | EmojiData;\n  backgroundImageFn: (set: string, sheetSize: number) => string;\n  fallback?: (data: any, props: any) => string;\n  emojiOver: EventEmitter<EmojiEvent>;\n  emojiLeave: EventEmitter<EmojiEvent>;\n  emojiClick: EventEmitter<EmojiEvent>;\n  imageUrlFn?: (emoji: EmojiData | null) => string;\n}\n\nexport interface EmojiEvent {\n  emoji: EmojiData;\n  $event: Event;\n}\n\n@Component({\n  selector: 'ngx-emoji',\n  template: `\n    <ng-template [ngIf]=\"isVisible\">\n      <button\n        *ngIf=\"useButton; else spanTpl\"\n        #button\n        type=\"button\"\n        (click)=\"handleClick($event)\"\n        [attr.title]=\"title\"\n        [attr.aria-label]=\"label\"\n        class=\"emoji-mart-emoji\"\n        [class.emoji-mart-emoji-native]=\"isNative\"\n        [class.emoji-mart-emoji-custom]=\"custom\"\n      >\n        <span [ngStyle]=\"style\">\n          <ng-template [ngIf]=\"isNative\">{{ unified }}</ng-template>\n          <ng-content></ng-content>\n        </span>\n      </button>\n    </ng-template>\n\n    <ng-template #spanTpl>\n      <span\n        #button\n        (click)=\"handleClick($event)\"\n        [attr.title]=\"title\"\n        [attr.aria-label]=\"label\"\n        class=\"emoji-mart-emoji\"\n        [class.emoji-mart-emoji-native]=\"isNative\"\n        [class.emoji-mart-emoji-custom]=\"custom\"\n      >\n        <span [ngStyle]=\"style\">\n          <ng-template [ngIf]=\"isNative\">{{ unified }}</ng-template>\n          <ng-content></ng-content>\n        </span>\n      </span>\n    </ng-template>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  preserveWhitespaces: false,\n})\nexport class EmojiComponent implements OnChanges, Emoji, OnDestroy {\n  @Input() skin: Emoji['skin'] = 1;\n  @Input() set: Emoji['set'] = 'apple';\n  @Input() sheetSize: Emoji['sheetSize'] = 64;\n  /** Renders the native unicode emoji */\n  @Input() isNative: Emoji['isNative'] = false;\n  @Input() forceSize: Emoji['forceSize'] = false;\n  @Input() tooltip: Emoji['tooltip'] = false;\n  @Input() size: Emoji['size'] = 24;\n  @Input() emoji: Emoji['emoji'] = '';\n  @Input() fallback?: Emoji['fallback'];\n  @Input() hideObsolete = false;\n  @Input() sheetRows?: number;\n  @Input() sheetColumns?: number;\n  @Input() useButton?: boolean;\n  @Output() emojiClick: Emoji['emojiClick'] = new EventEmitter();\n  /**\n   * Note: `emojiOver` and `emojiOverOutsideAngular` are dispatched on the same event (`mouseenter`), but\n   *       for different purposes. The `emojiOverOutsideAngular` event is listened only in `emoji-category`\n   *       component and the category component doesn't care about zone context the callback is being called in.\n   *       The `emojiOver` is for backwards compatibility if anyone is listening to this event explicitly in their code.\n   */\n  @Output() emojiOver: Emoji['emojiOver'] = new EventEmitter();\n  @Output() emojiOverOutsideAngular: Emoji['emojiOver'] = new EventEmitter();\n  /** See comments above, this serves the same purpose. */\n  @Output() emojiLeave: Emoji['emojiLeave'] = new EventEmitter();\n  @Output() emojiLeaveOutsideAngular: Emoji['emojiLeave'] = new EventEmitter();\n\n  style: any;\n  title?: string = undefined;\n  label = '';\n  unified?: string | null;\n  custom = false;\n  isVisible = true;\n  // TODO: replace 4.0.3 w/ dynamic get verison from emoji-datasource in package.json\n  @Input() backgroundImageFn: Emoji['backgroundImageFn'] = DEFAULT_BACKGROUNDFN;\n  @Input() imageUrlFn?: Emoji['imageUrlFn'];\n\n  @ViewChild('button', { static: false })\n  set button(button: ElementRef<HTMLElement> | undefined) {\n    // Note: `runOutsideAngular` is used to trigger `addEventListener` outside of the Angular zone\n    //       too. See `setupMouseEnterListener`. The `switchMap` will subscribe to `fromEvent` considering\n    //       the context where the factory is called in.\n    this.ngZone.runOutsideAngular(() => this.button$.next(button?.nativeElement));\n  }\n\n  /**\n   * The subject used to emit whenever view queries are run and `button` or `span` is set/removed.\n   * We use subject to keep the reactive behavior so we don't have to add and remove event listeners manually.\n   */\n  private readonly button$ = new Subject<HTMLElement | undefined>();\n\n  private readonly destroy$ = new Subject<void>();\n\n  private readonly ngZone = inject(NgZone);\n  private readonly emojiService = inject(EmojiService);\n\n  constructor() {\n    this.setupMouseListeners();\n  }\n\n  ngOnChanges() {\n    if (!this.emoji) {\n      return (this.isVisible = false);\n    }\n    const data = this.getData();\n    if (!data) {\n      return (this.isVisible = false);\n    }\n    // const children = this.children;\n    this.unified = data.native || null;\n    if (data.custom) {\n      this.custom = data.custom;\n    }\n    if (!data.unified && !data.custom) {\n      return (this.isVisible = false);\n    }\n    if (this.tooltip) {\n      this.title = data.shortNames[0];\n    }\n    if (data.obsoletedBy && this.hideObsolete) {\n      return (this.isVisible = false);\n    }\n\n    this.label = [data.native].concat(data.shortNames).filter(Boolean).join(', ');\n\n    if (this.isNative && data.unified && data.native) {\n      // hide older emoji before the split into gendered emoji\n      this.style = { fontSize: `${this.size}px` };\n\n      if (this.forceSize) {\n        this.style.display = 'inline-block';\n        this.style.width = `${this.size}px`;\n        this.style.height = `${this.size}px`;\n        this.style['word-break'] = 'keep-all';\n      }\n    } else if (data.custom) {\n      this.style = {\n        width: `${this.size}px`,\n        height: `${this.size}px`,\n        display: 'inline-block',\n      };\n      if (data.spriteUrl && this.sheetRows && this.sheetColumns) {\n        this.style = {\n          ...this.style,\n          backgroundImage: `url(${data.spriteUrl})`,\n          backgroundSize: `${100 * this.sheetColumns}% ${100 * this.sheetRows}%`,\n          backgroundPosition: this.emojiService.getSpritePosition(data.sheet, this.sheetColumns),\n        };\n      } else {\n        this.style = {\n          ...this.style,\n          backgroundImage: `url(${data.imageUrl})`,\n          backgroundSize: 'contain',\n        };\n      }\n    } else {\n      if (data.hidden.length && data.hidden.includes(this.set)) {\n        if (this.fallback) {\n          this.style = { fontSize: `${this.size}px` };\n          this.unified = this.fallback(data, this);\n        } else {\n          return (this.isVisible = false);\n        }\n      } else {\n        this.style = this.emojiService.emojiSpriteStyles(\n          data.sheet,\n          this.set,\n          this.size,\n          this.sheetSize,\n          this.sheetRows,\n          this.backgroundImageFn,\n          this.sheetColumns,\n          this.imageUrlFn?.(this.getData()),\n        );\n      }\n    }\n    return (this.isVisible = true);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n  }\n\n  getData() {\n    return this.emojiService.getData(this.emoji, this.skin, this.set);\n  }\n\n  getSanitizedData(): EmojiData {\n    return this.emojiService.getSanitizedData(this.emoji, this.skin, this.set) as EmojiData;\n  }\n\n  handleClick($event: Event) {\n    const emoji = this.getSanitizedData();\n    this.emojiClick.emit({ emoji, $event });\n  }\n\n  private setupMouseListeners(): void {\n    const eventListener$ = (eventName: string) =>\n      this.button$.pipe(\n        // Note: `EMPTY` is used to remove event listener once the DOM node is removed.\n        switchMap(button => (button ? fromEvent(button, eventName) : EMPTY)),\n        takeUntil(this.destroy$),\n      );\n\n    eventListener$('mouseenter').subscribe($event => {\n      const emoji = this.getSanitizedData();\n      this.emojiOverOutsideAngular.emit({ emoji, $event });\n      // Note: this is done for backwards compatibility. We run change detection if developers\n      //       are listening to `emojiOver` in their code. For instance:\n      //       `<ngx-emoji (emojiOver)=\"...\"></ngx-emoji>`.\n      if (this.emojiOver.observed) {\n        this.ngZone.run(() => this.emojiOver.emit({ emoji, $event }));\n      }\n    });\n\n    eventListener$('mouseleave').subscribe($event => {\n      const emoji = this.getSanitizedData();\n      this.emojiLeaveOutsideAngular.emit({ emoji, $event });\n      // Note: this is done for backwards compatibility. We run change detection if developers\n      //       are listening to `emojiLeave` in their code. For instance:\n      //       `<ngx-emoji (emojiLeave)=\"...\"></ngx-emoji>`.\n      if (this.emojiLeave.observed) {\n        this.ngZone.run(() => this.emojiLeave.emit({ emoji, $event }));\n      }\n    });\n  }\n}\n"]}
@@ -1,18 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { NgModule } from '@angular/core';
3
- import { EmojiComponent } from './emoji.component';
4
- import * as i0 from "@angular/core";
5
- export class EmojiModule {
6
- }
7
- EmojiModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
- EmojiModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.8", ngImport: i0, type: EmojiModule, declarations: [EmojiComponent], imports: [CommonModule], exports: [EmojiComponent] });
9
- EmojiModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiModule, imports: [CommonModule] });
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiModule, decorators: [{
11
- type: NgModule,
12
- args: [{
13
- imports: [CommonModule],
14
- exports: [EmojiComponent],
15
- declarations: [EmojiComponent],
16
- }]
17
- }] });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1vamkubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xpYi9waWNrZXIvbmd4LWVtb2ppL2Vtb2ppLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBT25ELE1BQU0sT0FBTyxXQUFXOzt3R0FBWCxXQUFXO3lHQUFYLFdBQVcsaUJBRlAsY0FBYyxhQUZuQixZQUFZLGFBQ1osY0FBYzt5R0FHYixXQUFXLFlBSlosWUFBWTsyRkFJWCxXQUFXO2tCQUx2QixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsY0FBYyxDQUFDO29CQUN6QixZQUFZLEVBQUUsQ0FBQyxjQUFjLENBQUM7aUJBQy9CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEVtb2ppQ29tcG9uZW50IH0gZnJvbSAnLi9lbW9qaS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW0Vtb2ppQ29tcG9uZW50XSxcbiAgZGVjbGFyYXRpb25zOiBbRW1vamlDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBFbW9qaU1vZHVsZSB7fVxuIl19