Ag grid header tabs?

Hi,

I had a quick question. Is it possible to input custom components within headers of an AG Grid?

Goal:
My hope is to have one of my columns be a tabbed header which will change the displayed data within the column based on which tab is selected.

Yes, it’s possible to have a custom component in a header. Here is a simple example with a button to help you get started


from dash import Dash, html, dcc, Input, Output
import dash_ag_grid as dag
import pandas as pd

app = Dash()


df = pd.read_csv(
    "https://raw.githubusercontent.com/plotly/datasets/master/ag-grid/olympic-winners.csv"
)

app.layout = html.Div([
    dcc.Store(id="store-button"),
    dag.AgGrid(
            id="column-definition-ID",
            rowData=df.to_dict("records"),
            columnDefs=[{
                "field": "athlete",
                "headerName": "Athlete",
                "headerComponent": "ButtonHeader"  # select custom component
            }],
            columnSize="sizeToFit",
        ),
    html.Div(id="container")

])

@app.callback(
    Output("container", "children"),
    Input("store-button", "data")
)
def update(data):
    return str(data)

if __name__== "__main__":
    app.run(debug=True)




Put this in the `dashAgGridComponentFunctions.js file in the assets folder"

var dagcomponentfuncs = window.dashAgGridComponentFunctions = window.dashAgGridComponentFunctions || {};

dagcomponentfuncs.ButtonHeader = function (props) {
    return React.createElement(
        'button',
        {
            onClick: () => {
                newData = JSON.stringify(new Date())
                dash_clientside.set_props("store-button", {data: newData})
            },
            className: props.className,
            style: props.style,
        },
        props.displayName)
}

See the example live here:

1 Like