reflex 0.6.8a1__py3-none-any.whl → 0.7.0a1__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.
- reflex/.templates/jinja/custom_components/pyproject.toml.jinja2 +1 -1
- reflex/.templates/jinja/web/pages/_app.js.jinja2 +7 -7
- reflex/.templates/jinja/web/pages/utils.js.jinja2 +2 -2
- reflex/.templates/web/components/reflex/radix_themes_color_mode_provider.js +1 -4
- reflex/.templates/web/utils/state.js +65 -36
- reflex/__init__.py +4 -17
- reflex/__init__.pyi +1 -2
- reflex/app.py +244 -115
- reflex/app_mixins/lifespan.py +9 -9
- reflex/app_mixins/middleware.py +6 -6
- reflex/app_module_for_backend.py +3 -7
- reflex/base.py +7 -7
- reflex/compiler/compiler.py +8 -0
- reflex/compiler/utils.py +35 -6
- reflex/components/base/bare.py +1 -1
- reflex/components/base/error_boundary.py +2 -1
- reflex/components/base/error_boundary.pyi +2 -1
- reflex/components/base/meta.py +2 -2
- reflex/components/base/strict_mode.py +10 -0
- reflex/components/base/strict_mode.pyi +57 -0
- reflex/components/component.py +38 -77
- reflex/components/core/banner.py +83 -4
- reflex/components/core/banner.pyi +86 -0
- reflex/components/core/breakpoints.py +3 -1
- reflex/components/core/client_side_routing.py +1 -1
- reflex/components/core/client_side_routing.pyi +1 -1
- reflex/components/core/cond.py +9 -10
- reflex/components/core/debounce.py +1 -1
- reflex/components/core/foreach.py +23 -3
- reflex/components/core/html.py +1 -1
- reflex/components/core/match.py +5 -5
- reflex/components/core/sticky.py +160 -0
- reflex/components/core/sticky.pyi +449 -0
- reflex/components/core/upload.py +2 -2
- reflex/components/datadisplay/code.py +5 -14
- reflex/components/datadisplay/dataeditor.py +7 -4
- reflex/components/datadisplay/logo.py +13 -8
- reflex/components/datadisplay/shiki_code_block.py +14 -9
- reflex/components/dynamic.py +22 -3
- reflex/components/el/constants/reflex.py +1 -1
- reflex/components/el/element.py +1 -1
- reflex/components/el/elements/forms.py +4 -4
- reflex/components/el/elements/forms.pyi +4 -4
- reflex/components/lucide/icon.py +46 -8
- reflex/components/lucide/icon.pyi +54 -0
- reflex/components/markdown/markdown.py +10 -8
- reflex/components/moment/moment.py +2 -2
- reflex/components/next/image.py +16 -4
- reflex/components/next/image.pyi +4 -2
- reflex/components/next/link.py +1 -1
- reflex/components/plotly/plotly.py +5 -5
- reflex/components/props.py +3 -3
- reflex/components/radix/__init__.pyi +1 -1
- reflex/components/radix/primitives/accordion.py +9 -5
- reflex/components/radix/primitives/accordion.pyi +3 -1
- reflex/components/radix/primitives/drawer.py +5 -2
- reflex/components/radix/primitives/drawer.pyi +4 -4
- reflex/components/radix/primitives/form.pyi +6 -6
- reflex/components/radix/primitives/progress.py +1 -1
- reflex/components/radix/primitives/slider.py +1 -1
- reflex/components/radix/themes/color_mode.py +11 -9
- reflex/components/radix/themes/components/alert_dialog.py +3 -0
- reflex/components/radix/themes/components/card.py +1 -1
- reflex/components/radix/themes/components/card.pyi +1 -1
- reflex/components/radix/themes/components/context_menu.py +5 -0
- reflex/components/radix/themes/components/dialog.py +3 -0
- reflex/components/radix/themes/components/dropdown_menu.py +5 -0
- reflex/components/radix/themes/components/hover_card.py +3 -0
- reflex/components/radix/themes/components/icon_button.py +2 -2
- reflex/components/radix/themes/components/icon_button.pyi +1 -0
- reflex/components/radix/themes/components/popover.py +3 -0
- reflex/components/radix/themes/components/radio_cards.py +2 -0
- reflex/components/radix/themes/components/radio_group.py +1 -1
- reflex/components/radix/themes/components/select.py +3 -0
- reflex/components/radix/themes/components/tabs.py +3 -0
- reflex/components/radix/themes/components/text_area.py +12 -0
- reflex/components/radix/themes/components/text_area.pyi +2 -0
- reflex/components/radix/themes/components/text_field.py +1 -1
- reflex/components/radix/themes/components/tooltip.py +3 -1
- reflex/components/radix/themes/components/tooltip.pyi +1 -0
- reflex/components/radix/themes/layout/__init__.pyi +1 -1
- reflex/components/radix/themes/layout/list.py +2 -2
- reflex/components/radix/themes/layout/stack.py +2 -2
- reflex/components/radix/themes/typography/link.py +1 -1
- reflex/components/radix/themes/typography/text.py +2 -2
- reflex/components/react_player/react_player.py +1 -1
- reflex/components/recharts/__init__.py +2 -0
- reflex/components/recharts/__init__.pyi +2 -0
- reflex/components/recharts/charts.py +15 -15
- reflex/components/recharts/general.py +19 -4
- reflex/components/recharts/general.pyi +55 -4
- reflex/components/recharts/polar.py +2 -2
- reflex/components/recharts/recharts.py +4 -4
- reflex/components/sonner/toast.py +15 -13
- reflex/components/sonner/toast.pyi +6 -6
- reflex/components/suneditor/editor.py +6 -4
- reflex/components/suneditor/editor.pyi +2 -2
- reflex/components/tags/iter_tag.py +3 -3
- reflex/components/tags/tag.py +25 -3
- reflex/config.py +48 -20
- reflex/constants/__init__.py +1 -0
- reflex/constants/base.py +4 -1
- reflex/constants/compiler.py +5 -2
- reflex/constants/config.py +8 -1
- reflex/constants/installer.py +9 -9
- reflex/constants/style.py +1 -1
- reflex/custom_components/custom_components.py +9 -7
- reflex/event.py +137 -163
- reflex/experimental/__init__.py +19 -11
- reflex/experimental/client_state.py +53 -28
- reflex/experimental/hooks.py +5 -5
- reflex/experimental/layout.py +8 -5
- reflex/experimental/layout.pyi +1 -1
- reflex/experimental/misc.py +3 -3
- reflex/istate/wrappers.py +1 -1
- reflex/middleware/hydrate_middleware.py +2 -2
- reflex/model.py +11 -6
- reflex/page.py +3 -3
- reflex/reflex.py +90 -19
- reflex/route.py +1 -1
- reflex/state.py +358 -401
- reflex/style.py +27 -3
- reflex/testing.py +34 -39
- reflex/utils/build.py +6 -2
- reflex/utils/codespaces.py +1 -4
- reflex/utils/compat.py +6 -5
- reflex/utils/console.py +52 -21
- reflex/utils/exceptions.py +76 -26
- reflex/utils/exec.py +69 -74
- reflex/utils/export.py +6 -1
- reflex/utils/format.py +7 -39
- reflex/utils/imports.py +2 -2
- reflex/utils/lazy_loader.py +7 -1
- reflex/utils/path_ops.py +28 -14
- reflex/utils/prerequisites.py +324 -65
- reflex/utils/processes.py +45 -32
- reflex/utils/pyi_generator.py +30 -25
- reflex/utils/registry.py +4 -4
- reflex/utils/serializers.py +1 -1
- reflex/utils/telemetry.py +5 -4
- reflex/utils/types.py +42 -18
- reflex/vars/base.py +650 -333
- reflex/vars/datetime.py +6 -7
- reflex/vars/dep_tracking.py +344 -0
- reflex/vars/function.py +11 -5
- reflex/vars/number.py +31 -43
- reflex/vars/object.py +63 -62
- reflex/vars/sequence.py +79 -67
- {reflex-0.6.8a1.dist-info → reflex-0.7.0a1.dist-info}/METADATA +7 -10
- {reflex-0.6.8a1.dist-info → reflex-0.7.0a1.dist-info}/RECORD +153 -150
- {reflex-0.6.8a1.dist-info → reflex-0.7.0a1.dist-info}/WHEEL +1 -1
- reflex/experimental/assets.py +0 -37
- reflex/proxy.py +0 -119
- {reflex-0.6.8a1.dist-info → reflex-0.7.0a1.dist-info}/LICENSE +0 -0
- {reflex-0.6.8a1.dist-info → reflex-0.7.0a1.dist-info}/entry_points.txt +0 -0
reflex/config.py
CHANGED
|
@@ -12,6 +12,7 @@ import threading
|
|
|
12
12
|
import urllib.parse
|
|
13
13
|
from importlib.util import find_spec
|
|
14
14
|
from pathlib import Path
|
|
15
|
+
from types import ModuleType
|
|
15
16
|
from typing import (
|
|
16
17
|
TYPE_CHECKING,
|
|
17
18
|
Any,
|
|
@@ -26,7 +27,6 @@ from typing import (
|
|
|
26
27
|
|
|
27
28
|
from typing_extensions import Annotated, get_type_hints
|
|
28
29
|
|
|
29
|
-
from reflex.utils.console import set_log_level
|
|
30
30
|
from reflex.utils.exceptions import ConfigError, EnvironmentVarValueError
|
|
31
31
|
from reflex.utils.types import GenericType, is_union, value_inside_optional
|
|
32
32
|
|
|
@@ -390,7 +390,7 @@ class EnvVar(Generic[T]):
|
|
|
390
390
|
os.environ[self.name] = str(value)
|
|
391
391
|
|
|
392
392
|
|
|
393
|
-
class env_var: #
|
|
393
|
+
class env_var: # noqa: N801 # pyright: ignore [reportRedeclaration]
|
|
394
394
|
"""Descriptor for environment variables."""
|
|
395
395
|
|
|
396
396
|
name: str
|
|
@@ -407,7 +407,7 @@ class env_var: # type: ignore
|
|
|
407
407
|
self.default = default
|
|
408
408
|
self.internal = internal
|
|
409
409
|
|
|
410
|
-
def __set_name__(self, owner, name):
|
|
410
|
+
def __set_name__(self, owner: Any, name: str):
|
|
411
411
|
"""Set the name of the descriptor.
|
|
412
412
|
|
|
413
413
|
Args:
|
|
@@ -416,7 +416,7 @@ class env_var: # type: ignore
|
|
|
416
416
|
"""
|
|
417
417
|
self.name = name
|
|
418
418
|
|
|
419
|
-
def __get__(self, instance, owner):
|
|
419
|
+
def __get__(self, instance: Any, owner: Any):
|
|
420
420
|
"""Get the EnvVar instance.
|
|
421
421
|
|
|
422
422
|
Args:
|
|
@@ -435,7 +435,7 @@ class env_var: # type: ignore
|
|
|
435
435
|
|
|
436
436
|
if TYPE_CHECKING:
|
|
437
437
|
|
|
438
|
-
def env_var(default, internal=False) -> EnvVar:
|
|
438
|
+
def env_var(default: Any, internal: bool = False) -> EnvVar:
|
|
439
439
|
"""Typing helper for the env_var descriptor.
|
|
440
440
|
|
|
441
441
|
Args:
|
|
@@ -490,6 +490,9 @@ class EnvironmentVariables:
|
|
|
490
490
|
# The working directory for the next.js commands.
|
|
491
491
|
REFLEX_WEB_WORKDIR: EnvVar[Path] = env_var(Path(constants.Dirs.WEB))
|
|
492
492
|
|
|
493
|
+
# The working directory for the states directory.
|
|
494
|
+
REFLEX_STATES_WORKDIR: EnvVar[Path] = env_var(Path(constants.Dirs.STATES))
|
|
495
|
+
|
|
493
496
|
# Path to the alembic config file
|
|
494
497
|
ALEMBIC_CONFIG: EnvVar[ExistingPath] = env_var(Path(constants.ALEMBIC_CONFIG))
|
|
495
498
|
|
|
@@ -556,9 +559,6 @@ class EnvironmentVariables:
|
|
|
556
559
|
# Arguments to pass to the app harness driver.
|
|
557
560
|
APP_HARNESS_DRIVER_ARGS: EnvVar[str] = env_var("")
|
|
558
561
|
|
|
559
|
-
# Where to save screenshots when tests fail.
|
|
560
|
-
SCREENSHOT_DIR: EnvVar[Optional[Path]] = env_var(None)
|
|
561
|
-
|
|
562
562
|
# Whether to check for outdated package versions.
|
|
563
563
|
REFLEX_CHECK_LATEST_VERSION: EnvVar[bool] = env_var(True)
|
|
564
564
|
|
|
@@ -568,6 +568,9 @@ class EnvironmentVariables:
|
|
|
568
568
|
# The maximum size of the reflex state in kilobytes.
|
|
569
569
|
REFLEX_STATE_SIZE_LIMIT: EnvVar[int] = env_var(1000)
|
|
570
570
|
|
|
571
|
+
# Whether to use the turbopack bundler.
|
|
572
|
+
REFLEX_USE_TURBOPACK: EnvVar[bool] = env_var(True)
|
|
573
|
+
|
|
571
574
|
|
|
572
575
|
environment = EnvironmentVariables()
|
|
573
576
|
|
|
@@ -597,15 +600,17 @@ class Config(Base):
|
|
|
597
600
|
See the [configuration](https://reflex.dev/docs/getting-started/configuration/) docs for more info.
|
|
598
601
|
"""
|
|
599
602
|
|
|
600
|
-
class Config:
|
|
603
|
+
class Config: # pyright: ignore [reportIncompatibleVariableOverride]
|
|
601
604
|
"""Pydantic config for the config."""
|
|
602
605
|
|
|
603
|
-
use_enum_values = False
|
|
604
606
|
validate_assignment = True
|
|
605
607
|
|
|
606
608
|
# The name of the app (should match the name of the app directory).
|
|
607
609
|
app_name: str
|
|
608
610
|
|
|
611
|
+
# The path to the app module.
|
|
612
|
+
app_module_import: Optional[str] = None
|
|
613
|
+
|
|
609
614
|
# The log level to use.
|
|
610
615
|
loglevel: constants.LogLevel = constants.LogLevel.DEFAULT
|
|
611
616
|
|
|
@@ -698,6 +703,12 @@ class Config(Base):
|
|
|
698
703
|
# Path to file containing key-values pairs to override in the environment; Dotenv format.
|
|
699
704
|
env_file: Optional[str] = None
|
|
700
705
|
|
|
706
|
+
# Whether to display the sticky "Built with Reflex" badge on all pages.
|
|
707
|
+
show_built_with_reflex: bool = True
|
|
708
|
+
|
|
709
|
+
# Whether the app is running in the reflex cloud environment.
|
|
710
|
+
is_reflex_cloud: bool = False
|
|
711
|
+
|
|
701
712
|
def __init__(self, *args, **kwargs):
|
|
702
713
|
"""Initialize the config values.
|
|
703
714
|
|
|
@@ -720,9 +731,6 @@ class Config(Base):
|
|
|
720
731
|
self._non_default_attributes.update(kwargs)
|
|
721
732
|
self._replace_defaults(**kwargs)
|
|
722
733
|
|
|
723
|
-
# Set the log level for this process
|
|
724
|
-
set_log_level(self.loglevel)
|
|
725
|
-
|
|
726
734
|
if (
|
|
727
735
|
self.state_manager_mode == constants.StateManagerMode.REDIS
|
|
728
736
|
and not self.redis_url
|
|
@@ -731,6 +739,19 @@ class Config(Base):
|
|
|
731
739
|
"REDIS_URL is required when using the redis state manager."
|
|
732
740
|
)
|
|
733
741
|
|
|
742
|
+
@property
|
|
743
|
+
def app_module(self) -> ModuleType | None:
|
|
744
|
+
"""Return the app module if `app_module_import` is set.
|
|
745
|
+
|
|
746
|
+
Returns:
|
|
747
|
+
The app module.
|
|
748
|
+
"""
|
|
749
|
+
return (
|
|
750
|
+
importlib.import_module(self.app_module_import)
|
|
751
|
+
if self.app_module_import
|
|
752
|
+
else None
|
|
753
|
+
)
|
|
754
|
+
|
|
734
755
|
@property
|
|
735
756
|
def module(self) -> str:
|
|
736
757
|
"""Get the module name of the app.
|
|
@@ -738,6 +759,8 @@ class Config(Base):
|
|
|
738
759
|
Returns:
|
|
739
760
|
The module name.
|
|
740
761
|
"""
|
|
762
|
+
if self.app_module is not None:
|
|
763
|
+
return self.app_module.__name__
|
|
741
764
|
return ".".join([self.app_name, self.app_name])
|
|
742
765
|
|
|
743
766
|
def update_from_env(self) -> dict[str, Any]:
|
|
@@ -749,7 +772,7 @@ class Config(Base):
|
|
|
749
772
|
"""
|
|
750
773
|
if self.env_file:
|
|
751
774
|
try:
|
|
752
|
-
from dotenv import load_dotenv #
|
|
775
|
+
from dotenv import load_dotenv # pyright: ignore [reportMissingImports]
|
|
753
776
|
|
|
754
777
|
# load env file if exists
|
|
755
778
|
load_dotenv(self.env_file, override=True)
|
|
@@ -809,16 +832,16 @@ class Config(Base):
|
|
|
809
832
|
if "api_url" not in self._non_default_attributes:
|
|
810
833
|
# If running in Github Codespaces, override API_URL
|
|
811
834
|
codespace_name = os.getenv("CODESPACE_NAME")
|
|
812
|
-
|
|
835
|
+
github_codespaces_port_forwarding_domain = os.getenv(
|
|
813
836
|
"GITHUB_CODESPACES_PORT_FORWARDING_DOMAIN"
|
|
814
837
|
)
|
|
815
838
|
# If running on Replit.com interactively, override API_URL to ensure we maintain the backend_port
|
|
816
839
|
replit_dev_domain = os.getenv("REPLIT_DEV_DOMAIN")
|
|
817
840
|
backend_port = kwargs.get("backend_port", self.backend_port)
|
|
818
|
-
if codespace_name and
|
|
841
|
+
if codespace_name and github_codespaces_port_forwarding_domain:
|
|
819
842
|
self.api_url = (
|
|
820
843
|
f"https://{codespace_name}-{kwargs.get('backend_port', self.backend_port)}"
|
|
821
|
-
f".{
|
|
844
|
+
f".{github_codespaces_port_forwarding_domain}"
|
|
822
845
|
)
|
|
823
846
|
elif replit_dev_domain and backend_port:
|
|
824
847
|
self.api_url = f"https://{replit_dev_domain}:{backend_port}"
|
|
@@ -876,7 +899,7 @@ def get_config(reload: bool = False) -> Config:
|
|
|
876
899
|
return cached_rxconfig.config
|
|
877
900
|
|
|
878
901
|
with _config_lock:
|
|
879
|
-
|
|
902
|
+
orig_sys_path = sys.path.copy()
|
|
880
903
|
sys.path.clear()
|
|
881
904
|
sys.path.append(str(Path.cwd()))
|
|
882
905
|
try:
|
|
@@ -884,9 +907,14 @@ def get_config(reload: bool = False) -> Config:
|
|
|
884
907
|
return _get_config()
|
|
885
908
|
except Exception:
|
|
886
909
|
# If the module import fails, try to import with the original sys.path.
|
|
887
|
-
sys.path.extend(
|
|
910
|
+
sys.path.extend(orig_sys_path)
|
|
888
911
|
return _get_config()
|
|
889
912
|
finally:
|
|
913
|
+
# Find any entries added to sys.path by rxconfig.py itself.
|
|
914
|
+
extra_paths = [
|
|
915
|
+
p for p in sys.path if p not in orig_sys_path and p != str(Path.cwd())
|
|
916
|
+
]
|
|
890
917
|
# Restore the original sys.path.
|
|
891
918
|
sys.path.clear()
|
|
892
|
-
sys.path.extend(
|
|
919
|
+
sys.path.extend(extra_paths)
|
|
920
|
+
sys.path.extend(orig_sys_path)
|
reflex/constants/__init__.py
CHANGED
reflex/constants/base.py
CHANGED
|
@@ -52,7 +52,7 @@ class Dirs(SimpleNamespace):
|
|
|
52
52
|
# The name of the postcss config file.
|
|
53
53
|
POSTCSS_JS = "postcss.config.js"
|
|
54
54
|
# The name of the states directory.
|
|
55
|
-
STATES = "states"
|
|
55
|
+
STATES = ".states"
|
|
56
56
|
|
|
57
57
|
|
|
58
58
|
class Reflex(SimpleNamespace):
|
|
@@ -75,6 +75,8 @@ class Reflex(SimpleNamespace):
|
|
|
75
75
|
# If user sets REFLEX_DIR envroment variable use that instead.
|
|
76
76
|
DIR = PlatformDirs(MODULE_NAME, False).user_data_path
|
|
77
77
|
|
|
78
|
+
LOGS_DIR = DIR / "logs"
|
|
79
|
+
|
|
78
80
|
# The root directory of the reflex library.
|
|
79
81
|
ROOT_DIR = Path(__file__).parents[2]
|
|
80
82
|
|
|
@@ -257,6 +259,7 @@ SESSION_STORAGE = "session_storage"
|
|
|
257
259
|
# Testing variables.
|
|
258
260
|
# Testing os env set by pytest when running a test case.
|
|
259
261
|
PYTEST_CURRENT_TEST = "PYTEST_CURRENT_TEST"
|
|
262
|
+
APP_HARNESS_FLAG = "APP_HARNESS_FLAG"
|
|
260
263
|
|
|
261
264
|
REFLEX_VAR_OPENING_TAG = "<reflex.Var>"
|
|
262
265
|
REFLEX_VAR_CLOSING_TAG = "</reflex.Var>"
|
reflex/constants/compiler.py
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"""Compiler variables."""
|
|
2
2
|
|
|
3
|
+
import dataclasses
|
|
3
4
|
import enum
|
|
4
5
|
from enum import Enum
|
|
5
6
|
from types import SimpleNamespace
|
|
6
7
|
|
|
7
|
-
from reflex.base import Base
|
|
8
8
|
from reflex.constants import Dirs
|
|
9
9
|
from reflex.utils.imports import ImportVar
|
|
10
10
|
|
|
@@ -28,6 +28,8 @@ class Ext(SimpleNamespace):
|
|
|
28
28
|
ZIP = ".zip"
|
|
29
29
|
# The extension for executable files on Windows.
|
|
30
30
|
EXE = ".exe"
|
|
31
|
+
# The extension for markdown files.
|
|
32
|
+
MD = ".md"
|
|
31
33
|
|
|
32
34
|
|
|
33
35
|
class CompileVars(SimpleNamespace):
|
|
@@ -149,7 +151,8 @@ class MemoizationDisposition(enum.Enum):
|
|
|
149
151
|
NEVER = "never"
|
|
150
152
|
|
|
151
153
|
|
|
152
|
-
|
|
154
|
+
@dataclasses.dataclass(frozen=True)
|
|
155
|
+
class MemoizationMode:
|
|
153
156
|
"""The mode for memoizing a Component."""
|
|
154
157
|
|
|
155
158
|
# The conditions under which the component should be memoized.
|
reflex/constants/config.py
CHANGED
|
@@ -39,7 +39,14 @@ class GitIgnore(SimpleNamespace):
|
|
|
39
39
|
# The gitignore file.
|
|
40
40
|
FILE = Path(".gitignore")
|
|
41
41
|
# Files to gitignore.
|
|
42
|
-
DEFAULTS = {
|
|
42
|
+
DEFAULTS = {
|
|
43
|
+
Dirs.WEB,
|
|
44
|
+
Dirs.STATES,
|
|
45
|
+
"*.db",
|
|
46
|
+
"__pycache__/",
|
|
47
|
+
"*.py[cod]",
|
|
48
|
+
"assets/external/",
|
|
49
|
+
}
|
|
43
50
|
|
|
44
51
|
|
|
45
52
|
class RequirementsTxt(SimpleNamespace):
|
reflex/constants/installer.py
CHANGED
|
@@ -37,10 +37,10 @@ class Bun(SimpleNamespace):
|
|
|
37
37
|
"""Bun constants."""
|
|
38
38
|
|
|
39
39
|
# The Bun version.
|
|
40
|
-
VERSION = "1.
|
|
40
|
+
VERSION = "1.2.0"
|
|
41
41
|
|
|
42
42
|
# Min Bun Version
|
|
43
|
-
MIN_VERSION = "
|
|
43
|
+
MIN_VERSION = "1.1.0"
|
|
44
44
|
|
|
45
45
|
# URL to bun install script.
|
|
46
46
|
INSTALL_URL = "https://raw.githubusercontent.com/reflex-dev/reflex/main/scripts/bun_install.sh"
|
|
@@ -178,21 +178,21 @@ class PackageJson(SimpleNamespace):
|
|
|
178
178
|
PATH = "package.json"
|
|
179
179
|
|
|
180
180
|
DEPENDENCIES = {
|
|
181
|
-
"@babel/standalone": "7.26.
|
|
182
|
-
"@emotion/react": "11.
|
|
183
|
-
"axios": "1.7.
|
|
181
|
+
"@babel/standalone": "7.26.6",
|
|
182
|
+
"@emotion/react": "11.14.0",
|
|
183
|
+
"axios": "1.7.9",
|
|
184
184
|
"json5": "2.2.3",
|
|
185
|
-
"next": "
|
|
185
|
+
"next": "15.1.6",
|
|
186
186
|
"next-sitemap": "4.2.3",
|
|
187
|
-
"next-themes": "0.4.
|
|
187
|
+
"next-themes": "0.4.4",
|
|
188
188
|
"react": "18.3.1",
|
|
189
189
|
"react-dom": "18.3.1",
|
|
190
|
-
"react-focus-lock": "2.13.
|
|
190
|
+
"react-focus-lock": "2.13.5",
|
|
191
191
|
"socket.io-client": "4.8.1",
|
|
192
192
|
"universal-cookie": "7.2.2",
|
|
193
193
|
}
|
|
194
194
|
DEV_DEPENDENCIES = {
|
|
195
195
|
"autoprefixer": "10.4.20",
|
|
196
|
-
"postcss": "8.
|
|
196
|
+
"postcss": "8.5.1",
|
|
197
197
|
"postcss-import": "16.1.0",
|
|
198
198
|
}
|
reflex/constants/style.py
CHANGED
|
@@ -83,7 +83,7 @@ def _get_package_config(exit_on_fail: bool = True) -> dict:
|
|
|
83
83
|
The package configuration.
|
|
84
84
|
|
|
85
85
|
Raises:
|
|
86
|
-
Exit: If the pyproject.toml file is not found.
|
|
86
|
+
Exit: If the pyproject.toml file is not found and exit_on_fail is True.
|
|
87
87
|
"""
|
|
88
88
|
pyproject = Path(CustomComponents.PYPROJECT_TOML)
|
|
89
89
|
try:
|
|
@@ -421,12 +421,13 @@ def _run_commands_in_subprocess(cmds: list[str]) -> bool:
|
|
|
421
421
|
console.debug(f"Running command: {' '.join(cmds)}")
|
|
422
422
|
try:
|
|
423
423
|
result = subprocess.run(cmds, capture_output=True, text=True, check=True)
|
|
424
|
-
console.debug(result.stdout)
|
|
425
|
-
return True
|
|
426
424
|
except subprocess.CalledProcessError as cpe:
|
|
427
425
|
console.error(cpe.stdout)
|
|
428
426
|
console.error(cpe.stderr)
|
|
429
427
|
return False
|
|
428
|
+
else:
|
|
429
|
+
console.debug(result.stdout)
|
|
430
|
+
return True
|
|
430
431
|
|
|
431
432
|
|
|
432
433
|
def _make_pyi_files():
|
|
@@ -771,7 +772,7 @@ def _validate_project_info():
|
|
|
771
772
|
pyproject_toml = _get_package_config()
|
|
772
773
|
project = pyproject_toml["project"]
|
|
773
774
|
console.print(
|
|
774
|
-
f
|
|
775
|
+
f"Double check the information before publishing: {project['name']} version {project['version']}"
|
|
775
776
|
)
|
|
776
777
|
|
|
777
778
|
console.print("Update or enter to keep the current information.")
|
|
@@ -783,7 +784,7 @@ def _validate_project_info():
|
|
|
783
784
|
author["name"] = console.ask("Author Name", default=author.get("name", ""))
|
|
784
785
|
author["email"] = console.ask("Author Email", default=author.get("email", ""))
|
|
785
786
|
|
|
786
|
-
console.print(f
|
|
787
|
+
console.print(f"Current keywords are: {project.get('keywords') or []}")
|
|
787
788
|
keyword_action = console.ask(
|
|
788
789
|
"Keep, replace or append?", choices=["k", "r", "a"], default="k"
|
|
789
790
|
)
|
|
@@ -924,17 +925,18 @@ def _get_file_from_prompt_in_loop() -> Tuple[bytes, str] | None:
|
|
|
924
925
|
image_file = file_extension = None
|
|
925
926
|
while image_file is None:
|
|
926
927
|
image_filepath = Path(
|
|
927
|
-
console.ask("Upload a preview image of your demo app (enter to skip)")
|
|
928
|
+
console.ask("Upload a preview image of your demo app (enter to skip)") # pyright: ignore [reportArgumentType]
|
|
928
929
|
)
|
|
929
930
|
if not image_filepath:
|
|
930
931
|
break
|
|
931
932
|
file_extension = image_filepath.suffix
|
|
932
933
|
try:
|
|
933
934
|
image_file = image_filepath.read_bytes()
|
|
934
|
-
return image_file, file_extension
|
|
935
935
|
except OSError as ose:
|
|
936
936
|
console.error(f"Unable to read the {file_extension} file due to {ose}")
|
|
937
937
|
raise typer.Exit(code=1) from ose
|
|
938
|
+
else:
|
|
939
|
+
return image_file, file_extension
|
|
938
940
|
|
|
939
941
|
console.debug(f"File extension detected: {file_extension}")
|
|
940
942
|
return None
|