-
Notifications
You must be signed in to change notification settings - Fork 67
/
Content.tsx
63 lines (54 loc) 路 2.12 KB
/
Content.tsx
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
import {useCallback, useMemo} from 'react';
import CreateButton from 'components/CreateButton';
import PaginatedList from 'components/PaginatedList';
import TestSuiteRunCard from 'components/RunCard/TestSuiteRunCard';
import TestHeader from 'components/TestHeader';
import useDocumentTitle from 'hooks/useDocumentTitle';
import TestSuiteRun from 'models/TestSuiteRun.model';
import {useDashboard} from 'providers/Dashboard/Dashboard.provider';
import {useTestSuite} from 'providers/TestSuite/TestSuite.provider';
import {useTestSuiteCrud} from 'providers/TestSuite';
import TracetestAPI from 'redux/apis/Tracetest';
import * as S from './TestSuite.styled';
const {useGetTestSuiteRunsQuery} = TracetestAPI.instance;
const Content = () => {
const {onDelete, testSuite} = useTestSuite();
const {runTestSuite, isEditLoading} = useTestSuiteCrud();
const params = useMemo(() => ({testSuiteId: testSuite.id}), [testSuite.id]);
useDocumentTitle(`${testSuite.name}`);
const handleRunTest = useCallback(async () => {
if (testSuite.id) runTestSuite(testSuite);
}, [runTestSuite, testSuite]);
const {navigate} = useDashboard();
const shouldEdit = testSuite.summary.hasRuns;
const onEdit = () => navigate(`/testsuite/${testSuite.id}/run/${testSuite.summary.runs}`);
return (
<S.Container $isWhite>
<TestHeader
description={testSuite.description}
id={testSuite.id}
onDelete={() => onDelete(testSuite.id, testSuite.name)}
onEdit={onEdit}
shouldEdit={shouldEdit}
title={`${testSuite.name} (v${testSuite.version})`}
runButton={
<CreateButton ghost loading={isEditLoading} onClick={handleRunTest} type="primary">
Run Test Suite
</CreateButton>
}
/>
<PaginatedList<TestSuiteRun, {testSuiteId: string}>
itemComponent={({item}) => (
<TestSuiteRunCard
linkTo={`/testsuite/${testSuite.id}/run/${item.id}`}
run={item}
testSuiteId={testSuite.id}
/>
)}
params={params}
query={useGetTestSuiteRunsQuery}
/>
</S.Container>
);
};
export default Content;