forked from MapComplete/MapComplete
57 lines
2.3 KiB
Svelte
57 lines
2.3 KiB
Svelte
<script lang="ts">
|
|
|
|
import DownloadButton from "./DownloadButton.svelte";
|
|
import ThemeViewState from "../../Models/ThemeViewState";
|
|
import {SvgToPdf} from "../../Utils/svgToPdf";
|
|
import Translations from "../i18n/Translations";
|
|
import {Translation} from "../i18n/Translation";
|
|
import {Utils} from "../../Utils";
|
|
import {AvailableRasterLayers} from "../../Models/RasterLayers";
|
|
import Constants from "../../Models/Constants";
|
|
import Locale from "../i18n/Locale";
|
|
import {UIEventSource} from "../../Logic/UIEventSource";
|
|
import DownloadHelper from "./DownloadHelper";
|
|
|
|
export let templateName: string
|
|
export let state: ThemeViewState
|
|
const template = SvgToPdf.templates[templateName]
|
|
console.log("template", template )
|
|
let mainText: Translation = typeof template.description === "string" ? new Translation(template.description) : template.description
|
|
let t = Translations.t.general.download
|
|
const downloadHelper = new DownloadHelper(state)
|
|
async function constructPdf(_, title: string, status: UIEventSource<string>) {
|
|
const templateUrls = SvgToPdf.templates["current_view_a3"].pages
|
|
const templates: string[] = await Promise.all(templateUrls.map(url => Utils.download(url)))
|
|
console.log("Templates are", templates)
|
|
const bg = state.mapProperties.rasterLayer.data ?? AvailableRasterLayers.maplibre
|
|
const creator = new SvgToPdf(title, templates, {
|
|
state,
|
|
freeComponentId: "belowmap",
|
|
generateImage(key: string): HTMLImageElement {
|
|
downloadHelper.generateImage(key)
|
|
},
|
|
textSubstitutions: <Record<string, string>> {
|
|
"layout.title": state.layout.title,
|
|
title: state.layout.title,
|
|
layoutImg: state.layout.icon,
|
|
version: Constants.vNumber,
|
|
date: new Date().toISOString().substring(0,16),
|
|
background: new Translation(bg.properties.name).txt
|
|
}
|
|
})
|
|
|
|
const unsub = creator.status.addCallbackAndRunD(s => status?.setData(s))
|
|
await creator.ExportPdf(Locale.language.data)
|
|
unsub()
|
|
return undefined
|
|
}
|
|
</script>
|
|
|
|
|
|
<DownloadButton {state}
|
|
mimetype="application/pdf"
|
|
extension="pdf"
|
|
{mainText}
|
|
helperText={t.downloadAsPdfHelper}
|
|
construct={constructPdf}
|
|
/>
|