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

[EuiDataGrid] Implement draggable column headers #8015

Merged
Merged
Changes from 1 commit
Commits
Show all changes
65 commits
Select commit Hold shift + click to select a range
7a43829
feat: enable draggable datagrid column headers
mgadewoll Sep 10, 2024
08f3583
test: add tests and update snapshots
mgadewoll Sep 10, 2024
64d52ee
fix: update datagrid story column order aligning with visibleColumns
mgadewoll Sep 10, 2024
ae292c9
refactor: ensure focus management for draggable cells
mgadewoll Sep 10, 2024
9a5576b
test: add test for draggable cell focus behavior
mgadewoll Sep 10, 2024
94c23cf
fix: ensure expected border and space styles
mgadewoll Sep 11, 2024
5f61f55
refactor: ensure accessible screen reader output
mgadewoll Sep 11, 2024
d8a8224
docs: add EUI docs example
mgadewoll Sep 11, 2024
f7d2adb
chore: add changelog
mgadewoll Sep 11, 2024
fab5380
docs: align EUI docs example with other examples
mgadewoll Sep 12, 2024
41b8d59
refactor: use portal for dragged items
mgadewoll Sep 12, 2024
b80e773
refactor: cleanup
mgadewoll Sep 12, 2024
da831e3
refactor: use portal inside datagrid to ensure scoped styles still apply
mgadewoll Sep 13, 2024
0632be7
test(VRT): update reference images
mgadewoll Sep 13, 2024
2edb2a6
fix: ensure there is only a single draggable element
mgadewoll Sep 13, 2024
8bcdf6a
test: update cypress test to work with portalled draggable cell
mgadewoll Sep 13, 2024
a16b314
refactor: add dragging hint only on non-entered header cell
mgadewoll Sep 16, 2024
de342bc
refactor: remove tabindex from drag wrapper for fully custom draggabl…
mgadewoll Sep 16, 2024
85226e7
refactor: add useCallbacks
mgadewoll Sep 18, 2024
ce61447
styles: cleanup
mgadewoll Sep 18, 2024
d76447b
docs: update column dragging example
mgadewoll Sep 18, 2024
c983138
refactor: dry-out actions styles
mgadewoll Sep 18, 2024
ddc8690
test: update snapshots
mgadewoll Sep 18, 2024
513998b
refactor: move column drag prop under columnVisibility
mgadewoll Sep 19, 2024
75c3fd2
docs(storybook): add column drag story
mgadewoll Sep 19, 2024
6bf338f
test(VRT): add reference images
mgadewoll Sep 19, 2024
62938ed
refactor: change portal position and fix visual issues
mgadewoll Sep 24, 2024
b4a751a
test(VRT): update reference images
mgadewoll Sep 24, 2024
60a0824
chore: update changelog
mgadewoll Sep 24, 2024
d64ebb8
refactor: use EuiDraggable usePortal instead of custom EuiPortal for …
mgadewoll Oct 1, 2024
87c0a74
test(VRT): update VRT images
mgadewoll Oct 1, 2024
cab7faf
[PR feedback] Clean up header row droppable styles
cee-chen Oct 3, 2024
969851d
Fix `gap` CSS being lost on header actions open
cee-chen Oct 3, 2024
d100bd8
[cleanup] Move actions popover logic out of the wrapper and into `dat…
cee-chen Oct 3, 2024
96f325e
Remove onBlur event in favor of blocking any drags/closing any open p…
cee-chen Oct 4, 2024
573ed22
[cleanup] Remove unnecessary `wrapperRef` waterfalling
cee-chen Oct 4, 2024
c63040c
Syntax nit cleanups
cee-chen Oct 3, 2024
114a5f4
[UX polish] Improve mouse drag UX for both reordering and resizing co…
cee-chen Oct 4, 2024
4d7945e
[UX polish] Add more visual affordance to keyboard drag start
cee-chen Oct 4, 2024
42c46d2
Fix broken scrolling to draggable header cells
cee-chen Oct 4, 2024
478adbd
Fix columns sometimes not being full height while dragging
cee-chen Oct 4, 2024
b8e5393
[Storybook] Add interactive element to draggable storybook
cee-chen Oct 6, 2024
ae21c3f
[refactor] Move all drag-related components/logic to its own file/com…
cee-chen Oct 5, 2024
3258fd2
[cleanup] Remove need to pass `isDragging` or `closeActionsPopover` t…
cee-chen Oct 5, 2024
abd1a04
[UX polish] Add a stopgap data attr that prevents the hover animation…
cee-chen Oct 5, 2024
7757eac
[opinionated] Revert EuiDraggable changes
cee-chen Oct 6, 2024
b50182d
[refactor pt 1] Move column sorting logic to its own file
cee-chen Oct 6, 2024
a2b3352
[refactor pt 2] Move actions popover keyboard logic to `column_action…
cee-chen Oct 6, 2024
a333a36
[refactor pt 3] Move all column action popover logic to `column_actions`
cee-chen Oct 6, 2024
f9f7593
[naming pt 1] rename various column action booleans to be more consis…
cee-chen Oct 6, 2024
74d4115
[naming pt 2] rename `column_resizer` file to match other utils / non…
cee-chen Oct 6, 2024
92a9fdf
chore: revert to customDragHandle='custom'
mgadewoll Oct 7, 2024
2194419
refactor: rewrite adding aria-describedby ids by using destructuring
mgadewoll Oct 7, 2024
b256ff6
fix: ensure cell focus context is updated on aborted drag
mgadewoll Oct 7, 2024
567684c
Move draggable column E2E tests to their own file
cee-chen Oct 7, 2024
1255321
Fix another focus bug where grid body could become untabbable
cee-chen Oct 7, 2024
26c72d5
Add a fix for focus traps being enterable while dragging
cee-chen Oct 7, 2024
955cef7
feat: add column width cache
mgadewoll Oct 8, 2024
a73ced5
Fix failing style test
cee-chen Oct 9, 2024
ec1835c
Fix a `:last-child` CSS selector that no longer applies after drag/dr…
cee-chen Oct 9, 2024
8361d71
Update downstream resizer snapshots
cee-chen Oct 9, 2024
7111417
[refactor] DRY out `isLastColumn` logic
cee-chen Oct 9, 2024
429b9e7
Merge branch 'main' into datagrid/7136-draggable-column-headers
cee-chen Oct 9, 2024
fb3ff84
[PR feedback] Column widths
cee-chen Oct 10, 2024
219040a
test(VRT): update reference images
mgadewoll Oct 10, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 33 additions & 4 deletions packages/eui/src/components/datagrid/utils/col_widths.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
* Side Public License, v 1.
*/

import { useMemo, useCallback, useState } from 'react';
import { useMemo, useCallback, useState, useRef } from 'react';
import { useUpdateEffect } from '../../../services';
import { IS_JEST_ENVIRONMENT } from '../../../utils';
import {
Expand All @@ -18,6 +18,7 @@ import {
} from '../data_grid_types';

const DEFAULT_COLUMN_WIDTH = 100;
const COLUMN_WIDTHS_CACHE = new Map<string, Map<string, number>>();
mgadewoll marked this conversation as resolved.
Show resolved Hide resolved

export const useDefaultColumnWidth = (
gridWidth: number,
Expand Down Expand Up @@ -79,11 +80,36 @@ export const useColumnWidths = ({
setColumnWidth: (columnId: string, width: number) => void;
getColumnWidth: (index: number) => number;
} => {
const instance = useRef(`dataGridColumnWidths_${COLUMN_WIDTHS_CACHE.size}`);
cee-chen marked this conversation as resolved.
Show resolved Hide resolved

const computeColumnWidths = useCallback(() => {
let columnWidthsCache = COLUMN_WIDTHS_CACHE.get(instance.current);
cee-chen marked this conversation as resolved.
Show resolved Hide resolved

return columns
.filter(doesColumnHaveAnInitialWidth)
.filter(
(column) =>
(doesColumnHaveAnInitialWidth(column) ||
columnWidthsCache?.has(column.id)) ??
false
)
.reduce<EuiDataGridColumnWidths>((initialWidths, column) => {
return { ...initialWidths, [column.id]: column.initialWidth! };
const width = columnWidthsCache?.get(column.id) ?? column.initialWidth!;

if (columnWidthsCache) {
columnWidthsCache.set(column.id, width);
} else {
COLUMN_WIDTHS_CACHE.set(
instance.current,
new Map([[column.id, width]])
);

columnWidthsCache = COLUMN_WIDTHS_CACHE.get(instance.current);
}

return {
...initialWidths,
[column.id]: width,
};
}, {});
}, [columns]);

Expand All @@ -98,6 +124,8 @@ export const useColumnWidths = ({

const setColumnWidth = useCallback(
(columnId: string, width: number) => {
COLUMN_WIDTHS_CACHE.get(instance.current)?.set(columnId, width);

setColumnWidths((prevColumnWidths) => ({
...prevColumnWidths,
[columnId]: width,
Expand Down Expand Up @@ -134,7 +162,8 @@ export const useColumnWidths = ({
? columns[index - leadingControlColumns.length].id
: '';
return (
columnWidths[columnId] || defaultColumnWidth || DEFAULT_COLUMN_WIDTH
COLUMN_WIDTHS_CACHE.get(instance.current)?.get(columnId) ??
(columnWidths[columnId] || defaultColumnWidth || DEFAULT_COLUMN_WIDTH)
);
},
[
Expand Down
Loading