picopass_scene_saved_menu.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include "../picopass_i.h"
  2. enum SubmenuIndex {
  3. SubmenuIndexDelete,
  4. SubmenuIndexInfo,
  5. SubmenuIndexWrite,
  6. };
  7. void picopass_scene_saved_menu_submenu_callback(void* context, uint32_t index) {
  8. Picopass* picopass = context;
  9. view_dispatcher_send_custom_event(picopass->view_dispatcher, index);
  10. }
  11. void picopass_scene_saved_menu_on_enter(void* context) {
  12. Picopass* picopass = context;
  13. Submenu* submenu = picopass->submenu;
  14. submenu_add_item(
  15. submenu,
  16. "Delete",
  17. SubmenuIndexDelete,
  18. picopass_scene_saved_menu_submenu_callback,
  19. picopass);
  20. submenu_add_item(
  21. submenu, "Info", SubmenuIndexInfo, picopass_scene_saved_menu_submenu_callback, picopass);
  22. submenu_set_selected_item(
  23. picopass->submenu,
  24. scene_manager_get_scene_state(picopass->scene_manager, PicopassSceneSavedMenu));
  25. view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewMenu);
  26. }
  27. bool picopass_scene_saved_menu_on_event(void* context, SceneManagerEvent event) {
  28. Picopass* picopass = context;
  29. bool consumed = false;
  30. if(event.type == SceneManagerEventTypeCustom) {
  31. scene_manager_set_scene_state(
  32. picopass->scene_manager, PicopassSceneSavedMenu, event.event);
  33. if(event.event == SubmenuIndexDelete) {
  34. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDelete);
  35. consumed = true;
  36. } else if(event.event == SubmenuIndexInfo) {
  37. scene_manager_next_scene(picopass->scene_manager, PicopassSceneDeviceInfo);
  38. consumed = true;
  39. }
  40. }
  41. return consumed;
  42. }
  43. void picopass_scene_saved_menu_on_exit(void* context) {
  44. Picopass* picopass = context;
  45. submenu_reset(picopass->submenu);
  46. }