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

[$250] LHN -When deleting expense on search, information doesn´t disappear from chat preview on LHN #53993

Open
2 of 8 tasks
IuliiaHerets opened this issue Dec 12, 2024 · 39 comments
Assignees
Labels
Bug Something is broken. Auto assigns a BugZero manager. Daily KSv2 Help Wanted Apply this label when an issue is open to proposals by contributors Internal Requires API changes or must be handled by Expensify staff Overdue

Comments

@IuliiaHerets
Copy link

IuliiaHerets commented Dec 12, 2024

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: 9.0.75-0
Reproducible in staging?: Yes
Reproducible in production?: Yes
If this was caught during regression testing, add the test name, ID and link from TestRail: https://expensify.testrail.io/index.php?/tests/view/5335362&group_by=cases:section_id&group_order=asc&group_id=296775
Email or phone of affected tester (no customers): [email protected]
Issue reported by: Applause Internal Team
Device used: Motorola MotoG60 - Android 12 - Chrome / Windows 10 - Chrome
App Component: Left Hand Navigation (LHN)

Action Performed:

  1. Open the staging.new.expensify.com
  2. Tap on the FAB and select "Create Expense"
  3. Complete the creation flow and submit the expense to any chat.
  4. Go to search section.
  5. Long tap on the just created expense and delete it.
  6. Return to LHN and check the message displayed on the preview of the chat where the expense was submitted.

Expected Result:

When an expense is deleted on search, the preview of the chat where this expense was submitted, should not display the expense information anymore.

Actual Result:

Expense information is still displayed on chat preview on LHN, after the expense was deleted on search section.
Issue reproduced only with Gmail account

Workaround:

Unknown

Platforms:

  • Android: Standalone
  • Android: HybridApp
  • Android: mWeb Chrome
  • iOS: Standalone
  • iOS: HybridApp
  • iOS: mWeb Safari
  • MacOS: Chrome / Safari
  • MacOS: Desktop

Screenshots/Videos

Bug6691822_1733984604638.LHN_Preview.mp4

View all open jobs on GitHub

Upwork Automation - Do Not Edit
  • Upwork Job URL: https://www.upwork.com/jobs/~021870237400147450769
  • Upwork Job ID: 1870237400147450769
  • Last Price Increase: 2025-01-03
@IuliiaHerets IuliiaHerets added Daily KSv2 Bug Something is broken. Auto assigns a BugZero manager. labels Dec 12, 2024
Copy link

melvin-bot bot commented Dec 12, 2024

Triggered auto assignment to @johncschuster (Bug), see https://stackoverflow.com/c/expensify/questions/14418 for more details. Please add this bug to a GH project, as outlined in the SO.

@johncschuster
Copy link
Contributor

I haven't gotten to dig into this one

@melvin-bot melvin-bot bot removed the Overdue label Dec 16, 2024
Copy link

melvin-bot bot commented Dec 20, 2024

@johncschuster Whoops! This issue is 2 days overdue. Let's get this updated quick!

@melvin-bot melvin-bot bot added the Overdue label Dec 20, 2024
@johncschuster johncschuster added the External Added to denote the issue can be worked on by a contributor label Dec 20, 2024
Copy link

melvin-bot bot commented Dec 20, 2024

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

@melvin-bot melvin-bot bot changed the title LHN -When deleting expense on search, information doesn´t disappear from chat preview on LHN [$250] LHN -When deleting expense on search, information doesn´t disappear from chat preview on LHN Dec 20, 2024
@melvin-bot melvin-bot bot added the Help Wanted Apply this label when an issue is open to proposals by contributors label Dec 20, 2024
Copy link

melvin-bot bot commented Dec 20, 2024

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

@melvin-bot melvin-bot bot removed the Overdue label Dec 20, 2024
@shamzahasan88
Copy link

I am here from Upwork, I can see the email contains +91 before @. Usually these kind of emails are being used to create multiple accounts with same email address.

For example, if my email is [email protected], then I can create multiple accounts with emails like [email protected], [email protected], and this is because I will receive any OTP or confirmation email at my original email, despite having these extra characters in given email.

What I can feel that your logic is dealing with original email, instead of this one (+91@gmail), can you please try this with a normal gmail address? Without any “+” thing?

Copy link

melvin-bot bot commented Dec 22, 2024

