*dressing.txt* *Dressing* *dressing* *dressing.nvim* =============================================================================== CONFIGURATION *dressing-configuration* Configure dressing.nvim by calling the setup() function. > require('dressing').setup({ input = { -- Set to false to disable the vim.ui.input implementation enabled = true, -- Default prompt string default_prompt = "Input:", -- Can be 'left', 'right', or 'center' prompt_align = "left", -- When true, will close the modal insert_only = true, -- These are passed to nvim_open_win anchor = "SW", border = "rounded", -- 'editor' and 'win' will default to being centered relative = "cursor", -- These can be integers or a float between 0 and 1 (e.g. 0.4 for 40%) prefer_width = 40, width = nil, -- min_width and max_width can be a list of mixed types. -- min_width = {20, 0.2} means "the greater of 20 columns or 20% of total" max_width = { 140, 0.9 }, min_width = { 20, 0.2 }, -- Window transparency (0-100) winblend = 10, -- Change default highlight groups (see :help winhl) winhighlight = "", override = function(conf) -- This is the config that will be passed to nvim_open_win. -- Change values here to customize the layout return conf end, -- see :help dressing_get_config get_config = nil, }, select = { -- Set to false to disable the vim.ui.select implementation enabled = true, -- Priority list of preferred vim.select implementations backend = { "telescope", "fzf_lua", "fzf", "builtin", "nui" }, -- Trim trailing `:` from prompt trim_prompt = true, -- Options for telescope selector -- These are passed into the telescope picker directly. Can be used like: -- telescope = require('telescope.themes').get_ivy({...}) telescope = nil, -- Options for fzf selector fzf = { window = { width = 0.5, height = 0.4, }, }, -- Options for fzf_lua selector fzf_lua = { winopts = { width = 0.5, height = 0.4, }, }, -- Options for nui Menu nui = { position = "50%", size = nil, relative = "editor", border = { style = "rounded", }, buf_options = { swapfile = false, filetype = "DressingSelect", }, win_options = { winblend = 10, }, max_width = 80, max_height = 40, min_width = 40, min_height = 10, }, -- Options for built-in selector builtin = { -- These are passed to nvim_open_win anchor = "NW", border = "rounded", -- 'editor' and 'win' will default to being centered relative = "editor", -- Window transparency (0-100) winblend = 10, -- Change default highlight groups (see :help winhl) winhighlight = "", -- These can be integers or a float between 0 and 1 (e.g. 0.4 for 40%) -- the min_ and max_ options can be a list of mixed types. -- max_width = {140, 0.8} means "the lesser of 140 columns or 80% of total" width = nil, max_width = { 140, 0.8 }, min_width = { 40, 0.2 }, height = nil, max_height = 0.9, min_height = { 10, 0.2 }, override = function(conf) -- This is the config that will be passed to nvim_open_win. -- Change values here to customize the layout return conf end, }, -- Used to override format_item. See :help dressing-format format_item_override = {}, -- see :help dressing_get_config get_config = nil, }, }) dressing.get_config() *dressing_get_config()* For each of the `input` and `select` configs, there is an option `get_config`. This can be a function that accepts the `opts` parameter that is passed in to `vim.select` or `vim.input`. It must return either `nil` (to no-op) or config values to use in place of the global config values for that module. For example, if you want to use a specific configuration for code actions: > require('dressing').setup({ select = { get_config = function(opts) if opts.kind == 'codeaction' then return { backend = 'nui', nui = { relative = 'cursor', max_width = 40, } } end end } }) =============================================================================== *dressing-format* Sometimes you may wish to change how choices are displayed for `vim.ui.select`. The calling function can pass a specific "kind" to the select function (for example, code actions from |vim.lsp.buf.code_action| use kind="codeaction"). You can, in turn, specify an override for the "format_item" function when selecting for that kind. For example, this configuration will display the name of the language server next to code actions: > format_item_override = { codeaction = function(action_tuple) local title = action_tuple[2].title:gsub("\r\n", "\\r\\n") local client = vim.lsp.get_client_by_id(action_tuple[1]) return string.format("%s\t[%s]", title:gsub("\n", "\\n"), client.name) end, } =============================================================================== vim:ft=help:et:ts=2:sw=2:sts=2:norl