Merge remote-tracking branch 'upstream/master'

This commit is contained in:
PhyoThandar
2020-06-02 14:59:05 +06:30
5 changed files with 297 additions and 48 deletions

View File

@@ -1,5 +1,7 @@
import 'package:fcs/model/shipment_model.dart'; import 'package:fcs/model/shipment_model.dart';
import 'package:fcs/model_fcs/message_model.dart';
import 'package:fcs/model_fcs/package_model.dart'; import 'package:fcs/model_fcs/package_model.dart';
import 'package:fcs/vo/message.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_localizations/flutter_localizations.dart'; import 'package:flutter_localizations/flutter_localizations.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
@@ -68,7 +70,8 @@ class _AppState extends State<App> {
final PickUpModel pickUpModel = new PickUpModel(); final PickUpModel pickUpModel = new PickUpModel();
final ShipmentRateModel shipmentRateModel = new ShipmentRateModel(); final ShipmentRateModel shipmentRateModel = new ShipmentRateModel();
final ShipmentModel shipmentModel = new ShipmentModel(); final ShipmentModel shipmentModel = new ShipmentModel();
final PackageModel packageModel = new PackageModel(); final PackageModel packageModel=new PackageModel();
final MessageModel messageModel=new MessageModel();
final InvoiceModel invoiceModel = new InvoiceModel(); final InvoiceModel invoiceModel = new InvoiceModel();
final CustomerModel customerModel = new CustomerModel(); final CustomerModel customerModel = new CustomerModel();
@@ -105,6 +108,7 @@ class _AppState extends State<App> {
..addModel(shipmentRateModel) ..addModel(shipmentRateModel)
..addModel(shipmentModel) ..addModel(shipmentModel)
..addModel(packageModel) ..addModel(packageModel)
..addModel(messageModel)
..addModel(shipmentRateModel) ..addModel(shipmentRateModel)
..addModel(invoiceModel) ..addModel(invoiceModel)
..addModel(customerModel); ..addModel(customerModel);
@@ -160,6 +164,7 @@ class _AppState extends State<App> {
ChangeNotifierProvider(builder: (context) => shipmentRateModel), ChangeNotifierProvider(builder: (context) => shipmentRateModel),
ChangeNotifierProvider(builder: (context) => shipmentModel), ChangeNotifierProvider(builder: (context) => shipmentModel),
ChangeNotifierProvider(builder: (context) => packageModel), ChangeNotifierProvider(builder: (context) => packageModel),
ChangeNotifierProvider(builder: (context) => messageModel),
ChangeNotifierProvider(builder: (context) => invoiceModel), ChangeNotifierProvider(builder: (context) => invoiceModel),
ChangeNotifierProvider(builder: (context) => customerModel), ChangeNotifierProvider(builder: (context) => customerModel),
ChangeNotifierProvider( ChangeNotifierProvider(

View File

@@ -0,0 +1,101 @@
import 'dart:async';
import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:fcs/model/base_model.dart';
import 'package:fcs/vo/message.dart';
import 'package:fcs/vo/package.dart';
import 'package:logging/logging.dart';
class MessageModel extends BaseModel {
final log = Logger('MessageModel');
StreamSubscription<QuerySnapshot> listener;
List<Message> messages = [
Message(
senderName: "FCS System",
receiverName: "Online Buyer",
date: DateTime(2020, 6, 1, 1, 1, 1),
message:
"Hi Online Buyer, we received your goods. Please see in 'A202-3 #1'",
),
Message(
senderName: "FCS System",
receiverName: "Online Buyer",
date: DateTime(2020, 6, 1, 1, 5, 1),
message: "Thank you. Will see the photos and check.",
isMe: false),
Message(
senderName: "FCS System",
receiverName: "Online Buyer",
date: DateTime(2020, 6, 1, 2, 1, 1),
message:
"Hi Online Buyer, we successfully processed your goods and ready for payment. Please see in 'INV202005010387'",
),
Message(
senderName: "FCS System",
receiverName: "Online Buyer",
date: DateTime(2020, 6, 1, 2, 10, 1),
message:
"Hi Online Buyer, we have confirmed your payment and ready to ship your packages.",
),
Message(
senderName: "FCS System",
receiverName: "Shipper",
date: DateTime(2020, 6, 1, 1, 1, 1),
message:
"Hi Online Buyer, we received your goods. Please see in 'A202-3 #1'",
),
Message(
senderName: "FCS System",
receiverName: "Shipper",
date: DateTime(2020, 6, 1, 2, 1, 1),
message:
"Hi Online Buyer, we successfully processed your goods and ready for payment. Please see in 'INV202005010387'",
),
Message(
senderName: "FCS System",
receiverName: "Shipper",
date: DateTime(2020, 6, 1, 2, 10, 1),
message:
"Hi Online Buyer, we have confirmed your payment and ready to ship your packages.",
),
];
List<Message> get lastMessage {
return [messages[2], messages[5]];
}
List<Message> getMessage(String receiver) {
return messages.where((e) => e.receiverName == receiver).toList();
}
// List<Package> get completed {
// return packages.where((e) => e.status == "Delivered").toList()
// ..sort((e1, e2) {
// return e2.packageNumber.compareTo(e1.packageNumber);
// });
// }
// List<Package> get upcoming {
// return packages
// .where((e) =>
// e.status == "Processing" ||
// e.status == "Received" ||
// e.status == "Ready to ship")
// .toList()
// ..sort((e1, e2) {
// return e2.packageNumber.compareTo(e1.packageNumber);
// });
// }
void initUser(user) {
super.initUser(user);
}
@override
logout() async {
if (listener != null) await listener.cancel();
messages = [];
}
}

View File

@@ -0,0 +1,140 @@
import 'package:fcs/model_fcs/message_model.dart';
import 'package:fcs/theme/theme.dart';
import 'package:fcs/vo/message.dart';
import 'package:flutter/material.dart';
import 'package:intl/intl.dart';
import 'package:provider/provider.dart';
class Bubble extends StatelessWidget {
Bubble({this.message, this.time, this.delivered, this.isMe});
final String message, time;
final delivered, isMe;
@override
Widget build(BuildContext context) {
final bg = isMe ? Colors.white : Colors.greenAccent.shade100;
final align = isMe ? CrossAxisAlignment.start : CrossAxisAlignment.end;
final icon = delivered ? Icons.done_all : Icons.done;
final radius = isMe
? BorderRadius.only(
topRight: Radius.circular(5.0),
bottomLeft: Radius.circular(10.0),
bottomRight: Radius.circular(5.0),
)
: BorderRadius.only(
topLeft: Radius.circular(5.0),
bottomLeft: Radius.circular(5.0),
bottomRight: Radius.circular(10.0),
);
return Column(
crossAxisAlignment: align,
children: <Widget>[
Container(
margin: const EdgeInsets.all(3.0),
padding: const EdgeInsets.all(8.0),
decoration: BoxDecoration(
boxShadow: [
BoxShadow(
blurRadius: .5,
spreadRadius: 1.0,
color: Colors.black.withOpacity(.12))
],
color: bg,
borderRadius: radius,
),
child: Stack(
children: <Widget>[
Padding(
padding: EdgeInsets.only(right: 48.0),
child: Text(message),
),
Positioned(
bottom: 0.0,
right: 0.0,
child: Row(
children: <Widget>[
Text(time,
style: TextStyle(
color: Colors.black38,
fontSize: 10.0,
)),
SizedBox(width: 3.0),
Icon(
icon,
size: 12.0,
color: Colors.black38,
)
],
),
)
],
),
)
],
);
}
}
class MessageDetail extends StatelessWidget {
final Message msg;
const MessageDetail({Key key, this.msg}) : super(key: key);
@override
Widget build(BuildContext context) {
DateFormat dateFormat=DateFormat("HH:mm");
MessageModel messageModel = Provider.of<MessageModel>(context);
List<Message> messages = messageModel.getMessage(msg.receiverName);
List<Bubble> bubbles = messages
.map((e) => Bubble(
message: e.message,
time: dateFormat.format(e.date),
delivered: true,
isMe: e.isMe != null ? e.isMe : true))
.toList();
return Scaffold(
appBar: AppBar(
backgroundColor: primaryColor,
elevation: .9,
title: Text(
msg.receiverName,
),
actions: <Widget>[],
),
body: Padding(
padding: EdgeInsets.all(16.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.stretch,
children: bubbles,
// children: <Widget>[
// Bubble(
// message: 'Hi there, this is a message',
// time: '12:00',
// delivered: true,
// isMe: false,
// ),
// Bubble(
// message: 'Whatsapp like bubble talk',
// time: '12:01',
// delivered: true,
// isMe: true,
// ),
// Bubble(
// message: 'Nice one, Flutter is awesome',
// time: '12:00',
// delivered: true,
// isMe: true,
// ),
// Bubble(
// message: 'I\'ve told you so dude!',
// time: '12:00',
// delivered: true,
// isMe: false,
// ),
// ],
),
),
);
}
}

View File

@@ -1,3 +1,7 @@
import 'package:fcs/model_fcs/message_model.dart';
import 'package:fcs/pages/message_detail.dart';
import 'package:fcs/vo/message.dart';
import 'package:fcs/widget/bottom_up_page_route.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:intl/intl.dart'; import 'package:intl/intl.dart';
import 'package:provider/provider.dart'; import 'package:provider/provider.dart';
@@ -16,15 +20,14 @@ class NotificationList extends StatefulWidget {
class _NotificationListState extends State<NotificationList> { class _NotificationListState extends State<NotificationList> {
var timeFormatter = new DateFormat('KK:mm a'); var timeFormatter = new DateFormat('KK:mm a');
var dateFormatter = new DateFormat('dd MMM yyyy'); var dateFormatter = new DateFormat('dd MMM yyyy');
final double dotSize = 15.0; final double dotSize = 25.0;
int _selectedIndex = 0; int _selectedIndex = 0;
bool _isLoading = false; bool _isLoading = false;
bool _isClicked = false; bool _isClicked = false;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
NotificationModel notificationModel = MessageModel messageModel = Provider.of<MessageModel>(context);
Provider.of<NotificationModel>(context);
return LocalProgress( return LocalProgress(
inAsyncCall: _isLoading, inAsyncCall: _isLoading,
@@ -40,7 +43,7 @@ class _NotificationListState extends State<NotificationList> {
backgroundColor: primaryColor, backgroundColor: primaryColor,
title: LocalText( title: LocalText(
context, context,
'noti.list.title', 'message.title',
fontSize: 20, fontSize: 20,
color: Colors.white, color: Colors.white,
), ),
@@ -50,15 +53,15 @@ class _NotificationListState extends State<NotificationList> {
color: Colors.black, color: Colors.black,
), ),
scrollDirection: Axis.vertical, scrollDirection: Axis.vertical,
padding: EdgeInsets.only(left: 15, right: 15, top: 15), padding: EdgeInsets.only(top: 5),
shrinkWrap: true, shrinkWrap: true,
itemCount: notificationModel.notifications.length, itemCount: messageModel.lastMessage.length,
itemBuilder: (BuildContext context, int index) { itemBuilder: (BuildContext context, int index) {
Noti.Notification noti = notificationModel.notifications[index]; Message msg = messageModel.lastMessage[index];
return Stack( return Stack(
children: <Widget>[ children: <Widget>[
InkWell( InkWell(
onTap: () => _display(noti), onTap: () => _display(msg),
child: Row( child: Row(
children: <Widget>[ children: <Widget>[
Expanded( Expanded(
@@ -68,8 +71,12 @@ class _NotificationListState extends State<NotificationList> {
children: <Widget>[ children: <Widget>[
new Padding( new Padding(
padding: new EdgeInsets.symmetric( padding: new EdgeInsets.symmetric(
horizontal: 32.0 - dotSize / 2), horizontal: 22.0 - dotSize / 2),
child: Icon(Icons.message,color: primaryColor,), child: Icon(
Icons.account_circle,
color: primaryColor,
size: 60,
),
), ),
new Expanded( new Expanded(
child: new Column( child: new Column(
@@ -77,35 +84,11 @@ class _NotificationListState extends State<NotificationList> {
CrossAxisAlignment.start, CrossAxisAlignment.start,
children: <Widget>[ children: <Widget>[
new Text( new Text(
noti.getDesc, msg.receiverName,
style: new TextStyle( style: new TextStyle(
fontSize: 15.0, fontSize: 15.0,
color: primaryColor), color: primaryColor),
), ),
noti.marketPlace == null
? Container()
: Padding(
padding: const EdgeInsets.only(
top: 8.0),
child: new Text(
noti.marketPlace,
style: new TextStyle(
fontSize: 15.0,
color: primaryColor),
),
),
Padding(
padding:
const EdgeInsets.only(top: 8.0),
child: new Text(
noti.status == null
? ""
: noti.status,
style: new TextStyle(
fontSize: 15.0,
color: Colors.grey),
),
),
], ],
), ),
), ),
@@ -113,17 +96,20 @@ class _NotificationListState extends State<NotificationList> {
), ),
), ),
), ),
Column( Padding(
mainAxisAlignment: MainAxisAlignment.center, padding: const EdgeInsets.only(right: 18.0),
children: <Widget>[ child: Column(
Padding( mainAxisAlignment: MainAxisAlignment.center,
padding: const EdgeInsets.all(8.0), children: <Widget>[
child: Text(timeFormatter.format(noti.time)), Padding(
), padding: const EdgeInsets.all(8.0),
noti.fromToday() child: Text(timeFormatter.format(msg.date)),
? Container() ),
: Text(dateFormatter.format(noti.time)), msg.fromToday()
], ? Container()
: Text(dateFormatter.format(msg.date)),
],
),
) )
], ],
), ),
@@ -135,5 +121,8 @@ class _NotificationListState extends State<NotificationList> {
); );
} }
_display(Noti.Notification noti) {} _display(Message msg) {
Navigator.push(context, BottomUpPageRoute(MessageDetail(msg:msg))
);
}
} }

14
lib/vo/message.dart Normal file
View File

@@ -0,0 +1,14 @@
class Message {
String receiverName;
String message;
DateTime date;
String senderName;
bool isMe;
Message({this.receiverName, this.message, this.date, this.senderName,this.isMe});
bool fromToday() {
var now = DateTime.now();
return date.day == now.day &&
date.month == now.month &&
date.year == now.year;
}
}