Updated radio group component

This commit is contained in:
Sagar Hedaoo 2024-06-11 05:30:43 +00:00
parent 66f0a49b75
commit c5212c3c0d
2 changed files with 37 additions and 17 deletions

View File

@ -2,14 +2,14 @@ fail_fast: true
repos:
- repo: https://github.com/charliermarsh/ruff-pre-commit
rev: v0.1.0
hooks:
- id: ruff-format
args: [integration, reflex, tests]
- id: ruff
args: ["--fix", "--exit-non-zero-on-fix"]
exclude: '^integration/benchmarks/'
# - repo: https://github.com/charliermarsh/ruff-pre-commit
# rev: v0.1.0
# hooks:
# - id: ruff-format
# args: [integration, reflex, tests]
# - id: ruff
# args: ["--fix", "--exit-non-zero-on-fix"]
# exclude: '^integration/benchmarks/'
- repo: https://github.com/RobertCraigie/pyright-python
rev: v1.1.313

View File

@ -16,7 +16,8 @@ from ..base import (
RadixThemesComponent,
)
LiteralFlexDirection = Literal["row", "column", "row-reverse", "column-reverse"]
LiteralFlexDirection = Literal["row",
"column", "row-reverse", "column-reverse"]
class RadioGroupRoot(RadixThemesComponent):
@ -25,10 +26,13 @@ class RadioGroupRoot(RadixThemesComponent):
tag = "RadioGroup.Root"
# The size of the radio group: "1" | "2" | "3"
size: Var[Literal["1", "2", "3"]]
size: Var[Literal["1", "2", "3"]] = Var.create_safe(
"2", _var_is_string=True)
# The variant of the radio group
variant: Var[Literal["classic", "surface", "soft"]]
variant: Var[Literal["classic", "surface", "soft"]] = Var.create_safe(
"classic", _var_is_string=True
)
# The color of the radio group
color_scheme: Var[LiteralAccentColor]
@ -88,16 +92,21 @@ class HighLevelRadioGroup(RadixThemesComponent):
items: Var[List[str]]
# The direction of the radio group.
direction: Var[LiteralFlexDirection]
direction: Var[LiteralFlexDirection] = Var.create_safe(
"column", _var_is_string=True
)
# The gap between the items of the radio group.
spacing: Var[LiteralSpacing] = Var.create_safe("2", _var_is_string=True)
# The size of the radio group.
size: Var[Literal["1", "2", "3"]] = Var.create_safe("2", _var_is_string=True)
size: Var[Literal["1", "2", "3"]] = Var.create_safe(
"2", _var_is_string=True)
# The variant of the radio group
variant: Var[Literal["classic", "surface", "soft"]]
variant: Var[Literal["classic", "surface", "soft"]] = Var.create_safe(
"classic", _var_is_string=True
)
# The color of the radio group
color_scheme: Var[LiteralAccentColor]
@ -141,14 +150,19 @@ class HighLevelRadioGroup(RadixThemesComponent):
direction = props.pop("direction", "column")
spacing = props.pop("spacing", "2")
size = props.pop("size", "2")
variant = props.pop("variant", "classic")
color_scheme = props.pop("color_scheme", None)
default_value = props.pop("default_value", "")
default_value = Var.create(default_value)
# convert only non-strings to json(JSON.stringify) so quotes are not rendered
# for string literal types.
if isinstance(default_value, str) or (
isinstance(default_value, Var) and default_value._var_type is str
):
default_value = Var.create(default_value, _var_is_string=True) # type: ignore
default_value = Var.create(
default_value, _var_is_string=True) # type: ignore
else:
default_value = (
Var.create(default_value, _var_is_string=False)
@ -157,7 +171,8 @@ class HighLevelRadioGroup(RadixThemesComponent):
)
def radio_group_item(value: str | Var) -> Component:
item_value = Var.create(value, _var_is_string=False) # type: ignore
item_value = Var.create(
value, _var_is_string=False) # type: ignore
item_value = rx.cond(
item_value._type() == str, # type: ignore
item_value,
@ -166,7 +181,10 @@ class HighLevelRadioGroup(RadixThemesComponent):
return Text.create(
Flex.create(
RadioGroupItem.create(value=item_value),
RadioGroupItem.create(
value=item_value, disabled=props.get(
"disabled", Var.create(False))
),
item_value,
spacing="2",
),
@ -184,6 +202,8 @@ class HighLevelRadioGroup(RadixThemesComponent):
spacing=spacing,
),
size=size,
variant=variant,
color_scheme=color_scheme,
default_value=default_value,
**props,
)