Skip to content

casamia918/aggrid-rowspan

Repository files navigation

aggrid-rowspan

1. Installation and run demo

  // pnpm
  pnpm install
  pnpm dev

  // npm
  npm install
  npm run dev
  • to set max rowCount, set queryParam of "count"
http://localhost:5173/?count=30

fig00*

2. OriginalRowSpan

  • Reference: https://www.ag-grid.com/react-data-grid/row-spanning/#row-spanning-example

  • The "rowSpan" callback function usage is very restricted.

  • In real cases, developer just want to "automatically" make row spanned cells if the adjacent cell data are same.

  • I've reserved the word "dynamically". Because, dynamic means, user can toggle any selected cells to be spanned or not spanned, as well as the cell merge feature of MS Excel. This is much more complicated use cases.

  • In this repo, I'm only focusing to the "automatic" row span.

3. AutomaticRowSpan

3.1. Goal

  • Grid cells should be automatically row spanned, without giving explictly define rowSpan callback function (like Original Example).

  • Application developer's interest is focused on "What the rowSpanGroup rule is", not "How many rows to be spanned"

    • AgGrid's colDef.rowSpan callback function means "How many rows spanned at specific row".
    • Ofcourse, This is interst of the AgGrid. Because, row spanning count is important to the grid renderer.
    • But, In real cases, adjacent cells of same data becomes candidate of row spanned group. So the row span count can be inferred from rowData.
    • However, there exist some cases where adjacent cells of same data should be remained as seperated cells.
    • This is why, developer should pass the callback function which saying "Hey AgGrid, I want to make rowSpanGroup of these cells. You can count rowSpan number from the rowData which I gave you. I just inform you what the row spanned group rule is."

    fig01*Fig01. User might want to merge green cells, not red cells.

3.2. Modeling RowSpanGroup

  • A RowSpanGroup is single level tree structure, consisted of "Head cell" and "Leaf cells".
  • Each RowSpanGroup should have unique id of its row span group.
  • "Head cell" have two responsiblity :
    • returning row spanning count from the AgGridColDef.rowSpan callback function
    • return TRUE to the row spanning cell class callback (in original example, ".cell-span") at the AgGridColDef.cellClassRules
  • "Head cell" have...
    • rowNodeId list of leaf nodes of belonging row span group.
  • "Leaf cell" have two responsibility :
    • returning 1 from the AgGridColDef.rowSpan callback function
    • return FALSE to the row spanning cell class callback (in original example, ".cell-span") at the AgGridColDef.cellClassRules
  • "Leaf cell" have...
    • rowNodeId of the head node of belonging row span group.

3.3. Key ingredients

  • ColDef.getRowSpanGroupId : return the unique id of its row span group. In same row span group, their rowSpanGroupId should be same.

    • rowSpanGroupId can be composed of multiple field value. Which means, row span group of later column can be diversed by earlier column row span group. In other words, rowSpanGroup can have hierarchy order of columns.

    fig02*Fig02. Visual presentation of row span group.
    Left : adjacent same data is considered as a row span group.
    Right : Row span group of Col2 is affected by earlier column (Col1).

  • useRowSpannedRowData : input is original row data. output is augmented row data of rowSpan related meta field attached.

  • getColDef_RowSpan : Create ColDef object with rowSpan and cellClassRules are automatically assigned. Developer requires to pass getRowSpanGroupId

  • meta field : special meta field which contains rowSpanGroup's tree structure information

type RowSpanMeta = {
  headId: string;
  leafIds: string[] | undefined;
};

interface WithMeta<Data> {
  __meta__: Partial<Record<keyof Data, RowSpanMeta>>;
}

// @see data-json folder
  • headCell: rowNodeId === meta.headId
  • leafCell : rowNodeId !== meta.headId
  • rowSpanCount : (meta.leafIds?.length ?? 0) + 1

4. Limitations

4.1. Sorting

  • When using row span features, it is not uncommon to be sorted by users. Because, when user sort row spanned data, the row span group will be broken by unexpected ways.

  • In other words, row spannable rowData should be sorted before passed into grid data. After than, its row order should be preserved.

  • In example, I've sorted olympic data right after fetch. (see src/examples/libs/fetchOlympicData). Also, I've set sortable:true in defaultColDef.

4.2. Row virtualization

  • Becaused of virtualization, rows which are not in viewable area wlll not be rendered.

  • When combining with row span feature, this is very tricky point. Because rows have vertical relations within certain column's row group.

  • In this example with enough row count (http://localhost:5173/?count=100), look carefully to the "Country" column with large row span group size. ("Australia")

    • At first, it looks good. But when scroll downs, row border will be shown inside of row span group.

    • This is inevitable because row span head is out of rendered area.

    fig03*

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published