Skip to content

XiLaiTL/vscode-toolbar

Repository files navigation

toolbar README

Until a day, I no longer wanted to remember those complicated keyboard shortcuts. With one hand on the mouse, the remaining hand on the keyboard was not enough for me to press Ctrl+Shift+P.

☝️中文介绍

icon

Catalog

Features

As the name suggests, it adds a toolbar to VSCode.

  • Floating Toolbar: Adds a toolbar to the floating window for the specified language. Floating Toolbar
  • Toolbar Panel: Exists as a View, which can be placed in the sidebar, panel, or any other location within the editor interface. It adds a button to the upper right corner of the editor for the specified language to open the toolbar interface. Sidebar Switch View Editor Panels

Provide Highly Customizable Toolboxes, Toolbars and Tools

You can customize toolboxes, toolbox layers, tools, and actions.

The extension provides 9 View positions for customization (Views are interfaces in VSCode that can be freely moved and rearranged). Each View can have multiple toolboxes, and each toolbox is composed of multiple toolbox layers (a toolbox layer is equivalent to a row of buttons). Each toolbox layer can have multiple tools (buttons), and when a tool is clicked, it can trigger a series of actions.

You can customize three types of actions: executing VSCode commands, finding and replacing selected text blocks, and executing a piece of code on the selected text block (TODO).

Tutorials and examples for customizing toolbars: At the end of the article

Built-in Markdown Toolbox

The extension provide the built-in toolboxes, containing 38 tools for dealing markdown text.

Toolboxes

Markdown Toolbox

Toolbox Layer
Formatting Toggle Bold Toggle Italic Toggle Strikethrough Toggle Code Span Toggle Math Span Increase Header Level Decrease Header Level
Blocks Toggle Container Bloc Toggle Detail Block Toggle Quote Block Toggle Code Block Toggle Math Block Insert Divider Insert New Line
Links Insert Link Insert Image Insert Link Reference Insert Footnotes Insert Path Delete Link
Lists Toggle Order List Toggle Unorder List Toggle Check List Create Content List Indent Outdent

(The actions of Create Content List, Indent and Outdent are denpendent on other extensions)

Markdown Table Toolbox (denpendent on other extensions)

Toolbox Layer
Cell Previous Cell Next Cell Create Table CSV To Table
Column Move Left Move Right Insert Left Insert Right
Formatting Align Left Align Right Align Center Format

Requirements

You can optionally install the following plugins, as some features in the built-in toolbox rely on them:

  • Markdown All in One : Provides list header indentation and table of contents creation features.
  • Markdown Table : Enables Markdown Table toolbox for table creation and formatting.
  • Markdown Table Maker : Adds table creation functionality to the Markdown Table toolbox.

Suggestions

  • macros : You can customize the command by combine the existed commands.

Extension Settings

  • toolbar.hover.languages: Languages support of the hover tooltip (when selecting text in the corresponding language editor, a tooltip will appear)
  • toolbar.panel.languages: Languages support of the additional panel (will add a button to the right top of the corresponding language editor to open the additional panel)
  • toolbar.actions: Actions of the tool
  • toolbar.toolboxs: Toolboxes
  • toolbar.builtin.markdown.activate: Whether to activate the built-in Markdown toolbox
  • toolbar.builtin.markdown.unorderListStyle: Set the style of the built-in Markdown toolbox's unordered list, optional values are -, + and *; default value is +
  • toolbar.builtin.markdown.orderListStyle: Set the style of the built-in Markdown toolbox's ordered list, optional values are 1) and 1. ; default value is 1.

Known Issues

haven't

Todo List

  • Add custom button in status bar
  • Add custom button in editor menu, like this which change the package.json to modify
  • Add preview in hover tooltip
  • Add input and output command, input can transfer to next action ( or collect as context) if a function has more than one params and more than one result, it can just turn to be combination of input and output. like: (selectionText, input1, input2)=>{ return [replaceholder,output1,output2] }
  • Add list view for changing buttons
  • Split the replace action into 3 commands: togglePrefix, toggleSuffix and replace. And change action into vscode object {"when":"","command":"", "args":{}}. Change the activate into {"postion":[]} and activate.language into when clause context.

Custom Toolbox

