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
8e30981f
Commit
8e30981f
authored
Jun 07, 2013
by
Brian Talbot
Committed by
Giulio Gratta
Jun 10, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
revises the show/hide answer input to use an HTML button element for accessibility purposes
parent
7390b517
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
38 additions
and
29 deletions
+38
-29
common/lib/xmodule/xmodule/css/capa/display.scss
+13
-4
common/lib/xmodule/xmodule/js/fixtures/problem_content.html
+1
-1
common/lib/xmodule/xmodule/js/src/capa/display.coffee
+19
-19
lms/templates/problem.html
+5
-5
No files found.
common/lib/xmodule/xmodule/css/capa/display.scss
View file @
8e30981f
...
...
@@ -555,6 +555,15 @@ section.problem {
@extend
.blue-button
;
}
button
.show
{
height
:
(
$baseline
*
2
);
span
{
font-size
:
1
.0em
;
font-weight
:
600
;
}
}
.submission_feedback
{
// background: #F3F3F3;
// border: 1px solid #ddd;
...
...
@@ -811,13 +820,13 @@ section.problem {
}
.selected-grade
{
background
:
#666
;
color
:
white
;
color
:
white
;
}
input
[
type
=
radio
]
:checked
+
label
{
background
:
#666
;
color
:
white
;
}
input
[
class
=
'score-selection'
]
{
display
:
none
;
display
:
none
;
}
}
...
...
@@ -878,11 +887,11 @@ section.problem {
.tag-status
,
.tag
{
padding
:
.25em
.5em
;
}
}
}
textarea
.comment
{
textarea
.comment
{
$num-lines-to-show
:
5
;
$line-height
:
1
.4em
;
$padding
:
.2em
;
width
:
100%
;
width
:
100%
;
padding
:
$padding
(
2
*
$padding
);
line-height
:
$line-height
;
height
:
(
$num-lines-to-show
*
$line-height
)
+
(
2
*
$padding
)
-
((
$line-height
-
1
)
/
2
);
...
...
common/lib/xmodule/xmodule/js/fixtures/problem_content.html
View file @
8e30981f
...
...
@@ -13,7 +13,7 @@
<input
class=
"check"
type=
"button"
value=
"Check"
>
<input
class=
"reset"
type=
"button"
value=
"Reset"
>
<input
class=
"save"
type=
"button"
value=
"Save"
>
<
input
class=
"show"
type=
"button"
value=
"Show Answer"
>
<
button
class=
"show"
><span
class=
"show-label"
>
Show Answer(s)
</span>
<span
class=
"sr"
>
(for question(s) above - adjacent to each field)
</span></button
>
<a
href=
"/courseware/6.002_Spring_2012/${ explain }"
class=
"new-page"
>
Explanation
</a>
<section
class=
"submission_feedback"
></section>
</section>
...
...
common/lib/xmodule/xmodule/js/src/capa/display.coffee
View file @
8e30981f
...
...
@@ -19,12 +19,12 @@ class @Problem
problem_prefix
=
@
element_id
.
replace
(
/problem_/
,
''
)
@
inputs
=
@
$
(
"[id^=input_
#{
problem_prefix
}
_]"
)
@
$
(
'section.action input:button'
).
click
@
refreshAnswers
@
$
(
'section.action input.check'
).
click
@
check_fd
#@$('section.action input.check').click @check
@
$
(
'section.action input.reset'
).
click
@
reset
@
$
(
'section.action
input
.show'
).
click
@
show
@
$
(
'section.action
button
.show'
).
click
@
show
@
$
(
'section.action input.save'
).
click
@
save
# Collapsibles
...
...
@@ -44,7 +44,7 @@ class @Problem
forceUpdate
:
(
response
)
=>
@
el
.
attr
progress
:
response
.
progress_status
@
el
.
trigger
(
'progressChanged'
)
queueing
:
=>
@
queued_items
=
@
$
(
".xqueue"
)
...
...
@@ -59,11 +59,11 @@ class @Problem
get_queuelen
:
=>
minlen
=
Infinity
@
queued_items
.
each
(
index
,
qitem
)
->
len
=
parseInt
(
$
.
text
(
qitem
))
len
=
parseInt
(
$
.
text
(
qitem
))
if
len
<
minlen
minlen
=
len
return
minlen
poll
:
=>
$
.
postWithPrefix
"
#{
@
url
}
/problem_get"
,
(
response
)
=>
# If queueing status changed, then render
...
...
@@ -73,9 +73,9 @@ class @Problem
JavascriptLoader
.
executeModuleScripts
@
el
,
()
=>
@
setupInputTypes
()
@
bind
()
@
num_queued_items
=
@
new_queued_items
.
length
if
@
num_queued_items
==
0
if
@
num_queued_items
==
0
@
forceUpdate
response
delete
window
.
queuePollerID
else
...
...
@@ -83,12 +83,12 @@ class @Problem
window
.
queuePollerID
=
window
.
setTimeout
(
@
poll
,
1000
)
# Use this if you want to make an ajax call on the input type object
# Use this if you want to make an ajax call on the input type object
# static method so you don't have to instantiate a Problem in order to use it
# Input:
# url: the AJAX url of the problem
# url: the AJAX url of the problem
# input_id: the input_id of the input you would like to make the call on
# NOTE: the id is the ${id} part of "input_${id}" during rendering
# NOTE: the id is the ${id} part of "input_${id}" during rendering
# If this function is passed the entire prefixed id, the backend may have trouble
# finding the correct input
# dispatch: string that indicates how this data should be handled by the inputtype
...
...
@@ -98,7 +98,7 @@ class @Problem
data
[
'dispatch'
]
=
dispatch
data
[
'input_id'
]
=
input_id
$
.
postWithPrefix
"
#{
url
}
/input_ajax"
,
data
,
callback
render
:
(
content
)
->
if
content
...
...
@@ -141,7 +141,7 @@ class @Problem
Logger
.
log
'problem_check'
,
@
answers
# If there are no file inputs in the problem, we can fall back on @check
if
$
(
'input:file'
).
length
==
0
if
$
(
'input:file'
).
length
==
0
@
check
()
return
...
...
@@ -150,7 +150,7 @@ class @Problem
return
fd
=
new
FormData
()
# Sanity checks on submission
max_filesize
=
4
*
1000
*
1000
# 4 MB
file_too_large
=
false
...
...
@@ -195,19 +195,19 @@ class @Problem
abort_submission
=
file_too_large
or
file_not_selected
or
unallowed_file_submitted
or
required_files_not_submitted
settings
=
settings
=
type
:
"POST"
data
:
fd
processData
:
false
contentType
:
false
success
:
(
response
)
=>
success
:
(
response
)
=>
switch
response
.
success
when
'incorrect'
,
'correct'
@
render
(
response
.
contents
)
@
updateProgress
response
else
@
gentle_alert
response
.
success
if
not
abort_submission
$
.
ajaxWithPrefix
(
"
#{
@
url
}
/problem_check"
,
settings
)
...
...
@@ -260,14 +260,14 @@ class @Problem
@
el
.
find
(
'.problem > div'
).
each
(
index
,
element
)
=>
MathJax
.
Hub
.
Queue
[
"Typeset"
,
MathJax
.
Hub
,
element
]
@
$
(
'.show
'
).
val
'Hide Answer
'
@
$
(
'.show
-label'
).
text
'Hide Answer(s)
'
@
el
.
addClass
'showed'
@
updateProgress
response
else
@
$
(
'[id^=answer_], [id^=solution_]'
).
text
''
@
$
(
'[correct_answer]'
).
attr
correct_answer
:
null
@
el
.
removeClass
'showed'
@
$
(
'.show
'
).
val
'Show Answer
'
@
$
(
'.show
-label'
).
text
'Show Answer(s)
'
@
el
.
find
(
".capa_inputtype"
).
each
(
index
,
inputtype
)
=>
display
=
@
inputtypeDisplays
[
$
(
inputtype
).
attr
(
'id'
)]
...
...
@@ -306,7 +306,7 @@ class @Problem
MathJax
.
Hub
.
Queue
([
'Text'
,
jax
,
eqn
],
[
@
updateMathML
,
jax
,
element
])
return
# Explicit return for CoffeeScript
updateMathML
:
(
jax
,
element
)
=>
try
$
(
"#
#{
element
.
id
}
_dynamath"
).
val
(
jax
.
root
.
toMathML
''
)
...
...
lms/templates/problem.html
View file @
8e30981f
...
...
@@ -10,19 +10,19 @@
${ problem['html'] }
<section
class=
"action"
>
<input
type=
"hidden"
name=
"problem_id"
value=
"${ problem['name'] }"
>
<input
type=
"hidden"
name=
"problem_id"
value=
"${ problem['name'] }"
/
>
% if check_button:
<input
class=
"check ${ check_button }"
type=
"button"
value=
"${ check_button }"
>
<input
class=
"check ${ check_button }"
type=
"button"
value=
"${ check_button }"
/
>
% endif
% if reset_button:
<input
class=
"reset"
type=
"button"
value=
"Reset"
>
<input
class=
"reset"
type=
"button"
value=
"Reset"
/
>
% endif
% if save_button:
<input
class=
"save"
type=
"button"
value=
"Save"
>
<input
class=
"save"
type=
"button"
value=
"Save"
/
>
% endif
% if answer_available:
<
input
class=
"show"
type=
"button"
value=
"Show Answer"
>
<
button
class=
"show"
><span
class=
"show-label"
>
Show Answer(s)
</span>
<span
class=
"sr"
>
(for question(s) above - adjacent to each field)
</span></button
>
% endif
% if attempts_allowed :
<section
class=
"submission_feedback"
>
...
...
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