1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/ui/gallery/map/map.service.ts

98 lines
3.5 KiB
TypeScript
Raw Normal View History

2018-11-26 07:26:29 +08:00
import {Injectable} from '@angular/core';
import {NetworkService} from '../../../model/network/network.service';
import {FileDTO} from '../../../../../common/entities/FileDTO';
import {Utils} from '../../../../../common/Utils';
import {Config} from '../../../../../common/config/public/Config';
import {ClientConfig} from '../../../../../common/config/public/ConfigClass';
import MapLayers = ClientConfig.MapLayers;
2018-11-26 07:26:29 +08:00
@Injectable()
export class MapService {
private static readonly OSMLAYERS = [{name: 'street', url: 'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png'}];
private static MAPBOXLAYERS: MapLayers[] = [];
2018-11-26 07:26:29 +08:00
constructor(private networkService: NetworkService) {
MapService.MAPBOXLAYERS = [{
name: 'street', url: 'https://api.tiles.mapbox.com/v4/mapbox.streets/{z}/{x}/{y}.png?access_token='
+ Config.Client.Map.mapboxAccessToken
}, {
name: 'satellite', url: 'https://api.tiles.mapbox.com/v4/mapbox.satellite/{z}/{x}/{y}.png?access_token='
+ Config.Client.Map.mapboxAccessToken
}, {
name: 'hybrid', url: 'https://api.tiles.mapbox.com/v4/mapbox.streets-satellite/{z}/{x}/{y}.png?access_token='
+ Config.Client.Map.mapboxAccessToken
2018-11-26 07:26:29 +08:00
}
];
2018-11-26 07:26:29 +08:00
}
2018-12-08 18:28:56 +08:00
public get ShortAttributions(): string[] {
const yaga = '<a href="https://yagajs.org" title="YAGA">YAGA</a>';
const lf = '<a href="https://leaflet-ng2.yagajs.org" title="Leaflet in Angular2">leaflet-ng2</a>';
const OSM = '<a href="https://www.openstreetmap.org/copyright">OSM</a>';
const MB = '<a href="https://www.mapbox.com/">Mapbox</a>';
if (Config.Client.Map.mapProvider === ClientConfig.MapProviders.OpenStreetMap) {
return [yaga + ' | &copy; ' + OSM];
}
if (Config.Client.Map.mapProvider === ClientConfig.MapProviders.Mapbox) {
return [yaga + ' | ' + OSM + ' | ' + MB];
}
return [yaga + ' | ' + lf];
}
public get Attributions(): string[] {
2018-12-08 18:28:56 +08:00
const yagalf = '<a href="https://yagajs.org" title="YAGA">YAGA</a> | ' +
'<a href="https://leaflet-ng2.yagajs.org" title="Leaflet in Angular2">leaflet-ng2</a>';
const OSM = '&copy; <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a>';
const MB = '&copy; <a href="https://www.mapbox.com/">Mapbox</a>';
if (Config.Client.Map.mapProvider === ClientConfig.MapProviders.OpenStreetMap) {
return [yagalf + ' | ' + OSM];
}
if (Config.Client.Map.mapProvider === ClientConfig.MapProviders.Mapbox) {
return [yagalf + ' | ' + OSM + ' | ' + MB];
}
return [yagalf];
}
public get MapLayer(): string {
return this.Layers[0].url;
}
public get Layers(): { name: string, url: string }[] {
switch (Config.Client.Map.mapProvider) {
case ClientConfig.MapProviders.Custom:
return Config.Client.Map.customLayers;
case ClientConfig.MapProviders.Mapbox:
return MapService.MAPBOXLAYERS;
case ClientConfig.MapProviders.OpenStreetMap:
return MapService.OSMLAYERS;
}
}
public async getMapPath(file: FileDTO): Promise<MapPath[]> {
const filePath = Utils.concatUrls(file.directory.path, file.directory.name, file.name);
const gpx = await this.networkService.getXML('/gallery/content/' + filePath);
const elements = gpx.getElementsByTagName('trkpt');
const points: MapPath[] = [];
for (let i = 0; i < elements.length; i++) {
points.push({
lat: parseFloat(elements[i].getAttribute('lat')),
lng: parseFloat(elements[i].getAttribute('lon'))
});
2018-12-08 18:28:56 +08:00
}
return points;
}
2018-11-26 07:26:29 +08:00
}
export interface MapPath {
lat: number;
lng: number;
2018-11-26 07:26:29 +08:00
}