Some checks failed
		
		
	
	Detach Plugins / check (FlyGrep.vim) (push) Has been cancelled
				
			Detach Plugins / check (GitHub.vim) (push) Has been cancelled
				
			Detach Plugins / check (JavaUnit.vim) (push) Has been cancelled
				
			Detach Plugins / check (SourceCounter.vim) (push) Has been cancelled
				
			Detach Plugins / check (cpicker.nvim) (push) Has been cancelled
				
			Detach Plugins / check (dein-ui.vim) (push) Has been cancelled
				
			Detach Plugins / check (git.vim) (push) Has been cancelled
				
			Detach Plugins / check (iedit.vim) (push) Has been cancelled
				
			Detach Plugins / check (scrollbar.vim) (push) Has been cancelled
				
			Detach Plugins / check (vim-chat) (push) Has been cancelled
				
			Detach Plugins / check (vim-cheat) (push) Has been cancelled
				
			Detach Plugins / check (vim-todo) (push) Has been cancelled
				
			Detach Plugins / check (xmake.vim) (push) Has been cancelled
				
			test / Linux (nvim, nightly) (push) Has been cancelled
				
			test / Linux (nvim, v0.3.8) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.3) (push) Has been cancelled
				
			test / Linux (nvim, v0.4.4) (push) Has been cancelled
				
			test / Linux (nvim, v0.5.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.5.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.6.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.6.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.7.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.7.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.1) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.2) (push) Has been cancelled
				
			test / Linux (nvim, v0.8.3) (push) Has been cancelled
				
			test / Linux (nvim, v0.9.0) (push) Has been cancelled
				
			test / Linux (nvim, v0.9.1) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.052) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.1689) (push) Has been cancelled
				
			test / Linux (true, vim, v7.4.629) (push) Has been cancelled
				
			test / Linux (true, vim, v8.0.0027) (push) Has been cancelled
				
			test / Linux (true, vim, v8.0.0183) (push) Has been cancelled
				
			test / Linux (vim, nightly) (push) Has been cancelled
				
			test / Linux (vim, v8.0.0184) (push) Has been cancelled
				
			test / Linux (vim, v8.0.1453) (push) Has been cancelled
				
			test / Linux (vim, v8.1.2269) (push) Has been cancelled
				
			test / Linux (vim, v8.2.2434) (push) Has been cancelled
				
			test / Linux (vim, v8.2.3995) (push) Has been cancelled
				
			test / Windows (nvim, nightly) (push) Has been cancelled
				
			test / Windows (nvim, v0.3.8) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.3) (push) Has been cancelled
				
			test / Windows (nvim, v0.4.4) (push) Has been cancelled
				
			test / Windows (nvim, v0.5.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.5.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.6.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.6.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.7.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.7.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.1) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.2) (push) Has been cancelled
				
			test / Windows (nvim, v0.8.3) (push) Has been cancelled
				
			test / Windows (nvim, v0.9.0) (push) Has been cancelled
				
			test / Windows (nvim, v0.9.1) (push) Has been cancelled
				
			test / Windows (vim, nightly) (push) Has been cancelled
				
			test / Windows (vim, v7.4.1185) (push) Has been cancelled
				
			test / Windows (vim, v7.4.1689) (push) Has been cancelled
				
			test / Windows (vim, v8.0.0027) (push) Has been cancelled
				
			test / Windows (vim, v8.0.1453) (push) Has been cancelled
				
			test / Windows (vim, v8.1.2269) (push) Has been cancelled
				
			test / Windows (vim, v8.2.2434) (push) Has been cancelled
				
			test / Windows (vim, v8.2.3995) (push) Has been cancelled
				
			docker / docker (push) Has been cancelled
				
			mirror / check (coding) (push) Has been cancelled
				
			mirror / check (gitee) (push) Has been cancelled
				
			mirror / check (gitlab) (push) Has been cancelled
				
			
		
			
				
	
	
		
			103 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# Input
 | 
						|
 | 
						|
