Skip to content

Commit

Permalink
Return ScrollAreaOutput from Table::body (emilk#4829)
Browse files Browse the repository at this point in the history
<!--
Please read the "Making a PR" section of
[`CONTRIBUTING.md`](https://github.com/emilk/egui/blob/master/CONTRIBUTING.md)
before opening a Pull Request!

* Keep your PR:s small and focused.
* The PR title is what ends up in the changelog, so make it descriptive!
* If applicable, add a screenshot or gif.
* If it is a non-trivial addition, consider adding a demo for it to
`egui_demo_lib`, or a new example.
* Do NOT open PR:s from your `master` branch, as that makes it hard for
maintainers to test and add commits to your PR.
* Remember to run `cargo fmt` and `cargo clippy`.
* Open the PR as a draft until you have self-reviewed it and run
`./scripts/check.sh`.
* When you have addressed a PR comment, mark it as resolved.

Please be patient! I will review your PR, but my time is limited!
-->

added return ScrollAreaOutput.

This can be used to monitor the scroll progress of a table(usage
example: custom scroll progress bar or lazy loading table)

* [X] I have followed the instructions in the PR template
  • Loading branch information
frederik-uni authored and hacknus committed Oct 30, 2024
1 parent 5dac0e6 commit a3a3ee4
Showing 1 changed file with 7 additions and 6 deletions.
13 changes: 7 additions & 6 deletions crates/egui_extras/src/table.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,8 @@
//! Takes all available height, so if you want something below the table, put it in a strip.
use egui::{
scroll_area::ScrollBarVisibility, Align, NumExt as _, Rangef, Rect, Response, ScrollArea, Ui,
Vec2, Vec2b,
scroll_area::{ScrollAreaOutput, ScrollBarVisibility},
Align, NumExt as _, Rangef, Rect, Response, ScrollArea, Ui, Vec2, Vec2b,
};

use crate::{
Expand Down Expand Up @@ -474,7 +474,7 @@ impl<'a> TableBuilder<'a> {
}

/// Create table body without a header row
pub fn body<F>(self, add_body_contents: F)
pub fn body<F>(self, add_body_contents: F) -> ScrollAreaOutput<()>
where
F: for<'b> FnOnce(TableBody<'b>),
{
Expand Down Expand Up @@ -515,7 +515,7 @@ impl<'a> TableBuilder<'a> {
scroll_options,
sense,
}
.body(add_body_contents);
.body(add_body_contents)
}
}

Expand Down Expand Up @@ -641,7 +641,7 @@ impl<'a> Table<'a> {
}

/// Create table body after adding a header row
pub fn body<F>(self, add_body_contents: F)
pub fn body<F>(self, add_body_contents: F) -> ScrollAreaOutput<()>
where
F: for<'b> FnOnce(TableBody<'b>),
{
Expand Down Expand Up @@ -692,7 +692,7 @@ impl<'a> Table<'a> {
let widths_ref = &state.column_widths;
let max_used_widths_ref = &mut max_used_widths;

scroll_area.show(ui, move |ui| {
let scroll_area_out = scroll_area.show(ui, move |ui| {
let mut scroll_to_y_range = None;

let clip_rect = ui.clip_rect();
Expand Down Expand Up @@ -843,6 +843,7 @@ impl<'a> Table<'a> {
state.max_used_widths = max_used_widths;

state.store(ui, state_id);
scroll_area_out
}
}

Expand Down

0 comments on commit a3a3ee4

Please sign in to comment.