HEX
Server: LiteSpeed
System: Linux s3604.bom1.stableserver.net 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User: dmstechonline (1480)
PHP: 7.4.33
Disabled: NONE
Upload Files
File: /home/dmstechonline/whatsapp.dmstech.online/node_modules/vue3-emoji-picker/README.md
# Vue3 Emoji Picker. [Live preview](https://codesandbox.io/p/github/delowardev/vue3-emoji-picker/main?file=%2FREADME.md)

[![Test Automation](https://github.com/delowardev/vue3-emoji-picker/actions/workflows/TestAutomation.yaml/badge.svg)](https://github.com/delowardev/vue3-emoji-picker/actions/workflows/TestAutomation.yaml)
[![npm version](https://badge.fury.io/js/vue3-emoji-picker.svg)](https://badge.fury.io/js/vue3-emoji-picker)
[![downloads](https://img.shields.io/npm/dm/vue3-emoji-picker.svg)](https://www.npmjs.com/package/vue3-emoji-picker)

<img src="https://i.imgur.com/CQc1nCF.png" width="280" />
<img src="https://i.imgur.com/RGGRQSk.png" width="280" />

## Installation:

```
npm install vue3-emoji-picker

// or
yarn add vue3-emoji-picker
```

_Important note: If you're using TypeScript, don't forget to add `declare module 'vue3-emoji-picker'` in your `.d.ts` file_

## Usage:

```javascript
// import picker compopnent
import EmojiPicker from 'vue3-emoji-picker'

// import css
import 'vue3-emoji-picker/css'
// or import directly:
// import'node_modules/vue3-emoji-picker/dist/style.css'
```

```vue
// use picker component
<EmojiPicker :native="true" @select="onSelectEmoji" />
```

```javascript
// event callback
function onSelectEmoji(emoji) {
  console.log(emoji)
  /*
    // result
    { 
        i: "😚", 
        n: ["kissing face"], 
        r: "1f61a", // with skin tone
        t: "neutral", // skin tone
        u: "1f61a" // without tone
    }
    */
}
```

## Options (`props`)

| Prop                       | Type    | Default Value | Description                                                                                 |
| :------------------------- | :------ | :------------ | :------------------------------------------------------------------------------------------ |
| native                     | Boolean | false         | Load native emoji instead of image.                                                         |
| hide-search                | Boolean | true          | Show/hide search input.                                                                     |
| hide-group-icons           | Boolean | false         | Show/hide header group icons.                                                               |
| hide-group-names           | Boolean | false         | Show/hide group names.                                                                      |
| disable-sticky-group-names | Boolean | false         | Disable sticky for group names                                                              |
| disable-skin-tones         | Boolean | false         | Disable skin tones.                                                                         |
| disabled-groups            | Array   | []            | Disable any group/category. See [Available groups](#available-groups)                       |
| group-names                | Object  | {}            | Change any group name. See [Default group names](#default-group-names)                      |
| static-texts               | Object  | Object        | See [static-texts](#propsstatic-texts) table                                                |
| pickerType                 | string  | ''            | Choose picker type, possible options: `input`, `textarea` (Popup with input/textarea), `''` |
| mode                       | string  | 'insert'      | Choose insert mode, possible options: `prepend`, `insert`, `append`                         |
| offset                     | Number  | '6'           | Choose emoji popup offset                                                                   |
| additional-groups          | Object  | {}            | Add additional customized groups, keys are the group names translated from snake_case       |
| group-order                | Array   | []            | Override ordering of groups                                                                 |
| group-icons                | Object  | {}            | Override group icons by passing svg's on keys                                               |
| display-recent             | Boolean | false         | Display Recently used emojis                                                                |
| theme                      | String  | 'light'       | Available options, 'light', 'dark', and 'auto'                                              |

## Static text option (`props['static-texts']`)

| Prop        | Type   | Default Value | Description                           |
| :---------- | :----- | :------------ | :------------------------------------ |
| placeholder | String | Search emoji  | Update search input placeholder text. |
| skinTone    | String | Skin tone     | Footer skin tone button text.         |

Example:
`:static-texts="{ placeholder: 'Search emoji'}" `<br/>

## Events / Callbacks

### `@select`

This event fires when an emoji gets selected/clicked.<br/>
Event callback will receive selected emoji in the first argument.

```
<EmojiPicker @select="onSelectEmoji" />

function onSelectEmoji(emoji) { /* do something */ }
```

### `@update:text`

This event fires when input text gets changed.<br/>
Event callback will receive the text in the first argument.

```
<EmojiPicker @update:text="onChangeText" />

function onChangeText(text) { /* do something */ }
```

## Available groups

```json
[
  "smileys_people",
  "animals_nature",
  "food_drink",
  "activities",
  "travel_places",
  "objects",
  "symbols",
  "flags"
]
```

## Default group names

```json
{
  "smileys_people": "Smiles & People",
  "animals_nature": "Animals & Nature",
  "food_drink": "Food & Drink",
  "activities": "Activities",
  "travel_places": "Travel places",
  "objects": "Objects",
  "symbols": "Symbols",
  "flags": "Flags"
}
```

## Overriding group names

```vue
<picker :group-names="{ smileys_people: 'My customized group name' }" />
```

## Overriding group icons

```vue
<template>
  <picker :group-icons="{ smileys_people: customSVG }" />
</template>

<script setup>
import customSVG from './path/to/svg'
</script>
```

## Override group order

This will make it so flags is first and then any other non-defined group will follow.

```vue
<picker :group-order="['flags']" />
```

## Add additional groups

To see any existing emoji's see `src/data/emojis.json`

```vue
<picker
  :additional-groups="{
    my_custom_group: [
      { n: ['grinning face', 'grinning'], u: '1f600' },
      { n: ['grinning face with smiling eyes', 'grin'], u: '1f601' },
    ],
  }"
  :group-names="{ my_custom_group: 'Frequently used' }"
/>
```