Mercurial > gemma
view client/src/components/App.vue @ 2704:84145179ec72
import_overview: open logs and details in parallel
author | Thomas Junk <thomas.junk@intevation.de> |
---|---|
date | Mon, 18 Mar 2019 15:56:54 +0100 |
parents | 8774054959a7 |
children | eb3d7a429eb0 |
line wrap: on
line source
<template> <div id="app" class="main"> <div v-if="isAuthenticated" class="d-flex flex-column userinterface"> <div class="d-flex p-2"> <div class="mr-auto d-flex"> <Sidebar :routeName="routeName" /> <div :class="searchContainer"> <Search v-if="isMapVisible" /> <Contextbox v-if="isMapVisible" /> </div> </div> <div class="ml-auto d-flex"> <div class="d-flex flex-column align-items-end"> <Profiles v-if="isMapVisible" /> <Gauges v-if="isMapVisible" /> <Pdftool v-if="isMapVisible" /> </div> <div class="d-flex flex-column align-items-end"> <Identify v-if="isMapVisible" /> <Layers v-if="isMapVisible" /> </div> <Toolbar v-if="isMapVisible" /> </div> </div> <Zoom v-if="isMapVisible" /> <Splitscreen v-if="isMapVisible" /> <MinimizedSplitscreens v-if="isMapVisible" /> </div> <router-view /> <vue-snotify /> <Popup /> </div> </template> <style lang="scss" scoped> .userinterface { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 4; pointer-events: none; } #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"]), isMapVisible() { return /importoverview|stretches|review|bottlenecks|mainview/.test( this.routeName ); }, routeName() { const routeName = this.$route.name; return routeName; }, searchContainer() { return [ "ml-2", { wide: this.showSearchbar } ]; } }, components: { Profiles: () => import("./fairway/Profiles"), Gauges: () => import("./gauge/Gauges"), 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"), Popup: () => import("./Popup"), Splitscreen: () => import("./splitscreen/Splitscreen"), MinimizedSplitscreens: () => import("./splitscreen/MinimizedSplitscreens") } }; </script>