-
-
Notifications
You must be signed in to change notification settings - Fork 2
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: adding authentication page UI based on Figma #12
base: dev
Are you sure you want to change the base?
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,187 @@ | ||
// ignore_for_file: prefer_const_constructors | ||
|
||
import 'package:flutter/material.dart'; | ||
|
||
class LoginScreen extends StatelessWidget { | ||
const LoginScreen({Key? key}) : super(key: key); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return Scaffold( | ||
backgroundColor: Color(0xffFFFFFF), | ||
body: ListView( | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Using a ListView for only two items is not recommanded. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I couldn't change the listview, but it is responsive now. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please show me your code without the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
padding: EdgeInsets.symmetric( | ||
horizontal: MediaQuery.of(context).size.width / 8), | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
children: const [ | ||
Menu(), | ||
Body(), | ||
], | ||
), | ||
); | ||
} | ||
} | ||
|
||
class Menu extends StatelessWidget { | ||
const Menu({Key? key}) : super(key: key); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return Padding( | ||
padding: const EdgeInsets.symmetric(vertical: 30), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. To have a consistency between all screens, could you store all dimensions in a separated file please? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Why do you mark this as resolved, as the dimension is still hardcoded? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. how I can put in a centralized file? Is creating a const for appappding would be good in theme_constants file? |
||
child: Row( | ||
mainAxisAlignment: MainAxisAlignment.spaceBetween, | ||
children: [ | ||
Row( | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
mainAxisAlignment: MainAxisAlignment.start, | ||
children: [ | ||
Image.asset( | ||
'icons/release_icon_transparent.png', | ||
width: 41, | ||
height: 65, | ||
) | ||
], | ||
), | ||
], | ||
), | ||
); | ||
} | ||
} | ||
|
||
class Body extends StatelessWidget { | ||
const Body({Key? key}) : super(key: key); | ||
|
||
@override | ||
Widget build(BuildContext context) { | ||
return Row( | ||
mainAxisAlignment: MainAxisAlignment.spaceBetween, | ||
children: [ | ||
SizedBox( | ||
width: 380, | ||
child: Column( | ||
crossAxisAlignment: CrossAxisAlignment.start, | ||
children: [ | ||
Text( | ||
' Sign In to the\nCommunity Portal', | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Do you plan to use a translation service? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @g123k suggestions please. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hello Sumit You can have a look here There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Thanks @AshAman999 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Please ask @teolemon how to use Crowdin (the same as Smoothie) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. It's as simple as tweaking the config file in the PR, with the path to the translation file (typically *.arb for flutter) There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||
style: TextStyle( | ||
fontSize: 45, | ||
fontWeight: FontWeight.bold, | ||
), | ||
), | ||
SizedBox( | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
height: null, | ||
), | ||
Text( | ||
"If you don't have an account", | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
style: TextStyle( | ||
color: Colors.black54, fontWeight: FontWeight.bold), | ||
), | ||
SizedBox( | ||
height: 10, | ||
), | ||
Row( | ||
children: [ | ||
RichText( | ||
text: TextSpan( | ||
text: 'You can', | ||
style: TextStyle( | ||
color: Colors.black54, fontWeight: FontWeight.bold), | ||
), | ||
), | ||
SizedBox(width: 15), | ||
Text( | ||
"Register here!", | ||
style: TextStyle( | ||
color: Theme.of(context).primaryColor, | ||
fontWeight: FontWeight.bold), | ||
), | ||
], | ||
), | ||
Image.asset( | ||
'icons/release_icon_with_name_transparent.png', | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
width: 400, | ||
), | ||
], | ||
), | ||
), | ||
Padding( | ||
padding: EdgeInsets.symmetric( | ||
vertical: MediaQuery.of(context).size.height / 6), | ||
child: SizedBox( | ||
width: 320, | ||
child: _formLogin(context), | ||
), | ||
) | ||
], | ||
); | ||
} | ||
|
||
Widget _formLogin(context) { | ||
return Column( | ||
children: [ | ||
TextField( | ||
decoration: InputDecoration( | ||
hintText: 'Enter email or Phone number', | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
filled: true, | ||
labelStyle: TextStyle(fontSize: 12), | ||
contentPadding: EdgeInsetsDirectional.only(start: 30), | ||
enabledBorder: OutlineInputBorder( | ||
borderRadius: BorderRadius.circular(15), | ||
), | ||
focusedBorder: OutlineInputBorder( | ||
borderRadius: BorderRadius.circular(15), | ||
), | ||
), | ||
), | ||
SizedBox(height: 30), | ||
TextField( | ||
decoration: InputDecoration( | ||
sumit-158 marked this conversation as resolved.
Show resolved
Hide resolved
|
||
hintText: 'Password', | ||
counterText: 'Forgot password?', | ||
suffixIcon: Icon( | ||
Icons.visibility_off_outlined, | ||
color: Colors.grey, | ||
), | ||
filled: true, | ||
labelStyle: TextStyle(fontSize: 12), | ||
contentPadding: EdgeInsetsDirectional.only(start: 30), | ||
enabledBorder: OutlineInputBorder( | ||
borderRadius: BorderRadius.circular(15), | ||
), | ||
focusedBorder: OutlineInputBorder( | ||
borderRadius: BorderRadius.circular(15), | ||
), | ||
), | ||
), | ||
SizedBox(height: 40), | ||
Container( | ||
decoration: BoxDecoration( | ||
color: Theme.of(context).primaryColor, | ||
borderRadius: BorderRadius.circular(30), | ||
boxShadow: [ | ||
BoxShadow( | ||
color: Theme.of(context).primaryColor, | ||
spreadRadius: 10, | ||
blurRadius: 20, | ||
), | ||
], | ||
), | ||
child: ElevatedButton( | ||
onPressed: () => ("it's pressed"), | ||
style: ElevatedButton.styleFrom( | ||
primary: Theme.of(context).primaryColor, | ||
onPrimary: Colors.white, | ||
shape: RoundedRectangleBorder( | ||
borderRadius: BorderRadius.circular(15), | ||
), | ||
), | ||
child: SizedBox( | ||
width: double.infinity, | ||
height: 50, | ||
child: Center(child: Text("Sign In"))), | ||
), | ||
), | ||
SizedBox(height: 40), | ||
], | ||
); | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Constant constructors are more performant
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
+1 please remove this kind of line
It's there for a reason