-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathApp.tsx
More file actions
38 lines (33 loc) · 905 Bytes
/
App.tsx
File metadata and controls
38 lines (33 loc) · 905 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import React, { useState } from 'react';
import FileUpload from './components/FileUpload';
import Dashboard from './components/Dashboard';
import { LogEntry } from './types';
function App() {
const [logs, setLogs] = useState<LogEntry[]>([]);
const [fileName, setFileName] = useState<string>('');
const [hasData, setHasData] = useState(false);
const handleDataLoaded = (parsedLogs: LogEntry[], name: string) => {
setLogs(parsedLogs);
setFileName(name);
setHasData(true);
};
const handleReset = () => {
setLogs([]);
setFileName('');
setHasData(false);
};
return (
<div className="min-h-screen bg-slate-50">
{!hasData ? (
<FileUpload onDataLoaded={handleDataLoaded} />
) : (
<Dashboard
logs={logs}
fileName={fileName}
onBack={handleReset}
/>
)}
</div>
);
}
export default App;