Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[POC] Dashboard generator #522

Merged
merged 142 commits into from
Aug 2, 2024
Merged
Show file tree
Hide file tree
Changes from 140 commits
Commits
Show all changes
142 commits
Select commit Hold shift + click to select a range
3fddb9c
pure data summary on multi datasets
lingyielia May 29, 2024
75cd1f2
remove nested func
lingyielia May 30, 2024
5790ebc
add in pydantic spike
lingyielia May 31, 2024
7a6e47d
remove graph creation
lingyielia May 31, 2024
a80955a
cleanup
lingyielia May 31, 2024
85d683c
cleanup
lingyielia May 31, 2024
4e8ef07
relocate core builder
lingyielia Jun 3, 2024
7895afa
full string generation
lingyielia Jun 4, 2024
391fe6c
data manager init
lingyielia Jun 5, 2024
26f967c
work with aggrid one dataframe
lingyielia Jun 6, 2024
57b7757
remove data manager
lingyielia Jun 6, 2024
d3dd078
multi dataframe
lingyielia Jun 6, 2024
9896efb
clean up
lingyielia Jun 6, 2024
3db523e
merge
lingyielia Jun 6, 2024
088b858
unify pydantic import
lingyielia Jun 6, 2024
2b1c8af
unify structured output usage
lingyielia Jun 7, 2024
f4d8562
consolidate nodes
lingyielia Jun 7, 2024
41260d5
dummy filter
lingyielia Jun 11, 2024
1541d05
rename data sample
lingyielia Jun 11, 2024
a6b950b
make state a pydantic
lingyielia Jun 11, 2024
bee0be8
add layout placeholder
lingyielia Jun 11, 2024
38fd0b8
make methods private
lingyielia Jun 11, 2024
f3df206
add some initial fallbacks
lingyielia Jun 12, 2024
6ed0d01
clean up
lingyielia Jun 12, 2024
35e1c15
example notebook
lingyielia Jun 12, 2024
e2e03cf
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 12, 2024
9f4eda1
decouple plan and build
lingyielia Jun 13, 2024
bc5e501
linting
lingyielia Jun 13, 2024
e60d488
merge
lingyielia Jun 13, 2024
714d851
linting
lingyielia Jun 13, 2024
db96fed
update dependencies
lingyielia Jun 13, 2024
30bf0c2
add changelog
lingyielia Jun 13, 2024
66e5d01
bugfix
lingyielia Jun 13, 2024
ea1b99e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 13, 2024
ff5164d
retry logic
lingyielia Jun 18, 2024
0622f26
bug fix
lingyielia Jun 19, 2024
55d80ee
improve logging
lingyielia Jun 20, 2024
da3b1fa
key error handle
lingyielia Jun 21, 2024
e31cc3c
add todos
lingyielia Jun 21, 2024
e756d8e
clean up
lingyielia Jun 21, 2024
f681e02
refactor page to dashboard portion into langgraph
lingyielia Jun 21, 2024
df9ec6e
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 21, 2024
0f07884
merge from main
lingyielia Jun 22, 2024
b671a2f
linting
lingyielia Jun 22, 2024
b75436d
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 22, 2024
1b6a911
lint
lingyielia Jun 22, 2024
000dd93
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jun 25, 2024
41a7106
be more specific about the message type
lingyielia Jun 25, 2024
aa2b37b
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 25, 2024
d254f4b
improve typing and model init
lingyielia Jun 25, 2024
f217156
merge
lingyielia Jun 25, 2024
8a022f8
linting
lingyielia Jun 25, 2024
7742758
use with anthoropic models
lingyielia Jun 26, 2024
e6f6b6c
lint
lingyielia Jun 26, 2024
c385704
lint
lingyielia Jun 26, 2024
c756f55
bugfix
lingyielia Jun 26, 2024
190b47e
address comments
lingyielia Jun 27, 2024
16149df
linting
lingyielia Jun 27, 2024
72566c5
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jun 27, 2024
20bf78e
bug fix
lingyielia Jun 27, 2024
7115fe3
merge
lingyielia Jun 27, 2024
d5a3405
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jun 27, 2024
d1b02a1
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 3, 2024
df2561f
update string
lingyielia Jul 4, 2024
14e4177
flatten plan and build
lingyielia Jul 4, 2024
9058815
lint
lingyielia Jul 4, 2024
5da09eb
address comments
lingyielia Jul 4, 2024
1600b55
merge
lingyielia Jul 6, 2024
e0b08f4
merge
lingyielia Jul 6, 2024
8106cdf
typo
lingyielia Jul 6, 2024
a4f6ff5
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 8, 2024
6c8a75d
progress bar
lingyielia Jul 9, 2024
e01a639
lint
lingyielia Jul 9, 2024
c7407dc
improve tqdm and add graph
lingyielia Jul 10, 2024
543dab3
lint
lingyielia Jul 10, 2024
5532bce
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 10, 2024
e6cf358
remove import builder
lingyielia Jul 10, 2024
0682377
remove black
lingyielia Jul 10, 2024
62fd67e
update tqdm and return elements
lingyielia Jul 10, 2024
c99c9c2
link filter to component id
lingyielia Jul 11, 2024
69df6e0
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 11, 2024
dbd5713
convert df_metadata to dataclass
lingyielia Jul 11, 2024
b265a19
lint
lingyielia Jul 11, 2024
9e00326
better naming
lingyielia Jul 13, 2024
42053ee
minimize input size
lingyielia Jul 13, 2024
77b8615
improve layout
lingyielia Jul 15, 2024
f648771
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 15, 2024
9eafb89
unit test examples
lingyielia Jul 16, 2024
b63c82c
merge
lingyielia Jul 16, 2024
e0fc9e9
bugfix
lingyielia Jul 16, 2024
a17bfbb
update progress bar
lingyielia Jul 16, 2024
7e0cbef
address comments
lingyielia Jul 16, 2024
2a325e4
bugfix
lingyielia Jul 16, 2024
2d4495d
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 16, 2024
77e6903
bugfix
lingyielia Jul 16, 2024
4b09fac
restructure files
lingyielia Jul 16, 2024
5f98ad7
add page build
lingyielia Jul 16, 2024
b427270
add page builder
lingyielia Jul 16, 2024
9973260
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 16, 2024
2cd6145
fix
lingyielia Jul 16, 2024
c99e5ba
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 16, 2024
0f6f564
improve progress tracking
lingyielia Jul 17, 2024
0998fdf
make _get_pydantic_output more testable
lingyielia Jul 17, 2024
457deba
refactor df_info
lingyielia Jul 17, 2024
a97e19c
tidy
lingyielia Jul 17, 2024
30282ce
restructure
lingyielia Jul 17, 2024
6b678a2
refactor page build
lingyielia Jul 18, 2024
24bfb5d
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 18, 2024
e1dc74e
lint
lingyielia Jul 18, 2024
009acbe
Merge branch 'dev/dashboard_generator' of github.com:mckinsey/vizro i…
lingyielia Jul 18, 2024
f66cc4f
add code sample and remove unit tests
lingyielia Jul 18, 2024
d65dd18
tidy
lingyielia Jul 18, 2024
def3b77
handle unsupported spec
lingyielia Jul 18, 2024
b955edb
add dashboard launch method
lingyielia Jul 19, 2024
23a035d
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 19, 2024
2c97828
lint
lingyielia Jul 19, 2024
0facbbb
refactor layout and add more examples
lingyielia Jul 22, 2024
ab7115c
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 22, 2024
4cac939
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 22, 2024
fe48708
improve layout creation
lingyielia Jul 23, 2024
365d875
tidy
lingyielia Jul 23, 2024
3e2da5a
tidy
lingyielia Jul 24, 2024
1f86504
small improvement for 4o and remove run dashboard
lingyielia Jul 26, 2024
8affb8f
improve 4o and handle datepicker
lingyielia Jul 27, 2024
e827605
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 27, 2024
c7df707
merge
lingyielia Jul 27, 2024
c652afb
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 27, 2024
b228a44
remove pageid for layout
lingyielia Jul 28, 2024
1de3815
address comments
lingyielia Jul 28, 2024
efa6d41
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 29, 2024
6ba48d9
address comments
lingyielia Jul 29, 2024
af1dc70
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Jul 30, 2024
1c48749
merge
lingyielia Jul 30, 2024
22b40dd
Small example changes
maxschulz-COL Jul 30, 2024
27190a5
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 30, 2024
0be1ad9
address comments
lingyielia Jul 30, 2024
5e1f7f7
Small adjustment to run scripts
maxschulz-COL Jul 31, 2024
625ee08
[pre-commit.ci] auto fixes from pre-commit.com hooks
pre-commit-ci[bot] Jul 31, 2024
9c2e91e
Merge branch 'main' into dev/dashboard_generator
lingyielia Jul 31, 2024
4b22839
Merge branch 'main' of github.com:mckinsey/vizro into dev/dashboard_g…
lingyielia Aug 1, 2024
dfd3a85
address comments
lingyielia Aug 2, 2024
1941993
remove code from DashboardOutputs
lingyielia Aug 2, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
<!--
A new scriv changelog fragment.

Uncomment the section that is right (remove the HTML comment wrapper).
-->

<!--
### Highlights ✨

- A bullet item for the Highlights ✨ category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Removed

- A bullet item for the Removed category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Added

- A bullet item for the Added category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Changed

- A bullet item for the Changed category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Deprecated

- A bullet item for the Deprecated category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Fixed

- A bullet item for the Fixed category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
<!--
### Security

- A bullet item for the Security category with a link to the relevant PR at the end of your entry, e.g. Enable feature XXX ([#1](https://github.com/mckinsey/vizro/pull/1))

-->
283 changes: 283 additions & 0 deletions vizro-ai/examples/example_dashboard.ipynb
Original file line number Diff line number Diff line change
@@ -0,0 +1,283 @@
{
"cells": [
{
"cell_type": "code",
"execution_count": null,
"id": "53e857ce-22bc-49de-9adc-9a2e7c9829cf",
"metadata": {},
"outputs": [],
"source": [
"from dotenv import load_dotenv\n",
"load_dotenv()"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "2a25acdd-20c3-4762-b97f-254de1586aeb",
"metadata": {},
"outputs": [],
"source": [
"import pandas as pd\n",
"import vizro.plotly.express as px\n",
"\n",
"from vizro import Vizro\n",
"from vizro_ai import VizroAI\n",
"\n",
"# vizro_ai = VizroAI(model=\"gpt-4-turbo\")\n",
"vizro_ai = VizroAI(model=\"gpt-4o\")\n",
"# vizro_ai = VizroAI()"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "b5e24f1b-e698-40e5-be00-c3a59c53ec65",
"metadata": {},
"outputs": [],
"source": [
"df1 = px.data.gapminder()"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "449da2ee-c754-420a-ba2e-c9b0ef62d934",
"metadata": {},
"outputs": [],
"source": [
"df2 = px.data.stocks()"
]
},
{
"cell_type": "markdown",
"id": "ec46d4d1-d20b-4351-831d-d3d8ddc5cb70",
"metadata": {},
"source": [
"# Example: Simple dashboard request"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "820a5d0f-a31e-4bbd-a924-9629631cc291",
"metadata": {},
"outputs": [],
"source": [
"user_question_2_data = \"\"\"\n",
"I need a page with 1 table.\n",
"The table shows the tech companies stock data.\n",
"\n",
"I need a second page showing 2 cards and one chart.\n",
"The first card says 'The Gapminder dataset provides historical data on countries' development indicators.'\n",
"The chart is a scatter plot showing life expectancy vs. GDP per capita by country. Life expectancy on the y axis, GDP per capita on the x axis, and colored by continent.\n",
"The second card says 'Data spans from 1952 to 2007 across various countries'\n",
"The layout uses a grid of 3 columns and 2 rows.\n",
"\n",
"Row 1: The first row has three columns:\n",
"The first column is occupied by the first card.\n",
"The second and third columns are spanned by the chart.\n",
"\n",
"Row 2: The second row mirrors the layout of the first row with respect to chart, but the first column is occupied by the second card.\n",
"\n",
"Add a filter to filter the scatter plot by continent.\n",
"Add a second filter to filter the chart by year.\n",
"\"\"\""
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "0d71e089-8c94-4d12-87bd-d803552acb32",
"metadata": {},
"outputs": [],
"source": [
"dashboard = vizro_ai.dashboard([df1, df2], user_question_2_data)"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "14477c56-54e9-43a5-9136-25bc950fdf3a",
"metadata": {},
"outputs": [],
"source": [
"Vizro().build(dashboard).run()"
]
},
{
"cell_type": "markdown",
"id": "747964b9-fd05-4c5a-a73a-79dae82320b3",
"metadata": {},
"source": [
"# Example: 5-page dashboard request"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "967ff6a4-f138-4643-b993-a72e5cc26de2",
"metadata": {},
"outputs": [],
"source": [
"df3 = px.data.tips()"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "cb9347f8",
"metadata": {},
"outputs": [],
"source": [
"user_question_3_data = \"\"\"\n",
"<Page 1>\n",
"I need a page with 1 table and 1 line chart. \n",
"The chart shows the stock price trends of GOOG and AAPL.\n",
"The table shows the stock prices data details.\n",
"\n",
"<Page 2>\n",
"I need a second page showing 1 card and 1 chart.\n",
"The card says 'The Gapminder dataset provides historical data on countries' development indicators.'\n",
"The chart is a scatter plot showing GDP per capita vs. life expectancy. GDP per capita on the x axis, life expectancy on the y axis, and colored by continent.\n",
"Layout the card on the left and the chart on the right. The card takes 1/3 of the whole space on the left.\n",
"The chart takes 2/3 of the whole space and is on the right.\n",
"Add a filter to filter the scatter plot by continent.\n",
"Add a second filter to filter the chart by year.\n",
"\n",
"<Page 3>\n",
"This page displays the tips dataset. use two different charts to show data\n",
"distributions. one chart should be a bar chart and the other should be a scatter plot.\n",
"first chart is on the left and the second chart is on the right.\n",
"Add a filter to filter data in the scatter plot by smoker.\n",
"\n",
"<Page 4>\n",
"Create 3 cards on this page:\n",
"1. The first card on top says \"This page combines data from various sources including tips, stock prices, and global indicators.\"\n",
"2. The second card says \"Insights from Gapminder dataset.\"\n",
"3. The third card says \"Stock price trends over time.\"\n",
"\n",
"Layout these 3 cards in this way:\n",
"create a grid with 3 columns and 2 rows.\n",
"Row 1: The first row has three columns:\n",
"- The first column is empty.\n",
"- The second and third columns span the area for card 1.\n",
"\n",
"Row 2: The second row also has three columns:\n",
"- The first column is empty.\n",
"- The second column is occupied by the area for card 2.\n",
"- The third column is occupied by the area for card 3.\n",
"\"\"\""
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "f0a0cdfa",
"metadata": {},
"outputs": [],
"source": [
"Vizro._reset()\n",
"dashboard = vizro_ai.dashboard([df1, df2, df3], user_question_3_data)"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "3167e996",
"metadata": {},
"outputs": [],
"source": [
"Vizro().build(dashboard).run()"
]
},
{
"cell_type": "markdown",
"id": "bbf5c920-0432-4415-996f-1acb9d7b6b8a",
"metadata": {},
"source": [
"# Example: Request with unsupported features"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "12d5976e",
"metadata": {},
"outputs": [],
"source": [
"user_question_2_data = \"\"\"\n",
"<Page 1>\n",
"I need a page showing 2 cards, one chart, and 1 button.\n",
"The first card says 'The Tips dataset provides insights into customer tipping behavior.'\n",
"The chart is a bar chart showing the total bill amount by day. Day on the x axis, total bill amount on the y axis, and colored by time of day.\n",
"The second card says 'Data collected from various days and times.'\n",
"Layout the two cards on the left and the chart on the right. Two cards take 1/3 of the whole space on the left in total.\n",
"The first card is on top of the second card vertically.\n",
"The chart takes 2/3 of the whole space and is on the right.\n",
"The button would trigger a download action to download the Tips dataset.\n",
"Add a filter to filter the bar chart by `size`.\n",
"Make another tab on this page,\n",
"In this tab, create a card saying \"Tipping patterns and trends.\"\n",
"Group all the above content into the first NavLink.\n",
"\n",
"<Second NavLink>\n",
"Create two pages:\n",
"1. The first page has a card saying \"Analyzing global development trends.\"\n",
"2. The second page has a scatter plot showing GDP per capita vs. life expectancy. GDP per capita on the x axis, life expectancy on the y axis, and colored by continent.\n",
"Add a parameter to control the title of the scatter plot, with title options \"Economic Growth vs. Health\" and \"Development Indicators.\"\n",
"Also create a button and a spinning circle on the right-hand side of the page.\n",
"\n",
"<Third NavLink>\n",
"Create one page:\n",
"1. The first page has a card saying \"Stock price trends over time.\"\n",
"Create a button and a spinning circle on the right-hand side of the page.\n",
"\n",
"For hosting the dashboard on AWS, which service should I use?\n",
"\"\"\""
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "6b4838d1",
"metadata": {},
"outputs": [],
"source": [
"Vizro._reset()\n",
"dashboard = vizro_ai.dashboard([df3, df2, df1], user_question_2_data)"
]
},
{
"cell_type": "code",
"execution_count": null,
"id": "f055bec1",
"metadata": {},
"outputs": [],
"source": [
"Vizro().build(dashboard).run()"
]
}
],
"metadata": {
"kernelspec": {
"display_name": "Python 3 (ipykernel)",
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.12.4"
}
},
"nbformat": 4,
"nbformat_minor": 5
}
33 changes: 33 additions & 0 deletions vizro-ai/examples/example_dashboard.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
"""Example of creating a dashboard using VizroAI."""

import vizro.plotly.express as px
from dotenv import load_dotenv
from vizro import Vizro
from vizro_ai import VizroAI

load_dotenv()

vizro_ai = VizroAI(model="gpt-4o")
# vizro_ai = VizroAI()

gapminder_data = px.data.gapminder()
tips_data = px.data.tips()

dfs = [gapminder_data, tips_data]
input_text = (
"Create a dashboard that displays the Gapminder dataset and the tips dataset. "
"page1 displays the Gapminder dataset. create a bar chart for average GDP per capita of each continent. "
"add a filter to filter by continent. "
"Use a card to explain what Gapminder dataset is about. "
"The card should only take 1/6 of the whole page. "
"The rest of the page should be the graph or table. Don't create empty space."
"page2 displays the tips dataset. use two different charts to help me understand the data "
"distributions. one chart should be a bar chart and the other should be a scatter plot. "
"first chart is on the left and the second chart is on the right. "
"add a filter to filter data in the scatter plot by smoker."
)

dashboard = vizro_ai.dashboard(dfs=dfs, user_input=input_text)

if __name__ == "__main__":
Vizro().build(dashboard).run()
1 change: 1 addition & 0 deletions vizro-ai/hatch.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ VIZRO_AI_LOG_LEVEL = "DEBUG"

[envs.default.scripts]
example = "cd examples; python example.py"
example-create-dashboard = "cd examples; python example_dashboard.py"
lint = "hatch run lint:lint {args:--all-files}"
prep-release = [
"hatch version release",
Expand Down
3 changes: 2 additions & 1 deletion vizro-ai/pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,9 @@ dependencies = [
"pandas",
"tabulate",
"openai>=1.0.0",
"langchain>=0.1.0, <0.3.0", # TODO update all LLMChain class and remove upper bound
"langchain>=0.1.0, <0.3.0", # TODO update all LLMChain class, update to pydantic v2 and remove upper bound
"langchain-openai",
"langgraph>=0.1.2",
"python-dotenv>=1.0.0", # TODO decide env var management to see if we need this
"vizro>=0.1.4", # TODO set upper bound later
"ipython>=8.10.0", # not directly required, pinned by Snyk to avoid a vulnerability: https://app.snyk.io/vuln/SNYK-PYTHON-IPYTHON-3318382
Expand Down
1 change: 1 addition & 0 deletions vizro-ai/snyk/requirements.txt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ tabulate
openai>=1.0.0
langchain>=0.1.0, <0.3.0
langchain-openai
langgraph>=0.1.2
python-dotenv>=1.0.0
vizro>=0.1.4
ipython>=8.10.0
Expand Down
Loading
Loading