You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
97 lines
3.0 KiB
97 lines
3.0 KiB
import { Component, AfterViewInit, ViewChild, ElementRef, OnInit } from '@angular/core';
|
|
|
|
import { environment } from '@env/environment';
|
|
|
|
import * as mapboxgl from 'mapbox-gl';
|
|
import { LogsService } from '@app/logs.service';
|
|
|
|
import { interval } from 'rxjs';
|
|
|
|
@Component({
|
|
selector: 'app-map',
|
|
templateUrl: './map.component.html',
|
|
styleUrls: ['./map.component.scss']
|
|
})
|
|
export class MapComponent implements OnInit {
|
|
version: string | null = environment.version;
|
|
|
|
pointsToDisplay = 10;
|
|
|
|
// data: Array<Object>;
|
|
|
|
map: mapboxgl.Map;
|
|
style = 'mapbox://styles/mapbox/streets-v11';
|
|
lat = 37.9838;
|
|
lng = 23.7275;
|
|
|
|
sub: any;
|
|
|
|
lastPoint: number[];
|
|
|
|
ommitedPoints: number = 0;
|
|
displayedPoints: number = 0;
|
|
|
|
constructor(private logsService: LogsService) {}
|
|
|
|
async ngOnInit() {
|
|
Object.getOwnPropertyDescriptor(mapboxgl, 'accessToken').set(environment.mapbox.accessToken);
|
|
this.map = new mapboxgl.Map({
|
|
container: 'map',
|
|
style: this.style,
|
|
center: [this.lng, this.lat],
|
|
zoom: 9
|
|
});
|
|
|
|
// Add map controls
|
|
// this.map.addControl(new mapboxgl.NavigationControl());
|
|
|
|
var firstRun: Boolean = true;
|
|
|
|
this.sub = interval(1000).subscribe(async val => {
|
|
let data: Array<Object>;
|
|
if (firstRun) {
|
|
data = await this.logsService.getLogsFirstRun();
|
|
firstRun = false;
|
|
if (data.length > this.pointsToDisplay) {
|
|
this.ommitedPoints = data.length - this.pointsToDisplay;
|
|
data = data.slice(data.length - this.pointsToDisplay, data.length);
|
|
}
|
|
} else {
|
|
data = await this.logsService.getUpdates();
|
|
}
|
|
let newPointsCount = 0;
|
|
this.displayedPoints = this.displayedPoints + data.length;
|
|
for (let log of data) {
|
|
if (log['gps_data']['status'] == 'A') {
|
|
newPointsCount++;
|
|
let html =
|
|
log['gps_data']['datestamp'] +
|
|
' ' +
|
|
log['gps_data']['timestamp'] +
|
|
'<br><table><tr><th>Sensor </th><th>Reading</th></tr>';
|
|
for (let record in log['sensorReadings']) {
|
|
if (Object.prototype.hasOwnProperty.call(log['sensorReadings'], record)) {
|
|
html += '<tr><td>' + record + '</td>' + '<td>' + log['sensorReadings'][record] + '</td></tr>';
|
|
}
|
|
}
|
|
html += '</table>';
|
|
var popup = new mapboxgl.Popup({ offset: 25 }).setHTML(html);
|
|
var marker = new mapboxgl.Marker({
|
|
draggable: false
|
|
})
|
|
.setLngLat([log['gps_data']['longitude'], log['gps_data']['latitude']])
|
|
.setPopup(popup)
|
|
.addTo(this.map);
|
|
}
|
|
this.lastPoint = [log['gps_data']['longitude'], log['gps_data']['latitude']];
|
|
}
|
|
if (newPointsCount) {
|
|
this.map.flyTo({
|
|
center: [this.lastPoint[0], this.lastPoint[1]],
|
|
essential: true, // this animation is considered essential with respect to prefers-reduced-motion
|
|
zoom: 22
|
|
});
|
|
}
|
|
});
|
|
}
|
|
}
|
|
|