added goal feature
This commit is contained in:
@ -1,16 +1,20 @@
|
||||
|
||||
|
||||
import 'dart:convert';
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:camera_camera/camera_camera.dart';
|
||||
import 'package:flutter/foundation.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:geojson/geojson.dart';
|
||||
import 'package:geolocator/geolocator.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:latlong2/latlong.dart';
|
||||
import 'package:rogapp/model/Rogaining.dart';
|
||||
import 'package:rogapp/model/destination.dart';
|
||||
import 'package:rogapp/pages/index/index_controller.dart';
|
||||
import 'package:rogapp/routes/app_pages.dart';
|
||||
import 'package:rogapp/services/action_service.dart';
|
||||
import 'package:rogapp/services/destination_service.dart';
|
||||
import 'package:rogapp/services/maxtrix_service.dart';
|
||||
import 'package:rogapp/services/reacking_service.dart';
|
||||
@ -18,6 +22,7 @@ import 'package:rogapp/utils/database_helper.dart';
|
||||
import 'dart:async';
|
||||
|
||||
import 'package:rogapp/widgets/bottom_sheet_widget.dart';
|
||||
import 'package:sqflite/sqlite_api.dart';
|
||||
|
||||
class DestinationController extends GetxController {
|
||||
|
||||
@ -26,9 +31,14 @@ class DestinationController extends GetxController {
|
||||
var destinationCount = 0.obs;
|
||||
List<Destination> destinations = <Destination>[].obs;
|
||||
List<Map<String, dynamic>> destination_index_data = <Map<String, dynamic>>[].obs;
|
||||
double current_lat = 0.0;
|
||||
double current_lon = 0.0;
|
||||
|
||||
List<Destination> currentSelectedDestinations = <Destination>[].obs;
|
||||
|
||||
var is_in_rog = false.obs;
|
||||
List<Rogaining> rogainings = <Rogaining>[].obs;
|
||||
|
||||
bool checking_in = false;
|
||||
var isSelected = false.obs;
|
||||
BuildContext? context;
|
||||
@ -41,8 +51,56 @@ class DestinationController extends GetxController {
|
||||
|
||||
Map<String, dynamic> matrix = {};
|
||||
|
||||
final photos = <File>[].obs;
|
||||
|
||||
final IndexController indexController = Get.find<IndexController>();
|
||||
|
||||
Timer? _timer;
|
||||
int _start = 1;
|
||||
var rogaining_counted = false.obs;
|
||||
|
||||
void startTimer(Destination d, double distance) {
|
||||
const oneSec = const Duration(seconds: 1);
|
||||
_timer = Timer.periodic(
|
||||
oneSec,
|
||||
(Timer timer) {
|
||||
if (_start == 0) {
|
||||
if(is_in_rog.value == false){
|
||||
is_in_rog.value = true;
|
||||
addToRogaining(current_lat, current_lon, d.location_id!);
|
||||
Get.snackbar("Rogaining Started ", "Rogaining session started");
|
||||
}
|
||||
else{
|
||||
//finish rogiain
|
||||
//is_in_rog.value = true;
|
||||
if (rogaining_counted.value && distance <=250){
|
||||
Get.toNamed(AppPages.CAMERA_PAGE);
|
||||
}
|
||||
}
|
||||
timer.cancel();
|
||||
} else {
|
||||
_start--;
|
||||
}
|
||||
},
|
||||
);
|
||||
}
|
||||
|
||||
void openCamera(BuildContext context) {
|
||||
photos.clear();
|
||||
Navigator.push(
|
||||
context,
|
||||
MaterialPageRoute(
|
||||
builder: (_) => CameraCamera(
|
||||
onFile: (file) {
|
||||
photos.add(file);
|
||||
Navigator.pop(context);
|
||||
print("----image file is : ${file}----");
|
||||
//setState(() {});
|
||||
},
|
||||
)));
|
||||
}
|
||||
|
||||
|
||||
void getRoutePoints() {
|
||||
indexController.routePoints = [];
|
||||
indexController.routePointLenght.value = 0;
|
||||
@ -63,7 +121,12 @@ class DestinationController extends GetxController {
|
||||
}
|
||||
}
|
||||
|
||||
checkForCheckin(double la, double ln){
|
||||
// void addToRogaining(Rogaining rog){
|
||||
// DatabaseHelper db = DatabaseHelper.instance;
|
||||
// db.insertRogaining(rog);
|
||||
// }
|
||||
|
||||
checkForCheckin(double la, double ln){
|
||||
|
||||
for(final d in destinations){
|
||||
|
||||
@ -79,6 +142,14 @@ class DestinationController extends GetxController {
|
||||
double rad = value!.checkin_radious ?? double.infinity;
|
||||
bool auto_checkin = value.auto_checkin == 0 ? false : true;
|
||||
|
||||
if(d.cp != -1 && is_in_rog == true){
|
||||
rogaining_counted.value == true;
|
||||
}
|
||||
|
||||
if(d.cp == -1 && dist <= 250 && rogaining_counted.value == false){
|
||||
startTimer(d, dist);
|
||||
}
|
||||
|
||||
indexController.currentDestinationFeature.add(value);
|
||||
//indexController.getAction();
|
||||
|
||||
@ -127,6 +198,22 @@ class DestinationController extends GetxController {
|
||||
}
|
||||
}
|
||||
|
||||
void addToRogaining(double lat, double lon, int destination_id){
|
||||
Rogaining rog = Rogaining(
|
||||
rog_id: null,
|
||||
course_id: 1,
|
||||
user_id: indexController.currentUser[0]['user']['id'],
|
||||
location_id: destination_id,
|
||||
lat: lat,
|
||||
lon:lon,
|
||||
time_stamp: DateTime.now().toUtc().microsecondsSinceEpoch
|
||||
);
|
||||
DatabaseHelper db = DatabaseHelper.instance;
|
||||
db.insertRogaining(rog).then((value){
|
||||
print("----- inserted value ${value} ---------");
|
||||
});
|
||||
}
|
||||
|
||||
void makeCheckin(Destination destination, bool action) async {
|
||||
print("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ ressssss ${action}@@@@@@@@@@@");
|
||||
DatabaseHelper db = DatabaseHelper.instance;
|
||||
@ -139,6 +226,15 @@ class DestinationController extends GetxController {
|
||||
PopulateDestinations();
|
||||
print("@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ after populating ${res} @@@@@@@@@@@");
|
||||
print("---- database update resulr ------ res : ${res}-------");
|
||||
|
||||
/// post to NATNAT
|
||||
if(indexController.currentUser.length > 0){
|
||||
String cp_num = destination.cp.toString();
|
||||
String team_name = indexController.currentUser[0]['user']['group'];
|
||||
ActionService.postCheckin(cp_num, team_name).then((value){
|
||||
print('------- NATNAT RES ${value} ------------');
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@ -187,6 +283,9 @@ class DestinationController extends GetxController {
|
||||
StreamSubscription<Position> positionStream = Geolocator.getPositionStream(locationSettings: locationSettings).listen(
|
||||
|
||||
(Position? position) {
|
||||
current_lat = position != null ? position.latitude : 0;
|
||||
current_lon = position != null ? position.longitude : 0;
|
||||
|
||||
if(isSelected.value){
|
||||
double czoom = indexController.rogMapController!.zoom;
|
||||
indexController.rogMapController!.move(LatLng(position!.latitude, position!.longitude), czoom);
|
||||
@ -220,6 +319,19 @@ class DestinationController extends GetxController {
|
||||
}
|
||||
}
|
||||
|
||||
Destination? destinationById(int id){
|
||||
Destination? d = null;
|
||||
print("--- target des - ${id} ----");
|
||||
for(Destination ss in destinations){
|
||||
print("--- des - ${ss.location_id} ----");
|
||||
if(ss.location_id == id){
|
||||
d = ss;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return d;
|
||||
}
|
||||
|
||||
void deleteDestination(Destination d){
|
||||
//int id = destinations[index].location_id!;
|
||||
//print("---- index ${destinations[index].location_id!}-----");
|
||||
|
||||
@ -1,9 +1,12 @@
|
||||
import 'dart:developer';
|
||||
import 'dart:io';
|
||||
|
||||
import 'package:camera_camera/camera_camera.dart';
|
||||
import 'package:flutter/material.dart';
|
||||
import 'package:geolocator/geolocator.dart';
|
||||
import 'package:get/get.dart';
|
||||
import 'package:latlong2/latlong.dart';
|
||||
import 'package:rogapp/pages/camera/camera_page.dart';
|
||||
import 'package:rogapp/pages/destination/destination_controller.dart';
|
||||
import 'package:rogapp/pages/destination_map/destination_map_page.dart';
|
||||
import 'package:rogapp/pages/drawer/drawer_page.dart';
|
||||
@ -156,6 +159,13 @@ class DestnationPage extends StatelessWidget {
|
||||
automaticallyImplyLeading: true,
|
||||
title: Text("app_title".tr),
|
||||
actions: [
|
||||
// TextButton(
|
||||
// onPressed: (){
|
||||
// //destinationController.openCamera(context);
|
||||
// Get.toNamed(AppPages.CAMERA_PAGE);
|
||||
// },
|
||||
// child: Icon(Icons.ac_unit),
|
||||
// ),
|
||||
Obx(() =>
|
||||
ToggleButtons(
|
||||
disabledColor: Colors.grey.shade200,
|
||||
@ -185,193 +195,3 @@ class DestnationPage extends StatelessWidget {
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// class DestinationPage extends StatefulWidget {
|
||||
// DestinationPage({ Key? key }) : super(key: key);
|
||||
|
||||
// @override
|
||||
// State<DestinationPage> createState() => _DestinationPageState();
|
||||
// }
|
||||
|
||||
// class DestinationPage extends State<DestinationPage> {
|
||||
// final DestinationController destinationController = Get.find<DestinationController>();
|
||||
|
||||
// final IndexController indexController = Get.find<IndexController>();
|
||||
|
||||
// final List<int> _items = List<int>.generate(50, (int index) => index);
|
||||
|
||||
// DestinationWidget dest = DestinationWidget();
|
||||
// DestinationMapPage destMap = DestinationMapPage();
|
||||
|
||||
// Future<void> showCurrentPosition() async {
|
||||
// LocationPermission permission = await Geolocator.checkPermission();
|
||||
// if (permission != LocationPermission.whileInUse ||
|
||||
// permission != LocationPermission.always) {
|
||||
// permission = await Geolocator.requestPermission();
|
||||
// }
|
||||
// Position position = await Geolocator.getCurrentPosition(
|
||||
// desiredAccuracy: LocationAccuracy.high);
|
||||
// indexController.rogMapController?.move(LatLng(position.latitude, position.longitude), 14);
|
||||
// }
|
||||
|
||||
// Image getImage(int index){
|
||||
// if(destinationController.destinations[index].photos == null || destinationController.destinations[index].photos == ""){
|
||||
// return Image(image: AssetImage('assets/images/empty_image.png'));
|
||||
// }
|
||||
// else{
|
||||
// return Image(image: NetworkImage(destinationController.destinations[index].photos!));
|
||||
// }
|
||||
// }
|
||||
|
||||
// Widget getRoutingImage(int route){
|
||||
// switch (route) {
|
||||
// case 0:
|
||||
// return Image(image: AssetImage('assets/images/p4_9_man.png'), width: 27.0,);
|
||||
// case 1:
|
||||
// return Image(image: AssetImage('assets/images/p4_8_car.png'), width: 27.0,);
|
||||
// case 2:
|
||||
// return Image(image: AssetImage('assets/images/p4_10_train.png'), width: 27.0,);
|
||||
// default:
|
||||
// return Image(image: AssetImage('assets/images/p4_9_man.png'), width: 27.0,);
|
||||
// }
|
||||
// }
|
||||
|
||||
// @override
|
||||
// void initState() {
|
||||
// //destinationController.context = context;
|
||||
// //destinationController.PopulateDestinations();
|
||||
// super.initState();
|
||||
// }
|
||||
|
||||
// @override
|
||||
// Widget build(BuildContext context) {
|
||||
// final ColorScheme colorScheme = Theme.of(context).colorScheme;
|
||||
// final Color oddItemColor = colorScheme.primary.withOpacity(0.05);
|
||||
// final Color evenItemColor = colorScheme.primary.withOpacity(0.15);
|
||||
// return WillPopScope(
|
||||
// onWillPop: () async {
|
||||
// indexController.switchPage(AppPages.INITIAL);
|
||||
// return false;
|
||||
// },
|
||||
// child: Scaffold(
|
||||
// drawer: DrawerPage(),
|
||||
// bottomNavigationBar: BottomAppBar(
|
||||
// child: Row(
|
||||
// mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
||||
// children: <Widget>[
|
||||
// Padding(
|
||||
// padding: const EdgeInsets.only(left:13.0),
|
||||
// child: InkWell(
|
||||
// child: Obx((() => getRoutingImage(destinationController.travelMode.value))),
|
||||
// onTap: (){
|
||||
// Get.bottomSheet(
|
||||
// Obx(() =>
|
||||
// ListView(
|
||||
// children: [
|
||||
// Padding(
|
||||
// padding: const EdgeInsets.only(top:30.0, bottom: 30),
|
||||
// child: Center(child: Text("select_travel_mode".tr, style: TextStyle(fontSize: 22.0, color:Colors.red, fontWeight:FontWeight.bold),),),
|
||||
// ),
|
||||
// ListTile(
|
||||
// selected: destinationController.travelMode == 0 ? true : false,
|
||||
// selectedTileColor: Colors.amber.shade200,
|
||||
// leading: Image(image: AssetImage('assets/images/p4_9_man.png'),),
|
||||
// title: Text("walking".tr),
|
||||
// onTap:(){
|
||||
// destinationController.travelMode.value = 0;
|
||||
// Get.back();
|
||||
// },
|
||||
// ),
|
||||
// ListTile(
|
||||
// selected: destinationController.travelMode == 1 ? true : false,
|
||||
// selectedTileColor: Colors.amber.shade200,
|
||||
// leading: Image(image: AssetImage('assets/images/p4_8_car.png'),),
|
||||
// title: Text("driving".tr),
|
||||
// onTap:(){
|
||||
// destinationController.travelMode.value = 1;
|
||||
// Get.back();
|
||||
// },
|
||||
// ),
|
||||
// ListTile(
|
||||
// selected: destinationController.travelMode == 2 ? true : false,
|
||||
// selectedTileColor: Colors.amber.shade200,
|
||||
// leading: Image(image: AssetImage('assets/images/p4_10_train.png'),),
|
||||
// title: Text("transit".tr),
|
||||
// onTap:(){
|
||||
// destinationController.travelMode.value = 2;
|
||||
// Get.back();
|
||||
// },
|
||||
// ),
|
||||
// ],
|
||||
|
||||
// ),
|
||||
// ),
|
||||
// isScrollControlled:false,
|
||||
// backgroundColor: Colors.white,
|
||||
// );
|
||||
// destinationController.PopulateDestinations();
|
||||
// destMap.
|
||||
// }
|
||||
// ),
|
||||
// )
|
||||
// ,
|
||||
// IconButton(
|
||||
// icon: const Icon(Icons.travel_explore),
|
||||
// onPressed: (){
|
||||
// indexController.switchPage(AppPages.INITIAL);
|
||||
// }
|
||||
// ),
|
||||
// ],
|
||||
// ),
|
||||
// ),
|
||||
// floatingActionButton: FloatingActionButton(
|
||||
// onPressed: (){
|
||||
// //print("######");
|
||||
// indexController.toggleDestinationMode();
|
||||
// },
|
||||
// tooltip: 'Increment',
|
||||
// child: Obx(() =>
|
||||
// indexController.desination_mode == 1 ?
|
||||
// Image(image: AssetImage('assets/images/list2.png'))
|
||||
// :
|
||||
// Image(image: AssetImage('assets/images/map.png'))
|
||||
// ),
|
||||
// elevation: 4.0,
|
||||
// ),
|
||||
// floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked,
|
||||
// appBar:AppBar(
|
||||
// automaticallyImplyLeading: true,
|
||||
// title: Text("app_title".tr),
|
||||
// actions: [
|
||||
// //Obx(() =>
|
||||
// ToggleButtons(
|
||||
// disabledColor: Colors.grey.shade200,
|
||||
// selectedColor: Colors.red,
|
||||
// children: <Widget>[
|
||||
// Icon(Icons.explore
|
||||
// )],
|
||||
// onPressed: (int index) {
|
||||
// setState(() {
|
||||
// destinationController.isSelected[index] = !destinationController.isSelected[index];
|
||||
// });
|
||||
// },
|
||||
// isSelected: destinationController.isSelected,
|
||||
// ),
|
||||
// //),
|
||||
// // IconButton(onPressed: (){
|
||||
// // showCurrentPosition();
|
||||
// // },
|
||||
// // icon: Icon(Icons.location_on_outlined))
|
||||
// ],
|
||||
// ),
|
||||
// body: Obx(() =>
|
||||
// indexController.desination_mode.value == 0 ?
|
||||
// dest:
|
||||
// destMap
|
||||
// )
|
||||
// ),
|
||||
// );
|
||||
|
||||
// }
|
||||
// }
|
||||
Reference in New Issue
Block a user