Skip to content

Commit

Permalink
feat: integrate side menu screen (#61)
Browse files Browse the repository at this point in the history
# Conflicts:
#	lib/modules/home/home_presenter.dart
  • Loading branch information
markgravity committed Jun 21, 2021
1 parent 138b5fe commit fae74f7
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 11 deletions.
10 changes: 10 additions & 0 deletions lib/modules/home/home_presenter.dart
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ class HomePresenterImpl extends HomePresenter
didSwipeDown.voidListen(_didSwipeDown).addTo(disposeBag);
userAvatarDidTap.voidListen(_userAvatarDidTap).addTo(disposeBag);
currentPageDidChange.listen(_currentPageDidChange).addTo(disposeBag);
sideMenuDidShow.voidListen(_sideMenuDidShow).addTo(disposeBag);
sideMenuDidDismiss.voidListen(_sideMenuDidDismiss).addTo(disposeBag);

surveysDidFetchFromCached
.listen(_surveysDidFetchFromCached)
Expand Down Expand Up @@ -128,4 +130,12 @@ class HomePresenterImpl extends HomePresenter
void _currentPageDidChange(int page) {
view.setCurrentPage(page);
}

void _sideMenuDidShow() {
view.setUserInteractionEnable(isEnabled: false);
}

void _sideMenuDidDismiss() {
view.setUserInteractionEnable(isEnabled: true);
}
}
23 changes: 20 additions & 3 deletions lib/modules/side_menu/side_menu_interactor.dart
Original file line number Diff line number Diff line change
@@ -1,10 +1,27 @@
part of 'side_menu_module.dart';

abstract class SideMenuInteractorDelegate {}
abstract class SideMenuInteractorDelegate {
BehaviorSubject<void> get logoutDidSuccess;
}

abstract class SideMenuInteractor
extends Interactor<SideMenuInteractorDelegate> {}
extends Interactor<SideMenuInteractorDelegate> {
UserInfo get authenticatedUser;
void logout();
}

class SideMenuInteractorImpl extends SideMenuInteractor {
//
final AuthRepository _authRepository = locator.get();

@override
UserInfo get authenticatedUser => _authRepository.user!;

@override
void logout() {
_authRepository
.logout()
.then((value) => delegate?.logoutDidSuccess.add(null))
.onError<Exception>(
(error, stackTrace) => delegate?.logoutDidSuccess.add(null));
}
}
3 changes: 3 additions & 0 deletions lib/modules/side_menu/side_menu_module.dart
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,11 @@ import 'package:flutter_platform_widgets/flutter_platform_widgets.dart';
import 'package:streams_provider/streams_provider.dart';
import 'package:survey/core/viper/module.dart';
import 'package:survey/models/user_info.dart';
import 'package:survey/modules/login/login_module.dart';
import 'package:survey/modules/screen.dart';
import 'package:flutter_gen/gen_l10n/app_localizations.dart';
import 'package:survey/repositories/auth_repository.dart';
import 'package:survey/services/locator/locator_service.dart';
part 'side_menu_interactor.dart';

part 'side_menu_router.dart';
Expand Down
24 changes: 24 additions & 0 deletions lib/modules/side_menu/side_menu_presenter.dart
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,30 @@ abstract class SideMenuPresenter

class SideMenuPresenterImpl extends SideMenuPresenter
implements SideMenuViewDelegate, SideMenuInteractorDelegate {
SideMenuPresenterImpl() {
logoutButtonDidTap.voidListen(_logoutButtonDidTap).addTo(disposeBag);
logoutDidSuccess.voidListen(_logoutDidSuccess).addTo(disposeBag);
stateDidInit.voidListen(_stateDidInit).addTo(disposeBag);
}

@override
final stateDidInit = BehaviorSubject<void>();

@override
final logoutButtonDidTap = BehaviorSubject<void>();

@override
final logoutDidSuccess = BehaviorSubject<void>();

void _logoutButtonDidTap() {
interactor.logout();
}

void _logoutDidSuccess() {
router.replaceToLoginScreen(view.context);
}

void _stateDidInit() {
view.setUser(interactor.authenticatedUser);
}
}
9 changes: 7 additions & 2 deletions lib/modules/side_menu/side_menu_router.dart
Original file line number Diff line number Diff line change
@@ -1,7 +1,12 @@
part of 'side_menu_module.dart';

abstract class SideMenuRouter extends Router {}
abstract class SideMenuRouter extends Router {
void replaceToLoginScreen(BuildContext context);
}

class SideMenuRouterImpl extends SideMenuRouter {
//
@override
void replaceToLoginScreen(BuildContext context) {
context.navigator.pushReplacementNamed(LoginModule.routePath);
}
}
9 changes: 3 additions & 6 deletions lib/modules/side_menu/side_menu_view.dart
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
part of 'side_menu_module.dart';

abstract class SideMenuViewDelegate {
BehaviorSubject<void> get stateDidInit;

BehaviorSubject<void> get logoutButtonDidTap;
}

Expand All @@ -23,12 +25,7 @@ class _SideMenuViewImplState
@override
void initState() {
super.initState();

final user = UserInfo();
user.email = "[email protected]";
user.avatarUrl =
"https://en.gravatar.com/userimage/137591909/6a42a5a20cd79d50edb957644bc41b0c.png";
setUser(user);
delegate?.stateDidInit.add(null);
}

@override
Expand Down

0 comments on commit fae74f7

Please sign in to comment.