@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_.
57 lines (47 loc) • 2.05 kB
text/typescript
import { SubscriptionOptions, UseSubscription, useSubscriptionWithDependencies } from '@prefecthq/vue-compositions'
import merge from 'lodash.merge'
import { ComputedRef, MaybeRefOrGetter, computed, toRef, toValue } from 'vue'
import { useCan } from '@/compositions/useCan'
import { useWorkspaceApi } from '@/compositions/useWorkspaceApi'
import { WorkPoolWorker, WorkPoolWorkersPagination } from '@/models'
import { WorkspaceWorkPoolWorkersApi } from '@/services'
import { Getter } from '@/types/reactivity'
type UsePaginatedWorkPoolWorkers = {
subscription: UseSubscription<WorkspaceWorkPoolWorkersApi['getWorkersPaginated']>,
workers: ComputedRef<WorkPoolWorker[]>,
count: ComputedRef<number>,
limit: ComputedRef<number>,
pages: ComputedRef<number>,
page: ComputedRef<number>,
}
export function usePaginatedWorkPoolWorkers(workPoolName: MaybeRefOrGetter<string>, filter: MaybeRefOrGetter<WorkPoolWorkersPagination | null | undefined> = {}, options?: SubscriptionOptions): UsePaginatedWorkPoolWorkers {
const api = useWorkspaceApi()
const can = useCan()
const getter: Getter<[string, WorkPoolWorkersPagination] | null> = () => {
if (!can.read.work_pool) {
return null
}
const value = toValue(filter)
const workPoolNameValue = toValue(workPoolName)
if (!value) {
return null
}
// merge here is important to track changes to `filter` if it is a reactive
return [workPoolNameValue, merge({}, value)]
}
const parameters = toRef(getter)
const subscription = useSubscriptionWithDependencies(api.workPoolWorkers.getWorkersPaginated, parameters, options)
const workers = computed(() => subscription.response?.workers ?? [])
const pages = computed(() => subscription.response?.pages ?? 0)
const limit = computed(() => subscription.response?.limit ?? 0)
const count = computed(() => subscription.response?.count ?? 0)
const page = computed(() => subscription.response?.page ?? 1)
return {
subscription,
workers,
pages,
page,
limit,
count,
}
}