39628-vm/frontend/src/pages/connectivity_tests/connectivity_tests-table.tsx
2026-04-14 00:58:20 +00:00

169 lines
5.9 KiB
TypeScript

import { mdiChartTimelineVariant } from '@mdi/js'
import Head from 'next/head'
import { uniqueId } from 'lodash';
import React, { ReactElement, useState } from 'react'
import CardBox from '../../components/CardBox'
import LayoutAuthenticated from '../../layouts/Authenticated'
import SectionMain from '../../components/SectionMain'
import SectionTitleLineWithButton from '../../components/SectionTitleLineWithButton'
import { getPageTitle } from '../../config'
import TableConnectivity_tests from '../../components/Connectivity_tests/TableConnectivity_tests'
import BaseButton from '../../components/BaseButton'
import axios from "axios";
import Link from "next/link";
import {useAppDispatch, useAppSelector} from "../../stores/hooks";
import CardBoxModal from "../../components/CardBoxModal";
import DragDropFilePicker from "../../components/DragDropFilePicker";
import {setRefetch, uploadCsv} from '../../stores/connectivity_tests/connectivity_testsSlice';
import {hasPermission} from "../../helpers/userPermissions";
const Connectivity_testsTablesPage = () => {
const [filterItems, setFilterItems] = useState([]);
const [csvFile, setCsvFile] = useState<File | null>(null);
const [isModalActive, setIsModalActive] = useState(false);
const [showTableView, setShowTableView] = useState(false);
const { currentUser } = useAppSelector((state) => state.auth);
const dispatch = useAppDispatch();
const [filters] = useState([{label: 'TestName', title: 'test_name'},{label: 'RequestCommand', title: 'request_command'},{label: 'RequestURL', title: 'request_url'},{label: 'RequestHeaders', title: 'request_headers'},{label: 'RequestBody', title: 'request_body'},{label: 'ResponseHeaders', title: 'response_headers'},{label: 'ResponseBody', title: 'response_body'},{label: 'ErrorMessage', title: 'error_message'},
{label: 'ResponseStatus', title: 'response_status', number: 'true'},
{label: 'StartedAt', title: 'started_at', date: 'true'},{label: 'FinishedAt', title: 'finished_at', date: 'true'},
{label: 'PlatformAIConfig', title: 'platform_ai_config'},
{label: 'TestType', title: 'test_type', type: 'enum', options: ['models_list','chat_hi','messages_hi','healthcheck','custom']},{label: 'RequestMethod', title: 'request_method', type: 'enum', options: ['GET','POST']},
]);
const hasCreatePermission = currentUser && hasPermission(currentUser, 'CREATE_CONNECTIVITY_TESTS');
const addFilter = () => {
const newItem = {
id: uniqueId(),
fields: {
filterValue: '',
filterValueFrom: '',
filterValueTo: '',
selectedField: '',
},
};
newItem.fields.selectedField = filters[0].title;
setFilterItems([...filterItems, newItem]);
};
const getConnectivity_testsCSV = async () => {
const response = await axios({url: '/connectivity_tests?filetype=csv', method: 'GET',responseType: 'blob'});
const type = response.headers['content-type']
const blob = new Blob([response.data], { type: type })
const link = document.createElement('a')
link.href = window.URL.createObjectURL(blob)
link.download = 'connectivity_testsCSV.csv'
link.click()
};
const onModalConfirm = async () => {
if (!csvFile) return;
await dispatch(uploadCsv(csvFile));
dispatch(setRefetch(true));
setCsvFile(null);
setIsModalActive(false);
};
const onModalCancel = () => {
setCsvFile(null);
setIsModalActive(false);
};
return (
<>
<Head>
<title>{getPageTitle('Connectivity_tests')}</title>
</Head>
<SectionMain>
<SectionTitleLineWithButton icon={mdiChartTimelineVariant} title="Connectivity_tests" main>
{''}
</SectionTitleLineWithButton>
<CardBox className='mb-6' cardBoxClassName='flex flex-wrap'>
{hasCreatePermission && <BaseButton className={'mr-3'} href={'/connectivity_tests/connectivity_tests-new'} color='info' label='New Item'/>}
<BaseButton
className={'mr-3'}
color='info'
label='Filter'
onClick={addFilter}
/>
<BaseButton className={'mr-3'} color='info' label='Download CSV' onClick={getConnectivity_testsCSV} />
{hasCreatePermission && (
<BaseButton
color='info'
label='Upload CSV'
onClick={() => setIsModalActive(true)}
/>
)}
<div className='md:inline-flex items-center ms-auto'>
<div id='delete-rows-button'></div>
<Link href={'/connectivity_tests/connectivity_tests-list'}>
Back to <span className='capitalize'>calendar</span>
</Link>
</div>
</CardBox>
<CardBox className="mb-6" hasTable>
<TableConnectivity_tests
filterItems={filterItems}
setFilterItems={setFilterItems}
filters={filters}
showGrid={true}
/>
</CardBox>
</SectionMain>
<CardBoxModal
title='Upload CSV'
buttonColor='info'
buttonLabel={'Confirm'}
// buttonLabel={false ? 'Deleting...' : 'Confirm'}
isActive={isModalActive}
onConfirm={onModalConfirm}
onCancel={onModalCancel}
>
<DragDropFilePicker
file={csvFile}
setFile={setCsvFile}
formats={'.csv'}
/>
</CardBoxModal>
</>
)
}
Connectivity_testsTablesPage.getLayout = function getLayout(page: ReactElement) {
return (
<LayoutAuthenticated
permission={'READ_CONNECTIVITY_TESTS'}
>
{page}
</LayoutAuthenticated>
)
}
export default Connectivity_testsTablesPage