import { computed, reactive, readonly } from 'vue' import { api } from '@/scripts/api' /** * Known server feature flags (top-level, not extensions) */ export enum ServerFeatureFlag { SUPPORTS_PREVIEW_METADATA = 'supports_preview_metadata', MAX_UPLOAD_SIZE = 'max_upload_size', MANAGER_SUPPORTS_V4 = 'extension.manager.supports_v4' } /** * Composable for reactive access to server-side feature flags */ export function useFeatureFlags() { const flags = reactive({ get supportsPreviewMetadata() { return api.getServerFeature(ServerFeatureFlag.SUPPORTS_PREVIEW_METADATA) }, get maxUploadSize() { return api.getServerFeature(ServerFeatureFlag.MAX_UPLOAD_SIZE) }, get supportsManagerV4() { return api.getServerFeature(ServerFeatureFlag.MANAGER_SUPPORTS_V4) } }) const featureFlag = (featurePath: string, defaultValue?: T) => computed(() => api.getServerFeature(featurePath, defaultValue)) return { flags: readonly(flags), featureFlag } }