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] Split - App crashes when tapping Copy to clipboard on code block context menu #47743

Closed
2 of 6 tasks
lanitochka17 opened this issue Aug 20, 2024 · 48 comments
Closed
2 of 6 tasks
Assignees
Labels
Bug Something is broken. Auto assigns a BugZero manager. External Added to denote the issue can be worked on by a contributor Reviewing Has a PR in review Weekly KSv2

Comments

@lanitochka17
Copy link

lanitochka17 commented Aug 20, 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.22-7
Reproducible in staging?: Y
Reproducible in production?: Y
If this was caught during regression testing, add the test name, ID and link from TestRail: N/A
Email or phone of affected tester (no customers): [email protected]
Issue reported by: Applause - Internal Team

Action Performed:

  1. Launch New Expensify app
  2. Go to group chat
  3. Tap + > Spli expense > Manual
  4. Create a split manual expense with code block as the description
  5. Tap on the split preview
  6. Long press on the code block
  7. Tap Copy to clipboard

Expected Result:

App will not crash

Actual Result:

App crashes when tapping Copy to clipboard on code block context menu in split menu

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

Add any screenshot/video evidence

Bug6577380_1724181250000.Screen_Recording_20240821_030954_One_UI_Home.mp4

logs (2).txt

View all open jobs on GitHub

Upwork Automation - Do Not Edit
  • Upwork Job URL: https://www.upwork.com/jobs/~01a78f1cc82b94611b
  • Upwork Job ID: 1827396760466325645
  • Last Price Increase: 2024-08-24
  • Automatic offers:
    • hoangzinh | Reviewer | 103731517
Issue OwnerCurrent Issue Owner: @hoangzinh
@lanitochka17 lanitochka17 added Daily KSv2 Bug Something is broken. Auto assigns a BugZero manager. labels Aug 20, 2024
Copy link

melvin-bot bot commented Aug 20, 2024

