Compare commits

..

2 Commits

Author SHA1 Message Date
Khaleel Al-Adhami
49001ba7c8 dang it darglint 2025-02-20 17:32:22 -08:00
Khaleel Al-Adhami
327c11899c add support for .f format 2025-02-20 17:25:07 -08:00
5 changed files with 58 additions and 18 deletions

View File

@ -15,13 +15,7 @@
"devDependencies": {
{% for package, version in dev_dependencies.items() %}
"{{ package }}": "{{ version }}"{% if not loop.last %},{% endif %}
{% endfor %}
},
"overrides": {
{% for package, version in overrides.items() %}
"{{ package }}": "{{ version }}"{% if not loop.last %},{% endif %}
{% endfor %}
}
}

View File

@ -11,9 +11,7 @@ from reflex.vars.base import Var, get_unique_variable_name
class AutoScroll(Div):
"""A div that automatically scrolls to the bottom when new content is added."""
_memoization_mode = MemoizationMode(
disposition=MemoizationDisposition.ALWAYS, recursive=False
)
_memoization_mode = MemoizationMode(disposition=MemoizationDisposition.ALWAYS)
@classmethod
def create(cls, *children, **props):
@ -46,6 +44,7 @@ class AutoScroll(Div):
"""
ref_name = self.get_ref()
return [
"const containerRef = useRef(null);",
"const wasNearBottom = useRef(false);",
"const hadScrollbar = useRef(false);",
f"""
@ -86,8 +85,6 @@ useEffect(() => {{
const container = {ref_name}.current;
if (!container) return;
scrollToBottomIfNeeded();
// Create ResizeObserver to detect height changes
const resizeObserver = new ResizeObserver(() => {{
scrollToBottomIfNeeded();

View File

@ -195,7 +195,3 @@ class PackageJson(SimpleNamespace):
"postcss": "8.5.1",
"postcss-import": "16.1.0",
}
OVERRIDES = {
# This should always match the `react` version in DEPENDENCIES for recharts compatibility.
"react-is": "19.0.0"
}

View File

@ -846,7 +846,6 @@ def _compile_package_json():
},
dependencies=constants.PackageJson.DEPENDENCIES,
dev_dependencies=constants.PackageJson.DEV_DEPENDENCIES,
overrides=constants.PackageJson.OVERRIDES,
)

View File

@ -17,7 +17,11 @@ from typing import (
)
from reflex.constants.base import Dirs
from reflex.utils.exceptions import PrimitiveUnserializableToJSONError, VarTypeError
from reflex.utils.exceptions import (
PrimitiveUnserializableToJSONError,
VarTypeError,
VarValueError,
)
from reflex.utils.imports import ImportDict, ImportVar
from .base import (
@ -530,6 +534,56 @@ class NumberVar(Var[NUMBER_T], python_types=(int, float)):
"""
return issubclass(self._var_type, int)
def __format__(self, format_spec: str) -> str:
"""Format the number.
Args:
format_spec: The format specifier.
Returns:
The formatted number.
Raises:
VarValueError: If the format specifier is not supported.
"""
if (
format_spec
and format_spec[-1] == "f"
and format_spec[0] == "."
and format_spec[1:-1].isdigit()
):
how_many_decimals = int(format_spec[1:-1])
return (
f"{get_decimal_string_operation(self, Var.create(how_many_decimals))}"
)
if format_spec:
raise VarValueError(
(
"Unknown format code '{}' for object of type 'NumberVar'. It is only supported to use '.f' for float numbers."
"If possible, use computed variables instead: https://reflex.dev/docs/vars/computed-vars/"
).format(format_spec)
)
return super().__format__(format_spec)
@var_operation
def get_decimal_string_operation(value: NumberVar, decimals: NumberVar):
"""Get the decimal string of the number.
Args:
value: The number.
decimals: The number of decimals.
Returns:
The decimal string of the number.
"""
return var_operation_return(
js_expression=f"({value}.toFixed({decimals}))",
var_type=str,
)
def binary_number_operation(
func: Callable[[NumberVar, NumberVar], str],