A bunch of cleanup and added stability

This commit is contained in:
Zakary Timson 2019-09-08 19:00:36 -04:00
parent 99bb7068b2
commit f899772218
6 changed files with 36 additions and 8 deletions

View File

@ -1,7 +1,7 @@
<div class="pt-sm-2"> <div class="pt-sm-2">
<div class="d-flex flex-column-reverse flex-sm-row"> <div class="d-flex flex-column-reverse flex-sm-row">
<div class="flex-grow-1"> <div class="flex-grow-1">
<mat-form-field appearance="fill" class="w-100 pr-sm-3"> <mat-form-field appearance="fill" class="w-100 pr-sm-3" style="max-width: 300px">
<mat-label>Label</mat-label> <mat-label>Label</mat-label>
<input matInput [(ngModel)]="symbol.label"> <input matInput [(ngModel)]="symbol.label">
</mat-form-field> </mat-form-field>

View File

@ -21,9 +21,22 @@ export class EditSymbolComponent {
} }
close() { close() {
if(this.mapItem.getRadius) {
let latlng = this.mapItem.getLatLng(); let latlng = this.mapItem.getLatLng();
this.symbol.latlng = {lat: latlng.lat, lng: latlng.lng}; this.symbol.latlng = {lat: latlng.lat, lng: latlng.lng};
if(this.mapItem.getRadius) this.symbol['radius'] = this.mapItem.getRadius(); this.symbol['radius'] = this.mapItem.getRadius();
} else if(this.mapItem.getLatLngs) {
let path = this.mapItem.getLatLngs();
this.symbol.latlng = path[0].map(latlng => ({lat: latlng.lat, lng: latlng.lng}));
} else if(this.mapItem.getBounds) {
let bounds = this.mapItem.getBounds();
this.symbol.latlng = {lat: bounds['_northEast'].lat, lng: bounds['_northEast'].lng};
this.symbol['latlng2'] = {lat: bounds['_southWest'].lat, lng: bounds['_southWest'].lng};
} else if(this.mapItem.getLatLng) {
let latlng = this.mapItem.getLatLng();
this.symbol.latlng = {lat: latlng.lat, lng: latlng.lng};
}
this.ref.dismiss(this.symbol); this.ref.dismiss(this.symbol);
} }

View File

@ -132,6 +132,7 @@ export class MapService {
newPolygon(p: Polygon) { newPolygon(p: Polygon) {
let polygon = new L.Polygon(p.latlng, Object.assign({color: '#ff4141', autoPan: false}, p)).addTo(this.map); let polygon = new L.Polygon(p.latlng, Object.assign({color: '#ff4141', autoPan: false}, p)).addTo(this.map);
if(p.label) polygon.bindTooltip(p.label, {permanent: true});
polygon.on('click', e => this.click.next({latlng: {lat: e.latlng.lat, lng: e.latlng.lng}, symbol: p, item: polygon})); polygon.on('click', e => this.click.next({latlng: {lat: e.latlng.lat, lng: e.latlng.lng}, symbol: p, item: polygon}));
if(!p.noDelete) this.polygons.push(polygon); if(!p.noDelete) this.polygons.push(polygon);
return polygon; return polygon;

View File

@ -131,11 +131,13 @@ export class SyncService {
mergeMaps(newMap: MapData, oldMap: MapData) { mergeMaps(newMap: MapData, oldMap: MapData) {
let map: MapData = {locations: {}}; let map: MapData = {locations: {}};
let twoMinAgo = new Date();
twoMinAgo.setMinutes(twoMinAgo.getMinutes() - 2);
Object.keys(newMap).forEach(key => { Object.keys(newMap).forEach(key => {
if(!map[key]) map[key] = {}; if(!map[key]) map[key] = {};
Object.keys(newMap[key]).forEach(id => map[key][id] = newMap[key][id]); Object.keys(newMap[key]).filter(id => !newMap[key][id].deleted || newMap[key][id].updated > twoMinAgo)
.forEach(id => map[key][id] = newMap[key][id]);
}); });
Object.keys(oldMap).filter(key => key != 'locations').forEach(key => { Object.keys(oldMap).filter(key => key != 'locations').forEach(key => {
if(!map[key]) map[key] = {}; if(!map[key]) map[key] = {};
Object.keys(oldMap[key]).filter(id => { Object.keys(oldMap[key]).filter(id => {

View File

@ -111,8 +111,15 @@ export class MapComponent implements OnDestroy, OnInit {
if(this.sub == null && e.symbol) { if(this.sub == null && e.symbol) {
if(e.symbol.noClick) return; if(e.symbol.noClick) return;
this.syncService.freeze.next(true); this.syncService.freeze.next(true);
this.sub = this.bottomSheet.open(EditSymbolComponent, {data: e, disableClose: true, hasBackdrop: false}).afterDismissed().pipe(finalize(() => this.sub = null)).subscribe(symbol => { let ref = this.bottomSheet.open(EditSymbolComponent, {data: e, disableClose: true, hasBackdrop: false});
this.syncService.addCircle(symbol); this.sub = ref.afterDismissed().pipe(finalize(() => {
ref.dismiss();
this.sub = null
})).subscribe(symbol => {
if(e.item instanceof L.Circle) this.syncService.addCircle(symbol);
else if(e.item instanceof L.Rectangle) this.syncService.addRectangle(symbol);
else if(e.item instanceof L.Marker) this.syncService.addMarker(symbol);
else if(e.item instanceof L.Polygon) this.syncService.addPolygon(symbol);
this.syncService.freeze.next(false); this.syncService.freeze.next(false);
}); });
} }
@ -191,6 +198,7 @@ export class MapComponent implements OnDestroy, OnInit {
}; };
startDelete = () => { startDelete = () => {
if(this.sub) this.sub.unsubscribe();
this.sub = this.map.click.pipe(skip(1), filter(e => !!e.symbol)).subscribe(e => { this.sub = this.map.click.pipe(skip(1), filter(e => !!e.symbol)).subscribe(e => {
if (!!e.symbol && e.symbol.noDeleteTool) return; if (!!e.symbol && e.symbol.noDeleteTool) return;
this.syncService.delete(e.symbol) this.syncService.delete(e.symbol)

View File

@ -60,6 +60,10 @@ a[href^="https://maps.google.com/maps"]{display:none !important}
background: rgba(0, 0, 0, 0.6) !important; background: rgba(0, 0, 0, 0.6) !important;
border-color: rgba(0, 0, 0, 0.6) !important; border-color: rgba(0, 0, 0, 0.6) !important;
color: white; color: white;
&:before {
border-right-color: rgba(0, 0, 0, 0.6) !important;
}
} }
.leaflet-tooltip-bottom:before { .leaflet-tooltip-bottom:before {