@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,22 +1,4 @@
|
|
|
1
|
-
import { Obj, Arr, Any,
|
|
2
|
-
|
|
3
|
-
const fileMap = {
|
|
4
|
-
image: [
|
|
5
|
-
'jpg', 'jpeg', 'gif', 'svg', 'png'
|
|
6
|
-
],
|
|
7
|
-
video: [
|
|
8
|
-
'mp4', 'webm', 'mov'
|
|
9
|
-
],
|
|
10
|
-
font: [
|
|
11
|
-
'woff', 'ttf', 'otf'
|
|
12
|
-
],
|
|
13
|
-
text: [
|
|
14
|
-
'csv', 'txt', 'html'
|
|
15
|
-
],
|
|
16
|
-
application: [
|
|
17
|
-
'pdf', 'doc', 'xls'
|
|
18
|
-
]
|
|
19
|
-
}
|
|
1
|
+
import { UUID, Obj, Arr, Any, Event, Locale } from "@kizmann/pico-js";
|
|
20
2
|
|
|
21
3
|
export default {
|
|
22
4
|
|
|
@@ -38,6 +20,30 @@ export default {
|
|
|
38
20
|
}
|
|
39
21
|
},
|
|
40
22
|
|
|
23
|
+
title: {
|
|
24
|
+
default()
|
|
25
|
+
{
|
|
26
|
+
return null;
|
|
27
|
+
},
|
|
28
|
+
type: [String]
|
|
29
|
+
},
|
|
30
|
+
|
|
31
|
+
index: {
|
|
32
|
+
default()
|
|
33
|
+
{
|
|
34
|
+
return 0;
|
|
35
|
+
},
|
|
36
|
+
type: [Number, String]
|
|
37
|
+
},
|
|
38
|
+
|
|
39
|
+
group: {
|
|
40
|
+
default()
|
|
41
|
+
{
|
|
42
|
+
return UUID();
|
|
43
|
+
},
|
|
44
|
+
type: [String]
|
|
45
|
+
},
|
|
46
|
+
|
|
41
47
|
fit: {
|
|
42
48
|
default()
|
|
43
49
|
{
|
|
@@ -51,7 +57,7 @@ export default {
|
|
|
51
57
|
{
|
|
52
58
|
return null;
|
|
53
59
|
},
|
|
54
|
-
|
|
60
|
+
type: [String]
|
|
55
61
|
},
|
|
56
62
|
|
|
57
63
|
preview: {
|
|
@@ -59,7 +65,7 @@ export default {
|
|
|
59
65
|
{
|
|
60
66
|
return true;
|
|
61
67
|
},
|
|
62
|
-
|
|
68
|
+
type: [Boolean]
|
|
63
69
|
},
|
|
64
70
|
|
|
65
71
|
showSrc: {
|
|
@@ -67,15 +73,23 @@ export default {
|
|
|
67
73
|
{
|
|
68
74
|
return true;
|
|
69
75
|
},
|
|
70
|
-
|
|
76
|
+
type: [Boolean]
|
|
71
77
|
},
|
|
72
78
|
|
|
73
|
-
|
|
79
|
+
buttonText: {
|
|
74
80
|
default()
|
|
75
81
|
{
|
|
76
|
-
return
|
|
82
|
+
return Locale.trans('Download file');
|
|
77
83
|
},
|
|
78
|
-
type: [
|
|
84
|
+
type: [String]
|
|
85
|
+
},
|
|
86
|
+
|
|
87
|
+
renderButton: {
|
|
88
|
+
default()
|
|
89
|
+
{
|
|
90
|
+
return true;
|
|
91
|
+
},
|
|
92
|
+
type: [Boolean]
|
|
79
93
|
}
|
|
80
94
|
|
|
81
95
|
},
|
|
@@ -92,86 +106,38 @@ export default {
|
|
|
92
106
|
return this.thumb || this.file;
|
|
93
107
|
},
|
|
94
108
|
|
|
95
|
-
fileMime()
|
|
96
|
-
{
|
|
97
|
-
return this.getFileMime();
|
|
98
|
-
},
|
|
99
|
-
|
|
100
|
-
thumbMime()
|
|
101
|
-
{
|
|
102
|
-
return this.getThumbMime();
|
|
103
|
-
},
|
|
104
|
-
|
|
105
109
|
},
|
|
106
110
|
|
|
107
|
-
|
|
111
|
+
provide()
|
|
108
112
|
{
|
|
109
|
-
return {
|
|
110
|
-
lightbox: false, load: false
|
|
111
|
-
};
|
|
113
|
+
return { NPreview: this };
|
|
112
114
|
},
|
|
113
115
|
|
|
114
116
|
methods: {
|
|
115
117
|
|
|
116
|
-
|
|
118
|
+
openBox()
|
|
117
119
|
{
|
|
118
|
-
|
|
119
|
-
this.tempFile);
|
|
120
|
-
|
|
121
|
-
if ( Any.isEmpty(file) ) {
|
|
122
|
-
return fallback;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
let extension = file.replace(/^.*?\.([^.?]+)(\?.*?)?$/,
|
|
126
|
-
'$1');
|
|
127
|
-
|
|
128
|
-
Obj.each(this.map, (exts, key) => {
|
|
129
|
-
if ( Arr.has(exts, extension) ) fallback = key;
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
if ( window.resolveVimeo(file) ) {
|
|
133
|
-
fallback = 'video';
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
if ( window.resolveYoutube(file) ) {
|
|
137
|
-
fallback = 'video';
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
if ( Any.isString(this.mime) ) {
|
|
141
|
-
fallback = this.mime;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
return fallback;
|
|
120
|
+
this.$refs.modal.openBox();
|
|
145
121
|
},
|
|
146
122
|
|
|
147
|
-
|
|
123
|
+
closeBox()
|
|
148
124
|
{
|
|
149
|
-
|
|
150
|
-
return this.mime;
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
let file = Obj.get(this.tempThumb, 'name',
|
|
154
|
-
this.tempThumb);
|
|
155
|
-
|
|
156
|
-
if ( Any.isEmpty(file) ) {
|
|
157
|
-
return fallback;
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
let extension = file.replace(/^.*?\.([^.?]+)(\?.*?)?$/,
|
|
161
|
-
'$1');
|
|
162
|
-
|
|
163
|
-
Obj.each(this.map, (exts, key) => {
|
|
164
|
-
if ( Arr.has(exts, extension) ) fallback = key;
|
|
165
|
-
});
|
|
166
|
-
|
|
167
|
-
return fallback;
|
|
125
|
+
this.$refs.modal.closeBox();
|
|
168
126
|
},
|
|
169
127
|
|
|
170
|
-
|
|
171
|
-
{
|
|
172
|
-
this.lightbox = true;
|
|
173
|
-
},
|
|
128
|
+
},
|
|
174
129
|
|
|
130
|
+
renderTitle()
|
|
131
|
+
{
|
|
132
|
+
if ( Any.isEmpty(this.title) ) {
|
|
133
|
+
return null;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
return (
|
|
137
|
+
<div class="n-preview__title">
|
|
138
|
+
<span>{this.title}</span>
|
|
139
|
+
</div>
|
|
140
|
+
);
|
|
175
141
|
},
|
|
176
142
|
|
|
177
143
|
renderPreview()
|
|
@@ -180,55 +146,51 @@ export default {
|
|
|
180
146
|
return this.ctor('renderFull')();
|
|
181
147
|
}
|
|
182
148
|
|
|
183
|
-
|
|
149
|
+
let type = this.PreviewHelper.getType(this.tempThumb);
|
|
150
|
+
|
|
151
|
+
if ( type === 'image' ) {
|
|
184
152
|
return (<NPreviewImage src={this.tempThumb} />);
|
|
185
153
|
}
|
|
186
154
|
|
|
187
155
|
let props = {
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
}
|
|
156
|
+
showSrc: false, renderButton: false,
|
|
157
|
+
};
|
|
191
158
|
|
|
192
159
|
return (<NPreviewPlain src={this.tempThumb} {...props} />);
|
|
193
160
|
},
|
|
194
161
|
|
|
195
162
|
renderFull()
|
|
196
163
|
{
|
|
197
|
-
let
|
|
164
|
+
let type = this.PreviewHelper.getType(this.tempFile);
|
|
198
165
|
|
|
199
|
-
if (
|
|
166
|
+
if ( type === 'image' ) {
|
|
200
167
|
return (<NPreviewImage src={this.tempFile} />);
|
|
201
168
|
}
|
|
202
169
|
|
|
203
|
-
if (
|
|
170
|
+
if ( type === 'video' ) {
|
|
204
171
|
return (<NPreviewVideo src={this.tempFile} />);
|
|
205
172
|
}
|
|
206
173
|
|
|
207
174
|
let props = {
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
}
|
|
175
|
+
showSrc: this.showSrc, buttonText: this.buttonText, renderButton: this.renderButton
|
|
176
|
+
};
|
|
211
177
|
|
|
212
178
|
return (<NPreviewPlain src={this.tempFile} {...props} />);
|
|
213
179
|
},
|
|
214
180
|
|
|
215
|
-
|
|
181
|
+
renderModal()
|
|
216
182
|
{
|
|
217
|
-
if ( ! this.
|
|
183
|
+
if ( ! this.preview ) {
|
|
218
184
|
return null;
|
|
219
185
|
}
|
|
220
186
|
|
|
221
|
-
let
|
|
222
|
-
|
|
223
|
-
}
|
|
224
|
-
|
|
225
|
-
let props = {
|
|
226
|
-
type: 'preview',
|
|
227
|
-
width: '80%',
|
|
228
|
-
height: '90%',
|
|
229
|
-
}
|
|
187
|
+
let modalProps = {
|
|
188
|
+
index: this.index, group: this.group, file: this.tempFile
|
|
189
|
+
};
|
|
230
190
|
|
|
231
|
-
return (
|
|
191
|
+
return (
|
|
192
|
+
<NPreviewModal ref="modal" {...modalProps} />
|
|
193
|
+
);
|
|
232
194
|
},
|
|
233
195
|
|
|
234
196
|
render()
|
|
@@ -242,21 +204,29 @@ export default {
|
|
|
242
204
|
classList.push('n-clickable');
|
|
243
205
|
}
|
|
244
206
|
|
|
245
|
-
|
|
246
|
-
|
|
207
|
+
let type = this.PreviewHelper.getType(this.tempFile);
|
|
208
|
+
|
|
209
|
+
if ( type ) {
|
|
210
|
+
classList.push('n-mime-' + type);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
let thumb = this.PreviewHelper.getType(this.tempThumb);
|
|
214
|
+
|
|
215
|
+
if ( thumb ) {
|
|
216
|
+
classList.push('n-mime-preview-' + thumb);
|
|
247
217
|
}
|
|
248
218
|
|
|
249
219
|
let props = {};
|
|
250
220
|
|
|
251
221
|
if ( this.preview ) {
|
|
252
|
-
props.onClick = this.
|
|
222
|
+
props.onClick = () => this.openBox();
|
|
253
223
|
}
|
|
254
224
|
|
|
255
225
|
let key = btoa(this.tempThumb);
|
|
256
226
|
|
|
257
227
|
return (
|
|
258
228
|
<div key={key} class={classList} {...props}>
|
|
259
|
-
{ [this.ctor('renderPreview')(), this.ctor('
|
|
229
|
+
{ [this.ctor('renderPreview')(), this.ctor('renderTitle')(), this.ctor('renderModal')()] }
|
|
260
230
|
</div>
|
|
261
231
|
);
|
|
262
232
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
@
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
2
2
|
|
|
3
3
|
.n-preview {
|
|
4
4
|
position: relative;
|
|
@@ -11,4 +11,31 @@
|
|
|
11
11
|
|
|
12
12
|
.n-preview--contain img {
|
|
13
13
|
object-fit: contain !important;
|
|
14
|
-
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.n-preview__title {
|
|
17
|
+
z-index: 10;
|
|
18
|
+
pointer-events: none;
|
|
19
|
+
position: absolute;
|
|
20
|
+
bottom: 0;
|
|
21
|
+
left: 0;
|
|
22
|
+
width: 100%;
|
|
23
|
+
padding: size('default-md-pad', 'calc($ * 0.5)') size('default-md-pad');
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
.n-preview__title span {
|
|
27
|
+
overflow: hidden;
|
|
28
|
+
display: block;
|
|
29
|
+
text-align: center;
|
|
30
|
+
width: 100%;
|
|
31
|
+
text-overflow: ellipsis;
|
|
32
|
+
white-space: nowrap;
|
|
33
|
+
font-size: size('base-fnt');
|
|
34
|
+
color: color('white', 0.7);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
.n-preview.n-mime-preview-image .n-preview__title span {
|
|
38
|
+
color: color('white');
|
|
39
|
+
text-shadow: 0 0 6px color('shadow', 0.7);
|
|
40
|
+
}
|
|
41
|
+
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
@
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
2
2
|
|
|
3
3
|
.n-preview-image {
|
|
4
4
|
position: relative;
|
|
5
5
|
width: 100%;
|
|
6
|
-
background: rgba($color-gray-50, 0.1);
|
|
7
6
|
}
|
|
8
7
|
|
|
9
8
|
.n-modal__frame > .n-preview-image {
|
|
@@ -34,7 +33,6 @@
|
|
|
34
33
|
height: 20px;
|
|
35
34
|
margin: -10px 0 0 -10px;
|
|
36
35
|
border-radius: 500px;
|
|
37
|
-
border: 2px solid rgba($color-gray-50, 0.2);
|
|
38
36
|
border-top-color: transparent;
|
|
39
37
|
animation: NImage 1s linear infinite;
|
|
40
38
|
}
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Any, Event, Obj, UUID } from "@kizmann/pico-js";
|
|
2
|
+
|
|
3
|
+
export default {
|
|
4
|
+
|
|
5
|
+
name: 'NPreviewModal',
|
|
6
|
+
|
|
7
|
+
inject: {
|
|
8
|
+
|
|
9
|
+
NPreview: {
|
|
10
|
+
default: undefined
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
props: {
|
|
16
|
+
|
|
17
|
+
file: {
|
|
18
|
+
default()
|
|
19
|
+
{
|
|
20
|
+
return null;
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
|
|
24
|
+
index: {
|
|
25
|
+
default()
|
|
26
|
+
{
|
|
27
|
+
return 0;
|
|
28
|
+
},
|
|
29
|
+
type: [Number, String]
|
|
30
|
+
},
|
|
31
|
+
|
|
32
|
+
group: {
|
|
33
|
+
default()
|
|
34
|
+
{
|
|
35
|
+
return UUID();
|
|
36
|
+
},
|
|
37
|
+
type: [String]
|
|
38
|
+
},
|
|
39
|
+
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
data()
|
|
43
|
+
{
|
|
44
|
+
return { uid: UUID(), visible: false };
|
|
45
|
+
},
|
|
46
|
+
|
|
47
|
+
computed: {
|
|
48
|
+
|
|
49
|
+
tempFile() {
|
|
50
|
+
return Obj.get(this.file, 'name', this.file);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
},
|
|
54
|
+
|
|
55
|
+
watch: {
|
|
56
|
+
|
|
57
|
+
visible: function (value) {
|
|
58
|
+
if ( value ) {
|
|
59
|
+
this.NPreview.$emit('slide');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
},
|
|
64
|
+
|
|
65
|
+
mounted()
|
|
66
|
+
{
|
|
67
|
+
this.PreviewHandler.create()
|
|
68
|
+
.append(this.$el);
|
|
69
|
+
|
|
70
|
+
this.PreviewHandler.append(this);
|
|
71
|
+
},
|
|
72
|
+
|
|
73
|
+
beforeUnmount()
|
|
74
|
+
{
|
|
75
|
+
this.$el.remove();
|
|
76
|
+
|
|
77
|
+
this.PreviewHandler.remove(this);
|
|
78
|
+
},
|
|
79
|
+
|
|
80
|
+
methods: {
|
|
81
|
+
|
|
82
|
+
openBox()
|
|
83
|
+
{
|
|
84
|
+
this.PreviewHandler.open(this);
|
|
85
|
+
},
|
|
86
|
+
|
|
87
|
+
closeBox()
|
|
88
|
+
{
|
|
89
|
+
this.PreviewHandler.close();
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
},
|
|
93
|
+
|
|
94
|
+
renderFull()
|
|
95
|
+
{
|
|
96
|
+
let classList = [
|
|
97
|
+
'n-preview-frame'
|
|
98
|
+
];
|
|
99
|
+
|
|
100
|
+
let mime = this.PreviewHelper.getType(this.tempFile);
|
|
101
|
+
|
|
102
|
+
if ( mime === 'image' ) {
|
|
103
|
+
return (<NPreviewImage class={classList} src={this.file} />);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
if ( mime === 'video' ) {
|
|
107
|
+
return (<NPreviewVideo class={classList} src={this.file} />);
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
let props = {
|
|
111
|
+
showSrc: this.NPreview ? this.NPreview.showSrc : false,
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
return (<NPreviewPlain class={classList} src={this.file} {...props} />);
|
|
115
|
+
},
|
|
116
|
+
|
|
117
|
+
render()
|
|
118
|
+
{
|
|
119
|
+
if ( ! this.visible ) {
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
return this.ctor('renderFull')();
|
|
124
|
+
},
|
|
125
|
+
|
|
126
|
+
}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
2
|
+
|
|
3
|
+
.n-preview-modal {
|
|
4
|
+
z-index: 999999997;
|
|
5
|
+
overflow: hidden;
|
|
6
|
+
position: fixed;
|
|
7
|
+
top: 0;
|
|
8
|
+
right: 0;
|
|
9
|
+
bottom: 0;
|
|
10
|
+
left: 0;
|
|
11
|
+
display: flex;
|
|
12
|
+
padding: size('base-hgt') size('base-hgt', 'calc($ * 2.4)');
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.n-preview-modal i {
|
|
16
|
+
font-size: 1.2em;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.n-preview-modal:not(.n-ready) {
|
|
20
|
+
pointer-events: none;
|
|
21
|
+
opacity: 0;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.n-preview-modal__close,
|
|
25
|
+
.n-preview-modal__prev,
|
|
26
|
+
.n-preview-modal__next {
|
|
27
|
+
width: size('base-hgt', 'calc($ * 1.2)');
|
|
28
|
+
height: size('base-hgt', 'calc($ * 1.2)');
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
.n-preview-modal__close {
|
|
32
|
+
cursor: pointer;
|
|
33
|
+
z-index: 100;
|
|
34
|
+
position: absolute;
|
|
35
|
+
top: size('base-hgt', 'calc($ * 0.5)');
|
|
36
|
+
right: size('base-hgt', 'calc($ * 0.5)');
|
|
37
|
+
display: flex;
|
|
38
|
+
align-items: center;
|
|
39
|
+
justify-content: center;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.n-preview-modal .n-preview-frame {
|
|
43
|
+
background: transparent !important;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.n-preview-modal__prev,
|
|
47
|
+
.n-preview-modal__next {
|
|
48
|
+
cursor: pointer;
|
|
49
|
+
z-index: 500;
|
|
50
|
+
position: absolute;
|
|
51
|
+
top: 50%;
|
|
52
|
+
display: none;
|
|
53
|
+
align-items: center;
|
|
54
|
+
justify-content: center;
|
|
55
|
+
transform: translateY(-50%);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.n-preview-modal.n-multi .n-preview-modal__prev,
|
|
59
|
+
.n-preview-modal.n-multi .n-preview-modal__next {
|
|
60
|
+
display: flex;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.n-preview-modal__prev {
|
|
64
|
+
left: size('base-hgt', 'calc($ * 0.5)');
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
.n-preview-modal__next {
|
|
68
|
+
right: size('base-hgt', 'calc($ * 0.5)');
|
|
69
|
+
}
|
|
@@ -13,38 +13,36 @@ export default {
|
|
|
13
13
|
}
|
|
14
14
|
},
|
|
15
15
|
|
|
16
|
-
|
|
16
|
+
showSrc: {
|
|
17
17
|
default()
|
|
18
18
|
{
|
|
19
|
-
return
|
|
20
|
-
}
|
|
19
|
+
return true;
|
|
20
|
+
},
|
|
21
|
+
type: [Boolean]
|
|
21
22
|
},
|
|
22
23
|
|
|
23
|
-
|
|
24
|
+
buttonText: {
|
|
25
|
+
default()
|
|
26
|
+
{
|
|
27
|
+
return Locale.trans('Download file');
|
|
28
|
+
},
|
|
29
|
+
type: [String]
|
|
30
|
+
},
|
|
31
|
+
|
|
32
|
+
renderButton: {
|
|
24
33
|
default()
|
|
25
34
|
{
|
|
26
35
|
return true;
|
|
27
|
-
}
|
|
36
|
+
},
|
|
37
|
+
type: [Boolean]
|
|
28
38
|
}
|
|
29
39
|
|
|
30
40
|
},
|
|
31
41
|
|
|
32
42
|
computed: {
|
|
33
43
|
|
|
34
|
-
|
|
35
|
-
{
|
|
44
|
+
file() {
|
|
36
45
|
return Obj.get(this.src, 'name', this.src);
|
|
37
|
-
},
|
|
38
|
-
|
|
39
|
-
tempExt()
|
|
40
|
-
{
|
|
41
|
-
let regex = /^.*?\.([^.?]+)(\?.*?)?$/;
|
|
42
|
-
|
|
43
|
-
if ( Any.isEmpty(this.tempSrc) ) {
|
|
44
|
-
return null;
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
return this.tempSrc.replace(regex, '$1');
|
|
48
46
|
}
|
|
49
47
|
|
|
50
48
|
},
|
|
@@ -58,11 +56,25 @@ export default {
|
|
|
58
56
|
let slots = [];
|
|
59
57
|
|
|
60
58
|
slots[0] = (
|
|
61
|
-
<li>{ this.
|
|
59
|
+
<li>{ this.PreviewHelper.getMime(this.file) }</li>
|
|
62
60
|
);
|
|
63
61
|
|
|
64
62
|
if ( this.showSrc ) {
|
|
65
|
-
slots
|
|
63
|
+
slots.push(<li class="np-file">{ this.file }</li>);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
let buttonProps = {
|
|
67
|
+
nativeType: 'a', href: this.file, target: '_blank'
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
let buttonHtml = (
|
|
71
|
+
<li class="np-button">
|
|
72
|
+
<NButton {...buttonProps}>{ this.buttonText }</NButton>
|
|
73
|
+
</li>
|
|
74
|
+
);
|
|
75
|
+
|
|
76
|
+
if ( this.renderButton ) {
|
|
77
|
+
slots.push(buttonHtml);
|
|
66
78
|
}
|
|
67
79
|
|
|
68
80
|
return (
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
@
|
|
1
|
+
@use "../../../root/helpers" as *;
|
|
2
2
|
|
|
3
3
|
.n-preview-plain {
|
|
4
4
|
position: relative;
|
|
5
5
|
width: 100%;
|
|
6
|
-
background: rgba($color-gray-50, 0.1);
|
|
7
6
|
}
|
|
8
7
|
|
|
9
8
|
.n-modal__frame > .n-preview-plain {
|
|
@@ -38,5 +37,8 @@
|
|
|
38
37
|
overflow: hidden;
|
|
39
38
|
text-overflow: ellipsis;
|
|
40
39
|
white-space: nowrap;
|
|
41
|
-
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
.n-preview-plain .np-button {
|
|
43
|
+
margin-top: size('base-pad');
|
|
42
44
|
}
|