📣 @shamzahasan88! 📣
Hey, it seems we don’t have your contributor details yet! You'll only have to do this once, and this is how we'll hire you on Upwork.
Please follow these steps:

  1. Make sure you've read and understood the contributing guidelines.
  2. Get the email address used to login to your Expensify account. If you don't already have an Expensify account, create one here. If you have multiple accounts (e.g. one for testing), please use your main account email.
  3. Get the link to your Upwork profile. It's necessary because we only pay via Upwork. You can access it by logging in, and then clicking on your name. It'll look like this. If you don't already have an account, sign up for one here.
  4. Copy the format below and paste it in a comment on this issue. Replace the placeholder text with your actual details.
    Screen Shot 2022-11-16 at 4 42 54 PM
    Format:
Contributor details
Your Expensify account email: <REPLACE EMAIL HERE>
Upwork Profile Link: <REPLACE LINK HERE>

@email4shahbaz
Copy link

Hey, I have worked on this issue and identified root cause of the issue and fixed it. Please add me as a contributor so that I can post my Proposal:

Contributor details
Your Expensify account email: [email protected]
Upwork Profile Link: https://www.upwork.com/freelancers/~01d656418b6899f383

@melvin-bot melvin-bot bot added the Overdue label Dec 23, 2024
Copy link

melvin-bot bot commented Dec 23, 2024

✅ Contributor details stored successfully. Thank you for contributing to Expensify!

@email4shahbaz
Copy link

Proposal

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

LHN -When deleting expense on search, information doesn´t disappear from chat preview on LHN

What is the root cause of that problem?

  • When we delete an expense, it works properly and delete expense from backend but we never update search results.

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

On clicking 'Search' icon on top bar, it does not make call to search api because we have empty search query text.
We have to change following if condition to only return if isNetworkOffline meet but remove !searchInput.trim().length check in src/libs/actions/Report.ts:

function searchInServer(searchInput: string, policyID?: string) {
    if (isNetworkOffline || !searchInput.trim().length) {
        Onyx.set(ONYXKEYS.IS_SEARCHING_FOR_REPORTS, false);
        return;
    }

    // Why not set this in optimistic data? It won't run until the API request happens and while the API request is debounced
    // we want to show the loading state right away. Otherwise, we will see a flashing UI where the client options are sorted and
    // tell the user there are no options, then we start searching, and tell them there are no options again.
    Onyx.set(ONYXKEYS.IS_SEARCHING_FOR_REPORTS, true);
    searchForReports(searchInput, policyID);
}

So, final solution will work seamless and always bring updated data which will not show expense amount in this case.

 if (isNetworkOffline) {
        Onyx.set(ONYXKEYS.IS_SEARCHING_FOR_REPORTS, false);
        return;
 }

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

Nothing

What alternative solutions did you explore? (Optional)

Another solution might be to manually call an action to update onyx 'personalDetailsList' by removing expense from the selected user. But it could be less efficient.

@ZhenjaHorbach
Copy link
Contributor

@shamzahasan88
Thanks for your idea
And yes, we use + to create multiple accounts
But these new accounts have the same functionality as the main one
So I don't think this is related to the issue

@email4shahbaz
Thanks for your proposal
And have you tested it?
I'm not entirely sure that these changes are related to the issue
Plus, this fix doesn't work

@melvin-bot melvin-bot bot removed the Overdue label Dec 23, 2024
@email4shahbaz
Copy link

@ZhenjaHorbach
Please see attached video-cast, it reflects exactly the problem and it's solution:

Issue.53993.mp4

Here are the steps to follow to reproduce issue and see it's solution:

1-I create a new expesce by clicking + button and entere '999' as amount. Then I selected '[email protected]' and completed expense creation.

2-I clicked 'Search' icon on top right to see list of all chats, my newly created chat shows '[email protected] owes PKR 999.'

3-I selected that new created expense and removed it.

4-I again went to search, it still show that old values with PKR 999 (just because this search list is not being updated by any action)

5-To prove that we need to update search results in order to see those expense values updated, I entered one character in the search textfield, it immediately updated search results and removed 'RS.999' from that record.

So, that proves that in order to see updated records in search, we must call search api immediately without entering any search query text.

For this to work, we already have a useEffect in SearchRouterList.tsx component as follows:

useEffect(() => {
       ReportUserActions.searchInServer(autocompleteQueryValue.trim());
   }, [autocompleteQueryValue]);

Above code already make api call upon we click 'Search' icon on top right. So if we make my proposed change in Report.ts to ignoring 'searchInput.trim().length', it will always show an updated search result and will not show expense values which is already removed.

Thanks and let me know your thoughts.

@ZhenjaHorbach
Copy link
Contributor

ZhenjaHorbach commented Dec 23, 2024

@email4shahbaz
Could you follow QA steps (Or you can use the attached video), please ?

@email4shahbaz
Copy link

@email4shahbaz Could you follow QA steps (Or you can use the attached video), please ?

sure, give me few minutes.

@email4shahbaz
Copy link

email4shahbaz commented Dec 23, 2024

Hi @ZhenjaHorbach,

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

I’ve revisited my earlier proposal and realized that while it is valid, it addresses a different issue related to the functionality triggered by clicking the Search button on the top-right corner of the screen. Let’s now focus on the actual issue, which can be reproduced by following the QA steps or watching the video attached to the issue.

What is the root cause of that problem?

Inbox items are loaded using the Onyx key personalDetailsList. The expense value text is dynamically appended based on the Onyx-loaded collection of reports. Each report contains lastMessageHtml and lastMessageText fields, which remain unchanged even when an expense is removed.

Example

For instance, a chat might display the following text:
"[email protected] owes PKR 1,500.00"

This text is calculated and appended from the API response when a new expense is added. However, if an expense is removed and the total value of a report becomes 0, this text is not updated accordingly.
Below is a code snippet from src/libs/SidebarUtils.ts that illustrates how text is appended to inbox items:

javascript
Copy code
const lastActorDisplayName = OptionsListUtils.getLastActorDisplayName(lastActorDetails, hasMultipleParticipants);
let lastMessageTextFromReport = lastMessageTextFromReportProp;
if (!lastMessageTextFromReport) {
    lastMessageTextFromReport = OptionsListUtils.getLastMessageTextForReport(report, lastActorDetails, policy);
}

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

I propose modifying the handleDeleteExpenses function in src/components/Search/searchPageHeader.tsx to address this issue. Specifically, the changes will include:

Checking for Zero Total:

Add logic to detect when all expenses are removed, and the total value of the report is 0.

Updating Report Fields:

Dynamically update the lastMessageHtml and lastMessageText fields in the relevant report within the Onyx reports collection.

Syncing with Onyx:

Ensure these updates are synchronized with Onyx so the changes are reflected in the UI.

What specific scenarios should we cover in automated tests to prevent reintroducing this issue in the future?

This requires a UI test where we need to assert that the lastMessageHtml and lastMessageText of chat item is updated when all the expenses are deleted for a specific chat item.

What alternative solutions did you explore? (Optional)

Alternatively, I suggest enhancing the getLastMessageTextForReport function in src/libs/OptionsListUtils.ts, which is triggered during re-renders. This function fetches the last message text from the report or special cases based on specific conditions.

Since it has access to the variable lastVisibleReportActions, I propose adding logic to check:

If the last report action contains a message with the deleted key, and
If the report's total field equals 0.
In this case, we can replace the lastMessageHtml and lastMessageText fields with a custom message indicating that all expenses have been removed. Below is an example of the logic I implemented:

javascript
Copy code
if (lastOriginalReportAction && lastOriginalReportAction.message) {
    if (Array.isArray(lastOriginalReportAction.message) && lastOriginalReportAction.message.length > 0) {
        const firstMessage = lastOriginalReportAction.message[0];
        if (firstMessage && firstMessage.deleted) {
            if (report?.total === 0 && report.lastMessageText?.trim().length && report.lastMessageText !== 'All expenses removed') {
                return 'All expenses removed';
            }
        }
    }
}

Note:

Of course, we will replace that plain text message with a localized constant for better consistency and adaptability.

Outcome

I tested my alternative solution locally, and it worked as expected. The chat list screen dynamically updated the expense values, effectively resolving the inconsistency when expenses were removed.

Let me know if you have any suggestions or concerns.

Thanks!

Copy link

melvin-bot bot commented Dec 26, 2024

