Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore: update docs to include blogs #371

Merged
merged 1 commit into from
Nov 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
70 changes: 70 additions & 0 deletions mintlify-docs/blogs/Buttons in zero-true.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,70 @@
---
title: 'Buttons in Zero-True'
---

## Creating a Button

Creating a button in zero-true is very easy. It’s as simple as

```py
import zero-true as zt
button=zt.Button(id=’btn’)
```

![](/blogs/photos/button.png)

## Button Values

Buttons return True when clicked and False otherwise. There is no need to write callbacks, simply reference buttons as follows.

```py
if button.value==True: print("hello") else: print("goodbye")
```

## Button Use Cases

Buttons have a ton of potential use cases in zero-true. The example above uses a button to toggle different printed statements but logic can be used to render more complicated layouts. One of the more common patterns for using buttons in zero-true are gating expensive computations, for example:

```py
import zero_true as zt
import time

def expensive_computation():
time.sleep(30)

if button.value==True:
expensive_computation()

else:
print("Press Button to Run Expensive Computation")
```

Another use case for buttons in zero-true is getting user confirmation before submitting a form. In the example below we save feedback that a user submits in a text area under a .txt file under their name.


![title](/blogs/gifs/button_computation.gif)

```py
import zero_true as zt

#function to write feedback to a file under someone's name
def write_feedback(name,text):
with open(name+'.txt','w+') as file:
file.write(text)

#name input
name_input = zt.TextInput(id='txt_i',label='Write you name')
text_area = zt.TextArea(id='txt_a',label='Write your feedback here')

#submission button
button=zt.Button(id='btn', label= 'Submit you feedback')

if button.value==True and name_input.value:
write_feedback(name_input.value, text_area.value)
```

![](/blogs/photos/button_form.png)

## Customizing your button

You can also add different colors and labels to your button to make things more interesting. Feel free to play around with all the attributes in the documentation.
62 changes: 62 additions & 0 deletions mintlify-docs/blogs/Displaying a Matplotlib Plot in zero-true.mdx

Large diffs are not rendered by default.

48 changes: 48 additions & 0 deletions mintlify-docs/blogs/Displaying a Pandas DataFrame in zero-true.mdx

Large diffs are not rendered by default.

66 changes: 66 additions & 0 deletions mintlify-docs/blogs/Displaying a Plotly Plot in zero-true.mdx

Large diffs are not rendered by default.

57 changes: 57 additions & 0 deletions mintlify-docs/blogs/Range Sliders in zero-true.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,57 @@
---
title: 'Range Sliders in zero-true'
---

## Creating a Range Slider

Creating a rage slider in zero-true is simple. Type:

```py
import zero-true as zt
range_slider=zt.RangeSlider(id='slider')
```

![][image1]

Run the cell in your notebook, and watch the range slider appear below.

## Range Slider Settings and Values

Range Sliders have a minimum, maximum, and step in zero-true. The default values for min and max are 0 and 100 and the step is 1 but you can set them to whatever you’d like. The range slider value will return a list structured as follows \[min,max\]. Here is a little snippet to show you how to access the min and max values from your range slider.

```py
max = range_slider.value[0]
min = range_slider.value[1]

print("Min val is "+str(min)+ " and max val is "+str(max))
```

## ![][image2]

## Range Slider Use Cases

Sliders can be used to capture any numeric input. Here is a more fleshed out example including filtering a dataframe:

```py
import pandas as pd
import zero_true as zt

novels_df = pd.read_html("https://en.wikipedia.org/w/index.php?title=Science_Fiction:_The_100_Best_Novels&oldid=1091082777", match='The 100 Best Novels')[0]

#define a slider in zero-true to filter the data
range_slider=zt.RangeSlider(id='range_slider',min=1, max=100,label='Move the Slider to Filter the DataFrame')
if not range_slider.value:
range_slider.value=[0,100]
zt.dataframe(id='df',df=novels_df[range_slider.value[0]:range_slider.value[1]])
```

![title](/blogs/gifs/range slider.gif)


## Customizing your Range Slider

You can also add different colors and labels to your slider to make it to your liking. Feel free to check out the full range of options with the api reference for a slider.

[image1]: <>

[image2]: <>
59 changes: 59 additions & 0 deletions mintlify-docs/blogs/Sliders in zero-true.mdx

Large diffs are not rendered by default.

50 changes: 50 additions & 0 deletions mintlify-docs/blogs/Text Areas in zero-true.mdx

Large diffs are not rendered by default.

51 changes: 51 additions & 0 deletions mintlify-docs/blogs/Text Inputs in zero-true.mdx

Large diffs are not rendered by default.

Loading
Loading