forked from MapComplete/MapComplete
		
	Decrese dependency on jquery
This commit is contained in:
		
							parent
							
								
									e3f2c56d3e
								
							
						
					
					
						commit
						d0997480c0
					
				
					 8 changed files with 43 additions and 60 deletions
				
			
		|  | @ -1,6 +1,5 @@ | ||||||
| import FeatureSource from "./FeatureSource"; | import FeatureSource from "./FeatureSource"; | ||||||
| import {UIEventSource} from "../UIEventSource"; | import {UIEventSource} from "../UIEventSource"; | ||||||
| import * as $ from "jquery"; |  | ||||||
| import Loc from "../../Models/Loc"; | import Loc from "../../Models/Loc"; | ||||||
| import State from "../../State"; | import State from "../../State"; | ||||||
| import {Utils} from "../../Utils"; | import {Utils} from "../../Utils"; | ||||||
|  | @ -152,12 +151,8 @@ export default class GeoJsonSource implements FeatureSource { | ||||||
|     private LoadJSONFrom(url: string) { |     private LoadJSONFrom(url: string) { | ||||||
|         const eventSource = this.features; |         const eventSource = this.features; | ||||||
|         const self = this; |         const self = this; | ||||||
|         $.getJSON(url, function (json, status) { |         Utils.downloadJson(url) | ||||||
|             if (status !== "success") { |             .then(json => { | ||||||
|                 self.onFail(status, url); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (json.elements === [] && json.remarks.indexOf("runtime error") > 0) { |             if (json.elements === [] && json.remarks.indexOf("runtime error") > 0) { | ||||||
|                 self.onFail("Runtime error (timeout)", url) |                 self.onFail("Runtime error (timeout)", url) | ||||||
|                 return; |                 return; | ||||||
|  | @ -193,7 +188,7 @@ export default class GeoJsonSource implements FeatureSource { | ||||||
| 
 | 
 | ||||||
|             eventSource.setData(eventSource.data.concat(newFeatures)) |             eventSource.setData(eventSource.data.concat(newFeatures)) | ||||||
| 
 | 
 | ||||||
|         }).fail(msg => self.onFail(msg, url)) |         }).catch(msg => self.onFail(msg, url)) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -4,6 +4,7 @@ import ImageAttributionSource from "./ImageAttributionSource"; | ||||||
| import BaseUIElement from "../../UI/BaseUIElement"; | import BaseUIElement from "../../UI/BaseUIElement"; | ||||||
| import {UIEventSource} from "../UIEventSource"; | import {UIEventSource} from "../UIEventSource"; | ||||||
| import Svg from "../../Svg"; | import Svg from "../../Svg"; | ||||||
|  | import {Utils} from "../../Utils"; | ||||||
| 
 | 
 | ||||||
| export class Mapillary extends ImageAttributionSource { | export class Mapillary extends ImageAttributionSource { | ||||||
| 
 | 
 | ||||||
|  | @ -43,7 +44,7 @@ export class Mapillary extends ImageAttributionSource { | ||||||
|         const key = Mapillary.ExtractKeyFromURL(url) |         const key = Mapillary.ExtractKeyFromURL(url) | ||||||
|         const metadataURL = `https://a.mapillary.com/v3/images/${key}?client_id=TXhLaWthQ1d4RUg0czVxaTVoRjFJZzowNDczNjUzNmIyNTQyYzI2` |         const metadataURL = `https://a.mapillary.com/v3/images/${key}?client_id=TXhLaWthQ1d4RUg0czVxaTVoRjFJZzowNDczNjUzNmIyNTQyYzI2` | ||||||
|         const source = new UIEventSource<LicenseInfo>(undefined) |         const source = new UIEventSource<LicenseInfo>(undefined) | ||||||
|         $.getJSON(metadataURL, function (data) { |         Utils.downloadJson(metadataURL).then(data => { | ||||||
|             const license = new LicenseInfo(); |             const license = new LicenseInfo(); | ||||||
|             license.artist = data.properties?.username; |             license.artist = data.properties?.username; | ||||||
|             license.licenseShortName = "CC BY-SA 4.0"; |             license.licenseShortName = "CC BY-SA 4.0"; | ||||||
|  |  | ||||||
|  | @ -1,4 +1,3 @@ | ||||||
| import * as $ from "jquery" |  | ||||||
| import ImageAttributionSource from "./ImageAttributionSource"; | import ImageAttributionSource from "./ImageAttributionSource"; | ||||||
| import BaseUIElement from "../../UI/BaseUIElement"; | import BaseUIElement from "../../UI/BaseUIElement"; | ||||||
| import Svg from "../../Svg"; | import Svg from "../../Svg"; | ||||||
|  | @ -43,7 +42,7 @@ export class Wikimedia extends ImageAttributionSource { | ||||||
|         } |         } | ||||||
|         const self = this; |         const self = this; | ||||||
|         console.log("Loading a wikimedia category: ", url) |         console.log("Loading a wikimedia category: ", url) | ||||||
|         $.getJSON(url, (response) => { |         Utils.downloadJson(url).then((response) => { | ||||||
|             let imageOverview = new ImagesInCategory(); |             let imageOverview = new ImagesInCategory(); | ||||||
|             let members = response.query?.categorymembers; |             let members = response.query?.categorymembers; | ||||||
|             if (members === undefined) { |             if (members === undefined) { | ||||||
|  | @ -78,7 +77,7 @@ export class Wikimedia extends ImageAttributionSource { | ||||||
| 
 | 
 | ||||||
|     static GetWikiData(id: number, handleWikidata: ((Wikidata) => void)) { |     static GetWikiData(id: number, handleWikidata: ((Wikidata) => void)) { | ||||||
|         const url = "https://www.wikidata.org/wiki/Special:EntityData/Q" + id + ".json"; |         const url = "https://www.wikidata.org/wiki/Special:EntityData/Q" + id + ".json"; | ||||||
|         $.getJSON(url, (response) => { |         Utils.downloadJson(url).then (response => { | ||||||
|             const entity = response.entities["Q" + id]; |             const entity = response.entities["Q" + id]; | ||||||
|             const commons = entity.sitelinks.commonswiki; |             const commons = entity.sitelinks.commonswiki; | ||||||
|             const wd = new Wikidata(); |             const wd = new Wikidata(); | ||||||
|  |  | ||||||
|  | @ -1,5 +1,6 @@ | ||||||
| import $ from "jquery" |  | ||||||
| import State from "../../State"; | import State from "../../State"; | ||||||
|  | import {Utils} from "../../Utils"; | ||||||
|  | 
 | ||||||
| export class Geocoding { | export class Geocoding { | ||||||
| 
 | 
 | ||||||
|     private static readonly host = "https://nominatim.openstreetmap.org/search?"; |     private static readonly host = "https://nominatim.openstreetmap.org/search?"; | ||||||
|  | @ -9,17 +10,12 @@ export class Geocoding { | ||||||
|                   osm_type: string, osm_id: string}[]) => void), |                   osm_type: string, osm_id: string}[]) => void), | ||||||
|                   onFail: (() => void)) { |                   onFail: (() => void)) { | ||||||
|         const b = State.state.leafletMap.data.getBounds(); |         const b = State.state.leafletMap.data.getBounds(); | ||||||
|         console.log(b); |         const url = Geocoding.host + "format=json&limit=1&viewbox=" + | ||||||
|         $.getJSON( |  | ||||||
|             Geocoding.host + "format=json&limit=1&viewbox=" +  |  | ||||||
|             `${b.getEast()},${b.getNorth()},${b.getWest()},${b.getSouth()}`+ |             `${b.getEast()},${b.getNorth()},${b.getWest()},${b.getSouth()}`+ | ||||||
|             "&accept-language=nl&q=" + query, |             "&accept-language=nl&q=" + query; | ||||||
|             function (data) { |         Utils.downloadJson( | ||||||
|                 handleResult(data); |             url) | ||||||
|             }).fail(() => { |             .then(handleResult) | ||||||
|             onFail(); |             .catch(onFail); | ||||||
|         }); |  | ||||||
|     } |     } | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,4 +1,3 @@ | ||||||
| import * as $ from "jquery" |  | ||||||
| import {Utils} from "../../Utils"; | import {Utils} from "../../Utils"; | ||||||
| import * as polygon_features from "../../assets/polygon-features.json"; | import * as polygon_features from "../../assets/polygon-features.json"; | ||||||
| import {UIEventSource} from "../UIEventSource"; | import {UIEventSource} from "../UIEventSource"; | ||||||
|  | @ -151,7 +150,7 @@ export abstract class OsmObject { | ||||||
|         const minlat = bounds[1][0] |         const minlat = bounds[1][0] | ||||||
|         const maxlat = bounds[0][0]; |         const maxlat = bounds[0][0]; | ||||||
|         const url = `${OsmObject.backendURL}api/0.6/map.json?bbox=${minlon},${minlat},${maxlon},${maxlat}` |         const url = `${OsmObject.backendURL}api/0.6/map.json?bbox=${minlon},${minlat},${maxlon},${maxlat}` | ||||||
|         $.getJSON(url, data => { |         Utils.downloadJson(url).then( data => { | ||||||
|             const elements: any[] = data.elements; |             const elements: any[] = data.elements; | ||||||
|             const objects = OsmObject.ParseObjects(elements) |             const objects = OsmObject.ParseObjects(elements) | ||||||
|             callback(objects); |             callback(objects); | ||||||
|  | @ -274,7 +273,7 @@ export abstract class OsmObject { | ||||||
|         const self = this; |         const self = this; | ||||||
|         const full = this.type !== "way" ? "" : "/full"; |         const full = this.type !== "way" ? "" : "/full"; | ||||||
|         const url = `${OsmObject.backendURL}api/0.6/${this.type}/${this.id}${full}`; |         const url = `${OsmObject.backendURL}api/0.6/${this.type}/${this.id}${full}`; | ||||||
|         $.getJSON(url, function (data) { |         Utils.downloadJson(url).then(data => { | ||||||
| 
 | 
 | ||||||
|                 const element = data.elements.pop(); |                 const element = data.elements.pop(); | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,8 +1,8 @@ | ||||||
| import * as $ from "jquery" |  | ||||||
| import * as OsmToGeoJson from "osmtogeojson"; | import * as OsmToGeoJson from "osmtogeojson"; | ||||||
| import Bounds from "../../Models/Bounds"; | import Bounds from "../../Models/Bounds"; | ||||||
| import {TagsFilter} from "../Tags/TagsFilter"; | import {TagsFilter} from "../Tags/TagsFilter"; | ||||||
| import ExtractRelations from "./ExtractRelations"; | import ExtractRelations from "./ExtractRelations"; | ||||||
|  | import {Utils} from "../../Utils"; | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * Interfaces overpass to get all the latest data |  * Interfaces overpass to get all the latest data | ||||||
|  | @ -27,14 +27,8 @@ export class Overpass { | ||||||
|             console.log("Using testing URL") |             console.log("Using testing URL") | ||||||
|             query = Overpass.testUrl; |             query = Overpass.testUrl; | ||||||
|         } |         } | ||||||
|         $.getJSON(query, |         Utils.downloadJson(query) | ||||||
|             function (json, status) { |             .then(json => { | ||||||
|                 if (status !== "success") { |  | ||||||
|                     console.log("Query failed") |  | ||||||
|                     onFail(status); |  | ||||||
|                     return; |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 if (json.elements === [] && json.remarks.indexOf("runtime error") > 0) { |                 if (json.elements === [] && json.remarks.indexOf("runtime error") > 0) { | ||||||
|                     console.log("Timeout or other runtime error"); |                     console.log("Timeout or other runtime error"); | ||||||
|                     onFail("Runtime error (timeout)") |                     onFail("Runtime error (timeout)") | ||||||
|  | @ -47,8 +41,7 @@ export class Overpass { | ||||||
|                 const osmTime = new Date(json.osm3s.timestamp_osm_base); |                 const osmTime = new Date(json.osm3s.timestamp_osm_base); | ||||||
| 
 | 
 | ||||||
|                 continuation(geojson, osmTime); |                 continuation(geojson, osmTime); | ||||||
| 
 |             }).catch(onFail) | ||||||
|             }).fail(onFail) |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     buildQuery(bbox: string): string { |     buildQuery(bbox: string): string { | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| 
 |  | ||||||
| import {UIEventSource} from "../UIEventSource"; | import {UIEventSource} from "../UIEventSource"; | ||||||
| import * as $ from "jquery" | import {Utils} from "../../Utils"; | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * Fetches data from random data sources, used in the metatagging |  * Fetches data from random data sources, used in the metatagging | ||||||
|  */ |  */ | ||||||
|  | @ -25,7 +25,7 @@ export default class LiveQueryHandler { | ||||||
|             LiveQueryHandler[url] = source; |             LiveQueryHandler[url] = source; | ||||||
| 
 | 
 | ||||||
|                 console.log("Fetching live data from a third-party (unknown) API:",url) |                 console.log("Fetching live data from a third-party (unknown) API:",url) | ||||||
|             $.getJSON(url, function (data) { |             Utils.downloadJson(url).then(data => { | ||||||
|                 for (const shorthandDescription of shorthandsSet) { |                 for (const shorthandDescription of shorthandsSet) { | ||||||
| 
 | 
 | ||||||
|                     const descr = shorthandDescription.trim().split(":"); |                     const descr = shorthandDescription.trim().split(":"); | ||||||
|  |  | ||||||
							
								
								
									
										32
									
								
								Utils.ts
									
										
									
									
									
								
							
							
						
						
									
										32
									
								
								Utils.ts
									
										
									
									
									
								
							|  | @ -9,12 +9,10 @@ export class Utils { | ||||||
|      */ |      */ | ||||||
|     public static runningFromConsole = false; |     public static runningFromConsole = false; | ||||||
|     public static readonly assets_path = "./assets/svg/"; |     public static readonly assets_path = "./assets/svg/"; | ||||||
| 
 |     public static externalDownloadFunction: (url: string) => Promise<any>; | ||||||
| 
 |  | ||||||
|     private static knownKeys = ["addExtraTags", "and", "calculatedTags", "changesetmessage", "clustering", "color", "condition", "customCss", "dashArray", "defaultBackgroundId", "description", "descriptionTail", "doNotDownload", "enableAddNewPoints", "enableBackgroundLayerSelection", "enableGeolocation", "enableLayers", "enableMoreQuests", "enableSearch", "enableShareScreen", "enableUserBadge", "freeform", "hideFromOverview", "hideInAnswer", "icon", "iconOverlays", "iconSize", "id", "if", "ifnot", "isShown", "key", "language", "layers", "lockLocation", "maintainer", "mappings", "maxzoom", "maxZoom", "minNeededElements", "minzoom", "multiAnswer", "name", "or", "osmTags", "passAllFeatures", "presets", "question", "render", "roaming", "roamingRenderings", "rotation", "shortDescription", "socialImage", "source", "startLat", "startLon", "startZoom", "tagRenderings", "tags", "then", "title", "titleIcons", "type", "version", "wayHandling", "widenFactor", "width"] |     private static knownKeys = ["addExtraTags", "and", "calculatedTags", "changesetmessage", "clustering", "color", "condition", "customCss", "dashArray", "defaultBackgroundId", "description", "descriptionTail", "doNotDownload", "enableAddNewPoints", "enableBackgroundLayerSelection", "enableGeolocation", "enableLayers", "enableMoreQuests", "enableSearch", "enableShareScreen", "enableUserBadge", "freeform", "hideFromOverview", "hideInAnswer", "icon", "iconOverlays", "iconSize", "id", "if", "ifnot", "isShown", "key", "language", "layers", "lockLocation", "maintainer", "mappings", "maxzoom", "maxZoom", "minNeededElements", "minzoom", "multiAnswer", "name", "or", "osmTags", "passAllFeatures", "presets", "question", "render", "roaming", "roamingRenderings", "rotation", "shortDescription", "socialImage", "source", "startLat", "startLon", "startZoom", "tagRenderings", "tags", "then", "title", "titleIcons", "type", "version", "wayHandling", "widenFactor", "width"] | ||||||
|     private static extraKeys = ["nl", "en", "fr", "de", "pt", "es", "name", "phone", "email", "amenity", "leisure", "highway", "building", "yes", "no", "true", "false"] |     private static extraKeys = ["nl", "en", "fr", "de", "pt", "es", "name", "phone", "email", "amenity", "leisure", "highway", "building", "yes", "no", "true", "false"] | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|     static EncodeXmlValue(str) { |     static EncodeXmlValue(str) { | ||||||
|         if (typeof str !== "string") { |         if (typeof str !== "string") { | ||||||
|             str = "" + str |             str = "" + str | ||||||
|  | @ -72,10 +70,10 @@ export class Utils { | ||||||
|         return res; |         return res; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static TimesT<T>(count : number, f: ((i: number) => T)): T[] { |     public static TimesT<T>(count: number, f: ((i: number) => T)): T[] { | ||||||
|         let res : T[] = []; |         let res: T[] = []; | ||||||
|         for (let i = 0; i < count; i++) { |         for (let i = 0; i < count; i++) { | ||||||
|             res .push(f(i)); |             res.push(f(i)); | ||||||
|         } |         } | ||||||
|         return res; |         return res; | ||||||
|     } |     } | ||||||
|  | @ -158,7 +156,7 @@ export class Utils { | ||||||
| 
 | 
 | ||||||
|     public static SubstituteKeys(txt: string, tags: any) { |     public static SubstituteKeys(txt: string, tags: any) { | ||||||
|         for (const key in tags) { |         for (const key in tags) { | ||||||
|             if(!tags.hasOwnProperty(key)) { |             if (!tags.hasOwnProperty(key)) { | ||||||
|                 continue |                 continue | ||||||
|             } |             } | ||||||
|             txt = txt.replace(new RegExp("{" + key + "}", "g"), tags[key]) |             txt = txt.replace(new RegExp("{" + key + "}", "g"), tags[key]) | ||||||
|  | @ -292,7 +290,7 @@ export class Utils { | ||||||
| 
 | 
 | ||||||
|     public static UnMinify(minified: string): string { |     public static UnMinify(minified: string): string { | ||||||
| 
 | 
 | ||||||
|         if(minified === undefined || minified === null){ |         if (minified === undefined || minified === null) { | ||||||
|             return undefined; |             return undefined; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -324,28 +322,30 @@ export class Utils { | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static externalDownloadFunction: (url: string) => Promise<any>; |     public static downloadJson(url: string): Promise<any> { | ||||||
|      |         if (this.externalDownloadFunction !== undefined) { | ||||||
|     public static downloadJson(url: string): Promise<any>{ |  | ||||||
|         if(this.externalDownloadFunction !== undefined){ |  | ||||||
|             return this.externalDownloadFunction(url) |             return this.externalDownloadFunction(url) | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return new Promise( |         return new Promise( | ||||||
|             (resolve, reject) => { |             (resolve, reject) => { | ||||||
|                 try{ |                 try { | ||||||
|                     const xhr = new XMLHttpRequest(); |                     const xhr = new XMLHttpRequest(); | ||||||
|                     xhr.onload = () => { |                     xhr.onload = () => { | ||||||
|                         if (xhr.status == 200) { |                         if (xhr.status == 200) { | ||||||
|                             resolve(JSON.parse(xhr.response)) |                             try { | ||||||
|  |                                 resolve(JSON.parse(xhr.response)) | ||||||
|  |                             } catch (e) { | ||||||
|  |                                 reject("Not a valid json: " + xhr.response) | ||||||
|  |                             } | ||||||
|                         } else { |                         } else { | ||||||
|                             reject(xhr.statusText) |                             reject(xhr.statusText) | ||||||
|                         } |                         } | ||||||
|                     }; |                     }; | ||||||
|                     xhr.open('GET', url); |                     xhr.open('GET', url); | ||||||
|                     xhr.setRequestHeader("accept","application/json") |                     xhr.setRequestHeader("accept", "application/json") | ||||||
|                     xhr.send(); |                     xhr.send(); | ||||||
|                 }catch(e){ |                 } catch (e) { | ||||||
|                     reject(e) |                     reject(e) | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue