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

Add Auto Column Size #18549

Open
wants to merge 14 commits into
base: main
Choose a base branch
from
Open

Add Auto Column Size #18549

wants to merge 14 commits into from

Conversation

cssuh
Copy link
Member

@cssuh cssuh commented Jan 7, 2025

Gives the proper space for column widths. Also enables double clicking on a column border to snap to the correct size.

In the first screenshot you can see that the column headers have an ellipsis but in the second screenshot, they are sized correctly.

Before:
Screenshot 2025-01-09 at 6 14 07 PM

After:
Screenshot 2025-01-09 at 6 13 43 PM

Note: Instead of adding an additional max column size config option, I hardcoded it at 400px to minimize the number of settings options we have for this extension.

Double-click feature:
autoColumnSize

Note: this feature will expand the column to fit the header or any visible row data (whichever is larger), but won't shrink a cell that's already been manually expanded past the size of the header or visible row data.

Fixes #18089
Fixes #18534

Copy link

github-actions bot commented Jan 7, 2025

PR Changes

Category Main Branch PR Branch Difference
Code Coverage 50.41% 50.51% $${\color{lightgreen} .10\% }$$
VSIX Size 12123 KB 12128 KB $${\color{lightgreen} 5 KB \space (0\%) }$$
Webview Bundle Size 3112 KB 3116 KB $${\color{lightgreen} 4 KB \space (0\%) }$$

@cssuh cssuh marked this pull request as draft January 7, 2025 22:01
@cssuh cssuh marked this pull request as ready for review January 9, 2025 23:15
@Benjin
Copy link
Contributor

Benjin commented Jan 13, 2025

Can you add a video of the double-click to expand a column to the PR description?

@Benjin
Copy link
Contributor

Benjin commented Jan 13, 2025

Last week, we'd talked about it remembering when a user adjusts a column width for that result set if they rerun the query. Is that part of this PR? If so, can you add a short video of how that works? (btw, separate video per topic/feature is best)

package.nls.json Outdated Show resolved Hide resolved
package.nls.json Outdated Show resolved Hide resolved
src/queryResult/queryResultWebViewController.ts Outdated Show resolved Hide resolved
src/reactviews/pages/QueryResult/table/dom.ts Outdated Show resolved Hide resolved
@@ -164,6 +166,13 @@ export class Table<T extends Slick.SlickData> implements IThemable {
new CopyKeybind(this.uri, this.resultSetSummary, this.webViewState),
);

this.registerPlugin(
new AutoColumnSize({
maxWidth: MAX_COLUMN_WIDTH_PX,
Copy link
Contributor

Choose a reason for hiding this comment

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

A user can still manually adjust wider than this MAX_COLUMN_WIDTH_PX, right?

Copy link
Member Author

Choose a reason for hiding this comment

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

No, I thought we discussed that we wouldn't include a user option for this because we don't want to add too many config options. Should I change this?

Copy link
Contributor

Choose a reason for hiding this comment

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

No, you're right about that. What I meant was that if I have a column with lots of text such that the content is wider than MAX_COLUMN_WIDTH_PX, autosize will limit itself to MAX_COLUMN_WIDTH_PX, but I - as the user - will still be able to drag the column to be even wider to see more of my data, right?

src/reactviews/pages/QueryResult/table/utils.ts Outdated Show resolved Hide resolved
src/reactviews/pages/QueryResult/table/utils.ts Outdated Show resolved Hide resolved
@cssuh
Copy link
Member Author

cssuh commented Jan 13, 2025

Last week, we'd talked about it remembering when a user adjusts a column width for that result set if they rerun the query. Is that part of this PR? If so, can you add a short video of how that works? (btw, separate video per topic/feature is best)

This part slipped my mind, I'll add it shortly.

let data = this._grid.getData() as Slick.DataProvider<T>;
let viewPort = this._grid.getViewport();
let start = Math.max(0, viewPort.top);
let end = Math.min(data.getLength(), viewPort.bottom);
Copy link
Member

Choose a reason for hiding this comment

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

are we going through all the data in the result set, or the visible viewPort? I'm not sure what viewPort.bottom is. But we probably shouldn't go through the whole result set, maybe 100 or 1000 rows is totally fine to get a general shape of the data.

Copy link
Member Author

Choose a reason for hiding this comment

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

It just goes through the visible viewPort

Copy link
Contributor

Choose a reason for hiding this comment

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

Recording here to make sure it doesn't get lost: the suggestion from sync yesterday was to calculate the width using the first 50-100 rows of data, rather than just the viewport since the viewport is possibly only a small slice.

Copy link
Member Author

Choose a reason for hiding this comment

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

@kburtram @Benjin increased it to 50 rows (don't want to make the calculation too expensive).

let max = 0,
maxTemplate: JQuery | HTMLElement | string | undefined;
let formatFun = columnDef.formatter;
texts.forEach((text, index) => {
Copy link
Member

Choose a reason for hiding this comment

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

this looks expensive at scale (e.g. lots of rows)

Copy link
Member Author

Choose a reason for hiding this comment

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

@kburtram Did some perf testing on this, and since it just goes by the visible viewport, it only did the first 10 rows of each column for me (30 rows if I expand the grid to my full screen). With 1024 columns (which seems like the upper recommended limit for # of columns), it took a couple seconds extra compared to if I had the setting off.

Copy link
Contributor

Choose a reason for hiding this comment

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

Can you add a telemetry point with timing and number of columns here so that we can detect any egregious times to autosize?

@Benjin
Copy link
Contributor

Benjin commented Jan 14, 2025

@cssuh

Last week, we'd talked about it remembering when a user adjusts a column width for that result set if they rerun the query. Is that part of this PR? If so, can you add a short video of how that works? (btw, separate video per topic/feature is best)

This part slipped my mind, I'll add it shortly.

Also okay if that comes in a quick follow-up PR.

@cssuh
Copy link
Member Author

cssuh commented Jan 14, 2025

@cssuh

Last week, we'd talked about it remembering when a user adjusts a column width for that result set if they rerun the query. Is that part of this PR? If so, can you add a short video of how that works? (btw, separate video per topic/feature is best)

This part slipped my mind, I'll add it shortly.

Also okay if that comes in a quick follow-up PR.

@Benjin I think I'll add this in a follow-up PR, and I realized this is not for if they re-run the query (since that would generate a new query result set and result set grid), but for if they leave the result pane and then come back (like switching to messages tab and then returning)

Created #18554 to track

@cssuh cssuh requested review from Benjin and kburtram January 15, 2025 01:00
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
3 participants