import { ipcRenderer } from 'electron';
import { ConfigKeys } from 'fyo/core/types';
import { IPC_ACTIONS } from 'utils/messages';
import { App as VueApp, createApp } from 'vue';
import App from './App.vue';
import Badge from './components/Badge.vue';
import FeatherIcon from './components/FeatherIcon.vue';
import { getErrorHandled, handleError } from './errorHandling';
import { fyo } from './initFyo';
import { outsideClickDirective } from './renderer/helpers';
import registerIpcRendererListeners from './renderer/registerIpcRendererListeners';
import router from './router';
import { stringifyCircular } from './utils';
import { setLanguageMap } from './utils/language';
(async () => {
const language = fyo.config.get(ConfigKeys.Language) as string;
if (language) {
await setLanguageMap(language);
}
setOnWindow();
ipcRenderer.send = getErrorHandled(ipcRenderer.send);
ipcRenderer.invoke = getErrorHandled(ipcRenderer.invoke);
registerIpcRendererListeners();
const app = createApp({
template: '',
});
setErrorHandlers(app);
app.use(router);
app.component('App', App);
app.component('FeatherIcon', FeatherIcon);
app.component('Badge', Badge);
app.directive('on-outside-click', outsideClickDirective);
app.mixin({
computed: {
fyo() {
return fyo;
},
platform() {
switch (process.platform) {
case 'win32':
return 'Windows';
case 'darwin':
return 'Mac';
case 'linux':
return 'Linux';
default:
return 'Linux';
}
},
},
methods: {
t: fyo.t,
T: fyo.T,
},
});
fyo.store.appVersion = await ipcRenderer.invoke(IPC_ACTIONS.GET_VERSION);
app.mount('body');
})();
function setErrorHandlers(app: VueApp) {
window.onerror = (message, source, lineno, colno, error) => {
error = error ?? new Error('triggered in window.onerror');
handleError(true, error, { message, source, lineno, colno });
};
app.config.errorHandler = (err, vm, info) => {
const more: Record = {
info,
};
if (vm) {
const { fullPath, params } = vm.$route;
more.fullPath = fullPath;
more.params = stringifyCircular(params ?? {});
more.data = stringifyCircular(vm.$data ?? {}, true, true);
more.props = stringifyCircular(vm.$props ?? {}, true, true);
}
handleError(false, err as Error, more);
console.error(err, vm, info);
};
process.on('unhandledRejection', (error) => {
handleError(true, error as Error);
});
process.on('uncaughtException', (error) => {
handleError(true, error, {}, () => process.exit(1));
});
}
function setOnWindow() {
if (process.env.NODE_ENV === 'development') {
// @ts-ignore
window.router = router;
// @ts-ignore
window.fyo = fyo;
}
}