Emoji library that contains only the emojis that work on most of the browsers and operating systems currently available π π
Finally no more οΏ½ symbols when rendering the emojis π₯³
Based off emojis from emojilib and keywords from unicode-emoji-json
NB: EmojiSet requires Node version 14 or above.
npm install emoji-set --save
To get started, you can import the package using two methods:
// ES6 import
import EmojiSet from 'emoji-set'
// or CommonJS import
const EmojiSet = require('emoji-set')
Returns the emojis that match the given filter. Leave the filter
parameter blank
to return all available emojis.
Available fields for the filter
parameter include:
Field | Default | Description |
---|---|---|
only_emoji |
false |
true to only return the emojis, false to return the emojis and their information |
by_section |
false |
true to return the emojis grouped by their section, false to return the emojis without any grouping |
by_keyword |
false |
true to return the emojis grouped by their keywords, false to return the emojis without any grouping |
Some examples can be seen below.
console.log(EmojiSet.get())
/* Returns */
{
'π': {
name: 'grinning face',
code: 'grinning_face',
group: 'Smileys & Emotion',
keywords: [ 'grin', 'face', 'smile', 'happy', 'joy', ':D' ]
},
'π': {
name: 'grinning face with big eyes',
code: 'grinning_face_with_big_eyes',
group: 'Smileys & Emotion',
keywords: [ 'grin', 'face', 'happy', 'joy', 'haha', ':D', ':)', 'smile', 'funny' ]
},
'π': {
name: 'grinning face with smiling eyes',
code: 'grinning_face_with_smiling_eyes',
group: 'Smileys & Emotion',
keywords: [ 'grin', 'face', 'happy', 'joy', 'funny', 'haha', 'laugh', 'like', ':D', ':)' ]
},
...
}
console.log(EmojiSet.get({ only_emoji: true }))
/* Returns */
[ 'π', 'π', 'π', ... ]
console.log(EmojiSet.get({ by_section: true }))
/* Returns */
{
'Smileys & Emotion': [
{
emoji: 'π',
name: 'grinning face',
code: 'grinning_face',
keywords: [ 'face', 'smile', 'happy', 'joy', ':D', 'grin' ]
},
{
emoji: 'π',
name: 'grinning face with big eyes',
code: 'grinning_face_with_big_eyes',
keywords: [ 'face', 'happy', 'joy', 'haha', ':D', ':)', 'smile', 'funny' ]
},
...
],
'People & Body': [
{
emoji: 'π',
name: 'waving hand',
code: 'waving_hand',
keywords: [ 'hands', 'gesture', 'goodbye', 'solong', 'farewell', 'hello', 'hi', 'palm' ]
},
{
emoji: 'π€',
name: 'raised back of hand',
code: 'raised_back_of_hand',
keywords: [ 'fingers', 'raised', 'backhand' ]
},
...
],
...
}
console.log(EmojiSet.get({ by_section: true, only_emoji: true }))
/* Returns */
{
'Smileys & Emotion': [ 'π', 'π', ... ],
'People & Body': [ 'π', 'π€', ... ],
...
}
console.log(EmojiSet.get({ by_keywords: true }))
/* Returns */
{
...
'playful': {
'π': {
name: 'face with tongue',
code: 'face_with_tongue',
group: 'Smileys & Emotion'
},
'π': {
name: 'winking face with tongue',
code: 'winking_face_with_tongue',
group: 'Smileys & Emotion'
},
'π': {
name: 'squinting face with tongue',
code: 'squinting_face_with_tongue',
group: 'Smileys & Emotion'
},
'π
': {
name: 'tongue',
code: 'tongue',
group: 'People & Body'
}
},
'quiet': {
'π€«': {
name: 'shushing face',
code: 'shushing_face',
group: 'Smileys & Emotion'
},
'π': {
name: 'muted speaker',
code: 'muted_speaker',
group: 'Objects'
},
'π': {
name: 'bell with slash',
code: 'bell_with_slash',
group: 'Objects'
},
'π΄': {
name: 'mobile phone off',
code: 'mobile_phone_off',
group: 'Symbols'
}
},
...
}
console.log(EmojiSet.get({ by_keywords: true, only_emoji: true }))
/* Returns */
{
...
'playful': [ 'π', 'π', 'π', 'π
' ],
'quiet': [ 'π€«', 'π', 'π', 'π΄' ],
...
}
Searches for emojis using the given filter.
Available fields for the filter
parameter include:
Field | Default | Description |
---|---|---|
only_emoji |
false |
true to only return the emojis, false to return the emojis and their information |
by_section |
'' |
Section to return the emojis from. Some examples are: 'Objects' , 'Animals & Nature' etc. Value is case-insensitive |
by_keyword |
'' |
Keyword to use in the emoji search. Some examples are: 'smile' , 'tada' etc. Value is case-insensitive |
first_match |
false |
true to only return the first match (when using by_keyword ), false to return all matches |
Some examples can be seen below.
console.log(EmojiSet.search({ by_section: 'flags' }))
/* Returns */
[
{
emoji: 'π',
code: 'chequered_flag',
keywords: [ 'chequered', 'flag', 'contest', 'finishline', 'race', 'gokart' ]
},
{
emoji: 'π©',
code: 'triangular_flag',
keywords: [ 'mark', 'milestone', 'place' ]
},
{
emoji: 'π',
code: 'crossed_flags',
keywords: [ 'cross', 'flag', 'japanese', 'nation', 'country', 'border' ]
},
{
emoji: 'π΄',
code: 'black_flag',
keywords: [ 'black', 'flag', 'pirate' ]
},
{
emoji: 'π³οΈ' ,
code: 'white_flag',
keywords: [ 'white', 'flag', 'losing', 'loser', 'lost', 'surrender', 'give up', 'fail' ]
},
{
emoji: 'π³οΈβπ' ,
code: 'rainbow_flag',
keywords: [ 'rainbow', 'flag', 'pride', 'gay', 'lgbt', 'glbt', 'queer', 'homosexual', 'lesbian', 'bisexual', 'transgender' ]
},
{
emoji: 'π΄ββ οΈ',
code: 'pirate_flag',
keywords: [ 'pirate', 'flag', 'skull', 'crossbones', 'banner' ]
}
]
console.log(EmojiSet.search({ by_section: 'flags', only_emoji: true }))
/* Returns */
[ 'π', 'π©', 'π', 'π΄', 'π³οΈ', 'π³οΈβπ', 'π΄ββ οΈ' ]
console.log(EmojiSet.search({ by_keyword: 'perf' }))
/* Returns */
{
'π―': {
name: 'hundred points',
code: 'hundred_points',
group: 'Smileys & Emotion'
},
'π': {
name: 'OK hand',
code: 'ok_hand',
group: 'People & Body'
},
'π―': {
name: 'people with bunny ears',
code: 'people_with_bunny_ears',
group: 'People & Body'
},
'π€Ή': {
name: 'person juggling',
code: 'person_juggling',
group: 'People & Body'
}
}
console.log(EmojiSet.search({ by_keyword: 'perf', first_match: true }))
/* Returns */
{
'π―': {
name: 'hundred points',
code: 'hundred_points',
group: 'Smileys & Emotion'
}
}
π Search for emojis that match the given keyword, returning the first match only and without any additional information
console.log(EmojiSet.search({ by_keyword: 'perf', first_match: true, only_emoji: true }))
/* Returns */
[ 'π―' ]