nfc_playlist_scene_playlist_rename.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #include "../nfc_playlist.h"
  2. static bool playlist_exist_already = false;
  3. int32_t nfc_playlist_playlist_rename_thread_task(void* context) {
  4. NfcPlaylist* nfc_playlist = context;
  5. FuriString* old_file_path = furi_string_alloc();
  6. path_extract_dirname(furi_string_get_cstr(nfc_playlist->settings.playlist_path), old_file_path);
  7. FuriString* new_file_path = furi_string_alloc_set(old_file_path);
  8. path_concat(
  9. furi_string_get_cstr(old_file_path), nfc_playlist->text_input_output, new_file_path);
  10. furi_string_free(old_file_path);
  11. furi_string_cat_str(new_file_path, ".txt");
  12. Storage* storage = furi_record_open(RECORD_STORAGE);
  13. if(!storage_file_exists(storage, furi_string_get_cstr(new_file_path))) {
  14. if(storage_common_rename(
  15. storage,
  16. furi_string_get_cstr(nfc_playlist->settings.playlist_path),
  17. furi_string_get_cstr(new_file_path)) == FSE_OK) {
  18. furi_string_swap(nfc_playlist->settings.playlist_path, new_file_path);
  19. }
  20. } else {
  21. if(furi_string_cmp(nfc_playlist->settings.playlist_path, new_file_path) != 0) {
  22. playlist_exist_already = true;
  23. }
  24. }
  25. furi_string_free(new_file_path);
  26. furi_record_close(RECORD_STORAGE);
  27. return 0;
  28. }
  29. void nfc_playlist_playlist_rename_thread_state_callback(FuriThreadState state, void* context) {
  30. NfcPlaylist* nfc_playlist = context;
  31. if(state == FuriThreadStateStopped) {
  32. furi_thread_yield();
  33. nfc_playlist->thread = NULL;
  34. if(playlist_exist_already) {
  35. scene_manager_next_scene(
  36. nfc_playlist->scene_manager, NfcPlaylistScene_ErrorPlaylistAlreadyExists);
  37. } else {
  38. scene_manager_search_and_switch_to_previous_scene(
  39. nfc_playlist->scene_manager, NfcPlaylistScene_MainMenu);
  40. }
  41. }
  42. }
  43. void nfc_playlist_playlist_rename_menu_callback(void* context) {
  44. NfcPlaylist* nfc_playlist = context;
  45. nfc_playlist->thread = furi_thread_alloc_ex(
  46. "NfcPlaylistRenamer", 1024, nfc_playlist_playlist_rename_thread_task, nfc_playlist);
  47. furi_thread_set_state_context(nfc_playlist->thread, nfc_playlist);
  48. furi_thread_set_state_callback(
  49. nfc_playlist->thread, nfc_playlist_playlist_rename_thread_state_callback);
  50. furi_thread_start(nfc_playlist->thread);
  51. }
  52. void nfc_playlist_playlist_rename_scene_on_enter(void* context) {
  53. NfcPlaylist* nfc_playlist = context;
  54. playlist_exist_already = false;
  55. FuriString* tmp_file_name = furi_string_alloc();
  56. path_extract_filename_no_ext(
  57. furi_string_get_cstr(nfc_playlist->settings.playlist_path), tmp_file_name);
  58. nfc_playlist->text_input_output = malloc(MAX_PLAYLIST_NAME_LEN + 1);
  59. strcpy(nfc_playlist->text_input_output, furi_string_get_cstr(tmp_file_name));
  60. furi_string_free(tmp_file_name);
  61. text_input_set_header_text(nfc_playlist->text_input, "Enter new file name");
  62. text_input_set_minimum_length(nfc_playlist->text_input, 1);
  63. text_input_set_result_callback(
  64. nfc_playlist->text_input,
  65. nfc_playlist_playlist_rename_menu_callback,
  66. nfc_playlist,
  67. nfc_playlist->text_input_output,
  68. MAX_PLAYLIST_NAME_LEN,
  69. false);
  70. view_dispatcher_switch_to_view(nfc_playlist->view_dispatcher, NfcPlaylistView_TextInput);
  71. }
  72. bool nfc_playlist_playlist_rename_scene_on_event(void* context, SceneManagerEvent event) {
  73. UNUSED(context);
  74. UNUSED(event);
  75. return false;
  76. }
  77. void nfc_playlist_playlist_rename_scene_on_exit(void* context) {
  78. NfcPlaylist* nfc_playlist = context;
  79. free(nfc_playlist->text_input_output);
  80. text_input_reset(nfc_playlist->text_input);
  81. }