This GNOME shell extension provides a emoji search pop-up menu. ๐
Want any emoji? It's right into your top bar!
This repo is a Fork from emoji-selector-for-gnome and was created for keeping the extension alive.
Please feel free to use and contribute to this project. ๐
- keyboard shortcut to open the extension's menu (Super+. by default)
- dynamic search (press Enter to copy the first result to the clipboard)
- lots of configurable things
- skin tone & gender modifiers
- middle-click to set to the clipboard without closing the menu (or Ctrl+Enter)
- right-click to add the emoji at the end of the current clipboard content (or Shift+Enter)
Keyboard navigation is designed to work with Tab, not the arrows.
The easiest way to install it is directly from Gnome Extensions: emoji-copy
Work in progress...
We need to publish this project to most known package managers, like AUR, Fedora and so on.
Not recommended at all: installing the extension this way will prevent any further updates.
- Download and extract the ZIP, then open a terminal in the project's directory.
- Choose a way to install the extension:
--> Make ๐ฅ
$ make install
--> NPM ๐
$ npm run deploy
--> Shell scripts ๐คจ
$ sh install.sh
--> Hardcore ๐
$ cp -a ./emoji-copy@felipeftn $HOME/.local/share/gnome-shell/extensions
You may need to restart the GNOME Shell environment (Alt+F2 -> restart
-> Enter).
(X11 only, if you are in Wayland, sign out and sign in from the session manually).
We have a lot of ways to debug and test our code. Currently, we already have a complete guide to debug and test our extension in a local environment described in debug.md file.
In a simpler way, you can debug the code in two ways:
--> Make ๐ฅ
$ make debug
--> Gnome Dbus Session ๐ง
$ make && dbus-run-session -- gnome-shell --nested --wayland
Loading hundreds of small pictures and thousands of keywords into the memory is
a lot. Despite a few attempts to optimize their loading, I'm not an expert at
all concerning memory management, and the extension may be responsible for
between 10MB and 60MB of memory usage, which is a lot. Don't blame the actual GS
devs for it.
โจ Update:
Currently, we are loading emojis with SQLite. With a SQL query system, we were
able to load just the necessary amount of emojis for each category. All the emojis are "pre-compiled" during the building process, and generates a emojis.db
file at data directory (inside extension's directory).
We still can do a lot of improvements in the way we load and display these emojis. Maybe some skeletons and non-syncronous loading should be great to avoid slow loadings.
It will be less ugly if you have the ยซ Noto Emoji ยป font, the ยซ Twitter Color Emoji ยป font, or the ยซ JoyPixels Color ยป font installed on your system.
Various contributions to the code itself:
- maoschanz emoji-selector-for-gnome creator
- Ryan Gonzalez
- amivaleo
- xurizaemon
- khaled-0
- VortexAcherontic
- NatVIII
- pavinjosdev
The extension is currently available in the following languages:
- ๐ช๐ธ Castillan (Thanks to @mario-mra)
- ๐จ๐ณ Simplified chinese (Thanks to @larryw3i)
- ๐ณ๐ฑ Dutch (Thanks to @vistaus)
- ๐บ๐ณ Esperanto (Thanks to @nicolasmaia)
- ๐ฉ๐ช German (Thanks to @jonnius)
- ๐ฎ๐น Italian (Thanks to @amivaleo)
- ๐ต๐ฑ Polish (Thanks to @alex4401)
- ๐ง๐ท Brazilian/๐ต๐น Portuguese (Thanks to @nicolasmaia, @picsi & @frnogueira)
- ๐น๐ท Turkish (Thanks to @mimoguz)
- ๐ท๐บ Russian (Thanks to @jasursadikov)
If you need another language, please contribute! โค๏ธ