Skip to content

Commit

Permalink
Revert "PR Dropdown"
Browse files Browse the repository at this point in the history
This reverts commit 8671838.
  • Loading branch information
jahn18 committed Mar 9, 2024
1 parent 8671838 commit 16a9a1c
Show file tree
Hide file tree
Showing 21 changed files with 468 additions and 398 deletions.
229 changes: 100 additions & 129 deletions src/website/package-lock.json

Large diffs are not rendered by default.

5 changes: 2 additions & 3 deletions src/website/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,9 @@
"format": "prettier --write ."
},
"dependencies": {
"@emotion/react": "^11.11.4",
"@emotion/react": "^11.11.1",
"@emotion/styled": "^11.11.0",
"@mui/icons-material": "^5.15.10",
"@mui/material": "^5.15.12",
"@mui/material": "^5.14.12",
"@react-google-maps/api": "^2.19.2",
"@reduxjs/toolkit": "^1.9.5",
"dotenv": "^16.3.1",
Expand Down
6 changes: 0 additions & 6 deletions src/website/pages/Polaris/index.tsx

This file was deleted.

5 changes: 4 additions & 1 deletion src/website/pages/index.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import dynamic from 'next/dynamic';
import { CircularProgress } from '@mui/material';
import DashboardContainer from '@/views/DashboardContainer';
import Header from '@/views/components/Header/Header';
import styles from './style.module.css';

Expand All @@ -22,6 +21,10 @@ const MapsContainer = dynamic(() => import('@/views/MapsContainer'), {
ssr: false,
});

const DashboardContainer = dynamic(() => import('@/views/DashboardContainer'), {
ssr: false,
});

export default function Home() {
return (
<>
Expand Down
Binary file added src/website/public/BoatIconFinal.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/website/public/NSEWCompass.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added src/website/public/NSEWCompassBackdrop.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file removed src/website/public/Polaris.png
Binary file not shown.
78 changes: 72 additions & 6 deletions src/website/views/DashboardContainer.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,17 @@
import React from 'react';
import { connect } from 'react-redux';
import UPlotLineChartComponent from './components/LineChart/UPlotLineChart';
import { GPS } from '@/stores/GPS/GPSTypes';
import { Batteries } from '@/stores/Batteries/BatteriesTypes';
import { WindSensors } from '@/stores/WindSensors/WindSensorsTypes';
import { GPSState } from '@/stores/GPS/GPSTypes';
import { BatteriesState } from '@/stores/Batteries/BatteriesTypes';
import { WindSensorsState } from '@/stores/WindSensors/WindSensorsTypes';
import UPlotMultiLineChartComponent from './components/LineChart/UPlotMultiLineChart';
import SingleValueChart from './components/SingleValueChart/SingleValueChart';
import { Grid } from '@mui/material';

export interface DashboardContainerProps {
gps: GPS[];
batteries: Batteries[];
windSensors: WindSensors[];
gps: GPSState;
batteries: BatteriesState;
windSensors: WindSensorsState;
}

class DashboardContainer extends React.PureComponent<DashboardContainerProps> {
Expand All @@ -21,6 +23,11 @@ class DashboardContainer extends React.PureComponent<DashboardContainerProps> {
gps.data.map((data) => data.speed),
];

const gpsDistanceData = [
gps.data.map((data) => data.latitude),
gps.data.map((data) => data.longitude)
];

const batteriesVoltageData = [
batteries.data.map((data) => this._parseISOString(data.timestamp)),
batteries.data.map((data) => data.batteries[0].voltage),
Expand All @@ -39,8 +46,29 @@ class DashboardContainer extends React.PureComponent<DashboardContainerProps> {
windSensors.data.map((data) => data.windSensors[1].speed),
];

const totalTripDistance = this._computeTotalTripDistance(gpsDistanceData[0], gpsDistanceData[1])

return (
<div>
{/* <Grid
container spacing={0}
direction={"row"}
justifyContent={"center"}
alignItems={"center"}
>
<Grid container justifyContent="center" item xs={3}>
<SingleValueChart title="Distance" data={totalTripDistance} unit="km" />
</Grid>
<Grid container justifyContent="center" item xs={3}>
<SingleValueChart title="Heading" data={this.props.gps.data.at(-1)?.heading} unit=""/>
</Grid>
<Grid container justifyContent="center" item xs={3}>
<SingleValueChart title="Latitude" data={this.props.gps.data.at(-1)?.latitude.toFixed(2)} unit="°"/>
</Grid>
<Grid container justifyContent="center" item xs={3}>
<SingleValueChart title="Longitude" data={this.props.gps.data.at(-1)?.longitude.toFixed(2)} unit="°"/>
</Grid>
</Grid> */}
<UPlotLineChartComponent
data={gpsChartData}
label='Boat Speed'
Expand Down Expand Up @@ -71,6 +99,44 @@ class DashboardContainer extends React.PureComponent<DashboardContainerProps> {
_parseISOString(s: string) {
return Math.floor(Date.parse(s) / 1000); // Converts to seconds
}

_haversineDistance(lat1: number, long1: number, lat2: number, long2: number) {

function toRadians(angle: number): number{
return angle * Math.PI / 180
}

const EARTH_RADIUS = 6571 // in km

let delta_lat = lat2-lat1
let delta_lat_rad = toRadians(delta_lat)
let delta_long = long2-long1
let delta_long_rad = toRadians(delta_long)

let a = (Math.sin(delta_lat_rad/2) * Math.sin(delta_lat_rad/2))
+ (Math.cos(toRadians(lat1)) * Math.cos(toRadians(lat2))
* Math.sin(delta_long_rad/2)
* Math.sin(delta_long_rad/2))
let c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));

let distance = EARTH_RADIUS * c;

return distance
}

_computeTotalTripDistance(latitude: number[], longitude: number[]) {
if(latitude.length != longitude.length){
return -1;
}

let totalDistance = 0;

for(let i = 1; i < latitude.length; i++){
totalDistance += this._haversineDistance(latitude[i-1], longitude[i-1], latitude[i], longitude[i]);
}

return Number(totalDistance.toFixed(2));
}
}

const mapStateToProps = (state: any) => ({
Expand Down
84 changes: 71 additions & 13 deletions src/website/views/MapsContainer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,9 @@ import { GlobalPathState } from '@/stores/GlobalPath/GlobalPathTypes';
import { AISShipsState } from '@/stores/AISShips/AISShipsTypes';
import { WayPoint, LocalPathState } from '@/stores/LocalPath/LocalPathTypes';
import Maps, { convertToLatLng } from './components/Maps/Maps';
import SingleValueLine from './components/SingleValueLine/SingleValueLine';
import styles from './components/SingleValueLine/singlevalueline.module.css'
import BoatCompass from './components/BoatCompass/BoatCompass';

export interface MapsContainerProps {
gps: GPSState;
Expand All @@ -15,22 +18,77 @@ export interface MapsContainerProps {

class MapsContainer extends React.PureComponent<MapsContainerProps> {
render() {
const { gps } = this.props;

const gpsDistanceData = [
gps.data.map((data) => data.latitude),
gps.data.map((data) => data.longitude)
];

const totalTripDistance = this._computeTotalTripDistance(gpsDistanceData[0], gpsDistanceData[1])

return (
<Maps
gpsLocation={this.props.gps.data.at(-1)}
gpsPath={this.props.gps.data.map((gpsPoint: GPS) =>
convertToLatLng(gpsPoint),
)}
globalPath={this.props.globalPath.data.waypoints.map(
(waypoint: WayPoint) => convertToLatLng(waypoint),
)}
aisShips={this.props.aisShips.data.ships}
localPath={this.props.localPath.data.waypoints.map(
(waypoint: WayPoint) => convertToLatLng(waypoint),
)}
/>
<div className={styles.parent}>
<div className={styles.topRight}>
<SingleValueLine title="Distance" data={totalTripDistance} unit="km" />
</div>
<div className={styles.bottomRight}>
<BoatCompass angle={this.props.gps.data.at(-1)?.heading} />
</div>
<Maps
gpsLocation={this.props.gps.data.at(-1)}
gpsPath={this.props.gps.data.map((gpsPoint: GPS) =>
convertToLatLng(gpsPoint),
)}
globalPath={this.props.globalPath.data.waypoints.map(
(waypoint: WayPoint) => convertToLatLng(waypoint),
)}
aisShips={this.props.aisShips.data.ships}
localPath={this.props.localPath.data.waypoints.map(
(waypoint: WayPoint) => convertToLatLng(waypoint),
)}
/>
</div>
);
}

_haversineDistance(lat1: number, long1: number, lat2: number, long2: number) {

function toRadians(angle: number): number{
return angle * Math.PI / 180
}

const EARTH_RADIUS = 6571 // in km

let delta_lat = lat2-lat1
let delta_lat_rad = toRadians(delta_lat)
let delta_long = long2-long1
let delta_long_rad = toRadians(delta_long)

let a = (Math.sin(delta_lat_rad/2) * Math.sin(delta_lat_rad/2))
+ (Math.cos(toRadians(lat1)) * Math.cos(toRadians(lat2))
* Math.sin(delta_long_rad/2)
* Math.sin(delta_long_rad/2))
let c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));

let distance = EARTH_RADIUS * c;

return distance
}

_computeTotalTripDistance(latitude: number[], longitude: number[]) {
if(latitude.length != longitude.length){
return -1;
}

let totalDistance = 0;

for(let i = 1; i < latitude.length; i++){
totalDistance += this._haversineDistance(latitude[i-1], longitude[i-1], latitude[i], longitude[i]);
}

return Number(totalDistance.toFixed(2));
}
}

const mapStateToProps = (state: any) => ({
Expand Down
101 changes: 0 additions & 101 deletions src/website/views/PolarisContainer.tsx

This file was deleted.

Loading

0 comments on commit 16a9a1c

Please sign in to comment.