BottomModalSheet & Venue details #53
@ -1,5 +1,7 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:geolocator/geolocator.dart';
|
||||||
import 'package:google_fonts/google_fonts.dart';
|
import 'package:google_fonts/google_fonts.dart';
|
||||||
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
|
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
import 'package:flutter_applicationdemo/Venue.dart';
|
import 'package:flutter_applicationdemo/Venue.dart';
|
||||||
@ -20,7 +22,7 @@ class _ListViewPageState extends State<ListViewPage> {
|
|||||||
return Scaffold(
|
return Scaffold(
|
||||||
appBar: AppBar(
|
appBar: AppBar(
|
||||||
title: const Text('Venues near you',),
|
title: const Text('Venues near you',),
|
||||||
backgroundColor: globals.BACKGROUNDCOLOR,
|
backgroundColor: globals.BACKGROUNDCOLOR,
|
||||||
),
|
),
|
||||||
body: buildListView(),
|
body: buildListView(),
|
||||||
);
|
);
|
||||||
@ -32,13 +34,13 @@ class _ListViewPageState extends State<ListViewPage> {
|
|||||||
itemCount: allVenues.length,
|
itemCount: allVenues.length,
|
||||||
itemBuilder: (context, index) {
|
itemBuilder: (context, index) {
|
||||||
return ListTile(
|
return ListTile(
|
||||||
shape: buildBorder(),
|
shape: buildBorder(),
|
||||||
onTap: () => _navigateToVenue(allVenues[index]),
|
onTap: () => _navigateToVenue(allVenues[index]),
|
||||||
leading: buildIconBox(index, context),
|
leading: buildIconBox(index, context),
|
||||||
title: buildTitleText(index),
|
title: buildTitleText(index),
|
||||||
subtitle: buildWeatherRow(),
|
subtitle: buildWeatherRow(),
|
||||||
|
|
||||||
trailing: const Text('400m'),
|
// trailing: const Text('400m'),
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
@ -46,43 +48,45 @@ class _ListViewPageState extends State<ListViewPage> {
|
|||||||
|
|
||||||
RoundedRectangleBorder buildBorder() {
|
RoundedRectangleBorder buildBorder() {
|
||||||
return RoundedRectangleBorder(
|
return RoundedRectangleBorder(
|
||||||
side: const BorderSide(color: Color(0xffe9e9e9), width: 1),
|
side: const BorderSide(color: Color(0xffe9e9e9), width: 1),
|
||||||
borderRadius: BorderRadius.circular(5));
|
borderRadius: BorderRadius.circular(5));
|
||||||
}
|
}
|
||||||
|
|
||||||
SizedBox buildIconBox(int index, BuildContext context) {
|
SizedBox buildIconBox(int index, BuildContext context) {
|
||||||
return SizedBox(
|
return SizedBox(
|
||||||
height: double.infinity,
|
height: double.infinity,
|
||||||
child: allVenues[index].getIcon(context),
|
child: allVenues[index].getIcon(context),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
Row buildWeatherRow() {
|
Row buildWeatherRow() {
|
||||||
return Row(
|
return Row(
|
||||||
children: [
|
children: [
|
||||||
const Text('Current weather: '),
|
const Text('Current weather: '),
|
||||||
const Spacer(
|
const Spacer(
|
||||||
flex: 2,
|
flex: 2,
|
||||||
),
|
),
|
||||||
globals.forecast.getCurrentWeatherIcon(),
|
globals.forecast.getCurrentWeatherIcon(),
|
||||||
const Spacer(),
|
const Spacer(),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
Text buildTitleText(int index) {
|
Text buildTitleText(int index) {
|
||||||
return Text(
|
return Text(
|
||||||
allVenues[index].venueName.toString(),
|
allVenues[index].venueName.toString(),
|
||||||
style: GoogleFonts.roboto(
|
style: GoogleFonts.roboto(
|
||||||
textStyle: const TextStyle(
|
textStyle: const TextStyle(
|
||||||
fontSize: 18,
|
fontSize: 18,
|
||||||
color: Color(0xff994411),
|
color: Color(0xff994411),
|
||||||
)),
|
)),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _navigateToVenue(Venue venue) {
|
void _navigateToVenue(Venue venue) {
|
||||||
Navigator.of(context)
|
Navigator.of(context)
|
||||||
.push(MaterialPageRoute(builder: (context) => VenuePage(venue)));
|
.push(MaterialPageRoute(builder: (context) => VenuePage(venue)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
401
lib/Map.dart
401
lib/Map.dart
@ -106,18 +106,18 @@ class MapState extends State<Map> {
|
|||||||
color: Colors.white,
|
color: Colors.white,
|
||||||
child: Center(
|
child: Center(
|
||||||
child: Column(
|
child: Column(
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
mainAxisAlignment: MainAxisAlignment.center,
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
/*const Text('BottomSheet'),
|
/*const Text('BottomSheet'),
|
||||||
ElevatedButton(
|
ElevatedButton(
|
||||||
child: const Text('Close BottomSheet'),
|
child: const Text('Close BottomSheet'),
|
||||||
onPressed: () {Navigator.pop(context);})*/
|
onPressed: () {Navigator.pop(context);})*/
|
||||||
Container(
|
Container(
|
||||||
child: Text(webScraper.openingHoursThisWeek.length.toString()),
|
child: Text(webScraper.openingHoursThisWeek.length.toString()),
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
)),
|
)),
|
||||||
);
|
);
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
@ -238,19 +238,19 @@ class MapState extends State<Map> {
|
|||||||
icon: Icon(Icons.filter_list),
|
icon: Icon(Icons.filter_list),
|
||||||
iconSize: 40,
|
iconSize: 40,
|
||||||
itemBuilder: (context) => [
|
itemBuilder: (context) => [
|
||||||
const PopupMenuItem(
|
const PopupMenuItem(
|
||||||
child: Text(
|
child: Text(
|
||||||
"Filters",
|
"Filters",
|
||||||
style: TextStyle(
|
style: TextStyle(
|
||||||
fontSize: 20,
|
fontSize: 20,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
padding: EdgeInsets.only(left: 60),
|
||||||
),
|
),
|
||||||
),
|
createCheckBoxes(),
|
||||||
padding: EdgeInsets.only(left: 60),
|
createPriceSlider(),
|
||||||
),
|
PopupMenuItem(
|
||||||
createCheckBoxes(),
|
child: ButtonBar(
|
||||||
createPriceSlider(),
|
|
||||||
PopupMenuItem(
|
|
||||||
child: ButtonBar(
|
|
||||||
alignment: MainAxisAlignment.center,
|
alignment: MainAxisAlignment.center,
|
||||||
children: [
|
children: [
|
||||||
ElevatedButton(
|
ElevatedButton(
|
||||||
@ -266,7 +266,7 @@ class MapState extends State<Map> {
|
|||||||
),
|
),
|
||||||
],
|
],
|
||||||
))
|
))
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Creates the checkboxes for the filter menu
|
// Creates the checkboxes for the filter menu
|
||||||
@ -282,46 +282,46 @@ class MapState extends State<Map> {
|
|||||||
),
|
),
|
||||||
StatefulBuilder(
|
StatefulBuilder(
|
||||||
builder: (BuildContext context, StateSetter setState) {
|
builder: (BuildContext context, StateSetter setState) {
|
||||||
return CheckboxListTile(
|
return CheckboxListTile(
|
||||||
value: _barFilterValue,
|
value: _barFilterValue,
|
||||||
onChanged: (bool? newValue) {
|
onChanged: (bool? newValue) {
|
||||||
setState(() {
|
setState(() {
|
||||||
_barFilterValue = newValue;
|
_barFilterValue = newValue;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
title: const Icon(
|
title: const Icon(
|
||||||
Icons.sports_bar,
|
Icons.sports_bar,
|
||||||
color: Colors.orange,
|
color: Colors.orange,
|
||||||
));
|
));
|
||||||
}),
|
}),
|
||||||
StatefulBuilder(
|
StatefulBuilder(
|
||||||
builder: (BuildContext context, StateSetter setState) {
|
builder: (BuildContext context, StateSetter setState) {
|
||||||
return CheckboxListTile(
|
return CheckboxListTile(
|
||||||
value: _restaurantFilterValue,
|
value: _restaurantFilterValue,
|
||||||
onChanged: (bool? newValue) {
|
onChanged: (bool? newValue) {
|
||||||
setState(() {
|
setState(() {
|
||||||
_restaurantFilterValue = newValue;
|
_restaurantFilterValue = newValue;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
title: Icon(
|
title: Icon(
|
||||||
Icons.restaurant,
|
Icons.restaurant,
|
||||||
color: Colors.blueGrey[200],
|
color: Colors.blueGrey[200],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}),
|
}),
|
||||||
//Cafe checkbox
|
//Cafe checkbox
|
||||||
StatefulBuilder(
|
StatefulBuilder(
|
||||||
builder: (BuildContext context, StateSetter setState) {
|
builder: (BuildContext context, StateSetter setState) {
|
||||||
return CheckboxListTile(
|
return CheckboxListTile(
|
||||||
value: _cafeFilterValue,
|
value: _cafeFilterValue,
|
||||||
onChanged: (bool? newValue) {
|
onChanged: (bool? newValue) {
|
||||||
setState(() => _cafeFilterValue = newValue);
|
setState(() => _cafeFilterValue = newValue);
|
||||||
},
|
},
|
||||||
title: Icon(
|
title: Icon(
|
||||||
Icons.coffee,
|
Icons.coffee,
|
||||||
color: Colors.brown[400],
|
color: Colors.brown[400],
|
||||||
));
|
));
|
||||||
}),
|
}),
|
||||||
],
|
],
|
||||||
|
|
||||||
/*floatingActionButton: Padding(
|
/*floatingActionButton: Padding(
|
||||||
@ -347,30 +347,30 @@ class MapState extends State<Map> {
|
|||||||
return PopupMenuItem(
|
return PopupMenuItem(
|
||||||
child: StatefulBuilder(
|
child: StatefulBuilder(
|
||||||
builder: (BuildContext context, StateSetter setState) {
|
builder: (BuildContext context, StateSetter setState) {
|
||||||
return SfSlider(
|
return SfSlider(
|
||||||
value: _priceFilterValue,
|
value: _priceFilterValue,
|
||||||
onChanged: (dynamic newValue) {
|
onChanged: (dynamic newValue) {
|
||||||
setState((() => _priceFilterValue = newValue));
|
setState((() => _priceFilterValue = newValue));
|
||||||
},
|
},
|
||||||
min: 1,
|
min: 1,
|
||||||
max: 3,
|
max: 3,
|
||||||
showTicks: true,
|
showTicks: true,
|
||||||
interval: 1,
|
interval: 1,
|
||||||
activeColor: Colors.blue,
|
activeColor: Colors.blue,
|
||||||
showLabels: true,
|
showLabels: true,
|
||||||
stepSize: 1.0,
|
stepSize: 1.0,
|
||||||
labelFormatterCallback: (dynamic value, String formattedText) {
|
labelFormatterCallback: (dynamic value, String formattedText) {
|
||||||
switch (value) {
|
switch (value) {
|
||||||
case 1:
|
case 1:
|
||||||
return '\$';
|
return '\$';
|
||||||
case 2:
|
case 2:
|
||||||
return '\$\$';
|
return '\$\$';
|
||||||
case 3:
|
case 3:
|
||||||
return '\$\$\$';
|
return '\$\$\$';
|
||||||
}
|
}
|
||||||
return value.toString();
|
return value.toString();
|
||||||
});
|
});
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -380,40 +380,40 @@ class MapState extends State<Map> {
|
|||||||
CameraPosition(target: LatLng(lat, lng), zoom: 15)));
|
CameraPosition(target: LatLng(lat, lng), zoom: 15)));
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _boxes(double lat, double lng, String resturantName) {
|
Widget _boxes(double lat, double lng, String restaurantName) {
|
||||||
return GestureDetector(
|
return GestureDetector(
|
||||||
onTap: () {
|
onTap: () {
|
||||||
_gotoLocation(lat, lng);
|
_gotoLocation(lat, lng);
|
||||||
},
|
},
|
||||||
child: Container(
|
child: Container(
|
||||||
child: FittedBox(
|
child: FittedBox(
|
||||||
child: Material(
|
child: Material(
|
||||||
color: Colors.white,
|
color: Colors.white,
|
||||||
elevation: 14.0,
|
elevation: 14.0,
|
||||||
borderRadius: BorderRadius.circular(24.0),
|
borderRadius: BorderRadius.circular(24.0),
|
||||||
shadowColor: Color(0x802196F3),
|
shadowColor: Color(0x802196F3),
|
||||||
child: Row(
|
child: Row(
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
Container(
|
Container(
|
||||||
width: 250,
|
width: 250,
|
||||||
height: 200,
|
height: 200,
|
||||||
child: ClipRRect(
|
child: ClipRRect(
|
||||||
borderRadius: new BorderRadius.circular(24.0),
|
borderRadius: new BorderRadius.circular(24.0),
|
||||||
child:
|
child:
|
||||||
const Image(image: AssetImage('assets/images/bild.png')),
|
const Image(image: AssetImage('assets/images/bild.png')),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
Container(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Text(resturantName),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
],
|
|
||||||
),
|
),
|
||||||
),
|
Container(
|
||||||
)),
|
child: Padding(
|
||||||
|
padding: const EdgeInsets.all(8.0),
|
||||||
|
child: Text(restaurantName),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
|
)),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -427,8 +427,6 @@ class MapState extends State<Map> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
createBottomDrawer(Venue venue) async {
|
createBottomDrawer(Venue venue) async {
|
||||||
// Position? position = await Geolocator.getLastKnownPosition();
|
|
||||||
// double bar = Geolocator.bearingBetween(position != null? position.latitude : 0, position != null? position.longitude : 0, venue.position.latitude, venue.position.longitude);
|
|
||||||
_bottomSheetIsOpen = true;
|
_bottomSheetIsOpen = true;
|
||||||
Scaffold.of(context).showBottomSheet<void>(((context) {
|
Scaffold.of(context).showBottomSheet<void>(((context) {
|
||||||
return InkWell(
|
return InkWell(
|
||||||
@ -439,48 +437,12 @@ class MapState extends State<Map> {
|
|||||||
);
|
);
|
||||||
},
|
},
|
||||||
child: Container(
|
child: Container(
|
||||||
height: 250,
|
height: 175,
|
||||||
color: const Color(0xFFF5F5F5),
|
color: const Color(0xFFF5F5F5),
|
||||||
child: Center(
|
child: Center(
|
||||||
child: Column(
|
child: Column(
|
||||||
// mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
||||||
children: [
|
children: [
|
||||||
Container(
|
bottomSheetWidgetContainer(venue, context),
|
||||||
margin: const EdgeInsets.all(8),
|
|
||||||
child: Row(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
||||||
// mainAxisSize: MainAxisSize.min,
|
|
||||||
children: <Widget>[
|
|
||||||
columnCoveringNameAndAddress(venue),
|
|
||||||
columnCoveringRating(),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
columnHandlingCloseButton(context),
|
|
||||||
Container(
|
|
||||||
padding: const EdgeInsets.all(16.0),
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
const Text('Weather: \t\t'),
|
|
||||||
globals.forecast.getCurrentWeatherIcon(),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
Text('– ' +
|
|
||||||
globals.forecast.getCurrentWeatherStatus()),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
const Text('Distance:'),
|
|
||||||
],
|
|
||||||
)
|
|
||||||
],
|
|
||||||
),
|
|
||||||
)
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@ -489,7 +451,45 @@ class MapState extends State<Map> {
|
|||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
|
|
||||||
Column columnHandlingCloseButton(BuildContext context) {
|
Container bottomSheetWidgetContainer(Venue venue, BuildContext context) {
|
||||||
|
return Container(
|
||||||
|
margin: const EdgeInsets.all(16),
|
||||||
|
child: Column(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
// mainAxisSize: MainAxisSize.min,
|
||||||
|
children: <Widget>[
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||||
|
children: [
|
||||||
|
Row(
|
||||||
|
children: [
|
||||||
|
columnCoveringNameAndAddress(venue),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
// columnCoveringRating(),
|
||||||
|
Column(
|
||||||
|
children: const [
|
||||||
|
weatherIconRow(),
|
||||||
|
weatherStatusRow(),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
const SizedBox(
|
||||||
|
height: 10,
|
||||||
|
),
|
||||||
|
Row(
|
||||||
|
mainAxisAlignment: MainAxisAlignment.end,
|
||||||
|
children: [
|
||||||
|
columnHandlingReadMoreButton(context, venue),
|
||||||
|
],
|
||||||
|
)
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
Column columnHandlingReadMoreButton(BuildContext context, Venue venue) {
|
||||||
return Column(
|
return Column(
|
||||||
mainAxisSize: MainAxisSize.min,
|
mainAxisSize: MainAxisSize.min,
|
||||||
children: [
|
children: [
|
||||||
@ -498,19 +498,7 @@ class MapState extends State<Map> {
|
|||||||
child: Row(
|
child: Row(
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
mainAxisAlignment: MainAxisAlignment.end,
|
||||||
children: [
|
children: [
|
||||||
ElevatedButton(
|
readMoreButton(context, venue),
|
||||||
child: const Text('Close'),
|
|
||||||
onPressed: () {
|
|
||||||
Navigator.pop(context);
|
|
||||||
_bottomSheetIsOpen = false;
|
|
||||||
}),
|
|
||||||
ElevatedButton(
|
|
||||||
child: const Text('ListView'),
|
|
||||||
onPressed: () {
|
|
||||||
Navigator.push(context,
|
|
||||||
MaterialPageRoute(builder: (context) => ListViewPage()));
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
@ -518,20 +506,20 @@ class MapState extends State<Map> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
Column columnCoveringRating() {
|
ElevatedButton readMoreButton(BuildContext context, Venue venue) {
|
||||||
return Column(
|
return ElevatedButton(
|
||||||
children: [
|
child: const Text(
|
||||||
Text(
|
'Read More',
|
||||||
'Rating',
|
style: TextStyle(fontSize: 18),
|
||||||
style: GoogleFonts.robotoCondensed(
|
),
|
||||||
textStyle: const TextStyle(
|
onPressed: () {
|
||||||
color: Colors.black87,
|
Navigator.push(
|
||||||
fontSize: 20,
|
context, MaterialPageRoute(builder: (context) => VenuePage(venue)));
|
||||||
fontWeight: FontWeight.bold,
|
_bottomSheetIsOpen = false;
|
||||||
),
|
},
|
||||||
),
|
style: ElevatedButton.styleFrom(
|
||||||
),
|
primary: globals.BUTTONCOLOR,
|
||||||
],
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -542,19 +530,19 @@ class MapState extends State<Map> {
|
|||||||
venue.venueName,
|
venue.venueName,
|
||||||
style: GoogleFonts.roboto(
|
style: GoogleFonts.roboto(
|
||||||
textStyle: const TextStyle(
|
textStyle: const TextStyle(
|
||||||
color: Colors.black87,
|
color: Colors.black87,
|
||||||
fontWeight: FontWeight.bold,
|
fontWeight: FontWeight.bold,
|
||||||
fontSize: 24,
|
fontSize: 26,
|
||||||
)),
|
)),
|
||||||
),
|
),
|
||||||
Text(
|
Text(
|
||||||
venue.venueAddress + ' ' + venue.venueStreetNo,
|
venue.venueAddress + ' ' + venue.venueStreetNo,
|
||||||
style: GoogleFonts.roboto(
|
style: GoogleFonts.roboto(
|
||||||
textStyle: const TextStyle(
|
textStyle: const TextStyle(
|
||||||
color: Colors.black,
|
color: Colors.black,
|
||||||
fontWeight: FontWeight.w300,
|
fontWeight: FontWeight.w300,
|
||||||
fontSize: 18,
|
fontSize: 20,
|
||||||
)),
|
)),
|
||||||
)
|
)
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
@ -564,6 +552,7 @@ class MapState extends State<Map> {
|
|||||||
print(_bottomSheetIsOpen);
|
print(_bottomSheetIsOpen);
|
||||||
if (_bottomSheetIsOpen) {
|
if (_bottomSheetIsOpen) {
|
||||||
Navigator.pop(context);
|
Navigator.pop(context);
|
||||||
|
_bottomSheetIsOpen = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -599,6 +588,46 @@ class MapState extends State<Map> {
|
|||||||
}*/
|
}*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class weatherIconRow extends StatelessWidget {
|
||||||
|
const weatherIconRow({
|
||||||
|
Key? key,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Row(
|
||||||
|
children: [
|
||||||
|
const Text(
|
||||||
|
'Weather: \t\t',
|
||||||
|
style: TextStyle(fontSize: 18),
|
||||||
|
),
|
||||||
|
globals.forecast.getCurrentWeatherIcon(),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class weatherStatusRow extends StatelessWidget {
|
||||||
|
const weatherStatusRow({
|
||||||
|
Key? key,
|
||||||
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Row(
|
||||||
|
children: [
|
||||||
|
Text(
|
||||||
|
'– ' + globals.forecast.getCurrentWeatherStatus(),
|
||||||
|
style: const TextStyle(
|
||||||
|
fontSize: 16,
|
||||||
|
fontStyle: FontStyle.italic,
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Widget buildDrawerSignedIn(BuildContext context) {
|
Widget buildDrawerSignedIn(BuildContext context) {
|
||||||
return Drawer(
|
return Drawer(
|
||||||
child: ListView(
|
child: ListView(
|
||||||
@ -606,7 +635,7 @@ Widget buildDrawerSignedIn(BuildContext context) {
|
|||||||
children: [
|
children: [
|
||||||
DrawerHeader(
|
DrawerHeader(
|
||||||
decoration:
|
decoration:
|
||||||
const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
||||||
child: Column(
|
child: Column(
|
||||||
children: const <Widget>[
|
children: const <Widget>[
|
||||||
Text(
|
Text(
|
||||||
@ -667,7 +696,7 @@ Widget buildDrawerSignedOut(BuildContext context) {
|
|||||||
children: [
|
children: [
|
||||||
DrawerHeader(
|
DrawerHeader(
|
||||||
decoration:
|
decoration:
|
||||||
const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
||||||
child: Column(
|
child: Column(
|
||||||
children: const <Widget>[
|
children: const <Widget>[
|
||||||
Text(
|
Text(
|
||||||
@ -737,4 +766,4 @@ class _Marker {
|
|||||||
var coordinates;
|
var coordinates;
|
||||||
|
|
||||||
_Marker(this.Plats_1, this.Gatunr_1, this.coordinates);
|
_Marker(this.Plats_1, this.Gatunr_1, this.coordinates);
|
||||||
}
|
}
|
||||||
|
@ -78,8 +78,11 @@ class VenueInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
String getOpeningHours() {
|
String getOpeningHours() {
|
||||||
|
String splitString;
|
||||||
if(_openHoursToday.isNotEmpty) {
|
if(_openHoursToday.isNotEmpty) {
|
||||||
return _openHoursToday;
|
splitString = _openHoursToday.replaceAll(';', '\n');
|
||||||
|
splitString = splitString.replaceAll(',', ',\n');
|
||||||
|
return splitString;
|
||||||
}
|
}
|
||||||
return 'N/A';
|
return 'N/A';
|
||||||
}
|
}
|
||||||
|
@ -88,6 +88,18 @@ class WeatherData {
|
|||||||
case 17:
|
case 17:
|
||||||
weatherStatus = 'Heavy snow showers';
|
weatherStatus = 'Heavy snow showers';
|
||||||
break;
|
break;
|
||||||
|
case 18:
|
||||||
|
weatherStatus = 'Light rain';
|
||||||
|
break;
|
||||||
|
case 19:
|
||||||
|
weatherStatus = 'Moderate rain';
|
||||||
|
break;
|
||||||
|
case 20:
|
||||||
|
weatherStatus = 'Heavy rain';
|
||||||
|
break;
|
||||||
|
case 21:
|
||||||
|
weatherStatus = 'Thunder';
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
weatherStatus = 'Undefined';
|
weatherStatus = 'Undefined';
|
||||||
}
|
}
|
||||||
@ -136,6 +148,14 @@ class WeatherData {
|
|||||||
return const FaIcon(FontAwesomeIcons.snowflake);
|
return const FaIcon(FontAwesomeIcons.snowflake);
|
||||||
case 17:
|
case 17:
|
||||||
return const FaIcon(FontAwesomeIcons.snowflake);
|
return const FaIcon(FontAwesomeIcons.snowflake);
|
||||||
|
case 18:
|
||||||
|
return const FaIcon(FontAwesomeIcons.cloudRain);
|
||||||
|
case 19:
|
||||||
|
return const FaIcon(FontAwesomeIcons.cloudRain);
|
||||||
|
case 20:
|
||||||
|
return const FaIcon(FontAwesomeIcons.cloudShowersHeavy);
|
||||||
|
case 21:
|
||||||
|
return const FaIcon(FontAwesomeIcons.bolt);
|
||||||
default:
|
default:
|
||||||
return const FaIcon(FontAwesomeIcons.times);
|
return const FaIcon(FontAwesomeIcons.times);
|
||||||
}
|
}
|
||||||
|
@ -26,14 +26,26 @@ void main() async {
|
|||||||
await Firebase.initializeApp();
|
await Firebase.initializeApp();
|
||||||
await loadAllVenues();
|
await loadAllVenues();
|
||||||
await fetchWeather();
|
await fetchWeather();
|
||||||
|
// await createVenue();
|
||||||
|
// await setWeather();
|
||||||
|
|
||||||
runApp(MyApp());
|
runApp(MyApp());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
setWeather() {
|
||||||
|
WeatherData weather = WeatherData(4, 15);
|
||||||
|
globals.forecast = weather;
|
||||||
|
}
|
||||||
|
|
||||||
|
createVenue() {
|
||||||
|
Venue venue = Venue(00, 'Restaurang Aira', 'Biskopsvägen', '9', const LatLng(59.32117929060902, 18.123636884658502));
|
||||||
|
globals.VENUES.add(venue);
|
||||||
|
}
|
||||||
|
|
||||||
Future fetchWeather() async {
|
Future fetchWeather() async {
|
||||||
WeatherData tempWeather = WeatherData(0, 0);
|
WeatherData tempWeather = WeatherData(0, 0);
|
||||||
Uri weatherDataURI = Uri.parse(
|
Uri weatherDataURI = Uri.parse(
|
||||||
'https://group-4-75.pvt.dsv.su.se/target/weather-0.0.2-SNAPSHOT.war/weather');
|
'https://group-4-75.pvt.dsv.su.se/target/info.war/weather');
|
||||||
|
|
||||||
final response = await http.get(weatherDataURI);
|
final response = await http.get(weatherDataURI);
|
||||||
|
|
||||||
@ -67,7 +79,7 @@ class MyApp extends StatelessWidget {
|
|||||||
|
|
||||||
Future loadAllVenues() async {
|
Future loadAllVenues() async {
|
||||||
Uri venueDataURI = Uri.parse(
|
Uri venueDataURI = Uri.parse(
|
||||||
'https://group-4-75.pvt.dsv.su.se/target/weather-0.0.4-SNAPSHOT.war/venue');
|
'https://group-4-75.pvt.dsv.su.se/target/info.war/venue');
|
||||||
|
|
||||||
final response = await http.get(venueDataURI);
|
final response = await http.get(venueDataURI);
|
||||||
|
|
||||||
@ -77,7 +89,7 @@ Future loadAllVenues() async {
|
|||||||
// var sd = ShadowDetector();
|
// var sd = ShadowDetector();
|
||||||
// await sd.evaluateShadowsForAllVenues(seventyFiveVenues);
|
// await sd.evaluateShadowsForAllVenues(seventyFiveVenues);
|
||||||
} else {
|
} else {
|
||||||
throw const HttpException("Problem fetching the weather data");
|
throw const HttpException("Problem fetching the venue data");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,6 @@ import 'VenueInfo.dart';
|
|||||||
import 'WeatherData.dart';
|
import 'WeatherData.dart';
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
|
|
||||||
|
|
||||||
class VenuePage extends StatefulWidget {
|
class VenuePage extends StatefulWidget {
|
||||||
const VenuePage(this.venue, {Key? key}) : super(key: key);
|
const VenuePage(this.venue, {Key? key}) : super(key: key);
|
||||||
final Venue venue;
|
final Venue venue;
|
||||||
@ -24,37 +23,27 @@ class _VenuePageState extends State<VenuePage> {
|
|||||||
final String imageLink = '';
|
final String imageLink = '';
|
||||||
late final Venue venue;
|
late final Venue venue;
|
||||||
late VenueInfo venueInfo;
|
late VenueInfo venueInfo;
|
||||||
|
|
||||||
_VenuePageState(this.venue);
|
_VenuePageState(this.venue);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
validateAndGetImageLink() {
|
|
||||||
if (imageLink == '') {
|
|
||||||
return 'https://live.staticflickr.com/6205/6081773215_19444220b6_b.jpg';
|
|
||||||
} else {
|
|
||||||
return imageLink;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
void initState() {
|
void initState() {
|
||||||
refreshWeather();
|
refreshWeather();
|
||||||
gatherVenueInfo();
|
gatherVenueInfo();
|
||||||
}
|
}
|
||||||
|
|
||||||
Future gatherVenueInfo( ) async {
|
Future gatherVenueInfo() async {
|
||||||
VenueInfo vu = VenueInfo();
|
VenueInfo vu = VenueInfo();
|
||||||
venueInfo = vu;
|
venueInfo = vu;
|
||||||
venueInfo = await vu.getVenueInfo(venue.venueName);
|
venueInfo = await vu.getVenueInfo(venue.venueName);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Future refreshWeather() async {
|
Future refreshWeather() async {
|
||||||
WeatherData tempWeather = WeatherData(0, 0);
|
WeatherData tempWeather = WeatherData(0, 0);
|
||||||
currentWeather = tempWeather;
|
currentWeather = tempWeather;
|
||||||
|
|
||||||
Uri weatherDataURI = Uri.parse(
|
Uri weatherDataURI = Uri.parse(
|
||||||
'https://group-4-75.pvt.dsv.su.se/target/weather-0.0.4-SNAPSHOT.war/weather');
|
'https://group-4-75.pvt.dsv.su.se/target/info.war/weather');
|
||||||
|
|
||||||
final response = await http.get(weatherDataURI);
|
final response = await http.get(weatherDataURI);
|
||||||
|
|
||||||
@ -80,70 +69,62 @@ class _VenuePageState extends State<VenuePage> {
|
|||||||
backgroundColor: const Color(0xffac7b84),
|
backgroundColor: const Color(0xffac7b84),
|
||||||
),
|
),
|
||||||
body: Center(
|
body: Center(
|
||||||
child: FutureBuilder(
|
child: FutureBuilder(
|
||||||
future: gatherVenueInfo(),
|
future: gatherVenueInfo(),
|
||||||
builder: (context, snapshot) {
|
builder: (context, snapshot) {
|
||||||
if(snapshot.connectionState == ConnectionState.done) {
|
if (snapshot.connectionState == ConnectionState.done) {
|
||||||
return SingleChildScrollView(
|
return SingleChildScrollView(
|
||||||
child: Container(
|
child: Container(
|
||||||
alignment: Alignment.center,
|
height: MediaQuery.of(context).size.height,
|
||||||
child: Column(children: <Widget>[
|
width: MediaQuery.of(context).size.width,
|
||||||
Row(
|
alignment: Alignment.center,
|
||||||
children: const [
|
child: buildPageContentColumn(),
|
||||||
ShareButton(),
|
),
|
||||||
SavePlaceButton(),
|
);
|
||||||
],
|
} else {
|
||||||
),
|
return const CircularProgressIndicator();
|
||||||
Row(children: [
|
}
|
||||||
Expanded(
|
})));
|
||||||
child: Image.network(venueInfo.getPhotoURL()),
|
}
|
||||||
),
|
|
||||||
]),
|
Column buildPageContentColumn() {
|
||||||
// Row(
|
return Column(children: <Widget>[
|
||||||
// children: const [
|
Row(
|
||||||
// Text(
|
children: const [
|
||||||
// 'Placeholder for image',
|
ShareButton(),
|
||||||
// ),
|
SavePlaceButton(),
|
||||||
// ],
|
],
|
||||||
// ),
|
),
|
||||||
Row(children: [
|
Row(children: [
|
||||||
Expanded(
|
Expanded(
|
||||||
child: Column(
|
child: Image.network(venueInfo.getPhotoURL()),
|
||||||
children: [
|
),
|
||||||
Text(venue.venueName,
|
]),
|
||||||
style: const TextStyle(
|
Row(children: [buildNameAndAddress(), buildWeatherInfo()]),
|
||||||
fontSize: 18,
|
AboutTheSpotTable(venueInfo: venueInfo),
|
||||||
fontWeight: FontWeight.bold,
|
]);
|
||||||
)
|
}
|
||||||
),
|
|
||||||
Text(venue.venueAddress + ' ' + venue.venueStreetNo),
|
Expanded buildWeatherInfo() {
|
||||||
],
|
return Expanded(
|
||||||
)),
|
child: Container(
|
||||||
Expanded(
|
child: buildWeatherColumn(),
|
||||||
child: Container(
|
),
|
||||||
// decoration: BoxDecoration(
|
);
|
||||||
// border: Border.all(color: const Color(0xffaaaaaa)),
|
}
|
||||||
// ),
|
|
||||||
// color: const Color(0xffe9e9e9),
|
Expanded buildNameAndAddress() {
|
||||||
child: buildWeatherColumn(),
|
return Expanded(
|
||||||
),
|
child: Column(
|
||||||
)
|
children: [
|
||||||
]),
|
Text(venue.venueName,
|
||||||
AboutTheSpotTable(venueInfo: venueInfo),
|
style: const TextStyle(
|
||||||
/*GridView.count(
|
fontSize: 18,
|
||||||
crossAxisCount: 2,
|
fontWeight: FontWeight.bold,
|
||||||
children: [],
|
)),
|
||||||
)*/
|
Text(venue.venueAddress + ' ' + venue.venueStreetNo),
|
||||||
]),
|
],
|
||||||
),
|
));
|
||||||
);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return CircularProgressIndicator();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Column buildWeatherColumn() {
|
Column buildWeatherColumn() {
|
||||||
@ -151,27 +132,16 @@ class _VenuePageState extends State<VenuePage> {
|
|||||||
children: [
|
children: [
|
||||||
Padding(
|
Padding(
|
||||||
padding: const EdgeInsets.all(4.0),
|
padding: const EdgeInsets.all(4.0),
|
||||||
child: /*Text('Weather Status:',
|
child:
|
||||||
style: GoogleFonts.robotoCondensed(
|
Row(mainAxisAlignment: MainAxisAlignment.spaceEvenly, children: [
|
||||||
textStyle: const TextStyle(
|
Column(
|
||||||
fontSize: 14,
|
|
||||||
fontWeight: FontWeight.bold,
|
|
||||||
),
|
|
||||||
)),*/
|
|
||||||
Row(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
|
|
||||||
children: [
|
children: [
|
||||||
Column(
|
currentWeather.getCurrentWeatherIcon(),
|
||||||
children: [
|
Text(currentWeather.getCurrentWeatherStatus()),
|
||||||
currentWeather.getCurrentWeatherIcon(),
|
],
|
||||||
Text(currentWeather.getCurrentWeatherStatus()),
|
),
|
||||||
],
|
Text(currentWeather.getCurrentTemperature().toString() + '\u2103'),
|
||||||
),
|
]),
|
||||||
Text(currentWeather
|
|
||||||
.getCurrentTemperature()
|
|
||||||
.toString() +
|
|
||||||
'\u2103'),
|
|
||||||
]),
|
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
@ -181,7 +151,8 @@ class _VenuePageState extends State<VenuePage> {
|
|||||||
//Just an example table
|
//Just an example table
|
||||||
class AboutTheSpotTable extends StatefulWidget {
|
class AboutTheSpotTable extends StatefulWidget {
|
||||||
final VenueInfo venueInfo;
|
final VenueInfo venueInfo;
|
||||||
AboutTheSpotTable({
|
|
||||||
|
AboutTheSpotTable({
|
||||||
Key? key,
|
Key? key,
|
||||||
required this.venueInfo,
|
required this.venueInfo,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
@ -193,50 +164,53 @@ class AboutTheSpotTable extends StatefulWidget {
|
|||||||
class _AboutTheSpotTableState extends State<AboutTheSpotTable> {
|
class _AboutTheSpotTableState extends State<AboutTheSpotTable> {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return DataTable(
|
return Center(
|
||||||
headingRowHeight: 30,
|
child: DataTable(
|
||||||
columnSpacing: 100,
|
// headingRowHeight: 30,
|
||||||
//dataRowHeight: 30,
|
// columnSpacing: 100,
|
||||||
dataTextStyle: GoogleFonts.robotoCondensed(
|
//dataRowHeight: 30,
|
||||||
color: const Color(0xff4F6272),
|
dataTextStyle: GoogleFonts.robotoCondensed(
|
||||||
|
color: const Color(0xff4F6272),
|
||||||
|
),
|
||||||
|
columns: [
|
||||||
|
DataColumn(
|
||||||
|
label: Text('About the spot',
|
||||||
|
style: GoogleFonts.roboto(
|
||||||
|
textStyle: const TextStyle(
|
||||||
|
fontSize: 18,
|
||||||
|
)))),
|
||||||
|
const DataColumn(label: Text('', style: TextStyle())),
|
||||||
|
],
|
||||||
|
rows: [
|
||||||
|
const DataRow(cells: [
|
||||||
|
DataCell(Text('Type of venue')),
|
||||||
|
DataCell(Text('Restaurant')),
|
||||||
|
]),
|
||||||
|
DataRow(cells: [
|
||||||
|
const DataCell(Text('Pricing')),
|
||||||
|
DataCell(Text(widget.venueInfo.getPriceClass())),
|
||||||
|
]),
|
||||||
|
DataRow(cells: [
|
||||||
|
const DataCell(Text('Rating')),
|
||||||
|
DataCell(Text(widget.venueInfo.getRating().toString() +
|
||||||
|
' (' +
|
||||||
|
widget.venueInfo.getTotalRatings().toString() +
|
||||||
|
' ratings)')),
|
||||||
|
]),
|
||||||
|
const DataRow(cells: [
|
||||||
|
DataCell(Text('Current activity')),
|
||||||
|
DataCell(Text('Moderate')),
|
||||||
|
]),
|
||||||
|
DataRow(cells: [
|
||||||
|
const DataCell(Text('Opening hours')),
|
||||||
|
DataCell(Text(widget.venueInfo.getOpeningHours())),
|
||||||
|
]),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
columns: [
|
|
||||||
DataColumn(
|
|
||||||
label: Text('About the spot',
|
|
||||||
style: GoogleFonts.roboto(
|
|
||||||
textStyle: const TextStyle(
|
|
||||||
fontSize: 18,
|
|
||||||
)))),
|
|
||||||
const DataColumn(label: Text('', style: TextStyle())),
|
|
||||||
],
|
|
||||||
rows: [
|
|
||||||
DataRow(cells: [
|
|
||||||
DataCell(Text('Type of venue')),
|
|
||||||
DataCell(Text('Saloon')),
|
|
||||||
]),
|
|
||||||
DataRow(cells: [
|
|
||||||
DataCell(Text('Pricing')),
|
|
||||||
DataCell(Text(widget.venueInfo.getPriceClass())),
|
|
||||||
]),
|
|
||||||
DataRow(cells: [
|
|
||||||
DataCell(Text('Rating')),
|
|
||||||
DataCell(Text(widget.venueInfo.getRating().toString() + ' (' + widget.venueInfo.getTotalRatings().toString() + ' ratings)')),
|
|
||||||
]),
|
|
||||||
DataRow(cells: [
|
|
||||||
DataCell(Text('Current activity')),
|
|
||||||
DataCell(Text('Moderate')),
|
|
||||||
]),
|
|
||||||
DataRow(cells: [
|
|
||||||
DataCell(Text('Opening hours')),
|
|
||||||
DataCell(Text(widget.venueInfo.getOpeningHours())),
|
|
||||||
]),
|
|
||||||
],
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class SavePlaceButton extends StatelessWidget {
|
class SavePlaceButton extends StatelessWidget {
|
||||||
const SavePlaceButton({
|
const SavePlaceButton({
|
||||||
Key? key,
|
Key? key,
|
||||||
@ -265,14 +239,27 @@ class ShareButton extends StatelessWidget {
|
|||||||
Key? key,
|
Key? key,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
|
/* Future<void> share() async {
|
||||||
|
await FlutterShare.share(
|
||||||
|
title: 'Share this place',
|
||||||
|
text: 'Share this place',
|
||||||
|
linkUrl: 'https://flutter.dev/',
|
||||||
|
chooserTitle: 'Example Chooser Title');
|
||||||
|
}
|
||||||
|
*/
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Expanded(
|
return Expanded(
|
||||||
child: TextButton.icon(
|
child: Column(
|
||||||
onPressed: () {},
|
children: <Widget>[
|
||||||
icon: const Icon(Icons.share),
|
TextButton.icon(
|
||||||
label: const Text('Share'),
|
onPressed: () {},
|
||||||
|
icon: const Icon(Icons.share),
|
||||||
|
label: const Text('Share'),
|
||||||
|
),
|
||||||
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user