mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
164 lines
5.8 KiB
JavaScript
164 lines
5.8 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 store from '@/store'
|
|
|
|
export default {
|
|
name: 'project',
|
|
title: 'label.projects',
|
|
icon: 'project',
|
|
docHelp: 'adminguide/projects.html',
|
|
permission: ['listProjects'],
|
|
resourceType: 'Project',
|
|
columns: ['name', 'state', 'displaytext', 'account', 'domain'],
|
|
searchFilters: ['name', 'displaytext', 'domainid', 'account'],
|
|
details: ['name', 'id', 'displaytext', 'projectaccountname', 'account', 'domain'],
|
|
tabs: [
|
|
{
|
|
name: 'details',
|
|
component: () => import('@/views/project/ProjectDetailsTab.vue')
|
|
},
|
|
{
|
|
name: 'accounts',
|
|
component: () => import('@/views/project/AccountsTab.vue'),
|
|
show: (record, route, user) => { return ['Admin', 'DomainAdmin'].includes(user.roletype) || record.isCurrentUserProjectAdmin }
|
|
},
|
|
{
|
|
name: 'project.roles',
|
|
component: () => import('@/views/project/iam/ProjectRoleTab.vue'),
|
|
show: (record, route, user) => {
|
|
return (['Admin', 'DomainAdmin'].includes(user.roletype) || record.isCurrentUserProjectAdmin) &&
|
|
'listProjectRoles' in store.getters.apis
|
|
}
|
|
},
|
|
{
|
|
name: 'resources',
|
|
component: () => import('@/components/view/ResourceCountUsage.vue')
|
|
},
|
|
{
|
|
name: 'limits',
|
|
show: (record, route, user) => { return ['Admin', 'DomainAdmin'].includes(user.roletype) },
|
|
component: () => import('@/components/view/ResourceLimitTab.vue')
|
|
}
|
|
],
|
|
actions: [
|
|
{
|
|
api: 'createProject',
|
|
icon: 'plus',
|
|
label: 'label.new.project',
|
|
docHelp: 'adminguide/projects.html#creating-a-new-project',
|
|
listView: true,
|
|
args: ['name', 'displaytext']
|
|
},
|
|
{
|
|
api: 'updateProjectInvitation',
|
|
icon: 'key',
|
|
label: 'label.enter.token',
|
|
docHelp: 'adminguide/projects.html#accepting-a-membership-invitation',
|
|
listView: true,
|
|
popup: true,
|
|
show: (record, store) => { return store.features.projectinviterequired },
|
|
component: () => import('@/views/project/InvitationTokenTemplate.vue')
|
|
},
|
|
{
|
|
api: 'listProjectInvitations',
|
|
icon: 'team',
|
|
label: 'label.project.invitation',
|
|
docHelp: 'adminguide/projects.html#accepting-a-membership-invitation',
|
|
listView: true,
|
|
popup: true,
|
|
showBadge: true,
|
|
badgeNum: 0,
|
|
param: {
|
|
state: 'Pending'
|
|
},
|
|
show: (record, store) => { return store.features.projectinviterequired },
|
|
component: () => import('@/views/project/InvitationsTemplate.vue')
|
|
},
|
|
{
|
|
api: 'updateProject',
|
|
icon: 'edit',
|
|
label: 'label.edit.project.details',
|
|
dataView: true,
|
|
args: ['displaytext'],
|
|
show: (record, store) => {
|
|
return (['Admin', 'DomainAdmin'].includes(store.userInfo.roletype)) || record.isCurrentUserProjectAdmin
|
|
}
|
|
},
|
|
{
|
|
api: 'activateProject',
|
|
icon: 'play-circle',
|
|
label: 'label.activate.project',
|
|
message: 'message.activate.project',
|
|
dataView: true,
|
|
show: (record, store) => {
|
|
return ((['Admin', 'DomainAdmin'].includes(store.userInfo.roletype)) || record.isCurrentUserProjectAdmin) && record.state === 'Suspended'
|
|
},
|
|
groupAction: true,
|
|
popup: true,
|
|
groupMap: (selection) => { return selection.map(x => { return { id: x } }) }
|
|
},
|
|
{
|
|
api: 'suspendProject',
|
|
icon: 'pause-circle',
|
|
label: 'label.suspend.project',
|
|
message: 'message.suspend.project',
|
|
docHelp: 'adminguide/projects.html#sending-project-membership-invitations',
|
|
dataView: true,
|
|
show: (record, store) => {
|
|
return ((['Admin', 'DomainAdmin'].includes(store.userInfo.roletype)) ||
|
|
record.isCurrentUserProjectAdmin) && record.state !== 'Suspended'
|
|
},
|
|
groupAction: true,
|
|
popup: true,
|
|
groupMap: (selection) => { return selection.map(x => { return { id: x } }) }
|
|
},
|
|
{
|
|
api: 'addAccountToProject',
|
|
icon: 'user-add',
|
|
label: 'label.action.project.add.account',
|
|
docHelp: 'adminguide/projects.html#adding-project-members-from-the-ui',
|
|
dataView: true,
|
|
popup: true,
|
|
show: (record, store) => {
|
|
return (['Admin', 'DomainAdmin'].includes(store.userInfo.roletype)) || record.isCurrentUserProjectAdmin
|
|
},
|
|
component: () => import('@/views/project/AddAccountOrUserToProject.vue')
|
|
},
|
|
{
|
|
api: 'deleteProject',
|
|
icon: 'delete',
|
|
label: 'label.delete.project',
|
|
message: 'message.delete.project',
|
|
docHelp: 'adminguide/projects.html#suspending-or-deleting-a-project',
|
|
dataView: true,
|
|
show: (record, store) => {
|
|
return (['Admin', 'DomainAdmin'].includes(store.userInfo.roletype)) || record.isCurrentUserProjectAdmin
|
|
},
|
|
groupAction: true,
|
|
popup: true,
|
|
groupMap: (selection) => { return selection.map(x => { return { id: x } }) },
|
|
args: (record, store) => {
|
|
const fields = []
|
|
if (store.apis.deleteProject.params.filter(x => x.name === 'cleanup').length > 0) {
|
|
fields.push('cleanup')
|
|
}
|
|
return fields
|
|
}
|
|
}
|
|
]
|
|
}
|