mirror of
https://github.com/status-im/rn-emoji-keyboard.git
synced 2025-02-19 19:28:12 +00:00
I think it should be `handlePick` instead of `handleSelect` that doesn't appear anywhere else. Feel free to close this PR if that was the intention
124 lines
4.7 KiB
Markdown
124 lines
4.7 KiB
Markdown
# 🚀 rn-emoji-keyboard
|
|
A lightweight, fully customizable emoji picker, written as React Native component (without native elements). Designated to be user and developer friendly! 💖
|
|
|
|
data:image/s3,"s3://crabby-images/b4715/b4715f2dd1bbda39ed29ec156fc0d69ee5441871" alt="Preview"
|
|
|
|
## 🪄 Installation
|
|
```sh
|
|
yarn add rn-emoji-keyboard
|
|
```
|
|
or
|
|
```sh
|
|
npm install rn-emoji-keyboard
|
|
```
|
|
## ⚡️ Usage
|
|
|
|
```js
|
|
import EmojiPicker from 'rn-emoji-keyboard';
|
|
|
|
export default function App() {
|
|
const [isOpen, setIsOpen] = React.useState<boolean>(false);
|
|
|
|
const handlePick = (emojiObject: EmojiType) => {
|
|
console.log(emojiObject);
|
|
/* example emojiObject = {
|
|
"emoji": "❤️",
|
|
"name": "red heart",
|
|
"slug": "red_heart",
|
|
"unicode_version": "0.6",
|
|
}
|
|
*/
|
|
};
|
|
|
|
return (
|
|
<EmojiPicker
|
|
onEmojiSelected={handlePick}
|
|
open={isOpen}
|
|
onClose={() => setIsOpen(false)} />
|
|
)
|
|
}
|
|
```
|
|
|
|
## ⚙️ Accepted props (current implemented)
|
|
| Name | Type | Default Value | Required | Description |
|
|
|---|---|---|---|---|
|
|
| onEmojiSelected | function | undefined | yes | Callback on emoji selected |
|
|
| open | boolean | false | yes | Opens modal picker |
|
|
| onClose | function | undefined | yes | Request close modal *runs when onEmojiSelected or backdrop pressed* |
|
|
| emojiSize | number | 28 | no | Custom emoji size |
|
|
| headerStyles | TextStyle | {} | no | Override category name styles |
|
|
| knobStyles | ViewStyle | {} | no | Override knob styles |
|
|
| containerStyles | ViewStyle | {} | no | Override container styles |
|
|
| hideHeader | boolean | false | no | Hide category names |
|
|
| expandable | boolean | true | no | Show knob and enable expand on swipe up |
|
|
| defaultHeight | number \| string | "40%" | no | Specify collapsed container height (number is points, string is a percentage of the screen height) |
|
|
| expandedHeight | number \| string | "80%" | no | Specify expanded container height (number is points, string is a percentage of the screen height) _works only if expandable is true_ |
|
|
| backdropColor | string | "#00000055" | no | Change backdrop color and alpha |
|
|
| categoryColor | string | "#000000" | no | Change category item color |
|
|
| activeCategoryColor | string | "#005b96" | no | Change active category item color |
|
|
| categoryContainerColor | string | "#e3dbcd" | no | Change category container color |
|
|
| activeCategoryContainerColor | string | "#ffffff" | no | Change selected category container color |
|
|
| onCategoryChangeFailed | function | warn(info) | no | Callback on category change failed (info: {index, highestMeasuredFrameIndex, averageItemLength}) |
|
|
| translation | CategoryTranslation | en | no | Translation object *see translation section* |
|
|
| disabledCategory | CategoryTypes[] | [] | no | Hide categories by passing their slugs |
|
|
## 🖼 Usage as static
|
|
|
|
```js
|
|
import { EmojiKeyboard } from 'rn-emoji-keyboard';
|
|
|
|
// ...
|
|
|
|
<EmojiKeyboard onEmojiSelected={handlePick} />
|
|
```
|
|
Example about serving as static keyboard [you can find here](/example/src/Dark/Dark.tsx).
|
|
## 🇺🇸 Internationalization
|
|
### Pre-defined
|
|
Due to the limited translation possibilities, we only provide a few pre-defined translations into the following languages:
|
|
* `en` - English 🇺🇸
|
|
* `pl` - Polish 🇵🇱
|
|
|
|
First import lang and use it as `translation` prop.
|
|
```ts
|
|
import { pl } from 'rn-emoji-keyboard';
|
|
|
|
// ...
|
|
|
|
translation={pl}
|
|
```
|
|
### 🏁 Own
|
|
There is possibility to pass own translation to library with the prop called `translation` like this
|
|
```ts
|
|
translation={{
|
|
smileys_emotion: 'Smileys & Emotion',
|
|
people_body: 'People & Body',
|
|
animals_nature: 'Animals & Nature',
|
|
food_drink: 'Food & Drink',
|
|
travel_places: 'Travel & Places',
|
|
activities: 'Activities',
|
|
objects: 'Objects',
|
|
symbols: 'Symbols',
|
|
flags: 'Flags',
|
|
}}
|
|
```
|
|
*If you have written a translation into your language, we strongly encourage you to create a Pull Request and add your language to the package, following the example of other langs.*
|
|
## 🎉 Examples
|
|
You can clone the repo and run `yarn example ios` or `yarn example android` to preview app with this examples.
|
|
### [Basic](/example/src/Basic/Basic.tsx)
|
|
data:image/s3,"s3://crabby-images/c6513/c6513bacb73a938335239654ddad058d23a8d3f4" alt="Preview"
|
|
### [Dark](/example/src/Dark/Dark.tsx)
|
|
data:image/s3,"s3://crabby-images/fbf93/fbf93aa792d92c5fb22bfe86cbdf4ed9132ae2b6" alt="Preview"
|
|
### [Translated](/example/src/Translated/Translated.tsx)
|
|
data:image/s3,"s3://crabby-images/d3f55/d3f557592d0561b3c2ee7da5f8f5e9aa918b1a4d" alt="Preview"
|
|
### [DisabledCategories](/example/src/DisabledCategories/DisabledCategories.tsx)
|
|
data:image/s3,"s3://crabby-images/7d294/7d2942612c39863b5b755ea3c75b6873502fb39c" alt="Preview"
|
|
### [StaticModal (without knob)](/example/src/StaticModal/StaticModal.tsx)
|
|
data:image/s3,"s3://crabby-images/7aa4b/7aa4b083caaaa928fad8af752ff7bc935e42eef5" alt="Preview"
|
|
### [Static](/example/src/Static/Static.tsx)
|
|
data:image/s3,"s3://crabby-images/98fd0/98fd05b9677c47a327556399e525c95f84e81697" alt="Preview"
|
|
## 📈 Future plans
|
|
* Skin tone palette selector.
|
|
* Search bar.
|
|
* Write native module to display forbidden emojis on android.
|
|
## ⚖️ License
|
|
**[MIT](/LICENSE)**
|