From 6c67b9a8ef7b158d9c72ebc50ec4deff56b1a7cb Mon Sep 17 00:00:00 2001 From: Rohan Chaturvedi Date: Wed, 28 Aug 2024 13:10:05 +0530 Subject: [PATCH] fix: check for limits and usage from organisation.planDetail (#353) * fix: check for limits and usage from organisation.planDetail * fix: plan label alignment in sidebar menu --- frontend/components/apps/NewAppDialog.tsx | 22 ++++--------------- .../environments/CreateEnvironmentDialog.tsx | 14 +++++------- frontend/components/layout/Sidebar.tsx | 2 +- 3 files changed, 11 insertions(+), 27 deletions(-) diff --git a/frontend/components/apps/NewAppDialog.tsx b/frontend/components/apps/NewAppDialog.tsx index e30cb5317..a67e1b147 100644 --- a/frontend/components/apps/NewAppDialog.tsx +++ b/frontend/components/apps/NewAppDialog.tsx @@ -9,7 +9,6 @@ import { BulkProcessSecrets } from '@/graphql/mutations/environments/bulkProcess import { GetOrganisationAdminsAndSelf } from '@/graphql/queries/organisation/getOrganisationAdminsAndSelf.gql' import { InitAppEnvironments } from '@/graphql/mutations/environments/initAppEnvironments.gql' import { GetAppEnvironments } from '@/graphql/queries/secrets/getAppEnvironments.gql' -import { GetOrganisationPlan } from '@/graphql/queries/organisation/getOrganisationPlan.gql' import { useLazyQuery, useMutation, useQuery } from '@apollo/client' import { ApiEnvironmentEnvTypeChoices, @@ -67,13 +66,6 @@ const NewAppDialog = forwardRef( skip: !organisation, }) - const { data: orgPlanData } = useQuery(GetOrganisationPlan, { - variables: { - organisationId: organisation?.id, - }, - skip: !organisation, - }) - const [createSuccess, setCreateSuccess] = useState(false) const { keyring } = useContext(KeyringContext) @@ -397,14 +389,8 @@ const NewAppDialog = forwardRef( } const allowNewApp = () => { - if ( - organisation.plan === ApiOrganisationPlanChoices.Fr || - organisation.plan === ApiOrganisationPlanChoices.Pr - ) { - return appCount < orgPlanData?.organisationPlan.maxApps - } else if (organisation.plan === ApiOrganisationPlanChoices.En) { - return true - } + if (!organisation.planDetail?.maxApps) return true + return appCount < organisation.planDetail?.maxApps } const planDisplay = () => { @@ -412,13 +398,13 @@ const NewAppDialog = forwardRef( return { planName: 'Free', dialogTitle: 'Upgrade to Pro', - description: `The Free plan is limited to ${orgPlanData?.organisationPlan.maxApps} Apps. To create more Apps, please upgrade to Pro.`, + description: `The Free plan is limited to ${organisation.planDetail?.maxApps} Apps. To create more Apps, please upgrade to Pro.`, } else if (organisation.plan === ApiOrganisationPlanChoices.Pr) return { planName: 'Pro', dialogTitle: 'Upgrade to Enterprise', - description: `The Pro plan is limited to ${orgPlanData?.organisationPlan.maxApps} Apps. To create more Apps, please upgrade to Enterprise.`, + description: `The Pro plan is limited to ${organisation.planDetail?.maxApps} Apps. To create more Apps, please upgrade to Enterprise.`, } } diff --git a/frontend/components/environments/CreateEnvironmentDialog.tsx b/frontend/components/environments/CreateEnvironmentDialog.tsx index 9f72e47ac..b3d562848 100644 --- a/frontend/components/environments/CreateEnvironmentDialog.tsx +++ b/frontend/components/environments/CreateEnvironmentDialog.tsx @@ -11,9 +11,7 @@ import { Button } from '../common/Button' import { Input } from '../common/Input' import { GetAppEnvironments } from '@/graphql/queries/secrets/getAppEnvironments.gql' import { toast } from 'react-toastify' -import { UpgradeRequestForm } from '../forms/UpgradeRequestForm' import Spinner from '../common/Spinner' -import { isCloudHosted } from '@/utils/appConfig' import { Alert } from '../common/Alert' import { UpsellDialog } from '../settings/organisation/UpsellDialog' @@ -36,10 +34,10 @@ export const CreateEnvironmentDialog = (props: { appId: string }) => { const isLoading = orgAdminsDataLoading || appDataLoading - const allowNewEnv = organisation - ? !organisation.planDetail!.maxEnvsPerApp || - organisation.planDetail!.maxEnvsPerApp! > appData?.appEnvironments.length - : false + const allowNewEnv = () => { + if (!organisation?.planDetail?.maxEnvsPerApp) return true + return appData?.appEnvironments.length < organisation.planDetail?.maxEnvsPerApp + } const planDisplay = () => { if (organisation?.plan === ApiOrganisationPlanChoices.Fr) @@ -103,7 +101,7 @@ export const CreateEnvironmentDialog = (props: { appId: string }) => { ) - if (!allowNewEnv) + if (!allowNewEnv()) return ( { return ( {}} buttonVariant={'outline'} diff --git a/frontend/components/layout/Sidebar.tsx b/frontend/components/layout/Sidebar.tsx index d06e6859e..260e20049 100644 --- a/frontend/components/layout/Sidebar.tsx +++ b/frontend/components/layout/Sidebar.tsx @@ -60,7 +60,7 @@ const Sidebar = () => { const OrgsMenu = () => { const OrgLabel = () => (
-
+