mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-19 03:11:52 +03:00
8cfd0eab9e
* rfal: add state changed callback * furi_hal_nfc: add NFC-A emulation API * nfc: add emulation logger, refactor scenes * elements: fix text_box element * gui: fix text box module * nfc: remove unnecessary buffers * nfc: introduce emulation callback concept * nfc: format sources * bt settings: fix incorrect scene switch * bt settings: format sources * Debug: fix x2d import for python 3 * Gui: rename method name widget_clear to widget_reset * nfc: add nfca emulation handler * nfc: add global custom events enum * nfc: UID emulation Data -> Log * furi_hal_nfc: fix incorrect timings * u2f, badusb: widget_clear() -> widget_reset() Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
68 lines
2.5 KiB
C
68 lines
2.5 KiB
C
#include "../subghz_i.h"
|
|
#include "../helpers/subghz_custom_event.h"
|
|
|
|
void subghz_scene_need_saving_callback(GuiButtonType result, InputType type, void* context) {
|
|
furi_assert(context);
|
|
SubGhz* subghz = context;
|
|
|
|
if((result == GuiButtonTypeRight) && (type == InputTypeShort)) {
|
|
view_dispatcher_send_custom_event(subghz->view_dispatcher, SubghzCustomEventSceneStay);
|
|
} else if((result == GuiButtonTypeLeft) && (type == InputTypeShort)) {
|
|
view_dispatcher_send_custom_event(subghz->view_dispatcher, SubghzCustomEventSceneExit);
|
|
}
|
|
}
|
|
|
|
void subghz_scene_need_saving_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
|
|
widget_add_string_multiline_element(
|
|
subghz->widget, 64, 13, AlignCenter, AlignCenter, FontPrimary, "Exit to Sub-Ghz menu?");
|
|
widget_add_string_multiline_element(
|
|
subghz->widget,
|
|
64,
|
|
32,
|
|
AlignCenter,
|
|
AlignCenter,
|
|
FontSecondary,
|
|
"All unsaved will be\nlost.");
|
|
|
|
widget_add_button_element(
|
|
subghz->widget, GuiButtonTypeRight, "Stay", subghz_scene_need_saving_callback, subghz);
|
|
widget_add_button_element(
|
|
subghz->widget, GuiButtonTypeLeft, "Exit", subghz_scene_need_saving_callback, subghz);
|
|
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewWidget);
|
|
}
|
|
|
|
bool subghz_scene_need_saving_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
if(event.type == SceneManagerEventTypeBack) {
|
|
subghz->txrx->rx_key_state = SubGhzRxKeyStateBack;
|
|
scene_manager_previous_scene(subghz->scene_manager);
|
|
return true;
|
|
} else if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == SubghzCustomEventSceneStay) {
|
|
subghz->txrx->rx_key_state = SubGhzRxKeyStateBack;
|
|
scene_manager_previous_scene(subghz->scene_manager);
|
|
return true;
|
|
} else if(event.event == SubghzCustomEventSceneExit) {
|
|
if(subghz->txrx->rx_key_state == SubGhzRxKeyStateExit) {
|
|
subghz->txrx->rx_key_state = SubGhzRxKeyStateIDLE;
|
|
scene_manager_search_and_switch_to_previous_scene(
|
|
subghz->scene_manager, SubGhzSceneStart);
|
|
} else {
|
|
subghz->txrx->rx_key_state = SubGhzRxKeyStateIDLE;
|
|
scene_manager_previous_scene(subghz->scene_manager);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void subghz_scene_need_saving_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
widget_reset(subghz->widget);
|
|
}
|