summaryrefslogtreecommitdiffstats
path: root/lib/data/models/date_time.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/date_time.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/date_time.dart')
-rw-r--r--lib/data/models/date_time.dart59
1 files changed, 59 insertions, 0 deletions
diff --git a/lib/data/models/date_time.dart b/lib/data/models/date_time.dart
new file mode 100644
index 0000000..62d7743
--- /dev/null
+++ b/lib/data/models/date_time.dart
@@ -0,0 +1,59 @@
+import 'dart:convert';
+
+import 'package:flutter_ics_homescreen/export.dart';
+import 'package:intl/intl.dart';
+
+@immutable
+class DateAndTime {
+ final String date;
+ final String time;
+ const DateAndTime({
+ required this.date,
+ required this.time,
+ });
+
+ DateAndTime.initial()
+ : date = DateFormat().add_yMMMMd().format(DateTime.now()),
+ time = DateFormat('hh:mm a').format(DateTime.now());
+ DateAndTime copyWith({
+ String? date,
+ String? time,
+ }) {
+ return DateAndTime(
+ date: date ?? this.date,
+ time: time ?? this.time,
+ );
+ }
+
+ Map<String, dynamic> toMap() {
+ return {
+ 'date': date,
+ 'time': time,
+ };
+ }
+
+ factory DateAndTime.fromMap(Map<String, dynamic> map) {
+ return DateAndTime(
+ date: map['date'],
+ time: map['time'],
+ );
+ }
+
+ String toJson() => json.encode(toMap());
+
+ factory DateAndTime.fromJson(String source) =>
+ DateAndTime.fromMap(json.decode(source));
+
+ @override
+ String toString() => 'DateAndTime(date: $date, time: $time)';
+
+ @override
+ bool operator ==(Object other) {
+ if (identical(this, other)) return true;
+
+ return other is DateAndTime && other.date == date && other.time == time;
+ }
+
+ @override
+ int get hashCode => date.hashCode ^ time.hashCode;
+}