yomichan/ext/js/app/content-script-main.js
toasted-nutbread 9279ced686
Log refactoring (#1393)
* Create Logger class and log instance

* Replace yomichan.logWarning with log.warn

* Replace yomichan.logError with log.error

* Replace yomichan.log with log.log

* Update the Yomichan class to use the global log object

* Update lint rules
2021-02-14 17:52:01 -05:00

58 lines
1.6 KiB
JavaScript

/*
* Copyright (C) 2019-2021 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
* Frontend
* HotkeyHandler
* PopupFactory
*/
(async () => {
try {
await yomichan.prepare();
const {tabId, frameId} = await yomichan.api.frameInformationGet();
if (typeof frameId !== 'number') {
throw new Error('Failed to get frameId');
}
const hotkeyHandler = new HotkeyHandler();
hotkeyHandler.prepare();
const popupFactory = new PopupFactory(frameId);
popupFactory.prepare();
const frontend = new Frontend({
tabId,
frameId,
popupFactory,
depth: 0,
parentPopupId: null,
parentFrameId: null,
useProxyPopup: false,
pageType: 'web',
allowRootFramePopupProxy: true,
hotkeyHandler
});
await frontend.prepare();
yomichan.ready();
} catch (e) {
log.error(e);
}
})();