UNPKG

@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_.

41 lines (32 loc) 1.27 kB
import { useSubscriptionWithDependencies } from '@prefecthq/vue-compositions' import merge from 'lodash.merge' import { MaybeRefOrGetter, computed, toRef, toValue } from 'vue' import { useCan, useWorkspaceApi } from '@/compositions' import { FlowsFilter } from '@/models' import { WorkspaceFlowsApi } from '@/services/WorkspaceFlowsApi' import { Getter } from '@/types/reactivity' import { UseEntitySubscription } from '@/types/useEntitySubscription' export type UseFlowsCount = UseEntitySubscription<WorkspaceFlowsApi['getFlowsCount'], 'count'> export function useFlowsCount(filter?: MaybeRefOrGetter<FlowsFilter>): UseFlowsCount { const api = useWorkspaceApi() const can = useCan() const getter: Getter<[FlowsFilter] | null> = () => { if (!can.read.flow) { return null } const filterValue = toValue(filter) if (!filterValue) { return null } // merge here is important to track changes to `filter` if it is a reactive const parameter = merge({}, filterValue) return [parameter] } const parameters = toRef(getter) const subscription = useSubscriptionWithDependencies(api.flows.getFlowsCount, parameters) const count = computed(() => subscription.response) return { subscription, count, } }