@oat-sa/tao-core-ui 1.58.1 → 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.
Files changed (233) hide show
  1. package/dist/actionbar.js +386 -395
  2. package/dist/adder.js +21 -19
  3. package/dist/animable/absorbable/absorbable.js +204 -213
  4. package/dist/animable/absorbable/css/absorb.css +1 -0
  5. package/dist/animable/absorbable/css/absorb.css.map +1 -1
  6. package/dist/animable/pulsable/pulsable.js +168 -177
  7. package/dist/autocomplete/css/autocomplete.css +1 -0
  8. package/dist/autocomplete/css/autocomplete.css.map +1 -1
  9. package/dist/autocomplete.js +68 -66
  10. package/dist/badge/badge.js +188 -197
  11. package/dist/badge/css/badge.css +1 -0
  12. package/dist/badge/css/badge.css.map +1 -1
  13. package/dist/breadcrumbs.js +275 -284
  14. package/dist/btngrouper.js +5 -5
  15. package/dist/bulkActionPopup.js +490 -495
  16. package/dist/button.js +283 -291
  17. package/dist/cascadingComboBox.js +249 -258
  18. package/dist/ckeditor/ckConfigurator.js +26 -19
  19. package/dist/ckeditor/dtdHandler.js +11 -9
  20. package/dist/class/selector.js +441 -450
  21. package/dist/component/resizable.js +1 -1
  22. package/dist/component/windowed.js +285 -294
  23. package/dist/component.js +419 -428
  24. package/dist/contextualPopup.js +417 -426
  25. package/dist/dashboard.js +300 -309
  26. package/dist/datalist.js +753 -762
  27. package/dist/datatable/filterStrategy/multiple.js +1 -1
  28. package/dist/datatable/filterStrategy/single.js +1 -1
  29. package/dist/datatable.js +1527 -1550
  30. package/dist/dateRange/dateRange.js +393 -402
  31. package/dist/datetime/picker.js +665 -672
  32. package/dist/deleter.js +368 -377
  33. package/dist/destination/selector.js +286 -295
  34. package/dist/dialog/alert.js +3 -3
  35. package/dist/dialog/confirm.js +1 -1
  36. package/dist/dialog/confirmDelete.js +216 -225
  37. package/dist/dialog.js +650 -654
  38. package/dist/disabler.js +8 -8
  39. package/dist/documentViewer/providers/pdfViewer/fallback/viewer.js +166 -175
  40. package/dist/documentViewer/providers/pdfViewer/pdfjs/findBar.js +518 -527
  41. package/dist/documentViewer/providers/pdfViewer/pdfjs/pageView.js +380 -389
  42. package/dist/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +539 -548
  43. package/dist/documentViewer/providers/pdfViewer/pdfjs/viewer.js +369 -378
  44. package/dist/documentViewer/providers/pdfViewer.js +184 -193
  45. package/dist/documentViewer.js +292 -301
  46. package/dist/dropdown.js +383 -392
  47. package/dist/durationer.js +5 -5
  48. package/dist/dynamicComponent.js +597 -598
  49. package/dist/feedback.js +356 -362
  50. package/dist/figure/FigureStateActive.js +117 -108
  51. package/dist/filesender.js +2 -2
  52. package/dist/filter.js +230 -239
  53. package/dist/form/dropdownForm.js +355 -357
  54. package/dist/form/form.js +919 -690
  55. package/dist/form/simpleForm.js +1 -1
  56. package/dist/form/validator/renderer.js +233 -235
  57. package/dist/form/validator/validator.js +257 -189
  58. package/dist/form/widget/definitions.js +1 -1
  59. package/dist/form/widget/providers/checkBox.js +254 -259
  60. package/dist/form/widget/providers/comboBox.js +187 -192
  61. package/dist/form/widget/providers/default.js +8 -9
  62. package/dist/form/widget/providers/hidden.js +170 -179
  63. package/dist/form/widget/providers/hiddenBox.js +262 -267
  64. package/dist/form/widget/providers/radioBox.js +216 -225
  65. package/dist/form/widget/providers/textArea.js +187 -196
  66. package/dist/form/widget/providers/textBox.js +2 -3
  67. package/dist/form/widget/widget.js +473 -475
  68. package/dist/formValidator/formValidator.js +1 -1
  69. package/dist/formValidator/highlighters/message.js +1 -1
  70. package/dist/generis/form/form.js +314 -323
  71. package/dist/generis/validator/validator.js +209 -218
  72. package/dist/generis/widget/checkBox/checkBox.js +218 -227
  73. package/dist/generis/widget/comboBox/comboBox.js +179 -188
  74. package/dist/generis/widget/hiddenBox/hiddenBox.js +220 -229
  75. package/dist/generis/widget/textBox/textBox.js +169 -178
  76. package/dist/generis/widget/widget.js +246 -255
  77. package/dist/groupedComboBox.js +222 -231
  78. package/dist/groupvalidator.js +2 -2
  79. package/dist/highlighter.js +967 -958
  80. package/dist/image/ImgStateActive/helper.js +7 -5
  81. package/dist/image/ImgStateActive/initHelper.js +49 -43
  82. package/dist/image/ImgStateActive/initMediaEditor.js +24 -20
  83. package/dist/image/ImgStateActive/mediaSizer.js +14 -12
  84. package/dist/image/ImgStateActive.js +72 -70
  85. package/dist/incrementer.js +6 -6
  86. package/dist/inplacer.js +6 -6
  87. package/dist/itemButtonList/css/item-button-list.css +1 -0
  88. package/dist/itemButtonList/css/item-button-list.css.map +1 -1
  89. package/dist/itemButtonList.js +439 -435
  90. package/dist/keyNavigation/navigableDomElement.js +51 -38
  91. package/dist/keyNavigation/navigator.js +85 -70
  92. package/dist/listbox.js +460 -469
  93. package/dist/liststyler.js +8 -8
  94. package/dist/loadingButton/loadingButton.js +209 -218
  95. package/dist/lock.js +476 -485
  96. package/dist/login/login.js +475 -484
  97. package/dist/maths/calculator/basicCalculator.js +235 -244
  98. package/dist/maths/calculator/calculatorComponent.js +3 -3
  99. package/dist/maths/calculator/core/board.js +772 -781
  100. package/dist/maths/calculator/core/expression.js +476 -485
  101. package/dist/maths/calculator/core/labels.js +228 -237
  102. package/dist/maths/calculator/core/tokenizer.js +1 -1
  103. package/dist/maths/calculator/core/tokens.js +163 -170
  104. package/dist/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +244 -253
  105. package/dist/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +279 -288
  106. package/dist/maths/calculator/scientificCalculator.js +327 -336
  107. package/dist/mediaEditor/mediaEditorComponent.js +238 -245
  108. package/dist/mediaEditor/plugins/mediaAlignment/helper.js +7 -7
  109. package/dist/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +229 -235
  110. package/dist/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +580 -589
  111. package/dist/mediaplayer/players/html5.js +666 -675
  112. package/dist/mediaplayer/players/youtube.js +419 -424
  113. package/dist/mediaplayer/support.js +11 -10
  114. package/dist/mediaplayer/utils/reminder.js +14 -13
  115. package/dist/mediaplayer/utils/timeObserver.js +10 -11
  116. package/dist/mediaplayer/youtubeManager.js +164 -145
  117. package/dist/mediaplayer.js +1565 -1520
  118. package/dist/mediasizer.js +669 -678
  119. package/dist/modal.js +10 -17
  120. package/dist/pageSizeSelector.js +219 -228
  121. package/dist/pagination/providers/pages.js +280 -289
  122. package/dist/pagination/providers/simple.js +192 -201
  123. package/dist/previewer.js +30 -30
  124. package/dist/progressbar.js +4 -4
  125. package/dist/report.js +347 -356
  126. package/dist/resource/filters.js +271 -280
  127. package/dist/resource/list.js +1264 -1273
  128. package/dist/resource/selector.js +865 -874
  129. package/dist/resource/tree.js +1483 -1492
  130. package/dist/resourcemgr/fileBrowser.js +564 -569
  131. package/dist/resourcemgr/filePreview.js +16 -16
  132. package/dist/resourcemgr/fileSelector.js +515 -524
  133. package/dist/resourcemgr/util/updatePermissions.js +2 -2
  134. package/dist/resourcemgr.js +306 -315
  135. package/dist/searchModal/advancedSearch.js +796 -767
  136. package/dist/searchModal.js +114 -91
  137. package/dist/switch/switch.js +298 -307
  138. package/dist/tabs.js +598 -575
  139. package/dist/taskQueue/status.js +312 -321
  140. package/dist/taskQueue/table.js +375 -384
  141. package/dist/taskQueue/taskQueueModel.js +488 -472
  142. package/dist/taskQueueButton/taskable.js +264 -273
  143. package/dist/taskQueueButton/treeButton.js +189 -198
  144. package/dist/themeLoader.js +24 -23
  145. package/dist/themes.js +1 -1
  146. package/dist/toggler.js +3 -3
  147. package/dist/tooltip.js +295 -304
  148. package/dist/transformer.js +2 -2
  149. package/dist/tristateCheckboxGroup.js +311 -320
  150. package/dist/uploader.js +687 -696
  151. package/dist/validator/Report.js +1 -1
  152. package/dist/validator/Validator.js +3 -3
  153. package/dist/validator/validators.js +9 -9
  154. package/dist/validator.js +240 -230
  155. package/dist/waitForMedia.js +1 -1
  156. package/package.json +3 -3
  157. package/src/animable/absorbable/css/absorb.css +1 -0
  158. package/src/animable/absorbable/css/absorb.css.map +1 -1
  159. package/src/autocomplete/css/autocomplete.css +1 -0
  160. package/src/autocomplete/css/autocomplete.css.map +1 -1
  161. package/src/badge/css/badge.css +1 -0
  162. package/src/badge/css/badge.css.map +1 -1
  163. package/src/ckeditor/ckConfigurator.js +4 -0
  164. package/src/itemButtonList/css/item-button-list.css +1 -0
  165. package/src/itemButtonList/css/item-button-list.css.map +1 -1
  166. package/src/.DS_Store +0 -0
  167. package/src/css/basic.css +0 -7826
  168. package/src/css/basic.css.map +0 -1
  169. package/src/css/ckeditor/skins/tao/css/dialog.css +0 -950
  170. package/src/css/ckeditor/skins/tao/css/dialog.css.map +0 -1
  171. package/src/css/ckeditor/skins/tao/css/editor.css +0 -1850
  172. package/src/css/ckeditor/skins/tao/css/editor.css.map +0 -1
  173. package/src/scss/.DS_Store +0 -0
  174. package/src/scss/basic.scss +0 -16
  175. package/src/scss/ckeditor/skins/tao/scss/dialog.scss +0 -763
  176. package/src/scss/ckeditor/skins/tao/scss/editor.scss +0 -111
  177. package/src/scss/ckeditor/skins/tao/scss/inc/_ck-icons.scss +0 -59
  178. package/src/scss/ckeditor/skins/tao/scss/inc/_colorpanel.scss +0 -118
  179. package/src/scss/ckeditor/skins/tao/scss/inc/_elementspath.scss +0 -69
  180. package/src/scss/ckeditor/skins/tao/scss/inc/_mainui.scss +0 -194
  181. package/src/scss/ckeditor/skins/tao/scss/inc/_menu.scss +0 -181
  182. package/src/scss/ckeditor/skins/tao/scss/inc/_panel.scss +0 -200
  183. package/src/scss/ckeditor/skins/tao/scss/inc/_presets.scss +0 -32
  184. package/src/scss/ckeditor/skins/tao/scss/inc/_reset.scss +0 -101
  185. package/src/scss/ckeditor/skins/tao/scss/inc/_richcombo.scss +0 -213
  186. package/src/scss/ckeditor/skins/tao/scss/inc/_tao.scss +0 -59
  187. package/src/scss/ckeditor/skins/tao/scss/inc/_toolbar.scss +0 -301
  188. package/src/scss/font/source-sans-pro/source-sans-pro-italic.eot +0 -0
  189. package/src/scss/font/source-sans-pro/source-sans-pro-italic.eot.b64 +0 -1
  190. package/src/scss/font/source-sans-pro/source-sans-pro-italic.woff +0 -0
  191. package/src/scss/font/source-sans-pro/source-sans-pro-italic.woff.b64 +0 -1
  192. package/src/scss/font/source-sans-pro/source-sans-pro-regular.eot +0 -0
  193. package/src/scss/font/source-sans-pro/source-sans-pro-regular.eot.b64 +0 -1
  194. package/src/scss/font/source-sans-pro/source-sans-pro-regular.woff +0 -0
  195. package/src/scss/font/source-sans-pro/source-sans-pro-regular.woff.b64 +0 -1
  196. package/src/scss/font/source-sans-pro/source-sans-pro-semibold-italic.eot +0 -0
  197. package/src/scss/font/source-sans-pro/source-sans-pro-semibold-italic.eot.b64 +0 -1
  198. package/src/scss/font/source-sans-pro/source-sans-pro-semibold-italic.woff +0 -0
  199. package/src/scss/font/source-sans-pro/source-sans-pro-semibold-italic.woff.b64 +0 -1
  200. package/src/scss/font/source-sans-pro/source-sans-pro-semibold.eot +0 -0
  201. package/src/scss/font/source-sans-pro/source-sans-pro-semibold.eot.b64 +0 -1
  202. package/src/scss/font/source-sans-pro/source-sans-pro-semibold.woff +0 -0
  203. package/src/scss/font/source-sans-pro/source-sans-pro-semibold.woff.b64 +0 -1
  204. package/src/scss/font/tao/tao.eot +0 -0
  205. package/src/scss/font/tao/tao.svg +0 -235
  206. package/src/scss/font/tao/tao.ttf +0 -0
  207. package/src/scss/font/tao/tao.woff +0 -0
  208. package/src/scss/inc/_base.scss +0 -496
  209. package/src/scss/inc/_bootstrap.scss +0 -6
  210. package/src/scss/inc/_buttons.scss +0 -114
  211. package/src/scss/inc/_colors.scss +0 -88
  212. package/src/scss/inc/_feedback.scss +0 -150
  213. package/src/scss/inc/_flex-grid.scss +0 -15
  214. package/src/scss/inc/_fonts.scss +0 -4
  215. package/src/scss/inc/_forms.scss +0 -827
  216. package/src/scss/inc/_functions.scss +0 -283
  217. package/src/scss/inc/_grid.scss +0 -66
  218. package/src/scss/inc/_jquery.nouislider.scss +0 -254
  219. package/src/scss/inc/_normalize.scss +0 -528
  220. package/src/scss/inc/_report.scss +0 -68
  221. package/src/scss/inc/_secondary-properties.scss +0 -89
  222. package/src/scss/inc/_select2.scss +0 -634
  223. package/src/scss/inc/_toolbars.scss +0 -155
  224. package/src/scss/inc/_tooltip.scss +0 -312
  225. package/src/scss/inc/_variables.scss +0 -21
  226. package/src/scss/inc/base/_highlight.scss +0 -5
  227. package/src/scss/inc/base/_list-style.scss +0 -59
  228. package/src/scss/inc/base/_svg.scss +0 -3
  229. package/src/scss/inc/base/_table.scss +0 -63
  230. package/src/scss/inc/fonts/_source-sans-pro.scss +0 -29
  231. package/src/scss/inc/fonts/_tao-icon-classes.scss +0 -226
  232. package/src/scss/inc/fonts/_tao-icon-def.scss +0 -12
  233. package/src/scss/inc/fonts/_tao-icon-vars.scss +0 -240
