Last active
April 10, 2024 10:40
-
-
Save eduardoflorence/e49780ab232fa8ad7767bbdbf8389f1e to your computer and use it in GitHub Desktop.
Getx - Sample Form
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import 'package:flutter/material.dart'; | |
import 'package:get/get.dart'; | |
void main() { | |
runApp(GetMaterialApp( | |
initialRoute: '/login', | |
getPages: [ | |
GetPage( | |
name: '/login', | |
page: () => LoginPage(), | |
binding: LoginBinding(), | |
), | |
], | |
)); | |
} | |
class LoginBinding implements Bindings { | |
@override | |
void dependencies() { | |
Get.lazyPut(() => LoginController()); | |
} | |
} | |
class LoginController extends GetxController { | |
final loginFormKey = GlobalKey<FormState>(); | |
final emailController = TextEditingController(); | |
final passwordController = TextEditingController(); | |
@override | |
void onInit() { | |
// Simulating obtaining the user name from some local storage | |
emailController.text = '[email protected]'; | |
super.onInit(); | |
} | |
@override | |
void onClose() { | |
emailController.dispose(); | |
passwordController.dispose(); | |
super.onClose(); | |
} | |
String validator(String value) { | |
if (value.isEmpty) { | |
return 'Please this field must be filled'; | |
} | |
return null; | |
} | |
void login() { | |
if (loginFormKey.currentState.validate()) { | |
checkUser(emailController.text, passwordController.text).then((auth) { | |
if (auth) { | |
Get.snackbar('Login', 'Login successfully'); | |
} else { | |
Get.snackbar('Login', 'Invalid email or password'); | |
} | |
passwordController.clear(); | |
}); | |
} | |
} | |
// Api Simulation | |
Future<bool> checkUser(String user, String password) { | |
if (user == '[email protected]' && password == '123') { | |
return Future.value(true); | |
} | |
return Future.value(false); | |
} | |
} | |
class LoginPage extends GetView<LoginController> { | |
@override | |
Widget build(BuildContext context) { | |
return Scaffold( | |
appBar: AppBar(title: Text('LOGIN')), | |
body: Container( | |
padding: const EdgeInsets.all(16.0), | |
child: Form( | |
key: controller.loginFormKey, | |
child: Column( | |
mainAxisAlignment: MainAxisAlignment.center, | |
children: [ | |
TextFormField( | |
controller: controller.emailController, | |
decoration: const InputDecoration(labelText: 'E-mail'), | |
validator: controller.validator, | |
), | |
TextFormField( | |
controller: controller.passwordController, | |
decoration: const InputDecoration(labelText: 'Password'), | |
validator: controller.validator, | |
obscureText: true, | |
), | |
RaisedButton( | |
child: Text('Login'), | |
onPressed: controller.login, | |
) | |
], | |
), | |
), | |
), | |
); | |
} | |
} |
Big thanks
big big big thanks...
thank you
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
@clust3rsekt0r
you can simply change the validator to =>
and it will work.
you need to check if the value is null before using
value.isEmpty