Skip to content

Introduction

Overleaf provides Vim and Emacs keybindings that can be switched on in the project menu. However, as these keybindings are emulated by the editor (i.e., there is no real Vim or Emacs running), it’s not possible to use Vim’s standard methods of adding new ones within Overleaf using Tampermonkey. Here we show ways that should help overcome this limitation.

Overleaf policy on Tampermonkey and UserScripts

Please be advised that UserScripts and Tampermonkey are not officially supported by Overleaf and that custom scripts can interfere with Overleaf’s normal operations. If you are using such scripts, and need to contact Overleaf for technical support, then we kindly ask you to disable any Tempermonkey scripts and check whether the situation improves. If disabling the scripts does not resolve your issue, please contact us for assistance.

Tampermonkey UserScript

Please note that this is not an officially supported method and the interface may change in the future, hence the “UNSTABLE_editor” naming.

// ==UserScript==
// @name         Overleaf Editor Custom VIM Keybindings
// @namespace    http://tampermonkey.net/
// @version      0.1
// @match        https://www.overleaf.com/project/*
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    window.addEventListener("UNSTABLE_editor:extensions", (event) => {
    const { CodeMirror, CodeMirrorVim, extensions } = event.detail;

    // add custom keybindings - insert mode applies on insert
    CodeMirrorVim.Vim.map("jj", "<Esc>", "insert");
    // normal mode applies while escaped
    CodeMirrorVim.Vim.map("h", "j", "normal");
    });
})();

Overleaf guides

LaTeX Basics

Mathematics

Figures and tables

References and Citations

Languages

Document structure

Formatting

Fonts

Presentations

Commands

Field specific

Class files

Advanced TeX/LaTeX