UI template
This commit is contained in:
		
					parent
					
						
							
								8cec608e21
							
						
					
				
			
			
				commit
				
					
						b6413f0e7d
					
				
			
		
					 6 changed files with 5897 additions and 21 deletions
				
			
		
							
								
								
									
										5815
									
								
								Cargo.lock
									
										
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										5815
									
								
								Cargo.lock
									
										
									
										generated
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										10
									
								
								src/main.rs
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								src/main.rs
									
										
									
									
									
								
							|  | @ -7,15 +7,7 @@ slint::include_modules!(); | |||
| 
 | ||||
| fn main() -> Result<(), Box<dyn Error>> { | ||||
|     let ui = AppWindow::new()?; | ||||
| 
 | ||||
|     ui.on_request_increase_value({ | ||||
|         let ui_handle = ui.as_weak(); | ||||
|         move || { | ||||
|             let ui = ui_handle.unwrap(); | ||||
|             ui.set_counter(ui.get_counter() + 1); | ||||
|         } | ||||
|     }); | ||||
| 
 | ||||
|     
 | ||||
|     ui.run()?; | ||||
| 
 | ||||
|     Ok(()) | ||||
|  |  | |||
|  | @ -1,18 +1,16 @@ | |||
| import { Button, VerticalBox } from "std-widgets.slint"; | ||||
| import { TabWidget } from "std-widgets.slint"; | ||||
| import { RecordWidget } from "record.slint"; | ||||
| import { ReviewWidget } from "review.slint"; | ||||
| 
 | ||||
| export component AppWindow inherits Window { | ||||
|     in-out property <int> counter: 42; | ||||
|     callback request-increase-value(); | ||||
|     VerticalBox { | ||||
|         Text { | ||||
|             text: "Counter: \{root.counter}"; | ||||
|     TabWidget { | ||||
|         Tab { | ||||
|             title: "Record"; | ||||
|             RecordWidget {} | ||||
|         } | ||||
| 
 | ||||
|         Button { | ||||
|             text: "Increase value"; | ||||
|             clicked => { | ||||
|                 root.request-increase-value(); | ||||
|             } | ||||
|         Tab { | ||||
|             title: "Review"; | ||||
|             ReviewWidget {} | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  |  | |||
							
								
								
									
										35
									
								
								ui/record.slint
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								ui/record.slint
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| import { VerticalBox, LineEdit, Button, ComboBox } from "std-widgets.slint"; | ||||
| import { Timeline } from "timeline.slint"; | ||||
| 
 | ||||
| export component RecordWidget inherits VerticalBox { | ||||
|     Timeline {} | ||||
|     GridLayout { | ||||
|         spacing-vertical: 8px; | ||||
|         spacing-horizontal: 16px; | ||||
|         LineEdit { | ||||
|             placeholder-text: "Event name"; | ||||
|             text: "Event name"; | ||||
|             font-size: 24px; | ||||
|             horizontal-alignment: center; | ||||
|             colspan: 2; | ||||
|             row: 0; | ||||
|         } | ||||
|         Button { | ||||
|             text: "Start"; | ||||
|             colspan: 2; | ||||
|             row: 1; | ||||
|         } | ||||
|         Text { | ||||
|             text: "Span:"; | ||||
|             font-size: 24px; | ||||
|             row: 2; | ||||
|             horizontal-alignment: right; | ||||
|         } | ||||
|         ComboBox { | ||||
|             model: ["1 Hour", "4 Hours", "8 Hours", "24 Hours"]; | ||||
|             current-index: 0; | ||||
|             row: 2; | ||||
|             col: 1; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										35
									
								
								ui/review.slint
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								ui/review.slint
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,35 @@ | |||
| import { VerticalBox, LineEdit, Button, DatePickerPopup } from "std-widgets.slint"; | ||||
| import { Timeline } from "timeline.slint"; | ||||
| 
 | ||||
| export component ReviewWidget inherits VerticalBox { | ||||
|     property<int> current-year; | ||||
|     property<int> current-month; | ||||
|     property<int> current-day; | ||||
| 
 | ||||
|     Timeline {} | ||||
|     GridLayout { | ||||
|         spacing-vertical: 8px; | ||||
|         spacing-horizontal: 16px; | ||||
|         Text { | ||||
|             text: "Day: \{current-day}/\{current-month}/\{current-year}"; | ||||
|             font-size: 32px; | ||||
|             horizontal-alignment: right; | ||||
|         } | ||||
|         Button { | ||||
|             text: "Select"; | ||||
|             clicked => { | ||||
|                 date-picker.show() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|     date-picker := DatePickerPopup { | ||||
|         x: (root.width - self.width) / 2; | ||||
|         y: (root.height - self.height) / 2; | ||||
|         title: ""; | ||||
|         accepted(date) => { | ||||
|             current-year = date.year; | ||||
|             current-month = date.month; | ||||
|             current-day = date.day; | ||||
|         } | ||||
|     } | ||||
| } | ||||
							
								
								
									
										1
									
								
								ui/timeline.slint
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								ui/timeline.slint
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| export component Timeline inherits Path {} | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue