mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2024-12-18 16:53:45 +00:00
4bf29827f8
* Quicksave 1 * Header stage complete * Source stage complete * Lint & merge fixes * Includes * Documentation step 1 * FBT: output free size considering BT STACK * Documentation step 2 * py lint * Fix music player plugin * unit test stage 1: string allocator, mem, getters, setters, appends, compare, search. * unit test: string equality * unit test: string replace * unit test: string start_with, end_with * unit test: string trim * unit test: utf-8 * Rename * Revert fw_size changes * Simplify CLI backspace handling * Simplify CLI character insert * Merge fixes * Furi: correct filenaming and spelling * Bt: remove furi string include Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
83 lines
3 KiB
C
83 lines
3 KiB
C
#include "../picopass_i.h"
|
|
#include <lib/toolbox/random_name.h>
|
|
#include <gui/modules/validators.h>
|
|
#include <toolbox/path.h>
|
|
|
|
void picopass_scene_save_name_text_input_callback(void* context) {
|
|
Picopass* picopass = context;
|
|
|
|
view_dispatcher_send_custom_event(picopass->view_dispatcher, PicopassCustomEventTextInputDone);
|
|
}
|
|
|
|
void picopass_scene_save_name_on_enter(void* context) {
|
|
Picopass* picopass = context;
|
|
|
|
// Setup view
|
|
TextInput* text_input = picopass->text_input;
|
|
bool dev_name_empty = false;
|
|
if(!strcmp(picopass->dev->dev_name, "")) {
|
|
set_random_name(picopass->text_store, sizeof(picopass->text_store));
|
|
dev_name_empty = true;
|
|
} else {
|
|
picopass_text_store_set(picopass, picopass->dev->dev_name);
|
|
}
|
|
text_input_set_header_text(text_input, "Name the card");
|
|
text_input_set_result_callback(
|
|
text_input,
|
|
picopass_scene_save_name_text_input_callback,
|
|
picopass,
|
|
picopass->text_store,
|
|
PICOPASS_DEV_NAME_MAX_LEN,
|
|
dev_name_empty);
|
|
|
|
FuriString* folder_path;
|
|
folder_path = furi_string_alloc();
|
|
|
|
if(furi_string_end_with(picopass->dev->load_path, PICOPASS_APP_EXTENSION)) {
|
|
path_extract_dirname(furi_string_get_cstr(picopass->dev->load_path), folder_path);
|
|
} else {
|
|
furi_string_set(folder_path, PICOPASS_APP_FOLDER);
|
|
}
|
|
|
|
ValidatorIsFile* validator_is_file = validator_is_file_alloc_init(
|
|
furi_string_get_cstr(folder_path), PICOPASS_APP_EXTENSION, picopass->dev->dev_name);
|
|
text_input_set_validator(text_input, validator_is_file_callback, validator_is_file);
|
|
|
|
view_dispatcher_switch_to_view(picopass->view_dispatcher, PicopassViewTextInput);
|
|
|
|
furi_string_free(folder_path);
|
|
}
|
|
|
|
bool picopass_scene_save_name_on_event(void* context, SceneManagerEvent event) {
|
|
Picopass* picopass = context;
|
|
bool consumed = false;
|
|
|
|
if(event.type == SceneManagerEventTypeCustom) {
|
|
if(event.event == PicopassCustomEventTextInputDone) {
|
|
if(strcmp(picopass->dev->dev_name, "")) {
|
|
// picopass_device_delete(picopass->dev, true);
|
|
}
|
|
strlcpy(
|
|
picopass->dev->dev_name, picopass->text_store, strlen(picopass->text_store) + 1);
|
|
if(picopass_device_save(picopass->dev, picopass->text_store)) {
|
|
scene_manager_next_scene(picopass->scene_manager, PicopassSceneSaveSuccess);
|
|
consumed = true;
|
|
} else {
|
|
consumed = scene_manager_search_and_switch_to_previous_scene(
|
|
picopass->scene_manager, PicopassSceneStart);
|
|
}
|
|
}
|
|
}
|
|
return consumed;
|
|
}
|
|
|
|
void picopass_scene_save_name_on_exit(void* context) {
|
|
Picopass* picopass = context;
|
|
|
|
// Clear view
|
|
void* validator_context = text_input_get_validator_callback_context(picopass->text_input);
|
|
text_input_set_validator(picopass->text_input, NULL, NULL);
|
|
validator_is_file_free(validator_context);
|
|
|
|
text_input_reset(picopass->text_input);
|
|
}
|