LoginPage #60
File diff suppressed because one or more lines are too long
|
@ -1,8 +1,8 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'Map.dart';
|
import 'package:flutter_applicationdemo/map.dart';
|
||||||
import 'FavoritePage.dart';
|
import 'favorite_page.dart';
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
import 'ListViewPage.dart';
|
import 'list_view_page.dart';
|
||||||
|
|
||||||
class BottomNavPage extends StatefulWidget {
|
class BottomNavPage extends StatefulWidget {
|
||||||
@override
|
@override
|
|
@ -1,8 +1,8 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/venuePage.dart';
|
import 'package:flutter_applicationdemo/venue_page.dart';
|
||||||
import 'Venue.dart';
|
import 'venue.dart';
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
import 'login/signInPage.dart';
|
import 'login/sign_in_page.dart';
|
||||||
import 'mysql.dart';
|
import 'mysql.dart';
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter_applicationdemo/mysql.dart';
|
import 'package:flutter_applicationdemo/mysql.dart';
|
||||||
import 'BottomNavPage.dart';
|
import 'bottom_nav_page.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'Form.dart';
|
import 'form.dart';
|
||||||
|
|
||||||
|
|
||||||
Color _backgroundColor = const Color.fromARGB(255, 190, 146, 160);
|
Color _backgroundColor = const Color.fromARGB(255, 190, 146, 160);
|
|
@ -1,14 +1,10 @@
|
||||||
import 'package:flutter_applicationdemo/WeatherData.dart';
|
import 'package:flutter_applicationdemo/weather_data.dart';
|
||||||
|
import 'venue.dart';
|
||||||
import 'Venue.dart';
|
import 'package:flutter_applicationdemo/login/user.dart';
|
||||||
import 'package:flutter_applicationdemo/login/User.dart';
|
import '../login/user.dart';
|
||||||
import '../login/User.dart';
|
|
||||||
import 'dart:ui';
|
import 'dart:ui';
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
import 'Venue.dart';
|
|
||||||
import 'main.dart';
|
|
||||||
|
|
||||||
User LOGGED_IN_USER = User(0, "", "");
|
User LOGGED_IN_USER = User(0, "", "");
|
||||||
Color BACKGROUNDCOLOR = const Color.fromARGB(255, 190, 146, 160);
|
Color BACKGROUNDCOLOR = const Color.fromARGB(255, 190, 146, 160);
|
||||||
|
|
|
@ -1,20 +1,18 @@
|
||||||
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';
|
||||||
import 'VenuePage.dart';
|
import 'venue_page.dart';
|
||||||
|
|
||||||
class ListViewPage extends StatefulWidget {
|
class ListViewPage extends StatefulWidget {
|
||||||
const ListViewPage({Key? key}) : super(key: key);
|
const ListViewPage({Key? key}) : super(key: key);
|
||||||
|
|
||||||
@override
|
@override
|
||||||
State<ListViewPage> createState() => _ListViewPageState();
|
State<ListViewPage> createState() => ListViewPageState();
|
||||||
}
|
}
|
||||||
|
|
||||||
class _ListViewPageState extends State<ListViewPage> {
|
@visibleForTesting
|
||||||
|
class ListViewPageState extends State<ListViewPage> {
|
||||||
final List<Venue> allVenues = globals.VENUES;
|
final List<Venue> allVenues = globals.VENUES;
|
||||||
|
|
||||||
@override
|
@override
|
|
@ -1,14 +1,13 @@
|
||||||
// ignore_for_file: prefer_const_constructors
|
// ignore_for_file: prefer_const_constructors
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/BottomNavPage.dart';
|
import 'package:flutter_applicationdemo/login/encrypt_data.dart';
|
||||||
import 'package:flutter_applicationdemo/login/EncryptData.dart';
|
|
||||||
import 'package:google_fonts/google_fonts.dart';
|
import 'package:google_fonts/google_fonts.dart';
|
||||||
import 'package:flutter_applicationdemo/mysql.dart';
|
import 'package:flutter_applicationdemo/mysql.dart';
|
||||||
import '../globals.dart' as globals;
|
import '../globals.dart' as globals;
|
||||||
import '../reusables/InputField.dart';
|
import '../reusables/input_field.dart';
|
||||||
import 'User.dart';
|
import 'user.dart';
|
||||||
import '../reusables/returnButton.dart';
|
import '../reusables/return_button.dart';
|
||||||
|
|
||||||
class CreateAccountPage extends StatefulWidget {
|
class CreateAccountPage extends StatefulWidget {
|
||||||
_CreateAccountPageState createState() => _CreateAccountPageState();
|
_CreateAccountPageState createState() => _CreateAccountPageState();
|
|
@ -1,4 +1,3 @@
|
||||||
import 'package:firebase_auth/firebase_auth.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:google_sign_in/google_sign_in.dart';
|
import 'package:google_sign_in/google_sign_in.dart';
|
||||||
|
|
|
@ -1,18 +1,14 @@
|
||||||
import 'dart:io';
|
|
||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/login/EncryptData.dart';
|
import 'package:flutter_applicationdemo/login/encrypt_data.dart';
|
||||||
import 'package:flutter_applicationdemo/BottomNavPage.dart';
|
import 'package:flutter_applicationdemo/bottom_nav_page.dart';
|
||||||
import '../mysql.dart';
|
import '../mysql.dart';
|
||||||
import '../main.dart';
|
import 'user.dart';
|
||||||
import 'User.dart';
|
import '../reusables/input_field.dart';
|
||||||
import '../reusables/InputField.dart';
|
import '../reusables/return_button.dart';
|
||||||
import '../reusables/returnButton.dart';
|
|
||||||
import 'package:flutter_signin_button/flutter_signin_button.dart';
|
import 'package:flutter_signin_button/flutter_signin_button.dart';
|
||||||
import 'GoogleSignInProvider.dart';
|
import 'google_sign_in_provider.dart';
|
||||||
import 'CreateAccountPage.dart';
|
import 'create_account_page.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:flutter_applicationdemo/Map.dart' as map;
|
|
||||||
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
||||||
|
|
||||||
class SignInPage extends StatefulWidget {
|
class SignInPage extends StatefulWidget {
|
||||||
|
@ -136,7 +132,6 @@ class _SignInPageState extends State<SignInPage> {
|
||||||
onPressed: () async {
|
onPressed: () async {
|
||||||
if (emailController.text.contains("'") ||
|
if (emailController.text.contains("'") ||
|
||||||
passwordController.text.contains("'")) {
|
passwordController.text.contains("'")) {
|
||||||
print("1");
|
|
||||||
loginError();
|
loginError();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -147,7 +142,6 @@ class _SignInPageState extends State<SignInPage> {
|
||||||
context,
|
context,
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
print(globals.LOGGED_IN_USER.userID);
|
|
||||||
loginError();
|
loginError();
|
||||||
}
|
}
|
||||||
//print(loggedInUser.email + " " + loggedInUser.userID.toString());
|
//print(loggedInUser.email + " " + loggedInUser.userID.toString());
|
|
@ -1,4 +1,4 @@
|
||||||
import 'package:flutter_applicationdemo/Venue.dart';
|
import 'package:flutter_applicationdemo/venue.dart';
|
||||||
import 'package:flutter_applicationdemo/mysql.dart';
|
import 'package:flutter_applicationdemo/mysql.dart';
|
||||||
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
||||||
|
|
||||||
|
@ -33,9 +33,6 @@ class User{
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
for(Venue venue in likedVenuesList){
|
|
||||||
print(venue.venueName);
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -4,27 +4,35 @@ import 'dart:io';
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:firebase_core/firebase_core.dart';
|
import 'package:firebase_core/firebase_core.dart';
|
||||||
import 'package:flutter_applicationdemo/login/GoogleSignInProvider.dart';
|
import 'package:flutter_applicationdemo/shadow_detector.dart';
|
||||||
|
import 'package:flutter_applicationdemo/login/google_sign_in_provider.dart';
|
||||||
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
import 'package:provider/provider.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
|
|
||||||
import 'BottomNavPage.dart';
|
import 'bottom_nav_page.dart';
|
||||||
import 'WeatherData.dart';
|
import 'weather_data.dart';
|
||||||
import 'Venue.dart';
|
import 'venue.dart';
|
||||||
import 'mysql.dart';
|
import 'mysql.dart';
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
|
|
||||||
void main() async {
|
void main() async {
|
||||||
WidgetsFlutterBinding.ensureInitialized();
|
WidgetsFlutterBinding.ensureInitialized();
|
||||||
await Firebase.initializeApp();
|
await Firebase.initializeApp();
|
||||||
//await loadAllVenues();
|
// await loadAllVenues();
|
||||||
//await fetchWeather();
|
// await fetchWeather();
|
||||||
|
await weatherInstance();
|
||||||
await loadAllVenuesSQL();
|
await loadAllVenuesSQL();
|
||||||
|
|
||||||
runApp(MyApp());
|
runApp(MyApp());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future weatherInstance() async{
|
||||||
|
WeatherData weather = WeatherData(3, 12);
|
||||||
|
globals.forecast = weather;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
Future fetchWeather() async {
|
Future fetchWeather() async {
|
||||||
WeatherData tempWeather = WeatherData(0, 0);
|
WeatherData tempWeather = WeatherData(0, 0);
|
||||||
Uri weatherDataURI = Uri.parse(
|
Uri weatherDataURI = Uri.parse(
|
||||||
|
@ -71,7 +79,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 venue data");
|
throw const HttpException("Problem fetching the venue data");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/BottomNavPage.dart';
|
import 'package:flutter_applicationdemo/login/encrypt_data.dart';
|
||||||
import 'package:flutter_applicationdemo/login/EncryptData.dart';
|
import 'package:flutter_applicationdemo/reusables/input_field.dart';
|
||||||
import 'package:flutter_applicationdemo/reusables/InputField.dart';
|
|
||||||
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
||||||
import 'package:flutter_applicationdemo/mysql.dart';
|
import 'package:flutter_applicationdemo/mysql.dart';
|
||||||
|
|
||||||
|
import 'bottom_nav_page.dart';
|
||||||
|
|
||||||
class ManageAccountPage extends StatefulWidget {
|
class ManageAccountPage extends StatefulWidget {
|
||||||
@override
|
@override
|
||||||
State<ManageAccountPage> createState() => ManageAccountPageState();
|
State<ManageAccountPage> createState() => ManageAccountPageState();
|
||||||
|
@ -21,8 +22,8 @@ class ManageAccountPageState extends State<ManageAccountPage> {
|
||||||
Widget _buildPasswordFiled(TextEditingController controller) {
|
Widget _buildPasswordFiled(TextEditingController controller) {
|
||||||
return InputField(
|
return InputField(
|
||||||
text: "New password",
|
text: "New password",
|
||||||
isPassword: true,
|
isPassword: true,
|
||||||
icon: const Icon(Icons.lock),
|
icon: const Icon(Icons.lock),
|
||||||
controller: controller
|
controller: controller
|
||||||
);
|
);
|
||||||
}
|
}
|
|
@ -1,30 +1,18 @@
|
||||||
import 'dart:convert';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/BottomNavPage.dart';
|
|
||||||
import 'package:flutter_applicationdemo/ListViewPage.dart';
|
|
||||||
import 'package:flutter_applicationdemo/ManageAccountPage.dart';
|
|
||||||
import 'package:flutter_applicationdemo/WeatherData.dart';
|
|
||||||
import 'package:flutter_applicationdemo/WebScraper.dart';
|
|
||||||
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
|
|
||||||
import 'package:google_fonts/google_fonts.dart';
|
import 'package:google_fonts/google_fonts.dart';
|
||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'login/User.dart';
|
|
||||||
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
import 'package:flutter_google_places/flutter_google_places.dart';
|
import 'package:flutter_google_places/flutter_google_places.dart';
|
||||||
import 'package:http/http.dart' as http;
|
|
||||||
import 'package:http/retry.dart';
|
|
||||||
import 'package:intl/number_symbols.dart';
|
|
||||||
import 'package:location/location.dart';
|
import 'package:location/location.dart';
|
||||||
import 'package:geolocator/geolocator.dart';
|
import 'venue_page.dart';
|
||||||
import 'package:intl/intl.dart';
|
import 'venue.dart';
|
||||||
import 'package:flutter_applicationdemo/login/User.dart';
|
import 'login/user.dart';
|
||||||
import 'venuePage.dart';
|
|
||||||
import 'Venue.dart';
|
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
import 'package:syncfusion_flutter_sliders/sliders.dart';
|
import 'package:syncfusion_flutter_sliders/sliders.dart';
|
||||||
import 'FeedbackPage.dart';
|
import 'package:flutter_applicationdemo/manage_account_page.dart';
|
||||||
import 'login/CreateAccountPage.dart';
|
import 'feedback_page.dart';
|
||||||
import 'login/signInPage.dart';
|
import 'login/create_account_page.dart';
|
||||||
|
import 'login/sign_in_page.dart';
|
||||||
|
|
||||||
class Map extends StatefulWidget {
|
class Map extends StatefulWidget {
|
||||||
@override
|
@override
|
||||||
|
@ -33,7 +21,7 @@ class Map extends StatefulWidget {
|
||||||
|
|
||||||
const kGoogleApiKey = "AIzaSyAUmhd6Xxud8SwgDxJ4LlYlcntm01FGoSk";
|
const kGoogleApiKey = "AIzaSyAUmhd6Xxud8SwgDxJ4LlYlcntm01FGoSk";
|
||||||
|
|
||||||
final homeSacffoldKey = GlobalKey<ScaffoldState>();
|
final homeScaffoldKey = GlobalKey<ScaffoldState>();
|
||||||
|
|
||||||
late CameraPosition _currentCameraPosition;
|
late CameraPosition _currentCameraPosition;
|
||||||
|
|
||||||
|
@ -70,32 +58,6 @@ class MapState extends State<Map> {
|
||||||
hiddenVenues.addAll(globals.VENUES);
|
hiddenVenues.addAll(globals.VENUES);
|
||||||
}
|
}
|
||||||
|
|
||||||
void createBottomSheet(String venueName) async {
|
|
||||||
var webScraper = WebScraper();
|
|
||||||
await webScraper.getWebsiteData(venueName);
|
|
||||||
Scaffold.of(context).showBottomSheet<void>(
|
|
||||||
((context) {
|
|
||||||
return Container(
|
|
||||||
height: 420,
|
|
||||||
color: Colors.white,
|
|
||||||
child: Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
mainAxisSize: MainAxisSize.min,
|
|
||||||
children: <Widget>[
|
|
||||||
/*const Text('BottomSheet'),
|
|
||||||
ElevatedButton(
|
|
||||||
child: const Text('Close BottomSheet'),
|
|
||||||
onPressed: () {Navigator.pop(context);})*/
|
|
||||||
Container(
|
|
||||||
child: Text(webScraper.openingHoursThisWeek.length.toString()),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
)),
|
|
||||||
);
|
|
||||||
}));
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<LocationData> _getLocationPermission() async {
|
Future<LocationData> _getLocationPermission() async {
|
||||||
Location location = Location();
|
Location location = Location();
|
||||||
|
|
||||||
|
@ -135,6 +97,7 @@ class MapState extends State<Map> {
|
||||||
final Mode _mode = Mode.fullscreen;
|
final Mode _mode = Mode.fullscreen;
|
||||||
|
|
||||||
int currentIndex = 0;
|
int currentIndex = 0;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
_currentCameraPosition = _stockholmCity;
|
_currentCameraPosition = _stockholmCity;
|
||||||
|
@ -142,28 +105,29 @@ class MapState extends State<Map> {
|
||||||
appBar: AppBar(
|
appBar: AppBar(
|
||||||
centerTitle: true,
|
centerTitle: true,
|
||||||
title: const Text("Sun chasers"),
|
title: const Text("Sun chasers"),
|
||||||
key: homeSacffoldKey,
|
key: homeScaffoldKey,
|
||||||
actions: <Widget>[createFilterMenuButton()],
|
actions: <Widget>[createFilterMenuButton()],
|
||||||
backgroundColor: const Color.fromARGB(255, 190, 146, 160),
|
backgroundColor: const Color.fromARGB(255, 190, 146, 160),
|
||||||
),
|
),
|
||||||
drawer : Drawer(
|
drawer: Drawer(
|
||||||
child: Container(
|
child: Container(
|
||||||
child: globals.LOGGED_IN_USER.userID == 0 ? buildDrawerSignedOut(context) : buildDrawerSignedIn(context),
|
child: globals.LOGGED_IN_USER.userID == 0
|
||||||
|
? buildDrawerSignedOut(context)
|
||||||
|
: buildDrawerSignedIn(context),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
|
body: Stack(
|
||||||
body: Stack (
|
|
||||||
children: [
|
children: [
|
||||||
GoogleMap(
|
GoogleMap(
|
||||||
zoomControlsEnabled: true,
|
|
||||||
cameraTargetBounds: CameraTargetBounds(LatLngBounds(
|
cameraTargetBounds: CameraTargetBounds(LatLngBounds(
|
||||||
northeast: const LatLng(59.3474696569038, 18.1001602476002147),
|
northeast: const LatLng(59.3474696569038, 18.1001602476002147),
|
||||||
southwest: const LatLng(59.297332547922636, 17.999522500277884))),
|
southwest:
|
||||||
|
const LatLng(59.297332547922636, 17.999522500277884))),
|
||||||
minMaxZoomPreference: MinMaxZoomPreference(12.5, 18.5),
|
minMaxZoomPreference: MinMaxZoomPreference(12.5, 18.5),
|
||||||
onCameraMove: (CameraPosition camera){
|
onCameraMove: (CameraPosition camera) {
|
||||||
_currentCameraPosition = camera;
|
_currentCameraPosition = camera;
|
||||||
},
|
},
|
||||||
onCameraIdle: (){
|
onCameraIdle: () {
|
||||||
(context as Element).reassemble();
|
(context as Element).reassemble();
|
||||||
removeMarkersOutOfRange();
|
removeMarkersOutOfRange();
|
||||||
addMarkersInRange();
|
addMarkersInRange();
|
||||||
|
@ -182,8 +146,6 @@ class MapState extends State<Map> {
|
||||||
closeBottomSheetIfOpen();
|
closeBottomSheetIfOpen();
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
// ElevatedButton(onPressed: () {} //_handelPressButton
|
|
||||||
// ,child: const Text("Search Placses"))
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
floatingActionButtonLocation: FloatingActionButtonLocation.endTop,
|
floatingActionButtonLocation: FloatingActionButtonLocation.endTop,
|
||||||
|
@ -284,8 +246,8 @@ class MapState extends State<Map> {
|
||||||
));
|
));
|
||||||
}),
|
}),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
)));
|
)));
|
||||||
}
|
}
|
||||||
|
|
||||||
PopupMenuItem<dynamic> createPriceSlider() {
|
PopupMenuItem<dynamic> createPriceSlider() {
|
||||||
|
@ -325,43 +287,6 @@ class MapState extends State<Map> {
|
||||||
CameraPosition(target: LatLng(lat, lng), zoom: 14.5)));
|
CameraPosition(target: LatLng(lat, lng), zoom: 14.5)));
|
||||||
}
|
}
|
||||||
|
|
||||||
Widget _boxes(double lat, double lng, String restaurantName) {
|
|
||||||
return GestureDetector(
|
|
||||||
onTap: () {
|
|
||||||
_gotoLocation(lat, lng);
|
|
||||||
},
|
|
||||||
child: Container(
|
|
||||||
child: FittedBox(
|
|
||||||
child: Material(
|
|
||||||
color: Colors.white,
|
|
||||||
elevation: 14.0,
|
|
||||||
borderRadius: BorderRadius.circular(24.0),
|
|
||||||
shadowColor: Color(0x802196F3),
|
|
||||||
child: Row(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
||||||
children: <Widget>[
|
|
||||||
Container(
|
|
||||||
width: 250,
|
|
||||||
height: 200,
|
|
||||||
child: ClipRRect(
|
|
||||||
borderRadius: new BorderRadius.circular(24.0),
|
|
||||||
child:
|
|
||||||
const Image(image: AssetImage('assets/images/bild.png')),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Container(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Text(restaurantName),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
)),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Future<void> _goToCurrentPosition(LatLng latlng) async {
|
Future<void> _goToCurrentPosition(LatLng latlng) async {
|
||||||
final GoogleMapController controller = await _controller.future;
|
final GoogleMapController controller = await _controller.future;
|
||||||
controller.animateCamera(CameraUpdate.newCameraPosition(CameraPosition(
|
controller.animateCamera(CameraUpdate.newCameraPosition(CameraPosition(
|
||||||
|
@ -372,57 +297,68 @@ class MapState extends State<Map> {
|
||||||
}
|
}
|
||||||
|
|
||||||
void removeMarkersOutOfRange() {
|
void removeMarkersOutOfRange() {
|
||||||
for(int i = 0; i<closeByMarkersList.length; i++){
|
for (int i = 0; i < closeByMarkersList.length; i++) {
|
||||||
Marker marker = closeByMarkersList[i];
|
Marker marker = closeByMarkersList[i];
|
||||||
globals.venueAlreadyAdded(globals.getVenueByID(int.parse(marker.markerId.value))!.venueName);
|
globals.venueAlreadyAdded(
|
||||||
if(marker.position.longitude - _currentCameraPosition.target.longitude > 0.02 || marker.position.latitude - _currentCameraPosition.target.latitude > 0.02){
|
globals.getVenueByID(int.parse(marker.markerId.value))!.venueName);
|
||||||
|
if (marker.position.longitude - _currentCameraPosition.target.longitude >
|
||||||
|
0.02 ||
|
||||||
|
marker.position.latitude - _currentCameraPosition.target.latitude >
|
||||||
|
0.02) {
|
||||||
closeByMarkersList.remove(marker);
|
closeByMarkersList.remove(marker);
|
||||||
globals.getVenueByID(int.parse(marker.markerId.value))?.isShownOnMap = false;
|
globals.getVenueByID(int.parse(marker.markerId.value))?.isShownOnMap =
|
||||||
|
false;
|
||||||
i--;
|
i--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void addMarkersInRange() {
|
void addMarkersInRange() {
|
||||||
for(int i = 0; i< globals.VENUES.length; i++){
|
for (int i = 0; i < globals.VENUES.length; i++) {
|
||||||
print(globals.VENUES[i].venueName + " " + globals.VENUES[i].venueID.toString());
|
if (!globals.VENUES[i].isShownOnMap &&
|
||||||
if(!globals.VENUES[i].isShownOnMap && (globals.VENUES[i].position.longitude - _currentCameraPosition.target.longitude < 0.02 && globals.VENUES[i].position.latitude - _currentCameraPosition.target.latitude < 0.02)){
|
(globals.VENUES[i].position.longitude -
|
||||||
|
_currentCameraPosition.target.longitude <
|
||||||
|
0.02 &&
|
||||||
|
globals.VENUES[i].position.latitude -
|
||||||
|
_currentCameraPosition.target.latitude <
|
||||||
|
0.02)) {
|
||||||
Marker marker = Marker(
|
Marker marker = Marker(
|
||||||
markerId: MarkerId(globals.VENUES[i].venueID.toString()),
|
markerId: MarkerId(globals.VENUES[i].venueID.toString()),
|
||||||
position: globals.VENUES[i].position,
|
position: globals.VENUES[i].position,
|
||||||
onTap: () => createBottomDrawer(globals.VENUES[i]),
|
onTap: () => createBottomSheet(globals.VENUES[i]),
|
||||||
icon: globals.VENUES[i].drawIconColor()
|
icon: globals.VENUES[i].drawIconColor());
|
||||||
);
|
|
||||||
globals.VENUES[i].isShownOnMap = true;
|
globals.VENUES[i].isShownOnMap = true;
|
||||||
closeByMarkersList.add(marker);
|
closeByMarkersList.add(marker);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
createBottomDrawer(Venue venue) async {
|
createBottomSheet(Venue venue) async {
|
||||||
_bottomSheetIsOpen = true;
|
_bottomSheetIsOpen = true;
|
||||||
// Scaffold.of(context).showBottomSheet<void>(((context) {
|
// Scaffold.of(context).showBottomSheet<void>(((context) {
|
||||||
showModalBottomSheet(context: context, builder: (BuildContext context) {
|
showModalBottomSheet(
|
||||||
return InkWell(
|
context: context,
|
||||||
onTap: () {
|
builder: (BuildContext context) {
|
||||||
Navigator.push(
|
return InkWell(
|
||||||
context,
|
onTap: () {
|
||||||
MaterialPageRoute(builder: (context) => VenuePage(venue)),
|
Navigator.push(
|
||||||
);
|
context,
|
||||||
},
|
MaterialPageRoute(builder: (context) => VenuePage(venue)),
|
||||||
child: Container(
|
);
|
||||||
height: 175,
|
},
|
||||||
color: const Color(0xFFF5F5F5),
|
child: Container(
|
||||||
child: Center(
|
height: 175,
|
||||||
child: Column(
|
color: const Color(0xFFF5F5F5),
|
||||||
children: [
|
child: Center(
|
||||||
bottomSheetWidgetContainer(venue, context),
|
child: Column(
|
||||||
],
|
children: [
|
||||||
|
bottomSheetWidgetContainer(venue, context),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
),
|
||||||
),
|
),
|
||||||
),
|
);
|
||||||
),
|
});
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Container bottomSheetWidgetContainer(Venue venue, BuildContext context) {
|
Container bottomSheetWidgetContainer(Venue venue, BuildContext context) {
|
||||||
|
@ -441,7 +377,6 @@ class MapState extends State<Map> {
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
// columnCoveringRating(),
|
// columnCoveringRating(),
|
||||||
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
const SizedBox(
|
const SizedBox(
|
||||||
|
@ -452,8 +387,8 @@ class MapState extends State<Map> {
|
||||||
children: [
|
children: [
|
||||||
Column(
|
Column(
|
||||||
children: const [
|
children: const [
|
||||||
weatherIconRow(),
|
WeatherIconRow(),
|
||||||
weatherStatusRow(),
|
WeatherStatusRow(),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
columnHandlingReadMoreButton(context, venue),
|
columnHandlingReadMoreButton(context, venue),
|
||||||
|
@ -531,45 +466,14 @@ class MapState extends State<Map> {
|
||||||
}
|
}
|
||||||
|
|
||||||
void setAllMarkersAsInvisible() {
|
void setAllMarkersAsInvisible() {
|
||||||
for(Venue venue in hiddenVenues){
|
for (Venue venue in hiddenVenues) {
|
||||||
venue.isShownOnMap = false;
|
venue.isShownOnMap = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/*
|
|
||||||
Future<void> _handelPressButton() async {
|
|
||||||
Prediction? p = await PlacesAutocomplete.show(
|
|
||||||
context: context,
|
|
||||||
apiKey: kGoogleApiKey,
|
|
||||||
mode: _mode, // Mode.fullscreen
|
|
||||||
language: "en",
|
|
||||||
strictbounds: false,
|
|
||||||
decoration: InputDecoration(
|
|
||||||
hintText:'serach',
|
|
||||||
focusedBorder: OutlineInputBorder(borderRadius: BorderRadius.circular(20), borderSide: BorderSide(color: Colors.white))
|
|
||||||
),
|
|
||||||
types: [""],
|
|
||||||
components: [Component(Component.country, "se")]);
|
|
||||||
if (p != null) {
|
|
||||||
displayPrediction(p,homeSacffoldKey.currentState);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Future<void> displayPrediction(Prediction p, ScaffoldState? currentState) async {
|
|
||||||
GoogleMapsPlaces places = GoogleMapsPlaces(
|
|
||||||
apiKey: kGoogleApiKey,
|
|
||||||
apiHeaders: await const GoogleApiHeaders().getHeaders()
|
|
||||||
);
|
|
||||||
PlacesDetailsResponse detail = await places.getDetailsByPlaceId(p.placeId!);
|
|
||||||
final lat = detail.result.geometry!.location.lat;
|
|
||||||
final lng = detail.result.geometry!.location.lng;
|
|
||||||
markersList.clear();
|
|
||||||
markersList.add(Marker(markerId: const MarkerId("0"), position: LatLng(lat, lng), infoWindow: InfoWindow(title: detail.result.name)));
|
|
||||||
setState(() {});
|
|
||||||
googleMapController.animateCamera(CameraUpdate.newLatLngZoom(LatLng(lat,lng), 14.0));
|
|
||||||
}*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
class weatherIconRow extends StatelessWidget {
|
class WeatherIconRow extends StatelessWidget {
|
||||||
const weatherIconRow({
|
const WeatherIconRow({
|
||||||
Key? key,
|
Key? key,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@ -587,8 +491,8 @@ class weatherIconRow extends StatelessWidget {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class weatherStatusRow extends StatelessWidget {
|
class WeatherStatusRow extends StatelessWidget {
|
||||||
const weatherStatusRow({
|
const WeatherStatusRow({
|
||||||
Key? key,
|
Key? key,
|
||||||
}) : super(key: key);
|
}) : super(key: key);
|
||||||
|
|
||||||
|
@ -627,41 +531,9 @@ Widget buildDrawerSignedIn(BuildContext context) {
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
ListTile(
|
giveFeedbackTile(context),
|
||||||
leading: Icon(Icons.thumb_up_alt),
|
settingsTile(context),
|
||||||
title: Text('Give feedback'),
|
signOutTile(context),
|
||||||
onTap: () {
|
|
||||||
Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => FormForFeedback(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
ListTile(
|
|
||||||
leading: Icon(Icons.settings),
|
|
||||||
title: Text('Change password'),
|
|
||||||
onTap: () {
|
|
||||||
Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => ManageAccountPage(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
ListTile(
|
|
||||||
leading: Icon(Icons.logout),
|
|
||||||
title: Text('Sign out'),
|
|
||||||
onTap: () {
|
|
||||||
globals.LOGGED_IN_USER = User(0, "", "");
|
|
||||||
Navigator.pop(
|
|
||||||
context,
|
|
||||||
);
|
|
||||||
(context as Element).reassemble();
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
|
@ -672,66 +544,102 @@ Widget buildDrawerSignedOut(BuildContext context) {
|
||||||
child: ListView(
|
child: ListView(
|
||||||
padding: EdgeInsets.zero,
|
padding: EdgeInsets.zero,
|
||||||
children: [
|
children: [
|
||||||
DrawerHeader(
|
drawerHeader(),
|
||||||
decoration:
|
createAccountTile(context),
|
||||||
const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
logInTile(context),
|
||||||
child: Column(
|
giveFeedbackTile(context),
|
||||||
children: const <Widget>[
|
|
||||||
Text(
|
|
||||||
'Sun Chaser',
|
|
||||||
style: TextStyle(fontSize: 32),
|
|
||||||
),
|
|
||||||
SizedBox(height: 30),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
ListTile(
|
|
||||||
leading: Icon(Icons.account_box_rounded),
|
|
||||||
title: Text('Create account'),
|
|
||||||
onTap: () async{
|
|
||||||
await Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => CreateAccountPage(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
(context as Element).reassemble();
|
|
||||||
},
|
|
||||||
),
|
|
||||||
ListTile(
|
|
||||||
leading: Icon(Icons.login),
|
|
||||||
title: Text('Sign in'),
|
|
||||||
onTap: () async {
|
|
||||||
await Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => SignInPage(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
(context as Element).reassemble();
|
|
||||||
},
|
|
||||||
),
|
|
||||||
ListTile(
|
|
||||||
leading: Icon(Icons.thumb_up_alt),
|
|
||||||
title: Text('Give feedback'),
|
|
||||||
onTap: () {
|
|
||||||
Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => FormForFeedback(),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
class _Marker {
|
DrawerHeader drawerHeader() {
|
||||||
var Plats_1;
|
return DrawerHeader(
|
||||||
var Gatunr_1;
|
decoration: const BoxDecoration(color: Color.fromARGB(255, 190, 146, 160)),
|
||||||
var coordinates;
|
child: Column(
|
||||||
|
children: const <Widget>[
|
||||||
_Marker(this.Plats_1, this.Gatunr_1, this.coordinates);
|
Text(
|
||||||
|
'Sun Chaser',
|
||||||
|
style: TextStyle(fontSize: 32),
|
||||||
|
),
|
||||||
|
SizedBox(height: 30),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ListTile settingsTile(BuildContext context) {
|
||||||
|
return ListTile(
|
||||||
|
leading: Icon(Icons.settings),
|
||||||
|
title: Text('Change password'),
|
||||||
|
onTap: () {
|
||||||
|
Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => ManageAccountPage(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ListTile signOutTile(BuildContext context) {
|
||||||
|
return ListTile(
|
||||||
|
leading: Icon(Icons.logout),
|
||||||
|
title: Text('Sign out'),
|
||||||
|
onTap: () {
|
||||||
|
globals.LOGGED_IN_USER = User(0, "", "");
|
||||||
|
Navigator.pop(
|
||||||
|
context,
|
||||||
|
);
|
||||||
|
(context as Element).reassemble();
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ListTile giveFeedbackTile(BuildContext context) {
|
||||||
|
return ListTile(
|
||||||
|
leading: Icon(Icons.thumb_up_alt),
|
||||||
|
title: Text('Give feedback'),
|
||||||
|
onTap: () {
|
||||||
|
Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => FormForFeedback(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ListTile logInTile(BuildContext context) {
|
||||||
|
return ListTile(
|
||||||
|
leading: Icon(Icons.login),
|
||||||
|
title: Text('Sign in'),
|
||||||
|
onTap: () async{
|
||||||
|
await Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => SignInPage(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
(context as Element).reassemble();
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
ListTile createAccountTile(BuildContext context) {
|
||||||
|
return ListTile(
|
||||||
|
leading: Icon(Icons.account_box_rounded),
|
||||||
|
title: Text('Create account'),
|
||||||
|
onTap: () async {
|
||||||
|
await Navigator.push(
|
||||||
|
context,
|
||||||
|
MaterialPageRoute(
|
||||||
|
builder: (context) => CreateAccountPage(),
|
||||||
|
),
|
||||||
|
);
|
||||||
|
(context as Element).reassemble();
|
||||||
|
},
|
||||||
|
);
|
||||||
}
|
}
|
|
@ -1,4 +1,3 @@
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
import 'package:html/dom.dart' as dom;
|
import 'package:html/dom.dart' as dom;
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
class ReturnButton extends StatelessWidget {
|
class ReturnButton extends StatelessWidget {
|
|
@ -2,15 +2,14 @@
|
||||||
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
import 'package:http/http.dart';
|
import 'package:http/http.dart';
|
||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'Venue.dart';
|
import 'venue.dart';
|
||||||
|
|
||||||
class ShadowDetector {
|
class ShadowDetector {
|
||||||
|
|
||||||
List<Venue> venuesInShade = [];
|
List<Venue> venuesInShade = [];
|
||||||
|
|
||||||
ShadowDetector() {
|
ShadowDetector();
|
||||||
|
|
||||||
}
|
|
||||||
//Called like "new ShadowDetector.fromShadowDetector(List of venues here);"
|
//Called like "new ShadowDetector.fromShadowDetector(List of venues here);"
|
||||||
ShadowDetector.fromShadowDetector(venues) {
|
ShadowDetector.fromShadowDetector(venues) {
|
||||||
evaluateShadowsForAllVenues(venues);
|
evaluateShadowsForAllVenues(venues);
|
|
@ -1,6 +1,5 @@
|
||||||
import 'package:flutter/cupertino.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_applicationdemo/ShadowDetector.dart';
|
import 'package:flutter_applicationdemo/shadow_detector.dart';
|
||||||
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
|
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
import 'package:html/dom.dart' as dom;
|
|
||||||
import 'package:intl/intl.dart';
|
import 'package:intl/intl.dart';
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
|
|
||||||
import 'Venue.dart';
|
import 'venue.dart';
|
||||||
|
|
||||||
class VenueInfo {
|
class VenueInfo {
|
||||||
|
|
||||||
|
@ -66,55 +65,6 @@ class VenueInfo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*Future getVenueInfo(String venueName) async {
|
|
||||||
|
|
||||||
final fourSquareURL =
|
|
||||||
Uri.parse('https://foursquare.com/explore?mode=url&near=Stockholm%2C%20Sweden&nearGeoId=72057594040601666&q=$venueName');
|
|
||||||
|
|
||||||
final response1 = await http.get(fourSquareURL);
|
|
||||||
if(response1.statusCode == 200) {
|
|
||||||
dom.Document html = dom.Document.html(response1.body);
|
|
||||||
|
|
||||||
var fsqId = html.getElementsByClassName('card singleRecommendation hasPhoto tipWithLogging leftPhotoLayout').map((e) => e.attributes['data-id']).toList()[0];
|
|
||||||
|
|
||||||
final response2 = await http.get(
|
|
||||||
Uri.parse('https://api.foursquare.com/v3/places/$fsqId?fields=price%2Crating%2Cphotos%2Chours%2Cstats%2Ctastes'),
|
|
||||||
headers: {
|
|
||||||
HttpHeaders.authorizationHeader: 'fsq3LBbeZ8imQK8X1hov7DTb9F64Xs1fs2bojHQ99QNm4TE='
|
|
||||||
},
|
|
||||||
);
|
|
||||||
|
|
||||||
if(response2.statusCode == 200) {
|
|
||||||
Map data = jsonDecode(response2.body);
|
|
||||||
if(data['price'] != null) {
|
|
||||||
_priceClass = data['price'];
|
|
||||||
}
|
|
||||||
if(data['rating'] != null) {
|
|
||||||
_rating = data['rating'];
|
|
||||||
}
|
|
||||||
if(data['photos'][0] != null) {
|
|
||||||
_photos = data['photos'][0];
|
|
||||||
}
|
|
||||||
if(data['hours']['open now'] != null) {
|
|
||||||
_openNow = data['hours']['open_now'];
|
|
||||||
}
|
|
||||||
if(data['stats']['total_ratings'] != null) {
|
|
||||||
_totalRatings = data['stats']['total_ratings'];
|
|
||||||
}
|
|
||||||
if(data['hours']['display'] != null) {
|
|
||||||
_openHoursToday = data['hours']['display'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw const HttpException("No connection to api.foursquare.com");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
throw const HttpException("No connection to foursquare.com");
|
|
||||||
}
|
|
||||||
}*/
|
|
||||||
|
|
||||||
|
|
||||||
String getPopularHoursToday() {
|
String getPopularHoursToday() {
|
||||||
var today = DateFormat('EEEE').format(DateTime.now());
|
var today = DateFormat('EEEE').format(DateTime.now());
|
||||||
if(_hoursPopular.isEmpty) {
|
if(_hoursPopular.isEmpty) {
|
||||||
|
@ -189,17 +139,4 @@ class VenueInfo {
|
||||||
String getVenueURL () {
|
String getVenueURL () {
|
||||||
return 'https://api.foursquare.com$_fsqLink';
|
return 'https://api.foursquare.com$_fsqLink';
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
enum WeekDays {
|
|
||||||
monday,
|
|
||||||
tuesday,
|
|
||||||
wednesday,
|
|
||||||
thursday,
|
|
||||||
friday,
|
|
||||||
saturday,
|
|
||||||
sunday,
|
|
||||||
|
|
||||||
}
|
}
|
|
@ -1,14 +1,14 @@
|
||||||
import 'dart:convert';
|
import 'dart:convert';
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
import 'package:share_plus/share_plus.dart';
|
import 'package:share_plus/share_plus.dart';
|
||||||
import 'package:flutter_applicationdemo/Venue.dart';
|
import 'package:flutter_applicationdemo/venue.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:google_fonts/google_fonts.dart';
|
import 'package:google_fonts/google_fonts.dart';
|
||||||
import 'package:http/http.dart' as http;
|
import 'package:http/http.dart' as http;
|
||||||
import 'VenueInfo.dart';
|
import 'venue_info.dart';
|
||||||
import 'WeatherData.dart';
|
import 'weather_data.dart';
|
||||||
import 'globals.dart' as globals;
|
import 'globals.dart' as globals;
|
||||||
import 'Venue.dart';
|
import 'venue.dart';
|
||||||
|
|
||||||
// Color _backgroundColor = const Color(0xffac7b84);
|
// Color _backgroundColor = const Color(0xffac7b84);
|
||||||
|
|
||||||
|
@ -18,24 +18,18 @@ class VenuePage extends StatefulWidget {
|
||||||
final Venue venue;
|
final Venue venue;
|
||||||
|
|
||||||
@override
|
@override
|
||||||
State<VenuePage> createState() => _VenuePageState(venue);
|
State<VenuePage> createState() => VenuePageState(venue);
|
||||||
}
|
}
|
||||||
|
|
||||||
class _VenuePageState extends State<VenuePage> {
|
@visibleForTesting
|
||||||
|
class VenuePageState extends State<VenuePage> {
|
||||||
late WeatherData currentWeather;
|
late WeatherData currentWeather;
|
||||||
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() {
|
||||||
|
@ -43,9 +37,9 @@ class _VenuePageState extends State<VenuePage> {
|
||||||
}
|
}
|
||||||
|
|
||||||
Future gatherVenueInfo() async {
|
Future gatherVenueInfo() async {
|
||||||
VenueInfo vu = VenueInfo();
|
VenueInfo vi = VenueInfo();
|
||||||
venueInfo = vu;
|
venueInfo = vi;
|
||||||
venueInfo = await vu.getVenueInfo(venue);
|
venueInfo = await vi.getVenueInfo(venue);
|
||||||
}
|
}
|
||||||
|
|
||||||
Future refreshWeather() async {
|
Future refreshWeather() async {
|
||||||
|
@ -63,7 +57,7 @@ class _VenuePageState extends State<VenuePage> {
|
||||||
|
|
||||||
setState(() {
|
setState(() {
|
||||||
globals.forecast = tempWeather;
|
globals.forecast = tempWeather;
|
||||||
currentWeather = tempWeather; //Could be a widget instead??
|
currentWeather = tempWeather;
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
throw const HttpException("Problem fetching the weather data");
|
throw const HttpException("Problem fetching the weather data");
|
||||||
|
@ -269,7 +263,7 @@ class LikeVenueButton extends StatelessWidget {
|
||||||
),
|
),
|
||||||
label: const Text('Like place'),
|
label: const Text('Like place'),
|
||||||
style: TextButton.styleFrom(
|
style: TextButton.styleFrom(
|
||||||
primary: Color(0xff4f6272),
|
primary: const Color(0xff4f6272),
|
||||||
),
|
),
|
||||||
)): Expanded(
|
)): Expanded(
|
||||||
child: TextButton.icon(
|
child: TextButton.icon(
|
17
test/list_view_page_test.dart
Normal file
17
test/list_view_page_test.dart
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
import 'package:flutter_applicationdemo/list_view_page.dart';
|
||||||
|
import 'package:flutter_applicationdemo/venue.dart';
|
||||||
|
import 'package:flutter_applicationdemo/globals.dart' as globals;
|
||||||
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
|
|
||||||
|
import 'package:test/test.dart';
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
test('Test ListViewPage can access venues', () {
|
||||||
|
// ListViewPage listViewPage = const ListViewPage();
|
||||||
|
ListViewPageState listViewPage = ListViewPageState();
|
||||||
|
globals.VENUES.add(Venue(
|
||||||
|
00, 'Aira', 'Biskopsudden', '9', const LatLng(59.354823, 19.29485)));
|
||||||
|
|
||||||
|
expect(globals.VENUES.first, listViewPage.allVenues.first);
|
||||||
|
});
|
||||||
|
}
|
|
@ -1,5 +1,5 @@
|
||||||
import 'package:test/test.dart';
|
import 'package:test/test.dart';
|
||||||
import 'package:flutter_applicationdemo/ManageAccountPage.dart';
|
import 'package:flutter_applicationdemo/manage_account_page.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
group('ManageAccountPage', () {
|
group('ManageAccountPage', () {
|
|
@ -1,6 +1,6 @@
|
||||||
import 'package:flutter_applicationdemo/Venue.dart';
|
import 'package:flutter_applicationdemo/venue.dart';
|
||||||
import 'package:flutter_test/flutter_test.dart';
|
import 'package:flutter_test/flutter_test.dart';
|
||||||
import 'package:flutter_applicationdemo/VenueInfo.dart';
|
import 'package:flutter_applicationdemo/venue_info.dart';
|
||||||
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
|
|
18
test/venue_page_test.dart
Normal file
18
test/venue_page_test.dart
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
import 'package:flutter_applicationdemo/list_view_page.dart';
|
||||||
|
import 'package:flutter_applicationdemo/venue.dart';
|
||||||
|
import 'package:flutter_applicationdemo/weather_data.dart';
|
||||||
|
import 'package:flutter_applicationdemo/venue_page.dart';
|
||||||
|
import 'package:google_maps_flutter/google_maps_flutter.dart';
|
||||||
|
import 'package:test/test.dart';
|
||||||
|
|
||||||
|
void main() {
|
||||||
|
test('Venue Page Has Access to Venue Instance', () {
|
||||||
|
Venue venue = Venue(
|
||||||
|
00, 'Aira', 'Biskopsudden', '9', const LatLng(59.354823, 19.29485));
|
||||||
|
VenuePage venuePage = VenuePage(venue);
|
||||||
|
|
||||||
|
expect('Aira', venuePage.venue.venueName);
|
||||||
|
expect('Biskopsudden', venuePage.venue.venueAddress);
|
||||||
|
expect('9', venuePage.venue.venueStreetNo);
|
||||||
|
});
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user