mapcomplete/UI/Popup/EditableTagRendering.ts

75 lines
2.8 KiB
TypeScript
Raw Normal View History

2020-10-27 01:01:34 +01:00
import {UIEventSource} from "../../Logic/UIEventSource";
import TagRenderingQuestion from "./TagRenderingQuestion";
import Translations from "../i18n/Translations";
import Combine from "../Base/Combine";
import TagRenderingAnswer from "./TagRenderingAnswer";
import State from "../../State";
2020-11-06 01:58:26 +01:00
import Svg from "../../Svg";
2021-06-14 02:39:23 +02:00
import Toggle from "../Input/Toggle";
import BaseUIElement from "../BaseUIElement";
import TagRenderingConfig from "../../Models/ThemeConfig/TagRenderingConfig";
import {Unit} from "../../Models/Unit";
2020-10-27 01:01:34 +01:00
2021-06-14 02:39:23 +02:00
export default class EditableTagRendering extends Toggle {
2020-10-27 01:01:34 +01:00
constructor(tags: UIEventSource<any>,
2021-06-16 21:23:03 +02:00
configuration: TagRenderingConfig,
units: Unit [],
2021-06-16 21:23:03 +02:00
editMode = new UIEventSource<boolean>(false)
) {
2021-06-14 02:39:23 +02:00
const answer: BaseUIElement = new TagRenderingAnswer(tags, configuration)
2021-06-16 14:23:53 +02:00
answer.SetClass("w-full")
2021-06-14 02:39:23 +02:00
let rendering = answer;
2020-10-27 01:01:34 +01:00
2021-06-14 02:39:23 +02:00
if (configuration.question !== undefined && State.state?.featureSwitchUserbadge?.data) {
// We have a question and editing is enabled
const editButton =
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);
});
2020-10-27 01:01:34 +01:00
2021-06-14 02:39:23 +02:00
const answerWithEditButton = new Combine([answer,
2021-06-14 17:28:11 +02:00
new Toggle(editButton, undefined, State.state.osmConnection.isLoggedIn)])
.SetClass("flex justify-between w-full")
2021-06-14 02:39:23 +02:00
2020-10-27 01:01:34 +01:00
const cancelbutton =
Translations.t.general.cancel.Clone()
.SetClass("btn btn-secondary mr-3")
2020-10-27 01:01:34 +01:00
.onClick(() => {
2021-06-14 02:39:23 +02:00
editMode.setData(false)
2020-10-27 01:01:34 +01:00
});
const question = new TagRenderingQuestion(tags, configuration,
{
units: units,
cancelButton: cancelbutton,
afterSave: () => {
editMode.setData(false)
}
})
2021-06-14 02:39:23 +02:00
rendering = new Toggle(
question,
answerWithEditButton,
editMode
)
2020-10-27 01:01:34 +01:00
}
2021-06-14 17:28:11 +02:00
rendering.SetClass("block w-full break-word text-default m-1 p-1 border-b border-gray-200 mb-2 pb-2")
2021-06-14 02:39:23 +02:00
// 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 =>
2021-06-14 17:28:11 +02:00
configuration.IsKnown(tags) &&
2021-06-14 02:39:23 +02:00
(configuration?.condition?.matchesProperties(tags) ?? true))
super(
rendering,
undefined,
renderingIsShown
)
2020-10-27 01:01:34 +01:00
}
}