-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore: update docs to include blogs (#371)
update docs to include blogs Co-authored-by: Red Giuliano <[email protected]>
- Loading branch information
1 parent
ed20ff2
commit d5947b5
Showing
37 changed files
with
532 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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
62
mintlify-docs/blogs/Displaying a Matplotlib Plot in zero-true.mdx
Large diffs are not rendered by default.
Oops, something went wrong.
48 changes: 48 additions & 0 deletions
48
mintlify-docs/blogs/Displaying a Pandas DataFrame in zero-true.mdx
Large diffs are not rendered by default.
Oops, something went wrong.
66 changes: 66 additions & 0 deletions
66
mintlify-docs/blogs/Displaying a Plotly Plot in zero-true.mdx
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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]: <> |
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
Oops, something went wrong.