1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- import 'package:app_flowy/startup/startup.dart';
- import 'package:app_flowy/user/domain/i_splash.dart';
- import 'package:app_flowy/user/presentation/sign_up_screen.dart';
- import 'package:app_flowy/workspace/presentation/home/home_screen.dart';
- import 'package:dartz/dartz.dart';
- import 'package:flowy_infra/time/duration.dart';
- import 'package:flowy_infra_ui/widget/route/animation.dart';
- import 'package:flowy_sdk/protobuf/flowy-user/protobuf.dart';
- import 'package:app_flowy/user/domain/i_auth.dart';
- import 'package:app_flowy/user/infrastructure/repos/auth_repo.dart';
- import 'package:flutter/material.dart';
- class AuthImpl extends IAuth {
- AuthRepository repo;
- AuthImpl({
- required this.repo,
- });
- @override
- Future<Either<UserProfile, UserError>> signIn(String? email, String? password) {
- return repo.signIn(email: email, password: password);
- }
- @override
- Future<Either<NewUser, UserError>> signUp(String? name, String? password, String? email) {
- return repo.signUp(name: name, password: password, email: email).then((result) {
- return result.fold(
- (tuple) => left(
- NewUser(
- profile: tuple.value1,
- workspaceId: tuple.value2,
- ),
- ),
- (error) => right(error));
- });
- }
- @override
- Future<Either<Unit, UserError>> signOut() {
- return repo.signOut();
- }
- }
- class AuthRouterImpl extends IAuthRouter {
- @override
- void pushForgetPasswordScreen(BuildContext context) {
- // TODO: implement showForgetPasswordScreen
- }
- @override
- void pushWelcomeScreen(BuildContext context, UserProfile userProfile) {
- getIt<ISplashRoute>().pushWelcomeScreen(context, userProfile);
- }
- @override
- void pushSignUpScreen(BuildContext context) {
- Navigator.of(context).push(
- PageRoutes.fade(
- () => SignUpScreen(router: getIt<IAuthRouter>()),
- ),
- );
- }
- @override
- void pushHomeScreen(BuildContext context, UserProfile profile, String workspaceId) {
- Navigator.push(
- context,
- PageRoutes.fade(() => HomeScreen(profile, workspaceId), RouteDurations.slow.inMilliseconds * .001),
- );
- }
- }
|