Skip to content

Commit

Permalink
TF-3002 [WEB] Allow select All folder from destination picker when …
Browse files Browse the repository at this point in the history
…search
  • Loading branch information
dab246 committed Oct 2, 2024
1 parent 31e8b53 commit 610e09e
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 33 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -481,8 +481,12 @@ class DestinationPickerView extends GetWidget<DestinationPickerController>
color: Colors.transparent,
child: InkWell(
onTap: () {
controller.selectMailboxAction(PresentationMailbox.unifiedMailbox);
controller.dispatchSelectMailboxDestination(context);
if (mailboxIdSelected != null
&& mailboxIdSelected != PresentationMailbox.unifiedMailbox.id
) {
controller.selectMailboxAction(PresentationMailbox.unifiedMailbox);
controller.dispatchSelectMailboxDestination(context);
}
},
customBorder: const RoundedRectangleBorder(borderRadius: BorderRadius.all(Radius.circular(8))),
hoverColor: AppColor.colorMailboxHovered,
Expand Down Expand Up @@ -511,15 +515,16 @@ class DestinationPickerView extends GetWidget<DestinationPickerController>
),
)),
const SizedBox(width: 8),
if (actions == MailboxActions.select && (mailboxIdSelected == null ||
mailboxIdSelected == PresentationMailbox.unifiedMailbox.id))
if (_validateDisplaySelectedIcon(
actions: actions,
mailboxIdSelected: mailboxIdSelected
))
Padding(
padding: EdgeInsets.only(
right: AppUtils.isDirectionRTL(context) ? 0 : 30.0,
left: AppUtils.isDirectionRTL(context) ? 30 : 0.0,
),
padding: const EdgeInsetsDirectional.only(end: 30.0),
child: SvgPicture.asset(
controller.imagePaths.icFilterSelected,
actions == MailboxActions.create
? controller.imagePaths.icSelectedSB
: controller.imagePaths.icFilterSelected,
width: 20,
height: 20,
fit: BoxFit.fill
Expand All @@ -532,6 +537,14 @@ class DestinationPickerView extends GetWidget<DestinationPickerController>
);
}

bool _validateDisplaySelectedIcon({
MailboxActions? actions,
MailboxId? mailboxIdSelected
}) {
return (actions == MailboxActions.select || actions == MailboxActions.create)
&& (mailboxIdSelected == null || mailboxIdSelected == PresentationMailbox.unifiedMailbox.id);
}

void _handleOpenMailboxNodeClick(MailboxNode mailboxNode) {
PresentationMailbox presentationMailbox;
final path = controller.findNodePath(mailboxNode.item.id)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1718,19 +1718,17 @@ class MailboxDashBoardController extends ReloadableController with UserSettingPo

if (destinationMailbox is! PresentationMailbox) return;

if (destinationMailbox != PresentationMailbox.unifiedMailbox &&
mailboxIdSelected != destinationMailbox.id) {

searchController.updateFilterEmail(
mailboxOption: Some(destinationMailbox),
beforeOption: const None(),
positionOption: searchController.sortOrderFiltered.value.isScrollByPosition()
? const Some(0)
: const None()
);
searchController.updateFilterEmail(
mailboxOption: destinationMailbox.id == PresentationMailbox.unifiedMailbox.id
? const None()
: Some(destinationMailbox),
beforeOption: const None(),
positionOption: searchController.sortOrderFiltered.value.isScrollByPosition()
? const Some(0)
: const None()
);

dispatchAction(StartSearchEmailAction());
}
dispatchAction(StartSearchEmailAction());
}

void selectReceiveTimeQuickSearchFilter(BuildContext context, EmailReceiveTimeType receiveTime) {
Expand Down
25 changes: 13 additions & 12 deletions lib/features/search/email/presentation/search_email_controller.dart
Original file line number Diff line number Diff line change
Expand Up @@ -600,19 +600,20 @@ class SearchEmailController extends BaseController
? await DialogRouter.pushGeneralDialog(routeName: AppRoutes.destinationPicker, arguments: arguments)
: await push(AppRoutes.destinationPicker, arguments: arguments);

if (destinationMailbox is PresentationMailbox) {
final mailboxSelected = destinationMailbox == PresentationMailbox.unifiedMailbox ? null : destinationMailbox;
if (mailboxSelected != null && mailbox?.id != mailboxSelected.id) {
_updateSimpleSearchFilter(
mailboxOption: Some(mailboxSelected),
beforeOption: const None(),
positionOption: emailSortOrderType.value.isScrollByPosition() ? const Some(0) : const None()
);
if (destinationMailbox is! PresentationMailbox) return;

if (context.mounted) {
_searchEmailAction(context);
}
}
_updateSimpleSearchFilter(
mailboxOption: destinationMailbox.id == PresentationMailbox.unifiedMailbox.id
? const None()
: Some(destinationMailbox),
beforeOption: const None(),
positionOption: emailSortOrderType.value.isScrollByPosition()
? const Some(0)
: const None()
);

if (context.mounted) {
_searchEmailAction(context);
}
}

Expand Down

0 comments on commit 610e09e

Please sign in to comment.