fixed up the layout of the PlannedPizzaWidget
This commit is contained in:
parent
fa3142d666
commit
0f656dfa05
1 changed files with 29 additions and 14 deletions
|
@ -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";
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Add table
Reference in a new issue