Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/ClusterM/flipperzero-firmware.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'applications/nfc/scenes/nfc_scene_retry_confirm.c')
-rw-r--r--applications/nfc/scenes/nfc_scene_retry_confirm.c47
1 files changed, 47 insertions, 0 deletions
diff --git a/applications/nfc/scenes/nfc_scene_retry_confirm.c b/applications/nfc/scenes/nfc_scene_retry_confirm.c
new file mode 100644
index 00000000..f7b3991e
--- /dev/null
+++ b/applications/nfc/scenes/nfc_scene_retry_confirm.c
@@ -0,0 +1,47 @@
+#include "../nfc_i.h"
+
+void nfc_scene_retry_confirm_dialog_callback(DialogExResult result, void* context) {
+ Nfc* nfc = context;
+
+ view_dispatcher_send_custom_event(nfc->view_dispatcher, result);
+}
+
+void nfc_scene_retry_confirm_on_enter(void* context) {
+ Nfc* nfc = context;
+ DialogEx* dialog_ex = nfc->dialog_ex;
+
+ dialog_ex_set_left_button_text(dialog_ex, "Retry");
+ dialog_ex_set_right_button_text(dialog_ex, "Stay");
+ dialog_ex_set_header(dialog_ex, "Retry reading?", 64, 11, AlignCenter, AlignTop);
+ dialog_ex_set_text(
+ dialog_ex, "All unsaved data will be\nlost.", 64, 25, AlignCenter, AlignTop);
+ dialog_ex_set_context(dialog_ex, nfc);
+ dialog_ex_set_result_callback(dialog_ex, nfc_scene_retry_confirm_dialog_callback);
+
+ view_dispatcher_switch_to_view(nfc->view_dispatcher, NfcViewDialogEx);
+}
+
+bool nfc_scene_retry_confirm_on_event(void* context, SceneManagerEvent event) {
+ Nfc* nfc = context;
+ bool consumed = false;
+
+ if(event.type == SceneManagerEventTypeCustom) {
+ if(event.event == DialogExResultRight) {
+ consumed = scene_manager_previous_scene(nfc->scene_manager);
+ } else if(event.event == DialogExResultLeft) {
+ consumed = scene_manager_search_and_switch_to_previous_scene(
+ nfc->scene_manager, NfcSceneRead);
+ }
+ } else if(event.type == SceneManagerEventTypeBack) {
+ consumed = true;
+ }
+
+ return consumed;
+}
+
+void nfc_scene_retry_confirm_on_exit(void* context) {
+ Nfc* nfc = context;
+
+ // Clean view
+ dialog_ex_reset(nfc->dialog_ex);
+}