view client/src/store/application.js @ 2212:733cfc3db48a pdf-export

started pdf template administration moved templates to vuex store, to have them available in pdf box and systen configuration.
author Markus Kottlaender <markus@intevation.de>
date Wed, 06 Feb 2019 16:19:16 +0100
parents 4235fa8f59d7
children 585373d33f8f
line wrap: on
line source

/* This is Free Software under GNU Affero General Public License v >= 3.0
 * without warranty, see README.md and license for details.
 *
 * SPDX-License-Identifier: AGPL-3.0-or-later
 * License-Filename: LICENSES/AGPL-3.0.txt
 *
 * Copyright (C) 2018 by via donau
 *   – Österreichische Wasserstraßen-Gesellschaft mbH
 * Software engineering by Intevation GmbH
 *
 * Author(s):
 *   Thomas Junk <thomas.junk@intevation.de>
 *   Markus Kottländer <markus.kottlaender@intevation.de>
 *   Bernhard E. Reiter <bernhard.reiter@intevation.de>
 */

import { version } from "../../package.json";
// import { HTTP } from "../lib/http";

// initial state
const init = () => {
  return {
    appTitle: process.env.VUE_APP_TITLE,
    secondaryLogo: process.env.VUE_APP_SECONDARY_LOGO_URL,
    logoForPDF: process.env.VUE_APP_LOGO_FOR_PDF_URL,
    pdfTemplates: [],
    showSidebar: false,
    showUsermenu: false,
    showSplitscreen: false,
    showSearchbar: false,
    showSearchbarLastState: false,
    showIdentify: false,
    showLayers: true,
    showPdfTool: false,
    showContextBox: false,
    showProfiles: false,
    contextBoxContent: null, // bottlenecks, imports, staging
    expandToolbar: false,
    countries: ["AT", "SK", "HU", "HR", "RS", "BiH", "BG", "RO", "UA"],
    searchQuery: "",
    version
  };
};

export default {
  init,
  namespaced: true,
  state: init(),
  getters: {
    versionStr: state => {
      // version number from package.json
      let versionStr = "v" + state.version;

      // hg revision
      if (
        process.env.VUE_APP_HGREV &&
        (state.version.includes("dev") ||
          state.version.includes("beta") ||
          state.version.includes("alpha"))
      )
        // a '+' according to semver 2.0.0 starts a build meta info section
        // which shall only have [0-9A-Za-z-] chars
        // and is to be ignored when determining the order
        versionStr += "+" + process.env.VUE_APP_HGREV;

      return versionStr;
    }
  },
  mutations: {
    showSidebar: (state, show) => {
      state.showSidebar = show;
    },
    showSplitscreen: (state, show) => {
      state.showSplitscreen = show;
    },
    showUsermenu: (state, show) => {
      state.showUsermenu = show;
    },
    showSearchbar: (state, show) => {
      state.showSearchbar = show;
    },
    showIdentify: (state, show) => {
      state.showIdentify = show;
    },
    showLayers: (state, show) => {
      state.showLayers = show;
    },
    showPdfTool: (state, show) => {
      state.showPdfTool = show;
    },
    showContextBox: (state, show) => {
      state.showContextBox = show;
    },
    showProfiles: (state, show) => {
      state.showProfiles = show;
    },
    contextBoxContent: (state, context) => {
      state.contextBoxContent = context;
      if (context) {
        state.showSearchbarLastState = state.showSearchbar;
      }
    },
    expandToolbar: (state, expandToolbar) => {
      state.expandToolbar = expandToolbar;
    },
    searchQuery: (state, searchQuery) => {
      state.searchQuery = searchQuery;
    },
    pdfTemplates: (state, pdfTemplates) => {
      state.pdfTemplates = pdfTemplates;
    }
  },
  actions: {
    loadPdfTemplates({ commit }) {
      return new Promise(resolve => {
        // pretend we do something async
        setTimeout(function() {
          commit("pdfTemplates", [
            {
              name: "Default",
              properties: {
                format: "landscape",
                resolution: "80",
                paperSize: "a4"
              },
              elements: [
                {
                  type: "docinfo",
                  x_coordinate: 0,
                  y_coordinate: 0,
                  elementWidth: 118,
                  elementHeight: 8,
                  textSize: 9
                },
                {
                  type: "image",
                  imageType: "PNG",
                  imageUrl: "",
                  x_coordinate: 30,
                  y_coordinate: 297,
                  imageWidth: 50,
                  imageHeight: 23
                },
                {
                  type: "scalebar",
                  x_coordinate: 226.5,
                  y_coordinate: 204
                  //elementsize: 50
                },
                {
                  type: "textbox",
                  x_coordinate: 50,
                  y_coordinate: 190,
                  elementSize: 8,
                  text: "textfrom template",
                  color: "black"
                },
                {
                  type: "aboutbox"
                  //x_coordinate: 0,
                  //y_coordinate: 210 - 20
                }
              ]
            },
            {
              name: "DE Querformat, groß",
              properties: {
                format: "landscape",
                resolution: "120",
                paperSize: "a3"
              },
              elements: [
                {
                  type: "docinfo",
                  x_coordinate: 0,
                  y_coordinate: 0,
                  elementWidth: 118,
                  elementHeight: 8,
                  textSize: 9
                },
                {
                  type: "image",
                  imageType: "PNG",
                  imageUrl: "",
                  x_coordinate: 30,
                  y_coordinate: 297,
                  imageWidth: 50,
                  imageHeight: 23
                },
                {
                  type: "scalebar",
                  x_coordinate: 247.3,
                  y_coordinate: 414
                  //elementsize: 50
                },
                {
                  type: "textbox",
                  x_coordinate: 50,
                  y_coordinate: 50,
                  elementSize: 22,
                  text: "from template",
                  color: "black"
                },
                {
                  type: "aboutbox"
                  //x_coordinate: 0,
                  //y_coordinate: 210 - 20
                }
              ]
            }
          ]);
          resolve();
        }, 500);
      });
    }
  }
};