Input is an abstraction layer on top of Popup.
 | 
						|
 | 
						|
It uses prompt buffer (check `:h prompt-buffer`) for its popup window.
 | 
						|
 | 
						|
```lua
 | 
						|
local Input = require("nui.input")
 | 
						|
local event = require("nui.utils.autocmd").event
 | 
						|
 | 
						|
local popup_options = {
 | 
						|
  relative = "cursor",
 | 
						|
  position = {
 | 
						|
    row = 1,
 | 
						|
    col = 0,
 | 
						|
  },
 | 
						|
  size = 20,
 | 
						|
  border = {
 | 
						|
    style = "rounded",
 | 
						|
    text = {
 | 
						|
      top = "[Input]",
 | 
						|
      top_align = "left",
 | 
						|
    },
 | 
						|
  },
 | 
						|
  win_options = {
 | 
						|
    winhighlight = "Normal:Normal",
 | 
						|
  },
 | 
						|
}
 | 
						|
 | 
						|
local input = Input(popup_options, {
 | 
						|
  prompt = "> ",
 | 
						|
  default_value = "42",
 | 
						|
  on_close = function()
 | 
						|
    print("Input closed!")
 | 
						|
  end,
 | 
						|
  on_submit = function(value)
 | 
						|
    print("Value submitted: ", value)
 | 
						|
  end,
 | 
						|
  on_change = function(value)
 | 
						|
    print("Value changed: ", value)
 | 
						|
  end,
 | 
						|
})
 | 
						|
```
 | 
						|
 | 
						|
If you provide the `on_change` function, it'll be run everytime value changes.
 | 
						|
 | 
						|
Pressing `<CR>` runs the `on_submit` callback function and closes the window.
 | 
						|
Pressing `<C-c>` runs the `on_close` callback function and closes the window.
 | 
						|
 | 
						|
Of course, you can override the default keymaps and add more. For example:
 | 
						|
 | 
						|
```lua
 | 
						|
-- unmount input by pressing `<Esc>` in normal mode
 | 
						|
input:map("n", "<Esc>", function()
 | 
						|
  input:unmount()
 | 
						|
end, { noremap = true })
 | 
						|
```
 | 
						|
 | 
						|
You can manipulate the assocciated buffer and window using the
 | 
						|
`split.bufnr` and `split.winid` properties.
 | 
						|
 | 
						|
**NOTE**: the first argument accepts options for `nui.popup` component.
 | 
						|
 | 
						|
## Options
 | 
						|
 | 
						|
### `prompt`
 | 
						|
 | 
						|
**Type:** `string` or `NuiText`
 | 
						|
 | 
						|
Prefix in the input.
 | 
						|
 | 
						|
### `default_value`
 | 
						|
 | 
						|
**Type:** `string`
 | 
						|
 | 
						|
Default value placed in the input on mount
 | 
						|
 | 
						|
### `on_close`
 | 
						|
 | 
						|
Callback function, called when input is closed.
 | 
						|
 | 
						|
### `on_submit`
 | 
						|
 | 
						|
Callback function, called when input value is submitted.
 | 
						|
 | 
						|
### `on_change`
 | 
						|
 | 
						|
Callback function, called when input value is changed.
 | 
						|
 | 
						|
### `disable_cursor_position_patch`
 | 
						|
 | 
						|
By default, `nui.input` will try to make sure the cursor on parent window is not
 | 
						|
moved after input is submitted/closed. If you want to disable this behavior
 | 
						|
for some reason, you can set `disable_cursor_position_patch` to `true`.
 | 
						|
 | 
						|
## Methods
 | 
						|
 | 
						|
Methods from `nui.popup` are also available for `nui.input`.
 | 
						|
 | 
						|
## Wiki Page
 | 
						|
 | 
						|
You can find additional documentation/examples/guides/tips-n-tricks in [nui.input wiki page](https://github.com/MunifTanjim/nui.nvim/wiki/nui.input).
 |