You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

150 lines
5.6 KiB

3 years ago
import 'package:cached_network_image/cached_network_image.dart';
import 'package:teso/Classes/inbox.dart';
import 'package:flutter/material.dart';
import 'package:time_elapsed/time_elapsed.dart';
import 'package:teso/util/consts.dart';
buildInboxTile(BuildContext context, InboxMessage message, bool read) {
return Container(
width: MediaQuery.of(context).size.width,
height: 80,
child: Row(
children: [
Container(
margin: EdgeInsets.symmetric(horizontal: 10),
height: 50.0,
width: 50.0,
decoration: new BoxDecoration(
shape: BoxShape.circle,
),
child: ClipRRect(
borderRadius: BorderRadius.circular(30.0),
child: message.thumbnail == null
? Center(
child: Text(
message.firstname!.characters
3 years ago
.characterAt(0)
.toString()
.toUpperCase(),
),
)
: CachedNetworkImage(
imageUrl: userdpURL + message.thumbnail!,
3 years ago
imageBuilder: (context, imageProvider) => FadeInImage(
height: 90,
width: 90,
fit: BoxFit.fill,
image: imageProvider,
placeholder: AssetImage("assets/images/tesoDP/dp1.png"),
),
),
),
),
Container(
width: MediaQuery.of(context).size.width - 80,
margin: EdgeInsets.only(
top: 10,
),
child: Column(
children: [
Row(
children: [
Column(
children: [
Container(
width: MediaQuery.of(context).size.width -
(MediaQuery.of(context).size.width * 0.35),
height: 30,
child: Container(
width: double.infinity,
height: double.infinity,
child: Align(
alignment: Alignment.centerLeft,
child: Text(
message.firstname! + " " + message.surname!,
3 years ago
style: TextStyle(
fontSize: 12.5,
color: Theme.of(context).primaryColorLight,
fontWeight: FontWeight.bold,
),
textAlign: TextAlign.left,
),
),
),
),
Container(
width: MediaQuery.of(context).size.width -
(MediaQuery.of(context).size.width * 0.35),
child: Text(
message.message!.length > 73
? message.message!.substring(0, 73).toString() +
3 years ago
"...."
: message.message!,
3 years ago
textAlign: TextAlign.left,
style: TextStyle(
fontSize: 11,
),
),
),
],
),
Visibility(
visible: !read,
child: Container(
child: Column(
children: [
Container(
width: 30,
height: 30,
// padding: EdgeInsets.symmetric(horizontal: 20.0),
child: Center(
child: Text(
TimeElapsed.fromDateTime(message.timestamp!),
3 years ago
style: TextStyle(
color:
Theme.of(context).colorScheme.secondary,
),
),
),
),
Material(
color: Colors.grey[300],
elevation: 10.0,
borderRadius: BorderRadius.circular(30.0),
shadowColor: Colors.grey,
child: Container(
width: 10,
height: 10,
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(30.0),
color: Theme.of(context).colorScheme.secondary,
),
// padding: EdgeInsets.symmetric(horizontal: 20.0),
),
),
],
),
),
),
Visibility(
visible: read,
child: Container(
height: 30,
child: Center(
child: Text(
TimeElapsed.fromDateTime(message.timestamp!),
3 years ago
),
),
),
),
],
),
Divider(),
],
),
),
],
),
);
}