Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
E
edx-platform
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
edx
edx-platform
Commits
78c194aa
Commit
78c194aa
authored
Jan 15, 2013
by
Diana Huang
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #1284 from MITx/feature/vik/add-staff-grading-notifications
Feature/vik/add staff grading notifications
parents
e2f8ce9d
8aa033f6
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
28 additions
and
3 deletions
+28
-3
lms/djangoapps/courseware/tabs.py
+19
-1
lms/djangoapps/open_ended_grading/staff_grading_service.py
+7
-0
lms/static/coffee/src/staff_grading/staff_grading.coffee
+1
-1
lms/templates/peer_grading/peer_grading.html
+1
-1
No files found.
lms/djangoapps/courseware/tabs.py
View file @
78c194aa
...
@@ -22,6 +22,7 @@ from courseware.access import has_access
...
@@ -22,6 +22,7 @@ from courseware.access import has_access
from
static_replace
import
replace_urls
from
static_replace
import
replace_urls
from
open_ended_grading.peer_grading_service
import
PeerGradingService
from
open_ended_grading.peer_grading_service
import
PeerGradingService
from
open_ended_grading.staff_grading_service
import
StaffGradingService
from
student.models
import
unique_id_for_user
from
student.models
import
unique_id_for_user
log
=
logging
.
getLogger
(
__name__
)
log
=
logging
.
getLogger
(
__name__
)
...
@@ -108,7 +109,24 @@ def _textbooks(tab, user, course, active_page):
...
@@ -108,7 +109,24 @@ def _textbooks(tab, user, course, active_page):
def
_staff_grading
(
tab
,
user
,
course
,
active_page
):
def
_staff_grading
(
tab
,
user
,
course
,
active_page
):
if
has_access
(
user
,
course
,
'staff'
):
if
has_access
(
user
,
course
,
'staff'
):
link
=
reverse
(
'staff_grading'
,
args
=
[
course
.
id
])
link
=
reverse
(
'staff_grading'
,
args
=
[
course
.
id
])
return
[
CourseTab
(
'Staff grading'
,
link
,
active_page
==
"staff_grading"
)]
staff_gs
=
StaffGradingService
(
settings
.
STAFF_GRADING_INTERFACE
)
pending_grading
=
False
tab_name
=
"Staff grading"
img_path
=
""
try
:
notifications
=
json
.
loads
(
staff_gs
.
get_notifications
(
course
.
id
))
if
notifications
[
'success'
]:
if
notifications
[
'staff_needs_to_grade'
]:
pending_grading
=
True
except
:
#Non catastrophic error, so no real action
log
.
info
(
"Problem with getting notifications from staff grading service."
)
if
pending_grading
:
img_path
=
"/static/images/slider-handle.png"
tab
=
[
CourseTab
(
tab_name
,
link
,
active_page
==
"staff_grading"
,
pending_grading
,
img_path
)]
return
tab
return
[]
return
[]
def
_peer_grading
(
tab
,
user
,
course
,
active_page
):
def
_peer_grading
(
tab
,
user
,
course
,
active_page
):
...
...
lms/djangoapps/open_ended_grading/staff_grading_service.py
View file @
78c194aa
...
@@ -66,6 +66,7 @@ class StaffGradingService(GradingService):
...
@@ -66,6 +66,7 @@ class StaffGradingService(GradingService):
self
.
get_next_url
=
self
.
url
+
'/get_next_submission/'
self
.
get_next_url
=
self
.
url
+
'/get_next_submission/'
self
.
save_grade_url
=
self
.
url
+
'/save_grade/'
self
.
save_grade_url
=
self
.
url
+
'/save_grade/'
self
.
get_problem_list_url
=
self
.
url
+
'/get_problem_list/'
self
.
get_problem_list_url
=
self
.
url
+
'/get_problem_list/'
self
.
get_notifications_url
=
self
.
url
+
"/get_notifications/"
def
get_problem_list
(
self
,
course_id
,
grader_id
):
def
get_problem_list
(
self
,
course_id
,
grader_id
):
...
@@ -132,6 +133,12 @@ class StaffGradingService(GradingService):
...
@@ -132,6 +133,12 @@ class StaffGradingService(GradingService):
return
self
.
post
(
self
.
save_grade_url
,
data
=
data
)
return
self
.
post
(
self
.
save_grade_url
,
data
=
data
)
def
get_notifications
(
self
,
course_id
):
params
=
{
'course_id'
:
course_id
}
response
=
self
.
get
(
self
.
get_notifications_url
,
params
)
return
response
# don't initialize until staff_grading_service() is called--means that just
# don't initialize until staff_grading_service() is called--means that just
# importing this file doesn't create objects that may not have the right config
# importing this file doesn't create objects that may not have the right config
_service
=
None
_service
=
None
...
...
lms/static/coffee/src/staff_grading/staff_grading.coffee
View file @
78c194aa
...
@@ -318,7 +318,7 @@ class StaffGrading
...
@@ -318,7 +318,7 @@ class StaffGrading
problem_link
:
(
problem
)
->
problem_link
:
(
problem
)
->
link
=
$
(
'<a>'
).
attr
(
'href'
,
"javascript:void(0)"
).
append
(
link
=
$
(
'<a>'
).
attr
(
'href'
,
"javascript:void(0)"
).
append
(
"
#{
problem
.
problem_name
}
(
#{
problem
.
num_graded
}
graded,
#{
problem
.
num_pending
}
pending)"
)
"
#{
problem
.
problem_name
}
(
#{
problem
.
num_graded
}
graded,
#{
problem
.
num_pending
}
pending
, required to grade
#{
problem
.
num_required
}
more
)"
)
.
click
=>
.
click
=>
@
get_next_submission
problem
.
location
@
get_next_submission
problem
.
location
...
...
lms/templates/peer_grading/peer_grading.html
View file @
78c194aa
...
@@ -29,7 +29,7 @@
...
@@ -29,7 +29,7 @@
<ul
class=
"problem-list"
>
<ul
class=
"problem-list"
>
%for problem in problem_list:
%for problem in problem_list:
<li>
<li>
<a
href=
"${ajax_url}problem?location=${problem['location']}"
>
${problem['problem_name']} (${problem['num_graded']} graded, ${problem['num_pending']} pending)
</a>
<a
href=
"${ajax_url}problem?location=${problem['location']}"
>
${problem['problem_name']} (${problem['num_graded']} graded, ${problem['num_pending']} pending
, required to grade ${problem['num_required']} more
)
</a>
</li>
</li>
%endfor
%endfor
</ul>
</ul>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment