Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
P
problem-builder
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
OpenEdx
problem-builder
Commits
8133e633
Commit
8133e633
authored
Sep 25, 2015
by
Tim Krones
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Move logic for displaying grade and review links to review step.
parent
026446e4
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
112 additions
and
93 deletions
+112
-93
problem_builder/public/js/mentoring_with_steps.js
+18
-29
problem_builder/public/js/review_step.js
+28
-0
problem_builder/step.py
+2
-0
problem_builder/templates/html/mentoring_review_templates.html
+0
-63
problem_builder/templates/html/review_step.html
+64
-1
No files found.
problem_builder/public/js/mentoring_with_steps.js
View file @
8133e633
function
MentoringWithStepsBlock
(
runtime
,
element
)
{
function
MentoringWithStepsBlock
(
runtime
,
element
)
{
var
steps
=
runtime
.
children
(
element
).
filter
(
var
children
=
runtime
.
children
(
element
);
var
steps
=
children
.
filter
(
function
(
c
)
{
return
c
.
element
.
className
.
indexOf
(
'sb-step'
)
>
-
1
;
}
function
(
c
)
{
return
c
.
element
.
className
.
indexOf
(
'sb-step'
)
>
-
1
;
}
);
);
var
reviewStep
;
for
(
var
i
=
0
;
i
<
children
.
length
;
i
++
)
{
var
child
=
children
[
i
];
if
(
child
.
type
===
'sb-review-step'
)
{
reviewStep
=
child
;
break
;
}
}
var
activeStep
=
$
(
'.mentoring'
,
element
).
data
(
'active-step'
);
var
activeStep
=
$
(
'.mentoring'
,
element
).
data
(
'active-step'
);
var
gradeTemplate
=
_
.
template
(
$
(
'#xblock-review-template'
).
html
());
var
reviewStepsTemplate
=
_
.
template
(
$
(
'#xblock-review-steps-template'
).
html
());
var
reviewTipsTemplate
=
_
.
template
(
$
(
'#xblock-review-tips-template'
).
html
());
// Tips about specific questions the user got wrong
var
reviewTipsTemplate
=
_
.
template
(
$
(
'#xblock-review-tips-template'
).
html
());
// Tips about specific questions the user got wrong
var
attemptsTemplate
=
_
.
template
(
$
(
'#xblock-attempts-template'
).
html
());
var
attemptsTemplate
=
_
.
template
(
$
(
'#xblock-attempts-template'
).
html
());
var
reviewStep
,
checkmark
,
submitDOM
,
nextDOM
,
reviewDOM
,
tryAgainDOM
,
var
checkmark
,
submitDOM
,
nextDOM
,
reviewDOM
,
tryAgainDOM
,
assessmentMessageDOM
,
gradeDOM
,
attemptsDOM
,
reviewTipsDOM
,
reviewLinkDOM
,
submitXHR
;
assessmentMessageDOM
,
gradeDOM
,
attemptsDOM
,
reviewTipsDOM
,
reviewLinkDOM
,
submitXHR
;
function
isLastStep
()
{
function
isLastStep
()
{
...
@@ -19,10 +27,6 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -19,10 +27,6 @@ function MentoringWithStepsBlock(runtime, element) {
return
(
activeStep
===
-
1
);
return
(
activeStep
===
-
1
);
}
}
function
reviewStepPresent
()
{
return
reviewStep
.
length
>
0
;
}
function
someAttemptsLeft
()
{
function
someAttemptsLeft
()
{
var
data
=
attemptsDOM
.
data
();
var
data
=
attemptsDOM
.
data
();
if
(
data
.
max_attempts
===
0
)
{
// Unlimited number of attempts available
if
(
data
.
max_attempts
===
0
)
{
// Unlimited number of attempts available
...
@@ -97,7 +101,7 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -97,7 +101,7 @@ function MentoringWithStepsBlock(runtime, element) {
if
(
nextDOM
.
is
(
':visible'
))
{
nextDOM
.
focus
();
}
if
(
nextDOM
.
is
(
':visible'
))
{
nextDOM
.
focus
();
}
if
(
atReviewStep
())
{
if
(
atReviewStep
())
{
if
(
reviewStep
Present
()
)
{
if
(
reviewStep
)
{
reviewDOM
.
removeAttr
(
'disabled'
);
reviewDOM
.
removeAttr
(
'disabled'
);
}
else
{
}
else
{
if
(
someAttemptsLeft
())
{
if
(
someAttemptsLeft
())
{
...
@@ -160,7 +164,7 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -160,7 +164,7 @@ function MentoringWithStepsBlock(runtime, element) {
showActiveStep
();
showActiveStep
();
validateXBlock
();
validateXBlock
();
nextDOM
.
attr
(
'disabled'
,
'disabled'
);
nextDOM
.
attr
(
'disabled'
,
'disabled'
);
if
(
isLastStep
()
&&
reviewStep
Present
()
)
{
if
(
isLastStep
()
&&
reviewStep
)
{
reviewDOM
.
attr
(
'disabled'
,
'disabled'
);
reviewDOM
.
attr
(
'disabled'
,
'disabled'
);
reviewDOM
.
show
();
reviewDOM
.
show
();
}
}
...
@@ -173,23 +177,13 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -173,23 +177,13 @@ function MentoringWithStepsBlock(runtime, element) {
}
}
function
showReviewStep
()
{
function
showReviewStep
()
{
reviewStep
.
show
();
var
data
=
gradeDOM
.
data
();
var
data
=
gradeDOM
.
data
();
// Links for reviewing individual questions (WIP)
// Forward to review step to render grade data
var
enableExtendedFeedback
=
(
!
someAttemptsLeft
()
&&
data
.
extended_feedback
);
var
showExtendedFeedback
=
(
!
someAttemptsLeft
()
&&
data
.
extended_feedback
);
reviewStep
.
renderGrade
(
gradeDOM
,
showExtendedFeedback
);
_
.
extend
(
data
,
{
// Add click handler that takes care of showing associated step to step links
'runDetails'
:
function
(
correctness
)
{
if
(
!
enableExtendedFeedback
)
{
return
''
;
}
var
self
=
this
;
return
reviewStepsTemplate
({
'questions'
:
self
[
correctness
],
'correctness'
:
correctness
});
}
});
gradeDOM
.
html
(
gradeTemplate
(
data
));
$
(
'a.step-link'
,
element
).
on
(
'click'
,
getStepToReview
);
$
(
'a.step-link'
,
element
).
on
(
'click'
,
getStepToReview
);
if
(
someAttemptsLeft
())
{
if
(
someAttemptsLeft
())
{
...
@@ -221,7 +215,6 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -221,7 +215,6 @@ function MentoringWithStepsBlock(runtime, element) {
function
jumpToReview
(
stepIndex
)
{
function
jumpToReview
(
stepIndex
)
{
activeStep
=
stepIndex
;
activeStep
=
stepIndex
;
cleanAll
();
cleanAll
();
reviewStep
.
hide
();
showActiveStep
();
showActiveStep
();
if
(
isLastStep
())
{
if
(
isLastStep
())
{
...
@@ -322,7 +315,6 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -322,7 +315,6 @@ function MentoringWithStepsBlock(runtime, element) {
function
handleTryAgain
(
result
)
{
function
handleTryAgain
(
result
)
{
activeStep
=
result
.
active_step
;
activeStep
=
result
.
active_step
;
updateDisplay
();
updateDisplay
();
reviewStep
.
hide
();
tryAgainDOM
.
hide
();
tryAgainDOM
.
hide
();
submitDOM
.
show
();
submitDOM
.
show
();
if
(
!
isLastStep
())
{
if
(
!
isLastStep
())
{
...
@@ -342,9 +334,6 @@ function MentoringWithStepsBlock(runtime, element) {
...
@@ -342,9 +334,6 @@ function MentoringWithStepsBlock(runtime, element) {
}
}
function
initXBlockView
()
{
function
initXBlockView
()
{
reviewStep
=
$
(
'.sb-review-step'
,
element
);
reviewStep
.
hide
();
checkmark
=
$
(
'.assessment-checkmark'
,
element
);
checkmark
=
$
(
'.assessment-checkmark'
,
element
);
submitDOM
=
$
(
element
).
find
(
'.submit .input-main'
);
submitDOM
=
$
(
element
).
find
(
'.submit .input-main'
);
...
...
problem_builder/public/js/review_step.js
0 → 100644
View file @
8133e633
function
ReviewStepBlock
(
runtime
,
element
)
{
var
gradeTemplate
=
_
.
template
(
$
(
'#xblock-feedback-template'
).
html
());
var
reviewStepsTemplate
=
_
.
template
(
$
(
'#xblock-step-links-template'
).
html
());
return
{
'renderGrade'
:
function
(
gradeDOM
,
showExtendedFeedback
)
{
var
data
=
gradeDOM
.
data
();
_
.
extend
(
data
,
{
'runDetails'
:
function
(
correctness
)
{
if
(
!
showExtendedFeedback
)
{
return
''
;
}
var
self
=
this
;
return
reviewStepsTemplate
({
'questions'
:
self
[
correctness
],
'correctness'
:
correctness
});
}
});
gradeDOM
.
html
(
gradeTemplate
(
data
));
}
};
}
problem_builder/step.py
View file @
8133e633
...
@@ -260,4 +260,6 @@ class ReviewStepBlock(XBlockWithPreviewMixin, XBlock):
...
@@ -260,4 +260,6 @@ class ReviewStepBlock(XBlockWithPreviewMixin, XBlock):
fragment
.
add_content
(
loader
.
render_template
(
'templates/html/review_step.html'
,
{
fragment
.
add_content
(
loader
.
render_template
(
'templates/html/review_step.html'
,
{
'self'
:
self
,
'self'
:
self
,
}))
}))
fragment
.
add_javascript_url
(
self
.
runtime
.
local_resource_url
(
self
,
'public/js/review_step.js'
))
fragment
.
initialize_js
(
'ReviewStepBlock'
)
return
fragment
return
fragment
problem_builder/templates/html/mentoring_review_templates.html
View file @
8133e633
<script
type=
"text/template"
id=
"xblock-review-template"
>
<
div
class
=
"grade-result"
>
<
h2
>
<%=
_
.
template
(
gettext
(
"You scored {percent}% on this assessment."
),
{
percent
:
score
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/h2
>
<
hr
/>
<
span
class
=
"assessment-checkmark icon-2x checkmark-correct icon-ok fa fa-check"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question correctly."
,
"You answered {number_correct} questions correctly."
,
correct_answer
),
{
number_correct
:
correct_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'correct'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
span
class
=
"assessment-checkmark icon-2x checkmark-partially-correct icon-ok fa fa-check"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question partially correctly."
,
"You answered {number_partially_correct} questions partially correctly."
,
partially_correct_answer
),
{
number_partially_correct
:
partially_correct_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'partial'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
span
class
=
"assessment-checkmark icon-2x checkmark-incorrect icon-exclamation fa fa-exclamation"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question incorrectly."
,
"You answered {number_incorrect} questions incorrectly."
,
incorrect_answer
),
{
number_incorrect
:
incorrect_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'incorrect'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
hr
/>
<
/div
>
</script>
<!-- Template for extended feedback: Show extended feedback details when all attempts are used up. -->
<script
type=
"text/template"
id=
"xblock-review-steps-template"
>
<%
var
q
,
last_question
;
%>
<
ul
class
=
"review-list <%= correctness %>-list"
>
<%
for
(
var
question
in
questions
)
{{
q
=
questions
[
question
];
last_question
=
question
==
questions
.
length
-
1
;
%>
<
li
><
a
href
=
"#"
class
=
"step-link"
data
-
step
=
"<%= q.step %>"
><%=
_
.
template
(
gettext
(
"Question {number}"
),
{
number
:
q
.
number
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%><
/a></
li
>
<%
}}
%>
<
/ul
>
</script>
<!-- Tips about specific questions the student got wrong. From pb-message[type=on-assessment-review-question] blocks -->
<!-- Tips about specific questions the student got wrong. From pb-message[type=on-assessment-review-question] blocks -->
<script
type=
"text/template"
id=
"xblock-review-tips-template"
>
<script
type=
"text/template"
id=
"xblock-review-tips-template"
>
<
p
class
=
"review-tips-intro"
><%=
gettext
(
"You might consider reviewing the following items before your next assessment attempt:"
)
%><
/p
>
<
p
class
=
"review-tips-intro"
><%=
gettext
(
"You might consider reviewing the following items before your next assessment attempt:"
)
%><
/p
>
...
...
problem_builder/templates/html/review_step.html
View file @
8133e633
<div
class=
"sb-review-step"
>
<div
class=
"sb-review-step"
>
<h3>
...
</h3>
<script
type=
"text/template"
id=
"xblock-feedback-template"
>
<
div
class
=
"grade-result"
>
<
h2
>
<%=
_
.
template
(
gettext
(
"You scored {percent}% on this assessment."
),
{
percent
:
score
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/h2
>
<
hr
/>
<
span
class
=
"assessment-checkmark icon-2x checkmark-correct icon-ok fa fa-check"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question correctly."
,
"You answered {number_correct} questions correctly."
,
correct_answer
),
{
number_correct
:
correct_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'correct'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
span
class
=
"assessment-checkmark icon-2x checkmark-partially-correct icon-ok fa fa-check"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question partially correctly."
,
"You answered {number_partially_correct} questions partially correctly."
,
partially_correct_answer
),
{
number_partially_correct
:
partially_correct_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'partial'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
span
class
=
"assessment-checkmark icon-2x checkmark-incorrect icon-exclamation fa fa-exclamation"
><
/span
>
<
div
class
=
"results-section"
>
<
p
>
<%=
_
.
template
(
ngettext
(
"You answered 1 question incorrectly."
,
"You answered {number_incorrect} questions incorrectly."
,
incorrect_answer
),
{
number_incorrect
:
incorrect_answer
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%>
<
/p
>
<%=
runDetails
(
'incorrect'
)
%>
<
/div
>
<
div
class
=
"clear"
><
/div
>
<
hr
/>
<
/div
>
</script>
<!-- Template for extended feedback: Show extended feedback details when all attempts are used up. -->
<script
type=
"text/template"
id=
"xblock-step-links-template"
>
<%
var
q
,
last_question
;
%>
<
ul
class
=
"review-list <%= correctness %>-list"
>
<%
for
(
var
question
in
questions
)
{{
q
=
questions
[
question
];
last_question
=
question
==
questions
.
length
-
1
;
%>
<
li
><
a
href
=
"#"
class
=
"step-link"
data
-
step
=
"<%= q.step %>"
><%=
_
.
template
(
gettext
(
"Question {number}"
),
{
number
:
q
.
number
},
{
interpolate
:
/
\{(
.+
?)\}
/g
})
%><
/a></
li
>
<%
}}
%>
<
/ul
>
</script>
</div>
</div>
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