@oat-sa/tao-core-ui 1.60.0 → 1.60.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 (765) hide show
  1. package/LICENSE +339 -339
  2. package/README.md +17 -17
  3. package/dist/actionbar.js +105 -105
  4. package/dist/adder.js +109 -109
  5. package/dist/animable/absorbable/absorbable.js +42 -42
  6. package/dist/animable/absorbable/css/absorb.css +7 -7
  7. package/dist/animable/absorbable/css/absorb.css.map +1 -1
  8. package/dist/animable/pulsable/css/pulse.css +7 -7
  9. package/dist/animable/pulsable/css/pulse.css.map +1 -1
  10. package/dist/animable/pulsable/pulsable.js +36 -36
  11. package/dist/areaBroker.js +51 -51
  12. package/dist/autocomplete/css/autocomplete.css +7 -7
  13. package/dist/autocomplete/css/autocomplete.css.map +1 -1
  14. package/dist/autocomplete.js +400 -400
  15. package/dist/autoscroll.js +22 -22
  16. package/dist/badge/badge.js +48 -48
  17. package/dist/badge/css/badge.css +7 -7
  18. package/dist/badge/css/badge.css.map +1 -1
  19. package/dist/breadcrumbs/css/breadcrumbs.css +7 -7
  20. package/dist/breadcrumbs/css/breadcrumbs.css.map +1 -1
  21. package/dist/breadcrumbs.js +70 -70
  22. package/dist/btngrouper.js +64 -64
  23. package/dist/bulkActionPopup/css/bulkActionPopup.css +7 -7
  24. package/dist/bulkActionPopup/css/bulkActionPopup.css.map +1 -1
  25. package/dist/bulkActionPopup.js +104 -104
  26. package/dist/button.js +102 -102
  27. package/dist/calculator/css/calculator.css +10 -10
  28. package/dist/calculator/css/calculator.css.map +1 -1
  29. package/dist/calculator.js +51 -51
  30. package/dist/cascadingComboBox.js +47 -47
  31. package/dist/ckeditor/ckConfigurator.js +48 -48
  32. package/dist/ckeditor/dtdHandler.js +110 -110
  33. package/dist/class/css/selector.css +7 -7
  34. package/dist/class/css/selector.css.map +1 -1
  35. package/dist/class/selector.js +111 -111
  36. package/dist/component/alignable.js +81 -81
  37. package/dist/component/containable.js +37 -37
  38. package/dist/component/css/components.css +7 -7
  39. package/dist/component/css/components.css.map +1 -1
  40. package/dist/component/css/windowComponent.css +7 -7
  41. package/dist/component/css/windowComponent.css.map +1 -1
  42. package/dist/component/draggable.js +25 -25
  43. package/dist/component/placeable.js +70 -70
  44. package/dist/component/resizable.js +61 -61
  45. package/dist/component/stackable.js +20 -20
  46. package/dist/component/windowed.js +59 -59
  47. package/dist/component.js +153 -153
  48. package/dist/container.js +76 -76
  49. package/dist/contextualPopup/css/contextualPopup.css +7 -7
  50. package/dist/contextualPopup/css/contextualPopup.css.map +1 -1
  51. package/dist/contextualPopup.js +113 -113
  52. package/dist/dashboard/css/dashboard.css +7 -7
  53. package/dist/dashboard/css/dashboard.css.map +1 -1
  54. package/dist/dashboard.js +75 -75
  55. package/dist/datalist/css/datalist.css +7 -7
  56. package/dist/datalist/css/datalist.css.map +1 -1
  57. package/dist/datalist.js +160 -160
  58. package/dist/datatable/css/datatable.css +7 -7
  59. package/dist/datatable/css/datatable.css.map +1 -1
  60. package/dist/datatable/filterStrategy/filterStrategy.js +27 -27
  61. package/dist/datatable/filterStrategy/multiple.js +25 -25
  62. package/dist/datatable/filterStrategy/single.js +25 -25
  63. package/dist/datatable.js +374 -374
  64. package/dist/dateRange/css/dateRange.css +7 -7
  65. package/dist/dateRange/css/dateRange.css.map +1 -1
  66. package/dist/dateRange/dateRange.js +110 -110
  67. package/dist/datetime/css/picker.css +7 -7
  68. package/dist/datetime/css/picker.css.map +1 -1
  69. package/dist/datetime/picker.js +174 -174
  70. package/dist/deleter.js +92 -92
  71. package/dist/destination/css/selector.css +7 -7
  72. package/dist/destination/css/selector.css.map +1 -1
  73. package/dist/destination/selector.js +65 -65
  74. package/dist/dialog/alert.js +26 -26
  75. package/dist/dialog/confirm.js +27 -27
  76. package/dist/dialog/confirmDelete.js +44 -44
  77. package/dist/dialog.js +156 -156
  78. package/dist/disabler.js +90 -90
  79. package/dist/documentViewer/css/documentViewer.css +7 -7
  80. package/dist/documentViewer/css/documentViewer.css.map +1 -1
  81. package/dist/documentViewer/providers/pdfViewer/fallback/viewer.js +43 -43
  82. package/dist/documentViewer/providers/pdfViewer/pdfjs/areaBroker.js +25 -25
  83. package/dist/documentViewer/providers/pdfViewer/pdfjs/findBar.js +133 -133
  84. package/dist/documentViewer/providers/pdfViewer/pdfjs/pageView.js +102 -102
  85. package/dist/documentViewer/providers/pdfViewer/pdfjs/pagesManager.js +52 -52
  86. package/dist/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +125 -125
  87. package/dist/documentViewer/providers/pdfViewer/pdfjs/textManager.js +67 -67
  88. package/dist/documentViewer/providers/pdfViewer/pdfjs/viewer.js +94 -94
  89. package/dist/documentViewer/providers/pdfViewer/pdfjs/wrapper.js +111 -111
  90. package/dist/documentViewer/providers/pdfViewer.js +42 -42
  91. package/dist/documentViewer/viewerFactory.js +71 -71
  92. package/dist/documentViewer.js +99 -99
  93. package/dist/dropdown/css/dropdown.css +7 -7
  94. package/dist/dropdown/css/dropdown.css.map +1 -1
  95. package/dist/dropdown.js +97 -97
  96. package/dist/durationer.js +58 -58
  97. package/dist/dynamicComponent/css/dynamicComponent.css +7 -7
  98. package/dist/dynamicComponent/css/dynamicComponent.css.map +1 -1
  99. package/dist/dynamicComponent.js +116 -116
  100. package/dist/feedback.js +97 -97
  101. package/dist/figure/FigureStateActive.js +117 -117
  102. package/dist/filesender.js +26 -26
  103. package/dist/filter.js +47 -47
  104. package/dist/form/css/dropdownForm.css +7 -7
  105. package/dist/form/css/dropdownForm.css.map +1 -1
  106. package/dist/form/css/form.css +7 -7
  107. package/dist/form/css/form.css.map +1 -1
  108. package/dist/form/dropdownForm.js +112 -112
  109. package/dist/form/form.js +245 -245
  110. package/dist/form/simpleForm.js +71 -71
  111. package/dist/form/validator/css/validator.css +7 -7
  112. package/dist/form/validator/css/validator.css.map +1 -1
  113. package/dist/form/validator/renderer.js +65 -65
  114. package/dist/form/validator/validator.js +87 -87
  115. package/dist/form/widget/css/widget.css +7 -7
  116. package/dist/form/widget/css/widget.css.map +1 -1
  117. package/dist/form/widget/definitions.js +24 -24
  118. package/dist/form/widget/loader.js +16 -16
  119. package/dist/form/widget/providers/checkBox.js +75 -75
  120. package/dist/form/widget/providers/comboBox.js +59 -59
  121. package/dist/form/widget/providers/default.js +35 -35
  122. package/dist/form/widget/providers/hidden.js +50 -50
  123. package/dist/form/widget/providers/hiddenBox.js +71 -71
  124. package/dist/form/widget/providers/radioBox.js +70 -70
  125. package/dist/form/widget/providers/textArea.js +48 -48
  126. package/dist/form/widget/providers/textBox.js +34 -34
  127. package/dist/form/widget/widget.js +154 -154
  128. package/dist/form.js +10 -10
  129. package/dist/formValidator/formValidator.js +61 -61
  130. package/dist/formValidator/highlighters/highlighter.js +41 -41
  131. package/dist/formValidator/highlighters/message.js +29 -29
  132. package/dist/formValidator/highlighters/tooltip.js +32 -32
  133. package/dist/generis/form/css/form.css +7 -7
  134. package/dist/generis/form/css/form.css.map +1 -1
  135. package/dist/generis/form/form.js +86 -86
  136. package/dist/generis/validator/css/validator.css +7 -7
  137. package/dist/generis/validator/css/validator.css.map +1 -1
  138. package/dist/generis/validator/validator.js +51 -51
  139. package/dist/generis/widget/checkBox/checkBox.js +52 -52
  140. package/dist/generis/widget/comboBox/comboBox.js +45 -45
  141. package/dist/generis/widget/css/widget.css +7 -7
  142. package/dist/generis/widget/css/widget.css.map +1 -1
  143. package/dist/generis/widget/hiddenBox/hiddenBox.js +53 -53
  144. package/dist/generis/widget/loader.js +20 -20
  145. package/dist/generis/widget/textBox/textBox.js +40 -40
  146. package/dist/generis/widget/widget.js +60 -60
  147. package/dist/groupedComboBox.js +49 -49
  148. package/dist/groupvalidator.js +19 -19
  149. package/dist/hider.js +41 -41
  150. package/dist/highlighter.js +262 -262
  151. package/dist/image/ImgStateActive/extractLabel.js +20 -20
  152. package/dist/image/ImgStateActive/helper.js +16 -16
  153. package/dist/image/ImgStateActive/initHelper.js +85 -85
  154. package/dist/image/ImgStateActive/initMediaEditor.js +48 -48
  155. package/dist/image/ImgStateActive/mediaSizer.js +32 -32
  156. package/dist/image/ImgStateActive.js +104 -104
  157. package/dist/incrementer.js +58 -58
  158. package/dist/inplacer.js +87 -87
  159. package/dist/interactUtils.js +42 -42
  160. package/dist/itemButtonList/css/item-button-list.css +23 -23
  161. package/dist/itemButtonList/css/item-button-list.css.map +1 -1
  162. package/dist/itemButtonList.js +115 -115
  163. package/dist/keyNavigation/navigableDomElement.js +76 -76
  164. package/dist/keyNavigation/navigator.js +158 -158
  165. package/dist/listbox/css/listbox.css +7 -7
  166. package/dist/listbox/css/listbox.css.map +1 -1
  167. package/dist/listbox.js +97 -97
  168. package/dist/liststyler.js +57 -57
  169. package/dist/loadingButton/css/button.css +7 -7
  170. package/dist/loadingButton/css/button.css.map +1 -1
  171. package/dist/loadingButton/loadingButton.js +48 -48
  172. package/dist/lock.js +125 -125
  173. package/dist/login/login.js +100 -100
  174. package/dist/maths/calculator/basicCalculator.js +63 -63
  175. package/dist/maths/calculator/calculatorComponent.js +29 -29
  176. package/dist/maths/calculator/core/areaBroker.js +25 -25
  177. package/dist/maths/calculator/core/board.js +313 -313
  178. package/dist/maths/calculator/core/expression.js +111 -111
  179. package/dist/maths/calculator/core/labels.js +29 -29
  180. package/dist/maths/calculator/core/plugin.js +19 -19
  181. package/dist/maths/calculator/core/terms.js +26 -26
  182. package/dist/maths/calculator/core/tokenizer.js +98 -98
  183. package/dist/maths/calculator/core/tokens.js +59 -59
  184. package/dist/maths/calculator/css/calculator.css +7 -7
  185. package/dist/maths/calculator/css/calculator.css.map +1 -1
  186. package/dist/maths/calculator/defaultCalculator.js +23 -23
  187. package/dist/maths/calculator/plugins/core/degrad.js +22 -22
  188. package/dist/maths/calculator/plugins/core/history.js +45 -45
  189. package/dist/maths/calculator/plugins/core/remind.js +22 -22
  190. package/dist/maths/calculator/plugins/core/stepNavigation.js +31 -31
  191. package/dist/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +61 -61
  192. package/dist/maths/calculator/plugins/modifiers/pow10.js +35 -35
  193. package/dist/maths/calculator/plugins/modifiers/sign.js +90 -90
  194. package/dist/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +60 -60
  195. package/dist/maths/calculator/pluginsLoader.js +21 -21
  196. package/dist/maths/calculator/scientificCalculator.js +91 -91
  197. package/dist/mediaEditor/mediaEditorComponent.js +64 -64
  198. package/dist/mediaEditor/plugins/mediaAlignment/helper.js +16 -16
  199. package/dist/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +60 -60
  200. package/dist/mediaEditor/plugins/mediaAlignment/style.css +7 -7
  201. package/dist/mediaEditor/plugins/mediaDimension/helper.js +70 -70
  202. package/dist/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +153 -153
  203. package/dist/mediaEditor/plugins/mediaDimension/style.css +141 -141
  204. package/dist/mediaplayer/css/player.css +31 -7
  205. package/dist/mediaplayer/css/player.css.map +1 -1
  206. package/dist/mediaplayer/players/html5.js +65 -65
  207. package/dist/mediaplayer/players/youtube.js +52 -52
  208. package/dist/mediaplayer/players.js +18 -18
  209. package/dist/mediaplayer/support.js +55 -55
  210. package/dist/mediaplayer/utils/reminder.js +100 -100
  211. package/dist/mediaplayer/utils/timeObserver.js +92 -92
  212. package/dist/mediaplayer/youtubeManager.js +35 -35
  213. package/dist/mediaplayer.js +460 -460
  214. package/dist/mediasizer.js +135 -135
  215. package/dist/modal.js +87 -87
  216. package/dist/movableComponent.js +35 -35
  217. package/dist/pageSizeSelector.js +44 -44
  218. package/dist/pageStatus.js +33 -33
  219. package/dist/pagination/css/pagination.css +7 -7
  220. package/dist/pagination/css/pagination.css.map +1 -1
  221. package/dist/pagination/paginationStrategy.js +23 -23
  222. package/dist/pagination/providers/pages.js +37 -37
  223. package/dist/pagination/providers/simple.js +35 -35
  224. package/dist/pagination.js +45 -45
  225. package/dist/previewer.js +67 -67
  226. package/dist/progressbar.js +58 -58
  227. package/dist/report.js +86 -86
  228. package/dist/resource/css/selector.css +7 -7
  229. package/dist/resource/css/selector.css.map +1 -1
  230. package/dist/resource/filters.js +73 -73
  231. package/dist/resource/list.js +66 -66
  232. package/dist/resource/selectable.js +92 -92
  233. package/dist/resource/selector.js +195 -195
  234. package/dist/resource/tree.js +104 -104
  235. package/dist/resourcemgr/css/resourcemgr.css +7 -7
  236. package/dist/resourcemgr/css/resourcemgr.css.map +1 -1
  237. package/dist/resourcemgr/fileBrowser.js +88 -88
  238. package/dist/resourcemgr/fileSelector.js +58 -58
  239. package/dist/resourcemgr/util/updatePermissions.js +4 -4
  240. package/dist/resourcemgr.js +62 -62
  241. package/dist/scroller.js +26 -26
  242. package/dist/searchModal/advancedSearch.js +130 -130
  243. package/dist/searchModal/css/advancedSearch.css +7 -7
  244. package/dist/searchModal/css/advancedSearch.css.map +1 -1
  245. package/dist/searchModal/css/searchModal.css +7 -7
  246. package/dist/searchModal/css/searchModal.css.map +1 -1
  247. package/dist/searchModal.js +96 -96
  248. package/dist/selecter.js +6 -6
  249. package/dist/stacker.js +43 -43
  250. package/dist/switch/css/switch.css +7 -7
  251. package/dist/switch/css/switch.css.map +1 -1
  252. package/dist/switch/switch.js +75 -75
  253. package/dist/tableModel.js +33 -33
  254. package/dist/tabs/css/tabs.css +12 -12
  255. package/dist/tabs/css/tabs.css.map +1 -1
  256. package/dist/tabs.js +217 -217
  257. package/dist/taskQueue/css/taskQueue.css +7 -7
  258. package/dist/taskQueue/css/taskQueue.css.map +1 -1
  259. package/dist/taskQueue/status.js +72 -72
  260. package/dist/taskQueue/table.js +67 -67
  261. package/dist/taskQueue/taskQueue.js +18 -18
  262. package/dist/taskQueue/taskQueueModel.js +86 -86
  263. package/dist/taskQueue.js +47 -47
  264. package/dist/taskQueueButton/css/taskable.css +7 -7
  265. package/dist/taskQueueButton/css/taskable.css.map +1 -1
  266. package/dist/taskQueueButton/css/treeButton.css +7 -7
  267. package/dist/taskQueueButton/css/treeButton.css.map +1 -1
  268. package/dist/taskQueueButton/standardButton.js +39 -39
  269. package/dist/taskQueueButton/taskable.js +54 -54
  270. package/dist/taskQueueButton/treeButton.js +56 -56
  271. package/dist/themeLoader.js +75 -75
  272. package/dist/themes.js +84 -84
  273. package/dist/toggler.js +57 -57
  274. package/dist/tooltip.js +54 -54
  275. package/dist/tooltipster.js +17 -17
  276. package/dist/transformer.js +117 -117
  277. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  278. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  279. package/dist/tristateCheckboxGroup.js +75 -75
  280. package/dist/uploader.js +158 -158
  281. package/dist/validator/validators.js +48 -48
  282. package/dist/validator.js +24 -24
  283. package/dist/waitForMedia.js +33 -33
  284. package/dist/waitingDialog/css/waitingDialog.css +7 -7
  285. package/dist/waitingDialog/css/waitingDialog.css.map +1 -1
  286. package/dist/waitingDialog/waitingDialog.js +54 -54
  287. package/package.json +107 -107
  288. package/scss/basic.scss +16 -16
  289. package/scss/ckeditor/skins/tao/scss/inc/_ck-icons.scss +59 -59
  290. package/scss/ckeditor/skins/tao/scss/inc/_tao.scss +59 -59
  291. package/scss/font/tao/tao.svg +234 -234
  292. package/scss/inc/_base.scss +495 -495
  293. package/scss/inc/_bootstrap.scss +6 -6
  294. package/scss/inc/_buttons.scss +114 -114
  295. package/scss/inc/_colors.scss +88 -88
  296. package/scss/inc/_feedback.scss +150 -150
  297. package/scss/inc/_flex-grid.scss +15 -15
  298. package/scss/inc/_fonts.scss +4 -4
  299. package/scss/inc/_forms.scss +832 -832
  300. package/scss/inc/_functions.scss +283 -283
  301. package/scss/inc/_grid.scss +5 -3
  302. package/scss/inc/_jquery.nouislider.scss +254 -254
  303. package/scss/inc/_normalize.scss +528 -528
  304. package/scss/inc/_report.scss +67 -67
  305. package/scss/inc/_secondary-properties.scss +89 -89
  306. package/scss/inc/_select2.scss +634 -634
  307. package/scss/inc/_toolbars.scss +155 -155
  308. package/scss/inc/_tooltip.scss +312 -312
  309. package/scss/inc/_variables.scss +21 -21
  310. package/scss/inc/base/_highlight.scss +5 -5
  311. package/scss/inc/base/_list-style.scss +58 -58
  312. package/scss/inc/base/_svg.scss +3 -3
  313. package/scss/inc/base/_table.scss +62 -62
  314. package/scss/inc/fonts/_source-sans-pro.scss +29 -29
  315. package/scss/inc/fonts/_tao-icon-classes.scss +226 -226
  316. package/scss/inc/fonts/_tao-icon-def.scss +12 -12
  317. package/scss/inc/fonts/_tao-icon-vars.scss +240 -240
  318. package/src/actionbar/tpl/main.tpl +8 -8
  319. package/src/actionbar.js +251 -251
  320. package/src/adder.js +250 -250
  321. package/src/animable/absorbable/absorbable.js +134 -134
  322. package/src/animable/absorbable/css/absorb.css +7 -7
  323. package/src/animable/absorbable/css/absorb.css.map +1 -1
  324. package/src/animable/absorbable/scss/absorb.scss +37 -37
  325. package/src/animable/pulsable/css/pulse.css +7 -7
  326. package/src/animable/pulsable/css/pulse.css.map +1 -1
  327. package/src/animable/pulsable/pulsable.js +90 -90
  328. package/src/animable/pulsable/scss/pulse.scss +22 -22
  329. package/src/areaBroker.js +160 -160
  330. package/src/autocomplete/css/autocomplete.css +7 -7
  331. package/src/autocomplete/css/autocomplete.css.map +1 -1
  332. package/src/autocomplete/scss/autocomplete.scss +37 -37
  333. package/src/autocomplete.js +1029 -1029
  334. package/src/autoscroll.js +57 -57
  335. package/src/badge/badge.js +119 -119
  336. package/src/badge/css/badge.css +7 -7
  337. package/src/badge/css/badge.css.map +1 -1
  338. package/src/badge/scss/badge.scss +92 -92
  339. package/src/badge/tpl/badge.tpl +4 -4
  340. package/src/breadcrumbs/css/breadcrumbs.css +7 -7
  341. package/src/breadcrumbs/css/breadcrumbs.css.map +1 -1
  342. package/src/breadcrumbs/scss/breadcrumbs.scss +52 -52
  343. package/src/breadcrumbs/tpl/breadcrumbs.tpl +20 -20
  344. package/src/breadcrumbs.js +99 -99
  345. package/src/btngrouper.js +213 -213
  346. package/src/bulkActionPopup/css/bulkActionPopup.css +7 -7
  347. package/src/bulkActionPopup/css/bulkActionPopup.css.map +1 -1
  348. package/src/bulkActionPopup/scss/bulkActionPopup.scss +63 -63
  349. package/src/bulkActionPopup/tpl/layout.tpl +76 -76
  350. package/src/bulkActionPopup/tpl/select.tpl +8 -8
  351. package/src/bulkActionPopup.js +274 -274
  352. package/src/button/tpl/button.tpl +4 -4
  353. package/src/button.js +135 -135
  354. package/src/calculator/css/calculator.css +10 -10
  355. package/src/calculator/css/calculator.css.map +1 -1
  356. package/src/calculator/scss/calculator.scss +139 -139
  357. package/src/calculator.js +188 -188
  358. package/src/cascadingComboBox.js +126 -126
  359. package/src/ckeditor/ckConfigurator.js +736 -736
  360. package/src/ckeditor/dtdHandler.js +1030 -1030
  361. package/src/class/css/selector.css +7 -7
  362. package/src/class/css/selector.css.map +1 -1
  363. package/src/class/scss/selector.scss +101 -101
  364. package/src/class/selector.js +329 -329
  365. package/src/class/tpl/listItem.tpl +9 -9
  366. package/src/class/tpl/selector.tpl +10 -10
  367. package/src/component/alignable.js +274 -274
  368. package/src/component/containable.js +122 -122
  369. package/src/component/css/components.css +7 -7
  370. package/src/component/css/components.css.map +1 -1
  371. package/src/component/css/windowComponent.css +7 -7
  372. package/src/component/css/windowComponent.css.map +1 -1
  373. package/src/component/draggable.js +104 -104
  374. package/src/component/placeable.js +233 -233
  375. package/src/component/resizable.js +195 -195
  376. package/src/component/scss/components.scss +507 -507
  377. package/src/component/scss/windowComponent.scss +62 -62
  378. package/src/component/stackable.js +67 -67
  379. package/src/component/tpl/window.tpl +7 -7
  380. package/src/component/windowed.js +206 -206
  381. package/src/component.js +401 -401
  382. package/src/container.js +200 -200
  383. package/src/contextualPopup/css/contextualPopup.css +7 -7
  384. package/src/contextualPopup/css/contextualPopup.css.map +1 -1
  385. package/src/contextualPopup/scss/contextualPopup.scss +78 -78
  386. package/src/contextualPopup/tpl/popup.tpl +10 -10
  387. package/src/contextualPopup.js +297 -297
  388. package/src/css/basic.css +104 -104
  389. package/src/css/basic.css.map +1 -1
  390. package/src/dashboard/css/dashboard.css +7 -7
  391. package/src/dashboard/css/dashboard.css.map +1 -1
  392. package/src/dashboard/scss/dashboard.scss +93 -93
  393. package/src/dashboard/tpl/dashboard.tpl +16 -16
  394. package/src/dashboard/tpl/dashboardMetricsList.tpl +15 -15
  395. package/src/dashboard.js +184 -184
  396. package/src/datalist/css/datalist.css +7 -7
  397. package/src/datalist/css/datalist.css.map +1 -1
  398. package/src/datalist/scss/datalist.scss +116 -116
  399. package/src/datalist/tpl/list.tpl +24 -24
  400. package/src/datalist/tpl/main.tpl +44 -44
  401. package/src/datalist.js +500 -500
  402. package/src/datatable/css/datatable.css +7 -7
  403. package/src/datatable/css/datatable.css.map +1 -1
  404. package/src/datatable/filterStrategy/filterStrategy.js +70 -70
  405. package/src/datatable/filterStrategy/multiple.js +126 -126
  406. package/src/datatable/filterStrategy/single.js +108 -108
  407. package/src/datatable/scss/datatable.scss +146 -146
  408. package/src/datatable/tpl/button.tpl +6 -6
  409. package/src/datatable/tpl/layout.tpl +158 -158
  410. package/src/datatable.js +1056 -1056
  411. package/src/dateRange/css/dateRange.css +7 -7
  412. package/src/dateRange/css/dateRange.css.map +1 -1
  413. package/src/dateRange/dateRange.js +341 -341
  414. package/src/dateRange/scss/dateRange.scss +7 -7
  415. package/src/dateRange/tpl/select.tpl +18 -18
  416. package/src/datetime/css/picker.css +7 -7
  417. package/src/datetime/css/picker.css.map +1 -1
  418. package/src/datetime/picker.js +576 -576
  419. package/src/datetime/scss/picker.scss +192 -192
  420. package/src/datetime/tpl/picker.tpl +18 -18
  421. package/src/deleter/undo.tpl +6 -6
  422. package/src/deleter.js +296 -296
  423. package/src/destination/css/selector.css +7 -7
  424. package/src/destination/css/selector.css.map +1 -1
  425. package/src/destination/scss/selector.scss +36 -36
  426. package/src/destination/selector.js +195 -195
  427. package/src/destination/tpl/selector.tpl +13 -13
  428. package/src/dialog/alert.js +70 -70
  429. package/src/dialog/confirm.js +85 -85
  430. package/src/dialog/confirmDelete.js +95 -95
  431. package/src/dialog/tpl/body.tpl +24 -24
  432. package/src/dialog/tpl/buttons.tpl +6 -6
  433. package/src/dialog/tpl/checkbox.tpl +5 -5
  434. package/src/dialog.js +517 -517
  435. package/src/disabler.js +230 -230
  436. package/src/documentViewer/css/documentViewer.css +7 -7
  437. package/src/documentViewer/css/documentViewer.css.map +1 -1
  438. package/src/documentViewer/providers/pdfViewer/fallback/viewer.js +69 -69
  439. package/src/documentViewer/providers/pdfViewer/pdfjs/areaBroker.js +41 -41
  440. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.js +475 -475
  441. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.tpl +20 -20
  442. package/src/documentViewer/providers/pdfViewer/pdfjs/match.tpl +1 -1
  443. package/src/documentViewer/providers/pdfViewer/pdfjs/page.tpl +4 -4
  444. package/src/documentViewer/providers/pdfViewer/pdfjs/pageView.js +318 -318
  445. package/src/documentViewer/providers/pdfViewer/pdfjs/pagesManager.js +167 -167
  446. package/src/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +451 -451
  447. package/src/documentViewer/providers/pdfViewer/pdfjs/textManager.js +252 -252
  448. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.js +299 -299
  449. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.tpl +16 -16
  450. package/src/documentViewer/providers/pdfViewer/pdfjs/wrapper.js +351 -351
  451. package/src/documentViewer/providers/pdfViewer.js +93 -93
  452. package/src/documentViewer/scss/documentViewer.scss +184 -184
  453. package/src/documentViewer/viewerFactory.js +191 -191
  454. package/src/documentViewer.js +238 -238
  455. package/src/dropdown/css/dropdown.css +7 -7
  456. package/src/dropdown/css/dropdown.css.map +1 -1
  457. package/src/dropdown/scss/dropdown.scss +99 -99
  458. package/src/dropdown/tpl/dropdown.tpl +8 -8
  459. package/src/dropdown/tpl/list-item.tpl +4 -4
  460. package/src/dropdown.js +255 -255
  461. package/src/durationer.js +222 -222
  462. package/src/dynamicComponent/css/dynamicComponent.css +7 -7
  463. package/src/dynamicComponent/css/dynamicComponent.css.map +1 -1
  464. package/src/dynamicComponent/scss/dynamicComponent.scss +98 -98
  465. package/src/dynamicComponent/tpl/layout.tpl +17 -17
  466. package/src/dynamicComponent.js +554 -554
  467. package/src/feedback/feedback.tpl +7 -7
  468. package/src/feedback.js +295 -295
  469. package/src/figure/FigureStateActive.js +174 -174
  470. package/src/filesender.js +114 -114
  471. package/src/filter/template.tpl +5 -5
  472. package/src/filter.js +135 -135
  473. package/src/form/css/dropdownForm.css +7 -7
  474. package/src/form/css/dropdownForm.css.map +1 -1
  475. package/src/form/css/form.css +7 -7
  476. package/src/form/css/form.css.map +1 -1
  477. package/src/form/dropdownForm.js +281 -281
  478. package/src/form/form.js +688 -688
  479. package/src/form/scss/dropdownForm.scss +60 -60
  480. package/src/form/scss/form.scss +25 -25
  481. package/src/form/simpleForm.js +125 -125
  482. package/src/form/tpl/dropdownForm.tpl +4 -4
  483. package/src/form/tpl/form.tpl +7 -7
  484. package/src/form/validator/css/validator.css +7 -7
  485. package/src/form/validator/css/validator.css.map +1 -1
  486. package/src/form/validator/renderer.js +118 -118
  487. package/src/form/validator/scss/validator.scss +14 -14
  488. package/src/form/validator/tpl/message.tpl +1 -1
  489. package/src/form/validator/tpl/validator.tpl +1 -1
  490. package/src/form/validator/validator.js +220 -220
  491. package/src/form/widget/css/widget.css +7 -7
  492. package/src/form/widget/css/widget.css.map +1 -1
  493. package/src/form/widget/definitions.js +51 -51
  494. package/src/form/widget/loader.js +40 -40
  495. package/src/form/widget/providers/checkBox.js +138 -138
  496. package/src/form/widget/providers/comboBox.js +63 -63
  497. package/src/form/widget/providers/default.js +90 -90
  498. package/src/form/widget/providers/hidden.js +62 -62
  499. package/src/form/widget/providers/hiddenBox.js +152 -152
  500. package/src/form/widget/providers/radioBox.js +99 -99
  501. package/src/form/widget/providers/textArea.js +52 -52
  502. package/src/form/widget/providers/textBox.js +48 -48
  503. package/src/form/widget/scss/widget.scss +55 -55
  504. package/src/form/widget/tpl/checkBox.tpl +25 -25
  505. package/src/form/widget/tpl/comboBox.tpl +13 -13
  506. package/src/form/widget/tpl/hidden.tpl +1 -1
  507. package/src/form/widget/tpl/hiddenBox.tpl +17 -17
  508. package/src/form/widget/tpl/label.tpl +6 -6
  509. package/src/form/widget/tpl/radioBox.tpl +25 -25
  510. package/src/form/widget/tpl/textArea.tpl +8 -8
  511. package/src/form/widget/tpl/widget.tpl +8 -8
  512. package/src/form/widget/widget.js +372 -372
  513. package/src/form.js +53 -53
  514. package/src/formValidator/formValidator.js +253 -253
  515. package/src/formValidator/highlighters/highlighter.js +102 -102
  516. package/src/formValidator/highlighters/message.js +70 -70
  517. package/src/formValidator/highlighters/tooltip.js +78 -78
  518. package/src/generis/form/css/form.css +7 -7
  519. package/src/generis/form/css/form.css.map +1 -1
  520. package/src/generis/form/form.js +239 -239
  521. package/src/generis/form/readme.md +70 -70
  522. package/src/generis/form/scss/form.scss +23 -23
  523. package/src/generis/form/tpl/form.tpl +16 -16
  524. package/src/generis/validator/css/validator.css +7 -7
  525. package/src/generis/validator/css/validator.css.map +1 -1
  526. package/src/generis/validator/readme.md +46 -46
  527. package/src/generis/validator/scss/validator.scss +13 -13
  528. package/src/generis/validator/validator.js +128 -128
  529. package/src/generis/widget/checkBox/checkBox.js +112 -112
  530. package/src/generis/widget/checkBox/checkBox.tpl +18 -18
  531. package/src/generis/widget/comboBox/comboBox.js +67 -67
  532. package/src/generis/widget/comboBox/comboBox.tpl +12 -12
  533. package/src/generis/widget/css/widget.css +7 -7
  534. package/src/generis/widget/css/widget.css.map +1 -1
  535. package/src/generis/widget/hiddenBox/hiddenBox.js +132 -132
  536. package/src/generis/widget/hiddenBox/hiddenBox.tpl +16 -16
  537. package/src/generis/widget/loader.js +49 -49
  538. package/src/generis/widget/readme.md +59 -59
  539. package/src/generis/widget/scss/widget.scss +61 -61
  540. package/src/generis/widget/textBox/textBox.js +65 -65
  541. package/src/generis/widget/textBox/textBox.tpl +7 -7
  542. package/src/generis/widget/widget.js +164 -164
  543. package/src/generis/widget/widget.tpl +5 -5
  544. package/src/groupedComboBox.js +99 -99
  545. package/src/groupvalidator.js +84 -84
  546. package/src/hider.js +88 -88
  547. package/src/highlighter.js +1166 -1166
  548. package/src/image/ImgStateActive/extractLabel.js +29 -29
  549. package/src/image/ImgStateActive/helper.js +36 -36
  550. package/src/image/ImgStateActive/initHelper.js +137 -137
  551. package/src/image/ImgStateActive/initMediaEditor.js +92 -92
  552. package/src/image/ImgStateActive/mediaSizer.js +63 -63
  553. package/src/image/ImgStateActive.js +115 -115
  554. package/src/incrementer.js +319 -319
  555. package/src/inplacer.js +316 -316
  556. package/src/interactUtils.js +140 -140
  557. package/src/itemButtonList/css/item-button-list.css +23 -23
  558. package/src/itemButtonList/css/item-button-list.css.map +1 -1
  559. package/src/itemButtonList/scss/item-button-list.scss +236 -236
  560. package/src/itemButtonList/tpl/itemButtonList.tpl +21 -21
  561. package/src/itemButtonList.js +274 -274
  562. package/src/keyNavigation/navigableDomElement.js +282 -282
  563. package/src/keyNavigation/navigator.js +543 -543
  564. package/src/listbox/css/listbox.css +7 -7
  565. package/src/listbox/css/listbox.css.map +1 -1
  566. package/src/listbox/scss/listbox.scss +116 -116
  567. package/src/listbox/tpl/list.tpl +14 -14
  568. package/src/listbox/tpl/main.tpl +9 -9
  569. package/src/listbox.js +251 -251
  570. package/src/liststyler.js +155 -155
  571. package/src/loadingButton/css/button.css +7 -7
  572. package/src/loadingButton/css/button.css.map +1 -1
  573. package/src/loadingButton/loadingButton.js +110 -110
  574. package/src/loadingButton/scss/button.scss +41 -41
  575. package/src/loadingButton/tpl/button.tpl +5 -5
  576. package/src/lock/lock.tpl +16 -16
  577. package/src/lock.js +395 -395
  578. package/src/login/login.js +322 -322
  579. package/src/login/tpl/login.tpl +29 -29
  580. package/src/login/tpl/passwordReveal.tpl +7 -7
  581. package/src/maths/calculator/basicCalculator.js +55 -55
  582. package/src/maths/calculator/calculatorComponent.js +128 -128
  583. package/src/maths/calculator/core/areaBroker.js +38 -38
  584. package/src/maths/calculator/core/board.js +841 -841
  585. package/src/maths/calculator/core/expression.js +430 -430
  586. package/src/maths/calculator/core/labels.js +116 -116
  587. package/src/maths/calculator/core/plugin.js +40 -40
  588. package/src/maths/calculator/core/terms.js +459 -459
  589. package/src/maths/calculator/core/tokenizer.js +245 -245
  590. package/src/maths/calculator/core/tokens.js +178 -178
  591. package/src/maths/calculator/core/tpl/board.tpl +4 -4
  592. package/src/maths/calculator/css/calculator.css +7 -7
  593. package/src/maths/calculator/css/calculator.css.map +1 -1
  594. package/src/maths/calculator/defaultCalculator.js +66 -66
  595. package/src/maths/calculator/plugins/core/degrad.js +90 -90
  596. package/src/maths/calculator/plugins/core/history.js +166 -166
  597. package/src/maths/calculator/plugins/core/remind.js +96 -96
  598. package/src/maths/calculator/plugins/core/stepNavigation.js +175 -175
  599. package/src/maths/calculator/plugins/keyboard/templateKeyboard/defaultTemplate.tpl +36 -36
  600. package/src/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +91 -91
  601. package/src/maths/calculator/plugins/modifiers/pow10.js +143 -143
  602. package/src/maths/calculator/plugins/modifiers/sign.js +339 -339
  603. package/src/maths/calculator/plugins/screen/simpleScreen/defaultTemplate.tpl +3 -3
  604. package/src/maths/calculator/plugins/screen/simpleScreen/history.tpl +3 -3
  605. package/src/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +191 -191
  606. package/src/maths/calculator/pluginsLoader.js +46 -46
  607. package/src/maths/calculator/scientificCalculator.js +74 -74
  608. package/src/maths/calculator/scss/calculator.scss +396 -396
  609. package/src/maths/calculator/tpl/basicKeyboard.tpl +37 -37
  610. package/src/maths/calculator/tpl/basicScreen.tpl +2 -2
  611. package/src/maths/calculator/tpl/scientificKeyboard.tpl +61 -61
  612. package/src/maths/calculator/tpl/scientificScreen.tpl +3 -3
  613. package/src/mediaEditor/mediaEditorComponent.js +141 -141
  614. package/src/mediaEditor/plugins/mediaAlignment/helper.js +62 -62
  615. package/src/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +99 -99
  616. package/src/mediaEditor/plugins/mediaAlignment/style.css +7 -7
  617. package/src/mediaEditor/plugins/mediaAlignment/tpl/mediaAlignment.tpl +25 -25
  618. package/src/mediaEditor/plugins/mediaDimension/helper.js +189 -189
  619. package/src/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +561 -561
  620. package/src/mediaEditor/plugins/mediaDimension/style.css +141 -141
  621. package/src/mediaEditor/plugins/mediaDimension/tpl/mediaDimension.tpl +55 -55
  622. package/src/mediaEditor/tpl/editor.tpl +4 -4
  623. package/src/mediaplayer/css/player.css +31 -7
  624. package/src/mediaplayer/css/player.css.map +1 -1
  625. package/src/mediaplayer/players/html5.js +564 -564
  626. package/src/mediaplayer/players/youtube.js +323 -323
  627. package/src/mediaplayer/players.js +29 -29
  628. package/src/mediaplayer/readme.md +305 -305
  629. package/src/mediaplayer/scss/player.scss +569 -540
  630. package/src/mediaplayer/support.js +126 -126
  631. package/src/mediaplayer/tpl/audio.tpl +6 -6
  632. package/src/mediaplayer/tpl/player.tpl +37 -37
  633. package/src/mediaplayer/tpl/source.tpl +1 -1
  634. package/src/mediaplayer/tpl/video.tpl +6 -6
  635. package/src/mediaplayer/tpl/youtube.tpl +1 -1
  636. package/src/mediaplayer/utils/reminder.js +184 -184
  637. package/src/mediaplayer/utils/timeObserver.js +143 -143
  638. package/src/mediaplayer/youtubeManager.js +161 -161
  639. package/src/mediaplayer.js +1606 -1606
  640. package/src/mediasizer/mediasizer.tpl +55 -55
  641. package/src/mediasizer.js +635 -635
  642. package/src/modal.js +365 -365
  643. package/src/movableComponent.js +78 -78
  644. package/src/pageSizeSelector/tpl/pageSizeSelector.tpl +9 -9
  645. package/src/pageSizeSelector.js +107 -107
  646. package/src/pageStatus.js +147 -147
  647. package/src/pagination/css/pagination.css +7 -7
  648. package/src/pagination/css/pagination.css.map +1 -1
  649. package/src/pagination/paginationStrategy.js +53 -53
  650. package/src/pagination/providers/pages.js +161 -161
  651. package/src/pagination/providers/simple.js +74 -74
  652. package/src/pagination/providers/tpl/pages/page.tpl +1 -1
  653. package/src/pagination/providers/tpl/pages.tpl +8 -8
  654. package/src/pagination/providers/tpl/simple.tpl +7 -7
  655. package/src/pagination/scss/pagination.scss +111 -111
  656. package/src/pagination.js +237 -237
  657. package/src/previewer.js +300 -300
  658. package/src/progressbar.js +165 -165
  659. package/src/report/feedback.tpl +11 -11
  660. package/src/report/layout.tpl +10 -10
  661. package/src/report.js +184 -184
  662. package/src/resource/css/selector.css +7 -7
  663. package/src/resource/css/selector.css.map +1 -1
  664. package/src/resource/filters.js +208 -208
  665. package/src/resource/list.js +200 -200
  666. package/src/resource/scss/_filters.scss +26 -26
  667. package/src/resource/scss/_resource-list.scss +107 -107
  668. package/src/resource/scss/_resource-tree.scss +205 -205
  669. package/src/resource/scss/selector.scss +187 -187
  670. package/src/resource/selectable.js +322 -322
  671. package/src/resource/selector.js +871 -871
  672. package/src/resource/tpl/filters.tpl +2 -2
  673. package/src/resource/tpl/list.tpl +7 -7
  674. package/src/resource/tpl/listNode.tpl +4 -4
  675. package/src/resource/tpl/selector.tpl +46 -46
  676. package/src/resource/tpl/tree.tpl +4 -4
  677. package/src/resource/tpl/treeNode.tpl +30 -30
  678. package/src/resource/tree.js +400 -400
  679. package/src/resourcemgr/css/resourcemgr.css +7 -7
  680. package/src/resourcemgr/css/resourcemgr.css.map +1 -1
  681. package/src/resourcemgr/fileBrowser.js +381 -381
  682. package/src/resourcemgr/filePreview.js +73 -73
  683. package/src/resourcemgr/fileSelector.js +348 -348
  684. package/src/resourcemgr/scss/resourcemgr.scss +254 -254
  685. package/src/resourcemgr/tpl/fileSelect.tpl +39 -39
  686. package/src/resourcemgr/tpl/folder.tpl +11 -11
  687. package/src/resourcemgr/tpl/layout.tpl +84 -84
  688. package/src/resourcemgr/tpl/rootFolder.tpl +13 -13
  689. package/src/resourcemgr/util/updatePermissions.js +53 -53
  690. package/src/resourcemgr.js +216 -216
  691. package/src/scroller.js +94 -94
  692. package/src/scss/basic.scss +16 -16
  693. package/src/searchModal/advancedSearch.js +601 -601
  694. package/src/searchModal/css/advancedSearch.css +7 -7
  695. package/src/searchModal/css/advancedSearch.css.map +1 -1
  696. package/src/searchModal/css/searchModal.css +7 -7
  697. package/src/searchModal/css/searchModal.css.map +1 -1
  698. package/src/searchModal/scss/advancedSearch.scss +177 -177
  699. package/src/searchModal/scss/searchModal.scss +375 -375
  700. package/src/searchModal/tpl/advanced-search.tpl +9 -9
  701. package/src/searchModal/tpl/info-message.tpl +3 -3
  702. package/src/searchModal/tpl/invalid-criteria-warning.tpl +10 -10
  703. package/src/searchModal/tpl/layout.tpl +25 -25
  704. package/src/searchModal/tpl/list-checkbox-criterion.tpl +12 -12
  705. package/src/searchModal/tpl/list-select-criterion.tpl +6 -6
  706. package/src/searchModal/tpl/text-criterion.tpl +6 -6
  707. package/src/searchModal.js +496 -496
  708. package/src/selecter.js +43 -43
  709. package/src/stacker.js +133 -133
  710. package/src/switch/css/switch.css +7 -7
  711. package/src/switch/css/switch.css.map +1 -1
  712. package/src/switch/scss/switch.scss +83 -83
  713. package/src/switch/switch.js +195 -195
  714. package/src/switch/tpl/switch.tpl +7 -7
  715. package/src/tableModel.js +112 -112
  716. package/src/tabs/css/tabs.css +12 -12
  717. package/src/tabs/css/tabs.css.map +1 -1
  718. package/src/tabs/scss/tabs.scss +50 -50
  719. package/src/tabs/tpl/panel.tpl +3 -3
  720. package/src/tabs/tpl/tabs.tpl +10 -10
  721. package/src/tabs.js +528 -528
  722. package/src/taskQueue/css/taskQueue.css +7 -7
  723. package/src/taskQueue/css/taskQueue.css.map +1 -1
  724. package/src/taskQueue/scss/taskQueue.scss +47 -47
  725. package/src/taskQueue/status.js +228 -228
  726. package/src/taskQueue/table.js +350 -350
  727. package/src/taskQueue/taskQueue.js +33 -33
  728. package/src/taskQueue/taskQueueModel.js +548 -548
  729. package/src/taskQueue/tpl/statusMessage.tpl +7 -7
  730. package/src/taskQueue.js +218 -218
  731. package/src/taskQueueButton/css/taskable.css +7 -7
  732. package/src/taskQueueButton/css/taskable.css.map +1 -1
  733. package/src/taskQueueButton/css/treeButton.css +7 -7
  734. package/src/taskQueueButton/css/treeButton.css.map +1 -1
  735. package/src/taskQueueButton/scss/taskable.scss +4 -4
  736. package/src/taskQueueButton/scss/treeButton.scss +34 -34
  737. package/src/taskQueueButton/standardButton.js +108 -108
  738. package/src/taskQueueButton/taskable.js +202 -202
  739. package/src/taskQueueButton/tpl/report.tpl +5 -5
  740. package/src/taskQueueButton/tpl/treeButton.tpl +6 -6
  741. package/src/taskQueueButton/treeButton.js +109 -109
  742. package/src/themeLoader.js +252 -252
  743. package/src/themes.js +162 -162
  744. package/src/toggler.js +200 -200
  745. package/src/tooltip/default.tpl +3 -3
  746. package/src/tooltip.js +160 -160
  747. package/src/tooltipster.js +25 -25
  748. package/src/transformer.js +327 -327
  749. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  750. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  751. package/src/tristateCheckboxGroup/scss/tristateCheckboxGroup.scss +15 -15
  752. package/src/tristateCheckboxGroup/tpl/li.tpl +6 -6
  753. package/src/tristateCheckboxGroup.js +207 -207
  754. package/src/uploader/fileEntry.tpl +6 -6
  755. package/src/uploader/uploader.tpl +32 -32
  756. package/src/uploader.js +594 -594
  757. package/src/validator/Report.js +10 -10
  758. package/src/validator/Validator.js +108 -108
  759. package/src/validator/validators.js +220 -220
  760. package/src/validator.js +264 -264
  761. package/src/waitForMedia.js +82 -82
  762. package/src/waitingDialog/css/waitingDialog.css +7 -7
  763. package/src/waitingDialog/css/waitingDialog.css.map +1 -1
  764. package/src/waitingDialog/scss/waitingDialog.scss +34 -34
  765. package/src/waitingDialog/waitingDialog.js +240 -240
