Overleaf Editor Custom VIM Keybindings

Bind fd to <esc> in overleaf

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @description  Bind fd to <esc> in overleaf
// @name         Overleaf Editor Custom VIM Keybindings
// @namespace    overleaf_spacemacs
// @version      1
// @match        https://www.overleaf.com/*
// @grant        GM_addStyle
// ==/UserScript==
 
(function() {
    // poll until editor is loaded
    const retry = setInterval(() => {
      	console.log("Retry")
      	console.log(window.wikiEnabled)
        if (unsafeWindow._debug_editors === undefined) return
      	clearInterval(retry)
        // get current editor instance
        const editor = unsafeWindow._debug_editors[0]
        // vim keyboard plugin
        const vimKeyboard = unsafeWindow.ace.require("ace/keyboard/vim")
        // add custom keybindings - insert mode applies on insert
        vimKeyboard.Vim.map("fd", "<Esc>", "insert")
        // set the modified keyboard handler for editor
        editor.setKeyboardHandler(vimKeyboard.handler)
        console.log("Custom key bindings applied")
    }, 1000)
})();