Files
FikaAndFocus/fika_and_fokus/lib/CafePage.dart
2022-05-26 13:22:35 +02:00

300 lines
12 KiB
Dart

import 'package:fika_and_fokus/GoogleMapNavigationButton.dart';
import 'package:flutter/material.dart';
import 'package:flutter_rating_bar/flutter_rating_bar.dart';
import 'package:google_fonts/google_fonts.dart';
import 'package:http/http.dart' as http;
import 'dart:convert';
import 'CafeItemModel.dart';
import 'GoogleMapMarkerInfoWindow.dart';
import 'Heart.dart';
import 'ReviewPage.dart';
import 'UserModel.dart';
class CafePage extends StatefulWidget {
final CafeItem cafeItem;
UserModel user = new UserModel(userName: "default", email: "", password: "");
CafePage(this.cafeItem, this.user, {Key? key}) : super(key: key);
@override
State<CafePage> createState() => _CafePageState();
}
class _CafePageState extends State<CafePage> {
var reviews = [];
@override
void initState() {
refreshReviews();
super.initState();
}
@override
Widget build(BuildContext context) {
final price = widget.cafeItem.buildPrice(context).data;
return Scaffold(
backgroundColor: Color(0xFFE0DBCF),
body: SafeArea(
child: Expanded(
child: RefreshIndicator(
onRefresh: refreshReviews,
child: CustomScrollView(slivers: [
SliverAppBar(
expandedHeight: 300,
backgroundColor: Color(0xFF75AB98),
floating: true,
pinned: true,
flexibleSpace: FlexibleSpaceBar(
centerTitle: true,
title: Text(
widget.cafeItem.name,
style: GoogleFonts.oswald(
color: Color(0xFFFFFFFF), fontWeight: FontWeight.w300),
),
background: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: const [
CircleAvatar(
radius: 100,
backgroundImage: AssetImage("images/test_cafe.jpg"))
],
),
),
),
SliverToBoxAdapter(
child: Padding(
padding: const EdgeInsets.all(10),
child: Column(
crossAxisAlignment: CrossAxisAlignment.center,
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: <Widget>[
Container(
margin: const EdgeInsets.fromLTRB(20, 5, 20, 5),
child: IntrinsicHeight(
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
widget.cafeItem.address,
textAlign: TextAlign.center,
style: GoogleFonts.oswald(
fontSize: 16,
letterSpacing: 0.6,
color: Color(0xFF696969),
fontWeight: FontWeight.w300),
),
],
),
),
),
Container(
margin: const EdgeInsets.fromLTRB(20, 10, 20, 10),
decoration: BoxDecoration(
color: Color(0x22696969),
borderRadius: BorderRadius.circular(30),
),
child: IntrinsicHeight(
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
widget.cafeItem.rating.toString(),
textAlign: TextAlign.center,
style: GoogleFonts.roboto(
fontSize: 25,
color: Colors.white,
fontWeight: FontWeight.normal),
),
const Icon(
Icons.star,
color: Colors.white,
size: 25,
),
const VerticalDivider(
width: 20,
indent: 20,
endIndent: 20,
thickness: 1,
color: Color(0xFF696969)),
Text(
price!,
style: GoogleFonts.roboto(
fontSize: 25,
color: Colors.white,
fontWeight: FontWeight.normal),
),
const VerticalDivider(
width: 20,
indent: 20,
endIndent: 20,
thickness: 1,
color: Color(0xFF696969)),
Transform.scale(
scale: 0.6,
child: WalkButton(currentCafe: widget.cafeItem),
),
const VerticalDivider(
width: 20,
indent: 20,
endIndent: 20,
thickness: 1,
color: Color(0xFF696969)),
Transform.scale(
scale: 0.6,
child: Heart(
currentCafe: widget.cafeItem,
user: widget.user)),
],
),
),
),
],
),
),
),
SliverToBoxAdapter(
child: Column(
children: [
Row(mainAxisAlignment: MainAxisAlignment.center, children: [
ElevatedButton(
onPressed: () {
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => ReviewPage(
widget.cafeItem, widget.user)));
},
child: Text(
'POST A REVIEW',
style: GoogleFonts.oswald(
color: Color(0xFFFFFFFF),
fontSize: 18,
fontWeight: FontWeight.normal),
),
style: ElevatedButton.styleFrom(
primary: Color(0xFF696969),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(30),
),
),
),
]),
],
),
),
// sliver items 2
SliverList(
// itemCount: reviews.length, //attribute from Listview
delegate: SliverChildBuilderDelegate(
(BuildContext context, int index) {
return Container(
decoration: const BoxDecoration(
// borderRadius: BorderRadius.only(
// topLeft: Radius.circular(20),
// topRight: Radius.circular(20)),
color: Color(0xFFE0DBCF),
// .all(Radius.circular(20))
),
child: Padding(
padding: const EdgeInsets.all(10),
child: Container(
margin: const EdgeInsets.all(5),
//height: 100,
decoration: _getBoxStyle(),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: <Widget>[
ListTile(
//style: GoogleFonts.roboto(fontWeight: FontWeight.w300),
leading: const CircleAvatar(
radius: 10,
// backgroundImage: NetworkImage(user.photoURL!.replaceAll("s96-c", "s192-c")),
backgroundImage:
AssetImage('images/profile_picture.png'),
),
title: reviews[index].buildUser(context),
trailing: reviews[index].buildDate(context),
),
Container(
margin: const EdgeInsets.fromLTRB(20, 0, 20, 0),
child: RatingBarIndicator(
rating: reviews[index].buildRating(context),
direction: Axis.horizontal,
itemCount: 5,
itemSize: 10.0,
itemPadding:
const EdgeInsets.fromLTRB(0, 0, 4, 5),
itemBuilder: (context, _) => const Icon(
Icons.star,
color: Colors.amber,
),
),
),
Container(
margin:
const EdgeInsets.fromLTRB(20, 0, 20, 20),
child: reviews[index].buildReview(context),
),
],
),
),
),
);
// childCount: reviews.length),
},
childCount: reviews.length,
),
)
]),
),
),
),
);
}
Future refreshReviews() async {
// Uri reviewsURI = Uri.parse('https://group-1-75.pvt.dsv.su.se/fikafocus-0.0.1-SNAPSHOT/cafes/ven_304c56776d34454959414e52593058646156516e6158614a496843/all');
Uri reviewsURI = Uri.parse(
'https://group-1-75.pvt.dsv.su.se/fikafocus-0.0.1-SNAPSHOT/cafes/${widget.cafeItem.id}/all');
final response = await http.get(reviewsURI);
if (response.statusCode == 200) {
String source = const Utf8Decoder().convert(response.bodyBytes);
var data = json.decode(source);
reviews = [];
var _reviewsTemp = [];
for (var i = 0; i < data.length; i++) {
_reviewsTemp.add(Review.fromJson(data[i]));
}
_reviewsTemp.sort((a, b) => (b.id) - (a.id));
setState(() {
reviews = _reviewsTemp;
});
} else {
throw Exception('Failed to load reviews');
}
}
BoxDecoration _getBoxStyle() {
return BoxDecoration(
color: Colors.white,
// border: Border.all(color: Colors.black),
borderRadius: const BorderRadius.all(Radius.circular(20)),
boxShadow: [
BoxShadow(
color: Colors.grey.withOpacity(0.5),
spreadRadius: 5,
blurRadius: 7,
offset: const Offset(2, 3))
]);
}
}