@oat-sa/tao-core-ui 1.60.2 → 1.62.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 (783) hide show
  1. package/LICENSE +339 -339
  2. package/README.md +23 -18
  3. package/dist/actionbar.js +393 -410
  4. package/dist/adder.js +143 -156
  5. package/dist/animable/absorbable/absorbable.js +208 -211
  6. package/dist/animable/absorbable/css/absorb.css +7 -8
  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 +174 -174
  11. package/dist/areaBroker.js +59 -72
  12. package/dist/autocomplete/css/autocomplete.css +7 -8
  13. package/dist/autocomplete/css/autocomplete.css.map +1 -1
  14. package/dist/autocomplete.js +494 -604
  15. package/dist/autoscroll.js +23 -25
  16. package/dist/badge/badge.js +201 -199
  17. package/dist/badge/css/badge.css +7 -8
  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 +286 -285
  22. package/dist/btngrouper.js +83 -95
  23. package/dist/bulkActionPopup/css/bulkActionPopup.css +7 -7
  24. package/dist/bulkActionPopup/css/bulkActionPopup.css.map +1 -1
  25. package/dist/bulkActionPopup.js +503 -503
  26. package/dist/button.js +300 -293
  27. package/dist/calculator/css/calculator.css +10 -10
  28. package/dist/calculator/css/calculator.css.map +1 -1
  29. package/dist/calculator.js +59 -72
  30. package/dist/cascadingComboBox.js +257 -256
  31. package/dist/ckeditor/ckConfigurator.js +130 -154
  32. package/dist/ckeditor/dtdHandler.js +305 -345
  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 +437 -470
  36. package/dist/component/alignable.js +97 -121
  37. package/dist/component/containable.js +53 -58
  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 +34 -36
  43. package/dist/component/placeable.js +84 -102
  44. package/dist/component/resizable.js +79 -89
  45. package/dist/component/stackable.js +21 -27
  46. package/dist/component/windowed.js +284 -297
  47. package/dist/component.js +439 -467
  48. package/dist/container.js +79 -98
  49. package/dist/contextualPopup/css/contextualPopup.css +7 -7
  50. package/dist/contextualPopup/css/contextualPopup.css.map +1 -1
  51. package/dist/contextualPopup.js +417 -436
  52. package/dist/dashboard/css/dashboard.css +7 -7
  53. package/dist/dashboard/css/dashboard.css.map +1 -1
  54. package/dist/dashboard.js +302 -305
  55. package/dist/datalist/css/datalist.css +7 -7
  56. package/dist/datalist/css/datalist.css.map +1 -1
  57. package/dist/datalist.js +783 -791
  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 +28 -30
  61. package/dist/datatable/filterStrategy/multiple.js +26 -45
  62. package/dist/datatable/filterStrategy/single.js +28 -40
  63. package/dist/datatable.js +1591 -1616
  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 +398 -412
  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 +670 -703
  70. package/dist/deleter.js +383 -398
  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 +295 -293
  74. package/dist/dialog/alert.js +30 -32
  75. package/dist/dialog/confirm.js +29 -32
  76. package/dist/dialog/confirmDelete.js +223 -221
  77. package/dist/dialog.js +651 -695
  78. package/dist/disabler.js +108 -119
  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 +172 -169
  82. package/dist/documentViewer/providers/pdfViewer/pdfjs/areaBroker.js +32 -29
  83. package/dist/documentViewer/providers/pdfViewer/pdfjs/findBar.js +523 -564
  84. package/dist/documentViewer/providers/pdfViewer/pdfjs/pageView.js +376 -393
  85. package/dist/documentViewer/providers/pdfViewer/pdfjs/pagesManager.js +53 -68
  86. package/dist/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +517 -567
  87. package/dist/documentViewer/providers/pdfViewer/pdfjs/textManager.js +73 -96
  88. package/dist/documentViewer/providers/pdfViewer/pdfjs/viewer.js +381 -392
  89. package/dist/documentViewer/providers/pdfViewer/pdfjs/wrapper.js +125 -152
  90. package/dist/documentViewer/providers/pdfViewer.js +189 -191
  91. package/dist/documentViewer/viewerFactory.js +76 -81
  92. package/dist/documentViewer.js +303 -311
  93. package/dist/dropdown/css/dropdown.css +7 -7
  94. package/dist/dropdown/css/dropdown.css.map +1 -1
  95. package/dist/dropdown.js +392 -412
  96. package/dist/durationer.js +77 -85
  97. package/dist/dynamicComponent/css/dynamicComponent.css +7 -7
  98. package/dist/dynamicComponent/css/dynamicComponent.css.map +1 -1
  99. package/dist/dynamicComponent.js +595 -630
  100. package/dist/feedback.js +365 -375
  101. package/dist/figure/FigureStateActive.js +246 -296
  102. package/dist/filesender.js +44 -54
  103. package/dist/filter.js +244 -240
  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 +357 -362
  109. package/dist/form/form.js +703 -984
  110. package/dist/form/simpleForm.js +74 -77
  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 +235 -241
  114. package/dist/form/validator/validator.js +181 -267
  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 +27 -28
  118. package/dist/form/widget/loader.js +16 -16
  119. package/dist/form/widget/providers/checkBox.js +257 -264
  120. package/dist/form/widget/providers/comboBox.js +194 -193
  121. package/dist/form/widget/providers/default.js +44 -50
  122. package/dist/form/widget/providers/hidden.js +179 -176
  123. package/dist/form/widget/providers/hiddenBox.js +262 -272
  124. package/dist/form/widget/providers/radioBox.js +222 -223
  125. package/dist/form/widget/providers/textArea.js +197 -193
  126. package/dist/form/widget/providers/textBox.js +36 -37
  127. package/dist/form/widget/widget.js +480 -508
  128. package/dist/form.js +12 -17
  129. package/dist/formValidator/formValidator.js +74 -91
  130. package/dist/formValidator/highlighters/highlighter.js +43 -51
  131. package/dist/formValidator/highlighters/message.js +31 -32
  132. package/dist/formValidator/highlighters/tooltip.js +33 -35
  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 +323 -331
  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 +215 -216
  139. package/dist/generis/widget/checkBox/checkBox.js +227 -225
  140. package/dist/generis/widget/comboBox/comboBox.js +189 -183
  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 +231 -232
  144. package/dist/generis/widget/loader.js +21 -23
  145. package/dist/generis/widget/textBox/textBox.js +178 -172
  146. package/dist/generis/widget/widget.js +255 -266
  147. package/dist/groupedComboBox.js +231 -226
  148. package/dist/groupvalidator.js +30 -34
  149. package/dist/hider.js +43 -50
  150. package/dist/highlighter.js +946 -1057
  151. package/dist/image/ImgStateActive/extractLabel.js +20 -21
  152. package/dist/image/ImgStateActive/helper.js +21 -25
  153. package/dist/image/ImgStateActive/initHelper.js +133 -162
  154. package/dist/image/ImgStateActive/initMediaEditor.js +72 -92
  155. package/dist/image/ImgStateActive/mediaSizer.js +48 -58
  156. package/dist/image/ImgStateActive.js +185 -215
  157. package/dist/incrementer.js +91 -110
  158. package/dist/inplacer.js +108 -132
  159. package/dist/interactUtils.js +56 -67
  160. package/dist/itemButtonList/css/item-button-list.css +23 -24
  161. package/dist/itemButtonList/css/item-button-list.css.map +1 -1
  162. package/dist/itemButtonList.js +444 -469
  163. package/dist/keyNavigation/navigableDomElement.js +124 -158
  164. package/dist/keyNavigation/navigator.js +235 -312
  165. package/dist/listbox/css/listbox.css +7 -7
  166. package/dist/listbox/css/listbox.css.map +1 -1
  167. package/dist/listbox.js +463 -476
  168. package/dist/liststyler.js +75 -76
  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 +219 -218
  172. package/dist/lock.js +484 -509
  173. package/dist/login/login.js +471 -486
  174. package/dist/maths/calculator/basicCalculator.js +247 -242
  175. package/dist/maths/calculator/calculatorComponent.js +34 -36
  176. package/dist/maths/calculator/core/areaBroker.js +30 -28
  177. package/dist/maths/calculator/core/board.js +805 -872
  178. package/dist/maths/calculator/core/expression.js +500 -518
  179. package/dist/maths/calculator/core/labels.js +240 -235
  180. package/dist/maths/calculator/core/plugin.js +20 -20
  181. package/dist/maths/calculator/core/terms.js +27 -27
  182. package/dist/maths/calculator/core/tokenizer.js +119 -132
  183. package/dist/maths/calculator/core/tokens.js +157 -168
  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 +24 -27
  187. package/dist/maths/calculator/plugins/core/degrad.js +22 -30
  188. package/dist/maths/calculator/plugins/core/history.js +55 -67
  189. package/dist/maths/calculator/plugins/core/remind.js +22 -25
  190. package/dist/maths/calculator/plugins/core/stepNavigation.js +33 -49
  191. package/dist/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +255 -258
  192. package/dist/maths/calculator/plugins/modifiers/pow10.js +47 -52
  193. package/dist/maths/calculator/plugins/modifiers/sign.js +103 -130
  194. package/dist/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +288 -293
  195. package/dist/maths/calculator/pluginsLoader.js +22 -22
  196. package/dist/maths/calculator/scientificCalculator.js +339 -334
  197. package/dist/mediaEditor/mediaEditorComponent.js +244 -249
  198. package/dist/mediaEditor/plugins/mediaAlignment/helper.js +28 -33
  199. package/dist/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +228 -236
  200. package/dist/mediaEditor/plugins/mediaAlignment/style.css +7 -7
  201. package/dist/mediaEditor/plugins/mediaDimension/helper.js +81 -106
  202. package/dist/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +597 -635
  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 +646 -706
  207. package/dist/mediaplayer/players/youtube.js +393 -438
  208. package/dist/mediaplayer/players.js +19 -19
  209. package/dist/mediaplayer/support.js +66 -79
  210. package/dist/mediaplayer/utils/reminder.js +117 -128
  211. package/dist/mediaplayer/utils/timeObserver.js +106 -109
  212. package/dist/mediaplayer/youtubeManager.js +142 -170
  213. package/dist/mediaplayer.js +1484 -1774
  214. package/dist/mediasizer.js +633 -676
  215. package/dist/modal.js +137 -153
  216. package/dist/movableComponent.js +37 -37
  217. package/dist/pageSizeSelector.js +231 -224
  218. package/dist/pageStatus.js +43 -46
  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 +24 -25
  222. package/dist/pagination/providers/pages.js +281 -291
  223. package/dist/pagination/providers/simple.js +202 -196
  224. package/dist/pagination.js +49 -72
  225. package/dist/previewer.js +113 -138
  226. package/dist/progressbar.js +70 -80
  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 +489 -0
  230. package/dist/report.js +356 -359
  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 +275 -289
  234. package/dist/resource/list.js +1589 -1371
  235. package/dist/resource/selectable.js +101 -136
  236. package/dist/resource/selector.js +855 -914
  237. package/dist/resource/tree.js +1796 -1612
  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 +540 -587
  241. package/dist/resourcemgr/filePreview.js +16 -25
  242. package/dist/resourcemgr/fileSelector.js +520 -547
  243. package/dist/resourcemgr/util/updatePermissions.js +10 -18
  244. package/dist/resourcemgr.js +325 -332
  245. package/dist/scroller.js +29 -33
  246. package/dist/searchModal/advancedSearch.js +949 -833
  247. package/dist/searchModal/css/advancedSearch.css +7 -14
  248. package/dist/searchModal/css/advancedSearch.css.map +1 -1
  249. package/dist/searchModal/css/searchModal.css +28 -8
  250. package/dist/searchModal/css/searchModal.css.map +1 -1
  251. package/dist/searchModal.js +616 -335
  252. package/dist/selecter.js +21 -28
  253. package/dist/stacker.js +52 -60
  254. package/dist/switch/css/switch.css +7 -7
  255. package/dist/switch/css/switch.css.map +1 -1
  256. package/dist/switch/switch.js +305 -311
  257. package/dist/tableModel.js +39 -49
  258. package/dist/tabs/css/tabs.css +12 -12
  259. package/dist/tabs/css/tabs.css.map +1 -1
  260. package/dist/tabs.js +588 -639
  261. package/dist/taskQueue/css/taskQueue.css +7 -7
  262. package/dist/taskQueue/css/taskQueue.css.map +1 -1
  263. package/dist/taskQueue/status.js +317 -322
  264. package/dist/taskQueue/table.js +383 -394
  265. package/dist/taskQueue/taskQueue.js +19 -19
  266. package/dist/taskQueue/taskQueueModel.js +459 -538
  267. package/dist/taskQueue.js +49 -67
  268. package/dist/taskQueueButton/css/taskable.css +7 -7
  269. package/dist/taskQueueButton/css/taskable.css.map +1 -1
  270. package/dist/taskQueueButton/css/treeButton.css +7 -7
  271. package/dist/taskQueueButton/css/treeButton.css.map +1 -1
  272. package/dist/taskQueueButton/standardButton.js +45 -43
  273. package/dist/taskQueueButton/taskable.js +267 -272
  274. package/dist/taskQueueButton/treeButton.js +200 -198
  275. package/dist/themeLoader.js +109 -129
  276. package/dist/themes.js +86 -100
  277. package/dist/toggler.js +76 -88
  278. package/dist/tooltip.js +296 -311
  279. package/dist/tooltipster.js +17 -17
  280. package/dist/transformer.js +140 -169
  281. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  282. package/dist/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  283. package/dist/tristateCheckboxGroup.js +319 -325
  284. package/dist/uploader.js +691 -724
  285. package/dist/validator/Report.js +1 -2
  286. package/dist/validator/Validator.js +6 -25
  287. package/dist/validator/validators.js +66 -80
  288. package/dist/validator.js +218 -254
  289. package/dist/waitForMedia.js +45 -51
  290. package/dist/waitingDialog/css/waitingDialog.css +7 -7
  291. package/dist/waitingDialog/css/waitingDialog.css.map +1 -1
  292. package/dist/waitingDialog/waitingDialog.js +59 -77
  293. package/package.json +109 -107
  294. package/scss/basic.scss +16 -16
  295. package/scss/ckeditor/skins/tao/scss/inc/_ck-icons.scss +59 -59
  296. package/scss/ckeditor/skins/tao/scss/inc/_tao.scss +59 -59
  297. package/scss/font/tao/tao.svg +234 -234
  298. package/scss/inc/_base.scss +495 -495
  299. package/scss/inc/_bootstrap.scss +6 -6
  300. package/scss/inc/_buttons.scss +114 -114
  301. package/scss/inc/_colors.scss +93 -88
  302. package/scss/inc/_feedback.scss +150 -150
  303. package/scss/inc/_flex-grid.scss +15 -15
  304. package/scss/inc/_fonts.scss +4 -4
  305. package/scss/inc/_forms.scss +832 -832
  306. package/scss/inc/_functions.scss +283 -283
  307. package/scss/inc/_jquery.nouislider.scss +254 -254
  308. package/scss/inc/_normalize.scss +528 -528
  309. package/scss/inc/_report.scss +67 -67
  310. package/scss/inc/_secondary-properties.scss +89 -89
  311. package/scss/inc/_select2.scss +634 -634
  312. package/scss/inc/_toolbars.scss +155 -155
  313. package/scss/inc/_tooltip.scss +312 -312
  314. package/scss/inc/_variables.scss +21 -21
  315. package/scss/inc/base/_highlight.scss +5 -5
  316. package/scss/inc/base/_list-style.scss +58 -58
  317. package/scss/inc/base/_svg.scss +3 -3
  318. package/scss/inc/base/_table.scss +62 -62
  319. package/scss/inc/fonts/_source-sans-pro.scss +29 -29
  320. package/scss/inc/fonts/_tao-icon-classes.scss +226 -226
  321. package/scss/inc/fonts/_tao-icon-def.scss +12 -12
  322. package/scss/inc/fonts/_tao-icon-vars.scss +240 -240
  323. package/src/actionbar/tpl/main.tpl +8 -8
  324. package/src/actionbar.js +251 -251
  325. package/src/adder.js +250 -250
  326. package/src/animable/absorbable/absorbable.js +134 -134
  327. package/src/animable/absorbable/css/absorb.css +7 -8
  328. package/src/animable/absorbable/css/absorb.css.map +1 -1
  329. package/src/animable/absorbable/scss/absorb.scss +37 -37
  330. package/src/animable/pulsable/css/pulse.css +7 -7
  331. package/src/animable/pulsable/css/pulse.css.map +1 -1
  332. package/src/animable/pulsable/pulsable.js +90 -90
  333. package/src/animable/pulsable/scss/pulse.scss +22 -22
  334. package/src/areaBroker.js +160 -160
  335. package/src/autocomplete/css/autocomplete.css +7 -8
  336. package/src/autocomplete/css/autocomplete.css.map +1 -1
  337. package/src/autocomplete/scss/autocomplete.scss +37 -37
  338. package/src/autocomplete.js +1029 -1029
  339. package/src/autoscroll.js +57 -57
  340. package/src/badge/badge.js +119 -119
  341. package/src/badge/css/badge.css +7 -8
  342. package/src/badge/css/badge.css.map +1 -1
  343. package/src/badge/scss/badge.scss +92 -92
  344. package/src/badge/tpl/badge.tpl +4 -4
  345. package/src/breadcrumbs/css/breadcrumbs.css +7 -7
  346. package/src/breadcrumbs/css/breadcrumbs.css.map +1 -1
  347. package/src/breadcrumbs/scss/breadcrumbs.scss +52 -52
  348. package/src/breadcrumbs/tpl/breadcrumbs.tpl +20 -20
  349. package/src/breadcrumbs.js +99 -99
  350. package/src/btngrouper.js +213 -213
  351. package/src/bulkActionPopup/css/bulkActionPopup.css +7 -7
  352. package/src/bulkActionPopup/css/bulkActionPopup.css.map +1 -1
  353. package/src/bulkActionPopup/scss/bulkActionPopup.scss +63 -63
  354. package/src/bulkActionPopup/tpl/layout.tpl +76 -76
  355. package/src/bulkActionPopup/tpl/select.tpl +8 -8
  356. package/src/bulkActionPopup.js +274 -274
  357. package/src/button/tpl/button.tpl +4 -4
  358. package/src/button.js +135 -135
  359. package/src/calculator/css/calculator.css +10 -10
  360. package/src/calculator/css/calculator.css.map +1 -1
  361. package/src/calculator/scss/calculator.scss +139 -139
  362. package/src/calculator.js +188 -188
  363. package/src/cascadingComboBox.js +126 -126
  364. package/src/ckeditor/ckConfigurator.js +736 -736
  365. package/src/ckeditor/dtdHandler.js +1030 -1030
  366. package/src/class/css/selector.css +7 -7
  367. package/src/class/css/selector.css.map +1 -1
  368. package/src/class/scss/selector.scss +101 -101
  369. package/src/class/selector.js +329 -329
  370. package/src/class/tpl/listItem.tpl +9 -9
  371. package/src/class/tpl/selector.tpl +10 -10
  372. package/src/component/alignable.js +274 -274
  373. package/src/component/containable.js +122 -122
  374. package/src/component/css/components.css +7 -7
  375. package/src/component/css/components.css.map +1 -1
  376. package/src/component/css/windowComponent.css +7 -7
  377. package/src/component/css/windowComponent.css.map +1 -1
  378. package/src/component/draggable.js +104 -104
  379. package/src/component/placeable.js +233 -233
  380. package/src/component/resizable.js +195 -195
  381. package/src/component/scss/components.scss +507 -507
  382. package/src/component/scss/windowComponent.scss +62 -62
  383. package/src/component/stackable.js +67 -67
  384. package/src/component/tpl/window.tpl +7 -7
  385. package/src/component/windowed.js +206 -206
  386. package/src/component.js +401 -401
  387. package/src/container.js +200 -200
  388. package/src/contextualPopup/css/contextualPopup.css +7 -7
  389. package/src/contextualPopup/css/contextualPopup.css.map +1 -1
  390. package/src/contextualPopup/scss/contextualPopup.scss +78 -78
  391. package/src/contextualPopup/tpl/popup.tpl +10 -10
  392. package/src/contextualPopup.js +297 -297
  393. package/src/css/basic.css +103 -106
  394. package/src/css/basic.css.map +1 -1
  395. package/src/dashboard/css/dashboard.css +7 -7
  396. package/src/dashboard/css/dashboard.css.map +1 -1
  397. package/src/dashboard/scss/dashboard.scss +93 -93
  398. package/src/dashboard/tpl/dashboard.tpl +16 -16
  399. package/src/dashboard/tpl/dashboardMetricsList.tpl +15 -15
  400. package/src/dashboard.js +184 -184
  401. package/src/datalist/css/datalist.css +7 -7
  402. package/src/datalist/css/datalist.css.map +1 -1
  403. package/src/datalist/scss/datalist.scss +116 -116
  404. package/src/datalist/tpl/list.tpl +24 -24
  405. package/src/datalist/tpl/main.tpl +44 -44
  406. package/src/datalist.js +500 -500
  407. package/src/datatable/css/datatable.css +11 -7
  408. package/src/datatable/css/datatable.css.map +1 -1
  409. package/src/datatable/filterStrategy/filterStrategy.js +70 -70
  410. package/src/datatable/filterStrategy/multiple.js +126 -126
  411. package/src/datatable/filterStrategy/single.js +108 -108
  412. package/src/datatable/scss/datatable.scss +149 -146
  413. package/src/datatable/tpl/button.tpl +6 -6
  414. package/src/datatable/tpl/layout.tpl +158 -158
  415. package/src/datatable.js +1056 -1056
  416. package/src/dateRange/css/dateRange.css +7 -7
  417. package/src/dateRange/css/dateRange.css.map +1 -1
  418. package/src/dateRange/dateRange.js +341 -341
  419. package/src/dateRange/scss/dateRange.scss +7 -7
  420. package/src/dateRange/tpl/select.tpl +18 -18
  421. package/src/datetime/css/picker.css +7 -7
  422. package/src/datetime/css/picker.css.map +1 -1
  423. package/src/datetime/picker.js +576 -576
  424. package/src/datetime/scss/picker.scss +192 -192
  425. package/src/datetime/tpl/picker.tpl +18 -18
  426. package/src/deleter/undo.tpl +6 -6
  427. package/src/deleter.js +296 -296
  428. package/src/destination/css/selector.css +7 -7
  429. package/src/destination/css/selector.css.map +1 -1
  430. package/src/destination/scss/selector.scss +36 -36
  431. package/src/destination/selector.js +195 -195
  432. package/src/destination/tpl/selector.tpl +13 -13
  433. package/src/dialog/alert.js +70 -70
  434. package/src/dialog/confirm.js +85 -85
  435. package/src/dialog/confirmDelete.js +95 -95
  436. package/src/dialog/tpl/body.tpl +24 -24
  437. package/src/dialog/tpl/buttons.tpl +6 -6
  438. package/src/dialog/tpl/checkbox.tpl +5 -5
  439. package/src/dialog.js +517 -517
  440. package/src/disabler.js +230 -230
  441. package/src/documentViewer/css/documentViewer.css +7 -7
  442. package/src/documentViewer/css/documentViewer.css.map +1 -1
  443. package/src/documentViewer/providers/pdfViewer/fallback/viewer.js +69 -69
  444. package/src/documentViewer/providers/pdfViewer/pdfjs/areaBroker.js +41 -41
  445. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.js +475 -475
  446. package/src/documentViewer/providers/pdfViewer/pdfjs/findBar.tpl +20 -20
  447. package/src/documentViewer/providers/pdfViewer/pdfjs/match.tpl +1 -1
  448. package/src/documentViewer/providers/pdfViewer/pdfjs/page.tpl +4 -4
  449. package/src/documentViewer/providers/pdfViewer/pdfjs/pageView.js +318 -318
  450. package/src/documentViewer/providers/pdfViewer/pdfjs/pagesManager.js +167 -167
  451. package/src/documentViewer/providers/pdfViewer/pdfjs/searchEngine.js +451 -451
  452. package/src/documentViewer/providers/pdfViewer/pdfjs/textManager.js +252 -252
  453. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.js +299 -299
  454. package/src/documentViewer/providers/pdfViewer/pdfjs/viewer.tpl +16 -16
  455. package/src/documentViewer/providers/pdfViewer/pdfjs/wrapper.js +351 -351
  456. package/src/documentViewer/providers/pdfViewer.js +93 -93
  457. package/src/documentViewer/scss/documentViewer.scss +184 -184
  458. package/src/documentViewer/viewerFactory.js +191 -191
  459. package/src/documentViewer.js +238 -238
  460. package/src/dropdown/css/dropdown.css +7 -7
  461. package/src/dropdown/css/dropdown.css.map +1 -1
  462. package/src/dropdown/scss/dropdown.scss +99 -99
  463. package/src/dropdown/tpl/dropdown.tpl +8 -8
  464. package/src/dropdown/tpl/list-item.tpl +4 -4
  465. package/src/dropdown.js +255 -255
  466. package/src/durationer.js +222 -222
  467. package/src/dynamicComponent/css/dynamicComponent.css +7 -7
  468. package/src/dynamicComponent/css/dynamicComponent.css.map +1 -1
  469. package/src/dynamicComponent/scss/dynamicComponent.scss +98 -98
  470. package/src/dynamicComponent/tpl/layout.tpl +17 -17
  471. package/src/dynamicComponent.js +554 -554
  472. package/src/feedback/feedback.tpl +7 -7
  473. package/src/feedback.js +295 -295
  474. package/src/figure/FigureStateActive.js +174 -174
  475. package/src/filesender.js +114 -114
  476. package/src/filter/template.tpl +5 -5
  477. package/src/filter.js +135 -135
  478. package/src/form/css/dropdownForm.css +7 -7
  479. package/src/form/css/dropdownForm.css.map +1 -1
  480. package/src/form/css/form.css +7 -7
  481. package/src/form/css/form.css.map +1 -1
  482. package/src/form/dropdownForm.js +281 -281
  483. package/src/form/form.js +688 -688
  484. package/src/form/scss/dropdownForm.scss +60 -60
  485. package/src/form/scss/form.scss +25 -25
  486. package/src/form/simpleForm.js +125 -125
  487. package/src/form/tpl/dropdownForm.tpl +4 -4
  488. package/src/form/tpl/form.tpl +7 -7
  489. package/src/form/validator/css/validator.css +7 -7
  490. package/src/form/validator/css/validator.css.map +1 -1
  491. package/src/form/validator/renderer.js +118 -118
  492. package/src/form/validator/scss/validator.scss +14 -14
  493. package/src/form/validator/tpl/message.tpl +1 -1
  494. package/src/form/validator/tpl/validator.tpl +1 -1
  495. package/src/form/validator/validator.js +220 -220
  496. package/src/form/widget/css/widget.css +7 -7
  497. package/src/form/widget/css/widget.css.map +1 -1
  498. package/src/form/widget/definitions.js +51 -51
  499. package/src/form/widget/loader.js +40 -40
  500. package/src/form/widget/providers/checkBox.js +138 -138
  501. package/src/form/widget/providers/comboBox.js +63 -63
  502. package/src/form/widget/providers/default.js +90 -90
  503. package/src/form/widget/providers/hidden.js +62 -62
  504. package/src/form/widget/providers/hiddenBox.js +152 -152
  505. package/src/form/widget/providers/radioBox.js +99 -99
  506. package/src/form/widget/providers/textArea.js +52 -52
  507. package/src/form/widget/providers/textBox.js +48 -48
  508. package/src/form/widget/scss/widget.scss +55 -55
  509. package/src/form/widget/tpl/checkBox.tpl +25 -25
  510. package/src/form/widget/tpl/comboBox.tpl +13 -13
  511. package/src/form/widget/tpl/hidden.tpl +1 -1
  512. package/src/form/widget/tpl/hiddenBox.tpl +17 -17
  513. package/src/form/widget/tpl/label.tpl +6 -6
  514. package/src/form/widget/tpl/radioBox.tpl +25 -25
  515. package/src/form/widget/tpl/textArea.tpl +8 -8
  516. package/src/form/widget/tpl/widget.tpl +8 -8
  517. package/src/form/widget/widget.js +372 -372
  518. package/src/form.js +53 -53
  519. package/src/formValidator/formValidator.js +253 -253
  520. package/src/formValidator/highlighters/highlighter.js +102 -102
  521. package/src/formValidator/highlighters/message.js +70 -70
  522. package/src/formValidator/highlighters/tooltip.js +78 -78
  523. package/src/generis/form/css/form.css +7 -7
  524. package/src/generis/form/css/form.css.map +1 -1
  525. package/src/generis/form/form.js +239 -239
  526. package/src/generis/form/readme.md +70 -70
  527. package/src/generis/form/scss/form.scss +23 -23
  528. package/src/generis/form/tpl/form.tpl +16 -16
  529. package/src/generis/validator/css/validator.css +7 -7
  530. package/src/generis/validator/css/validator.css.map +1 -1
  531. package/src/generis/validator/readme.md +46 -46
  532. package/src/generis/validator/scss/validator.scss +13 -13
  533. package/src/generis/validator/validator.js +128 -128
  534. package/src/generis/widget/checkBox/checkBox.js +112 -112
  535. package/src/generis/widget/checkBox/checkBox.tpl +18 -18
  536. package/src/generis/widget/comboBox/comboBox.js +67 -67
  537. package/src/generis/widget/comboBox/comboBox.tpl +12 -12
  538. package/src/generis/widget/css/widget.css +7 -7
  539. package/src/generis/widget/css/widget.css.map +1 -1
  540. package/src/generis/widget/hiddenBox/hiddenBox.js +132 -132
  541. package/src/generis/widget/hiddenBox/hiddenBox.tpl +16 -16
  542. package/src/generis/widget/loader.js +49 -49
  543. package/src/generis/widget/readme.md +59 -59
  544. package/src/generis/widget/scss/widget.scss +61 -61
  545. package/src/generis/widget/textBox/textBox.js +65 -65
  546. package/src/generis/widget/textBox/textBox.tpl +7 -7
  547. package/src/generis/widget/widget.js +164 -164
  548. package/src/generis/widget/widget.tpl +5 -5
  549. package/src/groupedComboBox.js +99 -99
  550. package/src/groupvalidator.js +84 -84
  551. package/src/hider.js +88 -88
  552. package/src/highlighter.js +1166 -1166
  553. package/src/image/ImgStateActive/extractLabel.js +29 -29
  554. package/src/image/ImgStateActive/helper.js +36 -36
  555. package/src/image/ImgStateActive/initHelper.js +137 -137
  556. package/src/image/ImgStateActive/initMediaEditor.js +92 -92
  557. package/src/image/ImgStateActive/mediaSizer.js +63 -63
  558. package/src/image/ImgStateActive.js +115 -115
  559. package/src/incrementer.js +319 -319
  560. package/src/inplacer.js +316 -316
  561. package/src/interactUtils.js +140 -140
  562. package/src/itemButtonList/css/item-button-list.css +23 -24
  563. package/src/itemButtonList/css/item-button-list.css.map +1 -1
  564. package/src/itemButtonList/scss/item-button-list.scss +236 -236
  565. package/src/itemButtonList/tpl/itemButtonList.tpl +21 -21
  566. package/src/itemButtonList.js +274 -274
  567. package/src/keyNavigation/navigableDomElement.js +282 -282
  568. package/src/keyNavigation/navigator.js +543 -543
  569. package/src/listbox/css/listbox.css +7 -7
  570. package/src/listbox/css/listbox.css.map +1 -1
  571. package/src/listbox/scss/listbox.scss +116 -116
  572. package/src/listbox/tpl/list.tpl +14 -14
  573. package/src/listbox/tpl/main.tpl +9 -9
  574. package/src/listbox.js +251 -251
  575. package/src/liststyler.js +155 -155
  576. package/src/loadingButton/css/button.css +7 -7
  577. package/src/loadingButton/css/button.css.map +1 -1
  578. package/src/loadingButton/loadingButton.js +110 -110
  579. package/src/loadingButton/scss/button.scss +41 -41
  580. package/src/loadingButton/tpl/button.tpl +5 -5
  581. package/src/lock/lock.tpl +16 -16
  582. package/src/lock.js +395 -395
  583. package/src/login/login.js +322 -322
  584. package/src/login/tpl/login.tpl +29 -29
  585. package/src/login/tpl/passwordReveal.tpl +7 -7
  586. package/src/maths/calculator/basicCalculator.js +55 -55
  587. package/src/maths/calculator/calculatorComponent.js +128 -128
  588. package/src/maths/calculator/core/areaBroker.js +38 -38
  589. package/src/maths/calculator/core/board.js +841 -841
  590. package/src/maths/calculator/core/expression.js +430 -430
  591. package/src/maths/calculator/core/labels.js +116 -116
  592. package/src/maths/calculator/core/plugin.js +40 -40
  593. package/src/maths/calculator/core/terms.js +459 -459
  594. package/src/maths/calculator/core/tokenizer.js +245 -245
  595. package/src/maths/calculator/core/tokens.js +178 -178
  596. package/src/maths/calculator/core/tpl/board.tpl +4 -4
  597. package/src/maths/calculator/css/calculator.css +7 -7
  598. package/src/maths/calculator/css/calculator.css.map +1 -1
  599. package/src/maths/calculator/defaultCalculator.js +66 -66
  600. package/src/maths/calculator/plugins/core/degrad.js +90 -90
  601. package/src/maths/calculator/plugins/core/history.js +166 -166
  602. package/src/maths/calculator/plugins/core/remind.js +96 -96
  603. package/src/maths/calculator/plugins/core/stepNavigation.js +175 -175
  604. package/src/maths/calculator/plugins/keyboard/templateKeyboard/defaultTemplate.tpl +36 -36
  605. package/src/maths/calculator/plugins/keyboard/templateKeyboard/templateKeyboard.js +91 -91
  606. package/src/maths/calculator/plugins/modifiers/pow10.js +143 -143
  607. package/src/maths/calculator/plugins/modifiers/sign.js +339 -339
  608. package/src/maths/calculator/plugins/screen/simpleScreen/defaultTemplate.tpl +3 -3
  609. package/src/maths/calculator/plugins/screen/simpleScreen/history.tpl +3 -3
  610. package/src/maths/calculator/plugins/screen/simpleScreen/simpleScreen.js +191 -191
  611. package/src/maths/calculator/pluginsLoader.js +46 -46
  612. package/src/maths/calculator/scientificCalculator.js +74 -74
  613. package/src/maths/calculator/scss/calculator.scss +396 -396
  614. package/src/maths/calculator/tpl/basicKeyboard.tpl +37 -37
  615. package/src/maths/calculator/tpl/basicScreen.tpl +2 -2
  616. package/src/maths/calculator/tpl/scientificKeyboard.tpl +61 -61
  617. package/src/maths/calculator/tpl/scientificScreen.tpl +3 -3
  618. package/src/mediaEditor/mediaEditorComponent.js +141 -141
  619. package/src/mediaEditor/plugins/mediaAlignment/helper.js +62 -62
  620. package/src/mediaEditor/plugins/mediaAlignment/mediaAlignmentComponent.js +99 -99
  621. package/src/mediaEditor/plugins/mediaAlignment/style.css +7 -7
  622. package/src/mediaEditor/plugins/mediaAlignment/tpl/mediaAlignment.tpl +25 -25
  623. package/src/mediaEditor/plugins/mediaDimension/helper.js +189 -189
  624. package/src/mediaEditor/plugins/mediaDimension/mediaDimensionComponent.js +561 -561
  625. package/src/mediaEditor/plugins/mediaDimension/style.css +141 -141
  626. package/src/mediaEditor/plugins/mediaDimension/tpl/mediaDimension.tpl +55 -55
  627. package/src/mediaEditor/tpl/editor.tpl +4 -4
  628. package/src/mediaplayer/css/player.css +7 -7
  629. package/src/mediaplayer/css/player.css.map +1 -1
  630. package/src/mediaplayer/players/html5.js +564 -564
  631. package/src/mediaplayer/players/youtube.js +323 -323
  632. package/src/mediaplayer/players.js +29 -29
  633. package/src/mediaplayer/readme.md +305 -305
  634. package/src/mediaplayer/scss/player.scss +569 -569
  635. package/src/mediaplayer/support.js +126 -126
  636. package/src/mediaplayer/tpl/audio.tpl +6 -6
  637. package/src/mediaplayer/tpl/player.tpl +37 -37
  638. package/src/mediaplayer/tpl/source.tpl +1 -1
  639. package/src/mediaplayer/tpl/video.tpl +6 -6
  640. package/src/mediaplayer/tpl/youtube.tpl +1 -1
  641. package/src/mediaplayer/utils/reminder.js +184 -184
  642. package/src/mediaplayer/utils/timeObserver.js +143 -143
  643. package/src/mediaplayer/youtubeManager.js +161 -161
  644. package/src/mediaplayer.js +1606 -1606
  645. package/src/mediasizer/mediasizer.tpl +55 -55
  646. package/src/mediasizer.js +635 -635
  647. package/src/modal.js +365 -365
  648. package/src/movableComponent.js +78 -78
  649. package/src/pageSizeSelector/tpl/pageSizeSelector.tpl +9 -9
  650. package/src/pageSizeSelector.js +107 -107
  651. package/src/pageStatus.js +147 -147
  652. package/src/pagination/css/pagination.css +7 -7
  653. package/src/pagination/css/pagination.css.map +1 -1
  654. package/src/pagination/paginationStrategy.js +53 -53
  655. package/src/pagination/providers/pages.js +161 -161
  656. package/src/pagination/providers/simple.js +74 -74
  657. package/src/pagination/providers/tpl/pages/page.tpl +1 -1
  658. package/src/pagination/providers/tpl/pages.tpl +8 -8
  659. package/src/pagination/providers/tpl/simple.tpl +7 -7
  660. package/src/pagination/scss/pagination.scss +111 -111
  661. package/src/pagination.js +237 -237
  662. package/src/previewer.js +300 -300
  663. package/src/progressbar.js +165 -165
  664. package/src/propertySelector/css/propertySelector.css +74 -0
  665. package/src/propertySelector/css/propertySelector.css.map +1 -0
  666. package/src/propertySelector/propertySelector.js +286 -0
  667. package/src/propertySelector/scss/propertySelector.scss +66 -0
  668. package/src/propertySelector/tpl/highlighted-text.tpl +1 -0
  669. package/src/propertySelector/tpl/property-description.tpl +13 -0
  670. package/src/propertySelector/tpl/property-selector.tpl +7 -0
  671. package/src/report/feedback.tpl +11 -11
  672. package/src/report/layout.tpl +10 -10
  673. package/src/report.js +184 -184
  674. package/src/resource/css/selector.css +7 -7
  675. package/src/resource/css/selector.css.map +1 -1
  676. package/src/resource/filters.js +208 -208
  677. package/src/resource/list.js +200 -200
  678. package/src/resource/scss/_filters.scss +26 -26
  679. package/src/resource/scss/_resource-list.scss +107 -107
  680. package/src/resource/scss/_resource-tree.scss +205 -205
  681. package/src/resource/scss/selector.scss +187 -187
  682. package/src/resource/selectable.js +322 -322
  683. package/src/resource/selector.js +871 -871
  684. package/src/resource/tpl/filters.tpl +2 -2
  685. package/src/resource/tpl/list.tpl +7 -7
  686. package/src/resource/tpl/listNode.tpl +4 -4
  687. package/src/resource/tpl/selector.tpl +46 -46
  688. package/src/resource/tpl/tree.tpl +4 -4
  689. package/src/resource/tpl/treeNode.tpl +30 -30
  690. package/src/resource/tree.js +400 -400
  691. package/src/resourcemgr/css/resourcemgr.css +7 -7
  692. package/src/resourcemgr/css/resourcemgr.css.map +1 -1
  693. package/src/resourcemgr/fileBrowser.js +381 -381
  694. package/src/resourcemgr/filePreview.js +73 -73
  695. package/src/resourcemgr/fileSelector.js +348 -348
  696. package/src/resourcemgr/scss/resourcemgr.scss +254 -254
  697. package/src/resourcemgr/tpl/fileSelect.tpl +39 -39
  698. package/src/resourcemgr/tpl/folder.tpl +11 -11
  699. package/src/resourcemgr/tpl/layout.tpl +84 -84
  700. package/src/resourcemgr/tpl/rootFolder.tpl +13 -13
  701. package/src/resourcemgr/util/updatePermissions.js +53 -53
  702. package/src/resourcemgr.js +216 -216
  703. package/src/scroller.js +94 -94
  704. package/src/scss/basic.scss +16 -16
  705. package/src/searchModal/advancedSearch.js +638 -601
  706. package/src/searchModal/css/advancedSearch.css +7 -14
  707. package/src/searchModal/css/advancedSearch.css.map +1 -1
  708. package/src/searchModal/css/searchModal.css +28 -8
  709. package/src/searchModal/css/searchModal.css.map +1 -1
  710. package/src/searchModal/scss/advancedSearch.scss +171 -177
  711. package/src/searchModal/scss/searchModal.scss +393 -375
  712. package/src/searchModal/tpl/advanced-search.tpl +9 -9
  713. package/src/searchModal/tpl/criteria-alias.tpl +1 -0
  714. package/src/searchModal/tpl/criteria-class-label.tpl +1 -0
  715. package/src/searchModal/tpl/criteria-label.tpl +1 -0
  716. package/src/searchModal/tpl/highlighted-text.tpl +1 -0
  717. package/src/searchModal/tpl/info-message.tpl +3 -3
  718. package/src/searchModal/tpl/invalid-criteria-warning.tpl +10 -10
  719. package/src/searchModal/tpl/layout.tpl +27 -25
  720. package/src/searchModal/tpl/list-checkbox-criterion.tpl +17 -12
  721. package/src/searchModal/tpl/list-select-criterion.tpl +12 -6
  722. package/src/searchModal/tpl/property-select-button.tpl +1 -0
  723. package/src/searchModal/tpl/results-container.tpl +1 -0
  724. package/src/searchModal/tpl/text-criterion.tpl +11 -6
  725. package/src/searchModal.js +761 -496
  726. package/src/selecter.js +43 -43
  727. package/src/stacker.js +133 -133
  728. package/src/switch/css/switch.css +7 -7
  729. package/src/switch/css/switch.css.map +1 -1
  730. package/src/switch/scss/switch.scss +83 -83
  731. package/src/switch/switch.js +195 -195
  732. package/src/switch/tpl/switch.tpl +7 -7
  733. package/src/tableModel.js +112 -112
  734. package/src/tabs/css/tabs.css +12 -12
  735. package/src/tabs/css/tabs.css.map +1 -1
  736. package/src/tabs/scss/tabs.scss +50 -50
  737. package/src/tabs/tpl/panel.tpl +3 -3
  738. package/src/tabs/tpl/tabs.tpl +10 -10
  739. package/src/tabs.js +528 -528
  740. package/src/taskQueue/css/taskQueue.css +7 -7
  741. package/src/taskQueue/css/taskQueue.css.map +1 -1
  742. package/src/taskQueue/scss/taskQueue.scss +47 -47
  743. package/src/taskQueue/status.js +228 -228
  744. package/src/taskQueue/table.js +350 -350
  745. package/src/taskQueue/taskQueue.js +33 -33
  746. package/src/taskQueue/taskQueueModel.js +548 -548
  747. package/src/taskQueue/tpl/statusMessage.tpl +7 -7
  748. package/src/taskQueue.js +218 -218
  749. package/src/taskQueueButton/css/taskable.css +7 -7
  750. package/src/taskQueueButton/css/taskable.css.map +1 -1
  751. package/src/taskQueueButton/css/treeButton.css +7 -7
  752. package/src/taskQueueButton/css/treeButton.css.map +1 -1
  753. package/src/taskQueueButton/scss/taskable.scss +4 -4
  754. package/src/taskQueueButton/scss/treeButton.scss +34 -34
  755. package/src/taskQueueButton/standardButton.js +108 -108
  756. package/src/taskQueueButton/taskable.js +202 -202
  757. package/src/taskQueueButton/tpl/report.tpl +5 -5
  758. package/src/taskQueueButton/tpl/treeButton.tpl +6 -6
  759. package/src/taskQueueButton/treeButton.js +109 -109
  760. package/src/themeLoader.js +252 -252
  761. package/src/themes.js +162 -162
  762. package/src/toggler.js +200 -200
  763. package/src/tooltip/default.tpl +3 -3
  764. package/src/tooltip.js +160 -160
  765. package/src/tooltipster.js +25 -25
  766. package/src/transformer.js +327 -327
  767. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css +7 -7
  768. package/src/tristateCheckboxGroup/css/tristateCheckboxGroup.css.map +1 -1
  769. package/src/tristateCheckboxGroup/scss/tristateCheckboxGroup.scss +15 -15
  770. package/src/tristateCheckboxGroup/tpl/li.tpl +6 -6
  771. package/src/tristateCheckboxGroup.js +207 -207
  772. package/src/uploader/fileEntry.tpl +6 -6
  773. package/src/uploader/uploader.tpl +32 -32
  774. package/src/uploader.js +594 -594
  775. package/src/validator/Report.js +10 -10
  776. package/src/validator/Validator.js +108 -108
  777. package/src/validator/validators.js +220 -220
  778. package/src/validator.js +264 -264
  779. package/src/waitForMedia.js +82 -82
  780. package/src/waitingDialog/css/waitingDialog.css +7 -7
  781. package/src/waitingDialog/css/waitingDialog.css.map +1 -1
  782. package/src/waitingDialog/scss/waitingDialog.scss +34 -34
  783. package/src/waitingDialog/waitingDialog.js +240 -240
