Elevate your Dash app's data visualization capabilities with Dash AG Grid, a high-performance and highly customizable Dash component that wraps AG Grid: "The best JavaScript grid in the world."
I'm thrilled to announce the recent release of Dash AG Grid V31.0.0, aligning with AG Grid V31.0.3 and encompassing all its cutting-edge features. If you haven't tried Dash AG Grid yet, this is a great time to take it for a spin. The V31 release has many grid features enabled by default, which means more features with less code. You'll be amazed at how easy it is to add this beautiful, feature-rich data grid to your Dash app. If you've used previous versions of Dash AG Grid, please see this migration guide to help you upgrade to the latest release.
I've been a member of the Dash community team contributing to the development of Dash AG Grid since Plotly's decision to open source this component last year. My main focus has been on testing and documentation. Bryan Schroeder has taken the lead in developing the component, while Sébastien Didier has played a pivotal role in enhancing the documentation. Throughout this project, we've received invaluable mentorship from Alex Johnson, Plotly's CTO, and Liam Connors from the technical writing team. This project has been a great learning experience, and I'm excited to be part of the team working to make AG Grid available to all Dash users.
This article draws inspiration from the AG Grid documentation's "Creating a Basic Grid" tutorial. I'll walk you through getting started with Dash AG Grid, focusing on the free AG Grid Community features, then touch on some of the advanced features you can unlock with an AG Grid Enterprise license.
AG Grid is a powerful and feature-rich JavaScript datagrid library for creating interactive and customizable tables in web applications. Dash AG Grid extends its functionality to Python developers within the Dash framework, providing a seamless integration for creating dynamic data tables in Python-based web apps.
Create a Dash app to display data with AG Grid in less than five minutes!
import dash_ag_grid as dag
from dash import Dash
import pandas as pd
app = Dash()
df = pd.read_csv("https://raw.githubusercontent.com/plotly/datasets/master/ag-grid/space-mission-data.csv")
app.layout = dag.AgGrid(
rowData=df.to_dict("records"),
columnDefs=[{"field": i} for i in df.columns],
)
app.run(debug=True)
Basic grid features enabled by default in Dash AG Grid V31:
- Alpine Theme Styling: The grid comes styled with the Alpine theme, available in both light and dark modes.
- Column Resizing: Resize columns by dragging the vertical handle in the header.
- Sorting Rows: Click on the header to sort rows; use shift-click for sorting by multiple columns.
- Animation: See the smooth row animation during sorting and filtering.
- Boolean Values as Checkboxes: Boolean values are automatically rendered as checkboxes.
- Column Reordering: Change the order of the columns by dragging the column header.
- Column Pinning: Pin a column to the right or left side of the grid by dragging the column header.
If you just want to add a basic grid to your app, you can stop here. But if you'd like to explore advanced capabilities, I'll show you how to filter, edit, format, and select the data in the next section. I'll also demonstrate how to add pagination, custom components, and interaction with the grid in Dash callbacks.
Access live examples and full code for each app featured in this article at the Dash AG Grid Examples site. There, you'll also find additional tutorials, examples, and a gallery of custom components.
Now that we have a basic grid with some data, let's configure the grid using Column Properties. Use Column Properties to configure a wide range of features; check out the Columns documentation for a complete list of options.
Add Column Properties to enable or disable column-specific features in one or more columns. Try this by settingfilter=True
in the "mission" column.
columnDefs=[
{"field": "mission", "filter": True},
{"field": "company"},
#... other columns
]
You'll now be able to filter the "mission" column --- give it a try by filtering for the "Apollo" missions.
The example above demonstrates how to configure a single column. To apply this configuration across all columns, we can use Default Column Definitions instead. Let's make all of our columns filterable by adding the defaultColDef
property and setting filter=True
:
dag.AgGrid(
defaultColDef={"filter": True}
)
The grid will now allow filtering on all columns. Note that the Column Definitions take precedence over Default Column Definitions.
In the example below, you'll see different types of filters used based on the Cell Data Type. This is one of the great new features available in this release.
- The "Successful" column, with boolean data, has a dropdown filter with True and False selections
- The "Price" has a Number Filter
- The "Date" has a Date Filter with a date picker component
- The other columns have the default Text Filter
In this release, Dash AG Grid introduces built-in cell data types featuring automatic type inference from column data. Beyond just filtering, as demonstrated in the above example, the grid can now automatically configure columns for rendering, editing, row grouping (an Enterprise feature), and Import & Export based on the data type. You have the flexibility to override predefined cell data types and even create fully custom data types for handling complex objects, such as dicts or lists within cells.
This means that tasks that previously required manual column configuration can now be automated by the grid. This is another new low-code feature in this latest release.
See more information in the Cell Data Types section of the Dash Docs.
So far, I've covered creating a grid and configuring columns. This section introduces Grid Options, which control functionality that extends across both rows and columns, such as Pagination and Row Selection.
AG Grid is highly customizable and has many props --- only a subset of these are defined as separate props in the Dash AG Grid component. Valid grid-level properties that are not listed in the reference section in the Dash docs can be used by passing them to the dashGridOptions
property on the Dash AG Grid component.
Let's try this by setting pagination=True
in the dashGridOptions
prop:
dag.AgGrid(
dashGridOptions={"pagination": True}
)
You'll now see Pagination is enabled on the grid. Note that the Page Size control is a new feature enabled by default in Dash AG Grid V31.
The data supplied to the grid usually requires some degree of formatting. For basic text formatting, we can use Value Formatters.
Value Formatters are functions that take the value of the cell, apply some formatting, and return a new value to be displayed by the grid. In Dash, it is not possible to have functions as props. Instead, we use a dictionary with "function" as the key and the value is the JavaScript function to execute. You can find more information in the Dash docs.
In Dash AG Grid, the d3 format functions are included. This makes it even easier to format numbers and dates.
Let's try this by adding the valueFormatter
property to our "price" column.
columnDefs = [
{
"field": "price",
"valueFormatter": {"function": "d3.format('$,.0f')(params.value)"},
},
]
The grid now shows the formatted value in the "price" column:
Value Formatters are useful for basic formatting, but for more advanced use cases, we can use Cell Renderer Components instead.
Cell Renderers allow you to add custom HTML, JavaScript, and other Dash components within cells. To use a Cell Renderer, set the cellRenderer
prop on a column, with the value as the name of your Cell Renderer.
If you are new to JavaScript, see the Dash docs:
Let's try this by creating a new component to display the company logo in the "company" column.
If you don't have one already, add a folder called assets
in the same folder as your app. Dash automatically serves the files in this folder.
- app.py
- assets/
|-- dashAgGridComponentFunctions.js
dashAgGridComponentFunctions.js
var dagcomponentfuncs = (window.dashAgGridComponentFunctions =
window.dashAgGridComponentFunctions || {});
dagcomponentfuncs.CompanyLogoRenderer = function (props) {
var url = "https://www.ag-grid.com/example-assets/space-company-logos/" + props.value.toLowerCase() + ".png";
return React.createElement(
"span",
null,
React.createElement("img", { src: url, style: { width: "25px", height: "auto", filter: "brightness(1.1)" } }),
React.createElement("span", { style: { paddingLeft: "4px" } }, props.value)
);
}
Now we can use the CompanyLogoRenderer
in our app like this:
columnDefs=[
{
"field": "company",
"cellRenderer": "CompanyLogoRenderer"
},
]
Be sure to check out the Dash docs Cell Renderer section for more details and examples. Also, check out all the components in the Dash AG Grid Custom Component Gallery
The grid provides several built-in cell editors, eliminating the need to create custom components for the following:
- Text Cell Editor: The default editor, is a standard HTML
input
component - Large Text Cell Editor: is an HTML
textarea
component - Select Cell Editor: is an HTML
select
component - Rich Select Cell Editor (Enterprise only): A custom dropdown component
- Number Cell Editor*: is an HTML number
input
- Date Cell Editor*: is an HTML date
input
- Checkbox Cell Editor*: is an HTML checkbox
input
*
New components available in V31
Let's try this by making all the data editable. We do this by adding editable=True
to the defaultColDef
prop:
dag.AgGrid(
defaultColDef={"editable": True, "filter":True}
)
The grid automatically uses the appropriate cell editors based on the Cell Data Type, just as it selects filters according to the data type.
See the new number, date and checkbox editor in action:
- The "Successful" column uses the Checkbox Cell Editor
- The "Price" uses the Number Cell Editor
- The "Date" uses the Date Cell Editor
- The other columns use the Text Cell Editor.
You can configure the provided cell editors by passing parameters to the cellEditorParams
prop. See the option for each component in the Provided Cell Editors documentation.
In the example above, we've configured the number editor to:
- Display stepper buttons within the component.
- Restrict entry to positive numbers by setting
min=0
. - Ensure whole numbers only by setting
precision=0
.
columnDefs = [
{
"field": "price",
"cellEditorParams": {"showStepperButtons": True, "min": 0, "precision": 0}
},
]
Certain properties in Dash AG Grid can trigger Dash callbacks. Please refer to the Reference section of the Dash documentation.
In the following example, I'll show how to track changes in data using a callback.
This example includes several more features:
- Multiple Rows are selectable. For more info, see the Selection section.
- The row animation is disabled when you sort, filter or move columns
- The date is formatted using the D3 functions
- Numeric columns are right aligned
Be sure to try it out for yourself in the live version at Dash AG Grid Examples
Explore additional features with AG Grid Enterprise. A license is required; check AG Grid docs for pricing details.
In AG Grid Enterprise, unlock functionalities like Grouping, Aggregation, Advanced Filtering, Hierarchical Data Support and Tree View, Data Export to Excel, Excel-like Pivoting, Copy/Paste, Sparklines, and more.
The Enterprise section in the Dash Grid docs provides only a few examples, so please refer to the AG Grid documentation for details.
Here's a new Enterprise feature in Dash AG Grid V31. You won't find this in the Dash Docs yet, but it's available in this release.
The Advanced Filter allows for complex filter conditions to be entered across columns in a single type-ahead input, as well as within a hierarchical visual builder.
import dash_ag_grid as dag
from dash import Dash
import pandas as pd
app = Dash()
df = pd.read_csv("https://raw.githubusercontent.com/plotly/datasets/master/ag-grid/olympic-winners.csv")
app.layout = dag.AgGrid(
rowData=df.to_dict("records"),
columnDefs=[{"field": i} for i in df.columns],
defaultColDef={"filter": True},
dashGridOptions={"enableAdvancedFilter": True},
enableEnterpriseModules=True,
# licenseKey= enter your license key here
)
app.run(debug=True)
See this app live in the AG Grid Docs
Congratulations! You've completed the tutorial and built your first grid. By now, you should be familiar with the key concepts of AG Grid:
-
Row Data: Your data, in JSON format, that you want the grid to display.
-
Column Definitions: Define your columns and control column-specific functionality, like sorting and filtering.
-
Default Column Definitions: Similar to Column Definitions, but applies configurations to all columns.
-
Grid Options: Configure functionality that extends across the entire grid.
-
Value Formatters: Functions used for basic text formatting
-
Cell Renderers: Add your own components to cells
-
Editing: Editing cells with provided text, number, date, and checkbox editors
-
Callbacks: Events that trigger Dash callbacks, typically as a result of user interaction.
- See the Dash docs and the AG Grid docs for details on all the features.
- If you've found Dash AG Grid valuable, show your support by starring us on GitHub! 🌟.
- Have questions or want to join the conversation? Head over to the Dash Community Forum and connect with fellow developers.
- If you would like to join our community development team and contribute to making Dash AG Grid even better, feel free to reach out to Adam Schroeder
Happy Coding!