summaryrefslogtreecommitdiffstats
path: root/lib/data/models/audio.dart
diff options
context:
space:
mode:
authorLisandro Pérez Meyer <lpmeyer@ics.com>2023-11-14 17:20:58 -0300
committerLisandro Pérez Meyer <lpmeyer@ics.com>2023-11-14 17:31:12 -0300
commit70ec8a79a121471a004e7e4c23157d10157e136f (patch)
treea4f9c0a4fac4e4274ec4324a289b6ef62e1c5653 /lib/data/models/audio.dart
Initial cleanup push.
Based on agldemo2024 on commit 2a5dc04d801134338150c3f6afc67eaa65599763 Disable device preview. Disable Lottie animation. The original commit was b3c493c340fcb4bb0a937692838fc830bec3e9ea but I am just keeping this change, because the json did not really needed to change. I think. Signed-off-by: Lisandro Pérez Meyer <lpmeyer@ics.com>
Diffstat (limited to 'lib/data/models/audio.dart')
-rw-r--r--lib/data/models/audio.dart84
1 files changed, 84 insertions, 0 deletions
diff --git a/lib/data/models/audio.dart b/lib/data/models/audio.dart
new file mode 100644
index 0000000..69df18b
--- /dev/null
+++ b/lib/data/models/audio.dart
@@ -0,0 +1,84 @@
+import 'dart:convert';
+
+import 'package:flutter_ics_homescreen/export.dart';
+
+@immutable
+class Audio {
+ final double volume;
+ final double treble;
+ final double bass;
+ final double rearFront;
+ const Audio({
+ required this.volume,
+ required this.treble,
+ required this.bass,
+ required this.rearFront,
+ });
+
+ const Audio.initial()
+ : volume = 5.0,
+ treble = 5.0,
+ bass = 5.0,
+ rearFront = 5.0;
+
+
+ Audio copyWith({
+ double? volume,
+ double? treble,
+ double? bass,
+ double? rearFront,
+ }) {
+ return Audio(
+ volume: volume ?? this.volume,
+ treble: treble ?? this.treble,
+ bass: bass ?? this.bass,
+ rearFront: rearFront ?? this.rearFront,
+ );
+ }
+
+ Map<String, dynamic> toMap() {
+ return {
+ 'volume': volume,
+ 'treble': treble,
+ 'bass': bass,
+ 'rearFront': rearFront,
+ };
+ }
+
+ factory Audio.fromMap(Map<String, dynamic> map) {
+ return Audio(
+ volume: map['volume']?.toDouble() ?? 0.0,
+ treble: map['treble']?.toDouble() ?? 0.0,
+ bass: map['bass']?.toDouble() ?? 0.0,
+ rearFront: map['rearFront']?.toDouble() ?? 0.0,
+ );
+ }
+
+ String toJson() => json.encode(toMap());
+
+ factory Audio.fromJson(String source) => Audio.fromMap(json.decode(source));
+
+ @override
+ String toString() {
+ return 'Audio(volume: $volume, treble: $treble, bass: $bass, rearFront: $rearFront)';
+ }
+
+ @override
+ bool operator ==(Object other) {
+ if (identical(this, other)) return true;
+
+ return other is Audio &&
+ other.volume == volume &&
+ other.treble == treble &&
+ other.bass == bass &&
+ other.rearFront == rearFront;
+ }
+
+ @override
+ int get hashCode {
+ return volume.hashCode ^
+ treble.hashCode ^
+ bass.hashCode ^
+ rearFront.hashCode;
+ }
+}