aboutsummaryrefslogtreecommitdiff
path: root/src/background/usecases/ConsoleUseCase.ts
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2019-05-07 21:16:47 +0900
committerGitHub <noreply@github.com>2019-05-07 21:16:47 +0900
commit05ef6a8ca35aaa801c11eb6b4896caa3690058af (patch)
tree2c7708ca91ac2b462cc86aa28612e3d3943496f3 /src/background/usecases/ConsoleUseCase.ts
parent457d954e08923b4accd28a919c72d0b61db1bb98 (diff)
parent27d0a7f37d24a0ad68a8ccb7dee18fc1d00eea58 (diff)
Merge pull request #578 from ueokande/move-to-typescript
Move to TypeScript
Diffstat (limited to 'src/background/usecases/ConsoleUseCase.ts')
-rw-r--r--src/background/usecases/ConsoleUseCase.ts65
1 files changed, 65 insertions, 0 deletions
diff --git a/src/background/usecases/ConsoleUseCase.ts b/src/background/usecases/ConsoleUseCase.ts
new file mode 100644
index 0000000..60c0439
--- /dev/null
+++ b/src/background/usecases/ConsoleUseCase.ts
@@ -0,0 +1,65 @@
+import TabPresenter from '../presenters/TabPresenter';
+import ConsoleClient from '../infrastructures/ConsoleClient';
+
+export default class ConsoleUseCase {
+ private tabPresenter: TabPresenter;
+
+ private consoleClient: ConsoleClient;
+
+ constructor() {
+ this.tabPresenter = new TabPresenter();
+ this.consoleClient = new ConsoleClient();
+ }
+
+ async showCommand(): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ return this.consoleClient.showCommand(tab.id as number, '');
+ }
+
+ async showOpenCommand(alter: boolean): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ let command = 'open ';
+ if (alter) {
+ command += tab.url || '';
+ }
+ return this.consoleClient.showCommand(tab.id as number, command);
+ }
+
+ async showTabopenCommand(alter: boolean): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ let command = 'tabopen ';
+ if (alter) {
+ command += tab.url || '';
+ }
+ return this.consoleClient.showCommand(tab.id as number, command);
+ }
+
+ async showWinopenCommand(alter: boolean): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ let command = 'winopen ';
+ if (alter) {
+ command += tab.url || '';
+ }
+ return this.consoleClient.showCommand(tab.id as number, command);
+ }
+
+ async showBufferCommand(): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ let command = 'buffer ';
+ return this.consoleClient.showCommand(tab.id as number, command);
+ }
+
+ async showAddbookmarkCommand(alter: boolean): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ let command = 'addbookmark ';
+ if (alter) {
+ command += tab.title || '';
+ }
+ return this.consoleClient.showCommand(tab.id as number, command);
+ }
+
+ async hideConsole(): Promise<any> {
+ let tab = await this.tabPresenter.getCurrent();
+ return this.consoleClient.hide(tab.id as number);
+ }
+}