Skip to content

Commit 6187021

Browse files
committed
Improving code flow of waypointer
1 parent 589f718 commit 6187021

File tree

5 files changed

+54
-56
lines changed

5 files changed

+54
-56
lines changed

src/App.jsx

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -79,7 +79,7 @@ function App() {
7979
setSpeed(position.coords.speed);
8080
});
8181
updateLocation();
82-
}, 2000);
82+
}, 3000);
8383
};
8484

8585
const handlePermissions = async () => {

src/components/points-of-interest/PodcastWrapper.css

Whitespace-only changes.
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
import React, { useEffect } from "react";
2+
3+
function PodcastWrapper({ IFrameUrl }) {
4+
useEffect(() => {}, []);
5+
6+
return (
7+
<iframe
8+
className="soundcloud-iframe"
9+
title="soundcloud-iframe"
10+
width="100%"
11+
height="300"
12+
scrolling="no"
13+
frameBorder="no"
14+
allow="autoplay"
15+
src={IFrameUrl}
16+
/>
17+
);
18+
}
19+
export default PodcastWrapper;

src/components/points-of-interest/PointOfInterest.jsx

Lines changed: 13 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,22 +1,30 @@
11
import { React, useState, useEffect, useContext } from "react";
22
import LatLongContext from "../../context/latitude-longitude-context";
33
import { getDistanceBetweenCoordinates } from "../../util/helper";
4+
import PodcastWrapper from "./PodcastWrapper";
45
import PermissionContext from "../../context/permission-context";
56
import AudioContext from "../../context/audio-context";
67
import Image from "../Image";
78

89
function PointOfInterest({
9-
pointOfInterest: { latitude, longitude, name, image, id, subtitles, podcast },
10+
pointOfInterest: {
11+
latitude,
12+
longitude,
13+
name,
14+
image,
15+
id,
16+
subtitles,
17+
podcast,
18+
IFrameUrl,
19+
},
1020
}) {
11-
const startBtn = document.querySelector(".start-btn");
1221
const { lat, long } = useContext(LatLongContext);
1322
const { setSource } = useContext(AudioContext);
1423
const [proximity, setProximity] = useState(null);
1524
const [unlocked, setUnlocked] = useState(false);
1625
const [viewSubtitles, setViewSubtitles] = useState(false);
1726

1827
const { geolocationAvailable } = useContext(PermissionContext);
19-
2028
useEffect(() => {
2129
if (
2230
latitude &&
@@ -32,7 +40,7 @@ function PointOfInterest({
3240
longitude
3341
);
3442
setProximity(distance);
35-
setUnlocked(distance < 10000); // todo magic number/get from config
43+
setUnlocked(distance < 5); // todo magic number/get from config
3644
}
3745
}, [latitude, longitude, lat, long, geolocationAvailable]);
3846

@@ -100,6 +108,7 @@ function PointOfInterest({
100108
)}
101109
{!unlocked && <div>kan ikke tilgås</div>}
102110
{viewSubtitles && <div>{subtitles}</div>}
111+
{unlocked && IFrameUrl && <PodcastWrapper IFrameUrl={IFrameUrl} />}
103112
</>
104113
);
105114
}

src/components/routes/RoutePage.jsx

Lines changed: 21 additions & 51 deletions
Original file line numberDiff line numberDiff line change
@@ -14,10 +14,7 @@ function RoutePage() {
1414
const [angle, setAngle] = useState(0);
1515
const [latitude, setLatitude] = useState(0);
1616
const [longitude, setLongitude] = useState(0);
17-
const [userLatitude, setUserLatitude] = useState(0);
18-
const [userLongitude, setUserLongitude] = useState(0);
19-
let handlerAvailable = true;
20-
let locationHandlerAvailable = true;
17+
const [destinationName, setDestinationName] = useState(null);
2118
const isIOS =
2219
navigator.userAgent.match(/(iPod|iPhone|iPad)/) &&
2320
navigator.userAgent.match(/AppleWebKit/);
@@ -36,32 +33,24 @@ function RoutePage() {
3633
}, [orientation, angle]);
3734

3835
function locationHandler(pos) {
39-
if (locationHandlerAvailable === false) return;
40-
locationHandlerAvailable = false;
4136
setTimeout(() => {
42-
locationHandlerAvailable = true;
43-
}, 750);
44-
setAngle(
45-
getAngleFromLocationToDestination(
46-
pos.coords.latitude,
47-
pos.coords.longitude,
48-
latitude,
49-
longitude
50-
)
51-
);
52-
setUserLatitude(pos.coords.latitude);
53-
setUserLongitude(pos.coords.longitude);
37+
setAngle(
38+
getAngleFromLocationToDestination(
39+
pos.coords.latitude,
40+
pos.coords.longitude,
41+
latitude,
42+
longitude
43+
)
44+
);
45+
}, 3000);
5446
}
5547

5648
function deviceOrientationHandler(e) {
57-
if (handlerAvailable === false) return;
58-
handlerAvailable = false;
5949
setTimeout(() => {
60-
handlerAvailable = true;
61-
}, 750);
62-
navigator.geolocation.getCurrentPosition(locationHandler);
63-
const orientaionValue = e.webkitCompassHeading || Math.abs(e.alpha - 360);
64-
setOrientation(orientaionValue);
50+
navigator.geolocation.getCurrentPosition(locationHandler);
51+
const orientaionValue = e.webkitCompassHeading || Math.abs(e.alpha - 360);
52+
setOrientation(orientaionValue);
53+
}, 3000);
6554
}
6655

6756
function startWaypointer() {
@@ -91,18 +80,11 @@ function RoutePage() {
9180
}, []);
9281

9382
useEffect(() => {
94-
console.log(pointsOfInterest);
9583
if (pointsOfInterest) {
96-
setLatitude(
97-
Object.values(pointsOfInterest)[
98-
Object.keys(pointsOfInterest).length - 1
99-
].latitude
100-
);
101-
setLongitude(
102-
Object.values(pointsOfInterest)[
103-
Object.keys(pointsOfInterest).length - 1
104-
].longitude
105-
);
84+
console.log(pointsOfInterest);
85+
setLatitude(pointsOfInterest[0].latitude);
86+
setLongitude(pointsOfInterest[0].longitude);
87+
setDestinationName(pointsOfInterest[0].name);
10688
}
10789
}, [pointsOfInterest]);
10890

@@ -129,29 +111,17 @@ function RoutePage() {
129111
}}
130112
src=""
131113
/>
132-
<p
133-
style={{
134-
width: 100,
135-
display: "block",
136-
margin: "auto",
137-
textAlign: "center",
138-
}}
139-
>
140-
user lat: {userLatitude} <br />
141-
user long: {userLongitude} <br />
142-
lat: {latitude} <br />
143-
long: {longitude} <br />
144-
</p>
145114
<button
146115
style={{
147-
width: 100,
116+
width: 300,
117+
height: 100,
148118
display: "block",
149119
margin: "auto",
150120
}}
151121
type="button"
152122
onClick={() => startWaypointer()}
153123
>
154-
Vis mig vej
124+
Vis mig vej til {destinationName}
155125
</button>
156126
</>
157127
);

0 commit comments

Comments
 (0)