reflex 0.4.8.post1__py3-none-any.whl → 0.4.9a1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of reflex might be problematic. Click here for more details.

Files changed (29) hide show
  1. reflex/components/component.py +10 -3
  2. reflex/components/core/debounce.py +4 -1
  3. reflex/constants/installer.py +0 -1
  4. reflex/experimental/__init__.py +2 -0
  5. reflex/experimental/hooks.py +19 -1
  6. reflex/experimental/layout.py +223 -0
  7. reflex/testing.py +23 -6
  8. reflex/utils/prerequisites.py +6 -4
  9. reflex/utils/processes.py +22 -1
  10. reflex/utils/serializers.py +14 -0
  11. reflex/vars.py +1 -1
  12. {reflex-0.4.8.post1.dist-info → reflex-0.4.9a1.dist-info}/METADATA +1 -1
  13. {reflex-0.4.8.post1.dist-info → reflex-0.4.9a1.dist-info}/RECORD +16 -28
  14. reflex/components/radix/themes/components/alertdialog.pyi +0 -1128
  15. reflex/components/radix/themes/components/aspectratio.pyi +0 -162
  16. reflex/components/radix/themes/components/contextmenu.pyi +0 -1249
  17. reflex/components/radix/themes/components/dropdownmenu.pyi +0 -1350
  18. reflex/components/radix/themes/components/hovercard.pyi +0 -700
  19. reflex/components/radix/themes/components/iconbutton.pyi +0 -284
  20. reflex/components/radix/themes/components/radiogroup.pyi +0 -701
  21. reflex/components/radix/themes/components/scrollarea.pyi +0 -176
  22. reflex/components/radix/themes/components/textfield.pyi +0 -1092
  23. reflex/components/radix/themes/typography/em.pyi +0 -213
  24. reflex/components/radix/themes/typography/kbd.pyi +0 -222
  25. reflex/components/radix/themes/typography/quote.pyi +0 -215
  26. reflex/components/radix/themes/typography/strong.pyi +0 -213
  27. {reflex-0.4.8.post1.dist-info → reflex-0.4.9a1.dist-info}/LICENSE +0 -0
  28. {reflex-0.4.8.post1.dist-info → reflex-0.4.9a1.dist-info}/WHEEL +0 -0
  29. {reflex-0.4.8.post1.dist-info → reflex-0.4.9a1.dist-info}/entry_points.txt +0 -0
@@ -662,9 +662,11 @@ class Component(BaseComponent, ABC):
662
662
  (
663
663
  child
664
664
  if isinstance(child, Component)
665
- else Fragment.create(*child)
666
- if isinstance(child, tuple)
667
- else Bare.create(contents=Var.create(child, _var_is_string=True))
665
+ else (
666
+ Fragment.create(*child)
667
+ if isinstance(child, tuple)
668
+ else Bare.create(contents=Var.create(child, _var_is_string=True))
669
+ )
668
670
  )
669
671
  for child in children
670
672
  ]
@@ -1053,6 +1055,11 @@ class Component(BaseComponent, ABC):
1053
1055
  ImportVar(tag="useEffect"),
1054
1056
  },
1055
1057
  )
1058
+
1059
+ user_hooks = self._get_hooks()
1060
+ if user_hooks is not None and isinstance(user_hooks, Var):
1061
+ _imports = imports.merge_imports(_imports, user_hooks._var_data.imports) # type: ignore
1062
+
1056
1063
  return _imports
1057
1064
 
1058
1065
  def _get_imports(self) -> imports.ImportDict:
@@ -79,7 +79,9 @@ class DebounceInput(Component):
79
79
  for p in cls.get_props()
80
80
  if getattr(child, p, None) is not None
81
81
  }
82
- props_from_child.update(child.event_triggers)
82
+ props[EventTriggers.ON_CHANGE] = child.event_triggers.pop(
83
+ EventTriggers.ON_CHANGE
84
+ )
83
85
  props = {**props_from_child, **props}
84
86
 
85
87
  # Carry all other child props directly via custom_attrs
@@ -117,6 +119,7 @@ class DebounceInput(Component):
117
119
 
118
120
  component = super().create(**props)
119
121
  component._get_style = child._get_style
122
+ component.event_triggers.update(child.event_triggers)
120
123
  return component
121
124
 
122
125
  def get_event_triggers(self) -> dict[str, Any]:
@@ -112,7 +112,6 @@ class PackageJson(SimpleNamespace):
112
112
  "next-themes": "0.2.1",
113
113
  "react": "18.2.0",
114
114
  "react-dom": "18.2.0",
115
- "react-focus-lock": "2.11.3",
116
115
  "socket.io-client": "4.6.1",
117
116
  "universal-cookie": "4.0.4",
118
117
  }
@@ -4,6 +4,7 @@ from types import SimpleNamespace
4
4
 
5
5
  from ..utils.console import warn
6
6
  from . import hooks as hooks
7
+ from .layout import layout as layout
7
8
  from .misc import run_in_thread as run_in_thread
8
9
 
