view client/src/components/toolbar/Identify.vue @ 2370:7fe2f5d334dc

client: improved identify tool readability There's now a formatter.js which can be used to format labels and values or to remove information that is not needed.
author Markus Kottlaender <markus@intevation.de>
date Thu, 21 Feb 2019 14:57:04 +0100
parents 0ded4c56978e
children 2097c3633f0a
line wrap: on
line source

<template>
  <div
    @click="$store.commit('application/showIdentify', !showIdentify)"
    class="toolbar-button"
  >
    <font-awesome-icon
      icon="info"
      :class="{ 'text-info': showIdentify }"
    ></font-awesome-icon>
    <span
      :class="[
        'indicator',
        {
          show:
            !showIdentify &&
            (filteredIdentifiedFeatures.length || currentMeasurement)
        }
      ]"
    >
      {{ badgeCount }}
    </span>
  </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):
 * Markus Kottländer <markus.kottlaender@intevation.de>
 */
import { mapState, mapGetters } from "vuex";

export default {
  name: "identify",
  computed: {
    ...mapState("application", ["showIdentify"]),
    ...mapState("map", ["currentMeasurement"]),
    ...mapGetters("map", ["filteredIdentifiedFeatures"]),
    badgeCount() {
      return this.filteredIdentifiedFeatures.length + !!this.currentMeasurement;
    }
  }
};
</script>