commit
e604a839ff
9 changed files with 108 additions and 58 deletions
|
@ -67,6 +67,8 @@ events collection
|
||||||
|
|
||||||
Stores information about events and persons registered for a given event.
|
Stores information about events and persons registered for a given event.
|
||||||
|
|
||||||
|
Please notice that information about a person registered for a given event is solely taken from the event.persons entry, and not to the relative entry in the persons collection. This may change in the future (to integrate missing information), but in general it is correct that, editing (or deleting) a person, older information about the partecipation to an event is not changed.
|
||||||
|
|
||||||
Main field:
|
Main field:
|
||||||
|
|
||||||
- title
|
- title
|
||||||
|
|
|
@ -1,11 +1,27 @@
|
||||||
<!-- show details of an Event -->
|
<!-- show details of an Event -->
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<h1>{{event.title}}
|
<div class="container">
|
||||||
<button ng-if="event._id" ng-click="$state.go('event.edit', {id: event._id})" class="btn btn-success">
|
<div class="row">
|
||||||
<span class="glyphicon glyphicon-edit"></span>
|
<div class="col-md-7 col-xs-7 vcenter">
|
||||||
{{'Edit' | translate}}
|
<h1>{{event.title}}
|
||||||
</button>
|
<button ng-if="event._id" ng-click="$state.go('event.edit', {id: event._id})" class="btn btn-success">
|
||||||
</h1>
|
<span class="glyphicon glyphicon-edit"></span>
|
||||||
|
{{'Edit' | translate}}
|
||||||
|
</button>
|
||||||
|
</h1>
|
||||||
|
</div><!--
|
||||||
|
--><div class="col-md-5 col-xs-5 vcenter">
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-md-6">
|
||||||
|
<h2><div class="label label-warning vcenter">{{'Registered:' | translate}} {{event.persons.length || 0}}</div></h2>
|
||||||
|
</div>
|
||||||
|
<div class="col-md-6">
|
||||||
|
<h2><div class="label label-info vcenter">{{'Attendees:' | translate}} {{countAttendees}}</div></h2>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div class="container">
|
<div class="container">
|
||||||
<div class="row">
|
<div class="row">
|
||||||
|
@ -34,7 +50,7 @@
|
||||||
<th>{{'Person' | translate}}</th>
|
<th>{{'Person' | translate}}</th>
|
||||||
<th>{{'Email' | translate}}</th>
|
<th>{{'Email' | translate}}</th>
|
||||||
<th>{{'Attended' | translate}}</th>
|
<th>{{'Attended' | translate}}</th>
|
||||||
<th>{{'Actions' | translate}}</th>
|
<th>{{'Delete' | translate}}</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
|
@ -57,7 +73,7 @@
|
||||||
<div class="col-md-4">
|
<div class="col-md-4">
|
||||||
|
|
||||||
<div class="panel panel-info table-striped top5">
|
<div class="panel panel-info table-striped top5">
|
||||||
<div class="panel-heading">{{'Fast add' | translate}}</div>
|
<div class="panel-heading">{{'Quick add' | translate}}</div>
|
||||||
<div class="panel-body">
|
<div class="panel-body">
|
||||||
<form>
|
<form>
|
||||||
<div class="input-group input-group-sm">
|
<div class="input-group input-group-sm">
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<td><strong>{{'Event' | translate}}</strong></td>
|
<td><strong>{{'Event' | translate}}</strong></td>
|
||||||
<td><strong>{{'Actions' | translate}}</strong></td>
|
<td><strong>{{'Delete' | translate}}</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
<script src="/static/js/eventman.js"></script>
|
<script src="/static/js/eventman.js"></script>
|
||||||
<script src="/js/app.js"></script>
|
<script src="/js/app.js"></script>
|
||||||
<script src="/js/i18n.js"></script>
|
<script src="/js/i18n.js"></script>
|
||||||
|
<script src="/js/filters.js"></script>
|
||||||
<script src="/js/services.js"></script>
|
<script src="/js/services.js"></script>
|
||||||
<script src="/js/controllers.js"></script>
|
<script src="/js/controllers.js"></script>
|
||||||
<link href="/static/css/normalize.css" rel="stylesheet">
|
<link href="/static/css/normalize.css" rel="stylesheet">
|
||||||
|
|
46
angular_app/js/app.js
vendored
46
angular_app/js/app.js
vendored
|
@ -49,52 +49,6 @@ eventManApp.filter('splittedFilter', ['$filter',
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
/* Filter for events that have (or not) information about a registered person. */
|
|
||||||
eventManApp.filter('eventWithPersonData', ['$filter',
|
|
||||||
function($filter) {
|
|
||||||
return function(inputArray, mustBePresent) {
|
|
||||||
if (mustBePresent === undefined) {
|
|
||||||
mustBePresent = true;
|
|
||||||
}
|
|
||||||
inputArray = inputArray || [];
|
|
||||||
var returnArray = [];
|
|
||||||
for (var x=0; x < inputArray.length; x++) {
|
|
||||||
var found = inputArray[x].person_data && inputArray[x].person_data.person_id;
|
|
||||||
if ((found && mustBePresent) || (!found && !mustBePresent)) {
|
|
||||||
returnArray.push(inputArray[x]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return returnArray;
|
|
||||||
};
|
|
||||||
}]
|
|
||||||
);
|
|
||||||
|
|
||||||
eventManApp.filter('personRegistered', ['$filter',
|
|
||||||
function($filter) {
|
|
||||||
return function(inputArray, data) {
|
|
||||||
if (data.present === undefined) {
|
|
||||||
data.present = true;
|
|
||||||
}
|
|
||||||
inputArray = inputArray || [];
|
|
||||||
var returnArray = [];
|
|
||||||
var registeredIDs = [];
|
|
||||||
if (!(data.event && data.event.persons && data.event.persons.length)) {
|
|
||||||
return inputArray;
|
|
||||||
}
|
|
||||||
for (var x=0; x < data.event.persons.length; x++) {
|
|
||||||
registeredIDs.push(data.event.persons[x].person_id);
|
|
||||||
}
|
|
||||||
for (var x=0; x < inputArray.length; x++) {
|
|
||||||
var found = registeredIDs.indexOf(inputArray[x]._id) != -1;
|
|
||||||
if ((found && data.present) || (!found && !data.present)) {
|
|
||||||
returnArray.push(inputArray[x]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return returnArray;
|
|
||||||
}
|
|
||||||
}]
|
|
||||||
);
|
|
||||||
|
|
||||||
/* Directive that can be used to make an input field react to the press of Enter. */
|
/* Directive that can be used to make an input field react to the press of Enter. */
|
||||||
eventManApp.directive('ngEnter', function () {
|
eventManApp.directive('ngEnter', function () {
|
||||||
return function (scope, element, attrs) {
|
return function (scope, element, attrs) {
|
||||||
|
|
25
angular_app/js/controllers.js
vendored
25
angular_app/js/controllers.js
vendored
|
@ -1,7 +1,7 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
/* Controllers; their method are available where specified with the ng-controller
|
/* Controllers; their method are available where specified with the ng-controller
|
||||||
* directive or for a given route (see app.js). They use some services to
|
* directive or for a given route/state (see app.js). They use some services to
|
||||||
* connect to the backend (see services.js). */
|
* connect to the backend (see services.js). */
|
||||||
var eventManControllers = angular.module('eventManControllers', []);
|
var eventManControllers = angular.module('eventManControllers', []);
|
||||||
|
|
||||||
|
@ -57,8 +57,15 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
||||||
function ($scope, Event, Person, $stateParams, $log) {
|
function ($scope, Event, Person, $stateParams, $log) {
|
||||||
$scope.personsOrderProp = 'name';
|
$scope.personsOrderProp = 'name';
|
||||||
$scope.eventsOrderProp = '-begin-date';
|
$scope.eventsOrderProp = '-begin-date';
|
||||||
|
$scope.countAttendees = 0;
|
||||||
if ($stateParams.id) {
|
if ($stateParams.id) {
|
||||||
$scope.event = Event.get($stateParams);
|
$scope.event = Event.get($stateParams, function() {
|
||||||
|
$scope.$watchCollection(function() {
|
||||||
|
return $scope.event.persons;
|
||||||
|
}, function(prev, old) {
|
||||||
|
$scope.calcAttendees();
|
||||||
|
});
|
||||||
|
});
|
||||||
$scope.allPersons = Person.all();
|
$scope.allPersons = Person.all();
|
||||||
}
|
}
|
||||||
// store a new Event or update an existing one
|
// store a new Event or update an existing one
|
||||||
|
@ -76,6 +83,20 @@ eventManControllers.controller('EventDetailsCtrl', ['$scope', 'Event', 'Person',
|
||||||
$scope.eventForm.$dirty = false;
|
$scope.eventForm.$dirty = false;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$scope.calcAttendees = function() {
|
||||||
|
if (!($scope.event && $scope.event.persons)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var attendees = 0;
|
||||||
|
$log.info($scope.event.persons.length);
|
||||||
|
angular.forEach($scope.event.persons, function(value, key) {
|
||||||
|
if (value.attended) {
|
||||||
|
attendees += 1;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$scope.countAttendees = attendees;
|
||||||
|
};
|
||||||
|
|
||||||
$scope._addAttendee = function(person_data) {
|
$scope._addAttendee = function(person_data) {
|
||||||
person_data.person_id = person_data._id;
|
person_data.person_id = person_data._id;
|
||||||
person_data._id = $stateParams.id;
|
person_data._id = $stateParams.id;
|
||||||
|
|
52
angular_app/js/filters.js
vendored
Normal file
52
angular_app/js/filters.js
vendored
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
/* Filters for EventMan(ager) lists of objects. */
|
||||||
|
|
||||||
|
/* Filter for events that have (or not) information about a registered person. */
|
||||||
|
eventManApp.filter('eventWithPersonData', ['$filter',
|
||||||
|
function($filter) {
|
||||||
|
return function(inputArray, mustBePresent) {
|
||||||
|
if (mustBePresent === undefined) {
|
||||||
|
mustBePresent = true;
|
||||||
|
}
|
||||||
|
inputArray = inputArray || [];
|
||||||
|
var returnArray = [];
|
||||||
|
for (var x=0; x < inputArray.length; x++) {
|
||||||
|
var found = inputArray[x].person_data && inputArray[x].person_data.person_id;
|
||||||
|
if ((found && mustBePresent) || (!found && !mustBePresent)) {
|
||||||
|
returnArray.push(inputArray[x]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnArray;
|
||||||
|
};
|
||||||
|
}]
|
||||||
|
);
|
||||||
|
|
||||||
|
|
||||||
|
/* Filter for persons (not) registered for a given event. */
|
||||||
|
eventManApp.filter('personRegistered', ['$filter',
|
||||||
|
function($filter) {
|
||||||
|
return function(inputArray, data) {
|
||||||
|
if (data.present === undefined) {
|
||||||
|
data.present = true;
|
||||||
|
}
|
||||||
|
inputArray = inputArray || [];
|
||||||
|
var returnArray = [];
|
||||||
|
var registeredIDs = [];
|
||||||
|
if (!(data.event && data.event.persons && data.event.persons.length)) {
|
||||||
|
return inputArray;
|
||||||
|
}
|
||||||
|
for (var x=0; x < data.event.persons.length; x++) {
|
||||||
|
registeredIDs.push(data.event.persons[x].person_id);
|
||||||
|
}
|
||||||
|
for (var x=0; x < inputArray.length; x++) {
|
||||||
|
var found = registeredIDs.indexOf(inputArray[x]._id) != -1;
|
||||||
|
if ((found && data.present) || (!found && !data.present)) {
|
||||||
|
returnArray.push(inputArray[x]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return returnArray;
|
||||||
|
}
|
||||||
|
}]
|
||||||
|
);
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<td><strong>{{'Name' | translate}}</strong></td>
|
<td><strong>{{'Name' | translate}}</strong></td>
|
||||||
<td><strong>{{'Actions' | translate}}</strong></td>
|
<td><strong>{{'Delete' | translate}}</strong></td>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
|
|
|
@ -14,5 +14,9 @@ body { padding-top: 70px; }
|
||||||
|
|
||||||
.vcenter {
|
.vcenter {
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
|
/* display: table-cell !important; */
|
||||||
|
display: inline-block !important;
|
||||||
|
float: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* .row { display: table; } */
|
||||||
|
|
Loading…
Reference in a new issue