Improve display of road details
This commit is contained in:
parent
61efdeb673
commit
7ad5fad056
|
@ -10,6 +10,7 @@ import {switchMap, distinctUntilChanged} from 'rxjs/operators'
|
||||||
|
|
||||||
import {Page} from 'components'
|
import {Page} from 'components'
|
||||||
import {useConfig, Config} from 'config'
|
import {useConfig, Config} from 'config'
|
||||||
|
import api from 'api'
|
||||||
|
|
||||||
import {roadsLayer, basemap} from '../mapstyles'
|
import {roadsLayer, basemap} from '../mapstyles'
|
||||||
|
|
||||||
|
@ -103,6 +104,10 @@ export function CustomMap({
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const UNITS = {distanceOvertaker: 'm', distanceStationary: 'm', speed: 'm/s'}
|
||||||
|
const LABELS = {distanceOvertaker: 'Overtaker', distanceStationary: 'Stationary', speed: 'Speed'}
|
||||||
|
const ZONE_COLORS = {urban: 'olive', rural: 'brown', motorway: 'purple'}
|
||||||
|
|
||||||
function CurrentRoadInfo({clickLocation}) {
|
function CurrentRoadInfo({clickLocation}) {
|
||||||
const info = useObservable(
|
const info = useObservable(
|
||||||
(_$, inputs$) =>
|
(_$, inputs$) =>
|
||||||
|
@ -139,43 +144,46 @@ function CurrentRoadInfo({clickLocation}) {
|
||||||
'No road found.'
|
'No road found.'
|
||||||
) : (
|
) : (
|
||||||
<>
|
<>
|
||||||
<Header as="h1">{loading ? '...' : info?.road.name || 'Unnamed way'}</Header>
|
<Header as="h3">{loading ? '...' : info?.road.name || 'Unnamed way'}</Header>
|
||||||
|
|
||||||
<List>
|
{info?.road.zone && (
|
||||||
<List.Item>
|
<Label size="small" color={ZONE_COLORS[info?.road.zone]}>
|
||||||
<List.Header>Zone</List.Header>
|
|
||||||
{info?.road.zone}
|
{info?.road.zone}
|
||||||
</List.Item>
|
</Label>
|
||||||
<List.Item>
|
)}
|
||||||
<List.Header>Tags</List.Header>
|
|
||||||
{info?.road.oneway && (
|
|
||||||
<Label size="small" color="blue">
|
|
||||||
<Icon name="long arrow alternate right" fitted /> oneway
|
|
||||||
</Label>
|
|
||||||
)}
|
|
||||||
</List.Item>
|
|
||||||
|
|
||||||
<List.Item>
|
{info?.road.oneway && (
|
||||||
<List.Header>Statistics</List.Header>
|
<Label size="small" color="blue">
|
||||||
<Table size='small' compact>
|
<Icon name="long arrow alternate right" fitted /> oneway
|
||||||
<Table.Header>
|
</Label>
|
||||||
<Table.Row><Table.HeaderCell></Table.HeaderCell>
|
)}
|
||||||
<Table.HeaderCell>n</Table.HeaderCell>
|
|
||||||
<Table.HeaderCell>min</Table.HeaderCell>
|
<Table size="small" compact>
|
||||||
<Table.HeaderCell>q50</Table.HeaderCell>
|
<Table.Header>
|
||||||
<Table.HeaderCell>max</Table.HeaderCell>
|
<Table.Row>
|
||||||
<Table.HeaderCell>mean</Table.HeaderCell>
|
<Table.HeaderCell>Property</Table.HeaderCell>
|
||||||
</Table.Row>
|
<Table.HeaderCell>n</Table.HeaderCell>
|
||||||
</Table.Header>
|
<Table.HeaderCell>min</Table.HeaderCell>
|
||||||
<Table.Body>
|
<Table.HeaderCell>q50</Table.HeaderCell>
|
||||||
{['distanceOvertaker', 'distanceStationary', 'speed'].map(prop => <Table.Row key={prop}>
|
<Table.HeaderCell>max</Table.HeaderCell>
|
||||||
<Table.Cell>{prop}</Table.Cell>
|
<Table.HeaderCell>mean</Table.HeaderCell>
|
||||||
{['count', 'min', 'median', 'max', 'mean'].map(stat => <Table.Cell key={stat}>{info?.[prop]?.statistics?.[stat]?.toFixed(3)}</Table.Cell>)}
|
<Table.HeaderCell>unit</Table.HeaderCell>
|
||||||
</Table.Row>)}
|
</Table.Row>
|
||||||
</Table.Body>
|
</Table.Header>
|
||||||
</Table>
|
<Table.Body>
|
||||||
</List.Item>
|
{['distanceOvertaker', 'distanceStationary', 'speed'].map((prop) => (
|
||||||
</List>
|
<Table.Row key={prop}>
|
||||||
|
<Table.Cell>{LABELS[prop]}</Table.Cell>
|
||||||
|
{['count', 'min', 'median', 'max', 'mean'].map((stat) => (
|
||||||
|
<Table.Cell key={stat}>
|
||||||
|
{info?.[prop]?.statistics?.[stat]?.toFixed(stat === 'count' ? 0 : 3)}
|
||||||
|
</Table.Cell>
|
||||||
|
))}
|
||||||
|
<Table.Cell>{UNITS[prop]}</Table.Cell>
|
||||||
|
</Table.Row>
|
||||||
|
))}
|
||||||
|
</Table.Body>
|
||||||
|
</Table>
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue