@oat-sa/tao-core-ui 1.60.2 → 1.61.0

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 (780) hide show
  1. package/LICENSE +339 -339
  2. package/README.md +23 -18
  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 +11 -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 +464 -431
  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 +7 -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/propertySelector/css/propertySelector.css +74 -0
  228. package/dist/propertySelector/css/propertySelector.css.map +1 -0
  229. package/dist/propertySelector/propertySelector.js +533 -0
  230. package/dist/report.js +86 -86
  231. package/dist/resource/css/selector.css +7 -7
  232. package/dist/resource/css/selector.css.map +1 -1
  233. package/dist/resource/filters.js +73 -73
  234. package/dist/resource/list.js +66 -66
  235. package/dist/resource/selectable.js +92 -92
  236. package/dist/resource/selector.js +195 -195
  237. package/dist/resource/tree.js +104 -104
  238. package/dist/resourcemgr/css/resourcemgr.css +7 -7
  239. package/dist/resourcemgr/css/resourcemgr.css.map +1 -1
  240. package/dist/resourcemgr/fileBrowser.js +88 -88
  241. package/dist/resourcemgr/fileSelector.js +58 -58
  242. package/dist/resourcemgr/util/updatePermissions.js +4 -4
  243. package/dist/resourcemgr.js +62 -62
  244. package/dist/scroller.js +26 -26
  245. package/dist/searchModal/advancedSearch.js +355 -161
  246. package/dist/searchModal/css/advancedSearch.css +7 -14
  247. package/dist/searchModal/css/advancedSearch.css.map +1 -1
  248. package/dist/searchModal/css/searchModal.css +29 -8
  249. package/dist/searchModal/css/searchModal.css.map +1 -1
  250. package/dist/searchModal.js +574 -190
  251. package/dist/selecter.js +6 -6
  252. package/dist/stacker.js +43 -43
  253. package/dist/switch/css/switch.css +7 -7
  254. package/dist/switch/css/switch.css.map +1 -1
  255. package/dist/switch/switch.js +75 -75
  256. package/dist/tableModel.js +33 -33
  257. package/dist/tabs/css/tabs.css +12 -12
  258. package/dist/tabs/css/tabs.css.map +1 -1
  259. package/dist/tabs.js +217 -217
  260. package/dist/taskQueue/css/taskQueue.css +7 -7
  261. package/dist/taskQueue/css/taskQueue.css.map +1 -1
  262. package/dist/taskQueue/status.js +72 -72
  263. package/dist/taskQueue/table.js +67 -67
  264. package/dist/taskQueue/taskQueue.js +18 -18
  265. package/dist/taskQueue/taskQueueModel.js +86 -86
  266. package/dist/taskQueue.js +47 -47
  267. package/dist/taskQueueButton/css/taskable.css +7 -7
  268. package/dist/taskQueueButton/css/taskable.css.map +1 -1
  269. package/dist/taskQueueButton/css/treeButton.css +7 -7
  270. package/dist/taskQueueButton/css/treeButton.css.map +1 -1
  271. package/dist/taskQueueButton/standardButton.js +39 -39
  272. package/dist/taskQueueButton/taskable.js +54 -54
  273. package/dist/taskQueueButton/treeButton.js +56 -56
  274. package/dist/themeLoader.js +75 -75
  275. package/dist/themes.js +84 -84
  276. package/dist/toggler.js +57 -57
  277. package/dist/tooltip.js +54 -54
  278. package/dist/tooltipster.js +17 -17
  279. package/dist/transformer.js +117 -117
  280. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  281. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  282. package/dist/tristateCheckboxGroup.js +75 -75
  283. package/dist/uploader.js +158 -158
  284. package/dist/validator/validators.js +48 -48
  285. package/dist/validator.js +24 -24
  286. package/dist/waitForMedia.js +33 -33
  287. package/dist/waitingDialog/css/waitingDialog.css +7 -7
  288. package/dist/waitingDialog/css/waitingDialog.css.map +1 -1
  289. package/dist/waitingDialog/waitingDialog.js +54 -54
  290. package/package.json +108 -107
  291. package/scss/basic.scss +16 -16
  292. package/scss/ckeditor/skins/tao/scss/inc/_ck-icons.scss +59 -59
  293. package/scss/ckeditor/skins/tao/scss/inc/_tao.scss +59 -59
  294. package/scss/font/tao/tao.svg +234 -234
  295. package/scss/inc/_base.scss +495 -495
  296. package/scss/inc/_bootstrap.scss +6 -6
  297. package/scss/inc/_buttons.scss +114 -114
  298. package/scss/inc/_colors.scss +93 -88
  299. package/scss/inc/_feedback.scss +150 -150
  300. package/scss/inc/_flex-grid.scss +15 -15
  301. package/scss/inc/_fonts.scss +4 -4
  302. package/scss/inc/_forms.scss +832 -832
  303. package/scss/inc/_functions.scss +283 -283
  304. package/scss/inc/_jquery.nouislider.scss +254 -254
  305. package/scss/inc/_normalize.scss +528 -528
  306. package/scss/inc/_report.scss +67 -67
  307. package/scss/inc/_secondary-properties.scss +89 -89
  308. package/scss/inc/_select2.scss +634 -634
  309. package/scss/inc/_toolbars.scss +155 -155
  310. package/scss/inc/_tooltip.scss +312 -312
  311. package/scss/inc/_variables.scss +21 -21
  312. package/scss/inc/base/_highlight.scss +5 -5
  313. package/scss/inc/base/_list-style.scss +58 -58
  314. package/scss/inc/base/_svg.scss +3 -3
  315. package/scss/inc/base/_table.scss +62 -62
  316. package/scss/inc/fonts/_source-sans-pro.scss +29 -29
  317. package/scss/inc/fonts/_tao-icon-classes.scss +226 -226
  318. package/scss/inc/fonts/_tao-icon-def.scss +12 -12
  319. package/scss/inc/fonts/_tao-icon-vars.scss +240 -240
  320. package/src/actionbar/tpl/main.tpl +8 -8
  321. package/src/actionbar.js +251 -251
  322. package/src/adder.js +250 -250
  323. package/src/animable/absorbable/absorbable.js +134 -134
  324. package/src/animable/absorbable/css/absorb.css +7 -7
  325. package/src/animable/absorbable/css/absorb.css.map +1 -1
  326. package/src/animable/absorbable/scss/absorb.scss +37 -37
  327. package/src/animable/pulsable/css/pulse.css +7 -7
  328. package/src/animable/pulsable/css/pulse.css.map +1 -1
  329. package/src/animable/pulsable/pulsable.js +90 -90
  330. package/src/animable/pulsable/scss/pulse.scss +22 -22
  331. package/src/areaBroker.js +160 -160
  332. package/src/autocomplete/css/autocomplete.css +7 -7
  333. package/src/autocomplete/css/autocomplete.css.map +1 -1
  334. package/src/autocomplete/scss/autocomplete.scss +37 -37
  335. package/src/autocomplete.js +1029 -1029
  336. package/src/autoscroll.js +57 -57
  337. package/src/badge/badge.js +119 -119
  338. package/src/badge/css/badge.css +7 -7
  339. package/src/badge/css/badge.css.map +1 -1
  340. package/src/badge/scss/badge.scss +92 -92
  341. package/src/badge/tpl/badge.tpl +4 -4
  342. package/src/breadcrumbs/css/breadcrumbs.css +7 -7
  343. package/src/breadcrumbs/css/breadcrumbs.css.map +1 -1
  344. package/src/breadcrumbs/scss/breadcrumbs.scss +52 -52
  345. package/src/breadcrumbs/tpl/breadcrumbs.tpl +20 -20
  346. package/src/breadcrumbs.js +99 -99
  347. package/src/btngrouper.js +213 -213
  348. package/src/bulkActionPopup/css/bulkActionPopup.css +7 -7
  349. package/src/bulkActionPopup/css/bulkActionPopup.css.map +1 -1
  350. package/src/bulkActionPopup/scss/bulkActionPopup.scss +63 -63
  351. package/src/bulkActionPopup/tpl/layout.tpl +76 -76
  352. package/src/bulkActionPopup/tpl/select.tpl +8 -8
  353. package/src/bulkActionPopup.js +274 -274
  354. package/src/button/tpl/button.tpl +4 -4
  355. package/src/button.js +135 -135
  356. package/src/calculator/css/calculator.css +10 -10
  357. package/src/calculator/css/calculator.css.map +1 -1
  358. package/src/calculator/scss/calculator.scss +139 -139
  359. package/src/calculator.js +188 -188
  360. package/src/cascadingComboBox.js +126 -126
  361. package/src/ckeditor/ckConfigurator.js +736 -736
  362. package/src/ckeditor/dtdHandler.js +1030 -1030
  363. package/src/class/css/selector.css +7 -7
  364. package/src/class/css/selector.css.map +1 -1
  365. package/src/class/scss/selector.scss +101 -101
  366. package/src/class/selector.js +329 -329
  367. package/src/class/tpl/listItem.tpl +9 -9
  368. package/src/class/tpl/selector.tpl +10 -10
  369. package/src/component/alignable.js +274 -274
  370. package/src/component/containable.js +122 -122
  371. package/src/component/css/components.css +7 -7
  372. package/src/component/css/components.css.map +1 -1
  373. package/src/component/css/windowComponent.css +7 -7
  374. package/src/component/css/windowComponent.css.map +1 -1
  375. package/src/component/draggable.js +104 -104
  376. package/src/component/placeable.js +233 -233
  377. package/src/component/resizable.js +195 -195
  378. package/src/component/scss/components.scss +507 -507
  379. package/src/component/scss/windowComponent.scss +62 -62
  380. package/src/component/stackable.js +67 -67
  381. package/src/component/tpl/window.tpl +7 -7
  382. package/src/component/windowed.js +206 -206
  383. package/src/component.js +401 -401
  384. package/src/container.js +200 -200
  385. package/src/contextualPopup/css/contextualPopup.css +7 -7
  386. package/src/contextualPopup/css/contextualPopup.css.map +1 -1
  387. package/src/contextualPopup/scss/contextualPopup.scss +78 -78
  388. package/src/contextualPopup/tpl/popup.tpl +10 -10
  389. package/src/contextualPopup.js +297 -297
  390. package/src/css/basic.css +103 -103
  391. package/src/css/basic.css.map +1 -1
  392. package/src/dashboard/css/dashboard.css +7 -7
  393. package/src/dashboard/css/dashboard.css.map +1 -1
  394. package/src/dashboard/scss/dashboard.scss +93 -93
  395. package/src/dashboard/tpl/dashboard.tpl +16 -16
  396. package/src/dashboard/tpl/dashboardMetricsList.tpl +15 -15
  397. package/src/dashboard.js +184 -184
  398. package/src/datalist/css/datalist.css +7 -7
  399. package/src/datalist/css/datalist.css.map +1 -1
  400. package/src/datalist/scss/datalist.scss +116 -116
  401. package/src/datalist/tpl/list.tpl +24 -24
  402. package/src/datalist/tpl/main.tpl +44 -44
  403. package/src/datalist.js +500 -500
  404. package/src/datatable/css/datatable.css +11 -7
  405. package/src/datatable/css/datatable.css.map +1 -1
  406. package/src/datatable/filterStrategy/filterStrategy.js +70 -70
  407. package/src/datatable/filterStrategy/multiple.js +126 -126
  408. package/src/datatable/filterStrategy/single.js +108 -108
  409. package/src/datatable/scss/datatable.scss +149 -146
  410. package/src/datatable/tpl/button.tpl +6 -6
  411. package/src/datatable/tpl/layout.tpl +158 -158
  412. package/src/datatable.js +1056 -1056
  413. package/src/dateRange/css/dateRange.css +7 -7
  414. package/src/dateRange/css/dateRange.css.map +1 -1
  415. package/src/dateRange/dateRange.js +341 -341
  416. package/src/dateRange/scss/dateRange.scss +7 -7
  417. package/src/dateRange/tpl/select.tpl +18 -18
  418. package/src/datetime/css/picker.css +7 -7
  419. package/src/datetime/css/picker.css.map +1 -1
  420. package/src/datetime/picker.js +576 -576
  421. package/src/datetime/scss/picker.scss +192 -192
  422. package/src/datetime/tpl/picker.tpl +18 -18
  423. package/src/deleter/undo.tpl +6 -6
  424. package/src/deleter.js +296 -296
  425. package/src/destination/css/selector.css +7 -7
  426. package/src/destination/css/selector.css.map +1 -1
  427. package/src/destination/scss/selector.scss +36 -36
  428. package/src/destination/selector.js +195 -195
  429. package/src/destination/tpl/selector.tpl +13 -13
  430. package/src/dialog/alert.js +70 -70
  431. package/src/dialog/confirm.js +85 -85
  432. package/src/dialog/confirmDelete.js +95 -95
  433. package/src/dialog/tpl/body.tpl +24 -24
  434. package/src/dialog/tpl/buttons.tpl +6 -6
  435. package/src/dialog/tpl/checkbox.tpl +5 -5
  436. package/src/dialog.js +517 -517
  437. package/src/disabler.js +230 -230
  438. package/src/documentViewer/css/documentViewer.css +7 -7
  439. package/src/documentViewer/css/documentViewer.css.map +1 -1
  440. package/src/documentViewer/providers/pdfViewer/fallback/viewer.js +69 -69
  441. package/src/documentViewer/providers/pdfViewer/pdfjs/areaBroker.js +41 -41
  442. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.js +475 -475
  443. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.tpl +20 -20
  444. package/src/documentViewer/providers/pdfViewer/pdfjs/match.tpl +1 -1
  445. package/src/documentViewer/providers/pdfViewer/pdfjs/page.tpl +4 -4
  446. package/src/documentViewer/providers/pdfViewer/pdfjs/pageView.js +318 -318
  447. package/src/documentViewer/providers/pdfViewer/pdfjs/pagesManager.js +167 -167
  448. package/src/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +451 -451
  449. package/src/documentViewer/providers/pdfViewer/pdfjs/textManager.js +252 -252
  450. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.js +299 -299
  451. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.tpl +16 -16
  452. package/src/documentViewer/providers/pdfViewer/pdfjs/wrapper.js +351 -351
  453. package/src/documentViewer/providers/pdfViewer.js +93 -93
  454. package/src/documentViewer/scss/documentViewer.scss +184 -184
  455. package/src/documentViewer/viewerFactory.js +191 -191
  456. package/src/documentViewer.js +238 -238
  457. package/src/dropdown/css/dropdown.css +7 -7
  458. package/src/dropdown/css/dropdown.css.map +1 -1
  459. package/src/dropdown/scss/dropdown.scss +99 -99
  460. package/src/dropdown/tpl/dropdown.tpl +8 -8
  461. package/src/dropdown/tpl/list-item.tpl +4 -4
  462. package/src/dropdown.js +255 -255
  463. package/src/durationer.js +222 -222
  464. package/src/dynamicComponent/css/dynamicComponent.css +7 -7
  465. package/src/dynamicComponent/css/dynamicComponent.css.map +1 -1
  466. package/src/dynamicComponent/scss/dynamicComponent.scss +98 -98
  467. package/src/dynamicComponent/tpl/layout.tpl +17 -17
  468. package/src/dynamicComponent.js +554 -554
  469. package/src/feedback/feedback.tpl +7 -7
  470. package/src/feedback.js +295 -295
  471. package/src/figure/FigureStateActive.js +174 -174
  472. package/src/filesender.js +114 -114
  473. package/src/filter/template.tpl +5 -5
  474. package/src/filter.js +135 -135
  475. package/src/form/css/dropdownForm.css +7 -7
  476. package/src/form/css/dropdownForm.css.map +1 -1
  477. package/src/form/css/form.css +7 -7
  478. package/src/form/css/form.css.map +1 -1
  479. package/src/form/dropdownForm.js +281 -281
  480. package/src/form/form.js +688 -688
  481. package/src/form/scss/dropdownForm.scss +60 -60
  482. package/src/form/scss/form.scss +25 -25
  483. package/src/form/simpleForm.js +125 -125
  484. package/src/form/tpl/dropdownForm.tpl +4 -4
  485. package/src/form/tpl/form.tpl +7 -7
  486. package/src/form/validator/css/validator.css +7 -7
  487. package/src/form/validator/css/validator.css.map +1 -1
  488. package/src/form/validator/renderer.js +118 -118
  489. package/src/form/validator/scss/validator.scss +14 -14
  490. package/src/form/validator/tpl/message.tpl +1 -1
  491. package/src/form/validator/tpl/validator.tpl +1 -1
  492. package/src/form/validator/validator.js +220 -220
  493. package/src/form/widget/css/widget.css +7 -7
  494. package/src/form/widget/css/widget.css.map +1 -1
  495. package/src/form/widget/definitions.js +51 -51
  496. package/src/form/widget/loader.js +40 -40
  497. package/src/form/widget/providers/checkBox.js +138 -138
  498. package/src/form/widget/providers/comboBox.js +63 -63
  499. package/src/form/widget/providers/default.js +90 -90
  500. package/src/form/widget/providers/hidden.js +62 -62
  501. package/src/form/widget/providers/hiddenBox.js +152 -152
  502. package/src/form/widget/providers/radioBox.js +99 -99
  503. package/src/form/widget/providers/textArea.js +52 -52
  504. package/src/form/widget/providers/textBox.js +48 -48
  505. package/src/form/widget/scss/widget.scss +55 -55
  506. package/src/form/widget/tpl/checkBox.tpl +25 -25
  507. package/src/form/widget/tpl/comboBox.tpl +13 -13
  508. package/src/form/widget/tpl/hidden.tpl +1 -1
  509. package/src/form/widget/tpl/hiddenBox.tpl +17 -17
  510. package/src/form/widget/tpl/label.tpl +6 -6
  511. package/src/form/widget/tpl/radioBox.tpl +25 -25
  512. package/src/form/widget/tpl/textArea.tpl +8 -8
  513. package/src/form/widget/tpl/widget.tpl +8 -8
  514. package/src/form/widget/widget.js +372 -372
  515. package/src/form.js +53 -53
  516. package/src/formValidator/formValidator.js +253 -253
  517. package/src/formValidator/highlighters/highlighter.js +102 -102
  518. package/src/formValidator/highlighters/message.js +70 -70
  519. package/src/formValidator/highlighters/tooltip.js +78 -78
  520. package/src/generis/form/css/form.css +7 -7
  521. package/src/generis/form/css/form.css.map +1 -1
  522. package/src/generis/form/form.js +239 -239
  523. package/src/generis/form/readme.md +70 -70
  524. package/src/generis/form/scss/form.scss +23 -23
  525. package/src/generis/form/tpl/form.tpl +16 -16
  526. package/src/generis/validator/css/validator.css +7 -7
  527. package/src/generis/validator/css/validator.css.map +1 -1
  528. package/src/generis/validator/readme.md +46 -46
  529. package/src/generis/validator/scss/validator.scss +13 -13
  530. package/src/generis/validator/validator.js +128 -128
  531. package/src/generis/widget/checkBox/checkBox.js +112 -112
  532. package/src/generis/widget/checkBox/checkBox.tpl +18 -18
  533. package/src/generis/widget/comboBox/comboBox.js +67 -67
  534. package/src/generis/widget/comboBox/comboBox.tpl +12 -12
  535. package/src/generis/widget/css/widget.css +7 -7
  536. package/src/generis/widget/css/widget.css.map +1 -1
  537. package/src/generis/widget/hiddenBox/hiddenBox.js +132 -132
  538. package/src/generis/widget/hiddenBox/hiddenBox.tpl +16 -16
  539. package/src/generis/widget/loader.js +49 -49
  540. package/src/generis/widget/readme.md +59 -59
  541. package/src/generis/widget/scss/widget.scss +61 -61
  542. package/src/generis/widget/textBox/textBox.js +65 -65
  543. package/src/generis/widget/textBox/textBox.tpl +7 -7
  544. package/src/generis/widget/widget.js +164 -164
  545. package/src/generis/widget/widget.tpl +5 -5
  546. package/src/groupedComboBox.js +99 -99
  547. package/src/groupvalidator.js +84 -84
  548. package/src/hider.js +88 -88
  549. package/src/highlighter.js +1166 -1166
  550. package/src/image/ImgStateActive/extractLabel.js +29 -29
  551. package/src/image/ImgStateActive/helper.js +36 -36
  552. package/src/image/ImgStateActive/initHelper.js +137 -137
  553. package/src/image/ImgStateActive/initMediaEditor.js +92 -92
  554. package/src/image/ImgStateActive/mediaSizer.js +63 -63
  555. package/src/image/ImgStateActive.js +115 -115
  556. package/src/incrementer.js +319 -319
  557. package/src/inplacer.js +316 -316
  558. package/src/interactUtils.js +140 -140
  559. package/src/itemButtonList/css/item-button-list.css +23 -23
  560. package/src/itemButtonList/css/item-button-list.css.map +1 -1
  561. package/src/itemButtonList/scss/item-button-list.scss +236 -236
  562. package/src/itemButtonList/tpl/itemButtonList.tpl +21 -21
  563. package/src/itemButtonList.js +274 -274
  564. package/src/keyNavigation/navigableDomElement.js +282 -282
  565. package/src/keyNavigation/navigator.js +543 -543
  566. package/src/listbox/css/listbox.css +7 -7
  567. package/src/listbox/css/listbox.css.map +1 -1
  568. package/src/listbox/scss/listbox.scss +116 -116
  569. package/src/listbox/tpl/list.tpl +14 -14
  570. package/src/listbox/tpl/main.tpl +9 -9
  571. package/src/listbox.js +251 -251
  572. package/src/liststyler.js +155 -155
  573. package/src/loadingButton/css/button.css +7 -7
  574. package/src/loadingButton/css/button.css.map +1 -1
  575. package/src/loadingButton/loadingButton.js +110 -110
  576. package/src/loadingButton/scss/button.scss +41 -41
  577. package/src/loadingButton/tpl/button.tpl +5 -5
  578. package/src/lock/lock.tpl +16 -16
  579. package/src/lock.js +395 -395
  580. package/src/login/login.js +322 -322
  581. package/src/login/tpl/login.tpl +29 -29
  582. package/src/login/tpl/passwordReveal.tpl +7 -7
  583. package/src/maths/calculator/basicCalculator.js +55 -55
  584. package/src/maths/calculator/calculatorComponent.js +128 -128
  585. package/src/maths/calculator/core/areaBroker.js +38 -38
  586. package/src/maths/calculator/core/board.js +841 -841
  587. package/src/maths/calculator/core/expression.js +430 -430
  588. package/src/maths/calculator/core/labels.js +116 -116
  589. package/src/maths/calculator/core/plugin.js +40 -40
  590. package/src/maths/calculator/core/terms.js +459 -459
  591. package/src/maths/calculator/core/tokenizer.js +245 -245
  592. package/src/maths/calculator/core/tokens.js +178 -178
  593. package/src/maths/calculator/core/tpl/board.tpl +4 -4
  594. package/src/maths/calculator/css/calculator.css +7 -7
  595. package/src/maths/calculator/css/calculator.css.map +1 -1
  596. package/src/maths/calculator/defaultCalculator.js +66 -66
  597. package/src/maths/calculator/plugins/core/degrad.js +90 -90
  598. package/src/maths/calculator/plugins/core/history.js +166 -166
  599. package/src/maths/calculator/plugins/core/remind.js +96 -96
  600. package/src/maths/calculator/plugins/core/stepNavigation.js +175 -175
  601. package/src/maths/calculator/plugins/keyboard/templateKeyboard/defaultTemplate.tpl +36 -36
  602. package/src/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +91 -91
  603. package/src/maths/calculator/plugins/modifiers/pow10.js +143 -143
  604. package/src/maths/calculator/plugins/modifiers/sign.js +339 -339
  605. package/src/maths/calculator/plugins/screen/simpleScreen/defaultTemplate.tpl +3 -3
  606. package/src/maths/calculator/plugins/screen/simpleScreen/history.tpl +3 -3
  607. package/src/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +191 -191
  608. package/src/maths/calculator/pluginsLoader.js +46 -46
  609. package/src/maths/calculator/scientificCalculator.js +74 -74
  610. package/src/maths/calculator/scss/calculator.scss +396 -396
  611. package/src/maths/calculator/tpl/basicKeyboard.tpl +37 -37
  612. package/src/maths/calculator/tpl/basicScreen.tpl +2 -2
  613. package/src/maths/calculator/tpl/scientificKeyboard.tpl +61 -61
  614. package/src/maths/calculator/tpl/scientificScreen.tpl +3 -3
  615. package/src/mediaEditor/mediaEditorComponent.js +141 -141
  616. package/src/mediaEditor/plugins/mediaAlignment/helper.js +62 -62
  617. package/src/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +99 -99
  618. package/src/mediaEditor/plugins/mediaAlignment/style.css +7 -7
  619. package/src/mediaEditor/plugins/mediaAlignment/tpl/mediaAlignment.tpl +25 -25
  620. package/src/mediaEditor/plugins/mediaDimension/helper.js +189 -189
  621. package/src/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +561 -561
  622. package/src/mediaEditor/plugins/mediaDimension/style.css +141 -141
  623. package/src/mediaEditor/plugins/mediaDimension/tpl/mediaDimension.tpl +55 -55
  624. package/src/mediaEditor/tpl/editor.tpl +4 -4
  625. package/src/mediaplayer/css/player.css +7 -7
  626. package/src/mediaplayer/css/player.css.map +1 -1
  627. package/src/mediaplayer/players/html5.js +564 -564
  628. package/src/mediaplayer/players/youtube.js +323 -323
  629. package/src/mediaplayer/players.js +29 -29
  630. package/src/mediaplayer/readme.md +305 -305
  631. package/src/mediaplayer/scss/player.scss +569 -569
  632. package/src/mediaplayer/support.js +126 -126
  633. package/src/mediaplayer/tpl/audio.tpl +6 -6
  634. package/src/mediaplayer/tpl/player.tpl +37 -37
  635. package/src/mediaplayer/tpl/source.tpl +1 -1
  636. package/src/mediaplayer/tpl/video.tpl +6 -6
  637. package/src/mediaplayer/tpl/youtube.tpl +1 -1
  638. package/src/mediaplayer/utils/reminder.js +184 -184
  639. package/src/mediaplayer/utils/timeObserver.js +143 -143
  640. package/src/mediaplayer/youtubeManager.js +161 -161
  641. package/src/mediaplayer.js +1606 -1606
  642. package/src/mediasizer/mediasizer.tpl +55 -55
  643. package/src/mediasizer.js +635 -635
  644. package/src/modal.js +365 -365
  645. package/src/movableComponent.js +78 -78
  646. package/src/pageSizeSelector/tpl/pageSizeSelector.tpl +9 -9
  647. package/src/pageSizeSelector.js +107 -107
  648. package/src/pageStatus.js +147 -147
  649. package/src/pagination/css/pagination.css +7 -7
  650. package/src/pagination/css/pagination.css.map +1 -1
  651. package/src/pagination/paginationStrategy.js +53 -53
  652. package/src/pagination/providers/pages.js +161 -161
  653. package/src/pagination/providers/simple.js +74 -74
  654. package/src/pagination/providers/tpl/pages/page.tpl +1 -1
  655. package/src/pagination/providers/tpl/pages.tpl +8 -8
  656. package/src/pagination/providers/tpl/simple.tpl +7 -7
  657. package/src/pagination/scss/pagination.scss +111 -111
  658. package/src/pagination.js +237 -237
  659. package/src/previewer.js +300 -300
  660. package/src/progressbar.js +165 -165
  661. package/src/propertySelector/css/propertySelector.css +74 -0
  662. package/src/propertySelector/css/propertySelector.css.map +1 -0
  663. package/src/propertySelector/propertySelector.js +286 -0
  664. package/src/propertySelector/scss/propertySelector.scss +66 -0
  665. package/src/propertySelector/tpl/highlighted-text.tpl +1 -0
  666. package/src/propertySelector/tpl/property-description.tpl +13 -0
  667. package/src/propertySelector/tpl/property-selector.tpl +7 -0
  668. package/src/report/feedback.tpl +11 -11
  669. package/src/report/layout.tpl +10 -10
  670. package/src/report.js +184 -184
  671. package/src/resource/css/selector.css +7 -7
  672. package/src/resource/css/selector.css.map +1 -1
  673. package/src/resource/filters.js +208 -208
  674. package/src/resource/list.js +200 -200
  675. package/src/resource/scss/_filters.scss +26 -26
  676. package/src/resource/scss/_resource-list.scss +107 -107
  677. package/src/resource/scss/_resource-tree.scss +205 -205
  678. package/src/resource/scss/selector.scss +187 -187
  679. package/src/resource/selectable.js +322 -322
  680. package/src/resource/selector.js +871 -871
  681. package/src/resource/tpl/filters.tpl +2 -2
  682. package/src/resource/tpl/list.tpl +7 -7
  683. package/src/resource/tpl/listNode.tpl +4 -4
  684. package/src/resource/tpl/selector.tpl +46 -46
  685. package/src/resource/tpl/tree.tpl +4 -4
  686. package/src/resource/tpl/treeNode.tpl +30 -30
  687. package/src/resource/tree.js +400 -400
  688. package/src/resourcemgr/css/resourcemgr.css +7 -7
  689. package/src/resourcemgr/css/resourcemgr.css.map +1 -1
  690. package/src/resourcemgr/fileBrowser.js +381 -381
  691. package/src/resourcemgr/filePreview.js +73 -73
  692. package/src/resourcemgr/fileSelector.js +348 -348
  693. package/src/resourcemgr/scss/resourcemgr.scss +254 -254
  694. package/src/resourcemgr/tpl/fileSelect.tpl +39 -39
  695. package/src/resourcemgr/tpl/folder.tpl +11 -11
  696. package/src/resourcemgr/tpl/layout.tpl +84 -84
  697. package/src/resourcemgr/tpl/rootFolder.tpl +13 -13
  698. package/src/resourcemgr/util/updatePermissions.js +53 -53
  699. package/src/resourcemgr.js +216 -216
  700. package/src/scroller.js +94 -94
  701. package/src/scss/basic.scss +16 -16
  702. package/src/searchModal/advancedSearch.js +638 -601
  703. package/src/searchModal/css/advancedSearch.css +7 -14
  704. package/src/searchModal/css/advancedSearch.css.map +1 -1
  705. package/src/searchModal/css/searchModal.css +29 -8
  706. package/src/searchModal/css/searchModal.css.map +1 -1
  707. package/src/searchModal/scss/advancedSearch.scss +171 -177
  708. package/src/searchModal/scss/searchModal.scss +393 -375
  709. package/src/searchModal/tpl/advanced-search.tpl +9 -9
  710. package/src/searchModal/tpl/criteria-alias.tpl +1 -0
  711. package/src/searchModal/tpl/criteria-class-label.tpl +1 -0
  712. package/src/searchModal/tpl/criteria-label.tpl +1 -0
  713. package/src/searchModal/tpl/highlighted-text.tpl +1 -0
  714. package/src/searchModal/tpl/info-message.tpl +3 -3
  715. package/src/searchModal/tpl/invalid-criteria-warning.tpl +10 -10
  716. package/src/searchModal/tpl/layout.tpl +27 -25
  717. package/src/searchModal/tpl/list-checkbox-criterion.tpl +17 -12
  718. package/src/searchModal/tpl/list-select-criterion.tpl +12 -6
  719. package/src/searchModal/tpl/property-select-button.tpl +1 -0
  720. package/src/searchModal/tpl/results-container.tpl +1 -0
  721. package/src/searchModal/tpl/text-criterion.tpl +11 -6
  722. package/src/searchModal.js +761 -496
  723. package/src/selecter.js +43 -43
  724. package/src/stacker.js +133 -133
  725. package/src/switch/css/switch.css +7 -7
  726. package/src/switch/css/switch.css.map +1 -1
  727. package/src/switch/scss/switch.scss +83 -83
  728. package/src/switch/switch.js +195 -195
  729. package/src/switch/tpl/switch.tpl +7 -7
  730. package/src/tableModel.js +112 -112
  731. package/src/tabs/css/tabs.css +12 -12
  732. package/src/tabs/css/tabs.css.map +1 -1
  733. package/src/tabs/scss/tabs.scss +50 -50
  734. package/src/tabs/tpl/panel.tpl +3 -3
  735. package/src/tabs/tpl/tabs.tpl +10 -10
  736. package/src/tabs.js +528 -528
  737. package/src/taskQueue/css/taskQueue.css +7 -7
  738. package/src/taskQueue/css/taskQueue.css.map +1 -1
  739. package/src/taskQueue/scss/taskQueue.scss +47 -47
  740. package/src/taskQueue/status.js +228 -228
  741. package/src/taskQueue/table.js +350 -350
  742. package/src/taskQueue/taskQueue.js +33 -33
  743. package/src/taskQueue/taskQueueModel.js +548 -548
  744. package/src/taskQueue/tpl/statusMessage.tpl +7 -7
  745. package/src/taskQueue.js +218 -218
  746. package/src/taskQueueButton/css/taskable.css +7 -7
  747. package/src/taskQueueButton/css/taskable.css.map +1 -1
  748. package/src/taskQueueButton/css/treeButton.css +7 -7
  749. package/src/taskQueueButton/css/treeButton.css.map +1 -1
  750. package/src/taskQueueButton/scss/taskable.scss +4 -4
  751. package/src/taskQueueButton/scss/treeButton.scss +34 -34
  752. package/src/taskQueueButton/standardButton.js +108 -108
  753. package/src/taskQueueButton/taskable.js +202 -202
  754. package/src/taskQueueButton/tpl/report.tpl +5 -5
  755. package/src/taskQueueButton/tpl/treeButton.tpl +6 -6
  756. package/src/taskQueueButton/treeButton.js +109 -109
  757. package/src/themeLoader.js +252 -252
  758. package/src/themes.js +162 -162
  759. package/src/toggler.js +200 -200
  760. package/src/tooltip/default.tpl +3 -3
  761. package/src/tooltip.js +160 -160
  762. package/src/tooltipster.js +25 -25
  763. package/src/transformer.js +327 -327
  764. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  765. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  766. package/src/tristateCheckboxGroup/scss/tristateCheckboxGroup.scss +15 -15
  767. package/src/tristateCheckboxGroup/tpl/li.tpl +6 -6
  768. package/src/tristateCheckboxGroup.js +207 -207
  769. package/src/uploader/fileEntry.tpl +6 -6
  770. package/src/uploader/uploader.tpl +32 -32
  771. package/src/uploader.js +594 -594
  772. package/src/validator/Report.js +10 -10
  773. package/src/validator/Validator.js +108 -108
  774. package/src/validator/validators.js +220 -220
  775. package/src/validator.js +264 -264
  776. package/src/waitForMedia.js +82 -82
  777. package/src/waitingDialog/css/waitingDialog.css +7 -7
  778. package/src/waitingDialog/css/waitingDialog.css.map +1 -1
  779. package/src/waitingDialog/scss/waitingDialog.scss +34 -34
  780. package/src/waitingDialog/waitingDialog.js +240 -240
