diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/@types/web-ext-api/index.d.ts | 4 | ||||
-rw-r--r-- | src/background/operators/impls/TabOperatorFactoryChain.ts | 3 | ||||
-rw-r--r-- | src/background/operators/impls/ToggleReaderOperator.ts | 11 | ||||
-rw-r--r-- | src/background/presenters/TabPresenter.ts | 6 | ||||
-rw-r--r-- | src/settings/keymaps.ts | 1 | ||||
-rw-r--r-- | src/shared/operations.ts | 7 | ||||
-rw-r--r-- | src/shared/settings/Settings.ts | 1 |
7 files changed, 33 insertions, 0 deletions
diff --git a/src/@types/web-ext-api/index.d.ts b/src/@types/web-ext-api/index.d.ts index 7eed334..c2ffbb2 100644 --- a/src/@types/web-ext-api/index.d.ts +++ b/src/@types/web-ext-api/index.d.ts @@ -1,3 +1,7 @@ +declare namespace browser.tabs { + function toggleReaderMode(tabId?: number): Promise<void>; +} + declare namespace browser.browserSettings.homepageOverride { type BrowserSettings = { value: string; diff --git a/src/background/operators/impls/TabOperatorFactoryChain.ts b/src/background/operators/impls/TabOperatorFactoryChain.ts index edd3eaf..d526f86 100644 --- a/src/background/operators/impls/TabOperatorFactoryChain.ts +++ b/src/background/operators/impls/TabOperatorFactoryChain.ts @@ -16,6 +16,7 @@ import PinTabOperator from "./PinTabOperator"; import UnpinTabOperator from "./UnpinTabOperator"; import TogglePinnedTabOperator from "./TogglePinnedTabOperator"; import DuplicateTabOperator from "./DuplicateTabOperator"; +import ToggleReaderOperator from "./ToggleReaderOperator"; @injectable() export default class TabOperatorFactoryChain implements OperatorFactoryChain { @@ -58,6 +59,8 @@ export default class TabOperatorFactoryChain implements OperatorFactoryChain { return new TogglePinnedTabOperator(this.tabPresenter); case operations.TAB_DUPLICATE: return new DuplicateTabOperator(this.tabPresenter); + case operations.TAB_TOGGLE_READER: + return new ToggleReaderOperator(this.tabPresenter); } return null; } diff --git a/src/background/operators/impls/ToggleReaderOperator.ts b/src/background/operators/impls/ToggleReaderOperator.ts new file mode 100644 index 0000000..681e4c3 --- /dev/null +++ b/src/background/operators/impls/ToggleReaderOperator.ts @@ -0,0 +1,11 @@ +import Operator from "../Operator"; +import TabPresenter from "../../presenters/TabPresenter"; + +export default class ToggleReaderOperator implements Operator { + constructor(private readonly tabPresenter: TabPresenter) {} + + async run(): Promise<void> { + const tab = await this.tabPresenter.getCurrent(); + return this.tabPresenter.toggleReaderMode(tab.id as number); + } +} diff --git a/src/background/presenters/TabPresenter.ts b/src/background/presenters/TabPresenter.ts index 2f8f5d9..ef4b343 100644 --- a/src/background/presenters/TabPresenter.ts +++ b/src/background/presenters/TabPresenter.ts @@ -47,6 +47,8 @@ export default interface TabPresenter { onSelected( listener: (arg: { tabId: number; windowId: number }) => void ): void; + + toggleReaderMode(tabId: number): Promise<void>; } export class TabPresenterImpl implements TabPresenter { @@ -152,6 +154,10 @@ export class TabPresenterImpl implements TabPresenter { ): void { browser.tabs.onActivated.addListener(listener); } + + toggleReaderMode(tabId: number): Promise<void> { + return browser.tabs.toggleReaderMode(tabId); + } } const tabPresenter = new TabPresenterImpl(); diff --git a/src/settings/keymaps.ts b/src/settings/keymaps.ts index 25c7a51..ff87cf4 100644 --- a/src/settings/keymaps.ts +++ b/src/settings/keymaps.ts @@ -31,6 +31,7 @@ const fields = [ ['tabs.reload?{"cache":true}', "Reload with no caches"], ["tabs.pin.toggle", "Toggle pinned state"], ["tabs.duplicate", "Duplicate a tab"], + ["tabs.reader.toggle", "Reader view"], ], [ ['follow.start?{"newTab":false,"background":false}', "Follow a link"], diff --git a/src/shared/operations.ts b/src/shared/operations.ts index 3544502..1433011 100644 --- a/src/shared/operations.ts +++ b/src/shared/operations.ts @@ -56,6 +56,7 @@ export const TAB_PIN = "tabs.pin"; export const TAB_UNPIN = "tabs.unpin"; export const TAB_TOGGLE_PINNED = "tabs.pin.toggle"; export const TAB_DUPLICATE = "tabs.duplicate"; +export const TAB_TOGGLE_READER = "tabs.reader.toggle"; // Zooms export const ZOOM_IN = "zoom.in"; @@ -257,6 +258,10 @@ export interface TabDuplicateOperation { type: typeof TAB_DUPLICATE; } +export interface TabToggleReaderOperation { + type: typeof TAB_TOGGLE_READER; +} + export interface ZoomInOperation { type: typeof ZOOM_IN; } @@ -352,6 +357,7 @@ export type Operation = | TabUnpinOperation | TabTogglePinnedOperation | TabDuplicateOperation + | TabToggleReaderOperation | ZoomInOperation | ZoomOutOperation | ZoomNeutralOperation @@ -506,6 +512,7 @@ export const valueOf = (o: any): Operation => { case TAB_UNPIN: case TAB_TOGGLE_PINNED: case TAB_DUPLICATE: + case TAB_TOGGLE_READER: case ZOOM_IN: case ZOOM_OUT: case ZOOM_NEUTRAL: diff --git a/src/shared/settings/Settings.ts b/src/shared/settings/Settings.ts index 43297a3..6c4fa0a 100644 --- a/src/shared/settings/Settings.ts +++ b/src/shared/settings/Settings.ts @@ -133,6 +133,7 @@ export const DefaultSettingJSONText = `{ "gf": { "type": "page.source" }, "gh": { "type": "page.home" }, "gH": { "type": "page.home", "newTab": true }, + "gr": { "type": "tabs.reader.toggle" }, "y": { "type": "urls.yank" }, "p": { "type": "urls.paste", "newTab": false }, "P": { "type": "urls.paste", "newTab": true }, |