forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			51 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
	
		
			1.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { SpecialVisualization, SpecialVisualizationState } from "../SpecialVisualization"
 | |
| import { Feature } from "geojson"
 | |
| import BaseUIElement from "../BaseUIElement"
 | |
| import { UIEventSource } from "../../Logic/UIEventSource"
 | |
| import SvelteUIElement from "../Base/SvelteUIElement"
 | |
| import Questionbox from "./TagRendering/Questionbox.svelte"
 | |
| import LayerConfig from "../../Models/ThemeConfig/LayerConfig"
 | |
| 
 | |
| /**
 | |
|  * Thin wrapper around QuestionBox.svelte to include it into the special Visualisations
 | |
|  */
 | |
| export default class QuestionViz implements SpecialVisualization {
 | |
|     funcName = "questions"
 | |
|     docs =
 | |
|         "The special element which shows the questions which are unkown. Added by default if not yet there"
 | |
|     args = [
 | |
|         {
 | |
|             name: "labels",
 | |
|             doc: "One or more ';'-separated labels. If these are given, only questions with these labels will be given. Use `unlabeled` for all questions that don't have an explicit label. If none given, all questions will be shown",
 | |
|         },
 | |
|         {
 | |
|             name: "blacklisted-labels",
 | |
|             doc: "One or more ';'-separated labels of questions which should _not_ be included",
 | |
|         },
 | |
|     ]
 | |
| 
 | |
|     constr(
 | |
|         state: SpecialVisualizationState,
 | |
|         tags: UIEventSource<Record<string, string>>,
 | |
|         args: string[],
 | |
|         feature: Feature,
 | |
|         layer: LayerConfig
 | |
|     ): BaseUIElement {
 | |
|         const labels = args[0]
 | |
|             ?.split(";")
 | |
|             ?.map((s) => s.trim())
 | |
|             ?.filter((s) => s !== "")
 | |
|         const blacklist = args[1]
 | |
|             ?.split(";")
 | |
|             ?.map((s) => s.trim())
 | |
|             ?.filter((s) => s !== "")
 | |
|         return new SvelteUIElement(Questionbox, {
 | |
|             layer,
 | |
|             tags,
 | |
|             selectedElement: feature,
 | |
|             state,
 | |
|             onlyForLabels: labels,
 | |
|             notForLabels: blacklist,
 | |
|         })
 | |
|     }
 | |
| }
 |