spi_mem_scene_select_model.c 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. #include "../spi_mem_app_i.h"
  2. static void spi_mem_scene_select_model_submenu_callback(void* context, uint32_t index) {
  3. SPIMemApp* app = context;
  4. spi_mem_chip_copy_chip_info(app->chip_info, *found_chips_get(app->found_chips, index));
  5. view_dispatcher_send_custom_event(app->view_dispatcher, index);
  6. }
  7. void spi_mem_scene_select_model_on_enter(void* context) {
  8. SPIMemApp* app = context;
  9. size_t models_on_vendor = 0;
  10. for(size_t index = 0; index < found_chips_size(app->found_chips); index++) {
  11. if(spi_mem_chip_get_vendor_enum(*found_chips_get(app->found_chips, index)) !=
  12. app->chip_vendor_enum)
  13. continue;
  14. submenu_add_item(
  15. app->submenu,
  16. spi_mem_chip_get_model_name(*found_chips_get(app->found_chips, index)),
  17. index,
  18. spi_mem_scene_select_model_submenu_callback,
  19. app);
  20. models_on_vendor++;
  21. }
  22. if(models_on_vendor == 1) spi_mem_scene_select_model_submenu_callback(context, 0);
  23. submenu_set_header(app->submenu, "Choose chip model");
  24. submenu_set_selected_item(
  25. app->submenu, scene_manager_get_scene_state(app->scene_manager, SPIMemSceneSelectVendor));
  26. view_dispatcher_switch_to_view(app->view_dispatcher, SPIMemViewSubmenu);
  27. }
  28. bool spi_mem_scene_select_model_on_event(void* context, SceneManagerEvent event) {
  29. SPIMemApp* app = context;
  30. bool success = false;
  31. if(event.type == SceneManagerEventTypeCustom) {
  32. scene_manager_set_scene_state(app->scene_manager, SPIMemSceneSelectVendor, event.event);
  33. scene_manager_next_scene(app->scene_manager, SPIMemSceneChipDetected);
  34. success = true;
  35. }
  36. return success;
  37. }
  38. void spi_mem_scene_select_model_on_exit(void* context) {
  39. SPIMemApp* app = context;
  40. submenu_reset(app->submenu);
  41. }