cligui_main.c 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #include "cligui_main_i.h"
  2. #include "cli_control.h"
  3. #include "text_input.h"
  4. #include "console_output.h"
  5. static bool cligui_custom_event_cb(void* context, uint32_t event) {
  6. UNUSED(event);
  7. CliguiApp* app = context;
  8. UNUSED(app);
  9. return true;
  10. }
  11. static bool cligui_back_event_cb(void* context) {
  12. CliguiApp* app = context;
  13. UNUSED(app);
  14. return true;
  15. }
  16. static void cligui_tick_event_cb(void* context) {
  17. CliguiApp* app = context;
  18. size_t available = furi_stream_buffer_bytes_available(app->data->streams.app_rx);
  19. for(size_t i = 0; i < available; i++) {
  20. char c = 0;
  21. size_t len = furi_stream_buffer_receive(app->data->streams.app_rx, &c, 1, 100);
  22. if(len > 0) {
  23. furi_string_push_back(app->text_box_store, c);
  24. }
  25. }
  26. if(available > 0) {
  27. text_box_set_text(app->text_box, furi_string_get_cstr(app->text_box_store));
  28. }
  29. // Set input header stuff
  30. size_t len = furi_string_size(app->text_box_store);
  31. size_t idx = len - 2;
  32. while(idx > 0) {
  33. if(furi_string_get_char(app->text_box_store, idx) == '\n') {
  34. idx++;
  35. break;
  36. }
  37. idx--;
  38. }
  39. text_input_set_header_text(app->text_input, furi_string_get_cstr(app->text_box_store) + idx);
  40. UNUSED(app);
  41. }
  42. volatile bool persistent_exit = false;
  43. static void input_callback(const void* event_ptr, void* context) {
  44. InputEvent* event = (InputEvent*)event_ptr;
  45. CliguiApp* app = context;
  46. if(event->type == InputTypeLong && event->key == InputKeyBack) {
  47. persistent_exit = false;
  48. view_dispatcher_stop(app->view_dispatcher);
  49. }
  50. if(event->type == InputTypeLong && event->key == InputKeyOk) {
  51. if(app->data->state == ViewConsoleOutput) {
  52. persistent_exit = true;
  53. view_dispatcher_stop(app->view_dispatcher);
  54. }
  55. }
  56. if(app->data->state == ViewTextInput) {
  57. text_input_input_handler(app, event);
  58. } else {
  59. console_output_input_handler(app, event);
  60. }
  61. }
  62. int32_t cligui_main(void* p) {
  63. UNUSED(p);
  64. CliguiApp* cligui = malloc(sizeof(CliguiApp));
  65. cligui->data = malloc(sizeof(CliguiData));
  66. clicontrol_hijack(512, 512);
  67. cligui->data->streams.app_tx = cli_rx_stream;
  68. cligui->data->streams.app_rx = cli_tx_stream;
  69. cligui->gui = furi_record_open(RECORD_GUI);
  70. cligui->view_dispatcher = view_dispatcher_alloc();
  71. FuriPubSub* input_events = furi_record_open(RECORD_INPUT_EVENTS);
  72. FuriPubSubSubscription* input_events_sub =
  73. furi_pubsub_subscribe(input_events, input_callback, (void*)cligui);
  74. view_dispatcher_enable_queue(cligui->view_dispatcher);
  75. view_dispatcher_set_event_callback_context(cligui->view_dispatcher, cligui);
  76. view_dispatcher_set_custom_event_callback(cligui->view_dispatcher, cligui_custom_event_cb);
  77. view_dispatcher_set_navigation_event_callback(cligui->view_dispatcher, cligui_back_event_cb);
  78. view_dispatcher_set_tick_event_callback(cligui->view_dispatcher, cligui_tick_event_cb, 100);
  79. view_dispatcher_attach_to_gui(
  80. cligui->view_dispatcher, cligui->gui, ViewDispatcherTypeFullscreen);
  81. view_dispatcher_send_to_front(cligui->view_dispatcher);
  82. cligui->text_box = text_box_alloc();
  83. view_dispatcher_add_view(
  84. cligui->view_dispatcher, ViewConsoleOutput, text_box_get_view(cligui->text_box));
  85. cligui->text_box_store = furi_string_alloc();
  86. furi_string_reserve(cligui->text_box_store, TEXT_BOX_STORE_SIZE);
  87. furi_string_set_char(cligui->text_box_store, 0, 0);
  88. text_box_set_text(cligui->text_box, furi_string_get_cstr(cligui->text_box_store));
  89. text_box_set_focus(cligui->text_box, TextBoxFocusEnd);
  90. cligui->text_input = text_input_alloc();
  91. text_input_set_result_callback(
  92. cligui->text_input,
  93. text_input_result_callback,
  94. cligui,
  95. cligui->text_input_store,
  96. TEXT_INPUT_STORE_SIZE,
  97. true);
  98. text_input_show_illegal_symbols(cligui->text_input, true);
  99. view_dispatcher_add_view(
  100. cligui->view_dispatcher, ViewTextInput, text_input_get_view(cligui->text_input));
  101. view_dispatcher_switch_to_view(cligui->view_dispatcher, ViewTextInput);
  102. cligui->data->state = ViewTextInput;
  103. view_dispatcher_run(cligui->view_dispatcher);
  104. view_dispatcher_remove_view(cligui->view_dispatcher, ViewConsoleOutput);
  105. view_dispatcher_remove_view(cligui->view_dispatcher, ViewTextInput);
  106. text_box_free(cligui->text_box);
  107. furi_string_free(cligui->text_box_store);
  108. text_input_free(cligui->text_input);
  109. view_dispatcher_free(cligui->view_dispatcher);
  110. clicontrol_unhijack(persistent_exit);
  111. furi_pubsub_unsubscribe(input_events, input_events_sub);
  112. furi_record_close(RECORD_GUI);
  113. furi_record_close(RECORD_INPUT_EVENTS);
  114. free(cligui->data);
  115. free(cligui);
  116. return 0;
  117. }