[Kimchi-devel] [PATCH 2/3] [new-ui] Guests tab
sguimaraes943 at gmail.com
sguimaraes943 at gmail.com
Wed Nov 25 21:25:59 UTC 2015
From: samhenri <samuel.guimaraes at eldorado.org.br>
Signed-off-by: samhenri <samuel.guimaraes at eldorado.org.br>
---
.../plugins/kimchi/ui/css/theme-default/list.css | 330 ----------
.../plugins/kimchi/ui/js/src/kimchi.guest_main.js | 676 +++++++++++++--------
src/wok/plugins/kimchi/ui/pages/guest.html.tmpl | 125 ++--
src/wok/plugins/kimchi/ui/pages/guests.html.tmpl | 33 +-
ui/css/src/modules/_guests.scss | 241 ++++++++
ui/images/theme-default/icon-unknown.png | Bin 761 -> 3797 bytes
6 files changed, 764 insertions(+), 641 deletions(-)
delete mode 100644 src/wok/plugins/kimchi/ui/css/theme-default/list.css
diff --git a/src/wok/plugins/kimchi/ui/css/theme-default/list.css b/src/wok/plugins/kimchi/ui/css/theme-default/list.css
deleted file mode 100644
index 1f75f6c..0000000
--- a/src/wok/plugins/kimchi/ui/css/theme-default/list.css
+++ /dev/null
@@ -1,330 +0,0 @@
-/*
- * Project Kimchi
- *
- * Copyright IBM, Corp. 2013-2015
- *
- * 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.
- */
-.list-vm {
- margin: 10px;
-}
-
-/* Generated at http://colorzilla.com/gradient-editor/ */
-.list-vm>li {
- margin-bottom: 10px;
- background: #ffffff;
- background: -moz-linear-gradient(top, #ffffff 0%, #e5e5e5 100%);
- background: -webkit-gradient(linear, left top, left bottom,
- color-stop(0%, #ffffff), color-stop(100%, #e5e5e5));
- background: -webkit-linear-gradient(top, #ffffff 0%, #e5e5e5 100%);
- background: -o-linear-gradient(top, #ffffff 0%, #e5e5e5 100%);
- background: -ms-linear-gradient(top, #ffffff 0%, #e5e5e5 100%);
- background: linear-gradient(to bottom, #ffffff 0%, #e5e5e5 100%);
- filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff',
- endColorstr='#e5e5e5', GradientType=0);
- border: 1px solid #ccc;
- color: #333;
- -webkit-border-radius: 8px;
- -moz-border-radius: 8px;
- border-radius: 8px;
-}
-
-.list-vm li>* {
- height: 130px;
- display: table-cell;
- vertical-align: top;
- position: relative;
- border-left: 1px solid #ccc;
- border-right: 1px solid #fff;
-}
-
-.list-vm li>*:FIRST-CHILD {
- border-left: none;
-}
-
-.list-vm li>*:LAST-CHILD {
- border-right: none;
-}
-
-.list-vm li>.guest-tile{
- text-align: center;
- vertical-align: middle;
-}
-
-.list-vm .handle {
- display: block;
- width: 50px;
- height: 130px;
- box-sizing: border-box;
- box-shadow: inset 4px 4px 4px #0289e2, inset -4px -4px 4px #04385d;
- background: #0b6bad url(../images/theme-default/arrow_out.png) center
- center no-repeat;
- border-top-right: 1px solid #CCC;
- -webkit-border-top-right-radius: 8px;
- -moz-border-top-right-radius: 8px;
- border-top-right-radius: 8px;
- border-bottom-right: 1px solid #CCC;
- -webkit-border-bottom-right-radius: 8px;
- -moz-border-bottom-right-radius: 8px;
- border-bottom-right-radius: 8px;
-}
-
-.list-vm .subtitle {
- color: #666;
- font-size: 13px;
- text-align: center;
- line-height: 10px;
- font-weight: bold;
-}
-
-.list-vm .tile .imgload {
- display: none;
-}
-
-.list-vm .tile.shutoff .imgactive {
- max-height: 110px;
- max-width: 170px;
- height: auto;
- width: auto;
- display:inline;
- border: none;
- position: relative;
-}
-
-.list-vm .tile.paused .imgactive {
- max-height: 110px;
- max-width: 170px;
- height: auto;
- width: auto;
- display:inline;
- border: none;
- position: relative;
-}
-
-.list-vm .tile.running .imgactive{
- max-height: 110px;
- max-width: 170px;
- height: auto;
- width: auto;
- display:inline;
- border: none;
- cursor: crosshair;
- cursor: -moz-zoom-in;
- cursor: -webkit-zoom-in;
-}
-
-.list-vm .tile .overlay {
- max-height: 110px;
- max-width: 170px;
- height: auto;
- width: auto;
- position:absolute;
- bottom:0;
- right:0;
- display:none;
-}
-
-.guest-type {
- width: 257px;
-}
-
-.guest-cpu {
- width: 90px;
-}
-
-.guest-memory {
- width: 90px;
-}
-
-.guest-network {
- width: 95px;
-}
-
-.guest-storage {
- width: 90px;
-}
-
-.guest-tile {
- width: 190px;
-}
-
-.guest-users {
- width: 93px;
-}
-
-.guest-actions {
- width: 125px;
- min-width: 125px;
-}
-
-.guest-handle {
- width: 50px;
-}
-
-.guest-general {
- padding: 10px;
- border-bottom: 1px solid #ccc;
- width: 237px;
-}
-
-.guest-ip {
- padding: 0 10px;
- border-top: 1px solid #fff;
-}
-
-.guest-general .title {
- color: #666;
- font-size: 16px;
- font-weight: normal;
- height: 25px;
- line-height: 25px;
- text-shadow: -1px -1px 1px #ccc, 1px 1px 1px #fff;
- max-width: 237px;
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
-}
-
-.guest-general .text {
- font-weight: bold;
- color: #999;
- font-size: 11px;
- text-shadow: -1px -1px 1px #ccc, 1px 1px 1px #fff;
-}
-
-.guest-users .top {
- border-bottom: 1px solid #ccc;
- padding: 3px 10px;
-}
-
-.guest-users .bottom {
- border-top: 1px solid #fff;
- padding: 3px 10px;
-}
-
-.guest-users .users {
- height: 45px;
- line-height: 45px;
- background: url(../images/theme-default/icon-user.png) left
- center no-repeat;
- padding-left: 50px;
- font-size: 36px;
- font-weight: bold;
-}
-
-.guest-users .snapshots {
- height: 40px;
- line-height: 40px;
- background: url(../images/theme-default/icon-camera.png) left
- center no-repeat;
- padding-left: 50px;
- font-size: 36px;
- font-weight: bold;
-}
-
-.guest-users .mini-text {
- font-size: 11px;
- font-weight: normal;
- text-shadow: -1px -1px 1px #ccc, 1px 1px 1px #fff;
-}
-
-.guest-actions .top {
- padding: 7px 10px;
- width: 200px;
-}
-
-.guest-actions .top button {
- display: inline-block;
- width: 42px;
- height: 42px;
-}
-
- at -moz-document url-prefix() {
- .guest-actions .top button span {
- margin-left: -3px;
- margin-top: -1px;
- }
-}
-
-.guest-actions .bottom {
- padding: 0 10px;
-}
-
-.list-vm .tile {
- max-width: 170px;
- max-height: 110px;
- width: auto;
- height: auto;
- margin: 10px;
-}
-
-.list-vm .tile:not(.shutoff) && .tile:not(.paused) img {
- box-shadow: -1px -1px 2px rgb(0, 0, 0, .25), 3px 3px 3px #fff;
-}
-
-.list-vm .shutoff {
- position: relative;
- box-shadow: none !important;
-}
-
-.list-vm .shutoff img {
- opacity: 0.4;
-}
-
-.list-vm .paused {
- position: relative;
- box-shadow: none !important;
-}
-
-.list-vm .paused img {
- opacity: 0.6;
-}
-
-.list-title {
- color: #666;
- font-weight: bold;
- font-size: 12px;
- overflow: hidden;
- margin: 10px;
-}
-
-.list-title li {
- display: table-cell;
- padding: 0 1px;
-}
-
-.list-no-result {
- font-size: 16px;
- height: 48px;
- line-height: 48px;
- text-shadow: -1px -1px 1px #ccc, 1px 1px 1px #fff;
- padding-left: 10px;
-}
-
-.guest-pending {
- margin: 10px;
-}
-
-.guest-pending .icon {
- background: url('../images/theme-default/kimchi-loading15x15.gif') no-repeat;
- display: inline-block;
- width: 20px;
- height: 20px;
- vertical-align: middle;
-}
-
-.guest-pending .text {
- color: #666666;
- margin-left: 5px;
- text-shadow: -1px -1px 1px #CCCCCC, 1px 1px 1px #FFFFFF;
-}
diff --git a/src/wok/plugins/kimchi/ui/js/src/kimchi.guest_main.js b/src/wok/plugins/kimchi/ui/js/src/kimchi.guest_main.js
index eb563fb..4ef3a89 100644
--- a/src/wok/plugins/kimchi/ui/js/src/kimchi.guest_main.js
+++ b/src/wok/plugins/kimchi/ui/js/src/kimchi.guest_main.js
@@ -46,19 +46,29 @@ kimchi.sampleGuestObject = {
};
kimchi.vmstart = function(event) {
- var button=$(this);
- if (!button.hasClass('loading')) {
- button.addClass('loading');
- var vm=$(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+ var button = event.target;
+ if (!$(button).hasClass('loading')) {
+ $(button).addClass('loading');
+ var vm = button.closest('li[name=guest]');
+ var vm_id = $(vm).attr("id");
+ // setting up css class when starting
+ $(vm).find('.guest-state').removeClass('shutoff');
+ $(vm).find('.guest-state').addClass('starting');
+ $(vm).find('.progress').css("display", "none");
+ $(vm).find('.percentage - label').html('--');
+ $(vm).find('.measure-label').html('--');
+ $(vm).find('.guest-actions').css("margin-top", "3px");
+ $(vm).addClass('inactive');
+ $(vm).find('.distro-icon').addClass('inactive');
+ $(vm).find('.vnc-link').css("display", "none");
+ $(vm).find('.column-vnc').html('--');
kimchi.startVM(vm_id, function(result) {
- button.removeClass('loading');
+ $(button).removeClass('loading');
kimchi.listVmsAuto();
- }, function(err) {
- button.removeClass('loading');
- wok.message.error(err.responseJSON.reason);
- }
- );
+ }, function(err) {
+ $(button).removeClass('loading');
+ wok.message.error(err.responseJSON.reason);
+ });
} else {
event.preventDefault();
event.stopPropagation();
@@ -67,19 +77,18 @@ kimchi.vmstart = function(event) {
};
kimchi.vmsuspend = function(event) {
- var button=$(this);
- if (!button.hasClass('pause-gray')) {
- button.addClass('pause-gray');
- var vm=$(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+ var button = event.target;
+ if (!$(button).hasClass('pause-gray')) {
+ $(button).addClass('pause-gray');
+ var vm = button.closest('li[name=guest]');
+ var vm_id = $(vm).attr("id");
kimchi.suspendVM(vm_id, function(result) {
- button.removeClass('pause-gray');
+ $(button).removeClass('pause-gray');
kimchi.listVmsAuto();
- }, function(err) {
- button.removeClass('pause-gray');
- wok.message.error(err.responseJSON.reason);
- }
- );
+ }, function(err) {
+ $(button).removeClass('pause-gray');
+ wok.message.error(err.responseJSON.reason);
+ });
} else {
event.preventDefault();
event.stopPropagation();
@@ -88,19 +97,18 @@ kimchi.vmsuspend = function(event) {
};
kimchi.vmresume = function(event) {
- var button=$(this);
- if (!button.hasClass('resume-gray')) {
- button.addClass('resume-gray');
- var vm=$(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+ var button = event.target;
+ if (!$(button).hasClass('resume-gray')) {
+ $(button).addClass('resume-gray');
+ var vm = button.closest('li[name=guest]');
+ var vm_id = vm.attr("id");
kimchi.resumeVM(vm_id, function(result) {
- button.removeClass('resume-gray');
+ $(button).removeClass('resume-gray');
kimchi.listVmsAuto();
- }, function(err) {
- button.removeClass('resume-gray');
- wok.message.error(err.responseJSON.reason);
- }
- );
+ }, function(err) {
+ $(button).removeClass('resume-gray');
+ wok.message.error(err.responseJSON.reason);
+ });
} else {
event.preventDefault();
event.stopPropagation();
@@ -109,84 +117,95 @@ kimchi.vmresume = function(event) {
};
kimchi.vmpoweroff = function(event) {
- var button=$(this);
- if (!button.hasClass('loading')) {
- button.addClass('loading');
- var vm=button.closest('li[name=guest]');
- var vm_id=vm.attr("id");
- var vmObject=vm.data();
- var vm_persistent=vmObject.persistent == true;
+ var button = event.target;
+ if (!$(button).hasClass('loading')) {
+ $(button).addClass('loading');
+ var vm = button.closest('li[name=guest]');
+ var vm_id = vm.attr("id");
+ var vmObject = vm.data();
+ var vm_persistent = vmObject.persistent == true;
var content_msg = vm_persistent ? i18n['KCHVM6003M'] :
i18n['KCHVM6009M'];
var settings = {
- title : i18n['KCHVM6002M'],
- content : content_msg,
- confirm : i18n['KCHAPI6002M'],
- cancel : i18n['KCHAPI6003M']
+ title: i18n['KCHVM6002M'],
+ content: content_msg,
+ confirm: i18n['KCHAPI6002M'],
+ cancel: i18n['KCHAPI6003M']
};
wok.confirm(settings, function() {
kimchi.poweroffVM(vm_id, function(result) {
- button.removeClass('loading');
+ $(button).removeClass('loading');
kimchi.listVmsAuto();
}, function(err) {
wok.message.error(err.responseJSON.reason);
});
- }, function() {
- });
+ }, function() {});
} else {
event.preventDefault();
event.stopPropagation();
}
};
-kimchi.vmshutdown = function(event){
- var vm=$(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+kimchi.vmshutdown = function(event) {
+ var button = event.target;
+ var vm = button.closest('li[name=guest]');
+ var vm_id = vm.attr("id");
var settings = {
- title : i18n['KCHVM6006M'],
- content : i18n['KCHVM6007M'],
- confirm : i18n['KCHAPI6002M'],
- cancel : i18n['KCHAPI6003M']
+ title: i18n['KCHVM6006M'],
+ content: i18n['KCHVM6007M'],
+ confirm: i18n['KCHAPI6002M'],
+ cancel: i18n['KCHAPI6003M']
};
wok.confirm(settings, function() {
kimchi.shutdownVM(vm_id, function(result) {
- kimchi.listVmsAuto();
- }, function(err) {
- wok.message.error(err.responseJSON.reason);
- }
- );
- }, function() {
- });
+ kimchi.listVmsAuto();
+ }, function(err) {
+ wok.message.error(err.responseJSON.reason);
+ });
+ }, function() {});
};
-kimchi.vmreset = function(event){
- var vm=$(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
- var settings = {
- title : i18n['KCHVM6004M'],
- content : i18n['KCHVM6005M'],
- confirm : i18n['KCHAPI6002M'],
- cancel : i18n['KCHAPI6003M']
- };
- wok.confirm(settings, function() {
- kimchi.resetVM(vm_id, function(result) {
+kimchi.vmreset = function(event) {
+ var button = event.target;
+ if (!$(button).hasClass('loading')) {
+ $(button).addClass('loading');
+ var vm = button.closest('li[name=guest]');
+ var vm_id = $(vm).attr("id");
+ var settings = {
+ title: i18n['KCHVM6004M'],
+ content: i18n['KCHVM6005M'],
+ confirm: i18n['KCHAPI6002M'],
+ cancel: i18n['KCHAPI6003M']
+ };
+ wok.confirm(settings, function() {
+ // setting up css class when resetting
+ $(vm).find('.guest-state').removeClass('running');
+ $(vm).find('.guest-state').addClass('resetting');
+ $(vm).find('.fa-spin').addClass('active');
+ kimchi.resetVM(vm_id, function(result) {
+ $(button).removeClass('loading');
kimchi.listVmsAuto();
}, function(err) {
+ $(button).removeClass('loading');
wok.message.error(err.responseJSON.reason);
- }
- );
- }, function() {
- });
+ });
+ }, function() {});
+ } else {
+ event.preventDefault();
+ event.stopPropagation();
+ return;
+ }
};
kimchi.vmdelete = function(event) {
- var vm = $(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+ var button = event.target;
+ var vm = button.closest('li[name=guest]');
+ var vm_id = $(vm).attr("id");
var settings = {
- title : i18n['KCHVM6008M'],
- content : i18n['KCHVM6001M'],
- confirm : i18n['KCHAPI6002M'],
- cancel : i18n['KCHAPI6003M']
+ title: i18n['KCHVM6008M'],
+ content: i18n['KCHVM6001M'],
+ confirm: i18n['KCHAPI6002M'],
+ cancel: i18n['KCHAPI6003M']
};
wok.confirm(settings, function() {
kimchi.deleteVM(vm_id, function(result) {
@@ -194,13 +213,13 @@ kimchi.vmdelete = function(event) {
}, function(err) {
wok.message.error(err.responseJSON.reason);
});
- }, function() {
- });
+ }, function() {});
};
kimchi.vmedit = function(event) {
- var vm = $(this).closest('li[name=guest]');
- var vm_id=vm.attr("id");
+ var button = event.target;
+ var vm = button.closest('li[name=guest]');
+ var vm_id = $(vm).attr("id");
kimchi.selectedGuest = vm_id;
wok.window.open({
url: 'plugins/kimchi/guest-edit.html',
@@ -211,13 +230,13 @@ kimchi.vmedit = function(event) {
};
kimchi.openVmConsole = function(event) {
- var vm=$(this).closest('li[name=guest]');
- var vmObject=vm.data();
+ var button = event.target;
+ var vm = button.closest('li[name=guest]');
+ var vmObject = $(vm).data();
if (vmObject.graphics['type'] == 'vnc') {
- kimchi.vncToVM(vm.attr('id'));
- }
- else if (vmObject.graphics['type'] == 'spice') {
- kimchi.spiceToVM(vm.attr('id'));
+ kimchi.vncToVM($(vm).attr('id'));
+ } else if (vmObject.graphics['type'] == 'spice') {
+ kimchi.spiceToVM($(vm).attr('id'));
}
};
@@ -232,95 +251,149 @@ kimchi.getVmsCurrentConsoleImgs = function() {
kimchi.getOpenMenuVmId = function() {
var result;
- var openMenu = $('#guestList div[name="actionmenu"] .popover:visible');
- if(openMenu) {
- var li_element=openMenu.closest('li');
- result=li_element.attr('id');
+ var openMenu = $('#guestList div[name="actionmenu"] .dropdown-menu:visible');
+ if (openMenu) {
+ var li_element = openMenu.closest('li');
+ result = li_element.attr('id');
}
return result;
};
kimchi.listVmsAuto = function() {
- if (kimchi.vmTimeout) {
- clearTimeout(kimchi.vmTimeout);
- }
- var getCreatingGuests = function(){
- var guests = [];
- kimchi.getTasksByFilter('status=running&target_uri='+encodeURIComponent('^/plugins/kimchi/vms/[^/]+$'), function(tasks) {
- for(var i=0;i<tasks.length;i++){
- var guestUri = tasks[i].target_uri;
- var guestName = guestUri.split('/')[4]
- guests.push($.extend({}, kimchi.sampleGuestObject, {name: guestName, isCreating: true}));
- if(kimchi.trackingTasks.indexOf(tasks[i].id)==-1)
- kimchi.trackTask(tasks[i].id, null, function(err){
- wok.message.error(err.message);
- }, null);
- }
- }, null, true);
- return guests;
- };
- var getCloningGuests = function(){
- var guests = [];
- kimchi.getTasksByFilter('status=running&target_uri='+encodeURIComponent('^/plugins/kimchi/vms/.+/clone'), function(tasks) {
- for(var i=0;i<tasks.length;i++){
- var guestUri = tasks[i].target_uri;
- var guestName = guestUri.split('/')[4]
- guests.push($.extend({}, kimchi.sampleGuestObject, {name: guestName, isCloning: true}));
- if(kimchi.trackingTasks.indexOf(tasks[i].id)==-1)
- kimchi.trackTask(tasks[i].id, null, function(err){
- wok.message.error(err.message);
- }, null);
- }
- }, null, true);
- return guests;
- };
- kimchi.listVMs(function(result, textStatus, jqXHR) {
- if (result && textStatus=="success") {
- result = getCloningGuests().concat(result);
- result = getCreatingGuests().concat(result);
- if(result.length) {
- var listHtml = '';
- var guestTemplate = kimchi.guestTemplate;
- var currentConsoleImages = kimchi.getVmsCurrentConsoleImgs();
- var openMenuGuest = kimchi.getOpenMenuVmId();
- $('#guestList').empty();
- $('#guestListField').show();
- $('#noGuests').hide();
-
- $.each(result, function(index, vm) {
- var guestLI = kimchi.createGuestLi(vm, currentConsoleImages[vm.name], vm.name==openMenuGuest);
- $('#guestList').append(guestLI);
- });
- } else {
- $('#guestListField').hide();
- $('#noGuests').show();
- }
- }
-
- kimchi.vmTimeout = window.setTimeout("kimchi.listVmsAuto();", 5000);
- }, function(errorResponse, textStatus, errorThrown) {
- if(errorResponse.responseJSON && errorResponse.responseJSON.reason) {
- wok.message.error(errorResponse.responseJSON.reason);
+ //Check if the actions button is opened or not,
+ //if opended stop the reload of the itens until closed
+ var $isDropdownOpened = $('[name="guest-actions"] ul.dropdown-menu').is(":visible");
+ if (!$isDropdownOpened) {
+ if (kimchi.vmTimeout) {
+ clearTimeout(kimchi.vmTimeout);
}
+ var getCreatingGuests = function() {
+ var guests = [];
+ kimchi.getTasksByFilter('status=running&target_uri=' + encodeURIComponent('^/plugins/kimchi/vms/[^/]+$'), function(tasks) {
+ for (var i = 0; i < tasks.length; i++) {
+ var guestUri = tasks[i].target_uri;
+ var guestName = guestUri.split('/')[2]
+ guests.push($.extend({}, kimchi.sampleGuestObject, {
+ name: guestName,
+ isCreating: true
+ }));
+ if (kimchi.trackingTasks.indexOf(tasks[i].id) == -1)
+ kimchi.trackTask(tasks[i].id, null, function(err) {
+ wok.message.error(err.message);
+ }, null);
+ }
+ }, null, true);
+ return guests;
+ };
+ var getCloningGuests = function() {
+ var guests = [];
+ kimchi.getTasksByFilter('status=running&target_uri=' + encodeURIComponent('^/plugins/kimchi/vms/.+/clone'), function(tasks) {
+ for (var i = 0; i < tasks.length; i++) {
+ var guestUri = tasks[i].target_uri;
+ var guestName = guestUri.split('/')[2]
+ guests.push($.extend({}, kimchi.sampleGuestObject, {
+ name: guestName,
+ isCloning: true
+ }));
+ if (kimchi.trackingTasks.indexOf(tasks[i].id) == -1)
+ kimchi.trackTask(tasks[i].id, null, function(err) {
+ wok.message.error(err.message);
+ }, null);
+ }
+ }, null, true);
+ return guests;
+ };
+ kimchi.listVMs(function(result, textStatus, jqXHR) {
+ if (result && textStatus == "success") {
+ result = getCloningGuests().concat(result);
+ result = getCreatingGuests().concat(result);
+ if (result.length) {
+ var listHtml = '';
+ var guestTemplate = kimchi.guestTemplate;
+ var currentConsoleImages = kimchi.getVmsCurrentConsoleImgs();
+ var openMenuGuest = kimchi.getOpenMenuVmId();
+ $('#guestList').empty();
+ $('#guestListField').show();
+ $('#noGuests').hide();
+
+ $.each(result, function(index, vm) {
+ var guestLI = kimchi.createGuestLi(vm, currentConsoleImages[vm.name], vm.name == openMenuGuest);
+ $('#guestList').append(guestLI);
+ });
+ } else {
+ $('#guestListField').hide();
+ $('#noGuests').show();
+ }
+ }
+
+ kimchi.vmTimeout = window.setTimeout("kimchi.listVmsAuto();", 5000);
+ },
+ function(errorResponse, textStatus, errorThrown) {
+ if (errorResponse.responseJSON && errorResponse.responseJSON.reason) {
+ wok.message.error(errorResponse.responseJSON.reason);
+ }
+ kimchi.vmTimeout = window.setTimeout("kimchi.listVmsAuto();", 5000);
+ });
+ } else {
+ clearTimeout(kimchi.vmTimeout);
kimchi.vmTimeout = window.setTimeout("kimchi.listVmsAuto();", 5000);
- });
+ }
};
+
kimchi.createGuestLi = function(vmObject, prevScreenImage, openMenu) {
- var result=kimchi.guestElem.clone();
-
+ var result = kimchi.guestElem.clone();
+
//Setup the VM list entry
- var vmRunningBool=(vmObject.state=="running");
- var vmSuspendedBool = (vmObject.state=="paused");
- var vmPoweredOffBool = (vmObject.state=="shutoff");
+ var currentState = result.find('.guest-state');
+ var vmRunningBool = (vmObject.state == "running");
+ var vmSuspendedBool = (vmObject.state == "paused");
+ var vmPoweredOffBool = (vmObject.state == "shutoff");
var vmPersistent = (vmObject.persistent == true);
- result.attr('id',vmObject.name);
+
+ if (vmObject.state !== 'undefined') {
+ currentState.addClass(vmObject.state);
+ };
+ result.attr('id', vmObject.name);
result.data(vmObject);
//Add the Name
- var guestTitle=result.find('.title').attr('title',vmObject.name);
+ var guestTitle = result.find('.title').attr('val', vmObject.name);
guestTitle.html(vmObject.name);
+ //Add the OS Type and Icon
+ var osType = result.find('.distro-icon');
+ if (vmObject.icon == 'plugins/kimchi/images/icon-fedora.png') {
+ osType.addClass('icon-fedora');
+ osType.attr('val', 'Fedora');
+ osType.html('Fedora');
+ } else if (vmObject.icon == 'plugins/kimchi/images/icon-ubuntu.png') {
+ osType.addClass('icon-ubuntu');
+ osType.attr('val', 'Ubuntu');
+ osType.html('Ubuntu');
+ } else if (vmObject.icon == 'plugins/kimchi/images/icon-centos.png') {
+ osType.addClass('icon-centos');
+ osType.attr('val', 'Centos');
+ osType.html('Centos');
+ } else if (vmObject.icon == 'plugins/kimchi/images/icon-opensuse.png') {
+ osType.addClass('icon-opensuse');
+ osType.attr('val', 'openSUSE');
+ osType.html('openSUSE');
+ } else if (vmObject.icon == 'plugins/kimchi/images/icon-gentoo.png') {
+ osType.addClass('icon-gentoo');
+ osType.attr('val', 'Gentoo');
+ osType.html('Gentoo');
+ } else if (vmObject.icon == 'plugins/kimchi/images/icon-debian.png') {
+ osType.addClass('icon-debian');
+ osType.attr('val', 'Debian');
+ osType.html('Debian');
+ } else {
+ //Unknown
+ osType.addClass('icon-unknown');
+ osType.attr('val', 'Unknown');
+ osType.html('Unknown');
+ }
+
//Setup the VM console thumbnail display
var curImg = vmObject.icon;
if (vmObject.screenshot) {
@@ -328,56 +401,133 @@ kimchi.createGuestLi = function(vmObject, prevScreenImage, openMenu) {
}
var load_src = curImg || 'plugins/kimchi/images/icon-vm.png';
var tile_src = prevScreenImage || vmObject['load-src'];
- var liveTile=result.find('div[name=guest-tile] > .tile');
+ var liveTile = result.find('div[name=guest-tile] > .tile');
liveTile.addClass(vmObject.state);
- liveTile.find('.imgactive').attr('src',tile_src);
- var imgLoad=liveTile.find('.imgload');
+ liveTile.find('.imgactive').attr('src', tile_src);
+ var imgLoad = liveTile.find('.imgload');
imgLoad.on('load', function() {
- var oldImg=$(this).parent().find('.imgactive');
- oldImg.removeClass("imgactive").addClass("imgload");
- oldImg.attr("src","");
- $(this).addClass("imgactive").removeClass("imgload");
- $(this).off('load');
- });
- imgLoad.attr('src',load_src);
+ var oldImg = $(this).parent().find('.imgactive');
+ oldImg.removeClass("imgactive").addClass("imgload");
+ oldImg.attr("src", "");
+ $(this).addClass("imgactive").removeClass("imgload");
+ $(this).off('load');
+ });
+ imgLoad.attr('src', load_src);
//Link the stopped tile to the start action, the running tile to open the console, and the paused tile to resume
- if(!(vmObject.isCloning || vmObject.isCreating)){
+ if (!(vmObject.isCloning || vmObject.isCreating)) {
if (vmPoweredOffBool) {
- liveTile.off("click", kimchi.openVmConsole);
- liveTile.off("click", kimchi.vmresume);
- liveTile.on("click", kimchi.vmstart);
- liveTile.hover(function(event){$(this).find('.overlay').show()}, function(event){$(this).find('.overlay').hide()});
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.vmresume(event);
+ });
+ liveTile.on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmstart(event);
+ });
+ liveTile.hover("click", function(event) {
+ event.preventDefault();
+ $(this).find('.overlay').show()
+ }, function(event) {
+ $(this).find('.overlay').hide()
+ });
} else if (vmSuspendedBool) {
- liveTile.off("click", kimchi.vmstart);
- liveTile.off("click", kimchi.openVmConsole);
- liveTile.on("click", kimchi.vmresume);
- if(vmObject.state="paused") {
- liveTile.find('.overlay').attr('src',"plugins/kimchi/images/theme-default/ac24_resume.png");
- liveTile.find('.overlay').attr('alt',"Resume");
- }
- liveTile.hover(function(event){$(this).find('.overlay').show()}, function(event){$(this).find('.overlay').hide()});
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.vmstart(event);
+ });
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
+ liveTile.on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmresume(event);
+ });
+ liveTile.hover("click", function(event) {
+ event.preventDefault();
+ $(this).find('.overlay').show()
+ }, function(event) {
+ $(this).find('.overlay').hide()
+ });
+ if (vmObject.state = "paused") {
+ liveTile.find('.overlay').attr('src', "plugins/kimchi/images/theme-default/ac24_resume.png");
+ liveTile.find('.overlay').attr('alt', "Resume");
+ }
+ liveTile.hover(function(event) {
+ $(this).find('.overlay').show()
+ }, function(event) {
+ $(this).find('.overlay').hide()
+ });
} else {
- liveTile.off("click", kimchi.vmstart);
- liveTile.off("click", kimchi.vmresume);
- liveTile.on("click", kimchi.openVmConsole);
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.vmstart(event);
+ });
+ liveTile.off("click", function(event) {
+ event.preventDefault();
+ kimchi.vmresume(event);
+ });
+ liveTile.on("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
}
}
- //Setup the gauges
- var stats=vmObject.stats;
- var gaugeValue=0;
- gaugeValue=parseInt(stats.net_throughput);
- kimchi.circleGaugeInit(result, "net_throughput",gaugeValue,(gaugeValue*100/stats.net_throughput_peak));
- gaugeValue=parseInt(stats.io_throughput);
- kimchi.circleGaugeInit(result, "io_throughput",gaugeValue,(gaugeValue*100/stats.io_throughput_peak));
- gaugeValue=parseInt(stats.cpu_utilization);
- kimchi.circleGaugeInit(result, "cpu_utilization",gaugeValue+"%",gaugeValue);
- gaugeValue=parseInt(stats.mem_utilization);
- kimchi.circleGaugeInit(result, "mem_utilization",gaugeValue+"%",gaugeValue);
+ //Setup progress bars
+ if (!vmPoweredOffBool) {
+ var cpuUtilization = 0;
+ var cpuMaxThreshold = 80;
+ var cpuMediumThreshold = 60;
+ cpuUtilization = parseInt(vmObject.stats.cpu_utilization);
+ result.find('.cpu-progress-bar').width(cpuUtilization + '%');
+ result.find('.processors-percentage').html(cpuUtilization + '%');
+ result.find('.medium-grey.cpu').width(cpuMaxThreshold + '%');
+ result.find('.light-grey.cpu').width(cpuMediumThreshold + '%');
+
+ var memoryUtilization = 0;
+ var memoryMaxThreshold = 80;
+ var memoryMediumThreshold = 60;
+ memoryUtilization = parseInt(vmObject.stats.mem_utilization);
+ result.find('.memory-progress-bar').width(memoryUtilization + '%');
+ result.find('.memory-percentage').html(memoryUtilization + '%');
+ result.find('.medium-grey.memory').width(memoryMaxThreshold + '%');
+ result.find('.light-grey.memory').width(memoryMediumThreshold + '%');
+
+ var ioThroughput = 0;
+ var ioMaxThreshold = 80;
+ var ioMediumThreshold = 60;
+ ioValue = parseInt(vmObject.stats.io_throughput);
+ ioThroughput = (ioValue * 100 / vmObject.stats.io_throughput_peak);
+ result.find('.storage-progress-bar').width(ioThroughput + '%');
+ result.find('.storage-percentage').html(Math.round(ioThroughput) + 'KB/s');
+ result.find('.medium-grey.io').width(ioMaxThreshold + '%');
+ result.find('.light-grey.io').width(ioMediumThreshold + '%');
+
+ var netThroughput = 0;
+ var netMaxThreshold = 80;
+ var netMediumThreshold = 60;
+ netValue = parseInt(vmObject.stats.net_throughput);
+ netThroughput = (netValue * 100 / vmObject.stats.net_throughput_peak);
+ result.find('.network-progress-bar').width(netThroughput + '%');
+ result.find('.network-percentage').html(Math.round(netThroughput) + 'KB/s');
+ result.find('.medium-grey.network').width(netMaxThreshold + '%');
+ result.find('.light-grey.network').width(netMediumThreshold + '%');
+ } else {
+ result.find('.progress').css("display", "none");
+ result.find('.percentage-label').html('--');
+ result.find('.measure-label').html('--');
+ result.find('.measure-label').html('--');
+ result.find('.guest-actions').css("margin-top", "3px");
+ }
//Setup the VM Actions
- var guestActions=result.find("div[name=guest-actions]");
+ var guestActions = result.find("div[name=guest-actions]");
guestActions.find(".shutoff-disabled").prop("disabled", !vmRunningBool);
guestActions.find(".running-disabled").prop("disabled", vmRunningBool);
guestActions.find(".non-persistent-disabled").prop("disabled", !vmPersistent);
@@ -390,7 +540,7 @@ kimchi.createGuestLi = function(vmObject, prevScreenImage, openMenu) {
//Hide Pause button and menu
guestActions.find(".pause-disabled").hide();
guestActions.find(".pause-hidden").hide();
- }
+ }
if (vmRunningBool) { //VM IS running
//Hide Start
@@ -400,6 +550,10 @@ kimchi.createGuestLi = function(vmObject, prevScreenImage, openMenu) {
}
if (vmPoweredOffBool) { //VM is powered off
+ result.addClass('inactive');
+ result.find('.distro-icon').addClass('inactive');
+ result.find('.vnc-link').css("display", "none");
+ result.find('.column-vnc').html('--');
//Hide PowerOff
guestActions.find(".shutoff-hidden").hide();
//Hide Pause
@@ -408,98 +562,116 @@ kimchi.createGuestLi = function(vmObject, prevScreenImage, openMenu) {
guestActions.find(".resume-hidden").hide();
}
- var consoleActions=guestActions.find("[name=vm-console]");
+ var consoleActions = guestActions.find("[name=vm-console]");
+ var consoleLinkActions = result.find(".vnc-link");
if ((vmObject.graphics['type'] == 'vnc') || (vmObject.graphics['type'] == 'spice')) {
- consoleActions.on("click", kimchi.openVmConsole);
+ consoleActions.on("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
+ consoleLinkActions.on("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
consoleActions.show();
- } else { //we don't recognize the VMs supported graphics, so hide the menu choice
+ } else { //we don't recognize the VMs supported graphics, so hide the menu choice
consoleActions.hide();
- consoleActions.off("click",kimchi.openVmConsole);
+ consoleActions.off("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
+ consoleLinkActions.off("click", function(event) {
+ event.preventDefault();
+ kimchi.openVmConsole(event);
+ });
}
//Setup action event handlers
- if(!(vmObject.isCloning || vmObject.isCreating)){
- guestActions.find("[name=vm-start]").on({click : kimchi.vmstart});
- guestActions.find("[name=vm-poweroff]").on({click : kimchi.vmpoweroff});
- if ((vmRunningBool) || (vmSuspendedBool)) {
- //If the guest is not running, do not enable reset; otherwise, reset is enabled (when running or paused)
- guestActions.find("[name=vm-reset]").on({click : kimchi.vmreset});
+ if (!(vmObject.isCloning || vmObject.isCreating)) {
- //If the guest is not running, do not enable shutdown;otherwise, shutdown is enabled (when running or paused)
- guestActions.find("[name=vm-shutdown]").on({click : kimchi.vmshutdown});
+ guestActions.find("[name=vm-start]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmstart(event);
+ });
+ guestActions.find("[name=vm-poweroff]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmpoweroff(event);
+ });
+ if ((vmRunningBool) || (vmSuspendedBool)) {
+ //If the guest is not running, do not enable reset; otherwise, reset is enabled (when running or paused)
+ guestActions.find("[name=vm-reset]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmreset(event);
+ });
+ //If the guest is not running, do not enable shutdown;otherwise, shutdown is enabled (when running or paused)
+ guestActions.find("[name=vm-shutdown]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmshutdown(event);
+ });
}
if (vmSuspendedBool) {
- guestActions.find("[name=vm-resume]").on({click : kimchi.vmresume});
+ guestActions.find("[name=vm-resume]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmresume(event);
+ });
}
if (vmRunningBool) {
- guestActions.find("[name=vm-pause]").on({click : kimchi.vmsuspend});
+ guestActions.find("[name=vm-pause]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmsuspend(event);
+ });
}
- guestActions.find("[name=vm-edit]").on({click : kimchi.vmedit});
- guestActions.find("[name=vm-delete]").on({click : kimchi.vmdelete});
- guestActions.find("[name=vm-clone]").click(function(){
+ guestActions.find("[name=vm-edit]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmedit(event);
+ });
+ guestActions.find("[name=vm-delete]").on("click", function(event) {
+ event.preventDefault();
+ kimchi.vmdelete(event);
+ });
+ guestActions.find("[name=vm-clone]").on("click", function(event) {
+ event.preventDefault();
var guest = $(this).closest('li[name=guest]').attr("id");
wok.confirm({
- title : i18n['KCHAPI6006M'],
- content : i18n['KCHVM6010M'],
- confirm : i18n['KCHAPI6002M'],
- cancel : i18n['KCHAPI6003M']
+ title: i18n['KCHAPI6006M'],
+ content: i18n['KCHVM6010M'],
+ confirm: i18n['KCHAPI6002M'],
+ cancel: i18n['KCHAPI6003M']
}, function() {
- kimchi.cloneGuest(guest, function(data){
+ kimchi.cloneGuest(guest, function(data) {
kimchi.listVmsAuto();
});
}, null);
});
-
- //Maintain menu open state
- var actionMenu=guestActions.find("div[name=actionmenu]");
- if (openMenu) {
- $('.popover', actionMenu).toggle();
- }
-
- }else{
+ } else {
guestActions.find('.btn').attr('disabled', true);
- $('.popover', guestActions.find("div[name=actionmenu]")).remove();
-
result.find('.guest-pending').removeClass('hide-content');
pendingText = result.find('.guest-pending .text')
- if(vmObject.isCloning)
+ if (vmObject.isCloning)
pendingText.text(i18n['KCHAPI6009M']);
else
pendingText.text(i18n['KCHAPI6008M']);
}
-
return result;
};
-kimchi.circleGaugeInit = function(topElement, divName, display, percentage){
- var gauge=topElement.find('div[name="' + divName + '"] .circleGauge');
- if(gauge) {
- var data=Object();
- data.percentage = percentage;
- data.display = display;
- gauge.data(data);
- }
- gauge.circleGauge();
- return(gauge);
-};
-
kimchi.guestSetRequestHeader = function(xhr) {
xhr.setRequestHeader('Accept', 'text/html');
};
kimchi.guest_main = function() {
- if(wok.tabMode['guests'] === 'admin') {
- $('.tools').attr('style','display');
+ if (wok.tabMode['guests'] === 'admin') {
+ $('.tools').attr('style', 'display');
$("#vm-add").on("click", function(event) {
wok.window.open('plugins/kimchi/guest-add.html');
});
}
kimchi.guestTemplate = $('#guest-tmpl').html();
- kimchi.guestElem=$('<div/>').html(kimchi.guestTemplate).find('li');
+ kimchi.guestElem = $('<div/>').html(kimchi.guestTemplate).find('li[name="guest"]');
$('#guests-root-container').on('remove', function() {
kimchi.vmTimeout && clearTimeout(kimchi.vmTimeout);
});
diff --git a/src/wok/plugins/kimchi/ui/pages/guest.html.tmpl b/src/wok/plugins/kimchi/ui/pages/guest.html.tmpl
index 4aba5ad..52f595d 100644
--- a/src/wok/plugins/kimchi/ui/pages/guest.html.tmpl
+++ b/src/wok/plugins/kimchi/ui/pages/guest.html.tmpl
@@ -21,60 +21,87 @@
#silent t = gettext.translation($lang.domain, $lang.localedir, languages=$lang.lang, fallback=True)
#silent _ = t.gettext
#silent _t = t.gettext
- <li name="guest" class="guest">
- <div class="sortable guest-type">
- <div class="guest-general">
- <h2 class="title" title="{name}">{name}</h2>
- </div>
- <div class="guest-pending hide-content">
- <span class="icon"></span><span class="text"></span>
- </div>
- </div>
- <div name="cpu_utilization" class="sortable">
- <div class="circleGauge"></div>
- </div>
- <div name="mem_utilization" class="sortable">
- <div class="circleGauge"></div>
- </div>
- <div name="io_throughput" class="sortable">
- <div class="circleGauge"></div>
- <div class="subtitle">KB/s</div>
- </div>
- <div name="net_throughput" class="sortable">
- <div class="circleGauge"></div>
- <div class="subtitle">KB/s</div>
- </div>
- <div name="guest-tile" class="sortable guest-tile">
+ <li name="guest" class="wok-guest-list-body">
+ <span class='column-state'>
+ <span class='guest-state'>
+ <i class="fa fa-power-off"></i>
+ <i class="fa fa-ban"></i>
+ <i class="fa fa-undo"></i>
+ <i class="fa fa-refresh fa-spin"></i>
+ </span>
+ </span><!--
+ --><span class='column-name title'></span><!--
+ --><span class='column-action pull-right'>
+ <span class="pull-right">
+ <div class="dropdown menu-flat guest-actions" name="guest-actions" style="margin-top: 6px">
+ <button class="btn btn-primary dropdown-toggle" type="button" data-toggle="dropdown" aria-expanded="false"><span class="edit-alt"></span>$_("Actions")<span class="caret"></span>
+ </button>
+ <ul class="dropdown-menu" role="menu">
+ <li role="presentation"><a nwAct="connect-vnc" class='shutoff-disabled' name="vm-console" href="#"><i class="fa fa-list-alt"></i>$_("Connect VNC")</a></li>
+ <!-- <li role="presentation"><a nwAct="view-vnc" class='shutoff-disabled' name="vm-view-vnc" href="#"><i class="fa fa-eye"></i>$_("View VNC Console")</a></li> -->
+ <li role="presentation"><a nwAct="edit" name="vm-edit" href="#"><i class="fa fa-pencil"></i>$_("Edit")</a></li>
+ <li role="presentation"><a href="#" nwAct="clone" class='running-disabled' name="vm-clone"><i class="fa fa-share-alt"></i>$_("Clone")</a></li>
+ <li role="presentation"><a nwAct="reset" class='shutoff-hidden non-persistent-disabled' name="vm-reset" href="#"><i class="fa fa-refresh"></i>$_("Reset")</a></li>
+ <li role="presentation"><a nwAct="pause" class='pause-hidden non-persistent-disabled' name="vm-pause" href="#"><i class="fa fa-pause"></i>$_("Pause")</a></li>
+ <li role="presentation"><a nwAct="resume" class='resume-hidden' name="vm-resume" href="#"><i class="fa fa-play-circle"></i>$_("Resume")</a></li>
+ <li role="presentation"><a nwAct="shutdown" class='shutoff-hidden' name="vm-shutdown" href="#"><i class="fa fa-ban"></i>$_("Shut Down")</a></li>
+ <li role="presentation"><a nwAct="start" class='running-hidden' name="vm-start" href="#"><i class="fa fa-power-off"></i>$_("Start")</a></li>
+ <li role="presentation"><a nwAct="power-off" class='shutoff-hidden' name="vm-poweroff" href="#"><i class="fa fa-power-off"></i>$_("Power Off")</a></li>
+ <li role="presentation" class='critical'><a nwAct="delete" class='non-persistent-disabled' name="vm-delete" href="#"><i class="fa fa-minus-circle"></i>$_("Delete")</a></li>
+ </ul>
+ </div>
+ </span>
+ </span><!--
+ --><span name="guest-tile" class="sortable guest-tile item-hidden">
<div class="tile ">
<img class="imgactive" alt="" src="">
<img class="imgload" alt="" src="">
<img class="overlay shutoff-hidden" alt="$_("Start")" src="plugins/kimchi/images/theme-default/icon-power-down.png" >
</div>
- </div>
- <div class="sortable guest-actions" name="guest-actions">
- <div class="top">
- <button class="btn reset-disabled" name="vm-reset" href="javascript:void(0);" title="$_("Reset")"><span class="icon reset"></span></button>
- <button class="btn pause-disabled" name="vm-pause" href="javascript:void(0);" title="$_("Pause")"><span class="icon pause"></span></button>
- <button class="btn resume-hidden" name="vm-resume" href="javascript:void(0);" title="$_("Resume")"><span class="icon resume"></span></button>
- <button class="btn running-hidden" name="vm-start" href="javascript:void(0);" title="$_("Start")"><span class="icon power-down"></span></button>
- <button class="btn shutoff-hidden" name="vm-poweroff" href="javascript:void(0);" title="$_("Power Off")"><span class="icon power-up"></span></button>
+ </span><!--
+ --><span class='column-type distro-icon' style='padding-left: 40px !important'></span><!--
+ --><span class='column-vnc'><i class="fa fa-spinner fa-spin"></i><a nwAct="connect-vnc" name="vm-console" class="vnc-link" href="#">$_("View Console")</a></span><!--
+ --><span class='column-processors'>
+ <div class="percentage-label processors-percentage">
</div>
- <div class="bottom">
- <div name="actionmenu" class="btn dropdown popable vm-action" style="width: 126px">
- <span class="text">$_("Actions")</span><span class="arrow"></span>
- <div class="popover actionsheet right-side" style="width: 250px">
- <button class="button-big shutoff-disabled" name="vm-console" ><span class="text">$_("Connect")</span></button>
- <button class="button-big running-disabled" name="vm-clone"><span class="text">$_("Clone")</span></button>
- <button class="button-big" name="vm-edit"><span class="text">$_("Edit")</span></button>
- <button class="button-big shutoff-hidden non-persistent-disabled" name="vm-reset"><span class="text">$_("Reset")</span></button>
- <button class="button-big pause-hidden non-persistent-disabled" name="vm-pause"><span class="text">$_("Pause")</span></button>
- <button class="button-big resume-hidden" name="vm-resume"><span class="text">$_("Resume")</span></button>
- <button class="button-big shutoff-hidden" name="vm-shutdown"><span class="text">$_("Shut Down")</span></button>
- <button class="button-big running-hidden" name="vm-start"><span class="text">$_("Start")</span></button>
- <button class="button-big shutoff-hidden" name="vm-poweroff"><span class="text">$_("Power Off")</span></button>
- <button class="button-big red non-persistent-disabled" name="vm-delete">$_("Delete")</button>
- </div>
- </div>
+ <div class="progress">
+ <div class="progress-bar dark-grey cpu" style="width: 100%"></div>
+ <div class="progress-bar medium-grey cpu"></div>
+ <div class="progress-bar light-grey cpu"></div>
+ <div class="progress-bar cpu-progress-bar"></div>
+ </div>
+ </span><!--
+ --><span class="item-hidden">$_("Processors Used")</span><!--
+ --><span class='column-memory'>
+ <div class='percentage-label memory-percentage'></div>
+ <div class="progress">
+ <div class="progress-bar dark-grey" style="width: 100%"></div>
+ <div class="progress-bar medium-grey memory"></div>
+ <div class="progress-bar light-grey memory"></div>
+ <div class="progress-bar memory-progress-bar"></div>
+ </div>
+ </span><!--
+ --><span class="item-hidden">$_("Memory Available")</span><!--
+ --><span class='column-storage'>
+ <div class='measure-label storage-percentage'></div>
+ <div class="progress">
+ <div class="progress-bar dark-grey" style="width: 100%"></div>
+ <div class="progress-bar medium-grey io"></div>
+ <div class="progress-bar light-grey io"></div>
+ <div class="progress-bar storage-progress-bar"></div>
+ </div>
+ </span><!--
+ --><span class="item-hidden">$_("Storage I/O")</span><!--
+ --><span class='column-network'>
+ <div class='measure-label network-percentage'></div>
+ <div class="progress">
+ <div class="progress-bar dark-grey" style="width: 100%"></div>
+ <div class="progress-bar medium-grey network" style="width: 85%"></div>
+ <div class="progress-bar light-grey network" style="width: 75%"></div>
+ <div class="progress-bar network-progress-bar"></div>
</div>
- </div>
+ </span><!--
+ --><span class="item-hidden">$_("Network I/O")</span>
</li>
+
+
diff --git a/src/wok/plugins/kimchi/ui/pages/guests.html.tmpl b/src/wok/plugins/kimchi/ui/pages/guests.html.tmpl
index a5c6846..0ca6d79 100644
--- a/src/wok/plugins/kimchi/ui/pages/guests.html.tmpl
+++ b/src/wok/plugins/kimchi/ui/pages/guests.html.tmpl
@@ -55,18 +55,31 @@
</nav>
<div id="guest-content-container">
<div class="container">
+ <div class="row grid-control">
+ <div class="pull-right">
+ <label for="guests-filter" class="sr-only">$_("Filter"):</label>
+ <input type="text" class="filter form-control" placeholder="$_("Filter")">
+ </div>
+ </div>
<div id="alert-container"></div>
<div id="guestListField" style="display: none">
- <ul class="list-title">
- <li class="guest-type">$_("Name")</li>
- <li class="guest-cpu">$_("CPU")</li>
- <li class="guest-memory">$_("Memory")</li>
- <li class="guest-storage">$_("Disk I/O")</li>
- <li class="guest-network">$_("Network I/O")</li>
- <li class="guest-tile">$_("Livetile")</li>
- <li class="guest-actions">$_("Actions")</li>
- </ul>
- <ul id="guestList" class="list-vm empty-when-logged-off">
+ <ul class="wok-guest-list">
+ <li class="wok-guest-list-header">
+ <span class="column-state"><span class="sr-only">$_("State")</span></span><!--
+ --><span class="column-name"><span>$_("Guest Name ID")</span></span><!--
+ --><span class="column-type"><span>$_("OS Type")</span></span><!--
+ --><span class="column-vnc"><span>$_("Virtual Network Console")</span></span><!--
+ --><span class="column-processors"><span>$_("Processors Used")</span></span><!--
+ --><span class="column-memory"><span>$_("Memory Available")</span></span><!--
+ --><span class="column-storage"><span>$_("Storage I/O")</span></span><!--
+ --><span class="column-network"><span>$_("Network I/O")</span></span><!--
+ --><span class="column-action" style="display:none">
+ <span class="sr-only">Actions</span><!--
+ --></span>
+ </li>
+ <li class="wok-guest-list-body">
+ <ul id="guestList" class="wok-guest-list empty-when-logged-off" style="-webkit-padding-start: 0px;">
+ </li>
</ul>
</div>
<div id="noGuests" class="list-no-result" style="display: none;">
diff --git a/ui/css/src/modules/_guests.scss b/ui/css/src/modules/_guests.scss
index 23c361a..b06be5f 100644
--- a/ui/css/src/modules/_guests.scss
+++ b/ui/css/src/modules/_guests.scss
@@ -90,3 +90,244 @@
width: 592px;
}
}
+
+#guest-content-container {
+ .wok-guest-list {
+ display: block;
+ width: 100%;
+ list-style-type: none;
+ > li:nth-child(even) {
+ background-color: $table-bg-accent;
+ }
+ > li:nth-child(odd) {
+ background-color: $table-bg;
+ }
+ > li:first-child {
+ border-top: 0;
+ }
+ .wok-guest-list-header {
+ border-top: 0 none;
+ height: 60px;
+ > span {
+ padding: 6px 2px;
+ display: inline-block;
+ vertical-align: middle;
+ height: 60px;
+ font-family: $font-family-sans-serif;
+ font-weight: 400;
+ font-size: 12.5pt;
+ line-height: 1.42857;
+ border-bottom: none;
+ border-top: 0;
+ position: relative;
+ > span {
+ position: absolute;
+ bottom: 6px;
+ display: block;
+ }
+ }
+ > span.column-state {
+ width: 2.9272%;
+ text-align: center;
+ }
+ }
+ .wok-guest-list-body {
+ border-top: 1px solid $table-border-color;
+ > span {
+ padding: 6px 2px;
+ display: inline-block;
+ vertical-align: middle;
+ font-family: $font-family-sans-serif;
+ font-size: 12.5pt;
+ line-height: 2.42857;
+ font-weight: bold;
+ }
+ .progress {
+ display: inline-block;
+ width: 60%;
+ position: relative;
+ vertical-align: top;
+ margin-top: 15px;
+ border-radius: 0;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+ }
+ .progress-bar {
+ position: absolute;
+ top: 0;
+ left: 0;
+ -webkit-box-shadow: none;
+ box-shadow: none;
+ &.dark-grey {
+ background-color: map-get($guestCharts, darkGray);
+ }
+ &.medium-grey {
+ background-color: map-get($guestCharts, mediumGray);
+ }
+ &.light-grey {
+ background-color: map-get($guestCharts, lightGray);
+ }
+ }
+ div.percentage-label {
+ display: inline-block;
+ width: 25%;
+ margin-top: 6px;
+ }
+ div.measure-label {
+ display: inline-block;
+ width: 35%;
+ margin-top: 6px;
+ }
+ }
+ }
+ .wok-guest-list .wok-guest-list-header,
+ .wok-guest-list .wok-guest-list-body {
+ > span.column-state {
+ width: 2.9272%;
+ text-align: center;
+ > span.guest-state {
+ font-size: 22px;
+ position: relative;
+ }
+ > span.guest-state.running > .fa-ban {
+ display: none;
+ }
+ > span.guest-state.running > .fa-power-off {
+ color: $fa-green;
+ }
+ > span.guest-state.running > .fa-undo {
+ display: none;
+ }
+ > span.guest-state.running > .fa-refresh {
+ display: none;
+ }
+ > span.guest-state.shutoff > .fa-ban {
+ color: $gray-light;
+ }
+ > span.guest-state.shutoff > .fa-power-off {
+ display: none;
+ }
+ > span.guest-state.shutoff > .fa-undo {
+ display: none;
+ }
+ > span.guest-state.shutoff > .fa-refresh {
+ display: none;
+ }
+ > span.guest-state.starting > .fa-ban {
+ display: none;
+ }
+ > span.guest-state.starting > .fa-power-off {
+ display: none;
+ }
+ > span.guest-state.starting > .fa-undo {
+ color: $gray-light;
+ }
+ > span.guest-state.starting > .fa-refresh {
+ display: none;
+ }
+ > span.guest-state.resetting > .fa-ban {
+ display: none;
+ }
+ > span.guest-state.resetting > .fa-power-off {
+ display: none;
+ }
+ > span.guest-state.resetting > .fa-undo {
+ display: none;
+ }
+ > span.guest-state.resetting > .fa-refresh {
+ color: $fa-green;
+ }
+ > span.guest-state.paused > .fa {
+ display: none;
+ }
+ }
+ > span.column-name {
+ width: 13.6867%;
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ }
+ > span.column-type {
+ width: 9.9683%;
+ }
+ > span.column-vnc {
+ width: 11.8670%;
+ > a {
+ font-weight: normal;
+ color: $vnc-blue !important;
+ }
+ .fa-spin {
+ display: none
+ }
+ .fa-spin.active {
+ display: inline-block;
+ margin-right: 8px;
+ font-size: 22px;
+ color: $vnc-blue !important;
+ }
+ }
+ > span.column-processors {
+ width: 12.1838%;
+ > div > div.progress-bar.cpu-progress-bar {
+ background-color: map-get($colors, administration);
+ }
+ }
+ > span.column-memory {
+ width: 12.1838%;
+ > div > div.progress-bar.memory-progress-bar {
+ background-color: map-get($colors, host);
+ }
+ }
+ > span.column-storage {
+ width: 12.9746%;
+ > div > div.progress-bar.storage-progress-bar {
+ background-color: $state-warning-border;
+ }
+ }
+ > span.column-network {
+ width: 12.9746%;
+ > div > div.progress-bar.network-progress-bar {
+ background-color: map-get($colors, network);
+ }
+ }
+ > span.column-action {
+ width: 10.9968%;
+ }
+ > span.item-hidden {
+ display: none !important;
+ }
+ }
+ .wok-guest-list .distro-icon {
+ background-color: transparent;
+ background-size: 27px 27px;
+ background-repeat: no-repeat;
+ background-position: left;
+ }
+ .wok-guest-list .distro-icon.inactive {
+ @include filter(grayscale(100%))
+ }
+ .wok-guest-list .distro-icon.icon-centos {
+ background-image: url('#{$wok-icon-path}/icon-centos.png');
+ }
+ .wok-guest-list .distro-icon.icon-debian {
+ background-image: url('#{$wok-icon-path}/icon-debian.png');
+ }
+ .wok-guest-list .distro-icon.icon-fedora {
+ background-image: url('#{$wok-icon-path}/icon-fedora.png');
+ }
+ .wok-guest-list .distro-icon.icon-opensuse {
+ background-image: url('#{$wok-icon-path}/icon-opensuse.png');
+ }
+ .wok-guest-list .distro-icon.icon-ubuntu {
+ background-image: url('#{$wok-icon-path}/icon-ubuntu.png');
+ }
+ .wok-guest-list .distro-icon.icon-gentoo {
+ background-image: url('#{$wok-icon-path}/icon-gentoo.png');
+ }
+ .wok-guest-list .distro-icon.icon-unknown {
+ background-image: url('#{$wok-icon-path}/icon-unknown.png');
+ }
+ .wok-guest-list .wok-guest-list-body.inactive {
+ color: $disabled-color !important;
+ }
+}
diff --git a/ui/images/theme-default/icon-unknown.png b/ui/images/theme-default/icon-unknown.png
index 83c7fe0fe4a452b815fab60aabb2a915777d8921..0de494b683ffa3da1646efdb93526ed880390093 100644
GIT binary patch
literal 3797
zcmV;`4l419P)<h;3K|Lk000e1NJLTq000{R000{Z1^@s6jnwp200009a7bBm000XU
z000XU0RWnu7ytkYPiaF#P*7-ZbZ>KLZ*U+<Lqi~Na&Km7Y-Iodc-oy)XH-+^7Crag
z^g>IBfRsybQWXdwQbLP>6p<z>Aqfylh#{fb6;Z(vMMVS~$e at S=j*ftg6;Uh<iVD~V
z<RPMtgQJLw%KPDaqifc at _vX$1wbwr9tn;0-&j-K=43<bUQ8j=JsX`tR;Dg7+#^K~H
zK!FM*Z~zbpvt%K2{UZSY_<lS*D<Z%Lz5oGu(+dayz)hRLFdT>f59&ghTmgWD0l;*T
zI7<kC6aYYajzXpYKt=(8otP$50H6c_V9R4-;{Z at C0AMG7=F<Rxo%or10RUT+Ar%3j
zkpLhQWr#!oXgdI`&sK^>09Y^p6lP1rIRMx#05C~cW=H_Aw*bJ-5DT&Z2n+x)QHX^p
z00esgV8|mQcmRZ%02D^@S3L16t`O%c004NIvOKvYIYoh62rY33S640`D9%Y2D-<?i
z0%4j!F2Z at 488U%158(66005wo6%pWr^Zj_v4zAA5HjcIqUoGmt2LB>rV&neh&#Q1i
z007~1e$oCcFS8neI|hJl{-P!B1ZZ9hpmq0)X0i`JwE&>$+E?>%_<lS*MWK+n+1cgf
z<k(8YLR(?VSAG6x!e78w{cQPuJpA|d;J)G{fihizM+Erb!p!tcr5w+a34~(Y=8s4G
zw+sLL9n&JjNn*KJDiq^U5^;`1nvC- at r6P$!k}1U{(*I=Q-z at tBKHoI}uxdU5dyy at u
zU1J0GOD7Ombim^G008p4Z^6_k2m^p<gW=D2|L;HjN1!DDfM!XOaR2~bL?kX$%CkSm
z2mk;?pn)o|K^yeJ7%adB9Ki+L!3+FgHiSYX#KJ-lLJDMn9CBbOtb#%)hRv`YDqt_v
zKpix|QD}yfa1JiQRk#j4a1Z)n2%f<xynzV>LC6RbVIkUx0b+_+BaR3cnT7Zv!AJxW
zizFb)h!jyGOOZ85F;a?DAXP{m@;!0_Ifq<Ex{*7`05XF7hP+2Hl!3BQJ=6 at fL%FCo
z8iYoo3(#bAF`ADSpqtQgv>H8(HlgRxt7s3}k3K`kFu>>-2Q$QMFfPW!La{h336o>X
zu_CMttHv6zR;&ZNiS=X8v3CR#fknUxHUxJ<AYmRsNLWl*PS{AOARHt#5!wki2?K;t
z!Y3k=s7tgax)J%r7-BLphge7~Bi0g+6E6^Zh(p9TBoc{3GAFr^0!gu?RMHaCM$&Fl
zBk3%un>0uoBa_M6WNWeqIg~6QE69c9o#eyhGvpiOA at W-aonk<7r1(?fC{oI5N*U!4
z<uv66WtcKSRim0x-Ke2d5jBrmLam{;Qm;{ms1r1GnmNsb7D-E`t)i9F8fX`2_i3-_
zbh;7Ul^#x)&{xvS=|||7=mYe33=M`AgU5(xC>fg=2N-7=cNnjjOr{yriy6mMFgG#l
znCF=fnQv8CDz++o6_Lscl}eQ+l^ZHARH>?_s@|##Rr6KLRFA1%Q+=*RRWnoLsR`7U
zt5vF<Q0r40Q)j6=sE4X&sBct1q<&fbi3VB2Ov6t at q*0);U*o*SAPZv|vv at 2aYYnT0
zb%8a+Cb7-ge0D0knEf5Qi#@8Tp*ce{N;6lpQuCB%KL_KOarm5cP6_8Ir<e17iry6O
zDdH&`rZh~sF=bq9s+O0QSgS~@QL9Jmy*94xr=6y~MY~!1fet~(N+(<=M`w at D1)b+p
z*;C!83a1uLJv#NSE~;y#8=<>IcfW3@?wFpwUVxrVZ>QdQz32KIeJ}k~{cZZE^+ya?
z2D1z#2HOnI7(B%_ac?{wFUQ;QQA1tBKtrWrm0_3Rgps+?Jfqb{jYbcQX~taRB;#$y
zZN{S}1|}gUOHJxc?wV3fxuz+mJ4`!F$IZ;mqRrNsHJd##*D~ju=bP7?-?v~|cv>vB
zsJ6IeNwVZxrdjT`yl#bBIa#GxRa#xMMy;K#CDyyGyQdMSxlWT#tDe?p!?5wT$+oGt
z8L;Kp2HUQ-ZMJ=3XJQv;x5ci*?vuTfeY$;({XGW_huIFR9a<fJbF^|4I#xQ~n$Dc=
zKYhjYmgz5NSkDm8*fZm{6U!;YX`NG>(?@3)XSs8O^N5RyOM=TTmp(3=8^+zpz2r)C
z^>JO{deZfso3oq3?Wo(Y?l$ge?uXo;%ru`Vo>?<<(8I_>;8Eq#KMS9gFl*neeosSB
zfoHYnBQIkwkyowPu(zdms`p{<7e4kra-ZWq<2*OsGTvEV%s0Td$hXT+!*8Bnh2KMe
zBmZRodjHV?r+_5^X9J0WL4jKW`}lf%A-|44I@@LTvf1rHjG(ze6+w at Jt%Bvjts!X0
z?2xS?_ve_-k<Mujg;0Lz*3buG=3$G&ehepthlN*$KaOySSQ^nWmo<0M+(UEUMEXRQ
zMBbZcF;6+KElM>iKB_KiJlZ$9G`c^=E at oNG)mWWaNo-3TIW8)$Hg0Ub-~8?KhvJ>$
z3*&nim at mj(aCxE5!t{lw7O5^0EIO7zOo&c6l<+|iDySBWCGrz at C5{St!X3hAA}`T4
z(TLbXTq+(;@<=L8dXnssyft|w#WSTW<++3>sgS%(4NTpeI-VAqb|7ssJvzNHgOZVu
zaYCvgO_R1~>SyL=cFU|~g|hy|Zi}}s9+d~lYqOB71z9Z$wnC=pR9Yz4DhIM>Wmjgu
z&56o6maCpC&F##y%G;1PobR9i?GnNg;gYtchD%p19a!eQtZF&3JaKv33gZ<8D~47E
ztUS1iwkmDaPpj=$m#%)jCVEY4fnLGNg2A-`YwHVD3gv};>)hAvT~AmqS>Lr``i7kw
zJ{5_It`yrBmlc25DBO7E8;5VoznR>Ww5hAaxn$2~(q`%A-YuS64wkBy=9dm`4cXeX
z4c}I@?e+FW+b@^RDBHV(wnMq2zdX3SWv9u`%{xC-q*U}&`cyXV(%rRT*Z6MH?i+i&
z_B8C(+grT%{XWUQ+f at NoP1R=AW&26{v-dx)iK^-Nmiuj8txj!m?Z*Ss1N{dh4z}01
z)YTo*JycSU)+_5r4#yw9{+;i4Ee$peRgIj+;v;ZGdF1K$3E%e~4LaI(jC-u%2h$&R
z9cLXcYC at Xwnns&bn)_Q~Te?roKGD|d-g^8;+aC{{G(1^(O7m37Y1-+6)01cN&y1aw
zoqc{T`P^XJqPBbIW6s}d4{z_f5Om?vMgNQEJG?v2T=KYd^0M3I6IZxbny)%vZR&LD
zJpPl at Psh8QyPB@KTx+ at RdcC!KX7}kEo;S|j^u2lU7XQ}Oo;f|;z4Ll+_r>@1-xl3|
zawq-H%e&ckC+ at AhPrP6BK<z=<L*0kfKU at CX*zeqbYQT4(^U>T#_XdT7&;F71j}Joy
zkC~6lh7E at 6o;W@^IpRNZ{ptLtL(gQ-CY~4mqW;US7Zxvm_|@yz&e53Bp_lTPlfP|z
zrTyx_>lv at x#=^!PzR7qqF<$gm`|ZJZ+;<)Cqu&ot<a{81DF0~rvGr5Xr~8u`lav1h
z1DNytV>2z=00004XF*Lt006O$eEU(80000WV at Og>004R=004l4008;_004mL004C`
z008P>0026e000+nl3&F}000B<Nkl<Zc-rjMTWcd_7zglw4n1ufHj_h7q>vW02MF7S
zmQrkONHUoe+DRvqOlC64OlEQ}WYZ=k&00mIH(sb0u7WJxMZEIDuduj?_z^@FFZ5ys
zQ511^p<C_ig`Jr61BhTR-kbN&%kO<2o_Pm^5d2#U*Vr}o- at y`z#8NOAd at mdh-;YM4
zuVu4Ycdb@~EX$y28Z67+*xugW3x~s}p-|`pmStZNMbX7D%<GqX_gI$Ive|53u~@{(
z$qCx+HaL!pheDx`XqrBaL?Ul<9QQIfj#CB(1_%Js*VjjQp1*y3d<<RJ5ex>w^E~5l
zI9>oCX0w?v409lgV$f!@T>u~eh|A at ArfFKB-EJe3$v{=rIj`6I#K^5yD~ZKobyO;q
zm!_wue=vgO<>g29dVL_9&4OVVL?V&*jcj~;{8=uSyCq4|_Q=QxG4=tFU at -VG$8ks`
z64=_>ddq6Hl5ULSxHih=G6I3XCq^(aG4Xq;R9eYoGGJNO>GS!%HnP>#)rYlO4e4}x
z_bN6uHT83`Se!jLIH2a|=fCOBF0mF=RfQx;@tZeqb_aL%_VyqM!VX1I1OOQv93-(=
z>~=n%ha^dH1G88x#AGrNv)N2omVHwY1bt{|h?q<!VpP|`j*gB{tJT~K3k#hJR#sLX
z)oL{>P1E;`J+IgMW3gDA)pZ?`B=H93bUMl8<Rk$=d_LckwY9Zx0T7SJL)>n6FIFy>
zQ79A;iA3Hpo6Q6O85<k>O;uHKc6PRNfz8d$Pn*pqs?{n)QS4xDxBHKcjg4Q8>W7Di
z2>=oZ1b!MF9X;>CbX`Y2pNFcdn{K!J%xFzC8hvcH+s^<Ho6Saeo|jZr#ns9vih7<(
zrS9A9_UFdMD2jS2isFY(r}JqK)@uFT%6h$i!|(Th*)=G{VzCeaWNvQmakW|<FPF>6
z<#Iik-EM!OC`xK+Y3U2&tl#hdTu~Ix;c%SwV49{u*LCD_IqdB0wEFw|d!`HkVHoCa
zv)RP{{ysEKyNX at NvK&k#67iXtneS(2X1+@%lQBh6UZp7N&mOE)Dxp*=p;D=!P$>93
z9?vh`kjv#dPo+|{EXz<71((y9=)#C7id&kdK~>e!Y&JV8NfIPUqA7~H==siCt$$kC
zXf(|0>+7F&V~dN6Uo{#H+u`9MGMNknK|nH at -0s58d7cmM?(QO$N<k0=@H`Je5H=}_
zI`4TwWLfU4bUF>5=Wj(Kk#}jDKBZ~;Zaf~}NT<`t<#K2=8fZ3~P*ruDrs+4r;qU{7
zVeZJX?9z1|rBVsHu0vH-WHK3NG#Wh$hr<s#Z{zj<>>B%jVt)+)m+A||QZPP500000
LNkvXXu0mjfHh&jM
delta 737
zcmV<70v`R<9r*>2B!2{FK}|sb0I$e51&Zka000?uMObuGZ)S9NVRB^vL1b at YWgtmy
zVP|DhWnpA_ami&o0007uNkl<Zc-pL%O-NKx6vy8<YJ+7FeL_L>MfA1E+yqS#5ft=I
zi`p49n|1{mRvW2JD;J7rP at AGC+GQX?K|zaJNI?bJ2bqGT*?*!T95ZM7U-&(F%-r4_
z(+fYC``)|vf6lq*o-;wAPzW4`u~gg?1LB)_DK3c0atkLljAB*dv0E46w|FC3XIgA~
zk&xquc*gH-7O{%JHa3YrVvPAXp-eN+ST?bW%@y~=N#<9?A#sWMhM5!_5t~K5=n-?o
z6VZ#u3CkvxMt`w93Gq~17Hh;p&dM1)pClT$WlH=wA(}m*&ET2aU{yH{t7m=Un)oON
zMM^BeySJiW>=o^Cn<PT75{cNbH;R3D at m~BC55+K{&5B=QD<LoO%o;|Q6rb_JWnhz7
z6nWnqxqD})bE#{|xV9K$HX`J_o)G*0SFDMR&c}!)#eX9)M0kg&qf-)FE<O;#6^07q
zgt{@VZK`5tSlDRH*jM5?1t7~An`)y=&0}Iz+&7B34zQXqx(ZWgEmudyVm25win-LU
zjuh*(RqP at q=u==HFCfQ!omH%x#CT08%Z+N1sE)cB(1Oa=#@VEEjkqlu44q>S9Xq_-
zz0nNzWq;#ZaYURJ^Z0HV7Pex&Z#bh4V_>JaAy$gr6l<^8aVmFh(Pjs*_D)RLPkG)Q
z#PAAV>L<A$*`h at c#9h)l?-ANb0jMc at -X*>gt&#+BEo0U{EI%i1iCwgpDg at klb|94V
zG~6DVZb_$J5YuV<S=>pOCpgcratu?5!?A_%e_EjxmGrYTALR*UAD8+&A#Ug3lU(32
zL{k*r9e9yppB8HCWVZX7XNnNH;<}z^u7ABFlsV7;nCl!tmiu`%dcL8?UjYUH-C8&C
T(|TA^00000NkvXXu0mjf`2A9?
--
1.9.3
More information about the Kimchi-devel
mailing list