| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  | use super::Widget;
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  | use gtk::prelude::*;
 | 
					
						
							|  |  |  | use gtk_macros::get_widget;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// A widget displaying a title, a framed child widget and, if needed, some
 | 
					
						
							|  |  |  | /// actions.
 | 
					
						
							|  |  |  | pub struct Section {
 | 
					
						
							|  |  |  |     /// The actual GTK widget.
 | 
					
						
							|  |  |  |     pub widget: gtk::Box,
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /// The box containing the title and action buttons.
 | 
					
						
							|  |  |  |     title_box: gtk::Box,
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /// An optional subtitle below the title.
 | 
					
						
							|  |  |  |     subtitle_label: gtk::Label,
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  | }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | impl Section {
 | 
					
						
							|  |  |  |     /// Create a new section.
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  |     pub fn new<W: Widget>(title: &str, content: &W) -> Self {
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  |         let builder = gtk::Builder::from_resource("/de/johrpan/musicus/ui/section.ui");
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         get_widget!(builder, gtk::Box, widget);
 | 
					
						
							|  |  |  |         get_widget!(builder, gtk::Box, title_box);
 | 
					
						
							|  |  |  |         get_widget!(builder, gtk::Label, title_label);
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  |         get_widget!(builder, gtk::Label, subtitle_label);
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  |         get_widget!(builder, gtk::Frame, frame);
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         title_label.set_label(title);
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  |         frame.set_child(Some(&content.get_widget()));
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         Self {
 | 
					
						
							|  |  |  |             widget,
 | 
					
						
							|  |  |  |             title_box,
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  |             subtitle_label,
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  |         }
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  |     /// Add a subtitle below the title.
 | 
					
						
							|  |  |  |     pub fn set_subtitle(&self, subtitle: &str) {
 | 
					
						
							|  |  |  |         self.subtitle_label.set_label(subtitle);
 | 
					
						
							|  |  |  |         self.subtitle_label.show();
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-31 20:03:20 +01:00
										 |  |  |     /// Add an action button. This should by definition be something that is
 | 
					
						
							|  |  |  |     /// doing something with the child widget that is applicable in all
 | 
					
						
							|  |  |  |     /// situations where the widget is visible. The new button will be packed
 | 
					
						
							|  |  |  |     /// to the end of the title box.
 | 
					
						
							|  |  |  |     pub fn add_action<F: Fn() + 'static>(&self, icon_name: &str, cb: F) {
 | 
					
						
							|  |  |  |         let button = gtk::ButtonBuilder::new()
 | 
					
						
							|  |  |  |             .has_frame(false)
 | 
					
						
							|  |  |  |             .valign(gtk::Align::Center)
 | 
					
						
							|  |  |  |             .icon_name(icon_name)
 | 
					
						
							|  |  |  |             .build();
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         button.connect_clicked(move |_| cb());
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         self.title_box.append(&button);
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 | 
					
						
							| 
									
										
										
										
											2021-02-02 12:18:42 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | impl Widget for Section {
 | 
					
						
							|  |  |  |     fn get_widget(&self) -> gtk::Widget {
 | 
					
						
							|  |  |  |         self.widget.clone().upcast()
 | 
					
						
							|  |  |  |     }
 | 
					
						
							|  |  |  | }
 |