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
afe75d0
..
fb8ea87
100644
(file)
--- a/
redakcja/static/edumed/js/edumed.coffee
+++ b/
redakcja/static/edumed/js/edumed.coffee
@@
-25,18
+25,21
@@
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", @element).click (ev) =>
- $(".correct, .incorrect", @element).removeClass("correct incorrect")
- $(ev.target).prev(".check").show()
- $(ev.target).hide()
+ @retry()
$('.solutions', @element).click =>
@show_solutions()
$(".comment", @element).show()
$('.reset', @element).click =>
@reset()
$('.solutions', @element).click =>
@show_solutions()
$(".comment", @element).show()
$('.reset', @element).click =>
@reset()
+ retry: ->
+ $(".correct, .incorrect", @element).removeClass("correct incorrect")
+ $(".check", @element).show()
+ $(".retry", @element).hide()
+
reset: ->
$(@element).html($(@element).data('exercise-html'))
exercise @element
reset: ->
$(@element).html($(@element).data('exercise-html'))
exercise @element
@@
-52,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: ->
@@
-94,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) ->
@@
-119,8
+128,9
@@
class Exercise extends Binding
if $added.is(".add-li")
$added.wrap("<li/>")
if $added.is(".add-li")
$added.wrap("<li/>")
- $added.append('<span class="remove">x</span>')
+ $added.append('<span class="remove">x</span>
<div class="clr"></div>
')
$('.remove', $added).click (ev) =>
$('.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')
@@
-136,6
+146,7
@@
class Exercise extends Binding
draggable_opts =
revert: 'invalid'
helper: 'clone'
draggable_opts =
revert: 'invalid'
helper: 'clone'
+ start: @retry
$(".draggable", question).draggable(draggable_opts)
self = this
$(".draggable", question).draggable(draggable_opts)
self = this
@@
-188,11
+199,13
@@
class Exercise extends Binding
class Wybor extends Exercise
constructor: (element) ->
super element
class Wybor extends Exercise
constructor: (element) ->
super element
+ $(".question-piece input", element).change(@retry);
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'
@@
-211,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')
@@
-227,14
+241,14
@@
class Wybor extends Exercise
else
should_be_checked = solution.indexOf(piece_no) >= 0
console.log("check " + $("input[type=checkbox]", qpiece).attr("id") + " -> " + should_be_checked)
else
should_be_checked = solution.indexOf(piece_no) >= 0
console.log("check " + $("input[type=checkbox]", qpiece).attr("id") + " -> " + should_be_checked)
- $("input[type=checkbox]", qpiece).prop 'checked', should_be_checked
+ $("input[type=checkbox]
,input[type=radio]
", qpiece).prop 'checked', should_be_checked
class Uporzadkuj extends Exercise
constructor: (element) ->
super element
class Uporzadkuj extends Exercise
constructor: (element) ->
super element
- $('ol, ul', @element).sortable({ items: "> li" })
+ $('ol, ul', @element).sortable({ items: "> li"
, start: @retry
})
check_question: (question) ->
positions = @get_value_list(question, 'original', true)
check_question: (question) ->
positions = @get_value_list(question, 'original', true)
@@
-242,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]
@@
-250,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)
@@
-276,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) =>
@@
-305,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) =>
@@
-318,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()
@@
-364,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
@@
-383,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'
@@
-401,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")
@@
-420,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
@@
-429,34
+453,38
@@
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()
ev.preventDefault()
- $(this).closest(".question-piece").data("value", "true")
- $(this).addClass('chosen').siblings('a').removeClass('chosen')
- $(".false", qp).click (ev) ->
+ @retry()
+ $(ev.target).closest(".question-piece").data("value", "true")
+ $(ev.target).addClass('chosen').siblings('a').removeClass('chosen')
+ $(".false", qp).click (ev) =>
ev.preventDefault()
ev.preventDefault()
- $(this).closest(".question-piece").data("value", "false")
- $(this).addClass('chosen').siblings('a').removeClass('chosen')
+ @retry()
+ $(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()
for qp in $(".question-piece", @element)
show_solutions: ->
@reset()
for qp in $(".question-piece", @element)
- if $(qp).data('solution') ==
'true'
+ if $(qp).data('solution') ==
true
$(".true", qp).click()
else
$(".false", qp).click()
$(".true", qp).click()
else
$(".false", qp).click()