annotate client/src/components/Pdftool.vue @ 4418:c0bfe7283384

pdftool: remove .replace()
author Thomas Junk <thomas.junk@intevation.de>
date Wed, 18 Sep 2019 13:47:52 +0200
parents ad7b06f2f2ad
children 69166db6ba8a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
1 <template>
1480
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
2 <div
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
3 :class="[
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
4 'box ui-element rounded bg-white text-nowrap',
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
5 { expanded: showPdfTool }
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
6 ]"
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
7 >
2260
531e776cb81d client: reduced width of pdf-, profile- and identify-box
Markus Kottlaender <markus@intevation.de>
parents: 2259
diff changeset
8 <div style="width: 18rem">
2387
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
9 <UIBoxHeader
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
10 icon="file-pdf"
2754
d0f6c222f4f9 client:correct a set of strings marking
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2737
diff changeset
11 :title="generatePdfLable"
2387
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
12 :closeCallback="close"
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
13 />
2534
bb5286acfee2 client: reduced spacings between and inside boxes and more compact main menu
Markus Kottlaender <markus@intevation.de>
parents: 2387
diff changeset
14 <div class="box-body">
2114
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
15 <select
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
16 @change="applyTemplateToForm"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
17 v-model="form.template"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
18 class="form-control d-block mb-2 w-100 font-weight-bold"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
19 >
2124
af136b1a854e linting
Markus Kottlaender <markus@intevation.de>
parents: 2114
diff changeset
20 <option
2257
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
21 v-for="template in templates"
2214
5a4b0c85e7a8 values in template select are now the actual objects
Markus Kottlaender <markus@intevation.de>
parents: 2212
diff changeset
22 :value="template"
2124
af136b1a854e linting
Markus Kottlaender <markus@intevation.de>
parents: 2114
diff changeset
23 :key="template.name"
2114
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
24 >
2754
d0f6c222f4f9 client:correct a set of strings marking
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2737
diff changeset
25 {{ template.name }}
2124
af136b1a854e linting
Markus Kottlaender <markus@intevation.de>
parents: 2114
diff changeset
26 </option>
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
27 </select>
2114
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
28 <select
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
29 v-model="form.format"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
30 class="form-control form-control-sm d-block mb-2 w-100"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
31 >
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
32 <option value="landscape"><translate>landscape</translate></option>
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
33 <option value="portrait"><translate>portrait</translate></option>
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
34 </select>
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
35 <div class="d-flex">
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
36 <div class="flex-fill mr-2">
2114
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
37 <select
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
38 v-model="form.resolution"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
39 class="form-control form-control-sm mb-2 d-block w-100"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
40 >
2225
bc1780dd7cd1 PDF generation: changed option names in resolution select
Markus Kottlaender <markus@intevation.de>
parents: 2224
diff changeset
41 <option value="80"><translate>80 dpi</translate></option>
bc1780dd7cd1 PDF generation: changed option names in resolution select
Markus Kottlaender <markus@intevation.de>
parents: 2224
diff changeset
42 <option value="120"><translate>120 dpi</translate></option>
bc1780dd7cd1 PDF generation: changed option names in resolution select
Markus Kottlaender <markus@intevation.de>
parents: 2224
diff changeset
43 <option value="200"><translate>200 dpi</translate></option>
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
44 </select>
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
45 </div>
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
46 <div class="flex-fill ml-2">
2114
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
47 <select
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
48 v-model="form.paperSize"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
49 class="form-control form-control-sm mb-2 d-block w-100"
910c21ea531a linting
Thomas Junk <thomas.junk@intevation.de>
parents: 2112
diff changeset
50 >
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
51 <option value="a4"><translate>A4</translate></option>
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
52 <option value="a3"><translate>A3</translate></option>
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
53 </select>
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
54 </div>
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
55 </div>
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
56 <div class="d-flex flex-fill-row">
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
57 <small class="my-auto text-muted">
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
58 <translate>Scale to 1:</translate>
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
59 </small>
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
60 <input
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
61 class="form-control form-control-sm w-100 ml-2"
4088
2db1124c32f7 pdftool: change placeholder
Thomas Junk <thomas.junk@intevation.de>
parents: 4077
diff changeset
62 placeholder="10000"
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
63 v-model.number="form.scale"
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
64 type="number"
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
65 />
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
66 </div>
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
67 <button
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
68 @click="download"
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
69 :key="'downloadBtn'"
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
70 type="button"
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
71 v-if="readyToGenerate"
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
72 class="btn btn-sm btn-info d-block w-100 mt-2"
1480
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
73 >
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
74 <translate>Generate PDF</translate>
9b81ac91a43e fix: linting
Thomas Junk <thomas.junk@intevation.de>
parents: 1433
diff changeset
75 </button>
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
76 <button
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
77 @click="cancel"
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
78 :key="'cancelBtn'"
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
79 type="button"
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
80 v-else
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
81 class="btn btn-sm btn-danger d-block w-100 mt-2"
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
82 >
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
83 <font-awesome-icon class="mr-1" icon="spinner" spin />
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
84 <translate>Cancel</translate>
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
85 </button>
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
86 </div>
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
87 </div>
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
88 </div>
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
89 </template>
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
90
3202
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
91 <style lang="scss" scoped>
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
92 input,
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
93 select {
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
94 font-size: 0.8em;
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
95 }
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
96 </style>
7c59955fbcca dialogs: styling
Thomas Junk <thomas.junk@intevation.de>
parents: 3127
diff changeset
97
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
98 <script>
1362
ca33ad696594 remove the first empyty lines
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1361
diff changeset
99 /* This is Free Software under GNU Affero General Public License v >= 3.0
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
100 * without warranty, see README.md and license for details.
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
101 *
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
102 * SPDX-License-Identifier: AGPL-3.0-or-later
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
103 * License-Filename: LICENSES/AGPL-3.0.txt
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
104 *
1878
f030182f82f1 client: fix style warning for pdfexport
Bernhard Reiter <bernhard@intevation.de>
parents: 1876
diff changeset
105 * Copyright (C) 2018, 2019 by via donau
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
106 * – Österreichische Wasserstraßen-Gesellschaft mbH
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
107 * Software engineering by Intevation GmbH
1361
ea3a89a1813a remove trailing whitespace, add headers for Makefile, add the missed authors
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1299
diff changeset
108 *
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
109 * Author(s):
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
110 * * Markus Kottländer <markus.kottlaender@intevation.de>
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
111 * * Bernhard E. Reiter <bernhard@intevation.de>
1878
f030182f82f1 client: fix style warning for pdfexport
Bernhard Reiter <bernhard@intevation.de>
parents: 1876
diff changeset
112 * * Fadi Abbud <fadi.abbud@intevation.de>
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
113 */
3044
c71373594719 client: map: prepared store to hold multiple map objects
Markus Kottlaender <markus@intevation.de>
parents: 3006
diff changeset
114 import { mapState, mapGetters } from "vuex";
3780
2b6734a6730a include svg2pdf. substitute upstream jsdpf with yworks-fork
Thomas Junk <thomas.junk@intevation.de>
parents: 3408
diff changeset
115 import jsPDF from "jspdf-yworks";
2985
1b8bb4f89227 client: removed .js and .vue extention from imports
Markus Kottlaender <markus@intevation.de>
parents: 2959
diff changeset
116 import "@/lib/font-linbiolinum";
1b8bb4f89227 client: removed .js and .vue extention from imports
Markus Kottlaender <markus@intevation.de>
parents: 2959
diff changeset
117 import { getPointResolution } from "ol/proj";
2947
a6eea3002e6e client: cleanup import paths
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2767
diff changeset
118 import { HTTP } from "@/lib/http";
2985
1b8bb4f89227 client: removed .js and .vue extention from imports
Markus Kottlaender <markus@intevation.de>
parents: 2959
diff changeset
119 import { displayError } from "@/lib/errors";
3802
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
120 import { pdfgen, templateLoader } from "@/lib/mixins";
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
121
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
122 const paperSizes = {
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
123 // in millimeter, landscape [width, height]
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
124 a3: [420, 297],
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
125 a4: [297, 210]
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
126 };
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
127
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
128 const DEFAULT_TEMPLATE = "Default";
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
129
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
130 export default {
3802
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
131 mixins: [pdfgen, templateLoader],
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
132 name: "pdftool",
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
133 data() {
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
134 return {
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
135 form: {
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
136 template: null,
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
137 format: "landscape",
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
138 paperSize: "a4",
1881
f512cfb63e53 pdf-generation: add select box to pdf tool to choose the resolutions
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1879
diff changeset
139 downloadType: "download",
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
140 resolution: "80",
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
141 scale: null
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
142 },
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
143 templates: [
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
144 {
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
145 name: DEFAULT_TEMPLATE,
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
146 properties: {
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
147 format: "landscape",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
148 paperSize: "a4",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
149 resolution: "80"
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
150 },
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
151 elements: [
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
152 {
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
153 type: "scalebar",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
154 position: "bottomright",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
155 offset: { x: 2, y: 2 }
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
156 },
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
157 {
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
158 type: "textbox",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
159 position: "bottomleft",
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
160 offset: { x: 2, y: 2 },
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
161 width: 60,
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
162 fontSize: 8,
2284
9f327f197ddd client: translation: mark some strings for translations
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2275
diff changeset
163 text: this.$gettext("Generated by") + " " + "{user}, {date}"
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
164 },
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
165 {
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
166 type: "northarrow",
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
167 position: "topleft",
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
168 offset: { x: 6, y: 4 },
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
169 size: 2
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
170 }
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
171 ]
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
172 }
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
173 ],
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
174 templateData: null,
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
175 pdf: {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
176 doc: null,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
177 width: null,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
178 height: null
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
179 },
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
180 logoImageForPDF: null, // a HTMLImageElement instance
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
181 readyToGenerate: true, // if the user is allowed to press the button
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
182 rendercompleteListener: null,
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
183 mapSize: null,
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
184 resolution: null
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
185 };
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
186 },
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
187 computed: {
2257
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
188 ...mapState("application", ["showPdfTool", "logoForPDF"]),
2137
a31c9fa47ab8 client: pdf-gen: add bottleneck details
Bernhard Reiter <bernhard@intevation.de>
parents: 2124
diff changeset
189 ...mapState("bottlenecks", ["selectedBottleneck", "selectedSurvey"]),
3044
c71373594719 client: map: prepared store to hold multiple map objects
Markus Kottlaender <markus@intevation.de>
parents: 3006
diff changeset
190 ...mapState("map", ["isolinesLegendImgDataURL"]),
c71373594719 client: map: prepared store to hold multiple map objects
Markus Kottlaender <markus@intevation.de>
parents: 3006
diff changeset
191 ...mapGetters("map", ["openLayersMap"]),
2754
d0f6c222f4f9 client:correct a set of strings marking
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2737
diff changeset
192 generatePdfLable() {
d0f6c222f4f9 client:correct a set of strings marking
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2737
diff changeset
193 return this.$gettext("Generate PDF");
d0f6c222f4f9 client:correct a set of strings marking
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2737
diff changeset
194 },
2376
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
195 filename() {
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
196 let date = new Date()
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
197 .toISOString()
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
198 .slice(0, 10)
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
199 .replace(/-/g, "");
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
200 let filename = "map";
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
201
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
202 if (this.selectedBottleneck) {
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
203 filename = this.selectedBottleneck;
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
204 if (this.selectedSurvey) {
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
205 filename += "-sr" + this.selectedSurvey.date_info.replace(/-/g, "");
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
206 }
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
207 }
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
208
4418
c0bfe7283384 pdftool: remove .replace()
Thomas Junk <thomas.junk@intevation.de>
parents: 4417
diff changeset
209 filename = filename.toLowerCase() + "-exported" + date + ".pdf";
2376
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
210 return filename;
6efd7ecd3a7d client: pdf-gen: generate more expressive filename
Markus Kottlaender <markus@intevation.de>
parents: 2325
diff changeset
211 }
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
212 },
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
213 methods: {
2387
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
214 close() {
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
215 this.$store.commit("application/showPdfTool", false);
f185503ef35a client: unified box's header styles by creating a reusable component
Markus Kottlaender <markus@intevation.de>
parents: 2376
diff changeset
216 },
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
217 // When a template is chosen from the dropdown, its propoerties are
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
218 // applied to the rest of the form.
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
219 applyTemplateToForm() {
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
220 if (this.form.template && this.form.template.name !== DEFAULT_TEMPLATE) {
3802
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
221 this.loadTemplates(
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
222 `/templates/${this.form.template.type}/${this.form.template.name}`
3227
6d4d8e7ef881 client: adjust route for pdftemplate,pdftool and add check type to uploaded templates
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3222
diff changeset
223 )
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
224 .then(response => {
3802
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
225 this.prepareImages(response.data.template_data.elements).then(
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
226 values => {
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
227 values.forEach(v => {
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
228 response.data.template_data.elements[v.index].url = v.url;
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
229 });
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
230 this.setTemplate(response.data.template_data);
3802
e8a950cf6c02 Move Template loading and Imageprocessing to mixin
Thomas Junk <thomas.junk@intevation.de>
parents: 3790
diff changeset
231 }
3786
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
232 );
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
233 })
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
234 .catch(e => {
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
235 const { status, data } = e.response;
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
236 displayError({
2284
9f327f197ddd client: translation: mark some strings for translations
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2275
diff changeset
237 title: this.$gettext("Backend Error"),
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
238 message: `${status}: ${data.message || data}`
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
239 });
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
240 });
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
241 } else {
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
242 this.setTemplate(this.templates[0]);
2112
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
243 }
8c0a0f237c2d improved behavior of pdf generation form
Markus Kottlaender <markus@intevation.de>
parents: 2111
diff changeset
244 },
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
245 setTemplate(template) {
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
246 this.templateData = template;
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
247 this.form.format = this.templateData.properties.format;
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
248 this.form.paperSize = this.templateData.properties.paperSize;
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
249 this.form.resolution = this.templateData.properties.resolution;
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
250 },
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
251 download() {
3981
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
252 /**
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
253 * In order to generate the image with the appropriate resolution
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
254 * we have to temporaily scale the visible part of the map.
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
255 * The newly rendered canvas is converted to Base64 DataURL.
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
256 * After that is done, the resolution is resetted to its previous state.
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
257 *
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
258 * calculateExtent() and fit() do not give the desired result
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
259 * when the view is rotated so we replace them completely by setting resolution
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
260 *
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
261 * Details: https://gis.stackexchange.com/questions/328933/openlayers-generating-clientside-pdfs
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
262 *
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
263 */
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
264 this.readyToGenerate = false;
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
265 console.log(
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
266 "will generate pdf with",
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
267 this.form.paperSize,
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
268 this.form.format,
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
269 this.form.resolution
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
270 );
1883
76a6d334e681 Client: pdf-gen: refactor addScaleBar
Bernhard Reiter <bernhard@intevation.de>
parents: 1882
diff changeset
271
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
272 if (this.form.format !== "portrait") {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
273 this.pdf.width = paperSizes[this.form.paperSize][0];
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
274 this.pdf.height = paperSizes[this.form.paperSize][1];
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
275 } else {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
276 this.pdf.width = paperSizes[this.form.paperSize][1];
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
277 this.pdf.height = paperSizes[this.form.paperSize][0];
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
278 }
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
279
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
280 // FUTURE: consider margins
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
281
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
282 var pixelsPerMapMillimeter = this.form.resolution / 25.4;
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
283 var mapSizeForPrint = [
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
284 Math.round(this.pdf.width * pixelsPerMapMillimeter),
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
285 Math.round(this.pdf.height * pixelsPerMapMillimeter)
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
286 ];
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
287 var map = this.openLayersMap();
3981
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
288 this.mapSize = map.getSize();
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
289 this.resolution = map.getView().getResolution();
1883
76a6d334e681 Client: pdf-gen: refactor addScaleBar
Bernhard Reiter <bernhard@intevation.de>
parents: 1882
diff changeset
290
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
291 this.pdf.doc = new jsPDF(this.form.format, "mm", this.form.paperSize);
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
292 this.rendercompleteListener = map.once("rendercomplete", event => {
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
293 let canvas = event.context.canvas;
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
294 let scaleDenominator = Math.round(
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
295 1000 *
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
296 pixelsPerMapMillimeter *
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
297 this.getMeterPerPixel(
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
298 this.openLayersMap()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
299 .getView()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
300 .getResolution()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
301 )
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
302 );
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
303 console.log("scaleDenominator = ", scaleDenominator);
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
304 var snapshot = canvas.toDataURL("image/jpeg");
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
305 this.pdf.doc.addImage(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
306 snapshot,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
307 "JPEG",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
308 0,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
309 0,
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
310 this.pdf.width,
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
311 this.pdf.height
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
312 );
1903
7247ac316cb7 client: pdf-gen: improve layout and ui
Bernhard Reiter <bernhard@intevation.de>
parents: 1897
diff changeset
313
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
314 if (this.templateData) {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
315 this.pdf.doc.setFont("linbiolinum", "normal");
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
316 let defaultFontSize = 11,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
317 defaultRounding = 2,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
318 defaultTextColor = "black",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
319 defaultBgColor = "white",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
320 defaultPadding = 3,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
321 defaultOffset = { x: 0, y: 0 },
3993
6672b780722f client: pdf-gen: improve addtext for pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3981
diff changeset
322 defaultBorderColor = "white";
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
323 this.templateData.elements.forEach(e => {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
324 switch (e.type) {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
325 case "text": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
326 this.addText(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
327 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
328 e.offset || defaultOffset,
3993
6672b780722f client: pdf-gen: improve addtext for pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3981
diff changeset
329 e.width,
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
330 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
331 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
332 e.text
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
333 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
334 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
335 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
336 case "box": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
337 this.addBox(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
338 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
339 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
340 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
341 e.height,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
342 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
343 e.color || defaultBgColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
344 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
345 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
346 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
347 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
348 case "textbox": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
349 this.addTextBox(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
350 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
351 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
352 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
353 e.height,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
354 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
355 e.padding || defaultPadding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
356 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
357 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
358 e.background || defaultBgColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
359 e.text,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
360 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
361 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
362 break;
2223
85142493096c PDF generation: improved positioning, prepared demo templates
Markus Kottlaender <markus@intevation.de>
parents: 2222
diff changeset
363 }
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
364 case "image": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
365 this.addImage(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
366 e.url,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
367 e.format,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
368 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
369 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
370 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
371 e.height
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
372 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
373 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
374 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
375 case "bottleneck": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
376 this.addBottleneckInfo(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
377 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
378 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
379 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
380 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
381 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
382 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
383 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
384 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
385 case "legend": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
386 this.addLegend(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
387 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
388 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
389 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
390 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
391 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
392 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
393 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
394 case "scalebar": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
395 this.addScaleBar(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
396 scaleDenominator,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
397 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
398 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
399 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
400 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
401 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
402 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
403 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
404 case "scale": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
405 this.addScale(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
406 scaleDenominator,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
407 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
408 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
409 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
410 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
411 e.color || defaultTextColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
412 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
413 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
414 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
415 case "northarrow": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
416 this.addNorthArrow(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
417 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
418 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
419 e.size
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
420 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
421 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
422 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
423 }
2205
59c21dee6315 pdf-gen: improve pdftool to use value from template
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2124
diff changeset
424 });
1928
76ca071cb006 client: pdf-gen: add legend graphic
Bernhard Reiter <bernhard@intevation.de>
parents: 1914
diff changeset
425
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
426 this.pdf.doc.save(this.filename);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
427 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
428 map.setSize(this.mapSize);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
429 map.getView().setResolution(this.resolution);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
430 this.readyToGenerate = true;
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
431 });
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
432
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
433 const size = map.getSize();
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
434 const [width, height] = mapSizeForPrint;
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
435 map.setSize(mapSizeForPrint);
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
436 const scaling = Math.min(width / size[0], height / size[1]);
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
437 map
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
438 .getView()
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
439 .setResolution(
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
440 this.form.scale
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
441 ? this.getResolutionFromScale()
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
442 : this.resolution / scaling
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
443 );
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
444 },
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
445 getResolutionFromScale() {
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
446 const scaling = Math.round(this.form.scale / 1000);
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
447 return scaling / this.getMeterPerPixel(this.form.resolution / 25.4);
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
448 },
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
449 getMeterPerPixel(f) {
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
450 var map = this.openLayersMap();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
451 let view = map.getView();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
452 let proj = view.getProjection();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
453 return (
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
454 getPointResolution(proj, f, view.getCenter()) * proj.getMetersPerUnit()
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
455 );
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
456 },
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
457 cancel() {
4416
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
458 try {
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
459 this.openLayersMap().un(
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
460 this.rendercompleteListener.type,
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
461 this.rendercompleteListener.listener
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
462 );
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
463 this.openLayersMap().setSize(this.mapSize);
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
464 this.openLayersMap()
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
465 .getView()
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
466 .fit(this.resolution, { size: this.mapSize });
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
467 } finally {
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
468 this.readyToGenerate = true;
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
469 }
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
470 },
2737
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
471 // add the used map scale and papersize
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
472 addScale(scaleDenominator, position, width, offset, fontSize, color) {
2737
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
473 //TODO: check the correctence of the scalnominator value here.
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
474 let str =
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
475 this.$gettext("Scale") +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
476 " 1 : " +
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
477 scaleDenominator +
2737
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
478 " " +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
479 "(DIN" +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
480 " " +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
481 this.form.paperSize.toUpperCase() +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
482 ")";
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
483 this.addText(position, offset, width, fontSize, color, str);
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
484 },
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
485 addScaleBar(scaleDenominator, position, offset, rounding, brcolor) {
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
486 // scaleDenominator is the x in 1:x of the map scale
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
487
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
488 // hardcode maximal width for now
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
489 let maxWidth = 80; // in mm
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
490
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
491 // reduce width until we'll find a nice number for printing
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
492 // strategy:
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
493 // 1. check which unit prefix we shall use to get [10:10000[
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
494 // 2. using a mapping for the leading digit to get [1:10[
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
495 // 3. select a smaller number which is nicely dividable
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
496 // 4. scale up again to get length in paper mm and to be shown
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
497
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
498 // from https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/log10#Polyfill
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
499 let log10 =
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
500 Math.log10 || // more precise, but unsupported by IE
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
501 function(x) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
502 return Math.log(x) * Math.LOG10E;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
503 };
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
504
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
505 let maxLength = maxWidth * scaleDenominator;
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
506
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
507 let unit = "mm";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
508 let unitConversionFactor = 1;
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
509 if (maxLength >= 1e7) {
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
510 // >= 10 km
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
511 unit = "km";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
512 unitConversionFactor = 1e6;
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
513 } else if (maxLength >= 1e4) {
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
514 // >= 10 m
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
515 unit = "m";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
516 unitConversionFactor = 1e3;
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
517 }
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
518
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
519 maxLength /= unitConversionFactor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
520
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
521 // DEBUG console.log(maxLength, unit);
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
522 let unroundedLength = maxLength;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
523 let numberOfDigits = Math.floor(log10(unroundedLength));
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
524 let factor = Math.pow(10, numberOfDigits);
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
525 let mapped = unroundedLength / factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
526 // DEBUG console.log(mapped);
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
527
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
528 var length = Math.floor(maxLength); // just to have an upper limit
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
529
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
530 // manually only use numbers that are very nice to devide by 4
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
531 // note that this is taken into account for rounding later
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
532 if (mapped > 8) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
533 length = 8 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
534 } else if (mapped > 4) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
535 length = 4 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
536 } else if (mapped > 2) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
537 length = 2 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
538 } else {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
539 length = factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
540 }
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
541
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
542 let size = (length * unitConversionFactor) / scaleDenominator / 4;
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
543 let fullSize = size * 4;
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
544
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
545 // x/y defaults to offset for topleft corner (normal x/y coordinates)
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
546 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
547 let y = offset.y;
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
548
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
549 // if position is on the right, x needs to be calculate with pdf width and
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
550 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
551 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
552 x = this.pdf.width - offset.x - fullSize - 8;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
553 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
554 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
555 y = this.pdf.height - offset.y - 10;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
556 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
557
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
558 // to give the outer white box 4mm padding
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
559 let scaleBarX = x + 4;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
560 let scaleBarY = y + 5; // 5 because above the scalebar will be the numbers
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
561
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
562 // draw outer white box
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
563 this.addRoundedBox(x, y, fullSize + 8, 10, "white", rounding, brcolor);
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
564
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
565 // draw first part of scalebar
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
566 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
567 this.pdf.doc.setFillColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
568 this.pdf.doc.rect(scaleBarX, scaleBarY, size, 1, "FD");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
569
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
570 // draw second part of scalebar
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
571 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
572 this.pdf.doc.setFillColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
573 this.pdf.doc.rect(scaleBarX + size, scaleBarY, size, 1, "FD");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
574
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
575 // draw third part of scalebar
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
576 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
577 this.pdf.doc.setFillColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
578 this.pdf.doc.rect(scaleBarX + size * 2, scaleBarY, size * 2, 1, "FD");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
579
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
580 // draw numeric labels above scalebar
2223
85142493096c PDF generation: improved positioning, prepared demo templates
Markus Kottlaender <markus@intevation.de>
parents: 2222
diff changeset
581 this.pdf.doc.setTextColor("black");
2240
c3cc21dee75d client: pdf-gen add multi-language font
Bernhard Reiter <bernhard@intevation.de>
parents: 2227
diff changeset
582 this.pdf.doc.setFontSize(6);
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
583 this.pdf.doc.text(scaleBarX, scaleBarY - 1, "0");
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
584 // /4 and could give 2.5. We still round, because of floating point arith
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
585 this.pdf.doc.text(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
586 scaleBarX + size - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
587 scaleBarY - 1,
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
588 (Math.round((length * 10) / 4) / 10).toString()
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
589 );
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
590 this.pdf.doc.text(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
591 scaleBarX + size * 2 - 2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
592 scaleBarY - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
593 Math.round(length / 2).toString()
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
594 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
595 this.pdf.doc.text(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
596 scaleBarX + size * 4 - 4,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
597 scaleBarY - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
598 Math.round(length).toString() + " " + unit
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
599 );
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
600 },
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
601 addNorthArrow(position, offset, size) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
602 // TODO: fix positioning
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
603 // x/y defaults to offset for topleft corner (normal x/y coordinates)
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
604 let x1 = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
605 let y1 = offset.y;
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
606
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
607 // if position is on the right, x needs to be calculate with pdf width and
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
608 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
609 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
610 x1 = this.pdf.width - offset.x - size;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
611 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
612 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
613 y1 = this.pdf.height - offset.y - size;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
614 }
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
615
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
616 var y2 = y1 + size * 3;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
617 var x3 = x1 - size * 2;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
618 var y3 = y1 + size * 5;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
619 var x4 = x1 + size * 2;
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
620 // white triangle
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
621 this.pdf.doc.setFillColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
622 this.pdf.doc.setDrawColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
623 this.pdf.doc.triangle(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
624 x3 - 0.8,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
625 y3 + 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
626 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
627 y1 - 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
628 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
629 y2 + 0.6,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
630 "F"
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
631 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
632 this.pdf.doc.triangle(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
633 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
634 y1 - 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
635 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
636 y2 + 0.6,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
637 x4 + 0.8,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
638 y3 + 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
639 "F"
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
640 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
641
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
642 // north arrow
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
643 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
644 this.pdf.doc.setFillColor(255, 255, 255);
2539
ad2a1d02ad1c client:pdf-gen: improve north arrow drawing
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2534
diff changeset
645 this.pdf.doc.triangle(x3, y3, x1 - 0.1, y1 + 0.2, x1 - 0.1, y2, "FD");
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
646 this.pdf.doc.setFillColor(0, 0, 0);
2539
ad2a1d02ad1c client:pdf-gen: improve north arrow drawing
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2534
diff changeset
647 this.pdf.doc.triangle(x1 + 0.1, y1 + 0.2, x1 + 0.1, y2, x4, y3, "FD");
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
648 this.pdf.doc.setFontSize(size * 3.1);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
649 this.pdf.doc.setTextColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
650 this.pdf.doc.setFontStyle("bold");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
651 this.pdf.doc.text(size < 3 ? x1 - 0.5 : x1 - 1.3, y3 + 1, "N");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
652 this.pdf.doc.setFontSize(size * 3);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
653 this.pdf.doc.setTextColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
654 this.pdf.doc.setFontStyle("normal");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
655 this.pdf.doc.text(size < 3 ? x1 - 0.5 : x1 - 1.3, y3 + 1, "N");
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
656 },
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
657 addLegend(position, offset, rounding, brcolor) {
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
658 if (
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
659 this.selectedBottleneck &&
2259
7e378b38d302 client: pdf-gen: made selectedSurvey mandatory for displaying the bottleneck info box and iso line legend.
Markus Kottlaender <markus@intevation.de>
parents: 2258
diff changeset
660 this.selectedSurvey &&
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
661 this.openLayersMap()
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
662 .getLayer("BOTTLENECKISOLINE")
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
663 .getVisible()
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
664 ) {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
665 // transforming into an HTMLImageElement only to find out
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
666 // the width x height of the legend image
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
667 // FUTURE: find a better way to get the width and height
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
668 let legendImage = new Image();
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
669 legendImage.src = this.isolinesLegendImgDataURL;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
670 let aspectRatio = legendImage.width / legendImage.height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
671 let width = 54;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
672 let height = width / aspectRatio;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
673 let padding = 2;
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
674
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
675 // x/y defaults to offset for topleft corner (normal x/y coordinates)
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
676 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
677 let y = offset.y;
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
678
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
679 // if position is on the right, x needs to be calculate with pdf width and
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
680 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
681 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
682 x = this.pdf.width - offset.x - width;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
683 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
684 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
685 y = this.pdf.height - offset.y - height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
686 }
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
687
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
688 this.addRoundedBox(x, y, width, height, "white", rounding, brcolor);
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
689 this.pdf.doc.addImage(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
690 legendImage,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
691 x + padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
692 y + padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
693 width - 2 * padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
694 height - 2 * padding
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
695 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
696 }
1931
8fb1b1a8ea85 client: pdf-gen: improve legend behaviour
Bernhard Reiter <bernhard@intevation.de>
parents: 1928
diff changeset
697 },
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
698 addBottleneckInfo(position, offset, rounding, color, brcolor) {
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
699 if (
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
700 this.selectedBottleneck &&
2259
7e378b38d302 client: pdf-gen: made selectedSurvey mandatory for displaying the bottleneck info box and iso line legend.
Markus Kottlaender <markus@intevation.de>
parents: 2258
diff changeset
701 this.selectedSurvey &&
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
702 this.openLayersMap()
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
703 .getLayer("BOTTLENECKISOLINE")
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
704 .getVisible()
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
705 ) {
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
706 let survey = this.selectedSurvey;
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
707
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
708 // determine text dimensions
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
709 // this is a little bit cumbersome but we need to separate width
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
710 // calculations and writing
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
711 this.pdf.doc.setFontSize(10);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
712 this.pdf.doc.setTextColor(color);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
713 let textOptions = { baseline: "hanging" };
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
714 let str1_1 = this.$gettext("Bottleneck") + ": ";
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
715 let str1_2 = this.selectedBottleneck;
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
716 let str2_1 = this.$gettext("Survey date") + ": ";
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
717 let str2_2 = survey.date_info;
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
718 let str3_1 = this.$gettext("Ref gauge") + ": ";
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
719 let str3_2 = survey.gauge_objname;
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
720 let str4_1 = this.$gettext("Depth relativ to") + ": ";
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
721 let str4_2 =
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
722 survey.depth_reference +
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
723 " = " +
2291
60af456d01f0 client:pdf-gen:(minor) fix bottleneckinfo function
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2288
diff changeset
724 (survey.hasOwnProperty("waterlevel_value")
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
725 ? survey.waterlevel_value + " cm"
2291
60af456d01f0 client:pdf-gen:(minor) fix bottleneckinfo function
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2288
diff changeset
726 : "?");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
727
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
728 this.pdf.doc.setFontStyle("italic");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
729 let w1_1 = this.pdf.doc.getTextWidth(str1_1);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
730 this.pdf.doc.setFontStyle("bold");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
731 let w1_2 = this.pdf.doc.getTextWidth(str1_2);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
732 this.pdf.doc.setFontStyle("italic");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
733 let w2_1 = this.pdf.doc.getTextWidth(str2_1);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
734 this.pdf.doc.setFontStyle("normal");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
735 let w2_2 = this.pdf.doc.getTextWidth(str2_2);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
736 this.pdf.doc.setFontStyle("italic");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
737 let w3_1 = this.pdf.doc.getTextWidth(str3_1);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
738 this.pdf.doc.setFontStyle("normal");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
739 let w3_2 = this.pdf.doc.getTextWidth(str3_2);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
740 this.pdf.doc.setFontStyle("italic");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
741 let w4_1 = this.pdf.doc.getTextWidth(str4_1);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
742 this.pdf.doc.setFontStyle("normal");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
743 let w4_2 = this.pdf.doc.getTextWidth(str4_2);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
744
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
745 let height = 21;
2240
c3cc21dee75d client: pdf-gen add multi-language font
Bernhard Reiter <bernhard@intevation.de>
parents: 2227
diff changeset
746 let padding = 3;
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
747 let width =
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
748 Math.max(w1_1 + w1_2, w2_1 + w2_2, w3_1 + w3_2, w4_1 + w4_2) +
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
749 2 * padding;
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
750
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
751 // x/y defaults to offset for topleft corner (normal x/y coordinates)
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
752 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
753 let y = offset.y;
1931
8fb1b1a8ea85 client: pdf-gen: improve legend behaviour
Bernhard Reiter <bernhard@intevation.de>
parents: 1928
diff changeset
754
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
755 // if position is on the right, x needs to be calculate with pdf width and
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
756 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
757 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
758 x = this.pdf.width - offset.x - width;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
759 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
760 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
761 y = this.pdf.height - offset.y - height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
762 }
2137
a31c9fa47ab8 client: pdf-gen: add bottleneck details
Bernhard Reiter <bernhard@intevation.de>
parents: 2124
diff changeset
763
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
764 // white background box
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
765 this.addRoundedBox(x, y, width, height, "white", rounding, brcolor);
2138
4a903d382901 client: pdf-gen: make bottleneck infos more fancy
Bernhard Reiter <bernhard@intevation.de>
parents: 2137
diff changeset
766
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
767 // bottleneck
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
768 this.pdf.doc.setFontStyle("italic");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
769 this.pdf.doc.text(x + padding, y + padding, str1_1, textOptions);
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
770 this.pdf.doc.setFontStyle("bold");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
771 this.pdf.doc.text(x + padding + w1_1, y + padding, str1_2, textOptions);
2137
a31c9fa47ab8 client: pdf-gen: add bottleneck details
Bernhard Reiter <bernhard@intevation.de>
parents: 2124
diff changeset
772
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
773 // survey date
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
774 this.pdf.doc.setFontStyle("italic");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
775 this.pdf.doc.text(x + padding, y + padding + 4, str2_1, textOptions);
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
776 this.pdf.doc.setFontStyle("normal");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
777 this.pdf.doc.text(
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
778 x + padding + w2_1,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
779 y + padding + 4,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
780 str2_2,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
781 textOptions
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
782 );
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
783
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
784 // ref gauge
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
785 this.pdf.doc.setFontStyle("italic");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
786 this.pdf.doc.text(x + padding, y + padding + 8, str3_1, textOptions);
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
787 this.pdf.doc.setFontStyle("normal");
2258
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
788 this.pdf.doc.text(
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
789 x + padding + w3_1,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
790 y + padding + 8,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
791 str3_2,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
792 textOptions
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
793 );
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
794
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
795 // depth relative to
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
796 this.pdf.doc.setFontStyle("italic");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
797 this.pdf.doc.text(x + padding, y + padding + 12, str4_1, textOptions);
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
798 this.pdf.doc.setFontStyle("normal");
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
799 this.pdf.doc.text(
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
800 x + padding + w4_1,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
801 y + padding + 12,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
802 str4_2,
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
803 textOptions
24cafd6b1a55 client: pdf-gen: width of bottleneck info box is calculated based on its content now
Markus Kottlaender <markus@intevation.de>
parents: 2257
diff changeset
804 );
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
805 }
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
806 }
2212
733cfc3db48a started pdf template administration
Markus Kottlaender <markus@intevation.de>
parents: 2207
diff changeset
807 },
733cfc3db48a started pdf template administration
Markus Kottlaender <markus@intevation.de>
parents: 2207
diff changeset
808 mounted() {
3227
6d4d8e7ef881 client: adjust route for pdftemplate,pdftool and add check type to uploaded templates
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3222
diff changeset
809 HTTP.get("/templates/map", {
2257
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
810 headers: {
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
811 "X-Gemma-Auth": localStorage.getItem("token"),
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
812 "Content-type": "text/xml; charset=UTF-8"
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
813 }
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
814 })
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
815 .then(response => {
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
816 if (response.data.length) {
3840
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
817 this.templates = [...this.templates, ...response.data];
387f239018c7 pdf_tool: retain default template, when custom template is uploaded
Thomas Junk <thomas.junk@intevation.de>
parents: 3802
diff changeset
818 this.form.template = this.templates[1];
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
819 this.applyTemplateToForm();
3786
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
820 } else {
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
821 this.form.template = this.templates[0];
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
822 this.templateData = this.form.template;
2265
940ae7c20326 client: pdf-gen: use default template when backend does not provide any
Markus Kottlaender <markus@intevation.de>
parents: 2260
diff changeset
823 }
2257
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
824 })
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
825 .catch(e => {
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
826 const { status, data } = e.response;
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
827 displayError({
2284
9f327f197ddd client: translation: mark some strings for translations
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2275
diff changeset
828 title: this.$gettext("Backend Error"),
2257
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
829 message: `${status}: ${data.message || data}`
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
830 });
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
831 });
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
832 }
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
833 };
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
834 </script>