main/view/vue-config.js

106 lines
2.5 KiB
JavaScript
Raw Normal View History

import {GlobalStore} from './lib/gstore-es6'
window.gstore = new GlobalStore();
2017-12-03 15:02:18 +00:00
// Header
gstore.add('header_title', 'ndli1718');
gstore.add('info', {
2017-12-04 18:19:15 +00:00
active: false,
type: 'warning',
message: 'Warning! blabla'
});
gstore.add('notif', {
emergency: { class: 'emergency', data: [], count: 0 },
event: { class: 'event', data: [], count: 0 },
inbox: { class: 'message', data: [], count: 0 },
dashboard: { class: 'menu', data: [], count: 0 }
})
2017-12-03 15:02:18 +00:00
// Menu
gstore.add('menu_item', {
dashboard: {
label: 'Accueil',
theme: 'dashboard'
}, emergency: {
label: 'Urgences',
theme: 'emergency'
}, event: {
label: 'Signalements',
theme: 'event'
}, inbox: {
label: 'Messagerie',
theme: 'inbox'
}
2017-12-03 15:02:18 +00:00
});
gstore.add('URI', document.URL.replace(/^(?:\/\/|[^\/]+)*/, ''));
gstore.add('is_local', document.URL.replace(/^http:\/\/([^\/]+).*$/, '$1') == 'ndli1718');
gstore.add('min_menu', false);
2017-12-04 22:29:02 +00:00
// Proccess current page from url
if( /^\/(\w+)(?:\/?.*)$/.test(gstore.data.URI) ){
var mi_keys = Object.keys( gstore.data.menu_item );
2017-12-04 22:29:02 +00:00
// if current page exists
if( !!~mi_keys.indexOf(RegExp.$1) ) gstore.add('menu_item_active', RegExp.$1);
else gstore.add('menu_item_active', 'dashboard');
2017-12-04 22:29:02 +00:00
}else
gstore.add('menu_item_active', 'dashboard');
// Functions
gstore.add('func', {
nav: function(router, uri){
// {1} Update view (vue-router) //
if( typeof uri == 'string' )
router.push('/'+uri);
// {2} if no @uri -> Extract route from @router //
else if( /^\/([^\/]+).*$/.test( router.app.$route.path ) )
uri = RegExp.$1;
// {3} If no @uri -> exit //
else
return;
// {4} Activate current menu_item //
gstore.data.menu_item_active = uri;
// {5} Manage notifications //
for( var id in gstore.data.notif )
if( id == uri ) // if notif links to current page
gstore.data.notif[id].count = 0;
},
toggleMenuSize: function(){ gstore.data.min_menu=!gstore.data.min_menu; },
sendMessage: function(msg, wsc){
/* (1) If empty message -> abort */
if( msg.trim().length == 0 )
return;
/* (2) Send message to WebSocket */
wsc.send(JSON.stringify({message: msg}));
2017-12-04 18:19:15 +00:00
/* (3) Add loader */
gstore.data.msg_pending.inbox = true;
2017-12-04 18:19:15 +00:00
}
2017-12-05 12:32:42 +00:00
});
// new-message container
gstore.add('new_msg', {
inbox: '',
emergency: '',
event: ''
});
// if message loader
gstore.add('msg_pending', {
inbox: true,
emergency: true,
event: true
}); // true when message send pending
// notification stack visibility
gstore.add('nstack', false);