created alarm models
This commit is contained in:
@@ -0,0 +1,3 @@
|
||||
abstract class Alarm {
|
||||
String get id;
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
import 'alarm.dart';
|
||||
import 'location.dart';
|
||||
|
||||
class LocationAlarm implements Alarm {
|
||||
@override
|
||||
final String id;
|
||||
|
||||
final Location location;
|
||||
|
||||
final int radiusMeters;
|
||||
|
||||
const LocationAlarm({
|
||||
required this.id,
|
||||
required this.location,
|
||||
required this.radiusMeters,
|
||||
});
|
||||
|
||||
factory LocationAlarm.fromJson(Map<String, dynamic> json) {
|
||||
return LocationAlarm(
|
||||
id: json['id'] as String,
|
||||
location: Location.fromJson(json['location'] as Map<String, dynamic>),
|
||||
radiusMeters: json['radiusMeters'] as int,
|
||||
);
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
return {
|
||||
'id': id,
|
||||
'location': location.toJson(),
|
||||
'radiusMeters': radiusMeters,
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,21 @@
|
||||
import 'alarm.dart';
|
||||
|
||||
class TimeAlarm implements Alarm {
|
||||
@override
|
||||
final String id;
|
||||
|
||||
final DateTime triggerAt;
|
||||
|
||||
const TimeAlarm({required this.id, required this.triggerAt});
|
||||
|
||||
factory TimeAlarm.fromJson(Map<String, dynamic> json) {
|
||||
return TimeAlarm(
|
||||
id: json['id'] as String,
|
||||
triggerAt: DateTime.parse(json['triggerAt'] as String),
|
||||
);
|
||||
}
|
||||
|
||||
Map<String, dynamic> toJson() {
|
||||
return {'id': id, 'triggerAt': triggerAt.toIso8601String()};
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user