view client/src/components/toolbar/Polygontool.vue @ 2355:31a1dcdba068

client: fix draw line/polygon and use name constants * the drawn line/polygon will disapear from the map when the user click on the relative icon. its a defect in the orginal code * use name constants instead of strings for the call of Layers
author Fadi Abbud <fadi.abbud@intevation.de>
date Wed, 20 Feb 2019 13:23:30 +0100
parents 0ded4c56978e
children 2097c3633f0a
line wrap: on
line source

<template>
  <div @click="togglePolygonTool" class="toolbar-button">
    <font-awesome-icon
      icon="draw-polygon"
      :class="{ 'text-info': polygonTool && polygonTool.getActive() }"
    ></font-awesome-icon>
  </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";
import { LAYERS } from "@/store/map.js";

export default {
  name: "polygontool",
  computed: {
    ...mapGetters("map", ["getVSourceByName"]),
    ...mapState("map", ["lineTool", "polygonTool", "cutTool"])
  },
  methods: {
    togglePolygonTool() {
      this.polygonTool.setActive(!this.polygonTool.getActive());
      this.lineTool.setActive(false);
      this.cutTool.setActive(false);
      this.$store.commit("map/setCurrentMeasurement", null);
      this.getVSourceByName(LAYERS.DRAWTOOL).clear();
    }
  }
};
</script>