mirror of
https://github.com/dborth/vbagx.git
synced 2025-01-03 22:51:49 +01:00
Updates & fixes:
-Config toast and dialog controls -Add forbidden route -Fix check auth & permission before enter, not so tested -Fix set data on login -Display sections according to roles -Show user contact name after login, still need fix.
This commit is contained in:
parent
9cd5d36a5f
commit
6527eb953b
@ -36,6 +36,17 @@ var app = new Framework7({
|
|||||||
// browserHistory: true,
|
// browserHistory: true,
|
||||||
// },
|
// },
|
||||||
|
|
||||||
|
dialog: {
|
||||||
|
buttonOk: 'Aceptar',
|
||||||
|
buttonCancel: 'Cancelar',
|
||||||
|
},
|
||||||
|
|
||||||
|
toast: {
|
||||||
|
closeTimeout: 2000,
|
||||||
|
closeButton: true,
|
||||||
|
closeButtonText: "[X]"
|
||||||
|
},
|
||||||
|
|
||||||
// Input settings
|
// Input settings
|
||||||
input: {
|
input: {
|
||||||
scrollIntoViewOnFocus: device.cordova && !device.electron,
|
scrollIntoViewOnFocus: device.cordova && !device.electron,
|
||||||
|
@ -4,7 +4,7 @@ import user from './../stores/user.js';
|
|||||||
let Check = {
|
let Check = {
|
||||||
authorization( { to, resolve } ) {
|
authorization( { to, resolve } ) {
|
||||||
const router = this;
|
const router = this;
|
||||||
if (user.getters.isLogged.value){
|
if (!user.getters.isLogged.value){
|
||||||
//if (!User.isLogged()){
|
//if (!User.isLogged()){
|
||||||
router.navigate('/login/', { reloadCurrent: true });
|
router.navigate('/login/', { reloadCurrent: true });
|
||||||
}
|
}
|
||||||
@ -47,7 +47,7 @@ let Check = {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
reject();
|
reject();
|
||||||
router.navigate('/forbidden/');
|
router.navigate('/forbidden/', { reloadCurrent: true });
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -3,15 +3,21 @@ import AboutPage from '../pages/about.f7.html';
|
|||||||
import home from './routes/home.js';
|
import home from './routes/home.js';
|
||||||
import login from './routes/login.js';
|
import login from './routes/login.js';
|
||||||
import not_found from './routes/not-found.js';
|
import not_found from './routes/not-found.js';
|
||||||
|
import forbidden from './routes/forbidden.js';
|
||||||
|
|
||||||
|
import Check from './controllers/check';
|
||||||
|
|
||||||
let routes = [
|
let routes = [
|
||||||
{
|
{
|
||||||
name: 'about',
|
name: 'about',
|
||||||
path: '/about/',
|
path: '/about/',
|
||||||
component: AboutPage,
|
component: AboutPage,
|
||||||
|
allowedRoles: [15],
|
||||||
|
beforeEnter: [Check.authorization, Check.permission],
|
||||||
},
|
},
|
||||||
...home,
|
...home,
|
||||||
...login,
|
...login,
|
||||||
|
...forbidden,
|
||||||
...not_found,
|
...not_found,
|
||||||
]
|
]
|
||||||
|
|
||||||
|
12
src/js/routes/forbidden.js
Normal file
12
src/js/routes/forbidden.js
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import ForbiddenPage from '../../pages/forbidden.f7.html';
|
||||||
|
|
||||||
|
/*Must be in last position*/
|
||||||
|
const forbidden = [
|
||||||
|
{
|
||||||
|
name: 'forbidden',
|
||||||
|
path: '/forbidden/',
|
||||||
|
component: ForbiddenPage
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
export default forbidden;
|
@ -16,12 +16,10 @@ const user = createStore({
|
|||||||
const token = response.data.token;
|
const token = response.data.token;
|
||||||
delete response.data.token;
|
delete response.data.token;
|
||||||
const user = response.data;
|
const user = response.data;
|
||||||
const roles = [1, 4]; //Owner, Customer, Seller, Deliverer//response.data.roles;
|
const roles = [1, 4, 14]; //Owner, Customer, Seller, Deliverer//response.data.roles;
|
||||||
console.log(roles);
|
|
||||||
console.log(user);
|
|
||||||
localStorage.setItem('token', token);
|
localStorage.setItem('token', token);
|
||||||
http.defaults.headers.common['Authorization'] = token;
|
http.defaults.headers.common['Authorization'] = token;
|
||||||
dispatch('auth_success', token, user, roles);
|
dispatch('auth_success', {token, user, roles});
|
||||||
resolve(response);
|
resolve(response);
|
||||||
})
|
})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
@ -47,7 +45,7 @@ const user = createStore({
|
|||||||
auth_request({ state }){
|
auth_request({ state }){
|
||||||
state.status = 'loading';
|
state.status = 'loading';
|
||||||
},
|
},
|
||||||
auth_success({ state }, token, user, roles){
|
auth_success({ state }, { token, user, roles }){
|
||||||
state.status = 'success';
|
state.status = 'success';
|
||||||
state.token = token;
|
state.token = token;
|
||||||
state.user = user;
|
state.user = user;
|
||||||
|
33
src/pages/forbidden.f7.html
Normal file
33
src/pages/forbidden.f7.html
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<template>
|
||||||
|
<div class="page" data-name="about">
|
||||||
|
<div class="navbar">
|
||||||
|
<div class="navbar-bg"></div>
|
||||||
|
<div class="navbar-inner sliding">
|
||||||
|
<div class="left">
|
||||||
|
<a href="/" class="link">
|
||||||
|
<i class="material-icons">home</i>
|
||||||
|
<span class="if-not-md">Home</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="title">Prohibido</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="page-content">
|
||||||
|
<div class="block-title">Contenido no autorizado</div>
|
||||||
|
<div class="block block-strong">
|
||||||
|
<p>
|
||||||
|
No tiene los permisos requeridos para poder visualizar el contenido solicitado.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div class="block-footer">
|
||||||
|
<p>© Aplicaciones Digitales Cab, 2019-2021 (v${version})</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
<script>
|
||||||
|
export default (props, { $f7, $on, $update }) => {
|
||||||
|
let version = $f7.version;
|
||||||
|
return $render;
|
||||||
|
};
|
||||||
|
</script>
|
@ -128,26 +128,26 @@
|
|||||||
<script>
|
<script>
|
||||||
import $ from 'dom7';
|
import $ from 'dom7';
|
||||||
import store from '../../js/stores/index.js';
|
import store from '../../js/stores/index.js';
|
||||||
import User from '../../js/controllers/users.js';
|
import user from '../../js/stores/user.js';
|
||||||
|
//import User from '../../js/controllers/users.js';
|
||||||
|
|
||||||
export default (props, { $f7, $on, $update, }) => {
|
export default (props, { $f7, $on, $update, }) => {
|
||||||
|
let isLogged = user.getters.isLogged.value;
|
||||||
let isLogged = false;
|
|
||||||
let isSeller = false;
|
let isSeller = false;
|
||||||
let isCustomer = false;
|
let isCustomer = false;
|
||||||
let isDeliverer = false;
|
let isDeliverer = false;
|
||||||
let theme = store.getters.themeName.value;
|
let theme = store.getters.themeName.value;
|
||||||
|
|
||||||
const onPanelOpen = () => {
|
|
||||||
if (User.isLogged()){
|
|
||||||
//const userData = JSON.parse(localStorage.getItem("userData"));
|
|
||||||
//const userRoles = userData['userPermissions'];
|
|
||||||
const userRoles = user.getters.roles.value;
|
const userRoles = user.getters.roles.value;
|
||||||
|
|
||||||
isLogged = true,
|
const onPanelOpen = () => {
|
||||||
isCustomer = userRoles.includes(4), //Customer,
|
//if (User.isLogged()){
|
||||||
isSeller = userRoles.includes(14), //Seller,
|
//const userData = JSON.parse(localStorage.getItem("userData"));
|
||||||
isDeliverer = userRoles.includes(15), //Deliverer,
|
//const userRoles = userData['userPermissions'];
|
||||||
|
//console.log("Roles:",userRoles.includes(4));
|
||||||
|
if (isLogged){
|
||||||
|
isCustomer = userRoles.includes(4); //Customer,
|
||||||
|
isSeller = userRoles.includes(14); //Seller,
|
||||||
|
isDeliverer = userRoles.includes(15); //Deliverer,
|
||||||
$update();
|
$update();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
<div class="item-title item-label">Usuario</div>
|
<div class="item-title item-label">Usuario</div>
|
||||||
<div class="item-input-wrap">
|
<div class="item-input-wrap">
|
||||||
<i class="icon f7-icons color-blue">person</i>
|
<i class="icon f7-icons color-blue">person</i>
|
||||||
<span id="menu-username"></span>
|
<span id="menu-username">${displayName}</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -67,8 +67,9 @@ import user from '../../js/stores/user.js';
|
|||||||
//import User from '../../js/controllers/users.js';
|
//import User from '../../js/controllers/users.js';
|
||||||
|
|
||||||
export default (props, { $f7, $on, $update, $f7router }) => {
|
export default (props, { $f7, $on, $update, $f7router }) => {
|
||||||
let isLogged = user.getters.isLogged.value;
|
|
||||||
let theme = store.getters.themeName.value;
|
let theme = store.getters.themeName.value;
|
||||||
|
let isLogged = user.getters.isLogged.value;
|
||||||
|
let displayName = user.getters.displayName.value['contactName'] || '';
|
||||||
|
|
||||||
const onPanelOpen = () => {
|
const onPanelOpen = () => {
|
||||||
$('#light-theme').prop('checked', (theme != 'theme-dark') ? true : false );
|
$('#light-theme').prop('checked', (theme != 'theme-dark') ? true : false );
|
||||||
@ -78,20 +79,13 @@ export default (props, { $f7, $on, $update, $f7router }) => {
|
|||||||
// isLogged = true;
|
// isLogged = true;
|
||||||
// $update();
|
// $update();
|
||||||
// }
|
// }
|
||||||
//console.log(user.getters.displayName.value);
|
|
||||||
console.log(user.getters.isLogged.value);
|
|
||||||
console.log(user.getters.authStatus.value);
|
|
||||||
console.log(user.getters.token.value);
|
|
||||||
console.log(user.getters.roles.value);
|
|
||||||
if (isLogged){
|
|
||||||
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const logout = () => {
|
const logout = () => {
|
||||||
//User.logOff();
|
//User.logOff();
|
||||||
user.dispatch('logOut').then( () => {
|
user.dispatch('logOut').then( () => {
|
||||||
$f7router.navigate('/');
|
$f7router.navigate('/');
|
||||||
|
$f7.toast.show( { text: "Ha cerrado sesión." });
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -65,11 +65,11 @@ export default (props, { $f7, $on, $update, $f7router }) => {
|
|||||||
// var username = $('#username').val();
|
// var username = $('#username').val();
|
||||||
// var password = $('#password').val();
|
// var password = $('#password').val();
|
||||||
// User.checkLogin(username, password).then(function(result){
|
// User.checkLogin(username, password).then(function(result){
|
||||||
user.dispatch('logIn', data)
|
user.dispatch('logIn', data).then(function(result){
|
||||||
.then(function(result){
|
|
||||||
$f7.preloader.hide();
|
$f7.preloader.hide();
|
||||||
if (result.status === 200){
|
if (result.status === 200){
|
||||||
$f7router.navigate('/');
|
$f7router.navigate('/');
|
||||||
|
$f7.toast.show( { text: "Ha iniciado sesión." });
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
$f7.toast.show( { text: result.message });
|
$f7.toast.show( { text: result.message });
|
||||||
|
Loading…
Reference in New Issue
Block a user