Open options page on banner click

jh-changes
Shin'ya Ueoka 5 years ago
parent 07bcc15e7b
commit 34bd084a4d
  1. 11
      src/background/presenters/NotifyPresenter.ts
  2. 4
      src/background/usecases/SettingUseCase.ts

@ -26,11 +26,20 @@ export default class NotifyPresenter {
});
}
async notifyInvalidSettings(): Promise<void> {
async notifyInvalidSettings(onclick: () => void): Promise<void> {
let title = `Loaded settings is invalid`;
// eslint-disable-next-line max-len
let message = 'The default settings is used due to the last saved settings is invalid. Check your current settings from the add-on preference';
const listener = (id: string) => {
if (id !== NOTIFICATION_ID_INVALID_SETTINGS) {
return;
}
onclick();
browser.notifications.onClicked.removeListener(listener);
};
browser.notifications.onClicked.addListener(listener);
await browser.notifications.create(NOTIFICATION_ID_INVALID_SETTINGS, {
'type': 'basic',
'iconUrl': browser.extension.getURL('resources/icon_48x48.png'),

@ -30,7 +30,9 @@ export default class SettingUseCase {
try {
value = data.toSettings();
} catch (e) {
this.notifyPresenter.notifyInvalidSettings();
this.notifyPresenter.notifyInvalidSettings(() => {
browser.runtime.openOptionsPage();
});
value = DefaultSettingData.toSettings();
}
this.settingRepository.update(value!!);