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.js
diff --git
a/redakcja/static/edumed/js/edumed.js
b/redakcja/static/edumed/js/edumed.js
index
817dd95
..
3262cac
100644
(file)
--- a/
redakcja/static/edumed/js/edumed.js
+++ b/
redakcja/static/edumed/js/edumed.js
@@
-40,8
+40,8
@@
$(this.element).data("exercise-html", $(this.element).html());
$(".check", this.element).click(function(ev) {
_this.check();
$(this.element).data("exercise-html", $(this.element).html());
$(".check", this.element).click(function(ev) {
_this.check();
- $(
ev.target).next(".retry"
).show();
- return $(
ev.targe
t).hide();
+ $(
".retry", _this.element
).show();
+ return $(
".check", _this.elemen
t).hide();
});
$(".retry", this.element).click(function(ev) {
return _this.retry();
});
$(".retry", this.element).click(function(ev) {
return _this.retry();
@@
-81,10
+81,11
@@
$(".question", this.element).each(function(i, question) {
return scores.push(_this.check_question(question));
});
$(".question", this.element).each(function(i, question) {
return scores.push(_this.check_question(question));
});
- score = [0, 0];
+ score = [0, 0
, 0
];
$.each(scores, function(i, s) {
score[0] += s[0];
$.each(scores, function(i, s) {
score[0] += s[0];
- return score[1] += s[1];
+ score[1] += s[1];
+ return score[2] += s[2];
});
return this.show_score(score);
};
});
return this.show_score(score);
};
@@
-125,7
+126,14
@@
};
Exercise.prototype.show_score = function(score) {
};
Exercise.prototype.show_score = function(score) {
- return $(".message", this.element).text("Wynik: " + score[0] + " / " + score[1]);
+ var $msg;
+ $msg = $(".message", this.element);
+ $msg.text("Wynik: " + score[0] + " / " + score[2]);
+ if (score[0] >= score[2] && score[1] === 0) {
+ return $msg.addClass("maxscore");
+ } else {
+ return $msg.removeClass("maxscore");
+ }
};
Exercise.prototype.draggable_equal = function($draggable1, $draggable2) {
};
Exercise.prototype.draggable_equal = function($draggable1, $draggable2) {
@@
-161,6
+169,7
@@
}
$added.append('<span class="remove">x</span><div class="clr"></div>');
return $('.remove', $added).click(function(ev) {
}
$added.append('<span class="remove">x</span><div class="clr"></div>');
return $('.remove', $added).click(function(ev) {
+ _this.retry();
if (!ismultiple) {
$($added.data('original')).removeClass('disabled').draggable('enable');
}
if (!ismultiple) {
$($added.data('original')).removeClass('disabled').draggable('enable');
}
@@
-229,10
+238,11
@@
}
Wybor.prototype.check_question = function(question) {
}
Wybor.prototype.check_question = function(question) {
- var all, good, solution,
+ var all,
bad,
good, solution,
_this = this;
all = 0;
good = 0;
_this = this;
all = 0;
good = 0;
+ bad = 0;
solution = this.get_value_list(question, 'solution');
$(".question-piece", question).each(function(i, qpiece) {
var is_checked, piece_name, piece_no, should_be_checked;
solution = this.get_value_list(question, 'solution');
$(".question-piece", question).each(function(i, qpiece) {
var is_checked, piece_name, piece_no, should_be_checked;
@@
-252,13
+262,14
@@
good += 1;
return _this.piece_correct(qpiece);
} else {
good += 1;
return _this.piece_correct(qpiece);
} else {
+ bad += 1;
return _this.piece_incorrect(qpiece);
}
} else {
return $(qpiece).removeClass("correct,incorrect");
}
});
return _this.piece_incorrect(qpiece);
}
} else {
return $(qpiece).removeClass("correct,incorrect");
}
});
- return [good, all];
+ return [good,
bad,
all];
};
Wybor.prototype.solve_question = function(question) {
};
Wybor.prototype.solve_question = function(question) {
@@
-296,11
+307,12
@@
}
Uporzadkuj.prototype.check_question = function(question) {
}
Uporzadkuj.prototype.check_question = function(question) {
- var all, correct, pkt, pkts, positions, sorted, _i, _ref;
+ var all,
bad,
correct, pkt, pkts, positions, sorted, _i, _ref;
positions = this.get_value_list(question, 'original', true);
sorted = positions.sort();
pkts = $('.question-piece', question);
correct = 0;
positions = this.get_value_list(question, 'original', true);
sorted = positions.sort();
pkts = $('.question-piece', question);
correct = 0;
+ bad = 0;
all = 0;
for (pkt = _i = 0, _ref = pkts.length; 0 <= _ref ? _i < _ref : _i > _ref; pkt = 0 <= _ref ? ++_i : --_i) {
all += 1;
all = 0;
for (pkt = _i = 0, _ref = pkts.length; 0 <= _ref ? _i < _ref : _i > _ref; pkt = 0 <= _ref ? ++_i : --_i) {
all += 1;
@@
-308,10
+320,11
@@
correct += 1;
this.piece_correct(pkts.eq(pkt));
} else {
correct += 1;
this.piece_correct(pkts.eq(pkt));
} else {
+ bad += 1;
this.piece_incorrect(pkts.eq(pkt));
}
}
this.piece_incorrect(pkts.eq(pkt));
}
}
- return [correct, all];
+ return [correct,
bad,
all];
};
Uporzadkuj.prototype.solve_question = function(question) {
};
Uporzadkuj.prototype.solve_question = function(question) {
@@
-354,22
+367,23
@@
}
Luki.prototype.check = function() {
}
Luki.prototype.check = function() {
- var all, correct,
+ var all,
bad,
correct,
_this = this;
_this = this;
- all =
0
;
+ all =
$(".placeholder", this.element).length
;
correct = 0;
correct = 0;
+ bad = 0;
$(".placeholder + .question-piece", this.element).each(function(i, qpiece) {
var $placeholder;
$placeholder = $(qpiece).prev(".placeholder");
if ($placeholder.data('solution') === $(qpiece).data('no')) {
_this.piece_correct(qpiece);
$(".placeholder + .question-piece", this.element).each(function(i, qpiece) {
var $placeholder;
$placeholder = $(qpiece).prev(".placeholder");
if ($placeholder.data('solution') === $(qpiece).data('no')) {
_this.piece_correct(qpiece);
- correct += 1;
+
return
correct += 1;
} else {
} else {
- _this.piece_incorrect(qpiece);
+ bad += 1;
+ return _this.piece_incorrect(qpiece);
}
}
- return all += 1;
});
});
- return this.show_score([correct, all]);
+ return this.show_score([correct,
bad,
all]);
};
Luki.prototype.solve_question = function(question) {
};
Luki.prototype.solve_question = function(question) {
@@
-399,10
+413,11
@@
}
Zastap.prototype.check = function() {
}
Zastap.prototype.check = function() {
- var all, correct,
+ var all,
bad,
correct,
_this = this;
all = 0;
correct = 0;
_this = this;
all = 0;
correct = 0;
+ bad = 0;
$(".paragraph", this.element).each(function(i, par) {
return $(".placeholder", par).each(function(j, qpiece) {
var $dragged, $qp;
$(".paragraph", this.element).each(function(i, par) {
return $(".placeholder", par).each(function(j, qpiece) {
var $dragged, $qp;
@@
-417,7
+432,7
@@
}
});
});
}
});
});
- return this.show_score([correct, all]);
+ return this.show_score([correct,
bad,
all]);
};
Zastap.prototype.show_solutions = function() {
};
Zastap.prototype.show_solutions = function() {
@@
-485,7
+500,7
@@
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
- if ($(qp).
data('
solution').split(/[ ,]+/).length > 1) {
+ if ($(qp).
attr('data-
solution').split(/[ ,]+/).length > 1) {
return true;
}
}
return true;
}
}
@@
-503,20
+518,24
@@
};
Przyporzadkuj.prototype.check_question = function(question) {
};
Przyporzadkuj.prototype.check_question = function(question) {
- var all,
count, mandatory, minimum, optional, pn, pred, qp
, v, _i, _j, _len, _len1, _ref, _ref1;
+ var all,
bad_count, count, mandatory, minimum, optional, pn, pred, qp, self
, v, _i, _j, _len, _len1, _ref, _ref1;
minimum = $(question).data("minimum");
count = 0;
minimum = $(question).data("minimum");
count = 0;
+ bad_count = 0;
all = 0;
if (!minimum) {
all = 0;
if (!minimum) {
- all = $(".subjects .question-piece", question).length;
+ self = this;
+ $(".subject .question-piece", question).each(function(i, el) {
+ var mandatory, v;
+ v = self.get_value_optional_list(el, 'solution');
+ mandatory = v[0];
+ return all += mandatory.length;
+ });
}
_ref = $(".predicate [data-predicate]", question);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
pred = _ref[_i];
pn = $(pred).attr('data-predicate');
}
_ref = $(".predicate [data-predicate]", question);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
pred = _ref[_i];
pn = $(pred).attr('data-predicate');
- if (minimum != null) {
- all += minimum;
- }
_ref1 = $(".question-piece", pred);
for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) {
qp = _ref1[_j];
_ref1 = $(".question-piece", pred);
for (_j = 0, _len1 = _ref1.length; _j < _len1; _j++) {
qp = _ref1[_j];
@@
-527,11
+546,12
@@
count += 1;
this.piece_correct(qp);
} else {
count += 1;
this.piece_correct(qp);
} else {
+ bad_count += 1;
this.piece_incorrect(qp);
}
}
}
this.piece_incorrect(qp);
}
}
}
- return [count, all];
+ return [count,
bad_count,
all];
};
Przyporzadkuj.prototype.solve_question = function(question) {
};
Przyporzadkuj.prototype.solve_question = function(question) {
@@
-556,7
+576,7
@@
m = draggables[_j];
$pr = $(".predicate [data-predicate=" + m + "]", question);
$ph = $pr.find(".placeholder:visible");
m = draggables[_j];
$pr = $(".predicate [data-predicate=" + m + "]", question);
$ph = $pr.find(".placeholder:visible");
- _results1.push(this.draggable_move($(qp), $ph, this.multiple));
+ _results1.push(this.draggable_move($(qp), $ph
.eq(0)
, this.multiple));
}
return _results1;
}).call(this));
}
return _results1;
}).call(this));
@@
-573,30
+593,32
@@
__extends(PrawdaFalsz, _super);
function PrawdaFalsz(element) {
__extends(PrawdaFalsz, _super);
function PrawdaFalsz(element) {
- var qp, _i, _len, _ref;
+ var qp, _i, _len, _ref,
+ _this = this;
PrawdaFalsz.__super__.constructor.call(this, element);
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
$(".true", qp).click(function(ev) {
ev.preventDefault();
PrawdaFalsz.__super__.constructor.call(this, element);
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
$(".true", qp).click(function(ev) {
ev.preventDefault();
- this.retry();
- $(
this
).closest(".question-piece").data("value", "true");
- return $(
this
).addClass('chosen').siblings('a').removeClass('chosen');
+
_
this.retry();
+ $(
ev.target
).closest(".question-piece").data("value", "true");
+ return $(
ev.target
).addClass('chosen').siblings('a').removeClass('chosen');
});
$(".false", qp).click(function(ev) {
ev.preventDefault();
});
$(".false", qp).click(function(ev) {
ev.preventDefault();
- this.retry();
- $(
this
).closest(".question-piece").data("value", "false");
- return $(
this
).addClass('chosen').siblings('a').removeClass('chosen');
+
_
this.retry();
+ $(
ev.target
).closest(".question-piece").data("value", "false");
+ return $(
ev.target
).addClass('chosen').siblings('a').removeClass('chosen');
});
}
}
PrawdaFalsz.prototype.check_question = function() {
});
}
}
PrawdaFalsz.prototype.check_question = function() {
- var all, good, qp, _i, _len, _ref;
+ var all,
bad,
good, qp, _i, _len, _ref;
all = 0;
good = 0;
all = 0;
good = 0;
+ bad = 0;
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
_ref = $(".question-piece", this.element);
for (_i = 0, _len = _ref.length; _i < _len; _i++) {
qp = _ref[_i];
@@
-604,11
+626,12
@@
good += 1;
this.piece_correct(qp);
} else {
good += 1;
this.piece_correct(qp);
} else {
+ bad += 1;
this.piece_incorrect(qp);
}
all += 1;
}
this.piece_incorrect(qp);
}
all += 1;
}
- return [good, all];
+ return [good,
bad,
all];
};
PrawdaFalsz.prototype.show_solutions = function() {
};
PrawdaFalsz.prototype.show_solutions = function() {