added support for pinning/unpinning tabs
features: * pin tab * unpin tab * toggle pin/unpin tab
This commit is contained in:
		
							parent
							
								
									b3b017a123
								
							
						
					
					
						commit
						c2d2f895a5
					
				
					 5 changed files with 24 additions and 1 deletions
				
			
		|  | @ -35,6 +35,7 @@ The default mappings are as follows: | |||
| - <kbd>g0</kbd>, <kbd>g$</kbd>: select first or last tab | ||||
| - <kbd>r</kbd>: reload current tab | ||||
| - <kbd>R</kbd>: reload current tab without cache | ||||
| - <kbd>p</kbd>: toggle pin/unpin current tab | ||||
| 
 | ||||
| ### Navigation | ||||
| - <kbd>f</kbd>: start following links in the page | ||||
|  |  | |||
|  | @ -26,6 +26,12 @@ const exec = (operation, tab) => { | |||
|     return tabs.selectLastTab(); | ||||
|   case operations.TAB_RELOAD: | ||||
|     return tabs.reload(tab, operation.cache); | ||||
|   case operations.TAB_PIN: | ||||
|     return tabs.updateTabPinned(tab, true); | ||||
|   case operations.TAB_UNPIN: | ||||
|     return tabs.updateTabPinned(tab, false); | ||||
|   case operations.TAB_TOGGLE_PINNED: | ||||
|     return tabs.updateTabPinned(tab); | ||||
|   case operations.ZOOM_IN: | ||||
|     return zooms.zoomIn(); | ||||
|   case operations.ZOOM_OUT: | ||||
|  |  | |||
|  | @ -100,7 +100,19 @@ const reload = (current, cache) => { | |||
|   ); | ||||
| }; | ||||
| 
 | ||||
| const updateTabPinned = (current, pinned) => { | ||||
|   return browser.tabs.query({ currentWindow: true, active: true }) | ||||
|     .then(() => { | ||||
|       let newPinned = pinned; | ||||
|       if (newPinned !== true && newPinned !== false) { | ||||
|         newPinned = !current.pinned; | ||||
|       } | ||||
|       return browser.tabs.update(current.id, { pinned: newPinned }); | ||||
|     }); | ||||
| }; | ||||
| 
 | ||||
| export { | ||||
|   closeTab, reopenTab, selectAt, selectByKeyword, getCompletions, | ||||
|   selectPrevTab, selectNextTab, selectFirstTab, selectLastTab, reload | ||||
|   selectPrevTab, selectNextTab, selectFirstTab, selectLastTab, reload, | ||||
|   updateTabPinned | ||||
| }; | ||||
|  |  | |||
|  | @ -32,6 +32,7 @@ export default { | |||
|     "g$": { "type": "tabs.last" }, | ||||
|     "r": { "type": "tabs.reload", "cache": false }, | ||||
|     "R": { "type": "tabs.reload", "cache": true }, | ||||
|     "p": { "type": "tabs.pin.toggle" }, | ||||
|     "zi": { "type": "zoom.in" }, | ||||
|     "zo": { "type": "zoom.out" }, | ||||
|     "zz": { "type": "zoom.neutral" }, | ||||
|  |  | |||
|  | @ -39,6 +39,9 @@ export default { | |||
|   TAB_FIRST: 'tabs.first', | ||||
|   TAB_LAST: 'tabs.last', | ||||
|   TAB_RELOAD: 'tabs.reload', | ||||
|   TAB_PIN: 'tabs.pin', | ||||
|   TAB_UNPIN: 'tabs.unpin', | ||||
|   TAB_TOGGLE_PINNED: 'tabs.pin.toggle', | ||||
| 
 | ||||
|   // Zooms
 | ||||
|   ZOOM_IN: 'zoom.in', | ||||
|  |  | |||
		Reference in a new issue