Mercurial > gemma
view client/src/components/importoverview/StretchDetails.vue @ 4238:fe24cdde614d
styles-config: prepare components for WMS-Layer styling and set default color values
author | Fadi Abbud <fadi.abbud@intevation.de> |
---|---|
date | Wed, 21 Aug 2019 17:21:14 +0200 |
parents | c0f8f9ba21a7 |
children | 4d0a09ae0828 |
line wrap: on
line source
<template> <div :class="{ full: !showLogs, split: showLogs }" > <div v-if="!details.summary.stretch" class="d-flex"> <UISpinnerButton @click="showDetails = !showDetails" :state="showDetails" :icons="['angle-right', 'angle-down']" classes="text-info" /> <a @click="zoomToStretch()" class="text-info pointer" >{{ details.summary.objnam }} ( {{ details.summary.countries.join(", ") }} )</a > </div> <div> <div v-if="showDetails"> <div v-for="(entry, index) in Object.keys(details.summary)" :key="index" class="comparison row no-gutters px-4 text-left" > <span class="col-4">{{ entry }}</span> <span v-if="entry === 'countries'" class="col-4">{{ details.summary[entry].join(", ") }}</span> <span v-else class="col-4">{{ details.summary[entry] }}</span> </div> </div> </div> </div> </template> <style lang="scss" scoped> .comparison { width: 668px; border-top: dashed 1px #dee2e6; } .comparison:nth-child(odd) { background-color: #f8f9fa; } .split { max-height: 35vh; } .full { max-height: 70vh; } </style> <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, mapGetters } from "vuex"; export default { data() { return { showDetails: true }; }, props: ["entry"], mounted() { this.$store.commit("imports/hideAdditionalInfo"); }, computed: { ...mapState("imports", ["showAdditional", "showLogs", "details"]), ...mapGetters("map", ["openLayersMap"]) }, methods: { zoomToStretch() { const { name } = this.details.summary; 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( "imports/selectedStretchId", response.data.features[0].id ); this.$store.dispatch("map/moveToFeauture", { 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>