extracted getTimeRemainingString from pizza event widget to util
This commit is contained in:
parent
843ebe19bc
commit
91fbc547ff
2 changed files with 21 additions and 21 deletions
|
@ -30,4 +30,24 @@ extension StringExtensions on String {
|
||||||
|
|
||||||
DateFormat getDateFormat(){
|
DateFormat getDateFormat(){
|
||||||
return DateFormat("yyyy-MM-dd H:mm");
|
return DateFormat("yyyy-MM-dd H:mm");
|
||||||
|
}
|
||||||
|
|
||||||
|
String getTimeRemainingString(DateTime other, {DateTime? now}){
|
||||||
|
now = now ?? DateTime.now();
|
||||||
|
Duration duration = other.difference(now);
|
||||||
|
Duration absDuration = duration.abs();
|
||||||
|
String durationString = "";
|
||||||
|
if (absDuration.inHours <= 0 && absDuration.inMinutes > 0) {
|
||||||
|
durationString = "${absDuration.inMinutes} minute" + (absDuration.inMinutes > 1 ? "s" : "");
|
||||||
|
}
|
||||||
|
else if (absDuration.inDays <= 0 && absDuration.inHours > 0) {
|
||||||
|
durationString = "${absDuration.inHours} hours";
|
||||||
|
}
|
||||||
|
else if (absDuration.inDays <= 31) {
|
||||||
|
durationString = "${absDuration.inDays} day" + (absDuration.inDays > 1 ? "s" : "");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
durationString = "${(absDuration.inDays / 7).floor()} week" + (absDuration.inDays >= 14 ? "s" : "");
|
||||||
|
}
|
||||||
|
return duration.isNegative ? "$durationString ago" : "In $durationString";
|
||||||
}
|
}
|
|
@ -22,7 +22,7 @@ class PizzaEventWidget extends StatelessWidget {
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
Text(pizzaEvent.name),
|
Text(pizzaEvent.name),
|
||||||
Text(this.getTimeRemainingString())
|
Text(getTimeRemainingString(pizzaEvent.dateTime))
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
Container(
|
Container(
|
||||||
|
@ -68,24 +68,4 @@ class PizzaEventWidget extends StatelessWidget {
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
String getTimeRemainingString(){
|
|
||||||
DateTime now = DateTime.now();
|
|
||||||
Duration duration = pizzaEvent.dateTime.difference(now);
|
|
||||||
Duration absDuration = duration.abs();
|
|
||||||
String durationString = "";
|
|
||||||
if (absDuration.inHours <= 0 && absDuration.inMinutes > 0) {
|
|
||||||
durationString = "${absDuration.inMinutes} minute" + (absDuration.inMinutes > 1 ? "s" : "");
|
|
||||||
}
|
|
||||||
else if (absDuration.inDays <= 0 && absDuration.inHours > 0) {
|
|
||||||
durationString = "${absDuration.inHours} hours";
|
|
||||||
}
|
|
||||||
else if (absDuration.inDays <= 31) {
|
|
||||||
durationString = "${absDuration.inDays} day" + (absDuration.inDays > 1 ? "s" : "");
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
durationString = "${(absDuration.inDays / 7).floor()} week" + (absDuration.inDays >= 14 ? "s" : "");
|
|
||||||
}
|
|
||||||
return duration.isNegative ? "$durationString ago" : "In $durationString";
|
|
||||||
}
|
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue