| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749 |
- #include "wifi_marauder_text_input.h"
- #include <gui/elements.h>
- #include "wifi_marauder_app_i.h"
- #include <furi.h>
- struct WIFI_TextInput {
- View* view;
- FuriTimer* timer;
- };
- typedef struct {
- const char text;
- const uint8_t x;
- const uint8_t y;
- } WIFI_TextInputKey;
- typedef struct {
- const WIFI_TextInputKey* rows[3];
- const uint8_t keyboard_index;
- } Keyboard;
- typedef struct {
- const char* header;
- char* text_buffer;
- size_t text_buffer_size;
- size_t minimum_length;
- bool clear_default_text;
- bool cursor_select;
- size_t cursor_pos;
- WIFI_TextInputCallback callback;
- void* callback_context;
- uint8_t selected_row;
- uint8_t selected_column;
- uint8_t selected_keyboard;
- WIFI_TextInputValidatorCallback validator_callback;
- void* validator_callback_context;
- FuriString* validator_text;
- bool validator_message_visible;
- } WIFI_TextInputModel;
- static const uint8_t keyboard_origin_x = 1;
- static const uint8_t keyboard_origin_y = 29;
- static const uint8_t keyboard_row_count = 3;
- static const uint8_t keyboard_count = 2;
- #define ENTER_KEY '\r'
- #define BACKSPACE_KEY '\b'
- #define SWITCH_KEYBOARD_KEY 0xfe
- static const WIFI_TextInputKey keyboard_keys_row_1[] = {
- {'q', 1, 8},
- {'w', 10, 8},
- {'e', 19, 8},
- {'r', 28, 8},
- {'t', 37, 8},
- {'y', 46, 8},
- {'u', 55, 8},
- {'i', 64, 8},
- {'o', 73, 8},
- {'p', 82, 8},
- {'0', 91, 8},
- {'1', 100, 8},
- {'2', 110, 8},
- {'3', 120, 8},
- };
- static const WIFI_TextInputKey keyboard_keys_row_2[] = {
- {'a', 1, 20},
- {'s', 10, 20},
- {'d', 19, 20},
- {'f', 28, 20},
- {'g', 37, 20},
- {'h', 46, 20},
- {'j', 55, 20},
- {'k', 64, 20},
- {'l', 73, 20},
- {BACKSPACE_KEY, 82, 12},
- {'4', 100, 20},
- {'5', 110, 20},
- {'6', 120, 20},
- };
- static const WIFI_TextInputKey keyboard_keys_row_3[] = {
- {SWITCH_KEYBOARD_KEY, 1, 23},
- {'z', 13, 32},
- {'x', 21, 32},
- {'c', 28, 32},
- {'v', 36, 32},
- {'b', 44, 32},
- {'n', 52, 32},
- {'m', 59, 32},
- {'_', 67, 32},
- {ENTER_KEY, 74, 23},
- {'7', 100, 32},
- {'8', 110, 32},
- {'9', 120, 32},
- };
- static const WIFI_TextInputKey symbol_keyboard_keys_row_1[] = {
- {'!', 2, 8},
- {'@', 12, 8},
- {'#', 22, 8},
- {'$', 32, 8},
- {'%', 42, 8},
- {'^', 52, 8},
- {'&', 62, 8},
- {'(', 71, 8},
- {')', 81, 8},
- {'0', 91, 8},
- {'1', 100, 8},
- {'2', 110, 8},
- {'3', 120, 8},
- };
- static const WIFI_TextInputKey symbol_keyboard_keys_row_2[] = {
- {'~', 2, 20},
- {'+', 12, 20},
- {'-', 22, 20},
- {'=', 32, 20},
- {'[', 42, 20},
- {']', 52, 20},
- {'{', 62, 20},
- {'}', 72, 20},
- {BACKSPACE_KEY, 82, 12},
- {'4', 100, 20},
- {'5', 110, 20},
- {'6', 120, 20},
- };
- static const WIFI_TextInputKey symbol_keyboard_keys_row_3[] = {
- {SWITCH_KEYBOARD_KEY, 1, 23},
- {'.', 15, 32},
- {',', 29, 32},
- {';', 41, 32},
- {'`', 53, 32},
- {'\'', 65, 32},
- {ENTER_KEY, 74, 23},
- {'7', 100, 32},
- {'8', 110, 32},
- {'9', 120, 32},
- };
- static const Keyboard keyboard = {
- .rows =
- {
- keyboard_keys_row_1,
- keyboard_keys_row_2,
- keyboard_keys_row_3,
- },
- .keyboard_index = 0,
- };
- static const Keyboard symbol_keyboard = {
- .rows =
- {
- symbol_keyboard_keys_row_1,
- symbol_keyboard_keys_row_2,
- symbol_keyboard_keys_row_3,
- },
- .keyboard_index = 1,
- };
- static const Keyboard* keyboards[] = {
- &keyboard,
- &symbol_keyboard,
- };
- static void switch_keyboard(WIFI_TextInputModel* model) {
- model->selected_keyboard = (model->selected_keyboard + 1) % keyboard_count;
- }
- static uint8_t get_row_size(const Keyboard* keyboard, uint8_t row_index) {
- uint8_t row_size = 0;
- if(keyboard == &symbol_keyboard) {
- switch(row_index + 1) {
- case 1:
- row_size = COUNT_OF(symbol_keyboard_keys_row_1);
- break;
- case 2:
- row_size = COUNT_OF(symbol_keyboard_keys_row_2);
- break;
- case 3:
- row_size = COUNT_OF(symbol_keyboard_keys_row_3);
- break;
- default:
- furi_crash(NULL);
- }
- } else {
- switch(row_index + 1) {
- case 1:
- row_size = COUNT_OF(keyboard_keys_row_1);
- break;
- case 2:
- row_size = COUNT_OF(keyboard_keys_row_2);
- break;
- case 3:
- row_size = COUNT_OF(keyboard_keys_row_3);
- break;
- default:
- furi_crash(NULL);
- }
- }
- return row_size;
- }
- static const WIFI_TextInputKey* get_row(const Keyboard* keyboard, uint8_t row_index) {
- const WIFI_TextInputKey* row = NULL;
- if(row_index < 3) {
- row = keyboard->rows[row_index];
- } else {
- furi_crash(NULL);
- }
- return row;
- }
- static char get_selected_char(WIFI_TextInputModel* model) {
- return get_row(
- keyboards[model->selected_keyboard], model->selected_row)[model->selected_column]
- .text;
- }
- static bool char_is_lowercase(char letter) {
- return (letter >= 0x61 && letter <= 0x7A);
- }
- static char char_to_uppercase(const char letter) {
- if(letter == '_') {
- return 0x20;
- } else if(char_is_lowercase(letter)) {
- return (letter - 0x20);
- } else {
- return letter;
- }
- }
- static void wifi_text_input_backspace_cb(WIFI_TextInputModel* model) {
- if(model->clear_default_text) {
- model->text_buffer[0] = 0;
- model->cursor_pos = 0;
- } else if(model->cursor_pos > 0) {
- char* move = model->text_buffer + model->cursor_pos;
- memmove(move - 1, move, strlen(move) + 1);
- model->cursor_pos--;
- }
- }
- static void wifi_text_input_view_draw_callback(Canvas* canvas, void* _model) {
- WIFI_TextInputModel* model = _model;
- uint8_t text_length = model->text_buffer ? strlen(model->text_buffer) : 0;
- uint8_t needed_string_width = canvas_width(canvas) - 8;
- uint8_t start_pos = 4;
- model->cursor_pos = model->cursor_pos > text_length ? text_length : model->cursor_pos;
- size_t cursor_pos = model->cursor_pos;
- canvas_clear(canvas);
- canvas_set_color(canvas, ColorBlack);
- canvas_draw_str(canvas, 2, 8, model->header);
- elements_slightly_rounded_frame(canvas, 1, 12, 126, 15);
- char buf[model->text_buffer_size + 1];
- if(model->text_buffer) {
- strlcpy(buf, model->text_buffer, sizeof(buf));
- }
- char* str = buf;
- if(model->clear_default_text) {
- elements_slightly_rounded_box(
- canvas, start_pos - 1, 14, canvas_string_width(canvas, str) + 2, 10);
- canvas_set_color(canvas, ColorWhite);
- } else {
- char* move = str + cursor_pos;
- memmove(move + 1, move, strlen(move) + 1);
- str[cursor_pos] = '|';
- }
- if(cursor_pos > 0 && canvas_string_width(canvas, str) > needed_string_width) {
- canvas_draw_str(canvas, start_pos, 22, "...");
- start_pos += 6;
- needed_string_width -= 8;
- for(uint32_t off = 0;
- strlen(str) && canvas_string_width(canvas, str) > needed_string_width &&
- off < cursor_pos;
- off++) {
- str++;
- }
- }
- if(canvas_string_width(canvas, str) > needed_string_width) {
- needed_string_width -= 4;
- size_t len = strlen(str);
- while(len && canvas_string_width(canvas, str) > needed_string_width) {
- str[len--] = '\0';
- }
- //strcat(str, "..."); // TODO - find replacement
- }
- canvas_draw_str(canvas, start_pos, 22, str);
- canvas_set_font(canvas, FontKeyboard);
- for(uint8_t row = 0; row < keyboard_row_count; row++) {
- const uint8_t column_count = get_row_size(keyboards[model->selected_keyboard], row);
- const WIFI_TextInputKey* keys = get_row(keyboards[model->selected_keyboard], row);
- for(size_t column = 0; column < column_count; column++) {
- bool selected = !model->cursor_select && model->selected_row == row &&
- model->selected_column == column;
- const Icon* icon = NULL;
- if(keys[column].text == ENTER_KEY) {
- icon = selected ? &I_KeySaveSelected_24x11 : &I_KeySave_24x11;
- } else if(keys[column].text == SWITCH_KEYBOARD_KEY) {
- icon = selected ? &I_KeyKeyboardSelected_10x11 : &I_KeyKeyboard_10x11;
- } else if(keys[column].text == BACKSPACE_KEY) {
- icon = selected ? &I_KeyBackspaceSelected_16x9 : &I_KeyBackspace_16x9;
- }
- canvas_set_color(canvas, ColorBlack);
- if(icon != NULL) {
- canvas_draw_icon(
- canvas,
- keyboard_origin_x + keys[column].x,
- keyboard_origin_y + keys[column].y,
- icon);
- } else {
- if(selected) {
- canvas_draw_box(
- canvas,
- keyboard_origin_x + keys[column].x - 1,
- keyboard_origin_y + keys[column].y - 8,
- 7,
- 10);
- canvas_set_color(canvas, ColorWhite);
- }
- if(model->clear_default_text || text_length == 0) {
- canvas_draw_glyph(
- canvas,
- keyboard_origin_x + keys[column].x,
- keyboard_origin_y + keys[column].y,
- char_to_uppercase(keys[column].text));
- } else {
- canvas_draw_glyph(
- canvas,
- keyboard_origin_x + keys[column].x,
- keyboard_origin_y + keys[column].y,
- keys[column].text);
- }
- }
- }
- }
- if(model->validator_message_visible) {
- canvas_set_font(canvas, FontSecondary);
- canvas_set_color(canvas, ColorWhite);
- canvas_draw_box(canvas, 8, 10, 110, 48);
- canvas_set_color(canvas, ColorBlack);
- canvas_draw_icon(canvas, 10, 14, &I_WarningDolphin_45x42);
- canvas_draw_rframe(canvas, 8, 8, 112, 50, 3);
- canvas_draw_rframe(canvas, 9, 9, 110, 48, 2);
- elements_multiline_text(canvas, 62, 20, furi_string_get_cstr(model->validator_text));
- canvas_set_font(canvas, FontKeyboard);
- }
- }
- static void
- wifi_text_input_handle_up(WIFI_TextInput* wifi_text_input, WIFI_TextInputModel* model) {
- UNUSED(wifi_text_input);
- if(model->selected_row > 0) {
- model->selected_row--;
- if(model->selected_row == 0 &&
- model->selected_column >
- get_row_size(keyboards[model->selected_keyboard], model->selected_row) - 6) {
- model->selected_column = model->selected_column + 1;
- }
- if(model->selected_row == 1 &&
- model->selected_keyboard == symbol_keyboard.keyboard_index) {
- if(model->selected_column > 5)
- model->selected_column += 2;
- else if(model->selected_column > 1)
- model->selected_column += 1;
- }
- } else {
- model->cursor_select = true;
- model->clear_default_text = false;
- }
- }
- static void
- wifi_text_input_handle_down(WIFI_TextInput* wifi_text_input, WIFI_TextInputModel* model) {
- UNUSED(wifi_text_input);
- if(model->cursor_select) {
- model->cursor_select = false;
- } else if(model->selected_row < keyboard_row_count - 1) {
- model->selected_row++;
- if(model->selected_row == 1 &&
- model->selected_column >
- get_row_size(keyboards[model->selected_keyboard], model->selected_row) - 4) {
- model->selected_column = model->selected_column - 1;
- }
- if(model->selected_row == 2 &&
- model->selected_keyboard == symbol_keyboard.keyboard_index) {
- if(model->selected_column > 7)
- model->selected_column -= 2;
- else if(model->selected_column > 1)
- model->selected_column -= 1;
- }
- }
- }
- static void
- wifi_text_input_handle_left(WIFI_TextInput* wifi_text_input, WIFI_TextInputModel* model) {
- UNUSED(wifi_text_input);
- if(model->cursor_select) {
- if(model->cursor_pos > 0) {
- model->cursor_pos = CLAMP(model->cursor_pos - 1, strlen(model->text_buffer), 0u);
- }
- } else if(model->selected_column > 0) {
- model->selected_column--;
- } else {
- model->selected_column =
- get_row_size(keyboards[model->selected_keyboard], model->selected_row) - 1;
- }
- }
- static void
- wifi_text_input_handle_right(WIFI_TextInput* wifi_text_input, WIFI_TextInputModel* model) {
- UNUSED(wifi_text_input);
- if(model->cursor_select) {
- model->cursor_pos = CLAMP(model->cursor_pos + 1, strlen(model->text_buffer), 0u);
- } else if(
- model->selected_column <
- get_row_size(keyboards[model->selected_keyboard], model->selected_row) - 1) {
- model->selected_column++;
- } else {
- model->selected_column = 0;
- }
- }
- static void wifi_text_input_handle_ok(
- WIFI_TextInput* wifi_text_input,
- WIFI_TextInputModel* model,
- InputType type) {
- if(model->cursor_select) return;
- bool shift = type == InputTypeLong;
- bool repeat = type == InputTypeRepeat;
- char selected = get_selected_char(model);
- size_t text_length = strlen(model->text_buffer);
- if(selected == ENTER_KEY) {
- if(model->validator_callback &&
- (!model->validator_callback(
- model->text_buffer, model->validator_text, model->validator_callback_context))) {
- model->validator_message_visible = true;
- furi_timer_start(wifi_text_input->timer, furi_kernel_get_tick_frequency() * 4);
- } else if(model->callback != 0 && text_length >= model->minimum_length) {
- model->callback(model->callback_context);
- }
- } else if(selected == SWITCH_KEYBOARD_KEY) {
- switch_keyboard(model);
- } else {
- if(selected == BACKSPACE_KEY) {
- wifi_text_input_backspace_cb(model);
- } else if(!repeat) {
- if(model->clear_default_text) {
- text_length = 0;
- }
- if(text_length < (model->text_buffer_size - 1)) {
- if(shift != (text_length == 0)) {
- selected = char_to_uppercase(selected);
- }
- if(model->clear_default_text) {
- model->text_buffer[0] = selected;
- model->text_buffer[1] = '\0';
- model->cursor_pos = 1;
- } else {
- char* move = model->text_buffer + model->cursor_pos;
- memmove(move + 1, move, strlen(move) + 1);
- model->text_buffer[model->cursor_pos] = selected;
- model->cursor_pos++;
- }
- }
- }
- model->clear_default_text = false;
- }
- }
- static bool wifi_text_input_view_input_callback(InputEvent* event, void* context) {
- WIFI_TextInput* wifi_text_input = context;
- furi_assert(wifi_text_input);
- bool consumed = false;
- // Acquire model
- WIFI_TextInputModel* model = view_get_model(wifi_text_input->view);
- if((!(event->type == InputTypePress) && !(event->type == InputTypeRelease)) &&
- model->validator_message_visible) {
- model->validator_message_visible = false;
- consumed = true;
- } else if(event->type == InputTypeShort) {
- consumed = true;
- switch(event->key) {
- case InputKeyUp:
- wifi_text_input_handle_up(wifi_text_input, model);
- break;
- case InputKeyDown:
- wifi_text_input_handle_down(wifi_text_input, model);
- break;
- case InputKeyLeft:
- wifi_text_input_handle_left(wifi_text_input, model);
- break;
- case InputKeyRight:
- wifi_text_input_handle_right(wifi_text_input, model);
- break;
- case InputKeyOk:
- wifi_text_input_handle_ok(wifi_text_input, model, event->type);
- break;
- default:
- consumed = false;
- break;
- }
- } else if(event->type == InputTypeLong) {
- consumed = true;
- switch(event->key) {
- case InputKeyUp:
- wifi_text_input_handle_up(wifi_text_input, model);
- break;
- case InputKeyDown:
- wifi_text_input_handle_down(wifi_text_input, model);
- break;
- case InputKeyLeft:
- wifi_text_input_handle_left(wifi_text_input, model);
- break;
- case InputKeyRight:
- wifi_text_input_handle_right(wifi_text_input, model);
- break;
- case InputKeyOk:
- wifi_text_input_handle_ok(wifi_text_input, model, event->type);
- break;
- case InputKeyBack:
- wifi_text_input_backspace_cb(model);
- break;
- default:
- consumed = false;
- break;
- }
- } else if(event->type == InputTypeRepeat) {
- consumed = true;
- switch(event->key) {
- case InputKeyUp:
- wifi_text_input_handle_up(wifi_text_input, model);
- break;
- case InputKeyDown:
- wifi_text_input_handle_down(wifi_text_input, model);
- break;
- case InputKeyLeft:
- wifi_text_input_handle_left(wifi_text_input, model);
- break;
- case InputKeyRight:
- wifi_text_input_handle_right(wifi_text_input, model);
- break;
- case InputKeyOk:
- wifi_text_input_handle_ok(wifi_text_input, model, event->type);
- break;
- case InputKeyBack:
- wifi_text_input_backspace_cb(model);
- break;
- default:
- consumed = false;
- break;
- }
- }
- // Commit model
- view_commit_model(wifi_text_input->view, consumed);
- return consumed;
- }
- void wifi_text_input_timer_callback(void* context) {
- furi_assert(context);
- WIFI_TextInput* wifi_text_input = context;
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- { model->validator_message_visible = false; },
- true);
- }
- WIFI_TextInput* wifi_text_input_alloc() {
- WIFI_TextInput* wifi_text_input = malloc(sizeof(WIFI_TextInput));
- wifi_text_input->view = view_alloc();
- view_set_context(wifi_text_input->view, wifi_text_input);
- view_allocate_model(wifi_text_input->view, ViewModelTypeLocking, sizeof(WIFI_TextInputModel));
- view_set_draw_callback(wifi_text_input->view, wifi_text_input_view_draw_callback);
- view_set_input_callback(wifi_text_input->view, wifi_text_input_view_input_callback);
- wifi_text_input->timer =
- furi_timer_alloc(wifi_text_input_timer_callback, FuriTimerTypeOnce, wifi_text_input);
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- {
- model->validator_text = furi_string_alloc();
- model->minimum_length = 1;
- model->cursor_pos = 0;
- model->cursor_select = false;
- },
- false);
- wifi_text_input_reset(wifi_text_input);
- return wifi_text_input;
- }
- void wifi_text_input_free(WIFI_TextInput* wifi_text_input) {
- furi_assert(wifi_text_input);
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- { furi_string_free(model->validator_text); },
- false);
- // Send stop command
- furi_timer_stop(wifi_text_input->timer);
- // Release allocated memory
- furi_timer_free(wifi_text_input->timer);
- view_free(wifi_text_input->view);
- free(wifi_text_input);
- }
- void wifi_text_input_reset(WIFI_TextInput* wifi_text_input) {
- furi_assert(wifi_text_input);
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- {
- model->header = "";
- model->selected_row = 0;
- model->selected_column = 0;
- model->selected_keyboard = 0;
- model->minimum_length = 1;
- model->clear_default_text = false;
- model->cursor_pos = 0;
- model->cursor_select = false;
- model->text_buffer = NULL;
- model->text_buffer_size = 0;
- model->callback = NULL;
- model->callback_context = NULL;
- model->validator_callback = NULL;
- model->validator_callback_context = NULL;
- furi_string_reset(model->validator_text);
- model->validator_message_visible = false;
- },
- true);
- }
- View* wifi_text_input_get_view(WIFI_TextInput* wifi_text_input) {
- furi_assert(wifi_text_input);
- return wifi_text_input->view;
- }
- void wifi_text_input_set_result_callback(
- WIFI_TextInput* wifi_text_input,
- WIFI_TextInputCallback callback,
- void* callback_context,
- char* text_buffer,
- size_t text_buffer_size,
- bool clear_default_text) {
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- {
- model->callback = callback;
- model->callback_context = callback_context;
- model->text_buffer = text_buffer;
- model->text_buffer_size = text_buffer_size;
- model->clear_default_text = clear_default_text;
- model->cursor_select = false;
- if(text_buffer && text_buffer[0] != '\0') {
- model->cursor_pos = strlen(text_buffer);
- // Set focus on Save
- model->selected_row = 2;
- model->selected_column = 9;
- model->selected_keyboard = 0;
- } else {
- model->cursor_pos = 0;
- }
- },
- true);
- }
- void wifi_text_input_set_minimum_length(WIFI_TextInput* wifi_text_input, size_t minimum_length) {
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- { model->minimum_length = minimum_length; },
- true);
- }
- void wifi_text_input_set_validator(
- WIFI_TextInput* wifi_text_input,
- WIFI_TextInputValidatorCallback callback,
- void* callback_context) {
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- {
- model->validator_callback = callback;
- model->validator_callback_context = callback_context;
- },
- true);
- }
- WIFI_TextInputValidatorCallback
- wifi_text_input_get_validator_callback(WIFI_TextInput* wifi_text_input) {
- WIFI_TextInputValidatorCallback validator_callback = NULL;
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- { validator_callback = model->validator_callback; },
- false);
- return validator_callback;
- }
- void* wifi_text_input_get_validator_callback_context(WIFI_TextInput* wifi_text_input) {
- void* validator_callback_context = NULL;
- with_view_model(
- wifi_text_input->view,
- WIFI_TextInputModel * model,
- { validator_callback_context = model->validator_callback_context; },
- false);
- return validator_callback_context;
- }
- void wifi_text_input_set_header_text(WIFI_TextInput* wifi_text_input, const char* text) {
- with_view_model(
- wifi_text_input->view, WIFI_TextInputModel * model, { model->header = text; }, true);
- }
|