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 TableOnboarding_cases from '../../components/Onboarding_cases/TableOnboarding_cases'; 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/onboarding_cases/onboarding_casesSlice'; import { hasPermission } from '../../helpers/userPermissions'; const Onboarding_casesTablesPage = () => { const [filterItems, setFilterItems] = useState([]); const [csvFile, setCsvFile] = useState(null); const [isModalActive, setIsModalActive] = useState(false); const [showTableView, setShowTableView] = useState(false); const { currentUser } = useAppSelector((state) => state.auth); const dispatch = useAppDispatch(); const [filters] = useState([ { label: 'StartDate', title: 'start_date', date: 'true' }, { label: 'CompletionDate', title: 'completion_date', date: 'true' }, { label: 'User', title: 'user' }, { label: 'AssignedStaff', title: 'assigned_staff' }, { label: 'Role', title: 'role', type: 'enum', options: ['finance_admin', 'provider', 'support'], }, { label: 'Status', title: 'status', type: 'enum', options: ['pending', 'active', 'completed'], }, ]); const hasCreatePermission = currentUser && hasPermission(currentUser, 'CREATE_ONBOARDING_CASES'); const addFilter = () => { const newItem = { id: uniqueId(), fields: { filterValue: '', filterValueFrom: '', filterValueTo: '', selectedField: '', }, }; newItem.fields.selectedField = filters[0].title; setFilterItems([...filterItems, newItem]); }; const getOnboarding_casesCSV = async () => { const response = await axios({ url: '/onboarding_cases?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 = 'onboarding_casesCSV.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 ( <> {getPageTitle('Onboarding_cases')} {''} {hasCreatePermission && ( )} {hasCreatePermission && ( setIsModalActive(true)} /> )}
Back to calendar
); }; Onboarding_casesTablesPage.getLayout = function getLayout(page: ReactElement) { return ( {page} ); }; export default Onboarding_casesTablesPage;