[pdm-devel] [PATCH datacenter-manager v2 3/3] ui: pve: lxc: pass the pve-manager version to panels
Dominik Csapak
d.csapak at proxmox.com
Tue Dec 2 12:13:34 CET 2025
this will be used by the panels to feature gate by version.
Signed-off-by: Dominik Csapak <d.csapak at proxmox.com>
---
ui/src/pve/lxc/mod.rs | 16 ++++++++++++++--
ui/src/pve/mod.rs | 8 +++++++-
2 files changed, 21 insertions(+), 3 deletions(-)
diff --git a/ui/src/pve/lxc/mod.rs b/ui/src/pve/lxc/mod.rs
index 7429e07c..949fefb9 100644
--- a/ui/src/pve/lxc/mod.rs
+++ b/ui/src/pve/lxc/mod.rs
@@ -8,10 +8,11 @@ use std::rc::Rc;
use yew::virtual_dom::{VComp, VNode};
-use pwt::prelude::*;
-
+use proxmox_deb_version::Version;
use pwt::css::FlexFit;
+use pwt::prelude::*;
use pwt::widget::{Button, Column, Container, Fa, Row, TabBarItem, TabPanel, Tooltip};
+use pwt_macros::builder;
use pdm_api_types::resource::PveLxcResource;
@@ -19,11 +20,17 @@ use crate::pve::utils::render_lxc_name;
use crate::renderer::render_title_row;
#[derive(Clone, Debug, Properties, PartialEq)]
+#[builder]
pub struct LxcPanel {
remote: String,
node: String,
info: PveLxcResource,
+ #[prop_or_default]
+ #[builder]
+ /// The nodes pve-manager version, used to feature gate some entries.
+ pve_manager_version: Option<Version>,
+
#[prop_or(60_000)]
/// The interval for refreshing the rrd data
pub rrd_interval: u32,
@@ -108,6 +115,7 @@ impl yew::Component for LxcPanelComp {
let remote = props.remote.clone();
let node = props.node.clone();
let vmid = props.info.vmid;
+ let pve_manager_version = props.pve_manager_version.clone();
move |_| {
Container::new()
.class(FlexFit)
@@ -119,6 +127,7 @@ impl yew::Component for LxcPanelComp {
.with_child(html! {<hr/>})
.with_child(
LxcResourcesPanel::new(node.clone(), vmid)
+ .pve_manager_version(pve_manager_version.clone())
.readonly(true)
.remote(remote.clone()),
)
@@ -128,6 +137,7 @@ impl yew::Component for LxcPanelComp {
.with_child(html! {<hr/>})
.with_child(
LxcNetworkPanel::new(node.clone(), vmid)
+ .pve_manager_version(pve_manager_version.clone())
.readonly(true)
.remote(remote.clone()),
)
@@ -135,6 +145,7 @@ impl yew::Component for LxcPanelComp {
.with_child(html! {<hr/>})
.with_child(
LxcDnsPanel::new(node.clone(), vmid)
+ .pve_manager_version(pve_manager_version.clone())
.readonly(true)
.remote(remote.clone()),
)
@@ -144,6 +155,7 @@ impl yew::Component for LxcPanelComp {
.with_child(html! {<hr/>})
.with_child(
LxcOptionsPanel::new(node.clone(), vmid)
+ .pve_manager_version(pve_manager_version.clone())
.readonly(true)
.remote(remote.clone()),
),
diff --git a/ui/src/pve/mod.rs b/ui/src/pve/mod.rs
index 6ec323e5..d0d038dd 100644
--- a/ui/src/pve/mod.rs
+++ b/ui/src/pve/mod.rs
@@ -205,7 +205,13 @@ impl LoadableComponent for PveRemoteComp {
.into()
}
PveTreeNode::Lxc(lxc) => {
- lxc::LxcPanel::new(remote.clone(), lxc.node.clone(), lxc.clone()).into()
+ let pve_manager = match &self.updates.data {
+ Some(updates) => extract_package_version(updates, &lxc.node, "pve-manager"),
+ None => None,
+ };
+ lxc::LxcPanel::new(remote.clone(), lxc.node.clone(), lxc.clone())
+ .pve_manager_version(pve_manager)
+ .into()
}
PveTreeNode::Storage(storage) => {
storage::StoragePanel::new(remote.clone(), storage.node.clone(), storage.clone())
--
2.47.3
More information about the pdm-devel
mailing list