Skip to content

A plugin to search for and insert emojis/kaomojis right from Neovim πŸ˜€

License

Notifications You must be signed in to change notification settings

Allaman/emoji.nvim

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

emoji.nvim πŸ˜€

Neovim Lua

CI Update-emojis size issues last commit license release

❓ Why

This plugin allows you to easily search and insert emojis and kaomojis in your current buffer.

Though there are a couple of plugins (see Similar plugins and inspiration), I decided to make a 15th plugin. πŸ˜‰

Jokes aside, I could not find a plugin that fulfills my wish for both telescope and cmp integration, so why not write a plugin myself?

πŸ’« Features

  • Automatic updates of available emojis via GitHub actions (emojis-api.com as source).
  • No dependencies (relies on vim.ui.select).
  • (Optional) fzf-lua integration with require("fzf-lua").register_ui_select() (register fzf-lua as the UI interface for vim.ui.select)
  • (Optional) telescope.nvim integration (emojis only).
  • (Optional) nvim-cmp integration (emojis only).
  • (Optional) blink.cmp integration via blink.compat (emojis only).

πŸ–ΌοΈ Screenshots

emojis via vim.uiui.png

Please note that I use dressing.nvim in this picture so your UI might look different!

kaomojis via vim.uikaomojis.png

Please note that I use dressing.nvim so your UI might look different!

telescope (emojis)telescope.png

cmp (emojis)cmp.png

πŸ”§ Installation

With Lazy.nvim:

{
  "allaman/emoji.nvim",
  version = "1.0.0", -- optionally pin to a tag
  ft = "markdown", -- adjust to your needs
  dependencies = {
    -- util for handling paths
    "nvim-lua/plenary.nvim",
    -- optional for nvim-cmp integration
    "hrsh7th/nvim-cmp",
    -- optional for telescope integration
    "nvim-telescope/telescope.nvim",
    -- optional for fzf-lua integration via vim.ui.select
    "ibhagwan/fzf-lua",
  },
  opts = {
    -- default is false, also needed for blink.cmp integration!
    enable_cmp_integration = true,
    -- optional if your plugin installation directory
    -- is not vim.fn.stdpath("data") .. "/lazy/
    plugin_path = vim.fn.expand("$HOME/plugins/"),
  },
  config = function(_, opts)
    require("emoji").setup(opts)
    -- optional for telescope integration
    local ts = require('telescope').load_extension 'emoji'
    vim.keymap.set('n', '<leader>se', ts.emoji, { desc = '[S]earch [E]moji' })
  end,
}

For nvim-cmp integration add emoji to your list of sources:

local sources = {
  { name = "nvim_lsp" },
  { name = "buffer", keyword_length = 5 },
  { name = "luasnip" },
  { name = "emoji" },
}

For telescope integration load the extension via:

require("telescope").load_extension("emoji")

blink.cmp integration:

{
  "saghen/blink.cmp",
  optional = true,
  dependencies = { "allaman/emoji.nvim", "saghen/blink.compat" },
  opts = {
    sources = {
      default = { "emoji" },
      providers = {
        emoji = {
          name = "emoji",
          module = "blink.compat.source",
          -- overwrite kind of suggestion
          transform_items = function(ctx, items)
            local kind = require("blink.cmp.types").CompletionItemKind.Text
            for i = 1, #items do
              items[i].kind = kind
            end
            return items
          end,
        },
      },
    },
  },
}

πŸ’» Use

Emojis

  1. :Emoji and :Emoji insert respective lua require("emoji").insert() or :Emoji by-group respective lua require("emoji").insert_by_group() allows you to select an emoji that is inserted at your cursor's current position.
  2. :Telescope emoji does the same but invokes Telescope instead of vim.ui.select. (if telescope.nvim is installed and the extension loaded).
  3. While in insert mode typing : triggers the auto-completion of nvim-cmp. (if nvim-cmp integration is enabled and configured).

Kaomojis

  1. :Emoji kaomoji respective lua require("emoji").insert_kaomoji()
  2. :Emoji kaomoji-by-group respective lua require("emoji").insert_kaomoji_by_group()

You can also create key bindings to your liking.

Auto-completion in command mode is supported.

πŸ’‘ Similar plugins and inspiration

β™₯️ Credits

Thanks to (emojis-api.com for providing its emoji API that is used in GitHub Actions to automatically update emojis.

Thanks to hines-r for providing kaomojis.json