-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdashboard.py
71 lines (60 loc) · 2.46 KB
/
dashboard.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
#################################################################################
## dashboard.py - Penn CIS Teaching Dashboard
##
## Main StreamLit application for the Penn CIS Teaching Dashboard.
## Renders a view of student assignment completion, submission, and
## grading status. Provides basic capabilities for assigning grades.
##
## Licensed to the Apache Software Foundation (ASF) under one
## or more contributor license agreements. See the NOTICE file
## distributed with this work for additional information
## regarding copyright ownership. The ASF licenses this file
## to you under the Apache License, Version 2.0 (the
## "License"); you may not use this file except in compliance
## with the License. You may obtain a copy of the License at
##
## http://www.apache.org/licenses/LICENSE-2.0
##
## Unless required by applicable law or agreed to in writing,
## software distributed under the License is distributed on an
## "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
## KIND, either express or implied. See the License for the
## specific language governing permissions and limitations
## under the License.
##
#################################################################################
import streamlit as st
from entities import get_course_names
from components import display_course, display_birds_eye
from views import get_course_student_status_summary
from status_tests import is_overdue, is_near_due, is_submitted
from database import include_canvas_data, include_gradescope_data
name = ''
if include_gradescope_data:
name = 'Gradescope'
if include_canvas_data:
if len(name) > 0:
name += '-'
name += 'Canvas'
st.markdown("# Penn CIS {} Dashboard".format(name))
# Inject custom CSS to set the width of the sidebar
st.markdown(
"""
<style>
section[data-testid="stSidebar"] {
width: 450px !important; # Set the width to your desired value
}
</style>
""",
unsafe_allow_html=True,
)
### Main dashboard is very simple.
### To the left, we have a "birds-eye" view of the course, showing the number of students
### and their progress on assignments.
### In the main view, there is a course selector with detailed data.
with st.sidebar:
display_birds_eye(get_course_student_status_summary(
is_overdue, is_near_due, is_submitted))
# Display the currently selected course contents
course_filter = st.selectbox("Select course", get_course_names())
display_course(course_filter=course_filter)