mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
* add new vue 3 library & and 2.x (beta) * edit config files, settings, utils, store,... corresponding to Vue 3 * edit layout and config to suit the new library * fix header & side menu * components, autogenview * fix dashboard & compute * compute: fix form errors * storage: fix form & template by vue3 * networks: fix form & template by vue3 * image: fix form & template by vue3 * project: fix by vue3 library * user: fix by vue3 * iam: fix by vue3 * fix zoneWizard & tooltip click event * fix infra > physicalnetwork & visible modal * fix infra by vue3 & antdv 2x * fix offerings by vue3 * fix plugin by vue3 * fix form & action form * update the ant-design latest version * fix icon, style dark mode, menu * fix unittest * fix babel plugins not found * add name,ref missing & callback i18n not found * fix slot & info icon * fix unit test * fix tooltip label of form item * fix lint errors * using global app, globalProperties * add focus directive & edit the position of ctrl+Enter * upgrage Vue 3 version * fix main UT * fix build failed * using `optionFilterProp="label"' & fix build fail * fix UT with new code * fix icons of undefined * fix error run app * fix selectbox options * add vue version for clear storage * fix template * fix template of iprange form * fix warning test UT * fix conflit * fix build failed * fix error run app the first time after upgrade * fix auto-complete & watch object/array * fix error run application * fix error build * fix form, icon, template & locales * fix conflit & form * remove slot errors * fix error build & test UT * fix error template * Add licenses for missing files * add scroll to first errors * add scroll to first errors * fix select filter, tag event * add shallowRef async component are missing * fix css, upgrade vue-cropper version * fix css * fix vue 3 coding for new components * Remove unused components * fixes `this` not found in @/roles * fix redirect after login again when session expired error * fix openKeys menu & watch router * fixes * fix build failed * fixes * fixes ut * fixes * fixes eslint * fixes * fixes * fixes css * fix menu sidebar css * fix some css icon, images * fix build fail * fixes * fixes * fixes * fixes * fix publicip resource * fixes ut * fixes * fixes * fixes layout mode * fixes dropdown filter columns * fixes dashboard & hidden setting for normal user * fixes * fixes layout * fixes avatar * fixes * Add missing else * Fix query in routable paths Co-authored-by: davidjumani <dj.davidjumani1994@gmail.com>
197 lines
6.3 KiB
JavaScript
197 lines
6.3 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 { shallowRef, defineAsyncComponent } from 'vue'
|
|
import store from '@/store'
|
|
|
|
export default {
|
|
name: 'cluster',
|
|
title: 'label.clusters',
|
|
icon: 'cluster-outlined',
|
|
permission: ['listClustersMetrics'],
|
|
columns: () => {
|
|
const fields = ['name', 'state', 'allocationstate', 'clustertype', 'hypervisortype', 'hosts']
|
|
const metricsFields = ['cpuused', 'cpumaxdeviation', 'cpuallocated', 'cputotal', 'memoryused', 'memorymaxdeviation', 'memoryallocated', 'memorytotal']
|
|
if (store.getters.metrics) {
|
|
fields.push(...metricsFields)
|
|
}
|
|
fields.push('podname')
|
|
fields.push('zonename')
|
|
return fields
|
|
},
|
|
details: ['name', 'id', 'allocationstate', 'clustertype', 'managedstate', 'hypervisortype', 'podname', 'zonename'],
|
|
related: [{
|
|
name: 'host',
|
|
title: 'label.hosts',
|
|
param: 'clusterid'
|
|
}],
|
|
resourceType: 'Cluster',
|
|
tabs: [{
|
|
name: 'details',
|
|
component: shallowRef(defineAsyncComponent(() => import('@/components/view/DetailsTab.vue')))
|
|
}, {
|
|
name: 'resources',
|
|
component: shallowRef(defineAsyncComponent(() => import('@/views/infra/Resources.vue')))
|
|
}, {
|
|
name: 'settings',
|
|
component: shallowRef(defineAsyncComponent(() => import('@/components/view/SettingsTab.vue')))
|
|
}, {
|
|
name: 'comments',
|
|
component: shallowRef(defineAsyncComponent(() => import('@/components/view/AnnotationsTab.vue')))
|
|
}],
|
|
actions: [
|
|
{
|
|
api: 'addCluster',
|
|
icon: 'plus-outlined',
|
|
label: 'label.add.cluster',
|
|
docHelp: 'adminguide/installguide/configuration.html#adding-a-cluster',
|
|
listView: true,
|
|
popup: true,
|
|
component: shallowRef(defineAsyncComponent(() => import('@/views/infra/ClusterAdd.vue')))
|
|
},
|
|
{
|
|
api: 'updateCluster',
|
|
icon: 'edit-outlined',
|
|
label: 'label.edit',
|
|
dataView: true,
|
|
args: ['clustername']
|
|
},
|
|
{
|
|
api: 'updateCluster',
|
|
icon: 'play-circle-outlined',
|
|
label: 'label.action.enable.cluster',
|
|
message: 'message.action.enable.cluster',
|
|
docHelp: 'adminguide/installguide/hosts.html#disabling-and-enabling-zones-pods-and-clusters',
|
|
dataView: true,
|
|
defaultArgs: { allocationstate: 'Enabled' },
|
|
show: (record) => { return record.allocationstate === 'Disabled' }
|
|
},
|
|
{
|
|
api: 'updateCluster',
|
|
icon: 'pause-circle-outlined',
|
|
label: 'label.action.disable.cluster',
|
|
message: 'message.action.disable.cluster',
|
|
docHelp: 'adminguide/installguide/hosts.html#disabling-and-enabling-zones-pods-and-clusters',
|
|
dataView: true,
|
|
defaultArgs: { allocationstate: 'Disabled' },
|
|
show: (record) => { return record.allocationstate === 'Enabled' }
|
|
},
|
|
{
|
|
api: 'updateCluster',
|
|
icon: 'plus-square-outlined',
|
|
label: 'label.action.manage.cluster',
|
|
message: 'message.action.manage.cluster',
|
|
dataView: true,
|
|
defaultArgs: { managedstate: 'Managed' },
|
|
show: (record) => { return record.managedstate !== 'Managed' }
|
|
},
|
|
{
|
|
api: 'updateCluster',
|
|
icon: 'minus-square-outlined',
|
|
label: 'label.action.unmanage.cluster',
|
|
message: 'message.action.unmanage.cluster',
|
|
dataView: true,
|
|
defaultArgs: { managedstate: 'Unmanaged' },
|
|
show: (record) => { return record.managedstate === 'Managed' }
|
|
},
|
|
{
|
|
api: 'enableOutOfBandManagementForCluster',
|
|
icon: 'plus-circle-outlined',
|
|
label: 'label.outofbandmanagement.enable',
|
|
message: 'label.outofbandmanagement.enable',
|
|
dataView: true,
|
|
show: (record) => {
|
|
return record?.resourcedetails?.outOfBandManagementEnabled === 'false'
|
|
},
|
|
args: ['clusterid'],
|
|
mapping: {
|
|
clusterid: {
|
|
value: (record) => { return record.id }
|
|
}
|
|
}
|
|
},
|
|
{
|
|
api: 'disableOutOfBandManagementForCluster',
|
|
icon: 'minus-circle-outlined',
|
|
label: 'label.outofbandmanagement.disable',
|
|
message: 'label.outofbandmanagement.disable',
|
|
dataView: true,
|
|
show: (record) => {
|
|
return !(record?.resourcedetails?.outOfBandManagementEnabled === 'false')
|
|
},
|
|
args: ['clusterid'],
|
|
mapping: {
|
|
clusterid: {
|
|
value: (record) => { return record.id }
|
|
}
|
|
}
|
|
},
|
|
{
|
|
api: 'enableHAForCluster',
|
|
icon: 'eye-outlined',
|
|
label: 'label.ha.enable',
|
|
message: 'label.ha.enable',
|
|
dataView: true,
|
|
show: (record) => {
|
|
return record?.resourcedetails?.resourceHAEnabled === 'false'
|
|
},
|
|
args: ['clusterid'],
|
|
mapping: {
|
|
clusterid: {
|
|
value: (record) => { return record.id }
|
|
}
|
|
}
|
|
},
|
|
{
|
|
api: 'disableHAForCluster',
|
|
icon: 'eye-invisible-outlined',
|
|
label: 'label.ha.disable',
|
|
message: 'label.ha.disable',
|
|
dataView: true,
|
|
show: (record) => {
|
|
return !(record?.resourcedetails?.resourceHAEnabled === 'false')
|
|
},
|
|
args: ['clusterid'],
|
|
mapping: {
|
|
clusterid: {
|
|
value: (record) => { return record.id }
|
|
}
|
|
}
|
|
},
|
|
{
|
|
api: 'startRollingMaintenance',
|
|
icon: 'setting-outlined',
|
|
label: 'label.start.rolling.maintenance',
|
|
message: 'label.start.rolling.maintenance',
|
|
dataView: true,
|
|
args: ['timeout', 'payload', 'forced', 'clusterids'],
|
|
mapping: {
|
|
clusterids: {
|
|
value: (record) => { return record.id }
|
|
}
|
|
}
|
|
},
|
|
{
|
|
api: 'deleteCluster',
|
|
icon: 'delete-outlined',
|
|
label: 'label.action.delete.cluster',
|
|
message: 'message.action.delete.cluster',
|
|
dataView: true
|
|
}
|
|
]
|
|
}
|