From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: 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 2928090BAF for ; Mon, 2 Oct 2023 10:38:50 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id 0704B14776 for ; Mon, 2 Oct 2023 10:38:20 +0200 (CEST) Received: from proxmox-new.maurer-it.com (proxmox-new.maurer-it.com [94.136.29.106]) (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 for ; Mon, 2 Oct 2023 10:38:18 +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 A86E442393 for ; Mon, 2 Oct 2023 10:38:18 +0200 (CEST) From: Philipp Hufnagl To: pbs-devel@lists.proxmox.com Date: Mon, 2 Oct 2023 10:38:11 +0200 Message-Id: <20231002083811.323890-1-p.hufnagl@proxmox.com> X-Mailer: git-send-email 2.39.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SPAM-LEVEL: Spam detection results: 0 AWL -0.070 Adjusted score from AWL reputation of From: address BAYES_00 -1.9 Bayes spam probability is 0 to 1% DMARC_MISSING 0.1 Missing DMARC policy KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record URIBL_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to URIBL was blocked. See http://wiki.apache.org/spamassassin/DnsBlocklists#dnsbl-block for more information. [item.data] Subject: [pbs-devel] [PATCH proxmox-backup v2] ui: fix #4260: add dynamic notes in backup group comment X-BeenThere: pbs-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox Backup Server development discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 02 Oct 2023 08:38:50 -0000 When there is no comment for a backup group, the comment of the last snapshot in this group will be shown slightly grayed out as long as the group is collapsed. Changes since v1: * fixed typo at "additonal classes" * renamed css class to "faded" so it can be used more generic * guarded snapshot comment for not being a string guarded snapshot Signed-off-by: Philipp Hufnagl --- www/css/ext6-pbs.css | 3 +++ www/datastore/Content.js | 17 ++++++++++++++--- 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/www/css/ext6-pbs.css b/www/css/ext6-pbs.css index 5fd65d25..fce3f4cd 100644 --- a/www/css/ext6-pbs.css +++ b/www/css/ext6-pbs.css @@ -226,6 +226,9 @@ span.snapshot-comment-column { display: inline-block; width: calc(100% - 18px); } +span.pmx-faded { + opacity: 0.7; +} .x-action-col-icon.good:before { color: #21BF4B; diff --git a/www/datastore/Content.js b/www/datastore/Content.js index 9fc07d49..8b8c114b 100644 --- a/www/datastore/Content.js +++ b/www/datastore/Content.js @@ -146,6 +146,7 @@ Ext.define('PBS.DataStoreContent', { leaf: false, iconCls: "fa " + cls, expanded: false, + comment: item.data.comment, backup_type: item.data["backup-type"], backup_id: item.data["backup-id"], children: [], @@ -287,6 +288,7 @@ Ext.define('PBS.DataStoreContent', { if (item["backup-time"] > last_backup && item.size !== null) { last_backup = item["backup-time"]; group["backup-time"] = last_backup; + group["last-comment"] = item.comment; group.files = item.files; group.size = item.size; group.owner = item.owner; @@ -903,13 +905,22 @@ Ext.define('PBS.DataStoreContent', { if (!data || data.leaf || data.root) { return ''; } - if (v === undefined || v === null) { - v = ''; + + let additional_classes = ""; + // when there is no group comment and the section is collapsed, + // display the most recent snapshot comment + if (v === undefined || v === null|| v === '') { + if (data.expanded === false) { + v = data['last-comment'] ?? ''; + additional_classes = "pmx-faded"; + } else { + v = ''; + } } v = Ext.String.htmlEncode(v); let icon = 'x-action-col-icon fa fa-fw fa-pencil pointer'; - return `${v} + return `${v} `; }, listeners: { -- 2.39.2