-
Notifications
You must be signed in to change notification settings - Fork 298
Configuration
- config.js format
- Options
- Key Bindings
- Programmability
- init.vim support
ONI is configurable via a
config.js
located in$HOME/.config/oni
on Mac & Linux, and%APPDATA%/oni
on Windows.
Here's an example config.js:
const activate = (oni) => {
// access the Oni plugin API here
// for example, unbind the default `<c-p>` action:
oni.input.unbind("<c-p>")
// or bind a new action:
oni.input.bind("<c-enter>", () => alert("Pressed control enter"));
};
module.exports = {
activate,
// change configuration values here:
"oni.useDefaultConfig": true,
"oni.loadInitVim": true,
"editor.fontSize": "14px",
"editor.fontFamily": "Monaco",
"editor.completions.enabled": true
}
Oni will also load a workspace configuration when opening a workspace folder. The configuration must be located at the root of the workspace, in a .oni
folder.
For example, if my workspace is located at /my-project
, the per-workspace configuration must be located at /my-project/.oni/config.js
.
The workspace configuration takes precedence over per-user configuration.
Config options are organized by namespaces. The full default configuration can be found here.
-
achievements.enabled (default:
true
) Set whether or not the achievements feature is enabled.
See Auto-Closing Pairs in the Language Support section.
-
autoUpdate.enabled (default:
true
)
Set whether or not Oni should check for updates on startup.
-
browser.defaultUrl (default:
https://github.com/oni/onivim
)
Set the default url that the browser window opens to when selectingBrowser: Vertical Split
orBrowser: Horizontal Split
from the command palette -
browser.enabled (default:
true
) Set whether or not the embedded browser is enabled. -
browser.zoomFactor (default:
1.0
) Set the 'zoomFactor' of the window. A zoom of1.0
equals 100%, a zoom of0.5
equals 50%,2.0
is 200%.
NOTE: Set your color scheme via the
ui.colorscheme
variable.
We do our best to provide a good look-and-feel out-of-the-box for Vim themes, but discerning users will want to have full control of the look-and-feel. Any of the colors that are available for theming can be configured by prefixing colors.
to the theme color.
For example, if I wish to override the default tab-bar styles, I can specify:
"colors.tabs.background": "red",
"colors.tabs.foreground": "white",
which would result in:
These settings will take precedence over themes.
Colors for the hover tooltip can also be configured in the oni config.js
Available options are:
editor.hover.title.foreground: HEXVALUE
editor.hover.title.background: HEXVALUE
editor.hover.contents.foreground: HEXVALUE
editor.hover.contents.background: HEXVALUE
editor.hover.codeblock.foreground: HEXVALUE
editor.hover.codeblock.background: HEXVALUE
-
oni.audio.bellUrl (default:
null
)
Set a custom sound effect for thebell
(:help bell
). The value should be an absolute path to a supported audio file, such as a WAV file. -
oni.useDefaultConfig (default:
true
)
ONI comes with an opinionated default set of plugins for a predictable out-of-box experience. This will be great for newcomers to ONI or Vim, but for Vim/Neovim veterans, this will likely conflict. Set this tofalse
to avoid loading the default config, and to load settings frominit.vim
instead (If this is false, it impliesoni.loadInitVim
is true) -
oni.loadInitVim (default:
false
)
This determines whether the user'sinit.vim
is loaded. This setting can be astring
path or aboolean
. If set totrue
, it will loadinit.vim
from the default location. If set to astring
path (ie, 'C:/somedir/myinit.vim'), this will loadinit.vim
from the specified path (useful if you want a separate config between Oni & Neovim). Use caution when setting this and settingoni.useDefaultConfig
to true, as there could be conflicts with the default configuration. -
oni.exclude (default:
["**/node_modules/**"]
)
Glob pattern of files to exclude from Fuzzy Finder (Ctrl-P). -
oni.bookmarks (default:
[]
)
Array of files to show in fuzzy finder if Oni is launched via application icon (no working directory). -
oni.hideMenu (default:
false
)
If true, hide menu bar. When hidden, menu bar can still be displayed withAlt
. -
oni.useExternalPopupMenu (default:
true
)
Sets thepopupmenu_external
option in Neovim. This will override the default UI to show a consistent popupmenu, whether using Oni's completion mechanisms or VIM's.
Use caution when changing themenuopt
parameters if using a custom init.vim, as that may cause problematic behavior
-
editor.clipboard.enabled (default:
true
)
Enables / disables system Clipboard Integration. -
editor.quickInfo.enabled (default:
true
)
Enables / disables QuickInfo popup when hovering over known method or variable in a supported file type. Theeditor.quickInfo.show
command can be bound to a key in order to explicitly open it - Key Bindings -
editor.quickInfo.delay (default:
500
)
Delay (in ms) for showing QuickInfo when the cursor is on a term. -
editor.completions.enabled (default:
true
) DEPRECATED: Useeditor.completions.mode
instead Enables / disables code completion popup when typing in a supported file type. -
editor.completions.mode (default
'oni'
) Can be one of'oni'
,'hidden'
, or'native'
.'oni'
uses Oni's default completion strategy,'hidden'
uses an externalized popupmenu, and'native'
uses the native Vim popupmenu. -
editor.errors.slideOnFocus (default:
true
)
Enables / disables showing details when cursor is over an error. -
editor.formatting.formatOnSwitchToNormalMode (default:
false
)
Perform language-specific "formatting" operation when returning to Normal mode -
editor.fontSize (default: Windows
11px
, OSX10px
, Linux11px
)
Font size -
editor.fontFamily (default: Windows
Consolas
, OSXMenlo
, LinuxDejaVu Sans Mono
)
Font family. There is a problem on MacOS when a font has multiple typefaces. If you want to select a specific typeface instead of the default one, try using the filename containing the specific typeface, See this issue N.B.: FormacOS
users to find the PostScript font name for a font, you can open up the Font Book app, select the font you want to use, and typecommand-i
-
editor.fontLigatures (default:
true
)
If true, ligatures are enabled. -
editor.fullScreenOnStart (default:
false
)
Iftrue
, launch Oni in fullscreen mode by default. -
editor.linePadding (default:
2
)
Padding between lines, in pixels. -
editor.maximizeScreenOnStart (default:
false
)
Iftrue
, maximize Oni on launch.
NOTE: If both
editor.fullScreenOnStart
andeditor.maximizeScreenOnStart
are specified,editor.fullScreenOnStart
will take precedence.
-
editor.backgroundImageUrl (default:
null
)
Path to a custom background image -
editor.backgroundImageSize (default:
initial
)
Specifies stretch factor for background image (initial
,cover
,contain
) -
editor.backgroundOpacity (default:
1.0
)
Opacity of background image. -
editor.scrollBar.visible (default:
true
)
Sets whether the buffer scrollbar is visible. -
editor.scrollBar.cursorTick.visible (default:
true
)
Sets whether the cursor tick within the buffer scrollbar is visible. -
editor.quickOpen.execCommand (default:
null
)
If specified, executes a custom command to populate the fuzzy finder. For example,fzf
orls
. Value should contain a placeholder${search}
which will be replaced with user's input to fuzzy finder. -
editor.quickOpen.defaultOpenMode (default:
Oni.FileOpenMode.Edit
)
Sets the default action for what to do when hittingEnter
in the QuickOpen menu. By default will open a new tab for users usingtabs.mode
astabs
, or open a new buffer forbuffer
users. To swap the default action to opening the selected file in the current buffer, swap toOni.FileOpenMode.ExistingTab
. Other options can be seen using the built in auto-complete, or by looking at the API docs. -
editor.quickOpen.alternativeOpenMode (default:
Oni.FileOpenMode.ExistingTab
)
Sets the alt action for what to do when hittingCtrl-Enter
in the QuickOpen menu. By default will open a new buffer. Other options can be seen using the built in auto-complete, or by looking at the API docs. -
editor.cursorLine (default:
true
)
Enables / disables cursor line highlight. -
editor.cursorLineOpacity (default:
0.1
)
Defines opacity of cursor line highlight. Only valid wheneditor.cursorLine: true
. -
editor.cursorColumn (default:
false
)
Enables / disables cursor column highlight. -
editor.cursorColumnOpacity (default:
0.1
)
Defines opacity of cursor column highlight. Only valid wheneditor.cursorColumn: true
.
-
learning.enabled (default:
true
) Sets whether or not the learning feature is enabled (this includes the learning sidebar and the interactive tutorials)
-
ui.colorscheme (default: "onedark") Colorscheme to theme the UI. Sets the
:colorscheme
value for Vim, and also loads a theme plugin, if available. -
ui.iconTheme (default:
seti
)
File icons theme to show in the tabs. They are only displayed iftabs.mode
is set tobuffer
(tab
mode not yet supported). If you don't want to have icons, set this option tonull
. -
ui.fontFamily (default:
"BlinkMacSystemFont, 'Lucida Grande', 'Segoe UI', Ubuntu, Cantarell, sans-serif"
)
Font family used by the UI. This currently includes the tab bar font, the status bar font, and the popup menus. -
ui.fontSize (default: Windows
11px
, OSX11px
, Linux11px
)
Font size for Oni's UI. This currently includes the tab bar font, the status bar font, and the popup menus. -
ui.fontSmoothing (default:
'auto'
) Directly sets the-webkit-font-smoothing
style property on the body element. Available options are'auto'
,'none'
, 'antialiased'
, and'subpixel-antialiased'
. More information at MDN: font-smooth -
ui.animations.enabled (default:
true
)
Enable / disable the Oni animation on typing, like cursor motion when typing.
-
statusbar.enabled (default:
true
)
Enable / disable Oni's status bar to replace Neovim's. -
statusbar.fontSize (default: Windows
11px
, OSX11px
, Linux11px
)
Font size for Oni's status bar. Only valid whenstatusbar.enabled: true
.
-
tabs.mode (default:
tabs
)
(buffers
,tabs
,native
,hidden
)
Sets the tab style in Oni.buffers
will show every buffer in its own tab. If you use tabs as part of your Vim workflow, you'll likely want to set this totabs
, which will instead only show tabs. To disable Oni's tab UI entirely and revert to the native Vim tab bar, usenative
. To remove both the Oni and Vim tab bar usehidden
. See #602 and #657 for discussion around this.
NOTE:
tabs.mode
requires Neovim version0.2.1
to function correctly.
-
tabs.highlight (default:
true
)
Highlights the active tab with the currentmode
(normal, insert, visual...
). -
tabs.height (default:
"2.5em"
)
The height of the Oni UI tabs. -
tabs.showFileIcon (default:
true
)
Whentrue
, show a file icon in the tab. -
tabs.showIndex (default:
false
)
Whentrue
, show the index alongside the tab. Applies to both 'buffer' and 'tab' settings for ('tabs.mode'
). -
tabs.width (default:
"30em"
)
The max width of the Oni UI tabs. -
tabs.wrap (default:
false
)
If the tabs in the Oni UI should wrap or not once the screen is full.
Oni currently persists the last opened workspace directory on subsequent sessions, To change oni's workspace settings use the following option
-
'workspace.autoDetectWorkspace' (default:
noworkspace
): This options sets oni to detect the workspace/ project root based on markers such as a.git
file orpackage.json
,build.xml
etc. If set tonoworkspace
Oni will only change workspace if there is none available. if set tonever
oni will not autodetect project roots and finally if set toalways
oni will change the project root to match the current buffer open in one. -
'workspace.autoDetectRootFiles' (default:
[".git","node_modules",".svn","package.json",".hg",".bzr","build.xml"]
) This option allows the user to specify which files are used to denote the project root.
-
environment.additionalPaths (default:
[]
on Windows,['/usr/bin', '/usr/local/bin']
on OSX and Linux)Sets additional paths for binaries. This may be necessary to configure, if using plugins or a Language Server that is not in the default set of runtime paths. Note that depending on where you launch Oni, there may be a different set of runtime paths sent to it - you can always check by opening the developer tools and running
process.env.PATH
in the console.
-
recorder.copyScreenshotToClipboard (default:
false
)
Automatically copies the screen of Oni to the system clipboard. -
recorder.outputPath (default:
os.tmpdir()
)
Sets where Oni will save any recordings or screenshots to.
See the Language-Support entry for more information on configuring language settings.
Enable a sidebar on the left side, containing a File Explorer and other useful features.
-
sidebar.enabled (default:
true
)
If the sidebar should be enabled or not. -
sidebar.default.open (default:
true
)
If the sidebar should start opened or not -
sidebar.width (default:
15em
)
Width of the sidebar.
The externalised commandline replaces the Vim default command line that lives at the bottom of the screen with one that has styling like that of the Quick Open and Command Palette windows.
-
commandline.mode (default:
true
)
If the externalised commandline should be enabled or not. Setting this to false will revert to the standard Vim commandline at the bottom of the screen. -
commandline.icons (default:
true
) The commandline employs Icons to replace/
and?
for searching, which default to on. Setting this tofalse
will remove the search icons when using/
or?
.
The externalised wildmenu replaces the vim default wildmenu, that is the menu that appears when pressing tab for the auto completion of options. It is stylised to look more like the Quick Open and Command Palette drop downs. This is only enabled if the externalised commandline is enabled.
-
wildmenu.mode (default:
true
)
If the externalised wild menu should be enabled or not. Set this tofalse
to revert to the vim default.
Experimental features are in-progress features that are still undergoing development and testing. These features are off by default, in order to maintain stability.
Enable the preview of markdown files on a side panel:
"experimental.markdownPreview.enabled": true
The window is opened by default, to toggle it you can define a keybinding, e.g.:
const activate = (oni) => {
// access the Oni plugin API here
...
oni.input.bind("<f8>", "markdown.togglePreview")
...
};
Oni, by default, integrates with the system clipboard. This is controlled by the editor.clipboard.enabled
option.
The behavior is as follows:
- All
yanks
ordeletes
will be pushed to the system clipboard. - Pressing
<C-c>
on Windows/Linux (<M-c>
on OSX) in visual mode will copy the selected text to the system clipboard. - Pressing
<C-v>
on Windows/Linux (<M-v>
on OSX) in insert mode will paste the text from the system clipboard.
If you have custom behavior or functionality bound to <C-c>
, <C-v>
(or <M-c>
, <M-v>
on OSX), you may wish to disable this behavior by setting editor.clipboard.enabled
to false
.
NOTE: If you have set your
g:clipboard
to includeunnamedplus
you will have to disable this inside ofOni
as this can lead to issues when pasting with new line characters.
Oni features syntax highlighting based on TextMate Grammars. These offer more 'smarts' about the language keywords, versus the out-of-box Vim syntax regions.
There are some settings to control this behavior:
-
editor.textMateHighlighting.enabled (default:
false
)
Set totrue
to turn on textmate highlighting. -
editor.tokenColors - an array of optional overrides, ex:
[{ scope: "variable.object"}, settings: "Identifier" }]
. Currently,settings
must correspond to a Vim highlight group, and scope must correspond to a TextMate scope. This configuration is only used whenexperimental.editor.textMateHighlighting.enabled
istrue
. -
editor.textMateHighlighting.debugScopes (default:
false
) Set totrue
to show scope information for a token. This is helpful when figuring out what to set for thescope
value foreditor.tokenColors
. -
language.[language-name].textMateGrammar This allows you to set a path to a TextMate grammar file for a particular language. This can either be a
string
, in which case it should be the path to the relevant file, or a dictionary of extension to grammar file - for example:"language.javascript.textMateGrammar: { ".js": "~/textmate-grammars/js.tmLanguage.json", ".jsx": "~/textmate-grammars/jsx.tmLanguage.json" }
.
SublimeText also has a great overview of how TextMate scopes work.
You can use the API surface area exposed by the oni
object in your configuration.
The oni
object is exposed in the activate
method, so all calls must be within that method.
const activate = (oni) => {
// access the Oni plugin API here
...
oni.input.bind("<c-enter>", () => oni.recorder.takeScreenshot())
...
};
This binds the <c-enter>
key to run the oni.recorder.takeScreenshot
method, which takes a screenshot of Oni and saves to recorder.outputPath
.
In VimL, the g:gui_oni
variable will be set to 1
, and can be validated with if exists("g:gui_oni")
in VimL.
In addition to the javascript config.js
bindings, you can also access most Oni functionality from your init.vim
, via the OniCommand
function in ex
mode.
An example is:
:call OniCommand('oni.about')