9
10
  warn(
@@ -12,5 +13,6 @@ warn(
12
13
 
13
14
  _x = SimpleNamespace(
14
15
  hooks=hooks,
16
+ layout=layout,
15
17
  run_in_thread=run_in_thread,
16
18
  )
@@ -12,7 +12,7 @@ def _add_react_import(v: Var | None, tags: str | list):
12
12
  tags = [tags]
13
13
 
14
14
  v._var_data = VarData( # type: ignore
15
- imports={"react": [ImportVar(tag=tag) for tag in tags]},
15
+ imports={"react": [ImportVar(tag=tag, install=False) for tag in tags]},
16
16
  )
17
17
 
18
18
 
@@ -26,6 +26,8 @@ def const(name, value) -> Var | None:
26
26
  Returns:
27
27
  The constant Var.
28
28
  """
29
+ if isinstance(name, list):
30
+ return Var.create(f"const [{', '.join(name)}] = {value}")
29
31
  return Var.create(f"const {name} = {value}")
30
32
 
31
33
 
@@ -73,3 +75,19 @@ def useRef(default) -> Var | None:
73
75
  v = Var.create(f"useRef({default})")
74
76
  _add_react_import(v, "useRef")
75
77
  return v
78
+
79
+
80
+ def useState(var_name, default=None) -> Var | None:
81
+ """Create a useState hook with a variable name and setter name.
82
+
83
+ Args:
84
+ var_name: The name of the variable.
85
+ default: The default value of the variable.
86
+
87
+ Returns:
88
+ A useState hook.
89
+ """
90
+ setter_name = f"set{var_name.capitalize()}"
91
+ v = const([var_name, setter_name], f"useState({default})")
92
+ _add_react_import(v, "useState")
93
+ return v
@@ -0,0 +1,223 @@
1
+ """To experiment with layout component, move them to reflex/components later."""
2
+
3
+ from reflex import color, cond
4
+ from reflex.components.base.fragment import Fragment
5
+ from reflex.components.component import Component, ComponentNamespace, MemoizationLeaf
6
+ from reflex.components.radix.primitives.drawer import DrawerRoot, drawer
7
+ from reflex.components.radix.themes.components.icon_button import IconButton
8
+ from reflex.components.radix.themes.layout import Box, Container, HStack
9
+ from reflex.event import call_script
10
+ from reflex.experimental import hooks
11
+ from reflex.state import ComponentState
12
+ from reflex.vars import Var
13
+
14
+
15
+ class Sidebar(Box, MemoizationLeaf):
16
+ """A component that renders the sidebar."""
17
+
18
+ @classmethod
19
+ def create(cls, *children, **props):
20
+ """Create the sidebar component.
21
+
22
+ Args:
23
+ children: The children components.
24
+ props: The properties of the sidebar.
25
+
26
+ Returns:
27
+ The sidebar component.
28
+ """
29
+ props.setdefault("border_right", f"1px solid {color('accent', 12)}")
30
+ props.setdefault("background_color", color("accent", 1))
31
+ props.setdefault("width", "20vw")
32
+ props.setdefault("height", "100vh")
33
+ props.setdefault("position", "fixed")
34
+
35
+ return super().create(
36
+ Box.create(*children, **props), # sidebar for content
37
+ Box.create(width=props.get("width")), # spacer for layout
38
+ )
39
+
40
+ def _apply_theme(self, theme: Component | None):
41
+ sidebar: Component = self.children[-2] # type: ignore
42
+ spacer: Component = self.children[-1] # type: ignore
43
+ open = self.State.open if self.State else Var.create("open") # type: ignore
44
+ sidebar.style["display"] = spacer.style["display"] = cond(open, "block", "none")
45
+
46
+ def _get_hooks(self) -> Var | None:
47
+ return hooks.useState("open", "true") if not self.State else None
48
+
49
+
50
+ class StatefulSidebar(ComponentState):
51
+ """Bind a state to a sidebar component."""
52
+
53
+ open: bool = True
54
+
55
+ def toggle(self):
56
+ """Toggle the sidebar."""
57
+ self.open = not self.open
58
+
59
+ @classmethod
60
+ def get_component(cls, *children, **props):
61
+ """Get the stateful sidebar component.
62
+
63
+ Args:
64
+ children: The children components.
65
+ props: The properties of the sidebar.
66
+
67
+ Returns:
68
+ The stateful sidebar component.
69
+ """
70
+ return Sidebar.create(*children, **props)
71
+
72
+
73
+ class DrawerSidebar(DrawerRoot):
74
+ """A component that renders a drawer sidebar."""
75
+
76
+ @classmethod
77
+ def create(cls, *children, **props):
78
+ """Create the sidebar component.
79
+
80
+ Args:
81
+ children: The children components.
82
+ props: The properties of the sidebar.
83
+
84
+ Returns:
85
+ The drawer sidebar component.
86
+ """
87
+ direction = props.pop("direction", "left")
88
+ props.setdefault("border_right", f"1px solid {color('accent', 12)}")
89
+ props.setdefault("background_color", color("accent", 1))
90
+ props.setdefault("width", "20vw")
91
+ props.setdefault("height", "100vh")
92
+ return super().create(
93
+ drawer.trigger(
94
+ IconButton.create(
95
+ "arrow-right-from-line",
96
+ background_color="transparent",
97
+ ),
98
+ position="absolute",
99
+ top="15",
100
+ left="15",
101
+ ),
102
+ drawer.portal(
103
+ drawer.content(
104
+ *children,
105
+ **props,
106
+ )
107
+ ),
108
+ direction=direction,
109
+ )
110
+
111
+
112
+ sidebar_trigger_style = {
113
+ "position": "fixed",
114
+ "z_index": "15",
115
+ "color": color("accent", 12),
116
+ "background_color": "transparent",
117
+ "padding": "0",
118
+ }
119
+
120
+
121
+ class SidebarTrigger(Fragment):
122
+ """A component that renders the sidebar trigger."""
123
+
124
+ @classmethod
125
+ def create(cls, sidebar: Component, **props):
126
+ """Create the sidebar trigger component.
127
+
128
+ Args:
129
+ sidebar: The sidebar component.
130
+ props: The properties of the sidebar trigger.
131
+
132
+ Returns:
133
+ The sidebar trigger component.
134
+ """
135
+ trigger_props = {**props, **sidebar_trigger_style}
136
+
137
+ inner_sidebar: Component = sidebar.children[0] # type: ignore
138
+ sidebar_width = inner_sidebar.style.get("width")
139
+
140
+ if sidebar.State:
141
+ open, toggle = sidebar.State.open, sidebar.State.toggle # type: ignore
142
+ else:
143
+ open, toggle = Var.create("open"), call_script(Var.create("setOpen(!open)")) # type: ignore
144
+
145
+ trigger_props["left"] = cond(open, f"calc({sidebar_width} - 32px)", "0")
146
+
147
+ trigger = cond(
148
+ open,
149
+ IconButton.create(
150
+ "arrow-left-from-line",
151
+ on_click=toggle,
152
+ **trigger_props,
153
+ ),
154
+ IconButton.create(
155
+ "arrow-right-from-line",
156
+ on_click=toggle,
157
+ **trigger_props,
158
+ ),
159
+ )
160
+ return super().create(trigger)
161
+
162
+
163
+ class Layout(Box):
164
+ """A component that renders the layout."""
165
+
166
+ @classmethod
167
+ def create(
168
+ cls,
169
+ *content: Component,
170
+ sidebar: Component | None = None,
171
+ **props,
172
+ ):
173
+ """Create the layout component.
174
+
175
+ Args:
176
+ content: The content component.
177
+ sidebar: The sidebar component.
178
+ props: The properties of the layout.
179
+
180
+ Returns:
181
+ The layout component.
182
+ """
183
+ layout_root = HStack.create
184
+
185
+ if sidebar is None:
186
+ return Container.create(*content, **props)
187
+
188
+ if isinstance(sidebar, DrawerSidebar):
189
+ return super().create(
190
+ sidebar,
191
+ Container.create(*content, height="100%"),
192
+ **props,
193
+ width="100vw",
194
+ min_height="100vh",
195
+ )
196
+
197
+ if not isinstance(sidebar, Sidebar):
198
+ sidebar = Sidebar.create(sidebar)
199
+
200
+ # Add the sidebar trigger to the sidebar as first child to not mess up the rendering.
201
+ sidebar.children.insert(0, SidebarTrigger.create(sidebar))
202
+
203
+ return super().create(
204
+ layout_root(
205
+ sidebar,
206
+ Container.create(*content, height="100%"),
207
+ **props,
208
+ width="100vw",
209
+ min_height="100vh",
210
+ )
211
+ )
212
+
213
+
214
+ class LayoutNamespace(ComponentNamespace):
215
+ """Namespace for layout components."""
216
+
217
+ drawer_sidebar = staticmethod(DrawerSidebar.create)
218
+ stateful_sidebar = staticmethod(StatefulSidebar.create)
219
+ sidebar = staticmethod(Sidebar.create)
220
+ __call__ = staticmethod(Layout.create)
221
+
222
+
223
+ layout = LayoutNamespace()
reflex/testing.py CHANGED
@@ -112,7 +112,9 @@ class AppHarness:
112
112
  """AppHarness executes a reflex app in-process for testing."""
113
113
 
114
114
  app_name: str
115
- app_source: Optional[types.FunctionType | types.ModuleType] | str
115
+ app_source: Optional[
116
+ types.FunctionType | types.ModuleType | str | functools.partial
117
+ ]
116
118
  app_path: pathlib.Path
117
119
  app_module_path: pathlib.Path
118
120
  app_module: Optional[types.ModuleType] = None
@@ -124,6 +126,7 @@ class AppHarness:
124
126
  backend: Optional[uvicorn.Server] = None
125
127
  state_manager: Optional[StateManagerMemory | StateManagerRedis] = None
126
128
  _frontends: list["WebDriver"] = dataclasses.field(default_factory=list)
129
+ _decorated_pages: list = dataclasses.field(default_factory=list)
127
130
 
128
131
  @classmethod
129
132
  def create(
@@ -149,15 +152,21 @@ class AppHarness:
149
152
  """
150
153
  if app_name is None:
151
154
  if app_source is None:
152
- app_name = root.name.lower()
155
+ app_name = root.name
153
156
  elif isinstance(app_source, functools.partial):
154
- app_name = app_source.func.__name__.lower()
157
+ keywords = app_source.keywords
158
+ slug_suffix = "_".join([str(v) for v in keywords.values()])
159
+ func_name = app_source.func.__name__
160
+ app_name = f"{func_name}_{slug_suffix}"
161
+ app_name = re.sub(r"[^a-zA-Z0-9_]", "_", app_name)
155
162
  elif isinstance(app_source, str):
156
163
  raise ValueError(
157
164
  "app_name must be provided when app_source is a string."
158
165
  )
159
166
  else:
160
- app_name = app_source.__name__.lower()
167
+ app_name = app_source.__name__
168
+
169
+ app_name = app_name.lower()
161
170
  return cls(
162
171
  app_name=app_name,
163
172
  app_source=app_source,
@@ -230,11 +239,15 @@ class AppHarness:
230
239
  with chdir(self.app_path):
231
240
  # ensure config and app are reloaded when testing different app
232
241
  reflex.config.get_config(reload=True)
233
- # Clean out any `rx.page` decorators from other tests.
234
- reflex.app.DECORATED_PAGES.clear()
242
+ # Save decorated pages before importing the test app module
243
+ before_decorated_pages = reflex.app.DECORATED_PAGES.copy()
235
244
  # Ensure the AppHarness test does not skip State assignment due to running via pytest
236
245
  os.environ.pop(reflex.constants.PYTEST_CURRENT_TEST, None)
237
246
  self.app_module = reflex.utils.prerequisites.get_compiled_app(reload=True)
247
+ # Save the pages that were added during testing
248
+ self._decorated_pages = [
249
+ p for p in reflex.app.DECORATED_PAGES if p not in before_decorated_pages
250
+ ]
238
251
  self.app_instance = self.app_module.app
239
252
  if isinstance(self.app_instance._state_manager, StateManagerRedis):
240
253
  # Create our own redis connection for testing.
@@ -396,6 +409,10 @@ class AppHarness:
396
409
  for driver in self._frontends:
397
410
  driver.quit()
398
411
 
412
+ # Cleanup decorated pages added during testing
413
+ for page in self._decorated_pages:
414
+ reflex.app.DECORATED_PAGES.remove(page)
415
+
399
416
  def __exit__(self, *excinfo) -> None:
400
417
  """Contextmanager protocol for `stop()`.
401
418
 
@@ -821,14 +821,16 @@ def install_frontend_packages(packages: set[str], config: Config):
821
821
  Example:
822
822
  >>> install_frontend_packages(["react", "react-dom"], get_config())
823
823
  """
824
- # unsupported archs will use npm anyway. so we dont have to run npm twice
824
+ # unsupported archs(arm and 32bit machines) will use npm anyway. so we dont have to run npm twice
825
825
  fallback_command = (
826
- get_package_manager()
827
- if constants.IS_WINDOWS and constants.IS_WINDOWS_BUN_SUPPORTED_MACHINE
826
+ get_install_package_manager()
827
+ if not constants.IS_WINDOWS
828
+ or constants.IS_WINDOWS
829
+ and constants.IS_WINDOWS_BUN_SUPPORTED_MACHINE
828
830
  else None
829
831
  )
830
832
  processes.run_process_with_fallback(
831
- [get_install_package_manager(), "install", "--loglevel", "silly"],
833
+ [get_install_package_manager(), "install"], # type: ignore
832
834
  fallback=fallback_command,
833
835
  show_status_message="Installing base frontend packages",
834
836
  cwd=constants.Dirs.WEB,
reflex/utils/processes.py CHANGED
@@ -8,6 +8,7 @@ import os
8
8
  import signal
9
9
  import subprocess
10
10
  from concurrent import futures
11
+ from pathlib import Path
11
12
  from typing import Callable, Generator, List, Optional, Tuple, Union
12
13
 
13
14
  import psutil
@@ -145,6 +146,7 @@ def new_process(args, run: bool = False, show_logs: bool = False, **kwargs):
145
146
  "stdout": None if show_logs else subprocess.PIPE,
146
147
  "universal_newlines": True,
147
148
  "encoding": "UTF-8",
149
+ "errors": "replace", # Avoid UnicodeDecodeError in unknown command output
148
150
  **kwargs,
149
151
  }
150
152
  console.debug(f"Running command: {args}")
@@ -296,6 +298,25 @@ def atexit_handler():
296
298
  console.log("Reflex app stopped.")
297
299
 
298
300
 
301
+ def get_command_with_loglevel(command: list[str]) -> list[str]:
302
+ """Add the right loglevel flag to the designated command.
303
+ npm uses --loglevel <level>, Bun doesnt use the --loglevel flag and
304
+ runs in debug mode by default.
305
+
306
+ Args:
307
+ command:The command to add loglevel flag.
308
+
309
+ Returns:
310
+ The updated command list
311
+ """
312
+ npm_path = path_ops.get_npm_path()
313
+ npm_path = str(Path(npm_path).resolve()) if npm_path else npm_path
314
+
315
+ if command[0] == npm_path:
316
+ return command + ["--loglevel", "silly"]
317
+ return command
318
+
319
+
299
320
  def run_process_with_fallback(args, *, show_status_message, fallback=None, **kwargs):
300
321
  """Run subprocess and retry using fallback command if initial command fails.
301
322
 
@@ -305,7 +326,7 @@ def run_process_with_fallback(args, *, show_status_message, fallback=None, **kwa
305
326
  fallback: The fallback command to run.
306
327
  kwargs: Kwargs to pass to new_process function.
307
328
  """
308
- process = new_process(args, **kwargs)
329
+ process = new_process(get_command_with_loglevel(args), **kwargs)
309
330
  if fallback is None:
310
331
  # No fallback given, or this _is_ the fallback command.
311
332
  show_status(show_status_message, process)
@@ -7,6 +7,7 @@ import types as builtin_types
7
7
  import warnings
8
8
  from datetime import date, datetime, time, timedelta
9
9
  from enum import Enum
10
+ from pathlib import Path
10
11
  from typing import Any, Callable, Dict, List, Set, Tuple, Type, Union, get_type_hints
11
12
 
12
13
  from reflex.base import Base
@@ -233,6 +234,19 @@ def serialize_datetime(dt: Union[date, datetime, time, timedelta]) -> str:
233
234
  return str(dt)
234
235
 
235
236
 
237
+ @serializer
238
+ def serialize_path(path: Path):
239
+ """Serialize a pathlib.Path to a JSON string.
240
+
241
+ Args:
242
+ path: The path to serialize.
243
+
244
+ Returns:
245
+ The serialized path.
246
+ """
247
+ return str(path.as_posix())
248
+
249
+
236
250
  @serializer
237
251
  def serialize_enum(en: Enum) -> str:
238
252
  """Serialize a enum to a JSON string.
reflex/vars.py CHANGED
@@ -1340,7 +1340,7 @@ class Var:
1340
1340
  Returns:
1341
1341
  A var representing the contain check.
1342
1342
  """
1343
- if not (types._issubclass(self._var_type, Union[dict, list, tuple, str])):
1343
+ if not (types._issubclass(self._var_type, Union[dict, list, tuple, str, set])):
1344
1344
  raise TypeError(
1345
1345
  f"Var {self._var_full_name} of type {self._var_type} does not support contains check."
1346
1346
  )
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: reflex
3
- Version: 0.4.8.post1
3
+ Version: 0.4.9a1
4
4
  Summary: Web apps in pure Python.
5
5
  Home-page: https://reflex.dev
6
6
  License: Apache-2.0
@@ -232,7 +232,7 @@ reflex/components/chakra/typography/span.py,sha256=2DbW5DB27ijtTeugSDUVp3nQ64mrG
232
232
  reflex/components/chakra/typography/span.pyi,sha256=itDe7RpjJN_K_9pZ7n_U9qlrTshGejv9lh5plvh3DCU,3372
233
233
  reflex/components/chakra/typography/text.py,sha256=9YXBdK5UYqgDam3ITeRSnd8bu9ht3zydt0pkmJAECsk,472
234
234
  reflex/components/chakra/typography/text.pyi,sha256=FzqNtf0NUkGmRLrazSyfKHqznJjz_KCryU-2sRghZ0M,3596
235
- reflex/components/component.py,sha256=jG_HT2cHLr9FdRsl6ruvYA41GJRSjxjGatVYIUxjIo4,66011
235
+ reflex/components/component.py,sha256=ujoniXIsD9mEuRhA3aaucI49GNSjnrSF4leELN0qXd4,66268
236
236
  reflex/components/core/__init__.py,sha256=mMSd2IZqBgGf7zkjuPeA-oIiIXu_O08fk9x15D8hBSU,844
237
237
  reflex/components/core/banner.py,sha256=DxYh4ORFIQlPPxvT-gudF0A8yj22oy6D_0IldTVHuZU,5943
238
238
  reflex/components/core/banner.pyi,sha256=PPS1GJLp5uyD1h6mI0Fs-IKf9w4l7qG50rmkSA_HVno,17164
@@ -240,7 +240,7 @@ reflex/components/core/client_side_routing.py,sha256=mdZsGuc1V9qvOE0TaLEnXmXo0qH
240
240
  reflex/components/core/client_side_routing.pyi,sha256=7Zel95b6tqfW0ulIJEHh9fmG_6av9eNeNjtORZ73jjM,6264
241
241
  reflex/components/core/colors.py,sha256=-hzVGLEq3TiqroqzMi_YzGBCPXMvkNsen3pS_NzIQNk,590
242
242
  reflex/components/core/cond.py,sha256=mKErdfgzMGDZ1VY7_ZLYWjFCaWF6m6jYLxiQ0eCISyY,6291
243
- reflex/components/core/debounce.py,sha256=r8gQ2udsul-zttKtuSEgGgtykq4_rZGIkJX0aupq28c,4642
243
+ reflex/components/core/debounce.py,sha256=waoY83ahekI2HOZXmch-q5Aj8CglDNF9_uQV14KeWU8,4763
244
244
  reflex/components/core/debounce.pyi,sha256=bi33P1deFHLLKpYLv8B2TroF45EuLRYOAA0g1U_gF-Y,4149
245
245
  reflex/components/core/foreach.py,sha256=Qk6UtwzQY6PR8-v40XRdt3knXiVH33cukbEvzyTV7XA,4031
246
246
  reflex/components/core/html.py,sha256=Un5qSM7T7AeYcXK_7Hs9YkStyUGtq1vtuJraQJdVPgA,1033
@@ -333,10 +333,8 @@ reflex/components/radix/themes/color_mode.pyi,sha256=t4NB9L6B5rnSGPc8TKcU2gFxys5
333
333
  reflex/components/radix/themes/components/__init__.py,sha256=CqJ0RLtjXOarnI1iQulFpANvX3TWFE5bw1jR-NFxVxs,1776
334
334
  reflex/components/radix/themes/components/alert_dialog.py,sha256=QNxRfqZZQb5oYG1or68cYOYH5NaSuy3RK03QrLyfhuA,3267
335
335
  reflex/components/radix/themes/components/alert_dialog.pyi,sha256=gVA8HRj4a_BmioWMIK8u6Xo4jO8QtwOcn7rKJtnmTlk,24434
336
- reflex/components/radix/themes/components/alertdialog.pyi,sha256=phU_g_eLYvKczHWEFaz8NwOzocV0rUwRmTdU0uJNtSE,40237
337
336
  reflex/components/radix/themes/components/aspect_ratio.py,sha256=jNoNtYkUYxhbBT90WjQYyuDPCpZFq4linlBvu4Qz3n4,400
338
337
  reflex/components/radix/themes/components/aspect_ratio.pyi,sha256=BrAbHWtv9nJFq_A0pdz5k4KdE2mKFHBJhCKVXK0pmXk,3640
339
- reflex/components/radix/themes/components/aspectratio.pyi,sha256=f_xFJFdoUP3Z8lp7r7Z8kuuv4TXgRUwTmEkgjjmR5T4,5724
340
338
  reflex/components/radix/themes/components/avatar.py,sha256=cwSbajTICFi_jnLBRP8-T_IKaXFKF9ZQj5UbpQvUA0E,989
341
339
  reflex/components/radix/themes/components/avatar.pyi,sha256=u9y5XAfe5td14EGu38mi9CDPLgIwZgxIJbaGxWQRsWQ,6562
342
340
  reflex/components/radix/themes/components/badge.py,sha256=XAaVsmxb6irTmTedN5TcZRodoPK_AdmUARiSbmK9b9E,815
@@ -351,28 +349,22 @@ reflex/components/radix/themes/components/checkbox.py,sha256=KFwGAvPXb1elNmjJZYh
351
349
  reflex/components/radix/themes/components/checkbox.pyi,sha256=NEEbJq4-dxh6VnWRjP0TL5wfpw9bl7UPQ2CskeRTqEI,20877
352
350
  reflex/components/radix/themes/components/context_menu.py,sha256=ReofwS0fIRjhyFnfrnv-IRB3nyCW0U_0An1TP5a1GOk,5049
353
351
  reflex/components/radix/themes/components/context_menu.pyi,sha256=Z053-qFpuW38NpFzuik6ltiaUJJbUAdEdQSDY_97k_s,31192
354
- reflex/components/radix/themes/components/contextmenu.pyi,sha256=357JCaGfRMYEILNgRq82ypXtWXIpz4K1aIW7LFC9fjI,44130
355
352
  reflex/components/radix/themes/components/dialog.py,sha256=DsvATCzPVshYyZssl6yxfDj4Y8yfZPMSFJQG3zUbffg,2600
356
353
  reflex/components/radix/themes/components/dialog.pyi,sha256=Uns0-9zljL41ecgvxrDLjx3rTnS4-ylfEmHLOe3dfZk,24895
357
354
  reflex/components/radix/themes/components/dropdown_menu.py,sha256=l4aVffoCdvezVjjXiMrBebMtFhEXmpTMUdZK28lsb8I,11256
358
355
  reflex/components/radix/themes/components/dropdown_menu.pyi,sha256=T9dvKSPEtFTEnaZ93o5sIZDpzCB0N_hbmdpTbYS_Sjk,37901
359
- reflex/components/radix/themes/components/dropdownmenu.pyi,sha256=Ju6dMbZip2nZ-nt3wOLHHzXblIzYOLoWyugopVqpPyI,52185
360
356
  reflex/components/radix/themes/components/hover_card.py,sha256=H8Utf1ox86YFYr-I9MYwD5iUzzpYRO2rAgB0k5TvnN8,2405
361
357
  reflex/components/radix/themes/components/hover_card.pyi,sha256=4uS8yhPJbWT5no8-pPGt9XJMp7iymqoSj7L9uu1yy9Q,17744
362
- reflex/components/radix/themes/components/hovercard.pyi,sha256=njC-fowMS34Gm1ftJcG37a-YvTAlgNXWPajacws0fCo,26453
363
358
  reflex/components/radix/themes/components/icon_button.py,sha256=IgllS5Jbc_6zFQEsK4FMuihS4hv0nu_QPF0rRTs3_rQ,2789
364
359
  reflex/components/radix/themes/components/icon_button.pyi,sha256=rNUnPmNO_fEMJxEiHWmfOHwetNOE71mWdW3FQF2Syyc,11916
365
- reflex/components/radix/themes/components/iconbutton.pyi,sha256=zN08ul2fa-RHBZEoGJlEAwagBa08PgcLOG_RGBvpFYg,12021
366
360
  reflex/components/radix/themes/components/inset.py,sha256=MEYMjiqCkUmAXyGONuwvqmnpEZ4ka1RL_rhCN3hUeR0,1015
367
361
  reflex/components/radix/themes/components/inset.pyi,sha256=iO8k-rNQtsqtnCl7KRa2QnTRJ_NZ-7vIBep9zqCPY9Q,7889
368
362
  reflex/components/radix/themes/components/popover.py,sha256=rUfOqbJEBTPjJHlKxbQ6_067rae4zByWHlMSEXwGB68,3177
369
363
  reflex/components/radix/themes/components/popover.pyi,sha256=DnSFL0s4WrQd9zCRqwS_YZ1OHu_Uavvvc6I0s6RPIsw,17404
370
364
  reflex/components/radix/themes/components/radio_group.py,sha256=PYottL-4UT2P8a4FAylpVL9y02OZ3xC_kIB7_d4FoG4,6253
371
365
  reflex/components/radix/themes/components/radio_group.pyi,sha256=qEdhf8eWUntn-H74k_10uaaEcAMfKXlz4Kl6G8guy7A,24106
372
- reflex/components/radix/themes/components/radiogroup.pyi,sha256=4A_iObTwZH2Be9I0zv2l6AzXOCZD9rr3vlti6Y-wZWA,26222
373
366
  reflex/components/radix/themes/components/scroll_area.py,sha256=0Oc5K7sycSH_X8HbVI2A_FS8AddoFXcwvH_YZpsjTkc,920
374
367
  reflex/components/radix/themes/components/scroll_area.pyi,sha256=jtpiX8b4LZWZwpUi4jElgkBfwOLIDgjnOSm-W88oaXc,4427
375
- reflex/components/radix/themes/components/scrollarea.pyi,sha256=rwOEpVI0m9gMjlSPPwOgUGc4n8tD2g5NQZ-NyvBGFWg,6513
376
368
  reflex/components/radix/themes/components/select.py,sha256=otgJdSdoE9VVv2z3PgtKJmDY_Ln6wPJlCz2ixFp9mDY,8028
377
369
  reflex/components/radix/themes/components/select.pyi,sha256=u5bmgAuFqV1A9_avfUZ9uYxWi8y0eqqM7-H_LVKEyaw,45123
378
370
  reflex/components/radix/themes/components/separator.py,sha256=si-4AZAKvjQwo6DCiHKdND7pK13vL1eWHCTO5OpIfb0,868
@@ -389,7 +381,6 @@ reflex/components/radix/themes/components/text_area.py,sha256=9AhvEXcr87B1o0wmCT
389
381
  reflex/components/radix/themes/components/text_area.pyi,sha256=xOeJ23O-LKoGsgRbFDOsubkGJjZeAEKvjGasTi5J09Y,11711
390
382
  reflex/components/radix/themes/components/text_field.py,sha256=LD3cQ2EnDzJ5W8G9yp5LPgCUBVONkWoy2SB2jjUFRZ0,5106
391
383
  reflex/components/radix/themes/components/text_field.pyi,sha256=9BR-tMZDgUEEzGJV20vKTQAkayJa-hB-Amgo-VzJuCc,43043
392
- reflex/components/radix/themes/components/textfield.pyi,sha256=SaH2-jvnGDFWFHmMW0ekWjYiVPr-qROZYGGDAxbHBxs,43365
393
384
  reflex/components/radix/themes/components/tooltip.py,sha256=gSeURvwI8ITUoTmtWVFFMIeUMEL6B3NrvX0hw3Y7lWg,4465
394
385
  reflex/components/radix/themes/components/tooltip.pyi,sha256=D53eQARMkv9claFUnfFVgL2uZA3bq48fWL21zzWGUaU,8092
395
386
  reflex/components/radix/themes/layout/__init__.py,sha256=BtVM87BKeMfvEnJxUo4LLZ20aQRYJSHXd6G1F1v4oRA,811
@@ -419,14 +410,10 @@ reflex/components/radix/themes/typography/blockquote.py,sha256=2oeU4a6y4BwlPXOtw
419
410
  reflex/components/radix/themes/typography/blockquote.pyi,sha256=xy28s36FJMtwVSDyEEWPku9J0DrIphVcd1UKFXNG3Fk,9316
420
411
  reflex/components/radix/themes/typography/code.py,sha256=b74UXNv6ktmO0bTkMKFYR41XkEHyHJoJI3mlhLuA0cE,909
421
412
  reflex/components/radix/themes/typography/code.pyi,sha256=EpqSO88Nlbg9XnH54Jkwxtx2bXiF3X2cDYqoeQI38rw,9513
422
- reflex/components/radix/themes/typography/em.pyi,sha256=QKPhUfXgKa3teUkozKViBY25TrXmgYddpdEX4CobwnE,8547
423
413
  reflex/components/radix/themes/typography/heading.py,sha256=xKJUzuodTcu6e1in8tDckTfZ9te460mswPgbSj5a6U4,1324
424
414
  reflex/components/radix/themes/typography/heading.pyi,sha256=DU78CN3o81WHOIuOi-OC8xBrp7K7DUSxXVvtYzZkXWk,10106
425
- reflex/components/radix/themes/typography/kbd.pyi,sha256=WlJwqocnl66l0nGMepsXjAcIsPdetLxumXf-QAxsZjU,8872
426
415
  reflex/components/radix/themes/typography/link.py,sha256=4sWxvAn-TIIlcp98F_Xfvkrs0kqivZDCQwTlpoG-nBA,3154
427
416
  reflex/components/radix/themes/typography/link.pyi,sha256=9sNiYEPr4pu3t2RYETro1NEAR4N2n8HoN6UwI7aNEXM,12063
428
- reflex/components/radix/themes/typography/quote.pyi,sha256=KISvHpKATndaIveaxP7Gd9GeM57SOkWMYGT9tNpDZwI,8701
429
- reflex/components/radix/themes/typography/strong.pyi,sha256=UZES3mhSZQLCHRZYmB8nImv_wtPweg7nS2SuLHQPMpk,8563
430
417
  reflex/components/radix/themes/typography/text.py,sha256=BQ_15kkTWvAbZr8dczgMmsKrUhIZzAN-f6r-Nzf9ZU0,2604
431
418
  reflex/components/radix/themes/typography/text.pyi,sha256=jYHiLVgK0hDxZD-3HhYatm66Vm0Hn_GRgMbszn1DAyU,57238
432
419
  reflex/components/react_player/__init__.py,sha256=W4wa5G4R_cl5tE1vfR4tY_RlvWLVsyTxzTAJ67q2gnc,144
@@ -466,14 +453,15 @@ reflex/constants/compiler.py,sha256=uWTC28IpBlJzh-BnO05xoiCwYQsGeXJJ3RG6UB1xZQo,
466
453
  reflex/constants/config.py,sha256=7uUypVy-ezLt3UN3jXEX1XvL3sKaCLBwnJCyYjg9erI,1331
467
454
  reflex/constants/custom_components.py,sha256=SX0SQVb-d6HJkZdezFL4UgkumyF6eJF682y4OvRUqUM,1268
468
455
  reflex/constants/event.py,sha256=7cEUTWdIhWVw7g5Bn9yTZlxNnJY5MeJL55q-vT1YOZ0,2668
469
- reflex/constants/installer.py,sha256=4ztmgMYNUYDEEwPHu_GNTlcMoAEuJ1C4waFuhwA83rY,3261
456
+ reflex/constants/installer.py,sha256=p0-9b57dyt1MR2fddnS2pbXYtUpRNhvGmuA0oyOHT_8,3223
470
457
  reflex/constants/route.py,sha256=9ydQEdlz3YwGmGMHVGz7zA-INoOLtz_xUU2S-WmhZZM,1940
471
458
  reflex/constants/style.py,sha256=gSzu0sQEQjW81PekxJnwRs7SXQQVco-LxtVjCi0IQZc,636
472
459
  reflex/custom_components/__init__.py,sha256=R4zsvOi4dfPmHc18KEphohXnQFBPnUCb50cMR5hSLDE,36
473
460
  reflex/custom_components/custom_components.py,sha256=Q2Ef3QvO3fheL-rcUF8g92xmY54UtJAHs7t_Dq1P65A,31705
474
461
  reflex/event.py,sha256=EU3qjaCt2F3-myCqLUDITSzg9YEctVsrr0h-V_TtLZ4,26537
475
- reflex/experimental/__init__.py,sha256=ReK9dMtv150QHXp6fDcrC3sx2hCg5xgq2m_o7BKEIts,369
476
- reflex/experimental/hooks.py,sha256=8LWdoq1aQPCA3ySDtlUzsPGiizM8CINvHUU6-ukZIFs,1647
462
+ reflex/experimental/__init__.py,sha256=8UHxGVhrvgs6KkVXUFh4kU2UW2w-Ix_73WyEf8cH-bQ,425
463
+ reflex/experimental/hooks.py,sha256=ruqdKV3smQT53vVwYvs8Zx4RyTy6nY00rD0Loe1gWdU,2196
464
+ reflex/experimental/layout.py,sha256=hVx-C5j-rkPMk_ZvQJNzjXgWaYGWIe2L1LHQawfpkjw,6770
477
465
  reflex/experimental/misc.py,sha256=4xlHrSCZaDyyiSexNKRbSfJ_UZy6-fzIBhKDeHNt94Q,281
478
466
  reflex/middleware/__init__.py,sha256=x7xTeDuc73Hjj43k1J63naC9x8vzFxl4sq7cCFBX7sk,111
479
467
  reflex/middleware/hydrate_middleware.py,sha256=iXgB_VID2moU9gNpc79TJHGGhQgDH6miT32T_0Ow5tU,1484
@@ -484,7 +472,7 @@ reflex/reflex.py,sha256=etDzJ7PzS5E7IGVdBiiPgFiG9z0xZkYwTWUJi9e8CU8,17828
484
472
  reflex/route.py,sha256=mRv4rHuSI6x-uWALujPfM5PNtoRea6cuThjchHtA2hQ,2908
485
473
  reflex/state.py,sha256=Crlh4A916t1dmURTD_ZvQz0ihhPxEaWswgY6rbgdBE0,105642
486
474
  reflex/style.py,sha256=3gM5xJpn1yd5UnRDRKrJWgCd871Rj_ZnxhQyWCspx2Q,8834
487
- reflex/testing.py,sha256=_tE8HYqrhpbra7LPaN_d2a_5X1bPh3RosddNx05s6Is,29808
475
+ reflex/testing.py,sha256=WOTjpnOo0U8tJHl5ie7mWOD3Cucf7HyP2x9FGMkYc4c,30556
488
476
  reflex/utils/__init__.py,sha256=y-AHKiRQAhk2oAkvn7W8cRVTZVK625ff8tTwvZtO7S4,24
489
477
  reflex/utils/build.py,sha256=9LE93QlbfTHYyQWTgGZYSXX7QGDYzuE01ttWUVw_rGQ,8573
490
478
  reflex/utils/compat.py,sha256=rfN5mMcNWFXT1ESLnZlR-bYG7XJKHvAScXMWo9iBsKg,1255
@@ -495,17 +483,17 @@ reflex/utils/export.py,sha256=UJd4BYFW9_eexhLCP4C5Ri8Cq2tWAPNVspq70lPLCyo,2270
495
483
  reflex/utils/format.py,sha256=4vY7NP-f7B2euJ5F5dM3yh5SYPzCY3bVZDATG2DMaMU,22648
496
484
  reflex/utils/imports.py,sha256=IRnSLA_LI0ougGpOT_smwVPDpfoPcC7t_tY4mnuhj6k,2277
497
485
  reflex/utils/path_ops.py,sha256=Vy6fU_bXvOcCvbXdTSmeLwy_C4h9seYU-3yIrVdZEZQ,4737
498
- reflex/utils/prerequisites.py,sha256=vMn1NnoDR-Xc8AsK1YM2f1gqxH_i8PxwfFp7r82sVkw,47173
499
- reflex/utils/processes.py,sha256=GHkDmGjRHz6xIC4KbNM6GIRzf5jfI60NbOGGV4KQwAI,10032
486
+ reflex/utils/prerequisites.py,sha256=0zBpFhStKZ_wzL_fKKM9XTkerS3L0QYuUjTnSkehYSM,47242
487
+ reflex/utils/processes.py,sha256=9XIffdPsxe-RnaMB9Q_VyaXVJrXAx9OIjrExNYBl8x0,10730
500
488
  reflex/utils/pyi_generator.py,sha256=VyGG0Tj3nvyBi2OQU-oscWRhJyRiYG9rUvJolKLK5Gg,27674
501
- reflex/utils/serializers.py,sha256=vHLJx2Dj7bcXiKp6lHkOrov1e7AbQtdT8piZq8Erh4M,8771
489
+ reflex/utils/serializers.py,sha256=AK3q6UqGwha21lz04c1rwlqlgbDkUMVpUG4Yf1sLmcs,9023
502
490
  reflex/utils/telemetry.py,sha256=NYAzPe7nU0EUwq2hIAByOzlie_5RhFlfHganBqG5OfA,4013
503
491
  reflex/utils/types.py,sha256=QtsWi7ACjwHLfc7Wy72YU85bGUS3J-P_XlltYUAfnPk,13679
504
492
  reflex/utils/watch.py,sha256=HzGrHQIZ_62Di0BO46kd2AZktNA3A6nFIBuf8c6ip30,2609
505
- reflex/vars.py,sha256=mef13GC4G_Iqicliyp6k9EWGULC1p1UewgM7gJODcBw,67152
493
+ reflex/vars.py,sha256=45Ejn54a3BC1bXp5nzFDUjirgGRrHD-YX3rKiKVRL-g,67157
506
494
  reflex/vars.pyi,sha256=7sVCLoLg9Y7QAmXWz6FCtVmScpSV84u0yQ3ZBImb_Bk,5583
507
- reflex-0.4.8.post1.dist-info/LICENSE,sha256=dw3zLrp9f5ObD7kqS32vWfhcImfO52PMmRqvtxq_YEE,11358
508
- reflex-0.4.8.post1.dist-info/METADATA,sha256=3uTcZhpW4c4lQ_y2BpiKSjskc3xBnHBkRO5OXSme9ik,11768
509
- reflex-0.4.8.post1.dist-info/WHEEL,sha256=Zb28QaM1gQi8f4VCBhsUklF61CTlNYfs9YAZn-TOGFk,88
510
- reflex-0.4.8.post1.dist-info/entry_points.txt,sha256=H1Z5Yat_xJfy0dRT1Frk2PkO_p41Xy7fCKlj4FcdL9o,44
511
- reflex-0.4.8.post1.dist-info/RECORD,,
495
+ reflex-0.4.9a1.dist-info/LICENSE,sha256=dw3zLrp9f5ObD7kqS32vWfhcImfO52PMmRqvtxq_YEE,11358
496
+ reflex-0.4.9a1.dist-info/METADATA,sha256=iz48869W2oj91cssc2H8wJBQQRNqenW5Ew6A75Ajhl0,11764
497
+ reflex-0.4.9a1.dist-info/WHEEL,sha256=Zb28QaM1gQi8f4VCBhsUklF61CTlNYfs9YAZn-TOGFk,88
498
+ reflex-0.4.9a1.dist-info/entry_points.txt,sha256=H1Z5Yat_xJfy0dRT1Frk2PkO_p41Xy7fCKlj4FcdL9o,44
499
+ reflex-0.4.9a1.dist-info/RECORD,,