fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
exercises fix: count good and bad answers correctly
[redakcja.git]
/
redakcja
/
static
/
edumed
/
js
/
edumed.coffee
diff --git
a/redakcja/static/edumed/js/edumed.coffee
b/redakcja/static/edumed/js/edumed.coffee
index
7c40bff
..
fb8ea87
100644
(file)
--- a/
redakcja/static/edumed/js/edumed.coffee
+++ b/
redakcja/static/edumed/js/edumed.coffee
@@
-25,8
+25,8
@@
class Exercise extends Binding
$(".check", @element).click (ev) =>
@check()
$(".check", @element).click (ev) =>
@check()
- $(
ev.target).next(".retry"
).show()
- $(
ev.targe
t).hide()
+ $(
".retry", @element
).show()
+ $(
".check", @elemen
t).hide()
$(".retry", @element).click (ev) =>
@retry()
$('.solutions', @element).click =>
$(".retry", @element).click (ev) =>
@retry()
$('.solutions', @element).click =>
@@
-55,10
+55,11
@@
class Exercise extends Binding
$(".question", @element).each (i, question) =>
scores.push(@check_question question)
$(".question", @element).each (i, question) =>
scores.push(@check_question question)
- score = [0, 0]
+ score = [0, 0
, 0
]
$.each scores, (i, s) ->
score[0] += s[0]
score[1] += s[1]
$.each scores, (i, s) ->
score[0] += s[0]
score[1] += s[1]
+ score[2] += s[2]
@show_score(score)
show_solutions: ->
@show_score(score)
show_solutions: ->
@@
-97,7
+98,12
@@
class Exercise extends Binding
return [mandat, opt]
show_score: (score) ->
return [mandat, opt]
show_score: (score) ->
- $(".message", @element).text("Wynik: #{score[0]} / #{score[1]}")
+ $msg = $(".message", @element)
+ $msg.text("Wynik: #{score[0]} / #{score[2]}")
+ if score[0] >= score[2] and score[1] == 0
+ $msg.addClass("maxscore")
+ else
+ $msg.removeClass("maxscore")
draggable_equal: ($draggable1, $draggable2) ->
draggable_equal: ($draggable1, $draggable2) ->
@@
-124,6
+130,7
@@
class Exercise extends Binding
$added.append('<span class="remove">x</span><div class="clr"></div>')
$('.remove', $added).click (ev) =>
$added.append('<span class="remove">x</span><div class="clr"></div>')
$('.remove', $added).click (ev) =>
+ @retry()
if not ismultiple
$($added.data('original')).removeClass('disabled').draggable('enable')
if not ismultiple
$($added.data('original')).removeClass('disabled').draggable('enable')
@@
-198,6
+205,7
@@
class Wybor extends Exercise
check_question: (question) ->
all = 0
good = 0
check_question: (question) ->
all = 0
good = 0
+ bad = 0
solution = @get_value_list(question, 'solution')
$(".question-piece", question).each (i, qpiece) =>
piece_no = $(qpiece).attr 'data-no'
solution = @get_value_list(question, 'solution')
$(".question-piece", question).each (i, qpiece) =>
piece_no = $(qpiece).attr 'data-no'
@@
-216,11
+224,12
@@
class Wybor extends Exercise
good += 1
@piece_correct qpiece
else
good += 1
@piece_correct qpiece
else
+ bad += 1
@piece_incorrect qpiece
else
$(qpiece).removeClass("correct,incorrect")
@piece_incorrect qpiece
else
$(qpiece).removeClass("correct,incorrect")
- return [good, all]
+ return [good,
bad,
all]
solve_question: (question) ->
solution = @get_value_list(question, 'solution')
solve_question: (question) ->
solution = @get_value_list(question, 'solution')
@@
-247,6
+256,7
@@
class Uporzadkuj extends Exercise
pkts = $('.question-piece', question)
correct = 0
pkts = $('.question-piece', question)
correct = 0
+ bad = 0
all = 0
for pkt in [0...pkts.length]
all = 0
for pkt in [0...pkts.length]
@@
-255,8
+265,9
@@
class Uporzadkuj extends Exercise
correct += 1
@piece_correct pkts.eq(pkt)
else
correct += 1
@piece_correct pkts.eq(pkt)
else
+ bad += 1
@piece_incorrect pkts.eq(pkt)
@piece_incorrect pkts.eq(pkt)
- return [correct, all]
+ return [correct,
bad,
all]
solve_question: (question) ->
positions = @get_value_list(question, 'original', true)
solve_question: (question) ->
positions = @get_value_list(question, 'original', true)
@@
-281,18
+292,19
@@
class Luki extends Exercise
@dragging false, false
check: ->
@dragging false, false
check: ->
- all =
0
+ all =
$(".placeholder", @element).length
correct = 0
correct = 0
+ bad = 0
$(".placeholder + .question-piece", @element).each (i, qpiece) =>
$placeholder = $(qpiece).prev(".placeholder")
if $placeholder.data('solution') == $(qpiece).data('no')
@piece_correct qpiece
correct += 1
else
$(".placeholder + .question-piece", @element).each (i, qpiece) =>
$placeholder = $(qpiece).prev(".placeholder")
if $placeholder.data('solution') == $(qpiece).data('no')
@piece_correct qpiece
correct += 1
else
+ bad += 1
@piece_incorrect qpiece
@piece_incorrect qpiece
- all += 1
- @show_score [correct, all]
+ @show_score [correct,
bad,
all]
solve_question: (question) ->
$(".placeholder", question).each (i, placeholder) =>
solve_question: (question) ->
$(".placeholder", question).each (i, placeholder) =>
@@
-310,6
+322,7
@@
class Zastap extends Exercise
check: ->
all = 0
correct = 0
check: ->
all = 0
correct = 0
+ bad = 0
$(".paragraph", @element).each (i, par) =>
$(".placeholder", par).each (j, qpiece) =>
$(".paragraph", @element).each (i, par) =>
$(".placeholder", par).each (j, qpiece) =>
@@
-323,7
+336,7
@@
class Zastap extends Exercise
all += 1
all += 1
- @show_score [correct, all]
+ @show_score [correct,
bad,
all]
show_solutions: ->
@reset()
show_solutions: ->
@reset()
@@
-369,7
+382,7
@@
class Zastap extends Exercise
class Przyporzadkuj extends Exercise
is_multiple: ->
for qp in $(".question-piece", @element)
class Przyporzadkuj extends Exercise
is_multiple: ->
for qp in $(".question-piece", @element)
- if $(qp).
data('
solution').split(/[ ,]+/).length > 1
+ if $(qp).
attr('data-
solution').split(/[ ,]+/).length > 1
return true
return false
return true
return false
@@
-388,14
+401,19
@@
class Przyporzadkuj extends Exercise
# subjects placed in predicates
minimum = $(question).data("minimum")
count = 0
# subjects placed in predicates
minimum = $(question).data("minimum")
count = 0
+ bad_count = 0
all = 0
if not minimum
all = 0
if not minimum
- all = $(".subjects .question-piece", question).length
+ self = this
+ $(".subject .question-piece", question).each (i, el) ->
+ v = self.get_value_optional_list el, 'solution'
+ mandatory = v[0]
+ all += mandatory.length
for pred in $(".predicate [data-predicate]", question)
pn = $(pred).attr('data-predicate')
for pred in $(".predicate [data-predicate]", question)
pn = $(pred).attr('data-predicate')
- if minimum?
- all += minimum
+
#
if minimum?
+
#
all += minimum
for qp in $(".question-piece", pred)
v = @get_value_optional_list qp, 'solution'
for qp in $(".question-piece", pred)
v = @get_value_optional_list qp, 'solution'
@@
-406,9
+424,10
@@
class Przyporzadkuj extends Exercise
count += 1
@piece_correct qp
else
count += 1
@piece_correct qp
else
+ bad_count += 1
@piece_incorrect qp
@piece_incorrect qp
- return [count, all]
+ return [count,
bad_count,
all]
solve_question: (question) ->
minimum = $(question).data("min")
solve_question: (question) ->
minimum = $(question).data("min")
@@
-425,7
+444,7
@@
class Przyporzadkuj extends Exercise
for m in draggables
$pr = $(".predicate [data-predicate=" + m + "]", question)
$ph = $pr.find ".placeholder:visible"
for m in draggables
$pr = $(".predicate [data-predicate=" + m + "]", question)
$ph = $pr.find ".placeholder:visible"
- @draggable_move $(qp), $ph, @multiple
+ @draggable_move $(qp), $ph
.eq(0)
, @multiple
@@
-434,31
+453,33
@@
class PrawdaFalsz extends Exercise
super element
for qp in $(".question-piece", @element)
super element
for qp in $(".question-piece", @element)
- $(".true", qp).click (ev)
-
>
+ $(".true", qp).click (ev)
=
>
ev.preventDefault()
@retry()
ev.preventDefault()
@retry()
- $(
this
).closest(".question-piece").data("value", "true")
- $(
this
).addClass('chosen').siblings('a').removeClass('chosen')
- $(".false", qp).click (ev)
-
>
+ $(
ev.target
).closest(".question-piece").data("value", "true")
+ $(
ev.target
).addClass('chosen').siblings('a').removeClass('chosen')
+ $(".false", qp).click (ev)
=
>
ev.preventDefault()
@retry()
ev.preventDefault()
@retry()
- $(
this
).closest(".question-piece").data("value", "false")
- $(
this
).addClass('chosen').siblings('a').removeClass('chosen')
+ $(
ev.target
).closest(".question-piece").data("value", "false")
+ $(
ev.target
).addClass('chosen').siblings('a').removeClass('chosen')
check_question: ->
all = 0
good = 0
check_question: ->
all = 0
good = 0
+ bad = 0
for qp in $(".question-piece", @element)
if $(qp).data("solution").toString() == $(qp).data("value")
good += 1
@piece_correct qp
else
for qp in $(".question-piece", @element)
if $(qp).data("solution").toString() == $(qp).data("value")
good += 1
@piece_correct qp
else
+ bad += 1
@piece_incorrect qp
all += 1
@piece_incorrect qp
all += 1
- return [good, all]
+ return [good,
bad,
all]
show_solutions: ->
@reset()
show_solutions: ->
@reset()