Skip to content

Commit

Permalink
TF-3025 Correctly update the action for the selection list when perfo…
Browse files Browse the repository at this point in the history
…rming some action `read/start/...` on each element
  • Loading branch information
dab246 authored and hoangdat committed Oct 14, 2024
1 parent 2e0026b commit c549397
Show file tree
Hide file tree
Showing 4 changed files with 288 additions and 111 deletions.
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@

import 'package:core/presentation/extensions/color_extension.dart';
import 'package:core/presentation/resources/image_paths.dart';
import 'package:core/presentation/views/button/icon_button_web.dart';
import 'package:core/presentation/views/button/tmail_button_widget.dart';
import 'package:flutter/material.dart';
import 'package:flutter_svg/flutter_svg.dart';
import 'package:get/get.dart';
import 'package:jmap_dart_client/jmap/mail/mailbox/mailbox.dart';
import 'package:model/email/email_action_type.dart';
Expand Down Expand Up @@ -37,114 +36,103 @@ class AppBarSelectionMode extends StatelessWidget {
final isAllBelongToTheSameMailbox = listEmail.isAllBelongToTheSameMailbox(mapMailbox);

return Row(children: [
buildIconWeb(
icon: SvgPicture.asset(
_imagePaths.icClose,
colorFilter: AppColor.colorTextButton.asFilter(),
fit: BoxFit.fill),
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
tooltip: AppLocalizations.of(context).cancel,
onTap: onCancelSelection),
Expanded(child: Text(
TMailButtonWidget.fromIcon(
icon: _imagePaths.icClose,
iconSize: 25,
iconColor: AppColor.colorTextButton,
backgroundColor: Colors.transparent,
tooltipMessage: AppLocalizations.of(context).cancel,
onTapActionCallback: onCancelSelection,
),
Expanded(
child: Text(
AppLocalizations.of(context).count_email_selected(listEmail.length),
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: const TextStyle(
fontSize: 17,
fontWeight: FontWeight.w500,
color: AppColor.colorTextButton))),
buildIconWeb(
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
icon: SvgPicture.asset(
listEmail.isAllEmailRead
? _imagePaths.icUnread
: _imagePaths.icRead,
fit: BoxFit.fill),
tooltip: listEmail.isAllEmailRead
? AppLocalizations.of(context).unread
: AppLocalizations.of(context).read,
onTap: () => onHandleEmailAction?.call(
listEmail.isAllEmailRead
? EmailActionType.markAsUnread
: EmailActionType.markAsRead,
listEmail)),
fontSize: 17,
fontWeight: FontWeight.w500,
color: AppColor.colorTextButton
)
)
),
TMailButtonWidget.fromIcon(
icon: listEmail.isAllEmailRead
? _imagePaths.icUnread
: _imagePaths.icRead,
iconSize: 25,
backgroundColor: Colors.transparent,
tooltipMessage: listEmail.isAllEmailRead
? AppLocalizations.of(context).unread
: AppLocalizations.of(context).read,
onTapActionCallback: () => onHandleEmailAction?.call(
listEmail.isAllEmailRead
? EmailActionType.markAsUnread
: EmailActionType.markAsRead,
listEmail
),
),
const SizedBox(width: 5),
buildIconWeb(
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
icon: SvgPicture.asset(
listEmail.isAllEmailStarred
? _imagePaths.icUnStar
: _imagePaths.icStar,
fit: BoxFit.fill),
tooltip: listEmail.isAllEmailStarred
? AppLocalizations.of(context).not_starred
: AppLocalizations.of(context).starred,
onTap: () => onHandleEmailAction?.call(
listEmail.isAllEmailStarred
? EmailActionType.unMarkAsStarred
: EmailActionType.markAsStarred,
listEmail)),
TMailButtonWidget.fromIcon(
icon: listEmail.isAllEmailStarred
? _imagePaths.icUnStar
: _imagePaths.icStar,
iconSize: 25,
backgroundColor: Colors.transparent,
tooltipMessage: listEmail.isAllEmailStarred
? AppLocalizations.of(context).not_starred
: AppLocalizations.of(context).starred,
onTapActionCallback: () => onHandleEmailAction?.call(
listEmail.isAllEmailStarred
? EmailActionType.unMarkAsStarred
: EmailActionType.markAsStarred,
listEmail
),
),
const SizedBox(width: 5),
if (canSpamAndMove)
... [
buildIconWeb(
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
icon: SvgPicture.asset(_imagePaths.icMove, fit: BoxFit.fill),
tooltip: AppLocalizations.of(context).move,
onTap: () => onHandleEmailAction?.call(EmailActionType.moveToMailbox, listEmail)),
TMailButtonWidget.fromIcon(
icon: _imagePaths.icMove,
iconSize: 25,
backgroundColor: Colors.transparent,
tooltipMessage: AppLocalizations.of(context).move,
onTapActionCallback: () => onHandleEmailAction?.call(
EmailActionType.moveToMailbox,
listEmail
),
),
const SizedBox(width: 5),
buildIconWeb(
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
icon: SvgPicture.asset(isAllSpam
? _imagePaths.icNotSpam
: _imagePaths.icSpam,
fit: BoxFit.fill),
tooltip: isAllSpam
? AppLocalizations.of(context).un_spam
: AppLocalizations.of(context).mark_as_spam,
onTap: () => isAllSpam
? onHandleEmailAction?.call(EmailActionType.unSpam, listEmail)
: onHandleEmailAction?.call(EmailActionType.moveToSpam, listEmail.listEmailCanSpam(mapMailbox))),
TMailButtonWidget.fromIcon(
icon: isAllSpam
? _imagePaths.icNotSpam
: _imagePaths.icSpam,
iconSize: 25,
backgroundColor: Colors.transparent,
tooltipMessage: isAllSpam
? AppLocalizations.of(context).un_spam
: AppLocalizations.of(context).mark_as_spam,
onTapActionCallback: () => isAllSpam
? onHandleEmailAction?.call(EmailActionType.unSpam, listEmail)
: onHandleEmailAction?.call(EmailActionType.moveToSpam, listEmail.listEmailCanSpam(mapMailbox)),
),
const SizedBox(width: 5),
],
if (isAllBelongToTheSameMailbox)
...[
buildIconWeb(
minSize: 25,
iconSize: 25,
iconPadding: const EdgeInsets.all(5),
splashRadius: 15,
icon: SvgPicture.asset(
canDeletePermanently
? _imagePaths.icDeleteComposer
: _imagePaths.icDelete,
colorFilter: canDeletePermanently
? AppColor.colorDeletePermanentlyButton.asFilter()
: AppColor.primaryColor.asFilter(),
width: 20,
height: 20,
fit: BoxFit.fill),
tooltip: canDeletePermanently
? AppLocalizations.of(context).delete_permanently
: AppLocalizations.of(context).move_to_trash,
onTap: () => canDeletePermanently
? onHandleEmailAction?.call(EmailActionType.deletePermanently, listEmail)
: onHandleEmailAction?.call(EmailActionType.moveToTrash, listEmail)),
const SizedBox(width: 10)
],
TMailButtonWidget.fromIcon(
icon: _imagePaths.icDeleteComposer,
iconSize: 20,
backgroundColor: Colors.transparent,
iconColor: canDeletePermanently
? AppColor.colorDeletePermanentlyButton
: AppColor.primaryColor,
tooltipMessage: canDeletePermanently
? AppLocalizations.of(context).delete_permanently
: AppLocalizations.of(context).move_to_trash,
onTapActionCallback: () => canDeletePermanently
? onHandleEmailAction?.call(EmailActionType.deletePermanently, listEmail)
: onHandleEmailAction?.call(EmailActionType.moveToTrash, listEmail),
),
]);
}
}
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@

