aboutsummaryrefslogtreecommitdiff
path: root/src/background/usecases
diff options
context:
space:
mode:
Diffstat (limited to 'src/background/usecases')
-rw-r--r--src/background/usecases/mark.js16
1 files changed, 13 insertions, 3 deletions
diff --git a/src/background/usecases/mark.js b/src/background/usecases/mark.js
index 2cb3b45..34b8a74 100644
--- a/src/background/usecases/mark.js
+++ b/src/background/usecases/mark.js
@@ -2,17 +2,19 @@ import GlobalMark from '../domains/global-mark';
import TabPresenter from '../presenters/tab';
import MarkRepository from '../repositories/mark';
import ConsolePresenter from '../presenters/console';
+import ContentMessageClient from '../infrastructures/content-message-client';
export default class MarkInteractor {
constructor() {
this.tabPresenter = new TabPresenter();
this.markRepository = new MarkRepository();
this.consolePresenter = new ConsolePresenter();
+ this.contentMessageClient = new ContentMessageClient();
}
async setGlobal(key, x, y) {
let tab = await this.tabPresenter.getCurrent();
- let mark = new GlobalMark(tab.id, x, y);
+ let mark = new GlobalMark(tab.id, tab.url, x, y);
return this.markRepository.setMark(key, mark);
}
@@ -23,7 +25,15 @@ export default class MarkInteractor {
if (!mark) {
return this.consolePresenter.showError(current.id, 'Mark is not set');
}
- // TODO scroll pages and handle if tab is gone
- return this.tabPresenter.select(mark.tabId);
+
+ return this.contentMessageClient.scrollTo(
+ mark.tabId, mark.x, mark.y
+ ).then(() => {
+ return this.tabPresenter.select(mark.tabId);
+ }).catch(async() => {
+ let tab = await this.tabPresenter.create(mark.url);
+ let mark2 = new GlobalMark(tab.id, mark.url, mark.x, mark.y);
+ return this.markRepository.setMark(key, mark2);
+ });
}
}