 182c8defb1
			
		
	
	
		182c8defb1
		
			
		
	
	
	
	
		
			
			* Add confirmation before exiting USB-UART * Redo the confirm view to be a scene to ignore the back button Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: あく <alleteam@gmail.com>
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "../gpio_app_i.h"
 | |
| #include "../usb_uart_bridge.h"
 | |
| 
 | |
| typedef struct {
 | |
|     UsbUartConfig cfg;
 | |
|     UsbUartState state;
 | |
| } SceneUsbUartBridge;
 | |
| 
 | |
| static SceneUsbUartBridge* scene_usb_uart;
 | |
| 
 | |
| void gpio_scene_usb_uart_callback(GpioCustomEvent event, void* context) {
 | |
|     furi_assert(context);
 | |
|     GpioApp* app = context;
 | |
|     view_dispatcher_send_custom_event(app->view_dispatcher, event);
 | |
| }
 | |
| 
 | |
| void gpio_scene_usb_uart_on_enter(void* context) {
 | |
|     GpioApp* app = context;
 | |
|     uint32_t prev_state = scene_manager_get_scene_state(app->scene_manager, GpioAppViewUsbUart);
 | |
|     if(prev_state == 0) {
 | |
|         scene_usb_uart = malloc(sizeof(SceneUsbUartBridge));
 | |
|         scene_usb_uart->cfg.vcp_ch = 0;
 | |
|         scene_usb_uart->cfg.uart_ch = 0;
 | |
|         scene_usb_uart->cfg.flow_pins = 0;
 | |
|         scene_usb_uart->cfg.baudrate_mode = 0;
 | |
|         scene_usb_uart->cfg.baudrate = 0;
 | |
|         app->usb_uart_bridge = usb_uart_enable(&scene_usb_uart->cfg);
 | |
|     }
 | |
| 
 | |
|     usb_uart_get_config(app->usb_uart_bridge, &scene_usb_uart->cfg);
 | |
|     usb_uart_get_state(app->usb_uart_bridge, &scene_usb_uart->state);
 | |
| 
 | |
|     gpio_usb_uart_set_callback(app->gpio_usb_uart, gpio_scene_usb_uart_callback, app);
 | |
|     scene_manager_set_scene_state(app->scene_manager, GpioSceneUsbUart, 0);
 | |
|     view_dispatcher_switch_to_view(app->view_dispatcher, GpioAppViewUsbUart);
 | |
|     notification_message(app->notifications, &sequence_display_backlight_enforce_on);
 | |
| }
 | |
| 
 | |
| bool gpio_scene_usb_uart_on_event(void* context, SceneManagerEvent event) {
 | |
|     GpioApp* app = context;
 | |
|     if(event.type == SceneManagerEventTypeCustom) {
 | |
|         scene_manager_set_scene_state(app->scene_manager, GpioSceneUsbUart, 1);
 | |
|         scene_manager_next_scene(app->scene_manager, GpioSceneUsbUartCfg);
 | |
|         return true;
 | |
|     } else if(event.type == SceneManagerEventTypeBack) {
 | |
|         scene_manager_next_scene(app->scene_manager, GpioSceneExitConfirm);
 | |
|         return true;
 | |
|     } else if(event.type == SceneManagerEventTypeTick) {
 | |
|         uint32_t tx_cnt_last = scene_usb_uart->state.tx_cnt;
 | |
|         uint32_t rx_cnt_last = scene_usb_uart->state.rx_cnt;
 | |
|         usb_uart_get_state(app->usb_uart_bridge, &scene_usb_uart->state);
 | |
|         gpio_usb_uart_update_state(
 | |
|             app->gpio_usb_uart, &scene_usb_uart->cfg, &scene_usb_uart->state);
 | |
|         if(tx_cnt_last != scene_usb_uart->state.tx_cnt)
 | |
|             notification_message(app->notifications, &sequence_blink_blue_10);
 | |
|         if(rx_cnt_last != scene_usb_uart->state.rx_cnt)
 | |
|             notification_message(app->notifications, &sequence_blink_green_10);
 | |
|     }
 | |
|     return false;
 | |
| }
 | |
| 
 | |
| void gpio_scene_usb_uart_on_exit(void* context) {
 | |
|     GpioApp* app = context;
 | |
|     uint32_t prev_state = scene_manager_get_scene_state(app->scene_manager, GpioSceneUsbUart);
 | |
|     if(prev_state == 0) {
 | |
|         usb_uart_disable(app->usb_uart_bridge);
 | |
|         free(scene_usb_uart);
 | |
|     }
 | |
|     notification_message(app->notifications, &sequence_display_backlight_enforce_auto);
 | |
| }
 |