1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-20 17:51:25 +01:00

add que functionality to globalnotification

This commit is contained in:
Tim Daubenschütz 2015-06-09 12:08:14 +02:00
parent e0e75151e0
commit d3fc902411
5 changed files with 56 additions and 38 deletions

View File

@ -6,8 +6,9 @@ import alt from '../alt';
class GlobalNotificationActions { class GlobalNotificationActions {
constructor() { constructor() {
this.generateActions( this.generateActions(
'updateGlobalNotification', 'appendGlobalNotification',
'resetGlobalNotification' 'shiftGlobalNotification',
'emulateEmptyStore'
); );
} }
} }

View File

@ -15,36 +15,38 @@ let GlobalNotification = React.createClass({
}, },
componentWillUnmount() { componentWillUnmount() {
GlobalNotificationStore.listen(this.onChange); GlobalNotificationStore.unlisten(this.onChange);
}, },
getInititalState() { getInititalState() {
return GlobalNotificationStore.getState(); return this.extractFirstElem(GlobalNotificationStore.getState().notificationQue);
},
extractFirstElem(l) {
return l.length > 0 ? l[0] : null;
}, },
onChange(state) { onChange(state) {
this.setState(state); let notification = this.extractFirstElem(state.notificationQue);
if(state.message && state.dismissAfter) {
setTimeout(GlobalNotificationActions.resetGlobalNotification, state.dismissAfter);
}
},
onClick() { if(notification) {
if(this.state.onClick) { this.setState(notification);
this.state.onClick(); } else {
this.replaceState(null);
} }
GlobalNotificationActions.resetGlobalNotification();
}, },
render() { render() {
let className = 'ascribe-global-notification '; let className = 'ascribe-global-notification ';
className += this.state && this.state.message ? 'ascribe-global-notification-on' : 'ascribe-global-notification-off'; let message = this.state && this.state.message ? this.state.message : null;
className += message ? 'ascribe-global-notification-on' : 'ascribe-global-notification-off';
return ( return (
<Row onClick={this.onClick}> <Row>
<Col> <Col>
<div className={className}> <div className={className}>
<div>{this.state ? this.state.message : null}</div> <div>{message ? message : null}</div>
</div> </div>
</Col> </Col>
</Row> </Row>

View File

@ -14,6 +14,7 @@ import MenuItem from 'react-bootstrap/lib/MenuItem';
import { getLangText } from '../utils/lang_utils'; import { getLangText } from '../utils/lang_utils';
import GlobalNotificationActions from '../actions/global_notification_actions'; import GlobalNotificationActions from '../actions/global_notification_actions';
import GlobalNotificationModel from '../models/global_notification_model';
let Link = Router.Link; let Link = Router.Link;
@ -37,7 +38,8 @@ let Header = React.createClass({
}, },
showNotification() { showNotification() {
GlobalNotificationActions.updateGlobalNotification({message: 'transaction successful', dismissAfter: 2000}); let notification = new GlobalNotificationModel('transaction successful', 3500);
GlobalNotificationActions.appendGlobalNotification(notification);
}, },
render() { render() {

View File

@ -0,0 +1,13 @@
'use strict';
export default class GlobalNotificationModel {
constructor(message, dismissAfter) {
if(!message) {
throw new Error('A notifications message must be defined.');
} else {
this.message = message;
}
this.dismissAfter = dismissAfter ? dismissAfter : 0;
}
}

View File

@ -6,34 +6,34 @@ import GlobalNotificationActions from '../actions/global_notification_actions';
class GlobalNotificationStore { class GlobalNotificationStore {
constructor() { constructor() {
this.message = ''; this.notificationQue = [];
this.action = '';
this.styles = {};
this.onClick = null;
this.dismissAfter = 0;
this.bindActions(GlobalNotificationActions); this.bindActions(GlobalNotificationActions);
} }
onUpdateGlobalNotification({message, action, styles, onClick, dismissAfter}) { onAppendGlobalNotification(newNotification) {
if(!message) { let notificationDelay = 0;
throw new Error('A notifications message must be defined.'); for(let i = 0; i < this.notificationQue.length; i++) {
} else { notificationDelay += this.notificationQue[i].dismissAfter;
this.message = message;
} }
this.action = action ? action : ''; this.notificationQue.push(newNotification);
this.styles = styles ? styles : {}; setTimeout(GlobalNotificationActions.emulateEmptyStore, notificationDelay + newNotification.dismissAfter);
this.onClick = onClick ? onClick : null;
this.dismissAfter = dismissAfter ? dismissAfter : 0;
} }
onResetGlobalNotification() { onEmulateEmptyStore() {
this.message = ''; let actualNotificitionQue = this.notificationQue.slice();
this.action = '';
this.styles = {}; this.notificationQue = [];
this.onClick = null;
this.dismissAfter = 0; setTimeout(() => {
this.notificationQue = actualNotificitionQue.slice();
GlobalNotificationActions.shiftGlobalNotification();
}, 400);
}
onShiftGlobalNotification() {
this.notificationQue.shift();
} }
} }