blob: a5370e28ef9340f363f305ec75bebb5076c8eb4e [file] [log] [blame]
// 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: 'project',
title: 'label.projects',
icon: 'project-outlined',
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: shallowRef(defineAsyncComponent(() => import('@/views/project/ProjectDetailsTab.vue')))
},
{
name: 'accounts',
component: shallowRef(defineAsyncComponent(() => import('@/views/project/AccountsTab.vue'))),
show: (record, route, user) => { return ['Admin', 'DomainAdmin'].includes(user.roletype) || record.isCurrentUserProjectAdmin }
},
{
name: 'project.roles',
component: shallowRef(defineAsyncComponent(() => import('@/views/project/iam/ProjectRoleTab.vue'))),
show: (record, route, user) => {
return (['Admin', 'DomainAdmin'].includes(user.roletype) || record.isCurrentUserProjectAdmin) &&
'listProjectRoles' in store.getters.apis
}
},
{
name: 'limits',
component: shallowRef(defineAsyncComponent(() => import('@/components/view/ResourceCountUsage.vue')))
},
{
name: 'limits.configure',
show: (record, route, user) => { return ['Admin', 'DomainAdmin'].includes(user.roletype) },
component: shallowRef(defineAsyncComponent(() => import('@/components/view/ResourceLimitTab.vue')))
},
{
name: 'events',
resourceType: 'Project',
component: shallowRef(defineAsyncComponent(() => import('@/components/view/EventsTab.vue'))),
show: () => { return 'listEvents' in store.getters.apis }
}
],
actions: [
{
api: 'createProject',
icon: 'plus-outlined',
label: 'label.new.project',
docHelp: 'adminguide/projects.html#creating-a-new-project',
listView: true,
args: ['name', 'displaytext']
},
{
api: 'updateProjectInvitation',
icon: 'key-outlined',
label: 'label.enter.token',
docHelp: 'adminguide/projects.html#accepting-a-membership-invitation',
listView: true,
popup: true,
show: (record, store) => { return store.features.projectinviterequired },
component: shallowRef(defineAsyncComponent(() => import('@/views/project/InvitationTokenTemplate.vue')))
},
{
api: 'listProjectInvitations',
icon: 'team-outlined',
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: shallowRef(defineAsyncComponent(() => import('@/views/project/InvitationsTemplate.vue')))
},
{
api: 'updateProject',
icon: 'edit-outlined',
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-outlined',
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-outlined',
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-outlined',
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: shallowRef(defineAsyncComponent(() => import('@/views/project/AddAccountOrUserToProject.vue')))
},
{
api: 'deleteProject',
icon: 'delete-outlined',
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) && record.id !== store.project.id
},
groupAction: true,
popup: true,
groupMap: (selection, values) => { return selection.map(x => { return { id: x, cleanup: values.cleanup || null } }) },
args: (record, store) => {
const fields = []
if (store.apis.deleteProject.params.filter(x => x.name === 'cleanup').length > 0) {
fields.push('cleanup')
}
return fields
}
}
]
}