Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[HOLD for payment 2024-02-07] [$500] Search Page opens in Background when delete Reciept Confirm Modal is visible #29511

Closed
2 of 6 tasks
m-natarajan opened this issue Oct 12, 2023 · 101 comments
Assignees
Labels
Awaiting Payment Auto-added when associated PR is deployed to production Bug Something is broken. Auto assigns a BugZero manager. Daily KSv2 Engineering External Added to denote the issue can be worked on by a contributor

Comments

@m-natarajan
Copy link

m-natarajan commented Oct 12, 2023

If you haven’t already, check out our contributing guidelines for onboarding and email [email protected] to request to join our Slack channel!


Version Number: 1.3.83-5
Reproducible in staging?: Yes
Reproducible in production?: Yes
If this was caught during regression testing, add the test name, ID and link from TestRail:
Email or phone of affected tester (no customers):
Logs: https://stackoverflow.com/c/expensify/questions/4856
Expensify/Expensify Issue URL:
Issue reported by: @ishpaul777
Slack conversation: https://expensify.slack.com/archives/C049HHMV9SM/p1697143133874499

Action Performed:

  1. Navigate to Distance Request money and request money from Location "X" to Location "Y" in a workspace.
  2. Navigation to Money Request Details and Open the Map Image
  3. Click on Threedot and Click Delete
  4. Navigate to search page using CMD+K

Expected Result:

Attachment modal is also closed.

Actual Result:

Attachment modal remains open and Search Page is open in background.

Workaround:

Unknown

Platforms:

Which of our officially supported platforms is this issue occurring on?

  • Android: Native
  • Android: mWeb Chrome
  • iOS: Native
  • iOS: mWeb Safari
  • MacOS: Chrome / Safari
  • MacOS: Desktop

Screenshots/Videos

Android: Native
Android: mWeb Chrome
iOS: Native
iOS: mWeb Safari
MacOS: Chrome / Safari
Screen.Recording.2023-10-13.at.2.05.30.AM.mov
delete.search.mp4
MacOS: Desktop
Screen.Recording.2023-10-13.at.2.18.06.AM.mov

View all open jobs on GitHub

Upwork Automation - Do Not Edit
  • Upwork Job URL: https://www.upwork.com/jobs/~01f56f13a4f213744d
  • Upwork Job ID: 1712594130617856000
  • Last Price Increase: 2023-11-02
  • Automatic offers:
    • aimane-chnaif | Reviewer | 28062789
@m-natarajan m-natarajan added External Added to denote the issue can be worked on by a contributor Daily KSv2 Bug Something is broken. Auto assigns a BugZero manager. labels Oct 12, 2023
@melvin-bot melvin-bot bot changed the title Search Page opens in Background when delete Reciept Confirm Modal is visible [$500] Search Page opens in Background when delete Reciept Confirm Modal is visible Oct 12, 2023
@melvin-bot
Copy link

melvin-bot bot commented Oct 12, 2023

Triggered auto assignment to @trjExpensify (Bug), see https://stackoverflow.com/c/expensify/questions/14418 for more details.

@melvin-bot
Copy link

melvin-bot bot commented Oct 12, 2023

Job added to Upwork: https://www.upwork.com/jobs/~01f56f13a4f213744d

@melvin-bot
Copy link

melvin-bot bot commented Oct 12, 2023

