@kizmann/nano-ui 1.0.15 → 1.1.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/dist/nano-ui.css +1 -1
- package/dist/nano-ui.js +1 -1
- package/dist/nano-ui.js.map +1 -1
- package/dist/themes/default.css +1 -0
- package/dist/themes/webservy.css +1 -0
- package/package.json +6 -2
- package/src/alert/index.js +13 -2
- package/src/alert/index.scss +1 -1
- package/src/alert/src/alert/alert-handler.mjs +143 -0
- package/src/alert/src/alert/alert.scss +35 -43
- package/src/button/index.scss +2 -2
- package/src/button/src/button/button.jsx +12 -0
- package/src/button/src/button/button.scss +30 -31
- package/src/button/src/button-group/button-group.scss +9 -19
- package/src/cascader/index.scss +2 -2
- package/src/cascader/src/cascader/cascader.jsx +22 -4
- package/src/cascader/src/cascader/cascader.scss +26 -78
- package/src/cascader/src/cascader-panel/cascader-panel.scss +2 -16
- package/src/chart/index.js +9 -0
- package/src/chart/index.scss +3 -0
- package/src/chart/src/chart-bar/chart-bar.jsx +344 -0
- package/src/chart/src/chart-bar/chart-bar.scss +143 -0
- package/src/chart/src/chart-donut/chart-donut.jsx +404 -0
- package/src/chart/src/chart-donut/chart-donut.scss +123 -0
- package/src/chart/src/chart-item/chart-item.jsx +110 -0
- package/src/chart/src/chart-item/chart-item.scss +30 -0
- package/src/checkbox/index.scss +2 -2
- package/src/checkbox/src/checkbox/checkbox.scss +11 -30
- package/src/checkbox/src/checkbox-group/checkbox-group.scss +19 -29
- package/src/collapse/index.scss +2 -2
- package/src/collapse/src/collapse/collapse.jsx +27 -4
- package/src/collapse/src/collapse/collapse.scss +14 -22
- package/src/collapse/src/collapse-item/collapse-item.jsx +43 -9
- package/src/collapse/src/collapse-item/collapse-item.scss +31 -29
- package/src/config/index.scss +3 -3
- package/src/config/src/builder/builder.scss +1 -1
- package/src/config/src/reference-panel/reference-panel.scss +1 -1
- package/src/confirm/index.js +23 -1
- package/src/confirm/index.scss +1 -1
- package/src/confirm/src/confirm/confirm-handler.mjs +226 -0
- package/src/confirm/src/confirm/confirm.jsx +109 -123
- package/src/confirm/src/confirm/confirm.scss +57 -49
- package/src/datepicker/index.scss +2 -2
- package/src/datepicker/src/datepicker/datepicker.jsx +23 -4
- package/src/datepicker/src/datepicker/datepicker.scss +20 -51
- package/src/datepicker/src/datepicker-panel/datepicker-panel.jsx +4 -2
- package/src/datepicker/src/datepicker-panel/datepicker-panel.scss +79 -53
- package/src/datetimepicker/index.scss +1 -1
- package/src/datetimepicker/src/datetimepicker/datetimepicker.jsx +3 -3
- package/src/datetimepicker/src/datetimepicker/datetimepicker.scss +23 -61
- package/src/draggable/index.scss +6 -6
- package/src/draggable/src/draggrid/draggrid.jsx +4 -4
- package/src/draggable/src/draggrid/draggrid.scss +2 -19
- package/src/draggable/src/draggrid-item/draggrid-item.scss +12 -34
- package/src/draggable/src/draghandler/draghandler.scss +1 -1
- package/src/draggable/src/draglist/draglist.jsx +4 -4
- package/src/draggable/src/draglist/draglist.scss +3 -20
- package/src/draggable/src/draglist-item/draglist-item.jsx +5 -2
- package/src/draggable/src/draglist-item/draglist-item.scss +15 -36
- package/src/draggable/src/dropzone/dropzone.scss +6 -19
- package/src/drawer/index.scss +1 -1
- package/src/drawer/src/drawer/drawer.jsx +6 -3
- package/src/drawer/src/drawer/drawer.scss +27 -31
- package/src/durationpicker/index.scss +1 -1
- package/src/durationpicker/src/durationpicker/durationpicker.jsx +3 -3
- package/src/durationpicker/src/durationpicker/durationpicker.scss +18 -55
- package/src/empty/index.scss +1 -1
- package/src/empty/src/empty-icon/empty-icon.jsx +1 -1
- package/src/empty/src/empty-icon/empty-icon.scss +13 -26
- package/src/file/index.scss +1 -1
- package/src/file/src/file/file.jsx +9 -0
- package/src/file/src/file/file.scss +2 -2
- package/src/form/index.js +2 -0
- package/src/form/index.scss +5 -4
- package/src/form/src/form/form-rules.mjs +182 -0
- package/src/form/src/form/form.jsx +108 -4
- package/src/form/src/form/form.scss +33 -1
- package/src/form/src/form-bag/form-bag.jsx +90 -0
- package/src/form/src/form-bag/form-bag.scss +59 -0
- package/src/form/src/form-frame/form-frame.jsx +17 -9
- package/src/form/src/form-frame/form-frame.scss +25 -38
- package/src/form/src/form-group/form-group.jsx +24 -6
- package/src/form/src/form-group/form-group.scss +85 -66
- package/src/form/src/form-item/form-item.jsx +79 -68
- package/src/form/src/form-item/form-item.scss +23 -32
- package/src/grid/index.scss +1 -0
- package/src/grid/src/grid/grid.scss +146 -0
- package/src/index.js +4 -1
- package/src/index.scss +45 -39
- package/src/info/index.scss +3 -3
- package/src/info/src/info/info.jsx +1 -1
- package/src/info/src/info/info.scss +7 -26
- package/src/info/src/info-column/info-column.scss +2 -16
- package/src/info/src/info-field/info-field.scss +1 -1
- package/src/input/index.scss +1 -1
- package/src/input/src/input/input.jsx +1 -1
- package/src/input/src/input/input.scss +15 -40
- package/src/input-number/index.scss +1 -1
- package/src/input-number/src/input-number/input-number.jsx +39 -23
- package/src/input-number/src/input-number/input-number.scss +14 -59
- package/src/loader/index.scss +1 -1
- package/src/loader/src/loader/loader.scss +16 -29
- package/src/map/index.scss +1 -1
- package/src/map/src/map/map.scss +1 -2
- package/src/modal/index.scss +1 -1
- package/src/modal/src/modal/modal.jsx +7 -4
- package/src/modal/src/modal/modal.scss +27 -40
- package/src/notification/index.js +23 -3
- package/src/notification/index.scss +1 -1
- package/src/notification/src/notification/notification-element.mjs +74 -0
- package/src/notification/src/notification/notification-handler.mjs +75 -0
- package/src/notification/src/notification/notification.scss +13 -25
- package/src/paginator/index.scss +1 -1
- package/src/paginator/src/paginator/paginator.jsx +24 -29
- package/src/paginator/src/paginator/paginator.scss +39 -44
- package/src/popover/index.js +20 -3
- package/src/popover/index.scss +1 -1
- package/src/popover/src/popover/popover-element.mjs +578 -0
- package/src/popover/src/popover/popover-handler.mjs +116 -0
- package/src/popover/src/popover/popover-helper.mjs +75 -0
- package/src/popover/src/popover/popover.jsx +78 -550
- package/src/popover/src/popover/popover.scss +186 -78
- package/src/preview/index.js +46 -4
- package/src/preview/index.scss +5 -4
- package/src/preview/src/preview/preview-handler.mjs +205 -0
- package/src/preview/src/preview/preview-helper.mjs +126 -0
- package/src/preview/src/preview/preview.jsx +87 -117
- package/src/preview/src/preview/preview.scss +29 -2
- package/src/preview/src/preview-image/preview-image.scss +1 -3
- package/src/preview/src/preview-modal/preview-modal.jsx +126 -0
- package/src/preview/src/preview-modal/preview-modal.scss +69 -0
- package/src/preview/src/preview-plain/preview-plain.jsx +32 -20
- package/src/preview/src/preview-plain/preview-plain.scss +5 -3
- package/src/preview/src/preview-video/preview-video.jsx +3 -60
- package/src/preview/src/preview-video/preview-video.scss +1 -2
- package/src/radio/index.scss +2 -2
- package/src/radio/src/radio/radio.scss +13 -32
- package/src/radio/src/radio-group/radio-group.scss +18 -28
- package/src/rating/index.scss +1 -1
- package/src/rating/src/rating/rating.scss +15 -33
- package/src/resizer/index.js +3 -1
- package/src/resizer/index.scss +1 -1
- package/src/resizer/src/resizer/resizer-next.jsx +556 -0
- package/src/resizer/src/resizer/resizer.scss +1 -1
- package/src/root/helpers.scss +41 -0
- package/src/root/image/angle-down-shadow.svg +3 -0
- package/src/root/image/angle-down.svg +3 -0
- package/src/root/image/angle-left-shadow.svg +3 -0
- package/src/root/image/angle-left.svg +3 -0
- package/src/root/image/angle-right-shadow.svg +3 -0
- package/src/root/image/angle-right.svg +3 -0
- package/src/root/image/angle-up-shadow.svg +3 -0
- package/src/root/image/angle-up.svg +3 -0
- package/src/root/image/empty-ufo.svg +8 -0
- package/src/root/image/empty.svg +10 -0
- package/src/root/image/star.svg +5 -0
- package/src/root/vars.scss +5 -3
- package/src/scrollbar/index.scss +1 -1
- package/src/scrollbar/src/scrollbar/scrollbar.jsx +213 -376
- package/src/scrollbar/src/scrollbar/scrollbar.scss +23 -19
- package/src/select/index.scss +2 -2
- package/src/select/src/select/select.jsx +30 -26
- package/src/select/src/select/select.scss +49 -104
- package/src/select/src/select-option/select-option.scss +1 -1
- package/src/slider/index.scss +1 -1
- package/src/slider/src/slider/slider.jsx +5 -3
- package/src/slider/src/slider/slider.scss +37 -46
- package/src/switch/index.scss +1 -1
- package/src/switch/src/switch/switch.scss +17 -44
- package/src/table/index.scss +4 -4
- package/src/table/src/table/table.jsx +9 -9
- package/src/table/src/table/table.scss +19 -25
- package/src/table/src/table-cell/table-cell.scss +7 -18
- package/src/table/src/table-cell/types/table-cell-image.jsx +9 -3
- package/src/table/src/table-column/table-column.jsx +12 -24
- package/src/table/src/table-column/table-column.scss +14 -13
- package/src/table/src/table-filter/table-filter.jsx +4 -4
- package/src/table/src/table-filter/table-filter.scss +10 -4
- package/src/tabs/index.scss +2 -2
- package/src/tabs/src/tabs/tabs.scss +20 -29
- package/src/tabs/src/tabs-item/tabs-item.jsx +15 -7
- package/src/tabs/src/tabs-item/tabs-item.scss +17 -25
- package/src/tags/index.scss +2 -2
- package/src/tags/src/tags/tags.jsx +1 -0
- package/src/tags/src/tags/tags.scss +6 -2
- package/src/tags/src/tags-item/tags-item.jsx +8 -9
- package/src/tags/src/tags-item/tags-item.scss +10 -31
- package/src/textarea/index.scss +1 -1
- package/src/textarea/src/textarea/textarea.jsx +2 -0
- package/src/textarea/src/textarea/textarea.scss +6 -23
- package/src/timepicker/index.scss +2 -2
- package/src/timepicker/src/timepicker/timepicker.jsx +6 -3
- package/src/timepicker/src/timepicker/timepicker.scss +21 -53
- package/src/timepicker/src/timepicker-panel/timepicker-panel.jsx +15 -3
- package/src/timepicker/src/timepicker-panel/timepicker-panel.scss +34 -41
- package/src/tooltip/index.scss +1 -0
- package/src/tooltip/src/tooltip/tooltip.scss +116 -0
- package/src/transfer/index.scss +1 -1
- package/src/transfer/src/transfer/transfer.jsx +2 -2
- package/src/transfer/src/transfer/transfer.scss +33 -53
- package/src/virtualscroller/index.scss +1 -1
- package/src/virtualscroller/src/virtualscroller/virtualscroller.jsx +71 -44
- package/src/virtualscroller/src/virtualscroller/virtualscroller.scss +4 -2
- package/themes/default/alert/index.scss +1 -0
- package/themes/default/alert/src/alert/alert.scss +29 -0
- package/themes/default/button/index.scss +2 -0
- package/themes/default/button/src/button/button.scss +87 -0
- package/themes/default/button/src/button-group/button-group.scss +1 -0
- package/themes/default/cascader/index.scss +2 -0
- package/themes/default/cascader/src/cascader/cascader.scss +31 -0
- package/themes/default/cascader/src/cascader-panel/cascader-panel.scss +21 -0
- package/themes/default/chart/index.scss +2 -0
- package/themes/default/chart/src/chart-donut/chart-donut.scss +22 -0
- package/themes/default/chart/src/chart-item/chart-item.scss +11 -0
- package/themes/default/checkbox/index.scss +2 -0
- package/themes/default/checkbox/src/checkbox/checkbox.scss +26 -0
- package/themes/default/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
- package/themes/default/collapse/index.scss +2 -0
- package/themes/default/collapse/src/collapse/collapse.scss +14 -0
- package/themes/default/collapse/src/collapse-item/collapse-item.scss +14 -0
- package/themes/default/confirm/index.scss +1 -0
- package/themes/default/confirm/src/confirm/confirm.scss +35 -0
- package/themes/default/datepicker/index.scss +2 -0
- package/themes/default/datepicker/src/datepicker/datepicker.scss +44 -0
- package/themes/default/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
- package/themes/default/datetimepicker/index.scss +1 -0
- package/themes/default/datetimepicker/src/datetimepicker/datetimepicker.scss +51 -0
- package/themes/default/demo/index.scss +1 -0
- package/themes/default/demo/src/demo/demo.scss +34 -0
- package/themes/default/draggable/index.scss +9 -0
- package/themes/default/draggable/src/draggrid/draggrid.scss +5 -0
- package/themes/default/draggable/src/draggrid-item/draggrid-item.scss +52 -0
- package/themes/default/draggable/src/draghandler/draghandler.scss +15 -0
- package/themes/default/draggable/src/draglist/draglist.scss +5 -0
- package/themes/default/draggable/src/draglist-item/draglist-item.scss +56 -0
- package/themes/default/draggable/src/dropzone/dropzone.scss +5 -0
- package/themes/default/drawer/index.scss +1 -0
- package/themes/default/drawer/src/drawer/drawer.scss +25 -0
- package/themes/default/durationpicker/index.scss +1 -0
- package/themes/default/durationpicker/src/durationpicker/durationpicker.scss +39 -0
- package/themes/default/empty/index.scss +1 -0
- package/themes/default/empty/src/empty-icon/empty-icon.scss +17 -0
- package/themes/default/example.scss +29 -0
- package/themes/default/file/index.scss +1 -0
- package/themes/default/file/src/file/file.scss +1 -0
- package/themes/default/form/index.scss +4 -0
- package/themes/default/form/src/form/form.scss +17 -0
- package/themes/default/form/src/form-frame/form-frame.scss +25 -0
- package/themes/default/form/src/form-group/form-group.scss +42 -0
- package/themes/default/form/src/form-item/form-item.scss +25 -0
- package/themes/default/index.scss +43 -0
- package/themes/default/info/index.scss +3 -0
- package/themes/default/info/src/info/info.scss +5 -0
- package/themes/default/info/src/info-column/info-column.scss +5 -0
- package/themes/default/info/src/info-field/info-field.scss +5 -0
- package/themes/default/input/index.scss +1 -0
- package/themes/default/input/src/input/input.scss +27 -0
- package/themes/default/input-number/index.scss +1 -0
- package/themes/default/input-number/src/input-number/input-number.scss +30 -0
- package/themes/default/loader/index.scss +1 -0
- package/themes/default/loader/src/loader/loader.scss +10 -0
- package/themes/default/map/index.scss +1 -0
- package/themes/default/map/src/map/map.scss +1 -0
- package/themes/default/modal/index.scss +1 -0
- package/themes/default/modal/src/modal/modal.scss +25 -0
- package/themes/default/notification/index.scss +1 -0
- package/themes/default/notification/src/notification/notification.scss +11 -0
- package/themes/default/paginator/index.scss +1 -0
- package/themes/default/paginator/src/paginator/paginator.scss +5 -0
- package/themes/default/popover/index.scss +1 -0
- package/themes/default/popover/src/popover/popover.scss +131 -0
- package/themes/default/preview/index.scss +4 -0
- package/themes/default/preview/src/preview-image/preview-image.scss +5 -0
- package/themes/default/preview/src/preview-modal/preview-modal.scss +39 -0
- package/themes/default/preview/src/preview-plain/preview-plain.scss +9 -0
- package/themes/default/preview/src/preview-video/preview-video.scss +5 -0
- package/themes/default/radio/index.scss +2 -0
- package/themes/default/radio/src/radio/radio.scss +32 -0
- package/themes/default/radio/src/radio-group/radio-group.scss +1 -0
- package/themes/default/rating/index.scss +1 -0
- package/themes/default/rating/src/rating/rating.scss +14 -0
- package/themes/default/resizer/index.scss +1 -0
- package/themes/default/resizer/src/resizer/resizer.scss +5 -0
- package/themes/default/root/helpers.scss +41 -0
- package/themes/default/root/image/angle-down-shadow.svg +3 -0
- package/themes/default/root/image/angle-down.svg +3 -0
- package/themes/default/root/image/angle-left-shadow.svg +3 -0
- package/themes/default/root/image/angle-left.svg +3 -0
- package/themes/default/root/image/angle-right-shadow.svg +3 -0
- package/themes/default/root/image/angle-right.svg +3 -0
- package/themes/default/root/image/angle-up-shadow.svg +3 -0
- package/themes/default/root/image/angle-up.svg +3 -0
- package/themes/default/root/image/empty-ufo.svg +8 -0
- package/themes/default/root/image/empty.svg +10 -0
- package/themes/default/root/image/star.svg +5 -0
- package/themes/default/root/vars/colors-dark-bluish.scss +457 -0
- package/themes/default/root/vars/colors-dark.scss +457 -0
- package/themes/default/root/vars/colors-light-bluish.scss +479 -0
- package/themes/default/root/vars/colors-light.scss +479 -0
- package/themes/default/root/vars/sizes-default.scss +101 -0
- package/themes/default/scrollbar/index.scss +1 -0
- package/themes/default/scrollbar/src/scrollbar/scrollbar.scss +7 -0
- package/themes/default/select/index.scss +2 -0
- package/themes/default/select/src/select/select.scss +32 -0
- package/themes/default/select/src/select-option/select-option.scss +1 -0
- package/themes/default/slider/index.scss +1 -0
- package/themes/default/slider/src/slider/slider.scss +30 -0
- package/themes/default/switch/index.scss +1 -0
- package/themes/default/switch/src/switch/switch.scss +19 -0
- package/themes/default/table/index.scss +4 -0
- package/themes/default/table/src/table/table.scss +14 -0
- package/themes/default/table/src/table-cell/table-cell.scss +34 -0
- package/themes/{macos → default}/table/src/table-column/table-column.scss +9 -10
- package/themes/default/table/src/table-filter/table-filter.scss +1 -0
- package/themes/default/tabs/index.scss +2 -0
- package/themes/default/tabs/src/tabs/tabs.scss +9 -0
- package/themes/default/tabs/src/tabs-item/tabs-item.scss +23 -0
- package/themes/default/tags/index.scss +2 -0
- package/themes/default/tags/src/tags/tags.scss +1 -0
- package/themes/default/tags/src/tags-item/tags-item.scss +17 -0
- package/themes/default/textarea/index.scss +1 -0
- package/themes/default/textarea/src/textarea/textarea.scss +18 -0
- package/themes/default/timepicker/index.scss +2 -0
- package/themes/default/timepicker/src/timepicker/timepicker.scss +44 -0
- package/themes/default/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
- package/themes/default/transfer/index.scss +1 -0
- package/themes/default/transfer/src/transfer/transfer.scss +20 -0
- package/themes/default/virtualscroller/index.scss +1 -0
- package/themes/default/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
- package/themes/webservy/alert/index.scss +1 -0
- package/themes/webservy/alert/src/alert/alert.scss +29 -0
- package/themes/webservy/button/index.scss +2 -0
- package/themes/webservy/button/src/button/button.scss +87 -0
- package/themes/webservy/button/src/button-group/button-group.scss +1 -0
- package/themes/webservy/cascader/index.scss +2 -0
- package/themes/webservy/cascader/src/cascader/cascader.scss +27 -0
- package/themes/webservy/cascader/src/cascader-panel/cascader-panel.scss +21 -0
- package/themes/webservy/chart/index.scss +2 -0
- package/themes/webservy/chart/src/chart-donut/chart-donut.scss +22 -0
- package/themes/webservy/chart/src/chart-item/chart-item.scss +11 -0
- package/themes/webservy/checkbox/index.scss +2 -0
- package/themes/webservy/checkbox/src/checkbox/checkbox.scss +25 -0
- package/themes/webservy/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
- package/themes/webservy/collapse/index.scss +2 -0
- package/themes/webservy/collapse/src/collapse/collapse.scss +14 -0
- package/themes/webservy/collapse/src/collapse-item/collapse-item.scss +14 -0
- package/themes/webservy/confirm/index.scss +1 -0
- package/themes/webservy/confirm/src/confirm/confirm.scss +35 -0
- package/themes/webservy/datepicker/index.scss +2 -0
- package/themes/webservy/datepicker/src/datepicker/datepicker.scss +40 -0
- package/themes/webservy/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
- package/themes/webservy/datetimepicker/index.scss +1 -0
- package/themes/webservy/datetimepicker/src/datetimepicker/datetimepicker.scss +47 -0
- package/themes/webservy/demo/index.scss +1 -0
- package/themes/webservy/demo/src/demo/demo.scss +34 -0
- package/themes/webservy/draggable/index.scss +9 -0
- package/themes/webservy/draggable/src/draggrid/draggrid.scss +5 -0
- package/themes/webservy/draggable/src/draggrid-item/draggrid-item.scss +51 -0
- package/themes/webservy/draggable/src/draghandler/draghandler.scss +15 -0
- package/themes/webservy/draggable/src/draglist/draglist.scss +5 -0
- package/themes/webservy/draggable/src/draglist-item/draglist-item.scss +55 -0
- package/themes/webservy/draggable/src/dropzone/dropzone.scss +5 -0
- package/themes/webservy/drawer/index.scss +1 -0
- package/themes/webservy/drawer/src/drawer/drawer.scss +23 -0
- package/themes/webservy/durationpicker/index.scss +1 -0
- package/themes/webservy/durationpicker/src/durationpicker/durationpicker.scss +35 -0
- package/themes/webservy/empty/index.scss +1 -0
- package/themes/webservy/empty/src/empty-icon/empty-icon.scss +17 -0
- package/themes/webservy/example.scss +29 -0
- package/themes/webservy/file/index.scss +1 -0
- package/themes/webservy/file/src/file/file.scss +1 -0
- package/themes/webservy/form/index.scss +4 -0
- package/themes/webservy/form/src/form/form.scss +17 -0
- package/themes/webservy/form/src/form-frame/form-frame.scss +25 -0
- package/themes/webservy/form/src/form-group/form-group.scss +42 -0
- package/themes/webservy/form/src/form-item/form-item.scss +25 -0
- package/themes/webservy/index.scss +43 -0
- package/themes/webservy/info/index.scss +3 -0
- package/themes/webservy/info/src/info/info.scss +5 -0
- package/themes/webservy/info/src/info-column/info-column.scss +5 -0
- package/themes/webservy/info/src/info-field/info-field.scss +5 -0
- package/themes/webservy/input/index.scss +1 -0
- package/themes/webservy/input/src/input/input.scss +23 -0
- package/themes/webservy/input-number/index.scss +1 -0
- package/themes/webservy/input-number/src/input-number/input-number.scss +27 -0
- package/themes/webservy/loader/index.scss +1 -0
- package/themes/webservy/loader/src/loader/loader.scss +10 -0
- package/themes/webservy/map/index.scss +1 -0
- package/themes/webservy/map/src/map/map.scss +1 -0
- package/themes/webservy/modal/index.scss +1 -0
- package/themes/webservy/modal/src/modal/modal.scss +23 -0
- package/themes/webservy/notification/index.scss +1 -0
- package/themes/webservy/notification/src/notification/notification.scss +11 -0
- package/themes/webservy/paginator/index.scss +1 -0
- package/themes/webservy/paginator/src/paginator/paginator.scss +5 -0
- package/themes/webservy/popover/index.scss +1 -0
- package/themes/webservy/popover/src/popover/popover.scss +131 -0
- package/themes/webservy/preview/index.scss +4 -0
- package/themes/webservy/preview/src/preview-image/preview-image.scss +5 -0
- package/themes/webservy/preview/src/preview-modal/preview-modal.scss +39 -0
- package/themes/webservy/preview/src/preview-plain/preview-plain.scss +9 -0
- package/themes/webservy/preview/src/preview-video/preview-video.scss +5 -0
- package/themes/webservy/radio/index.scss +2 -0
- package/themes/webservy/radio/src/radio/radio.scss +31 -0
- package/themes/webservy/radio/src/radio-group/radio-group.scss +1 -0
- package/themes/webservy/rating/index.scss +1 -0
- package/themes/webservy/rating/src/rating/rating.scss +14 -0
- package/themes/webservy/resizer/index.scss +1 -0
- package/themes/webservy/resizer/src/resizer/resizer.scss +5 -0
- package/themes/webservy/root/helpers.scss +41 -0
- package/themes/webservy/root/image/angle-down-shadow.svg +3 -0
- package/themes/webservy/root/image/angle-down.svg +3 -0
- package/themes/webservy/root/image/angle-left-shadow.svg +3 -0
- package/themes/webservy/root/image/angle-left.svg +3 -0
- package/themes/webservy/root/image/angle-right-shadow.svg +3 -0
- package/themes/webservy/root/image/angle-right.svg +3 -0
- package/themes/webservy/root/image/angle-up-shadow.svg +3 -0
- package/themes/webservy/root/image/angle-up.svg +3 -0
- package/themes/webservy/root/image/empty-ufo.svg +8 -0
- package/themes/webservy/root/image/empty.svg +10 -0
- package/themes/webservy/root/image/star.svg +5 -0
- package/themes/webservy/root/vars/colors-dark-bluish.scss +461 -0
- package/themes/webservy/root/vars/colors-dark.scss +461 -0
- package/themes/webservy/root/vars/colors-light-bluish.scss +483 -0
- package/themes/webservy/root/vars/colors-light.scss +483 -0
- package/themes/webservy/root/vars/sizes-default.scss +101 -0
- package/themes/webservy/scrollbar/index.scss +1 -0
- package/themes/webservy/scrollbar/src/scrollbar/scrollbar.scss +7 -0
- package/themes/webservy/select/index.scss +2 -0
- package/themes/webservy/select/src/select/select.scss +28 -0
- package/themes/webservy/select/src/select-option/select-option.scss +1 -0
- package/themes/webservy/slider/index.scss +1 -0
- package/themes/webservy/slider/src/slider/slider.scss +30 -0
- package/themes/webservy/switch/index.scss +1 -0
- package/themes/webservy/switch/src/switch/switch.scss +19 -0
- package/themes/webservy/table/index.scss +4 -0
- package/themes/webservy/table/src/table/table.scss +14 -0
- package/themes/webservy/table/src/table-cell/table-cell.scss +34 -0
- package/themes/webservy/table/src/table-column/table-column.scss +31 -0
- package/themes/webservy/table/src/table-filter/table-filter.scss +1 -0
- package/themes/webservy/tabs/index.scss +2 -0
- package/themes/webservy/tabs/src/tabs/tabs.scss +9 -0
- package/themes/webservy/tabs/src/tabs-item/tabs-item.scss +23 -0
- package/themes/webservy/tags/index.scss +2 -0
- package/themes/webservy/tags/src/tags/tags.scss +1 -0
- package/themes/webservy/tags/src/tags-item/tags-item.scss +17 -0
- package/themes/webservy/textarea/index.scss +1 -0
- package/themes/webservy/textarea/src/textarea/textarea.scss +14 -0
- package/themes/webservy/timepicker/index.scss +2 -0
- package/themes/webservy/timepicker/src/timepicker/timepicker.scss +40 -0
- package/themes/webservy/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
- package/themes/webservy/transfer/index.scss +1 -0
- package/themes/webservy/transfer/src/transfer/transfer.scss +24 -0
- package/themes/webservy/virtualscroller/index.scss +1 -0
- package/themes/webservy/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
- package/dist/themes/dark.css +0 -1
- package/dist/themes/light.css +0 -1
- package/src/alert/src/alert/alert.js +0 -133
- package/src/notification/src/notification/notification.js +0 -165
- package/src/root/image/empty-default.svg +0 -30
- package/src/root/image/empty-space.svg +0 -34
- package/src/root/image/star-default.svg +0 -10
- package/themes/macos/alert/index.scss +0 -1
- package/themes/macos/alert/src/alert/alert.scss +0 -27
- package/themes/macos/button/index.scss +0 -2
- package/themes/macos/button/src/button/button.scss +0 -98
- package/themes/macos/button/src/button-group/button-group.scss +0 -1
- package/themes/macos/cascader/index.scss +0 -2
- package/themes/macos/cascader/src/cascader/cascader.scss +0 -47
- package/themes/macos/cascader/src/cascader-panel/cascader-panel.scss +0 -14
- package/themes/macos/checkbox/index.scss +0 -2
- package/themes/macos/checkbox/src/checkbox/checkbox.scss +0 -45
- package/themes/macos/checkbox/src/checkbox-group/checkbox-group.scss +0 -1
- package/themes/macos/collapse/index.scss +0 -2
- package/themes/macos/collapse/src/collapse/collapse.scss +0 -22
- package/themes/macos/collapse/src/collapse-item/collapse-item.scss +0 -22
- package/themes/macos/confirm/index.scss +0 -1
- package/themes/macos/confirm/src/confirm/confirm.scss +0 -14
- package/themes/macos/datepicker/index.scss +0 -2
- package/themes/macos/datepicker/src/datepicker/datepicker.scss +0 -51
- package/themes/macos/datepicker/src/datepicker-panel/datepicker-panel.scss +0 -45
- package/themes/macos/datetimepicker/index.scss +0 -1
- package/themes/macos/datetimepicker/src/datetimepicker/datetimepicker.scss +0 -69
- package/themes/macos/demo/index.scss +0 -1
- package/themes/macos/demo/src/demo/demo.scss +0 -22
- package/themes/macos/draggable/index.scss +0 -9
- package/themes/macos/draggable/src/draggrid/draggrid.scss +0 -14
- package/themes/macos/draggable/src/draggrid-item/draggrid-item.scss +0 -66
- package/themes/macos/draggable/src/draghandler/draghandler.scss +0 -15
- package/themes/macos/draggable/src/draglist/draglist.scss +0 -14
- package/themes/macos/draggable/src/draglist-item/draglist-item.scss +0 -73
- package/themes/macos/draggable/src/dropzone/dropzone.scss +0 -14
- package/themes/macos/drawer/index.scss +0 -1
- package/themes/macos/drawer/src/drawer/drawer.scss +0 -35
- package/themes/macos/durationpicker/index.scss +0 -1
- package/themes/macos/durationpicker/src/durationpicker/durationpicker.scss +0 -53
- package/themes/macos/empty/index.scss +0 -1
- package/themes/macos/empty/src/empty-icon/empty-icon.scss +0 -13
- package/themes/macos/file/index.scss +0 -1
- package/themes/macos/file/src/file/file.scss +0 -39
- package/themes/macos/form/index.scss +0 -4
- package/themes/macos/form/src/form/form.scss +0 -1
- package/themes/macos/form/src/form-frame/form-frame.scss +0 -34
- package/themes/macos/form/src/form-group/form-group.scss +0 -43
- package/themes/macos/form/src/form-item/form-item.scss +0 -29
- package/themes/macos/index-dark.scss +0 -3
- package/themes/macos/index-light.scss +0 -3
- package/themes/macos/index.scss +0 -40
- package/themes/macos/info/index.scss +0 -3
- package/themes/macos/info/src/info/info.scss +0 -5
- package/themes/macos/info/src/info-column/info-column.scss +0 -5
- package/themes/macos/info/src/info-field/info-field.scss +0 -5
- package/themes/macos/input/index.scss +0 -1
- package/themes/macos/input/src/input/input.scss +0 -39
- package/themes/macos/input-number/index.scss +0 -1
- package/themes/macos/input-number/src/input-number/input-number.scss +0 -48
- package/themes/macos/loader/index.scss +0 -1
- package/themes/macos/loader/src/loader/loader.scss +0 -22
- package/themes/macos/map/index.scss +0 -1
- package/themes/macos/map/src/map/map.scss +0 -1
- package/themes/macos/modal/index.scss +0 -1
- package/themes/macos/modal/src/modal/modal.scss +0 -35
- package/themes/macos/notification/index.scss +0 -1
- package/themes/macos/notification/src/notification/notification.scss +0 -25
- package/themes/macos/paginator/index.scss +0 -1
- package/themes/macos/paginator/src/paginator/paginator.scss +0 -5
- package/themes/macos/popover/index.scss +0 -1
- package/themes/macos/popover/src/popover/popover.scss +0 -84
- package/themes/macos/radio/index.scss +0 -2
- package/themes/macos/radio/src/radio/radio.scss +0 -46
- package/themes/macos/radio/src/radio-group/radio-group.scss +0 -1
- package/themes/macos/rating/index.scss +0 -1
- package/themes/macos/rating/src/rating/rating.scss +0 -19
- package/themes/macos/resizer/index.scss +0 -1
- package/themes/macos/resizer/src/resizer/resizer.scss +0 -5
- package/themes/macos/root/image/empty-default.svg +0 -30
- package/themes/macos/root/image/empty-space.svg +0 -34
- package/themes/macos/root/image/star-default.svg +0 -10
- package/themes/macos/root/vars-dark.scss +0 -234
- package/themes/macos/root/vars-light.scss +0 -234
- package/themes/macos/root/vars.scss +0 -233
- package/themes/macos/scrollbar/index.scss +0 -1
- package/themes/macos/scrollbar/src/scrollbar/scrollbar.scss +0 -6
- package/themes/macos/select/index.scss +0 -2
- package/themes/macos/select/src/select/select.scss +0 -49
- package/themes/macos/select/src/select-option/select-option.scss +0 -1
- package/themes/macos/slider/index.scss +0 -1
- package/themes/macos/slider/src/slider/slider.scss +0 -41
- package/themes/macos/switch/index.scss +0 -1
- package/themes/macos/switch/src/switch/switch.scss +0 -30
- package/themes/macos/table/index.scss +0 -4
- package/themes/macos/table/src/table/table.scss +0 -15
- package/themes/macos/table/src/table-cell/table-cell.scss +0 -51
- package/themes/macos/table/src/table-filter/table-filter.scss +0 -1
- package/themes/macos/tabs/index.scss +0 -2
- package/themes/macos/tabs/src/tabs/tabs.scss +0 -39
- package/themes/macos/tabs/src/tabs-item/tabs-item.scss +0 -19
- package/themes/macos/tags/index.scss +0 -2
- package/themes/macos/tags/src/tags/tags.scss +0 -1
- package/themes/macos/tags/src/tags-item/tags-item.scss +0 -32
- package/themes/macos/textarea/index.scss +0 -1
- package/themes/macos/textarea/src/textarea/textarea.scss +0 -31
- package/themes/macos/timepicker/index.scss +0 -2
- package/themes/macos/timepicker/src/timepicker/timepicker.scss +0 -51
- package/themes/macos/timepicker/src/timepicker-panel/timepicker-panel.scss +0 -28
- package/themes/macos/transfer/index.scss +0 -1
- package/themes/macos/transfer/src/transfer/transfer.scss +0 -18
- package/themes/macos/virtualscroller/index.scss +0 -1
- package/themes/macos/virtualscroller/src/virtualscroller/virtualscroller.scss +0 -1
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
@use
|
|
2
|
-
@import "../../../root/vars";
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
3
2
|
|
|
4
3
|
.n-paginator {
|
|
5
4
|
display: flex;
|
|
@@ -8,6 +7,11 @@
|
|
|
8
7
|
justify-content: stretch;
|
|
9
8
|
}
|
|
10
9
|
|
|
10
|
+
|
|
11
|
+
.n-paginator .n-button {
|
|
12
|
+
min-width: size('base-hgt');
|
|
13
|
+
}
|
|
14
|
+
|
|
11
15
|
.n-paginator__spacer {
|
|
12
16
|
flex: 1 1 auto;
|
|
13
17
|
}
|
|
@@ -35,47 +39,38 @@
|
|
|
35
39
|
align-items: center;
|
|
36
40
|
}
|
|
37
41
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
.n-paginator--#{$suffix} .n-paginator__pages > button {
|
|
70
|
-
margin: 0 $-paginator-size * $-paginator-ratio * 0.2;
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
.n-paginator--#{$suffix} .n-paginator__pages > button:first-child {
|
|
74
|
-
margin-left: 0;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
.n-paginator--#{$suffix} .n-paginator__pages > button:last-child {
|
|
78
|
-
margin-right: 0;
|
|
79
|
-
}
|
|
42
|
+
.n-paginator__count {
|
|
43
|
+
font-size: size('base-fnt');
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.n-paginator > div {
|
|
47
|
+
padding: 0 size('base-pad', 'calc($ * 0.5)');
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
.n-paginator > div:first-child {
|
|
51
|
+
padding-left: 0;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
.n-paginator > div:last-child {
|
|
55
|
+
padding-right: 0;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.n-paginator__limit .n-select {
|
|
59
|
+
width: size('base-hgt-inline', 'calc($ * 8)');
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.n-paginator__goto .n-select {
|
|
63
|
+
width: size('base-hgt-inline', 'calc($ * 5)');
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.n-paginator__pages > button:not(:last-child) {
|
|
67
|
+
margin-right: size('base-pad', 'calc($ * 0.4)');
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.n-paginator__pages > button:first-child {
|
|
71
|
+
margin-left: 0;
|
|
72
|
+
}
|
|
80
73
|
|
|
74
|
+
.n-paginator__pages > button:last-child {
|
|
75
|
+
margin-right: 0;
|
|
81
76
|
}
|
package/src/popover/index.js
CHANGED
|
@@ -2,8 +2,25 @@ import Popover from "./src/popover/popover.jsx";
|
|
|
2
2
|
import PopoverGroup from "./src/popover-group/popover-group.jsx";
|
|
3
3
|
import PopoverOption from "./src/popover-option/popover-option.jsx";
|
|
4
4
|
|
|
5
|
+
import PopoverElement from "./src/popover/popover-element.mjs";
|
|
6
|
+
import PopoverHandler from "./src/popover/popover-handler.mjs";
|
|
7
|
+
import PopoverHelper from "./src/popover/popover-helper.mjs";
|
|
8
|
+
|
|
5
9
|
export default function (App) {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
10
|
+
|
|
11
|
+
let directives = [
|
|
12
|
+
PopoverElement, PopoverHandler, PopoverHelper
|
|
13
|
+
];
|
|
14
|
+
|
|
15
|
+
pi.Arr.each(directives, (glob) => {
|
|
16
|
+
App.config.globalProperties[glob.alias] = window[glob.alias] = glob;
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
let components = [
|
|
20
|
+
Popover, PopoverGroup, PopoverOption
|
|
21
|
+
];
|
|
22
|
+
|
|
23
|
+
pi.Arr.each(components, (comp) => {
|
|
24
|
+
App.component(comp.name, comp);
|
|
25
|
+
});
|
|
9
26
|
}
|
package/src/popover/index.scss
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
@
|
|
1
|
+
@forward "./src/popover/popover";
|
|
@@ -0,0 +1,578 @@
|
|
|
1
|
+
import { Any, Dom, Arr, Obj, UUID } from "@kizmann/pico-js";
|
|
2
|
+
import { PopoverHelper } from "./popover-helper.mjs";
|
|
3
|
+
import PopoverHandler from "./popover-handler.mjs";
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
export class PopoverElement
|
|
7
|
+
{
|
|
8
|
+
static alias = 'Popover';
|
|
9
|
+
|
|
10
|
+
visible = false;
|
|
11
|
+
|
|
12
|
+
options = {
|
|
13
|
+
parent: null,
|
|
14
|
+
target: null,
|
|
15
|
+
listen: false,
|
|
16
|
+
trigger: 'hover',
|
|
17
|
+
toggle: false,
|
|
18
|
+
position: 'bottom-center',
|
|
19
|
+
width: -1,
|
|
20
|
+
scrollClose: true,
|
|
21
|
+
multiClose: true,
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
client = {
|
|
25
|
+
x: 0, y: 0
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
events = {};
|
|
29
|
+
|
|
30
|
+
constructor(el, options = {})
|
|
31
|
+
{
|
|
32
|
+
this.options = Obj.assign(this.options, options, {
|
|
33
|
+
el
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
if ( ! options.uid ) {
|
|
37
|
+
options.uid = UUID()
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
this.bind();
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
bind()
|
|
44
|
+
{
|
|
45
|
+
let { uid, trigger } = this.options;
|
|
46
|
+
|
|
47
|
+
if ( trigger === 'hover' ) {
|
|
48
|
+
Dom.find(document.body).on(PopoverHelper.getHoverEvent(),
|
|
49
|
+
Any.framerate((e) => this.onHover(e), 30), { uid });
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
if ( trigger === 'click' ) {
|
|
53
|
+
Dom.find(document.body).on(PopoverHelper.getClickEvent(),
|
|
54
|
+
Any.throttle((e) => this.onClick(e), 30), { uid });
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if ( trigger === 'context' ) {
|
|
58
|
+
Dom.find(document.body).on(PopoverHelper.getContextEvent(),
|
|
59
|
+
Any.throttle((e) => this.onContext(e), 30), { uid });
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
unbind()
|
|
64
|
+
{
|
|
65
|
+
let { uid, trigger } = this.options;
|
|
66
|
+
|
|
67
|
+
if ( trigger === 'hover' ) {
|
|
68
|
+
Dom.find(document).off(PopoverHelper.getHoverEvent(),
|
|
69
|
+
null, { uid });
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
if ( trigger === 'click' ) {
|
|
73
|
+
Dom.find(document).off(PopoverHelper.getClickEvent(),
|
|
74
|
+
null, { uid });
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
if ( trigger === 'context' ) {
|
|
78
|
+
Dom.find(document).off(PopoverHelper.getContextEvent(),
|
|
79
|
+
null, { uid });
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
parents()
|
|
84
|
+
{
|
|
85
|
+
let { parent } = this.options;
|
|
86
|
+
|
|
87
|
+
if ( Any.isEmpty(parent) ) {
|
|
88
|
+
return [];
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
return Arr.merge(parent.parents(), [
|
|
92
|
+
parent.options.uid
|
|
93
|
+
]);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
currentChange(parents)
|
|
97
|
+
{
|
|
98
|
+
let { uid, multiClose } = this.options;
|
|
99
|
+
|
|
100
|
+
if ( ! multiClose || Arr.has(parents, uid) ) {
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
this.hide('multi')
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
on(event, cb)
|
|
108
|
+
{
|
|
109
|
+
this.events[event] = cb;
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
off(event)
|
|
113
|
+
{
|
|
114
|
+
delete this.events[event];
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
show(event = 'default')
|
|
118
|
+
{
|
|
119
|
+
if ( this.interval ) {
|
|
120
|
+
clearInterval(this.interval);
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
this.interval = setTimeout(() => {
|
|
124
|
+
this.showQueue(event);
|
|
125
|
+
}, 100);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
showQueue(event = 'default')
|
|
129
|
+
{
|
|
130
|
+
if ( this.visible ) {
|
|
131
|
+
return this.updatePosition();
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
let { el } = this.options;
|
|
135
|
+
|
|
136
|
+
Dom.find(el).attr('data-ready', 'true');
|
|
137
|
+
|
|
138
|
+
if ( Any.isFunction(this.events['open']) ) {
|
|
139
|
+
this.events['open'].apply({}, [event]);
|
|
140
|
+
}
|
|
141
|
+
|
|
142
|
+
requestAnimationFrame(() => {
|
|
143
|
+
this.updatePosition();
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
requestAnimationFrame(() => {
|
|
147
|
+
this.bindResizeObserver();
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
this.visible = true;
|
|
151
|
+
|
|
152
|
+
PopoverHandler.setCurrent(this);
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
hide(event = 'default')
|
|
156
|
+
{
|
|
157
|
+
if ( this.interval ) {
|
|
158
|
+
clearInterval(this.interval);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
this.interval = setTimeout(() => {
|
|
162
|
+
this.hideQueue(event);
|
|
163
|
+
}, 50);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
hideQueue(event = 'default')
|
|
167
|
+
{
|
|
168
|
+
let { el } = this.options;
|
|
169
|
+
|
|
170
|
+
Dom.find(el).attr('data-ready', null);
|
|
171
|
+
|
|
172
|
+
if ( Any.isFunction(this.events['close']) ) {
|
|
173
|
+
this.events['close'].apply({}, [event]);
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
this.unbindResizeObserver();
|
|
177
|
+
|
|
178
|
+
this.visible = false;
|
|
179
|
+
|
|
180
|
+
PopoverHandler.unsetCurrent(this);
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
onHover(event)
|
|
184
|
+
{
|
|
185
|
+
let { el, target } = this.options;
|
|
186
|
+
|
|
187
|
+
let tgt = Dom.find(event.target).closest(target),
|
|
188
|
+
src = Dom.find(event.target).closest(el);
|
|
189
|
+
|
|
190
|
+
let result = (!! tgt || !! src);
|
|
191
|
+
|
|
192
|
+
if ( this.visible === result ) {
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
if ( ! result ) {
|
|
197
|
+
return this.hideQueue('hover');
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
this.showQueue('hover');
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
onClick(event)
|
|
204
|
+
{
|
|
205
|
+
let { el, target } = this.options;
|
|
206
|
+
|
|
207
|
+
let keyCode = event.which === 1 || event.which === 0;
|
|
208
|
+
|
|
209
|
+
if ( ! keyCode ) {
|
|
210
|
+
return;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
let tgt = Dom.find(event.target).closest(target),
|
|
214
|
+
src = Dom.find(event.target).closest(el);
|
|
215
|
+
|
|
216
|
+
if ( this.visible ) {
|
|
217
|
+
return this.options.toggle && tgt && this.hideQueue('click');
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
let result = (!! tgt || !! src);
|
|
221
|
+
|
|
222
|
+
if ( this.visible === result ) {
|
|
223
|
+
return;
|
|
224
|
+
}
|
|
225
|
+
|
|
226
|
+
this.showQueue('click');
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
onContext(event)
|
|
230
|
+
{
|
|
231
|
+
let { el, target } = this.options;
|
|
232
|
+
|
|
233
|
+
let keyCode = event.which === 3;
|
|
234
|
+
|
|
235
|
+
if ( !keyCode ) {
|
|
236
|
+
return;
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
let tgt = Dom.find(event.target).closest(target),
|
|
240
|
+
src = Dom.find(event.target).closest(el);
|
|
241
|
+
|
|
242
|
+
this.client.x = event.clientX;
|
|
243
|
+
this.client.y = event.clientY;
|
|
244
|
+
|
|
245
|
+
let result = (!! tgt || !! src);
|
|
246
|
+
|
|
247
|
+
if ( result ) {
|
|
248
|
+
event.preventDefault();
|
|
249
|
+
event.stopPropagation();
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
if ( ! result ) {
|
|
253
|
+
return;
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
this.showQueue('context');
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
bindResizeObserver()
|
|
260
|
+
{
|
|
261
|
+
let { el } = this.options;
|
|
262
|
+
|
|
263
|
+
this.observer = new ResizeObserver(() => {
|
|
264
|
+
this.updatePosition();
|
|
265
|
+
});
|
|
266
|
+
|
|
267
|
+
this.observer.observe(el);
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
unbindResizeObserver()
|
|
271
|
+
{
|
|
272
|
+
if ( this.observer ) {
|
|
273
|
+
this.observer.disconnect();
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
updatePosition()
|
|
278
|
+
{
|
|
279
|
+
let { el, target, width } = this.options;
|
|
280
|
+
|
|
281
|
+
let [offset, scroll] = [
|
|
282
|
+
this.getTargetOffset(), Dom.find(document.body).scroll()
|
|
283
|
+
];
|
|
284
|
+
|
|
285
|
+
Dom.find(el).attr('data-position', offset.position);
|
|
286
|
+
|
|
287
|
+
if ( ! window.zIndex ) {
|
|
288
|
+
window.zIndex = 9000;
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
let style = Obj.assign(Dom.find(el).css(), {
|
|
292
|
+
'z-index': window.zIndex++,
|
|
293
|
+
'top': Math.round(offset.y + scroll.top) + 'px',
|
|
294
|
+
'left': Math.round(offset.x + scroll.left) + 'px',
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
let rect = target.getBoundingClientRect();
|
|
298
|
+
|
|
299
|
+
if ( width === -1 ) {
|
|
300
|
+
style.width = Math.round(rect.width) + 'px';
|
|
301
|
+
}
|
|
302
|
+
|
|
303
|
+
Dom.find(el).css(style);
|
|
304
|
+
|
|
305
|
+
if ( ! style['--n-parent-width'] ) {
|
|
306
|
+
style['--n-parent-width'] = `${rect.width}px`;
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
if ( ! style['--n-node-width'] && Dom.find(el).innerWidth() ) {
|
|
310
|
+
style['--n-node-width'] = `${el.clientWidth}px`;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
if ( ! style['--n-parent-height'] ) {
|
|
314
|
+
style['--n-parent-height'] = `${rect.height}px`;
|
|
315
|
+
}
|
|
316
|
+
|
|
317
|
+
if ( ! style['--n-node-height'] && Dom.find(el).innerHeight() ) {
|
|
318
|
+
style['--n-node-height'] = `${el.clientHeight}px`;
|
|
319
|
+
}
|
|
320
|
+
|
|
321
|
+
Dom.find(el).css(style);
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
getTargetHorizontal(position, fallback = null)
|
|
325
|
+
{
|
|
326
|
+
let { el, target, trigger, width, scrollClose } = this.options;
|
|
327
|
+
|
|
328
|
+
let targetRect = target.getBoundingClientRect();
|
|
329
|
+
|
|
330
|
+
if ( trigger === 'context' ) {
|
|
331
|
+
targetRect = {
|
|
332
|
+
top: this.client.y, left: this.client.x, width: 2, height: 2
|
|
333
|
+
};
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
let windowRect = el.getBoundingClientRect();
|
|
337
|
+
|
|
338
|
+
if ( width === -1 ) {
|
|
339
|
+
windowRect.width = targetRect.width;
|
|
340
|
+
}
|
|
341
|
+
|
|
342
|
+
let posY = {
|
|
343
|
+
|
|
344
|
+
// Set above the tagret element
|
|
345
|
+
start: targetRect.top - windowRect.height,
|
|
346
|
+
|
|
347
|
+
// Set at bottom of target element
|
|
348
|
+
end: targetRect.top + targetRect.height,
|
|
349
|
+
|
|
350
|
+
};
|
|
351
|
+
|
|
352
|
+
let posX = {
|
|
353
|
+
|
|
354
|
+
// Set on the left of target element
|
|
355
|
+
start: targetRect.left,
|
|
356
|
+
|
|
357
|
+
// Set into the center of the target element
|
|
358
|
+
center: targetRect.left + (targetRect.width * 0.5) -
|
|
359
|
+
(windowRect.width * 0.5),
|
|
360
|
+
|
|
361
|
+
// Set on the right of the target element
|
|
362
|
+
end: targetRect.left + targetRect.width -
|
|
363
|
+
windowRect.width,
|
|
364
|
+
|
|
365
|
+
};
|
|
366
|
+
|
|
367
|
+
let offset = { x: 0, y: 0 };
|
|
368
|
+
|
|
369
|
+
if ( position === 'top-start' ) {
|
|
370
|
+
offset = { x: posX.start, y: posY.start };
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
if ( position === 'top-center' ) {
|
|
374
|
+
offset = { x: posX.center, y: posY.start };
|
|
375
|
+
}
|
|
376
|
+
|
|
377
|
+
if ( position === 'top-end' ) {
|
|
378
|
+
offset = { x: posX.end, y: posY.start };
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
if ( position === 'bottom-start' ) {
|
|
382
|
+
offset = { x: posX.start, y: posY.end };
|
|
383
|
+
}
|
|
384
|
+
|
|
385
|
+
if ( position === 'bottom-center' ) {
|
|
386
|
+
offset = { x: posX.center, y: posY.end };
|
|
387
|
+
}
|
|
388
|
+
|
|
389
|
+
if ( position === 'bottom-end' ) {
|
|
390
|
+
offset = { x: posX.end, y: posY.end };
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
let inverse = position;
|
|
394
|
+
|
|
395
|
+
if ( position.match(/^(top)\-/) ) {
|
|
396
|
+
inverse = inverse.replace(/^(top)\-/, 'bottom-');
|
|
397
|
+
}
|
|
398
|
+
|
|
399
|
+
if ( position.match(/^(bottom)\-/) ) {
|
|
400
|
+
inverse = inverse.replace(/^(bottom)\-/, 'top-');
|
|
401
|
+
}
|
|
402
|
+
|
|
403
|
+
let broken = offset.y + windowRect.height >
|
|
404
|
+
window.innerHeight || offset.y < 0;
|
|
405
|
+
|
|
406
|
+
if ( scrollClose && broken && ! fallback ) {
|
|
407
|
+
return this.getTargetHorizontal(inverse, offset);
|
|
408
|
+
}
|
|
409
|
+
|
|
410
|
+
if ( fallback && broken ) {
|
|
411
|
+
offset = fallback;
|
|
412
|
+
}
|
|
413
|
+
|
|
414
|
+
if ( offset.y < 0 ) {
|
|
415
|
+
offset.y = 0;
|
|
416
|
+
}
|
|
417
|
+
|
|
418
|
+
if ( offset.y + windowRect.height > window.innerHeight ) {
|
|
419
|
+
offset.y = window.innerHeight - windowRect.height;
|
|
420
|
+
}
|
|
421
|
+
|
|
422
|
+
if ( offset.x < 0 ) {
|
|
423
|
+
offset.x = 0;
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
if ( offset.x + windowRect.width > window.innerWidth ) {
|
|
427
|
+
offset.x = window.innerWidth - windowRect.width -
|
|
428
|
+
(window.innerWidth - document.body.clientWidth);
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
if ( broken ) {
|
|
432
|
+
position = 'auto';
|
|
433
|
+
}
|
|
434
|
+
|
|
435
|
+
return Obj.assign(offset, { position });
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
getTargetVertical(position, fallback = null)
|
|
439
|
+
{
|
|
440
|
+
let { el, target, trigger, width, scrollClose } = this.options;
|
|
441
|
+
|
|
442
|
+
let targetRect = target.getBoundingClientRect();
|
|
443
|
+
|
|
444
|
+
if ( trigger === 'context' ) {
|
|
445
|
+
targetRect = {
|
|
446
|
+
top: this.client.y, left: this.client.x, width: 2, height: 2
|
|
447
|
+
};
|
|
448
|
+
}
|
|
449
|
+
|
|
450
|
+
let windowRect = el.getBoundingClientRect();
|
|
451
|
+
|
|
452
|
+
if ( width === -1 ) {
|
|
453
|
+
windowRect.width = targetRect.width;
|
|
454
|
+
}
|
|
455
|
+
|
|
456
|
+
let posY = {
|
|
457
|
+
|
|
458
|
+
// Set at top edge of the target element
|
|
459
|
+
start: targetRect.top,
|
|
460
|
+
|
|
461
|
+
// Set at the middle of the target element
|
|
462
|
+
center: targetRect.top + (targetRect.height * 0.5) -
|
|
463
|
+
(windowRect.height * 0.5),
|
|
464
|
+
|
|
465
|
+
// Ste at the bottom of the target elemnent
|
|
466
|
+
end: targetRect.top + targetRect.height -
|
|
467
|
+
windowRect.height,
|
|
468
|
+
|
|
469
|
+
};
|
|
470
|
+
|
|
471
|
+
let posX = {
|
|
472
|
+
|
|
473
|
+
// Set to the left of the target element
|
|
474
|
+
start: targetRect.left - windowRect.width,
|
|
475
|
+
|
|
476
|
+
// Set to the right of the target element
|
|
477
|
+
end: targetRect.left + targetRect.width,
|
|
478
|
+
|
|
479
|
+
};
|
|
480
|
+
|
|
481
|
+
let offset = { x: 0, y: 0 };
|
|
482
|
+
|
|
483
|
+
if ( position === 'left-start' ) {
|
|
484
|
+
offset = { x: posX.start, y: posY.start };
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
if ( position === 'left-center' ) {
|
|
488
|
+
offset = { x: posX.start, y: posY.center };
|
|
489
|
+
}
|
|
490
|
+
|
|
491
|
+
if ( position === 'left-end' ) {
|
|
492
|
+
offset = { x: posX.start, y: posY.end };
|
|
493
|
+
}
|
|
494
|
+
|
|
495
|
+
if ( position === 'right-start' ) {
|
|
496
|
+
offset = { x: posX.end, y: posY.start };
|
|
497
|
+
}
|
|
498
|
+
|
|
499
|
+
if ( position === 'right-center' ) {
|
|
500
|
+
offset = { x: posX.end, y: posY.center };
|
|
501
|
+
}
|
|
502
|
+
|
|
503
|
+
if ( position === 'right-end' ) {
|
|
504
|
+
offset = { x: posX.end, y: posY.end };
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
let inverse = position;
|
|
508
|
+
|
|
509
|
+
if ( position.match(/^(left)\-/) ) {
|
|
510
|
+
inverse = inverse.replace(/^(left)\-/, 'right-');
|
|
511
|
+
}
|
|
512
|
+
|
|
513
|
+
if ( position.match(/^(right)\-/) ) {
|
|
514
|
+
inverse = inverse.replace(/^(right)\-/, 'left-');
|
|
515
|
+
}
|
|
516
|
+
|
|
517
|
+
let broken = offset.x + windowRect.width >
|
|
518
|
+
window.innerWidth || offset.x < 0;
|
|
519
|
+
|
|
520
|
+
if ( scrollClose && broken && ! fallback ) {
|
|
521
|
+
return this.getTargetVertical(inverse, offset);
|
|
522
|
+
}
|
|
523
|
+
|
|
524
|
+
if ( fallback && broken ) {
|
|
525
|
+
offset = fallback;
|
|
526
|
+
}
|
|
527
|
+
|
|
528
|
+
if ( offset.y < 0 ) {
|
|
529
|
+
offset.y = 0;
|
|
530
|
+
}
|
|
531
|
+
|
|
532
|
+
if ( offset.y + windowRect.height > window.innerHeight ) {
|
|
533
|
+
offset.y = window.innerHeight - windowRect.height;
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
if ( offset.x < 0 ) {
|
|
537
|
+
offset.x = 0;
|
|
538
|
+
}
|
|
539
|
+
|
|
540
|
+
if ( offset.x + windowRect.width > window.innerWidth ) {
|
|
541
|
+
offset.x = window.innerWidth - windowRect.width -
|
|
542
|
+
(window.innerWidth - document.body.clientWidth);
|
|
543
|
+
}
|
|
544
|
+
|
|
545
|
+
if ( broken ) {
|
|
546
|
+
position = 'auto';
|
|
547
|
+
}
|
|
548
|
+
|
|
549
|
+
return Obj.assign(offset, { position });
|
|
550
|
+
}
|
|
551
|
+
|
|
552
|
+
getTargetOffset()
|
|
553
|
+
{
|
|
554
|
+
let { el, width, position } = this.options;
|
|
555
|
+
|
|
556
|
+
|
|
557
|
+
if ( width > 0 ) {
|
|
558
|
+
Dom.find(el).css({ width: `${width}px`});
|
|
559
|
+
}
|
|
560
|
+
|
|
561
|
+
if ( position.match(/^(top|bottom)\-/) ) {
|
|
562
|
+
return this.getTargetHorizontal(position);
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
if ( position.match(/^(left|right)\-/) ) {
|
|
566
|
+
return this.getTargetVertical(position);
|
|
567
|
+
}
|
|
568
|
+
|
|
569
|
+
console.error(`Popover position "${position}" does not exist`);
|
|
570
|
+
}
|
|
571
|
+
|
|
572
|
+
}
|
|
573
|
+
|
|
574
|
+
if ( ! window[PopoverElement.alias] ) {
|
|
575
|
+
window[PopoverElement.alias] = PopoverElement;
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
export default PopoverElement;
|