Skip to content

lucio-cornejo/custom-pluto

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

50 Commits
 
 
 
 

Repository files navigation

custom-pluto

Customize Julia's Pluto notebook's stlye and keyboard shortcuts.

Motivation

fonsp/Pluto.jl#65 (comment)

Implementation

  • Tutorial for how to implement the Pluto changes from this project into your own Pluto notebooks.

  • For the Pluto changes implemented in this project, to be preserved into the exported HTML file(s) of your Pluto notebook, rather than following the tutorial, execute this code in any cell of your Pluto notebook:

html"""
<script
  src="https://cdn.jsdelivr.net/gh/lucio-cornejo/custom-pluto/custom-Pluto.js">
</script>
"""

New commands

  • Toggle light/dark mode:
    Added a button in Pluto notebook page.

  • Wrap in begin ... end: TBD
    Implemented shortcut: Ctrl+Alt+B

  • Wrap in let ... end: TBD
    Implemented shortcut: Ctrl+Alt+L

  • Wrap in with_terminal() do ... end:
    Implemented shortcut: Ctrl+Alt+T

  • Wrap in md""" ... """
    Implemented shortcut: Ctrl+Alt+M

  • Toggle every markdown cell's code visibility:
    Implemented shortcut: Alt+M

  • Toggle cell's input visibilty:
    Implemented shortcut: Alt+V (Non VS Code)

  • Toggle live documentation:
    Implemented shortcut: Ctrl+Alt+D (Non VS Code?)

  • Split cell:
    Implemented shortcut: Ctrl+Alt+S (Non VS Code?)

  • Add cell above:
    Implemented shortcut: Ctrl+Shift+Enter (VS Code)

  • Add cell without running:
    Implemented shortcut: Alt+Enter (Non VS Code)

  • Move cell(s) up/down: Ctrl+Up and Ctrl+Down
    Suggested shortcut: Alt+PageUp and Alt+PageDown

    The following code seemed promising, but failed. Code cell swaping occurs, but after interacting with the notebook, the cells are

    // Alt+PageUp
    const cellCode = getPlutoCell(getSelection().anchorNode)
    cellCode.previousElementSibling.before(cellCode)
    // Alt+PageDown
    const cellCode = getPlutoCell(getSelection().anchorNode)
    cellCode.nextElementSibling.after(cellCode)
    
    function getPlutoCell(el) {
      try {
        if (el.tagName !== "PLUTO-CELL") {
          return getPlutoCell(el.parentElement);
        }
        return el;
      } catch (e) { }
    }

Recommendation

  • The code which enables this Pluto customization is inserted into the Pluto notebook via Tampermonkey.

  • You can set custom keyboard shortcuts using the following JavaScript function:

    keysAction(
      keydownEvent,  // event when some key is pressed
      keys,          // Arrays of elemets of keys combination
      firstLine,    // Custom String
      lastLine      // Custom String
    )

    For example:

    /*
      Insert "begin ... end" code in Pluto cell
      Keyboard shortcut: Ctrl+Alt+B
    */
    keysAction(evt, ["Control", "Alt", "b"], "begin", "end");

    Such code must be inserted in the appropriate context ... a complete example can be found here.

    You can get the keyPressed.key value of the key you want to use via executing the following code in your browser console (press Ctrl+Shift+J to open it):

    document.addEventListener("keydown", 
      (evt) => console.log(`keyPressed.key: ${evt.key}`)
    );
  • Due to the tedious process of mapping custom keyboard shortcuts (from VS Code, Atom, Vim or whatever) to Pluto, a partial solution may be to run Pluto via:

    import Pluto
    Pluto.run(auto_reload_from_file=true)

    This way, changes in the .jl file associated to the Pluto notebook will be applied to the notebook itself.

    Therefore, custom keyboard shortcuts can be used via opening the .jl file in some prefered editor, and the notebook will be updated accordingly.

About

Customize Julia's Pluto notebook's style and keyboard shortcuts.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published