Use parent `Ui`s style for popups (#4325)

* Closes <https://github.com/emilk/egui/issues/4324>

---------

Co-authored-by: Alex Parlett <alexparlett@Alexs-MacBook-Air.local>
This commit is contained in:
Alexander Parlett 2024-04-21 10:44:44 +01:00 committed by GitHub
parent 5f9c17c855
commit 690c3ba883
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 7 additions and 6 deletions

1
.gitignore vendored
View File

@ -5,3 +5,4 @@
/.*.json
/.vscode
/media/*
.idea/

View File

@ -333,13 +333,13 @@ pub fn popup_below_widget<R>(
/// # });
/// ```
pub fn popup_above_or_below_widget<R>(
ui: &Ui,
parent_ui: &Ui,
popup_id: Id,
widget_response: &Response,
above_or_below: AboveOrBelow,
add_contents: impl FnOnce(&mut Ui) -> R,
) -> Option<R> {
if ui.memory(|mem| mem.is_popup_open(popup_id)) {
if parent_ui.memory(|mem| mem.is_popup_open(popup_id)) {
let (pos, pivot) = match above_or_below {
AboveOrBelow::Above => (widget_response.rect.left_top(), Align2::LEFT_BOTTOM),
AboveOrBelow::Below => (widget_response.rect.left_bottom(), Align2::LEFT_TOP),
@ -350,8 +350,8 @@ pub fn popup_above_or_below_widget<R>(
.constrain(true)
.fixed_pos(pos)
.pivot(pivot)
.show(ui.ctx(), |ui| {
let frame = Frame::popup(ui.style());
.show(parent_ui.ctx(), |ui| {
let frame = Frame::popup(parent_ui.style());
let frame_margin = frame.total_margin();
frame
.show(ui, |ui| {
@ -365,8 +365,8 @@ pub fn popup_above_or_below_widget<R>(
})
.inner;
if ui.input(|i| i.key_pressed(Key::Escape)) || widget_response.clicked_elsewhere() {
ui.memory_mut(|mem| mem.close_popup());
if parent_ui.input(|i| i.key_pressed(Key::Escape)) || widget_response.clicked_elsewhere() {
parent_ui.memory_mut(|mem| mem.close_popup());
}
Some(inner)
} else {