Files
supabase/apps/studio/data/config/disk-utilization-query.ts
Joshen Lim 07699ad76b Chore/disk attributes mangement (#29219)
* init

* moar

* moat

* moar

* add read replica bar

* moar

* Update DiskMangementPanelForm.tsx

* added temp state mang to test

* moar

* Prepare react queries + data from API for disk mgt

* moat

* moat

* moar

* Update DiskMangementReviewAndSubmitDialog.tsx

* badge updates

* Hook up actual endpoints for E2E testing, but commented out for now for local dev

* Hook up real data + clean up files and add tests

* Update APi types

* Hook up E2E and fix all validation logic

* Only show new disk mgt UI for orb billing

* Add note on RRs 25% more disk size

* Add state to handle free plan for disk mgt

* Update increase disk size CTA in reports/database

* Fix file spelling errors

* Address feedback

* Fix missing framer motion package in ui

* Address comments

* Address feedabck

* Minor fix

* Use new disk util endpoint

* Remove unused import

* Address feedback

* More addressing of feedback

* Update pricing details for IO2 - no included disk size

---------

Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com>
2024-09-13 11:51:51 +08:00

41 lines
1.2 KiB
TypeScript

import { useQuery, UseQueryOptions } from '@tanstack/react-query'
import { get, handleError } from 'data/fetchers'
import type { ResponseError } from 'types'
import { configKeys } from './keys'
export type DiskUtilizationVariables = {
projectRef?: string
}
export async function getDiskUtilization(
{ projectRef }: DiskUtilizationVariables,
signal?: AbortSignal
) {
if (!projectRef) throw new Error('Project ref is required')
const { data, error } = await get(`/platform/projects/{ref}/disk/util`, {
params: { path: { ref: projectRef } },
signal,
})
if (error) handleError(error)
return data
}
export type DiskUtilizationData = Awaited<ReturnType<typeof getDiskUtilization>>
export type DiskUtilizationError = ResponseError
export const useDiskUtilizationQuery = <TData = DiskUtilizationData>(
{ projectRef }: DiskUtilizationVariables,
{
enabled = true,
...options
}: UseQueryOptions<DiskUtilizationData, DiskUtilizationError, TData> = {}
) =>
useQuery<DiskUtilizationData, DiskUtilizationError, TData>(
configKeys.diskUtilization(projectRef),
({ signal }) => getDiskUtilization({ projectRef }, signal),
{ enabled: enabled && typeof projectRef !== 'undefined', ...options }
)