123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { ref, type Ref, watch } from 'vue'
- import { useReactiveNow } from '#shared/composables/useReactiveNow.ts'
- import type { TicketLiveAppUser } from '../types.ts'
- // Default idle time from 5 minutes.
- const IDLE_TIME_MS = 5 * 60 * 1000
- export const useTicketLiveUsersDisplay = (
- liveUserList: Ref<TicketLiveAppUser[]>,
- ) => {
- const liveUsers = ref<TicketLiveAppUser[]>([])
- const viewingUsers = ref<TicketLiveAppUser[]>([])
- const idleUsers = ref<TicketLiveAppUser[]>([])
- const reactiveNow = useReactiveNow()
- watch(
- [liveUserList, reactiveNow],
- () => {
- const localLiveUsers: TicketLiveAppUser[] = []
- liveUserList.value?.forEach((liveUser) => {
- if (
- liveUser.lastInteraction &&
- new Date(liveUser.lastInteraction).getTime() + IDLE_TIME_MS <
- reactiveNow.value.getTime()
- ) {
- localLiveUsers.push({
- user: liveUser.user,
- editing: liveUser.editing,
- app: liveUser.app,
- isIdle: true,
- })
- } else {
- localLiveUsers.push({
- user: liveUser.user,
- editing: liveUser.editing,
- app: liveUser.app,
- isIdle: false,
- })
- }
- })
- liveUsers.value = localLiveUsers
- viewingUsers.value = localLiveUsers.filter((user) => !user.isIdle)
- idleUsers.value = localLiveUsers.filter((user) => user.isIdle)
- },
- { immediate: true },
- )
- return {
- liveUsers,
- viewingUsers,
- idleUsers,
- }
- }
|