2018-02-01 12:27:52 +00:00
|
|
|
angular.module('portainer.docker')
|
2017-12-06 11:04:02 +00:00
|
|
|
.controller('ImagesDatatableController', ['PaginationService', 'DatatableService',
|
|
|
|
function (PaginationService, DatatableService) {
|
|
|
|
|
|
|
|
var ctrl = this;
|
|
|
|
|
|
|
|
this.state = {
|
|
|
|
selectAll: false,
|
|
|
|
orderBy: this.orderBy,
|
|
|
|
paginatedItemLimit: PaginationService.getPaginationLimit(this.tableKey),
|
|
|
|
displayTextFilter: false,
|
|
|
|
selectedItemCount: 0,
|
|
|
|
selectedItems: []
|
|
|
|
};
|
2018-07-11 14:18:44 +00:00
|
|
|
|
2017-12-06 11:04:02 +00:00
|
|
|
this.filters = {
|
|
|
|
usage: {
|
|
|
|
open: false,
|
|
|
|
enabled: false,
|
|
|
|
showUsedImages: true,
|
|
|
|
showUnusedImages: true
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2018-12-06 19:54:34 +00:00
|
|
|
this.onTextFilterChange = function() {
|
|
|
|
DatatableService.setDataTableTextFilters(this.tableKey, this.state.textFilter);
|
|
|
|
};
|
|
|
|
|
2017-12-06 11:04:02 +00:00
|
|
|
this.changeOrderBy = function(orderField) {
|
|
|
|
this.state.reverseOrder = this.state.orderBy === orderField ? !this.state.reverseOrder : false;
|
|
|
|
this.state.orderBy = orderField;
|
|
|
|
DatatableService.setDataTableOrder(this.tableKey, orderField, this.state.reverseOrder);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.selectItem = function(item) {
|
|
|
|
if (item.Checked) {
|
|
|
|
this.state.selectedItemCount++;
|
|
|
|
this.state.selectedItems.push(item);
|
|
|
|
} else {
|
|
|
|
this.state.selectedItems.splice(this.state.selectedItems.indexOf(item), 1);
|
|
|
|
this.state.selectedItemCount--;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
this.selectAll = function() {
|
|
|
|
for (var i = 0; i < this.state.filteredDataSet.length; i++) {
|
|
|
|
var item = this.state.filteredDataSet[i];
|
|
|
|
if (item.Checked !== this.state.selectAll) {
|
|
|
|
item.Checked = this.state.selectAll;
|
|
|
|
this.selectItem(item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
this.changePaginationLimit = function() {
|
|
|
|
PaginationService.setPaginationLimit(this.tableKey, this.state.paginatedItemLimit);
|
|
|
|
};
|
|
|
|
|
2018-08-22 15:33:06 +00:00
|
|
|
this.applyFilters = function(value) {
|
2017-12-06 11:04:02 +00:00
|
|
|
var image = value;
|
|
|
|
var filters = ctrl.filters;
|
2018-07-11 14:18:44 +00:00
|
|
|
if ((image.ContainerCount === 0 && filters.usage.showUnusedImages)
|
2017-12-06 11:04:02 +00:00
|
|
|
|| (image.ContainerCount !== 0 && filters.usage.showUsedImages)) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
};
|
2018-07-11 14:18:44 +00:00
|
|
|
|
2017-12-06 11:04:02 +00:00
|
|
|
this.onUsageFilterChange = function() {
|
|
|
|
var filters = this.filters.usage;
|
|
|
|
var filtered = false;
|
|
|
|
if (!filters.showUsedImages || !filters.showUnusedImages) {
|
|
|
|
filtered = true;
|
|
|
|
}
|
|
|
|
this.filters.usage.enabled = filtered;
|
|
|
|
DatatableService.setDataTableFilters(this.tableKey, this.filters);
|
|
|
|
};
|
|
|
|
|
|
|
|
this.$onInit = function() {
|
|
|
|
setDefaults(this);
|
|
|
|
|
|
|
|
var storedOrder = DatatableService.getDataTableOrder(this.tableKey);
|
|
|
|
if (storedOrder !== null) {
|
|
|
|
this.state.reverseOrder = storedOrder.reverse;
|
|
|
|
this.state.orderBy = storedOrder.orderBy;
|
|
|
|
}
|
2018-07-11 14:18:44 +00:00
|
|
|
|
2017-12-06 11:04:02 +00:00
|
|
|
var storedFilters = DatatableService.getDataTableFilters(this.tableKey);
|
|
|
|
if (storedFilters !== null) {
|
|
|
|
this.filters = storedFilters;
|
|
|
|
}
|
|
|
|
this.filters.usage.open = false;
|
2018-12-06 19:54:34 +00:00
|
|
|
|
|
|
|
var textFilter = DatatableService.getDataTableTextFilters(this.tableKey);
|
|
|
|
if (textFilter !== null) {
|
|
|
|
this.state.textFilter = textFilter;
|
|
|
|
}
|
2017-12-06 11:04:02 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
function setDefaults(ctrl) {
|
|
|
|
ctrl.showTextFilter = ctrl.showTextFilter ? ctrl.showTextFilter : false;
|
|
|
|
ctrl.state.reverseOrder = ctrl.reverseOrder ? ctrl.reverseOrder : false;
|
|
|
|
}
|
|
|
|
}]);
|