From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: <d.csapak@proxmox.com> Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by lists.proxmox.com (Postfix) with ESMTPS id D9DDC74C75 for <pve-devel@lists.proxmox.com>; Tue, 20 Apr 2021 10:15:58 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id CCAE2202BD for <pve-devel@lists.proxmox.com>; Tue, 20 Apr 2021 10:15:28 +0200 (CEST) Received: from proxmox-new.maurer-it.com (proxmox-new.maurer-it.com [212.186.127.180]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by firstgate.proxmox.com (Proxmox) with ESMTPS id 582D22026E for <pve-devel@lists.proxmox.com>; Tue, 20 Apr 2021 10:15:24 +0200 (CEST) Received: from proxmox-new.maurer-it.com (localhost.localdomain [127.0.0.1]) by proxmox-new.maurer-it.com (Proxmox) with ESMTP id 24A1F45B82; Tue, 20 Apr 2021 10:15:24 +0200 (CEST) From: Dominik Csapak <d.csapak@proxmox.com> To: pve-devel@lists.proxmox.com Cc: Alwin Antreich <a.antreich@proxmox.com> Date: Tue, 20 Apr 2021 10:15:16 +0200 Message-Id: <20210420081523.2704-3-d.csapak@proxmox.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210420081523.2704-1-d.csapak@proxmox.com> References: <20210420081523.2704-1-d.csapak@proxmox.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SPAM-LEVEL: Spam detection results: 0 AWL 0.157 Adjusted score from AWL reputation of From: address KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment RCVD_IN_DNSWL_MED -2.3 Sender listed at https://www.dnswl.org/, medium trust SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record Subject: [pve-devel] [PATCH manager v4 2/9] ceph: gui: add autoscale & flatten pool view X-BeenThere: pve-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox VE development discussion <pve-devel.lists.proxmox.com> List-Unsubscribe: <https://lists.proxmox.com/cgi-bin/mailman/options/pve-devel>, <mailto:pve-devel-request@lists.proxmox.com?subject=unsubscribe> List-Archive: <http://lists.proxmox.com/pipermail/pve-devel/> List-Post: <mailto:pve-devel@lists.proxmox.com> List-Help: <mailto:pve-devel-request@lists.proxmox.com?subject=help> List-Subscribe: <https://lists.proxmox.com/cgi-bin/mailman/listinfo/pve-devel>, <mailto:pve-devel-request@lists.proxmox.com?subject=subscribe> X-List-Received-Date: Tue, 20 Apr 2021 08:15:58 -0000 From: Alwin Antreich <a.antreich@proxmox.com> Letting the columns flex needs a flat column head structure. Signed-off-by: Alwin Antreich <a.antreich@proxmox.com> Signed-off-by: Dominik Csapak <d.csapak@proxmox.com> --- www/manager6/ceph/Pool.js | 138 ++++++++++++++++++++++---------------- 1 file changed, 82 insertions(+), 56 deletions(-) diff --git a/www/manager6/ceph/Pool.js b/www/manager6/ceph/Pool.js index 5dabd4e6..7f341ce8 100644 --- a/www/manager6/ceph/Pool.js +++ b/www/manager6/ceph/Pool.js @@ -105,14 +105,16 @@ Ext.define('PVE.node.CephPoolList', { columns: [ { - header: gettext('Name'), - width: 120, + text: gettext('Name'), + minWidth: 120, + flex: 2, sortable: true, dataIndex: 'pool_name', }, { - header: gettext('Size') + '/min', - width: 100, + text: gettext('Size') + '/min', + minWidth: 100, + flex: 1, align: 'right', renderer: function(v, meta, rec) { return v + '/' + rec.data.min_size; @@ -120,62 +122,82 @@ Ext.define('PVE.node.CephPoolList', { dataIndex: 'size', }, { - text: 'Placement Groups', - columns: [ - { - text: '# of PGs', // pg_num', - width: 150, - align: 'right', - dataIndex: 'pg_num', - }, - { - text: gettext('Autoscale'), - width: 140, - align: 'right', - dataIndex: 'pg_autoscale_mode', - }, - ], + text: '# of Placement Groups', + flex: 1, + minWidth: 150, + align: 'right', + dataIndex: 'pg_num', }, { - text: 'CRUSH Rule', - columns: [ - { - text: 'ID', - align: 'right', - width: 50, - dataIndex: 'crush_rule', - }, - { - text: gettext('Name'), - width: 150, - dataIndex: 'crush_rule_name', - }, - ], + text: gettext('Optimal # of PGs'), + flex: 1, + minWidth: 140, + align: 'right', + dataIndex: 'pg_num_final', + renderer: function(value, metaData) { + if (!value) { + value = '<i class="fa fa-info-circle faded"></i> n/a'; + metaData.tdAttr = 'data-qtip="Needs pg_autoscaler module enabled."'; + } + return value; + }, }, { - text: gettext('Used'), - columns: [ - { - text: '%', - width: 100, - sortable: true, - align: 'right', - renderer: function(val) { - return Ext.util.Format.percent(val, '0.00'); - }, - dataIndex: 'percent_used', - }, - { - text: gettext('Total'), - width: 100, - sortable: true, - renderer: PVE.Utils.render_size, - align: 'right', - dataIndex: 'bytes_used', - summaryType: 'sum', - summaryRenderer: PVE.Utils.render_size, - }, - ], + text: gettext('Target Size Ratio'), + flex: 1, + minWidth: 140, + align: 'right', + dataIndex: 'target_size_ratio', + renderer: Ext.util.Format.numberRenderer('0.0000'), + hidden: true, + }, + { + text: gettext('Target Size'), + flex: 1, + minWidth: 140, + align: 'right', + dataIndex: 'target_size', + hidden: true, + renderer: function(v, metaData, rec) { + let value = PVE.Utils.render_size(v); + if (rec.data.target_size_ratio > 0) { + value = '<i class="fa fa-info-circle faded"></i> ' + value; + metaData.tdAttr = 'data-qtip="Target Size Ratio takes precedence over Target Size."'; + } + return value; + }, + }, + { + text: gettext('Autoscale Mode'), + flex: 1, + minWidth: 140, + align: 'right', + dataIndex: 'pg_autoscale_mode', + }, + { + text: 'CRUSH Rule (ID)', + flex: 1, + align: 'right', + minWidth: 150, + renderer: function(v, meta, rec) { + return v + ' (' + rec.data.crush_rule + ')'; + }, + dataIndex: 'crush_rule_name', + }, + { + text: gettext('Used') + ' (%)', + flex: 1, + minWidth: 180, + sortable: true, + align: 'right', + dataIndex: 'bytes_used', + summaryType: 'sum', + summaryRenderer: PVE.Utils.render_size, + renderer: function(v, meta, rec) { + let percentage = Ext.util.Format.percent(rec.data.percent_used, '0.00'); + let used = PVE.Utils.render_size(v); + return used + ' (' + percentage + ')'; + }, }, ], initComponent: function() { @@ -276,6 +298,10 @@ Ext.define('PVE.node.CephPoolList', { { name: 'percent_used', type: 'number' }, { name: 'crush_rule', type: 'integer' }, { name: 'crush_rule_name', type: 'string' }, + { name: 'pg_autoscale_mode', type: 'string'}, + { name: 'pg_num_final', type: 'integer'}, + { name: 'target_size_ratio', type: 'number'}, + { name: 'target_size_bytes', type: 'integer'}, ], idProperty: 'pool_name', }); -- 2.20.1