import { organizationQueryKeys } from "@better-auth-ui/core/plugins" import { type DataTag, type QueryClient, queryOptions } from "@tanstack/react-query" import type { APIError } from "better-auth" import type { OrganizationAuthServer } from "../../../lib/auth-server" export type FullOrganizationData< TAuth extends OrganizationAuthServer = OrganizationAuthServer > = Awaited> export type FullOrganizationParams< TAuth extends OrganizationAuthServer = OrganizationAuthServer > = Parameters[0] /** * Query options factory for full organization details (members, invitations, etc.). * * @param auth - The Better Auth server instance. * @param userId - The signed-in user's ID. Used for cache partitioning so * the key matches the client-side `fullOrganizationOptions` for SSR hydration. * @param params - Parameters forwarded to `auth.api.getFullOrganization`. */ export function fullOrganizationOptions( auth: TAuth, userId: string, params: FullOrganizationParams ) { type TData = FullOrganizationData const queryKey = organizationQueryKeys.fullDetail(userId, params?.query) const options = queryOptions({ queryKey, queryFn: () => auth.api.getFullOrganization(params) as Promise }) return options as typeof options & { queryKey: DataTag } } export const ensureFullOrganization = ( queryClient: QueryClient, auth: TAuth, userId: string, params: FullOrganizationParams ) => queryClient.ensureQueryData(fullOrganizationOptions(auth, userId, params)) export const prefetchFullOrganization = ( queryClient: QueryClient, auth: TAuth, userId: string, params: FullOrganizationParams ) => queryClient.prefetchQuery(fullOrganizationOptions(auth, userId, params)) export const fetchFullOrganization = ( queryClient: QueryClient, auth: TAuth, userId: string, params: FullOrganizationParams ) => queryClient.fetchQuery(fullOrganizationOptions(auth, userId, params))