mirror of
https://gitlab.com/foxixus/neomovies_mobile.git
synced 2025-10-27 23:18:49 +05:00
Fix API auth flow and poster URLs
- Fix authorization issues by improving error handling for unverified accounts - Enable auto-login after successful email verification - Fix poster fetching to use NeoMovies API instead of TMDB directly - Add missing video player models (VideoQuality, AudioTrack, Subtitle, PlayerSettings) - Add video_player and chewie dependencies for native video playback - Update Movie model to use API images endpoint for better CDN control Resolves authentication and image loading issues.
This commit is contained in:
73
lib/data/models/player/player_settings.dart
Normal file
73
lib/data/models/player/player_settings.dart
Normal file
@@ -0,0 +1,73 @@
|
||||
import 'package:neomovies_mobile/data/models/player/video_quality.dart';
|
||||
import 'package:neomovies_mobile/data/models/player/audio_track.dart';
|
||||
import 'package:neomovies_mobile/data/models/player/subtitle.dart';
|
||||
|
||||
class PlayerSettings {
|
||||
final VideoQuality? selectedQuality;
|
||||
final AudioTrack? selectedAudioTrack;
|
||||
final Subtitle? selectedSubtitle;
|
||||
final double volume;
|
||||
final double playbackSpeed;
|
||||
final bool autoPlay;
|
||||
final bool muted;
|
||||
|
||||
PlayerSettings({
|
||||
this.selectedQuality,
|
||||
this.selectedAudioTrack,
|
||||
this.selectedSubtitle,
|
||||
this.volume = 1.0,
|
||||
this.playbackSpeed = 1.0,
|
||||
this.autoPlay = true,
|
||||
this.muted = false,
|
||||
});
|
||||
|
||||
PlayerSettings copyWith({
|
||||
VideoQuality? selectedQuality,
|
||||
AudioTrack? selectedAudioTrack,
|
||||
Subtitle? selectedSubtitle,
|
||||
double? volume,
|
||||
double? playbackSpeed,
|
||||
bool? autoPlay,
|
||||
bool? muted,
|
||||
}) {
|
||||
return PlayerSettings(
|
||||
selectedQuality: selectedQuality ?? this.selectedQuality,
|
||||
selectedAudioTrack: selectedAudioTrack ?? this.selectedAudioTrack,
|
||||
selectedSubtitle: selectedSubtitle ?? this.selectedSubtitle,
|
||||
volume: volume ?? this.volume,
|
||||
playbackSpeed: playbackSpeed ?? this.playbackSpeed,
|
||||
autoPlay: autoPlay ?? this.autoPlay,
|
||||
muted: muted ?? this.muted,
|
||||
);
|
||||
}
|
||||
|
||||
factory PlayerSettings.fromJson(Map<String, dynamic> json) {
|
||||
return PlayerSettings(
|
||||
selectedQuality: json['selectedQuality'] != null
|
||||
? VideoQuality.fromJson(json['selectedQuality'])
|
||||
: null,
|
||||
selectedAudioTrack: json['selectedAudioTrack'] != null
|
||||
? AudioTrack.fromJson(json['selectedAudioTrack'])
|
||||
: null,
|
||||
selectedSubtitle: json['selectedSubtitle'] != null
|
||||
? Subtitle.fromJson(json['selectedSubtitle'])
|
||||
: null,
|
||||
volume: json['volume']?.toDouble() ?? 1.0,
|
||||
playbackSpeed: json['playbackSpeed']?.toDouble() ?? 1.0,
|
||||
autoPlay: json['autoPlay'] ?? true,
|
||||
muted: json['muted'] ?? false,
|
||||
);
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
return {
|
||||
'selectedQuality': selectedQuality?.toJson(),
|
||||
'selectedAudioTrack': selectedAudioTrack?.toJson(),
|
||||
'selectedSubtitle': selectedSubtitle?.toJson(),
|
||||
'volume': volume,
|
||||
'playbackSpeed': playbackSpeed,
|
||||
'autoPlay': autoPlay,
|
||||
'muted': muted,
|
||||
};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user