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 TableUnits from '../../components/Units/TableUnits' 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 InventoryImportGuidance from '../../components/InventoryImportGuidance'; import {setRefetch, uploadCsv} from '../../stores/units/unitsSlice'; import { downloadInventoryImportTemplate, getInventoryImportTemplateConfig } from '../../helpers/inventoryImportTemplates'; import {hasPermission} from "../../helpers/userPermissions"; const UnitsTablesPage = () => { 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 importTemplate = getInventoryImportTemplateConfig('units', currentUser); const [filters] = useState([{label: 'Unitnumber', title: 'unit_number'},{label: 'Floor', title: 'floor'},{label: 'Notes', title: 'notes'}, {label: 'Maxoccupancyoverride', title: 'max_occupancy_override', number: 'true'}, {label: 'Property', title: 'property'}, {label: 'Unittype', title: 'unit_type'}, {label: 'Availabilityblocks', title: 'availability_blocks'}, {label: 'Status', title: 'status', type: 'enum', options: ['available','occupied','maintenance','cleaning_hold','reserved','out_of_service']}, ]); const hasCreatePermission = currentUser && hasPermission(currentUser, 'CREATE_UNITS'); const addFilter = () => { const newItem = { id: uniqueId(), fields: { filterValue: '', filterValueFrom: '', filterValueTo: '', selectedField: '', }, }; newItem.fields.selectedField = filters[0].title; setFilterItems([...filterItems, newItem]); }; const getUnitsCSV = async () => { const response = await axios({url: '/units?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 = 'unitsCSV.csv' link.click() }; const downloadInventoryTemplate = async () => { await downloadInventoryImportTemplate('units', importTemplate.fileName); }; 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('Units')} {''} {hasCreatePermission && } {hasCreatePermission && ( setIsModalActive(true)} /> )}
) } UnitsTablesPage.getLayout = function getLayout(page: ReactElement) { return ( {page} ) } export default UnitsTablesPage