funkwhale/front/src/main.ts

55 wiersze
1.2 KiB
TypeScript
Czysty Zwykły widok Historia

import logger from '~/logging'
import router from '~/router'
import VueLazyload from 'vue-lazyload'
import store from '~/store'
import { sync } from 'vuex-router-sync'
2022-04-18 08:24:47 +00:00
import Vue, { createApp } from 'vue'
2022-04-23 07:26:25 +00:00
import useTheme from '~/composables/useTheme'
useTheme()
2022-04-18 00:40:34 +00:00
Vue.config.devtools = true
logger.default.info('Loading environment:', import.meta.env.MODE)
logger.default.debug('Environment variables:', import.meta.env)
sync(store, router)
const app = createApp({
store,
router,
2022-04-18 00:40:34 +00:00
components: {
App: () => import('~/App.vue')
},
2022-04-17 23:24:50 +00:00
data: () => ({ isMounted: false }),
async mounted () {
this.isMounted = true
},
2022-04-18 08:24:47 +00:00
render (h) {
2022-04-17 23:24:50 +00:00
if (this.isMounted) {
2022-04-23 07:37:43 +00:00
return h('app')
2022-04-17 23:24:50 +00:00
}
2022-04-18 08:24:47 +00:00
// TODO (wvffle): Import fake app component
2022-04-17 23:24:50 +00:00
return h()
}
})
app.use(VueLazyload)
2022-04-17 23:24:50 +00:00
const modules: Promise<unknown>[] = []
2022-04-23 12:10:36 +00:00
for (const module of Object.values(import.meta.globEager('./init/*.ts'))) {
2022-04-17 23:24:50 +00:00
modules.push(module.install?.({
app,
router,
store
2022-04-17 23:24:50 +00:00
}))
}
2022-04-17 23:24:50 +00:00
store.dispatch('instance/fetchFrontSettings').finally(async () => {
// Wait for all modules to load
await Promise.all(modules)
app.mount('#app')
logger.default.info('Everything loaded!')
})