import State from "../../State"; import Combine from "../Base/Combine"; import ScrollableFullScreen from "../Base/ScrollableFullScreen"; import Translations from "../i18n/Translations"; import {UIEventSource} from "../../Logic/UIEventSource"; import BaseUIElement from "../BaseUIElement"; import Toggle from "../Input/Toggle"; import {DownloadPanel} from "./DownloadPanel"; import {SubtleButton} from "../Base/SubtleButton"; import Svg from "../../Svg"; import ExportPDF from "../ExportPDF"; import {Browser} from "leaflet"; import ie = Browser.ie; import {FixedUiElement} from "../Base/FixedUiElement"; export default class AllDownloads extends ScrollableFullScreen { constructor(isShown: UIEventSource) { super(AllDownloads.GenTitle, AllDownloads.GeneratePanel, "layers", isShown); } private static GenTitle(): BaseUIElement { return Translations.t.general.download.title .Clone() .SetClass("text-2xl break-words font-bold p-2"); } private static GeneratePanel(): BaseUIElement { const isExporting = new UIEventSource(false, "Pdf-is-exporting") const generatePdf = () => { isExporting.setData(true) new ExportPDF( { freeDivId: "belowmap", background: State.state.backgroundLayer, location: State.state.locationControl, features: State.state.featurePipeline.features, layout: State.state.layoutToUse, }).isRunning.addCallbackAndRun(isRunning => isExporting.setData(isRunning)) } const loading = Svg.loading_svg().SetClass("animate-rotate"); const icon = new Toggle(loading, Svg.floppy_ui(), isExporting); const text = new Toggle( new FixedUiElement("Exporting..."), new Combine([ Translations.t.general.download.downloadAsPdf.Clone().SetClass("font-bold"), Translations.t.general.download.downloadAsPdfHelper.Clone()] ).SetClass("flex flex-col") .onClick(() => { generatePdf() }), isExporting); const pdf = new Toggle( new SubtleButton( icon, text), undefined, State.state.featureSwitchExportAsPdf ) const exportPanel = new Toggle( new DownloadPanel(), undefined, State.state.featureSwitchEnableExport ) return new Combine([pdf, exportPanel]).SetClass("flex flex-col"); } }