package/src/dialog.js CHANGED
@@ -1,517 +1,517 @@
1
- /**
2
- * This program is free software; you can redistribute it and/or
3
- * modify it under the terms of the GNU General Public License
4
- * as published by the Free Software Foundation; under version 2
5
- * of the License (non-upgradable).
6
- *
7
- * This program is distributed in the hope that it will be useful,
8
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
9
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
- * GNU General Public License for more details.
11
- *
12
- * You should have received a copy of the GNU General Public License
13
- * along with this program; if not, write to the Free Software
14
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15
- *
16
- * Copyright (c) 2015-2019 (original work) Open Assessment Technologies SA ;
17
- */
18
- /**
19
- * Create a modal dialog component
20
- *
21
- *
22
- * TODO move to ui/component
23
- * TODO use core/eventifier
24
- *
25
- *
26
- * @author Jean-Sébastien Conan <jean-sebastien.conan@vesperiagroup.com>
27
- */
28
- import $ from 'jquery';
29
- import _ from 'lodash';
30
- import __ from 'i18n';
31
- import bodyTpl from 'ui/dialog/tpl/body';
32
- import buttonsTpl from 'ui/dialog/tpl/buttons';
33
- import keyNavigator from 'ui/keyNavigation/navigator';
34
- import navigableDomElement from 'ui/keyNavigation/navigableDomElement';
35
- import shortcutRegistry from 'util/shortcut/registry';
36
- import 'ui/modal';
37
-
38
- /**
39
- * The scope of events names
40
- * @type {string}
41
- */
42
- const _scope = '.modal';
43
-
44
- /**
45
- * A list of predefined buttons
46
- * @type {Object}
47
- */
48
- const _definedButtons = {
49
- ok: {
50
- id: 'ok',
51
- type: 'info',
52
- label: __('Ok'),
53
- close: true
54
- },
55
-
56
- cancel: {
57
- id: 'cancel',
58
- type: 'regular',
59
- label: __('Cancel'),
60
- close: true
61
- },
62
-
63
- yes: {
64
- id: 'yes',
65
- type: 'info',
66
- label: __('Yes'),
67
- close: true
68
- },
69
-
70
- no: {
71
- id: 'no',
72
- type: 'regular',
73
- label: __('No'),
74
- close: true
75
- }
76
- };
77
-
78
- /**
79
- * The defaults fields values
80
- * @type {Object}
81
- */
82
- const _defaults = {
83
- message: '',
84
- content: '',
85
- width: 500,
86
- animate: false,
87
- autoRender: false,
88
- autoDestroy: false,
89
- renderTo: 'body',
90
- buttons: 'cancel,ok'
91
- };
92
-
93
- /**
94
- * Define a dialog box
95
- * @type {Object}
96
- */
97
- const dialog = {
98
- /**
99
- * Initialise the dialog box.
100
- * @param {Object} options - A list of options.
101
- * @param {String} options.heading - An optional heading to display.
102
- * @param {String} options.message - The message to display.
103
- * @param {String} options.content - An optional content to display under the displayed message.
104
- * @param {String} options.class - Space-separated string of classes to add to the root HTML element
105
- * @param {Array|Object|String} options.buttons - A list of buttons to display (default: 'cancel,ok'). Can be:
106
- * - a string: the button names separated by commas
107
- * - an array: an array of button names or an array of button definitions
108
- * - an object: a unique button definition, containing:
109
- * - id: The button's id
110
- * - type: A display type (regular, info, warning, error)
111
- * - label: The button's caption
112
- * - icon: An optional icon
113
- * - close: A boolean value telling if the dialog must be closed after the button has been activated
114
- * @param {String|jQuery|HTMLElement} options.renderTo - A container in which renders the dialog (default: 'body').
115
- * @param {Boolean} options.autoRender - Allow the dialog to be immediately rendered after initialise.
116
- * @param {Boolean} options.autoDestroy - Allow the dialog to be immediately destroyed when closing.
117
- * @param {Boolean} [options.disableClosing = false] - to disable the default closers
118
- * @param {Boolean} [options.disableEscape = false] - to disable the ability to escape close the dialog
119
- * @param {Number} options.width - The dialog box width in pixels (default: 500).
120
- * @param {Number|Boolean} options.animate - The dialog box animate duration (default: false).
121
- * @param {Function} options.onXYZbtn - An event handler assigned to a particular button (XYZ).
122
- * @returns {dialog}
123
- */
124
- init(options) {
125
- // split options to events
126
- const events = {};
127
- const initOptions = _.omit(options || {}, (value, key) => {
128
- if (key.length > 2 && 'on' === key.substr(0, 2)) {
129
- events[key.substr(2)] = value;
130
- return true;
131
- }
132
- return false;
133
- });
134
-
135
- // assign default values and options
136
- _.defaults(this, initOptions, _defaults);
137
-
138
- // pre-render the dialog box
139
- this.dialogId = _.uniqueId('dlg-');
140
- this.$html = $(bodyTpl(this));
141
- this.$buttons = this.$html.find('.buttons');
142
- this.rendered = false;
143
- this.destroyed = false;
144
-
145
- // install the buttons and bind the actions
146
- this.$buttons.on('click' + _scope, 'button', this._onButtonClick.bind(this));
147
- this.setButtons(this.buttons);
148
-
149
- // install the events extracted from the options
150
- _.forEach(events, (callback, eventName) => {
151
- if (eventName.indexOf('.') < 0) {
152
- eventName += _scope;
153
- }
154
- this.on(eventName.toLowerCase(), callback);
155
- });
156
-
157
- if (this.autoRender) {
158
- this.render();
159
- }
160
-
161
- return this;
162
- },
163
-
164
- /**
165
- * Destroys the dialog box
166
- * @returns {dialog}
167
- * @fires dialog#destroy.modal
168
- */
169
- destroy() {
170
- if (!this.destroyed) {
171
- this._destroy();
172
-
173
- // reset the context
174
- this.rendered = false;
175
- this.destroyed = true;
176
-
177
- this.trigger('destroy' + _scope);
178
-
179
- // disable events and remove DOM
180
- this.$buttons.off(_scope);
181
- this.$html.off(_scope).remove();
182
- this.$html = null;
183
- this.$buttons = null;
184
- }
185
-
186
- return this;
187
- },
188
-
189
- /**
190
- * Set the action buttons
191
- * @param {Object|Array|String} buttons
192
- * @returns {dialog}
193
- */
194
- setButtons(buttons) {
195
- if (!this.destroyed) {
196
- if (!buttons) {
197
- buttons = _defaults.buttons;
198
- }
199
-
200
- if (!_.isArray(buttons)) {
201
- // buttons can be set as a list of names
202
- if (_.isString(buttons)) {
203
- buttons = buttons.split(',');
204
- }
205
- }
206
-
207
- // bind the buttons with
208
- this.buttons = {};
209
- _.forEach(buttons, btn => {
210
- if (_.isString(btn)) {
211
- btn = btn.trim();
212
- btn = _definedButtons[btn] || {
213
- id: btn,
214
- type: 'info',
215
- label: btn
216
- };
217
- }
218
- if (!btn.type) {
219
- btn.type = 'regular';
220
- }
221
- this.buttons[btn.id] = btn;
222
- });
223
-
224
- this.$buttons.html(buttonsTpl(this));
225
- }
226
-
227
- return this;
228
- },
229
-
230
- /**
231
- * Renders and shows the dialog box
232
- * @param {String|HTMLElement|jQuery} [to]
233
- * @returns {dialog}
234
- * @fires modal#create.modal
235
- */
236
- render(to) {
237
- if (!this.destroyed) {
238
- $(to || this.renderTo).append(this.$html);
239
- this._install();
240
- this.rendered = true;
241
- }
242
- return this;
243
- },
244
-
245
- /**
246
- * Shows the dialog box. Also renders if needed.
247
- * @returns {dialog}
248
- * @fires modal#opened.modal
249
- */
250
- show() {
251
- if (!this.destroyed) {
252
- if (!this.rendered) {
253
- this.render();
254
- } else {
255
- this._open();
256
- }
257
- }
258
- return this;
259
- },
260
-
261
- /**
262
- * Hides the dialog box. Does nothing if the dialog box has not been rendered.
263
- * @returns {dialog}
264
- * @fires modal#closed.modal
265
- */
266
- hide() {
267
- if (!this.destroyed && this.rendered) {
268
- this._close();
269
-
270
- if (this.autoDestroy) {
271
- this.destroy();
272
- }
273
- }
274
- return this;
275
- },
276
-
277
- /**
278
- * Install an event handler on the underlying DOM element
279
- * @param {String} eventName
280
- * @returns {dialog}
281
- */
282
- on(eventName) {
283
- if (this.$html) {
284
- this.$html.on.apply(this.$html, arguments);
285
- }
286
-
287
- return this;
288
- },
289
-
290
- /**
291
- * Uninstall an event handler from the underlying DOM element
292
- * @param {String} eventName
293
- * @returns {dialog}
294
- */
295
- off(eventName) {
296
- if (this.$html) {
297
- this.$html.off.apply(this.$html, arguments);
298
- }
299
-
300
- return this;
301
- },
302
-
303
- /**
304
- * Triggers an event on the underlying DOM element
305
- * @param {String} eventName
306
- * @param {Array|Object} extraParameters
307
- * @returns {dialog}
308
- */
309
- trigger(eventName, extraParameters) {
310
- if (this.$html) {
311
- if (undefined === extraParameters) {
312
- extraParameters = [];
313
- }
314
- if (!_.isArray(extraParameters)) {
315
- extraParameters = [extraParameters];
316
- }
317
-
318
- extraParameters = Array.prototype.slice.call(extraParameters);
319
- extraParameters.push(this);
320
-
321
- this.$html.trigger(eventName, extraParameters);
322
- }
323
-
324
- return this;
325
- },
326
-
327
- /**
328
- * Gets the underlying DOM element
329
- * @returns {jQuery}
330
- */
331
- getDom() {
332
- return this.$html;
333
- },
334
-
335
- /**
336
- * Called when button is clicked.
337
- * Executes a button related action
338
- * @param {Event} event
339
- * @private
340
- */
341
- _onButtonClick(event) {
342
- const $btn = $(event.target).closest('button');
343
- const id = $btn.data('control');
344
- const btn = this.buttons[id];
345
-
346
- if (btn) {
347
- this._execute(btn);
348
- }
349
- },
350
-
351
- /**
352
- * Execute a button related action
353
- * @param {Object} btn
354
- * @private
355
- * @fires dialog#[button.id]btn.modal
356
- */
357
- _execute(btn) {
358
- // call the optional callback
359
- if (btn.action) {
360
- btn.action.apply(this, [btn, this]);
361
- }
362
-
363
- /**
364
- * Fires the event based on the button name
365
- * @event dialog#[button.id]btn.modal
366
- * @param {Object} btn - The related button
367
- */
368
- this.trigger(btn.id + 'btn' + _scope, [btn]);
369
-
370
- // auto close the dialog box if the button allows it
371
- if (btn.close) {
372
- this.hide();
373
- }
374
- },
375
-
376
- /**
377
- * Set focus on the dialog
378
- * @param {String} [button] - The identifier of the button to focus. If none is provided, the focus will be put
379
- * on the first navigable element.
380
- */
381
- focus(button) {
382
- let position = -1;
383
- if (button) {
384
- position = _.findIndex(this.navigator.getNavigableElements(), navigable => {
385
- return navigable.getElement().is('[data-control="' + button + '"]');
386
- });
387
- }
388
- if (position >= 0) {
389
- this.navigator.setCursorAt(position);
390
- } else {
391
- this.navigator.focus();
392
- }
393
- },
394
-
395
- /**
396
- * Installs the dialog box
397
- * @private
398
- * #fires dialog#create.dialog
399
- */
400
- _install() {
401
- if (!this.destroyed) {
402
- this.$html
403
- .modal({
404
- width: this.width,
405
- animate: this.animate,
406
- disableClosing: this.disableClosing,
407
- disableEscape: this.disableEscape
408
- })
409
- .on('closed' + _scope, () => {
410
- if (this.autoDestroy) {
411
- this.destroy();
412
- }
413
- });
414
- const $items = this.getDom()
415
- .add($(_scope).find('input'))
416
- .add(this.$buttons.find('button'));
417
- const closeButton = $(_scope).find('#modal-close-btn')[0];
418
-
419
- if (closeButton) {
420
- $items.push(closeButton);
421
- }
422
-
423
- //creates the navigator to manage the key navigation
424
- this.navigator = keyNavigator({
425
- elements: navigableDomElement.createFromDoms($items),
426
- propagateTab: false
427
- })
428
- .on('right down', function() {
429
- if (this.getCursor().position === $items.length - 1) {
430
- this.setCursorAt(1); // Skip container.
431
- } else {
432
- this.next();
433
- }
434
- })
435
- .on('left up', function() {
436
- if (this.getCursor().position === 1) { // Skip container.
437
- this.last();
438
- } else {
439
- this.previous();
440
- }
441
- })
442
- .on('tab', function() {
443
- if (this.getCursor().position === $items.length - 1) {
444
- this.setCursorAt(1); // Skip container.
445
- } else {
446
- this.next();
447
- }
448
- })
449
- .on('shift+tab', function() {
450
- if (this.getCursor().position === 1) { // Skip container.
451
- this.last();
452
- } else {
453
- this.previous();
454
- }
455
- })
456
- .on('activate', _.debounce(function(cursor) {
457
- const $elt = cursor.navigable.getElement();
458
- if (!$elt.is(':radio,:checkbox')) {
459
- $elt.click();
460
- } else {
461
- $elt.prop('checked', !$elt.prop('checked')).change();
462
- }
463
- }, 10)
464
- );
465
- this.navigator.first();
466
- //added a global shortcut to enable setting focus on tab
467
- this.globalShortcut = shortcutRegistry($('body')).add('tab shift+tab', () => {
468
- if (!this.navigator.isFocused()) {
469
- this.navigator.focus();
470
- }
471
- });
472
-
473
- this.trigger('create.dialog');
474
- }
475
- },
476
-
477
- /**
478
- * Opens the dialog box
479
- * @private
480
- */
481
- _open() {
482
- this.$html.modal('open');
483
- },
484
-
485
- /**
486
- * Closes the dialog box
487
- * @private
488
- */
489
- _close() {
490
- this.$html.modal('close');
491
- },
492
-
493
- /**
494
- * Destroys the dialog box
495
- * @private
496
- */
497
- _destroy() {
498
- this.$html.modal('destroy');
499
- if (this.navigator) {
500
- this.navigator.destroy();
501
- }
502
- if (this.globalShortcut) {
503
- this.globalShortcut.clear();
504
- }
505
- }
506
- };
507
-
508
- /**
509
- * Builds a dialog box instance
510
- * @param {Object} options
511
- * @returns {dialog}
512
- */
513
- export default function dialogFactory(options) {
514
- const instance = Object.assign({}, dialog);
515
- instance.init(options);
516
- return instance;
517
- };
1
+ /**
2
+ * This program is free software; you can redistribute it and/or
3
+ * modify it under the terms of the GNU General Public License
4
+ * as published by the Free Software Foundation; under version 2
5
+ * of the License (non-upgradable).
6
+ *
7
+ * This program is distributed in the hope that it will be useful,
8
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
9
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10
+ * GNU General Public License for more details.
11
+ *
12
+ * You should have received a copy of the GNU General Public License
13
+ * along with this program; if not, write to the Free Software
14
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
15
+ *
16
+ * Copyright (c) 2015-2019 (original work) Open Assessment Technologies SA ;
17
+ */
18
+ /**
19
+ * Create a modal dialog component
20
+ *
21
+ *
22
+ * TODO move to ui/component
23
+ * TODO use core/eventifier
24
+ *
25
+ *
26
+ * @author Jean-Sébastien Conan <jean-sebastien.conan@vesperiagroup.com>
27
+ */
28
+ import $ from 'jquery';
29
+ import _ from 'lodash';
30
+ import __ from 'i18n';
31
+ import bodyTpl from 'ui/dialog/tpl/body';
32
+ import buttonsTpl from 'ui/dialog/tpl/buttons';
33
+ import keyNavigator from 'ui/keyNavigation/navigator';
34
+ import navigableDomElement from 'ui/keyNavigation/navigableDomElement';
35
+ import shortcutRegistry from 'util/shortcut/registry';
36
+ import 'ui/modal';
37
+
38
+ /**
39
+ * The scope of events names
40
+ * @type {string}
41
+ */
42
+ const _scope = '.modal';
43
+
44
+ /**
45
+ * A list of predefined buttons
46
+ * @type {Object}
47
+ */
48
+ const _definedButtons = {
49
+ ok: {
50
+ id: 'ok',
51
+ type: 'info',
52
+ label: __('Ok'),
53
+ close: true
54
+ },
55
+
56
+ cancel: {
57
+ id: 'cancel',
58
+ type: 'regular',
59
+ label: __('Cancel'),
60
+ close: true
61
+ },
62
+
63
+ yes: {
64
+ id: 'yes',
65
+ type: 'info',
66
+ label: __('Yes'),
67
+ close: true
68
+ },
69
+
70
+ no: {
71
+ id: 'no',
72
+ type: 'regular',
73
+ label: __('No'),
74
+ close: true
75
+ }
76
+ };
77
+
78
+ /**
79
+ * The defaults fields values
80
+ * @type {Object}
81
+ */
82
+ const _defaults = {
83
+ message: '',
84
+ content: '',
85
+ width: 500,
86
+ animate: false,
87
+ autoRender: false,
88
+ autoDestroy: false,
89
+ renderTo: 'body',
90
+ buttons: 'cancel,ok'
91
+ };
92
+
93
+ /**
94
+ * Define a dialog box
95
+ * @type {Object}
96
+ */
97
+ const dialog = {
98
+ /**
99
+ * Initialise the dialog box.
100
+ * @param {Object} options - A list of options.
101
+ * @param {String} options.heading - An optional heading to display.
102
+ * @param {String} options.message - The message to display.
103
+ * @param {String} options.content - An optional content to display under the displayed message.
104
+ * @param {String} options.class - Space-separated string of classes to add to the root HTML element
105
+ * @param {Array|Object|String} options.buttons - A list of buttons to display (default: 'cancel,ok'). Can be:
106
+ * - a string: the button names separated by commas
107
+ * - an array: an array of button names or an array of button definitions
108
+ * - an object: a unique button definition, containing:
109
+ * - id: The button's id
110
+ * - type: A display type (regular, info, warning, error)
111
+ * - label: The button's caption
112
+ * - icon: An optional icon
113
+ * - close: A boolean value telling if the dialog must be closed after the button has been activated
114
+ * @param {String|jQuery|HTMLElement} options.renderTo - A container in which renders the dialog (default: 'body').
115
+ * @param {Boolean} options.autoRender - Allow the dialog to be immediately rendered after initialise.
116
+ * @param {Boolean} options.autoDestroy - Allow the dialog to be immediately destroyed when closing.
117
+ * @param {Boolean} [options.disableClosing = false] - to disable the default closers
118
+ * @param {Boolean} [options.disableEscape = false] - to disable the ability to escape close the dialog
119
+ * @param {Number} options.width - The dialog box width in pixels (default: 500).
120
+ * @param {Number|Boolean} options.animate - The dialog box animate duration (default: false).
121
+ * @param {Function} options.onXYZbtn - An event handler assigned to a particular button (XYZ).
122
+ * @returns {dialog}
123
+ */
124
+ init(options) {
125
+ // split options to events
126
+ const events = {};
127
+ const initOptions = _.omit(options || {}, (value, key) => {
128
+ if (key.length > 2 && 'on' === key.substr(0, 2)) {
129
+ events[key.substr(2)] = value;
130
+ return true;
131
+ }
132
+ return false;
133
+ });
134
+
135
+ // assign default values and options
136
+ _.defaults(this, initOptions, _defaults);
137
+
138
+ // pre-render the dialog box
139
+ this.dialogId = _.uniqueId('dlg-');
140
+ this.$html = $(bodyTpl(this));
141
+ this.$buttons = this.$html.find('.buttons');
142
+ this.rendered = false;
143
+ this.destroyed = false;
144
+
145
+ // install the buttons and bind the actions
146
+ this.$buttons.on('click' + _scope, 'button', this._onButtonClick.bind(this));
147
+ this.setButtons(this.buttons);
148
+
149
+ // install the events extracted from the options
150
+ _.forEach(events, (callback, eventName) => {
151
+ if (eventName.indexOf('.') < 0) {
152
+ eventName += _scope;
153
+ }
154
+ this.on(eventName.toLowerCase(), callback);
155
+ });
156
+
157
+ if (this.autoRender) {
158
+ this.render();
159
+ }
160
+
161
+ return this;
162
+ },
163
+
164
+ /**
165
+ * Destroys the dialog box
166
+ * @returns {dialog}
167
+ * @fires dialog#destroy.modal
168
+ */
169
+ destroy() {
170
+ if (!this.destroyed) {
171
+ this._destroy();
172
+
173
+ // reset the context
174
+ this.rendered = false;
175
+ this.destroyed = true;
176
+
177
+ this.trigger('destroy' + _scope);
178
+
179
+ // disable events and remove DOM
180
+ this.$buttons.off(_scope);
181
+ this.$html.off(_scope).remove();
182
+ this.$html = null;
183
+ this.$buttons = null;
184
+ }
185
+
186
+ return this;
187
+ },
188
+
189
+ /**
190
+ * Set the action buttons
191
+ * @param {Object|Array|String} buttons
192
+ * @returns {dialog}
193
+ */
194
+ setButtons(buttons) {
195
+ if (!this.destroyed) {
196
+ if (!buttons) {
197
+ buttons = _defaults.buttons;
198
+ }
199
+
200
+ if (!_.isArray(buttons)) {
201
+ // buttons can be set as a list of names
202
+ if (_.isString(buttons)) {
203
+ buttons = buttons.split(',');
204
+ }
205
+ }
206
+
207
+ // bind the buttons with
208
+ this.buttons = {};
209
+ _.forEach(buttons, btn => {
210
+ if (_.isString(btn)) {
211
+ btn = btn.trim();
212
+ btn = _definedButtons[btn] || {
213
+ id: btn,
214
+ type: 'info',
215
+ label: btn
216
+ };
217
+ }
218
+ if (!btn.type) {
219
+ btn.type = 'regular';
220
+ }
221
+ this.buttons[btn.id] = btn;
222
+ });
223
+
224
+ this.$buttons.html(buttonsTpl(this));
225
+ }
226
+
227
+ return this;
228
+ },
229
+
230
+ /**
231
+ * Renders and shows the dialog box
232
+ * @param {String|HTMLElement|jQuery} [to]
233
+ * @returns {dialog}
234
+ * @fires modal#create.modal
235
+ */
236
+ render(to) {
237
+ if (!this.destroyed) {
238
+ $(to || this.renderTo).append(this.$html);
239
+ this._install();
240
+ this.rendered = true;
241
+ }
242
+ return this;
243
+ },
244
+
245
+ /**
246
+ * Shows the dialog box. Also renders if needed.
247
+ * @returns {dialog}
248
+ * @fires modal#opened.modal
249
+ */
250
+ show() {
251
+ if (!this.destroyed) {
252
+ if (!this.rendered) {
253
+ this.render();
254
+ } else {
255
+ this._open();
256
+ }
257
+ }
258
+ return this;
259
+ },
260
+
261
+ /**
262
+ * Hides the dialog box. Does nothing if the dialog box has not been rendered.
263
+ * @returns {dialog}
264
+ * @fires modal#closed.modal
265
+ */
266
+ hide() {
267
+ if (!this.destroyed && this.rendered) {
268
+ this._close();
269
+
270
+ if (this.autoDestroy) {
271
+ this.destroy();
272
+ }
273
+ }
274
+ return this;
275
+ },
276
+
277
+ /**
278
+ * Install an event handler on the underlying DOM element
279
+ * @param {String} eventName
280
+ * @returns {dialog}
281
+ */
282
+ on(eventName) {
283
+ if (this.$html) {
284
+ this.$html.on.apply(this.$html, arguments);
285
+ }
286
+
287
+ return this;
288
+ },
289
+
290
+ /**
291
+ * Uninstall an event handler from the underlying DOM element
292
+ * @param {String} eventName
293
+ * @returns {dialog}
294
+ */
295
+ off(eventName) {
296
+ if (this.$html) {
297
+ this.$html.off.apply(this.$html, arguments);
298
+ }
299
+
300
+ return this;
301
+ },
302
+
303
+ /**
304
+ * Triggers an event on the underlying DOM element
305
+ * @param {String} eventName
306
+ * @param {Array|Object} extraParameters
307
+ * @returns {dialog}
308
+ */
309
+ trigger(eventName, extraParameters) {
310
+ if (this.$html) {
311
+ if (undefined === extraParameters) {
312
+ extraParameters = [];
313
+ }
314
+ if (!_.isArray(extraParameters)) {
315
+ extraParameters = [extraParameters];
316
+ }
317
+
318
+ extraParameters = Array.prototype.slice.call(extraParameters);
319
+ extraParameters.push(this);
320
+
321
+ this.$html.trigger(eventName, extraParameters);
322
+ }
323
+
324
+ return this;
325
+ },
326
+
327
+ /**
328
+ * Gets the underlying DOM element
329
+ * @returns {jQuery}
330
+ */
331
+ getDom() {
332
+ return this.$html;
333
+ },
334
+
335
+ /**
336
+ * Called when button is clicked.
337
+ * Executes a button related action
338
+ * @param {Event} event
339
+ * @private
340
+ */
341
+ _onButtonClick(event) {
342
+ const $btn = $(event.target).closest('button');
343
+ const id = $btn.data('control');
344
+ const btn = this.buttons[id];
345
+
346
+ if (btn) {
347
+ this._execute(btn);
348
+ }
349
+ },
350
+
351
+ /**
352
+ * Execute a button related action
353
+ * @param {Object} btn
354
+ * @private
355
+ * @fires dialog#[button.id]btn.modal
356
+ */
357
+ _execute(btn) {
358
+ // call the optional callback
359
+ if (btn.action) {
360
+ btn.action.apply(this, [btn, this]);
361
+ }
362
+
363
+ /**
364
+ * Fires the event based on the button name
365
+ * @event dialog#[button.id]btn.modal
366
+ * @param {Object} btn - The related button
367
+ */
368
+ this.trigger(btn.id + 'btn' + _scope, [btn]);
369
+
370
+ // auto close the dialog box if the button allows it
371
+ if (btn.close) {
372
+ this.hide();
373
+ }
374
+ },
375
+
376
+ /**
377
+ * Set focus on the dialog
378
+ * @param {String} [button] - The identifier of the button to focus. If none is provided, the focus will be put
379
+ * on the first navigable element.
380
+ */
381
+ focus(button) {
382
+ let position = -1;
383
+ if (button) {
384
+ position = _.findIndex(this.navigator.getNavigableElements(), navigable => {
385
+ return navigable.getElement().is('[data-control="' + button + '"]');
386
+ });
387
+ }
388
+ if (position >= 0) {
389
+ this.navigator.setCursorAt(position);
390
+ } else {
391
+ this.navigator.focus();
392
+ }
393
+ },
394
+
395
+ /**
396
+ * Installs the dialog box
397
+ * @private
398
+ * #fires dialog#create.dialog
399
+ */
400
+ _install() {
401
+ if (!this.destroyed) {
402
+ this.$html
403
+ .modal({
404
+ width: this.width,
405
+ animate: this.animate,
406
+ disableClosing: this.disableClosing,
407
+ disableEscape: this.disableEscape
408
+ })
409
+ .on('closed' + _scope, () => {
410
+ if (this.autoDestroy) {
411
+ this.destroy();
412
+ }
413
+ });
414
+ const $items = this.getDom()
415
+ .add($(_scope).find('input'))
416
+ .add(this.$buttons.find('button'));
417
+ const closeButton = $(_scope).find('#modal-close-btn')[0];
418
+
419
+ if (closeButton) {
420
+ $items.push(closeButton);
421
+ }
422
+
423
+ //creates the navigator to manage the key navigation
424
+ this.navigator = keyNavigator({
425
+ elements: navigableDomElement.createFromDoms($items),
426
+ propagateTab: false
427
+ })
428
+ .on('right down', function() {
429
+ if (this.getCursor().position === $items.length - 1) {
430
+ this.setCursorAt(1); // Skip container.
431
+ } else {
432
+ this.next();
433
+ }
434
+ })
435
+ .on('left up', function() {
436
+ if (this.getCursor().position === 1) { // Skip container.
437
+ this.last();
438
+ } else {
439
+ this.previous();
440
+ }
441
+ })
442
+ .on('tab', function() {
443
+ if (this.getCursor().position === $items.length - 1) {
444
+ this.setCursorAt(1); // Skip container.
445
+ } else {
446
+ this.next();
447
+ }
448
+ })
449
+ .on('shift+tab', function() {
450
+ if (this.getCursor().position === 1) { // Skip container.
451
+ this.last();
452
+ } else {
453
+ this.previous();
454
+ }
455
+ })
456
+ .on('activate', _.debounce(function(cursor) {
457
+ const $elt = cursor.navigable.getElement();
458
+ if (!$elt.is(':radio,:checkbox')) {
459
+ $elt.click();
460
+ } else {
461
+ $elt.prop('checked', !$elt.prop('checked')).change();
462
+ }
463
+ }, 10)
464
+ );
465
+ this.navigator.first();
466
+ //added a global shortcut to enable setting focus on tab
467
+ this.globalShortcut = shortcutRegistry($('body')).add('tab shift+tab', () => {
468
+ if (!this.navigator.isFocused()) {
469
+ this.navigator.focus();
470
+ }
471
+ });
472
+
473
+ this.trigger('create.dialog');
474
+ }
475
+ },
476
+
477
+ /**
478
+ * Opens the dialog box
479
+ * @private
480
+ */
481
+ _open() {
482
+ this.$html.modal('open');
483
+ },
484
+
485
+ /**
486
+ * Closes the dialog box
487
+ * @private
488
+ */
489
+ _close() {
490
+ this.$html.modal('close');
491
+ },
492
+
493
+ /**
494
+ * Destroys the dialog box
495
+ * @private
496
+ */
497
+ _destroy() {
498
+ this.$html.modal('destroy');
499
+ if (this.navigator) {
500
+ this.navigator.destroy();
501
+ }
502
+ if (this.globalShortcut) {
503
+ this.globalShortcut.clear();
504
+ }
505
+ }
506
+ };
507
+
508
+ /**
509
+ * Builds a dialog box instance
510
+ * @param {Object} options
511
+ * @returns {dialog}
512
+ */
513
+ export default function dialogFactory(options) {
514
+ const instance = Object.assign({}, dialog);
515
+ instance.init(options);
516
+ return instance;
517
+ };