added a lot of translations and fixed profile and navbar
This commit is contained in:
81
src/App.vue
81
src/App.vue
@@ -6,36 +6,53 @@
|
||||
</b-alert>
|
||||
|
||||
<div id="nav">
|
||||
<router-link to="/">Home</router-link>
|
||||
|
|
||||
<router-link to="/about">About</router-link>
|
||||
|
|
||||
<router-link to="/login">Login</router-link>
|
||||
|
|
||||
<router-link to="/profile">Profile</router-link>
|
||||
|
|
||||
<router-link :to="{ name: 'rooms' }">{{ $t('rooms') }}</router-link>
|
||||
|
|
||||
<router-link :to="{ name: 'recorders' }">{{ $t('recorders') }}</router-link>
|
||||
|
|
||||
<router-link :to="{ name: 'commands' }">{{ $t('commands') }}</router-link>
|
||||
|
|
||||
<!-- Example split danger button -->
|
||||
<div class="btn-group">
|
||||
<button type="button" onclick="location.href='/admin'" class="btn btn-danger">Admin</button>
|
||||
<button type="button" class="btn btn-danger dropdown-toggle dropdown-toggle-split"
|
||||
data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
|
||||
<span class="sr-only">Toggle Dropdown</span>
|
||||
</button>
|
||||
<div class="dropdown-menu">
|
||||
<router-link class="dropdown-item" :to="{ name: 'admin.user' }">{{ $t('user') }}</router-link>
|
||||
<router-link class="dropdown-item" :to="{ name: 'admin.group' }">{{ $t('group') }}</router-link>
|
||||
<a class="dropdown-item" href="#">Something else here</a>
|
||||
<div class="dropdown-divider"></div>
|
||||
<a class="dropdown-item" href="#">Separated link</a>
|
||||
</div>
|
||||
</div>
|
||||
|
|
||||
<b-navbar toggleable="lg" type="dark" variant="info">
|
||||
<b-navbar-brand to="/">
|
||||
<img src="https://placekitten.com/g/30/30" class="d-inline-block align-top" alt="Kitten">
|
||||
LRC - <strong>L</strong>ecture <strong>R</strong>ecord <strong>C</strong>ontrol
|
||||
</b-navbar-brand>
|
||||
|
||||
<b-navbar-toggle target="nav-collapse"></b-navbar-toggle>
|
||||
|
||||
<b-collapse id="nav-collapse" is-nav>
|
||||
<b-navbar-nav>
|
||||
<b-nav-item to="/about">About</b-nav-item>
|
||||
<b-nav-item to="/login" >Login</b-nav-item>
|
||||
|
||||
<b-nav-item :to="{name: 'rooms'}">{{ $t('Rooms') }}</b-nav-item>
|
||||
<b-nav-item :to="{name: 'recorders'}">{{ $t('Recorders') }}</b-nav-item>
|
||||
<b-nav-item :to="{name: 'commands'}">{{ $t('Commands') }}</b-nav-item>
|
||||
</b-navbar-nav>
|
||||
|
||||
<!-- Right aligned nav items -->
|
||||
<b-navbar-nav class="ml-auto">
|
||||
<b-nav-form>
|
||||
<b-form-input size="sm" class="mr-sm-2" placeholder="Search"></b-form-input>
|
||||
<b-button size="sm" class="my-2 my-sm-0" type="submit">Search</b-button>
|
||||
</b-nav-form>
|
||||
|
||||
<b-nav-item-dropdown split split-to="admin" variant="outline-danger" :text="$t('admin')">
|
||||
<b-dropdown-item to="user">{{ $t('user') }}</b-dropdown-item>
|
||||
<b-dropdown-item to="group">{{ $t('group') }}</b-dropdown-item>
|
||||
<b-dropdown-item href="#">Something else here...</b-dropdown-item>
|
||||
</b-nav-item-dropdown>
|
||||
|
||||
<b-nav-item-dropdown text="Lang" right>
|
||||
<b-dropdown-item v-for="(lang, i) in langs"
|
||||
v-bind:key="lang"
|
||||
@click="$i18n.locale=lang">{{ lang }}</b-dropdown-item>
|
||||
</b-nav-item-dropdown>
|
||||
|
||||
<b-nav-item-dropdown right>
|
||||
<!-- Using 'button-content' slot -->
|
||||
<template slot="button-content"><em>User</em></template>
|
||||
<b-dropdown-item to="/profile">Profile</b-dropdown-item>
|
||||
<b-dropdown-item to="/logout">Sign Out</b-dropdown-item>
|
||||
</b-nav-item-dropdown>
|
||||
</b-navbar-nav>
|
||||
</b-collapse>
|
||||
</b-navbar>
|
||||
|
||||
<span>({{tokenValidity}})</span> |
|
||||
<span>({{refreshTokenValidity}})</span>
|
||||
</div>
|
||||
@@ -59,6 +76,7 @@
|
||||
refreshTokenValidity: -1,
|
||||
showAlert: true,
|
||||
alertMessage: 'NO MESSAGE PROVIDED',
|
||||
langs: ['de', 'en', 'es'],
|
||||
};
|
||||
},
|
||||
methods: {
|
||||
@@ -81,6 +99,9 @@
|
||||
this.tokenValidity = getRemainingJwtValiditySeconds(this.$store.state.access_token);
|
||||
this.refreshTokenValidity = getRemainingJwtValiditySeconds(this.$store.state.refresh_token);
|
||||
// this.$log.debug(this.$store.state);
|
||||
if (this.tokenValidity < 50 && this.refreshTokenValidity > 30) {
|
||||
this.$store.dispatch('refreshToken'); // renew access token
|
||||
}
|
||||
}, 1000);
|
||||
});
|
||||
|
||||
|
||||
Reference in New Issue
Block a user