Mercurial > gemma
view client/src/components/Sidebar.vue @ 5721:0500d76e074b uploadwg
Fixed eraseObsoleteGaugesSQL by reintroducing matching on users CC.
The condition was removed when introducing file upload, but that leads
to too many gauges being removed.
author | Sascha Wilde <wilde@sha-bang.de> |
---|---|
date | Fri, 19 Apr 2024 16:52:14 +0200 |
parents | 84d01a536bec |
children |
line wrap: on
line source
<template> <div class="position-relative"> <span class="indicator" v-if="!showSidebar && stagingNotifications"> {{ stagingNotifications }} </span> <div :class="sidebarStyle"> <div @click="$store.commit('application/showSidebar', !showSidebar)" class="menubutton ui-element d-print-none p-2 bg-white rounded position-absolute d-flex justify-content-center" > <font-awesome-icon class="fa-fw" icon="bars" /> </div> <div class="menu text-nowrap text-left"> <router-link to="/"> <font-awesome-icon class="mr-2" fixed-width icon="map-marked-alt" /> <span class="fix-trans-space" v-translate>Map</span> </router-link> <router-link to="/bottlenecks"> <font-awesome-icon class="mr-2" fixed-width icon="ship" /> <span class="fix-trans-space" v-translate>Bottlenecks</span> </router-link> <div v-if="isWaterwayAdmin"> <router-link to="/imports/overview" class="position-relative"> <font-awesome-icon class="mr-2" fixed-width icon="clipboard-check" /> <span class="fix-trans-space" v-translate>Import review</span> <span class="indicator" v-if="showSidebar && stagingNotifications"> {{ stagingNotifications }} </span> </router-link> <router-link to="/imports/configuration"> <font-awesome-icon class="mr-2" fixed-width icon="clock" /> <translate class="fix-trans-space">Imports</translate> </router-link> </div> <div v-if="isSysAdmin"> <router-link to="/stretches"> <font-awesome-icon class="mr-2" fixed-width icon="road" /> <span class="fix-trans-space" v-translate>Define stretches</span> </router-link> </div> <div v-if="isWaterwayAdmin"> <router-link to="/sections"> <font-awesome-icon class="mr-2" fixed-width icon="road" /> <span class="fix-trans-space" v-translate>Define sections</span> </router-link> </div> <small class="text-muted pl-2 pb-1 d-block border-bottom" v-if="isSysAdmin" > <translate>Systemadministration</translate> </small> <div v-if="isSysAdmin"> <router-link to="/usermanagement"> <font-awesome-icon class="mr-2" fixed-width icon="users-cog" /> <span class="fix-trans-space" v-translate>Users</span> </router-link> </div> <div v-if="isWaterwayAdmin"> <router-link to="/systemconfiguration"> <font-awesome-icon class="mr-2" fixed-width icon="wrench" /> <span class="fix-trans-space" v-translate>Configuration</span> </router-link> </div> <div v-if="isSysAdmin"> <router-link to="/logs"> <font-awesome-icon class="mr-2" fixed-width icon="book" /> <span class="fix-trans-space" v-translate>Logs</span> </router-link> </div> <hr class="m-0" /> <a @click="logoff" href="#" class="logout"> <font-awesome-icon class="mr-2" fixed-width icon="power-off" /> <span class="fix-trans-space" v-translate>Logout</span> {{ user }} </a> </div> </div> </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): * Thomas Junk <thomas.junk@intevation.de> * Markus Kottländer <markus.kottlaender@intevation.de> */ import { mapGetters, mapState } from "vuex"; import { logOff } from "@/lib/session"; import { displayError } from "@/lib/errors"; export default { name: "sidebar", data() { return { notificationTimer: null }; }, computed: { ...mapGetters("user", ["isSysAdmin", "isWaterwayAdmin"]), ...mapState("user", ["user", "roles", "isAuthenticated"]), ...mapState("imports", ["stagingNotifications"]), ...mapState("application", [ "showSidebar", "showSearchbarLastState", "contextBoxContent", "showContextBox" ]), sidebarStyle() { return [ "ui-element position-relative sidebar rounded shadow-xs d-print-none mb-auto", { sidebarcollapsed: !this.showSidebar, sidebarextended: this.showSidebar } ]; } }, methods: { logoff() { logOff(); }, toggleContextBox(context) { if (this.$route.path !== "/") this.$router.push("/"); this.$store.commit("application/searchQuery", ""); this.$store.commit("application/showContextBox", true); this.$store.commit("application/contextBoxContent", context); this.$store.commit("application/showSearchbar", true); }, isActive(item) { return ( this.showContextBox && this.contextBoxContent === item && this.$route.name == "mainview" ); } }, mounted() { this.$store.dispatch("importschedule/loadAvailableReports").catch(error => { let message = "Backend not reachable"; if (error.response) { const { status, data } = error.response; message = `${status}: ${data.message || data}`; } displayError({ title: this.$gettext("Backend Error"), message: message }); }); const updateIndicators = () => { if (this.isWaterwayAdmin) { this.$store .dispatch("imports/loadStagingNotifications") .then(() => { if (this.isAuthenticated) { this.notificationTimer = setTimeout(updateIndicators, 15000); } }) .catch(error => { let message = "Backend not reachable"; if (error.response) { const { status, data } = error.response; message = `${status}: ${data.message || data}`; } displayError({ title: this.$gettext("Backend Error"), message: message }); }); } }; updateIndicators(); }, destroyed() { clearTimeout(this.notificationTimer); } }; </script> <style scoped> .menubutton { height: 2rem; width: 2rem; top: 0; left: 0; color: #666; } .indicator { font-size: 11px; line-height: 11px; padding: 2px 4px 1px; position: absolute; top: 18px; left: 0px; z-index: 10; color: #fff; background: #17a2b8; border-top-right-radius: 0.25rem; border-bottom-left-radius: 0.25rem; } .menu a { display: block; text-align: left; padding: 0.25rem 0.5rem; color: #333; text-decoration: none; font-size: 90%; } .menu a .indicator { left: auto; right: 10px; top: 8px; border-radius: 0.25rem; } .menu a.router-link-exact-active .indicator { background: #fff; color: #333; } .menu a svg path { fill: #666; } .menu a:hover { background-color: #f8f8f8; } .menu a.router-link-exact-active { background-color: #17a2b8; color: #fff; } .menu a.router-link-exact-active svg path { fill: #fff; } .menu a.secondary.active { background: #ebfafd; color: #0f6674; } .menu a.secondary.active svg path { fill: #0f6674; } .sidebar { background-color: #ffffff; padding-top: var(--large-offset); opacity: var(--slight-transparent); transition: var(--transition-fast); overflow: hidden; } .sidebarcollapsed { max-height: var(--icon-height); max-width: var(--icon-width); } .sidebarextended { max-width: var(--sidebar-width); min-width: var(--sidebar-width); } </style>