The commit modifies the teamAccountBillingPageLoader by swapping out the previously used Accounts API for the Team Accounts API. This change includes adjustments in the import statement and the creation of the api variable, aligning better with the team account related functionalities.
44 lines
1.4 KiB
TypeScript
44 lines
1.4 KiB
TypeScript
import 'server-only';
|
|
|
|
import { cache } from 'react';
|
|
|
|
import { z } from 'zod';
|
|
|
|
import { getSupabaseServerComponentClient } from '@kit/supabase/server-component-client';
|
|
import { createTeamAccountsApi } from '@kit/team-accounts/api';
|
|
|
|
/**
|
|
* The variable BILLING_MODE represents the billing mode for a service. It can
|
|
* have either the value 'subscription' or 'one-time'. If not provided, the default
|
|
* value is 'subscription'. The value can be overridden by the environment variable
|
|
* BILLING_MODE.
|
|
*
|
|
* If the value is 'subscription', we fetch the subscription data for the user.
|
|
* If the value is 'one-time', we fetch the orders data for the user.
|
|
* if none of these suits your needs, please override the below function.
|
|
*/
|
|
const BILLING_MODE = z
|
|
.enum(['subscription', 'one-time'])
|
|
.default('subscription')
|
|
.parse(process.env.BILLING_MODE);
|
|
|
|
/**
|
|
* @name loadTeamAccountBillingPage
|
|
* @description Load the team account billing page data for the given account.
|
|
*/
|
|
export const loadTeamAccountBillingPage = cache(teamAccountBillingPageLoader);
|
|
|
|
function teamAccountBillingPageLoader(accountId: string) {
|
|
const client = getSupabaseServerComponentClient();
|
|
const api = createTeamAccountsApi(client);
|
|
|
|
const data =
|
|
BILLING_MODE === 'subscription'
|
|
? api.getSubscription(accountId)
|
|
: api.getOrder(accountId);
|
|
|
|
const customerId = api.getCustomerId(accountId);
|
|
|
|
return Promise.all([data, customerId]);
|
|
}
|