@oat-sa/tao-core-ui 1.57.0 → 1.58.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/actionbar.js +386 -395
- package/dist/adder.js +21 -19
- package/dist/animable/absorbable/absorbable.js +204 -213
- package/dist/animable/absorbable/css/absorb.css +1 -0
- package/dist/animable/absorbable/css/absorb.css.map +1 -1
- package/dist/animable/pulsable/pulsable.js +168 -177
- package/dist/autocomplete/css/autocomplete.css +1 -0
- package/dist/autocomplete/css/autocomplete.css.map +1 -1
- package/dist/autocomplete.js +68 -66
- package/dist/badge/badge.js +188 -197
- package/dist/badge/css/badge.css +1 -0
- package/dist/badge/css/badge.css.map +1 -1
- package/dist/breadcrumbs.js +275 -284
- package/dist/btngrouper.js +5 -5
- package/dist/bulkActionPopup.js +490 -495
- package/dist/button.js +283 -291
- package/dist/cascadingComboBox.js +249 -258
- package/dist/ckeditor/ckConfigurator.js +42 -20
- package/dist/ckeditor/dtdHandler.js +11 -9
- package/dist/class/selector.js +441 -450
- package/dist/component/resizable.js +1 -1
- package/dist/component/windowed.js +285 -294
- package/dist/component.js +419 -428
- package/dist/contextualPopup.js +417 -426
- package/dist/dashboard.js +300 -309
- package/dist/datalist.js +753 -762
- package/dist/datatable/filterStrategy/multiple.js +1 -1
- package/dist/datatable/filterStrategy/single.js +1 -1
- package/dist/datatable.js +1527 -1550
- package/dist/dateRange/dateRange.js +393 -402
- package/dist/datetime/picker.js +665 -672
- package/dist/deleter.js +368 -377
- package/dist/destination/selector.js +286 -295
- package/dist/dialog/alert.js +3 -3
- package/dist/dialog/confirm.js +1 -1
- package/dist/dialog/confirmDelete.js +216 -225
- package/dist/dialog.js +650 -654
- package/dist/disabler.js +8 -8
- package/dist/documentViewer/providers/pdfViewer/fallback/viewer.js +166 -175
- package/dist/documentViewer/providers/pdfViewer/pdfjs/findBar.js +518 -527
- package/dist/documentViewer/providers/pdfViewer/pdfjs/pageView.js +380 -389
- package/dist/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +539 -548
- package/dist/documentViewer/providers/pdfViewer/pdfjs/viewer.js +369 -378
- package/dist/documentViewer/providers/pdfViewer.js +184 -193
- package/dist/documentViewer.js +292 -301
- package/dist/dropdown.js +383 -392
- package/dist/durationer.js +5 -5
- package/dist/dynamicComponent.js +597 -598
- package/dist/feedback.js +356 -362
- package/dist/figure/FigureStateActive.js +117 -108
- package/dist/filesender.js +2 -2
- package/dist/filter.js +230 -239
- package/dist/form/dropdownForm.js +355 -357
- package/dist/form/form.js +919 -690
- package/dist/form/simpleForm.js +1 -1
- package/dist/form/validator/renderer.js +233 -235
- package/dist/form/validator/validator.js +257 -189
- package/dist/form/widget/definitions.js +1 -1
- package/dist/form/widget/providers/checkBox.js +254 -259
- package/dist/form/widget/providers/comboBox.js +187 -192
- package/dist/form/widget/providers/default.js +8 -9
- package/dist/form/widget/providers/hidden.js +170 -179
- package/dist/form/widget/providers/hiddenBox.js +262 -267
- package/dist/form/widget/providers/radioBox.js +216 -225
- package/dist/form/widget/providers/textArea.js +187 -196
- package/dist/form/widget/providers/textBox.js +2 -3
- package/dist/form/widget/widget.js +473 -475
- package/dist/formValidator/formValidator.js +1 -1
- package/dist/formValidator/highlighters/message.js +1 -1
- package/dist/generis/form/form.js +314 -323
- package/dist/generis/validator/validator.js +209 -218
- package/dist/generis/widget/checkBox/checkBox.js +218 -227
- package/dist/generis/widget/comboBox/comboBox.js +179 -188
- package/dist/generis/widget/hiddenBox/hiddenBox.js +220 -229
- package/dist/generis/widget/textBox/textBox.js +169 -178
- package/dist/generis/widget/widget.js +246 -255
- package/dist/groupedComboBox.js +222 -231
- package/dist/groupvalidator.js +2 -2
- package/dist/highlighter.js +967 -958
- package/dist/image/ImgStateActive/helper.js +7 -5
- package/dist/image/ImgStateActive/initHelper.js +49 -43
- package/dist/image/ImgStateActive/initMediaEditor.js +24 -20
- package/dist/image/ImgStateActive/mediaSizer.js +14 -12
- package/dist/image/ImgStateActive.js +72 -70
- package/dist/incrementer.js +6 -6
- package/dist/inplacer.js +6 -6
- package/dist/itemButtonList/css/item-button-list.css +1 -0
- package/dist/itemButtonList/css/item-button-list.css.map +1 -1
- package/dist/itemButtonList.js +439 -435
- package/dist/keyNavigation/navigableDomElement.js +51 -38
- package/dist/keyNavigation/navigator.js +85 -70
- package/dist/listbox.js +460 -469
- package/dist/liststyler.js +8 -8
- package/dist/loadingButton/loadingButton.js +209 -218
- package/dist/lock.js +476 -485
- package/dist/login/login.js +475 -484
- package/dist/maths/calculator/basicCalculator.js +235 -244
- package/dist/maths/calculator/calculatorComponent.js +3 -3
- package/dist/maths/calculator/core/board.js +772 -781
- package/dist/maths/calculator/core/expression.js +476 -485
- package/dist/maths/calculator/core/labels.js +228 -237
- package/dist/maths/calculator/core/tokenizer.js +1 -1
- package/dist/maths/calculator/core/tokens.js +163 -170
- package/dist/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +244 -253
- package/dist/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +279 -288
- package/dist/maths/calculator/scientificCalculator.js +327 -336
- package/dist/mediaEditor/mediaEditorComponent.js +238 -245
- package/dist/mediaEditor/plugins/mediaAlignment/helper.js +7 -7
- package/dist/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +229 -235
- package/dist/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +580 -589
- package/dist/mediaplayer/players/html5.js +666 -675
- package/dist/mediaplayer/players/youtube.js +419 -424
- package/dist/mediaplayer/support.js +11 -10
- package/dist/mediaplayer/utils/reminder.js +14 -13
- package/dist/mediaplayer/utils/timeObserver.js +10 -11
- package/dist/mediaplayer/youtubeManager.js +164 -145
- package/dist/mediaplayer.js +1565 -1520
- package/dist/mediasizer.js +669 -678
- package/dist/modal.js +10 -17
- package/dist/pageSizeSelector.js +219 -228
- package/dist/pagination/providers/pages.js +280 -289
- package/dist/pagination/providers/simple.js +192 -201
- package/dist/previewer.js +30 -30
- package/dist/progressbar.js +4 -4
- package/dist/report.js +347 -356
- package/dist/resource/filters.js +271 -280
- package/dist/resource/list.js +1264 -1273
- package/dist/resource/selector.js +865 -874
- package/dist/resource/tree.js +1483 -1492
- package/dist/resourcemgr/fileBrowser.js +564 -569
- package/dist/resourcemgr/filePreview.js +16 -16
- package/dist/resourcemgr/fileSelector.js +515 -524
- package/dist/resourcemgr/util/updatePermissions.js +2 -2
- package/dist/resourcemgr.js +306 -315
- package/dist/searchModal/advancedSearch.js +796 -767
- package/dist/searchModal.js +597 -549
- package/dist/switch/switch.js +298 -307
- package/dist/tabs.js +598 -575
- package/dist/taskQueue/status.js +312 -321
- package/dist/taskQueue/table.js +375 -384
- package/dist/taskQueue/taskQueueModel.js +488 -472
- package/dist/taskQueueButton/taskable.js +264 -273
- package/dist/taskQueueButton/treeButton.js +189 -198
- package/dist/themeLoader.js +24 -23
- package/dist/themes.js +1 -1
- package/dist/toggler.js +3 -3
- package/dist/tooltip.js +295 -304
- package/dist/transformer.js +2 -2
- package/dist/tristateCheckboxGroup.js +311 -320
- package/dist/uploader.js +687 -696
- package/dist/validator/Report.js +1 -1
- package/dist/validator/Validator.js +3 -3
- package/dist/validator/validators.js +9 -9
- package/dist/validator.js +240 -230
- package/dist/waitForMedia.js +1 -1
- package/package.json +3 -3
- package/scss/ckeditor/skins/tao/scss/inc/_menu.scss +51 -27
- package/scss/ckeditor/skins/tao/scss/inc/_panel.scss +16 -5
- package/scss/ckeditor/skins/tao/scss/inc/_richcombo.scss +0 -2
- package/scss/ckeditor/skins/tao/scss/inc/_toolbar.scss +15 -3
- package/src/animable/absorbable/css/absorb.css +1 -0
- package/src/animable/absorbable/css/absorb.css.map +1 -1
- package/src/autocomplete/css/autocomplete.css +1 -0
- package/src/autocomplete/css/autocomplete.css.map +1 -1
- package/src/badge/css/badge.css +1 -0
- package/src/badge/css/badge.css.map +1 -1
- package/src/ckeditor/ckConfigurator.js +24 -1
- package/src/itemButtonList/css/item-button-list.css +1 -0
- package/src/itemButtonList/css/item-button-list.css.map +1 -1
- package/scss/.DS_Store +0 -0
- package/src/.DS_Store +0 -0
|
@@ -1,359 +1,350 @@
|
|
|
1
1
|
define(['jquery', 'lodash', 'i18n', 'ui/component', 'handlebars', 'lib/dompurify/purify', 'ui/tooltip', 'css!ui/tristateCheckboxGroup/css/tristateCheckboxGroup.css'], function ($$1, _, __, component, Handlebars, DOMPurify, tooltip, tristateCheckboxGroup_css) { 'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
3
|
+
$$1 = $$1 && Object.prototype.hasOwnProperty.call($$1, 'default') ? $$1['default'] : $$1;
|
|
4
|
+
_ = _ && Object.prototype.hasOwnProperty.call(_, 'default') ? _['default'] : _;
|
|
5
|
+
__ = __ && Object.prototype.hasOwnProperty.call(__, 'default') ? __['default'] : __;
|
|
6
|
+
component = component && Object.prototype.hasOwnProperty.call(component, 'default') ? component['default'] : component;
|
|
7
|
+
Handlebars = Handlebars && Object.prototype.hasOwnProperty.call(Handlebars, 'default') ? Handlebars['default'] : Handlebars;
|
|
8
|
+
DOMPurify = DOMPurify && Object.prototype.hasOwnProperty.call(DOMPurify, 'default') ? DOMPurify['default'] : DOMPurify;
|
|
9
|
+
tooltip = tooltip && Object.prototype.hasOwnProperty.call(tooltip, 'default') ? tooltip['default'] : tooltip;
|
|
10
|
+
|
|
11
|
+
function _typeof(obj) {
|
|
12
|
+
"@babel/helpers - typeof";
|
|
13
|
+
|
|
14
|
+
return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
|
|
15
|
+
return typeof obj;
|
|
16
|
+
} : function (obj) {
|
|
17
|
+
return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
|
|
18
|
+
}, _typeof(obj);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
function Helpers0 (hb) {
|
|
22
|
+
//register a i18n helper
|
|
23
|
+
hb.registerHelper('__', function (key) {
|
|
24
|
+
return __(key);
|
|
25
|
+
});
|
|
11
26
|
/**
|
|
12
|
-
*
|
|
13
|
-
* modify it under the terms of the GNU General Public License
|
|
14
|
-
* as published by the Free Software Foundation; under version 2
|
|
15
|
-
* of the License (non-upgradable).
|
|
16
|
-
*
|
|
17
|
-
* This program is distributed in the hope that it will be useful,
|
|
18
|
-
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
19
|
-
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
20
|
-
* GNU General Public License for more details.
|
|
21
|
-
*
|
|
22
|
-
* You should have received a copy of the GNU General Public License
|
|
23
|
-
* along with this program; if not, write to the Free Software
|
|
24
|
-
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
25
|
-
*
|
|
26
|
-
* Copyright (c) 2013-2019 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
|
|
27
|
-
*
|
|
27
|
+
* Register dompurify helper
|
|
28
28
|
*
|
|
29
|
+
* https://github.com/cure53/DOMPurify
|
|
30
|
+
* with config SAFE_FOR_TEMPLATES: true
|
|
31
|
+
* to make output safe for template systems
|
|
29
32
|
*/
|
|
30
|
-
function Helpers0 (hb) {
|
|
31
|
-
//register a i18n helper
|
|
32
|
-
hb.registerHelper('__', function (key) {
|
|
33
|
-
return __(key);
|
|
34
|
-
});
|
|
35
|
-
/**
|
|
36
|
-
* Register dompurify helper
|
|
37
|
-
*
|
|
38
|
-
* https://github.com/cure53/DOMPurify
|
|
39
|
-
* with config SAFE_FOR_TEMPLATES: true
|
|
40
|
-
* to make output safe for template systems
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
hb.registerHelper('dompurify', function (context) {
|
|
44
|
-
return DOMPurify.sanitize(context);
|
|
45
|
-
});
|
|
46
|
-
/**
|
|
47
|
-
* Register join helper
|
|
48
|
-
*
|
|
49
|
-
* Example :
|
|
50
|
-
* var values = {a:v1, b:v2, c:v3};
|
|
51
|
-
* Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
|
|
52
|
-
* Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
|
|
53
|
-
*/
|
|
54
|
-
|
|
55
|
-
hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
|
|
56
|
-
var fragments = [];
|
|
57
|
-
keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
|
|
58
|
-
fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
|
|
59
|
-
wrapper = typeof wrapper === 'string' ? wrapper : '"';
|
|
60
|
-
|
|
61
|
-
_.forIn(arr, function (value, key) {
|
|
62
|
-
var fragment = '';
|
|
63
|
-
|
|
64
|
-
if (value !== null || value !== undefined) {
|
|
65
|
-
if (typeof value === 'boolean') {
|
|
66
|
-
value = value ? 'true' : 'false';
|
|
67
|
-
} else if (typeof value === 'object') {
|
|
68
|
-
value = _.values(value).join(' ');
|
|
69
|
-
}
|
|
70
|
-
} else {
|
|
71
|
-
value = '';
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
if (keyValueGlue !== undefined) {
|
|
75
|
-
fragment += key + keyValueGlue;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
fragment += wrapper + value + wrapper;
|
|
79
|
-
fragments.push(fragment);
|
|
80
|
-
});
|
|
81
33
|
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
34
|
+
hb.registerHelper('dompurify', function (context) {
|
|
35
|
+
return DOMPurify.sanitize(context);
|
|
36
|
+
});
|
|
37
|
+
/**
|
|
38
|
+
* Register join helper
|
|
39
|
+
*
|
|
40
|
+
* Example :
|
|
41
|
+
* var values = {a:v1, b:v2, c:v3};
|
|
42
|
+
* Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
|
|
43
|
+
* Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
|
|
44
|
+
*/
|
|
85
45
|
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
46
|
+
hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
|
|
47
|
+
var fragments = [];
|
|
48
|
+
keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
|
|
49
|
+
fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
|
|
50
|
+
wrapper = typeof wrapper === 'string' ? wrapper : '"';
|
|
91
51
|
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
i: i
|
|
95
|
-
}));
|
|
96
|
-
}
|
|
52
|
+
_.forIn(arr, function (value, key) {
|
|
53
|
+
var fragment = '';
|
|
97
54
|
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
55
|
+
if (value !== null || value !== undefined) {
|
|
56
|
+
if (typeof value === 'boolean') {
|
|
57
|
+
value = value ? 'true' : 'false';
|
|
58
|
+
} else if (_typeof(value) === 'object') {
|
|
59
|
+
value = _.values(value).join(' ');
|
|
60
|
+
}
|
|
103
61
|
} else {
|
|
104
|
-
|
|
62
|
+
value = '';
|
|
105
63
|
}
|
|
106
|
-
}); // register a "get property" helper
|
|
107
|
-
// it gets the named property from the provided context
|
|
108
64
|
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
}); // register an 'includes' helper
|
|
112
|
-
// it checks if value is in array
|
|
113
|
-
|
|
114
|
-
hb.registerHelper('includes', function (haystack, needle, options) {
|
|
115
|
-
if (_.contains(haystack, needle)) {
|
|
116
|
-
return options.fn(this);
|
|
65
|
+
if (keyValueGlue !== undefined) {
|
|
66
|
+
fragment += key + keyValueGlue;
|
|
117
67
|
}
|
|
68
|
+
|
|
69
|
+
fragment += wrapper + value + wrapper;
|
|
70
|
+
fragments.push(fragment);
|
|
118
71
|
});
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
if (!Helpers0.__initialized) {
|
|
122
|
-
Helpers0(Handlebars);
|
|
123
|
-
Helpers0.__initialized = true;
|
|
124
|
-
}
|
|
125
|
-
var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
|
|
126
|
-
this.compilerInfo = [4,'>= 1.0.0'];
|
|
127
|
-
helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
|
|
128
|
-
var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression;
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
buffer += "<ul class=\"tristate-checkbox-group plain\" data-serial=\"";
|
|
132
|
-
if (helper = helpers.serial) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
133
|
-
else { helper = (depth0 && depth0.serial); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
134
|
-
buffer += escapeExpression(stack1)
|
|
135
|
-
+ "\"></ul>";
|
|
136
|
-
return buffer;
|
|
137
|
-
});
|
|
138
|
-
function layoutTpl(data, options, asString) {
|
|
139
|
-
var html = Template(data, options);
|
|
140
|
-
return (asString || true) ? html : $(html);
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
if (!Helpers0.__initialized) {
|
|
144
|
-
Helpers0(Handlebars);
|
|
145
|
-
Helpers0.__initialized = true;
|
|
146
|
-
}
|
|
147
|
-
var Template$1 = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
|
|
148
|
-
this.compilerInfo = [4,'>= 1.0.0'];
|
|
149
|
-
helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
|
|
150
|
-
var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression;
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
buffer += "<li>\n <label>\n <input type=\"checkbox\" value=\"";
|
|
154
|
-
if (helper = helpers.value) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
155
|
-
else { helper = (depth0 && depth0.value); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
156
|
-
buffer += escapeExpression(stack1)
|
|
157
|
-
+ "\" name=\"tristate-checkbox-";
|
|
158
|
-
if (helper = helpers.serial) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
159
|
-
else { helper = (depth0 && depth0.serial); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
160
|
-
buffer += escapeExpression(stack1)
|
|
161
|
-
+ "\"/>\n <span class=\"icon icon-checkbox\"></span>\n <span class=\"label\">";
|
|
162
|
-
if (helper = helpers.label) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
163
|
-
else { helper = (depth0 && depth0.label); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
164
|
-
buffer += escapeExpression(stack1)
|
|
165
|
-
+ "</span>\n </label>\n</li>";
|
|
166
|
-
return buffer;
|
|
167
|
-
});
|
|
168
|
-
function elementTpl(data, options, asString) {
|
|
169
|
-
var html = Template$1(data, options);
|
|
170
|
-
return (asString || true) ? html : $(html);
|
|
171
|
-
}
|
|
172
72
|
|
|
73
|
+
return fragments.join(fragmentGlue);
|
|
74
|
+
}); //register a classic "for loop" helper
|
|
75
|
+
//it also adds a local variable "i" as the index in each iteration loop
|
|
76
|
+
|
|
77
|
+
hb.registerHelper('for', function (startIndex, stopIndex, increment, options) {
|
|
78
|
+
var ret = '';
|
|
79
|
+
startIndex = parseInt(startIndex);
|
|
80
|
+
stopIndex = parseInt(stopIndex);
|
|
81
|
+
increment = parseInt(increment);
|
|
82
|
+
|
|
83
|
+
for (var i = startIndex; i < stopIndex; i += increment) {
|
|
84
|
+
ret += options.fn(_.extend({}, this, {
|
|
85
|
+
i: i
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
return ret;
|
|
90
|
+
});
|
|
91
|
+
hb.registerHelper('equal', function (var1, var2, options) {
|
|
92
|
+
if (var1 == var2) {
|
|
93
|
+
return options.fn(this);
|
|
94
|
+
} else {
|
|
95
|
+
return options.inverse(this);
|
|
96
|
+
}
|
|
97
|
+
}); // register a "get property" helper
|
|
98
|
+
// it gets the named property from the provided context
|
|
99
|
+
|
|
100
|
+
hb.registerHelper('property', function (name, context) {
|
|
101
|
+
return context[name] || '';
|
|
102
|
+
}); // register an 'includes' helper
|
|
103
|
+
// it checks if value is in array
|
|
104
|
+
|
|
105
|
+
hb.registerHelper('includes', function (haystack, needle, options) {
|
|
106
|
+
if (_.contains(haystack, needle)) {
|
|
107
|
+
return options.fn(this);
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
if (!Helpers0.__initialized) {
|
|
113
|
+
Helpers0(Handlebars);
|
|
114
|
+
Helpers0.__initialized = true;
|
|
115
|
+
}
|
|
116
|
+
var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
|
|
117
|
+
this.compilerInfo = [4,'>= 1.0.0'];
|
|
118
|
+
helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
|
|
119
|
+
var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression;
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
buffer += "<ul class=\"tristate-checkbox-group plain\" data-serial=\"";
|
|
123
|
+
if (helper = helpers.serial) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
124
|
+
else { helper = (depth0 && depth0.serial); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
125
|
+
buffer += escapeExpression(stack1)
|
|
126
|
+
+ "\"></ul>";
|
|
127
|
+
return buffer;
|
|
128
|
+
});
|
|
129
|
+
function layoutTpl(data, options, asString) {
|
|
130
|
+
var html = Template(data, options);
|
|
131
|
+
return (asString || true) ? html : $(html);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
if (!Helpers0.__initialized) {
|
|
135
|
+
Helpers0(Handlebars);
|
|
136
|
+
Helpers0.__initialized = true;
|
|
137
|
+
}
|
|
138
|
+
var Template$1 = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
|
|
139
|
+
this.compilerInfo = [4,'>= 1.0.0'];
|
|
140
|
+
helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
|
|
141
|
+
var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression;
|
|
142
|
+
|
|
143
|
+
|
|
144
|
+
buffer += "<li>\n <label>\n <input type=\"checkbox\" value=\"";
|
|
145
|
+
if (helper = helpers.value) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
146
|
+
else { helper = (depth0 && depth0.value); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
147
|
+
buffer += escapeExpression(stack1)
|
|
148
|
+
+ "\" name=\"tristate-checkbox-";
|
|
149
|
+
if (helper = helpers.serial) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
150
|
+
else { helper = (depth0 && depth0.serial); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
151
|
+
buffer += escapeExpression(stack1)
|
|
152
|
+
+ "\"/>\n <span class=\"icon icon-checkbox\"></span>\n <span class=\"label\">";
|
|
153
|
+
if (helper = helpers.label) { stack1 = helper.call(depth0, {hash:{},data:data}); }
|
|
154
|
+
else { helper = (depth0 && depth0.label); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
|
|
155
|
+
buffer += escapeExpression(stack1)
|
|
156
|
+
+ "</span>\n </label>\n</li>";
|
|
157
|
+
return buffer;
|
|
158
|
+
});
|
|
159
|
+
function elementTpl(data, options, asString) {
|
|
160
|
+
var html = Template$1(data, options);
|
|
161
|
+
return (asString || true) ? html : $(html);
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* This program is free software; you can redistribute it and/or
|
|
166
|
+
* modify it under the terms of the GNU General Public License
|
|
167
|
+
* as published by the Free Software Foundation; under version 2
|
|
168
|
+
* of the License (non-upgradable).
|
|
169
|
+
*
|
|
170
|
+
* This program is distributed in the hope that it will be useful,
|
|
171
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
172
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
173
|
+
* GNU General Public License for more details.
|
|
174
|
+
*
|
|
175
|
+
* You should have received a copy of the GNU General Public License
|
|
176
|
+
* along with this program; if not, write to the Free Software
|
|
177
|
+
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
178
|
+
*
|
|
179
|
+
* Copyright (c) 2016 (original work) Open Assessment Technologies SA ;
|
|
180
|
+
*/
|
|
181
|
+
/**
|
|
182
|
+
* Defines tristate checkboxes methods
|
|
183
|
+
* @type {Object}
|
|
184
|
+
*/
|
|
185
|
+
|
|
186
|
+
var tristateCheckboxGroup = {
|
|
173
187
|
/**
|
|
174
|
-
*
|
|
175
|
-
* modify it under the terms of the GNU General Public License
|
|
176
|
-
* as published by the Free Software Foundation; under version 2
|
|
177
|
-
* of the License (non-upgradable).
|
|
178
|
-
*
|
|
179
|
-
* This program is distributed in the hope that it will be useful,
|
|
180
|
-
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
181
|
-
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
182
|
-
* GNU General Public License for more details.
|
|
183
|
-
*
|
|
184
|
-
* You should have received a copy of the GNU General Public License
|
|
185
|
-
* along with this program; if not, write to the Free Software
|
|
186
|
-
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
188
|
+
* Get the value of tristateCheckboxGroup
|
|
187
189
|
*
|
|
188
|
-
*
|
|
190
|
+
* @returns {Object}
|
|
191
|
+
* {array} values.checked - checkbox in checked state
|
|
192
|
+
* {array} values.indeterminate - checkbox in intermediate state
|
|
189
193
|
*/
|
|
194
|
+
getValues: function getValues() {
|
|
195
|
+
var values = {
|
|
196
|
+
checked: [],
|
|
197
|
+
indeterminate: []
|
|
198
|
+
};
|
|
199
|
+
var $list = this.getElement();
|
|
200
|
+
$list.find('input:checked').each(function () {
|
|
201
|
+
values.checked.push($$1(this).val());
|
|
202
|
+
});
|
|
203
|
+
$list.find('input:indeterminate').each(function () {
|
|
204
|
+
values.indeterminate.push($$1(this).val());
|
|
205
|
+
});
|
|
206
|
+
return values;
|
|
207
|
+
},
|
|
208
|
+
|
|
190
209
|
/**
|
|
191
|
-
*
|
|
192
|
-
*
|
|
210
|
+
* Set the checked/indeterminate state of the tristateCheckboxGroup
|
|
211
|
+
*
|
|
212
|
+
* @param {Object} values
|
|
213
|
+
* @param {array} [values.checked] - checkbox in checked state
|
|
214
|
+
* @param {array} [values.indeterminate] - checkbox in intermediate state
|
|
215
|
+
* @returns {tristateCheckboxGroup}
|
|
193
216
|
*/
|
|
217
|
+
setValues: function setValues(values) {
|
|
218
|
+
var $list = this.getElement();
|
|
219
|
+
$list.find('input').prop('checked', false).prop('indeterminate', false); //priority to checked values
|
|
194
220
|
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
*
|
|
199
|
-
* @returns {Object}
|
|
200
|
-
* {array} values.checked - checkbox in checked state
|
|
201
|
-
* {array} values.indeterminate - checkbox in intermediate state
|
|
202
|
-
*/
|
|
203
|
-
getValues: function getValues() {
|
|
204
|
-
var values = {
|
|
205
|
-
checked: [],
|
|
206
|
-
indeterminate: []
|
|
207
|
-
};
|
|
208
|
-
var $list = this.getElement();
|
|
209
|
-
$list.find('input:checked').each(function () {
|
|
210
|
-
values.checked.push($$1(this).val());
|
|
221
|
+
if (_.isArray(values.checked)) {
|
|
222
|
+
_.each(values.checked, function (v) {
|
|
223
|
+
$list.find('input[value="' + v + '"]').prop('checked', true);
|
|
211
224
|
});
|
|
212
|
-
|
|
213
|
-
|
|
225
|
+
}
|
|
226
|
+
|
|
227
|
+
if (_.isArray(values.indeterminate)) {
|
|
228
|
+
_.each(values.indeterminate, function (v) {
|
|
229
|
+
$list.find('input[value="' + v + '"]:not(:checked)').prop('indeterminate', true);
|
|
214
230
|
});
|
|
215
|
-
|
|
216
|
-
},
|
|
217
|
-
|
|
218
|
-
/**
|
|
219
|
-
* Set the checked/indeterminate state of the tristateCheckboxGroup
|
|
220
|
-
*
|
|
221
|
-
* @param {Object} values
|
|
222
|
-
* @param {array} [values.checked] - checkbox in checked state
|
|
223
|
-
* @param {array} [values.indeterminate] - checkbox in intermediate state
|
|
224
|
-
* @returns {tristateCheckboxGroup}
|
|
225
|
-
*/
|
|
226
|
-
setValues: function setValues(values) {
|
|
227
|
-
var $list = this.getElement();
|
|
228
|
-
$list.find('input').prop('checked', false).prop('indeterminate', false); //priority to checked values
|
|
229
|
-
|
|
230
|
-
if (_.isArray(values.checked)) {
|
|
231
|
-
_.each(values.checked, function (v) {
|
|
232
|
-
$list.find('input[value="' + v + '"]').prop('checked', true);
|
|
233
|
-
});
|
|
234
|
-
}
|
|
231
|
+
}
|
|
235
232
|
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
$list.find('input[value="' + v + '"]:not(:checked)').prop('indeterminate', true);
|
|
239
|
-
});
|
|
240
|
-
}
|
|
233
|
+
return this;
|
|
234
|
+
},
|
|
241
235
|
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
//if already exists, check if label needs to be updated
|
|
271
|
-
$cbox.siblings('.label').text(data.label);
|
|
272
|
-
}
|
|
236
|
+
/**
|
|
237
|
+
* Set checkbox elements
|
|
238
|
+
* The given checkbox element "value" is used as a key.
|
|
239
|
+
* If the key already exists, the existing checkbox element will updated.
|
|
240
|
+
* If not, a new checkbox element will be created and appended to the list.
|
|
241
|
+
*
|
|
242
|
+
* @param {Array} elements
|
|
243
|
+
* @returns {tristateCheckboxGroup}
|
|
244
|
+
*/
|
|
245
|
+
setElements: function setElements(elements) {
|
|
246
|
+
var $list = this.getElement();
|
|
247
|
+
var self = this;
|
|
248
|
+
var $cbox;
|
|
249
|
+
|
|
250
|
+
_.each(elements, function (data) {
|
|
251
|
+
if (data) {
|
|
252
|
+
//try to find if the value is already set
|
|
253
|
+
$cbox = $list.find('input[value="' + data.value + '"]');
|
|
254
|
+
|
|
255
|
+
if (!$cbox.length) {
|
|
256
|
+
//does not exist, create one
|
|
257
|
+
data.serial = self.config.serial;
|
|
258
|
+
$cbox = $$1(elementTpl(data)).appendTo($list).find('input');
|
|
259
|
+
} else {
|
|
260
|
+
if (data.label) {
|
|
261
|
+
//if already exists, check if label needs to be updated
|
|
262
|
+
$cbox.siblings('.label').text(data.label);
|
|
263
|
+
}
|
|
273
264
|
|
|
274
|
-
|
|
275
|
-
|
|
265
|
+
$cbox.find('input').prop('checked', false).prop('indeterminate', false);
|
|
266
|
+
} //finally, set the checked or indeterminate properties
|
|
276
267
|
|
|
277
268
|
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
}
|
|
269
|
+
if (data.checked) {
|
|
270
|
+
$cbox.prop('checked', true);
|
|
271
|
+
} else if (data.indeterminate) {
|
|
272
|
+
$cbox.prop('indeterminate', true);
|
|
283
273
|
}
|
|
284
|
-
}
|
|
274
|
+
}
|
|
275
|
+
});
|
|
285
276
|
|
|
286
|
-
|
|
287
|
-
|
|
277
|
+
return this;
|
|
278
|
+
},
|
|
288
279
|
|
|
289
|
-
/**
|
|
290
|
-
* tooltip instance integrated in checkbox group
|
|
291
|
-
* will be defined with initialization
|
|
292
|
-
*/
|
|
293
|
-
tooltip: null
|
|
294
|
-
};
|
|
295
280
|
/**
|
|
296
|
-
*
|
|
297
|
-
*
|
|
298
|
-
* @param {Object} config
|
|
299
|
-
* @param {jQuery|HTMLElement|String} [config.renderTo] - An optional container in which renders the component
|
|
300
|
-
* @param {Boolean} [config.replace] - When the component is appended to its container, clears the place before
|
|
301
|
-
* @param {String} [config.serial] - The unique string to uniquely identify the checkbox group
|
|
302
|
-
* @param {Array} [config.list] - Default list of checkbox element to be rendered
|
|
303
|
-
* @param {String} [config.list[].value] - the value (used as key) of the checkbox element
|
|
304
|
-
* @param {String} [config.list[].label] - the label of the checkbox element
|
|
305
|
-
* @param {Boolean} [config.list[].checked] - the checkbox element is initial checked or not
|
|
306
|
-
* @param {Boolean} [config.list[].indeterminate] - the checkbox element is initial indeterminate or not
|
|
307
|
-
* @param {String} [config.serial] - the unique string to uniquely identify the checkbox group
|
|
308
|
-
* @param {String} [config.maxSelection] - the maximum number of selectable checkboxes
|
|
309
|
-
* @param {String} [config.maxMessage] - the message that will be displayed in the tooltip if the maxSelection is reached
|
|
310
|
-
* @returns {listBox}
|
|
281
|
+
* tooltip instance integrated in checkbox group
|
|
282
|
+
* will be defined with initialization
|
|
311
283
|
*/
|
|
284
|
+
tooltip: null
|
|
285
|
+
};
|
|
286
|
+
/**
|
|
287
|
+
* Builds an instance of tristateCheckboxGroup
|
|
288
|
+
*
|
|
289
|
+
* @param {Object} config
|
|
290
|
+
* @param {jQuery|HTMLElement|String} [config.renderTo] - An optional container in which renders the component
|
|
291
|
+
* @param {Boolean} [config.replace] - When the component is appended to its container, clears the place before
|
|
292
|
+
* @param {String} [config.serial] - The unique string to uniquely identify the checkbox group
|
|
293
|
+
* @param {Array} [config.list] - Default list of checkbox element to be rendered
|
|
294
|
+
* @param {String} [config.list[].value] - the value (used as key) of the checkbox element
|
|
295
|
+
* @param {String} [config.list[].label] - the label of the checkbox element
|
|
296
|
+
* @param {Boolean} [config.list[].checked] - the checkbox element is initial checked or not
|
|
297
|
+
* @param {Boolean} [config.list[].indeterminate] - the checkbox element is initial indeterminate or not
|
|
298
|
+
* @param {String} [config.serial] - the unique string to uniquely identify the checkbox group
|
|
299
|
+
* @param {String} [config.maxSelection] - the maximum number of selectable checkboxes
|
|
300
|
+
* @param {String} [config.maxMessage] - the message that will be displayed in the tooltip if the maxSelection is reached
|
|
301
|
+
* @returns {listBox}
|
|
302
|
+
*/
|
|
303
|
+
|
|
304
|
+
function tristateCheckboxGroupFactory(config) {
|
|
305
|
+
config = _.defaults(config || {}, {
|
|
306
|
+
serial: _.uniqueId('tscb'),
|
|
307
|
+
list: [],
|
|
308
|
+
maxSelection: 0,
|
|
309
|
+
maxMessage: __('Maximum selection reached')
|
|
310
|
+
});
|
|
311
|
+
return component(tristateCheckboxGroup).setTemplate(layoutTpl).on('render', function () {
|
|
312
|
+
var self = this;
|
|
313
|
+
var $list = this.getElement();
|
|
314
|
+
$list.on('change', function (e) {
|
|
315
|
+
var $input;
|
|
316
|
+
var $icon;
|
|
317
|
+
var maxSelection = self.config.maxSelection;
|
|
318
|
+
|
|
319
|
+
if (maxSelection && $list.find('input:checked,input:indeterminate').length > maxSelection) {
|
|
320
|
+
$input = $$1(e.target);
|
|
321
|
+
|
|
322
|
+
if ($input.is(':checked')) {
|
|
323
|
+
$icon = $input.siblings('.icon').addClass('cross').each(function () {
|
|
324
|
+
self.tooltip = tooltip.warning(this, self.config.maxMessage);
|
|
325
|
+
self.tooltip.show();
|
|
326
|
+
});
|
|
327
|
+
$icon.parent('label').on('mouseleave', function () {
|
|
328
|
+
if (self.tooltip) {
|
|
329
|
+
self.tooltip.dispose();
|
|
330
|
+
}
|
|
331
|
+
}); //visually highlight the invalid new choice
|
|
312
332
|
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
maxSelection: 0,
|
|
318
|
-
maxMessage: __('Maximum selection reached')
|
|
319
|
-
});
|
|
320
|
-
return component(tristateCheckboxGroup).setTemplate(layoutTpl).on('render', function () {
|
|
321
|
-
var self = this;
|
|
322
|
-
var $list = this.getElement();
|
|
323
|
-
$list.on('change', function (e) {
|
|
324
|
-
var $input;
|
|
325
|
-
var $icon;
|
|
326
|
-
var maxSelection = self.config.maxSelection;
|
|
327
|
-
|
|
328
|
-
if (maxSelection && $list.find('input:checked,input:indeterminate').length > maxSelection) {
|
|
329
|
-
$input = $$1(e.target);
|
|
330
|
-
|
|
331
|
-
if ($input.is(':checked')) {
|
|
332
|
-
$icon = $input.siblings('.icon').addClass('cross').each(function () {
|
|
333
|
-
self.tooltip = tooltip.warning(this, self.config.maxMessage);
|
|
334
|
-
self.tooltip.show();
|
|
335
|
-
});
|
|
336
|
-
$icon.parent('label').on('mouseleave', function () {
|
|
337
|
-
if (self.tooltip) {
|
|
338
|
-
self.tooltip.dispose();
|
|
339
|
-
}
|
|
340
|
-
}); //visually highlight the invalid new choice
|
|
341
|
-
|
|
342
|
-
_.delay(function () {
|
|
343
|
-
$input.prop('checked', false);
|
|
344
|
-
$icon.removeClass('cross');
|
|
345
|
-
}, 150);
|
|
346
|
-
}
|
|
347
|
-
|
|
348
|
-
return;
|
|
333
|
+
_.delay(function () {
|
|
334
|
+
$input.prop('checked', false);
|
|
335
|
+
$icon.removeClass('cross');
|
|
336
|
+
}, 150);
|
|
349
337
|
}
|
|
350
338
|
|
|
351
|
-
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
339
|
+
return;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
self.trigger('change', self.getValues());
|
|
343
|
+
});
|
|
344
|
+
this.setElements(this.config.list);
|
|
345
|
+
}).init(config);
|
|
346
|
+
}
|
|
356
347
|
|
|
357
|
-
|
|
348
|
+
return tristateCheckboxGroupFactory;
|
|
358
349
|
|
|
359
350
|
});
|