@ctrl/ngx-emoji-mart 8.1.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 +3 -3
  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 +81 -68
  17. package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +1 -1
  18. package/{fesm2020 → fesm2022}/ctrl-ngx-emoji-mart.mjs +327 -261
  19. package/fesm2022/ctrl-ngx-emoji-mart.mjs.map +1 -0
  20. package/ngx-emoji/emoji.component.d.ts +10 -9
  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 -283
  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 -34325
  41. package/fesm2015/ctrl-ngx-emoji-mart-ngx-emoji.mjs.map +0 -1
  42. package/fesm2015/ctrl-ngx-emoji-mart.mjs +0 -1763
  43. package/fesm2015/ctrl-ngx-emoji-mart.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,283 +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.emojiOver = new EventEmitter();
25
- /**
26
- * Note: `emojiLeave` and `emojiLeaveOutsideAngular` are dispatched on the same event, but for different
27
- * purposes. The `emojiLeaveOutsideAngular` would be set up in category component so we don't care
28
- * about zone context the callback is being called in. The `emojiLeave` is for backwards compatibility
29
- * if anyone is listening to this event explicitly in their code.
30
- */
31
- this.emojiLeave = new EventEmitter();
32
- this.emojiLeaveOutsideAngular = new EventEmitter();
33
- this.emojiClick = new EventEmitter();
34
- this.title = undefined;
35
- this.label = '';
36
- this.custom = false;
37
- this.isVisible = true;
38
- // TODO: replace 4.0.3 w/ dynamic get verison from emoji-datasource in package.json
39
- this.backgroundImageFn = DEFAULT_BACKGROUNDFN;
40
- /**
41
- * The subject used to emit whenever view queries are run and `button` or `span` is set/removed.
42
- * We use subject to keep the reactive behavior so we don't have to add and remove event listeners manually.
43
- */
44
- this.button$ = new Subject();
45
- this.destroy$ = new Subject();
46
- this.ngZone = inject(NgZone);
47
- this.emojiService = inject(EmojiService);
48
- this.setupMouseLeaveListener();
49
- }
50
- ngOnChanges() {
51
- if (!this.emoji) {
52
- return (this.isVisible = false);
53
- }
54
- const data = this.getData();
55
- if (!data) {
56
- return (this.isVisible = false);
57
- }
58
- // const children = this.children;
59
- this.unified = data.native || null;
60
- if (data.custom) {
61
- this.custom = data.custom;
62
- }
63
- if (!data.unified && !data.custom) {
64
- return (this.isVisible = false);
65
- }
66
- if (this.tooltip) {
67
- this.title = data.shortNames[0];
68
- }
69
- if (data.obsoletedBy && this.hideObsolete) {
70
- return (this.isVisible = false);
71
- }
72
- this.label = [data.native].concat(data.shortNames).filter(Boolean).join(', ');
73
- if (this.isNative && data.unified && data.native) {
74
- // hide older emoji before the split into gendered emoji
75
- this.style = { fontSize: `${this.size}px` };
76
- if (this.forceSize) {
77
- this.style.display = 'inline-block';
78
- this.style.width = `${this.size}px`;
79
- this.style.height = `${this.size}px`;
80
- this.style['word-break'] = 'keep-all';
81
- }
82
- }
83
- else if (data.custom) {
84
- this.style = {
85
- width: `${this.size}px`,
86
- height: `${this.size}px`,
87
- display: 'inline-block',
88
- };
89
- if (data.spriteUrl && this.sheetRows && this.sheetColumns) {
90
- this.style = {
91
- ...this.style,
92
- backgroundImage: `url(${data.spriteUrl})`,
93
- backgroundSize: `${100 * this.sheetColumns}% ${100 * this.sheetRows}%`,
94
- backgroundPosition: this.emojiService.getSpritePosition(data.sheet, this.sheetColumns),
95
- };
96
- }
97
- else {
98
- this.style = {
99
- ...this.style,
100
- backgroundImage: `url(${data.imageUrl})`,
101
- backgroundSize: 'contain',
102
- };
103
- }
104
- }
105
- else {
106
- if (data.hidden.length && data.hidden.includes(this.set)) {
107
- if (this.fallback) {
108
- this.style = { fontSize: `${this.size}px` };
109
- this.unified = this.fallback(data, this);
110
- }
111
- else {
112
- return (this.isVisible = false);
113
- }
114
- }
115
- else {
116
- this.style = this.emojiService.emojiSpriteStyles(data.sheet, this.set, this.size, this.sheetSize, this.sheetRows, this.backgroundImageFn, this.sheetColumns, this.imageUrlFn?.(this.getData()));
117
- }
118
- }
119
- return (this.isVisible = true);
120
- }
121
- ngOnDestroy() {
122
- this.destroy$.next();
123
- }
124
- getData() {
125
- return this.emojiService.getData(this.emoji, this.skin, this.set);
126
- }
127
- getSanitizedData() {
128
- return this.emojiService.getSanitizedData(this.emoji, this.skin, this.set);
129
- }
130
- handleClick($event) {
131
- const emoji = this.getSanitizedData();
132
- this.emojiClick.emit({ emoji, $event });
133
- }
134
- handleOver($event) {
135
- const emoji = this.getSanitizedData();
136
- this.emojiOver.emit({ emoji, $event });
137
- }
138
- setupMouseLeaveListener() {
139
- this.button$
140
- .pipe(
141
- // Note: `EMPTY` is used to remove event listener once the DOM node is removed.
142
- switchMap(button => (button ? fromEvent(button, 'mouseleave') : EMPTY)), takeUntil(this.destroy$))
143
- .subscribe($event => {
144
- const emoji = this.getSanitizedData();
145
- this.emojiLeaveOutsideAngular.emit({ emoji, $event });
146
- // Note: this is done for backwards compatibility. We run change detection if developers
147
- // are listening to `emojiLeave` in their code. For instance:
148
- // `<ngx-emoji (emojiLeave)="..."></ngx-emoji>`.
149
- if (this.emojiLeave.observed) {
150
- this.ngZone.run(() => this.emojiLeave.emit({ emoji, $event }));
151
- }
152
- });
153
- }
154
- }
155
- EmojiComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
156
- 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: { emojiOver: "emojiOver", emojiLeave: "emojiLeave", emojiLeaveOutsideAngular: "emojiLeaveOutsideAngular", emojiClick: "emojiClick" }, viewQueries: [{ propertyName: "button", first: true, predicate: ["button"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
157
- <ng-template [ngIf]="isVisible">
158
- <button
159
- *ngIf="useButton; else spanTpl"
160
- #button
161
- type="button"
162
- (click)="handleClick($event)"
163
- (mouseenter)="handleOver($event)"
164
- [attr.title]="title"
165
- [attr.aria-label]="label"
166
- class="emoji-mart-emoji"
167
- [class.emoji-mart-emoji-native]="isNative"
168
- [class.emoji-mart-emoji-custom]="custom"
169
- >
170
- <span [ngStyle]="style">
171
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
172
- <ng-content></ng-content>
173
- </span>
174
- </button>
175
- </ng-template>
176
-
177
- <ng-template #spanTpl>
178
- <span
179
- #button
180
- (click)="handleClick($event)"
181
- (mouseenter)="handleOver($event)"
182
- [attr.title]="title"
183
- [attr.aria-label]="label"
184
- class="emoji-mart-emoji"
185
- [class.emoji-mart-emoji-native]="isNative"
186
- [class.emoji-mart-emoji-custom]="custom"
187
- >
188
- <span [ngStyle]="style">
189
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
190
- <ng-content></ng-content>
191
- </span>
192
- </span>
193
- </ng-template>
194
- `, 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 });
195
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: EmojiComponent, decorators: [{
196
- type: Component,
197
- args: [{
198
- selector: 'ngx-emoji',
199
- template: `
200
- <ng-template [ngIf]="isVisible">
201
- <button
202
- *ngIf="useButton; else spanTpl"
203
- #button
204
- type="button"
205
- (click)="handleClick($event)"
206
- (mouseenter)="handleOver($event)"
207
- [attr.title]="title"
208
- [attr.aria-label]="label"
209
- class="emoji-mart-emoji"
210
- [class.emoji-mart-emoji-native]="isNative"
211
- [class.emoji-mart-emoji-custom]="custom"
212
- >
213
- <span [ngStyle]="style">
214
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
215
- <ng-content></ng-content>
216
- </span>
217
- </button>
218
- </ng-template>
219
-
220
- <ng-template #spanTpl>
221
- <span
222
- #button
223
- (click)="handleClick($event)"
224
- (mouseenter)="handleOver($event)"
225
- [attr.title]="title"
226
- [attr.aria-label]="label"
227
- class="emoji-mart-emoji"
228
- [class.emoji-mart-emoji-native]="isNative"
229
- [class.emoji-mart-emoji-custom]="custom"
230
- >
231
- <span [ngStyle]="style">
232
- <ng-template [ngIf]="isNative">{{ unified }}</ng-template>
233
- <ng-content></ng-content>
234
- </span>
235
- </span>
236
- </ng-template>
237
- `,
238
- changeDetection: ChangeDetectionStrategy.OnPush,
239
- preserveWhitespaces: false,
240
- }]
241
- }], ctorParameters: function () { return []; }, propDecorators: { skin: [{
242
- type: Input
243
- }], set: [{
244
- type: Input
245
- }], sheetSize: [{
246
- type: Input
247
- }], isNative: [{
248
- type: Input
249
- }], forceSize: [{
250
- type: Input
251
- }], tooltip: [{
252
- type: Input
253
- }], size: [{
254
- type: Input
255
- }], emoji: [{
256
- type: Input
257
- }], fallback: [{
258
- type: Input
259
- }], hideObsolete: [{
260
- type: Input
261
- }], sheetRows: [{
262
- type: Input
263
- }], sheetColumns: [{
264
- type: Input
265
- }], useButton: [{
266
- type: Input
267
- }], emojiOver: [{
268
- type: Output
269
- }], emojiLeave: [{
270
- type: Output
271
- }], emojiLeaveOutsideAngular: [{
272
- type: Output
273
- }], emojiClick: [{
274
- type: Output
275
- }], backgroundImageFn: [{
276
- type: Input
277
- }], imageUrlFn: [{
278
- type: Input
279
- }], button: [{
280
- type: ViewChild,
281
- args: ['button', { static: false }]
282
- }] } });
283
- //# 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        (mouseenter)=\"handleOver($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        (mouseenter)=\"handleOver($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() emojiOver: Emoji['emojiOver'] = new EventEmitter();\n  /**\n   * Note: `emojiLeave` and `emojiLeaveOutsideAngular` are dispatched on the same event, but for different\n   *       purposes. The `emojiLeaveOutsideAngular` would be set up in category component so we don't care\n   *       about zone context the callback is being called in. The `emojiLeave` is for backwards compatibility\n   *       if anyone is listening to this event explicitly in their code.\n   */\n  @Output() emojiLeave: Emoji['emojiLeave'] = new EventEmitter();\n  @Output() emojiLeaveOutsideAngular: Emoji['emojiLeave'] = new EventEmitter();\n  @Output() emojiClick: Emoji['emojiClick'] = new EventEmitter();\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.setupMouseLeaveListener();\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  handleOver($event: Event) {\n    const emoji = this.getSanitizedData();\n    this.emojiOver.emit({ emoji, $event });\n  }\n\n  private setupMouseLeaveListener(): void {\n    this.button$\n      .pipe(\n        // Note: `EMPTY` is used to remove event listener once the DOM node is removed.\n        switchMap(button => (button ? fromEvent(button, 'mouseleave') : EMPTY)),\n        takeUntil(this.destroy$),\n      )\n      .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