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

Various Linechart Issues (missing domain prop, not working allow_decimal prop, not working tick_count prop) #3752

Closed
s-kruschel opened this issue Aug 7, 2024 · 6 comments · Fixed by #3764
Labels
bug Something isn't working

Comments

@s-kruschel
Copy link

Describe the bug
Working with the rx.recharts.line_chart component I stumpled across several issues / bugs.

Missing domain prop.
Similar to this issue #3083 which was solved via PR #3652. Also the X_Axis component does miss the domain prop. Also I would like to suggest to add the domain prop directly to the axis component, instead of separately to the Y_Axis and X_Axis component as both should inherit domain from Axis - if I'm not wrong.

Not working allow_decimal prop
As I have numerical x- and y-values I would like to set allow_decimals = False. From my understanding, this should show integers as x-ticks instead of decimals. So e.g. 2.3445345234 should become 2 for the x-tick. However, setting it True, False or Default, does not make any difference.

Not working tick_count prop
As I have severals hundreds of values, I do not want to see every x-tick for every value, but an appropriate amount of ticks (e.g. 15). Setting tick_count = 15 does not show me 15 ticks but e.g. 2. This could be just a side-effect due to the length of the x-ticks when all decimals are shown in the plot. However, I'm not sure about that.

To Reproduce

import reflex as rx

data = [
        {"name": 1.23342434, "uv": 4000, "pv": 2400, "amt": 2400},
        {"name": 2.34245245234, "uv": 3000, "pv": 1398, "amt": 2210},
        {"name": 3.34456345, "uv": 2000, "pv": 9800, "amt": 2290},
        {"name": 4.5435345, "uv": 2780, "pv": 3908, "amt": 2000},
        {"name": 5.23543453, "uv": 1890, "pv": 4800, "amt": 2181},
        {"name": 6.2345345, "uv": 2390, "pv": 3800, "amt": 2500},
        {"name": 7.435345, "uv": 3490, "pv": 4300, "amt": 2100},
    ]


def index() -> rx.Component:
    return rx.recharts.line_chart(
        rx.recharts.line(data_key="uv", type_="step", dot=False),
        rx.recharts.x_axis(
            data_key="name",
            type_="number",
            domain=["dataMin", "dataMax"],
            allow_decimals=False, # I'd expect that only integers are shown as x-ticks.
            tick_count=5, # I'd expect that exact 5 ticks are shown on the x-axis. 
        ),
        rx.recharts.y_axis(),
        data=data,
        width="50%",
        height=300,
    )

Screenshots
screenshot

Specifics (please complete the following information):

  • Python Version: 3.10.3
  • Reflex Version: 0.5.8.
  • OS: macOS
@s-kruschel s-kruschel added the bug Something isn't working label Aug 7, 2024
@dimritium
Copy link
Contributor

dimritium commented Aug 7, 2024

@s-kruschel I tested with 0.5.9 and it seemed to work without any issue for tick_count and allow_decimal.

image

@s-kruschel
Copy link
Author

s-kruschel commented Aug 8, 2024

@dimritium Thanks for looking into this issue.

I only partly agree. Indeed, after upgrading to 0.5.9 the issue seems to be resolved. However, it is only due to the fact, that it overwrote my changes related to the domain prop. According to Recharts' XAxis documentation, also the XAxis component should have a domain prop - that's why I added it leading to my issues. As far as I understand it can be used to limit the X-Axis scale to e.g. 2 - 6 instead of 0 - 8 (according to the used example above). At least that is exactly what happens to the YAxis if I set e.g. rx.recharts.y_axis(domain=[1000, 4000]).

As soon as I implement that prop myself, it is not working anymore.

However, your comment was helpful as we now know, that allow_decimal and tick_count are indeed working. They only do not work, as soon as a domain prop is set.

I also tried to make similar changes like @Lendemor did in PR #3652 just for XAxis, however somehow it does not work.

