passy_scene_main_menu.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. #include "../passy_i.h"
  2. #define TAG "SceneMainMenu"
  3. enum SubmenuIndex {
  4. SubmenuIndexRead,
  5. };
  6. void passy_scene_main_menu_submenu_callback(void* context, uint32_t index) {
  7. Passy* passy = context;
  8. view_dispatcher_send_custom_event(passy->view_dispatcher, index);
  9. }
  10. void passy_scene_main_menu_on_enter(void* context) {
  11. Passy* passy = context;
  12. Submenu* submenu = passy->submenu;
  13. submenu_reset(submenu);
  14. submenu_add_item(
  15. submenu, "Read", SubmenuIndexRead, passy_scene_main_menu_submenu_callback, passy);
  16. view_dispatcher_switch_to_view(passy->view_dispatcher, PassyViewMenu);
  17. }
  18. bool passy_scene_main_menu_on_event(void* context, SceneManagerEvent event) {
  19. Passy* passy = context;
  20. bool consumed = false;
  21. if(event.type == SceneManagerEventTypeCustom) {
  22. if(event.event == SubmenuIndexRead) {
  23. scene_manager_set_scene_state(
  24. passy->scene_manager, PassySceneMainMenu, SubmenuIndexRead);
  25. if(strlen(passy->passport_number) > 0 && strlen(passy->date_of_birth) > 0 &&
  26. strlen(passy->date_of_expiry) > 0) {
  27. scene_manager_next_scene(passy->scene_manager, PassySceneRead);
  28. } else {
  29. scene_manager_next_scene(passy->scene_manager, PassyScenePassportNumberInput);
  30. }
  31. consumed = true;
  32. }
  33. }
  34. return consumed;
  35. }
  36. void passy_scene_main_menu_on_exit(void* context) {
  37. Passy* passy = context;
  38. submenu_reset(passy->submenu);
  39. }