| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | import {LayerDefinition} from "../LayerDefinition"; | 
					
						
							|  |  |  | import {Quests} from "../Quests"; | 
					
						
							|  |  |  | import {TagMappingOptions} from "../UI/TagMapping"; | 
					
						
							|  |  |  | import L from "leaflet" | 
					
						
							|  |  |  | import {CommonTagMappings} from "./CommonTagMappings"; | 
					
						
							| 
									
										
										
										
											2020-06-28 00:06:23 +02:00
										 |  |  | import {Or, Tag} from "../Logic/TagsFilter"; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class Park extends LayerDefinition { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor() { | 
					
						
							|  |  |  |         super(); | 
					
						
							|  |  |  |         this.name = "park"; | 
					
						
							|  |  |  |         this.icon = "./assets/tree_white_background.svg"; | 
					
						
							| 
									
										
										
										
											2020-06-28 00:06:23 +02:00
										 |  |  |         this.overpassFilter =  | 
					
						
							|  |  |  |             new Or([new Tag("leisure","park"), new Tag("landuse","village_green")]); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |         this.newElementTags = [new Tag("leisure", "park"),  | 
					
						
							|  |  |  |             new Tag("fixme", "Toegevoegd met MapComplete, geometry nog uit te tekenen")]; | 
					
						
							| 
									
										
										
										
											2020-06-28 23:33:48 +02:00
										 |  |  |         this.maxAllowedOverlapPercentage = 25; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         this.minzoom = 13; | 
					
						
							|  |  |  |         this.questions = [Quests.nameOf("park")]; | 
					
						
							|  |  |  |         this.style = this.generateStyleFunction(); | 
					
						
							|  |  |  |         this.elementsToShow = [ | 
					
						
							|  |  |  |             new TagMappingOptions({ | 
					
						
							|  |  |  |                 key: "name", | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |                 template: "{name}", | 
					
						
							|  |  |  |                 missing: "Naamloos park" | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |             }), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             CommonTagMappings.access, | 
					
						
							|  |  |  |             CommonTagMappings.operator, | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private readonly treeIcon = new L.icon({ | 
					
						
							|  |  |  |         iconUrl: "assets/tree_white_background.svg", | 
					
						
							|  |  |  |         iconSize: [40, 40] | 
					
						
							|  |  |  |     }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private generateStyleFunction() { | 
					
						
							|  |  |  |         const self = this; | 
					
						
							|  |  |  |         return function (properties: any) { | 
					
						
							|  |  |  |             let questionSeverity = 0; | 
					
						
							|  |  |  |             for (const qd of self.questions) { | 
					
						
							|  |  |  |                 if (qd.isApplicable(properties)) { | 
					
						
							|  |  |  |                     questionSeverity = Math.max(questionSeverity, qd.severity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             let colormapping = { | 
					
						
							|  |  |  |                 0: "#00bb00", | 
					
						
							|  |  |  |                 1: "#00ff00", | 
					
						
							|  |  |  |                 10: "#dddd00", | 
					
						
							|  |  |  |                 20: "#ff0000" | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             let colour = colormapping[questionSeverity]; | 
					
						
							|  |  |  |             while (colour == undefined) { | 
					
						
							|  |  |  |                 questionSeverity--; | 
					
						
							|  |  |  |                 colormapping[questionSeverity]; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             return { | 
					
						
							|  |  |  |                 color: colour, | 
					
						
							|  |  |  |                 icon: self.treeIcon | 
					
						
							|  |  |  |             }; | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |