Spaces:
Sleeping
Sleeping
Commit
Β·
8210d08
0
Parent(s):
Duplicate from aieye/aieye_tutorial_template
Browse files- .gitattributes +34 -0
- .sessions/.gitkeep +0 -0
- .sessions/johndoe/level.txt +1 -0
- 0_Introduction.py +24 -0
- README.md +14 -0
- assets/logo.png +0 -0
- pages/1_Step_1.py +15 -0
- pages/2_Step_2.py +16 -0
- pages/3_Congratulations.py +13 -0
- requirements.txt +0 -0
- utils/__init__.py +0 -0
- utils/__pycache__/__init__.cpython-310.pyc +0 -0
- utils/__pycache__/levels.cpython-310.pyc +0 -0
- utils/__pycache__/login.cpython-310.pyc +0 -0
- utils/levels.py +36 -0
- utils/login.py +28 -0
.gitattributes
ADDED
@@ -0,0 +1,34 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
*.7z filter=lfs diff=lfs merge=lfs -text
|
2 |
+
*.arrow filter=lfs diff=lfs merge=lfs -text
|
3 |
+
*.bin filter=lfs diff=lfs merge=lfs -text
|
4 |
+
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
5 |
+
*.ckpt filter=lfs diff=lfs merge=lfs -text
|
6 |
+
*.ftz filter=lfs diff=lfs merge=lfs -text
|
7 |
+
*.gz filter=lfs diff=lfs merge=lfs -text
|
8 |
+
*.h5 filter=lfs diff=lfs merge=lfs -text
|
9 |
+
*.joblib filter=lfs diff=lfs merge=lfs -text
|
10 |
+
*.lfs.* filter=lfs diff=lfs merge=lfs -text
|
11 |
+
*.mlmodel filter=lfs diff=lfs merge=lfs -text
|
12 |
+
*.model filter=lfs diff=lfs merge=lfs -text
|
13 |
+
*.msgpack filter=lfs diff=lfs merge=lfs -text
|
14 |
+
*.npy filter=lfs diff=lfs merge=lfs -text
|
15 |
+
*.npz filter=lfs diff=lfs merge=lfs -text
|
16 |
+
*.onnx filter=lfs diff=lfs merge=lfs -text
|
17 |
+
*.ot filter=lfs diff=lfs merge=lfs -text
|
18 |
+
*.parquet filter=lfs diff=lfs merge=lfs -text
|
19 |
+
*.pb filter=lfs diff=lfs merge=lfs -text
|
20 |
+
*.pickle filter=lfs diff=lfs merge=lfs -text
|
21 |
+
*.pkl filter=lfs diff=lfs merge=lfs -text
|
22 |
+
*.pt filter=lfs diff=lfs merge=lfs -text
|
23 |
+
*.pth filter=lfs diff=lfs merge=lfs -text
|
24 |
+
*.rar filter=lfs diff=lfs merge=lfs -text
|
25 |
+
*.safetensors filter=lfs diff=lfs merge=lfs -text
|
26 |
+
saved_model/**/* filter=lfs diff=lfs merge=lfs -text
|
27 |
+
*.tar.* filter=lfs diff=lfs merge=lfs -text
|
28 |
+
*.tflite filter=lfs diff=lfs merge=lfs -text
|
29 |
+
*.tgz filter=lfs diff=lfs merge=lfs -text
|
30 |
+
*.wasm filter=lfs diff=lfs merge=lfs -text
|
31 |
+
*.xz filter=lfs diff=lfs merge=lfs -text
|
32 |
+
*.zip filter=lfs diff=lfs merge=lfs -text
|
33 |
+
*.zst filter=lfs diff=lfs merge=lfs -text
|
34 |
+
*tfevents* filter=lfs diff=lfs merge=lfs -text
|
.sessions/.gitkeep
ADDED
File without changes
|
.sessions/johndoe/level.txt
ADDED
@@ -0,0 +1 @@
|
|
|
|
|
1 |
+
3
|
0_Introduction.py
ADDED
@@ -0,0 +1,24 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
from utils.levels import complete_level, initialize_level, render_page, get_level
|
3 |
+
from utils.login import initialize_login
|
4 |
+
|
5 |
+
initialize_login()
|
6 |
+
initialize_level()
|
7 |
+
|
8 |
+
LEVEL=0
|
9 |
+
|
10 |
+
def intro_page():
|
11 |
+
st.header("AI Eye Tutorial Template")
|
12 |
+
st.subheader("Level 0: Introduction")
|
13 |
+
|
14 |
+
st.write("""Welcome to the AI Eye Tutorial Template! This template is designed to help you create your own AI Eye tutorial.
|
15 |
+
The template is divided into levels, and each level has a set of tasks that you need to complete before you can move on to the next level.
|
16 |
+
You can use this template to create your own tutorial by completing the tasks in each level and adding your own content. You can also use
|
17 |
+
this template to learn how to use AI Eye by completing the tasks in each level.""")
|
18 |
+
|
19 |
+
st.info(f"Current Level: {get_level()}")
|
20 |
+
|
21 |
+
if st.button("Complete"):
|
22 |
+
complete_level(LEVEL)
|
23 |
+
|
24 |
+
render_page(intro_page, LEVEL)
|
README.md
ADDED
@@ -0,0 +1,14 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
---
|
2 |
+
title: Aieye Tutorial Template
|
3 |
+
emoji: π
|
4 |
+
colorFrom: green
|
5 |
+
colorTo: purple
|
6 |
+
sdk: streamlit
|
7 |
+
sdk_version: 1.21.0
|
8 |
+
app_file: 0_Introduction.py
|
9 |
+
pinned: false
|
10 |
+
license: openrail
|
11 |
+
duplicated_from: aieye/aieye_tutorial_template
|
12 |
+
---
|
13 |
+
|
14 |
+
Check out the configuration reference at https://huggingface.co/docs/hub/spaces-config-reference
|
assets/logo.png
ADDED
![]() |
pages/1_Step_1.py
ADDED
@@ -0,0 +1,15 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
from utils.levels import complete_level, render_page, initialize_level
|
3 |
+
LEVEL = 1
|
4 |
+
|
5 |
+
initialize_level()
|
6 |
+
|
7 |
+
def step1_page():
|
8 |
+
st.header("Step 1")
|
9 |
+
st.subheader("Level 1: Introduction")
|
10 |
+
st.write("This is the first step of the tutorial. You can add your own content here.")
|
11 |
+
|
12 |
+
if st.button("Complete"):
|
13 |
+
complete_level(LEVEL)
|
14 |
+
|
15 |
+
render_page(step1_page, LEVEL)
|
pages/2_Step_2.py
ADDED
@@ -0,0 +1,16 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
from utils.levels import complete_level, render_page, initialize_level
|
3 |
+
|
4 |
+
initialize_level()
|
5 |
+
|
6 |
+
LEVEL = 2
|
7 |
+
|
8 |
+
def step2_page():
|
9 |
+
st.header("Step 2")
|
10 |
+
st.subheader("Level 2: Introduction")
|
11 |
+
st.write("This is the second step of the tutorial. You can add your own content here.")
|
12 |
+
|
13 |
+
if st.button("Complete"):
|
14 |
+
complete_level(LEVEL)
|
15 |
+
|
16 |
+
render_page(step2_page, LEVEL)
|
pages/3_Congratulations.py
ADDED
@@ -0,0 +1,13 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
from utils.levels import complete_level, render_page, initialize_level
|
3 |
+
|
4 |
+
initialize_level()
|
5 |
+
|
6 |
+
LEVEL = 3
|
7 |
+
|
8 |
+
def step1_page():
|
9 |
+
st.header("Congratulations!")
|
10 |
+
st.subheader("You have completed the tutorial!")
|
11 |
+
st.write("You can now use this template to create your own tutorial.")
|
12 |
+
|
13 |
+
render_page(step1_page, LEVEL)
|
requirements.txt
ADDED
File without changes
|
utils/__init__.py
ADDED
File without changes
|
utils/__pycache__/__init__.cpython-310.pyc
ADDED
Binary file (161 Bytes). View file
|
|
utils/__pycache__/levels.cpython-310.pyc
ADDED
Binary file (1.59 kB). View file
|
|
utils/__pycache__/login.cpython-310.pyc
ADDED
Binary file (1.05 kB). View file
|
|
utils/levels.py
ADDED
@@ -0,0 +1,36 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
from utils.login import get_login
|
3 |
+
import os
|
4 |
+
|
5 |
+
def initialize_level():
|
6 |
+
if 'level' not in st.session_state:
|
7 |
+
if get_login()["status"]:
|
8 |
+
if not os.path.exists(f".sessions/{get_login()['username']}/level.txt"):
|
9 |
+
with open(f".sessions/{get_login()['username']}/level.txt", "w") as f:
|
10 |
+
f.write("0")
|
11 |
+
st.session_state['level'] = 0
|
12 |
+
else:
|
13 |
+
with open(f".sessions/{get_login()['username']}/level.txt", "r") as f:
|
14 |
+
st.session_state['level'] = int(f.read())
|
15 |
+
|
16 |
+
def get_level():
|
17 |
+
return st.session_state['level']
|
18 |
+
|
19 |
+
def render_page(page, level):
|
20 |
+
if get_login()["status"]:
|
21 |
+
if st.session_state['level'] < level:
|
22 |
+
st.error(f"You need to complete Level {st.session_state['level']} first!")
|
23 |
+
else:
|
24 |
+
page()
|
25 |
+
else:
|
26 |
+
st.error("You need to login first!")
|
27 |
+
|
28 |
+
def complete_level(level):
|
29 |
+
if st.session_state['level'] > level:
|
30 |
+
st.info(f'You have Already completed Level {level}!')
|
31 |
+
else:
|
32 |
+
st.session_state['level'] = level + 1
|
33 |
+
with open(f".sessions/{get_login()['username']}/level.txt", "w") as f:
|
34 |
+
f.write(str(st.session_state['level']))
|
35 |
+
st.balloons()
|
36 |
+
st.success(f'You have completed Level {level}! You can now move on to the next level.')
|
utils/login.py
ADDED
@@ -0,0 +1,28 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
import streamlit as st
|
2 |
+
import os
|
3 |
+
|
4 |
+
|
5 |
+
def initialize_login():
|
6 |
+
if "login" not in st.session_state:
|
7 |
+
st.columns(3)[1].image("assets/logo.png")
|
8 |
+
username = st.text_input("Username")
|
9 |
+
password = st.text_input("Password", type="password")
|
10 |
+
if st.button("Login"):
|
11 |
+
# TODO: replace with actual authorization check
|
12 |
+
authorized = {"status": True, "Name": "John Doe", "username": "johndoe"}
|
13 |
+
if authorized["status"]:
|
14 |
+
st.session_state["login"] = authorized
|
15 |
+
os.makedirs(
|
16 |
+
os.path.join(".sessions", st.session_state["login"]["username"]),
|
17 |
+
exist_ok=True,
|
18 |
+
)
|
19 |
+
st.success("Login Successful!")
|
20 |
+
st.experimental_rerun()
|
21 |
+
else:
|
22 |
+
st.error("Invalid username or password")
|
23 |
+
else:
|
24 |
+
st.sidebar.success(f'Hello, {st.session_state["login"]["Name"]}!')
|
25 |
+
|
26 |
+
|
27 |
+
def get_login():
|
28 |
+
return st.session_state.get("login", {"status": False})
|