InfiniTime.git

commit 3c9b3435a55b201ef29e50ba2c43cfe500a90a55

Author: Riku Isokoski <riksu9000@gmail.com>

SetingTimeFormat use CheckboxList, reduce duplication

 src/displayapp/screens/CheckboxList.cpp | 4 
 src/displayapp/screens/settings/SettingTimeFormat.cpp | 99 +++++-------
 src/displayapp/screens/settings/SettingTimeFormat.h | 15 -


diff --git a/src/displayapp/screens/CheckboxList.cpp b/src/displayapp/screens/CheckboxList.cpp
index c189b075136d25fa0d21dd51a24bb9883a663aff..928b2e6127c736f22289329f8a9414aa02b5b47f 100644
--- a/src/displayapp/screens/CheckboxList.cpp
+++ b/src/displayapp/screens/CheckboxList.cpp
@@ -28,7 +28,9 @@     pageIndicator(screenID, numScreens) {
   // Set the background to Black
   lv_obj_set_style_local_bg_color(lv_scr_act(), LV_OBJ_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_BLACK);
 
-  pageIndicator.Create();
+  if (numScreens > 1) {
+    pageIndicator.Create();
+  }
 
   lv_obj_t* container1 = lv_cont_create(lv_scr_act(), nullptr);
 




diff --git a/src/displayapp/screens/settings/SettingTimeFormat.cpp b/src/displayapp/screens/settings/SettingTimeFormat.cpp
index e137c0af87d4227a71fa6540da7845535a022de3..824a10b25b69f74881634f27cad46d382c460bf4 100644
--- a/src/displayapp/screens/settings/SettingTimeFormat.cpp
+++ b/src/displayapp/screens/settings/SettingTimeFormat.cpp
@@ -8,69 +8,56 @@
 using namespace Pinetime::Applications::Screens;
 
 namespace {
-  void event_handler(lv_obj_t* obj, lv_event_t event) {
-    auto* screen = static_cast<SettingTimeFormat*>(obj->user_data);
-    screen->UpdateSelected(obj, event);
-  }
-}
+  struct Option {
+    Pinetime::Controllers::Settings::ClockType clockType;
+    const char* name;
+  };
 
-constexpr std::array<SettingTimeFormat::Option, 2> SettingTimeFormat::options;
+  constexpr std::array<Option, 2> options = {{
+    {Pinetime::Controllers::Settings::ClockType::H12, "12-hour"},
+    {Pinetime::Controllers::Settings::ClockType::H24, "24-hour"},
+  }};
 
-SettingTimeFormat::SettingTimeFormat(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController)
-  : Screen(app), settingsController {settingsController} {
-
-  lv_obj_t* container1 = lv_cont_create(lv_scr_act(), nullptr);
-
-  lv_obj_set_style_local_bg_opa(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, LV_OPA_TRANSP);
-  lv_obj_set_style_local_pad_all(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 10);
-  lv_obj_set_style_local_pad_inner(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 5);
-  lv_obj_set_style_local_border_width(container1, LV_CONT_PART_MAIN, LV_STATE_DEFAULT, 0);
-
-  lv_obj_set_pos(container1, 10, 60);
-  lv_obj_set_width(container1, LV_HOR_RES - 20);
-  lv_obj_set_height(container1, LV_VER_RES - 50);
-  lv_cont_set_layout(container1, LV_LAYOUT_COLUMN_LEFT);
+  std::array<CheckboxList::Item, CheckboxList::MaxItems> CreateOptionArray() {
+    std::array<Pinetime::Applications::Screens::CheckboxList::Item, CheckboxList::MaxItems> optionArray;
+    for (size_t i = 0; i < CheckboxList::MaxItems; i++) {
+      if (i >= options.size()) {
+        optionArray[i].name = "";
+        optionArray[i].enabled = false;
+      } else {
+        optionArray[i].name = options[i].name;
+        optionArray[i].enabled = true;
+      }
+    }
+    return optionArray;
+  }
 
-  lv_obj_t* title = lv_label_create(lv_scr_act(), nullptr);
-  lv_label_set_text_static(title, "Time format");
-  lv_label_set_align(title, LV_LABEL_ALIGN_CENTER);
-  lv_obj_align(title, lv_scr_act(), LV_ALIGN_IN_TOP_MID, 15, 15);
-
-  lv_obj_t* icon = lv_label_create(lv_scr_act(), nullptr);
-  lv_obj_set_style_local_text_color(icon, LV_LABEL_PART_MAIN, LV_STATE_DEFAULT, LV_COLOR_ORANGE);
-  lv_label_set_text_static(icon, Symbols::clock);
-  lv_label_set_align(icon, LV_LABEL_ALIGN_CENTER);
-  lv_obj_align(icon, title, LV_ALIGN_OUT_LEFT_MID, -10, 0);
-
-  for (unsigned int i = 0; i < options.size(); i++) {
-    cbOption[i] = lv_checkbox_create(container1, nullptr);
-    lv_checkbox_set_text(cbOption[i], options[i].name);
-    cbOption[i]->user_data = this;
-    lv_obj_set_event_cb(cbOption[i], event_handler);
-    SetRadioButtonStyle(cbOption[i]);
+  uint32_t GetDefaultOption(Pinetime::Controllers::Settings::ClockType currentOption) {
+    for (size_t i = 0; i < options.size(); i++) {
+      if (options[i].clockType == currentOption) {
+        return i;
+      }
+    }
+    return 0;
   }
+}
 
-  if (settingsController.GetClockType() == Controllers::Settings::ClockType::H12) {
-    lv_checkbox_set_checked(cbOption[0], true);
-  } else if (settingsController.GetClockType() == Controllers::Settings::ClockType::H24) {
-    lv_checkbox_set_checked(cbOption[1], true);
-  }
+SettingTimeFormat::SettingTimeFormat(Pinetime::Applications::DisplayApp* app, Pinetime::Controllers::Settings& settingsController)
+  : Screen(app),
+    checkboxList(
+      0,
+      1,
+      app,
+      "Time format",
+      Symbols::clock,
+      GetDefaultOption(settingsController.GetClockType()),
+      [&settings = settingsController](uint32_t index) {
+        settings.SetClockType(options[index].clockType);
+        settings.SaveSettings();
+      },
+      CreateOptionArray()) {
 }
 
 SettingTimeFormat::~SettingTimeFormat() {
   lv_obj_clean(lv_scr_act());
-  settingsController.SaveSettings();
-}
-
-void SettingTimeFormat::UpdateSelected(lv_obj_t* object, lv_event_t event) {
-  if (event == LV_EVENT_VALUE_CHANGED) {
-    for (unsigned int i = 0; i < options.size(); i++) {
-      if (object == cbOption[i]) {
-        lv_checkbox_set_checked(cbOption[i], true);
-        settingsController.SetClockType(options[i].clockType);
-      } else {
-        lv_checkbox_set_checked(cbOption[i], false);
-      }
-    }
-  }
 }




diff --git a/src/displayapp/screens/settings/SettingTimeFormat.h b/src/displayapp/screens/settings/SettingTimeFormat.h
index 426dc1974b25eb8b9c417449bb6f1646e29bd4c4..de37f43e387d4605338dffd8c1f1fa759d0deed8 100644
--- a/src/displayapp/screens/settings/SettingTimeFormat.h
+++ b/src/displayapp/screens/settings/SettingTimeFormat.h
@@ -6,6 +6,7 @@ #include 
 
 #include "components/settings/Settings.h"
 #include "displayapp/screens/Screen.h"
+#include "displayapp/screens/CheckboxList.h"
 
 namespace Pinetime {
 
@@ -17,20 +18,8 @@       public:
         SettingTimeFormat(DisplayApp* app, Pinetime::Controllers::Settings& settingsController);
         ~SettingTimeFormat() override;
 
-        void UpdateSelected(lv_obj_t* object, lv_event_t event);
-
       private:
-        struct Option {
-          Controllers::Settings::ClockType clockType;
-          const char* name;
-        };
-
-        static constexpr std::array<Option, 2> options = {{
-          {Controllers::Settings::ClockType::H12, "12-hour"},
-          {Controllers::Settings::ClockType::H24, "24-hour"},
-        }};
-        Controllers::Settings& settingsController;
-        lv_obj_t* cbOption[options.size()];
+        CheckboxList checkboxList;
       };
     }
   }