RocketChat/Rocket.Chat

View on GitHub
apps/meteor/client/views/admin/engagementDashboard/users/useActiveUsers.ts

Summary

Maintainability
A
0 mins
Test Coverage
import { useEndpoint } from '@rocket.chat/ui-contexts';
import { useQuery } from '@tanstack/react-query';

import { getPeriodRange } from '../../../../components/dashboards/periods';

type UseActiveUsersOptions = { utc: boolean };

// eslint-disable-next-line @typescript-eslint/explicit-function-return-type
export const useActiveUsers = ({ utc }: UseActiveUsersOptions) => {
    const getActiveUsers = useEndpoint('GET', '/v1/engagement-dashboard/users/active-users');

    return useQuery(
        ['admin/engagement-dashboard/users/active', { utc }],
        async () => {
            const { start, end } = getPeriodRange('last 30 days', utc);

            const response = await getActiveUsers({
                start: start.toISOString(),
                end: end.toISOString(),
            });

            return response
                ? {
                        ...response,
                        start,
                        end,
                  }
                : undefined;
        },
        {
            refetchInterval: 5 * 60 * 1000,
            useErrorBoundary: true,
        },
    );
};