|
|
@@ -1,16 +1,26 @@
|
|
|
#include "../desktop_i.h"
|
|
|
-#include "../views/desktop_hw_mismatch.h"
|
|
|
+#include <furi-hal-version.h>
|
|
|
|
|
|
-void desktop_scene_hw_mismatch_callback(DesktopHwMismatchEvent event, void* context) {
|
|
|
+#define HW_MISMATCH_BACK_EVENT (0UL)
|
|
|
+
|
|
|
+void desktop_scene_hw_mismatch_callback(void* context) {
|
|
|
Desktop* desktop = (Desktop*)context;
|
|
|
- view_dispatcher_send_custom_event(desktop->view_dispatcher, event);
|
|
|
+ view_dispatcher_send_custom_event(desktop->view_dispatcher, HW_MISMATCH_BACK_EVENT);
|
|
|
}
|
|
|
|
|
|
void desktop_scene_hw_mismatch_on_enter(void* context) {
|
|
|
Desktop* desktop = (Desktop*)context;
|
|
|
-
|
|
|
- desktop_hw_mismatch_set_callback(
|
|
|
- desktop->hw_mismatch_view, desktop_scene_hw_mismatch_callback, desktop);
|
|
|
+ Popup* popup = desktop->hw_mismatch_popup;
|
|
|
+ char buffer[256]; // strange but smaller buffer not making it
|
|
|
+ snprintf(
|
|
|
+ buffer,
|
|
|
+ sizeof(buffer),
|
|
|
+ "HW target: F%d\nFW target: " TARGET,
|
|
|
+ furi_hal_version_get_hw_target());
|
|
|
+ popup_set_context(popup, desktop);
|
|
|
+ popup_set_header(popup, "!!!! HW Mismatch !!!!", 60, 14, AlignCenter, AlignCenter);
|
|
|
+ popup_set_text(popup, buffer, 60, 37, AlignCenter, AlignCenter);
|
|
|
+ popup_set_callback(popup, desktop_scene_hw_mismatch_callback);
|
|
|
view_dispatcher_switch_to_view(desktop->view_dispatcher, DesktopViewHwMismatch);
|
|
|
}
|
|
|
|
|
|
@@ -20,7 +30,7 @@ bool desktop_scene_hw_mismatch_on_event(void* context, SceneManagerEvent event)
|
|
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
|
switch(event.event) {
|
|
|
- case DesktopHwMismatchEventExit:
|
|
|
+ case HW_MISMATCH_BACK_EVENT:
|
|
|
scene_manager_previous_scene(desktop->scene_manager);
|
|
|
consumed = true;
|
|
|
break;
|
|
|
@@ -33,5 +43,10 @@ bool desktop_scene_hw_mismatch_on_event(void* context, SceneManagerEvent event)
|
|
|
}
|
|
|
|
|
|
void desktop_scene_hw_mismatch_on_exit(void* context) {
|
|
|
- // Desktop* desktop = (Desktop*)context;
|
|
|
+ Desktop* desktop = (Desktop*)context;
|
|
|
+ Popup* popup = desktop->hw_mismatch_popup;
|
|
|
+ popup_set_header(popup, NULL, 0, 0, AlignCenter, AlignBottom);
|
|
|
+ popup_set_text(popup, NULL, 0, 0, AlignCenter, AlignTop);
|
|
|
+ popup_set_callback(popup, NULL);
|
|
|
+ popup_set_context(popup, NULL);
|
|
|
}
|