Triggered auto assignment to @kevinksullivan (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.

@lanitochka17
Copy link
Author

@kevinksullivan FYI I haven't added the External label as I wasn't 100% sure about this issue. Please take a look and add the label if you agree it's a bug and can be handled by external contributors

@lanitochka17
Copy link
Author

We think that this bug might be related to #vip-split

@Krishna2323
Copy link
Contributor

Krishna2323 commented Aug 20, 2024

Edited by proposal-police: This proposal was edited at 2024-08-20 19:46:28 UTC.

Proposal

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

Split - App crashes when tapping Copy to clipboard on code block context menu

What is the root cause of that problem?

Context menu is not disabled when action and report are undefined.

onLongPress={(event) =>
showContextMenuForReport(event, anchor, report?.reportID ?? '-1', action, checkIfContextMenuActive, ReportUtils.isArchivedRoom(report, reportNameValuePairs))
}

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

  • We should not call showContextMenuForReport when report or action is undefined. The check can be added before calling showContextMenuForReport or here.
  • We should also check other html renderers with same bug.

What alternative solutions did you explore? (Optional)



When report or action is not present, we can render TDefaultRenderer without PressableWithoutFeedback.

        <View style={isLast ? styles.mt2 : styles.mv2}>
            <ShowContextMenuContext.Consumer>
                {({anchor, report, reportNameValuePairs, action, checkIfContextMenuActive}) =>
                    report && action ? (
                        <PressableWithoutFeedback
                            onPress={onPressIn ?? (() => {})}
                            onPressIn={onPressIn}
                            onPressOut={onPressOut}
                            onLongPress={(event) => {
                                if (!report || !action) {
                                    return;
                                }
                                showContextMenuForReport(event, anchor, report?.reportID ?? '-1', action, checkIfContextMenuActive, ReportUtils.isArchivedRoom(report, reportNameValuePairs));
                            }}
                            shouldUseHapticsOnLongPress
                            role={CONST.ROLE.PRESENTATION}
                            accessibilityLabel={translate('accessibilityHints.prestyledText')}
                        >
                            <View>
                                {/* eslint-disable-next-line react/jsx-props-no-spreading */}
                                <TDefaultRenderer {...defaultRendererProps} />
                            </View>
                        </PressableWithoutFeedback>
                    ) : (
                        <View>
                            {/* eslint-disable-next-line react/jsx-props-no-spreading */}
                            <TDefaultRenderer {...defaultRendererProps} />
                        </View>
                    )
                }
            </ShowContextMenuContext.Consumer>
        </View>

Result

@daledah
Copy link
Contributor

daledah commented Aug 21, 2024

Proposal

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

A long press on the description field show the context menu actions.

What is the root cause of that problem?

  • The code block is displayed as the pre tag:

    function PreRenderer({TDefaultRenderer, onPressIn, onPressOut, onLongPress, ...defaultRendererProps}: PreRendererProps) {

  • When long pressing on it, we will call:

    showContextMenuForReport(event, anchor, report?.reportID ?? '-1', action, checkIfContextMenuActive, ReportUtils.isArchivedRoom(report, reportNameValuePairs))

  • There is the case the report or action data is undefined, because there is no ShowContextMenuContext.Provider wrapped in it, this issue for example.

  • As a result, call any context menu action, such as "Copy to clipboard" will throw the error "Cannot read properties of null (reading 'actionName')".

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

  • There are 4 types of context menu:
    CONTEXT_MENU_TYPES: {
        LINK: 'LINK',
        REPORT_ACTION: 'REPORT_ACTION',
        EMAIL: 'EMAIL',
        REPORT: 'REPORT',
    },

we must not allow user to open context menu type REPORT_ACTION by long pressing on the description field. Because they only can open context menu type REPORT_ACTION by long pressing on the report action.

was initially added in this PR to ensure that long-pressing on a link or email triggers context menu type LINK or EMAIL. However, this is redundant because if an email or link is wrapped in a code block like:

or

https://dev.new.expensify.com:8082/

They are displayed as code, not as an active email or link. Therefore, long-pressing on them should not trigger the context menu type LINK or EMAIL.

  • So the solution is just need to remove the above onLongPress.

What alternative solutions did you explore? (Optional)

  • In ShowContextMenuContext, we can introduce a new value in its context value, named canOpenContextMenu and its default value is false.

  • So this:

    onLongPress={(event) =>
    showContextMenuForReport(event, anchor, report?.reportID ?? '-1', action, checkIfContextMenuActive, ReportUtils.isArchivedRoom(report, reportNameValuePairs))
    }

    will be:

                        onLongPress={(event) => {
                            if (!canOpenContextMenu) {
                                return;
                            }
                            showContextMenuForReport(event, anchor, report?.reportID ?? '-1', action, checkIfContextMenuActive, ReportUtils.isArchivedRoom(report, reportNameValuePairs));
                        }}

and just pass canOpenContextMenu: true in where in need through the ShowContextMenuContext.provider.

@wildan-m
Copy link
Contributor

Proposal

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

Context menu shown in code block in menu item

What is the root cause of that problem?

The context menu shouldn't be shown in codeblock in menu item

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

If codeblocks are unnecessary in the menu item description, we can remove the shouldParseTitle parameter from MenuItemWithTopDescription.

src/components/ReportActionItem/MoneyRequestView.tsx (or other similar parts)

                <OfflineWithFeedback pendingAction={getPendingFieldAction('comment')}>
                    <MenuItemWithTopDescription
                        description={translate('common.description')}
                        shouldParseTitle
                        title={updatedTransactionDescription ?? transactionDescription}

What alternative solutions did you explore? (Optional)

N/A

@melvin-bot melvin-bot bot added the Overdue label Aug 23, 2024
@kevinksullivan kevinksullivan added the External Added to denote the issue can be worked on by a contributor label Aug 24, 2024
@melvin-bot melvin-bot bot changed the title Split - App crashes when tapping Copy to clipboard on code block context menu [$250] Split - App crashes when tapping Copy to clipboard on code block context menu Aug 24, 2024
Copy link

melvin-bot bot commented Aug 24, 2024

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

@melvin-bot melvin-bot bot added the Help Wanted Apply this label when an issue is open to proposals by contributors label Aug 24, 2024
Copy link

melvin-bot bot commented Aug 24, 2024

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

@hoangzinh
Copy link
Contributor

Thanks for proposals, everyone. Will review today

@hoangzinh
Copy link
Contributor

hoangzinh commented Aug 27, 2024

Thanks for your patience, everyone. After reviewing, here is my feedbacks

  • @Krishna2323's proposal: Can you add more details on your RCA next time? It's too short to understand the root cause. But your solution is most viable to me.
  • @daledah's proposal: Love your RCA, it's clear and helpful to me. But your main solution will cause a regression bug when long press on mobile devices, it doesn't open the context menu. Your alternative solution looks promising, but it will cause passing unnecessary context value. Because I think if report or action is undefined (like @Krishna2323 described in his proposal), it means it's not on a report action.
Click here to view recording
Screen.Recording.2024-08-27.at.09.05.20.mov

Based on the above, I think we can go with @Krishna2323's proposal #47743 (comment)

Updated: changed my suggestion base on this #47743 (comment)

🎀👀🎀 C+ reviewed~

Copy link

melvin-bot bot commented Aug 27, 2024

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

@daledah
Copy link
Contributor

daledah commented Aug 27, 2024

@hoangzinh

when long press on mobile devices, it doesn't open the context menu

I think it is expected, long press on the money request view's description should not display the context menu action. For example, In the video below, we still can open the context menu action in the confirmation page:

Screen.Recording.2024-08-27.at.12.22.42.mov

@daledah
Copy link
Contributor

daledah commented Aug 27, 2024

cc @lakchote, do you have any thoughts on my comment above?

@daledah
Copy link
Contributor

daledah commented Aug 27, 2024

Added evidence in comment.

@hoangzinh
Copy link
Contributor

@daledah I mean with your solution, on the report page, it won't open the context menu when user long presses on the codeblock messages

Step to reproduce on native apps:

  1. Go to any reports
  2. Send a codeblock message
  3. Long press on that message
  4. Expect: the context menu will be opened.

@hoangzinh
Copy link
Contributor

Ah you can also check my recording here for reference #47743 (comment)

@daledah
Copy link
Contributor

daledah commented Aug 27, 2024

  • Thanks @hoangzinh . I followed your test steps and It still works well with my changes:
Screen.Recording.2024-08-27.at.15.29.20.mov

@hoangzinh
Copy link
Contributor

Can you go back and revisit the report again? When I test, I have to do the same to reproduce the issue if you've already opened the report page

Click here to view recording
Screen.Recording.2024-08-27.at.17.41.34.mov

@daledah
Copy link
Contributor

daledah commented Aug 27, 2024

Can you go back and revisit the report again?

  • I was only able to test on the web due to an issue with running the iOS app. I noticed that if I long press on a container area outside the code block, the context menu opens. However, if I long press directly on the code block, the context menu does not open.
Screen.Recording.2024-08-27.at.18.06.10.mov
  • I my alternative solution can fix two bugs because it fixed the RCA:

I mean with your solution, on the report page, it won't open the context menu when user long presses on the codeblock messages

and

we still can open the context menu action in the confirmation page

@melvin-bot melvin-bot bot added Weekly KSv2 and removed Daily KSv2 labels Aug 31, 2024
@daledah
Copy link
Contributor

daledah commented Aug 31, 2024

@hoangzinh PR is ready.

@kevinksullivan
Copy link
Contributor

PR still in review. Looping in another BZ member as I am going OOO

@kevinksullivan kevinksullivan removed their assignment Sep 12, 2024
@kevinksullivan kevinksullivan added Bug Something is broken. Auto assigns a BugZero manager. and removed Bug Something is broken. Auto assigns a BugZero manager. labels Sep 12, 2024
Copy link

melvin-bot bot commented Sep 12, 2024

Triggered auto assignment to @isabelastisser (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.

@melvin-bot melvin-bot bot added Daily KSv2 and removed Weekly KSv2 labels Sep 12, 2024
@kevinksullivan kevinksullivan self-assigned this Sep 12, 2024
@isabelastisser
Copy link
Contributor

No updates yet.

Copy link

melvin-bot bot commented Sep 20, 2024

@hoangzinh, @lakchote, @kevinksullivan, @isabelastisser, @daledah Uh oh! This issue is overdue by 2 days. Don't forget to update your issues!

@lakchote
Copy link
Contributor

Discussion is still happening in the PR.

Copy link

melvin-bot bot commented Sep 24, 2024

@hoangzinh, @lakchote, @kevinksullivan, @isabelastisser, @daledah 6 days overdue. This is scarier than being forced to listen to Vogon poetry!

@hoangzinh
Copy link
Contributor

PR has been deployed to staging. Awaiting for testing

@hoangzinh
Copy link
Contributor

@lakchote @isabelastisser can you help to add the "Weekly" label back for this issue? It seems to be reverted to "Daily"

@lakchote lakchote added Weekly KSv2 and removed Daily KSv2 labels Sep 25, 2024
@lakchote
Copy link
Contributor

@lakchote @isabelastisser can you help to add the "Weekly" label back for this issue? It seems to be reverted to "Daily"

Done.

@hoangzinh
Copy link
Contributor

BugZero Checklist:

  • The PR that introduced the bug has been identified. Link to the PR: Nope, I think it's just a new edge case that we haven't covered.
  • 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: N/A
  • 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: N/A
  • Determine if we should create a regression test for this bug: 🚫 It's just an edge case UI issue. We don't need a regression test for it.

@hoangzinh
Copy link
Contributor

cc @isabelastisser this issue is ready for payment

@isabelastisser
Copy link
Contributor

@hoangzinh, I processed your payment in Upwork.
@daledah, please share your Upwork profile, thanks!

@daledah
Copy link
Contributor

daledah commented Oct 29, 2024

@isabelastisser Here you go https://www.upwork.com/freelancers/~0138d999529f34d33f

@isabelastisser
Copy link
Contributor

@daledah, thanks! I sent you the offer in Upwork now. All set!

@daledah
Copy link
Contributor

daledah commented Nov 6, 2024

@isabelastisser Many thanks, offer accepted.

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. External Added to denote the issue can be worked on by a contributor Reviewing Has a PR in review Weekly KSv2
Projects
None yet
Development

No branches or pull requests

8 participants