package/dist/dropdown.js CHANGED
@@ -1,452 +1,443 @@
1
1
  define(['jquery', 'lodash', 'ui/component', 'handlebars', 'i18n', 'lib/dompurify/purify', 'css!ui/dropdown/css/dropdown.css'], function ($$1, _, component, Handlebars, __, DOMPurify, dropdown_css) { 'use strict';
2
2
 
3
- $$1 = $$1 && Object.prototype.hasOwnProperty.call($$1, 'default') ? $$1['default'] : $$1;
4
- _ = _ && Object.prototype.hasOwnProperty.call(_, 'default') ? _['default'] : _;
5
- component = component && Object.prototype.hasOwnProperty.call(component, 'default') ? component['default'] : component;
6
- Handlebars = Handlebars && Object.prototype.hasOwnProperty.call(Handlebars, 'default') ? Handlebars['default'] : Handlebars;
7
- __ = __ && Object.prototype.hasOwnProperty.call(__, 'default') ? __['default'] : __;
8
- DOMPurify = DOMPurify && Object.prototype.hasOwnProperty.call(DOMPurify, 'default') ? DOMPurify['default'] : DOMPurify;
9
-
3
+ $$1 = $$1 && Object.prototype.hasOwnProperty.call($$1, 'default') ? $$1['default'] : $$1;
4
+ _ = _ && Object.prototype.hasOwnProperty.call(_, 'default') ? _['default'] : _;
5
+ component = component && Object.prototype.hasOwnProperty.call(component, 'default') ? component['default'] : component;
6
+ Handlebars = Handlebars && Object.prototype.hasOwnProperty.call(Handlebars, 'default') ? Handlebars['default'] : Handlebars;
7
+ __ = __ && Object.prototype.hasOwnProperty.call(__, 'default') ? __['default'] : __;
8
+ DOMPurify = DOMPurify && Object.prototype.hasOwnProperty.call(DOMPurify, 'default') ? DOMPurify['default'] : DOMPurify;
9
+
10
+ function _typeof(obj) {
11
+ "@babel/helpers - typeof";
12
+
13
+ return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
14
+ return typeof obj;
15
+ } : function (obj) {
16
+ return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
17
+ }, _typeof(obj);
18
+ }
19
+
20
+ function Helpers0 (hb) {
21
+ //register a i18n helper
22
+ hb.registerHelper('__', function (key) {
23
+ return __(key);
24
+ });
10
25
  /**
11
- * This program is free software; you can redistribute it and/or
12
- * modify it under the terms of the GNU General Public License
13
- * as published by the Free Software Foundation; under version 2
14
- * of the License (non-upgradable).
15
- *
16
- * This program is distributed in the hope that it will be useful,
17
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19
- * GNU General Public License for more details.
20
- *
21
- * You should have received a copy of the GNU General Public License
22
- * along with this program; if not, write to the Free Software
23
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
24
- *
25
- * Copyright (c) 2013-2019 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
26
+ * Register dompurify helper
26
27
  *
28
+ * https://github.com/cure53/DOMPurify
29
+ * with config SAFE_FOR_TEMPLATES: true
30
+ * to make output safe for template systems
31
+ */
32
+
33
+ hb.registerHelper('dompurify', function (context) {
34
+ return DOMPurify.sanitize(context);
35
+ });
36
+ /**
37
+ * Register join helper
27
38
  *
39
+ * Example :
40
+ * var values = {a:v1, b:v2, c:v3};
41
+ * Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
42
+ * Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
28
43
  */
29
- function Helpers0 (hb) {
30
- //register a i18n helper
31
- hb.registerHelper('__', function (key) {
32
- return __(key);
33
- });
34
- /**
35
- * Register dompurify helper
36
- *
37
- * https://github.com/cure53/DOMPurify
38
- * with config SAFE_FOR_TEMPLATES: true
39
- * to make output safe for template systems
40
- */
41
44
 
42
- hb.registerHelper('dompurify', function (context) {
43
- return DOMPurify.sanitize(context);
44
- });
45
- /**
46
- * Register join helper
47
- *
48
- * Example :
49
- * var values = {a:v1, b:v2, c:v3};
50
- * Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
51
- * Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
52
- */
45
+ hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
46
+ var fragments = [];
47
+ keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
48
+ fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
49
+ wrapper = typeof wrapper === 'string' ? wrapper : '"';
53
50
 
54
- hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
55
- var fragments = [];
56
- keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
57
- fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
58
- wrapper = typeof wrapper === 'string' ? wrapper : '"';
59
-
60
- _.forIn(arr, function (value, key) {
61
- var fragment = '';
62
-
63
- if (value !== null || value !== undefined) {
64
- if (typeof value === 'boolean') {
65
- value = value ? 'true' : 'false';
66
- } else if (typeof value === 'object') {
67
- value = _.values(value).join(' ');
68
- }
69
- } else {
70
- value = '';
71
- }
51
+ _.forIn(arr, function (value, key) {
52
+ var fragment = '';
72
53
 
73
- if (keyValueGlue !== undefined) {
74
- fragment += key + keyValueGlue;
54
+ if (value !== null || value !== undefined) {
55
+ if (typeof value === 'boolean') {
56
+ value = value ? 'true' : 'false';
57
+ } else if (_typeof(value) === 'object') {
58
+ value = _.values(value).join(' ');
75
59
  }
76
-
77
- fragment += wrapper + value + wrapper;
78
- fragments.push(fragment);
79
- });
80
-
81
- return fragments.join(fragmentGlue);
82
- }); //register a classic "for loop" helper
83
- //it also adds a local variable "i" as the index in each iteration loop
84
-
85
- hb.registerHelper('for', function (startIndex, stopIndex, increment, options) {
86
- var ret = '';
87
- startIndex = parseInt(startIndex);
88
- stopIndex = parseInt(stopIndex);
89
- increment = parseInt(increment);
90
-
91
- for (var i = startIndex; i < stopIndex; i += increment) {
92
- ret += options.fn(_.extend({}, this, {
93
- i: i
94
- }));
95
- }
96
-
97
- return ret;
98
- });
99
- hb.registerHelper('equal', function (var1, var2, options) {
100
- if (var1 == var2) {
101
- return options.fn(this);
102
60
  } else {
103
- return options.inverse(this);
61
+ value = '';
104
62
  }
105
- }); // register a "get property" helper
106
- // it gets the named property from the provided context
107
-
108
- hb.registerHelper('property', function (name, context) {
109
- return context[name] || '';
110
- }); // register an 'includes' helper
111
- // it checks if value is in array
112
63
 
113
- hb.registerHelper('includes', function (haystack, needle, options) {
114
- if (_.contains(haystack, needle)) {
115
- return options.fn(this);
64
+ if (keyValueGlue !== undefined) {
65
+ fragment += key + keyValueGlue;
116
66
  }
67
+
68
+ fragment += wrapper + value + wrapper;
69
+ fragments.push(fragment);
117
70
  });
118
- }
119
71
 
120
- if (!Helpers0.__initialized) {
121
- Helpers0(Handlebars);
122
- Helpers0.__initialized = true;
123
- }
124
- var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
125
- this.compilerInfo = [4,'>= 1.0.0'];
126
- helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
127
- var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression, self=this;
128
-
129
- function program1(depth0,data) {
130
-
131
-
132
- return " open";
133
- }
72
+ return fragments.join(fragmentGlue);
73
+ }); //register a classic "for loop" helper
74
+ //it also adds a local variable "i" as the index in each iteration loop
134
75
 
135
- buffer += "<div class=\"dropdown-container\">\n <div class=\"dropdown ";
136
- if (helper = helpers.cls) { stack1 = helper.call(depth0, {hash:{},data:data}); }
137
- else { helper = (depth0 && depth0.cls); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
138
- buffer += escapeExpression(stack1);
139
- stack1 = helpers['if'].call(depth0, (depth0 && depth0.isOpen), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
140
- if(stack1 || stack1 === 0) { buffer += stack1; }
141
- buffer += "\" id=\"";
142
- if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
143
- else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
144
- buffer += escapeExpression(stack1)
145
- + "\" data-control=\"";
146
- if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
147
- else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
148
- buffer += escapeExpression(stack1)
149
- + "\" role=\"navigation\">\n <div class=\"dropdown-header a toggler\" aria-haspopup=\"true\" tabindex=\"0\">\n </div>\n <ul class=\"dropdown-submenu plain\" aria-label=\"submenu\">\n </ul>\n </div>\n</div>\n";
150
- return buffer;
151
- });
152
- function dropdownTpl(data, options, asString) {
153
- var html = Template(data, options);
154
- return (asString || true) ? html : $(html);
155
- }
76
+ hb.registerHelper('for', function (startIndex, stopIndex, increment, options) {
77
+ var ret = '';
78
+ startIndex = parseInt(startIndex);
79
+ stopIndex = parseInt(stopIndex);
80
+ increment = parseInt(increment);
156
81
 
157
- if (!Helpers0.__initialized) {
158
- Helpers0(Handlebars);
159
- Helpers0.__initialized = true;
160
- }
161
- var Template$1 = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
162
- this.compilerInfo = [4,'>= 1.0.0'];
163
- helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
164
- var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression, self=this;
165
-
166
- function program1(depth0,data) {
167
-
168
- var buffer = "", stack1, helper;
169
- buffer += "<span class=\"icon-";
170
- if (helper = helpers.icon) { stack1 = helper.call(depth0, {hash:{},data:data}); }
171
- else { helper = (depth0 && depth0.icon); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
172
- buffer += escapeExpression(stack1)
173
- + "\"></span>";
174
- return buffer;
82
+ for (var i = startIndex; i < stopIndex; i += increment) {
83
+ ret += options.fn(_.extend({}, this, {
84
+ i: i
85
+ }));
175
86
  }
176
87
 
177
- buffer += "<li class=\"dropdown-item ";
178
- if (helper = helpers.cls) { stack1 = helper.call(depth0, {hash:{},data:data}); }
179
- else { helper = (depth0 && depth0.cls); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
180
- buffer += escapeExpression(stack1)
181
- + "\" id=\"";
182
- if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
183
- else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
184
- buffer += escapeExpression(stack1)
185
- + "\" data-control=\"";
186
- if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
187
- else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
188
- buffer += escapeExpression(stack1)
189
- + "\">\n ";
190
- stack1 = helpers['if'].call(depth0, (depth0 && depth0.icon), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
191
- if(stack1 || stack1 === 0) { buffer += stack1; }
192
- buffer += "\n ";
193
- if (helper = helpers.content) { stack1 = helper.call(depth0, {hash:{},data:data}); }
194
- else { helper = (depth0 && depth0.content); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
195
- if(stack1 || stack1 === 0) { buffer += stack1; }
196
- buffer += "\n</li>\n";
197
- return buffer;
198
- });
199
- function itemTpl(data, options, asString) {
200
- var html = Template$1(data, options);
201
- return (asString || true) ? html : $(html);
202
- }
88
+ return ret;
89
+ });
90
+ hb.registerHelper('equal', function (var1, var2, options) {
91
+ if (var1 == var2) {
92
+ return options.fn(this);
93
+ } else {
94
+ return options.inverse(this);
95
+ }
96
+ }); // register a "get property" helper
97
+ // it gets the named property from the provided context
203
98
 
204
- /**
205
- * This program is free software; you can redistribute it and/or
206
- * modify it under the terms of the GNU General Public License
207
- * as published by the Free Software Foundation; under version 2
208
- * of the License (non-upgradable).
209
- *
210
- * This program is distributed in the hope that it will be useful,
211
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
212
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
213
- * GNU General Public License for more details.
214
- *
215
- * You should have received a copy of the GNU General Public License
216
- * along with this program; if not, write to the Free Software
217
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
218
- *
219
- * Copyright (c) 2018 (original work) Open Assessment Technologies SA ;
220
- */
221
- /**
222
- * Some default config
223
- * @type {Object}
224
- */
99
+ hb.registerHelper('property', function (name, context) {
100
+ return context[name] || '';
101
+ }); // register an 'includes' helper
102
+ // it checks if value is in array
225
103
 
226
- var defaults = {
227
- isOpen: false,
228
- activatedBy: 'hover' // can be hover or click
104
+ hb.registerHelper('includes', function (haystack, needle, options) {
105
+ if (_.contains(haystack, needle)) {
106
+ return options.fn(this);
107
+ }
108
+ });
109
+ }
110
+
111
+ if (!Helpers0.__initialized) {
112
+ Helpers0(Handlebars);
113
+ Helpers0.__initialized = true;
114
+ }
115
+ var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
116
+ this.compilerInfo = [4,'>= 1.0.0'];
117
+ helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
118
+ var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression, self=this;
119
+
120
+ function program1(depth0,data) {
121
+
122
+
123
+ return " open";
124
+ }
229
125
 
230
- };
231
- /**
232
- * Builds a simple dropdown component
233
- *
234
- * @param {Object} config
235
- * @param {String} [config.id] - The id of the dropdown element
236
- * @param {String} [config.cls] - An additional CSS class name
237
- * @param {Boolean} [config.isOpen] - Does the dropdown start open?
238
- * @param {String} [config.activatedBy] - hover or click
239
- * @param {Object} [data] - the data to initialise the component with
240
- * @param {String} [data.header]
241
- * @param {Object} [data.items]
242
- * @returns {dropdown}
243
- */
126
+ buffer += "<div class=\"dropdown-container\">\n <div class=\"dropdown ";
127
+ if (helper = helpers.cls) { stack1 = helper.call(depth0, {hash:{},data:data}); }
128
+ else { helper = (depth0 && depth0.cls); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
129
+ buffer += escapeExpression(stack1);
130
+ stack1 = helpers['if'].call(depth0, (depth0 && depth0.isOpen), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
131
+ if(stack1 || stack1 === 0) { buffer += stack1; }
132
+ buffer += "\" id=\"";
133
+ if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
134
+ else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
135
+ buffer += escapeExpression(stack1)
136
+ + "\" data-control=\"";
137
+ if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
138
+ else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
139
+ buffer += escapeExpression(stack1)
140
+ + "\" role=\"navigation\">\n <div class=\"dropdown-header a toggler\" aria-haspopup=\"true\" tabindex=\"0\">\n </div>\n <ul class=\"dropdown-submenu plain\" aria-label=\"submenu\">\n </ul>\n </div>\n</div>\n";
141
+ return buffer;
142
+ });
143
+ function dropdownTpl(data, options, asString) {
144
+ var html = Template(data, options);
145
+ return (asString || true) ? html : $(html);
146
+ }
147
+
148
+ if (!Helpers0.__initialized) {
149
+ Helpers0(Handlebars);
150
+ Helpers0.__initialized = true;
151
+ }
152
+ var Template$1 = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
153
+ this.compilerInfo = [4,'>= 1.0.0'];
154
+ helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
155
+ var buffer = "", stack1, helper, functionType="function", escapeExpression=this.escapeExpression, self=this;
156
+
157
+ function program1(depth0,data) {
158
+
159
+ var buffer = "", stack1, helper;
160
+ buffer += "<span class=\"icon-";
161
+ if (helper = helpers.icon) { stack1 = helper.call(depth0, {hash:{},data:data}); }
162
+ else { helper = (depth0 && depth0.icon); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
163
+ buffer += escapeExpression(stack1)
164
+ + "\"></span>";
165
+ return buffer;
166
+ }
244
167
 
245
- function dropdownFactory(config, data) {
246
- var dropdownSpecs = {
247
- /**
248
- * Gets the identifier of the dropdown
249
- * @returns {String}
250
- */
251
- getId: function getId() {
252
- return this.config.id;
253
- },
168
+ buffer += "<li class=\"dropdown-item ";
169
+ if (helper = helpers.cls) { stack1 = helper.call(depth0, {hash:{},data:data}); }
170
+ else { helper = (depth0 && depth0.cls); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
171
+ buffer += escapeExpression(stack1)
172
+ + "\" id=\"";
173
+ if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
174
+ else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
175
+ buffer += escapeExpression(stack1)
176
+ + "\" data-control=\"";
177
+ if (helper = helpers.id) { stack1 = helper.call(depth0, {hash:{},data:data}); }
178
+ else { helper = (depth0 && depth0.id); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
179
+ buffer += escapeExpression(stack1)
180
+ + "\">\n ";
181
+ stack1 = helpers['if'].call(depth0, (depth0 && depth0.icon), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
182
+ if(stack1 || stack1 === 0) { buffer += stack1; }
183
+ buffer += "\n ";
184
+ if (helper = helpers.content) { stack1 = helper.call(depth0, {hash:{},data:data}); }
185
+ else { helper = (depth0 && depth0.content); stack1 = typeof helper === functionType ? helper.call(depth0, {hash:{},data:data}) : helper; }
186
+ if(stack1 || stack1 === 0) { buffer += stack1; }
187
+ buffer += "\n</li>\n";
188
+ return buffer;
189
+ });
190
+ function itemTpl(data, options, asString) {
191
+ var html = Template$1(data, options);
192
+ return (asString || true) ? html : $(html);
193
+ }
194
+
195
+ /**
196
+ * This program is free software; you can redistribute it and/or
197
+ * modify it under the terms of the GNU General Public License
198
+ * as published by the Free Software Foundation; under version 2
199
+ * of the License (non-upgradable).
200
+ *
201
+ * This program is distributed in the hope that it will be useful,
202
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
203
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
204
+ * GNU General Public License for more details.
205
+ *
206
+ * You should have received a copy of the GNU General Public License
207
+ * along with this program; if not, write to the Free Software
208
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
209
+ *
210
+ * Copyright (c) 2018 (original work) Open Assessment Technologies SA ;
211
+ */
212
+ /**
213
+ * Some default config
214
+ * @type {Object}
215
+ */
216
+
217
+ var defaults = {
218
+ isOpen: false,
219
+ activatedBy: 'hover' // can be hover or click
220
+
221
+ };
222
+ /**
223
+ * Builds a simple dropdown component
224
+ *
225
+ * @param {Object} config
226
+ * @param {String} [config.id] - The id of the dropdown element
227
+ * @param {String} [config.cls] - An additional CSS class name
228
+ * @param {Boolean} [config.isOpen] - Does the dropdown start open?
229
+ * @param {String} [config.activatedBy] - hover or click
230
+ * @param {Object} [data] - the data to initialise the component with
231
+ * @param {String} [data.header]
232
+ * @param {Object} [data.items]
233
+ * @returns {dropdown}
234
+ */
235
+
236
+ function dropdownFactory(config, data) {
237
+ var dropdownSpecs = {
238
+ /**
239
+ * Gets the identifier of the dropdown
240
+ * @returns {String}
241
+ */
242
+ getId: function getId() {
243
+ return this.config.id;
244
+ },
254
245
 
255
- /**
256
- * Opens the dropdown
257
- *
258
- * @returns {dropdown} this
259
- */
260
- open: function open() {
261
- if (!this.is('open')) {
262
- this.controls.$dropdown.addClass('open');
263
- this.setState('open', true);
264
- }
246
+ /**
247
+ * Opens the dropdown
248
+ *
249
+ * @returns {dropdown} this
250
+ */
251
+ open: function open() {
252
+ if (!this.is('open')) {
253
+ this.controls.$dropdown.addClass('open');
254
+ this.setState('open', true);
255
+ }
265
256
 
266
- return this;
267
- },
257
+ return this;
258
+ },
268
259
 
269
- /**
270
- * Closes the dropdown
271
- *
272
- * @returns {dropdown} this
273
- */
274
- close: function close() {
275
- if (this.is('open')) {
276
- this.controls.$dropdown.removeClass('open');
277
- this.setState('open', false);
278
- }
260
+ /**
261
+ * Closes the dropdown
262
+ *
263
+ * @returns {dropdown} this
264
+ */
265
+ close: function close() {
266
+ if (this.is('open')) {
267
+ this.controls.$dropdown.removeClass('open');
268
+ this.setState('open', false);
269
+ }
279
270
 
280
- return this;
281
- },
271
+ return this;
272
+ },
282
273
 
283
- /**
284
- * Toggles the dropdown open/closed
285
- *
286
- * @returns {dropdown} this
287
- */
288
- toggle: function toggle() {
289
- if (this.is('open')) {
290
- this.close();
291
- } else {
292
- this.open();
293
- }
274
+ /**
275
+ * Toggles the dropdown open/closed
276
+ *
277
+ * @returns {dropdown} this
278
+ */
279
+ toggle: function toggle() {
280
+ if (this.is('open')) {
281
+ this.close();
282
+ } else {
283
+ this.open();
284
+ }
294
285
 
295
- return this;
296
- },
286
+ return this;
287
+ },
297
288
 
298
- /**
299
- * Sets the header item above the dropdown list
300
- *
301
- * @param {String} html
302
- * @returns {dropdown} this
303
- */
304
- setHeader: function setHeader(html) {
305
- if (typeof html === 'string') {
306
- data.header = html;
289
+ /**
290
+ * Sets the header item above the dropdown list
291
+ *
292
+ * @param {String} html
293
+ * @returns {dropdown} this
294
+ */
295
+ setHeader: function setHeader(html) {
296
+ if (typeof html === 'string') {
297
+ data.header = html;
307
298
 
308
- if (this.is('rendered')) {
309
- this.controls.$headerItem.html(html);
310
- }
299
+ if (this.is('rendered')) {
300
+ this.controls.$headerItem.html(html);
311
301
  }
302
+ }
312
303
 
313
- return this;
314
- },
304
+ return this;
305
+ },
315
306
 
316
- /**
317
- * Sets all the list items in one go
318
- * Replaces any existing items
319
- *
320
- * @param {Array} items
321
- * @returns {dropdown} this
322
- */
323
- setItems: function setItems(items) {
324
- var self = this;
307
+ /**
308
+ * Sets all the list items in one go
309
+ * Replaces any existing items
310
+ *
311
+ * @param {Array} items
312
+ * @returns {dropdown} this
313
+ */
314
+ setItems: function setItems(items) {
315
+ var self = this;
325
316
 
326
- if (Array.isArray(items)) {
327
- data.items = items;
317
+ if (Array.isArray(items)) {
318
+ data.items = items;
328
319
 
329
- if (this.is('rendered')) {
330
- this.controls.$listContainer.empty();
320
+ if (this.is('rendered')) {
321
+ this.controls.$listContainer.empty();
331
322
 
332
- _.forEach(items, function (item) {
333
- self.controls.$listContainer.append(itemTpl(item));
334
- });
335
- }
323
+ _.forEach(items, function (item) {
324
+ self.controls.$listContainer.append(itemTpl(item));
325
+ });
336
326
  }
327
+ }
337
328
 
338
- return this;
339
- },
329
+ return this;
330
+ },
340
331
 
341
- /**
342
- * Adds a list item to the dropdown list
343
- *
344
- * @param {Object} item
345
- * @param {String} item.content - the content to insert (should be HTML)
346
- * @param {String} [item.id] - the id the list item will have
347
- * @param {String} [item.cls] - any extra classes to put on the list item
348
- * @param {String} [item.icon] - the name of an icon to precede the content, if desired
349
- * @returns {dropdown} this
350
- */
351
- addItem: function addItem(item) {
352
- if (item.content && typeof item.content === 'string' && item.content.length) {
353
- data.items.push(item);
332
+ /**
333
+ * Adds a list item to the dropdown list
334
+ *
335
+ * @param {Object} item
336
+ * @param {String} item.content - the content to insert (should be HTML)
337
+ * @param {String} [item.id] - the id the list item will have
338
+ * @param {String} [item.cls] - any extra classes to put on the list item
339
+ * @param {String} [item.icon] - the name of an icon to precede the content, if desired
340
+ * @returns {dropdown} this
341
+ */
342
+ addItem: function addItem(item) {
343
+ if (item.content && typeof item.content === 'string' && item.content.length) {
344
+ data.items.push(item);
354
345
 
355
- if (this.is('rendered')) {
356
- this.controls.$listContainer.append(itemTpl(item));
357
- }
346
+ if (this.is('rendered')) {
347
+ this.controls.$listContainer.append(itemTpl(item));
358
348
  }
349
+ }
359
350
 
360
- return this;
361
- },
351
+ return this;
352
+ },
362
353
 
363
- /**
364
- * Removes a list item from the dropdown list
365
- *
366
- * @param {Number} index - list index to remove
367
- * @returns {dropdown} this
368
- */
369
- removeItem: function removeItem(index) {
370
- if (index >= 0 && index < data.items.length) {
371
- data.items.splice(index, 1);
354
+ /**
355
+ * Removes a list item from the dropdown list
356
+ *
357
+ * @param {Number} index - list index to remove
358
+ * @returns {dropdown} this
359
+ */
360
+ removeItem: function removeItem(index) {
361
+ if (index >= 0 && index < data.items.length) {
362
+ data.items.splice(index, 1);
372
363
 
373
- if (this.is('rendered')) {
374
- this.controls.$listContainer.children().get(index).remove();
375
- }
364
+ if (this.is('rendered')) {
365
+ this.controls.$listContainer.children().get(index).remove();
376
366
  }
367
+ }
377
368
 
378
- return this;
379
- },
380
-
381
- /**
382
- * Empties the dropdown list (but not its header!)
383
- *
384
- * @returns {dropdown} this
385
- */
386
- clearItems: function clearItems() {
387
- data.items = [];
369
+ return this;
370
+ },
388
371
 
389
- if (this.is('rendered')) {
390
- this.controls.$listContainer.empty();
391
- }
372
+ /**
373
+ * Empties the dropdown list (but not its header!)
374
+ *
375
+ * @returns {dropdown} this
376
+ */
377
+ clearItems: function clearItems() {
378
+ data.items = [];
392
379
 
393
- return this;
394
- }
395
- };
396
- data = _.defaults({}, data, {
397
- header: '',
398
- items: []
399
- });
400
- return component(dropdownSpecs, defaults).setTemplate(dropdownTpl) // dropdown-specific init:
401
- .on('init', function () {
402
- this.setState('open', this.config.isOpen);
403
- }) // renders the component
404
- .on('render', function () {
405
- var $component = this.getElement();
406
- this.controls = {
407
- $dropdown: $component.find('.dropdown'),
408
- $toggler: $component.find('.dropdown-header:after'),
409
- $headerItem: $component.find('.dropdown-header'),
410
- $listContainer: $component.find('.dropdown-submenu')
411
- }; // insert data into rendered template:
412
-
413
- if (!_.isEmpty(data)) {
414
- this.setHeader(data.header);
415
- this.setItems(data.items);
380
+ if (this.is('rendered')) {
381
+ this.controls.$listContainer.empty();
416
382
  }
417
383
 
418
- this.trigger('wireup');
419
- }).on('wireup', function () {
420
- var self = this;
421
- var $component = this.getElement(); // wire up main behaviour:
384
+ return this;
385
+ }
386
+ };
387
+ data = _.defaults({}, data, {
388
+ header: '',
389
+ items: []
390
+ });
391
+ return component(dropdownSpecs, defaults).setTemplate(dropdownTpl) // dropdown-specific init:
392
+ .on('init', function () {
393
+ this.setState('open', this.config.isOpen);
394
+ }) // renders the component
395
+ .on('render', function () {
396
+ var $component = this.getElement();
397
+ this.controls = {
398
+ $dropdown: $component.find('.dropdown'),
399
+ $toggler: $component.find('.dropdown-header:after'),
400
+ $headerItem: $component.find('.dropdown-header'),
401
+ $listContainer: $component.find('.dropdown-submenu')
402
+ }; // insert data into rendered template:
403
+
404
+ if (!_.isEmpty(data)) {
405
+ this.setHeader(data.header);
406
+ this.setItems(data.items);
407
+ }
422
408
 
423
- if (this.config.activatedBy === 'hover') {
424
- $component.on('mouseenter', self.open).on('mouseleave', self.close);
425
- this.controls.$toggler.on('click', self.toggle).on('focus', self.open);
426
- } else if (this.config.activatedBy === 'click') {
427
- this.controls.$headerItem.on('click', self.toggle);
428
- }
409
+ this.trigger('wireup');
410
+ }).on('wireup', function () {
411
+ var self = this;
412
+ var $component = this.getElement(); // wire up main behaviour:
429
413
 
430
- $component.on('focus', self.open).on('blur', self.close); // list item events
414
+ if (this.config.activatedBy === 'hover') {
415
+ $component.on('mouseenter', self.open).on('mouseleave', self.close);
416
+ this.controls.$toggler.on('click', self.toggle).on('focus', self.open);
417
+ } else if (this.config.activatedBy === 'click') {
418
+ this.controls.$headerItem.on('click', self.toggle);
419
+ }
431
420
 
432
- this.controls.$listContainer.on('click', 'li', function () {
433
- var id = $$1(this).closest('li').attr('id');
434
- /**
435
- * @event item-click
436
- */
421
+ $component.on('focus', self.open).on('blur', self.close); // list item events
437
422
 
438
- self.trigger('item-click', id);
439
- /**
440
- * @event item-click-<id>
441
- */
423
+ this.controls.$listContainer.on('click', 'li', function () {
424
+ var id = $$1(this).closest('li').attr('id');
425
+ /**
426
+ * @event item-click
427
+ */
442
428
 
443
- self.trigger('item-click-' + id);
444
- });
445
- }).on('item-click', function () {
446
- this.close();
447
- }).init(config);
448
- }
429
+ self.trigger('item-click', id);
430
+ /**
431
+ * @event item-click-<id>
432
+ */
433
+
434
+ self.trigger('item-click-' + id);
435
+ });
436
+ }).on('item-click', function () {
437
+ this.close();
438
+ }).init(config);
439
+ }
449
440
 
450
- return dropdownFactory;
441
+ return dropdownFactory;
451
442
 
452
443
  });