Files
robot-command-center/frontend/src/lib/api.ts

36 lines
1.1 KiB
TypeScript

import type { DashboardSnapshot, VideoStatus } from '@/types'
const envBaseUrl = import.meta.env.VITE_API_BASE_URL as string | undefined
export const API_BASE = (envBaseUrl?.trim() || 'http://127.0.0.1:8001').replace(/\/$/, '')
async function fetchJson<T>(path: string): Promise<T> {
const response = await fetch(`${API_BASE}${path}`)
if (!response.ok) {
throw new Error(`请求失败: ${response.status} ${response.statusText}`)
}
return response.json() as Promise<T>
}
export function fetchDashboardSnapshot() {
return fetchJson<DashboardSnapshot>('/api/dashboard/')
}
export function fetchVideoStatus() {
return fetchJson<VideoStatus>('/api/video/status/')
}
export function buildVideoFrameUrl(frameKey: number) {
return `${API_BASE}/api/video/frame/?frame=${frameKey}&t=${Date.now()}`
}
export function buildControlWebSocketUrl() {
const url = new URL(API_BASE, window.location.origin)
const basePath = url.pathname.replace(/\/$/, '')
url.protocol = url.protocol === 'https:' ? 'wss:' : 'ws:'
url.pathname = `${basePath}/ws/control/`
url.search = ''
url.hash = ''
return url.toString()
}