Files
fcs/lib/pages/pickup/pickup_list_row.dart

91 lines
3.1 KiB
Dart
Raw Normal View History

2021-10-09 17:08:28 +06:30
import 'package:fcs/domain/entities/pickup.dart';
2021-09-13 17:36:52 +06:30
import 'package:fcs/helpers/theme.dart';
import 'package:fcs/pages/main/util.dart';
import 'package:fcs/pages/pickup/pickup_info.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:flutter_vector_icons/flutter_vector_icons.dart';
import 'package:intl/intl.dart';
2021-10-09 17:08:28 +06:30
typedef CallbackPickupSelect(Pickup pickup);
2021-09-13 17:36:52 +06:30
class PickupListRow extends StatelessWidget {
2021-10-09 17:08:28 +06:30
final Pickup? pickup;
final CallbackPickupSelect? callbackPickupSelect;
2021-09-13 17:36:52 +06:30
final double dotSize = 15.0;
final DateFormat dateFormat = new DateFormat("dd MMM yyyy");
2021-10-09 17:08:28 +06:30
PickupListRow({Key? key, this.pickup, this.callbackPickupSelect})
2021-09-13 17:36:52 +06:30
: super(key: key);
@override
Widget build(BuildContext context) {
return InkWell(
onTap: () {
2021-10-09 17:08:28 +06:30
if (callbackPickupSelect != null) {
callbackPickupSelect!(pickup!);
2021-09-13 17:36:52 +06:30
return;
}
Navigator.push(
context,
2021-10-09 17:08:28 +06:30
CupertinoPageRoute(builder: (context) => PickupInfo(pickup: pickup!)),
2021-09-13 17:36:52 +06:30
);
},
child: Container(
padding: EdgeInsets.only(left: 15, right: 15),
child: Row(
children: <Widget>[
Expanded(
child: new Padding(
padding: const EdgeInsets.symmetric(vertical: 16.0),
child: new Row(
children: <Widget>[
Container(
padding: EdgeInsets.only(left: 5, right: 10),
child: Icon(
SimpleLineIcons.direction,
color: primaryColor,
size: 30,
),
),
new Expanded(
child: new Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: <Widget>[
Padding(
padding: const EdgeInsets.only(left: 8.0),
child: new Text(
2021-10-09 17:08:28 +06:30
pickup?.pickupNumber ?? '',
2021-09-13 17:36:52 +06:30
style: new TextStyle(
fontSize: 15.0, color: Colors.black),
),
),
Padding(
2021-10-09 17:08:28 +06:30
padding: const EdgeInsets.only(left: 10.0, top: 10),
2021-09-13 17:36:52 +06:30
child: new Text(
2021-10-09 17:08:28 +06:30
pickup!.pickupDate != null
? dateFormat.format(pickup!.pickupDate!)
: "",
2021-09-13 17:36:52 +06:30
style: new TextStyle(
2021-10-09 17:08:28 +06:30
fontSize: 15.0, color: Colors.grey),
2021-09-13 17:36:52 +06:30
),
2021-10-09 17:08:28 +06:30
)
2021-09-13 17:36:52 +06:30
],
),
),
],
),
),
),
Column(
children: <Widget>[
2021-10-09 17:08:28 +06:30
getStatus(pickup!.status ?? ""),
2021-09-13 17:36:52 +06:30
],
)
],
),
),
);
}
}