| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- #include "../nfc_i.h"
- #include <dolphin/dolphin.h>
- enum SubmenuIndex {
- SubmenuIndexSaveUid,
- SubmenuIndexEmulateUid,
- SubmenuIndexInfo,
- };
- void nfc_scene_nfca_menu_submenu_callback(void* context, uint32_t index) {
- Nfc* nfc = context;
- view_dispatcher_send_custom_event(nfc->view_dispatcher, index);
- }
- void nfc_scene_nfca_menu_on_enter(void* context) {
- Nfc* nfc = context;
- Submenu* submenu = nfc->submenu;
- submenu_add_item(
- submenu, "Save UID", SubmenuIndexSaveUid, nfc_scene_nfca_menu_submenu_callback, nfc);
- submenu_add_item(
- submenu, "Emulate UID", SubmenuIndexEmulateUid, nfc_scene_nfca_menu_submenu_callback, nfc);
- submenu_add_item(submenu, "Info", SubmenuIndexInfo, nfc_scene_nfca_menu_submenu_callback, nfc);
- submenu_set_selected_item(
- nfc->submenu, scene_manager_get_scene_state(nfc->scene_manager, NfcSceneNfcaMenu));
- view_dispatcher_switch_to_view(nfc->view_dispatcher, NfcViewMenu);
- }
- bool nfc_scene_nfca_menu_on_event(void* context, SceneManagerEvent event) {
- Nfc* nfc = context;
- bool consumed = false;
- if(event.type == SceneManagerEventTypeCustom) {
- if(event.event == SubmenuIndexSaveUid) {
- nfc->dev->format = NfcDeviceSaveFormatUid;
- // Clear device name
- nfc_device_set_name(nfc->dev, "");
- scene_manager_next_scene(nfc->scene_manager, NfcSceneSaveName);
- consumed = true;
- } else if(event.event == SubmenuIndexEmulateUid) {
- scene_manager_next_scene(nfc->scene_manager, NfcSceneEmulateUid);
- if(scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneSetType)) {
- DOLPHIN_DEED(DolphinDeedNfcAddEmulate);
- } else {
- DOLPHIN_DEED(DolphinDeedNfcEmulate);
- }
- consumed = true;
- } else if(event.event == SubmenuIndexInfo) {
- scene_manager_next_scene(nfc->scene_manager, NfcSceneNfcDataInfo);
- consumed = true;
- }
- scene_manager_set_scene_state(nfc->scene_manager, NfcSceneNfcaMenu, event.event);
- } else if(event.type == SceneManagerEventTypeBack) {
- consumed = scene_manager_previous_scene(nfc->scene_manager);
- }
- return consumed;
- }
- void nfc_scene_nfca_menu_on_exit(void* context) {
- Nfc* nfc = context;
- // Clear view
- submenu_reset(nfc->submenu);
- }
|