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