about summary refs log tree commit diff
path: root/src/ui
diff options
context:
space:
mode:
authorRicky Kresslein <rk@lakoliu.com>2022-04-20 09:59:46 +0300
committerRicky Kresslein <rk@lakoliu.com>2022-04-20 11:22:07 +0300
commit49007b3d4073b19c7b9ea352bc36f4ecca2de22a (patch)
tree5f9ba96b0b9445a99159aafce12f4678873ff369 /src/ui
parenta4ad1ee1b69af7ce7ea6b07cbb4ae0a604dd5836 (diff)
downloadFurtherance-49007b3d4073b19c7b9ea352bc36f4ecca2de22a.tar.zst
Change start btn color and deactivate when task is empty
Diffstat (limited to 'src/ui')
-rwxr-xr-xsrc/ui/window.rs98
1 files changed, 43 insertions, 55 deletions
diff --git a/src/ui/window.rs b/src/ui/window.rs
index e535c2e..9052e34 100755
--- a/src/ui/window.rs
+++ b/src/ui/window.rs
@@ -125,11 +125,6 @@ impl FurtheranceWindow {
         imp.task_input.set_sensitive(sensitive);
     }
 
-    fn get_task_text(&self) -> String {
-        let imp = imp::FurtheranceWindow::from_instance(self);
-        imp.task_input.text().to_string()
-    }
-
     fn save_task(&self, start_time: DateTime<Local>, mut stop_time: DateTime<Local>) {
         // Save the most recent task to the database and clear the task_input field
         let imp = imp::FurtheranceWindow::from_instance(self);
@@ -169,6 +164,8 @@ impl FurtheranceWindow {
             self.add_css_class("devel");
         }
 
+        imp.start_button.set_sensitive(false);
+        imp.start_button.add_css_class("suggested-action");
         imp.task_input.grab_focus();
     }
 
@@ -179,60 +176,51 @@ impl FurtheranceWindow {
         let start_time = Rc::new(RefCell::new(Local::now()));
         let stop_time = Rc::new(RefCell::new(Local::now()));
 
-        imp.start_button.connect_clicked(clone!(
-            @weak self as this => move |button| {
+        imp.task_input.connect_changed(clone!(@weak self as this => move |task_input| {
             let imp2 = imp::FurtheranceWindow::from_instance(&this);
-            if this.get_task_text().trim().is_empty() {
-                let dialog = gtk::MessageDialog::with_markup(
-                    Some(&this),
-                    gtk::DialogFlags::MODAL,
-                    gtk::MessageType::Error,
-                    gtk::ButtonsType::Ok,
-                    Some(&format!("<span size='large'>{}</span>", &gettext("No Task Name"))),
-                );
-                dialog.set_secondary_text(Some(&gettext("Enter a task name to start the timer.")));
-                dialog.show();
-
-                dialog.connect_response(clone!(@strong dialog => move |_,_|{
-                    dialog.close();
-                }));
-
+            if task_input.text().trim().is_empty() {
+                imp2.start_button.set_sensitive(false);
             } else {
-                if !*imp2.running.lock().unwrap() {
-                    let mut secs: u32 = 0;
-                    let mut mins: u32 = 0;
-                    let mut hrs: u32 = 0;
-
-                    *imp2.running.lock().unwrap() = true;
-                    *start_time.borrow_mut() = Local::now();
-                    this.activate_task_input(false);
-                    let duration = Duration::new(1,0);
-                    timeout_add_local(duration, clone!(@strong this as this_clone => move || {
-                        let imp3 = imp::FurtheranceWindow::from_instance(&this_clone);
-                        if *imp3.running.lock().unwrap() {
-                            secs += 1;
-                            if secs > 59 {
-                                secs = 0;
-                                mins += 1;
-                                if mins > 59 {
-                                    mins = 0;
-                                    hrs += 1;
-                                }
+                imp2.start_button.set_sensitive(true);
+            }
+        }));
+
+        imp.start_button.connect_clicked(clone!(@weak self as this => move |button| {
+            let imp2 = imp::FurtheranceWindow::from_instance(&this);
+            if !*imp2.running.lock().unwrap() {
+                let mut secs: u32 = 0;
+                let mut mins: u32 = 0;
+                let mut hrs: u32 = 0;
+
+                *imp2.running.lock().unwrap() = true;
+                *start_time.borrow_mut() = Local::now();
+                this.activate_task_input(false);
+                let duration = Duration::new(1,0);
+                timeout_add_local(duration, clone!(@strong this as this_clone => move || {
+                    let imp3 = imp::FurtheranceWindow::from_instance(&this_clone);
+                    if *imp3.running.lock().unwrap() {
+                        secs += 1;
+                        if secs > 59 {
+                            secs = 0;
+                            mins += 1;
+                            if mins > 59 {
+                                mins = 0;
+                                hrs += 1;
                             }
-                            let watch_text: &str = &format!("{:02}:{:02}:{:02}", hrs, mins, secs).to_string();
-                            this_clone.set_watch_time(watch_text);
                         }
-                        Continue(*imp3.running.lock().unwrap())
-                    }));
-                    button.set_icon_name("media-playback-stop-symbolic");
-                } else {
-                    *stop_time.borrow_mut() = Local::now();
-                    *imp2.running.lock().unwrap() = false;
-                    button.set_icon_name("media-playback-start-symbolic");
-                    this.set_watch_time("00:00:00");
-                    this.activate_task_input(true);
-                    this.save_task(*start_time.borrow(), *stop_time.borrow());
-                }
+                        let watch_text: &str = &format!("{:02}:{:02}:{:02}", hrs, mins, secs).to_string();
+                        this_clone.set_watch_time(watch_text);
+                    }
+                    Continue(*imp3.running.lock().unwrap())
+                }));
+                button.set_icon_name("media-playback-stop-symbolic");
+            } else {
+                *stop_time.borrow_mut() = Local::now();
+                *imp2.running.lock().unwrap() = false;
+                button.set_icon_name("media-playback-start-symbolic");
+                this.set_watch_time("00:00:00");
+                this.activate_task_input(true);
+                this.save_task(*start_time.borrow(), *stop_time.borrow());
             }
         }));
     }