annotate client/src/components/Pdftool.vue @ 4454:69166db6ba8a

console.log removed
author Thomas Junk <thomas.junk@intevation.de>
date Mon, 23 Sep 2019 09:19:03 +0200
parents c0bfe7283384
children 3543af71d04c
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 if (this.form.format !== "portrait") {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
266 this.pdf.width = paperSizes[this.form.paperSize][0];
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
267 this.pdf.height = paperSizes[this.form.paperSize][1];
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
268 } else {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
269 this.pdf.width = paperSizes[this.form.paperSize][1];
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
270 this.pdf.height = paperSizes[this.form.paperSize][0];
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
271 }
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
272
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
273 // FUTURE: consider margins
1635
ca48145dba9c client: improve pdf generation
Bernhard Reiter <bernhard@intevation.de>
parents: 1613
diff changeset
274
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
275 var pixelsPerMapMillimeter = this.form.resolution / 25.4;
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
276 var mapSizeForPrint = [
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
277 Math.round(this.pdf.width * pixelsPerMapMillimeter),
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
278 Math.round(this.pdf.height * pixelsPerMapMillimeter)
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
279 ];
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
280 var map = this.openLayersMap();
3981
8ec8d9bc5468 document algorithm
Thomas Junk <thomas.junk@intevation.de>
parents: 3980
diff changeset
281 this.mapSize = map.getSize();
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
282 this.resolution = map.getView().getResolution();
1883
76a6d334e681 Client: pdf-gen: refactor addScaleBar
Bernhard Reiter <bernhard@intevation.de>
parents: 1882
diff changeset
283
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
284 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
285 this.rendercompleteListener = map.once("rendercomplete", event => {
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
286 let canvas = event.context.canvas;
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
287 let scaleDenominator = Math.round(
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
288 1000 *
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
289 pixelsPerMapMillimeter *
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
290 this.getMeterPerPixel(
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
291 this.openLayersMap()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
292 .getView()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
293 .getResolution()
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
294 )
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
295 );
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
296 var snapshot = canvas.toDataURL("image/jpeg");
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
297 this.pdf.doc.addImage(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
298 snapshot,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
299 "JPEG",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
300 0,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
301 0,
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
302 this.pdf.width,
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
303 this.pdf.height
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
304 );
1903
7247ac316cb7 client: pdf-gen: improve layout and ui
Bernhard Reiter <bernhard@intevation.de>
parents: 1897
diff changeset
305
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
306 if (this.templateData) {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
307 this.pdf.doc.setFont("linbiolinum", "normal");
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
308 let defaultFontSize = 11,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
309 defaultRounding = 2,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
310 defaultTextColor = "black",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
311 defaultBgColor = "white",
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
312 defaultPadding = 3,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
313 defaultOffset = { x: 0, y: 0 },
3993
6672b780722f client: pdf-gen: improve addtext for pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3981
diff changeset
314 defaultBorderColor = "white";
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
315 this.templateData.elements.forEach(e => {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
316 switch (e.type) {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
317 case "text": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
318 this.addText(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
319 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
320 e.offset || defaultOffset,
3993
6672b780722f client: pdf-gen: improve addtext for pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3981
diff changeset
321 e.width,
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
322 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
323 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
324 e.text
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
325 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
326 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
327 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
328 case "box": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
329 this.addBox(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
330 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
331 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
332 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
333 e.height,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
334 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
335 e.color || defaultBgColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
336 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
337 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
338 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
339 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
340 case "textbox": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
341 this.addTextBox(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
342 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
343 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
344 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
345 e.height,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
346 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
347 e.padding || defaultPadding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
348 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
349 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
350 e.background || defaultBgColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
351 e.text,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
352 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
353 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
354 break;
2223
85142493096c PDF generation: improved positioning, prepared demo templates
Markus Kottlaender <markus@intevation.de>
parents: 2222
diff changeset
355 }
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
356 case "image": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
357 this.addImage(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
358 e.url,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
359 e.format,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
360 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
361 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
362 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
363 e.height
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
364 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
365 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
366 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
367 case "bottleneck": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
368 this.addBottleneckInfo(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
369 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
370 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
371 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
372 e.color || defaultTextColor,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
373 e.brcolor || defaultBorderColor
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 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
376 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
377 case "legend": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
378 this.addLegend(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
379 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
380 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
381 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
382 e.brcolor || defaultBorderColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
383 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
384 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
385 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
386 case "scalebar": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
387 this.addScaleBar(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
388 scaleDenominator,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
389 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
390 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
391 e.rounding === 0 || e.rounding ? e.rounding : defaultRounding,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
392 e.brcolor || defaultBorderColor
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 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
395 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
396 case "scale": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
397 this.addScale(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
398 scaleDenominator,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
399 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
400 e.width,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
401 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
402 e.fontSize || defaultFontSize,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
403 e.color || defaultTextColor
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
404 );
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
405 break;
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
406 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
407 case "northarrow": {
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
408 this.addNorthArrow(
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
409 e.position,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
410 e.offset || defaultOffset,
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
411 e.size
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 }
2205
59c21dee6315 pdf-gen: improve pdftool to use value from template
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2124
diff changeset
416 });
1928
76ca071cb006 client: pdf-gen: add legend graphic
Bernhard Reiter <bernhard@intevation.de>
parents: 1914
diff changeset
417
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
418 this.pdf.doc.save(this.filename);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
419 }
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
420 map.setSize(this.mapSize);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
421 map.getView().setResolution(this.resolution);
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
422 this.readyToGenerate = true;
1874
bad32adafef2 client: add real pdf generation with jspdf
Bernhard Reiter <bernhard@intevation.de>
parents: 1635
diff changeset
423 });
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
424
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
425 const size = map.getSize();
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
426 const [width, height] = mapSizeForPrint;
2227
9b545e470b94 PDF generation: logo image, adjusted templates
Markus Kottlaender <markus@intevation.de>
parents: 2226
diff changeset
427 map.setSize(mapSizeForPrint);
3980
7316b7e8246f improve PDFTool
Thomas Junk <thomas.junk@intevation.de>
parents: 3960
diff changeset
428 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
429 map
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
430 .getView()
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
431 .setResolution(
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
432 this.form.scale
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
433 ? this.getResolutionFromScale()
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
434 : this.resolution / scaling
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
435 );
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
436 },
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
437 getResolutionFromScale() {
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
438 const scaling = Math.round(this.form.scale / 1000);
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
439 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
440 },
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
441 getMeterPerPixel(f) {
4034
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
442 var map = this.openLayersMap();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
443 let view = map.getView();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
444 let proj = view.getProjection();
917c72e8360d client: pdf-gen: implement basic print scaling
Fadi Abbud <fadi.abbud@intevation.de>
parents: 3993
diff changeset
445 return (
4077
d34e9b8ad396 fix scaling issues
Thomas Junk <thomas.junk@intevation.de>
parents: 4034
diff changeset
446 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
447 );
2275
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
448 },
a6cfa06c5983 client: pdf-gen: added cancel button
Markus Kottlaender <markus@intevation.de>
parents: 2265
diff changeset
449 cancel() {
4416
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
450 try {
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
451 this.openLayersMap().un(
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
452 this.rendercompleteListener.type,
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
453 this.rendercompleteListener.listener
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
454 );
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
455 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
456 this.openLayersMap()
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
457 .getView()
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
458 .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
459 } finally {
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
460 this.readyToGenerate = true;
5b2023c2c41e pdftool: independent if cancel crashes, the cancel button should vanish
Thomas Junk <thomas.junk@intevation.de>
parents: 4088
diff changeset
461 }
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
462 },
2737
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
463 // add the used map scale and papersize
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
464 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
465 //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
466 let str =
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
467 this.$gettext("Scale") +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
468 " 1 : " +
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
469 scaleDenominator +
2737
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
470 " " +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
471 "(DIN" +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
472 " " +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
473 this.form.paperSize.toUpperCase() +
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
474 ")";
4a5c0e7cb75b client:pdf-gen: add template element
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2714
diff changeset
475 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
476 },
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
477 addScaleBar(scaleDenominator, position, offset, rounding, brcolor) {
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
478 // 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
479
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
480 // hardcode maximal width for now
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
481 let maxWidth = 80; // in mm
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
482
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
483 // 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
484 // strategy:
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
485 // 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
486 // 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
487 // 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
488 // 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
489
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
490 // 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
491 let log10 =
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
492 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
493 function(x) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
494 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
495 };
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
496
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
497 let maxLength = maxWidth * scaleDenominator;
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
498
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
499 let unit = "mm";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
500 let unitConversionFactor = 1;
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
501 if (maxLength >= 1e7) {
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
502 // >= 10 km
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
503 unit = "km";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
504 unitConversionFactor = 1e6;
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
505 } else if (maxLength >= 1e4) {
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
506 // >= 10 m
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
507 unit = "m";
1914
3d2b55d2d8a6 client: pdf-gen: fix scale bar calculation
Bernhard Reiter <bernhard@intevation.de>
parents: 1903
diff changeset
508 unitConversionFactor = 1e3;
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
509 }
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
510
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
511 maxLength /= unitConversionFactor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
512
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
513 let unroundedLength = maxLength;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
514 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
515 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
516 let mapped = unroundedLength / factor;
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 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
519
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
520 // 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
521 // 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
522 if (mapped > 8) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
523 length = 8 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
524 } else if (mapped > 4) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
525 length = 4 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
526 } else if (mapped > 2) {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
527 length = 2 * factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
528 } else {
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
529 length = factor;
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
530 }
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
531
2767
3063f1485ad6 client:fix typo
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2754
diff changeset
532 let size = (length * unitConversionFactor) / scaleDenominator / 4;
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
533 let fullSize = size * 4;
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
534
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
535 // 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
536 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
537 let y = offset.y;
1933
1aa2921d8832 client: pdf-gen: make scalebar box size dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1931
diff changeset
538
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
539 // 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
540 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
541 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
542 x = this.pdf.width - offset.x - fullSize - 8;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
543 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
544 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
545 y = this.pdf.height - offset.y - 10;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
546 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
547
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
548 // to give the outer white box 4mm padding
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
549 let scaleBarX = x + 4;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
550 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
551
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
552 // draw outer white box
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
553 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
554
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
555 // draw first part of scalebar
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
556 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
557 this.pdf.doc.setFillColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
558 this.pdf.doc.rect(scaleBarX, scaleBarY, size, 1, "FD");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
559
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
560 // draw second part of scalebar
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
561 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
562 this.pdf.doc.setFillColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
563 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
564
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
565 // draw third 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 + size * 2, scaleBarY, size * 2, 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 numeric labels above scalebar
2223
85142493096c PDF generation: improved positioning, prepared demo templates
Markus Kottlaender <markus@intevation.de>
parents: 2222
diff changeset
571 this.pdf.doc.setTextColor("black");
2240
c3cc21dee75d client: pdf-gen add multi-language font
Bernhard Reiter <bernhard@intevation.de>
parents: 2227
diff changeset
572 this.pdf.doc.setFontSize(6);
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
573 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
574 // /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
575 this.pdf.doc.text(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
576 scaleBarX + size - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
577 scaleBarY - 1,
1897
c78efb1ddb02 client: pdf-gen: improve scalebar to show nice values
Bernhard Reiter <bernhard@intevation.de>
parents: 1887
diff changeset
578 (Math.round((length * 10) / 4) / 10).toString()
1884
59ef76d83de7 client: pdf-gen: make scalebar dynamic
Bernhard Reiter <bernhard@intevation.de>
parents: 1883
diff changeset
579 );
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
580 this.pdf.doc.text(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
581 scaleBarX + size * 2 - 2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
582 scaleBarY - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
583 Math.round(length / 2).toString()
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
584 );
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 * 4 - 4,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
587 scaleBarY - 1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
588 Math.round(length).toString() + " " + unit
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
589 );
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
590 },
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
591 addNorthArrow(position, offset, size) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
592 // TODO: fix positioning
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
593 // 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
594 let x1 = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
595 let y1 = offset.y;
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
596
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
597 // 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
598 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
599 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
600 x1 = this.pdf.width - offset.x - size;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
601 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
602 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
603 y1 = this.pdf.height - offset.y - size;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
604 }
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
605
1876
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
606 var y2 = y1 + size * 3;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
607 var x3 = x1 - size * 2;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
608 var y3 = y1 + size * 5;
e53924abb4a2 client: export some elements to pdf
Fadi Abbud <fadi.abbud@intevation.de>
parents: 1874
diff changeset
609 var x4 = x1 + size * 2;
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
610 // white triangle
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
611 this.pdf.doc.setFillColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
612 this.pdf.doc.setDrawColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
613 this.pdf.doc.triangle(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
614 x3 - 0.8,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
615 y3 + 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
616 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
617 y1 - 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
618 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
619 y2 + 0.6,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
620 "F"
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
621 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
622 this.pdf.doc.triangle(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
623 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
624 y1 - 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
625 x1,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
626 y2 + 0.6,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
627 x4 + 0.8,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
628 y3 + 1.2,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
629 "F"
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
630 );
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 // north arrow
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
633 this.pdf.doc.setDrawColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
634 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
635 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
636 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
637 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
638 this.pdf.doc.setFontSize(size * 3.1);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
639 this.pdf.doc.setTextColor(255, 255, 255);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
640 this.pdf.doc.setFontStyle("bold");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
641 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
642 this.pdf.doc.setFontSize(size * 3);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
643 this.pdf.doc.setTextColor(0, 0, 0);
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
644 this.pdf.doc.setFontStyle("normal");
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
645 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
646 },
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
647 addLegend(position, offset, rounding, brcolor) {
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
648 if (
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
649 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
650 this.selectedSurvey &&
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
651 this.openLayersMap()
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
652 .getLayer("BOTTLENECKISOLINE")
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
653 .getVisible()
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
654 ) {
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
655 // transforming into an HTMLImageElement only to find out
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
656 // the width x height of the legend image
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
657 // 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
658 let legendImage = new Image();
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
659 legendImage.src = this.isolinesLegendImgDataURL;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
660 let aspectRatio = legendImage.width / legendImage.height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
661 let width = 54;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
662 let height = width / aspectRatio;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
663 let padding = 2;
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 // 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
666 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
667 let y = offset.y;
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
668
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
669 // 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
670 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
671 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
672 x = this.pdf.width - offset.x - width;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
673 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
674 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
675 y = this.pdf.height - offset.y - height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
676 }
1947
4235fa8f59d7 clien: pdf-gen: load logo externally; add prepare step
Bernhard Reiter <bernhard@intevation.de>
parents: 1936
diff changeset
677
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
678 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
679 this.pdf.doc.addImage(
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
680 legendImage,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
681 x + padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
682 y + padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
683 width - 2 * padding,
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
684 height - 2 * padding
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
685 );
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
686 }
1931
8fb1b1a8ea85 client: pdf-gen: improve legend behaviour
Bernhard Reiter <bernhard@intevation.de>
parents: 1928
diff changeset
687 },
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
688 addBottleneckInfo(position, offset, rounding, color, brcolor) {
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
689 if (
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
690 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
691 this.selectedSurvey &&
3127
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
692 this.openLayersMap()
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
693 .getLayer("BOTTLENECKISOLINE")
0374197c384f client: fix openLayersMap getter calls
Markus Kottlaender <markus@intevation.de>
parents: 3044
diff changeset
694 .getVisible()
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
695 ) {
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
696 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
697
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
698 // 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
699 // 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
700 // 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
701 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
702 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
703 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
704 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
705 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
706 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
707 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
708 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
709 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
710 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
711 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
712 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
713 " = " +
2291
60af456d01f0 client:pdf-gen:(minor) fix bottleneckinfo function
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2288
diff changeset
714 (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
715 ? survey.waterlevel_value + " cm"
2291
60af456d01f0 client:pdf-gen:(minor) fix bottleneckinfo function
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2288
diff changeset
716 : "?");
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
717
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 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
719 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
720 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
721 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
722 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
723 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
724 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
725 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
726 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
727 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
728 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
729 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
730 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
731 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
732 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
733 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
734
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 height = 21;
2240
c3cc21dee75d client: pdf-gen add multi-language font
Bernhard Reiter <bernhard@intevation.de>
parents: 2227
diff changeset
736 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
737 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
738 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
739 2 * padding;
2220
d926292d81b6 PDF generation: changed form labels/option texts
Markus Kottlaender <markus@intevation.de>
parents: 2219
diff changeset
740
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
741 // 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
742 let x = offset.x;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
743 let y = offset.y;
1931
8fb1b1a8ea85 client: pdf-gen: improve legend behaviour
Bernhard Reiter <bernhard@intevation.de>
parents: 1928
diff changeset
744
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
745 // 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
746 // the size of the element
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
747 if (["topright", "bottomright"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
748 x = this.pdf.width - offset.x - width;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
749 }
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
750 if (["bottomright", "bottomleft"].indexOf(position) !== -1) {
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
751 y = this.pdf.height - offset.y - height;
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
752 }
2137
a31c9fa47ab8 client: pdf-gen: add bottleneck details
Bernhard Reiter <bernhard@intevation.de>
parents: 2124
diff changeset
753
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
754 // white background box
2714
4dd38840d74b client:pdf-gen:imporve some template elements
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2561
diff changeset
755 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
756
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
757 // bottleneck
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
758 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
759 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
760 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
761 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
762
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
763 // survey date
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
764 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
765 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
766 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
767 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
768 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
769 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
770 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
771 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
772 );
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
773
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
774 // ref gauge
2247
e6fba449aa3c merged pdf-export in default
Markus Kottlaender <markus@intevation.de>
parents: 2240
diff changeset
775 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
776 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
777 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
778 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
779 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
780 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
781 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
782 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
783 );
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
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
785 // 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
786 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
787 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
788 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
789 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
790 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
791 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
792 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
793 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
794 );
2218
631ca0412db9 adjusted positioning of pdf elements
Markus Kottlaender <markus@intevation.de>
parents: 2215
diff changeset
795 }
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
796 }
2212
733cfc3db48a started pdf template administration
Markus Kottlaender <markus@intevation.de>
parents: 2207
diff changeset
797 },
733cfc3db48a started pdf template administration
Markus Kottlaender <markus@intevation.de>
parents: 2207
diff changeset
798 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
799 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
800 headers: {
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
801 "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
802 "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
803 }
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
804 })
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
805 .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
806 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
807 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
808 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
809 this.applyTemplateToForm();
3786
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
810 } else {
a2da2328bb86 PDFTool: prefetch images of template and convert to dataURI
Thomas Junk <thomas.junk@intevation.de>
parents: 3781
diff changeset
811 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
812 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
813 }
2257
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 .catch(e => {
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
816 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
817 displayError({
2284
9f327f197ddd client: translation: mark some strings for translations
Fadi Abbud <fadi.abbud@intevation.de>
parents: 2275
diff changeset
818 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
819 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
820 });
ce6fd3d4a3a2 client: pdf-gen: moved template handling from store to components
Markus Kottlaender <markus@intevation.de>
parents: 2247
diff changeset
821 });
1272
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
822 }
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
823 };
bc55ffaeb639 cleaned up client/src directory
Markus Kottlaender <markus@intevation.de>
parents:
diff changeset
824 </script>