mirror of https://github.com/nextcloud/contacts
157 lines
4.1 KiB
Vue
157 lines
4.1 KiB
Vue
<!--
|
|
- @copyright Copyright (c) 2021 John Molakvoæ <skjnldsv@protonmail.com>
|
|
-
|
|
- @author John Molakvoæ <skjnldsv@protonmail.com>
|
|
-
|
|
- @license GNU AGPL version 3 or any later version
|
|
-
|
|
- This program is free software: you can redistribute it and/or modify
|
|
- it under the terms of the GNU Affero General Public License as
|
|
- published by the Free Software Foundation, either version 3 of the
|
|
- License, or (at your option) any later version.
|
|
-
|
|
- This program is distributed in the hope that it will be useful,
|
|
- but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
- GNU Affero General Public License for more details.
|
|
-
|
|
- You should have received a copy of the GNU Affero General Public License
|
|
- along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
-
|
|
-->
|
|
<template>
|
|
<AppNavigationItem :key="circle.key"
|
|
:name="circle.displayName"
|
|
:to="circle.router">
|
|
<template #icon>
|
|
<AccountStar v-if="circle.isOwner" :size="20" />
|
|
<AccountGroup v-else-if="circle.isMember" :size="20" />
|
|
<AccountGroupOutline v-else :size="20" />
|
|
</template>
|
|
<template v-if="loadingAction" slot="actions">
|
|
<ActionText>
|
|
<template #icon>
|
|
<IconLoading :size="20" />
|
|
</template>
|
|
{{ t('contacts', 'Loading …') }}
|
|
</ActionText>
|
|
</template>
|
|
|
|
<template v-else slot="actions">
|
|
<ActionButton v-if="circle.canManageMembers"
|
|
:close-after-click="true"
|
|
@click="addMemberToCircle">
|
|
<template #icon>
|
|
<IconAdd :size="20" />
|
|
</template>
|
|
{{ t('contacts', 'Add member') }}
|
|
</ActionButton>
|
|
|
|
<!-- copy circle link -->
|
|
<ActionLink :href="circleUrl"
|
|
:icon="copyLinkIcon"
|
|
@click.stop.prevent="copyToClipboard(circleUrl)">
|
|
{{ copyButtonText }}
|
|
</ActionLink>
|
|
|
|
<!-- leave circle -->
|
|
<ActionButton v-if="circle.canLeave"
|
|
@click="confirmLeaveCircle">
|
|
{{ t('contacts', 'Leave team') }}
|
|
<ExitToApp slot="icon"
|
|
:size="16"
|
|
decorative />
|
|
</ActionButton>
|
|
|
|
<!-- join circle -->
|
|
<ActionButton v-else-if="!circle.isMember && circle.canJoin"
|
|
:disabled="loadingJoin"
|
|
@click="joinCircle">
|
|
{{ joinButtonTitle }}
|
|
<LocationEnter slot="icon"
|
|
:size="16"
|
|
decorative />
|
|
</ActionButton>
|
|
|
|
<!-- delete circle -->
|
|
<ActionButton v-if="circle.canDelete"
|
|
@click="confirmDeleteCircle">
|
|
<template #icon>
|
|
<IconDelete :size="20" />
|
|
</template>
|
|
{{ t('contacts', 'Delete team') }}
|
|
</ActionButton>
|
|
</template>
|
|
|
|
<template #counter>
|
|
<NcCounterBubble v-if="memberCount > 0">
|
|
{{ memberCount }}
|
|
</NcCounterBubble>
|
|
</template>
|
|
</AppNavigationItem>
|
|
</template>
|
|
|
|
<script>
|
|
import {
|
|
NcActionButton as ActionButton,
|
|
NcActionLink as ActionLink,
|
|
NcActionText as ActionText,
|
|
NcCounterBubble,
|
|
NcAppNavigationItem as AppNavigationItem,
|
|
NcLoadingIcon as IconLoading,
|
|
} from '@nextcloud/vue'
|
|
|
|
import ExitToApp from 'vue-material-design-icons/ExitToApp.vue'
|
|
import IconAdd from 'vue-material-design-icons/Plus.vue'
|
|
import IconDelete from 'vue-material-design-icons/Delete.vue'
|
|
import LocationEnter from 'vue-material-design-icons/LocationEnter.vue'
|
|
import AccountStar from 'vue-material-design-icons/AccountStar.vue'
|
|
import AccountGroup from 'vue-material-design-icons/AccountGroup.vue'
|
|
import AccountGroupOutline from 'vue-material-design-icons/AccountGroupOutline.vue'
|
|
|
|
import Circle from '../../models/circle.ts'
|
|
import CircleActionsMixin from '../../mixins/CircleActionsMixin.js'
|
|
|
|
export default {
|
|
name: 'CircleNavigationItem',
|
|
|
|
components: {
|
|
ActionButton,
|
|
ActionLink,
|
|
ActionText,
|
|
NcCounterBubble,
|
|
AppNavigationItem,
|
|
ExitToApp,
|
|
IconAdd,
|
|
IconDelete,
|
|
LocationEnter,
|
|
AccountStar,
|
|
AccountGroup,
|
|
AccountGroupOutline,
|
|
IconLoading,
|
|
},
|
|
|
|
mixins: [CircleActionsMixin],
|
|
|
|
props: {
|
|
circle: {
|
|
type: Circle,
|
|
required: true,
|
|
},
|
|
},
|
|
|
|
computed: {
|
|
memberCount() {
|
|
const count = Object.keys(this.circle?.members || []).length
|
|
|
|
// If member list is empty, let's try the population initial count
|
|
if (count === 0 && this.circle.population > 0) {
|
|
return this.circle.population
|
|
}
|
|
|
|
return count
|
|
},
|
|
},
|
|
}
|
|
</script>
|