1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- <!-- Copyright (C) 2012-2024 Zammad Foundation, https://zammad-foundation.org/ -->
- <script setup lang="ts">
- import { computed } from 'vue'
- import CommonOrganizationAvatar from '#shared/components/CommonOrganizationAvatar/CommonOrganizationAvatar.vue'
- import type { AvatarOrganization } from '#shared/components/CommonOrganizationAvatar/index.ts'
- import ObjectAttributes from '#shared/components/ObjectAttributes/ObjectAttributes.vue'
- import { useOnlineNotificationSeen } from '#shared/composables/useOnlineNotificationSeen.ts'
- import CommonLoader from '#mobile/components/CommonLoader/CommonLoader.vue'
- import CommonTicketStateList from '#mobile/components/CommonTicketStateList/CommonTicketStateList.vue'
- import OrganizationMembersList from '#mobile/components/Organization/OrganizationMembersList.vue'
- import { useHeader } from '#mobile/composables/useHeader.ts'
- import { useOrganizationDetail } from '#mobile/entities/organization/composables/useOrganizationDetail.ts'
- import { useOrganizationEdit } from '#mobile/entities/organization/composables/useOrganizationEdit.ts'
- import { useOrganizationTicketsCount } from '#mobile/entities/organization/composables/useOrganizationTicketsCount.ts'
- interface Props {
- internalId: number
- }
- const props = defineProps<Props>()
- const {
- organization,
- loading,
- objectAttributes,
- organizationQuery,
- loadAllMembers,
- loadOrganization,
- } = useOrganizationDetail()
- loadOrganization(props.internalId)
- useOnlineNotificationSeen(organization)
- const { openEditOrganizationDialog } = useOrganizationEdit()
- useHeader({
- title: __('Organization'),
- backUrl: '/',
- actionTitle: __('Edit'),
- actionHidden: computed(
- () => organization.value == null || !organization.value.policy.update,
- ),
- refetch: computed(
- () => organization.value != null && organizationQuery.loading().value,
- ),
- onAction() {
- if (!organization.value || !organization.value.policy.update) return
- openEditOrganizationDialog(organization.value)
- },
- })
- const { getTicketData } = useOrganizationTicketsCount()
- const ticketData = computed(() => getTicketData(organization.value))
- </script>
- <template>
- <div v-if="organization" class="px-4">
- <div class="flex flex-col items-center justify-center py-6">
- <div>
- <CommonOrganizationAvatar
- :entity="organization as AvatarOrganization"
- size="xl"
- />
- </div>
- <div class="mt-2 text-xl font-bold">
- {{ organization.name }}
- </div>
- </div>
- <ObjectAttributes
- :object="organization"
- :attributes="objectAttributes"
- :skip-attributes="['name']"
- />
- <OrganizationMembersList
- :organization="organization"
- :disable-show-more="loading"
- @load-more="loadAllMembers()"
- />
- <CommonTicketStateList
- v-if="ticketData"
- :create-link="ticketData.createLink"
- :create-label="ticketData.createLabel"
- :counts="ticketData.count"
- :tickets-link-query="ticketData.query"
- />
- </div>
- <CommonLoader v-else-if="loading" class="w-full p-4" :loading="loading" />
- </template>
|