Skip to content

Commit

Permalink
fix(sdk): remove fetch plan from confirm-change (#779)
Browse files Browse the repository at this point in the history
* fix: remove additional API call and fetch data from props

* chore: remove console.log

* fix: update plans fetch

* chore: rearrange imports

* chore: remove extra comma

---------

Co-authored-by: Rishabh Mishra <[email protected]>
  • Loading branch information
paanSinghCoder and rsbh authored Sep 20, 2024
1 parent b9c0207 commit 0c636c6
Show file tree
Hide file tree
Showing 3 changed files with 14 additions and 18 deletions.
Original file line number Diff line number Diff line change
@@ -1,21 +1,21 @@
import { useCallback, useEffect, useMemo, useState } from 'react';
import { Dialog, Flex, Text, Image, Separator, Button } from '@raystack/apsara';
import styles from '../../organization.module.css';
import Skeleton from 'react-loading-skeleton';
import { useNavigate, useParams } from '@tanstack/react-router';
import * as _ from 'lodash';
import cross from '~/react/assets/cross.svg';
import { useFrontier } from '~/react/contexts/FrontierContext';
import { useCallback, useEffect, useState } from 'react';
import dayjs from 'dayjs';
import {
DEFAULT_DATE_FORMAT,
DEFAULT_PLAN_UPGRADE_MESSAGE
} from '~/react/utils/constants';
import { V1Beta1Plan } from '~/src';
import Skeleton from 'react-loading-skeleton';
import { getPlanChangeAction, getPlanNameWithInterval } from '~/react/utils';
import planStyles from '../plans.module.css';
import { usePlans } from '../hooks/usePlans';
import { toast } from 'sonner';
import * as _ from 'lodash';
import styles from '../../organization.module.css';

export default function ConfirmPlanChange() {
const navigate = useNavigate({ from: '/plans/confirm-change/$planId' });
Expand All @@ -25,7 +25,6 @@ export default function ConfirmPlanChange() {
isActivePlanLoading,
config,
client,
fetchActiveSubsciption,
activeSubscription,
basePlan,
allPlans
Expand All @@ -42,6 +41,8 @@ export default function ConfirmPlanChange() {
checkBasePlan
} = usePlans();

const currentPlan = useMemo(() => allPlans.find((plan) => plan.id === planId), [ allPlans, planId ])

const isNewPlanBasePlan = checkBasePlan(planId);

const newPlanMetadata = newPlan?.metadata as Record<string, number>;
Expand All @@ -54,10 +55,6 @@ export default function ConfirmPlanChange() {

const cancel = useCallback(() => navigate({ to: '/plans' }), [navigate]);

useEffect(() => {
fetchActiveSubsciption();
}, [fetchActiveSubsciption]);

const planChangeSlug =
activePlan?.name && newPlan?.name
? `${activePlan?.name}:${newPlan?.name}`
Expand Down Expand Up @@ -115,13 +112,12 @@ export default function ConfirmPlanChange() {
]);

const getPlan = useCallback(
async (planId: string) => {
() => {
setIsNewPlanLoading(true);
try {
const resp = isNewPlanBasePlan
? { data: { plan: basePlan } }
: await client?.frontierServiceGetPlan(planId);
const plan = resp?.data?.plan;
const plan = isNewPlanBasePlan
? basePlan
: currentPlan
if (plan) {
setNewPlan(plan);
}
Expand All @@ -139,7 +135,7 @@ export default function ConfirmPlanChange() {

useEffect(() => {
if (planId) {
getPlan(planId);
getPlan();
}
}, [getPlan, planId]);

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { V1Beta1Feature, V1Beta1Plan } from '~/src';
import { V1Beta1Plan } from '~/src';
import {
IntervalKeys,
IntervalPricing,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,9 +1,10 @@
import Skeleton from 'react-loading-skeleton';
import { useNavigate } from '@tanstack/react-router';
import { useFrontier } from '~/react/contexts/FrontierContext';
import dayjs from 'dayjs';
import { toast } from 'sonner';
import * as _ from 'lodash';
import { memo, useCallback, useEffect, useMemo, useState } from 'react';
import { useCallback, useEffect, useMemo, useState } from 'react';

import { Button, Flex, Text, ToggleGroup, Image } from '@raystack/apsara';
import {
Expand All @@ -23,7 +24,6 @@ import checkCircle from '~/react/assets/check-circle.svg';
import Amount from '~/react/components/helpers/Amount';

import plansStyles from './plans.module.css';
import Skeleton from 'react-loading-skeleton';

interface PricingColumnHeaderProps {
plan: PlanIntervalPricing;
Expand Down

0 comments on commit 0c636c6

Please sign in to comment.