This extension toolbox is designed with four levels:

  1. View: A freely movable interface in VS Code, such as the Explorer in the sidebar. This extension comes with nine built-in Views for use in the toolbox, named after the names of the planets in our solar system:

    "markdown", "mercury", "venus", "terra", "mars", "jupiter", "saturn", "uranus", "neptune"

  2. Toolbox: The toolbox is composed of multiple Toolbox layers. The toolbox is the most basic part within a View, and a View can contain multiple toolboxes.
  3. Toolbox layer: The toolbox is divided into multiple Toolbox layers by rows. Each Toolbox layer is composed of various tools.
  4. Tool: Tools are displayed as buttons on the interface and are the most basic action combinations.

Basic Toolbox

There are two options:

  1. Copy the following content to the settings.json file:
"toolbar.toolboxs": [
  {
    "name": "My Box",
    "activate": true,
    "view": "mars",
    "layers": [
      {
        "name": "My Layer",
        "icon": "person",
        "tools": [
          {
            "name": "Open Extensions Folder",
            "icon": "folder-library",
            "actions": ["workbench.extensions.action.openExtensionsFolder"]
          }
        ]
      }
    ]
  }
],
  1. Go to Settings -> Extensions -> Toolbar -> Toolbar:Toolboxs and hit Edit in settings.json. In this case, the Markdown Table Box code will automatically be inserted in addition to the My Box code.

359906724-bccd8397-a071-4a33-8a40-d6b66d9c679e

Then click on the "View -> Open View -> Mars Toolbar" button on the top of VSCode, and you will see a button appear on the side bar.

The action defined for this tool is to execute the VSCode command: workbench.extensions.action.openExtensionsFolder, which means to open the extensions folder.

Toolbox

In the settings.json file, the toolbox list is defined by "toolbar.toolboxs".

"toolbar.toolboxs": [ // This is the list of toolboxes, where each object in the list represents a toolbox.  
  {  
    // The name of the toolbox, which will be displayed as the title.  
    "name": "My Box",   
  
    // The view displayed by the toolbox, which can only be one of the following specific views. If there are multiple toolboxes on an view, they will share the same view.  
    // "markdown", "mercury", "venus", "terra", "mars", "jupiter", "saturn", "uranus", "neptune"  
    "view": "mars",   
  
    // The activation status, which can be a boolean value or an object with properties {"languages":[], "hover":false}.  
    "activate": true,   
  
    // The toolbar, displayed as a row within the toolbox.  
    "layers": [],   
  }  
]

Activation Status

Activation status is used in toolboxes, toolbox layers, and tools. The value that can be entered is a boolean or an object.

// When set to true, activation is consistent with the activation status of the parent.  
"activate": true  
  
// When set to false, it is always inactive.  
"activate": false  
  
"activate":{  
  
  // When the opened text is in one of the specified languages, activate.  
  "languages":[  
    // Language ID, e.g., "markdown".  
    "markdown"  
  ],  
  
  // Optional, whether to display in the tooltip.  
  "hover":true  
}

Tooltip

To make the tooltip appear when working with code in one or another language, the user should perform the following sequence of actions:

  1. The main first step to determine under which languages the tooltip will appear at all is to go to Settings -> Extensions -> Toolbar -> Hover:Languages and add the desired Language ID, for example markdown, json, jsonc, javascript etc .
  2. The second step to control the presence of a particular toolbox in the tooltip when working with the corresponding language is to insert or modify the following code in the settings.json file when defining the appropriate toolbox.
      "activate": {
        "languages": ["markdown"],
        "hover": false // whether to display in the tooltip (true) or not (false)
      }

If there are many languages, then it is necessary to insert them all into the "activate" field.

E.g. toolbar.hover.languages(Settings -> Extensions -> Toolbar -> Hover:Languages) is set to ["markdown", "json", "jsonc", "javascript"]. If the user wants the tooltip for the MyBox toolbox appears only in the json, jsonc files, then they need to add the following lines into the settings.json when defining MyBox.

      "activate": {
        "languages": ["markdown","javascript"],
        "hover": false
      }

or

      "activate": {
        "languages": ["json","jsonc"],
        "hover": true
      }

In this case, both statements are equal.

Toolbar

Defined in the "layers" list within a toolbox object.

Supported icon names can be found in the Icon Reference.

"layers":[
  {
    // Toolbox layer name  
    "name": "",  
      
    // Optional, icon name. Enter a supported icon name from https://code.visualstudio.com/api/references/icons-in-labels.  
    // If no suitable icon is found, use a string starting with "$" as the name, e.g., "$∑". It is recommended not to exceed 3 characters.  
    "icon": "person",  
      
    // Optional, toolbox layer description. It will be displayed when the mouse hovers over the toolbox layer. If left blank, the toolbox layer's name will be displayed instead.  
    "description": "",  
      
    // Optional, activation status. It can be a boolean value or an object {"languages":[], "hover":false}.  
    "activate": true,  

    //Tools, appear as buttons in the toolbox layer  
    "tools":[],
  }
]

