import { useState, useEffect, FormEvent } from 'react'; import { useGetLogs } from '../generated/anthoLumeAPIV1'; import type { LogsResponse } from '../generated/model'; import { Button } from '../components/Button'; import { LoadingState } from '../components'; import { useDebounce } from '../hooks/useDebounce'; import { Search2Icon } from '../icons'; export default function AdminLogsPage() { const [filter, setFilter] = useState(''); const [activeFilter, setActiveFilter] = useState(''); const debouncedFilter = useDebounce(filter, 300); useEffect(() => { setActiveFilter(debouncedFilter); }, [debouncedFilter]); const { data: logsData, isLoading } = useGetLogs(activeFilter ? { filter: activeFilter } : {}); const logs = logsData?.status === 200 ? ((logsData.data as LogsResponse).logs ?? []) : []; const handleFilterSubmit = (e: FormEvent) => { e.preventDefault(); setActiveFilter(filter); }; return (