flutter_animated_login 0.0.8 flutter_animated_login: ^0.0.8 copied to clipboard
A Flutter package to create a beautiful animated login screen with phone/email otp, password, and social login options. It also includes a phone number with country code picker.
import 'package:flutter/material.dart';
import 'package:flutter/services.dart';
import 'package:flutter_animated_login/flutter_animated_login.dart';
void main() {
runApp(const MyApp());
}
ValueNotifier<bool> isDark = ValueNotifier<bool>(true);
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return ValueListenableBuilder(
valueListenable: isDark,
builder: (context, value, child) => MaterialApp(
title: 'Flutter Animated Login',
themeMode: value ? ThemeMode.dark : ThemeMode.light,
theme: value ? ThemeData.dark() : ThemeData.dark(),
debugShowCheckedModeBanner: false,
home: Scaffold(
floatingActionButton: FilledButton(
onPressed: () => isDark.value = !isDark.value,
child: value
? const Text("Login with OTP")
: const Text("Login with Password"),
),
body: FlutterAnimatedLogin(
loginType: value ? LoginType.password : LoginType.otp,
onLogin: (loginData) async {
final result = await Future.delayed(
const Duration(seconds: 2),
() => '',
);
SystemChannels.textInput.invokeMethod('TextInput.hide');
TextInput.finishAutofillContext();
return result;
},
loginConfig: const LoginConfig(
logo: FlutterLogo(size: 100),
title: 'Mohesu Enterprise',
subtitle: 'Let\'s Sign In',
),
providers: [
LoginProvider(
icon: Icons.reddit,
label: 'Reddit',
callback: () async {
return "";
},
),
LoginProvider(
icon: Icons.apple,
label: 'Apple',
callback: () async {
return "";
},
),
LoginProvider(
icon: Icons.facebook,
label: 'Facebook',
callback: () async {
return "";
},
),
],
),
),
),
);
}
}