all lists on lists.proxmox.com
 help / color / mirror / Atom feed
From: Aaron Lauterer <a.lauterer@proxmox.com>
To: pve-devel@lists.proxmox.com
Subject: [pve-devel] [PATCH v3 manager 2/2] ui: ceph status: add tooltip with details to warnings
Date: Wed,  8 Mar 2023 13:09:19 +0100	[thread overview]
Message-ID: <20230308120919.1646218-3-a.lauterer@proxmox.com> (raw)
In-Reply-To: <20230308120919.1646218-1-a.lauterer@proxmox.com>

This is another step to make it easier for admins to discover more
information for a warning or problem that is shown in the Ceph health
panel.

The length is limited to give a first glimpse. For the full details one
can click on the info/detail button.

Signed-off-by: Aaron Lauterer <a.lauterer@proxmox.com>
---
changes since
v2:
* don't use arrow functions -> rework context in many places. mainly use
  'this' now
* destroy tooltip when no detail text is present. This can easily be
  tested by setting 'ceph osd set noout' for example
* guard show/hide on info button with '?'

v1:
* only destroy it when leaving the whole grid, use show/hide for all
other situations
* factor out text handling of newlines and max lines
* factor out updating and destroying into their own functions
* add more listeners
* hide it when hovering the info button
* auto update it whenever the store is updated to either hide it
  (nothing under the mouse) or set the content

 www/manager6/ceph/Status.js | 75 +++++++++++++++++++++++++++++++++++++
 1 file changed, 75 insertions(+)

diff --git a/www/manager6/ceph/Status.js b/www/manager6/ceph/Status.js
index b223ab35..46ced651 100644
--- a/www/manager6/ceph/Status.js
+++ b/www/manager6/ceph/Status.js
@@ -76,6 +76,72 @@ Ext.define('PVE.node.CephStatus', {
 			trackRemoved: false,
 			data: [],
 		    },
+		    generateTooltipText: function(text) {
+			text = text.trimStart();
+			if (text.length > 500) {
+			    text = `${text.substring(0, 500)}…`;
+			}
+			return text.replaceAll('\n', '<br>');
+		    },
+		    updateTooltip: function(isLeave) {
+			let me = this;
+			if (!me.tooltip) {
+			    return;
+			}
+			if (me.store.data.length - 1 < me.tooltip.gridIndex || isLeave) {
+			    me.tooltip.hide();
+			    return;
+			}
+			let data = me.store.getData().items[me.tooltip.gridIndex].data;
+			if (!data.detail) {
+			    me.destroyTooltip();
+			    return;
+			}
+			let text = me.generateTooltipText(data.detail);
+			me.tooltip.setData({ text });
+			me.tooltip.show();
+		    },
+		    destroyTooltip: function() {
+			this.tooltip?.destroy();
+			delete this.tooltip;
+		    },
+
+		    listeners: {
+			destroy: function() {
+			    this.destroyTooltip();
+			},
+			itemmouseenter: function(view, record, item, index) {
+			    let me = this;
+			    if (!view) {
+				return;
+			    }
+			    if (!record.data.detail) {
+				if (me.tooltip) {
+				    me.destroyTooltip();
+				}
+				return;
+			    }
+			    let text = me.generateTooltipText(record.data.detail);
+			    if (!me.tooltip) {
+				 me.tooltip = Ext.create('Ext.tip.ToolTip', {
+				    target: view,
+				    trackMouse: true,
+				    dismissDelay: 0,
+				    tpl: '{text}',
+				    renderTo: Ext.getBody(),
+				});
+			    }
+			    me.tooltip.gridIndex = index;
+			    me.tooltip.setData({ text });
+			    me.tooltip.show();
+			},
+			itemmouseleave: function() {
+			    this.updateTooltip(true);
+			},
+			containermouseout: function() {
+			    this.destroyTooltip();
+			},
+		    },
 		    emptyText: gettext('No Warnings/Errors'),
 		    columns: [
 			{
@@ -133,6 +199,14 @@ Ext.define('PVE.node.CephStatus', {
 					}],
 				    });
 				},
+				listeners: {
+				    mouseover: function() {
+					this.up('#warnings').tooltip?.hide();
+				    },
+				    mouseout: function() {
+					this.up('#warnings').tooltip?.show();
+				    },
+				},
 			    },
 			},
 		    ],
@@ -286,6 +360,7 @@ Ext.define('PVE.node.CephStatus', {
 	me.down('#overallhealth').updateHealth(PVE.Utils.render_ceph_health(rec.data.health || {}));
 	// add errors to gridstore
 	me.down('#warnings').getStore().loadRawData(me.generateCheckData(rec.data.health || {}), false);
+	me.down('#warnings').updateTooltip();
 
 	// update services
 	me.getComponent('services').updateAll(me.metadata || {}, rec.data);
-- 
2.30.2





  parent reply	other threads:[~2023-03-08 12:09 UTC|newest]

Thread overview: 6+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-03-08 12:09 [pve-devel] [PATCH v3 manager 0/2] ui: ceph: improve discoverability of warning details Aaron Lauterer
2023-03-08 12:09 ` [pve-devel] [PATCH v3 manager 1/2] ui: ceph: make the warning detail button stand out more Aaron Lauterer
2023-03-08 12:09 ` Aaron Lauterer [this message]
2023-03-08 16:05 ` [pve-devel] [PATCH v3 manager 0/2] ui: ceph: improve discoverability of warning details Thomas Lamprecht
2023-03-08 16:38   ` Aaron Lauterer
2023-03-08 16:43     ` Thomas Lamprecht

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20230308120919.1646218-3-a.lauterer@proxmox.com \
    --to=a.lauterer@proxmox.com \
    --cc=pve-devel@lists.proxmox.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.
Service provided by Proxmox Server Solutions GmbH | Privacy | Legal