@@ -1,238 +1,240 @@
1
1
  define(['jquery', 'lodash', 'core/pluginifier', 'handlebars', 'i18n', 'lib/dompurify/purify', 'nouislider', 'ui/tooltip'], function ($$1, _, Pluginifier, Handlebars, __, DOMPurify, nouislider, tooltip) { 'use strict';
2
2
 
3
- $$1 = $$1 && Object.prototype.hasOwnProperty.call($$1, 'default') ? $$1['default'] : $$1;
4
- _ = _ && Object.prototype.hasOwnProperty.call(_, 'default') ? _['default'] : _;
5
- Pluginifier = Pluginifier && Object.prototype.hasOwnProperty.call(Pluginifier, 'default') ? Pluginifier['default'] : Pluginifier;
6
- Handlebars = Handlebars && Object.prototype.hasOwnProperty.call(Handlebars, 'default') ? Handlebars['default'] : Handlebars;
7
- __ = __ && Object.prototype.hasOwnProperty.call(__, 'default') ? __['default'] : __;
8
- DOMPurify = DOMPurify && Object.prototype.hasOwnProperty.call(DOMPurify, 'default') ? DOMPurify['default'] : DOMPurify;
9
-
10
- function _typeof(obj) {
11
- "@babel/helpers - typeof";
12
-
13
- return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) {
14
- return typeof obj;
15
- } : function (obj) {
16
- return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
17
- }, _typeof(obj);
18
- }
19
-
20
- function Helpers0 (hb) {
21
- //register a i18n helper
22
- hb.registerHelper('__', function (key) {
23
- return __(key);
24
- });
25
- /**
26
- * Register dompurify helper
27
- *
28
- * https://github.com/cure53/DOMPurify
29
- * with config SAFE_FOR_TEMPLATES: true
30
- * to make output safe for template systems
3
+ $$1 = $$1 && Object.prototype.hasOwnProperty.call($$1, 'default') ? $$1['default'] : $$1;
4
+ _ = _ && Object.prototype.hasOwnProperty.call(_, 'default') ? _['default'] : _;
5
+ Pluginifier = Pluginifier && Object.prototype.hasOwnProperty.call(Pluginifier, 'default') ? Pluginifier['default'] : Pluginifier;
6
+ Handlebars = Handlebars && Object.prototype.hasOwnProperty.call(Handlebars, 'default') ? Handlebars['default'] : Handlebars;
7
+ __ = __ && Object.prototype.hasOwnProperty.call(__, 'default') ? __['default'] : __;
8
+ DOMPurify = DOMPurify && Object.prototype.hasOwnProperty.call(DOMPurify, 'default') ? DOMPurify['default'] : DOMPurify;
9
+
10
+ /**
11
+ * This program is free software; you can redistribute it and/or
12
+ * modify it under the terms of the GNU General Public License
13
+ * as published by the Free Software Foundation; under version 2
14
+ * of the License (non-upgradable).
15
+ *
16
+ * This program is distributed in the hope that it will be useful,
17
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
18
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19
+ * GNU General Public License for more details.
20
+ *
21
+ * You should have received a copy of the GNU General Public License
22
+ * along with this program; if not, write to the Free Software
23
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
24
+ *
25
+ * Copyright (c) 2013-2019 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
26
+ *
27
+ *
31
28
  */
29
+ function Helpers0 (hb) {
30
+ //register a i18n helper
31
+ hb.registerHelper('__', function (key) {
32
+ return __(key);
33
+ });
32
34
 
33
- hb.registerHelper('dompurify', function (context) {
34
- return DOMPurify.sanitize(context);
35
- });
36
- /**
37
- * Register join helper
38
- *
39
- * Example :
40
- * var values = {a:v1, b:v2, c:v3};
41
- * Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
42
- * Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
43
- */
44
-
45
- hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
46
- var fragments = [];
47
- keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
48
- fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
49
- wrapper = typeof wrapper === 'string' ? wrapper : '"';
50
-
51
- _.forIn(arr, function (value, key) {
52
- var fragment = '';
35
+ /**
36
+ * Register dompurify helper
37
+ *
38
+ * https://github.com/cure53/DOMPurify
39
+ * with config SAFE_FOR_TEMPLATES: true
40
+ * to make output safe for template systems
41
+ */
42
+ hb.registerHelper('dompurify', function (context) {
43
+ return DOMPurify.sanitize(context);
44
+ });
53
45
 
54
- if (value !== null || value !== undefined) {
55
- if (typeof value === 'boolean') {
56
- value = value ? 'true' : 'false';
57
- } else if (_typeof(value) === 'object') {
58
- value = _.values(value).join(' ');
46
+ /**
47
+ * Register join helper
48
+ *
49
+ * Example :
50
+ * var values = {a:v1, b:v2, c:v3};
51
+ * Using {{{join attributes '=' ' ' '"'}}} will return : a="v1" b="v2" c="v3"
52
+ * Using {{{join values null ' or ' '*'}}} will return : *v1* or *v2* or *v3*
53
+ */
54
+ hb.registerHelper('join', function (arr, keyValueGlue, fragmentGlue, wrapper) {
55
+ var fragments = [];
56
+ keyValueGlue = typeof keyValueGlue === 'string' ? keyValueGlue : undefined;
57
+ fragmentGlue = typeof fragmentGlue === 'string' ? fragmentGlue : ' ';
58
+ wrapper = typeof wrapper === 'string' ? wrapper : '"';
59
+ _.forIn(arr, function (value, key) {
60
+ var fragment = '';
61
+ if (value !== null || value !== undefined) {
62
+ if (typeof value === 'boolean') {
63
+ value = value ? 'true' : 'false';
64
+ } else if (typeof value === 'object') {
65
+ value = _.values(value).join(' ');
66
+ }
67
+ } else {
68
+ value = '';
59
69
  }
60
- } else {
61
- value = '';
62
- }
70
+ if (keyValueGlue !== undefined) {
71
+ fragment += key + keyValueGlue;
72
+ }
73
+ fragment += wrapper + value + wrapper;
74
+ fragments.push(fragment);
75
+ });
76
+ return fragments.join(fragmentGlue);
77
+ });
63
78
 
64
- if (keyValueGlue !== undefined) {
65
- fragment += key + keyValueGlue;
79
+ //register a classic "for loop" helper
80
+ //it also adds a local variable "i" as the index in each iteration loop
81
+ hb.registerHelper('for', function (startIndex, stopIndex, increment, options) {
82
+ var ret = '';
83
+ startIndex = parseInt(startIndex);
84
+ stopIndex = parseInt(stopIndex);
85
+ increment = parseInt(increment);
86
+ for (var i = startIndex; i < stopIndex; i += increment) {
87
+ ret += options.fn(_.extend({}, this, {
88
+ i: i
89
+ }));
90
+ }
91
+ return ret;
92
+ });
93
+ hb.registerHelper('equal', function (var1, var2, options) {
94
+ if (var1 == var2) {
95
+ return options.fn(this);
96
+ } else {
97
+ return options.inverse(this);
66
98
  }
67
-
68
- fragment += wrapper + value + wrapper;
69
- fragments.push(fragment);
70
99
  });
71
100
 
72
- return fragments.join(fragmentGlue);
73
- }); //register a classic "for loop" helper
74
- //it also adds a local variable "i" as the index in each iteration loop
75
-
76
- hb.registerHelper('for', function (startIndex, stopIndex, increment, options) {
77
- var ret = '';
78
- startIndex = parseInt(startIndex);
79
- stopIndex = parseInt(stopIndex);
80
- increment = parseInt(increment);
101
+ // register a "get property" helper
102
+ // it gets the named property from the provided context
103
+ hb.registerHelper('property', function (name, context) {
104
+ return context[name] || '';
105
+ });
81
106
 
82
- for (var i = startIndex; i < stopIndex; i += increment) {
83
- ret += options.fn(_.extend({}, this, {
84
- i: i
85
- }));
86
- }
107
+ // register an 'includes' helper
108
+ // it checks if value is in array
109
+ hb.registerHelper('includes', function (haystack, needle, options) {
110
+ if (_.contains(haystack, needle)) {
111
+ return options.fn(this);
112
+ }
113
+ });
114
+ }
87
115
 
88
- return ret;
89
- });
90
- hb.registerHelper('equal', function (var1, var2, options) {
91
- if (var1 == var2) {
92
- return options.fn(this);
93
- } else {
94
- return options.inverse(this);
116
+ if (!Helpers0.__initialized) {
117
+ Helpers0(Handlebars);
118
+ Helpers0.__initialized = true;
119
+ }
120
+ var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
121
+ this.compilerInfo = [4,'>= 1.0.0'];
122
+ helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
123
+ var buffer = "", stack1, helper, options, self=this, helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression;
124
+
125
+ function program1(depth0,data) {
126
+
127
+
128
+ return "checked=\"checked\"";
95
129
  }
96
- }); // register a "get property" helper
97
- // it gets the named property from the provided context
98
130
 
99
- hb.registerHelper('property', function (name, context) {
100
- return context[name] || '';
101
- }); // register an 'includes' helper
102
- // it checks if value is in array
103
-
104
- hb.registerHelper('includes', function (haystack, needle, options) {
105
- if (_.contains(haystack, needle)) {
106
- return options.fn(this);
107
- }
108
- });
109
- }
110
-
111
- if (!Helpers0.__initialized) {
112
- Helpers0(Handlebars);
113
- Helpers0.__initialized = true;
114
- }
115
- var Template = Handlebars.template(function (Handlebars,depth0,helpers,partials,data) {
116
- this.compilerInfo = [4,'>= 1.0.0'];
117
- helpers = this.merge(helpers, Handlebars.helpers); data = data || {};
118
- var buffer = "", stack1, helper, options, self=this, helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression;
119
-
120
- function program1(depth0,data) {
121
-
122
-
123
- return "checked=\"checked\"";
131
+ buffer += "<div class=\"media-sizer media-sizer-synced\">\n\n <div class=\"media-sizer-responsive-toggle\">\n <label>\n <input type=\"checkbox\" ";
132
+ stack1 = helpers['if'].call(depth0, (depth0 && depth0.responsive), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
133
+ if(stack1 || stack1 === 0) { buffer += stack1; }
134
+ buffer += " class=\"media-mode-switch\"/>\n <span class=\"icon-checkbox\"></span>\n "
135
+ + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Responsive mode", options) : helperMissing.call(depth0, "__", "Responsive mode", options)))
136
+ + "\n </label>\n <span class=\"icon-help tooltipstered\" data-tooltip=\"~ .tooltip-content:first\" data-tooltip-theme=\"warning\"></span>\n\n <div class=\"tooltip-content\">\n "
137
+ + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Media resize along with their container, e.g. 50% means half of the container size not half of the media size.", options) : helperMissing.call(depth0, "__", "Media resize along with their container, e.g. 50% means half of the container size not half of the media size.", options)))
138
+ + "\n </div>\n </div>\n\n\n <div class=\"media-sizer-percent\">\n <label for=\"media-sizer-percent-width\">"
139
+ + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Size", options) : helperMissing.call(depth0, "__", "Size", options)))
140
+ + "</label>\n <span class=\"item-editor-unit-input-box\">\n <input type=\"text\" name=\"width\" id=\"media-sizer-percent-width\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\n </span>\n\n <div class=\"media-sizer-reset media-sizer-reset-percent\" data-unit=\"percent\">\n <span class=\"icon-reset\"></span>\n </div>\n\n <div class=\"media-sizer-slider-box\">\n <div class=\"media-sizer-slider\"></div>\n </div>\n </div>\n\n <div class=\"media-sizer-pixel\">\n <label for=\"media-sizer-pixel-width\">"
141
+ + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Width", options) : helperMissing.call(depth0, "__", "Width", options)))
142
+ + "</label>\n <span class=\"item-editor-unit-input-box\">\n <input type=\"text\" name=\"width\" id=\"media-sizer-pixel-width\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\n </span>\n\n <label for=\"media-sizer-pixel-height\">"
143
+ + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Height", options) : helperMissing.call(depth0, "__", "Height", options)))
144
+ + "</label>\n <span class=\"item-editor-unit-input-box\">\n <input type=\"text\" name=\"height\" id=\"media-sizer-pixel-height\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\n </span>\n\n <div class=\"media-sizer-sync\">\n <span class=\"icon-link\"></span>\n </div>\n\n <div class=\"media-sizer-reset media-sizer-reset-pixel\" data-unit=\"pixel\">\n <span class=\"icon-reset\"></span>\n </div>\n\n <div class=\"media-sizer-slider-box\">\n <div class=\"media-sizer-slider\"></div>\n <div class=\"media-sizer-cover\"></div>\n </div>\n </div>\n</div>";
145
+ return buffer;
146
+ });
147
+ function tpl(data, options, asString) {
148
+ var html = Template(data, options);
149
+ return (asString || true) ? html : $(html);
124
150
  }
125
151
 
126
- buffer += "<div class=\"media-sizer media-sizer-synced\">\r\n\r\n <div class=\"media-sizer-responsive-toggle\">\r\n <label>\r\n <input type=\"checkbox\" ";
127
- stack1 = helpers['if'].call(depth0, (depth0 && depth0.responsive), {hash:{},inverse:self.noop,fn:self.program(1, program1, data),data:data});
128
- if(stack1 || stack1 === 0) { buffer += stack1; }
129
- buffer += " class=\"media-mode-switch\"/>\r\n <span class=\"icon-checkbox\"></span>\r\n "
130
- + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Responsive mode", options) : helperMissing.call(depth0, "__", "Responsive mode", options)))
131
- + "\r\n </label>\r\n <span class=\"icon-help tooltipstered\" data-tooltip=\"~ .tooltip-content:first\" data-tooltip-theme=\"warning\"></span>\r\n\r\n <div class=\"tooltip-content\">\r\n "
132
- + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Media resize along with their container, e.g. 50% means half of the container size not half of the media size.", options) : helperMissing.call(depth0, "__", "Media resize along with their container, e.g. 50% means half of the container size not half of the media size.", options)))
133
- + "\r\n </div>\r\n </div>\r\n\r\n\r\n <div class=\"media-sizer-percent\">\r\n <label for=\"media-sizer-percent-width\">"
134
- + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Size", options) : helperMissing.call(depth0, "__", "Size", options)))
135
- + "</label>\r\n <span class=\"item-editor-unit-input-box\">\r\n <input type=\"text\" name=\"width\" id=\"media-sizer-percent-width\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\r\n </span>\r\n\r\n <div class=\"media-sizer-reset media-sizer-reset-percent\" data-unit=\"percent\">\r\n <span class=\"icon-reset\"></span>\r\n </div>\r\n\r\n <div class=\"media-sizer-slider-box\">\r\n <div class=\"media-sizer-slider\"></div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"media-sizer-pixel\">\r\n <label for=\"media-sizer-pixel-width\">"
136
- + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Width", options) : helperMissing.call(depth0, "__", "Width", options)))
137
- + "</label>\r\n <span class=\"item-editor-unit-input-box\">\r\n <input type=\"text\" name=\"width\" id=\"media-sizer-pixel-width\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\r\n </span>\r\n\r\n <label for=\"media-sizer-pixel-height\">"
138
- + escapeExpression((helper = helpers.__ || (depth0 && depth0.__),options={hash:{},data:data},helper ? helper.call(depth0, "Height", options) : helperMissing.call(depth0, "__", "Height", options)))
139
- + "</label>\r\n <span class=\"item-editor-unit-input-box\">\r\n <input type=\"text\" name=\"height\" id=\"media-sizer-pixel-height\" data-validate=\"$numeric\" data-validate-option=\"$allowEmpty;\"/>\r\n </span>\r\n\r\n <div class=\"media-sizer-sync\">\r\n <span class=\"icon-link\"></span>\r\n </div>\r\n\r\n <div class=\"media-sizer-reset media-sizer-reset-pixel\" data-unit=\"pixel\">\r\n <span class=\"icon-reset\"></span>\r\n </div>\r\n\r\n <div class=\"media-sizer-slider-box\">\r\n <div class=\"media-sizer-slider\"></div>\r\n <div class=\"media-sizer-cover\"></div>\r\n </div>\r\n </div>\r\n</div>";
140
- return buffer;
141
- });
142
- function tpl(data, options, asString) {
143
- var html = Template(data, options);
144
- return (asString || true) ? html : $(html);
145
- }
146
-
147
- /*
148
- * This program is free software; you can redistribute it and/or
149
- * modify it under the terms of the GNU General Public License
150
- * as published by the Free Software Foundation; under version 2
151
- * of the License (non-upgradable).
152
- *
153
- * This program is distributed in the hope that it will be useful,
154
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
155
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
156
- * GNU General Public License for more details.
157
- *
158
- * You should have received a copy of the GNU General Public License
159
- * along with this program; if not, write to the Free Software
160
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
161
- *
162
- * Copyright (c) 2015 (original work) Open Assessment Technologies SA;
163
- *
164
- */
165
- var ns = 'mediasizer';
166
- var dataNs = 'ui.' + ns;
167
- var MediaSizer;
168
- /**
169
- * default setup
170
- *
171
- * optional values are:
172
- * width | naturalWidth (alias)
173
- * height | naturalHeight (alias)
174
- * maxWidth
175
- * parentSelector
176
- *
177
- * @type {Object}
178
- */
179
-
180
- var defaults = {
181
- disableClass: 'disabled',
182
- applyToMedium: true,
183
- denyCustomRatio: true,
184
- responsive: true,
185
- showResponsiveToggle: true,
186
- showReset: true,
187
- showSync: true,
188
- size: 100
189
- };
190
- /**
191
- * Round a decimal value to n digits
192
- *
193
- * @param {number} value
194
- * @param {int} precision
195
- * @returns {number}
196
- * @private
197
- */
198
-
199
- function _round(value, precision) {
200
- var factor = Math.pow(10, precision);
201
- return Math.round(value * factor) / factor;
202
- }
203
- /**
204
- * The MediaSizer component, that helps you to show/hide an element
205
- * @exports ui/toggler
206
- */
207
-
208
-
209
- MediaSizer = {
210
- /**
211
- * Returns width, height, target element and the reset button
212
- * It's meant to be used when triggering an event
213
- *
214
- * @param $elt
215
- * @param options
216
- * @returns {{}}
217
- * @private
152
+ /*
153
+ * This program is free software; you can redistribute it and/or
154
+ * modify it under the terms of the GNU General Public License
155
+ * as published by the Free Software Foundation; under version 2
156
+ * of the License (non-upgradable).
157
+ *
158
+ * This program is distributed in the hope that it will be useful,
159
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
160
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
161
+ * GNU General Public License for more details.
162
+ *
163
+ * You should have received a copy of the GNU General Public License
164
+ * along with this program; if not, write to the Free Software
165
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
166
+ *
167
+ * Copyright (c) 2015 (original work) Open Assessment Technologies SA;
168
+ *
169
+ */
170
+ var ns = 'mediasizer';
171
+ var dataNs = 'ui.' + ns;
172
+ var MediaSizer;
173
+
174
+ /**
175
+ * default setup
176
+ *
177
+ * optional values are:
178
+ * width | naturalWidth (alias)
179
+ * height | naturalHeight (alias)
180
+ * maxWidth
181
+ * parentSelector
182
+ *
183
+ * @type {Object}
184
+ */
185
+ var defaults = {
186
+ disableClass: 'disabled',
187
+ applyToMedium: true,
188
+ denyCustomRatio: true,
189
+ responsive: true,
190
+ showResponsiveToggle: true,
191
+ showReset: true,
192
+ showSync: true,
193
+ size: 100
194
+ };
195
+
196
+ /**
197
+ * Round a decimal value to n digits
198
+ *
199
+ * @param {number} value
200
+ * @param {int} precision
201
+ * @returns {number}
202
+ * @private
218
203
  */
219
- _publicArgs: function _publicArgs($elt, options) {
220
- var params = this._getValues($elt);
221
-
222
- params.$target = options.target || $$1();
223
- params.$resetBtn = options.$resetBtn;
224
- return params;
225
- },
226
-
227
- /**
228
- * Creates object that contains all size related data of the medium (= image, video, etc.)
229
- *
230
- * @param $elt
231
- * @returns {{px: {natural: {width: (number|*), height: (number|*)}, current: {width: *, height: *}}, %: {natural: {width: number, height: null}, current: {width: number, height: null}}, ratio: {natural: number, current: number}, containerWidth: , sliders: {%: {min: number, max: number, start: number}, px: {min: number, max: number, start: *}}, currentUnit: string}}
232
- * @private
204
+ function _round(value, precision) {
205
+ var factor = Math.pow(10, precision);
206
+ return Math.round(value * factor) / factor;
207
+ }
208
+
209
+ /**
210
+ * The MediaSizer component, that helps you to show/hide an element
211
+ * @exports ui/toggler
233
212
  */
234
- _getSizeProps: function _getSizeProps($elt) {
235
- var options = $elt.data(dataNs),
213
+ MediaSizer = {
214
+ /**
215
+ * Returns width, height, target element and the reset button
216
+ * It's meant to be used when triggering an event
217
+ *
218
+ * @param $elt
219
+ * @param options
220
+ * @returns {{}}
221
+ * @private
222
+ */
223
+ _publicArgs: function ($elt, options) {
224
+ var params = this._getValues($elt);
225
+ params.$target = options.target || $$1();
226
+ params.$resetBtn = options.$resetBtn;
227
+ return params;
228
+ },
229
+ /**
230
+ * Creates object that contains all size related data of the medium (= image, video, etc.)
231
+ *
232
+ * @param $elt
233
+ * @returns {{px: {natural: {width: (number|*), height: (number|*)}, current: {width: *, height: *}}, %: {natural: {width: number, height: null}, current: {width: number, height: null}}, ratio: {natural: number, current: number}, containerWidth: , sliders: {%: {min: number, max: number, start: number}, px: {min: number, max: number, start: *}}, currentUnit: string}}
234
+ * @private
235
+ */
236
+ _getSizeProps: function ($elt) {
237
+ var options = $elt.data(dataNs),
236
238
  $medium,
237
239
  naturalWidth,
238
240
  naturalHeight,
@@ -240,243 +242,210 @@ define(['jquery', 'lodash', 'core/pluginifier', 'handlebars', 'i18n', 'lib/dompu
240
242
  displaySize,
241
243
  minWidth = _.isNumber(options.minWidth) ? options.minWidth : 0,
242
244
  maxWidth;
243
-
244
- if (options.hasTarget) {
245
- $medium = options.target;
246
- displaySize = $medium[0].getBoundingClientRect();
247
- options.width = displaySize.width;
248
- options.height = displaySize.height;
249
- naturalWidth = $medium[0].naturalWidth || options.width;
250
- naturalHeight = $medium[0].naturalHeight || options.height;
251
-
252
- containerWidth = function () {
253
- var $parentContainer = options.parentSelector ? $medium.parents(options.parentSelector) : $medium.parent().parent(),
245
+ if (options.hasTarget) {
246
+ $medium = options.target;
247
+ displaySize = $medium[0].getBoundingClientRect();
248
+ options.width = displaySize.width;
249
+ options.height = displaySize.height;
250
+ naturalWidth = $medium[0].naturalWidth || options.width;
251
+ naturalHeight = $medium[0].naturalHeight || options.height;
252
+ containerWidth = function () {
253
+ var $parentContainer = options.parentSelector ? $medium.parents(options.parentSelector) : $medium.parent().parent(),
254
254
  _maxWidth;
255
-
256
- if (options.maxWidth) {
257
- return options.maxWidth;
258
- }
259
-
260
- _maxWidth = $parentContainer.css('max-width');
261
-
262
- if (_maxWidth !== 'none') {
263
- return parseInt(_maxWidth);
264
- }
265
-
266
- return $parentContainer.innerWidth();
267
- }();
268
- } else {
269
- // init() already makes sure width and height exist at this point
270
- naturalWidth = options.width;
271
- naturalHeight = options.height;
272
- containerWidth = options.maxWidth || options.width;
273
- }
274
-
275
- maxWidth = Math.max(containerWidth, naturalWidth);
276
- return {
277
- px: {
278
- //original values for all media
279
- natural: {
280
- width: naturalWidth,
281
- height: naturalHeight
255
+ if (options.maxWidth) {
256
+ return options.maxWidth;
257
+ }
258
+ _maxWidth = $parentContainer.css('max-width');
259
+ if (_maxWidth !== 'none') {
260
+ return parseInt(_maxWidth);
261
+ }
262
+ return $parentContainer.innerWidth();
263
+ }();
264
+ } else {
265
+ // init() already makes sure width and height exist at this point
266
+ naturalWidth = options.width;
267
+ naturalHeight = options.height;
268
+ containerWidth = options.maxWidth || options.width;
269
+ }
270
+ maxWidth = Math.max(containerWidth, naturalWidth);
271
+ return {
272
+ px: {
273
+ //original values for all media
274
+ natural: {
275
+ width: naturalWidth,
276
+ height: naturalHeight
277
+ },
278
+ current: {
279
+ width: options.width,
280
+ height: options.height
281
+ }
282
282
  },
283
- current: {
284
- width: options.width,
285
- height: options.height
286
- }
287
- },
288
- '%': {
289
- natural: {
290
- width: 100,
291
- height: null
283
+ '%': {
284
+ natural: {
285
+ width: 100,
286
+ height: null
287
+ },
288
+ current: {
289
+ width: options.width * 100 / containerWidth,
290
+ height: null // height does not work on % - this is just in case you have to loop or something
291
+ }
292
292
  },
293
- current: {
294
- width: options.width * 100 / containerWidth,
295
- height: null // height does not work on % - this is just in case you have to loop or something
296
293
 
297
- }
298
- },
299
- ratio: {
300
- natural: naturalWidth / naturalHeight,
301
- current: options.width / options.height
302
- },
303
- containerWidth: containerWidth,
304
- sliders: {
305
- '%': {
306
- min: minWidth * 100 / maxWidth,
307
- max: 100,
308
- start: options.width * 100 / containerWidth
294
+ ratio: {
295
+ natural: naturalWidth / naturalHeight,
296
+ current: options.width / options.height
309
297
  },
310
- px: {
311
- min: minWidth,
312
- max: maxWidth,
313
- start: +options.width
314
- }
315
- },
316
- currentUnit: '%'
317
- };
318
- },
319
-
320
- /**
321
- * Toggle width/height synchronization
322
- *
323
- * @param $elt
324
- * @returns {*}
325
- * @private
326
- */
327
- _initSyncBtn: function _initSyncBtn($elt) {
328
- var options = $elt.data(dataNs),
298
+ containerWidth: containerWidth,
299
+ sliders: {
300
+ '%': {
301
+ min: minWidth * 100 / maxWidth,
302
+ max: 100,
303
+ start: options.width * 100 / containerWidth
304
+ },
305
+ px: {
306
+ min: minWidth,
307
+ max: maxWidth,
308
+ start: +options.width
309
+ }
310
+ },
311
+ currentUnit: '%'
312
+ };
313
+ },
314
+ /**
315
+ * Toggle width/height synchronization
316
+ *
317
+ * @param $elt
318
+ * @returns {*}
319
+ * @private
320
+ */
321
+ _initSyncBtn: function ($elt) {
322
+ var options = $elt.data(dataNs),
329
323
  $mediaSizer = $elt.find('.media-sizer'),
330
324
  self = this,
331
325
  $syncBtn = $elt.find('.media-sizer-sync');
332
-
333
- if (!options.showSync) {
334
- $syncBtn.hide();
335
- $mediaSizer.addClass('media-sizer-sync-off');
336
- } // this stays intact even if hidden in case it will be
337
- // displayed from somewhere else
338
-
339
-
340
- $syncBtn.on('click', function () {
341
- $mediaSizer.toggleClass('media-sizer-synced');
342
- options.syncDimensions = $mediaSizer.hasClass('media-sizer-synced');
343
-
344
- if (options.syncDimensions) {
345
- self._sync($elt, options.$fields.px.width, 'blur');
326
+ if (!options.showSync) {
327
+ $syncBtn.hide();
328
+ $mediaSizer.addClass('media-sizer-sync-off');
346
329
  }
347
- });
348
- return $syncBtn;
349
- },
350
-
351
- /**
352
- * Button to reset the size to its original values
353
- *
354
- * @param $elt
355
- * @returns {*}
356
- * @private
357
- */
358
- _initResetBtn: function _initResetBtn($elt) {
359
- var options = $elt.data(dataNs),
330
+ // this stays intact even if hidden in case it will be
331
+ // displayed from somewhere else
332
+ $syncBtn.on('click', function () {
333
+ $mediaSizer.toggleClass('media-sizer-synced');
334
+ options.syncDimensions = $mediaSizer.hasClass('media-sizer-synced');
335
+ if (options.syncDimensions) {
336
+ self._sync($elt, options.$fields.px.width, 'blur');
337
+ }
338
+ });
339
+ return $syncBtn;
340
+ },
341
+ /**
342
+ * Button to reset the size to its original values
343
+ *
344
+ * @param $elt
345
+ * @returns {*}
346
+ * @private
347
+ */
348
+ _initResetBtn: function ($elt) {
349
+ var options = $elt.data(dataNs),
360
350
  $resetBtn = $elt.find('.media-sizer-reset');
351
+ if (!options.showReset) {
352
+ $elt.find('.media-sizer').addClass('media-sizer-reset-off');
353
+ }
361
354
 
362
- if (!options.showReset) {
363
- $elt.find('.media-sizer').addClass('media-sizer-reset-off');
364
- } // this stays intact even if hidden in case it will be
365
- // displayed from somewhere else
366
-
367
-
368
- $resetBtn.on('click', function () {
369
- // this will take care of all other size changes
370
- options.$fields.px.width.val(options.originalSizeProps.px.current.width).trigger('sliderchange');
371
- });
372
- return $resetBtn;
373
- },
374
-
375
- /**
376
- * Blocks are the two different parts of the form (either width|height or size)
377
- *
378
- * @param $elt
379
- * @returns {{}}
380
- * @private
381
- */
382
- _initBlocks: function _initBlocks($elt) {
383
- var options = $elt.data(dataNs),
355
+ // this stays intact even if hidden in case it will be
356
+ // displayed from somewhere else
357
+ $resetBtn.on('click', function () {
358
+ // this will take care of all other size changes
359
+ options.$fields.px.width.val(options.originalSizeProps.px.current.width).trigger('sliderchange');
360
+ });
361
+ return $resetBtn;
362
+ },
363
+ /**
364
+ * Blocks are the two different parts of the form (either width|height or size)
365
+ *
366
+ * @param $elt
367
+ * @returns {{}}
368
+ * @private
369
+ */
370
+ _initBlocks: function ($elt) {
371
+ var options = $elt.data(dataNs),
384
372
  _blocks = {},
385
373
  $responsiveToggleField = $elt.find('.media-mode-switch'),
386
374
  self = this,
387
- _checkMode = function _checkMode() {
388
- if ($responsiveToggleField.is(':checked')) {
389
- _blocks.px.hide();
390
-
391
- _blocks['%'].show();
392
-
393
- options.sizeProps.currentUnit = '%';
394
-
395
- if (options.$fields && options.$fields['%'].width.val() > options.sizeProps.sliders['%'].max) {
396
- options.$fields['%'].width.val(options.sizeProps.sliders['%'].max);
397
-
398
- self._sync($elt, options.$fields['%'].width, 'blur');
399
- }
400
- } else {
401
- _blocks['%'].hide();
402
-
403
- _blocks.px.show();
404
-
405
- options.sizeProps.currentUnit = 'px';
375
+ _checkMode = function () {
376
+ if ($responsiveToggleField.is(':checked')) {
377
+ _blocks.px.hide();
378
+ _blocks['%'].show();
379
+ options.sizeProps.currentUnit = '%';
380
+ if (options.$fields && options.$fields['%'].width.val() > options.sizeProps.sliders['%'].max) {
381
+ options.$fields['%'].width.val(options.sizeProps.sliders['%'].max);
382
+ self._sync($elt, options.$fields['%'].width, 'blur');
383
+ }
384
+ } else {
385
+ _blocks['%'].hide();
386
+ _blocks.px.show();
387
+ options.sizeProps.currentUnit = 'px';
388
+ }
389
+ };
390
+ if (!options.showResponsiveToggle) {
391
+ $elt.find('.media-sizer').addClass('media-sizer-responsivetoggle-off');
406
392
  }
407
- };
408
-
409
- if (!options.showResponsiveToggle) {
410
- $elt.find('.media-sizer').addClass('media-sizer-responsivetoggle-off');
411
- }
412
-
413
- _(['px', '%']).forEach(function (unit) {
414
- _blocks[unit] = $elt.find('.media-sizer-' + (unit === 'px' ? 'pixel' : 'percent'));
415
-
416
- _blocks[unit].prop('unit', unit);
417
-
418
- _blocks[unit].find('input').data('unit', unit).after($$1('<span>', {
419
- class: 'unit-indicator',
420
- text: unit
421
- }));
422
- });
393
+ _(['px', '%']).forEach(function (unit) {
394
+ _blocks[unit] = $elt.find('.media-sizer-' + (unit === 'px' ? 'pixel' : 'percent'));
395
+ _blocks[unit].prop('unit', unit);
396
+ _blocks[unit].find('input').data('unit', unit).after($$1('<span>', {
397
+ class: 'unit-indicator',
398
+ text: unit
399
+ }));
400
+ });
401
+ $responsiveToggleField.on('click', function () {
402
+ _checkMode();
403
+ $elt.trigger('responsiveswitch.' + ns, [$responsiveToggleField.is(':checked')]);
404
+ $elt.trigger('sizechange.' + ns, self._publicArgs($elt, options));
405
+ });
423
406
 
424
- $responsiveToggleField.on('click', function () {
407
+ //initialize it properly
425
408
  _checkMode();
426
-
427
- $elt.trigger('responsiveswitch.' + ns, [$responsiveToggleField.is(':checked')]);
428
- $elt.trigger('sizechange.' + ns, self._publicArgs($elt, options));
429
- }); //initialize it properly
430
-
431
- _checkMode();
432
-
433
- return _blocks;
434
- },
435
-
436
- /**
437
- * Initialize the two sliders, one based on pixels the other on percentage
438
- *
439
- * @param $elt
440
- * @returns {{}}
441
- * @private
442
- */
443
- _initSliders: function _initSliders($elt) {
444
- var options = $elt.data(dataNs),
409
+ return _blocks;
410
+ },
411
+ /**
412
+ * Initialize the two sliders, one based on pixels the other on percentage
413
+ *
414
+ * @param $elt
415
+ * @returns {{}}
416
+ * @private
417
+ */
418
+ _initSliders: function ($elt) {
419
+ var options = $elt.data(dataNs),
445
420
  _sliders = {};
446
-
447
- _(options.$blocks).forOwn(function ($block, unit) {
448
- _sliders[unit] = $block.find('.media-sizer-slider');
449
-
450
- _sliders[unit].prop('unit', unit);
451
-
452
- _sliders[unit].noUiSlider({
453
- start: options.sizeProps.sliders[unit].start,
454
- range: {
455
- min: options.sizeProps.sliders[unit].min,
456
- max: options.sizeProps.sliders[unit].max
457
- }
458
- }).on('slide', function () {
459
- var $slider = $$1(this),
421
+ _(options.$blocks).forOwn(function ($block, unit) {
422
+ _sliders[unit] = $block.find('.media-sizer-slider');
423
+ _sliders[unit].prop('unit', unit);
424
+ _sliders[unit].noUiSlider({
425
+ start: options.sizeProps.sliders[unit].start,
426
+ range: {
427
+ min: options.sizeProps.sliders[unit].min,
428
+ max: options.sizeProps.sliders[unit].max
429
+ }
430
+ }).on('slide', function () {
431
+ var $slider = $$1(this),
460
432
  _unit = $slider.prop('unit');
461
-
462
- options.$fields[_unit].width.val(_round($slider.val(), 0)).trigger('sliderchange');
433
+ options.$fields[_unit].width.val(_round($slider.val(), 0)).trigger('sliderchange');
434
+ });
463
435
  });
464
- });
465
-
466
- return _sliders;
467
- },
468
-
469
- /**
470
- * Synchronize all parameters
471
- *
472
- * @param $elt
473
- * @param $field
474
- * @param eventType
475
- * @private
476
- */
477
- _sync: function _sync($elt, $field, eventType) {
478
- var self = this;
479
- var options = $elt.data(dataNs),
436
+ return _sliders;
437
+ },
438
+ /**
439
+ * Synchronize all parameters
440
+ *
441
+ * @param $elt
442
+ * @param $field
443
+ * @param eventType
444
+ * @private
445
+ */
446
+ _sync: function ($elt, $field, eventType) {
447
+ var self = this;
448
+ var options = $elt.data(dataNs),
480
449
  unit = $field.prop('unit'),
481
450
  dimension = $field.prop('dimension'),
482
451
  value = parseFloat($field.val()),
@@ -486,274 +455,262 @@ define(['jquery', 'lodash', 'core/pluginifier', 'handlebars', 'i18n', 'lib/dompu
486
455
  otherBlockWidthValue,
487
456
  otherBlockHeightValue,
488
457
  currentValues;
489
- eventType = eventType === 'sliderchange' ? 'sliderEvent' : 'fieldEvent'; // invalid entries
490
-
491
- if (isNaN(value)) {
492
- return;
493
- } // Re-calculate current ratio
494
- // change scenario: someone has typed height and width in pixels while syncing was off
495
- // whether current or natural ratio eventually will be used depends on options.denyCustomRatio
496
-
497
-
498
- if (options.sizeProps.px.current.width > 0 && options.sizeProps.px.current.height > 0) {
499
- options.sizeProps.ratio.current = options.sizeProps.px.current.width / options.sizeProps.px.current.height;
500
- }
458
+ eventType = eventType === 'sliderchange' ? 'sliderEvent' : 'fieldEvent';
501
459
 
502
- ratio = options.denyCustomRatio ? options.sizeProps.ratio.natural : options.sizeProps.ratio.current;
503
- ratio = ratio ? ratio : 1; // There is only one scenario where dimension != width: manual input of the height in px
504
- // this is treated here separately because then we just need to deal with widths below
505
-
506
- if (dimension === 'height' && unit === 'px') {
507
- options.sizeProps.px.current.height = value;
460
+ // invalid entries
461
+ if (isNaN(value)) {
462
+ return;
463
+ }
508
464
 
509
- if (options.syncDimensions) {
510
- options.sizeProps.px.current.width = value * ratio;
465
+ // Re-calculate current ratio
466
+ // change scenario: someone has typed height and width in pixels while syncing was off
467
+ // whether current or natural ratio eventually will be used depends on options.denyCustomRatio
468
+ if (options.sizeProps.px.current.width > 0 && options.sizeProps.px.current.height > 0) {
511
469
  options.sizeProps.ratio.current = options.sizeProps.px.current.width / options.sizeProps.px.current.height;
512
- options.$fields.px.width.val(_round(options.sizeProps.px.current.width, 0)); // now all values can be set to the width since width entry is now the only scenario
513
-
514
- value = parseFloat(options.$fields.px.width.val());
515
- } else {
516
- options.sizeProps['%'].current.height = null; // update medium
517
-
518
- if (options.applyToMedium) {
519
- currentValues = this._getValues($elt);
520
- options.target.attr('width', currentValues.width);
521
- options.target.attr('height', currentValues.height);
470
+ }
471
+ ratio = options.denyCustomRatio ? options.sizeProps.ratio.natural : options.sizeProps.ratio.current;
472
+ ratio = ratio ? ratio : 1;
473
+
474
+ // There is only one scenario where dimension != width: manual input of the height in px
475
+ // this is treated here separately because then we just need to deal with widths below
476
+ if (dimension === 'height' && unit === 'px') {
477
+ options.sizeProps.px.current.height = value;
478
+ if (options.syncDimensions) {
479
+ options.sizeProps.px.current.width = value * ratio;
480
+ options.sizeProps.ratio.current = options.sizeProps.px.current.width / options.sizeProps.px.current.height;
481
+ options.$fields.px.width.val(_round(options.sizeProps.px.current.width, 0));
482
+
483
+ // now all values can be set to the width since width entry is now the only scenario
484
+ value = parseFloat(options.$fields.px.width.val());
485
+ } else {
486
+ options.sizeProps['%'].current.height = null;
487
+ // update medium
488
+ if (options.applyToMedium) {
489
+ currentValues = this._getValues($elt);
490
+ options.target.attr('width', currentValues.width);
491
+ options.target.attr('height', currentValues.height);
492
+ }
493
+ $elt.trigger('sizechange.' + ns, this._publicArgs($elt, options));
494
+ return;
522
495
  }
523
-
524
- $elt.trigger('sizechange.' + ns, this._publicArgs($elt, options));
525
- return;
526
496
  }
527
- } // *** as of here we can be sure that the dimension is 'width' *** //
528
- // remember that heightValue and otherUnit work _not_ on the same block
529
-
530
-
531
- if (unit === 'px') {
532
- otherBlockUnit = '%';
533
- otherBlockWidthValue = value * 100 / options.sizeProps.containerWidth;
534
- } else {
535
- otherBlockUnit = 'px';
536
- otherBlockWidthValue = value * options.sizeProps.containerWidth / 100;
537
- } // update the unit-side of the tree with the value
538
-
539
-
540
- options.sizeProps[unit].current.width = value;
541
- options.sizeProps[otherBlockUnit].current.width = otherBlockWidthValue; // update the height fields of the same and of the other block
542
-
543
- if (options.syncDimensions) {
544
- heightValue = value / ratio;
545
- otherBlockHeightValue = otherBlockWidthValue / ratio; //same block
546
-
547
- options.sizeProps[unit].current.height = heightValue;
548
- options.$fields[unit].height.val(_round(heightValue, 0)); //other block
549
-
550
- options.sizeProps[otherBlockUnit].current.height = otherBlockHeightValue;
551
- options.$fields[otherBlockUnit].height.val(_round(otherBlockHeightValue, 0));
552
- }
553
- /* sliders */
554
- // update same slider value only when fn is triggered by typing
555
-
556
-
557
- if (eventType !== 'sliderEvent') {
558
- options.$sliders[unit].val(value);
559
- } // update other slider
497
+ // *** as of here we can be sure that the dimension is 'width' *** //
560
498
 
499
+ // remember that heightValue and otherUnit work _not_ on the same block
500
+ if (unit === 'px') {
501
+ otherBlockUnit = '%';
502
+ otherBlockWidthValue = value * 100 / options.sizeProps.containerWidth;
503
+ } else {
504
+ otherBlockUnit = 'px';
505
+ otherBlockWidthValue = value * options.sizeProps.containerWidth / 100;
506
+ }
561
507
 
562
- options.$sliders[otherBlockUnit].val(otherBlockWidthValue); // update other width field
508
+ // update the unit-side of the tree with the value
509
+ options.sizeProps[unit].current.width = value;
510
+ options.sizeProps[otherBlockUnit].current.width = otherBlockWidthValue;
563
511
 
564
- options.$fields[otherBlockUnit].width.val(_round(otherBlockWidthValue, 0)); // reset percent height to null
512
+ // update the height fields of the same and of the other block
513
+ if (options.syncDimensions) {
514
+ heightValue = value / ratio;
515
+ otherBlockHeightValue = otherBlockWidthValue / ratio;
516
+ //same block
517
+ options.sizeProps[unit].current.height = heightValue;
518
+ options.$fields[unit].height.val(_round(heightValue, 0));
519
+ //other block
520
+ options.sizeProps[otherBlockUnit].current.height = otherBlockHeightValue;
521
+ options.$fields[otherBlockUnit].height.val(_round(otherBlockHeightValue, 0));
522
+ }
565
523
 
566
- options.sizeProps['%'].current.height = null; // update medium
524
+ /* sliders */
525
+ // update same slider value only when fn is triggered by typing
526
+ if (eventType !== 'sliderEvent') {
527
+ options.$sliders[unit].val(value);
528
+ }
529
+ // update other slider
530
+ options.$sliders[otherBlockUnit].val(otherBlockWidthValue);
567
531
 
568
- if (options.applyToMedium) {
569
- currentValues = this._getValues($elt);
570
- options.target.attr('width', currentValues.width);
571
- options.target.attr('height', currentValues.height || 'auto');
572
- }
532
+ // update other width field
533
+ options.$fields[otherBlockUnit].width.val(_round(otherBlockWidthValue, 0));
573
534
 
574
- $elt.trigger('sizechange.' + ns, self._publicArgs($elt, options));
575
- },
535
+ // reset percent height to null
536
+ options.sizeProps['%'].current.height = null;
576
537
 
577
- /**
578
- * Initialize the fields
579
- *
580
- * @param $elt
581
- * @returns {{}}
582
- * @private
583
- */
584
- _initFields: function _initFields($elt) {
585
- var options = $elt.data(dataNs),
538
+ // update medium
539
+ if (options.applyToMedium) {
540
+ currentValues = this._getValues($elt);
541
+ options.target.attr('width', currentValues.width);
542
+ options.target.attr('height', currentValues.height || 'auto');
543
+ }
544
+ $elt.trigger('sizechange.' + ns, self._publicArgs($elt, options));
545
+ },
546
+ /**
547
+ * Initialize the fields
548
+ *
549
+ * @param $elt
550
+ * @returns {{}}
551
+ * @private
552
+ */
553
+ _initFields: function ($elt) {
554
+ var options = $elt.data(dataNs),
586
555
  dimensions = ['width', 'height'],
587
556
  field,
588
557
  _fields = {},
589
558
  self = this;
590
-
591
- _(options.$blocks).forOwn(function ($block, unit) {
592
- _fields[unit] = {};
593
- options.$blocks[unit].find('input').each(function () {
594
- _(dimensions).forEach(function (dim) {
595
- field = options.$blocks[unit].find('[name="' + dim + '"]'); // there is no 'height' field for % - $('<input>') is a dummy to avoid checking if the field exists all the time
596
-
597
- _fields[unit][dim] = field.length ? field : $$1('<input>');
598
-
599
- _fields[unit][dim].prop({
600
- unit: unit,
601
- dimension: dim
602
- });
603
-
604
- _fields[unit][dim].val(_round(options.sizeProps[unit].current[dim], 0));
605
-
606
- _fields[unit][dim].data({
607
- min: 0,
608
- max: options.sizeProps.sliders[unit].max
609
- });
610
-
611
- _fields[unit][dim].on('keydown', function (e) {
612
- var $field = $$1(this),
559
+ _(options.$blocks).forOwn(function ($block, unit) {
560
+ _fields[unit] = {};
561
+ options.$blocks[unit].find('input').each(function () {
562
+ _(dimensions).forEach(function (dim) {
563
+ field = options.$blocks[unit].find('[name="' + dim + '"]');
564
+ // there is no 'height' field for % - $('<input>') is a dummy to avoid checking if the field exists all the time
565
+ _fields[unit][dim] = field.length ? field : $$1('<input>');
566
+ _fields[unit][dim].prop({
567
+ unit: unit,
568
+ dimension: dim
569
+ });
570
+ _fields[unit][dim].val(_round(options.sizeProps[unit].current[dim], 0));
571
+ _fields[unit][dim].data({
572
+ min: 0,
573
+ max: options.sizeProps.sliders[unit].max
574
+ });
575
+ _fields[unit][dim].on('keydown', function (e) {
576
+ var $field = $$1(this),
613
577
  c = e.keyCode,
614
578
  specChars = function () {
615
- var chars = [8, 37, 39, 46];
616
-
617
- if ($field.val().indexOf('.') === -1) {
618
- chars.push(190);
619
- chars.push(110);
620
- }
621
-
622
- return chars;
623
- }();
624
-
625
- return _.contains(specChars, c) || c >= 48 && c <= 57 || c >= 96 && c <= 105;
626
- });
627
-
628
- _fields[unit][dim].on('keyup blur sliderchange', function (e) {
629
- var $field = $$1(this),
579
+ var chars = [8, 37, 39, 46];
580
+ if ($field.val().indexOf('.') === -1) {
581
+ chars.push(190);
582
+ chars.push(110);
583
+ }
584
+ return chars;
585
+ }();
586
+ return _.contains(specChars, c) || c >= 48 && c <= 57 || c >= 96 && c <= 105;
587
+ });
588
+ _fields[unit][dim].on('keyup blur sliderchange', function (e) {
589
+ var $field = $$1(this),
630
590
  value = $field.val().replace(/,/g, '.');
631
- $field.val(value);
632
-
633
- if (value > $field.data('max')) {
634
- $field.val($field.data('max'));
635
- } else if (value < $field.data('min')) {
636
- $field.val($field.data('min'));
637
- }
638
-
639
- self._sync($elt, $$1(this), e.type);
591
+ $field.val(value);
592
+ if (value > $field.data('max')) {
593
+ $field.val($field.data('max'));
594
+ } else if (value < $field.data('min')) {
595
+ $field.val($field.data('min'));
596
+ }
597
+ self._sync($elt, $$1(this), e.type);
598
+ });
640
599
  });
641
600
  });
642
601
  });
643
- });
644
-
645
- return _fields;
646
- },
647
-
648
- /**
649
- * Retrieve current size values in current unit
650
- *
651
- * @param $elt
652
- * @returns {{}}
653
- * @private
654
- */
655
- _getValues: function _getValues($elt) {
656
- var options = $elt.data(dataNs),
602
+ return _fields;
603
+ },
604
+ /**
605
+ * Retrieve current size values in current unit
606
+ *
607
+ * @param $elt
608
+ * @returns {{}}
609
+ * @private
610
+ */
611
+ _getValues: function ($elt) {
612
+ var options = $elt.data(dataNs),
657
613
  attr = {};
614
+ _.forOwn(options.sizeProps[options.sizeProps.currentUnit].current, function (value, dimension) {
615
+ if (_.isNull(value)) {
616
+ value = '';
617
+ } else {
618
+ value = _round(value, 0).toString();
619
+ }
620
+ if (options.sizeProps.currentUnit === '%' && value !== '') {
621
+ value += options.sizeProps.currentUnit;
622
+ }
623
+ attr[dimension] = value;
624
+ });
625
+ return attr;
626
+ },
627
+ /**
628
+ * Initialize the plugin.
629
+ *
630
+ * Called the jQuery way once registered by the Pluginifier.
631
+ * @example $('selector').mediaSizer({target : $('target') });
632
+ * @public
633
+ *
634
+ * @constructor
635
+ * @returns {*}
636
+ */
637
+ init: function (options) {
638
+ //get options using default
639
+ options = $$1.extend(true, {}, defaults, options);
640
+ return this.each(function () {
641
+ var $elt = $$1(this);
642
+ options.hasTarget = options.target && options.target.length;
643
+
644
+ // compatibility layer naturalWidth|Height vs. naturalHeight
645
+ // internally width/height are used
646
+ options.width = options.width || options.naturalWidth || options.maxWidth || defaults.size;
647
+ options.height = options.height || options.naturalHeight || defaults.size;
648
+ options.naturalWidth = options.naturalWidth || options.width || defaults.size;
649
+ options.naturalHeight = options.naturalHeight || options.height || defaults.size;
650
+ options.hasSize = _.isFinite(+options.width) && _.isFinite(+options.height);
651
+
652
+ // incomplete or conflicting configurations
653
+ // no target provided, also no width and/or no height
654
+ if (!options.hasTarget && !options.hasSize) {
655
+ throw new Error('MediaSizer::init() You must either set width and height or a target element');
656
+ }
658
657
 
659
- _.forOwn(options.sizeProps[options.sizeProps.currentUnit].current, function (value, dimension) {
660
- if (_.isNull(value)) {
661
- value = '';
662
- } else {
663
- value = _round(value, 0).toString();
664
- }
665
-
666
- if (options.sizeProps.currentUnit === '%' && value !== '') {
667
- value += options.sizeProps.currentUnit;
668
- }
669
-
670
- attr[dimension] = value;
671
- });
672
-
673
- return attr;
674
- },
675
-
676
- /**
677
- * Initialize the plugin.
678
- *
679
- * Called the jQuery way once registered by the Pluginifier.
680
- * @example $('selector').mediaSizer({target : $('target') });
681
- * @public
682
- *
683
- * @constructor
684
- * @returns {*}
685
- */
686
- init: function init(options) {
687
- //get options using default
688
- options = $$1.extend(true, {}, defaults, options);
689
- return this.each(function () {
690
- var $elt = $$1(this);
691
- options.hasTarget = options.target && options.target.length; // compatibility layer naturalWidth|Height vs. naturalHeight
692
- // internally width/height are used
693
-
694
- options.width = options.width || options.naturalWidth || options.maxWidth || defaults.size;
695
- options.height = options.height || options.naturalHeight || defaults.size;
696
- options.naturalWidth = options.naturalWidth || options.width || defaults.size;
697
- options.naturalHeight = options.naturalHeight || options.height || defaults.size;
698
- options.hasSize = _.isFinite(+options.width) && _.isFinite(+options.height); // incomplete or conflicting configurations
699
- // no target provided, also no width and/or no height
700
-
701
- if (!options.hasTarget && !options.hasSize) {
702
- throw new Error('MediaSizer::init() You must either set width and height or a target element');
703
- } // no target provided, but applyToMedium = true
704
- else if (!options.hasTarget && options.applyToMedium) {
705
- throw new Error('MediaSizer::init() options.applyToMedium can only be true if a target element is provided');
706
- } // target quietly takes precedence over width and height
707
- else if (options.hasTarget && options.hasSize) {
708
- delete options.width;
709
- delete options.height;
710
- options.hasSize = false;
711
- }
658
+ // no target provided, but applyToMedium = true
659
+ else if (!options.hasTarget && options.applyToMedium) {
660
+ throw new Error('MediaSizer::init() options.applyToMedium can only be true if a target element is provided');
661
+ }
712
662
 
713
- if (!$elt.data(dataNs)) {
714
- $elt.html(tpl({
715
- responsive: typeof options.responsive !== 'undefined' ? !!options.responsive : true
716
- })); //add data to the element
717
-
718
- $elt.data(dataNs, options);
719
- options.sizeProps = MediaSizer._getSizeProps($elt);
720
- options.originalSizeProps = _.cloneDeep(options.sizeProps);
721
- options.syncDimensions = $elt.find('.media-sizer').hasClass('media-sizer-synced');
722
- options.$blocks = MediaSizer._initBlocks($elt);
723
- options.$fields = MediaSizer._initFields($elt);
724
- options.$sliders = MediaSizer._initSliders($elt);
725
- options.$syncBtn = MediaSizer._initSyncBtn($elt);
726
- options.$resetBtn = MediaSizer._initResetBtn($elt);
727
- /**
728
- * The plugin has been created
729
- * @event MediaSizer#create.toggler
663
+ // target quietly takes precedence over width and height
664
+ else if (options.hasTarget && options.hasSize) {
665
+ delete options.width;
666
+ delete options.height;
667
+ options.hasSize = false;
668
+ }
669
+ if (!$elt.data(dataNs)) {
670
+ $elt.html(tpl({
671
+ responsive: typeof options.responsive !== 'undefined' ? !!options.responsive : true
672
+ }));
673
+
674
+ //add data to the element
675
+ $elt.data(dataNs, options);
676
+ options.sizeProps = MediaSizer._getSizeProps($elt);
677
+ options.originalSizeProps = _.cloneDeep(options.sizeProps);
678
+ options.syncDimensions = $elt.find('.media-sizer').hasClass('media-sizer-synced');
679
+ options.$blocks = MediaSizer._initBlocks($elt);
680
+ options.$fields = MediaSizer._initFields($elt);
681
+ options.$sliders = MediaSizer._initSliders($elt);
682
+ options.$syncBtn = MediaSizer._initSyncBtn($elt);
683
+ options.$resetBtn = MediaSizer._initResetBtn($elt);
684
+
685
+ /**
686
+ * The plugin has been created
687
+ * @event MediaSizer#create.toggler
688
+ */
689
+ $elt.trigger('create.' + ns, MediaSizer._publicArgs($elt, options));
690
+ }
691
+ });
692
+ },
693
+ /**
694
+ * Destroy the plugin completely.
695
+ * Called the jQuery way once registered by the Pluginifier.
696
+ *
697
+ * @example $('selector').toggler('destroy');
698
+ * @public
699
+ */
700
+ destroy: function () {
701
+ this.each(function () {
702
+ var $elt = $$1(this);
703
+
704
+ /**
705
+ * The plugin have been destroyed.
706
+ * @event MediaSizer#destroy.toggler
730
707
  */
708
+ $elt.trigger('destroy.' + ns);
709
+ });
710
+ }
711
+ };
731
712
 
732
- $elt.trigger('create.' + ns, MediaSizer._publicArgs($elt, options));
733
- }
734
- });
735
- },
736
-
737
- /**
738
- * Destroy the plugin completely.
739
- * Called the jQuery way once registered by the Pluginifier.
740
- *
741
- * @example $('selector').toggler('destroy');
742
- * @public
743
- */
744
- destroy: function destroy() {
745
- this.each(function () {
746
- var $elt = $$1(this);
747
- /**
748
- * The plugin have been destroyed.
749
- * @event MediaSizer#destroy.toggler
750
- */
751
-
752
- $elt.trigger('destroy.' + ns);
753
- });
754
- }
755
- }; //Register the toggler to behave as a jQuery plugin.
756
-
757
- Pluginifier.register(ns, MediaSizer);
713
+ //Register the toggler to behave as a jQuery plugin.
714
+ Pluginifier.register(ns, MediaSizer);
758
715
 
759
716
  });