-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(deriv_auth): fix 2fa for social login
- Loading branch information
1 parent
3f3f1c0
commit b5f9044
Showing
3 changed files
with
226 additions
and
13 deletions.
There are no files selected for viewing
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,175 @@ | ||
# Deriv Auth UI | ||
This package contains the shared `Auth` UI for deriv apps. This was exctracted from `flutter-multipliers` and some modifications were made to make it more generic and flexible. | ||
|
||
## Features: | ||
|
||
- Provides basic layout for auth pages. | ||
- Handles form validation. | ||
- Handles state management for auth pages. | ||
|
||
## Getting Started: | ||
|
||
1. Add the package to your project: | ||
|
||
``` yaml | ||
dependencies: | ||
git: | ||
url: [email protected]:regentmarkets/flutter-deriv-packages.git | ||
path: packages/deriv_auth_ui | ||
ref: dev | ||
``` | ||
2. Import the package: | ||
``` dart | ||
import 'package:deriv_auth_ui/deriv_auth_ui.dart'; | ||
``` | ||
|
||
3. Wrap your MaterialApp with `DerivThemeProvider`: | ||
|
||
```dart | ||
DerivThemeProvider.builder( | ||
initialTheme: ThemeMode.dark, | ||
builder: (context) => MaterialApp( | ||
/// ... | ||
), | ||
), | ||
``` | ||
|
||
4. In your MaterialApp add the `DerivAuthUILocalization` delegate: | ||
|
||
```dart | ||
MaterialApp( | ||
localizationsDelegates: [ | ||
DerivAuthUILocalization.delegate, | ||
/// ... more localization delegates | ||
], | ||
) | ||
``` | ||
|
||
## Layouts provided: | ||
|
||
### - Get Started Flow | ||
- **Get Started Layout** | ||
``` dart | ||
DerivGetStartedLayout( | ||
slides: [ | ||
// List of instances of DerivGetStartedSlideModel | ||
], | ||
appLogoIconPath: appLogoIconPath, | ||
backgroundImagePath: backgroundImagePath, | ||
onLoginTapped: () {}, | ||
onSignupTapped: () {}, | ||
); | ||
``` | ||
### - Login Flow | ||
- **Login Layout** | ||
``` dart | ||
DerivLoginLayout( | ||
welcomeLabel: 'Welcome back!', | ||
greetingLabel: | ||
'Log in to your Deriv account to start trading and investing.', | ||
onResetPassTapped: () { | ||
// Navigate to reset password page | ||
}, | ||
onSignupTapped: () { | ||
// Navigate to signup page | ||
}, | ||
onLoginError: (DerivAuthErrorState error) { | ||
// Show error message | ||
}, | ||
onLoggedIn: (DerivAuthLoggedInState state) { | ||
// Navigate to home page | ||
}, | ||
onSocialAuthButtonPressed: (SocialAuthProvider provider) { | ||
// Handle social auth | ||
}, | ||
); | ||
``` | ||
- **2FA Layout** | ||
``` dart | ||
// For 2FA with email and password | ||
Deriv2FALayout.systemLogin( | ||
email: email, | ||
password: password, | ||
); | ||
// For 2FA with social auth | ||
Deriv2FALayout.socialLogin( | ||
socialAuthDto: socialAuthDto, | ||
); | ||
// For 2FA with oneAll social login | ||
Deriv2FALayout.oneAll( | ||
oneAllConnectionToken: oneAllConnectionToken, | ||
); | ||
``` | ||
### - Signup Flow | ||
- **Signup Layout** | ||
``` dart | ||
DerivSignupLayout( | ||
signupPageLabel: 'Start trading with Deriv', | ||
signupPageDescription: | ||
'Join over 1 million traders worldwide who loves trading at Deriv.', | ||
onSocialAuthButtonPressed: (SocialAuthProvider provider) {}, | ||
onSingupError: (DerivSignupErrorState error) {}, | ||
onSingupEmailSent: (String email) {}, | ||
onSignupPressed: () {}, | ||
onLoginTapped: () {}, | ||
); | ||
``` | ||
- **Verify Email Layout** | ||
``` dart | ||
DerivVerifyEmailLayout( | ||
email: email, | ||
onEmailNotReceivedPressed: () {}, | ||
); | ||
``` | ||
- **Email not received layout** | ||
``` dart | ||
DerivEmailNotReceivedLayout( | ||
onReEnterEmailPressed: () {}, | ||
); | ||
``` | ||
- **Verification Done Layout** | ||
``` dart | ||
DerivVerificationDoneLayout( | ||
verificationCode: '123456', | ||
onContinuePressed: () {}, | ||
); | ||
``` | ||
- **Country Selection Layout** | ||
``` dart | ||
DerivCountrySelectionLayout( | ||
onNextPressed: () {}, | ||
verificationCode: '123456', | ||
residences: residences, | ||
); | ||
``` | ||
- **Set Password Layout** | ||
``` dart | ||
DerivSetPasswordLayout( | ||
onDerivAuthState: (BuildContext, DerivAuthState) {}, | ||
onDerivSignupState: (BuildContext, DerivSignupState) {}, | ||
onPreviousPressed: () {}, | ||
verificationCode: '123456', | ||
residence: 'residence', | ||
); | ||
``` | ||
### - Reset Password Flow | ||
- **Reset Password Layout** | ||
``` dart | ||
DerivResetPassLayout( | ||
onResetPassError: (String? error) {}, | ||
), | ||
``` | ||
- **Choose New Password Layout** | ||
``` dart | ||
DerivChooseNewPassLayout( | ||
onResetPassError: (String? error) {}, | ||
onResetPassSucceed: () {}, | ||
token: token, | ||
), | ||
``` | ||
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
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