NeoDash - Neo4j Dashboard Builder
NeoDash is an open source tool for visualizing your Neo4j data. It lets you group visualizations together as dashboards, and allow for interactions between reports.
Neodash supports presenting your data as tables, graphs, bar charts, line charts, maps and more. It contains a Cypher editor to directly write the Cypher queries that populate the reports. You can save dashboards to your database, and share them with others.
Try NeoDash
You can run NeoDash in one of three ways:
- You can install NeoDash into Neo4j Desktop from the graph app gallery. NeoDash will automatically connect to your active database.
- You can run NeoDash from a web browser by visiting http://neodash.graphapp.io.
- For on-prem deployments, you can build the application yourself, or pull the latest Docker image from Docker Hub.
# Run the application on http://localhost:5005
docker pull neo4jlabs/neodash:latest
docker run -it --rm -p 5005:5005 neo4jlabs/neodash
Windows users may need to prefix the docker run
command with winpty
.
Build and Run
This project uses yarn
to install, run, build prettify and apply linting to the code.
To install dependencies:
yarn install
To run the application in development mode:
yarn run dev
To build the app for deployment:
yarn run build
To manually prettify all the project .ts
and .tsx
files, run:
yarn run format
To manually run linting of all your .ts and .tsx files, run:
yarn run lint
To manually run linting of all your .ts and .tsx staged files, run:
yarn run lint-staged
See the Developer Guide for more on installing, building, and running the application.
Pre-Commit Hook
While commiting, a pre-commit hook will be executed in order to prettify and run the Linter on your staged files. Linter warnings are currently accepted. The commands executed by this hook can be found in /.lintstagedrc.json.
There is also a dedicated linting step in the Github project pipeline in order to catch each potential inconsistency.
Don't hesitate to setup your IDE formatting feature to use the Prettier module and our defined rules (.prettierrc.json).
User Guide
NeoDash comes with built-in examples of dashboards and reports. For more details on the types of reports and how to customize them, see the User Guide.
Publish Dashboards
After building a dashboard, you can chose to deploy a read-only, standalone instance for users. See Publishing for more on publishing dashboards.
Questions / Suggestions
If you have any questions about NeoDash, please reach out to the maintainers:
NeoDash is a free and open-source tool developed by the Neo4j community - not an official Neo4j product. If you have a need for a commercial agreement around training, custom extensions or other services, please contact the Neo4j Professional Services team.
NeoDash 2.4.0
NeoDash 2.4 is out! 🎂 This release packs a ton of new features, as well as improvements to the existing visualizations.
Key new features:
- A new sidebar with support for managing, save and load multiple dashboards directly from the UI.
#657
- Added Forms as a new extension. Forms let you combine multiple parameter selectors in one card and have users edit/submit data to Neo4j. #568
- Added a new advanced visualization type: Gantt charts. #684
- Doubled the grid resolution for dashboards, giving you more freedom to arrange visualizations. #682
- Several improvements for the natural language queries extension - including customizable prompting, and faster schema retrieval. #600
Other improvements:
- Support for multiselect checkboxes as a report action for tables. #688
- Added keyboard shortcuts (CMD/CTRL+Enter) for running Cypher queries from the editor. #694
- Added new experimental graph layouts (trees in various directions), with customizable level distance. #690
- Increased customizability for the Pie chart's styling. #638
- Fixed issues with parameter selector: Better handling of integer / long parameters and processing external updates. #641
- Improvements on text readability for the experimental dark mode. #668
- UX improvements on database connection interface. #675
- Added option to provide a custom message when no data is returned by a report. #683
- Fixed issue where column names were not hidden correctly. #685
Thanks to all the contributors for this release:
alfredorubin96,
AleSim94,
BennuFire,
jacobbleakley-neo4j,
hugorplobo,
brahmprakashMishra,
m-o-n-i-s-h,
JonanOribe,
nielsdejong