| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #include "../seader_i.h"
- enum SubmenuIndex {
- SubmenuIndexReadPicopass,
- SubmenuIndexRead14a,
- SubmenuIndexReadMfc,
- SubmenuIndexSaved,
- SubmenuIndexAPDURunner,
- SubmenuIndexSamInfo,
- SubmenuIndexFwVersion,
- };
- static uint8_t fwChecks = 3;
- void seader_scene_sam_present_submenu_callback(void* context, uint32_t index) {
- Seader* seader = context;
- view_dispatcher_send_custom_event(seader->view_dispatcher, index);
- }
- void seader_scene_sam_present_on_update(void* context) {
- Seader* seader = context;
- SeaderWorker* seader_worker = seader->worker;
- Submenu* submenu = seader->submenu;
- submenu_reset(submenu);
- submenu_add_item(
- submenu,
- "Read Picopass",
- SubmenuIndexReadPicopass,
- seader_scene_sam_present_submenu_callback,
- seader);
- submenu_add_item(
- submenu,
- "Read 14443A",
- SubmenuIndexRead14a,
- seader_scene_sam_present_submenu_callback,
- seader);
- submenu_add_item(
- submenu,
- "Read MFC",
- SubmenuIndexReadMfc,
- seader_scene_sam_present_submenu_callback,
- seader);
- submenu_add_item(
- submenu, "Saved", SubmenuIndexSaved, seader_scene_sam_present_submenu_callback, seader);
- if(apdu_log_check_presence(SEADER_APDU_RUNNER_FILE_NAME)) {
- submenu_add_item(
- submenu,
- "Run APDUs",
- SubmenuIndexAPDURunner,
- seader_scene_sam_present_submenu_callback,
- seader);
- }
- if(seader_worker->sam_version[0] != 0 && seader_worker->sam_version[1] != 0) {
- FuriString* fw_str = furi_string_alloc();
- furi_string_cat_printf(
- fw_str, "FW %d.%d", seader_worker->sam_version[0], seader_worker->sam_version[1]);
- submenu_add_item(
- submenu,
- furi_string_get_cstr(fw_str),
- SubmenuIndexFwVersion,
- seader_scene_sam_present_submenu_callback,
- seader);
- furi_string_free(fw_str);
- fwChecks = 0;
- }
- submenu_set_selected_item(
- submenu, scene_manager_get_scene_state(seader->scene_manager, SeaderSceneSamPresent));
- view_dispatcher_switch_to_view(seader->view_dispatcher, SeaderViewMenu);
- }
- void seader_scene_sam_present_on_enter(void* context) {
- seader_scene_sam_present_on_update(context);
- }
- bool seader_scene_sam_present_on_event(void* context, SceneManagerEvent event) {
- Seader* seader = context;
- bool consumed = false;
- if(event.type == SceneManagerEventTypeCustom) {
- scene_manager_set_scene_state(seader->scene_manager, SeaderSceneSamPresent, event.event);
- if(event.event == SubmenuIndexReadPicopass) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneReadPicopass);
- consumed = true;
- } else if(event.event == SubmenuIndexRead14a) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneRead14a);
- consumed = true;
- } else if(event.event == SubmenuIndexReadMfc) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneReadMfc);
- consumed = true;
- } else if(event.event == SubmenuIndexSamInfo) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneSamInfo);
- consumed = true;
- } else if(event.event == SubmenuIndexSaved) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneFileSelect);
- consumed = true;
- } else if(event.event == SubmenuIndexFwVersion) {
- consumed = true;
- } else if(event.event == SeaderWorkerEventSamMissing) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneSamMissing);
- consumed = true;
- } else if(event.event == SubmenuIndexAPDURunner) {
- scene_manager_next_scene(seader->scene_manager, SeaderSceneAPDURunner);
- consumed = true;
- }
- } else if(event.type == SceneManagerEventTypeBack) {
- scene_manager_stop(seader->scene_manager);
- view_dispatcher_stop(seader->view_dispatcher);
- consumed = true;
- } else if(event.type == SceneManagerEventTypeTick) {
- SeaderWorker* seader_worker = seader->worker;
- if(fwChecks > 0 && seader_worker->sam_version[0] != 0 &&
- seader_worker->sam_version[1] != 0) {
- fwChecks--;
- seader_scene_sam_present_on_update(context);
- }
- }
- return consumed;
- }
- void seader_scene_sam_present_on_exit(void* context) {
- Seader* seader = context;
- submenu_reset(seader->submenu);
- }
|