3857cd7d5f
* Fix TextBox word wrap behavior * Wrap width is 120 pixels, not 140. (140 is larger than the screen!) * Glyph width already includes spacing; don't add 1 additional px * When starting a new line, include wrapped glyph width in new line_width. * Call canvas_set_font before text_box_insert_endline so that glyph width is calculated using correct font. Previous approach worked somewhat well using default TextBoxFontText but this version is more robust, particularly when using TextBoxFontHex. * Add basic Mifare DESFire reading, file/app browser * Fix build with APP_ARCHIVE=0 * Add bool type to flipper_format * Add ability to save and load DESFire card data * Skip over NfcSceneDeviceInfo when viewing saved DESFire info * mf_df_clear: don't leak master key settings key versions * When opening a DESFire card from Archive, retain UID emulation behavior * rm unnecessary \r\n * show Popup instead of leaving view in bad state * Move NfcReaderRequestData out of union This makes it safe to emulate DESFire/EMV without clobbering card data. * Display saved DESFire cards via NfcSceneDeviceInfo * Display and save file metadata even when contents are missing This can happen when a file doesn't allow unauthenticated reads (see the call to mf_df_parse_read_data_response in nfc_worker.c). Co-authored-by: Kevin Wallace <git+flipperzero@kevin.wallace.seattle.wa.us> Co-authored-by: あく <alleteam@gmail.com> Co-authored-by: gornekich <n.gorbadey@gmail.com>
62 lines
2.4 KiB
C
62 lines
2.4 KiB
C
#include "../nfc_i.h"
|
|
#include <dolphin/dolphin.h>
|
|
|
|
void nfc_scene_save_success_popup_callback(void* context) {
|
|
Nfc* nfc = (Nfc*)context;
|
|
view_dispatcher_send_custom_event(nfc->view_dispatcher, NfcCustomEventViewExit);
|
|
}
|
|
|
|
void nfc_scene_save_success_on_enter(void* context) {
|
|
Nfc* nfc = (Nfc*)context;
|
|
DOLPHIN_DEED(DolphinDeedNfcSave);
|
|
|
|
// Setup view
|
|
Popup* popup = nfc->popup;
|
|
popup_set_icon(popup, 32, 5, &I_DolphinNice_96x59);
|
|
popup_set_header(popup, "Saved!", 13, 22, AlignLeft, AlignBottom);
|
|
popup_set_timeout(popup, 1500);
|
|
popup_set_context(popup, nfc);
|
|
popup_set_callback(popup, nfc_scene_save_success_popup_callback);
|
|
popup_enable_timeout(popup);
|
|
view_dispatcher_switch_to_view(nfc->view_dispatcher, NfcViewPopup);
|
|
}
|
|
|
|
bool nfc_scene_save_success_on_event(void* context, SceneManagerEvent event) {
|
|
Nfc* nfc = (Nfc*)context;
|
|
bool consumed = false;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == NfcCustomEventViewExit) {
|
|
if(scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneCardMenu)) {
|
|
consumed = scene_manager_search_and_switch_to_previous_scene(
|
|
nfc->scene_manager, NfcSceneCardMenu);
|
|
} else if(scene_manager_has_previous_scene(nfc->scene_manager, NfcSceneSetType)) {
|
|
consumed = scene_manager_search_and_switch_to_another_scene(
|
|
nfc->scene_manager, NfcSceneFileSelect);
|
|
} else if(scene_manager_has_previous_scene(
|
|
nfc->scene_manager, NfcSceneMifareDesfireMenu)) {
|
|
consumed = scene_manager_search_and_switch_to_previous_scene(
|
|
nfc->scene_manager, NfcSceneMifareDesfireMenu);
|
|
} else {
|
|
consumed = scene_manager_search_and_switch_to_previous_scene(
|
|
nfc->scene_manager, NfcSceneStart);
|
|
}
|
|
}
|
|
}
|
|
return consumed;
|
|
}
|
|
|
|
void nfc_scene_save_success_on_exit(void* context) {
|
|
Nfc* nfc = (Nfc*)context;
|
|
|
|
// Clear view
|
|
Popup* popup = nfc->popup;
|
|
popup_set_header(popup, NULL, 0, 0, AlignCenter, AlignBottom);
|
|
popup_set_text(popup, NULL, 0, 0, AlignCenter, AlignTop);
|
|
popup_set_icon(popup, 0, 0, NULL);
|
|
popup_set_callback(popup, NULL);
|
|
popup_set_context(popup, NULL);
|
|
popup_set_timeout(popup, 0);
|
|
popup_disable_timeout(popup);
|
|
}
|