import 'package:cloud_firestore/cloud_firestore.dart';
import 'package:firebase_auth/firebase_auth.dart';
import 'package:flutter/material.dart';
import 'package:flutter_application_1/Project/NavigationBar.dart';
import 'package:flutter_application_1/Project/utils/utils.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
class TopContainer extends StatelessWidget {
final String title;
final String searchBarTitle;
const TopContainer(
{Key? key, required this.title, required this.searchBarTitle})
: super(key: key);
@override
Widget build(BuildContext context) {
return StreamBuilder<DocumentSnapshot>(
stream: FirebaseFirestore.instance
.collection('users')
.doc(FirebaseAuth.instance.currentUser!.uid)
.snapshots(),
builder:
(BuildContext context, AsyncSnapshot<DocumentSnapshot> snapshot) {
if (!snapshot.hasData) {
return const Center(child: CircularProgressIndicator());
}
final user = snapshot.data!.data() as Map<String, dynamic>;
final imageUrl = user['image_url'] as String?;
return Column(
children: [
//title
Row(
children: [
Text(
title,
style: kNormalStyle.copyWith(
fontSize: 23,
fontWeight: FontWeight.w600,
),
),
const Spacer(),
Container(
height: 40,
width: 40,
alignment: Alignment.center,
),
const SizedBox(
width: 10,
),
ClipRRect(
borderRadius: BorderRadius.circular(30),
child: imageUrl != null
? Image.network(
imageUrl,
height: 50,
width: 50,
fit: BoxFit.cover,
)
: Container(
height: 50,
width: 50,
color: Colors.grey[300],
),
),
],
),
//search bar
InkWell(
onTap: () {
Navigator.pushReplacement(
context,
MaterialPageRoute(
builder: (context) => const MyBottomNavigationBar(
getIndex: 1,
),
),
);
},
child: Container(
margin: const EdgeInsets.symmetric(vertical: 15),
padding: const EdgeInsets.all(15),
decoration: BoxDecoration(
color: Colors.grey[200],
borderRadius: BorderRadius.circular(30),
),
child: Row(
children: [
const Icon(
FontAwesomeIcons.magnifyingGlass,
size: 20,
),
const SizedBox(
width: 10,
),
Text(
searchBarTitle,
style: const TextStyle(
color: Colors.black38,
fontWeight: FontWeight.w400,
),
),
],
),
),
)
],
);
},
);
}
}