fixed up the layout of the PlannedPizzaWidget

This commit is contained in:
broodjeaap89 2021-07-02 21:08:11 +02:00
parent fa3142d666
commit 0f656dfa05

View file

@ -26,7 +26,7 @@ class PlannedPizzasState extends State<PlannedPizzasPage> {
itemCount: plannedPizzas.length, itemCount: plannedPizzas.length,
itemBuilder: (BuildContext context, int i) { itemBuilder: (BuildContext context, int i) {
return Container( return Container(
height: 100, height: 150,
color: Colors.blueAccent, color: Colors.blueAccent,
child: PlannedPizzaWidget(plannedPizzas[i]) child: PlannedPizzaWidget(plannedPizzas[i])
); );
@ -48,12 +48,22 @@ class PlannedPizzaWidget extends StatelessWidget {
return Container( return Container(
height: 100, height: 100,
color: Colors.blueAccent, color: Colors.blueAccent,
child: Column( child: Container(
children: <Widget>[ padding: const EdgeInsets.all(8),
Text(plannedPizza.name), child: Column(
Text(dateFormatter.format(plannedPizza.dateTime)), mainAxisAlignment: MainAxisAlignment.spaceBetween,
Text(this.getTimeRemainingString()) children: <Widget>[
] Row(
mainAxisAlignment: MainAxisAlignment.spaceBetween,
children: <Widget>[
Text(plannedPizza.name),
Text(this.getTimeRemainingString())
],
),
Text(dateFormatter.format(plannedPizza.dateTime)),
]
)
) )
); );
} }
@ -61,15 +71,20 @@ class PlannedPizzaWidget extends StatelessWidget {
String getTimeRemainingString(){ String getTimeRemainingString(){
DateTime now = DateTime.now(); DateTime now = DateTime.now();
Duration duration = plannedPizza.dateTime.difference(now); Duration duration = plannedPizza.dateTime.difference(now);
if (duration.inHours <= 0) { Duration absDuration = duration.abs();
return "In ${duration.inMinutes} minutes!"; String durationString = "";
if (absDuration.inHours <= 0 && absDuration.inMinutes > 0) {
durationString = "${absDuration.inMinutes} minute" + (absDuration.inMinutes > 1 ? "s" : "");
} }
if (duration.inDays <= 0) { else if (absDuration.inDays <= 0 && absDuration.inHours > 0) {
return "In ${duration.inHours} hours"; durationString = "${absDuration.inHours} hours";
} }
if (duration.inDays <= 31) { else if (absDuration.inDays <= 31) {
return "In ${duration.inDays} days"; durationString = "${absDuration.inDays} day" + (absDuration.inDays > 1 ? "s" : "");
} }
return "In ${(duration.inDays / 7).floor()} weeks"; else {
durationString = "${(absDuration.inDays / 7).floor()} week" + (absDuration.inDays >= 14 ? "s" : "");
}
return duration.isNegative ? "$durationString ago" : "In $durationString";
} }
} }