// 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 } } ] }