A package for the Atom Editor that allows you to apply multiple syntax themes to your editing session at multiple levels, including by window, by pane, by file type, by file, and by editor.
fig. 1: Screenshot of an Atom editing session with multiple syntax themes.
The Atom editor only allows for a single monolithic theme to be applied across all your tabs, panes, and windows. This is a disappointing, and somewhat surprising fact of life in the Atom ecosystem given its excellent overall customization capabilities. Other editors such as emacs, have long allowed multiple themes to be applied at various levels of granularity (e.g. by window, by file, or file type).
Well no more.
Multi-theme-applicator, in the spirit of the emacs package color-theme-buffer-local , allows you to apply any installed syntax theme, at your chosen level of granularity, to the windows, panes, or editors in your editing session. With multi-theme-applicator, you now have this powerful capability available in Atom, making the best browser in its class that much better.
Experienced developers know that they can easily have dozens of separate files open over a long-lived editing session, with anywhere from 12 to 20 of those files being on the "active" workflow at any one time. Thus being able to visually categorize your work files is essential: decreasing the likelihood of "losing your place", and avoiding costly mistakes like editing the wrong file.
In other words, multi-theme-applicator, is a tool for increasing your workflow efficiency.
Allowing multiple coloring themes allows you to group files, and serves as a visual reminder for what "document-plex" you are currently in (for those who distribute their workload over multiple workspaces).
Additionally, since you don't have to commit to one all-encompassing theme, it allows you to experiment with many more of the outstanding themes available for Atom. So now it becomes no big deal to try out an "exotic" theme such as, say, fairyfloss, since you can restrict it to as small an "area" as a single file.
Allowing editor level theming is also useful when your global themes looks good on one file type, but not so good on others. Having this problem? Simply pick another theme that looks good on the other file type and your problem is solved. No more trying to find that one perfect theme that works across all your file types.
Requires Atom >=1.13.0. Tested on Atom 1.56.0 on Mac and Windows 10.
Install from the Atom control panel as you would for any standard Atom package.
<iframe width="560" height="315" src="https://www.youtube.com/embed/7u0TVjH_C4A" frameborder="0" allowfullscreen></iframe>fig. 2: Multi-Theme Applicator Getting Started video.
When you activate the multi-theme-applicator (MTA) panel with shift-ctrl-v (windows/linux) or shift-cmd-v (mac), you are presented with a list of currently available themes. Select the theme you want and click Apply Local Theme or press Enter. It is not necessary to remove any prior themes before applying a new one. If a theme has already been applied to the current active editor, then that prior theme and scope should be seeded in the dropdown as a reminder to the user, otherwise it will default to the last selected theme with a scope of "file". After applying a theme you should then see the editor update with the new theme. If you select by "file type" then you should see all editors of the filetype update. The panel and theme selection can be entirely controlled with home-row friendly key bindings or via mouse. Having selected a new theme, the dialog will still remain active, allowing you to quickly iterate through and apply several themes until you find just the right one. When you're done, toggle the multi-theme-applicator to close by pressing the escape key, ctrl-shift-v, or clicking the "x" button, and resume working.
Note: MTA only works with syntax themes, not UI themes. UI themes affect the global theme of Atom and thus are not applicable to editor level application.
- We start in a session with three open files across three panes in the default monolithic theme atom-dark.
Note how two of the panes are open on one file and the third pane on another file and how relatively difficult it is to visually distinguish between them:
- We want to apply the humane theme to file 'utils.coffee' that is visually active in the left pane (pane 1), and upper right pane (pane 2), and in a non-selected tab in the lower right pane (pane 3).
While either pane 1 or pane 2 is active, type shift-ctrl-v or shift-cmd-v (or activate the command palette and type 'multi') and activate the MTA modal panel. The modal dialog should come up with keyboard focus:
Note how the syntax theme selected item is a darker color and has a slightly larger border to denote its been selected.
- At this point, press 'ctrl-n' and 'ctrl-p' or the arrow keys to scroll through the list. Alternatively, you can press 'shift-alt-v' to "expand" the full list of themes (Unfortunately, if you expand the themes, ctrl-n and ctrl-p won't work for scrolling and you have to use the arrow keys).
- If you know the theme you want to apply, you can quickly narrow down on it by typing the first letter of the theme. For instance, if I type "d" on my system, the dropdown jumps to "dracula" in the list, allowing me to select it right away. If this is not the "d" theme you had in mind, then you can press ctrl-n and ctrl-p to scroll through its neighbors, or keep pressing the letter to get the next theme that starts with that letter.
Here we type 'h' to quickly locate the humane theme:
4) Hit Enter key, or press the Apply Local Theme button to activate the new theme.
Note 1: The theme was applied at the file level, not the editor level (new feature added in v 0.8.0). All three editors that are opened on file 'utils.cofee' will have the new theme, saving you the hassle of having to apply it three times. Of course, only two editors with the selected file are visible in this current example since the editor in pane 3 is in a tab that is not currently visible. However, if we do activate the file's tab in that pane, it will also have the new theme.
Note 2: Even after the theme is applied the dialog is still active, so you can scroll to another theme, hit Enter again, and apply that theme. This allows you to quickly decide if you like the theme or not, without having to go through the whole selection process again.
Note 3: Observe how much easier it is to distinguish between the files with multi-themes.
- If you like your new theme, toggle the modal dialog off by pressing ctrl-shift-v or escape (or invoke ctrl-shift-p and search for "multi"), or clicking the "x" button. If we switch to pane 3 and activate the hidden tab, you'll see that it too has the new theme. Congratulations, you now have a mixed theme session! Repeat as desired to your other files.
Note: with version 0.9.0, MTA remembers the theme applied to each file. See release notes below for more details.
Screenshot showing all three editors for the selected file successfully themed:
- If you don't like all the different themes and want to return to the default, just press 'ctrl-alt-r' which will refresh Atom (while keeping your pane and file hierarchy) and restore the default theme to every panel i.e. no need to hard cycle (close and re-open) the editor itself.
The following default key bindings are in effect:
shift-ctrl-v : Toggle MTA (mult-theme-applicator) (window/linux)
shift-cmd-v : Toggle MTA (mult-theme-applicator) (Mac)
shift-alt-v: Give MTA dialog keyboard focus (in editor context)
ctrl-n: scroll down through themes
ctrl-p: scroll up through themes
shift-alt-v: expand the theme list (in modal dialog context)
escape: close the MTA dialog (when it has keyboard focus)
You can also close the MTA dialog by clicking the "x" button.
Note 1: 'shift-alt-v' is used twice: once in the editor context, and the other in the modal dialog context.
Note 2: Quite frankly, some of these are kind of tricky key bindings. I have emacs and vim key bindings in effect on Atom, and finding free key bindings is difficult. If you don't have this problem, you can probably make better choices. See note 3 about how to do this.
Note 3: to change the keybindings, edit $HOME/.atom/packages/mult-theme-applicator/multi-theme-applicator.cson, or use the keybindings section of the Settings panel.
- Sticky themes does not work on window, pane, or editor scoped themes.
- Because Atom no longer uses a Shadow DOM, which isolated editor level themes, there can now be "bleed over" between themes. That is to say, some elements of your theme may be overridden by a higher level theme. This is just a property of Cascading Style Sheets.
2022-03-29 - version 2.2.1
-
Add support for theming files that have not yet been saved e.g. when you first open a file and the tab shows "untitled", per this requst.
Note: 2.1.0 download count as 3/29/22 is 3981.
2021-04-19 - version 2.1.0
-
Dynamically seed the theme dropdown with the active theme and scope based on the current active editor. If no prior theme applied, default to the last selected theme and scope of "file".
I added this because I recently added a bunch new themes to my atom and I realized it would be nice if the dropdown had the prior selection and scope because I was unable to recognize the new themes by sight. Really, this is something that should have been in there all along.
-
Fix a bug noticed during testing whereby "cljs" files were being themed with ".js" file upon fileType scope being applied. This might have been my only coffeescript conversion issue. I had to tighten up the regex in utils.getTextEditors.
Note: 1.3.6 download count as 4/19/21 is 3307.
2021-04-16 - version 2.0.0
- Convert from coffeescript to Javascript ES6, using decaffeinate.
- upgrade jquery and a few other package per "npm audit".
In short, kind of a utilitarian update that doesn't really add any new functionality. Just trying to give the package a "little love" after three years of no updates.
2018-02-26 - version 1.3.6
Minor Bug Fixes:
- Upgrade to jquery 3.x as recommended per github "vulnerable dependencies".
- Fix problem:
Form submission failed, as the <SELECT> element named 'selectTheme' was implicitly closed by reaching the end of the file. Please add an explicit end tag ('</SELECT>')
When applying a window level theme on Atom 1.25-beta2 X64.
2017-11-15 - version 1.3.2
Bug Fixes:
- It appears, at least in the beta version of Atom, that Atom now binds 'ctrl-shift-v' to 'paste-without-reformatting' which interferes with MTA's default key binding. This fix unbinds the Atom default binding for 'ctrl-shift-v' so that that the MTA binding again takes precedence.
Note: if you want to restore Atom's default key binding for 'paste-without-reformatting' then edit file '~/.atom/packages/multi-theme-applicator/keymaps/multi-theme-applicator.cson' and delete or comment out the following lines:
"atom-workspace atom-text-editor":
"ctrl-shift-v" : "unset!"
"cmd-shift-v" : "unset!"
Of course, if you do this you will then lose the 'ctrl-shift-v' bindings for MTA. If you want to re-map MTA to a different sequence, edit all references to 'ctrl-shift-v' (Windows) or 'cmd-shift-v' (Mac) in the aforementioned 'multi-theme-applicator.cson' file, or simply edit under Atom via menu selection 'file->settings'.
- Fix a problem whereby MTA crashed when starting against an editor with no actively opened file. Noticed during Mac testing.
2017-09-12 - version 1.3.0
Bix Fixes:
- Reworked theme restoration process
- Fixed problem whereby file type restoration (e.g. a theme applied to all '.html' files) was not working.
- Reduced the amount of redundant application. Now restoration loops through each editor exactly once.
- Improved alt-shift-v "theme expansion" in theme dropdown. Use alt-shift-v to toggle it off.
- Throw an error message when attempting to apply a local theme when no files are open.
- Fix problem with cmd-shift-v (mta toggle) not working on startup on the Macintosh.
2017-07-21 - version 1.2.0
- Fix window and pane level theming.
- Improved clean up when using MTA reset.
2017-04-25 - version 1.1.3
Bug Fix:
- File extension identification was not working properly on filenames with two dots e.g 'app.component.html', causing fileType themeing to not work properly in certain cases. This problem becomes apparent when working on Angular2 projects, which uses a lot of multi-dot-qualified file names.
2017-04-19 - version 1.1.2
Minor bug fixes:
- fix ctrl-n and ctrl-p (scroll through theme list)
- add better error handling for cases where a theme no longer exists
2017-02-08 - version 1.1.0
- New File Type Scope
- allows you to apply a theme by file type e.g. make all currently opened and to-be-opened JavaScript files be one theme, and all .html files be another theme etc.
- Improved reset
- Invoking MTA reset from the command pallet will remove all themes dynamically, without requiring a restart
- This is necessary because the theming can get very convoluted if you're not careful. Sometimes you just want to start from scratch.
- New Refresh Themes command
- Selecting MTA Refresh Themes from the command pallet allows you to dynamically add themes for the main dropdown, without restarting Atom.
2017-02-02 - version 1.0.0
- Atom 1.13 support
- Atom 1.13 removed the shadow DOM which was relied upon by Multi-theme-applicator to achieve its styling. Thus a re-architecting of the styling mechanism was required.
- Scope level theming added.
- The new styling architecture allows for easier theming at different levels of granularity. Thus window, pane, file, and editor level scope was added.
- New Remove Scoped Theme button.
- Allows for finer control over backing off applied themes. This is necessary because there can now be multiple layers of themes applied.
2016-09-03 - version 0.9.0
This release introduces quite a large amount of new functionality. Basically, local theming has been made much more "sticky", and requires less manual intervention and re-application. In short, it's starting to work a lot more like one "would expect", and fixes several edge cases where themes were previously not applied as expected.
- The package now listens on pane events, such as splitting the screen, and will automatically apply the appropriate theme for that file. In other words, you should only have to apply the file theme once, and that theme should show on all editors for that file, across all life-cycle events including adding new editors.
- file level theming is now persisted across atom cyclings i.e. if you close atom completely, and then start it again, once you invoke MTA (shift-ctrl-v) then the local themes you supplied for any open files will be re-themed automatically.
- Added a new command 'mta-reset' to reset the "theme memory", but you should normally not want to use this.
- Fixed a bug on mac where the "apply local theme" button was not driving the appropriate event handler.
2016-06-30 - version 0.8.0
- Added file level theming.
- Added Mac-friendly key binding shift-cmd-v
- Added a little better styling to the modal dialog.
- Updated README to reflect new changes.
2016-06-09 - version 0.7.0
- Improved key binding support
- Modal dialog now comes up with focus -- no need to press alt-shift-v first.
- ESC key now closes the dialog.
- Added close button on modal dialog
2016-05-29 - version 0.6.1
- Initial release.