Or, how would you limit the x-axis ticks / x-axis scale to not show the "empty value ranges" (in our example: 0- ~1.7 and ~7.6 - 8) and allow_decimals = False?

@dimritium
Copy link
Contributor

@s-kruschel I will take another look at source code, but last time I saw it seemed like domain is missing in XAxis implementation.

YAxis is working correctly with domain, right?

@s-kruschel
Copy link
Author

s-kruschel commented Aug 9, 2024

@dimritium exactly, domain is missing in XAxis implementation. That's why I added it and expected similar behaviour like for the YAxis. However, I was not able to get it to work. YAxis is indeed working, at least if setting domain. I do not know if it is working in combination withallow_decimals and tick_count.

I now implemented a workaround by calculating the ticks by myself and pass it to the ticks prop. However, this is not very nice and rather hacky.

@dimritium
Copy link
Contributor

@s-kruschel ok thanks, will try to test it today, might be able to raise a PR for this.

@dimritium
Copy link
Contributor

@s-kruschel I was able to make domain work, but then allow_decimals doesn't work :(
I found that this is a bug in recharts.js itself (JS library being used by reflex)

Reflex fix for domain:
Added domain for XAxis
image

Working XAxis domain but allow_decimals fail:
image

I also tested a fiddle with Recharts.js which also fails to respect allow_decimals if domain prop is present:
JS Recharts fiddle

picklelo pushed a commit that referenced this issue Aug 9, 2024
benedikt-bartscher pushed a commit to benedikt-bartscher/reflex that referenced this issue Aug 11, 2024
masenf added a commit that referenced this issue Aug 22, 2024
* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>
masenf added a commit that referenced this issue Aug 26, 2024
* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>
adhami3310 added a commit that referenced this issue Aug 27, 2024
* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>
adhami3310 added a commit that referenced this issue Aug 27, 2024
* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>
adhami3310 added a commit that referenced this issue Aug 27, 2024
* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>
adhami3310 added a commit that referenced this issue Oct 25, 2024
* basic functionality

* reorder page evaluation

