fixes #149: export tickets in CSV format

This commit is contained in:
Davide Alberani 2017-04-29 17:00:06 +02:00
parent a6d60a0e10
commit f338da9078
7 changed files with 5748 additions and 11 deletions

View file

@ -23,12 +23,22 @@
</h1> </h1>
</div> </div>
<div class="panel-body"> <div class="panel-body">
<div>
<div style="float:left;">
<form class="form-inline"> <form class="form-inline">
<div class="form-group"> <div class="form-group">
<label for="query-tickets">{{'Search:' | translate}}</label> <label for="query-tickets">{{'Search:' | translate}}</label>
<input eventman-focus type="text" id="query-tickets" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query" ng-model-options="{debounce: 350}"> <input eventman-focus type="text" id="query-tickets" class="form-control" placeholder="{{'Name or email' | translate}}" ng-model="query" ng-model-options="{debounce: 350}">
</div>&nbsp;<label>&nbsp;<input type="checkbox" ng-model="registeredFilterOptions.all" /> {{'Show cancelled tickets' | translate}}</label> </div>&nbsp;<label>&nbsp;<input type="checkbox" ng-model="registeredFilterOptions.all" /> {{'Show cancelled tickets' | translate}}</label>
</form> </form>
</div>
<div style="float:right;">
<span style="color:#9e9e9e;">({{filteredLength}} {{'filtered item/s' | translate}})</span>&nbsp;
<a download="eventman.csv" ng-href="{{downloadURL}}" class="btn btn-primary" ng-class="{disabled: !filteredLength}"><span class="fa fa-download"></span> {{'export CSV' | translate}}</a>
</div>
</div>
<div class="clearfix"></div>
<uib-pagination ng-model="currentPage" total-items="filteredLength" items-per-page="itemsPerPage" <uib-pagination ng-model="currentPage" total-items="filteredLength" items-per-page="itemsPerPage"
direction-links="false" boundary-links="true" boundary-link-numbers="true" max-size="maxPaginationSize"> direction-links="false" boundary-links="true" boundary-link-numbers="true" max-size="maxPaginationSize">
</uib-pagination> </uib-pagination>

View file

@ -29,6 +29,7 @@
<script type="text/javascript" src="/static/js/api-check.min.js"></script> <script type="text/javascript" src="/static/js/api-check.min.js"></script>
<script type="text/javascript" src="/static/js/formly.min.js"></script> <script type="text/javascript" src="/static/js/formly.min.js"></script>
<script type="text/javascript" src="/static/js/angular-formly-templates-bootstrap.min.js"></script> <script type="text/javascript" src="/static/js/angular-formly-templates-bootstrap.min.js"></script>
<script type="text/javascript" src="/static/js/json2csv.min.js"></script>
<script type="text/javascript" src="/static/js/eventman.js"></script> <script type="text/javascript" src="/static/js/eventman.js"></script>
<script type="text/javascript" src="/js/app.js"></script> <script type="text/javascript" src="/js/app.js"></script>

View file

@ -105,8 +105,9 @@ eventManApp.run(['$rootScope', '$state', '$stateParams', '$log', 'Info',
/* Configure the states. */ /* Configure the states. */
eventManApp.config(['$stateProvider', '$urlRouterProvider', eventManApp.config(['$stateProvider', '$urlRouterProvider', '$compileProvider',
function($stateProvider, $urlRouterProvider) { function($stateProvider, $urlRouterProvider, $compileProvider) {
$compileProvider.aHrefSanitizationWhitelist(/^\s*(https?|ftp|mailto|tel|file|blob):/);
$urlRouterProvider.otherwise('/events'); $urlRouterProvider.otherwise('/events');
$stateProvider $stateProvider
.state('events', { .state('events', {

View file

@ -202,6 +202,7 @@ eventManControllers.controller('EventTicketsCtrl', ['$scope', '$state', 'Event',
$scope.shownItems = []; $scope.shownItems = [];
$scope.ticket = {}; // current ticket, for the event.ticket.* states $scope.ticket = {}; // current ticket, for the event.ticket.* states
$scope.tickets = []; // list of all tickets, for the 'tickets' state $scope.tickets = []; // list of all tickets, for the 'tickets' state
$scope.filteredTickets = [];
$scope.formSchema = {}; $scope.formSchema = {};
$scope.formData = {}; $scope.formData = {};
$scope.guiOptions = {dangerousActionsEnabled: false}; $scope.guiOptions = {dangerousActionsEnabled: false};
@ -221,9 +222,11 @@ eventManControllers.controller('EventTicketsCtrl', ['$scope', '$state', 'Event',
tickets = $filter('splittedFilter')(tickets, $scope.query); tickets = $filter('splittedFilter')(tickets, $scope.query);
tickets = $filter('registeredFilter')(tickets, $scope.registeredFilterOptions); tickets = $filter('registeredFilter')(tickets, $scope.registeredFilterOptions);
tickets = $filter('orderBy')(tickets, $scope.ticketsOrder); tickets = $filter('orderBy')(tickets, $scope.ticketsOrder);
$scope.filteredLength = tickets.length; $scope.filteredTickets = angular.copy(tickets);
$scope.filteredLength = $scope.filteredTickets.length;
tickets = $filter('pagination')(tickets, $scope.currentPage, $scope.itemsPerPage); tickets = $filter('pagination')(tickets, $scope.currentPage, $scope.itemsPerPage);
$scope.shownItems = tickets; $scope.shownItems = tickets;
$scope.updateCSV();
}; };
$scope.$watch('query', function() { $scope.$watch('query', function() {
@ -663,6 +666,17 @@ eventManControllers.controller('EventTicketsCtrl', ['$scope', '$state', 'Event',
$scope.filterTickets(); $scope.filterTickets();
}; };
$scope.updateCSV = function() {
if (!$scope.filteredTickets.length) {
return;
}
try {
var csv = json2csv({data: $scope.filteredTickets});
var blob = new Blob([csv], {type: 'text/csv'});
$scope.downloadURL = (window.URL || window.webkitURL).createObjectURL(blob);
} catch(err) {}
};
$scope.$on('$destroy', function() { $scope.$on('$destroy', function() {
$scope.EventUpdates && $scope.EventUpdates.close(); $scope.EventUpdates && $scope.EventUpdates.close();
}); });

5707
static/js/json2csv.js Normal file

File diff suppressed because it is too large Load diff

3
static/js/json2csv.min.js vendored Normal file

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long