import 'package:core/core.dart';
import 'package:core/presentation/state/failure.dart';
import 'package:core/presentation/state/success.dart';
import 'package:dartz/dartz.dart';
import 'package:jmap_dart_client/jmap/account_id.dart';
import 'package:jmap_dart_client/jmap/core/filter/filter.dart';
Expand All @@ -26,11 +27,11 @@ class SearchEmailInteractor {
Set<Comparator>? sort,
Filter? filter,
Properties? properties,
bool isRefreshChange = false,
bool needRefreshSearchState = false,
}
) async* {
try {
if (isRefreshChange) {
if (needRefreshSearchState) {
yield Right(RefreshingSearchState());
} else {
yield Right(SearchingState());
Expand Down
25 changes: 17 additions & 8 deletions lib/features/thread/presentation/thread_controller.dart
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,8 @@ class ThreadController extends BaseController with EmailActionController {
final ScrollController listEmailController = ScrollController();
final FocusNode focusNodeKeyBoard = FocusNode();
final latestEmailSelectedOrUnselected = Rxn<PresentationEmail>();
@visibleForTesting
bool isListEmailScrollViewJumping = false;

StreamSubscription<html.Event>? _resizeBrowserStreamSubscription;

Expand Down Expand Up @@ -458,7 +460,9 @@ class ThreadController extends BaseController with EmailActionController {
isSearchEmailRunning: searchController.isSearchEmailRunning
);
mailboxDashBoardController.updateEmailList(newListEmail);

if (mailboxDashBoardController.isSelectionEnabled()) {
mailboxDashBoardController.listEmailSelected.value = listEmailSelected;
}
canLoadMore = newListEmail.length >= ThreadConstants.maxCountEmails;

if (listEmailController.hasClients) {
Expand Down Expand Up @@ -490,7 +494,9 @@ class ThreadController extends BaseController with EmailActionController {
isSearchEmailRunning: searchController.isSearchEmailRunning
);
mailboxDashBoardController.updateEmailList(emailListSynced);

if (mailboxDashBoardController.isSelectionEnabled()) {
mailboxDashBoardController.listEmailSelected.value = listEmailSelected;
}
canLoadMore = newListEmail.length >= ThreadConstants.maxCountEmails;

if (mailboxDashBoardController.emailsInCurrentMailbox.isEmpty) {
Expand Down Expand Up @@ -578,7 +584,7 @@ class ThreadController extends BaseController with EmailActionController {
void _refreshEmailChanges({jmap.State? currentEmailState}) {
log('ThreadController::_refreshEmailChanges(): currentEmailState: $currentEmailState');
if (searchController.isSearchEmailRunning) {
_searchEmail(limit: limitEmailFetched, isRefreshChange: true);
_searchEmail(limit: limitEmailFetched, needRefreshSearchState: true);
} else {
final newEmailState = currentEmailState ?? _currentEmailState;
log('ThreadController::_refreshEmailChanges(): newEmailState: $newEmailState');
Expand Down Expand Up @@ -802,12 +808,13 @@ class ThreadController extends BaseController with EmailActionController {
searchController.clearTextSearch();
}

void _searchEmail({UnsignedInt? limit, bool isRefreshChange = false}) {
void _searchEmail({UnsignedInt? limit, bool needRefreshSearchState = false}) {
if (_session != null && _accountId != null) {
if (!isRefreshChange && listEmailController.hasClients) {
if (!needRefreshSearchState && listEmailController.hasClients) {
isListEmailScrollViewJumping = true;
listEmailController.jumpTo(0);
}
if (!isRefreshChange) {
if (!needRefreshSearchState) {
mailboxDashBoardController.emailsInCurrentMailbox.clear();
}
canSearchMore = false;
Expand All @@ -828,7 +835,7 @@ class ThreadController extends BaseController with EmailActionController {
moreFilterCondition: _getFilterCondition()
),
properties: EmailUtils.getPropertiesForEmailGetMethod(_session!, _accountId!),
isRefreshChange: isRefreshChange
needRefreshSearchState: needRefreshSearchState
));
} else {
consumeState(Stream.value(Left(SearchEmailFailure(NotFoundSessionException()))));
Expand Down Expand Up @@ -868,7 +875,9 @@ class ThreadController extends BaseController with EmailActionController {
isSearchEmailRunning: searchController.isSearchEmailRunning
);
mailboxDashBoardController.updateEmailList(newEmailListSynced);

if (mailboxDashBoardController.isSelectionEnabled()) {
mailboxDashBoardController.listEmailSelected.value = listEmailSelected;
}
canSearchMore = newEmailListSynced.length >= ThreadConstants.maxCountEmails;

if (PlatformInfo.isWeb) {
Expand Down
Loading

0 comments on commit c549397

Please sign in to comment.