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

Add variable height/width property for charts #4578

Closed
MShekow opened this issue Dec 31, 2024 · 2 comments · Fixed by #4587
Closed

Add variable height/width property for charts #4578

MShekow opened this issue Dec 31, 2024 · 2 comments · Fixed by #4587
Labels
enhancement Anything you want improved

Comments

@MShekow
Copy link

MShekow commented Dec 31, 2024

Describe the Enhancement you want

All charts inheriting from reflex.components.recharts.charts.ChartBase are limited because the height or width property cannot be assigned to a State attribute. Trying to do so would result in the following error:

<more stuff, omitted>
File "D:\Code\reflex-demo\reflex_demo\reflex_demo.py", line 22, in bar_vertical
    return rx.recharts.bar_chart(
           ^^^^^^^^^^^^^^^^^^^^^^
  File "D:\Code\reflex-demo\.venv\Lib\site-packages\reflex\components\recharts\charts.py", line 89, in create
    "height": height or "100%",
              ^^^^^^^^^^^^^^^^
  File "D:\Code\reflex-demo\.venv\Lib\site-packages\reflex\vars\base.py", line 1181, in __bool__
    raise VarTypeError(
reflex.utils.exceptions.VarTypeError: Cannot convert Var 'reflex___state____state__reflex_demo___reflex_demo____graph_data_state.height' to bool for use with `if`, `and`, `or`, and `not`. Instead use `rx.cond` and bitwise operators `&` (and), `|` (or), `~` (invert).

This is for the following example:

import reflex as rx

app = rx.App()


@rx.page(route="/", title="Demo")
def bar_vertical():
    return rx.recharts.bar_chart(
        rx.recharts.bar(
            data_key="uv",
            stroke=rx.color("accent", 8),
            fill=rx.color("accent", 3),
        ),
        rx.recharts.x_axis(type_="number"),
        rx.recharts.y_axis(
            data_key="name", type_="category"
        ),
        data=GraphDataState.data,
        layout="vertical",
        margin={
            "top": 20,
            "right": 20,
            "left": 20,
            "bottom": 20,
        },
        width="100%",
        height=GraphDataState.height,
    )


class GraphDataState(rx.State):
    data = [
        {"name": "Page A", "uv": 4000, "pv": 2400, "amt": 2400},
        {"name": "Page B", "uv": 3000, "pv": 1398, "amt": 2210},
        {"name": "Page C", "uv": 2000, "pv": 9800, "amt": 2290},
        {"name": "Page D", "uv": 2780, "pv": 3908, "amt": 2000},
        {"name": "Page E", "uv": 1890, "pv": 4800, "amt": 2181},
        {"name": "Page F", "uv": 2390, "pv": 3800, "amt": 2500},
        {"name": "Page G", "uv": 3490, "pv": 4300, "amt": 2100},
    ]

    height: int = 900

Thus, I'm forced to hard-code the height / width (as integers or percentage strings).

Hard-coding numbers make no sense because data often comes from a database, and I don't know beforehand how many rows the database will return. Sure, my application logic needs to keep the numbers in check (I don't want to plot a bar chart with 1000000 entries), but I would like to be able to compute a sensible height in my State's on_load_data() method. Would this addition be possible?

@MShekow MShekow added the enhancement Anything you want improved label Dec 31, 2024
Copy link

linear bot commented Dec 31, 2024

@KanvaBhatia
Copy link
Contributor

KanvaBhatia commented Jan 4, 2025

Hi, I would like to work on this issue.
I have a proposed solution that is working -

Here - https://github.com/reflex-dev/reflex/blob/dcdcbfd83391314db93cb2cdbbf3cc12619d084e/reflex/components/recharts/charts.py#L87C3-L90C10

instead of using the following -

dim_props = {
    "width": width or "100%",
    "height": height or "100%",
}

changing it to the following works

dim_props = {
    "width": width if width is not None else "100%",
    "height": height if height is not None else "100%",
}

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement Anything you want improved
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants