- 
                Notifications
    You must be signed in to change notification settings 
- Fork 1.3k
fix: Inline editing tables #8983
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
Conversation
| // If the active element is NOT tabbable but is contained by an element that IS tabbable (aka the cell), the browser will actually move focus to | ||
| // the containing element. We need to special case this so that tab will move focus out of the grid instead of looping between | ||
| // focusing the containing cell and back to the non-tabbable child element | ||
| if (next && (!next.contains(document.activeElement) || (document.activeElement && !isTabbable(document.activeElement)))) { | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Note that I didn't write a test for this because it seems like user.tab() doesn't emulate this browser behavior
| Build successful! 🎉 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, just one small question
| onCancel={() => {}} | ||
| isSaving={item.isSaving[column.id!]} | ||
| renderEditing={() => ( | ||
| <Picker | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
just a nitpick, but I noticed that opening the picker here on mobile now properly expands the dropdown to grow to fit the available Table space, albiet with a slightly strange "grow" animation that only happens the first time the picker gets opened. However, I was wondering why it doesn't do that for the Async example? I was assuming it would use the width of the table as its bounds per say
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also noticed that "grow" animation, I have no idea where it's coming from. There should be a max width on the popover of the table's width,
| minWidth: `min(${triggerWidth}px, ${tableWidth}px)`, | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For others reviewing the PR, the positioning of the popover being off is expected, the fix is in #8848 (I forgot lol)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM, might be good to get an example in the S2 docs soon
| 
 sounds good, I remembered a few other things I needed to follow up on so I'll be making another PR shortly | 
* fix: Inline editing tables * fix edit buttons not showing up by default on Android phones * fix case where user cant tab forward in a table w/ edit buttons and no selection * make scrolling boundary story more obvious * fix text * fix lint --------- Co-authored-by: Daniel Lu <[email protected]>
Closes
✅ Pull Request Checklist:
📝 Test Instructions:
🧢 Your Project: