MapComplete/UI/NewPoint/ConfirmLocationOfPoint.ts

81 lines
3 KiB
TypeScript
Raw Normal View History

2022-11-08 14:37:48 +01:00
import { UIEventSource } from "../../Logic/UIEventSource"
2022-09-08 21:40:48 +02:00
import BaseUIElement from "../BaseUIElement"
2022-11-08 14:37:48 +01:00
import { SubtleButton } from "../Base/SubtleButton"
2022-09-08 21:40:48 +02:00
import Combine from "../Base/Combine"
import Translations from "../i18n/Translations"
import Svg from "../../Svg"
import Toggle from "../Input/Toggle"
import { PresetInfo } from "../BigComponents/SimpleAddUI"
2022-11-08 14:37:48 +01:00
import { VariableUiElement } from "../Base/VariableUIElement"
import { Tag } from "../../Logic/Tags/Tag"
import { WayId } from "../../Models/OsmFeature"
2022-11-14 01:29:22 +01:00
import { Translation } from "../i18n/Translation"
2023-03-28 05:13:48 +02:00
import { SpecialVisualizationState } from "../SpecialVisualization"
export default class ConfirmLocationOfPoint extends Combine {
constructor(
2023-03-28 05:13:48 +02:00
state: SpecialVisualizationState,
filterViewIsOpened: UIEventSource<boolean>,
preset: PresetInfo,
confirmText: BaseUIElement,
2022-09-08 21:40:48 +02:00
loc: { lon: number; lat: number },
confirm: (
tags: any[],
location: { lat: number; lon: number },
2022-09-21 02:21:20 +02:00
snapOntoWayId: WayId | undefined
2022-09-08 21:40:48 +02:00
) => void,
cancel: () => void,
closePopup: () => void,
options?: {
2022-11-14 01:29:22 +01:00
cancelIcon: BaseUIElement
cancelText?: string | Translation
}
) {
2022-09-08 21:40:48 +02:00
let confirmButton: BaseUIElement = new SubtleButton(
preset.icon(),
2022-11-08 14:37:48 +01:00
new Combine([confirmText]).SetClass("flex flex-col")
2022-09-08 21:40:48 +02:00
)
.SetClass("font-bold break-words")
.onClick(() => {
2022-09-08 21:40:48 +02:00
const globalFilterTagsToAdd: Tag[][] = state.globalFilters.data
.filter((gf) => gf.onNewPoint !== undefined)
.map((gf) => gf.onNewPoint.tags)
const globalTags: Tag[] = [].concat(...globalFilterTagsToAdd)
console.log("Global tags to add are: ", globalTags)
2022-09-08 21:40:48 +02:00
})
confirmButton = new Combine([confirmButton])
let openLayerOrConfirm = confirmButton
// We assume the number of global filters won't change during the run of the program
for (let i = 0; i < state.globalFilters.data.length; i++) {
2022-09-08 21:40:48 +02:00
const hasBeenCheckedOf = new UIEventSource(false)
const filterConfirmPanel = new VariableUiElement(
2022-09-08 21:40:48 +02:00
state.globalFilters.map((gfs) => {
const gf = gfs[i]
2022-11-08 14:37:48 +01:00
const confirm = gf.onNewPoint?.confirmAddNew?.Subs({ preset: preset.title })
2022-09-08 21:40:48 +02:00
return new Combine([
gf.onNewPoint?.safetyCheck,
new SubtleButton(Svg.confirm_svg(), confirm).onClick(() =>
hasBeenCheckedOf.setData(true)
),
])
})
)
openLayerOrConfirm = new Toggle(
2022-09-08 21:40:48 +02:00
openLayerOrConfirm,
filterConfirmPanel,
state.globalFilters.map(
(f) => hasBeenCheckedOf.data || f[i]?.onNewPoint === undefined,
[hasBeenCheckedOf]
)
)
}
super([openLayerOrConfirm])
}
2022-09-08 21:40:48 +02:00
}