forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			120 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
	
		
			4.7 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { ExtraFuncParams, ExtraFunctions } from "../../src/Logic/ExtraFunctions"
 | 
						|
import { OsmFeature } from "../../src/Models/OsmFeature"
 | 
						|
import { describe, expect, it } from "vitest"
 | 
						|
import { Feature } from "geojson"
 | 
						|
 | 
						|
describe("OverlapFunc", () => {
 | 
						|
    it("should give doors on the edge", () => {
 | 
						|
        const door: OsmFeature = {
 | 
						|
            type: "Feature",
 | 
						|
            id: "node/9909268725",
 | 
						|
            properties: {
 | 
						|
                automatic_door: "no",
 | 
						|
                door: "hinged",
 | 
						|
                indoor: "door",
 | 
						|
                "kerb:height": "0 cm",
 | 
						|
                width: "1",
 | 
						|
                id: "node/9909268725",
 | 
						|
            },
 | 
						|
            geometry: {
 | 
						|
                type: "Point",
 | 
						|
                coordinates: [4.3494436, 50.8657928],
 | 
						|
            },
 | 
						|
        }
 | 
						|
 | 
						|
        const hermanTeirlinck: Feature = {
 | 
						|
            type: "Feature",
 | 
						|
            id: "way/444059131",
 | 
						|
            properties: {
 | 
						|
                timestamp: "2022-07-27T15:15:01Z",
 | 
						|
                version: 27,
 | 
						|
                changeset: 124146283,
 | 
						|
                user: "Pieter Vander Vennet",
 | 
						|
                uid: 3818858,
 | 
						|
                "addr:city": "Bruxelles - Brussel",
 | 
						|
                "addr:housenumber": "88",
 | 
						|
                "addr:postcode": "1000",
 | 
						|
                "addr:street": "Avenue du Port - Havenlaan",
 | 
						|
                building: "government",
 | 
						|
                "building:levels": "5",
 | 
						|
                name: "Herman Teirlinckgebouw",
 | 
						|
                operator: "Vlaamse overheid",
 | 
						|
                wikidata: "Q47457146",
 | 
						|
                wikipedia: "nl:Herman Teirlinckgebouw",
 | 
						|
                id: "way/444059131",
 | 
						|
                _backend: "https://www.openstreetmap.org",
 | 
						|
                _lat: "50.86622355",
 | 
						|
                _lon: "4.3501212",
 | 
						|
                _layer: "walls_and_buildings",
 | 
						|
                _length: "380.5933566256343",
 | 
						|
                "_length:km": "0.4",
 | 
						|
                "_now:date": "2022-07-29",
 | 
						|
                "_now:datetime": "2022-07-29 14:19:25",
 | 
						|
                "_loaded:date": "2022-07-29",
 | 
						|
                "_loaded:datetime": "2022-07-29 14:19:25",
 | 
						|
                "_last_edit:contributor": "Pieter Vander Vennet",
 | 
						|
                "_last_edit:contributor:uid": 3818858,
 | 
						|
                "_last_edit:changeset": 124146283,
 | 
						|
                "_last_edit:timestamp": "2022-07-27T15:15:01Z",
 | 
						|
                _version_number: 27,
 | 
						|
                "_geometry:type": "Polygon",
 | 
						|
                _surface: "7461.252251355437",
 | 
						|
                "_surface:ha": "0.7",
 | 
						|
                _country: "be",
 | 
						|
            },
 | 
						|
            geometry: {
 | 
						|
                type: "Polygon",
 | 
						|
                coordinates: [
 | 
						|
                    [
 | 
						|
                        [4.3493369, 50.8658274],
 | 
						|
                        [4.3493393, 50.8658266],
 | 
						|
                        [4.3494436, 50.8657928],
 | 
						|
                        [4.3495272, 50.8657658],
 | 
						|
                        [4.349623, 50.8657348],
 | 
						|
                        [4.3497442, 50.8656956],
 | 
						|
                        [4.3498441, 50.8656632],
 | 
						|
                        [4.3500768, 50.8655878],
 | 
						|
                        [4.3501619, 50.8656934],
 | 
						|
                        [4.3502113, 50.8657551],
 | 
						|
                        [4.3502729, 50.8658321],
 | 
						|
                        [4.3503063, 50.8658737],
 | 
						|
                        [4.3503397, 50.8659153],
 | 
						|
                        [4.3504159, 50.8660101],
 | 
						|
                        [4.3504177, 50.8660123],
 | 
						|
                        [4.3504354, 50.8660345],
 | 
						|
                        [4.3505348, 50.8661584],
 | 
						|
                        [4.3504935, 50.866172],
 | 
						|
                        [4.3506286, 50.8663405],
 | 
						|
                        [4.3506701, 50.8663271],
 | 
						|
                        [4.3508563, 50.8665592],
 | 
						|
                        [4.3509055, 50.8666206],
 | 
						|
                        [4.3506278, 50.8667104],
 | 
						|
                        [4.3504502, 50.8667675],
 | 
						|
                        [4.3503132, 50.8668115],
 | 
						|
                        [4.3502162, 50.8668427],
 | 
						|
                        [4.3501645, 50.8668593],
 | 
						|
                        [4.3499296, 50.8665664],
 | 
						|
                        [4.3498821, 50.8665073],
 | 
						|
                        [4.3498383, 50.8664527],
 | 
						|
                        [4.3498126, 50.8664207],
 | 
						|
                        [4.3497459, 50.8663376],
 | 
						|
                        [4.3497227, 50.8663086],
 | 
						|
                        [4.3496517, 50.8662201],
 | 
						|
                        [4.3495158, 50.8660507],
 | 
						|
                        [4.3493369, 50.8658274],
 | 
						|
                    ],
 | 
						|
                ],
 | 
						|
            },
 | 
						|
        }
 | 
						|
 | 
						|
        const params: ExtraFuncParams = {
 | 
						|
            getFeatureById: () => undefined,
 | 
						|
            getFeaturesWithin: () => [[door]],
 | 
						|
        }
 | 
						|
        const helpers = ExtraFunctions.constructHelpers(params)
 | 
						|
 | 
						|
        const overlap = helpers.overlapWith(hermanTeirlinck)("*")
 | 
						|
        console.log(JSON.stringify(overlap))
 | 
						|
        expect(overlap[0].feat == door).toBe(true)
 | 
						|
    })
 | 
						|
})
 |