Files
speckle-server/packages/frontend-2/lib/workspaces/composables/limits.ts
T
2025-04-14 10:40:46 +02:00

84 lines
2.1 KiB
TypeScript

import { graphql } from '~/lib/common/generated/gql/gql'
import { useQuery } from '@vue/apollo-composable'
import { workspaceLimitsQuery } from '~/lib/workspaces/graphql/queries'
import { WorkspacePlanConfigs } from '@speckle/shared'
import { useWorkspaceUsage } from '~/lib/workspaces/composables/usage'
graphql(`
fragment WorkspacePlanLimits_Workspace on Workspace {
id
plan {
name
}
}
`)
export const useWorkspaceLimits = (slug: string) => {
const { modelCount, projectCount } = useWorkspaceUsage(slug)
const { result } = useQuery(
workspaceLimitsQuery,
() => ({
slug
}),
() => ({
enabled: !!slug
})
)
// Plan limits
const limits = computed(() => {
const planName = result.value?.workspaceBySlug?.plan?.name
if (!planName) return { projectCount: 0, modelCount: 0, versionsHistory: null }
const planConfig = WorkspacePlanConfigs[planName]
return planConfig?.limits
})
const versionLimitFormatted = computed(() => {
const versionsHistory = limits.value?.versionsHistory
if (!versionsHistory) return 'Unlimited'
const { value, unit } = versionsHistory
return `${value} ${unit}`
})
const remainingProjectCount = computed(() =>
limits.value.projectCount ? limits.value.projectCount - projectCount.value : 0
)
const remainingModelCount = computed(() =>
limits.value.modelCount ? limits.value.modelCount - modelCount.value : 0
)
// TODO; move to permissions
const canAddProject = computed(() => {
// Unlimited
if (limits.value.projectCount === null) return true
return projectCount.value + 1 <= limits.value.projectCount
})
// TODO; move to permissions
const canAddModels = (additionalModels?: number) => {
// Unlimited
if (limits.value.modelCount === null) return true
if (!additionalModels) {
return remainingModelCount.value > 0
}
return modelCount.value + additionalModels <= limits.value.modelCount
}
return {
projectCount,
modelCount,
limits,
remainingProjectCount,
remainingModelCount,
canAddProject,
canAddModels,
versionLimitFormatted
}
}