import { createApp } from 'vue'; import 'vue-json-pretty/lib/styles.css'; import '@jsplumb/browser-ui/css/jsplumbtoolkit.css'; import 'n8n-design-system/css/index.scss'; import './n8n-theme.scss'; import './styles/autocomplete-theme.scss'; import '@fontsource/open-sans/latin-400.css'; import '@fontsource/open-sans/latin-600.css'; import '@fontsource/open-sans/latin-700.css'; import App from '@/App.vue'; import router from './router'; import { TelemetryPlugin } from './plugins/telemetry'; import { I18nPlugin, i18nInstance } from './plugins/i18n'; import { GlobalComponentsPlugin } from './plugins/components'; import { GlobalDirectivesPlugin } from './plugins/directives'; import { FontAwesomePlugin } from './plugins/icons'; import { runExternalHook } from '@/utils'; import { createPinia, PiniaVuePlugin } from 'pinia'; import { useWebhooksStore } from '@/stores'; const pinia = createPinia(); const app = createApp(App); app.use(TelemetryPlugin); app.use(PiniaVuePlugin); app.use(I18nPlugin); app.use(FontAwesomePlugin); app.use(GlobalComponentsPlugin); app.use(GlobalDirectivesPlugin); app.use(pinia); app.use(router); app.use(i18nInstance); app.mount('#app'); router.afterEach((to, from) => { void runExternalHook('main.routeChange', useWebhooksStore(), { from, to }); }); if (!import.meta.env.PROD) { // Make sure that we get all error messages properly displayed // as long as we are not in production mode window.onerror = (message, source, lineno, colno, error) => { if (message.toString().includes('ResizeObserver')) { // That error can apparently be ignored and can probably // not do anything about it anyway return; } console.error('error caught in main.ts'); console.error(message); console.error(error); }; }