step 12 : ubah dari nomitism ke google apis untuk address

This commit is contained in:
sindhu
2024-08-28 10:34:27 +07:00
parent 102760babc
commit 40453ab16b
9 changed files with 142 additions and 18 deletions

View File

@@ -0,0 +1,75 @@
import 'package:absensi_sas/repository/googleapis_repository.dart';
import 'package:equatable/equatable.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import '../../provider/dio_provider.dart';
import '../../provider/graphql_provider.dart';
import '../../repository/base_repository.dart';
abstract class GoogleApisProviderState extends Equatable {
final DateTime date;
const GoogleApisProviderState(this.date);
@override
List<Object?> get props => [date];
}
class GoogleApisProviderStateInit extends GoogleApisProviderState {
GoogleApisProviderStateInit() : super(DateTime.now());
}
class GoogleApisProviderStateLoading extends GoogleApisProviderState {
GoogleApisProviderStateLoading() : super(DateTime.now());
}
class GoogleApisProviderStateError extends GoogleApisProviderState {
final String message;
GoogleApisProviderStateError({
required this.message,
}) : super(DateTime.now());
}
class GoogleApisProviderStateDone extends GoogleApisProviderState {
final String model;
GoogleApisProviderStateDone({
required this.model,
}) : super(DateTime.now());
}
//notifier
class GoogleApisProviderNotifier extends StateNotifier<GoogleApisProviderState> {
final Ref ref;
GoogleApisProviderNotifier({
required this.ref,
}) : super(GoogleApisProviderStateInit());
void googleApisProvider(
String latitude,
String longitude,
) async {
try {
state = GoogleApisProviderStateLoading();
final graphql = ref.read(graphqlProvider(''));
final dio = ref.read(dioProvider);
final resp = await GoogleApisRepository(graphql: graphql, dio: dio)
.getAddressFromCoordinates(
latitude,
longitude
);
state = GoogleApisProviderStateDone(model: resp);
} catch (e) {
if (e is BaseRepositoryException) {
print(e.message);
state = GoogleApisProviderStateError(message: e.message ?? "");
} else {
state = GoogleApisProviderStateError(message: e.toString());
}
}
}
}
// provider
final googleApisProviderProvider =
StateNotifierProvider<GoogleApisProviderNotifier, GoogleApisProviderState>(
(ref) => GoogleApisProviderNotifier(ref: ref),
);

View File

@@ -12,6 +12,7 @@ import 'package:location/location.dart';
// import 'package:permission_handler/permission_handler.dart';
import 'package:fluentui_system_icons/fluentui_system_icons.dart';
import '../../app/googleapis_location.dart';
import '../../app/route.dart';
import '../../provider/current_check_distance_provider.dart';
import '../../provider/current_check_jam_presensi_provider.dart';
@@ -128,10 +129,10 @@ class HomeScreen extends HookConsumerWidget {
positionLongitude.value = _locationData.longitude.toString();
// Mendapatkan alamat dari posisi
final address = await positionToAddress(
final address = await positionToAddressGoogleApis(
LatLng(_locationData.latitude!, _locationData.longitude!));
if (address.city != "") {
if (address != "") {
positionLatitude.value = _locationData.latitude.toString();
positionLongitude.value = _locationData.longitude.toString();

View File

@@ -16,7 +16,7 @@ class GoogleApisNotifier extends StateNotifier<GoogleApisState> {
GoogleApisNotifier({required this.ref}) : super(GoogleApisStateInit());
void getAddressGoogleApis(
{required double latitude, required double longitude}) async {
{required String latitude, required String longitude}) async {
try {
state = GoogleApisStateLoading();
final graphql = ref.read(graphqlProvider(''));

View File

@@ -1,4 +1,5 @@
import 'dart:convert';
import 'package:absensi_sas/app/googleapis_location.dart';
import 'package:camera/camera.dart';
import 'package:camera_web/camera_web.dart';
import 'dart:io';
@@ -94,16 +95,16 @@ class PresensiScreen extends HookConsumerWidget {
_locationData = await location.getLocation();
// Mendapatkan alamat dari posisi
final address = await positionToAddress(
final address = await positionToAddressGoogleApis(
LatLng(_locationData.latitude!, _locationData.longitude!));
if (positionLongitude.value.isEmpty && positionLatitude.value.isEmpty) {
if (address.city != "") {
if (address != "") {
isLoadingAddressUserLocation.value = false;
ref.read(googleApisProvider.notifier).getAddressGoogleApis(
latitude: _locationData.latitude!,
longitude: _locationData.longitude!,
latitude: _locationData.latitude.toString(),
longitude: _locationData.longitude.toString(),
);
// String address =

View File

@@ -24,6 +24,7 @@ import 'package:shared_preferences/shared_preferences.dart';
// import 'package:permission_handler/permission_handler.dart';
import '../../app/constant.dart';
import '../../app/googleapis_location.dart';
import '../../app/route.dart';
import '../../provider/camera_controller_provider.dart';
import '../../provider/current_check_distance_provider.dart';
@@ -194,7 +195,7 @@ class PresensiSelfieScreen extends HookConsumerWidget {
_locationData = await location.getLocation();
// Mendapatkan alamat dari posisi
final address = await positionToAddress(
final address = await positionToAddressGoogleApis(
LatLng(_locationData.latitude!, _locationData.longitude!));
// final address = await positionToAddress(
@@ -203,12 +204,12 @@ class PresensiSelfieScreen extends HookConsumerWidget {
// Mendapatkan alamat dari posisi
if (positionLongitude.value.isEmpty && positionLatitude.value.isEmpty) {
if (address.city != "") {
if (address != "") {
isLoadingAddressUserLocation.value = false;
ref.read(googleApisProvider.notifier).getAddressGoogleApis(
latitude: _locationData.latitude!,
longitude: _locationData.longitude!,
latitude: _locationData.latitude.toString(),
longitude: _locationData.longitude.toString(),
);
// String address =