@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,14 +1,148 @@
|
|
|
1
|
-
@use
|
|
2
|
-
@import "../../../root/vars";
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
3
2
|
|
|
4
3
|
.n-popover {
|
|
5
4
|
position: absolute;
|
|
6
5
|
display: inline-flex;
|
|
7
6
|
flex-direction: column;
|
|
8
|
-
transition: opacity 0.1s
|
|
7
|
+
transition: opacity 0.1s;
|
|
8
|
+
font-size: size('base-fnt');
|
|
9
9
|
}
|
|
10
10
|
|
|
11
|
-
.n-popover:
|
|
11
|
+
.n-popover:before,
|
|
12
|
+
.n-popover:after {
|
|
13
|
+
content: '\00a0';
|
|
14
|
+
position: absolute;
|
|
15
|
+
display: none;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.n-popover:before {
|
|
19
|
+
z-index: 220;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
.n-popover:after {
|
|
23
|
+
z-index: 210;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.n-popover:not([data-position="auto"]):before,
|
|
27
|
+
.n-popover:not([data-position="auto"]):after {
|
|
28
|
+
display: block;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.n-popover[data-position^="top-"]:before,
|
|
32
|
+
.n-popover[data-position^="top-"]:after,
|
|
33
|
+
.n-popover[data-position^="bottom-"]:before,
|
|
34
|
+
.n-popover[data-position^="bottom-"]:after {
|
|
35
|
+
left: 0;
|
|
36
|
+
width: 16px;
|
|
37
|
+
height: 6px;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
.n-popover[data-position^="top-"]:before,
|
|
41
|
+
.n-popover[data-position^="top-"]:after,
|
|
42
|
+
.n-popover[data-position^="bottom-"]:before,
|
|
43
|
+
.n-popover[data-position^="bottom-"]:after {
|
|
44
|
+
width: var(--n-parent-width, 16px);
|
|
45
|
+
max-width: var(--n-node-width, 100%);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
.n-popover[data-position="top-start"]:before,
|
|
49
|
+
.n-popover[data-position="top-start"]:after,
|
|
50
|
+
.n-popover[data-position="bottom-start"]:before,
|
|
51
|
+
.n-popover[data-position="bottom-start"]:after {
|
|
52
|
+
left: 0;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
.n-popover[data-position="top-end"]:before,
|
|
56
|
+
.n-popover[data-position="top-end"]:after,
|
|
57
|
+
.n-popover[data-position="bottom-end"]:before,
|
|
58
|
+
.n-popover[data-position="bottom-end"]:after {
|
|
59
|
+
right: 0;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.n-popover[data-position="top-center"]:before,
|
|
63
|
+
.n-popover[data-position="top-center"]:after,
|
|
64
|
+
.n-popover[data-position="bottom-center"]:before,
|
|
65
|
+
.n-popover[data-position="bottom-center"]:after {
|
|
66
|
+
left: 50%;
|
|
67
|
+
transform: translateX(-50%);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
.n-popover[data-position^="top-"] {
|
|
71
|
+
padding-bottom: 6px;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.n-popover[data-position^="bottom-"] {
|
|
75
|
+
padding-top: 6px;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
.n-popover[data-position^="top-"]:before,
|
|
79
|
+
.n-popover[data-position^="top-"]:after {
|
|
80
|
+
bottom: 0;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
.n-popover[data-position^="bottom-"]:before,
|
|
84
|
+
.n-popover[data-position^="bottom-"]:after {
|
|
85
|
+
top: 0;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
.n-popover[data-position^="left-"]:before,
|
|
89
|
+
.n-popover[data-position^="left-"]:after,
|
|
90
|
+
.n-popover[data-position^="right-"]:before,
|
|
91
|
+
.n-popover[data-position^="right-"]:after {
|
|
92
|
+
width: 6px;
|
|
93
|
+
height: 16px;
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
.n-popover[data-position^="left-"]:before,
|
|
97
|
+
.n-popover[data-position^="left-"]:after,
|
|
98
|
+
.n-popover[data-position^="right-"]:before,
|
|
99
|
+
.n-popover[data-position^="right-"]:after {
|
|
100
|
+
height: var(--n-parent-height, 16px);
|
|
101
|
+
max-height: var(--n-node-height, 100%);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.n-popover[data-position="left-start"]:before,
|
|
105
|
+
.n-popover[data-position="left-start"]:after,
|
|
106
|
+
.n-popover[data-position="right-start"]:before,
|
|
107
|
+
.n-popover[data-position="right-start"]:after {
|
|
108
|
+
top: 0;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
.n-popover[data-position="left-end"]:before,
|
|
112
|
+
.n-popover[data-position="left-end"]:after,
|
|
113
|
+
.n-popover[data-position="right-end"]:before,
|
|
114
|
+
.n-popover[data-position="right-end"]:after {
|
|
115
|
+
bottom: 0;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
.n-popover[data-position="left-center"]:before,
|
|
119
|
+
.n-popover[data-position="left-center"]:after,
|
|
120
|
+
.n-popover[data-position="right-center"]:before,
|
|
121
|
+
.n-popover[data-position="right-center"]:after {
|
|
122
|
+
top: 50%;
|
|
123
|
+
transform: translateY(-50%);
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
.n-popover[data-position^="left-"] {
|
|
127
|
+
padding-right: 6px;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
.n-popover[data-position^="right-"] {
|
|
131
|
+
padding-left: 6px;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
.n-popover[data-position^="left-"]:before,
|
|
135
|
+
.n-popover[data-position^="left-"]:after {
|
|
136
|
+
right: 0;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
.n-popover[data-position^="right-"]:before,
|
|
140
|
+
.n-popover[data-position^="right-"]:after {
|
|
141
|
+
left: 0;
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
|
|
145
|
+
.n-popover:not([data-ready]) {
|
|
12
146
|
opacity: 0;
|
|
13
147
|
}
|
|
14
148
|
|
|
@@ -22,6 +156,7 @@
|
|
|
22
156
|
|
|
23
157
|
.n-popover__frame {
|
|
24
158
|
overflow: hidden;
|
|
159
|
+
border-radius: size('base-rad');
|
|
25
160
|
}
|
|
26
161
|
|
|
27
162
|
.n-popover__header {
|
|
@@ -43,14 +178,18 @@
|
|
|
43
178
|
flex-direction: row;
|
|
44
179
|
align-items: center;
|
|
45
180
|
justify-content: stretch;
|
|
46
|
-
text-decoration: none
|
|
181
|
+
text-decoration: none;
|
|
182
|
+
padding: size('base-pad', 'calc($ - 2px)') size('base-pad');
|
|
183
|
+
font-size: size('base-fnt');
|
|
47
184
|
}
|
|
48
185
|
|
|
49
186
|
.n-popover-group {
|
|
187
|
+
font-size: 0.8em;
|
|
50
188
|
font-weight: bold;
|
|
51
189
|
}
|
|
52
190
|
|
|
53
191
|
.n-popover-option {
|
|
192
|
+
font-size: 1em;
|
|
54
193
|
width: 100%;
|
|
55
194
|
}
|
|
56
195
|
|
|
@@ -88,7 +227,9 @@
|
|
|
88
227
|
|
|
89
228
|
.n-popover-option .n-icon {
|
|
90
229
|
flex: 0 0 auto;
|
|
230
|
+
font-size: size('base-fnt-icon');
|
|
91
231
|
text-align: center;
|
|
232
|
+
width: size('base-pad', 'calc($ * 2)');
|
|
92
233
|
}
|
|
93
234
|
|
|
94
235
|
.n-popover-option .n-icon--before {
|
|
@@ -99,78 +240,45 @@
|
|
|
99
240
|
order: 3;
|
|
100
241
|
}
|
|
101
242
|
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
.n-popover-option.n-popover-option--#{$suffix} {
|
|
137
|
-
padding: $-popover-padding * 0.6 $-popover-padding * 1.2;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-group,
|
|
141
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-option {
|
|
142
|
-
width: calc(100% + #{$-popover-padding * 2.4});
|
|
143
|
-
margin: 0 -#{$-popover-padding * 1.2};
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-group:first-child,
|
|
147
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-option:first-child {
|
|
148
|
-
margin-top: -#{$-popover-padding};
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-group:last-child,
|
|
152
|
-
.n-popover--#{$suffix} .n-popover__body .n-popover-option:last-child {
|
|
153
|
-
margin-bottom: -#{$-popover-padding};
|
|
154
|
-
}
|
|
155
|
-
|
|
156
|
-
.n-popover-option--#{$suffix} .n-image {
|
|
157
|
-
width: $-popover-font + 10;
|
|
158
|
-
height: $-popover-font + 10;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
.n-popover-option--#{$suffix} .n-icon {
|
|
162
|
-
width: $-popover-font;
|
|
163
|
-
font-size: $-popover-font - 4;
|
|
164
|
-
}
|
|
165
|
-
|
|
166
|
-
.n-popover-option--#{$suffix} .n-image--before,
|
|
167
|
-
.n-popover-option--#{$suffix} .n-icon--before {
|
|
168
|
-
margin-right: $-popover-padding;
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
.n-popover-option--#{$suffix} .n-image--after,
|
|
172
|
-
.n-popover-option--#{$suffix} .n-icon--after {
|
|
173
|
-
margin-left: $-popover-padding;
|
|
174
|
-
}
|
|
243
|
+
.n-popover .n-popover__header {
|
|
244
|
+
padding: size('base-pad-vertical') size('base-pad');
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
.n-popover .n-popover__body {
|
|
248
|
+
padding: size('base-pad-vertical') size('base-pad');
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
.n-popover .n-popover__footer {
|
|
252
|
+
padding: size('base-pad-vertical') size('base-pad');
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
.n-popover .n-popover__body .n-popover-group:first-child,
|
|
256
|
+
.n-popover .n-popover__body .n-popover-option:first-child {
|
|
257
|
+
margin-top: size('base-pad-vertical', 'calc($ * -1)');
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
.n-popover .n-popover__body .n-popover-group:last-child,
|
|
261
|
+
.n-popover .n-popover__body .n-popover-option:last-child {
|
|
262
|
+
margin-bottom: size('base-pad-vertical', 'calc($ * -1)');
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
.n-popover .n-popover__body .n-popover-group,
|
|
266
|
+
.n-popover .n-popover__body .n-popover-option {
|
|
267
|
+
width: size('base-pad', 'calc(100% + ($ * 2))');
|
|
268
|
+
margin: 0 size('base-pad', 'calc($ * -1)');
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
.n-popover-option .n-image {
|
|
272
|
+
width: size('base-pad', 'calc($ * 2)');
|
|
273
|
+
height: size('base-pad', 'calc($ * 2)');
|
|
274
|
+
}
|
|
175
275
|
|
|
276
|
+
.n-popover-option .n-image--before,
|
|
277
|
+
.n-popover-option .n-icon--before {
|
|
278
|
+
margin-right: size('base-pad');
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
.n-popover-option .n-image--after,
|
|
282
|
+
.n-popover-option .n-icon--after {
|
|
283
|
+
margin-left: size('base-pad');
|
|
176
284
|
}
|
package/src/preview/index.js
CHANGED
|
@@ -2,11 +2,53 @@ import Preview from "./src/preview/preview.jsx";
|
|
|
2
2
|
import PreviewPlain from "./src/preview-plain/preview-plain.jsx";
|
|
3
3
|
import PreviewImage from "./src/preview-image/preview-image.jsx";
|
|
4
4
|
import PreviewVideo from "./src/preview-video/preview-video.jsx";
|
|
5
|
+
import PreviewModal from "./src/preview-modal/preview-modal.jsx";
|
|
6
|
+
|
|
7
|
+
import PreviewHelper from "./src/preview/preview-helper.mjs";
|
|
8
|
+
import PreviewHandler from "./src/preview/preview-handler.mjs";
|
|
9
|
+
|
|
10
|
+
window.DefaultPreviewMimes = {
|
|
11
|
+
image: [
|
|
12
|
+
'jpg', 'jpeg', 'gif', 'svg', 'png', 'bmp'
|
|
13
|
+
],
|
|
14
|
+
video: [
|
|
15
|
+
'mp4', 'webm', 'mov'
|
|
16
|
+
],
|
|
17
|
+
audio: [
|
|
18
|
+
'mp3', 'aac',
|
|
19
|
+
],
|
|
20
|
+
font: [
|
|
21
|
+
'woff', 'ttf', 'otf'
|
|
22
|
+
],
|
|
23
|
+
text: [
|
|
24
|
+
'csv', 'txt', 'html'
|
|
25
|
+
],
|
|
26
|
+
application: [
|
|
27
|
+
'pdf', 'doc', 'xls'
|
|
28
|
+
]
|
|
29
|
+
};
|
|
5
30
|
|
|
6
31
|
export default function (App) {
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
32
|
+
|
|
33
|
+
if ( ! window.PreviewMimes ) {
|
|
34
|
+
window.PreviewMimes = pi.Obj.assign(window.DefaultPreviewMimes, window.PreviewMimes);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
let directives = [
|
|
38
|
+
PreviewHelper, PreviewHandler
|
|
39
|
+
];
|
|
40
|
+
|
|
41
|
+
pi.Arr.each(directives, (glob) => {
|
|
42
|
+
App.config.globalProperties[glob.alias] = glob;
|
|
43
|
+
});
|
|
44
|
+
|
|
45
|
+
let components = [
|
|
46
|
+
Preview, PreviewModal, PreviewPlain, PreviewImage, PreviewVideo
|
|
47
|
+
];
|
|
48
|
+
|
|
49
|
+
pi.Arr.each(components, (comp) => {
|
|
50
|
+
App.component(comp.name, comp);
|
|
51
|
+
});
|
|
52
|
+
|
|
11
53
|
}
|
|
12
54
|
|
package/src/preview/index.scss
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
@
|
|
2
|
-
@
|
|
3
|
-
@
|
|
4
|
-
@
|
|
1
|
+
@forward "./src/preview/preview";
|
|
2
|
+
@forward "./src/preview-modal/preview-modal";
|
|
3
|
+
@forward "./src/preview-plain/preview-plain";
|
|
4
|
+
@forward "./src/preview-image/preview-image";
|
|
5
|
+
@forward "./src/preview-video/preview-video";
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
import { Any, Arr, Obj, Dom } from "@kizmann/pico-js";
|
|
2
|
+
|
|
3
|
+
window.PreviewGroups = {};
|
|
4
|
+
|
|
5
|
+
export class PreviewHandler
|
|
6
|
+
{
|
|
7
|
+
static alias = 'PreviewHandler';
|
|
8
|
+
|
|
9
|
+
static current = null;
|
|
10
|
+
|
|
11
|
+
static append(item)
|
|
12
|
+
{
|
|
13
|
+
if ( !window.PreviewGroups[item.group] ) {
|
|
14
|
+
window.PreviewGroups[item.group] = {};
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
window.PreviewGroups[item.group][item.uid] = item;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
static remove(item)
|
|
21
|
+
{
|
|
22
|
+
delete window.PreviewGroups[item.group][item.uid];
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
static get(group)
|
|
26
|
+
{
|
|
27
|
+
if ( !window.PreviewGroups[group] ) {
|
|
28
|
+
window.PreviewGroups[group] = {};
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
return Arr.sort(window.PreviewGroups[group], 'index');
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
static next()
|
|
35
|
+
{
|
|
36
|
+
if ( ! Any.isObject(this.current) ) {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
let items = this.get(this.current.group);
|
|
41
|
+
|
|
42
|
+
let index = Arr.findIndex(items, {
|
|
43
|
+
uid: this.current.uid
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
let next = Arr.first(items);
|
|
47
|
+
|
|
48
|
+
if ( items.length > index + 1 ) {
|
|
49
|
+
next = Arr.get(items, index + 1);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
return this.switch(next);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
static prev()
|
|
56
|
+
{
|
|
57
|
+
if ( ! Any.isObject(this.current) ) {
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
let items = this.get(this.current.group);
|
|
62
|
+
|
|
63
|
+
let index = Arr.findIndex(items, {
|
|
64
|
+
uid: this.current.uid
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
let prev = Arr.last(items);
|
|
68
|
+
|
|
69
|
+
if ( 0 <= index - 1 ) {
|
|
70
|
+
prev = Arr.get(items, index - 1);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return this.switch(prev);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
static create()
|
|
77
|
+
{
|
|
78
|
+
el = Dom.find('.n-preview-modal');
|
|
79
|
+
|
|
80
|
+
if ( el.length() ) {
|
|
81
|
+
return el;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
let classList = [
|
|
85
|
+
'n-preview-modal',
|
|
86
|
+
'n-preview-modal--md',
|
|
87
|
+
'n-preview-modal--primary',
|
|
88
|
+
'n-theme--dark'
|
|
89
|
+
];
|
|
90
|
+
|
|
91
|
+
let el = Dom.make('div', {
|
|
92
|
+
classList: classList.join(' ')
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
el.attr('data-preview', 'nano');
|
|
96
|
+
|
|
97
|
+
let close = Dom.make('div', {
|
|
98
|
+
classList: 'n-preview-modal__close',
|
|
99
|
+
innerHTML: `<i class="${nano.Icons.times}"></i>`
|
|
100
|
+
});
|
|
101
|
+
|
|
102
|
+
close.on('click', () => {
|
|
103
|
+
this.close()
|
|
104
|
+
});
|
|
105
|
+
|
|
106
|
+
close.appendTo(el);
|
|
107
|
+
|
|
108
|
+
let prev = Dom.make('div', {
|
|
109
|
+
classList: 'n-preview-modal__prev',
|
|
110
|
+
innerHTML: `<i class="${nano.Icons.angleLeft}"></i>`
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
prev.on('click', () => {
|
|
114
|
+
this.prev()
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
prev.appendTo(el);
|
|
118
|
+
|
|
119
|
+
let next = Dom.make('div', {
|
|
120
|
+
classList: 'n-preview-modal__next',
|
|
121
|
+
innerHTML: `<i class="${nano.Icons.angleRight}"></i>`
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
next.on('click', () => {
|
|
125
|
+
this.next()
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
next.appendTo(el);
|
|
129
|
+
|
|
130
|
+
el.appendTo(document.body);
|
|
131
|
+
|
|
132
|
+
return el;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
static open(item)
|
|
136
|
+
{
|
|
137
|
+
let el = this.create();
|
|
138
|
+
|
|
139
|
+
let keydownFn = (e) => {
|
|
140
|
+
|
|
141
|
+
if ( e.keyCode === 27 ) {
|
|
142
|
+
e.stopPropagation();
|
|
143
|
+
return this.close();
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
if ( e.keyCode === 37 ) {
|
|
147
|
+
e.stopPropagation();
|
|
148
|
+
return this.prev();
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
if ( e.keyCode === 39 ) {
|
|
152
|
+
e.stopPropagation();
|
|
153
|
+
return this.next();
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
Dom.find(window).on('keydown', keydownFn, {
|
|
159
|
+
uid: 'n-preview-modal'
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
this.switch(item);
|
|
163
|
+
|
|
164
|
+
if ( this.get(item.group).length > 1 ) {
|
|
165
|
+
el.addClass('n-multi');
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
el.addClass('n-ready');
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
static close()
|
|
172
|
+
{
|
|
173
|
+
let el = this.create();
|
|
174
|
+
|
|
175
|
+
Dom.find(window).off('keydown', null, {
|
|
176
|
+
uid: 'n-preview-modal'
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
this.switch(null);
|
|
180
|
+
|
|
181
|
+
el.removeClass(['n-ready', 'n-multi']);
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
static switch(item)
|
|
185
|
+
{
|
|
186
|
+
if ( Any.isObject(this.current) ) {
|
|
187
|
+
Obj.set(this.current, 'visible', false);
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
this.current = item;
|
|
191
|
+
|
|
192
|
+
if ( Any.isObject(this.current) ) {
|
|
193
|
+
Obj.set(this.current, 'visible', true);
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
return item;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
if ( ! window.PreviewHandler ) {
|
|
202
|
+
window.PreviewHandler = PreviewHandler;
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
export default PreviewHandler;
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Any, Arr, Dom, Obj } from "@kizmann/pico-js";
|
|
2
|
+
|
|
3
|
+
export class PreviewHelper
|
|
4
|
+
{
|
|
5
|
+
static alias = 'PreviewHelper';
|
|
6
|
+
|
|
7
|
+
static getExt(source, fallback = 'plain')
|
|
8
|
+
{
|
|
9
|
+
let match = source.match(/\.([^.?]+)(\?.*?)?$/);
|
|
10
|
+
|
|
11
|
+
if ( ! match ) {
|
|
12
|
+
return fallback;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
if ( Any.isEmpty(match[1]) ) {
|
|
16
|
+
return fallback;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
return match[1];
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
static getType(source, fallback = 'text')
|
|
23
|
+
{
|
|
24
|
+
let file = Obj.get(source, 'name', source);
|
|
25
|
+
|
|
26
|
+
if ( Any.isEmpty(file) ) {
|
|
27
|
+
return fallback;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
let extension = PreviewHelper.getExt(file);
|
|
31
|
+
|
|
32
|
+
if ( PreviewHelper.getYoutubeKey(file) ) {
|
|
33
|
+
return 'video';
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
if ( PreviewHelper.getVimeoKey(file) ) {
|
|
37
|
+
return 'video';
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
Obj.each(window.PreviewMimes, (exts, key) => {
|
|
41
|
+
if ( Arr.has(exts, extension) ) fallback = key;
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
return fallback;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
static getMime(source, fallback = 'text/plain')
|
|
48
|
+
{
|
|
49
|
+
let file = Obj.get(source, 'name', source);
|
|
50
|
+
|
|
51
|
+
if ( Any.isEmpty(file) ) {
|
|
52
|
+
return fallback;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
if ( PreviewHelper.getYoutubeKey(source) ) {
|
|
56
|
+
return 'video/youtube';
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
if ( PreviewHelper.getVimeoKey(source) ) {
|
|
60
|
+
return 'video/vimeo';
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
return PreviewHelper.getType(file) + '/' + PreviewHelper.getExt(file);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
static getVimeoKey(source, fallback = null)
|
|
67
|
+
{
|
|
68
|
+
if ( ! Any.isString(source) ) {
|
|
69
|
+
return fallback;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
let host = source.match(/^https?:\/\/(www\.|player\.)?vimeo\.com/);
|
|
73
|
+
|
|
74
|
+
if ( ! host ) {
|
|
75
|
+
return fallback;
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
let path = source.match(/(\/[0-9]+)(&|$)/);
|
|
79
|
+
|
|
80
|
+
if ( path && path.length === 3 ) {
|
|
81
|
+
return path[0].replace(/(^\/|&$)/, '');
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
return fallback;
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
static getYoutubeKey(source, fallback)
|
|
88
|
+
{
|
|
89
|
+
if ( ! Any.isString(source) ) {
|
|
90
|
+
return fallback;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
let host = source.match(/^https?:\/\/(www\.)?(youtube\.com|youtu\.be)/);
|
|
94
|
+
|
|
95
|
+
if ( ! host ) {
|
|
96
|
+
return fallback;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
let id = source.match(/(\?v=.*?)(?=&|$)/);
|
|
100
|
+
|
|
101
|
+
if ( id && id.length === 2 ) {
|
|
102
|
+
return id[0].replace(/^\?v=/, '');
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
let path = source.match(/(\.be\/.*?)(?=\?|$)/);
|
|
106
|
+
|
|
107
|
+
if ( path && path.length === 2 ) {
|
|
108
|
+
return path[0].replace(/^\.be\//, '');
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
let frame = source.match(/(\/embed\/)(.*?$)/);
|
|
112
|
+
|
|
113
|
+
if ( frame && frame.length === 3 ) {
|
|
114
|
+
return frame[0].replace(/^\/embed\//, '');
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
return fallback;
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
if ( ! window[PreviewHelper.alias] ) {
|
|
123
|
+
window[PreviewHelper.alias] = PreviewHelper;
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
export default PreviewHelper;
|