1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
// (C) Copyright 2015 Martin Dougiamas
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
angular.module('mm.addons.qtype_algebra')
/**
* Short answer question handlers.
*
* @module mm.addons.qtype_algebra
* @ngdoc service
* @name $mmaQtypeAlgebraHandler
*/
.factory('$mmaQtypeAlgebraHandler', function($mmUtil) {
var self = {};
/**
* Check if a response is complete.
*
* @param {Object} question Question.
* @param {Object} answers Question answers (without prefix).
* @return {Mixed} True if complete, false if not complete, -1 if cannot determine.
*/
self.isCompleteResponse = function(question, answers) {
return answers['answer'] || answers['answer'] === 0;
};
/**
* Whether or not the module is enabled for the site.
*
* @return {Boolean}
*/
self.isEnabled = function() {
return true;
};
/**
* Check if a student has provided enough of an answer for the question to be graded automatically,
* or whether it must be considered aborted.
*
* @param {Object} question Question.
* @param {Object} answers Question answers (without prefix).
* @return {Mixed} True if gradable, false if not gradable, -1 if cannot determine.
*/
self.isGradableResponse = function(question, answers) {
return self.isCompleteResponse(question, answers);
};
/**
* Check if two responses are the same.
*
* @param {Object} question Question.
* @param {Object} prevAnswers Previous answers.
* @param {Object} newAnswers New answers.
* @return {Boolean} True if same, false otherwise.
*/
self.isSameResponse = function(question, prevAnswers, newAnswers) {
return $mmUtil.sameAtKeyMissingIsBlank(prevAnswers, newAnswers, 'answer');
};
/**
* Get the directive.
*
* @param {Object} question The question.
* @return {String} Directive's name.
*/
self.getDirectiveName = function(question) {
return 'mma-qtype-algebra';
};
return self;
});
|