Tool

Defined in the "tools" list within a toolbar object.

"tools": [
  {
    // Tool name  
    "name": "",  
      
    // Optional, icon name. Enter a supported icon name from https://code.visualstudio.com/api/references/icons-in-labels.  
    // If no suitable icon is found, use a string starting with "$" as the name, e.g., "$∑". It is recommended not to exceed 3 characters.  
    "icon": "person",  
      
    // Optional, tool description. It will be displayed when the mouse hovers over the tool. If left blank, the tool's name will be displayed instead.  
    "description": "",  
      
    // Optional, activation status. It can be a boolean value or an object {"languages":[], "hover":false}.  
    "activate": true,  
      
    // Actions of the tool. A tool can have multiple actions executed in sequence.  
    "actions": []
  }
]

Action

Tool actions support three types: executing a VSCode command, performing a find and replace operation on selected text blocks, and executing a piece of code on selected text blocks (TODO).

Actions are defined in the "actions" list within a tool object.

Supports input of a string, or a "Command Action" object, or a "Replace Action" object.

"actions":[
  // String, you can type a VS Code command or a defined action name
  "workbench.extensions.action.openExtensionsFolder",

  // "Command Action" object
  {
    // Specify the action type as "Command Action"
    "mode": "command",

    // VS Code command specified by "Command Action"
    "command": "",

    // Optional, command arguments for "Command Action", which can be string, number, boolean, array, or object
    "argument": {}
  },

  // "Replace Action" object
  {
    // Specify the action type as "Replace Action"
    "mode": "replace",

    // Optional, argument for "Replace Action", which can be a string that replaces the selected text with this string
    "argument": "",

    // Optional, argument for "Replace Action", which can be an object with three properties: "start", "end", and "self": {"regex", "with"}
    "argument": {
      // Optional, add or delete this string to the front of the selected text
      "start": "`",
      // Optional, add or delete this string to the back of the selected text
      "end": "`",
      // Optional, processing of the selected text, which can be a string (direct replacement)
      "self": "replacement",
      // Optional, processing of the selected text, which can be an object with two properties: "regex" and "with" (regular expression matching)
      "self": {
        // Regular expression used to match the selected text, where parentheses () can be used to delimit the text to be retained
        "regex": "\"(.+)\"",

        // String used to replace the selected text, where $1~$9 are used to mark the position of the retained text
        "with": "$1"
      }
    }
  }
]

Predefined Action Names:

Markdown: Toggle Bold
Markdown: Toggle Italic
Markdown: Toggle Strikethrough
Markdown: Toggle Math Span
Markdown: Toggle Math Block
Markdown: Toggle Code Span
Markdown: Toggle Code Block
Markdown: Toggle Container Block
Markdown: Toggle Detail Block
Markdown: Toggle Quote Block
Markdown: Insert Link
Markdown: Insert Image
Markdown: Insert Link Reference
Markdown: Insert Footnotes
Markdown: Insert Path
Markdown: Delete Link
Markdown: Increase Header Level
Markdown: Decrease Header Level
Markdown: Insert Divider
Markdown: Insert New Line
Markdown: Toggle Order List
Markdown: Toggle Unorder List
Markdown: Toggle Check List

Multiple Tools Using the Same Action

In the settings.json, actions can be defined under "toolbar.actions", which are able to be referenced . The actions defined here need to include the "name" property. And then write the preset "name" value inside the list of a tool "actions": [].

Example: Here are both buttons referencing the "toggle-bold" action.

"toolbar.actions": [
  {
    //Name of the action to referenced in tool
    "name": "toggle-bold",
    "mode": "command",
    "argument": "Markdown: Toggle Bold",
    "command": "toolbar.toggle",
  }
],
"toolbar.toolboxs": [
  {
    "name": "My Box",
    "activate": true,
    "view": "mars",
    "layers": [
      {
        "name": "My Layer",
        "icon": "person",
        "tools": [
          {
            "name": "Toggle Bold",
            "icon": "bold",
            "actions": ["toggle-bold"]
          },
          {
            "name": "Toggle Bold After Open Extensions Folder",
            "icon": "folder-library",
            "actions": ["workbench.extensions.action.openExtensionsFolder","toggle-bold"]
          }
        ]
      },
    ]
  }
],

Thanks

Spark:

Tools:

About

VSCode Extension. Add custom buttons instead of commands. Markdown toolbar is built-in.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published