fnp
/
redakcja.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix: Editing nodes with XNodeAttributes might lead to data corruption
[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
24955fd
..
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) ->
@@
-199,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'
@@
-217,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')
@@
-248,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]
@@
-256,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)
@@
-282,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) =>
@@
-311,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) =>
@@
-324,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()
@@
-370,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
@@
-389,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'
@@
-407,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")
@@
-450,16
+468,18
@@
class PrawdaFalsz extends Exercise
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()