154 lines
5.0 KiB
JavaScript

// Licensed to the Apache Software Foundation (ASF) under one
// or more contributor license agreements. See the NOTICE file
// distributed with this work for additional information
// regarding copyright ownership. The ASF licenses this file
// to you 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.
angular.module("storage", ["resources.volumes", "resources.snapshots", "resources.zones", "resources.diskofferings", "services.breadcrumbs"]).
config(['$routeProvider', function($routeProvider){
$routeProvider.
when('/volumes',{
controller: 'VolumesListCtrl',
templateUrl: '/static/js/app/storage/storage.tpl.html',
resolve: {
volumes: function(Volumes){
return Volumes.getAll();
}
}
}).
when('/snapshots', {
controller: 'SnapshotsListCtrl',
templateUrl: 'table.html',
resolve:{
snapshots: function(Snapshots){
return Snapshots.getAll();
}
}
})
}]);
angular.module("storage").controller("VolumesListCtrl", ["$scope", "$location", "volumes", "Breadcrumbs", "Volumes", "Zones", "DiskOfferings",
function($scope, $location, volumes, Breadcrumbs, Volumes, Zones, DiskOfferings){
Breadcrumbs.refresh();
Breadcrumbs.push('Volumes', '/#/volumes');
$scope.collection = volumes;
$scope.view = 'volumes';
$scope.toDisplay = ['name', 'type', 'hypervisor', 'vmdisplayname'];
$scope.addVolumeForm = {
title: 'label.add.volume',
onSubmit: Volumes.getAll,
fields: [
{
model: 'name',
type: 'input-text',
label: 'name',
required: true
},
{
model: 'zoneid',
type: 'select',
label: 'availabilityZone',
options: Zones.getAll,
getValue: function(model){
return model.id;
},
getName: function(model){
return model.name;
}
},
{
model: 'diskofferingid',
type: 'select',
label: 'diskoffering',
options: DiskOfferings.getAll,
getValue: function(model){
return model.id;
},
getName: function(model){
return model.name;
}
}
]
};
$scope.uploadVolumeForm = {
title: 'Upload Volume',
onSubmit: Volumes.getAll,
fields: [
{
model: 'name',
type: 'input-text',
label: 'name',
},
{
model: 'zoneid',
type: 'select',
label: 'availabilityZone',
options: Zones.getAll,
getValue: function(model){
return model.id;
},
getName: function(model){
return model.name;
}
},
{
model: 'format',
type: 'select',
label: 'format',
options: function(){
return ['RAW', 'VHD', 'OVA', 'QCOW2'];
},
getValue: function(model){
return model;
},
getName: function(model){
return model;
}
},
{
model: 'url',
type: 'input-text',
label: 'url'
},
{
model: 'checksum',
type: 'input-text',
label: 'checksum'
}
],
}
$scope.$watch('view', function(newVal, oldVal){
if(newVal === oldVal) return;
if(newVal === 'volumes') return;
else $location.path('/snapshots');
});
}]);
angular.module("storage").controller("SnapshotsListCtrl", ["$scope", "$location", "snapshots", "Breadcrumbs", function($scope, $location, snapshots, Breadcrumbs){
Breadcrumbs.refresh();
Breadcrumbs.push('Snapshots', '/#/snapshots');
$scope.collection = snapshots;
$scope.view = "snapshots";
$scope.toDisplay = ['volumename', 'intervaltype', 'created', 'state'];
$scope.$watch('view', function(newVal, oldVal){
if(newVal === oldVal) return;
if(newVal === 'snapshots') return;
else $location.path('/volumes');
});
}]);