cloudstack/ui/src/main.js
Vishesh f52e05863e
UI fix api in project view (#11191)
* Add project id for post requests as well in the params

* Replace leftover api calls to getAPI calls

* ui: don't remove values from request if the value is null or empty string

* Address comments

* Apply suggestions from code review

* Apply suggestions from code review

Co-authored-by: Suresh Kumar Anaparti <sureshkumar.anaparti@gmail.com>

* fixup

* Return null if guiTheme requests fails

---------

Co-authored-by: Suresh Kumar Anaparti <sureshkumar.anaparti@gmail.com>
2025-07-15 18:19:46 +05:30

127 lines
4.1 KiB
JavaScript

// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you under the Apache License, Version 2.0 (the
// "License"); you may not use this file except in compliance
// with the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing,
// software distributed under the License is distributed on an
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
// KIND, either express or implied. See the License for the
// specific language governing permissions and limitations
// under the License.
import { createApp, h } from 'vue'
import { vueApp, vueProps } from './vue-app'
import router from './router'
import store from './store'
import { i18n, loadLanguageAsync } from './locales'
import bootstrap from './core/bootstrap'
import './core/lazy_use'
import extensions from './core/ext'
import './permission' // permission control
import './utils/filter' // global filter
import {
pollJobPlugin,
notifierPlugin,
toLocaleDatePlugin,
configUtilPlugin,
apiMetaUtilPlugin,
showIconPlugin,
resourceTypePlugin,
fileSizeUtilPlugin,
genericUtilPlugin,
localesPlugin,
dialogUtilPlugin,
cpuArchitectureUtilPlugin,
imagesUtilPlugin
} from './utils/plugins'
import { VueAxios } from './utils/request'
import directives from './utils/directives'
import Cookies from 'js-cookie'
import { getAPI } from '@/api'
import { applyCustomGuiTheme } from './utils/guiTheme'
vueApp.use(VueAxios, router)
vueApp.use(pollJobPlugin)
vueApp.use(notifierPlugin)
vueApp.use(toLocaleDatePlugin)
vueApp.use(configUtilPlugin)
vueApp.use(apiMetaUtilPlugin)
vueApp.use(showIconPlugin)
vueApp.use(resourceTypePlugin)
vueApp.use(fileSizeUtilPlugin)
vueApp.use(localesPlugin)
vueApp.use(genericUtilPlugin)
vueApp.use(dialogUtilPlugin)
vueApp.use(cpuArchitectureUtilPlugin)
vueApp.use(imagesUtilPlugin)
vueApp.use(extensions)
vueApp.use(directives)
const renderError = (err) => {
console.error('Fatal error during app initialization: ', err)
const ErrorComponent = {
render: () => h(
'div',
{ style: 'font-family: sans-serif; text-align: center; padding: 2rem;' },
[
h('h2', { style: 'color: #ff4d4f;' }, 'We\'re experiencing a problem'),
h('p', 'The application could not be loaded due to a configuration issue. Please try again later.'),
h('details', { style: 'margin-top: 20px;' }, [
h('summary', { style: 'cursor: pointer;' }, 'Technical details'),
h('pre', {
style: 'text-align: left; display: inline-block; margin-top: 10px;'
}, 'Missing or malformed config.json. Please ensure the file is present, accessible, and contains valid JSON. Check the browser console for more information.')
])
]
)
}
createApp(ErrorComponent).mount('#app')
}
fetch('config.json?ts=' + Date.now())
.then(response => {
if (!response.ok) {
throw new Error(`Failed to fetch config.json: ${response.status} ${response.statusText}`)
}
return response.json()
})
.then(async config => {
vueProps.$config = config
let baseUrl = config.apiBase
if (config.multipleServer) {
baseUrl = (config.servers[0].apiHost || '') + config.servers[0].apiBase
}
vueProps.axios.defaults.baseURL = baseUrl
const userid = Cookies.get('userid')
let accountid = null
let domainid = null
if (userid !== undefined && Cookies.get('sessionkey')) {
await getAPI('listUsers', { userid: userid }).then(response => {
accountid = response.listusersresponse.user[0].accountid
domainid = response.listusersresponse.user[0].domainid
})
}
await applyCustomGuiTheme(accountid, domainid)
loadLanguageAsync().then(() => {
vueApp.use(store)
.use(router)
.use(i18n)
.use(bootstrap)
.mount('#app')
})
}).catch(error => {
renderError(error)
})