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 { FixedUiElement } from "../Base/FixedUiElement" import FeaturePipelineState from "../../Logic/State/FeaturePipelineState" export default class EditableTagRendering extends Toggle { constructor( tags: UIEventSource, configuration: TagRenderingConfig, units: Unit[], state, options: { editMode?: UIEventSource 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(false) let rendering = EditableTagRendering.CreateRendering( state, tags, configuration, units, editMode ) rendering.SetClass(options.innerElementClasses) if (state.featureSwitchIsDebugging.data || state.featureSwitchIsTesting.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: FeaturePipelineState, tags: UIEventSource, configuration: TagRenderingConfig, units: Unit[], editMode: UIEventSource ): 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 } }