6d7a8dc3bf
This patch adds images panel with pull action. To enable images panel, copy enabled files: * zun_ui/enabled/_2330_project_container_panelgroup.py * zun_ui/enabled/_2331_project_container_images_panel.py into horizon: * openstack_dashboard/local/enabled/ Change-Id: I452449e6cf8dd5c150f5ff0843ce5babfface6ea Implements: blueprint add-images-panel
61 lines
1.7 KiB
JavaScript
61 lines
1.7 KiB
JavaScript
/*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
(function() {
|
|
"use strict";
|
|
|
|
angular
|
|
.module('horizon.dashboard.container.images')
|
|
.factory('horizon.dashboard.container.images.service', imagesService);
|
|
|
|
imagesService.$inject = [
|
|
'horizon.app.core.detailRoute',
|
|
'horizon.app.core.openstack-service-api.zun'
|
|
];
|
|
|
|
/*
|
|
* @ngdoc factory
|
|
* @name horizon.dashboard.container.images.service
|
|
*
|
|
* @description
|
|
* This service provides functions that are used through
|
|
* the images of container features.
|
|
*/
|
|
function imagesService(detailRoute, zun) {
|
|
return {
|
|
getImagesPromise: getImagesPromise
|
|
};
|
|
|
|
/*
|
|
* @ngdoc function
|
|
* @name getImagesPromise
|
|
* @description
|
|
* Given filter/query parameters, returns a promise for the matching
|
|
* images. This is used in displaying lists of images.
|
|
*/
|
|
function getImagesPromise(params) {
|
|
return zun.getImages(params).then(modifyResponse);
|
|
}
|
|
|
|
function modifyResponse(response) {
|
|
return {data: {items: response.data.items.map(modifyItem)}};
|
|
|
|
function modifyItem(item) {
|
|
var timestamp = new Date();
|
|
item.trackBy = item.id.concat(timestamp.getTime());
|
|
return item;
|
|
}
|
|
}
|
|
}
|
|
})();
|