1
- import { React , useEffect , useState } from "react" ;
1
+ import { React , useEffect , useState , useContext } from "react" ;
2
2
import { useParams } from "react-router-dom" ;
3
3
import useFetch from "../../util/useFetch" ;
4
4
import PointOfInterest from "../points-of-interest/PointOfInterest" ;
5
5
import { getAngleFromLocationToDestination } from "../../util/helper" ;
6
+ import BackButton from "../BackButton" ;
7
+ import { ReactComponent as LocationArrow } from "../../icons/location-arrow-solid.svg" ;
8
+ import AudioContext from "../../context/audio-context" ;
6
9
7
10
function RoutePage ( ) {
8
11
const { id } = useParams ( ) ;
@@ -15,6 +18,11 @@ function RoutePage() {
15
18
const [ latitude , setLatitude ] = useState ( 0 ) ;
16
19
const [ longitude , setLongitude ] = useState ( 0 ) ;
17
20
const [ destinationName , setDestinationName ] = useState ( null ) ;
21
+ const [ userLatitude , setUserLatitude ] = useState ( 0 ) ;
22
+ const [ userLongitude , setUserLongitude ] = useState ( 0 ) ;
23
+ const { audio } = useContext ( AudioContext ) ;
24
+ let handlerAvailable = true ;
25
+ let locationHandlerAvailable = true ;
18
26
const isIOS =
19
27
navigator . userAgent . match ( / ( i P o d | i P h o n e | i P a d ) / ) &&
20
28
navigator . userAgent . match ( / A p p l e W e b K i t / ) ;
@@ -89,41 +97,56 @@ function RoutePage() {
89
97
} , [ pointsOfInterest ] ) ;
90
98
91
99
if ( selectedRoute === null ) return null ;
100
+
92
101
return (
93
- < >
94
- < h1 > { selectedRoute . name } </ h1 >
95
- { pointsOfInterest &&
96
- pointsOfInterest
97
- . toReversed ( )
98
- . map ( ( pointOfInterest ) => (
99
- < PointOfInterest
100
- pointOfInterest = { pointOfInterest }
101
- key = { pointOfInterest . id }
102
- />
103
- ) ) }
104
- < img
105
- alt = ""
106
- style = { {
107
- width : 100 ,
108
- display : "block" ,
109
- margin : "auto" ,
110
- transform : `rotate(${ - rotation } deg)` ,
111
- } }
112
- src = ""
113
- />
114
- < button
115
- style = { {
116
- width : 300 ,
117
- height : 100 ,
118
- display : "block" ,
119
- margin : "auto" ,
120
- } }
121
- type = "button"
122
- onClick = { ( ) => startWaypointer ( ) }
123
- >
124
- Vis mig vej til { destinationName }
125
- </ button >
126
- </ >
102
+ < div className = "flex flex-col place-items-start pb-20" >
103
+ < BackButton > Afslut</ BackButton >
104
+ < h1 className = "text-xl font-bold my-3" > { selectedRoute . name } </ h1 >
105
+ < div className = "overflow-y-auto h-4/6 relative w-full bg-white dark:bg-zinc-700 dark:highlight-white/5 shadow-lg ring-1 ring-black/5 rounded-lg flex flex-col divide-y dark:divide-zinc-200/5" >
106
+ { pointsOfInterest &&
107
+ pointsOfInterest
108
+ . toReversed ( )
109
+ . map ( ( pointOfInterest ) => (
110
+ < PointOfInterest
111
+ pointOfInterest = { pointOfInterest }
112
+ key = { pointOfInterest . id }
113
+ />
114
+ ) ) }
115
+ </ div >
116
+ { /* TODO: Make room for audio player below when playing */ }
117
+ < div className = "fixed left-3 bottom-3 right-3 bg-zinc-200 dark:bg-zinc-700 flex gap-3 rounded-lg p-3 pb-15 divide-x dark:divide-zinc-200/5" >
118
+ < div >
119
+ < span className = "block text-sm text-bold" > Afstand til del 1</ span >
120
+ < span className = "block" > 180 meter</ span >
121
+ < button
122
+ className = "bg-zinc-700 dark:bg-zinc-200 dark:text-zinc-800 rounded text-sm py-1 px-3"
123
+ type = "button"
124
+ onClick = { ( ) => startWaypointer ( ) }
125
+ >
126
+ Vis mig vej
127
+ </ button >
128
+ </ div >
129
+ < div className = "pl-3" >
130
+ < div className = "flex justify-between mb-3" >
131
+ < span className = "text-sm text-bold" > Retning</ span >
132
+ < span className = "w-1/2" >
133
+ < LocationArrow
134
+ className = "inline w-5"
135
+ style = { {
136
+ transform : `rotate(${ - rotation } deg)` ,
137
+ } }
138
+ />
139
+ </ span >
140
+ </ div >
141
+ < div className = "text-xs text-zinc-500" >
142
+ Lat: { userLatitude } /{ latitude }
143
+ </ div >
144
+ < div className = "text-xs text-zinc-500" >
145
+ Long: { userLongitude } /{ longitude }
146
+ </ div >
147
+ </ div >
148
+ </ div >
149
+ </ div >
127
150
) ;
128
151
}
129
152
0 commit comments