Skip to content

Conversation

subashraja1803
Copy link

@subashraja1803 subashraja1803 commented May 6, 2024

You can recreate this by setting default value for allowWrapping in drawTextCell as true
Screenshot 2024-05-06 230902

@vydimitrov
Copy link

This is great, I was just looking for rowSpan or I a way to merge cells in a column. Thanks!

@subashraja1803
Copy link
Author

This is great, I was just looking for rowSpan or I a way to merge cells in a column. Thanks!

You are welcome

@divyanshupundir
Copy link

Great work! Ths is exactly what I was looking for. Is there a chance for this to get merged anytime soon?

@subashraja1803
Copy link
Author

Great work! Ths is exactly what I was looking for. Is there a chance for this to get merged anytime soon?

I am not sure about merge, But if you want you can make these changes to your own fork

@lukasmasuch lukasmasuch requested a review from Copilot June 18, 2025 02:22
Copy link
Contributor

@Copilot Copilot AI left a comment

Choose a reason for hiding this comment

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

Pull Request Overview

Adds vertical span (rowSpan) support to DataGrid rendering, selection, and user interactions.

  • Introduces rowSpan property in cell types and new getRowSpanBounds utility.
  • Updates rendering in drawCells and drawFillHandle to account for row spans.
  • Extends selection logic (cellIsSelected, expandSelection) and example stories to demonstrate row spans.

Reviewed Changes

Copilot reviewed 7 out of 7 changed files in this pull request and generated 3 comments.

Show a summary per file
File Description
packages/core/src/internal/data-grid/render/data-grid.render.rings.ts Import rowSpan bounds and adjust fill handle positioning for row spans
packages/core/src/internal/data-grid/render/data-grid-render.walk.ts Add getRowSpanBounds to compute vertical span geometry
packages/core/src/internal/data-grid/render/data-grid-render.cells.ts Clip and draw cells with row spans, handle row-span highlighting
packages/core/src/internal/data-grid/render/data-grid-lib.ts Extend cellIsSelected to consider rowSpan
packages/core/src/internal/data-grid/data-grid-types.ts Add rowSpan to BaseGridCell interface
packages/core/src/docs/examples/span-cell.stories.tsx Update story to demonstrate rowSpan
packages/core/src/data-editor/data-editor-fns.ts Extend expandSelection to include row spans
Comments suppressed due to low confidence (1)

packages/core/src/internal/data-grid/render/data-grid.render.rings.ts:252

  • getRowHeight is not imported in this file, leading to a runtime error. Add the appropriate import for getRowHeight from the module where it’s defined.
                    let cellHeight = getRowHeight(row);

@dogfootruler-kr
Copy link

I wanted to use this functionality as well and found this PR, so I tried it locally. It works fine for cell that have only a rowSpan, but not if there is a span and a rowSpan.

I couldn't find a fix for it, do you have any idea what it could be?

Thank you very much!

image

<DataEditor
      columns={[
        {
          id: "1",
          title: "First column",
          width: 100,
        },
        {
          id: "2",
          title: "Second column",
          width: 100,
        },
        {
          id: "3",
          title: "Third column",
          width: 100,
        },
        {
          id: "4",
          title: "Fourth column",
          width: 100,
        },
      ]}
      getCellContent={(cell) => {
        const [col, row] = cell;

        if (
          (row === 3 && col === 1) ||
          (row === 3 && col === 2) ||
          (row === 4 && col === 1) ||
          (row === 4 && col === 2)
        ) {
          return {
            kind: GridCellKind.Text,
            data: `${row} ${col}`,
            copyData: `${row} ${col}`,
            span: [1, 2],
            rowSpan: [3, 4],
            allowOverlay: true,
            displayData: `${row} ${col}`,
          };
        }

        return {
          kind: GridCellKind.Text,
          data: `${row} ${col}`,
          copyData: `${row} ${col}`,
          span: (col === 1 || col === 2) && row === 1 ? [1, 2] : undefined,
          rowSpan: (row === 7 || row === 8) && col === 1 ? [7, 8] : undefined,
          allowOverlay: true,
          displayData: `${row} ${col}`,
        };
      }}
      rows={10}
    />

@subashraja1803
Copy link
Author

subashraja1803 commented Jun 26, 2025

I wanted to use this functionality as well and found this PR, so I tried it locally. It works fine for cell that have only a rowSpan, but not if there is a span and a rowSpan.

I couldn't find a fix for it, do you have any idea what it could be?

Thank you very much!

image

<DataEditor
      columns={[
        {
          id: "1",
          title: "First column",
          width: 100,
        },
        {
          id: "2",
          title: "Second column",
          width: 100,
        },
        {
          id: "3",
          title: "Third column",
          width: 100,
        },
        {
          id: "4",
          title: "Fourth column",
          width: 100,
        },
      ]}
      getCellContent={(cell) => {
        const [col, row] = cell;

        if (
          (row === 3 && col === 1) ||
          (row === 3 && col === 2) ||
          (row === 4 && col === 1) ||
          (row === 4 && col === 2)
        ) {
          return {
            kind: GridCellKind.Text,
            data: `${row} ${col}`,
            copyData: `${row} ${col}`,
            span: [1, 2],
            rowSpan: [3, 4],
            allowOverlay: true,
            displayData: `${row} ${col}`,
          };
        }

        return {
          kind: GridCellKind.Text,
          data: `${row} ${col}`,
          copyData: `${row} ${col}`,
          span: (col === 1 || col === 2) && row === 1 ? [1, 2] : undefined,
          rowSpan: (row === 7 || row === 8) && col === 1 ? [7, 8] : undefined,
          allowOverlay: true,
          displayData: `${row} ${col}`,
        };
      }}
      rows={10}
    />

The text is rendered vertically mid automatically.. Thats one of the reason... Need to check for missing Text

@subashraja1803
Copy link
Author

I wanted to use this functionality as well and found this PR, so I tried it locally. It works fine for cell that have only a rowSpan, but not if there is a span and a rowSpan.

I couldn't find a fix for it, do you have any idea what it could be?

Thank you very much!

image

<DataEditor
      columns={[
        {
          id: "1",
          title: "First column",
          width: 100,
        },
        {
          id: "2",
          title: "Second column",
          width: 100,
        },
        {
          id: "3",
          title: "Third column",
          width: 100,
        },
        {
          id: "4",
          title: "Fourth column",
          width: 100,
        },
      ]}
      getCellContent={(cell) => {
        const [col, row] = cell;

        if (
          (row === 3 && col === 1) ||
          (row === 3 && col === 2) ||
          (row === 4 && col === 1) ||
          (row === 4 && col === 2)
        ) {
          return {
            kind: GridCellKind.Text,
            data: `${row} ${col}`,
            copyData: `${row} ${col}`,
            span: [1, 2],
            rowSpan: [3, 4],
            allowOverlay: true,
            displayData: `${row} ${col}`,
          };
        }

        return {
          kind: GridCellKind.Text,
          data: `${row} ${col}`,
          copyData: `${row} ${col}`,
          span: (col === 1 || col === 2) && row === 1 ? [1, 2] : undefined,
          rowSpan: (row === 7 || row === 8) && col === 1 ? [7, 8] : undefined,
          allowOverlay: true,
          displayData: `${row} ${col}`,
        };
      }}
      rows={10}
    />
Screenshot 2025-10-16 at 12 25 32 PM Fixed this

@subashraja1803
Copy link
Author

@lukasmasuch Kindly check

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

5 participants