add mail queue view

This commit is contained in:
Girish Ramakrishnan
2022-08-31 08:45:28 +02:00
parent 380b41a1b4
commit 0d573e0213
6 changed files with 206 additions and 2 deletions
+69
View File
@@ -0,0 +1,69 @@
'use strict';
/* global $ */
/* global angular */
angular.module('Application').controller('EmailsQueueController', ['$scope', '$location', '$translate', '$timeout', 'Client', function ($scope, $location, $translate, $timeout, Client) {
Client.onReady(function () { if (!Client.getUserInfo().isAtLeastOwner) $location.path('/'); });
$scope.ready = false;
$scope.config = Client.getConfig();
$scope.user = Client.getUserInfo();
$scope.pageItemCount = [
{ name: $translate.instant('main.pagination.perPageSelector', { n: 20 }), value: 20 },
{ name: $translate.instant('main.pagination.perPageSelector', { n: 50 }), value: 50 },
{ name: $translate.instant('main.pagination.perPageSelector', { n: 100 }), value: 100 }
];
$scope.queue = {
busy: true,
items: [],
activeItem: null,
currentPage: 1,
perPage: 20,
pageItems: $scope.pageItemCount[0],
search: '',
refresh: function () {
$scope.queue.busy = true;
Client.listMailQueue($scope.queue.search, $scope.queue.currentPage, $scope.queue.pageItems.value, function (error, result) {
if (error) return console.error('Failed to fetch mail eventlogs.', error);
$scope.queue.busy = false;
$scope.queue.items = result;
});
},
showNextPage: function () {
$scope.queue.currentPage++;
$scope.queue.refresh();
},
showPrevPage: function () {
if ($scope.queue.currentPage > 1) $scope.queue.currentPage--;
else $scope.queue.currentPage = 1;
$scope.queue.refresh();
},
showItemDetails: function (item) {
if ($scope.queue.activeItem === item) $scope.queue.activeItem = null;
else $scope.queue.activeItem = item;
},
updateFilter: function (fresh) {
if (fresh) $scope.queue.currentPage = 1;
$scope.queue.refresh();
}
};
Client.onReady(function () {
$scope.ready = true;
$scope.queue.refresh();
});
$('.modal-backdrop').remove();
}]);