Files
directus/app/src/main.ts
Rijk van Zanten 545d392e93 Deprecate utils/package.js in favor of directus/version (#20840)
* Deprecate utils/package.js in favor of directus/version

* Add changeset

* Drop version console log

* Make info reactive

* Fix import order

* Update directus/version.js

Co-authored-by: Pascal Jufer <pascal-jufer@bluewin.ch>

* Fix tests

---------

Co-authored-by: Pascal Jufer <pascal-jufer@bluewin.ch>
2023-12-21 13:53:22 -05:00

68 lines
2.0 KiB
TypeScript

/* eslint-disable no-console */
// Note: the import order is important. Vue has to come first. (Unhead will break if that's first)
import { createApp } from 'vue';
import { getVueComponentName } from '@/utils/get-vue-component-name';
import { createHead } from '@unhead/vue';
import { createPinia } from 'pinia';
import App from './app.vue';
import { registerComponents } from './components/register';
import { DIRECTUS_LOGO } from './constants';
import { registerDirectives } from './directives/register';
import { loadExtensions, registerExtensions } from './extensions';
import { i18n } from './lang/';
import { router } from './router';
import './styles/main.scss';
import { registerViews } from './views/register';
init();
async function init() {
console.log(DIRECTUS_LOGO);
console.info(
`Hey! Interested in helping build this open-source data management platform?\nIf so, join our growing team of contributors at: https://directus.chat`,
);
console.info(`%c🐰 Starting Directus...`, 'color:Green');
console.time('🕓 Application Loaded');
const app = createApp(App);
app.use(i18n);
app.use(createPinia());
app.use(createHead());
app.config.errorHandler = (err, vm, info) => {
const source = getVueComponentName(vm);
console.warn(`[app-${source}-error] ${info}`);
console.warn(err);
return false;
};
registerDirectives(app);
registerComponents(app);
registerViews(app);
await loadExtensions();
registerExtensions(app);
// Add router after loading of extensions to ensure all routes are registered
app.use(router);
app.mount('#app');
console.timeEnd('🕓 Application Loaded');
console.group(`%c✨ Project Information`, 'color:DodgerBlue'); // groupCollapsed
console.info(`%cEnvironment: ${import.meta.env.MODE}`, 'color:DodgerBlue');
console.groupEnd();
// Prevent the browser from opening files that are dragged on the window
window.addEventListener('dragover', (e) => e.preventDefault(), false);
window.addEventListener('drop', (e) => e.preventDefault(), false);
}