123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { useDateFormat } from '@vueuse/shared'
- import { computed, toValue, type MaybeRef } from 'vue'
- import type {
- AvatarUser,
- AvatarUserAccess,
- AvatarUserLive,
- } from '#shared/components/CommonUserAvatar/types.ts'
- import { EnumTaskbarApp } from '#shared/graphql/types.ts'
- import { i18n } from '#shared/i18n.ts'
- import { useAppName } from './useAppName.ts'
- import { useReactiveNow } from './useReactiveNow.ts'
- export const useAvatarIndicator = (
- entity: MaybeRef<AvatarUser>,
- personal?: MaybeRef<boolean>,
- live?: MaybeRef<AvatarUserLive | undefined>,
- access?: MaybeRef<AvatarUserAccess | undefined>,
- ) => {
- const appName = useAppName()
- const currentDate = useReactiveNow()
- const isOutOfOffice = computed(() => {
- const user = toValue(entity)
- if (user.outOfOffice && user.outOfOfficeStartAt && user.outOfOfficeEndAt) {
- const today = useDateFormat(currentDate.value, 'YYYY-MM-DD')
- const startDate = user.outOfOfficeStartAt
- const endDate = user.outOfOfficeEndAt
- return startDate <= today.value && endDate >= today.value // Today is between start and end date
- }
- return false
- })
- const isInactive = computed(() => toValue(entity).active === false)
- const isWithoutAccess = computed(
- () => toValue(access)?.agentReadAccess === false,
- )
- const isLiveUserIdle = computed(() => toValue(live)?.isIdle)
- const isLiveUserEditing = computed(() => toValue(live)?.editing)
- const isLiveUserDesktop = computed(
- () => toValue(live)?.app === EnumTaskbarApp.Desktop,
- )
- const isLiveUserMobile = computed(
- () => toValue(live)?.app === EnumTaskbarApp.Mobile,
- )
- const indicatorIcon = computed(() => {
- if (isInactive.value) return 'avatar-indicator-inactive'
- if (isWithoutAccess.value) return 'avatar-indicator-without-access'
- if (isOutOfOffice.value) return 'avatar-indicator-out-of-office'
- if (isLiveUserEditing.value && isLiveUserDesktop.value)
- return 'avatar-indicator-editing-desktop'
- if (isLiveUserEditing.value && isLiveUserMobile.value)
- return 'avatar-indicator-editing-mobile'
- if (isLiveUserDesktop.value && appName !== 'desktop')
- return 'avatar-indicator-desktop'
- if (isLiveUserMobile.value && appName !== 'mobile')
- return 'avatar-indicator-mobile'
- if (isLiveUserIdle.value) return 'avatar-indicator-idle'
- return null
- })
- const indicatorLabel = computed(() => {
- if (isInactive.value) return i18n.t('User is inactive')
- if (isWithoutAccess.value) return i18n.t('User has no access')
- if (isOutOfOffice.value && toValue(personal))
- return i18n.t('Out of office active')
- if (isOutOfOffice.value) return i18n.t('User is out of office')
- if (isLiveUserEditing.value && isLiveUserDesktop.value)
- return i18n.t('User is editing on desktop')
- if (isLiveUserEditing.value && isLiveUserMobile.value)
- return i18n.t('User is editing on mobile')
- if (isLiveUserEditing.value) return i18n.t('User is editing')
- if (isLiveUserDesktop.value && appName !== 'desktop')
- return i18n.t('User is on desktop')
- if (isLiveUserMobile.value && appName !== 'mobile')
- return i18n.t('User is on mobile')
- if (isLiveUserIdle.value) return i18n.t('User is idle')
- return undefined
- })
- const indicatorIsIdle = computed(
- () =>
- isInactive.value ||
- isOutOfOffice.value ||
- isWithoutAccess.value ||
- isLiveUserIdle.value,
- )
- return {
- isInactive,
- isLiveUserDesktop,
- isLiveUserEditing,
- isLiveUserIdle,
- isLiveUserMobile,
- isOutOfOffice,
- isWithoutAccess,
- indicatorIcon,
- indicatorLabel,
- indicatorIsIdle,
- }
- }
|