mapcomplete/Logic/Osm/Overpass.ts

56 lines
1.8 KiB
TypeScript
Raw Normal View History

2020-07-30 00:59:08 +02:00
import {Bounds} from "../Bounds";
import {TagsFilter} from "../Tags";
2020-07-30 00:59:08 +02:00
import $ from "jquery"
import * as OsmToGeoJson from "osmtogeojson";
/**
* Interfaces overpass to get all the latest data
*/
2020-06-24 00:35:19 +02:00
export class Overpass {
private _filter: TagsFilter
public static testUrl: string = null
2020-06-24 00:35:19 +02:00
constructor(filter: TagsFilter) {
this._filter = filter
2020-06-24 00:35:19 +02:00
}
2020-07-30 00:59:08 +02:00
private buildQuery(bbox: string): string {
const filters = this._filter.asOverpass()
let filter = ""
2020-06-24 00:35:19 +02:00
for (const filterOr of filters) {
filter += 'nwr' + filterOr + ';'
2020-06-24 00:35:19 +02:00
}
const query =
'[out:json][timeout:25]' + bbox + ';(' + filter + ');out body;>;out skel qt;'
return "https://overpass-api.de/api/interpreter?data=" + encodeURIComponent(query)
2020-06-24 00:35:19 +02:00
}
2020-07-30 00:59:08 +02:00
queryGeoJson(bounds: Bounds, continuation: ((any) => void), onFail: ((reason) => void)): void {
let query = this.buildQuery( "[bbox:" + bounds.south + "," + bounds.west + "," + bounds.north + "," + bounds.east + "]")
2020-07-20 20:15:21 +02:00
2020-06-24 00:35:19 +02:00
if(Overpass.testUrl !== null){
console.log("Using testing URL")
query = Overpass.testUrl;
}
$.getJSON(query,
function (json, status) {
if (status !== "success") {
console.log("Query failed")
onFail(status);
}
2020-07-20 20:15:21 +02:00
2020-07-01 21:21:29 +02:00
if(json.elements === [] && json.remarks.indexOf("runtime error") > 0){
console.log("Timeout or other runtime error");
onFail("Runtime error (timeout)")
2020-07-01 21:21:29 +02:00
return;
}
2020-06-24 00:35:19 +02:00
// @ts-ignore
const geojson = OsmToGeoJson.default(json);
continuation(geojson);
}).fail(onFail)
}
}