-
Notifications
You must be signed in to change notification settings - Fork 14
Expand file tree
/
Copy pathDetailSection.tsx
More file actions
121 lines (113 loc) · 2.85 KB
/
DetailSection.tsx
File metadata and controls
121 lines (113 loc) · 2.85 KB
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
import { useSelector } from "react-redux"
// internal
import {
AppIcon,
DatabaseIcon,
GraphBarIcon,
HistoryIcon,
LayoutGroupIcon,
VectorSquareIcon,
} from "@/assets/icons"
import { useMemo } from "react"
import { IResultState } from "@/types/state"
const DetailSection = () => {
const benchmarkResults = useSelector((state: { results: IResultState }) => {
return state.results.rawBenchmarkResults
})
const rawMetaData = useSelector((state: { results: IResultState }) => {
return state.results.rawMetaData
})
const availableBenchmarksCount = Object.keys(rawMetaData).length
const availableSolvers = useSelector((state: { results: IResultState }) => {
return state.results.availableSolvers
})
const avaliableVersion = useMemo(
() =>
Array.from(
new Set(benchmarkResults.map((result) => result.solverVersion))
),
[benchmarkResults]
)
const avaliableInstance = useMemo(
() =>
Array.from(
new Set(
benchmarkResults.map((result) => `${result.benchmark}-${result.size}`)
)
),
[benchmarkResults]
)
const detailData = [
{
label: "Benchmarks",
value: availableBenchmarksCount,
icon: <GraphBarIcon />,
generateLabel: () => (
<>
Benchmarks:{" "}
<span className="font-bold">
{availableBenchmarksCount} {`(${avaliableInstance.length}`} instances
{")"}
</span>
</>
),
},
{
label: "Solvers",
value: availableSolvers.length,
icon: <VectorSquareIcon />,
generateLabel: () => (
<>
Solvers:{" "}
<span className="font-bold">
{availableSolvers.length} {`(${avaliableVersion.length}`} versions
{")"}
</span>
</>
),
},
{
label: "Iterations",
value: "1",
icon: <LayoutGroupIcon />,
},
{
label: "vCPUs",
value: "2 (1 core)",
icon: <AppIcon />,
},
{
label: "Memory",
value: "16 GB",
icon: <DatabaseIcon />,
},
{
label: "Timeout",
value: "10 min",
icon: <HistoryIcon />,
},
]
return (
<div className="bg-white rounded-xl py-4 px-12">
<ul className="flex justify-between text-dark-grey">
{detailData.map((data, idx) => (
<li key={idx} className="text-base flex items-center">
{data.icon}
{data.generateLabel ? (
<div className="ml-1">{data.generateLabel()}</div>
) : (
<div className="ml-1">
<span className="ml-1">
{data.label}
{":"}
</span>
<span className="font-bold ml-1">{data.value}</span>
</div>
)}
</li>
))}
</ul>
</div>
)
}
export default DetailSection