forked from MapComplete/MapComplete
		
	
		
			
	
	
		
			928 lines
		
	
	
	
		
			36 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
		
		
			
		
	
	
			928 lines
		
	
	
	
		
			36 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
|  | import {describe} from 'mocha' | ||
|  | import {expect} from 'chai' | ||
|  | import Minimap from "../../../../UI/Base/Minimap"; | ||
|  | import {Utils} from "../../../../Utils"; | ||
|  | import LayoutConfig from "../../../../Models/ThemeConfig/LayoutConfig"; | ||
|  | import State from "../../../../State"; | ||
|  | import {BBox} from "../../../../Logic/BBox"; | ||
|  | import ReplaceGeometryAction from "../../../../Logic/Osm/Actions/ReplaceGeometryAction"; | ||
|  | 
 | ||
|  | describe("ReplaceGeometryAction", () => { | ||
|  | 
 | ||
|  |     const grbStripped =  { | ||
|  |         "id": "grb", | ||
|  |         "title": { | ||
|  |             "nl": "GRB import helper" | ||
|  |         }, | ||
|  |         "description": "Smaller version of the GRB theme", | ||
|  |         "language": [ | ||
|  |             "nl", | ||
|  |             "en" | ||
|  |         ], | ||
|  |         socialImage: "img.jpg", | ||
|  |         "version": "0", | ||
|  |         "startLat": 51.0249, | ||
|  |         "startLon": 4.026489, | ||
|  |         "startZoom": 9, | ||
|  |         "clustering": false, | ||
|  |         "overrideAll": { | ||
|  |             "minzoom": 19 | ||
|  |         }, | ||
|  |         "layers": [ | ||
|  |             { | ||
|  |                 "id": "type_node", | ||
|  |                 source: { | ||
|  |                     osmTags: "type=node" | ||
|  |                 }, | ||
|  |                 mapRendering: null, | ||
|  |                 "override": { | ||
|  |                     "calculatedTags": [ | ||
|  |                         "_is_part_of_building=feat.get('parent_ways')?.some(p => p.building !== undefined && p.building !== '') ?? false", | ||
|  |                         "_is_part_of_grb_building=feat.get('parent_ways')?.some(p => p['source:geometry:ref'] !== undefined) ?? false", | ||
|  |                         "_is_part_of_building_passage=feat.get('parent_ways')?.some(p => p.tunnel === 'building_passage') ?? false", | ||
|  |                         "_is_part_of_highway=!feat.get('is_part_of_building_passage') && (feat.get('parent_ways')?.some(p => p.highway !== undefined && p.highway !== '') ?? false)", | ||
|  |                         "_is_part_of_landuse=feat.get('parent_ways')?.some(p => (p.landuse !== undefined && p.landuse !== '') || (p.natural !== undefined && p.natural !== '')) ?? false", | ||
|  |                         "_moveable=feat.get('_is_part_of_building') && !feat.get('_is_part_of_grb_building')" | ||
|  |                     ], | ||
|  |                     "mapRendering": [ | ||
|  |                         { | ||
|  |                             "icon": "square:#cc0", | ||
|  |                             "iconSize": "5,5,center", | ||
|  |                             "location": [ | ||
|  |                                 "point" | ||
|  |                             ] | ||
|  |                         } | ||
|  |                     ], | ||
|  |                     "passAllFeatures": true | ||
|  |                 } | ||
|  |             }, | ||
|  |             { | ||
|  |                 "id": "osm-buildings", | ||
|  |                 "name": "All OSM-buildings", | ||
|  |                 "source": { | ||
|  |                     "osmTags": "building~*", | ||
|  |                     "maxCacheAge": 0 | ||
|  |                 }, | ||
|  |                 "calculatedTags": [ | ||
|  |                     "_surface:strict:=feat.get('_surface')" | ||
|  |                 ], | ||
|  |                 "mapRendering": [ | ||
|  |                     { | ||
|  |                         "width": { | ||
|  |                             "render": "2", | ||
|  |                             "mappings": [ | ||
|  |                                 { | ||
|  |                                     "if": "fixme~*", | ||
|  |                                     "then": "5" | ||
|  |                                 } | ||
|  |                             ] | ||
|  |                         }, | ||
|  |                         "color": { | ||
|  |                             "render": "#00c", | ||
|  |                             "mappings": [ | ||
|  |                                 { | ||
|  |                                     "if": "fixme~*", | ||
|  |                                     "then": "#ff00ff" | ||
|  |                                 }, | ||
|  |                                 { | ||
|  |                                     "if": "building=house", | ||
|  |                                     "then": "#a00" | ||
|  |                                 }, | ||
|  |                                 { | ||
|  |                                     "if": "building=shed", | ||
|  |                                     "then": "#563e02" | ||
|  |                                 }, | ||
|  |                                 { | ||
|  |                                     "if": { | ||
|  |                                         "or": [ | ||
|  |                                             "building=garage", | ||
|  |                                             "building=garages" | ||
|  |                                         ] | ||
|  |                                     }, | ||
|  |                                     "then": "#f9bfbb" | ||
|  |                                 }, | ||
|  |                                 { | ||
|  |                                     "if": "building=yes", | ||
|  |                                     "then": "#0774f2" | ||
|  |                                 } | ||
|  |                             ] | ||
|  |                         } | ||
|  |                     } | ||
|  |                 ], | ||
|  |                 "title": "OSM-gebouw", | ||
|  |                 "tagRenderings": [ | ||
|  |                     { | ||
|  |                         "id": "building type", | ||
|  |                         "freeform": { | ||
|  |                             "key": "building" | ||
|  |                         }, | ||
|  |                         "render": "The building type is <b>{building}</b>", | ||
|  |                         "question": { | ||
|  |                             "en": "What kind of building is this?" | ||
|  |                         }, | ||
|  |                         "mappings": [ | ||
|  |                             { | ||
|  |                                 "if": "building=house", | ||
|  |                                 "then": "A normal house" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=detached", | ||
|  |                                 "then": "A house detached from other building" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=semidetached_house", | ||
|  |                                 "then": "A house sharing only one wall with another house" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=apartments", | ||
|  |                                 "then": "An apartment building - highrise for living" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=office", | ||
|  |                                 "then": "An office building - highrise for work" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=apartments", | ||
|  |                                 "then": "An apartment building" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=shed", | ||
|  |                                 "then": "A small shed, e.g. in a garden" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=garage", | ||
|  |                                 "then": "A single garage to park a car" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=garages", | ||
|  |                                 "then": "A building containing only garages; typically they are all identical" | ||
|  |                             }, | ||
|  |                             { | ||
|  |                                 "if": "building=yes", | ||
|  |                                 "then": "A building - no specification" | ||
|  |                             } | ||
|  |                         ] | ||
|  |                     }, | ||
|  |                     { | ||
|  |                         "id": "grb-housenumber", | ||
|  |                         "render": { | ||
|  |                             "nl": "Het huisnummer is <b>{addr:housenumber}</b>" | ||
|  |                         }, | ||
|  |                         "question": { | ||
|  |                             "nl": "Wat is het huisnummer?" | ||
|  |                         }, | ||
|  |                         "freeform": { | ||
|  |                             "key": "addr:housenumber" | ||
|  |                         }, | ||
|  |                         "mappings": [ | ||
|  |                             { | ||
|  |                                 "if": { | ||
|  |                                     "and": [ | ||
|  |                                         "not:addr:housenumber=yes", | ||
|  |                                         "addr:housenumber=" | ||
|  |                                     ] | ||
|  |                                 }, | ||
|  |                                 "then": { | ||
|  |                                     "nl": "Geen huisnummer" | ||
|  |                                 } | ||
|  |                             } | ||
|  |                         ] | ||
|  |                     }, | ||
|  |                     { | ||
|  |                         "id": "grb-unit", | ||
|  |                         "question": "Wat is de wooneenheid-aanduiding?", | ||
|  |                         "render": { | ||
|  |                             "nl": "De wooneenheid-aanduiding is <b>{addr:unit}</b> " | ||
|  |                         }, | ||
|  |                         "freeform": { | ||
|  |                             "key": "addr:unit" | ||
|  |                         }, | ||
|  |                         "mappings": [ | ||
|  |                             { | ||
|  |                                 "if": "addr:unit=", | ||
|  |                                 "then": "Geen wooneenheid-nummer" | ||
|  |                             } | ||
|  |                         ] | ||
|  |                     }, | ||
|  |                     { | ||
|  |                         "id": "grb-street", | ||
|  |                         "render": { | ||
|  |                             "nl": "De straat is <b>{addr:street}</b>" | ||
|  |                         }, | ||
|  |                         "freeform": { | ||
|  |                             "key": "addr:street" | ||
|  |                         }, | ||
|  |                         "question": { | ||
|  |                             "nl": "Wat is de straat?" | ||
|  |                         } | ||
|  |                     }, | ||
|  |                     { | ||
|  |                         "id": "grb-fixme", | ||
|  |                         "render": { | ||
|  |                             "nl": "De fixme is <b>{fixme}</b>" | ||
|  |                         }, | ||
|  |                         "question": { | ||
|  |                             "nl": "Wat zegt de fixme?" | ||
|  |                         }, | ||
|  |                         "freeform": { | ||
|  |                             "key": "fixme" | ||
|  |                         }, | ||
|  |                         "mappings": [ | ||
|  |                             { | ||
|  |                                 "if": { | ||
|  |                                     "and": [ | ||
|  |                                         "fixme=" | ||
|  |                                     ] | ||
|  |                                 }, | ||
|  |                                 "then": { | ||
|  |                                     "nl": "Geen fixme" | ||
|  |                                 } | ||
|  |                             } | ||
|  |                         ] | ||
|  |                     }, | ||
|  |                     { | ||
|  |                         "id": "grb-min-level", | ||
|  |                         "render": { | ||
|  |                             "nl": "Dit gebouw begint maar op de {building:min_level} verdieping" | ||
|  |                         }, | ||
|  |                         "question": { | ||
|  |                             "nl": "Hoeveel verdiepingen ontbreken?" | ||
|  |                         }, | ||
|  |                         "freeform": { | ||
|  |                             "key": "building:min_level", | ||
|  |                             "type": "pnat" | ||
|  |                         } | ||
|  |                     }, | ||
|  |                     "all_tags" | ||
|  |                 ], | ||
|  |                 "filter": [ | ||
|  |                     { | ||
|  |                         "id": "has-fixme", | ||
|  |                         "options": [ | ||
|  |                             { | ||
|  |                                 "osmTags": "fixme~*", | ||
|  |                                 "question": "Heeft een FIXME" | ||
|  |                             } | ||
|  |                         ] | ||
|  |                     } | ||
|  |                 ] | ||
|  |             }, | ||
|  |             { | ||
|  |                 "id": "grb", | ||
|  |                 "description": "Geometry which comes from GRB with tools to import them", | ||
|  |                 "source": { | ||
|  |                     "osmTags": { | ||
|  |                         "and": [ | ||
|  |                             "HUISNR~*", | ||
|  |                             "man_made!=mast" | ||
|  |                         ] | ||
|  |                     }, | ||
|  |                     "geoJson": "https://betadata.grbosm.site/grb?bbox={x_min},{y_min},{x_max},{y_max}", | ||
|  |                     "geoJsonZoomLevel": 18, | ||
|  |                     "mercatorCrs": true, | ||
|  |                     "maxCacheAge": 0 | ||
|  |                 }, | ||
|  |                 "name": "GRB geometries", | ||
|  |                 "title": "GRB outline", | ||
|  |                 "calculatedTags": [ | ||
|  |                     "_overlaps_with_buildings=feat.overlapWith('osm-buildings').filter(f => f.feat.properties.id.indexOf('-') < 0)", | ||
|  |                     "_overlaps_with=feat.get('_overlaps_with_buildings').filter(f => f.overlap > 1 /* square meter */ )[0] ?? ''", | ||
|  |                     "_osm_obj:source:ref=feat.get('_overlaps_with')?.feat?.properties['source:geometry:ref']", | ||
|  |                     "_osm_obj:id=feat.get('_overlaps_with')?.feat?.properties?.id", | ||
|  |                     "_osm_obj:source:date=feat.get('_overlaps_with')?.feat?.properties['source:geometry:date'].replace(/\\//g, '-')", | ||
|  |                     "_osm_obj:building=feat.get('_overlaps_with')?.feat?.properties?.building", | ||
|  |                     "_osm_obj:addr:street=(feat.get('_overlaps_with')?.feat?.properties ?? {})['addr:street']", | ||
|  |                     "_osm_obj:addr:housenumber=(feat.get('_overlaps_with')?.feat?.properties ?? {})['addr:housenumber']", | ||
|  |                     "_osm_obj:surface=(feat.get('_overlaps_with')?.feat?.properties ?? {})['_surface:strict']", | ||
|  | 
 | ||
|  |                     "_overlap_absolute=feat.get('_overlaps_with')?.overlap", | ||
|  |                     "_reverse_overlap_percentage=Math.round(100 * feat.get('_overlap_absolute') / feat.get('_surface'))", | ||
|  |                     "_overlap_percentage=Math.round(100 * feat.get('_overlap_absolute') / feat.get('_osm_obj:surface'))", | ||
|  |                     "_grb_ref=feat.properties['source:geometry:entity'] + '/' + feat.properties['source:geometry:oidn']", | ||
|  |                     "_imported_osm_object_found= feat.properties['_osm_obj:source:ref'] == feat.properties._grb_ref", | ||
|  |                     "_grb_date=feat.properties['source:geometry:date'].replace(/\\//g,'-')", | ||
|  |                     "_imported_osm_still_fresh= feat.properties['_osm_obj:source:date'] == feat.properties._grb_date", | ||
|  |                     "_target_building_type=feat.properties['_osm_obj:building'] === 'yes' ? feat.properties.building : (feat.properties['_osm_obj:building'] ?? feat.properties.building)", | ||
|  |                     "_building:min_level= feat.properties['fixme']?.startsWith('verdieping, correct the building tag, add building:level and building:min_level before upload in JOSM!') ? '1' : ''", | ||
|  |                     "_intersects_with_other_features=feat.intersectionsWith('generic_osm_object').map(f => \"<a href='https://osm.org/\"+f.feat.properties.id+\"' target='_blank'>\" + f.feat.properties.id + \"</a>\").join(', ')" | ||
|  |                 ], | ||
|  |                 "tagRenderings": [], | ||
|  |                 "mapRendering": [ | ||
|  |                     { | ||
|  |                         "iconSize": "50,50,center", | ||
|  |                         "icon": "./assets/themes/grb_import/housenumber_blank.svg", | ||
|  |                         "location": [ | ||
|  |                             "point", | ||
|  |                             "centroid" | ||
|  |                         ] | ||
|  |                     } | ||
|  |                 ] | ||
|  |             } | ||
|  |         ] | ||
|  |     } | ||
|  | 
 | ||
|  |     Minimap.createMiniMap = () => undefined; | ||
|  | 
 | ||
|  |     const coordinates = <[number, number][]>[ | ||
|  |         [ | ||
|  |             3.216690793633461, | ||
|  |             51.21474084112525 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2167256623506546, | ||
|  |             51.214696737309964 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2169999182224274, | ||
|  |             51.214768983537674 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2169650495052338, | ||
|  |             51.21480720678671 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2169368863105774, | ||
|  |             51.21480090625335 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2169489562511444, | ||
|  |             51.21478074454077 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.216886594891548, | ||
|  |             51.214765203214625 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2168812304735184, | ||
|  |             51.21477192378873 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2168644666671753, | ||
|  |             51.214768983537674 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.2168537378311157, | ||
|  |             51.21478746511261 | ||
|  |         ], | ||
|  |         [ | ||
|  |             3.216690793633461, | ||
|  |             51.21474084112525 | ||
|  |         ] | ||
|  |     ] | ||
|  | 
 | ||
|  |     const targetFeature = { | ||
|  |         type: "Feature", | ||
|  |         properties: {}, | ||
|  |         geometry: { | ||
|  |             type: "Polygon", | ||
|  |             coordinates: [coordinates] | ||
|  |         } | ||
|  |     } | ||
|  | 
 | ||
|  |     const wayId = "way/160909312" | ||
|  | 
 | ||
|  |     Utils.injectJsonDownloadForTests( | ||
|  |         "https://www.openstreetmap.org/api/0.6/map.json?bbox=3.2166673243045807,51.21467321525788,3.217007964849472,51.21482442824023", | ||
|  |         { | ||
|  |             "version": "0.6", | ||
|  |             "generator": "CGImap 0.8.6 (1549677 spike-06.openstreetmap.org)", | ||
|  |             "copyright": "OpenStreetMap and contributors", | ||
|  |             "attribution": "http://www.openstreetmap.org/copyright", | ||
|  |             "license": "http://opendatacommons.org/licenses/odbl/1-0/", | ||
|  |             "bounds": {"minlat": 51.2146732, "minlon": 3.2166673, "maxlat": 51.2148244, "maxlon": 3.217008}, | ||
|  |             "elements": [{ | ||
|  |                 "type": "node", | ||
|  |                 "id": 1612385157, | ||
|  |                 "lat": 51.2148016, | ||
|  |                 "lon": 3.2168453, | ||
|  |                 "timestamp": "2018-04-30T12:26:00Z", | ||
|  |                 "version": 3, | ||
|  |                 "changeset": 58553478, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728816256, | ||
|  |                 "lat": 51.2147111, | ||
|  |                 "lon": 3.2170233, | ||
|  |                 "timestamp": "2017-07-18T22:52:44Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728816287, | ||
|  |                 "lat": 51.2146408, | ||
|  |                 "lon": 3.2167601, | ||
|  |                 "timestamp": "2021-10-29T16:24:43Z", | ||
|  |                 "version": 3, | ||
|  |                 "changeset": 113131915, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823481, | ||
|  |                 "lat": 51.2146968, | ||
|  |                 "lon": 3.2167242, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823499, | ||
|  |                 "lat": 51.2147127, | ||
|  |                 "lon": 3.2170302, | ||
|  |                 "timestamp": "2017-07-18T22:52:45Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823501, | ||
|  |                 "lat": 51.2148696, | ||
|  |                 "lon": 3.2168941, | ||
|  |                 "timestamp": "2017-07-18T22:52:45Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823514, | ||
|  |                 "lat": 51.2147863, | ||
|  |                 "lon": 3.2168551, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823522, | ||
|  |                 "lat": 51.2148489, | ||
|  |                 "lon": 3.2169012, | ||
|  |                 "timestamp": "2017-07-18T22:52:45Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823523, | ||
|  |                 "lat": 51.2147578, | ||
|  |                 "lon": 3.2169995, | ||
|  |                 "timestamp": "2017-07-18T22:52:45Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823543, | ||
|  |                 "lat": 51.2148075, | ||
|  |                 "lon": 3.2166445, | ||
|  |                 "timestamp": "2017-07-18T22:52:46Z", | ||
|  |                 "version": 3, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823544, | ||
|  |                 "lat": 51.2148553, | ||
|  |                 "lon": 3.2169315, | ||
|  |                 "timestamp": "2017-07-18T22:52:46Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823549, | ||
|  |                 "lat": 51.2147401, | ||
|  |                 "lon": 3.2168877, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288376, | ||
|  |                 "lat": 51.2147306, | ||
|  |                 "lon": 3.2168928, | ||
|  |                 "timestamp": "2017-07-18T22:52:21Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288381, | ||
|  |                 "lat": 51.2147638, | ||
|  |                 "lon": 3.2168856, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288382, | ||
|  |                 "lat": 51.2148189, | ||
|  |                 "lon": 3.216912, | ||
|  |                 "timestamp": "2017-07-18T22:52:21Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288385, | ||
|  |                 "lat": 51.2148835, | ||
|  |                 "lon": 3.2170623, | ||
|  |                 "timestamp": "2017-07-18T22:52:21Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288387, | ||
|  |                 "lat": 51.2148904, | ||
|  |                 "lon": 3.2171037, | ||
|  |                 "timestamp": "2017-07-18T22:52:21Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289383, | ||
|  |                 "lat": 51.2147678, | ||
|  |                 "lon": 3.2169969, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289384, | ||
|  |                 "lat": 51.2147684, | ||
|  |                 "lon": 3.2168674, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289386, | ||
|  |                 "lat": 51.2147716, | ||
|  |                 "lon": 3.2168811, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289388, | ||
|  |                 "lat": 51.2148115, | ||
|  |                 "lon": 3.216966, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 7, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289391, | ||
|  |                 "lat": 51.2148019, | ||
|  |                 "lon": 3.2169194, | ||
|  |                 "timestamp": "2017-07-18T22:52:21Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 50391526, | ||
|  |                 "user": "catweazle67", | ||
|  |                 "uid": 1976209 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219974337, | ||
|  |                 "lat": 51.2148449, | ||
|  |                 "lon": 3.2171278, | ||
|  |                 "timestamp": "2021-11-02T23:40:52Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979643, | ||
|  |                 "lat": 51.2147405, | ||
|  |                 "lon": 3.216693, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979646, | ||
|  |                 "lat": 51.2148043, | ||
|  |                 "lon": 3.2169312, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979647, | ||
|  |                 "lat": 51.2147792, | ||
|  |                 "lon": 3.2169466, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "way", | ||
|  |                 "id": 160909311, | ||
|  |                 "timestamp": "2021-12-23T12:03:37Z", | ||
|  |                 "version": 6, | ||
|  |                 "changeset": 115295690, | ||
|  |                 "user": "s8evq", | ||
|  |                 "uid": 3710738, | ||
|  |                 "nodes": [1728823481, 1728823549, 4978288376, 1728823523, 1728823499, 1728816256, 1728816287, 1728823481], | ||
|  |                 "tags": { | ||
|  |                     "addr:city": "Brugge", | ||
|  |                     "addr:country": "BE", | ||
|  |                     "addr:housenumber": "106", | ||
|  |                     "addr:postcode": "8000", | ||
|  |                     "addr:street": "Ezelstraat", | ||
|  |                     "building": "house", | ||
|  |                     "source:geometry:date": "2015-07-09", | ||
|  |                     "source:geometry:ref": "Gbg/2391617" | ||
|  |                 } | ||
|  |             }, { | ||
|  |                 "type": "way", | ||
|  |                 "id": 160909312, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858, | ||
|  |                 "nodes": [9219979643, 1728823481, 1728823549, 4978289383, 4978289388, 9219979646, 9219979647, 4978288381, 4978289386, 4978289384, 1728823514, 9219979643], | ||
|  |                 "tags": { | ||
|  |                     "addr:city": "Brugge", | ||
|  |                     "addr:country": "BE", | ||
|  |                     "addr:housenumber": "108", | ||
|  |                     "addr:postcode": "8000", | ||
|  |                     "addr:street": "Ezelstraat", | ||
|  |                     "building": "house", | ||
|  |                     "source:geometry:date": "2018-10-02", | ||
|  |                     "source:geometry:ref": "Gbg/5926383" | ||
|  |                 } | ||
|  |             }, { | ||
|  |                 "type": "way", | ||
|  |                 "id": 160909315, | ||
|  |                 "timestamp": "2021-12-23T12:03:37Z", | ||
|  |                 "version": 8, | ||
|  |                 "changeset": 115295690, | ||
|  |                 "user": "s8evq", | ||
|  |                 "uid": 3710738, | ||
|  |                 "nodes": [1728823543, 1728823501, 1728823522, 4978288382, 1612385157, 1728823514, 9219979643, 1728823543], | ||
|  |                 "tags": { | ||
|  |                     "addr:city": "Brugge", | ||
|  |                     "addr:country": "BE", | ||
|  |                     "addr:housenumber": "110", | ||
|  |                     "addr:postcode": "8000", | ||
|  |                     "addr:street": "Ezelstraat", | ||
|  |                     "building": "house", | ||
|  |                     "name": "La Style", | ||
|  |                     "shop": "hairdresser", | ||
|  |                     "source:geometry:date": "2015-07-09", | ||
|  |                     "source:geometry:ref": "Gbg/5260837" | ||
|  |                 } | ||
|  |             }, { | ||
|  |                 "type": "way", | ||
|  |                 "id": 508533816, | ||
|  |                 "timestamp": "2021-12-23T12:03:37Z", | ||
|  |                 "version": 7, | ||
|  |                 "changeset": 115295690, | ||
|  |                 "user": "s8evq", | ||
|  |                 "uid": 3710738, | ||
|  |                 "nodes": [4978288387, 4978288385, 1728823544, 1728823522, 4978288382, 4978289391, 9219979646, 4978289388, 9219974337, 4978288387], | ||
|  |                 "tags": { | ||
|  |                     "building": "yes", | ||
|  |                     "source:geometry:date": "2015-07-09", | ||
|  |                     "source:geometry:ref": "Gbg/5260790" | ||
|  |                 } | ||
|  |             }] | ||
|  |         } | ||
|  |     ) | ||
|  | 
 | ||
|  |     Utils.injectJsonDownloadForTests( | ||
|  |         "https://www.openstreetmap.org/api/0.6/way/160909312/full", | ||
|  |         { | ||
|  |             "version": "0.6", | ||
|  |             "generator": "CGImap 0.8.6 (2407324 spike-06.openstreetmap.org)", | ||
|  |             "copyright": "OpenStreetMap and contributors", | ||
|  |             "attribution": "http://www.openstreetmap.org/copyright", | ||
|  |             "license": "http://opendatacommons.org/licenses/odbl/1-0/", | ||
|  |             "elements": [{ | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823481, | ||
|  |                 "lat": 51.2146968, | ||
|  |                 "lon": 3.2167242, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823514, | ||
|  |                 "lat": 51.2147863, | ||
|  |                 "lon": 3.2168551, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 1728823549, | ||
|  |                 "lat": 51.2147401, | ||
|  |                 "lon": 3.2168877, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 5, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978288381, | ||
|  |                 "lat": 51.2147638, | ||
|  |                 "lon": 3.2168856, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289383, | ||
|  |                 "lat": 51.2147678, | ||
|  |                 "lon": 3.2169969, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289384, | ||
|  |                 "lat": 51.2147684, | ||
|  |                 "lon": 3.2168674, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289386, | ||
|  |                 "lat": 51.2147716, | ||
|  |                 "lon": 3.2168811, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 4978289388, | ||
|  |                 "lat": 51.2148115, | ||
|  |                 "lon": 3.216966, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 7, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979643, | ||
|  |                 "lat": 51.2147405, | ||
|  |                 "lon": 3.216693, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979646, | ||
|  |                 "lat": 51.2148043, | ||
|  |                 "lon": 3.2169312, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 2, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "node", | ||
|  |                 "id": 9219979647, | ||
|  |                 "lat": 51.2147792, | ||
|  |                 "lon": 3.2169466, | ||
|  |                 "timestamp": "2021-11-02T23:37:11Z", | ||
|  |                 "version": 1, | ||
|  |                 "changeset": 113305401, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858 | ||
|  |             }, { | ||
|  |                 "type": "way", | ||
|  |                 "id": 160909312, | ||
|  |                 "timestamp": "2021-11-02T23:38:13Z", | ||
|  |                 "version": 4, | ||
|  |                 "changeset": 113306325, | ||
|  |                 "user": "Pieter Vander Vennet", | ||
|  |                 "uid": 3818858, | ||
|  |                 "nodes": [9219979643, 1728823481, 1728823549, 4978289383, 4978289388, 9219979646, 9219979647, 4978288381, 4978289386, 4978289384, 1728823514, 9219979643], | ||
|  |                 "tags": { | ||
|  |                     "addr:city": "Brugge", | ||
|  |                     "addr:country": "BE", | ||
|  |                     "addr:housenumber": "108", | ||
|  |                     "addr:postcode": "8000", | ||
|  |                     "addr:street": "Ezelstraat", | ||
|  |                     "building": "house", | ||
|  |                     "source:geometry:date": "2018-10-02", | ||
|  |                     "source:geometry:ref": "Gbg/5926383" | ||
|  |                 } | ||
|  |             }] | ||
|  |         } | ||
|  |     ) | ||
|  |     Utils.injectJsonDownloadForTests("https://raw.githubusercontent.com/pietervdvn/MapComplete-data/main/latlon2country/0.0.0.json", "be") | ||
|  | 
 | ||
|  | 
 | ||
|  | it("should move nodes accordingly", async () => { | ||
|  | 
 | ||
|  | 
 | ||
|  |     const layout = new LayoutConfig(<any>grbStripped) | ||
|  | 
 | ||
|  | 
 | ||
|  |     const state = new State(layout) | ||
|  |     State.state = state; | ||
|  |     const bbox = new BBox( | ||
|  |         [[ | ||
|  |             3.2166673243045807, | ||
|  |             51.21467321525788 | ||
|  |         ], | ||
|  |             [ | ||
|  |                 3.217007964849472, | ||
|  |                 51.21482442824023 | ||
|  |             ] | ||
|  |         ]) | ||
|  |     const url = `https://www.openstreetmap.org/api/0.6/map.json?bbox=${bbox.minLon},${bbox.minLat},${bbox.maxLon},${bbox.maxLat}` | ||
|  |     const data = await Utils.downloadJson(url) | ||
|  | 
 | ||
|  |     state.featurePipeline.fullNodeDatabase.handleOsmJson(data, 0) | ||
|  | 
 | ||
|  | 
 | ||
|  |     const action = new ReplaceGeometryAction(state, targetFeature, wayId, { | ||
|  |             theme: "test" | ||
|  |         } | ||
|  |     ) | ||
|  | 
 | ||
|  |     const closestIds = await action.GetClosestIds() | ||
|  |     expect(closestIds.closestIds).deep.equal([9219979643, | ||
|  |         1728823481, | ||
|  |         4978289383, | ||
|  |         4978289388, | ||
|  |         9219979646, | ||
|  |         9219979647, | ||
|  |         4978288381, | ||
|  |         4978289386, | ||
|  |         4978289384, | ||
|  |         1728823514, | ||
|  |         undefined]) | ||
|  | 
 | ||
|  |     expect(closestIds.reprojectedNodes.size).deep.equal(1) | ||
|  |     const reproj = closestIds.reprojectedNodes.get(1728823549) | ||
|  |     expect(reproj.projectAfterIndex).deep.equal(1) | ||
|  |     expect(reproj.newLon).deep.equal(3.2168880864669203) | ||
|  |     expect(reproj.newLat).deep.equal(51.214739524104694) | ||
|  |     expect(closestIds.detachedNodes.size).deep.equal(0) | ||
|  |     const changes = await action.Perform(state.changes) | ||
|  |     expect(changes[11].changes["coordinates"]).deep.equal([[3.216690793633461, 51.21474084112525], [3.2167256623506546, 51.214696737309964], [3.2168880864669203, 51.214739524104694], [3.2169999182224274, 51.214768983537674], [3.2169650495052338, 51.21480720678671], [3.2169368863105774, 51.21480090625335], [3.2169489562511444, 51.21478074454077], [3.216886594891548, 51.214765203214625], [3.2168812304735184, 51.21477192378873], [3.2168644666671753, 51.214768983537674], [3.2168537378311157, 51.21478746511261], [3.216690793633461, 51.21474084112525]]) | ||
|  | 
 | ||
|  | }) | ||
|  | 
 | ||
|  | 
 | ||
|  | }) |