69 lines
2.9 KiB
TypeScript
69 lines
2.9 KiB
TypeScript
import React, { useEffect } from 'react'
|
|
import { useGetOffersQuery, useGetRwQuery } from "../../codegen/generates"
|
|
import HostOfferLookupTable, {HostOfferLookupTableProps} from "./HostOfferLookupTable"
|
|
import { Box } from "@mui/material"
|
|
import { useTranslation } from 'react-i18next'
|
|
import { Login, useAuthStore } from '../Login'
|
|
import { useLeafletStore } from './LeafletStore'
|
|
import { filterUndefOrNull } from '../util/notEmpty'
|
|
import { haversine_distance } from '../util/distance'
|
|
|
|
type HostOfferLookupWrapperProps = Partial<HostOfferLookupTableProps>
|
|
|
|
function floor(v: number|undefined) {
|
|
return v && Math.floor(v)
|
|
}
|
|
|
|
const HostOfferLookupWrapper = (props: HostOfferLookupWrapperProps) => {
|
|
const { t } = useTranslation()
|
|
const auth = useAuthStore()
|
|
|
|
const staleTimeMinutes_ro = 5
|
|
const staleTimeMinutes_rw = 1
|
|
const queryResult_ro = useGetOffersQuery({auth}, {enabled: !!auth.jwt, staleTime: staleTimeMinutes_ro * 60 * 1000})
|
|
const queryResult_rw = useGetRwQuery({auth}, {enabled: !!auth.jwt, staleTime: staleTimeMinutes_rw * 60 * 1000})
|
|
const {data: data_ro} = queryResult_ro
|
|
const {data: data_rw} = queryResult_rw
|
|
|
|
const {setMarkers, center} = useLeafletStore()
|
|
useEffect(() => {
|
|
const markers = data_ro?.get_offers?.map(row => (row.id && row.place_lon && row.place_lat
|
|
&& ({id: row.id,
|
|
lat: row.place_lat,
|
|
lng: row.place_lon,
|
|
radius: 1000, // TODO
|
|
content: 'TODO'}) || undefined))
|
|
setMarkers(filterUndefOrNull(markers))
|
|
}, [data_ro])
|
|
|
|
const data_ro_withDistance = data_ro?.get_offers?.map(r => ({...r,
|
|
place_distance: floor(haversine_distance(center?.lat, center?.lng, r.place_lat, r.place_lon))}))
|
|
|
|
return <>
|
|
<Box sx={{
|
|
display: 'flex',
|
|
alignItems: 'stretch',
|
|
flexDirection: 'column',
|
|
height: '100%'}}>
|
|
<div style={{minHeight: '2em', display: 'flex'}}>
|
|
{ (queryResult_ro.isFetching || queryResult_rw.isFetching) && t('loading…') }
|
|
{ (queryResult_ro.error || queryResult_rw.error) && t('An error occurred while trying to get data from the backend.') }
|
|
{ (data_ro && !data_ro.get_offers || data_rw && !data_rw.get_rw)
|
|
&& t('Seems like you have no permissions. Please try to login again.') }
|
|
<Login/>
|
|
</div>
|
|
{data_ro && <div
|
|
style={{flex: '1 1', height: '100%'}}>
|
|
<HostOfferLookupTable
|
|
{...props}
|
|
data_ro={data_ro_withDistance}
|
|
data_rw={data_rw?.get_rw}
|
|
refetch_rw={queryResult_rw.refetch}
|
|
/>
|
|
</div>}
|
|
</Box>
|
|
</>
|
|
}
|
|
|
|
export default HostOfferLookupWrapper
|