Search
 
SCRIPT & CODE EXAMPLE
 

DART

using email signin or phone number in flutter firebase

class PhoneAuthForm extends StatefulWidget {
  PhoneAuthForm({Key? key}) : super(key: key);

  @override
  _PhoneAuthFormState createState() => _PhoneAuthFormState();
}

class _PhoneAuthFormState extends State<PhoneAuthForm> {
  final FirebaseAuth _auth = FirebaseAuth.instance;
  GlobalKey<FormState> _formKey = GlobalKey<FormState>();
  TextEditingController phoneNumber = TextEditingController();
  TextEditingController otpCode = TextEditingController();

  OutlineInputBorder border = OutlineInputBorder(
      borderSide: BorderSide(color: Constants.kBorderColor, width: 3.0));

  bool isLoading = false;

  String? verificationId;
  @override
  Widget build(BuildContext context) {
    Size size = MediaQuery.of(context).size;
    return Scaffold(
      appBar: AppBar(title: Text("Verify OTP"),
                backwardsCompatibility: false,
          systemOverlayStyle: SystemUiOverlayStyle(statusBarColor: Colors.blue),),
      backgroundColor: Constants.kPrimaryColor,
      body:  Center(
        child: Form(
              key: _formKey,
              child: Column(
                mainAxisAlignment: MainAxisAlignment.center,
                children: [
                  SizedBox(
                    width: size.width * 0.8,
                    child: TextFormField(
                        keyboardType: TextInputType.phone,
                        controller: phoneNumber,
                        decoration: InputDecoration(
                          labelText: "Enter Phone",
                          contentPadding: EdgeInsets.symmetric(
                              vertical: 15.0, horizontal: 10.0),
                          border: border,
                        )),
                  ),
                  SizedBox(
                    height: size.height * 0.01,
                  ),
                  SizedBox(
                    width: size.width * 0.8,
                    child: TextFormField(
                      keyboardType: TextInputType.number,
                      controller: otpCode,
                      obscureText: true,
                      decoration: InputDecoration(
                        labelText: "Enter Otp",
                        contentPadding: EdgeInsets.symmetric(
                            vertical: 15.0, horizontal: 10.0),
                        border: border,
                        suffixIcon: Padding(
                          child: FaIcon(
                            FontAwesomeIcons.eye,
                            size: 15,
                          ),
                          padding: EdgeInsets.only(top: 15, left: 15),
                        ),
                      ),
                    ),
                  ),
                  Padding(padding: EdgeInsets.only(bottom: size.height * 0.05)),
                  !isLoading
                      ? SizedBox(
                          width: size.width * 0.8,
                          child: OutlinedButton(
                            onPressed: () async {
                              FirebaseService service = new FirebaseService();
                              if (_formKey.currentState!.validate()) {
                                setState(() {
                                  isLoading = true;
                                });
                                await phoneSignIn(phoneNumber: phoneNumber.text);
                              }
                            },
                            child: Text(Constants.textSignIn),
                            style: ButtonStyle(
                                foregroundColor: MaterialStateProperty.all<Color>(
                                    Constants.kPrimaryColor),
                                backgroundColor: MaterialStateProperty.all<Color>(
                                    Constants.kBlackColor),
                                side: MaterialStateProperty.all<BorderSide>(
                                    BorderSide.none)),
                          ),
                        )
                      : CircularProgressIndicator(),
                ],
              ),
            ),
      ));
  }
Comment

PREVIOUS NEXT
Code Example
Dart :: Convertir la liste en carte dans Dart/Flutter 
Dart :: package:grpc/grpc.dart import target uri doesnt exist 
Dart :: how to parse json with missing key in lfutter 
Dart :: dart rob cross axis align not work 
Dart :: dart list get by index 
Dart :: factory in dart 
Swift :: random string swift 
Swift :: swift generate random number 
Swift :: swift + data to string 
Swift :: toggle in swift 
Swift :: swift remove space from string 
Swift :: add buton border swift 
Swift :: swift xcode debug cannot see code backtrace 
Swift :: cgrect swift 
Swift :: swiftui navigation link with button 
Swift :: firestore subcollection swift 
Swift :: save Codable in userdefaults and fetch codable from userdefaults ios swift 
Swift :: swift rounded tab bar 
Swift :: swift alamofire x-www-form-urlencoded 
Swift :: unit testing swift ui 
Swift :: swift tuple 
Swift :: closure swift 
Swift :: how to set the center in view in swift 
Swift :: transform string to url swift 
Swift :: navigationBarTitle text size swiftui 
Swift :: ForEach tabs swiftui 
Swift :: swift split string into array of 2 characters 
Swift :: swift guard statement 
Swift :: value to value in sum 
Swift :: Swift Assignment Operators 
ADD CONTENT
Topic
Content
Source link
Name
7+2 =