@@ -1,576 +1,576 @@
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) 2019 (original work) Open Assessment Technologies SA
17
- *
18
- */
19
-
20
- /**
21
- * Date/Time picker component.
22
- * It supports different setups : date-range, datetime-range, date, time and datetime
23
- * It supports localized format.
24
- * It supports either hooking a field, replacing it and adding controls.
25
- *
26
- * It wraps the library Flatpickr (https://flatpickr.js.org)
27
- *
28
- * @example
29
- * dateTimePicker(container, {
30
- * setup : 'date',
31
- * format : 'YYYY-MM-DD',
32
- * controlButtons : true
33
- * })
34
- * .on('change', function(value){
35
- * if (value === '1983-04-03'){
36
- * //...
37
- * }
38
- * });
39
- *
40
- * @author Bertrand Chevrier <bertrand@taotesting.com>
41
- */
42
- import _ from 'lodash';
43
- import __ from 'i18n';
44
- import moment from 'moment';
45
- import component from 'ui/component';
46
- import flatpickr from 'lib/flatpickr/flatpickr';
47
- import flatpickrLocalization from 'lib/flatpickr/l10n/index';
48
- import dateTimePickerTpl from 'ui/datetime/tpl/picker';
49
- import 'lib/flatpickr/flatpickr.css';
50
- import 'ui/datetime/css/picker.css';
51
-
52
- /**
53
- * The supported formats
54
- */
55
- var formats = {
56
- date: {
57
- default: 'YYYY-MM-DD',
58
- localized: 'L'
59
- },
60
- time: {
61
- default: 'HH:mm',
62
- localized: 'LT'
63
- },
64
- datetime: {
65
- default: 'YYYY-MM-DD HH:mm',
66
- localized: 'L LT'
67
- }
68
- };
69
-
70
- /**
71
- * Possible setups for the picker
72
- */
73
- var setups = {
74
- 'date-range': {
75
- mode: 'range',
76
- label: __('date range'),
77
- format: formats.date
78
- },
79
- 'datetime-range': {
80
- mode: 'range',
81
- label: __('date time range'),
82
- enableTime: true,
83
- format: formats.datetime
84
- },
85
- date: {
86
- mode: 'single',
87
- format: formats.date
88
- },
89
- time: {
90
- mode: 'single',
91
- enableTime: true,
92
- label: __('time'),
93
- noCalendar: true,
94
- format: formats.time
95
- },
96
- datetime: {
97
- mode: 'single',
98
- enableTime: true,
99
- label: __('date time'),
100
- format: formats.datetime
101
- }
102
- };
103
-
104
- /**
105
- * List of supported constraints
106
- */
107
- var supportedConstraints = ['minDate', 'maxDate', 'enable', 'disable'];
108
-
109
- /**
110
- * Checks translation existing for given locale
111
- * @param {String} locale
112
- * @returns {Boolean}
113
- */
114
- const hasTranslationsForLocale = locale => _.isObject(flatpickrLocalization[locale]);
115
-
116
- /**
117
- * Detects document language
118
- * @returns {String | undefined}
119
- */
120
- const getDefaultLocale = () => {
121
- const documentLang = window.document.documentElement.getAttribute('lang');
122
- const documentLocale = documentLang && documentLang.split('-')[0];
123
-
124
- if (documentLocale && hasTranslationsForLocale(documentLocale)) {
125
- return documentLocale;
126
- }
127
- };
128
-
129
- /**
130
- * The default configuration
131
- * @see dateTimePickerFactory
132
- */
133
- var defaultConfig = {
134
- setup: 'date',
135
- controlButtons: false,
136
- locale: getDefaultLocale(),
137
- useLocalizedFormat: false,
138
- constraints: {}
139
- };
140
-
141
- /**
142
- * Get the long date/time format from the localized format (LT to 'DD/MM/YYYY HH:mm')
143
- * @param {String} locale - 2 digits locale code (en, fr, de, etc.)
144
- * @param {String} localizedFormat - see moment's localized format (L, LT, LLLL, ...)
145
- * @returns {String|boolean} the long date/time format
146
- */
147
- var getLongLocalizedFormat = function getLongLocalizedFormat(locale, localizedFormat) {
148
- if (/[LT]+/.test(localizedFormat) && locale) {
149
- return localizedFormat
150
- .split(' ')
151
- .map(function(format) {
152
- return moment(new Date())
153
- .locale(locale)
154
- .localeData()
155
- .longDateFormat(format);
156
- })
157
- .join(' ');
158
- }
159
- return false;
160
- };
161
-
162
- /**
163
- * Does the given date/time format uses the am/pm pattern ?
164
- * @param {String} format - moment format
165
- * @returns {Boolean} true if the contains am/pm
166
- */
167
- var isFormatAmPm = function isFormatAmPm(format) {
168
- return format && /a$/i.test(format);
169
- };
170
-
171
- /**
172
- * Does the given date/time format contains seconds ?
173
- * @param {String} format - moment format
174
- * @returns {Boolean} true if the format contains seconds
175
- */
176
- var isFormatInSeconds = function isFormatInSeconds(format) {
177
- return format && /(:ss)+/i.test(format);
178
- };
179
-
180
- /**
181
- * The component factory
182
- *
183
- * @param {HTMLElement|jQuery} container - where to append the component
184
- * @param {Object} [config]
185
- * @param {String} [config.setup = date] - the picker setup in date-range, datetime-range, date, time and datetime
186
- * @param {String} [config.locale] - the picker local
187
- * @param {String} [config.useLocalzedFormat = false] - does the locale is used to define the format
188
- * @param {String} [config.format] - define your own date/time format for the instance
189
- * @param {Boolean} [config.controlButtons = false] - does the field have controls to trigger opening and reset
190
- * @param {Object} [config.constraints] - date time selection constraints
191
- * @param {Object} [config.constraints] - date time selection constraints
192
- * @param {Array<String|Date>} [config.constraints.disable] - list of dates to disable
193
- * @param {Array<String|Date>} [config.constraints.enable] - list of dates to enable (if some are disabled)
194
- * @param {String|Date} [config.constraints.minDate] - minimum date to start picking from
195
- * @param {String|Date} [config.constraints.maxDate] - maximum date to start picking from
196
- *
197
- * @param {HTMLInputElement} [config.replaceField] - an input field to replace. The field attr are taken instead of config.field
198
- * @param {Object} [config.field] - the input field configuration
199
- * @param {String} [config.field.name] - the input field name
200
- * @param {String} [config.field.id] - the input field id
201
- * @param {String} [config.field.placeholder] - the input field placeholder
202
- * @param {String} [config.field.pattern] - the input field pattern mask
203
- * @param {String} [config.field.value] - the input field value
204
- * @param {String} [config.field.label] - label the field for a11y
205
- *
206
- * @returns {dateTimePickerComponent} the component instance
207
- */
208
- export default function dateTimePickerFactory(container, options) {
209
- var format = '';
210
- var value = '';
211
-
212
- /**
213
- * @typedef {Object} dateTimePicker
214
- */
215
- var dateTimePicker = component(
216
- {
217
- /**
218
- * Get the current value
219
- * @returns {String} the field value, null if none
220
- */
221
- getValue: function getValue() {
222
- if (this.is('rendered')) {
223
- return this.controls.input.value;
224
- }
225
- return null;
226
- },
227
-
228
- /**
229
- * Set the current value
230
- * @param {String|Date} newValue - the new value matching the format
231
- */
232
- setValue: function setValue(newValue) {
233
- if (this.is('ready')) {
234
- value = newValue;
235
-
236
- if (_.isString(value)) {
237
- this.controls.input.value = value;
238
- }
239
- this.picker.setDate(value, true);
240
- }
241
- return null;
242
- },
243
-
244
- /**
245
- * Get the dates currently selected.
246
- * Usefull for the range mode to get the date list
247
- * @returns {Array<[Date|String]>|boolean} the selected dates
248
- */
249
- getSelectedDates: function getSelectedDates() {
250
- var selection;
251
- if (this.is('ready') && this.picker) {
252
- selection = this.picker.selectedDates;
253
- if (selection && !_.isArray(selection)) {
254
- return [selection];
255
- }
256
- return selection;
257
- }
258
- return false;
259
- },
260
-
261
- /**
262
- * Get the date/time format description, ie. 'YYYY-MM-DD'
263
- * @returns {String} the format
264
- */
265
- getFormat: function getFormat() {
266
- return format;
267
- },
268
-
269
- /**
270
- * Open the picker
271
- * @returns {dateTimePicker} chains
272
- * @fires dateTimePicker#open
273
- */
274
- open: function open() {
275
- if (this.is('ready')) {
276
- this.picker.open();
277
- }
278
- return this;
279
- },
280
-
281
- /**
282
- * Close the picker
283
- * @returns {dateTimePicker} chains
284
- * @fires dateTimePicker#close
285
- */
286
- close: function close() {
287
- if (this.is('ready')) {
288
- this.picker.close();
289
- }
290
- return this;
291
- },
292
-
293
- /**
294
- * Clear the field content and close the picker
295
- * @returns {dateTimePicker} chains
296
- * @fires dateTimePicker#close
297
- * @fires dateTimePicker#clear
298
- */
299
- clear: function clear() {
300
- if (this.is('ready')) {
301
- value = '';
302
-
303
- this.picker.close();
304
- this.picker.clear();
305
-
306
- /**
307
- * The picker get cleared
308
- * @event dateTimePicker#clear
309
- */
310
- this.trigger('clear');
311
- }
312
- return this;
313
- },
314
-
315
- /**
316
- * Clear the field content and close the picker
317
- * @returns {dateTimePicker} chains
318
- * @fires dateTimePicker#open
319
- * @fires dateTimePicker#close
320
- */
321
- toggle: function toogle() {
322
- if (this.is('ready')) {
323
- this.picker.toggle();
324
- }
325
- return this;
326
- },
327
-
328
- /**
329
- * Update constraints on a running instance
330
- * @param {String} constraint - the constraint name in minDate, maxDate, enable, disable
331
- * @param {*} constraintValue - the constraint value to update
332
- * @returns {dateTimePicker} chains
333
- * @fires dateTimePicker#open
334
- * @fires dateTimePicker#close
335
- */
336
- updateConstraints: function updateConstraints(constraint, constraintValue) {
337
- if (this.is('ready')) {
338
- if (_.contains(supportedConstraints, constraint)) {
339
- this.picker.set(constraint, constraintValue);
340
- }
341
- }
342
- return this;
343
- }
344
- },
345
- defaultConfig
346
- );
347
-
348
- dateTimePicker
349
- .setTemplate(dateTimePickerTpl)
350
- .on('init', function() {
351
- var self = this;
352
-
353
- var locale;
354
- var setup = setups[this.config.setup] || setups.datetime;
355
-
356
- //map the locale from the options to the picker locale
357
- if (this.config.locale && hasTranslationsForLocale(this.config.locale)) {
358
- locale = this.config.locale;
359
- }
360
-
361
- //date/time format
362
- if (locale && this.config.useLocalizedFormat) {
363
- //get the format from the locale
364
- format = getLongLocalizedFormat(locale, setup.format.localized);
365
- } else {
366
- //get the format from the config
367
- format = this.config.format || setup.format.default;
368
- }
369
-
370
- //input field configuration
371
- this.config.field = this.config.field || {};
372
-
373
- // replace a field by the date picker input field
374
- //TODO consider replacing data-attr and classes
375
- if (this.config.replaceField && this.config.replaceField instanceof HTMLInputElement) {
376
- this.config.field.id = this.config.replaceField.id;
377
- this.config.field.name = this.config.replaceField.name;
378
- this.config.field.placeholder = this.config.replaceField.placeholder;
379
- this.config.field.value = this.config.replaceField.value;
380
- this.config.field.pattern = this.config.replaceField.pattern;
381
-
382
- this.config.replaceField.parentNode.removeChild(this.config.replaceField);
383
- }
384
-
385
- if (!this.config.field.placeholder && format && setup.mode === 'single') {
386
- this.config.field.placeholder = format.toLowerCase();
387
- }
388
- if (!this.config.field.label) {
389
- this.config.field.label = setup.label;
390
- }
391
-
392
- /**
393
- * Build the configuration of the picker
394
- * @see https://flatpickr.js.org/options/
395
- */
396
- this.pickerConfig = {
397
- mode: setup.mode,
398
- enableTime: !!setup.enableTime,
399
- noCalendar: !!setup.noCalendar,
400
- time_24hr: !isFormatAmPm(format),
401
- enableSeconds: setup.enableTime && isFormatInSeconds(format),
402
- allowInput: true,
403
- clickOpens: !this.config.controlButtons,
404
- disableMobile: true,
405
-
406
- /**
407
- * How flatpickr will format the given date
408
- * @param {Date} date
409
- * @returns {String} the formatted date
410
- */
411
- formatDate: function formatDate(date) {
412
- return moment(date).format(format);
413
- },
414
-
415
- /**
416
- * How flatpickr parse the given input
417
- * @param {String} dateString
418
- * @returns {Date}
419
- */
420
- parseDate: function parseDate(dateString) {
421
- return moment(dateString, format).toDate();
422
- },
423
-
424
- /**
425
- * When the picker is opened
426
- * @fires dateTimePicker#open
427
- */
428
- onOpen: function onOpen() {
429
- /**
430
- * The picker get opened
431
- * @event dateTimePicker#open
432
- */
433
- self.trigger('open');
434
- },
435
-
436
- /**
437
- * When the picker is opened
438
- * @fires dateTimePicker#close
439
- */
440
- onClose: function onClose() {
441
- /**
442
- * The picker get closed
443
- * @event dateTimePicker#close
444
- */
445
- self.trigger('close');
446
- },
447
-
448
- /**
449
- * Hook flatpickr error handler
450
- * @param {Error} err - the thrown error
451
- */
452
- errorHandler: function errorHandler(err) {
453
- if (err instanceof Error) {
454
- //if an invalid date is provided
455
- //add a visual feedback indicating why the field get emptied
456
- if (/^Invalid date/.test(err.message)) {
457
- self.controls.input.classList.add('error');
458
- _.delay(function() {
459
- self.controls.input.classList.remove('error');
460
- }, 1000);
461
- } else {
462
- /**
463
- * Unexpected error
464
- * @event dateTimePicker#error
465
- * @param {Error} err
466
- */
467
- self.trigger('error', err);
468
- }
469
- }
470
- }
471
- };
472
- //locale should be defined only if set...
473
- if (locale) {
474
- this.pickerConfig.locale = locale;
475
- }
476
-
477
- _.forEach(this.config.constraints, function(constraintValue, constraint) {
478
- if (_.contains(supportedConstraints, constraint) && constraintValue) {
479
- self.pickerConfig[constraint] = constraintValue;
480
- }
481
- });
482
-
483
- //render into the container
484
- if (container) {
485
- setTimeout(function() {
486
- self.render(container);
487
- }, 0);
488
- }
489
- })
490
- .on('render', function() {
491
- var self = this;
492
-
493
- var element = this.getElement()[0];
494
-
495
- this.controls = {
496
- input: element.querySelector('input')
497
- };
498
-
499
- //always scope the picker to the component container
500
- //in order to scope and style each instance
501
- this.pickerConfig.appendTo = element;
502
-
503
- //behavior of the right buttons if configured
504
- if (this.config.controlButtons) {
505
- this.controls.toggleButton = element.querySelector('.picker-toggle');
506
- this.controls.clearButton = element.querySelector('.picker-clear');
507
-
508
- this.controls.toggleButton.addEventListener('click', function(e) {
509
- e.preventDefault();
510
- e.stopPropagation();
511
- self.toggle();
512
- });
513
-
514
- this.controls.clearButton.addEventListener('click', function(e) {
515
- e.preventDefault();
516
- e.stopPropagation();
517
- self.clear();
518
- });
519
- }
520
-
521
- this.controls.input.addEventListener('change', function() {
522
- var newValue = self.controls.input.value;
523
-
524
- if (value && _.isString(newValue) && _.isEmpty(newValue)) {
525
- //if someone remove the value from the field
526
- //it's considered a property clean (resets everything)
527
- self.clear();
528
- } else if (value !== newValue) {
529
- value = newValue;
530
-
531
- /**
532
- * A value get changed
533
- * @event dateTimePicker#change
534
- * @param {String} value - the date/time value
535
- */
536
- self.trigger('change', value);
537
- }
538
- });
539
-
540
- value = this.controls.input.value;
541
-
542
- //instantiate the picker
543
- _.defer(function() {
544
- self.picker = flatpickr(self.controls.input, self.pickerConfig);
545
-
546
- self.enable()
547
- .setState('ready', true)
548
- .trigger('ready');
549
- });
550
- })
551
- .on('enable', function() {
552
- if (this.controls) {
553
- this.controls.input.disabled = false;
554
- if (this.config.controlButtons) {
555
- this.controls.toggleButton.disabled = false;
556
- this.controls.clearButton.disabled = false;
557
- }
558
- }
559
- })
560
- .on('disable', function() {
561
- if (this.controls) {
562
- this.controls.input.disabled = true;
563
- if (this.config.controlButtons) {
564
- this.controls.toggleButton.disabled = true;
565
- this.controls.clearButton.disabled = true;
566
- }
567
- }
568
- });
569
-
570
- //defered init to catch the event
571
- setTimeout(function() {
572
- dateTimePicker.init(options);
573
- }, 0);
574
-
575
- return dateTimePicker;
576
- }
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) 2019 (original work) Open Assessment Technologies SA
17
+ *
18
+ */
19
+
20
+ /**
21
+ * Date/Time picker component.
22
+ * It supports different setups : date-range, datetime-range, date, time and datetime
23
+ * It supports localized format.
24
+ * It supports either hooking a field, replacing it and adding controls.
25
+ *
26
+ * It wraps the library Flatpickr (https://flatpickr.js.org)
27
+ *
28
+ * @example
29
+ * dateTimePicker(container, {
30
+ * setup : 'date',
31
+ * format : 'YYYY-MM-DD',
32
+ * controlButtons : true
33
+ * })
34
+ * .on('change', function(value){
35
+ * if (value === '1983-04-03'){
36
+ * //...
37
+ * }
38
+ * });
39
+ *
40
+ * @author Bertrand Chevrier <bertrand@taotesting.com>
41
+ */
42
+ import _ from 'lodash';
43
+ import __ from 'i18n';
44
+ import moment from 'moment';
45
+ import component from 'ui/component';
46
+ import flatpickr from 'lib/flatpickr/flatpickr';
47
+ import flatpickrLocalization from 'lib/flatpickr/l10n/index';
48
+ import dateTimePickerTpl from 'ui/datetime/tpl/picker';
49
+ import 'lib/flatpickr/flatpickr.css';
50
+ import 'ui/datetime/css/picker.css';
51
+
52
+ /**
53
+ * The supported formats
54
+ */
55
+ var formats = {
56
+ date: {
57
+ default: 'YYYY-MM-DD',
58
+ localized: 'L'
59
+ },
60
+ time: {
61
+ default: 'HH:mm',
62
+ localized: 'LT'
63
+ },
64
+ datetime: {
65
+ default: 'YYYY-MM-DD HH:mm',
66
+ localized: 'L LT'
67
+ }
68
+ };
69
+
70
+ /**
71
+ * Possible setups for the picker
72
+ */
73
+ var setups = {
74
+ 'date-range': {
75
+ mode: 'range',
76
+ label: __('date range'),
77
+ format: formats.date
78
+ },
79
+ 'datetime-range': {
80
+ mode: 'range',
81
+ label: __('date time range'),
82
+ enableTime: true,
83
+ format: formats.datetime
84
+ },
85
+ date: {
86
+ mode: 'single',
87
+ format: formats.date
88
+ },
89
+ time: {
90
+ mode: 'single',
91
+ enableTime: true,
92
+ label: __('time'),
93
+ noCalendar: true,
94
+ format: formats.time
95
+ },
96
+ datetime: {
97
+ mode: 'single',
98
+ enableTime: true,
99
+ label: __('date time'),
100
+ format: formats.datetime
101
+ }
102
+ };
103
+
104
+ /**
105
+ * List of supported constraints
106
+ */
107
+ var supportedConstraints = ['minDate', 'maxDate', 'enable', 'disable'];
108
+
109
+ /**
110
+ * Checks translation existing for given locale
111
+ * @param {String} locale
112
+ * @returns {Boolean}
113
+ */
114
+ const hasTranslationsForLocale = locale => _.isObject(flatpickrLocalization[locale]);
115
+
116
+ /**
117
+ * Detects document language
118
+ * @returns {String | undefined}
119
+ */
120
+ const getDefaultLocale = () => {
121
+ const documentLang = window.document.documentElement.getAttribute('lang');
122
+ const documentLocale = documentLang && documentLang.split('-')[0];
123
+
124
+ if (documentLocale && hasTranslationsForLocale(documentLocale)) {
125
+ return documentLocale;
126
+ }
127
+ };
128
+
129
+ /**
130
+ * The default configuration
131
+ * @see dateTimePickerFactory
132
+ */
133
+ var defaultConfig = {
134
+ setup: 'date',
135
+ controlButtons: false,
136
+ locale: getDefaultLocale(),
137
+ useLocalizedFormat: false,
138
+ constraints: {}
139
+ };
140
+
141
+ /**
142
+ * Get the long date/time format from the localized format (LT to 'DD/MM/YYYY HH:mm')
143
+ * @param {String} locale - 2 digits locale code (en, fr, de, etc.)
144
+ * @param {String} localizedFormat - see moment's localized format (L, LT, LLLL, ...)
145
+ * @returns {String|boolean} the long date/time format
146
+ */
147
+ var getLongLocalizedFormat = function getLongLocalizedFormat(locale, localizedFormat) {
148
+ if (/[LT]+/.test(localizedFormat) && locale) {
149
+ return localizedFormat
150
+ .split(' ')
151
+ .map(function(format) {
152
+ return moment(new Date())
153
+ .locale(locale)
154
+ .localeData()
155
+ .longDateFormat(format);
156
+ })
157
+ .join(' ');
158
+ }
159
+ return false;
160
+ };
161
+
162
+ /**
163
+ * Does the given date/time format uses the am/pm pattern ?
164
+ * @param {String} format - moment format
165
+ * @returns {Boolean} true if the contains am/pm
166
+ */
167
+ var isFormatAmPm = function isFormatAmPm(format) {
168
+ return format && /a$/i.test(format);
169
+ };
170
+
171
+ /**
172
+ * Does the given date/time format contains seconds ?
173
+ * @param {String} format - moment format
174
+ * @returns {Boolean} true if the format contains seconds
175
+ */
176
+ var isFormatInSeconds = function isFormatInSeconds(format) {
177
+ return format && /(:ss)+/i.test(format);
178
+ };
179
+
180
+ /**
181
+ * The component factory
182
+ *
183
+ * @param {HTMLElement|jQuery} container - where to append the component
184
+ * @param {Object} [config]
185
+ * @param {String} [config.setup = date] - the picker setup in date-range, datetime-range, date, time and datetime
186
+ * @param {String} [config.locale] - the picker local
187
+ * @param {String} [config.useLocalzedFormat = false] - does the locale is used to define the format
188
+ * @param {String} [config.format] - define your own date/time format for the instance
189
+ * @param {Boolean} [config.controlButtons = false] - does the field have controls to trigger opening and reset
190
+ * @param {Object} [config.constraints] - date time selection constraints
191
+ * @param {Object} [config.constraints] - date time selection constraints
192
+ * @param {Array<String|Date>} [config.constraints.disable] - list of dates to disable
193
+ * @param {Array<String|Date>} [config.constraints.enable] - list of dates to enable (if some are disabled)
194
+ * @param {String|Date} [config.constraints.minDate] - minimum date to start picking from
195
+ * @param {String|Date} [config.constraints.maxDate] - maximum date to start picking from
196
+ *
197
+ * @param {HTMLInputElement} [config.replaceField] - an input field to replace. The field attr are taken instead of config.field
198
+ * @param {Object} [config.field] - the input field configuration
199
+ * @param {String} [config.field.name] - the input field name
200
+ * @param {String} [config.field.id] - the input field id
201
+ * @param {String} [config.field.placeholder] - the input field placeholder
202
+ * @param {String} [config.field.pattern] - the input field pattern mask
203
+ * @param {String} [config.field.value] - the input field value
204
+ * @param {String} [config.field.label] - label the field for a11y
205
+ *
206
+ * @returns {dateTimePickerComponent} the component instance
207
+ */
208
+ export default function dateTimePickerFactory(container, options) {
209
+ var format = '';
210
+ var value = '';
211
+
212
+ /**
213
+ * @typedef {Object} dateTimePicker
214
+ */
215
+ var dateTimePicker = component(
216
+ {
217
+ /**
218
+ * Get the current value
219
+ * @returns {String} the field value, null if none
220
+ */
221
+ getValue: function getValue() {
222
+ if (this.is('rendered')) {
223
+ return this.controls.input.value;
224
+ }
225
+ return null;
226
+ },
227
+
228
+ /**
229
+ * Set the current value
230
+ * @param {String|Date} newValue - the new value matching the format
231
+ */
232
+ setValue: function setValue(newValue) {
233
+ if (this.is('ready')) {
234
+ value = newValue;
235
+
236
+ if (_.isString(value)) {
237
+ this.controls.input.value = value;
238
+ }
239
+ this.picker.setDate(value, true);
240
+ }
241
+ return null;
242
+ },
243
+
244
+ /**
245
+ * Get the dates currently selected.
246
+ * Usefull for the range mode to get the date list
247
+ * @returns {Array<[Date|String]>|boolean} the selected dates
248
+ */
249
+ getSelectedDates: function getSelectedDates() {
250
+ var selection;
251
+ if (this.is('ready') && this.picker) {
252
+ selection = this.picker.selectedDates;
253
+ if (selection && !_.isArray(selection)) {
254
+ return [selection];
255
+ }
256
+ return selection;
257
+ }
258
+ return false;
259
+ },
260
+
261
+ /**
262
+ * Get the date/time format description, ie. 'YYYY-MM-DD'
263
+ * @returns {String} the format
264
+ */
265
+ getFormat: function getFormat() {
266
+ return format;
267
+ },
268
+
269
+ /**
270
+ * Open the picker
271
+ * @returns {dateTimePicker} chains
272
+ * @fires dateTimePicker#open
273
+ */
274
+ open: function open() {
275
+ if (this.is('ready')) {
276
+ this.picker.open();
277
+ }
278
+ return this;
279
+ },
280
+
281
+ /**
282
+ * Close the picker
283
+ * @returns {dateTimePicker} chains
284
+ * @fires dateTimePicker#close
285
+ */
286
+ close: function close() {
287
+ if (this.is('ready')) {
288
+ this.picker.close();
289
+ }
290
+ return this;
291
+ },
292
+
293
+ /**
294
+ * Clear the field content and close the picker
295
+ * @returns {dateTimePicker} chains
296
+ * @fires dateTimePicker#close
297
+ * @fires dateTimePicker#clear
298
+ */
299
+ clear: function clear() {
300
+ if (this.is('ready')) {
301
+ value = '';
302
+
303
+ this.picker.close();
304
+ this.picker.clear();
305
+
306
+ /**
307
+ * The picker get cleared
308
+ * @event dateTimePicker#clear
309
+ */
310
+ this.trigger('clear');
311
+ }
312
+ return this;
313
+ },
314
+
315
+ /**
316
+ * Clear the field content and close the picker
317
+ * @returns {dateTimePicker} chains
318
+ * @fires dateTimePicker#open
319
+ * @fires dateTimePicker#close
320
+ */
321
+ toggle: function toogle() {
322
+ if (this.is('ready')) {
323
+ this.picker.toggle();
324
+ }
325
+ return this;
326
+ },
327
+
328
+ /**
329
+ * Update constraints on a running instance
330
+ * @param {String} constraint - the constraint name in minDate, maxDate, enable, disable
331
+ * @param {*} constraintValue - the constraint value to update
332
+ * @returns {dateTimePicker} chains
333
+ * @fires dateTimePicker#open
334
+ * @fires dateTimePicker#close
335
+ */
336
+ updateConstraints: function updateConstraints(constraint, constraintValue) {
337
+ if (this.is('ready')) {
338
+ if (_.contains(supportedConstraints, constraint)) {
339
+ this.picker.set(constraint, constraintValue);
340
+ }
341
+ }
342
+ return this;
343
+ }
344
+ },
345
+ defaultConfig
346
+ );
347
+
348
+ dateTimePicker
349
+ .setTemplate(dateTimePickerTpl)
350
+ .on('init', function() {
351
+ var self = this;
352
+
353
+ var locale;
354
+ var setup = setups[this.config.setup] || setups.datetime;
355
+
356
+ //map the locale from the options to the picker locale
357
+ if (this.config.locale && hasTranslationsForLocale(this.config.locale)) {
358
+ locale = this.config.locale;
359
+ }
360
+
361
+ //date/time format
362
+ if (locale && this.config.useLocalizedFormat) {
363
+ //get the format from the locale
364
+ format = getLongLocalizedFormat(locale, setup.format.localized);
365
+ } else {
366
+ //get the format from the config
367
+ format = this.config.format || setup.format.default;
368
+ }
369
+
370
+ //input field configuration
371
+ this.config.field = this.config.field || {};
372
+
373
+ // replace a field by the date picker input field
374
+ //TODO consider replacing data-attr and classes
375
+ if (this.config.replaceField && this.config.replaceField instanceof HTMLInputElement) {
376
+ this.config.field.id = this.config.replaceField.id;
377
+ this.config.field.name = this.config.replaceField.name;
378
+ this.config.field.placeholder = this.config.replaceField.placeholder;
379
+ this.config.field.value = this.config.replaceField.value;
380
+ this.config.field.pattern = this.config.replaceField.pattern;
381
+
382
+ this.config.replaceField.parentNode.removeChild(this.config.replaceField);
383
+ }
384
+
385
+ if (!this.config.field.placeholder && format && setup.mode === 'single') {
386
+ this.config.field.placeholder = format.toLowerCase();
387
+ }
388
+ if (!this.config.field.label) {
389
+ this.config.field.label = setup.label;
390
+ }
391
+
392
+ /**
393
+ * Build the configuration of the picker
394
+ * @see https://flatpickr.js.org/options/
395
+ */
396
+ this.pickerConfig = {
397
+ mode: setup.mode,
398
+ enableTime: !!setup.enableTime,
399
+ noCalendar: !!setup.noCalendar,
400
+ time_24hr: !isFormatAmPm(format),
401
+ enableSeconds: setup.enableTime && isFormatInSeconds(format),
402
+ allowInput: true,
403
+ clickOpens: !this.config.controlButtons,
404
+ disableMobile: true,
405
+
406
+ /**
407
+ * How flatpickr will format the given date
408
+ * @param {Date} date
409
+ * @returns {String} the formatted date
410
+ */
411
+ formatDate: function formatDate(date) {
412
+ return moment(date).format(format);
413
+ },
414
+
415
+ /**
416
+ * How flatpickr parse the given input
417
+ * @param {String} dateString
418
+ * @returns {Date}
419
+ */
420
+ parseDate: function parseDate(dateString) {
421
+ return moment(dateString, format).toDate();
422
+ },
423
+
424
+ /**
425
+ * When the picker is opened
426
+ * @fires dateTimePicker#open
427
+ */
428
+ onOpen: function onOpen() {
429
+ /**
430
+ * The picker get opened
431
+ * @event dateTimePicker#open
432
+ */
433
+ self.trigger('open');
434
+ },
435
+
436
+ /**
437
+ * When the picker is opened
438
+ * @fires dateTimePicker#close
439
+ */
440
+ onClose: function onClose() {
441
+ /**
442
+ * The picker get closed
443
+ * @event dateTimePicker#close
444
+ */
445
+ self.trigger('close');
446
+ },
447
+
448
+ /**
449
+ * Hook flatpickr error handler
450
+ * @param {Error} err - the thrown error
451
+ */
452
+ errorHandler: function errorHandler(err) {
453
+ if (err instanceof Error) {
454
+ //if an invalid date is provided
455
+ //add a visual feedback indicating why the field get emptied
456
+ if (/^Invalid date/.test(err.message)) {
457
+ self.controls.input.classList.add('error');
458
+ _.delay(function() {
459
+ self.controls.input.classList.remove('error');
460
+ }, 1000);
461
+ } else {
462
+ /**
463
+ * Unexpected error
464
+ * @event dateTimePicker#error
465
+ * @param {Error} err
466
+ */
467
+ self.trigger('error', err);
468
+ }
469
+ }
470
+ }
471
+ };
472
+ //locale should be defined only if set...
473
+ if (locale) {
474
+ this.pickerConfig.locale = locale;
475
+ }
476
+
477
+ _.forEach(this.config.constraints, function(constraintValue, constraint) {
478
+ if (_.contains(supportedConstraints, constraint) && constraintValue) {
479
+ self.pickerConfig[constraint] = constraintValue;
480
+ }
481
+ });
482
+
483
+ //render into the container
484
+ if (container) {
485
+ setTimeout(function() {
486
+ self.render(container);
487
+ }, 0);
488
+ }
489
+ })
490
+ .on('render', function() {
491
+ var self = this;
492
+
493
+ var element = this.getElement()[0];
494
+
495
+ this.controls = {
496
+ input: element.querySelector('input')
497
+ };
498
+
499
+ //always scope the picker to the component container
500
+ //in order to scope and style each instance
501
+ this.pickerConfig.appendTo = element;
502
+
503
+ //behavior of the right buttons if configured
504
+ if (this.config.controlButtons) {
505
+ this.controls.toggleButton = element.querySelector('.picker-toggle');
506
+ this.controls.clearButton = element.querySelector('.picker-clear');
507
+
508
+ this.controls.toggleButton.addEventListener('click', function(e) {
509
+ e.preventDefault();
510
+ e.stopPropagation();
511
+ self.toggle();
512
+ });
513
+
514
+ this.controls.clearButton.addEventListener('click', function(e) {
515
+ e.preventDefault();
516
+ e.stopPropagation();
517
+ self.clear();
518
+ });
519
+ }
520
+
521
+ this.controls.input.addEventListener('change', function() {
522
+ var newValue = self.controls.input.value;
523
+
524
+ if (value && _.isString(newValue) && _.isEmpty(newValue)) {
525
+ //if someone remove the value from the field
526
+ //it's considered a property clean (resets everything)
527
+ self.clear();
528
+ } else if (value !== newValue) {
529
+ value = newValue;
530
+
531
+ /**
532
+ * A value get changed
533
+ * @event dateTimePicker#change
534
+ * @param {String} value - the date/time value
535
+ */
536
+ self.trigger('change', value);
537
+ }
538
+ });
539
+
540
+ value = this.controls.input.value;
541
+
542
+ //instantiate the picker
543
+ _.defer(function() {
544
+ self.picker = flatpickr(self.controls.input, self.pickerConfig);
545
+
546
+ self.enable()
547
+ .setState('ready', true)
548
+ .trigger('ready');
549
+ });
550
+ })
551
+ .on('enable', function() {
552
+ if (this.controls) {
553
+ this.controls.input.disabled = false;
554
+ if (this.config.controlButtons) {
555
+ this.controls.toggleButton.disabled = false;
556
+ this.controls.clearButton.disabled = false;
557
+ }
558
+ }
559
+ })
560
+ .on('disable', function() {
561
+ if (this.controls) {
562
+ this.controls.input.disabled = true;
563
+ if (this.config.controlButtons) {
564
+ this.controls.toggleButton.disabled = true;
565
+ this.controls.clearButton.disabled = true;
566
+ }
567
+ }
568
+ });
569
+
570
+ //defered init to catch the event
571
+ setTimeout(function() {
572
+ dateTimePicker.init(options);
573
+ }, 0);
574
+
575
+ return dateTimePicker;
576
+ }