89ac85afd0
* Update eslint settings * Update 2021 files * Update other files
184 lines
6.7 KiB
JavaScript
184 lines
6.7 KiB
JavaScript
/*
|
|
* Copyright (C) 2020-2022 Yomichan Authors
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* global
|
|
* AnkiController
|
|
* AnkiTemplatesController
|
|
* AudioController
|
|
* BackupController
|
|
* CollapsibleDictionaryController
|
|
* DictionaryController
|
|
* DictionaryImportController
|
|
* DocumentFocusController
|
|
* Environment
|
|
* ExtensionKeyboardShortcutController
|
|
* GenericSettingController
|
|
* KeyboardShortcutController
|
|
* MecabController
|
|
* ModalController
|
|
* NestedPopupsController
|
|
* PermissionsToggleController
|
|
* PersistentStorageController
|
|
* PopupPreviewController
|
|
* PopupWindowController
|
|
* ProfileController
|
|
* ScanInputsController
|
|
* ScanInputsSimpleController
|
|
* SecondarySearchDictionaryController
|
|
* SentenceTerminationCharactersController
|
|
* SettingsController
|
|
* SettingsDisplayController
|
|
* SortFrequencyDictionaryController
|
|
* StatusFooter
|
|
* StorageController
|
|
* TranslationTextReplacementsController
|
|
*/
|
|
|
|
async function setupEnvironmentInfo() {
|
|
const {dataset} = document.documentElement;
|
|
const {manifest_version: manifestVersion} = chrome.runtime.getManifest();
|
|
dataset.manifestVersion = `${manifestVersion}`;
|
|
|
|
const environment = new Environment();
|
|
await environment.prepare();
|
|
const {browser, platform} = environment.getInfo();
|
|
|
|
dataset.browser = browser;
|
|
dataset.os = platform.os;
|
|
}
|
|
|
|
async function setupGenericSettingsController(genericSettingController) {
|
|
await genericSettingController.prepare();
|
|
await genericSettingController.refresh();
|
|
}
|
|
|
|
(async () => {
|
|
try {
|
|
const documentFocusController = new DocumentFocusController();
|
|
documentFocusController.prepare();
|
|
|
|
const statusFooter = new StatusFooter(document.querySelector('.status-footer-container'));
|
|
statusFooter.prepare();
|
|
|
|
setupEnvironmentInfo();
|
|
|
|
let prepareTimer = setTimeout(() => {
|
|
prepareTimer = null;
|
|
document.documentElement.dataset.loadingStalled = 'true';
|
|
}, 1000);
|
|
|
|
await yomichan.prepare();
|
|
|
|
if (prepareTimer !== null) {
|
|
clearTimeout(prepareTimer);
|
|
prepareTimer = null;
|
|
}
|
|
delete document.documentElement.dataset.loadingStalled;
|
|
|
|
const optionsFull = await yomichan.api.optionsGetFull();
|
|
|
|
const preparePromises = [];
|
|
|
|
const modalController = new ModalController();
|
|
modalController.prepare();
|
|
|
|
const settingsController = new SettingsController(optionsFull.profileCurrent);
|
|
settingsController.prepare();
|
|
|
|
const persistentStorageController = new PersistentStorageController();
|
|
persistentStorageController.prepare();
|
|
|
|
const storageController = new StorageController(persistentStorageController);
|
|
storageController.prepare();
|
|
|
|
const dictionaryController = new DictionaryController(settingsController, modalController, statusFooter);
|
|
dictionaryController.prepare();
|
|
|
|
const dictionaryImportController = new DictionaryImportController(settingsController, modalController, statusFooter);
|
|
dictionaryImportController.prepare();
|
|
|
|
const genericSettingController = new GenericSettingController(settingsController);
|
|
preparePromises.push(setupGenericSettingsController(genericSettingController));
|
|
|
|
const audioController = new AudioController(settingsController, modalController);
|
|
audioController.prepare();
|
|
|
|
const profileController = new ProfileController(settingsController, modalController);
|
|
profileController.prepare();
|
|
|
|
const settingsBackup = new BackupController(settingsController, modalController);
|
|
settingsBackup.prepare();
|
|
|
|
const ankiController = new AnkiController(settingsController);
|
|
ankiController.prepare();
|
|
|
|
const ankiTemplatesController = new AnkiTemplatesController(settingsController, modalController, ankiController);
|
|
ankiTemplatesController.prepare();
|
|
|
|
const popupPreviewController = new PopupPreviewController(settingsController);
|
|
popupPreviewController.prepare();
|
|
|
|
const scanInputsController = new ScanInputsController(settingsController);
|
|
scanInputsController.prepare();
|
|
|
|
const simpleScanningInputController = new ScanInputsSimpleController(settingsController);
|
|
simpleScanningInputController.prepare();
|
|
|
|
const nestedPopupsController = new NestedPopupsController(settingsController);
|
|
nestedPopupsController.prepare();
|
|
|
|
const permissionsToggleController = new PermissionsToggleController(settingsController);
|
|
permissionsToggleController.prepare();
|
|
|
|
const secondarySearchDictionaryController = new SecondarySearchDictionaryController(settingsController);
|
|
secondarySearchDictionaryController.prepare();
|
|
|
|
const translationTextReplacementsController = new TranslationTextReplacementsController(settingsController);
|
|
translationTextReplacementsController.prepare();
|
|
|
|
const sentenceTerminationCharactersController = new SentenceTerminationCharactersController(settingsController);
|
|
sentenceTerminationCharactersController.prepare();
|
|
|
|
const keyboardShortcutController = new KeyboardShortcutController(settingsController);
|
|
keyboardShortcutController.prepare();
|
|
|
|
const extensionKeyboardShortcutController = new ExtensionKeyboardShortcutController(settingsController);
|
|
extensionKeyboardShortcutController.prepare();
|
|
|
|
const popupWindowController = new PopupWindowController();
|
|
popupWindowController.prepare();
|
|
|
|
const mecabController = new MecabController();
|
|
mecabController.prepare();
|
|
|
|
const collapsibleDictionaryController = new CollapsibleDictionaryController(settingsController);
|
|
collapsibleDictionaryController.prepare();
|
|
|
|
const sortFrequencyDictionaryController = new SortFrequencyDictionaryController(settingsController);
|
|
sortFrequencyDictionaryController.prepare();
|
|
|
|
await Promise.all(preparePromises);
|
|
|
|
document.documentElement.dataset.loaded = 'true';
|
|
|
|
const settingsDisplayController = new SettingsDisplayController(settingsController, modalController);
|
|
settingsDisplayController.prepare();
|
|
} catch (e) {
|
|
log.error(e);
|
|
}
|
|
})();
|