# check out https://solara.dev/ for documentation
# or https://github.com/widgetti/solara/
# And check out https://py.cafe/maartenbreddels for more examples
import solara
# reactive variables will trigger a component rerender
# when changed.
# When you change the default (now 0), hit the embedded browser
# refresh button to reset the state
clicks = solara.reactive(0)
foods = ["Kiwi", "Banana", "Apple"]
food = solara.reactive("Banana")
code_snippets = {
"Kiwi": '''
{"foo": 8, "bar": 9}
''',
"Apple": '''
{"boop": 10, "bar": 10}
''',
}
@solara.component
def Page():
print("The component render function gets called")
# change this code, and see the output refresh
solara.Select(label="Food", value=food, values=foods)
json_code = f"""
```python
{code_snippets[food.value]}
```"""
solara.Markdown(f"**Selected**: {food.value}")
solara.Markdown(f"**Selected**: {food.value}")
# Solara also supports ipywidgets
# remove the Page component and assign an ipywidget to
# the page variable, e.g.
# page = mywidget