| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 |
- /**
- * @file text_input.h
- * GUI: TextInput keyboard view module API
- */
- #pragma once
- #ifndef FW_ORIGIN_Momentum
- #include <gui/view.h>
- #include <gui/modules/validators.h>
- #ifdef __cplusplus
- extern "C" {
- #endif
- /** Text input anonymous structure */
- typedef struct TextInput TextInput;
- typedef void (*TextInputCallback)(void* context);
- typedef bool (*TextInputValidatorCallback)(const char* text, FuriString* error, void* context);
- /** Allocate and initialize text input
- *
- * This text input is used to enter string
- *
- * @return TextInput instance
- */
- TextInput* text_input_alloc(void);
- /** Deinitialize and free text input
- *
- * @param text_input TextInput instance
- */
- void text_input_free(TextInput* text_input);
- /** Clean text input view Note: this function does not free memory
- *
- * @param text_input Text input instance
- */
- void text_input_reset(TextInput* text_input);
- /** Get text input view
- *
- * @param text_input TextInput instance
- *
- * @return View instance that can be used for embedding
- */
- View* text_input_get_view(TextInput* text_input);
- /** Set text input result callback
- *
- * @param text_input 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 text_input_set_result_callback(
- TextInput* text_input,
- TextInputCallback callback,
- void* callback_context,
- char* text_buffer,
- size_t text_buffer_size,
- bool clear_default_text);
- /**
- * @brief Sets the minimum length of a TextInput
- * @param [in] text_input TextInput
- * @param [in] minimum_length Minimum input length
- */
- void text_input_set_minimum_length(TextInput* text_input, size_t minimum_length);
- void text_input_set_validator(
- TextInput* text_input,
- TextInputValidatorCallback callback,
- void* callback_context);
- /**
- * @brief Show the 9 illegal (windows) symbols <>:"/\|?* in the symbols keyboard instead of the numbers
- * @param [in] text_input TextInput
- * @param [in] show Whether to show the illegal symbols or not
- */
- void text_input_show_illegal_symbols(TextInput* text_input, bool show);
- TextInputValidatorCallback text_input_get_validator_callback(TextInput* text_input);
- void* text_input_get_validator_callback_context(TextInput* text_input);
- /** Set text input header text
- *
- * @param text_input TextInput instance
- * @param text text to be shown
- */
- void text_input_set_header_text(TextInput* text_input, const char* text);
- #ifdef __cplusplus
- }
- #endif
- #endif
|