uart_terminal_scene_start.c 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. #include "../uart_terminal_app_i.h"
  2. // Command action type
  3. typedef enum { NO_ACTION = 0, OPEN_SETUP, OPEN_PORT, SEND_CMD, SEND_AT_CMD, SEND_FAST_CMD, OPEN_HELP } ActionType;
  4. // Command availability in different modes
  5. typedef enum { OFF = 0, TEXT_MODE = 1, HEX_MODE = 2, BOTH_MODES = 3 } ModeMask;
  6. #define MAX_OPTIONS (8)
  7. typedef struct {
  8. const char* item_string;
  9. const char* options_menu[MAX_OPTIONS];
  10. int num_options_menu;
  11. ActionType action;
  12. ModeMask mode_mask;
  13. } UART_TerminalItem;
  14. static const char at_str[] = "AT";
  15. // NUM_MENU_ITEMS defined in uart_terminal_app_i.h - if you add an entry here, increment it!
  16. static const UART_TerminalItem items[START_MENU_ITEMS] = {
  17. {"Setup", {""}, 1, OPEN_SETUP, BOTH_MODES},
  18. {"Open port", {""}, 1, OPEN_PORT, BOTH_MODES},
  19. {"Send packet", {""}, 1, SEND_CMD, HEX_MODE},
  20. {"Send command", {""}, 1, SEND_CMD, TEXT_MODE},
  21. {"Send AT command", {""}, 1, SEND_AT_CMD, TEXT_MODE},
  22. {"Fast cmd",
  23. {"help", "uptime", "date", "df -h", "ps", "dmesg", "reboot", "poweroff"},
  24. 8, SEND_FAST_CMD, TEXT_MODE},
  25. {"Help", {""}, 1, OPEN_HELP, BOTH_MODES},
  26. };
  27. static uint8_t menu_items_num = 0;
  28. static uint8_t item_indexes[START_MENU_ITEMS] = { 0 };
  29. static void uart_terminal_scene_start_var_list_enter_callback(void* context, uint32_t index) {
  30. furi_assert(context);
  31. UART_TerminalApp* app = context;
  32. furi_assert(index < menu_items_num);
  33. uint8_t item_index = item_indexes[index];
  34. furi_assert(item_index < START_MENU_ITEMS);
  35. const UART_TerminalItem* item = &items[item_index];
  36. const int selected_option_index = app->selected_option_index[index];
  37. furi_assert(selected_option_index < item->num_options_menu);
  38. app->selected_tx_string = item->options_menu[selected_option_index];
  39. app->is_command = false;
  40. app->is_custom_tx_string = false;
  41. app->selected_menu_index = index;
  42. switch (item->action)
  43. {
  44. case OPEN_SETUP:
  45. view_dispatcher_send_custom_event(app->view_dispatcher, UART_TerminalEventSetup);
  46. return;
  47. case SEND_AT_CMD:
  48. case SEND_CMD:
  49. case SEND_FAST_CMD:
  50. app->is_command = true;
  51. if(item->action == SEND_AT_CMD) {
  52. app->selected_tx_string = at_str;
  53. }
  54. if(app->hex_mode) {
  55. view_dispatcher_send_custom_event(app->view_dispatcher, UART_TerminalEventStartKeyboardHex);
  56. }
  57. else {
  58. view_dispatcher_send_custom_event(app->view_dispatcher, UART_TerminalEventStartKeyboardText);
  59. }
  60. return;
  61. case OPEN_PORT:
  62. view_dispatcher_send_custom_event(app->view_dispatcher, UART_TerminalEventStartConsole);
  63. return;
  64. case OPEN_HELP:
  65. view_dispatcher_send_custom_event(app->view_dispatcher, UART_TerminalEventStartHelp);
  66. return;
  67. default:
  68. return;
  69. }
  70. }
  71. static void uart_terminal_scene_start_var_list_change_callback(VariableItem* item) {
  72. furi_assert(item);
  73. UART_TerminalApp* app = variable_item_get_context(item);
  74. furi_assert(app);
  75. uint8_t item_index = item_indexes[app->selected_menu_index];
  76. const UART_TerminalItem* menu_item = &items[item_index];
  77. uint8_t option_index = variable_item_get_current_value_index(item);
  78. furi_assert(option_index < menu_item->num_options_menu);
  79. variable_item_set_current_value_text(item, menu_item->options_menu[option_index]);
  80. app->selected_option_index[app->selected_menu_index] = option_index;
  81. }
  82. void uart_terminal_scene_start_on_enter(void* context) {
  83. UART_TerminalApp* app = context;
  84. VariableItemList* var_item_list = app->var_item_list;
  85. for(int i = 0; i < START_MENU_ITEMS; ++i) {
  86. app->selected_option_index[i] = 0;
  87. }
  88. variable_item_list_set_enter_callback(
  89. var_item_list, uart_terminal_scene_start_var_list_enter_callback, app);
  90. VariableItem* item;
  91. menu_items_num = 0;
  92. for(int i = 0; i < START_MENU_ITEMS; ++i) {
  93. bool enabled = false;
  94. if(app->hex_mode && (items[i].mode_mask & HEX_MODE)) {
  95. enabled = true;
  96. }
  97. if(!app->hex_mode && (items[i].mode_mask & TEXT_MODE)) {
  98. enabled = true;
  99. }
  100. if(enabled) {
  101. item = variable_item_list_add(
  102. var_item_list,
  103. items[i].item_string,
  104. items[i].num_options_menu,
  105. uart_terminal_scene_start_var_list_change_callback,
  106. app);
  107. variable_item_set_current_value_index(item, app->selected_option_index[i]);
  108. variable_item_set_current_value_text(
  109. item, items[i].options_menu[app->selected_option_index[i]]);
  110. item_indexes[menu_items_num] = i;
  111. menu_items_num++;
  112. }
  113. }
  114. variable_item_list_set_selected_item(
  115. var_item_list, scene_manager_get_scene_state(app->scene_manager, UART_TerminalSceneStart));
  116. view_dispatcher_switch_to_view(app->view_dispatcher, UART_TerminalAppViewVarItemList);
  117. }
  118. bool uart_terminal_scene_start_on_event(void* context, SceneManagerEvent event) {
  119. UNUSED(context);
  120. UART_TerminalApp* app = context;
  121. bool consumed = false;
  122. if(event.type == SceneManagerEventTypeCustom) {
  123. if(event.event == UART_TerminalEventSetup) {
  124. scene_manager_set_scene_state(
  125. app->scene_manager, UART_TerminalSceneStart, app->selected_menu_index);
  126. scene_manager_next_scene(app->scene_manager, UART_TerminalSceneSetup);
  127. } else if(event.event == UART_TerminalEventStartKeyboardText) {
  128. scene_manager_set_scene_state(
  129. app->scene_manager, UART_TerminalSceneStart, app->selected_menu_index);
  130. scene_manager_next_scene(app->scene_manager, UART_TerminalSceneTextInput);
  131. } else if(event.event == UART_TerminalEventStartKeyboardHex) {
  132. scene_manager_set_scene_state(
  133. app->scene_manager, UART_TerminalSceneStart, app->selected_menu_index);
  134. scene_manager_next_scene(app->scene_manager, UART_TerminalSceneHexInput);
  135. } else if(event.event == UART_TerminalEventStartConsole) {
  136. scene_manager_set_scene_state(
  137. app->scene_manager, UART_TerminalSceneStart, app->selected_menu_index);
  138. scene_manager_next_scene(app->scene_manager, UART_TerminalSceneConsoleOutput);
  139. } else if(event.event == UART_TerminalEventStartHelp) {
  140. scene_manager_set_scene_state(
  141. app->scene_manager, UART_TerminalSceneStart, app->selected_menu_index);
  142. scene_manager_next_scene(app->scene_manager, UART_TerminalSceneHelp);
  143. }
  144. consumed = true;
  145. } else if(event.type == SceneManagerEventTypeTick) {
  146. app->selected_menu_index = variable_item_list_get_selected_item_index(app->var_item_list);
  147. consumed = true;
  148. }
  149. return consumed;
  150. }
  151. void uart_terminal_scene_start_on_exit(void* context) {
  152. UART_TerminalApp* app = context;
  153. variable_item_list_reset(app->var_item_list);
  154. }