-
Notifications
You must be signed in to change notification settings - Fork 28
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #266 from AnnMarieW/update-readme
Update readme
- Loading branch information
Showing
3 changed files
with
137 additions
and
46 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,48 @@ | ||
|
||
# Dash AG Grid Contributing Guide | ||
|
||
Dash AG Grid welcomes community contributions! | ||
|
||
If you have identified a bug or have an idea for a new feature, it's best to start with a GitHub issue. First look at existing issues at https://github.com/plotly/dash-ag-grid/issues to make sure this is not a duplicate. Then create a new issue. Bug reports should be accompanied by a small example app that someone else can copy and run to reproduce the problem. | ||
|
||
If you have questions, please ask on the [Dash Community Forum](https://community.plotly.com/). rather than using GitHub issues. | ||
|
||
|
||
### Developing in this repo | ||
|
||
Make sure you have Dash installed with dev and testing extras: | ||
``` | ||
pip install dash[dev,testing] | ||
``` | ||
Build the component (from the root of this repo): | ||
``` | ||
npm i | ||
npm run build | ||
``` | ||
Now install the component in development mode: | ||
``` | ||
$ pip install -e . | ||
``` | ||
In development mode, Python uses the files in this directory when you import the package. So you can write a testing app in another folder, and whenever you change some code and rebuild the component here it will update in your testing app. | ||
|
||
### Create a production build | ||
|
||
Create source and wheel distributions in the generated `dist/` folder, after emptying out any previous builds: | ||
``` | ||
rm -rf dist build | ||
python setup.py sdist bdist_wheel | ||
``` | ||
See [PyPA](https://packaging.python.org/guides/distributing-packages-using-setuptools/#packaging-your-project) | ||
for more information. | ||
Then use [`twine`](https://pypi.org/project/twine/) to upload these to PyPI: | ||
``` | ||
twine upload dist/* | ||
``` | ||
We also publish the JavaScript build to NPM, so `unpkg` has the bundles if users set `serve_locally=False`. First make a test of the NPM package, verify that its contents are reasonable: | ||
``` | ||
npm pack | ||
``` | ||
Then publish: | ||
``` | ||
npm publish | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,67 +1,103 @@ | ||
# Dash AG Grid | ||
# Dash AG Grid [![PyPi Version](https://img.shields.io/pypi/v/dash-ag-grid.svg)](https://pypi.org/project/dash-ag-grid/) | ||
|
||
Dash AG Grid is a Dash component wrapper for the AG Grid JavaScript package, enabling you to display AG Grid components natively in your Dash app. | ||
|
||
The underlying AG Grid JavaScript package is a third-party software component developed by [AG Grid Ltd](http://www.ag-grid.com/). Many features are available for free in the AG Grid [Community version](https://github.com/ag-grid/ag-grid). Some features require a paid subscription to the AG Grid Enterprise version ([more info available here](https://www.ag-grid.com/license-pricing.php)). Both the community and enterprise versions are included in this component, but the enterprise features require you to provide a valid AG Grid license key. The demos which use Enterprise features are clearly marked. | ||
|
||
|
||
## v2.0.0 Release | ||
### Documentation | ||
Please see the [Plotly Dash AG Grid Documentation](https://dash.plotly.com/dash-ag-grid). | ||
|
||
If you have tried v2.0.0 alpha releases, release candidates, or our v1.x enterprise package, please see our [Migration Guide](https://dash.plotly.com/dash-ag-grid/migration-guide) (previously hosted [here](https://dashaggrid.pythonanywhere.com/getting-started/migration-guide)). | ||
### Quick Start | ||
|
||
`pip install dash-ag-grid` | ||
|
||
### Getting Started | ||
This basic grid has the following features enabled by default: | ||
- Alpine theme | ||
- Sort | ||
- Resize, reorder and pin columns | ||
- Boolean values rendered as check boxes | ||
- Row animation on sort | ||
|
||
`pip install dash-ag-grid` | ||
```python | ||
|
||
import dash_ag_grid as dag | ||
from dash import Dash | ||
import pandas as pd | ||
|
||
### Documentation | ||
Please see the [Dash Documentation](https://dash.plotly.com/dash-ag-grid). | ||
app = Dash() | ||
|
||
## Contributing | ||
df = pd.read_csv("https://raw.githubusercontent.com/plotly/datasets/master/ag-grid/space-mission-data.csv") | ||
|
||
Dash AG Grid welcomes community contributions! | ||
app.layout = dag.AgGrid( | ||
rowData=df.to_dict("records"), | ||
columnDefs=[{"field": i} for i in df.columns], | ||
) | ||
|
||
If you have identified a bug or have an idea for a new feature, it's best to start with a GitHub issue. First look at existing issues at https://github.com/plotly/dash-ag-grid/issues to make sure this is not a duplicate. Then create a new issue. Bug reports should be accompanied by a small example app that someone else can copy and run to reproduce the problem. | ||
app.run(debug=True) | ||
``` | ||
|
||
The docs are under development as well. There are many examples in the official AG Grid docs that have not been included here yet. Please open an issue or do pull requests for edits or to add examples. Or post your question, comments or demo apps on the [Dash Community Forum](https://community.plotly.com/). | ||
<img src="https://github.com/AnnMarieW/dash-ag-grid-examples/assets/72614349/74fe86e1-eb54-4dec-915f-d692f2c8cead" width="1000"/> | ||
|
||
|
||
### Developing in this repo | ||
### AG Grid Community Features | ||
Here are a few of the AG Grid Community features available: | ||
|
||
Make sure you have Dash installed with dev and testing extras: | ||
``` | ||
pip install dash[dev,testing] | ||
``` | ||
Build the component (from the root of this repo): | ||
``` | ||
npm i | ||
npm run build | ||
``` | ||
Now install the component in development mode: | ||
``` | ||
$ pip install -e . | ||
``` | ||
In development mode, Python uses the files in this directory when you import the package. So you can write a testing app in another folder, and whenever you change some code and rebuild the component here it will update in your testing app. | ||
- Column Interactions (resize, reorder, and pin columns) | ||
- Column Spanning | ||
- Column Grouping | ||
- Pagination | ||
- Sorting | ||
- Row Selection | ||
- Row Reordering | ||
- Row Spanning | ||
- Pinned Rows | ||
- Full Width Rows | ||
|
||
### Create a production build | ||
- Cell data types with automatic type inference | ||
- Custom Filtering | ||
- Cell Editing | ||
|
||
- Provided components including number editors, date picker, select editor, text editor, large text editor | ||
- Custom Components in cells - add your own components such as buttons, graphs, indicators, markdown and more | ||
- Tooltips in cells and headers | ||
|
||
- Provided themes with light/dark versions | ||
- Customizable themes | ||
- Figma Design System to design and customize themes | ||
|
||
- Format Cell Data | ||
- Conditional formatting | ||
|
||
- Data Export to CSV | ||
- Keyboard Navigation | ||
- Accessibility support | ||
- Localization | ||
|
||
|
||
|
||
### AG Grid Enterprise features | ||
Here are a few of the features available in AG Grid Enterprise. See the AG Grid docs for more information. | ||
|
||
- Grouping / Aggregation | ||
- Advanced Filtering | ||
- Records Lazy Loading | ||
- Server-Side Records Operations | ||
- Hierarchical Data Support & Tree View | ||
- Data Export to Excel | ||
- Excel-like Pivoting | ||
- Copy / Paste | ||
- Sparklines | ||
|
||
### See a [live demo](https://www.ag-grid.com/example/) of AG Grid Community and Enterprise Features | ||
|
||
--------- | ||
|
||
|
||
|
||
<img src="https://github.com/AnnMarieW/dash-ag-grid-examples/assets/72614349/0c7319e4-0ebd-437a-bbdc-1091ec7ae325" width="1000"/> | ||
|
||
### Contributing | ||
|
||
We welcome contributions to `dash-ag-grid`. Please see our [contributing guide](https://github.com/plotly/dash-ag-grid/blob/main/CONTRIBUTING.md) for more information. | ||
|
||
Create source and wheel distributions in the generated `dist/` folder, after emptying out any previous builds: | ||
``` | ||
rm -rf dist build | ||
python setup.py sdist bdist_wheel | ||
``` | ||
See [PyPA](https://packaging.python.org/guides/distributing-packages-using-setuptools/#packaging-your-project) | ||
for more information. | ||
Then use [`twine`](https://pypi.org/project/twine/) to upload these to PyPI: | ||
``` | ||
twine upload dist/* | ||
``` | ||
We also publish the JavaScript build to NPM, so `unpkg` has the bundles if users set `serve_locally=False`. First make a test of the NPM package, verify that its contents are reasonable: | ||
``` | ||
npm pack | ||
``` | ||
Then publish: | ||
``` | ||
npm publish | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters