view client/src/components/App.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 a25b4988eb0c
children c69432c1c4ac
line wrap: on
line source

<template>
  <div id="app" class="main">
    <div v-if="isAuthenticated" class="d-flex flex-column userinterface">
      <div class="topbar d-flex pt-3 mx-3">
        <div class="mr-auto d-flex">
          <Sidebar :routeName="routeName"></Sidebar>
          <div :class="searchContainer">
            <Search v-if="routeName == 'mainview'"></Search>
            <Contextbox v-if="routeName == 'mainview'"></Contextbox>
          </div>
        </div>
        <div class="ml-auto d-flex">
          <div class="d-flex flex-column align-items-end">
            <Profiles v-if="routeName == 'mainview'"></Profiles>
            <Pdftool v-if="routeName == 'mainview'"></Pdftool>
          </div>
          <div class="d-flex flex-column align-items-end">
            <Identify v-if="routeName == 'mainview'"></Identify>
            <Layers v-if="routeName == 'mainview'"></Layers>
          </div>
          <Toolbar v-if="routeName == 'mainview'"></Toolbar>
        </div>
      </div>
      <div class="flex-fill"></div>
      <div class="d-flex flex-row align-items-end">
        <Infobar v-if="routeName == 'mainview'"></Infobar>
      </div>
      <Zoom v-if="routeName == 'mainview'"></Zoom>
    </div>
    <div class="d-flex flex-column"><router-view /></div>
    <vue-snotify></vue-snotify>
  </div>
</template>

<style lang="scss" scoped>
.small {
  width: $icon-width;
}
.wide {
  width: 600px;
}

.userinterface {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 4;
  pointer-events: none;
}

.topbar {
  position: relative;
  z-index: 2;
}

#app {
  height: 100%;
  width: 100%;
  font-family: "Avenir", Helvetica, Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
}
</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>
 * Markus Kottländer <markus.kottlaender@intevation.de>
 */
import { mapState } from "vuex";

export default {
  name: "app",
  computed: {
    ...mapState("user", ["isAuthenticated"]),
    ...mapState("application", ["contextBoxContent", "showSearchbar"]),
    routeName() {
      const routeName = this.$route.name;
      return routeName;
    },
    searchContainer() {
      return [
        "ml-3",
        {
          wide: this.showSearchbar
        }
      ];
    }
  },
  components: {
    Profiles: () => import("./fairway/Profiles"),
    Infobar: () => import("./fairway/Infobar"),
    Pdftool: () => import("./Pdftool"),
    Zoom: () => import("./Zoom"),
    Identify: () => import("./identify/Identify"),
    Layers: () => import("./layers/Layers"),
    Sidebar: () => import("./Sidebar"),
    Search: () => import("./Search"),
    Contextbox: () => import("./Contextbox"),
    Toolbar: () => import("./toolbar/Toolbar")
  }
};
</script>