Skip to content

Latest commit

 

History

History
221 lines (164 loc) · 5.94 KB

README.md

File metadata and controls

221 lines (164 loc) · 5.94 KB

Sidebery

https://addons.mozilla.org/en-US/firefox/addon/sidebery/

About

Sidebery provides the list of tabs structured in a tree and bookmarks within the customizable panels. It aims to be fast, beautiful* and configurable. Some of the key features:

Vertical tabs layout (flat or tree)

You can use a simple flat list of tabs or tree structure. Tree layout allows you to fold sub-tries, creates groups with a custom name to organize open pages.

Bookmarks panel

Simple catalogs of your bookmarks. You can drag and drop links or tabs to create bookmarks and vice-versa. Basic operations: open in new window / sort / create / edit / delete.

Other bookmarks features:

  • Automatically delete an open bookmark from "Other Bookmarks" folder.
  • Highlight open bookmarks and activate its tab instead of opening new on clicking.

Tabs panels

Configurable panels will help you sort your tabs.

Containers management

You can set "Include" and "Exclude" url-rules, proxy config and UserAgent header for each container.

Customizable context menu

Sidebery allows you to change the context menu for tabs and bookmarks. You can enable/disable/move different options, create sub-menus/separators.

Multi-selection with right mouse button or keyboard shortcuts

You can select multiple tabs or bookmarks only with the mouse - push right mouse button and then move the cursor to adjust selection range.
note: This feature is not working with the native context menu.

Also, you can use ctrl+click/shift+click method or use keyboard shortcuts.

Customizable styles

Sidebery provides full control of styles for sidebar and group page via variables and custom CSS.

NOTE: To get currently available css-selectors use debugger:

  • Enter "about:debugging" in the URL bar
  • In the left-hand menu, click This Firefox (or This Nightly)
  • Click Inspect next to Sidebery extension
  • Select frame to inspect
    • Click on the rectangular icon (with three sections) in top-right area of the debugger page
    • Select "/sidebar/index.html" for sidebar frame
    • Select "/group/group.html" for group page frame
  • Browse "Inspector" tab

Snapshots

You can setup auto snapshots that will keep info about open windows and tabs.


Usage

Open sidebery
Shortcut ctrl+E (default) or click on Sidebery button.

Create new tab
ctrl+T - In default container.
ctrl+space - In active panel.
ctrl+shift+space - after active tab.
Also "Middle click on panel", "Left click on panel's icon" and other configurable methods...

Switching between panels
alt+Comma(<) - to previous panel
alt+Period(>) - to next panel
Scroll on navigation strip - (optional)
Horizontal scroll - (optional)

Switching between tabs
ctrl+PgUp/PgDown - firefox's defaults
alt+Up/Down + alt+space - select tab and activate it
Scroll - (optional)

Expand/Fold parent tab
Click on favicon of target tab.

Expand/Fold tabs or bookmarks while dragging elements
Move mouse cursor to pointer's triangle.

Select all descendants of tab
Right click on favicon.

Close whole tabs branch
Right click on close button.

Switch panel while dragging elements
Move mouse cursor to panel's icon.


Tips and Tricks

userChrome.css

Note: Starting with Firefox 69 you have to enable toolkit.legacyUserProfileCustomizations.stylesheets in about:config.

In 'Profile Directory' (Menu > Help > Troubleshooting Information > Profile Directory) create folder chrome with file userChrome.css:

@namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul");

/* ...your css here... */

To find and inspect browser's selectors open Browser Toolbox.

Completely hide tabs strip

#TabsToolbar {
  display: none;
}

Hide tabs strip only in fullscreen

#TabsToolbar[inFullscreen="true"] {
  display: none;
}

Hide sidebar top-menu

#sidebar-header {
  display: none;
}

Dynamic sidebar
Thanks @ongots

  • Set navigation button width to 30px (Settings/Styles/Navigation Strip)
  • Set width of pinned tabs to 30px (Settings/Styles/Sidebar css):
    .PinnedTab {
      width: 30px;
    }
  • Add in userChrome.css
    #sidebar-header {
      display: none;
    }
    #sidebar-splitter {
      width: 0 !important;
    }
    #main-window #appcontent {
      margin-left: 30px
    }
    #main-window #sidebar-box {
      position: fixed;
      display: block;
      min-width: 0px !important;
      max-width: none !important;
      width: 30px !important;
      height: calc(100% - 61px); /* 61px - height of #navigator-toolbox */
      overflow: hidden;
      box-shadow: 0 0 8px 0 #00000064, 1px 0 0 0 #212121;
      transition: all 0.12s;
    }
    #main-window #sidebar {
      position: absolute;
      min-width: 0px !important;
      max-width: none !important;
      left: 0;
      top: 0;
      right: auto;
      bottom: auto;
      width: 30px;
      height: 100%;
    }
    
    /* Completely (almost) hide in fullscreen */
    #main-window[inFullscreen] #appcontent {
      margin-left: 1px
    }
    #main-window[inFullscreen] #sidebar-box,
    #main-window[inFullscreen] #sidebar {
      width: 1px !important;
    }
    
    /* Show on hover */
    #main-window #sidebar-box:hover,
    #main-window[inFullscreen] #sidebar-box:hover,
    #main-window #sidebar-box:hover #sidebar,
    #main-window[inFullscreen] #sidebar-box:hover #sidebar {
      height: 100% !important;
      width: 250px !important;
    }
    #main-window #sidebar-box:hover #sidebar:before {
      transform: translateX(-100%);
    }

Build

Framework: Vue
Bundler: Parcel
Tests: Jest

Install dependencies: npm install
Build all parts of addon: npm run build
Create addon archive in ./dist: npm run build.ext


Licence

MIT