@johncschuster @ZhenjaHorbach 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 Dec 26, 2024
@melvin-bot melvin-bot bot removed the Overdue label Dec 30, 2024
@email4shahbaz
Copy link

email4shahbaz commented Dec 30, 2024

Yes, we can do it from BE too but there are many other conditions are added in getLastMessageTextForReport function in src/libs/OptionsListUtils.ts
to generate this text from frontend JavaScript

Also delete report api call from backend is not returning any data in the case of all expenses removed.

@ZhenjaHorbach
Copy link
Contributor

ZhenjaHorbach commented Dec 30, 2024

Yes, we can do it from BE too but there are many other conditions are added in getLastMessageTextForReport function in src/libs/OptionsListUtils.ts to generate this text from frontend JavaScript

It's true 😅
But I still think that the root cause of the issue is related with BE
And I don't think we need to add new message if we removed all expenses

But let's find out what an internal engineer thinks !
🎀👀🎀

Copy link

melvin-bot bot commented Dec 30, 2024

Triggered auto assignment to @tylerkaraszewski, see https://stackoverflow.com/c/expensify/questions/7972 for more details.

Copy link

melvin-bot bot commented Jan 3, 2025

@tylerkaraszewski, @johncschuster, @ZhenjaHorbach Whoops! This issue is 2 days overdue. Let's get this updated quick!

@melvin-bot melvin-bot bot added the Overdue label Jan 3, 2025
Copy link

melvin-bot bot commented Jan 3, 2025

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

@tylerkaraszewski
Copy link
Contributor

Are we suggesting that the backend should return empty strings for lastMessageText and lastMessageHtml after the expense is deleted?

@ZhenjaHorbach
Copy link
Contributor

Are we suggesting that the backend should return empty strings for lastMessageText and lastMessageHtml after the expense is deleted?

Not really
Backend should return actual lastMessageText and lastMessageHtml
And empty strings for lastMessageText and lastMessageHtml in case we have no more elements in the chat

@melvin-bot melvin-bot bot removed the Overdue label Jan 4, 2025
@johncschuster johncschuster moved this to Bugs and Follow Up Issues in [#whatsnext] #expense Jan 6, 2025
Copy link

melvin-bot bot commented Jan 7, 2025

@tylerkaraszewski, @johncschuster, @ZhenjaHorbach Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@melvin-bot melvin-bot bot added the Overdue label Jan 7, 2025
@johncschuster
Copy link
Contributor

@tylerkaraszewski ^^

Copy link

melvin-bot bot commented Jan 9, 2025

@tylerkaraszewski @johncschuster @ZhenjaHorbach this issue is now 4 weeks old, please consider:

  • Finding a contributor to fix the bug
  • Closing the issue if BZ has been unable to add the issue to a VIP or Wave project
  • If you have any questions, don't hesitate to start a discussion in #expensify-open-source

Thanks!

Copy link

melvin-bot bot commented Jan 9, 2025

@tylerkaraszewski, @johncschuster, @ZhenjaHorbach Huh... This is 4 days overdue. Who can take care of this?

@tylerkaraszewski
Copy link
Contributor

I think we can mark this as internal and do the backend fix.

@johncschuster johncschuster added Internal Requires API changes or must be handled by Expensify staff and removed External Added to denote the issue can be worked on by a contributor labels Jan 9, 2025
@johncschuster
Copy link
Contributor

Thanks, @tylerkaraszewski! I've done that now.

@melvin-bot melvin-bot bot removed the Overdue label Jan 9, 2025
@tylerkaraszewski tylerkaraszewski removed their assignment Jan 9, 2025
@melvin-bot melvin-bot bot added the Overdue label Jan 13, 2025
Copy link

melvin-bot bot commented Jan 13, 2025

@johncschuster, @ZhenjaHorbach Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@johncschuster
Copy link
Contributor

Gotta find an internal engineer for this one

@melvin-bot melvin-bot bot added Overdue and removed Overdue labels Jan 13, 2025
Copy link

melvin-bot bot commented Jan 17, 2025

@johncschuster, @ZhenjaHorbach Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Something is broken. Auto assigns a BugZero manager. Daily KSv2 Help Wanted Apply this label when an issue is open to proposals by contributors Internal Requires API changes or must be handled by Expensify staff Overdue
Projects
Status: Bugs and Follow Up Issues
Development

No branches or pull requests

7 participants