Compose Emoji Picker uses Emoji Core to fetch all the latest emojis and display them.
- Added checks to skip emojis that can not be rendered instead of showing them as tofu (�).
- Searching and Filtering
- All emoji from Unicode emoji version 15.0 (latest) are available. (as supported by device)
- Sticky header for the group name
The latest version can be found here
- Add it in your root
build.gradle
at the end of repositories:
allprojects {
repositories {
maven { url "https://jitpack.io" }
}
}
- Add dependency to module
build.gradle
dependencies {
implementation "com.github.Abhimanyu14:compose-emoji-picker:$latest_version"
}
compose.emoji.picker.2.mov
@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun ComposeEmojiPickerDemo() {
val context = LocalContext.current
val sheetState = rememberModalBottomSheetState(
skipPartiallyExpanded = true,
)
var isModalBottomSheetVisible by remember {
mutableStateOf(false)
}
var selectedEmoji by remember {
mutableStateOf("😃")
}
var searchText by remember {
mutableStateOf("")
}
if (isModalBottomSheetVisible) {
ModalBottomSheet(
sheetState = sheetState,
shape = RectangleShape,
tonalElevation = 0.dp,
onDismissRequest = {
isModalBottomSheetVisible = false
searchText = ""
},
dragHandle = null,
windowInsets = WindowInsets(0),
) {
Column(
modifier = Modifier
.fillMaxSize(),
) {
ComposeEmojiPickerBottomSheetUI(
onEmojiClick = { emoji ->
isModalBottomSheetVisible = false
selectedEmoji = emoji.character
},
onEmojiLongClick = { emoji ->
Toast.makeText(
context,
emoji.unicodeName.capitalizeWords(),
Toast.LENGTH_SHORT,
).show()
},
searchText = searchText,
updateSearchText = { updatedSearchText ->
searchText = updatedSearchText
},
)
}
}
}
Box(
contentAlignment = Alignment.Center,
modifier = Modifier
.fillMaxSize()
.padding(16.dp),
) {
ComposeEmojiPickerEmojiUI(
emojiCharacter = selectedEmoji,
onClick = {
isModalBottomSheetVisible = true
},
fontSize = 56.sp,
)
}
}
- Jetpack Compose dependencies
- emoji2
Please do create new issues if there are any bugs or feature requests.
You can also directly reach out to me via LinkedIn
Support it by joining stargazers for this repository. 🌟
Also follow me for my next creations! 🤗
Copyright 2023 Abhimanyu
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.