@prefecthq/prefect-ui-library
Version:
This library is the Vue and Typescript component library for [Prefect 2](https://github.com/PrefectHQ/prefect) and [Prefect Cloud 2](https://www.prefect.io/cloud/). _The components and utilities in this project are not meant to be used independently_.
45 lines (37 loc) • 1.33 kB
text/typescript
import { MaybeRefOrGetter, toValue } from 'vue'
import { useCan } from '@/compositions/useCan'
import { PaginationOptions, UsePaginationEntity, usePagination } from '@/compositions/usePagination'
import { useWorkspaceApi } from '@/compositions/useWorkspaceApi'
import { BlockDocumentsFilter } from '@/models'
import { WorkspaceBlockDocumentsApi } from '@/services'
import { Getter } from '@/types/reactivity'
export type UseBlockDocuments = UsePaginationEntity<
WorkspaceBlockDocumentsApi['getBlockDocuments'],
WorkspaceBlockDocumentsApi['getBlockDocumentsCount'],
'blockDocuments'
>
export function useBlockDocuments(filter?: MaybeRefOrGetter<BlockDocumentsFilter | null | undefined>, options?: PaginationOptions): UseBlockDocuments {
const api = useWorkspaceApi()
const can = useCan()
const parameters: Getter<[BlockDocumentsFilter?] | null> = () => {
if (!can.read.block) {
return null
}
const value = toValue(filter)
if (!value) {
return null
}
return [value]
}
const pagination = usePagination({
fetchMethod: api.blockDocuments.getBlockDocuments,
fetchParameters: parameters,
countMethod: api.blockDocuments.getBlockDocumentsCount,
countParameters: parameters,
options,
})
return {
...pagination,
blockDocuments: pagination.results,
}
}