An open API service indexing awesome lists of open source software.

https://github.com/xingxing-collective/node-emoji-nuxt

Friendly emoji lookups and parsing utilities for nuxt module. πŸ’–
https://github.com/xingxing-collective/node-emoji-nuxt

emoji emojis emoticons node-emoji nuxt-module smiley smileys smilies

Last synced: 4 months ago
JSON representation

Friendly emoji lookups and parsing utilities for nuxt module. πŸ’–

Awesome Lists containing this project

README

          

# Emoji Nuxt Module

> Friendly emoji lookups and parsing utilities for Node.js. πŸ’–

[![npm version][npm-version-src]][npm-version-href]
[![npm downloads][npm-downloads-src]][npm-downloads-href]
[![License][license-src]][license-href]
[![Nuxt][nuxt-src]][nuxt-href]

[Node Emoji](https://github.com/omnidan/node-emoji) Nuxt Module supporting v3

- [✨  Release Notes](/CHANGELOG.md)
- [πŸ€ Β Online playground](https://stackblitz.com/github/xingxing-collective/node-emoji-nuxt?file=playground%2Fapp.vue)

## Quick Setup

1. Add `node-emoji-nuxt` dependency to your project

```bash
npx nuxi@latest module add node-emoji-nuxt
```

2. Add `node-emoji-nuxt` to the `modules` section of `nuxt.config.ts`

```ts
export default defineNuxtConfig({
modules: [
'node-emoji-nuxt'
]
})
```

## Basic Usage

You can use the provided `$emoji` to access node-emoji-nuxt in template.

```vue


{{ $emoji.emojify("I :heart: :coffee:!") }}

```

## Composables

You can use the useEmoji,useEmojify and useUnemojify composable to access node-emoji-nuxt anywhere.

```ts
const emoji = useEmoji()
emoji.emojify("I :heart: :coffee:!") // 'I ❀️ β˜•οΈ!'
// or use the useEmojify composable

emoji.unemojify('The πŸ¦„ is a fictitious animal.') // 'The :unicorn: is a fictitious animal.'
// or use the useUnemojify composable
```
## API

### emoji.emojify(input, options?)

Parse all markdown-encoded emojis in a string.

Parameters:

1. **`input`** (`string`): The input string containing the markdown-encoding emojis.
1. **`options`** _(optional)_:
- **`fallback`** (`string`; default: `""`): The string to fallback to if an emoji was not found.
- **`format`** (`() => (emoji: string, part: string, string: string) => string`; default: `value => value`): Add a middleware layer to modify each matched emoji after parsing.

```ts
const emoji = useEmoji()

console.log(emoji.emojify('The :unicorn: is a fictitious animal.'))
// 'The πŸ¦„ is a fictitious animal.'
```

### emoji.find(emoji)

Get the name and character of an emoji.

Parameters:

1. **`emoji`** (`string`): The emoji to get the data of.

```ts
const emoji = useEmoji()

console.log(emoji.find('πŸ¦„'))
// { name: 'unicorn', emoji: 'πŸ¦„' }
```

### emoji.get(name)

Get an emoji from an emoji name.

Parameters:

1. **`name`** (`string`): The name of the emoji to get.

```ts
const emoji = useEmoji()

console.log(emoji.get('unicorn'))
// 'πŸ¦„'
```

### emoji.has(emoji)

Check if this library supports a specific emoji.

Parameters:

1. **`emoji`** (`string`): The emoji to check.

```ts
const emoji = useEmoji()

console.log(emoji.has('πŸ¦„'))
// true
```

### emoji.random()

Get a random emoji.

```ts
const emoji = useEmoji()

console.log(emoji.random())
// { name: 'unicorn', emoji: 'πŸ¦„' }
```

### emoji.replace(input, replacement)

Replace the emojis in a string.

Parameters:

- **`input`** (`string`): The input string.
- **`replacement`** (`string | (emoji: string, index: number, string: string) => string`): The character to replace the emoji with.
Can be either a string or a callback that returns a string.

```ts
const emoji = useEmoji()

console.log(emoji.replace('The πŸ¦„ is a fictitious animal.', 'unicorn'))
// 'The unicorn is a fictitious animal.'
```

### emoji.search(keyword)

Search for emojis containing the provided name in their name.

Parameters:

1. **`keyword`** (`string`): The keyword to search for.

```ts
const emoji = useEmoji()

console.log(emoji.search('honey'))
// [ { name: 'honeybee', emoji: '🐝' }, { name: 'honey_pot', emoji: '🍯' } ]
```

### emoji.strip(input, options?)

Remove all of the emojis from a string.

Parameters:

1. **`input`** (`string`): The input string to strip the emojis from.
1. **`options`** _(optional)_:

- **`preserveSpaces`** (`boolean`): Whether to keep the extra space after a stripped emoji.

```ts
const emoji = useEmoji()

console.log(emoji.strip('πŸ¦„ The unicorn is a fictitious animal.'))
// 'The unicorn is a fictitious animal.'

console.log(
emoji.strip('πŸ¦„ The unicorn is a fictitious animal.', {
preserveSpaces: true,
}),
)
// ' The unicorn is a fictitious animal.'
```

### emoji.unemojify(input)

Convert all emojis in a string to their markdown-encoded counterparts.

Parameters:

1. **`input`** (`string`): The input string containing the emojis.

```ts
const emoji = useEmoji()

console.log(emoji.unemojify('The πŸ¦„ is a fictitious animal.'))
// 'The :unicorn: is a fictitious animal.'
```

### emoji.which(emoji, options?)

Get an emoji name from an emoji.

Parameters:

1. **`emoji`** (`string`): The emoji to get the name of.
1. **`options`** _(optional)_:
- **`markdown`** (`boolean`; default: `false`): Whether to return a `":emoji:"` string instead of `"emoji"`

```ts
const emoji = useEmoji()

console.log(emoji.which('πŸ¦„'))
// 'unicorn'
```

## Development

```bash
# Install dependencies
npm install

# Generate type stubs
npm run dev:prepare

# Develop with the playground
npm run dev

# Build the playground
npm run dev:build

# Run ESLint
npm run lint

# Run Vitest
npm run test
npm run test:watch

# Release new version
npm run release
```

[npm-version-src]: https://img.shields.io/npm/v/node-emoji-nuxt/latest.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-version-href]: https://npmjs.com/package/node-emoji-nuxt
[npm-downloads-src]: https://img.shields.io/npm/dm/node-emoji-nuxt.svg?style=flat&colorA=18181B&colorB=28CF8D
[npm-downloads-href]: https://npmjs.com/package/node-emoji-nuxt
[license-src]: https://img.shields.io/npm/l/node-emoji-nuxt.svg?style=flat&colorA=18181B&colorB=28CF8D
[license-href]: https://npmjs.com/package/node-emoji-nuxt
[nuxt-src]: https://img.shields.io/badge/Nuxt-18181B?logo=nuxt.js
[nuxt-href]: https://nuxt.com