-
Notifications
You must be signed in to change notification settings - Fork 21
/
uart_text_input.h
82 lines (69 loc) · 2.45 KB
/
uart_text_input.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
#pragma once
#include <gui/view.h>
#include "uart_validators.h"
#ifdef __cplusplus
extern "C" {
#endif
/** Text input anonymous structure */
typedef struct UART_TextInput UART_TextInput;
typedef void (*UART_TextInputCallback)(void* context);
typedef bool (*UART_TextInputValidatorCallback)(const char* text, FuriString* error, void* context);
/** Allocate and initialize text input
*
* This text input is used to enter string
*
* @return UART_TextInput instance
*/
UART_TextInput* uart_text_input_alloc();
/** Deinitialize and free text input
*
* @param uart_text_input UART_TextInput instance
*/
void uart_text_input_free(UART_TextInput* uart_text_input);
/** Clean text input view Note: this function does not free memory
*
* @param uart_text_input Text input instance
*/
void uart_text_input_reset(UART_TextInput* uart_text_input);
/** Get text input view
*
* @param uart_text_input UART_TextInput instance
*
* @return View instance that can be used for embedding
*/
View* uart_text_input_get_view(UART_TextInput* uart_text_input);
/** Set text input result callback
*
* @param uart_text_input UART_TextInput instance
* @param callback callback fn
* @param callback_context callback context
* @param text_buffer pointer to YOUR text buffer, that we going
* to modify
* @param text_buffer_size YOUR text buffer size in bytes. Max string
* length will be text_buffer_size-1.
* @param clear_default_text clear text from text_buffer on first OK
* event
*/
void uart_text_input_set_result_callback(
UART_TextInput* uart_text_input,
UART_TextInputCallback callback,
void* callback_context,
char* text_buffer,
size_t text_buffer_size,
bool clear_default_text);
void uart_text_input_set_validator(
UART_TextInput* uart_text_input,
UART_TextInputValidatorCallback callback,
void* callback_context);
UART_TextInputValidatorCallback
uart_text_input_get_validator_callback(UART_TextInput* uart_text_input);
void* uart_text_input_get_validator_callback_context(UART_TextInput* uart_text_input);
/** Set text input header text
*
* @param uart_text_input UART_TextInput instance
* @param text text to be shown
*/
void uart_text_input_set_header_text(UART_TextInput* uart_text_input, const char* text);
#ifdef __cplusplus
}
#endif