120 lines
3.7 KiB
Dart
Raw Permalink Normal View History

2024-11-08 13:07:43 +04:00
import 'dart:convert';
import 'package:dio/dio.dart';
import 'package:pmd_labs/data/dto/album_dto.dart';
import 'package:pmd_labs/card_data.dart';
2024-11-26 01:44:56 +04:00
import 'package:uuid/uuid.dart';
import '../../home_page/home_page.dart';
2024-11-08 13:07:43 +04:00
2024-12-10 20:49:23 +04:00
String generateAlbumId(String name, String artist, String url) {
return '$name|$artist|$url';
}
2024-11-08 13:07:43 +04:00
extension AlbumDataDtoMapper on AlbumDataDto {
List<AlbumDataDto> fetchAlbums(List<dynamic> albumsData) {
2024-11-26 01:44:56 +04:00
const String defaultImageUrl = "https://i.ibb.co/VwCkRD4/image.jpg";
2024-11-08 13:07:43 +04:00
List<AlbumDataDto> albums = [];
for (var album in albumsData) {
String? albumImage;
// Ищем наиболее подходящее изображение
List<dynamic> images = album['image'] as List<dynamic>;
var largestImage = images.firstWhere(
2024-12-10 20:49:23 +04:00
(image) => image['size'] == 'mega',
2024-11-26 01:44:56 +04:00
orElse: () => images.firstWhere(
2024-12-10 20:49:23 +04:00
(image) => image['size'] == 'extralarge',
2024-11-26 01:44:56 +04:00
orElse: () => images.firstWhere(
2024-12-10 20:49:23 +04:00
(image) => image['size'] == 'large',
2024-11-26 01:44:56 +04:00
orElse: () => null, // запасной вариант
),
),
2024-11-08 13:07:43 +04:00
);
2024-12-10 20:49:23 +04:00
if (largestImage['#text'] != "")
2024-11-26 01:44:56 +04:00
albumImage = largestImage['#text'] as String?;
else
albumImage = defaultImageUrl;
2024-11-08 13:07:43 +04:00
if (album['name'] != "(null)" && album['artist'] != "(null)") {
2024-12-10 20:49:23 +04:00
final id = generateAlbumId(album['name'], album['artist'], album['url']);
2024-11-08 13:07:43 +04:00
albums.add(AlbumDataDto(
2024-11-26 01:44:56 +04:00
id: id,
2024-11-08 13:07:43 +04:00
title: album['name'] as String?,
artist: album['artist'] as String?,
year: "",
genres: [],
tracks: [],
summary: "",
url: album['url'] as String?,
images: AlbumDataImagesDto(
jpg: AlbumDataImagesJPGDto(image_url: albumImage),
),
));
}
}
return albums;
}
2024-11-26 01:44:56 +04:00
Future<AlbumDataDto> fetchAlbumDetails(Map<String, dynamic> data, AlbumDataDto album) async {
2024-11-08 13:07:43 +04:00
if (data['album'] != null) {
// Получаем жанры и год
String year = "";
List<String> genres = [];
// Находим год в тегах
2024-12-10 20:49:23 +04:00
year = (data['album']?['tags']?['tag'] as List).firstWhere(
2024-11-08 13:07:43 +04:00
(tag) => tag['name'].contains(RegExp(r'^\d{4}$')),
2024-12-10 20:49:23 +04:00
orElse: () => null,
)?['name'] ??
"_";
2024-11-08 13:07:43 +04:00
// Получаем список жанров
2024-12-10 20:49:23 +04:00
genres = List<String>.from((data['album']?['tags']?['tag'] as List<dynamic>? ?? [])
.map((tag) => tag['name'] as String));
2024-11-08 13:07:43 +04:00
// Заполняем список треков
List<String> tracks = List<String>.from(
(data['album']?['tracks']?['track'] as List<dynamic>? ?? [])
2024-12-10 20:49:23 +04:00
.map((track) => track['name'] as String));
2024-11-08 13:07:43 +04:00
// Обновляем информацию в нашем DTO альбома
album.year = year;
album.genres = genres;
album.tracks = tracks;
2024-12-21 02:31:23 +04:00
album.summary = data['album']?['wiki']?['summary'] ?? "missing";
2024-11-08 13:07:43 +04:00
}
2024-12-21 02:31:23 +04:00
return album;
2024-11-08 13:07:43 +04:00
}
CardData toDomain() {
return CardData(
2024-11-26 01:44:56 +04:00
id: id,
2024-11-08 13:07:43 +04:00
title: title ?? 'UNKNOWN',
artist: artist ?? 'UNKNOWN',
year: year ?? 'UNKNOWN',
url: url ?? 'UNKNOWN',
summary: summary ?? 'UNKNOWN',
genres: genres ?? ['UNKNOWN'],
tracks: tracks ?? ['UNKNOWN'],
2024-12-21 02:31:23 +04:00
imageUrl: images?.jpg?.image_url ?? 'UNKNOWN',
2024-11-26 01:44:56 +04:00
);
}
}
extension AlbumDtoMapper on AlbumDto {
List<AlbumDataDto> fetchAlbumsWithPagination(List<dynamic> albumsData) {
List<AlbumDataDto> albums = AlbumDataDto().fetchAlbums(albumsData);
return albums;
}
HomeData toDomain() {
return HomeData(
data: data?.map((e) => e.toDomain()).toList(),
2024-12-10 20:49:23 +04:00
nextPage: (pagination?.hasNextPage ?? false) ? ((pagination?.currentPage ?? 0) + 1) : null,
2024-11-08 13:07:43 +04:00
);
}
2024-12-10 20:49:23 +04:00
}