2019-03-21 05:46:49 +00:00
|
|
|
import _ from 'lodash-es';
|
|
|
|
|
2018-06-11 13:13:19 +00:00
|
|
|
angular.module('portainer.docker')
|
2019-07-02 15:51:17 +00:00
|
|
|
.controller('ServiceTasksDatatableController', ['$scope', '$controller', 'DatatableService',
|
|
|
|
function ($scope, $controller, DatatableService) {
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
angular.extend(this, $controller('GenericDatatableController', {$scope: $scope}));
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
var ctrl = this;
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.state = Object.assign(this.state, {
|
|
|
|
showQuickActionStats: true,
|
|
|
|
showQuickActionLogs: true,
|
|
|
|
showQuickActionConsole: true,
|
|
|
|
showQuickActionInspect: true,
|
2019-07-25 22:38:07 +00:00
|
|
|
showQuickActionExec: true,
|
2019-07-02 15:51:17 +00:00
|
|
|
showQuickActionAttach: false
|
|
|
|
});
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.filters = {
|
|
|
|
state: {
|
|
|
|
open: false,
|
|
|
|
enabled: false,
|
|
|
|
values: []
|
|
|
|
}
|
|
|
|
};
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.applyFilters = function(item) {
|
|
|
|
var filters = ctrl.filters;
|
|
|
|
for (var i = 0; i < filters.state.values.length; i++) {
|
|
|
|
var filter = filters.state.values[i];
|
|
|
|
if (item.Status.State === filter.label && filter.display) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
};
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.onStateFilterChange = function() {
|
|
|
|
var filters = this.filters.state.values;
|
|
|
|
var filtered = false;
|
|
|
|
for (var i = 0; i < filters.length; i++) {
|
|
|
|
var filter = filters[i];
|
|
|
|
if (!filter.display) {
|
|
|
|
filtered = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
this.filters.state.enabled = filtered;
|
|
|
|
};
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.prepareTableFromDataset = function() {
|
|
|
|
var availableStateFilters = [];
|
|
|
|
for (var i = 0; i < this.dataset.length; i++) {
|
|
|
|
var item = this.dataset[i];
|
|
|
|
availableStateFilters.push({ label: item.Status.State, display: true });
|
|
|
|
}
|
|
|
|
this.filters.state.values = _.uniqBy(availableStateFilters, 'label');
|
|
|
|
};
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
this.$onInit = function() {
|
|
|
|
this.setDefaults();
|
|
|
|
this.prepareTableFromDataset();
|
|
|
|
|
2019-08-12 14:25:35 +00:00
|
|
|
this.state.orderBy = this.orderBy;
|
2019-07-02 15:51:17 +00:00
|
|
|
var storedOrder = DatatableService.getDataTableOrder(this.tableKey);
|
|
|
|
if (storedOrder !== null) {
|
|
|
|
this.state.reverseOrder = storedOrder.reverse;
|
|
|
|
this.state.orderBy = storedOrder.orderBy;
|
|
|
|
}
|
2018-06-11 13:13:19 +00:00
|
|
|
|
2019-07-02 15:51:17 +00:00
|
|
|
var textFilter = DatatableService.getDataTableTextFilters(this.tableKey);
|
|
|
|
if (textFilter !== null) {
|
|
|
|
this.state.textFilter = textFilter;
|
|
|
|
this.onTextFilterChange();
|
|
|
|
}
|
|
|
|
|
|
|
|
var storedFilters = DatatableService.getDataTableFilters(this.tableKey);
|
|
|
|
if (storedFilters !== null) {
|
|
|
|
this.filters = storedFilters;
|
|
|
|
}
|
|
|
|
if (this.filters && this.filters.state) {
|
|
|
|
this.filters.state.open = false;
|
|
|
|
}
|
2019-07-22 10:54:59 +00:00
|
|
|
|
|
|
|
var storedSettings = DatatableService.getDataTableSettings(this.tableKey);
|
|
|
|
if (storedSettings !== null) {
|
|
|
|
this.settings = storedSettings;
|
|
|
|
this.settings.open = false;
|
|
|
|
}
|
|
|
|
this.onSettingsRepeaterChange();
|
2019-07-02 15:51:17 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
]);
|