Newer
Older
<div>
<GroupsBreadcrumb />
<b-card no-body>
<b-tabs content-class="mt-3" card v-on:input="tabChanged" v-model="input.tabIndex">
<GroupsPanel />
<MembersPanel />
<PermissionsPanel />
<template slot="tabs-end">
<b-button variant="primary" class="in-tabs-header-btn" v-if="showAddGroupBtn" v-on:click="openAddGroupModal">Add group</b-button>
<b-button variant="primary" class="in-tabs-header-btn" v-if="showAddMemberBtn" v-on:click="openAddMemberModal">Add member</b-button>
<b-button variant="primary" class="in-tabs-header-btn" v-if="showAddCollaboratorBtn" v-on:click="openAddMemberModal">Add collaborator</b-button>
<b-button variant="primary" class="in-tabs-header-btn" v-if="showAddPermissionBtn" v-on:click="openAddPermissionModal">Add permission</b-button>
</template>
</b-tabs>
</b-card>
<AddGroupModal />
<AddMemberModal />
<AddPermissionModal />
</div>
</template>
<script>
import GroupsBreadcrumb from './GroupsBreadcrumb.vue'
import GroupsPanel from './GroupsPanel.vue'
import MembersPanel from './MembersPanel.vue'
import PermissionsPanel from './PermissionsPanel.vue'
import AddGroupModal from './modals/AddGroupModal.vue'
import AddMemberModal from './modals/AddMemberModal.vue'
import AddPermissionModal from './modals/AddPermissionModal.vue'
import {
mapState
} from 'vuex';
Sonia Zorba
committed
import client from 'api-client';
export default {
name: 'Main',
components: {
GroupsBreadcrumb,
GroupsPanel,
MembersPanel,
AddGroupModal,
computed: mapState({
Sonia Zorba
committed
input: state => state.input,
showAddMemberBtn: state => state.model.permission === 'ADMIN' && state.input.tabIndex === 1,
showAddCollaboratorBtn: state => state.model.permission === 'MANAGE_MEMBERS' && state.input.tabIndex === 1,
showAddGroupBtn: state => state.model.permission === 'ADMIN' && state.input.tabIndex === 0,
showAddPermissionBtn: state => state.model.permission === 'ADMIN' && state.input.tabIndex === 2
// reset paginator
this.input.paginatorPage = 1;
client.fetchGroupsTab(this.input)
.then(model => {
this.$store.commit('updateGroups', model);
});
client.fetchMembersPanel(this.input)
.then(panel => {
this.$store.commit('updateMembersPanel', panel);
});
client.fetchPermissionsPanel(this.input)
.then(panel => {
this.$store.commit('updatePermissionsPanel', panel);
});
this.$bvModal.show('add-group-modal');
this.$bvModal.show('add-member-modal');
},
openAddPermissionModal: function() {
this.$bvModal.show('add-permission-modal');
.in-tabs-header-btn {
position: absolute;
right: 8px;
top: 8px;
}