closes #51: show notification when a person is (not) attending at an event
This commit is contained in:
parent
60150a4f4f
commit
bb3fe77321
4 changed files with 58 additions and 0 deletions
|
@ -1,5 +1,6 @@
|
|||
<!-- show details of an Event -->
|
||||
<div class="container">
|
||||
<div eventman-message="eventman-message" control="message" ng-class="{'eventman-message': true, clearfix: true, alert: true, 'alert-success': !dControl.isError, 'alert-danger': dControl.isError}"></div>
|
||||
<div class="container">
|
||||
<div class="row">
|
||||
<div class="col-md-7 col-xs-7 vcenter">
|
||||
|
|
18
angular_app/js/controllers.js
vendored
18
angular_app/js/controllers.js
vendored
|
@ -58,6 +58,7 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
|||
$scope.personsOrderProp = 'name';
|
||||
$scope.eventsOrderProp = '-begin-date';
|
||||
$scope.countAttendees = 0;
|
||||
$scope.message = {};
|
||||
$scope.customFields = Setting.query({setting: 'person_custom_field',
|
||||
in_event_details: true});
|
||||
|
||||
|
@ -118,6 +119,9 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
|||
$scope.allPersons = Person.all();
|
||||
}
|
||||
$scope.newPerson = {};
|
||||
// XXX: must be converted in a i18n-able form.
|
||||
var msg = '' + person_data.name + ' ' + person_data.surname + ' successfully added to event ' + $scope.event.title;
|
||||
$scope.showMessage({message: msg});
|
||||
});
|
||||
});
|
||||
$scope.query = '';
|
||||
|
@ -150,6 +154,16 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
|||
if (callback) {
|
||||
callback(data);
|
||||
}
|
||||
if (key === 'attended') {
|
||||
var msg = {};
|
||||
if (value) {
|
||||
msg.message = '' + person.name + ' ' + person.surname + ' successfully added to event ' + $scope.event.title;
|
||||
} else {
|
||||
msg.message = '' + person.name + ' ' + person.surname + ' successfully removed from event ' + $scope.event.title;
|
||||
msg.isError = true;
|
||||
}
|
||||
$scope.showMessage(msg);
|
||||
}
|
||||
});
|
||||
};
|
||||
|
||||
|
@ -168,6 +182,10 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
|||
$scope.allPersons = Person.all();
|
||||
});
|
||||
};
|
||||
|
||||
$scope.showMessage = function(cfg) {
|
||||
$scope.message.show(cfg);
|
||||
};
|
||||
}]
|
||||
);
|
||||
|
||||
|
|
29
angular_app/js/directives.js
vendored
29
angular_app/js/directives.js
vendored
|
@ -39,3 +39,32 @@ eventManApp.directive('resetFocus', function () {
|
|||
};
|
||||
});
|
||||
|
||||
|
||||
eventManApp.directive('eventmanMessage', ['$timeout',
|
||||
function($timeout) {
|
||||
function link(scope, element, attrs) {
|
||||
scope.dControl = scope.control || {};
|
||||
scope.dControl.isVisible = false;
|
||||
|
||||
scope.dControl.show = function(cfg) {
|
||||
cfg = cfg || {};
|
||||
scope.dControl.isVisible = true;
|
||||
scope.dControl.message = cfg.message;
|
||||
scope.dControl.isError = cfg.isError;
|
||||
$timeout(function () {
|
||||
scope.dControl.isVisible = false;
|
||||
}, cfg.timeout || 2000);
|
||||
};
|
||||
};
|
||||
|
||||
return {
|
||||
scope: {
|
||||
control: '='
|
||||
},
|
||||
link: link,
|
||||
replace: true,
|
||||
template: '<div ng-if="dControl.isVisible">{{dControl.message}}</div>'
|
||||
};
|
||||
}]
|
||||
);
|
||||
|
||||
|
|
|
@ -19,4 +19,14 @@ body { padding-top: 70px; }
|
|||
float: none;
|
||||
}
|
||||
|
||||
.eventman-message {
|
||||
position: fixed;
|
||||
top: 2%;
|
||||
width: 40%;
|
||||
left: 30%;
|
||||
text-align: center;
|
||||
display: inline-block;
|
||||
z-index: 10000;
|
||||
}
|
||||
|
||||
/* .row { display: table; } */
|
||||
|
|
Loading…
Reference in a new issue