Bug0 Triage Checklist (Main S/O)

  • This "bug" occurs on a supported platform (ensure Platforms in OP are ✅)
  • This bug is not a duplicate report (check E/App issues and #expensify-bugs)
    • If it is, comment with a link to the original report, close the issue and add any novel details to the original issue instead
  • This bug is reproducible using the reproduction steps in the OP. S/O
    • If the reproduction steps are clear and you're unable to reproduce the bug, check with the reporter and QA first, then close the issue.
    • If the reproduction steps aren't clear and you determine the correct steps, please update the OP.
  • This issue is filled out as thoroughly and clearly as possible
    • Pay special attention to the title, results, platforms where the bug occurs, and if the bug happens on staging/production.
  • I have reviewed and subscribed to the linked Slack conversation to ensure Slack/Github stay in sync

@melvin-bot melvin-bot bot added the Help Wanted Apply this label when an issue is open to proposals by contributors label Oct 12, 2023
@melvin-bot
Copy link

melvin-bot bot commented Oct 12, 2023

Triggered auto assignment to Contributor-plus team member for initial proposal review - @aimane-chnaif (External)

@zukilover
Copy link
Contributor

zukilover commented Oct 13, 2023

Proposal

Please re-state the problem that we are trying to solve in this issue.

Search Page opens in Background when delete Reciept Confirm Modal is visible

What is the root cause of that problem?

When opening the search modal, closeConfirmModal is only closing the delete confirmation modal itself, and not reading from is isNavigating to trigger the removal of the attachment modal.

const closeConfirmModal = useCallback(() => {
setIsAttachmentInvalid(false);
setIsDeleteReceiptConfirmModalVisible(false);
}, []);

What changes do you think we should make in order to solve the problem?

Dismiss attachment modal if it is navigating to /search (opening search modal), e.g.:

const closeConfirmModal = useCallback((isNavigating) => {
        setIsAttachmentInvalid(false);
        setIsDeleteReceiptConfirmModalVisible(false);
        if (isNavigating) {
            Navigation.dismissModal(props.report.reportID);
        }
    }, []);

Result:

modal.mp4

@tienifr
Copy link
Contributor

tienifr commented Oct 13, 2023

Proposal

Please re-state the problem that we are trying to solve in this issue.

Search Page opens in Background when delete Reciept Confirm Modal is visible

What is the root cause of that problem?

When the modal is open, we store the onclose function, and clear it when the modal is close. But in this case, we have two modals are open at the same time, so when we open the second modal, onClose on first modal will be replaced by the one of second modal -> When we navigate to search page, just the onClose of second modal is executed

Modal.setCloseModal(onClose);
} else if (wasVisible && !isVisible) {
Modal.willAlertModalBecomeVisible(false);
Modal.setCloseModal(null);

What changes do you think we should make in order to solve the problem?

As we can see there are more than 1 modal are open at the same time, that why we should store their onClose in the object (closeModals = {key1: func, key2: func,...}).
When the modal is mounted, we will assign the free key to identify this modal (the key that don't have value). If the modal is open, we will store the onClose to this key, and clear it when the modal is close

After users press CMD + K to open search page we will execute Modal.close()

Modal.close(() => Navigation.navigate(ROUTES.SEARCH));

In Modal.close, we will execute all the onClose functions, then reset this object to empty ({})

@redpanda-bit
Copy link
Contributor

Proposal

Please re-state the problem that we are trying to solve in this issue.

Search page opens behind attachment modal. Leaving search page not usable unless the modal is manually closed.

What is the root cause of that problem?

This is a navigation error where the modal screen (ReportAttachments) remains mounted when navigating to the search page. No Navigation.dismissModal is called and due to this the search screen is pushed on top of the ReportAttachment modal.

navigation-state

What changes do you think we should make in order to solve the problem?

We need to dismiss both, confirmation and attachment modals, in order to accomplish this I propose to create a new function Navigation.dismissAllModals. This new function within Navigation.js would remove any modal screens from the navigation state.

// https://github.com/Expensify/App/blob/main/src/libs/actions/Modal.ts
function closeAll(callback) {
    Navigation.dismissAllModals();
    callback();
}

// https://github.com/Expensify/App/blob/main/src/libs/Navigation/AppNavigator/AuthScreens.js#L201
Modal.closeAll(() => {
    Navigation.navigate(ROUTES.SEARCH);
});

// https://github.com/Expensify/App/blob/main/src/libs/Navigation/Navigation.js
function dismissAllModals() {
    navigationRef.current.dispatch((state) => {
        let newState = {...state};
        newState.routes = removeModalScreens(newState.routes);
        newState.index = newState.routes.length - 1;
        const action = getActionFromState(newState, linkingConfig.config);
        return action;
    });
}

What alternative solutions did you explore? (Optional)

Please also consider this solution. Modal.closeAll can also only remove the 2 top most modals if the user experience is guaranteed to be 2 modals max.

function closeAll(callback: () => void) {
    close(() => {}); // 1 
    Navigation.dismissAllModals(); // 2
    callback();  // navigate
}

@ishpaul777
Copy link
Contributor

ishpaul777 commented Oct 14, 2023

I have proposed the exact same solution @tienifr in #27277 (comment) a while ago

@melvin-bot melvin-bot bot added the Overdue label Oct 16, 2023
@melvin-bot
Copy link

melvin-bot bot commented Oct 16, 2023

@trjExpensify, @aimane-chnaif Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@trjExpensify
Copy link
Contributor

If another similar instance of this problem was solved by #27639 previously, I'm curious if this is a regression then? CC: @bernhardoj @s77rt as you have experience with this :)

@melvin-bot melvin-bot bot removed the Overdue label Oct 16, 2023
@s77rt
Copy link
Contributor

s77rt commented Oct 16, 2023

Not a regression. The plan was that any given time there should be only one modal open. But now this does not seem to be the case any more.

@trjExpensify
Copy link
Contributor

Cool, well I think this is pretty low value anyhow. The reality of anyone seriously clicking CMD+K to "search" while also in the process of of completing the delete receipt confirmation modal is slim to none:

  1. Navigate to Distance Request money and request money from Location "X" to Location "Y" in a workspace.
  2. Navigation to Money Request Details and Open the Map Image
  3. Click on Threedot and Click Delete
    4 Navigate to search page using CMD+K

Given that, I'm inclined to close this issue as we have far more pressing issues in the repo. What's your thoughts?

@melvin-bot
Copy link

melvin-bot bot commented Oct 19, 2023

📣 It's been a week! Do we have any satisfactory proposals yet? Do we need to adjust the bounty for this issue? 💸

@aimane-chnaif
Copy link
Contributor

I think this should be fixed. This bug itself is not critical but another weird bug (critical) happening after following repro step.

Report screen got frozen. After switching to another chat and come back, it's unfrozon but when click receipt image, got stuck again.

Screen.Recording.2023-10-19.at.5.28.08.PM.mov

@trjExpensify
Copy link
Contributor

I don't think you can call that critical given the steps to get here are pretty farfetched to happen in reality. But fair enough, if the app is freezing as a result we can look at it.

@melvin-bot melvin-bot bot added the Overdue label Oct 23, 2023
@melvin-bot
Copy link

melvin-bot bot commented Oct 23, 2023

@trjExpensify, @aimane-chnaif Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@trjExpensify
Copy link
Contributor

Proposals awaiting a review.

@melvin-bot melvin-bot bot removed the Overdue label Oct 23, 2023
@melvin-bot
Copy link

melvin-bot bot commented Oct 26, 2023

@trjExpensify @aimane-chnaif this issue was created 2 weeks ago. Are we close to approving a proposal? If not, what's blocking us from getting this issue assigned? Don't hesitate to create a thread in #expensify-open-source to align faster in real time. Thanks!

@melvin-bot melvin-bot bot added the Overdue label Oct 26, 2023
@melvin-bot melvin-bot bot added Reviewing Has a PR in review Weekly KSv2 and removed Daily KSv2 labels Dec 17, 2023
@melvin-bot melvin-bot bot added Monthly KSv2 and removed Weekly KSv2 labels Jan 9, 2024
Copy link

melvin-bot bot commented Jan 9, 2024

This issue has not been updated in over 15 days. @trjExpensify, @jasperhuangg, @aimane-chnaif, @tsa321 eroding to Monthly issue.

P.S. Is everyone reading this sure this is really a near-term priority? Be brave: if you disagree, go ahead and close it out. If someone disagrees, they'll reopen it, and if they don't: one less thing to do!

@trjExpensify trjExpensify added Weekly KSv2 and removed Monthly KSv2 labels Jan 9, 2024
@trjExpensify
Copy link
Contributor

PR is in review. Can we get an update on progress please?

@jasperhuangg
Copy link
Contributor

Looks like review has been progressing steadily in the last few days on #33203

@trjExpensify
Copy link
Contributor

That hit staging yesterday! What are the next steps here?

@aimane-chnaif
Copy link
Contributor

Waiting for production hit

@melvin-bot melvin-bot bot added Weekly KSv2 Awaiting Payment Auto-added when associated PR is deployed to production and removed Weekly KSv2 labels Jan 31, 2024
@melvin-bot melvin-bot bot changed the title [$500] Search Page opens in Background when delete Reciept Confirm Modal is visible [HOLD for payment 2024-02-07] [$500] Search Page opens in Background when delete Reciept Confirm Modal is visible Jan 31, 2024
Copy link

melvin-bot bot commented Jan 31, 2024

Reviewing label has been removed, please complete the "BugZero Checklist".

@melvin-bot melvin-bot bot removed the Reviewing Has a PR in review label Jan 31, 2024
Copy link

melvin-bot bot commented Jan 31, 2024

The solution for this issue has been 🚀 deployed to production 🚀 in version 1.4.33-5 and is now subject to a 7-day regression period 📆. Here is the list of pull requests that resolve this issue:

If no regressions arise, payment will be issued on 2024-02-07. 🎊

For reference, here are some details about the assignees on this issue:

Copy link

melvin-bot bot commented Jan 31, 2024

BugZero Checklist: The PR fixing this issue has been merged! The following checklist (instructions) will need to be completed before the issue can be closed:

  • [@aimane-chnaif] The PR that introduced the bug has been identified. Link to the PR:
  • [@aimane-chnaif] The offending PR has been commented on, pointing out the bug it caused and why, so the author and reviewers can learn from the mistake. Link to comment:
  • [@aimane-chnaif] A discussion in #expensify-bugs has been started about whether any other steps should be taken (e.g. updating the PR review checklist) in order to catch this type of bug sooner. Link to discussion:
  • [@aimane-chnaif] Determine if we should create a regression test for this bug.
  • [@aimane-chnaif] If we decide to create a regression test for the bug, please propose the regression test steps to ensure the same bug will not reach production again.
  • [@trjExpensify] Link the GH issue for creating/updating the regression test once above steps have been agreed upon:

@aimane-chnaif
Copy link
Contributor

This is old issue and not able to find offending PR. Since this was rare user case, hard to catch.

Regression Test Proposal

  1. Create manual request with receipt.
  2. Open transaction detail page and click receipt preview to open receipt modal.
  3. Click three dots menu and click delete receipt to open delete confirm modal.
  4. Press CMD + K to open Search page
  5. Verify that both modals are closed and then Search page shows
  6. Close Search page and repeat Step 3
  7. Press ESC
  8. Verify that only delete confirmation modal is closed and receipt modal keeps showing

@melvin-bot melvin-bot bot added Daily KSv2 and removed Weekly KSv2 labels Feb 6, 2024
@trjExpensify
Copy link
Contributor

Agree it's edge case, and a regression test would be extraneous.

Payment summary as follows:

  • @ishpaul777: $50 for the bug report (it was reported prior to the program change) - offer sent!
  • @tsa321: $500 for the fix - offer sent!
  • @aimane-chnaif: $500 for C+ - paid!

@tsa321
Copy link
Contributor

tsa321 commented Feb 8, 2024

@trjExpensify Thank you, I have accepted the offer...

@ishpaul777
Copy link
Contributor

@trjExpensify Accepted offer! Thank you! 🙇‍♂️

@trjExpensify
Copy link
Contributor

@ishpaul777 - paid
@tsa321 - paid

Closing, thanks everyone!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Awaiting Payment Auto-added when associated PR is deployed to production Bug Something is broken. Auto assigns a BugZero manager. Daily KSv2 Engineering External Added to denote the issue can be worked on by a contributor
Projects
None yet
Development

No branches or pull requests