"use client"; import { useState, useEffect } from "react"; import { useRouter } from "next/navigation"; import Link from "next/link"; import Button from "@/components/shared/Button"; import { Terminal, MoreVertical } from "lucide-react"; import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuTrigger, } from "@/components/ui/dropdown-menu"; export default function ApplicationsPage() { const router = useRouter(); const [applications, setApplications] = useState([]); const [isLoading, setIsLoading] = useState(true); const [error, setError] = useState(null); const [deletingApps, setDeletingApps] = useState(new Set()); useEffect(() => { fetchApplications(); }, []); async function fetchApplications() { try { const response = await fetch( "http://localhost:8080/twirp/applications.ApplicationsService/ListApplications", { method: "POST", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ token: localStorage.getItem("token"), }), }, ); if (!response.ok) throw new Error("Failed to fetch applications"); const data = await response.json(); setApplications(data.applications || []); } catch (error) { setError("Failed to load applications"); console.error("Error:", error); } finally { setIsLoading(false); } } async function handleDeleteApplication(appId, e) { e.stopPropagation(); if ( !confirm( "Are you sure you want to delete this application? This action cannot be undone and will delete all associated logs.", ) ) { return; } setDeletingApps((prev) => new Set([...prev, appId])); try { const response = await fetch( `http://localhost:8080/twirp/applications.ApplicationsService/DeleteApplication`, { method: "POST", headers: { "Content-Type": "application/json", }, body: JSON.stringify({ token: localStorage.getItem("token"), application_id: appId, }), }, ); if (!response.ok) throw new Error("Failed to delete application"); await fetchApplications(); } catch (error) { setError("Failed to delete application"); console.error("Error:", error); } finally { setDeletingApps((prev) => { const newSet = new Set(prev); newSet.delete(appId); return newSet; }); } } if (isLoading) { return (
Create your first application to start sending logs to Argus.