mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-01-04 11:25:55 +03:00
23ff6723cf
* bt: update connection parameters * bt: set correct connection latency and timeout * gui popup: add clean method * furi_hal_bt: add connection parameters request, clear database * bt: add forget bonded devices API * bt_settings: add forget bonded devices GUI * bt: rework pin code show with view port to hide view * bt: support conn parameters for different profiles * furi_hal_bt: sync f6 target * target f6: fix build * bt: format sources * furi_hal_bt: update connection parameters * bt: update connection params, fix GUI * FuriHal: fix spelling * Refactoring: rename _clean to _reset Co-authored-by: あく <alleteam@gmail.com>
102 lines
3.9 KiB
C
102 lines
3.9 KiB
C
#include "../subghz_i.h"
|
|
|
|
enum SubmenuIndex {
|
|
SubmenuIndexRead = 10,
|
|
SubmenuIndexSaved,
|
|
SubmenuIndexTest,
|
|
SubmenuIndexAddManualy,
|
|
SubmenuIndexFrequencyAnalyzer,
|
|
SubmenuIndexReadRAW,
|
|
};
|
|
|
|
void subghz_scene_start_submenu_callback(void* context, uint32_t index) {
|
|
SubGhz* subghz = context;
|
|
view_dispatcher_send_custom_event(subghz->view_dispatcher, index);
|
|
}
|
|
|
|
void subghz_scene_start_on_enter(void* context) {
|
|
SubGhz* subghz = context;
|
|
if(subghz->state_notifications == SubGhzNotificationStateStarting) {
|
|
subghz->state_notifications = SubGhzNotificationStateIDLE;
|
|
}
|
|
submenu_add_item(
|
|
subghz->submenu, "Read", SubmenuIndexRead, subghz_scene_start_submenu_callback, subghz);
|
|
submenu_add_item(
|
|
subghz->submenu,
|
|
"Read RAW",
|
|
SubmenuIndexReadRAW,
|
|
subghz_scene_start_submenu_callback,
|
|
subghz);
|
|
submenu_add_item(
|
|
subghz->submenu, "Saved", SubmenuIndexSaved, subghz_scene_start_submenu_callback, subghz);
|
|
submenu_add_item(
|
|
subghz->submenu,
|
|
"Add manually",
|
|
SubmenuIndexAddManualy,
|
|
subghz_scene_start_submenu_callback,
|
|
subghz);
|
|
submenu_add_item(
|
|
subghz->submenu,
|
|
"Frequency Analyzer",
|
|
SubmenuIndexFrequencyAnalyzer,
|
|
subghz_scene_start_submenu_callback,
|
|
subghz);
|
|
if(furi_hal_rtc_is_flag_set(FuriHalRtcFlagDebug)) {
|
|
submenu_add_item(
|
|
subghz->submenu, "Test", SubmenuIndexTest, subghz_scene_start_submenu_callback, subghz);
|
|
}
|
|
submenu_set_selected_item(
|
|
subghz->submenu, scene_manager_get_scene_state(subghz->scene_manager, SubGhzSceneStart));
|
|
|
|
view_dispatcher_switch_to_view(subghz->view_dispatcher, SubGhzViewMenu);
|
|
}
|
|
|
|
bool subghz_scene_start_on_event(void* context, SceneManagerEvent event) {
|
|
SubGhz* subghz = context;
|
|
if(event.type == SceneManagerEventTypeBack) {
|
|
//exit app
|
|
scene_manager_stop(subghz->scene_manager);
|
|
view_dispatcher_stop(subghz->view_dispatcher);
|
|
return true;
|
|
} else if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == SubmenuIndexReadRAW) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexReadRAW);
|
|
subghz->txrx->rx_key_state = SubGhzRxKeyStateIDLE;
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneReadRAW);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexRead) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexRead);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneReceiver);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexSaved) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexSaved);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSaved);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexAddManualy) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexAddManualy);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneSetType);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexFrequencyAnalyzer) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexFrequencyAnalyzer);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneFrequencyAnalyzer);
|
|
return true;
|
|
} else if(event.event == SubmenuIndexTest) {
|
|
scene_manager_set_scene_state(
|
|
subghz->scene_manager, SubGhzSceneStart, SubmenuIndexTest);
|
|
scene_manager_next_scene(subghz->scene_manager, SubGhzSceneTest);
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void subghz_scene_start_on_exit(void* context) {
|
|
SubGhz* subghz = context;
|
|
submenu_reset(subghz->submenu);
|
|
}
|