nfc_playlist_scene_view_playlist_content.c 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. #include "../nfc_playlist.h"
  2. void nfc_playlist_view_playlist_content_scene_on_enter(void* context) {
  3. NfcPlaylist* nfc_playlist = context;
  4. Storage* storage = furi_record_open(RECORD_STORAGE);
  5. File* file = storage_file_alloc(storage);
  6. if (storage_file_open(file, furi_string_get_cstr(nfc_playlist->settings.file_path), FSAM_READ, FSOM_OPEN_EXISTING)) {
  7. uint8_t buffer[PLAYLIST_VIEW_MAX_SIZE];
  8. uint16_t read_count = storage_file_read(file, buffer, PLAYLIST_VIEW_MAX_SIZE);
  9. FuriString* playlist_content = furi_string_alloc();
  10. for(uint16_t i = 0; i < read_count; i++) {
  11. furi_string_push_back(playlist_content, buffer[i]);
  12. }
  13. widget_add_text_scroll_element(nfc_playlist->widget, 4, 4, 124, 60, furi_string_get_cstr(playlist_content));
  14. widget_add_frame_element(nfc_playlist->widget, 0, 0, 128, 64, 0);
  15. furi_string_free(playlist_content);
  16. storage_file_close(file);
  17. } else {
  18. widget_add_text_box_element(nfc_playlist->widget, 0, 0, 128, 64, AlignCenter, AlignCenter, "\eFailed to open playlist\n\nPress back\e", false);
  19. }
  20. storage_file_free(file);
  21. furi_record_close(RECORD_STORAGE);
  22. view_dispatcher_switch_to_view(nfc_playlist->view_dispatcher, NfcPlaylistView_Widget);
  23. }
  24. bool nfc_playlist_view_playlist_content_scene_on_event(void* context, SceneManagerEvent event) {
  25. UNUSED(context);
  26. UNUSED(event);
  27. return false;
  28. }
  29. void nfc_playlist_view_playlist_content_scene_on_exit(void* context) {
  30. NfcPlaylist* nfc_playlist = context;
  31. widget_reset(nfc_playlist->widget);
  32. }