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

fix: No context menu item for paste in an input table #2341

Conversation

ericlln
Copy link
Contributor

@ericlln ericlln commented Jan 15, 2025

  • Added paste as a context menu option in IrisGrid
  • Added methods to check for and request clipboard permissions, which are called when clicking paste in context menu
  • For browsers that support the clipboard-read permission (e.g. Chrome), clicking paste results in the same behaviour as pressing the keyboard shortcut, provided the user has accepted the request for permission
  • For browsers that don't support the clipboard-read permission (e.g. Firefox and Safari), a modal is shown to explain the reason and to suggest using the keyboard shortcut instead

Additional related issues fixed

  • Show relevant warning when attempting to paste too many columns into input table
  • Fixed copy and pasting between Deephaven tables on Firefox. The issue is caused by tabs in pasted content being converted to     instead of      which we were expecting before. Was able to reproduce former behaviour on an older build of Firefox (91.0), meaning this discrepancy is likely caused by an update to Firefox (unsure when exactly)

@ericlln ericlln requested a review from mofojed January 15, 2025 18:55
@ericlln ericlln self-assigned this Jan 15, 2025
Copy link

codecov bot commented Jan 15, 2025

Codecov Report

Attention: Patch coverage is 61.81818% with 21 lines in your changes missing coverage. Please review.

Project coverage is 46.76%. Comparing base (5f6c8d6) to head (1872100).
Report is 7 commits behind head on main.

Files with missing lines Patch % Lines
...d/src/mousehandlers/IrisGridContextMenuHandler.tsx 0.00% 12 Missing ⚠️
packages/iris-grid/src/IrisGrid.tsx 20.00% 4 Missing ⚠️
packages/grid/src/Grid.tsx 0.00% 2 Missing ⚠️
packages/utils/src/ClipboardUtils.ts 90.47% 2 Missing ⚠️
packages/utils/src/PermissionUtils.ts 85.71% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main    #2341      +/-   ##
==========================================
+ Coverage   46.70%   46.76%   +0.06%     
==========================================
  Files         704      710       +6     
  Lines       39044    39107      +63     
  Branches     9757     9958     +201     
==========================================
+ Hits        18234    18288      +54     
+ Misses      20799    20765      -34     
- Partials       11       54      +43     
Flag Coverage Δ
unit 46.76% <61.81%> (+0.06%) ⬆️

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

Copy link
Member

@mofojed mofojed left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Exceptions should still be thrown/caught, rather than mapping to null. Excellent work, great find confirming the old behaviour in Firefox as well!

packages/iris-grid/src/NoPastePermissionModal.tsx Outdated Show resolved Hide resolved
packages/utils/src/ClipboardUtils.ts Outdated Show resolved Hide resolved
packages/utils/src/PermissionUtils.ts Outdated Show resolved Hide resolved
@ericlln ericlln requested a review from mofojed January 21, 2025 21:43
Copy link
Member

@mofojed mofojed left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Great work! Just one minor thing that can be simplified.

See how using exceptions instead of returning null gives you better flexibility about how you handle exceptional cases.

packages/utils/src/ClipboardUtils.ts Outdated Show resolved Hide resolved
@ericlln ericlln requested a review from mofojed January 23, 2025 15:57
@ericlln ericlln merged commit 680f015 into deephaven:main Jan 23, 2025
11 checks passed
@github-actions github-actions bot locked and limited conversation to collaborators Jan 23, 2025
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

2 participants