pof_scene_main.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. #include "../portal_of_flipper_i.h"
  2. #include "../pof_token.h"
  3. enum SubmenuIndex {
  4. // SubmenuIndexFigure* need to match POF_TOKEN_LIMIT
  5. SubmenuIndexFigure1,
  6. SubmenuIndexFigure2,
  7. SubmenuIndexFigure3,
  8. SubmenuIndexFigure4,
  9. SubmenuIndexFigure5,
  10. SubmenuIndexFigure6,
  11. SubmenuIndexFigure7,
  12. SubmenuIndexLoad,
  13. };
  14. void pof_scene_main_submenu_callback(void* context, uint32_t index) {
  15. PoFApp* pof = context;
  16. view_dispatcher_send_custom_event(pof->view_dispatcher, index);
  17. }
  18. void pof_scene_main_on_update(void* context) {
  19. PoFApp* pof = context;
  20. VirtualPortal* virtual_portal = pof->virtual_portal;
  21. Submenu* submenu = pof->submenu;
  22. submenu_reset(pof->submenu);
  23. FuriString* token_name = furi_string_alloc();
  24. if(pof->pof_usb) {
  25. int count = 0;
  26. for(int i = 0; i < POF_TOKEN_LIMIT; i++) {
  27. if(virtual_portal->tokens[i]->loaded) {
  28. PoFToken* pof_token = virtual_portal->tokens[i];
  29. furi_string_reset(token_name);
  30. //TODO: only do if debug mode
  31. furi_string_cat_printf(token_name, "%d: %s", i, pof_token->dev_name);
  32. // Unload figure
  33. submenu_add_item(
  34. submenu,
  35. furi_string_get_cstr(token_name),
  36. SubmenuIndexFigure1 + i,
  37. pof_scene_main_submenu_callback,
  38. pof);
  39. count++;
  40. }
  41. }
  42. if(count < POF_TOKEN_LIMIT) {
  43. submenu_add_item(
  44. submenu, "<Load figure>", SubmenuIndexLoad, pof_scene_main_submenu_callback, pof);
  45. }
  46. submenu_set_selected_item(
  47. submenu, scene_manager_get_scene_state(pof->scene_manager, PoFSceneMain));
  48. } else {
  49. submenu_add_item(
  50. submenu, "Failed to start", SubmenuIndexLoad, pof_scene_main_submenu_callback, pof);
  51. }
  52. furi_string_free(token_name);
  53. view_dispatcher_switch_to_view(pof->view_dispatcher, PoFViewSubmenu);
  54. }
  55. void pof_scene_main_on_enter(void* context) {
  56. pof_scene_main_on_update(context);
  57. }
  58. bool pof_scene_main_on_event(void* context, SceneManagerEvent event) {
  59. PoFApp* pof = context;
  60. VirtualPortal* virtual_portal = pof->virtual_portal;
  61. bool consumed = false;
  62. if(event.type == SceneManagerEventTypeCustom) {
  63. if(event.event == SubmenuIndexLoad) {
  64. if(pof->pof_usb) {
  65. // Explicitly save state so that the correct item is
  66. // reselected if the user cancels loading a file.
  67. scene_manager_set_scene_state(pof->scene_manager, PoFSceneMain, SubmenuIndexLoad);
  68. scene_manager_next_scene(pof->scene_manager, PoFSceneFileSelect);
  69. } else {
  70. // No-op
  71. }
  72. consumed = true;
  73. } else {
  74. pof_token_clear(virtual_portal->tokens[event.event], true);
  75. pof_scene_main_on_update(context);
  76. }
  77. } else if(event.type == SceneManagerEventTypeBack) {
  78. scene_manager_stop(pof->scene_manager);
  79. view_dispatcher_stop(pof->view_dispatcher);
  80. consumed = true;
  81. }
  82. return consumed;
  83. }
  84. void pof_scene_main_on_exit(void* context) {
  85. PoFApp* pof = context;
  86. submenu_reset(pof->submenu);
  87. }