Merge branch 'flipperdevices:dev' into dev

This commit is contained in:
Eng1n33r 2022-06-21 17:46:11 +03:00 committed by GitHub
commit d97a27e1af
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
11 changed files with 66 additions and 12 deletions

View File

@ -8,7 +8,9 @@ static const NotificationSequence* infrared_notification_sequences[] = {
&sequence_set_only_green_255, &sequence_set_only_green_255,
&sequence_reset_green, &sequence_reset_green,
&sequence_blink_cyan_10, &sequence_blink_cyan_10,
&sequence_blink_magenta_10}; &sequence_blink_magenta_10,
&sequence_solid_yellow,
&sequence_reset_rgb};
static void infrared_make_app_folder(Infrared* infrared) { static void infrared_make_app_folder(Infrared* infrared) {
if(!storage_simply_mkdir(infrared->storage, INFRARED_APP_FOLDER)) { if(!storage_simply_mkdir(infrared->storage, INFRARED_APP_FOLDER)) {
@ -360,11 +362,11 @@ void infrared_text_input_callback(void* context) {
infrared->view_dispatcher, InfraredCustomEventTypeTextEditDone); infrared->view_dispatcher, InfraredCustomEventTypeTextEditDone);
} }
void infrared_popup_timeout_callback(void* context) { void infrared_popup_closed_callback(void* context) {
furi_assert(context); furi_assert(context);
Infrared* infrared = context; Infrared* infrared = context;
view_dispatcher_send_custom_event( view_dispatcher_send_custom_event(
infrared->view_dispatcher, InfraredCustomEventTypePopupTimeout); infrared->view_dispatcher, InfraredCustomEventTypePopupClosed);
} }
int32_t infrared_app(void* p) { int32_t infrared_app(void* p) {

View File

@ -11,7 +11,7 @@ enum InfraredCustomEventType {
InfraredCustomEventTypeTransmitStopped, InfraredCustomEventTypeTransmitStopped,
InfraredCustomEventTypeSignalReceived, InfraredCustomEventTypeSignalReceived,
InfraredCustomEventTypeTextEditDone, InfraredCustomEventTypeTextEditDone,
InfraredCustomEventTypePopupTimeout, InfraredCustomEventTypePopupClosed,
InfraredCustomEventTypeButtonSelected, InfraredCustomEventTypeButtonSelected,
InfraredCustomEventTypeBackPressed, InfraredCustomEventTypeBackPressed,
}; };

View File

@ -113,6 +113,8 @@ typedef enum {
InfraredNotificationMessageGreenOff, InfraredNotificationMessageGreenOff,
InfraredNotificationMessageBlinkRead, InfraredNotificationMessageBlinkRead,
InfraredNotificationMessageBlinkSend, InfraredNotificationMessageBlinkSend,
InfraredNotificationMessageYellowOn,
InfraredNotificationMessageYellowOff,
} InfraredNotificationMessage; } InfraredNotificationMessage;
bool infrared_add_remote_with_button(Infrared* infrared, const char* name, InfraredSignal* signal); bool infrared_add_remote_with_button(Infrared* infrared, const char* name, InfraredSignal* signal);
@ -129,4 +131,4 @@ void infrared_show_loading_popup(Infrared* infrared, bool show);
void infrared_signal_sent_callback(void* context); void infrared_signal_sent_callback(void* context);
void infrared_signal_received_callback(void* context, InfraredWorkerSignal* received_signal); void infrared_signal_received_callback(void* context, InfraredWorkerSignal* received_signal);
void infrared_text_input_callback(void* context); void infrared_text_input_callback(void* context);
void infrared_popup_timeout_callback(void* context); void infrared_popup_closed_callback(void* context);

View File

@ -15,3 +15,4 @@ ADD_SCENE(infrared, remote_list, RemoteList)
ADD_SCENE(infrared, universal, Universal) ADD_SCENE(infrared, universal, Universal)
ADD_SCENE(infrared, universal_tv, UniversalTV) ADD_SCENE(infrared, universal_tv, UniversalTV)
ADD_SCENE(infrared, debug, Debug) ADD_SCENE(infrared, debug, Debug)
ADD_SCENE(infrared, error_databases, ErrorDatabases)

View File

@ -7,7 +7,7 @@ void infrared_scene_edit_delete_done_on_enter(void* context) {
popup_set_icon(popup, 0, 2, &I_DolphinMafia_115x62); popup_set_icon(popup, 0, 2, &I_DolphinMafia_115x62);
popup_set_header(popup, "Deleted", 83, 19, AlignLeft, AlignBottom); popup_set_header(popup, "Deleted", 83, 19, AlignLeft, AlignBottom);
popup_set_callback(popup, infrared_popup_timeout_callback); popup_set_callback(popup, infrared_popup_closed_callback);
popup_set_context(popup, context); popup_set_context(popup, context);
popup_set_timeout(popup, 1500); popup_set_timeout(popup, 1500);
popup_enable_timeout(popup); popup_enable_timeout(popup);
@ -21,7 +21,7 @@ bool infrared_scene_edit_delete_done_on_event(void* context, SceneManagerEvent e
bool consumed = false; bool consumed = false;
if(event.type == SceneManagerEventTypeCustom) { if(event.type == SceneManagerEventTypeCustom) {
if(event.event == InfraredCustomEventTypePopupTimeout) { if(event.event == InfraredCustomEventTypePopupClosed) {
const InfraredEditTarget edit_target = infrared->app_state.edit_target; const InfraredEditTarget edit_target = infrared->app_state.edit_target;
if(edit_target == InfraredEditTargetButton) { if(edit_target == InfraredEditTargetButton) {
scene_manager_search_and_switch_to_previous_scene( scene_manager_search_and_switch_to_previous_scene(

View File

@ -7,7 +7,7 @@ void infrared_scene_edit_rename_done_on_enter(void* context) {
popup_set_icon(popup, 32, 5, &I_DolphinNice_96x59); popup_set_icon(popup, 32, 5, &I_DolphinNice_96x59);
popup_set_header(popup, "Saved!", 5, 7, AlignLeft, AlignTop); popup_set_header(popup, "Saved!", 5, 7, AlignLeft, AlignTop);
popup_set_callback(popup, infrared_popup_timeout_callback); popup_set_callback(popup, infrared_popup_closed_callback);
popup_set_context(popup, context); popup_set_context(popup, context);
popup_set_timeout(popup, 1500); popup_set_timeout(popup, 1500);
popup_enable_timeout(popup); popup_enable_timeout(popup);
@ -20,7 +20,7 @@ bool infrared_scene_edit_rename_done_on_event(void* context, SceneManagerEvent e
bool consumed = false; bool consumed = false;
if(event.type == SceneManagerEventTypeCustom) { if(event.type == SceneManagerEventTypeCustom) {
if(event.event == InfraredCustomEventTypePopupTimeout) { if(event.event == InfraredCustomEventTypePopupClosed) {
scene_manager_next_scene(infrared->scene_manager, InfraredSceneRemote); scene_manager_next_scene(infrared->scene_manager, InfraredSceneRemote);
consumed = true; consumed = true;
} }

View File

@ -0,0 +1,37 @@
#include "../infrared_i.h"
void infrared_scene_error_databases_on_enter(void* context) {
Infrared* infrared = context;
Popup* popup = infrared->popup;
popup_set_icon(popup, 5, 11, &I_SDQuestion_35x43);
popup_set_text(
popup, "Function requires\nSD card with fresh\ndatabases.", 47, 17, AlignLeft, AlignTop);
popup_set_context(popup, context);
popup_set_callback(popup, infrared_popup_closed_callback);
infrared_play_notification_message(infrared, InfraredNotificationMessageYellowOn);
view_dispatcher_switch_to_view(infrared->view_dispatcher, InfraredViewPopup);
}
bool infrared_scene_error_databases_on_event(void* context, SceneManagerEvent event) {
Infrared* infrared = context;
bool consumed = false;
if(event.type == SceneManagerEventTypeCustom) {
if(event.event == InfraredCustomEventTypePopupClosed) {
scene_manager_search_and_switch_to_previous_scene(
infrared->scene_manager, InfraredSceneUniversal);
consumed = true;
}
}
return consumed;
}
void infrared_scene_error_databases_on_exit(void* context) {
Infrared* infrared = context;
popup_reset(infrared->popup);
infrared_play_notification_message(infrared, InfraredNotificationMessageYellowOff);
}

View File

@ -15,7 +15,7 @@ void infrared_scene_learn_done_on_enter(void* context) {
popup_set_header(popup, "Saved!", 5, 7, AlignLeft, AlignTop); popup_set_header(popup, "Saved!", 5, 7, AlignLeft, AlignTop);
} }
popup_set_callback(popup, infrared_popup_timeout_callback); popup_set_callback(popup, infrared_popup_closed_callback);
popup_set_context(popup, context); popup_set_context(popup, context);
popup_set_timeout(popup, 1500); popup_set_timeout(popup, 1500);
popup_enable_timeout(popup); popup_enable_timeout(popup);
@ -28,7 +28,7 @@ bool infrared_scene_learn_done_on_event(void* context, SceneManagerEvent event)
bool consumed = false; bool consumed = false;
if(event.type == SceneManagerEventTypeCustom) { if(event.type == SceneManagerEventTypeCustom) {
if(event.event == InfraredCustomEventTypePopupTimeout) { if(event.event == InfraredCustomEventTypePopupClosed) {
scene_manager_next_scene(infrared->scene_manager, InfraredSceneRemote); scene_manager_next_scene(infrared->scene_manager, InfraredSceneRemote);
consumed = true; consumed = true;
} }

View File

@ -98,7 +98,7 @@ void infrared_scene_universal_tv_on_enter(void* context) {
infrared_show_loading_popup(infrared, false); infrared_show_loading_popup(infrared, false);
if(!success) { if(!success) {
scene_manager_previous_scene(infrared->scene_manager); scene_manager_next_scene(infrared->scene_manager, InfraredSceneErrorDatabases);
} }
} }

View File

@ -335,6 +335,15 @@ const NotificationSequence sequence_set_blue_255 = {
NULL, NULL,
}; };
// Solid colors
const NotificationSequence sequence_solid_yellow = {
&message_red_255,
&message_green_255,
&message_blue_0,
&message_do_not_reset,
NULL,
};
// Blink // Blink
const NotificationSequence sequence_blink_blue_10 = { const NotificationSequence sequence_blink_blue_10 = {
&message_blue_255, &message_blue_255,

View File

@ -103,6 +103,9 @@ extern const NotificationSequence sequence_set_red_255;
extern const NotificationSequence sequence_set_green_255; extern const NotificationSequence sequence_set_green_255;
extern const NotificationSequence sequence_set_blue_255; extern const NotificationSequence sequence_set_blue_255;
// Solid colors
extern const NotificationSequence sequence_solid_yellow;
// Blink // Blink
extern const NotificationSequence sequence_blink_blue_10; extern const NotificationSequence sequence_blink_blue_10;
extern const NotificationSequence sequence_blink_red_10; extern const NotificationSequence sequence_blink_red_10;