forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			93 lines
		
	
	
		
			No EOL
		
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			93 lines
		
	
	
		
			No EOL
		
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import {UIEventSource} from "../../Logic/UIEventSource";
 | |
| import TagRenderingQuestion from "./TagRenderingQuestion";
 | |
| import Translations from "../i18n/Translations";
 | |
| import Combine from "../Base/Combine";
 | |
| import TagRenderingAnswer from "./TagRenderingAnswer";
 | |
| import Svg from "../../Svg";
 | |
| import Toggle from "../Input/Toggle";
 | |
| import BaseUIElement from "../BaseUIElement";
 | |
| import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig";
 | |
| import {Unit} from "../../Models/Unit";
 | |
| import Lazy from "../Base/Lazy";
 | |
| import {OsmConnection} from "../../Logic/Osm/OsmConnection";
 | |
| import {FixedUiElement} from "../Base/FixedUiElement";
 | |
| 
 | |
| export default class EditableTagRendering extends Toggle {
 | |
| 
 | |
|     constructor(tags: UIEventSource<any>,
 | |
|                 configuration: TagRenderingConfig,
 | |
|                 units: Unit [],
 | |
|                 state,
 | |
|                 options: {
 | |
|                     editMode?: UIEventSource<boolean>,
 | |
|                     innerElementClasses?: string
 | |
|                 }
 | |
|     ) {
 | |
| 
 | |
|         // The tagrendering is hidden if:
 | |
|         // - The answer is unknown. The questionbox will then show the question
 | |
|         // - There is a condition hiding the answer
 | |
|         const renderingIsShown = tags.map(tags =>
 | |
|             configuration.IsKnown(tags) &&
 | |
|             (configuration?.condition?.matchesProperties(tags) ?? true))
 | |
| 
 | |
|         super(
 | |
|             new Lazy(() => {
 | |
|                 const editMode = options.editMode ?? new UIEventSource<boolean>(false)
 | |
|                 let rendering = EditableTagRendering.CreateRendering(state, tags, configuration, units, editMode);
 | |
|                 rendering.SetClass(options.innerElementClasses)
 | |
|                 if(state.featureSwitchIsDebugging.data){
 | |
|                     rendering = new Combine([
 | |
|                         new FixedUiElement(configuration.id).SetClass("self-end subtle"),
 | |
|                         rendering
 | |
|                     ]).SetClass("flex flex-col")
 | |
|                 }
 | |
|                 return rendering
 | |
|             }),
 | |
|             undefined,
 | |
|             renderingIsShown
 | |
|         )
 | |
|     }
 | |
| 
 | |
|     private static CreateRendering(state: { featureSwitchUserbadge?: UIEventSource<boolean>, osmConnection: OsmConnection }, tags: UIEventSource<any>, configuration: TagRenderingConfig, units: Unit[], editMode: UIEventSource<boolean>): BaseUIElement {
 | |
|         const answer: BaseUIElement = new TagRenderingAnswer(tags, configuration, state)
 | |
|         answer.SetClass("w-full")
 | |
|         let rendering = answer;
 | |
| 
 | |
|         if (configuration.question !== undefined && state?.featureSwitchUserbadge?.data) {
 | |
|             // We have a question and editing is enabled
 | |
|             const answerWithEditButton = new Combine([answer,
 | |
|                 new Toggle(new Combine([Svg.pencil_ui()]).SetClass("block relative h-10 w-10 p-2 float-right").SetStyle("border: 1px solid black; border-radius: 0.7em")
 | |
|                         .onClick(() => {
 | |
|                             editMode.setData(true);
 | |
|                         }),
 | |
|                     undefined,
 | |
|                     state.osmConnection.isLoggedIn)
 | |
|             ]).SetClass("flex justify-between w-full")
 | |
| 
 | |
| 
 | |
|             const question = new Lazy(() =>
 | |
|                 new TagRenderingQuestion(tags, configuration, state,
 | |
|                     {
 | |
|                         units: units,
 | |
|                         cancelButton: Translations.t.general.cancel.Clone()
 | |
|                             .SetClass("btn btn-secondary")
 | |
|                             .onClick(() => {
 | |
|                                 editMode.setData(false)
 | |
|                             }),
 | |
|                         afterSave: () => {
 | |
|                             editMode.setData(false)
 | |
|                         }
 | |
|                     }))
 | |
| 
 | |
| 
 | |
|             rendering = new Toggle(
 | |
|                 question,
 | |
|                 answerWithEditButton,
 | |
|                 editMode
 | |
|             )
 | |
|         }
 | |
|         return rendering;
 | |
|     }
 | |
| 
 | |
| } |