Files
absensi_sas_flutter/lib/screen/login/login_screen.dart

254 lines
9.1 KiB
Dart

import 'dart:io';
import 'package:dio/dio.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:google_sign_in/google_sign_in.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:path_provider/path_provider.dart';
import '../../app/constant.dart';
import '../../provider/google_login_provider.dart';
import 'package:crypton/crypton.dart' as crypton;
class LoginScreen extends HookConsumerWidget {
const LoginScreen({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
// inisialisasi
// ref.watch itu sama spt memantau state terus menerus
// ref.read itu memantau namun hny 1x saja
GoogleSignInAccount? currentUser = ref.watch(currentUserProvider);
final googleSignIn = ref.watch(googleSignInProvider);
Future<void> postPublicKey() async {
Dio dio = Dio();
String url = "https://example.com/api/post_endpoint";
try {
final publicPem = await rootBundle.loadString('assets/public_key.pem');
final publicKey = crypton.RSAPublicKey.fromPEM(publicPem);
// GoogleSignInAccount? currentUser = ref.watch(currentUserProvider);
// final googleSignIn = ref.watch(googleSignInProvider);
// return filePath;
publicKey.encrypt("testing satu dua tiga");
Map<String, dynamic> data = {
"publickey": publicKey,
"id_google_sign_in": "102110797605607117832",
"email": "sindhu@sismedia.com"
};
Response response = await dio.post(
url,
data: data,
);
// Menampilkan respons dari server
print("Response data: ${response.data}");
// googleSignIn.onCurrentUserChanged.listen((account) {
// // untuk update value ke provider google_login_provider yaitu currentUserProvider
// ref.read(currentUserProvider.notifier).update((state) => account);
// });
// googleSignIn.signInSilently();
} catch (e) {
print("Error reading file: $e");
}
}
useEffect(() {
// googleSignIn.onCurrentUserChanged.listen((account) {
// // untuk update value ke provider google_login_provider yaitu currentUserProvider
// ref.read(currentUserProvider.notifier).update((state) => account);
// });
// googleSignIn.signInSilently();
postPublicKey();
return () {};
}, const []);
// fungsi untuk sync ke google mail
Future<void> handleSignIn() async {
try {
await googleSignIn.signIn();
} catch (error) {
if (kDebugMode) {
print(error);
}
}
}
return Scaffold(
body: SafeArea(
child: SingleChildScrollView(
child: Column(
children: [
SizedBox(
height: Constant.getActualYPhone(context: context, y: 100),
),
(currentUser != null)
? Container(
child: ListTile(
leading: GoogleUserCircleAvatar(
identity: currentUser,
),
title: Text(
currentUser.displayName ?? "",
),
subtitle: Text(
currentUser.email,
),
trailing: IconButton(
icon: Icon(Icons.logout_outlined),
onPressed: () async {
await googleSignIn.disconnect();
},
),
),
)
:
// Logo Landscape
Padding(
padding: EdgeInsets.only(
top: Constant.getActualYPhone(context: context, y: 120),
left: Constant.getActualXPhone(context: context, x: 91),
right:
Constant.getActualXPhone(context: context, x: 90),
// bottom: Constant.getActualYPhone(context: context, y: y)
),
child: Container(
width:
Constant.getActualXPhone(context: context, x: 209),
height:
Constant.getActualYPhone(context: context, y: 70),
decoration: BoxDecoration(
// color: Colors.green,
image: DecorationImage(
// fit: BoxFit.contain,
image: AssetImage(
'images/logo_sismedika_landscape.png'),
),
),
),
),
SizedBox(
height: Constant.getActualYPhone(context: context, y: 100),
),
// title
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
'Selamat Datang',
style: Constant.titleH1_700(context: context)
.copyWith(color: Constant.textBlack),
),
Container(
width: Constant.getActualXPhone(context: context, x: 24),
height: Constant.getActualYPhone(context: context, y: 24),
// color: Colors.redAccent,
decoration: BoxDecoration(
// color: Colors.green,
image: DecorationImage(
// fit: BoxFit.contain,
image: AssetImage('images/emoji_handshake.png'),
),
),
),
],
),
SizedBox(
height: Constant.getActualYPhone(context: context, y: 7),
),
// title grey
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
'Silahkan masuk untuk mengakses akun Anda',
style: Constant.titleH2_600(context: context).copyWith(
color: Constant.textLightGrey,
),
),
],
),
SizedBox(
height: Constant.getActualYPhone(context: context, y: 64),
),
// button login
Padding(
padding: EdgeInsets.only(
left: Constant.getActualXPhone(context: context, x: 23),
right: Constant.getActualXPhone(context: context, x: 23),
),
child: SizedBox(
width: Constant.getActualXPhone(context: context, x: 344),
height: Constant.getActualYPhone(context: context, y: 48),
child: ElevatedButton(
onPressed: () async {
await handleSignIn();
},
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Container(
width:
Constant.getActualXPhone(context: context, x: 24),
height:
Constant.getActualYPhone(context: context, y: 24),
decoration: BoxDecoration(
// color: Colors.green,
image: DecorationImage(
// fit: BoxFit.contain,
image: AssetImage('images/icon_google.png'),
),
),
),
SizedBox(
width:
Constant.getActualXPhone(context: context, x: 2),
),
Text(
'Continue with Google',
style: Constant.logintitle_700(context: context)
.copyWith(
color: Constant.textBlack,
),
),
],
),
style: ButtonStyle(
backgroundColor: MaterialStateColor.resolveWith(
(st) => Colors.white,
),
shape: MaterialStateProperty.all<RoundedRectangleBorder>(
RoundedRectangleBorder(
borderRadius: BorderRadius.circular(24),
side: BorderSide(
color: Color.fromRGBO(145, 158, 171, 0.32),
),
),
),
),
),
),
),
],
),
),
),
);
}
}