-
Notifications
You must be signed in to change notification settings - Fork 366
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
Fixed the issue where long values overflowed the modal in the pages u… #8640
base: master
Are you sure you want to change the base?
Conversation
…nder the "Administration" tab in the UI.
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.
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.
Great first big PR -
Really nice effort mapping the issues, looking around, and getting to a complete solution.
Some notes:
- Agree with @guy-har 's comment about limiting the width of the checkbox.
- You should consider splitting this PR into one with the specific changes, and one with the general ones, that will apply multiple components. Since changing global components (potentially) affects the whole app, I think it's better to have a separate PR and discussion for it.
- Nit: better to have a shorter title for the PR, for better readability. 😊
Anyway, nice work 💪
I addressed all the comments:
So now this PR addresses only this fix: IssueLong values overflowed modal windows across tables in "Groups", "Users" and "Policies" pages in the "Administration" tab. Fix
Changes Made
Updated the Table under the DataTable component to prevent overflow. Changed in file: TestingVerified on lakeFS OSS using local DB & object store & ACL. |
…to control the width of the first column if it's a checkbox column
@Annaseli I'm not sure where it stands at the moment, |
…ponent in DataTable
@itaigilo |
key={header} | ||
title={header} | ||
className={` | ||
${(firstFixedCol && i === 0) ? "col-1" : "col-12"} |
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.
Well, this is a usage of bootstrap classes which sort-of work for you, but it's pretty accidental. The bootstrap framework uses 12-cols grid elements, so setting an element as col-1
makes it take 1/12 of the width of a element, and col-12
makes it take the whole width of it. So these classes maybe work for you in this context, but there's no guarantee it'll work on other browsers, for example.
How about doing something like:
style={
${(firstFixedCol && i === 0) ? "width: 60px" : ""`
(Not sure about the details, but the general idea is to give an actual fixed size for the first column.)
Does this give the same result?
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.
(Having said that, I still think that a better overall solution is required here. Either by using a different Table package that might allow this truncate ability, or using a non-table solution for the Auth components (when thinking about it, these are not actually data tables, but UI components, and should be treated as such).
But since this requires an effort which is out-of-scope for this bug fix, it can be deferred.)
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 agree that using col-* isn't the best solution, and after I checked it a few days ago further, I found that overriding the width with a style like {{"width: X"}}, is indeed a more appropriate and common approach in React.
I understood that bootstrap’s col-* classes come from its grid system, which isn't designed to be used directly inside elements in tables. They attempt to control column width and they have an effect when combined with "table-layout: fixed" as I used it. Since Bootstrap’s grid system (col-*) is meant for div-based layouts rather than tables, it's not suitable perfectly inside .
I found out that a better approach for fixing column widths in tables:
To use style={{ width: "X%" }} inside .
or
To use with { width: "X%" } .
However, when I previously suggested it, I understood that it’s not a good practice and that we should use Bootstrap classes instead. The "w-" approach didn't work for me, but "col-" did.
In my earlier solution (before the col-* solution) , I used a fixed width, and it worked.
So, would you recommend using style={{ width: "X%" }} instead of col-* in this case?
I believe using percentages instead of a fixed 60px width is a better approach since the browser can dynamically adjust it rather than us setting a fixed size manually.
And yes, I agree with you that a more generalized approach is needed here, and that this PR provides just a compromise.
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.
The thing is -
We use this mechanism only for the checkbox column. And since a checkbox has a fixed size, why do you prefer to give it a dynamic width instead of a fixed width (assuming, of course, that fixed width also gives good results for this)?
…nder the "Administration" tab in the UI.
Closes #8489
Issue
Long values overflowed modal windows across multiple pages in the "Administration" tab. Initially reported for one modal, but found in Users, Groups, and other sections (for other sections I opened another issue).
Fix
Changes Made
1. "Add to Group" Pop-up (Groups -> click on some group name -> Add Members)
Updated the DataTable component to prevent overflow.
Changed in files:
webui/src/lib/components/controls.jsx (DataTable)
webui/src/lib/components/auth/forms.jsx (AttachModal)
The issue screenshot:
Fix:
Note
This pop-up is implemented using a "DataTable" and AttachModal, which is also used in other functions.
For example it fixed in addition this issue:
data:image/s3,"s3://crabby-images/94bd6/94bd6611ae900a582db619ce654aa9651bba5f0a" alt="long_group_name_issue_1"
data:image/s3,"s3://crabby-images/1fb71/1fb7175022075536e50f45be02c607211a980157" alt="long_group_name_issue_2"
Issue:
Fix:
data:image/s3,"s3://crabby-images/d5e40/d5e40994c50642e625780e663cb09ee707cd915d" alt="long_group_name_fix"
2. "Groups" Page (Groups -> Group Name) "Users" Page (Users -> User Name)
Fixed GroupHeader, PolicyHeader, UserHeader overflow.
Changed in files:
webui/src/lib/components/auth/nav.jsx (GroupHeader, PolicyHeader, UserHeader)
The issue screenshot:
Fix:
3. Fixed user name overflow in confirmation pop-up (Users -> selecting a user with a long name -> Access Credentials -> Create Access Key)
Changed in files:
webui/src/pages/auth/users/user/credentials.jsx (getMsg function)
The issue screenshot:
Fix:
Testing
Verified on lakeFS OSS using local DB & object store.