* Fix benchmark tests (#3822)

* Upper bound for reflex-chakra dependency (#3824)

* Upper bound for reflex-chakra dependency

We have to make a breaking change in reflex-chakra, and it will happen in 0.6.0, so ensure that reflex 0.5.10 never installs the breaking version of reflex-chakra.

* Relock deps

* Add comments to DataList components (#3827)

* fix: Adding missing comments to the data list

* fix: Ran make pyi

* fully migrate vars into new system (#3743)

* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* guess_type: if the type is optional, treat it like it's "not None" (#3839)

* guess_type: if the type is optional, treat it like it's "not None"

When guessing the type for an Optional annotation, the Optional was already
being stripped off, but this value was being ignored, except for error
messages. So actually use the Optional-stripped value.

* Strip Optional when casting Var .to

* Fix double-quoting of defaultColorMode (#3840)

If the user provided an `appearance` or `color_mode` value to `rx.theme`, then
the resulting value ended up being double-double-quoted in the resulting JS
output.

Instead remove the quotes from the context.js.jinja2 and always pass appearance
as a Var.

* basic functionality

* run pyright

* fully migrate vars into new system (#3743)

* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* basic functionality

* reorder page evaluation

* fully migrate vars into new system (#3743)

* fully migrate vars into new system

* i hate rufffff (no i don't)

* fix silly pright issues (except colormode and state)

* remove all instances of Var.create

* create immutable callable var and get rid of more base vars

* implement hash for all functions

* get reflex-web to compile

* get it to compile reflex-web successfully

* fix tests

* fix pyi

* use override from typing_extension

* put plotly inside of a catch

* dicts are unusable sadly

* fix silly mistake

* overload equals to special case immutable var

* improve test_cond

* solve more CI issues, down to 94 failures

* down to 20 errors

* down to 13 errors

* pass all testcases

* fix pyright issues

* reorder things

* use get origin more

* use fixed_type logic

* various optimizations

* go back to passing test cases

* use less boilerplate

* remove unnecessary print message

* remove weird comment

* add test for html issue

* add type ignore

* fix another silly issue

* override get all var data for var operations call

* make integration tests pass

* fix immutable call var

* better logic for finding parent class

* use even better logic for finding state wrt computedvar

* only choose the ones that are defined in the same module

* small dict to large dict

* [REF-3591] Remove chakra-related files from immutable vars PR (#3821)

* Add comments to html metadata component (#3731)

* fix: add verification for path /404 (#3723)

Co-authored-by: coolstorm <[email protected]>

* Use the new state name when setting `is_hydrated` to false (#3738)

* Use `._is_mutable()` to account for parent state proxy (#3739)

When a parent state proxy is set, also allow child StateProxy._self_mutable to
override the parent's `_is_mutable()`.

* bump to 0.5.9 (#3746)

* add message when installing requirements.txt is needed for chosen template during init (#3750)

* #3752 bugfix add domain for XAxis (#3764)

* fix appharness app_source typing (#3777)

* fix import clash between connectionToaster and hooks.useState (#3749)

* use different registry when in china, fixes #3700 (#3702)

* do not reload compilation if using local app in AppHarness (#3790)

* do not reload if using local app

* Update reflex/testing.py

Co-authored-by: Masen Furer <[email protected]>

---------

Co-authored-by: Masen Furer <[email protected]>

* Bump memory on relevant actions (#3781)

Co-authored-by: Alek Petuskey <[email protected]>

* [REF-3334] Validate Toast Props (#3793)

* [REF-3536][REF-3537][REF-3541] Move chakra components into its repo(reflex-chakra) (#3798)

* fix get_uuid_string_var (#3795)

* minor State cleanup (#3768)

* Fix code wrap in markdown (#3755)

---------

Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Khaleel Al-Adhami <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* pyproject.toml: bump to 0.6.0a1

* pyproject.toml: depend on reflex-chakra>=0.6.0a

New Var system support in reflex-chakra 0.6.0a1

* poetry.lock: relock dependencies

* integration: bump listening timeout to 1200 seconds

* integration: bump listening timeout to 1800 seconds

* Use cached_var_no_lock to avoid ImmutableVar deadlocks (#3835)

* Use cached_var_no_lock to avoid ImmutableVar deadlocks

ImmutableVar subclasses will always return the same value for a _var_name or
_get_all_var_data so there is no need to use a per-class lock to protect a
cached attribute on an instance, and doing so actually is observed to cause
deadlocks when a particular _cached_var_name creates new LiteralVar instances
and attempts to serialize them.

* remove unused module global

---------

Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Elijah Ahianyo <[email protected]>

* guess_type: if the type is optional, treat it like it's "not None" (#3839)

* guess_type: if the type is optional, treat it like it's "not None"

When guessing the type for an Optional annotation, the Optional was already
being stripped off, but this value was being ignored, except for error
messages. So actually use the Optional-stripped value.

* Strip Optional when casting Var .to

* run format

* use original mp

* evaluate page regardless

* use old typing

* dangit pydantic

* i have two braincells and they are NOT collaborating

* adjust testcases

* always add the upload endpoint

* retrieve upload but after evaluate component

* check against none

Co-authored-by: Masen Furer <[email protected]>

* make it var

* fix page title

* don't change style.py

* fix counter

* remove duplicated logic

---------

Co-authored-by: Elijah Ahianyo <[email protected]>
Co-authored-by: Masen Furer <[email protected]>
Co-authored-by: elvis kahoro <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Co-authored-by: Manas Gupta <[email protected]>
Co-authored-by: coolstorm <[email protected]>
Co-authored-by: Thomas Brandého <[email protected]>
Co-authored-by: Shubhankar Dimri <[email protected]>
Co-authored-by: benedikt-bartscher <[email protected]>
Co-authored-by: Alek Petuskey <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
2 participants