parent
828ac8cd84
commit
c5c08783d2
4 changed files with 116 additions and 97 deletions
@ -1,92 +0,0 @@ |
|||||||
import operations from 'shared/operations'; |
|
||||||
import messages from 'shared/messages'; |
|
||||||
import * as tabs from 'background/tabs'; |
|
||||||
import * as zooms from 'background/zooms'; |
|
||||||
|
|
||||||
const sendConsoleShowCommand = (tab, command) => { |
|
||||||
return browser.tabs.sendMessage(tab.id, { |
|
||||||
type: messages.CONSOLE_SHOW_COMMAND, |
|
||||||
command, |
|
||||||
}); |
|
||||||
}; |
|
||||||
|
|
||||||
// This switch statement is only gonna get longer as more
|
|
||||||
// features are added, so disable complexity check
|
|
||||||
/* eslint-disable complexity */ |
|
||||||
const exec = (operation, tab) => { |
|
||||||
switch (operation.type) { |
|
||||||
case operations.TAB_CLOSE: |
|
||||||
return tabs.closeTab(tab.id); |
|
||||||
case operations.TAB_CLOSE_FORCE: |
|
||||||
return tabs.closeTabForce(tab.id); |
|
||||||
case operations.TAB_REOPEN: |
|
||||||
return tabs.reopenTab(); |
|
||||||
case operations.TAB_PREV: |
|
||||||
return tabs.selectPrevTab(tab.index, operation.count); |
|
||||||
case operations.TAB_NEXT: |
|
||||||
return tabs.selectNextTab(tab.index, operation.count); |
|
||||||
case operations.TAB_FIRST: |
|
||||||
return tabs.selectFirstTab(); |
|
||||||
case operations.TAB_LAST: |
|
||||||
return tabs.selectLastTab(); |
|
||||||
case operations.TAB_PREV_SEL: |
|
||||||
return tabs.selectPrevSelTab(); |
|
||||||
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.toggleTabPinned(tab); |
|
||||||
case operations.TAB_DUPLICATE: |
|
||||||
return tabs.duplicate(tab.id); |
|
||||||
case operations.ZOOM_IN: |
|
||||||
return zooms.zoomIn(); |
|
||||||
case operations.ZOOM_OUT: |
|
||||||
return zooms.zoomOut(); |
|
||||||
case operations.ZOOM_NEUTRAL: |
|
||||||
return zooms.neutral(); |
|
||||||
case operations.COMMAND_SHOW: |
|
||||||
return sendConsoleShowCommand(tab, ''); |
|
||||||
case operations.COMMAND_SHOW_OPEN: |
|
||||||
if (operation.alter) { |
|
||||||
// alter url
|
|
||||||
return sendConsoleShowCommand(tab, 'open ' + tab.url); |
|
||||||
} |
|
||||||
return sendConsoleShowCommand(tab, 'open '); |
|
||||||
case operations.COMMAND_SHOW_TABOPEN: |
|
||||||
if (operation.alter) { |
|
||||||
// alter url
|
|
||||||
return sendConsoleShowCommand(tab, 'tabopen ' + tab.url); |
|
||||||
} |
|
||||||
return sendConsoleShowCommand(tab, 'tabopen '); |
|
||||||
case operations.COMMAND_SHOW_WINOPEN: |
|
||||||
if (operation.alter) { |
|
||||||
// alter url
|
|
||||||
return sendConsoleShowCommand(tab, 'winopen ' + tab.url); |
|
||||||
} |
|
||||||
return sendConsoleShowCommand(tab, 'winopen '); |
|
||||||
case operations.COMMAND_SHOW_BUFFER: |
|
||||||
return sendConsoleShowCommand(tab, 'buffer '); |
|
||||||
case operations.FIND_START: |
|
||||||
return browser.tabs.sendMessage(tab.id, { |
|
||||||
type: messages.CONSOLE_SHOW_FIND |
|
||||||
}); |
|
||||||
case operations.CANCEL: |
|
||||||
return browser.tabs.sendMessage(tab.id, { |
|
||||||
type: messages.CONSOLE_HIDE, |
|
||||||
}); |
|
||||||
case operations.PAGE_SOURCE: |
|
||||||
return browser.tabs.create({ |
|
||||||
url: 'view-source:' + tab.url, |
|
||||||
index: tab.index + 1, |
|
||||||
openerTabId: tab.id, |
|
||||||
}); |
|
||||||
default: |
|
||||||
return Promise.resolve(); |
|
||||||
} |
|
||||||
}; |
|
||||||
/* eslint-enable complexity */ |
|
||||||
|
|
||||||
export { exec }; |
|
@ -0,0 +1,113 @@ |
|||||||
|
import messages from 'shared/messages'; |
||||||
|
import operations from 'shared/operations'; |
||||||
|
import * as tabs from 'background/tabs'; |
||||||
|
import * as zooms from 'background/zooms'; |
||||||
|
|
||||||
|
export default class BackgroundComponent { |
||||||
|
constructor(store) { |
||||||
|
this.store = store; |
||||||
|
|
||||||
|
browser.runtime.onMessage.addListener((message, sender) => { |
||||||
|
try { |
||||||
|
return this.onMessage(message, sender); |
||||||
|
} catch (e) { |
||||||
|
return browser.tabs.sendMessage(sender.tab.id, { |
||||||
|
type: messages.CONSOLE_SHOW_ERROR, |
||||||
|
text: e.message, |
||||||
|
}); |
||||||
|
} |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
|
onMessage(message, sender) { |
||||||
|
switch (message.type) { |
||||||
|
case messages.BACKGROUND_OPERATION: |
||||||
|
return this.store.dispatch( |
||||||
|
this.exec(message.operation, sender.tab), |
||||||
|
sender); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// eslint-disable-next-line complexity
|
||||||
|
exec(operation, tab) { |
||||||
|
switch (operation.type) { |
||||||
|
case operations.TAB_CLOSE: |
||||||
|
return tabs.closeTab(tab.id); |
||||||
|
case operations.TAB_CLOSE_FORCE: |
||||||
|
return tabs.closeTabForce(tab.id); |
||||||
|
case operations.TAB_REOPEN: |
||||||
|
return tabs.reopenTab(); |
||||||
|
case operations.TAB_PREV: |
||||||
|
return tabs.selectPrevTab(tab.index, operation.count); |
||||||
|
case operations.TAB_NEXT: |
||||||
|
return tabs.selectNextTab(tab.index, operation.count); |
||||||
|
case operations.TAB_FIRST: |
||||||
|
return tabs.selectFirstTab(); |
||||||
|
case operations.TAB_LAST: |
||||||
|
return tabs.selectLastTab(); |
||||||
|
case operations.TAB_PREV_SEL: |
||||||
|
return tabs.selectPrevSelTab(); |
||||||
|
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.toggleTabPinned(tab); |
||||||
|
case operations.TAB_DUPLICATE: |
||||||
|
return tabs.duplicate(tab.id); |
||||||
|
case operations.ZOOM_IN: |
||||||
|
return zooms.zoomIn(); |
||||||
|
case operations.ZOOM_OUT: |
||||||
|
return zooms.zoomOut(); |
||||||
|
case operations.ZOOM_NEUTRAL: |
||||||
|
return zooms.neutral(); |
||||||
|
case operations.COMMAND_SHOW: |
||||||
|
return this.sendConsoleShowCommand(tab, ''); |
||||||
|
case operations.COMMAND_SHOW_OPEN: |
||||||
|
if (operation.alter) { |
||||||
|
// alter url
|
||||||
|
return this.sendConsoleShowCommand(tab, 'open ' + tab.url); |
||||||
|
} |
||||||
|
return this.sendConsoleShowCommand(tab, 'open '); |
||||||
|
case operations.COMMAND_SHOW_TABOPEN: |
||||||
|
if (operation.alter) { |
||||||
|
// alter url
|
||||||
|
return this.sendConsoleShowCommand(tab, 'tabopen ' + tab.url); |
||||||
|
} |
||||||
|
return this.sendConsoleShowCommand(tab, 'tabopen '); |
||||||
|
case operations.COMMAND_SHOW_WINOPEN: |
||||||
|
if (operation.alter) { |
||||||
|
// alter url
|
||||||
|
return this.sendConsoleShowCommand(tab, 'winopen ' + tab.url); |
||||||
|
} |
||||||
|
return this.sendConsoleShowCommand(tab, 'winopen '); |
||||||
|
case operations.COMMAND_SHOW_BUFFER: |
||||||
|
return this.sendConsoleShowCommand(tab, 'buffer '); |
||||||
|
case operations.FIND_START: |
||||||
|
return browser.tabs.sendMessage(tab.id, { |
||||||
|
type: messages.CONSOLE_SHOW_FIND |
||||||
|
}); |
||||||
|
case operations.CANCEL: |
||||||
|
return browser.tabs.sendMessage(tab.id, { |
||||||
|
type: messages.CONSOLE_HIDE, |
||||||
|
}); |
||||||
|
case operations.PAGE_SOURCE: |
||||||
|
return browser.tabs.create({ |
||||||
|
url: 'view-source:' + tab.url, |
||||||
|
index: tab.index + 1, |
||||||
|
openerTabId: tab.id, |
||||||
|
}); |
||||||
|
default: |
||||||
|
return Promise.resolve(); |
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
sendConsoleShowCommand(tab, command) { |
||||||
|
return browser.tabs.sendMessage(tab.id, { |
||||||
|
type: messages.CONSOLE_SHOW_COMMAND, |
||||||
|
command, |
||||||
|
}); |
||||||
|
} |
||||||
|
} |
Reference in new issue