Skip to content
This repository has been archived by the owner on Apr 9, 2023. It is now read-only.

A simple set of PowerShell scripts to add options to the Windows' context menu from json or xml files.

Notifications You must be signed in to change notification settings

ElianFabian/Windows-ContextMenuManager

Repository files navigation

Windows-ContextMenuManager

A simple set of PowerShell scripts to add options to the Windows' context menu from JSON or XML files.

context-menu

Introduction

We have 2 main scripts: Import-ContextMenuItem.ps1 and Remove-ContextMenuItem.ps1. What they do is to read all the files listed in context-menu-list.txt, they can be single files or folders with files in them, and it allows absolute and relative paths.

As metion these file paths are stored in context-menu-list.txt, it's one path per line, and also allows comments that start with "#" and empty lines.

In case you want to change the default configuration you can do it in settings.ini, it stores the path of the list of paths to read (by default it's context-menu-list.txt), and also as we'll see later you can change the names of the properties in the files as you wish (you could use it to translate them to the language you want).

Finally the BasicSetup.ps1 script, it generates the basic needed files needed for the scripts to work and also generates a JSON and XML template inside the "Source" folder as an example (this repository already includes those generated files). In case you have setup your directory and execute the script it won't override any of your existing scripts with the same name as the generated ones.

There's also the Update-ContextMenuItem.ps1 that first executes Remove and then Import.

How context menus work

This is an example of how to create items and groups with JSON and XML:

JSON

[
    // Group item
    {
        "Key" : "utils",
        "Name" : "Utils",
        "Type" : "File",
        "Extended" : true,
        "Icon" : "an/Arbitrary/Path/image.ico",
        "Options" : [...]
    },
    // Command item
    {
        "Key" : "command_util",
        "Name" : "Command Util",
        "Type" : "File",
        "Icon" : "an/Arbitrary/Path/image.ico",
        "Command" : "powershell.exe -NoExit -Command (Get-Content '%1' -Raw).Length"
    }
]

XML

<Root>
    <ItemGroup
        Key="utils"
        Name="Utils"
        Type="File"
        Icon="an/Arbitrary/Path/image.ico"
        Extended="true">

        <Item ... />
        <Item ... />
        ...
    </ItemGroup>

    <Item
        Key="command_util"
        Name="Command Util"
        Type="File"
        Icon="an/Arbitrary/Path/image.ico"
        Command="powershell.exe -NoExit -Command (Get-Content '%1' -Raw).Length" />
</Root>

We have 2 kind of items in context menus, commands and groups of commands. The first type executes code and the other it's just a container.

All the items in context menus have 3 common properties:

  • Key: it's the way to identify an item in the same level of depth, this is the name stored in the Windows' registry. Avoid changing the key because if you import the context menu items, then change one key and try to remove them it won't work properly.
  • Name: this is the name you will see in the context menu.
  • Icon: it's the icon of the item, it must be a .ico file, you can use an absolute or a relative path.

We have to different first-level items, which are the ones who aren't inside another group, these are kind of special because they have 2 properties subitems can't have:

  • Type: indicates where the context menu items must appear. These are the valid values:

[File, Directory, Desktop, Drive]

  • Extended: if present and set to true you have to hold Shift to make the item visible. Setting the value to false has the same effect as removing the property.
  • Position: if present sets the item position. These are the valid values:

[Top, Bottom]

Lastly there 2 left properties that exclusively belong to either commands or groups:

  • Command: it's a string of code.
  • Options: it's an array of groups and commads (in XML files you add the items as child nodes).

To better undertand the json structure consider checking out this json template: context-menu-items.json.

In here you have the XML template: context-menu-items.xml.

Keep in mind that in XML the tag names are actually arbitrary, if you change the names of Root, Item or ItemGroup tags it will have no effect.

How to use

First, you will probably have to do the following in order to make it work:

  • Run a PowerShell console as administrator and execute this:
Set-ExecutionPolicy -ExecutionPolicy Bypass

In general doing this is not a good idea because you're more exposed in case you try to execute dangerous scripts, but, it's the only way to make this work.

Assuming you've downloaded the repository and you already have your file(s) ready you only have to execute Import-ContextMenuItem.ps1 to import your context menu items. It may take a few seconds to import it, you will know it finished when the empty console window closes automatically. When you want to remove the context menu just execute Remove-ContextMenuItem.ps1. Removing it's faster than importing.

In case your file has a wrong format or even inappropriate keys or values it will stop executing and shows you what's the error and the specific file (remember you can work with more than one file). In order to see the error you should set CONSOLE_NO_EXIT to true in settings.ini to avoid autoclosing the console.

Extra

I want to mention that I may be missing some features of the context menu items because of my lack of knowledge on this topic, but probably I will be adding more features when learning more or in case someone wants to give any idea.

In case you want to know what is the manual way of adding context menu items check these articles:

About

A simple set of PowerShell scripts to add options to the Windows' context menu from json or xml files.

Topics

Resources

Stars

Watchers

Forks