2022-05-25 23:26:05 +02:00
|
|
|
import { IUser } from 'interfaces/user';
|
|
|
|
import { useMemo } from 'react';
|
|
|
|
import { useInstanceStatus } from './api/getters/useInstanceStatus/useInstanceStatus';
|
|
|
|
import { InstancePlan } from 'interfaces/instance';
|
2023-02-22 20:50:29 +01:00
|
|
|
import useUiConfig from './api/getters/useUiConfig/useUiConfig';
|
2022-05-25 23:26:05 +02:00
|
|
|
|
|
|
|
export interface IUsersPlanOutput {
|
|
|
|
planUsers: IUser[];
|
|
|
|
isBillingUsers: boolean;
|
2023-03-01 08:49:14 +01:00
|
|
|
seats: number;
|
|
|
|
extraSeats: number;
|
2022-05-25 23:26:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
export const useUsersPlan = (users: IUser[]): IUsersPlanOutput => {
|
|
|
|
const { instanceStatus } = useInstanceStatus();
|
2023-02-22 20:50:29 +01:00
|
|
|
const { uiConfig } = useUiConfig();
|
2022-05-25 23:26:05 +02:00
|
|
|
|
2023-02-22 20:50:29 +01:00
|
|
|
const isBillingUsers = Boolean(
|
|
|
|
uiConfig?.flags?.proPlanAutoCharge &&
|
2023-10-02 14:25:46 +02:00
|
|
|
instanceStatus?.plan === InstancePlan.PRO,
|
2023-02-22 20:50:29 +01:00
|
|
|
);
|
2022-05-31 08:59:09 +02:00
|
|
|
const seats = instanceStatus?.seats ?? 5;
|
2022-05-25 23:26:05 +02:00
|
|
|
|
|
|
|
const planUsers = useMemo(
|
2022-05-31 08:59:09 +02:00
|
|
|
() => calculatePaidUsers(users, isBillingUsers, seats),
|
2023-10-02 14:25:46 +02:00
|
|
|
[users, isBillingUsers, seats],
|
2022-05-25 23:26:05 +02:00
|
|
|
);
|
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
const extraSeats = planUsers.filter((user) => user.paid).length;
|
2023-03-01 08:49:14 +01:00
|
|
|
|
2022-05-25 23:26:05 +02:00
|
|
|
return {
|
2023-03-01 08:49:14 +01:00
|
|
|
seats,
|
|
|
|
extraSeats,
|
2022-05-25 23:26:05 +02:00
|
|
|
planUsers,
|
|
|
|
isBillingUsers,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const calculatePaidUsers = (
|
|
|
|
users: IUser[],
|
|
|
|
isBillingUsers: boolean,
|
2023-10-02 14:25:46 +02:00
|
|
|
seats: number = 0,
|
2022-05-25 23:26:05 +02:00
|
|
|
) => {
|
|
|
|
if (!isBillingUsers || !seats) return users;
|
|
|
|
|
|
|
|
users
|
|
|
|
.sort((a, b) => a.createdAt.localeCompare(b.createdAt))
|
|
|
|
.forEach((user, index) => {
|
|
|
|
user.paid = false;
|
|
|
|
|
|
|
|
// If index is greater or equal to seat, the
|
|
|
|
// user isn't paid for and we will add use this
|
|
|
|
// to add costs and icons in the userlist
|
|
|
|
if (index >= seats) {
|
|
|
|
user.paid = true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
return users;
|
|
|
|
};
|