view client/src/components/importoverview/StretchDetails.vue @ 3017:9a408a8b74b8

client: inlined some functions that were used only once
author Markus Kottlaender <markus@intevation.de>
date Thu, 11 Apr 2019 16:56:15 +0200
parents 44493664d40e
children c71373594719
line wrap: on
line source

<template>
  <div>
    <a @click="zoomToStretch()" class="text-info pointer">{{
      details.summary.stretch
    }}</a>
  </div>
</template>

<script>
/* 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>
 */
import { displayError } from "@/lib/errors";
import { mapState } from "vuex";

export default {
  name: "stretchdetails",
  props: ["entry"],
  mounted() {
    this.$store.commit("imports/hideAdditionalInfo");
  },
  computed: {
    ...mapState("imports", ["showAdditional", "details"]),
    ...mapState("map", ["openLayersMap"])
  },
  methods: {
    zoomToStretch() {
      const name = this.details.summary.stretch;
      this.openLayersMap.getLayer("STRETCHES").setVisible(true);
      this.$store
        .dispatch("imports/loadStretch", name)
        .then(response => {
          if (response.data.features.length < 1)
            throw new Error("no feaures found for: " + name);
          this.$store.commit("map/moveToExtent", {
            feature: response.data.features[0],
            zoom: 17,
            preventZoomOut: true
          });
        })
        .catch(error => {
          console.log(error);
          const { status, data } = error.response;
          displayError({
            title: this.$gettext("Backend Error"),
            message: `${status}: ${data.message || data}`
          });
        });
    }
  }
};
</script>

<style></style>