parent
a880d5684b
commit
f707f4da75
10 changed files with 279 additions and 251 deletions
@ -0,0 +1,8 @@ |
||||
import * as urls from '../../shared/urls'; |
||||
|
||||
export default class BrowserSettingRepository { |
||||
async getHomepageUrls() { |
||||
let { value } = await browser.browserSettings.homepageOverride.get({}); |
||||
return value.split('|').map(urls.normalizeUrl); |
||||
} |
||||
} |
@ -0,0 +1,61 @@ |
||||
import TabPresenter from '../presenters/TabPresenter'; |
||||
import ConsoleClient from '../infrastructures/ConsoleClient'; |
||||
|
||||
export default class ConsoleUseCase { |
||||
constructor() { |
||||
this.tabPresenter = new TabPresenter(); |
||||
this.consoleClient = new ConsoleClient(); |
||||
} |
||||
|
||||
async showCommand() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.consoleClient.showCommand(tab.id, ''); |
||||
} |
||||
|
||||
async showOpenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'open '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showTabopenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'tabopen '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showWinopenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'winopen '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showBufferCommand() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'buffer '; |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showAddbookmarkCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'addbookmark '; |
||||
if (alter) { |
||||
command += tab.title; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async hideConsole() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.consoleClient.hide(tab.id); |
||||
} |
||||
} |
@ -1,208 +0,0 @@ |
||||
import TabPresenter from '../presenters/TabPresenter'; |
||||
import ConsoleClient from '../infrastructures/ConsoleClient'; |
||||
import * as urls from '../../shared/urls'; |
||||
|
||||
const ZOOM_SETTINGS = [ |
||||
0.33, 0.50, 0.66, 0.75, 0.80, 0.90, 1.00, |
||||
1.10, 1.25, 1.50, 1.75, 2.00, 2.50, 3.00 |
||||
]; |
||||
|
||||
export default class OperationUseCase { |
||||
constructor() { |
||||
this.tabPresenter = new TabPresenter(); |
||||
this.consoleClient = new ConsoleClient(); |
||||
} |
||||
|
||||
async close(force) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
if (!force && tab.pinned) { |
||||
return; |
||||
} |
||||
return this.tabPresenter.remove([tab.id]); |
||||
} |
||||
|
||||
async closeRight() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
tabs.sort((t1, t2) => t1.index - t2.index); |
||||
let index = tabs.findIndex(t => t.active); |
||||
if (index < 0) { |
||||
return; |
||||
} |
||||
for (let i = index + 1; i < tabs.length; ++i) { |
||||
let tab = tabs[i]; |
||||
if (!tab.pinned) { |
||||
this.tabPresenter.remove(tab.id); |
||||
} |
||||
} |
||||
} |
||||
|
||||
reopen() { |
||||
return this.tabPresenter.reopen(); |
||||
} |
||||
|
||||
async selectPrev(count) { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
if (tabs.length < 2) { |
||||
return; |
||||
} |
||||
let tab = tabs.find(t => t.active); |
||||
if (!tab) { |
||||
return; |
||||
} |
||||
let select = (tab.index - count + tabs.length) % tabs.length; |
||||
return this.tabPresenter.select(tabs[select].id); |
||||
} |
||||
|
||||
async selectNext(count) { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
if (tabs.length < 2) { |
||||
return; |
||||
} |
||||
let tab = tabs.find(t => t.active); |
||||
if (!tab) { |
||||
return; |
||||
} |
||||
let select = (tab.index + count) % tabs.length; |
||||
return this.tabPresenter.select(tabs[select].id); |
||||
} |
||||
|
||||
async selectFirst() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
return this.tabPresenter.select(tabs[0].id); |
||||
} |
||||
|
||||
async selectLast() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
return this.tabPresenter.select(tabs[tabs.length - 1].id); |
||||
} |
||||
|
||||
async selectPrevSelected() { |
||||
let tabId = await this.tabPresenter.getLastSelectedId(); |
||||
if (tabId === null || typeof tabId === 'undefined') { |
||||
return; |
||||
} |
||||
this.tabPresenter.select(tabId); |
||||
} |
||||
|
||||
async reload(cache) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.reload(tab.id, cache); |
||||
} |
||||
|
||||
async setPinned(pinned) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.setPinned(tab.id, pinned); |
||||
} |
||||
|
||||
async togglePinned() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.setPinned(tab.id, !tab.pinned); |
||||
} |
||||
|
||||
async duplicate() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.duplicate(tab.id); |
||||
} |
||||
|
||||
async openPageSource() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let url = 'view-source:' + tab.url; |
||||
return this.tabPresenter.create(url); |
||||
} |
||||
|
||||
async zoomIn(tabId) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let current = await this.tabPresenter.getZoom(tab.id); |
||||
let factor = ZOOM_SETTINGS.find(f => f > current); |
||||
if (factor) { |
||||
return this.tabPresenter.setZoom(tabId, factor); |
||||
} |
||||
} |
||||
|
||||
async zoomOut(tabId) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let current = await this.tabPresenter.getZoom(tab.id); |
||||
let factor = [].concat(ZOOM_SETTINGS).reverse().find(f => f < current); |
||||
if (factor) { |
||||
return this.tabPresenter.setZoom(tabId, factor); |
||||
} |
||||
} |
||||
|
||||
zoomNutoral(tabId) { |
||||
return this.tabPresenter.setZoom(tabId, 1); |
||||
} |
||||
|
||||
async showCommand() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.consoleClient.showCommand(tab.id, ''); |
||||
} |
||||
|
||||
async showOpenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'open '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showTabopenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'tabopen '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showWinopenCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'winopen '; |
||||
if (alter) { |
||||
command += tab.url; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showBufferCommand() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'buffer '; |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async showAddbookmarkCommand(alter) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let command = 'addbookmark '; |
||||
if (alter) { |
||||
command += tab.title; |
||||
} |
||||
return this.consoleClient.showCommand(tab.id, command); |
||||
} |
||||
|
||||
async findStart() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.consoleClient.showFind(tab.id); |
||||
} |
||||
|
||||
async hideConsole() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.consoleClient.hide(tab.id); |
||||
} |
||||
|
||||
async openHome(newTab) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let result = await browser.browserSettings.homepageOverride.get({}); |
||||
let us = urls.homepageUrls(result.value); |
||||
if (us.length === 1 && us[0] === 'about:home') { |
||||
// eslint-disable-next-line max-len
|
||||
throw new Error('Cannot open Firefox Home (about:home) by WebExtensions, set your custom URLs'); |
||||
} |
||||
if (us.length === 1 && !newTab) { |
||||
return this.tabPresenter.open(us[0], tab.id); |
||||
} |
||||
for (let u of us) { |
||||
this.tabPresenter.create(u); |
||||
} |
||||
} |
||||
} |
||||
|
@ -0,0 +1,51 @@ |
||||
import TabPresenter from '../presenters/TabPresenter'; |
||||
|
||||
export default class TabSelectUseCase { |
||||
constructor() { |
||||
this.tabPresenter = new TabPresenter(); |
||||
} |
||||
|
||||
async selectPrev(count) { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
if (tabs.length < 2) { |
||||
return; |
||||
} |
||||
let tab = tabs.find(t => t.active); |
||||
if (!tab) { |
||||
return; |
||||
} |
||||
let select = (tab.index - count + tabs.length) % tabs.length; |
||||
return this.tabPresenter.select(tabs[select].id); |
||||
} |
||||
|
||||
async selectNext(count) { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
if (tabs.length < 2) { |
||||
return; |
||||
} |
||||
let tab = tabs.find(t => t.active); |
||||
if (!tab) { |
||||
return; |
||||
} |
||||
let select = (tab.index + count) % tabs.length; |
||||
return this.tabPresenter.select(tabs[select].id); |
||||
} |
||||
|
||||
async selectFirst() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
return this.tabPresenter.select(tabs[0].id); |
||||
} |
||||
|
||||
async selectLast() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
return this.tabPresenter.select(tabs[tabs.length - 1].id); |
||||
} |
||||
|
||||
async selectPrevSelected() { |
||||
let tabId = await this.tabPresenter.getLastSelectedId(); |
||||
if (tabId === null || typeof tabId === 'undefined') { |
||||
return; |
||||
} |
||||
this.tabPresenter.select(tabId); |
||||
} |
||||
} |
@ -0,0 +1,77 @@ |
||||
import TabPresenter from '../presenters/TabPresenter'; |
||||
import BrowserSettingRepository from '../repositories/BrowserSettingRepository'; |
||||
|
||||
export default class TabUseCase { |
||||
constructor() { |
||||
this.tabPresenter = new TabPresenter(); |
||||
this.browserSettingRepository = new BrowserSettingRepository(); |
||||
} |
||||
|
||||
async close(force) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
if (!force && tab.pinned) { |
||||
return; |
||||
} |
||||
return this.tabPresenter.remove([tab.id]); |
||||
} |
||||
|
||||
async closeRight() { |
||||
let tabs = await this.tabPresenter.getAll(); |
||||
tabs.sort((t1, t2) => t1.index - t2.index); |
||||
let index = tabs.findIndex(t => t.active); |
||||
if (index < 0) { |
||||
return; |
||||
} |
||||
for (let i = index + 1; i < tabs.length; ++i) { |
||||
let tab = tabs[i]; |
||||
if (!tab.pinned) { |
||||
this.tabPresenter.remove(tab.id); |
||||
} |
||||
} |
||||
} |
||||
|
||||
reopen() { |
||||
return this.tabPresenter.reopen(); |
||||
} |
||||
|
||||
async reload(cache) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.reload(tab.id, cache); |
||||
} |
||||
|
||||
async setPinned(pinned) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.setPinned(tab.id, pinned); |
||||
} |
||||
|
||||
async togglePinned() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.setPinned(tab.id, !tab.pinned); |
||||
} |
||||
|
||||
async duplicate() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
return this.tabPresenter.duplicate(tab.id); |
||||
} |
||||
|
||||
async openPageSource() { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let url = 'view-source:' + tab.url; |
||||
return this.tabPresenter.create(url); |
||||
} |
||||
|
||||
async openHome(newTab) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let urls = await this.browserSettingRepository.getHomepageUrls(); |
||||
if (urls.length === 1 && urls[0] === 'about:home') { |
||||
// eslint-disable-next-line max-len
|
||||
throw new Error('Cannot open Firefox Home (about:home) by WebExtensions, set your custom URLs'); |
||||
} |
||||
if (urls.length === 1 && !newTab) { |
||||
return this.tabPresenter.open(urls[0], tab.id); |
||||
} |
||||
for (let url of urls) { |
||||
this.tabPresenter.create(url); |
||||
} |
||||
} |
||||
} |
@ -0,0 +1,35 @@ |
||||
import TabPresenter from '../presenters/TabPresenter'; |
||||
|
||||
const ZOOM_SETTINGS = [ |
||||
0.33, 0.50, 0.66, 0.75, 0.80, 0.90, 1.00, |
||||
1.10, 1.25, 1.50, 1.75, 2.00, 2.50, 3.00 |
||||
]; |
||||
|
||||
export default class ZoomUseCase { |
||||
constructor() { |
||||
this.tabPresenter = new TabPresenter(); |
||||
} |
||||
|
||||
async zoomIn(tabId) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let current = await this.tabPresenter.getZoom(tab.id); |
||||
let factor = ZOOM_SETTINGS.find(f => f > current); |
||||
if (factor) { |
||||
return this.tabPresenter.setZoom(tabId, factor); |
||||
} |
||||
} |
||||
|
||||
async zoomOut(tabId) { |
||||
let tab = await this.tabPresenter.getCurrent(); |
||||
let current = await this.tabPresenter.getZoom(tab.id); |
||||
let factor = [].concat(ZOOM_SETTINGS).reverse().find(f => f < current); |
||||
if (factor) { |
||||
return this.tabPresenter.setZoom(tabId, factor); |
||||
} |
||||
} |
||||
|
||||
zoomNutoral(tabId) { |
||||
return this.tabPresenter.setZoom(tabId, 1); |
||||
} |
||||
|
||||
} |
Reference in new issue