* 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>
		
			
				
	
	
		
			79 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/**
 | 
						|
 * @file submenu.h
 | 
						|
 * GUI: SubMenu view module API
 | 
						|
 */
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include <gui/view.h>
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
extern "C" {
 | 
						|
#endif
 | 
						|
 | 
						|
/** Submenu anonymous structure */
 | 
						|
typedef struct Submenu Submenu;
 | 
						|
typedef void (*SubmenuItemCallback)(void* context, uint32_t index);
 | 
						|
 | 
						|
/** Allocate and initialize submenu 
 | 
						|
 * 
 | 
						|
 * This submenu is used to select one option
 | 
						|
 *
 | 
						|
 * @return     Submenu instance
 | 
						|
 */
 | 
						|
Submenu* submenu_alloc();
 | 
						|
 | 
						|
/** Deinitialize and free submenu
 | 
						|
 *
 | 
						|
 * @param      submenu  Submenu instance
 | 
						|
 */
 | 
						|
void submenu_free(Submenu* submenu);
 | 
						|
 | 
						|
/** Get submenu view
 | 
						|
 *
 | 
						|
 * @param      submenu  Submenu instance
 | 
						|
 *
 | 
						|
 * @return     View instance that can be used for embedding
 | 
						|
 */
 | 
						|
View* submenu_get_view(Submenu* submenu);
 | 
						|
 | 
						|
/** Add item to submenu
 | 
						|
 *
 | 
						|
 * @param      submenu           Submenu instance
 | 
						|
 * @param      label             menu item label
 | 
						|
 * @param      index             menu item index, used for callback, may be
 | 
						|
 *                               the same with other items
 | 
						|
 * @param      callback          menu item callback
 | 
						|
 * @param      callback_context  menu item callback context
 | 
						|
 */
 | 
						|
void submenu_add_item(
 | 
						|
    Submenu* submenu,
 | 
						|
    const char* label,
 | 
						|
    uint32_t index,
 | 
						|
    SubmenuItemCallback callback,
 | 
						|
    void* callback_context);
 | 
						|
 | 
						|
/** Remove all items from submenu
 | 
						|
 *
 | 
						|
 * @param      submenu  Submenu instance
 | 
						|
 */
 | 
						|
void submenu_reset(Submenu* submenu);
 | 
						|
 | 
						|
/** Set submenu item selector
 | 
						|
 *
 | 
						|
 * @param      submenu  Submenu instance
 | 
						|
 * @param      index    The index
 | 
						|
 */
 | 
						|
void submenu_set_selected_item(Submenu* submenu, uint32_t index);
 | 
						|
 | 
						|
/** Set optional header for submenu
 | 
						|
 *
 | 
						|
 * @param      submenu  Submenu instance
 | 
						|
 * @param      header   header to set
 | 
						|
 */
 | 
						|
void submenu_set_header(Submenu* submenu, const char* header);
 | 
						|
 | 
						|
#ifdef __cplusplus
 | 
						|
}
 | 
						|
#endif
 |