From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: <yew-devel-bounces@lists.proxmox.com> Received: from firstgate.proxmox.com (firstgate.proxmox.com [IPv6:2a01:7e0:0:424::9]) by lore.proxmox.com (Postfix) with ESMTPS id 6DF821FF285 for <inbox@lore.proxmox.com>; Wed, 7 May 2025 16:37:46 +0200 (CEST) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id DFBE83DEC5; Wed, 7 May 2025 16:38:03 +0200 (CEST) From: Dominik Csapak <d.csapak@proxmox.com> To: yew-devel@lists.proxmox.com Date: Wed, 7 May 2025 16:37:58 +0200 Message-Id: <20250507143800.3461963-3-d.csapak@proxmox.com> X-Mailer: git-send-email 2.39.5 In-Reply-To: <20250507143800.3461963-1-d.csapak@proxmox.com> References: <20250507143800.3461963-1-d.csapak@proxmox.com> MIME-Version: 1.0 X-SPAM-LEVEL: Spam detection results: 0 AWL 0.021 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 RCVD_IN_VALIDITY_CERTIFIED_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. RCVD_IN_VALIDITY_RPBL_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. RCVD_IN_VALIDITY_SAFE_BLOCKED 0.001 ADMINISTRATOR NOTICE: The query to Validity was blocked. See https://knowledge.validity.com/hc/en-us/articles/20961730681243 for more information. SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record Subject: [yew-devel] [PATCH yew-widget-toolkit 2/2] widget: data table: add table scroll callback X-BeenThere: yew-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Yew framework devel list at Proxmox <yew-devel.lists.proxmox.com> List-Unsubscribe: <https://lists.proxmox.com/cgi-bin/mailman/options/yew-devel>, <mailto:yew-devel-request@lists.proxmox.com?subject=unsubscribe> List-Archive: <http://lists.proxmox.com/pipermail/yew-devel/> List-Post: <mailto:yew-devel@lists.proxmox.com> List-Help: <mailto:yew-devel-request@lists.proxmox.com?subject=help> List-Subscribe: <https://lists.proxmox.com/cgi-bin/mailman/listinfo/yew-devel>, <mailto:yew-devel-request@lists.proxmox.com?subject=subscribe> Reply-To: Yew framework devel list at Proxmox <yew-devel@lists.proxmox.com> Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: yew-devel-bounces@lists.proxmox.com Sender: "yew-devel" <yew-devel-bounces@lists.proxmox.com> sometimes it's useful to do things on scrolling, e.g. when wanting to load additional data when at the end of the table. Signed-off-by: Dominik Csapak <d.csapak@proxmox.com> --- src/widget/data_table/data_table.rs | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/src/widget/data_table/data_table.rs b/src/widget/data_table/data_table.rs index f926955..cb0f781 100644 --- a/src/widget/data_table/data_table.rs +++ b/src/widget/data_table/data_table.rs @@ -7,7 +7,7 @@ use derivative::Derivative; use gloo_timers::callback::Timeout; use wasm_bindgen::JsCast; -use yew::html::IntoPropValue; +use yew::html::{IntoEventCallback, IntoPropValue}; use yew::prelude::*; use yew::virtual_dom::{Key, VComp, VNode}; @@ -212,6 +212,10 @@ pub struct DataTable<S: DataStore> { #[prop_or_default] pub multiselect_mode: MultiSelectMode, + + /// Table scroll callback + #[prop_or_default] + pub on_table_scroll: Option<Callback<Event>>, } impl<S: DataStore> AsClassesMut for DataTable<S> { @@ -456,6 +460,12 @@ impl<S: DataStore> DataTable<S> { self.set_multiselect_mode(multiselect_mode); self } + + /// Builder style method to set the table scroll callback. + pub fn on_table_scroll(mut self, cb: impl IntoEventCallback<Event>) -> Self { + self.on_table_scroll = cb.into_event_callback(); + self + } } #[derive(Default)] @@ -1602,8 +1612,18 @@ impl<S: DataStore + 'static> Component for PwtDataTable<S> { let column_widths = self.column_widths.iter().sum::<f64>() + self.scrollbar_size.unwrap_or_default(); + let on_scroll = { + let on_scroll = props.on_table_scroll.clone(); + move |event: Event| { + if let Some(on_scroll) = &on_scroll { + on_scroll.emit(event); + } + } + }; + let viewport = Container::new() .node_ref(self.scroll_ref.clone()) + .onscroll(on_scroll) .key(Key::from("table-viewport")) .class("pwt-flex-fill") .style( -- 2.39.5 _______________________________________________ yew-devel mailing list yew-devel@lists.proxmox.com https://lists.proxmox.com/cgi-bin/mailman/listinfo/yew-devel