forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			124 lines
		
	
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
	
		
			5.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import Combine from "../Base/Combine"
 | 
						|
import { UIEventSource } from "../../Logic/UIEventSource"
 | 
						|
import { OsmConnection } from "../../Logic/Osm/OsmConnection"
 | 
						|
import Translations from "../i18n/Translations"
 | 
						|
import Title from "../Base/Title"
 | 
						|
import ValidatedTextField from "../Input/ValidatedTextField"
 | 
						|
import { SubtleButton } from "../Base/SubtleButton"
 | 
						|
import Svg from "../../Svg"
 | 
						|
import { LocalStorageSource } from "../../Logic/Web/LocalStorageSource"
 | 
						|
import Toggle from "../Input/Toggle"
 | 
						|
import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig"
 | 
						|
import FeaturePipeline from "../../Logic/FeatureSource/FeaturePipeline"
 | 
						|
import FilteredLayer from "../../Models/FilteredLayer"
 | 
						|
import Hash from "../../Logic/Web/Hash"
 | 
						|
 | 
						|
export default class NewNoteUi extends Toggle {
 | 
						|
    constructor(
 | 
						|
        noteLayer: FilteredLayer,
 | 
						|
        isShown: UIEventSource<boolean>,
 | 
						|
        state: {
 | 
						|
            LastClickLocation: UIEventSource<{ lat: number; lon: number }>
 | 
						|
            osmConnection: OsmConnection
 | 
						|
            layoutToUse: LayoutConfig
 | 
						|
            featurePipeline: FeaturePipeline
 | 
						|
            selectedElement: UIEventSource<any>
 | 
						|
        }
 | 
						|
    ) {
 | 
						|
        const t = Translations.t.notes
 | 
						|
        const isCreated = new UIEventSource(false)
 | 
						|
        state.LastClickLocation.addCallbackAndRun((_) => isCreated.setData(false)) // Reset 'isCreated' on every click
 | 
						|
        const text = ValidatedTextField.ForType("text").ConstructInputElement({
 | 
						|
            value: LocalStorageSource.Get("note-text"),
 | 
						|
        })
 | 
						|
        text.SetClass("border rounded-sm border-grey-500")
 | 
						|
 | 
						|
        const postNote = new SubtleButton(Svg.addSmall_svg().SetClass("max-h-7"), t.createNote)
 | 
						|
        postNote.OnClickWithLoading(t.creating, async () => {
 | 
						|
            let txt = text.GetValue().data
 | 
						|
            if (txt === undefined || txt === "") {
 | 
						|
                return
 | 
						|
            }
 | 
						|
            txt += "\n\n #MapComplete #" + state?.layoutToUse?.id
 | 
						|
            const loc = state.LastClickLocation.data
 | 
						|
            const id = await state?.osmConnection?.openNote(loc.lat, loc.lon, txt)
 | 
						|
            const feature = {
 | 
						|
                type: "Feature",
 | 
						|
                geometry: {
 | 
						|
                    type: "Point",
 | 
						|
                    coordinates: [loc.lon, loc.lat],
 | 
						|
                },
 | 
						|
                properties: {
 | 
						|
                    id: "" + id.id,
 | 
						|
                    date_created: new Date().toISOString(),
 | 
						|
                    _first_comment: txt,
 | 
						|
                    comments: JSON.stringify([
 | 
						|
                        {
 | 
						|
                            text: txt,
 | 
						|
                            html: txt,
 | 
						|
                            user: state.osmConnection?.userDetails?.data?.name,
 | 
						|
                            uid: state.osmConnection?.userDetails?.data?.uid,
 | 
						|
                        },
 | 
						|
                    ]),
 | 
						|
                },
 | 
						|
            }
 | 
						|
            state?.featurePipeline?.InjectNewPoint(feature)
 | 
						|
            state.selectedElement?.setData(feature)
 | 
						|
            Hash.hash.setData(feature.properties.id)
 | 
						|
            text.GetValue().setData("")
 | 
						|
            isCreated.setData(true)
 | 
						|
        })
 | 
						|
        const createNoteDialog = new Combine([
 | 
						|
            new Title(t.createNoteTitle),
 | 
						|
            t.createNoteIntro,
 | 
						|
            text,
 | 
						|
            new Combine([
 | 
						|
                new Toggle(
 | 
						|
                    undefined,
 | 
						|
                    t.warnAnonymous.SetClass("block alert"),
 | 
						|
                    state?.osmConnection?.isLoggedIn
 | 
						|
                ),
 | 
						|
                new Toggle(
 | 
						|
                    postNote,
 | 
						|
                    t.textNeeded.SetClass("block alert"),
 | 
						|
                    text.GetValue().map((txt) => txt?.length > 3)
 | 
						|
                ),
 | 
						|
            ]).SetClass("flex justify-end items-center"),
 | 
						|
        ]).SetClass("flex flex-col border-2 border-black rounded-xl p-4")
 | 
						|
 | 
						|
        const newNoteUi = new Toggle(
 | 
						|
            new Toggle(t.isCreated.SetClass("thanks"), createNoteDialog, isCreated),
 | 
						|
            undefined,
 | 
						|
            new UIEventSource<boolean>(true)
 | 
						|
        )
 | 
						|
 | 
						|
        super(
 | 
						|
            new Toggle(
 | 
						|
                new Combine([
 | 
						|
                    t.noteLayerHasFilters.SetClass("alert"),
 | 
						|
                    new SubtleButton(Svg.filter_svg(), t.disableAllNoteFilters).onClick(() => {
 | 
						|
                        const filters = noteLayer.appliedFilters.data
 | 
						|
                        for (const key of Array.from(filters.keys())) {
 | 
						|
                            filters.set(key, undefined)
 | 
						|
                        }
 | 
						|
                        noteLayer.appliedFilters.ping()
 | 
						|
                        isShown.setData(false)
 | 
						|
                    }),
 | 
						|
                ]).SetClass("flex flex-col"),
 | 
						|
                newNoteUi,
 | 
						|
                noteLayer.appliedFilters.map((filters) => {
 | 
						|
                    console.log("Applied filters for notes are: ", filters)
 | 
						|
                    return Array.from(filters.values()).some((v) => v?.currentFilter !== undefined)
 | 
						|
                })
 | 
						|
            ),
 | 
						|
            new Combine([
 | 
						|
                t.noteLayerNotEnabled.SetClass("alert"),
 | 
						|
                new SubtleButton(Svg.layers_svg(), t.noteLayerDoEnable).onClick(() => {
 | 
						|
                    noteLayer.isDisplayed.setData(true)
 | 
						|
                    isShown.setData(false)
 | 
						|
                }),
 | 
						|
            ]).SetClass("flex flex-col"),
 | 
						|
            noteLayer.isDisplayed
 | 
						|
        )
 | 
						|
    }
 | 
						|
}
 |