Merge pull request #622 from ueokande/fallback-default-settings
Handle errors on loading settings
This commit is contained in:
commit
e7ed84f757
4 changed files with 33 additions and 15 deletions
|
@ -33,6 +33,7 @@
|
||||||
"function-paren-newline": "off",
|
"function-paren-newline": "off",
|
||||||
"id-length": "off",
|
"id-length": "off",
|
||||||
"indent": ["error", 2],
|
"indent": ["error", 2],
|
||||||
|
"init-declarations": "off",
|
||||||
"jsx-quotes": ["error", "prefer-single"],
|
"jsx-quotes": ["error", "prefer-single"],
|
||||||
"max-classes-per-file": "off",
|
"max-classes-per-file": "off",
|
||||||
"max-lines": "off",
|
"max-lines": "off",
|
||||||
|
|
|
@ -1,26 +1,37 @@
|
||||||
import { injectable } from 'tsyringe';
|
import { injectable } from 'tsyringe';
|
||||||
|
|
||||||
const NOTIFICATION_ID = 'vimvixen-update';
|
const NOTIFICATION_ID_UPDATE = 'vimvixen-update';
|
||||||
|
const NOTIFICATION_ID_INVALID_SETTINGS = 'vimvixen-update-invalid-settings';
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export default class NotifyPresenter {
|
export default class NotifyPresenter {
|
||||||
async notify(
|
async notifyUpdated(version: string, onclick: () => void): Promise<void> {
|
||||||
title: string,
|
let title = `Vim Vixen ${version} has been installed`;
|
||||||
message: string,
|
let message = 'Click here to see release notes';
|
||||||
onclick: () => void,
|
|
||||||
): Promise<void> {
|
|
||||||
const listener = (id: string) => {
|
const listener = (id: string) => {
|
||||||
if (id !== NOTIFICATION_ID) {
|
if (id !== NOTIFICATION_ID_UPDATE) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
onclick();
|
onclick();
|
||||||
|
|
||||||
browser.notifications.onClicked.removeListener(listener);
|
browser.notifications.onClicked.removeListener(listener);
|
||||||
};
|
};
|
||||||
browser.notifications.onClicked.addListener(listener);
|
browser.notifications.onClicked.addListener(listener);
|
||||||
|
|
||||||
await browser.notifications.create(NOTIFICATION_ID, {
|
await browser.notifications.create(NOTIFICATION_ID_UPDATE, {
|
||||||
|
'type': 'basic',
|
||||||
|
'iconUrl': browser.extension.getURL('resources/icon_48x48.png'),
|
||||||
|
title,
|
||||||
|
message,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
async notifyInvalidSettings(): 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';
|
||||||
|
|
||||||
|
await browser.notifications.create(NOTIFICATION_ID_INVALID_SETTINGS, {
|
||||||
'type': 'basic',
|
'type': 'basic',
|
||||||
'iconUrl': browser.extension.getURL('resources/icon_48x48.png'),
|
'iconUrl': browser.extension.getURL('resources/icon_48x48.png'),
|
||||||
title,
|
title,
|
||||||
|
|
|
@ -4,6 +4,7 @@ import PersistentSettingRepository
|
||||||
import SettingRepository from '../repositories/SettingRepository';
|
import SettingRepository from '../repositories/SettingRepository';
|
||||||
import { DefaultSettingData } from '../../shared/SettingData';
|
import { DefaultSettingData } from '../../shared/SettingData';
|
||||||
import Settings from '../../shared/Settings';
|
import Settings from '../../shared/Settings';
|
||||||
|
import NotifyPresenter from '../presenters/NotifyPresenter';
|
||||||
|
|
||||||
@injectable()
|
@injectable()
|
||||||
export default class SettingUseCase {
|
export default class SettingUseCase {
|
||||||
|
@ -11,6 +12,7 @@ export default class SettingUseCase {
|
||||||
constructor(
|
constructor(
|
||||||
private persistentSettingRepository: PersistentSettingRepository,
|
private persistentSettingRepository: PersistentSettingRepository,
|
||||||
private settingRepository: SettingRepository,
|
private settingRepository: SettingRepository,
|
||||||
|
private notifyPresenter: NotifyPresenter,
|
||||||
) {
|
) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -24,8 +26,14 @@ export default class SettingUseCase {
|
||||||
data = DefaultSettingData;
|
data = DefaultSettingData;
|
||||||
}
|
}
|
||||||
|
|
||||||
let value = data.toSettings();
|
let value: Settings;
|
||||||
this.settingRepository.update(value);
|
try {
|
||||||
|
value = data.toSettings();
|
||||||
|
} catch (e) {
|
||||||
|
this.notifyPresenter.notifyInvalidSettings();
|
||||||
|
value = DefaultSettingData.toSettings();
|
||||||
|
}
|
||||||
|
this.settingRepository.update(value!!);
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -12,10 +12,8 @@ export default class VersionUseCase {
|
||||||
|
|
||||||
notify(): Promise<void> {
|
notify(): Promise<void> {
|
||||||
let manifest = browser.runtime.getManifest();
|
let manifest = browser.runtime.getManifest();
|
||||||
let title = `Vim Vixen ${manifest.version} has been installed`;
|
|
||||||
let message = 'Click here to see release notes';
|
|
||||||
let url = this.releaseNoteUrl(manifest.version);
|
let url = this.releaseNoteUrl(manifest.version);
|
||||||
return this.notifyPresenter.notify(title, message, () => {
|
return this.notifyPresenter.notifyUpdated(manifest.version, () => {
|
||||||
this.tabPresenter.create(url);
|
this.tabPresenter.create(url);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Reference in a new issue