@kizmann/nano-ui 1.1.0 → 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.
Files changed (583) hide show
  1. package/dist/nano-ui.css +1 -1
  2. package/dist/nano-ui.js +1 -1
  3. package/dist/nano-ui.js.map +1 -1
  4. package/dist/themes/default.css +1 -0
  5. package/dist/themes/webservy.css +1 -0
  6. package/package.json +6 -2
  7. package/src/alert/index.js +13 -2
  8. package/src/alert/index.scss +1 -1
  9. package/src/alert/src/alert/alert-handler.mjs +143 -0
  10. package/src/alert/src/alert/alert.scss +35 -43
  11. package/src/button/index.scss +2 -2
  12. package/src/button/src/button/button.jsx +12 -0
  13. package/src/button/src/button/button.scss +29 -33
  14. package/src/button/src/button-group/button-group.scss +9 -19
  15. package/src/cascader/index.scss +2 -2
  16. package/src/cascader/src/cascader/cascader.jsx +22 -4
  17. package/src/cascader/src/cascader/cascader.scss +26 -78
  18. package/src/cascader/src/cascader-panel/cascader-panel.scss +2 -16
  19. package/src/chart/index.js +9 -0
  20. package/src/chart/index.scss +3 -0
  21. package/src/chart/src/chart-bar/chart-bar.jsx +344 -0
  22. package/src/chart/src/chart-bar/chart-bar.scss +143 -0
  23. package/src/chart/src/chart-donut/chart-donut.jsx +404 -0
  24. package/src/chart/src/chart-donut/chart-donut.scss +123 -0
  25. package/src/chart/src/chart-item/chart-item.jsx +110 -0
  26. package/src/chart/src/chart-item/chart-item.scss +30 -0
  27. package/src/checkbox/index.scss +2 -2
  28. package/src/checkbox/src/checkbox/checkbox.scss +11 -30
  29. package/src/checkbox/src/checkbox-group/checkbox-group.scss +19 -29
  30. package/src/collapse/index.scss +2 -2
  31. package/src/collapse/src/collapse/collapse.jsx +27 -4
  32. package/src/collapse/src/collapse/collapse.scss +14 -22
  33. package/src/collapse/src/collapse-item/collapse-item.jsx +42 -8
  34. package/src/collapse/src/collapse-item/collapse-item.scss +31 -29
  35. package/src/config/index.scss +3 -3
  36. package/src/config/src/builder/builder.scss +1 -1
  37. package/src/config/src/reference-panel/reference-panel.scss +1 -1
  38. package/src/confirm/index.js +23 -1
  39. package/src/confirm/index.scss +1 -1
  40. package/src/confirm/src/confirm/confirm-handler.mjs +226 -0
  41. package/src/confirm/src/confirm/confirm.jsx +109 -123
  42. package/src/confirm/src/confirm/confirm.scss +57 -49
  43. package/src/datepicker/index.scss +2 -2
  44. package/src/datepicker/src/datepicker/datepicker.jsx +23 -4
  45. package/src/datepicker/src/datepicker/datepicker.scss +20 -51
  46. package/src/datepicker/src/datepicker-panel/datepicker-panel.jsx +4 -2
  47. package/src/datepicker/src/datepicker-panel/datepicker-panel.scss +79 -53
  48. package/src/datetimepicker/index.scss +1 -1
  49. package/src/datetimepicker/src/datetimepicker/datetimepicker.jsx +3 -3
  50. package/src/datetimepicker/src/datetimepicker/datetimepicker.scss +23 -61
  51. package/src/draggable/index.scss +6 -6
  52. package/src/draggable/src/draggrid/draggrid.jsx +4 -4
  53. package/src/draggable/src/draggrid/draggrid.scss +2 -19
  54. package/src/draggable/src/draggrid-item/draggrid-item.scss +12 -34
  55. package/src/draggable/src/draghandler/draghandler.scss +1 -1
  56. package/src/draggable/src/draglist/draglist.jsx +3 -3
  57. package/src/draggable/src/draglist/draglist.scss +3 -20
  58. package/src/draggable/src/draglist-item/draglist-item.scss +15 -36
  59. package/src/draggable/src/dropzone/dropzone.scss +6 -19
  60. package/src/drawer/index.scss +1 -1
  61. package/src/drawer/src/drawer/drawer.jsx +6 -3
  62. package/src/drawer/src/drawer/drawer.scss +27 -31
  63. package/src/durationpicker/index.scss +1 -1
  64. package/src/durationpicker/src/durationpicker/durationpicker.jsx +3 -3
  65. package/src/durationpicker/src/durationpicker/durationpicker.scss +18 -55
  66. package/src/empty/index.scss +1 -1
  67. package/src/empty/src/empty-icon/empty-icon.jsx +1 -1
  68. package/src/empty/src/empty-icon/empty-icon.scss +13 -26
  69. package/src/file/index.scss +1 -1
  70. package/src/file/src/file/file.jsx +9 -0
  71. package/src/file/src/file/file.scss +2 -2
  72. package/src/form/index.js +2 -0
  73. package/src/form/index.scss +5 -4
  74. package/src/form/src/form/form-rules.mjs +182 -0
  75. package/src/form/src/form/form.jsx +108 -4
  76. package/src/form/src/form/form.scss +33 -1
  77. package/src/form/src/form-bag/form-bag.jsx +90 -0
  78. package/src/form/src/form-bag/form-bag.scss +59 -0
  79. package/src/form/src/form-frame/form-frame.jsx +17 -9
  80. package/src/form/src/form-frame/form-frame.scss +25 -38
  81. package/src/form/src/form-group/form-group.jsx +24 -6
  82. package/src/form/src/form-group/form-group.scss +85 -66
  83. package/src/form/src/form-item/form-item.jsx +79 -68
  84. package/src/form/src/form-item/form-item.scss +23 -32
  85. package/src/grid/index.scss +1 -0
  86. package/src/grid/src/grid/grid.scss +146 -0
  87. package/src/index.js +4 -1
  88. package/src/index.scss +45 -39
  89. package/src/info/index.scss +3 -3
  90. package/src/info/src/info/info.scss +7 -26
  91. package/src/info/src/info-column/info-column.scss +2 -16
  92. package/src/info/src/info-field/info-field.scss +1 -1
  93. package/src/input/index.scss +1 -1
  94. package/src/input/src/input/input.jsx +1 -1
  95. package/src/input/src/input/input.scss +15 -40
  96. package/src/input-number/index.scss +1 -1
  97. package/src/input-number/src/input-number/input-number.jsx +39 -23
  98. package/src/input-number/src/input-number/input-number.scss +14 -59
  99. package/src/loader/index.scss +1 -1
  100. package/src/loader/src/loader/loader.scss +16 -29
  101. package/src/map/index.scss +1 -1
  102. package/src/map/src/map/map.scss +1 -2
  103. package/src/modal/index.scss +1 -1
  104. package/src/modal/src/modal/modal.jsx +6 -3
  105. package/src/modal/src/modal/modal.scss +25 -38
  106. package/src/notification/index.js +23 -3
  107. package/src/notification/index.scss +1 -1
  108. package/src/notification/src/notification/notification-element.mjs +74 -0
  109. package/src/notification/src/notification/notification-handler.mjs +75 -0
  110. package/src/notification/src/notification/notification.scss +13 -25
  111. package/src/paginator/index.scss +1 -1
  112. package/src/paginator/src/paginator/paginator.scss +39 -44
  113. package/src/popover/index.js +20 -3
  114. package/src/popover/index.scss +1 -1
  115. package/src/popover/src/popover/popover-element.mjs +578 -0
  116. package/src/popover/src/popover/popover-handler.mjs +116 -0
  117. package/src/popover/src/popover/popover-helper.mjs +75 -0
  118. package/src/popover/src/popover/popover.jsx +78 -550
  119. package/src/popover/src/popover/popover.scss +186 -78
  120. package/src/preview/index.js +45 -5
  121. package/src/preview/index.scss +5 -5
  122. package/src/preview/src/{_tools/preview-handler.js → preview/preview-handler.mjs} +46 -34
  123. package/src/preview/src/{_tools/preview-helper.js → preview/preview-helper.mjs} +24 -40
  124. package/src/preview/src/preview/preview.jsx +62 -25
  125. package/src/preview/src/preview/preview.scss +27 -1
  126. package/src/preview/src/preview-image/preview-image.scss +1 -3
  127. package/src/preview/src/preview-modal/preview-modal.jsx +18 -48
  128. package/src/preview/src/preview-modal/preview-modal.scss +24 -11
  129. package/src/preview/src/preview-plain/preview-plain.jsx +32 -20
  130. package/src/preview/src/preview-plain/preview-plain.scss +5 -3
  131. package/src/preview/src/preview-video/preview-video.jsx +3 -4
  132. package/src/preview/src/preview-video/preview-video.scss +1 -2
  133. package/src/radio/index.scss +2 -2
  134. package/src/radio/src/radio/radio.scss +13 -32
  135. package/src/radio/src/radio-group/radio-group.scss +18 -28
  136. package/src/rating/index.scss +1 -1
  137. package/src/rating/src/rating/rating.scss +15 -33
  138. package/src/resizer/index.scss +1 -1
  139. package/src/resizer/src/resizer/resizer-next.jsx +40 -20
  140. package/src/resizer/src/resizer/resizer.scss +1 -1
  141. package/src/root/helpers.scss +41 -0
  142. package/src/root/image/angle-down-shadow.svg +3 -0
  143. package/src/root/image/angle-down.svg +3 -0
  144. package/src/root/image/angle-left-shadow.svg +3 -0
  145. package/src/root/image/angle-left.svg +3 -0
  146. package/src/root/image/angle-right-shadow.svg +3 -0
  147. package/src/root/image/angle-right.svg +3 -0
  148. package/src/root/image/angle-up-shadow.svg +3 -0
  149. package/src/root/image/angle-up.svg +3 -0
  150. package/src/root/image/empty-ufo.svg +8 -0
  151. package/src/root/image/empty.svg +10 -0
  152. package/src/root/image/star.svg +5 -0
  153. package/src/root/vars.scss +5 -3
  154. package/src/scrollbar/index.js +1 -3
  155. package/src/scrollbar/index.scss +1 -2
  156. package/src/scrollbar/src/scrollbar/scrollbar.jsx +213 -376
  157. package/src/scrollbar/src/scrollbar/scrollbar.scss +9 -11
  158. package/src/select/index.scss +2 -2
  159. package/src/select/src/select/select.jsx +22 -14
  160. package/src/select/src/select/select.scss +49 -104
  161. package/src/select/src/select-option/select-option.scss +1 -1
  162. package/src/slider/index.scss +1 -1
  163. package/src/slider/src/slider/slider.jsx +5 -3
  164. package/src/slider/src/slider/slider.scss +37 -46
  165. package/src/switch/index.scss +1 -1
  166. package/src/switch/src/switch/switch.scss +17 -44
  167. package/src/table/index.scss +4 -4
  168. package/src/table/src/table/table.jsx +5 -2
  169. package/src/table/src/table/table.scss +11 -18
  170. package/src/table/src/table-cell/table-cell.scss +7 -18
  171. package/src/table/src/table-column/table-column.jsx +5 -1
  172. package/src/table/src/table-column/table-column.scss +14 -13
  173. package/src/table/src/table-filter/table-filter.jsx +4 -4
  174. package/src/table/src/table-filter/table-filter.scss +10 -4
  175. package/src/tabs/index.scss +2 -2
  176. package/src/tabs/src/tabs/tabs.scss +20 -29
  177. package/src/tabs/src/tabs-item/tabs-item.jsx +14 -6
  178. package/src/tabs/src/tabs-item/tabs-item.scss +17 -25
  179. package/src/tags/index.scss +2 -2
  180. package/src/tags/src/tags/tags.jsx +1 -0
  181. package/src/tags/src/tags/tags.scss +6 -2
  182. package/src/tags/src/tags-item/tags-item.jsx +7 -7
  183. package/src/tags/src/tags-item/tags-item.scss +10 -31
  184. package/src/textarea/index.scss +1 -1
  185. package/src/textarea/src/textarea/textarea.jsx +2 -0
  186. package/src/textarea/src/textarea/textarea.scss +6 -23
  187. package/src/timepicker/index.scss +2 -2
  188. package/src/timepicker/src/timepicker/timepicker.jsx +6 -3
  189. package/src/timepicker/src/timepicker/timepicker.scss +21 -53
  190. package/src/timepicker/src/timepicker-panel/timepicker-panel.scss +33 -41
  191. package/src/tooltip/index.scss +1 -0
  192. package/src/tooltip/src/tooltip/tooltip.scss +116 -0
  193. package/src/transfer/index.scss +1 -1
  194. package/src/transfer/src/transfer/transfer.jsx +2 -2
  195. package/src/transfer/src/transfer/transfer.scss +33 -53
  196. package/src/virtualscroller/index.scss +1 -1
  197. package/src/virtualscroller/src/virtualscroller/virtualscroller.jsx +28 -34
  198. package/src/virtualscroller/src/virtualscroller/virtualscroller.scss +3 -2
  199. package/themes/default/alert/index.scss +1 -0
  200. package/themes/default/alert/src/alert/alert.scss +29 -0
  201. package/themes/default/button/index.scss +2 -0
  202. package/themes/default/button/src/button/button.scss +87 -0
  203. package/themes/default/button/src/button-group/button-group.scss +1 -0
  204. package/themes/default/cascader/index.scss +2 -0
  205. package/themes/default/cascader/src/cascader/cascader.scss +31 -0
  206. package/themes/default/cascader/src/cascader-panel/cascader-panel.scss +21 -0
  207. package/themes/default/chart/index.scss +2 -0
  208. package/themes/default/chart/src/chart-donut/chart-donut.scss +22 -0
  209. package/themes/default/chart/src/chart-item/chart-item.scss +11 -0
  210. package/themes/default/checkbox/index.scss +2 -0
  211. package/themes/default/checkbox/src/checkbox/checkbox.scss +26 -0
  212. package/themes/default/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
  213. package/themes/default/collapse/index.scss +2 -0
  214. package/themes/default/collapse/src/collapse/collapse.scss +14 -0
  215. package/themes/default/collapse/src/collapse-item/collapse-item.scss +14 -0
  216. package/themes/default/confirm/index.scss +1 -0
  217. package/themes/default/confirm/src/confirm/confirm.scss +35 -0
  218. package/themes/default/datepicker/index.scss +2 -0
  219. package/themes/default/datepicker/src/datepicker/datepicker.scss +44 -0
  220. package/themes/default/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
  221. package/themes/default/datetimepicker/index.scss +1 -0
  222. package/themes/default/datetimepicker/src/datetimepicker/datetimepicker.scss +51 -0
  223. package/themes/default/demo/index.scss +1 -0
  224. package/themes/default/demo/src/demo/demo.scss +34 -0
  225. package/themes/default/draggable/index.scss +9 -0
  226. package/themes/default/draggable/src/draggrid/draggrid.scss +5 -0
  227. package/themes/default/draggable/src/draggrid-item/draggrid-item.scss +52 -0
  228. package/themes/default/draggable/src/draghandler/draghandler.scss +15 -0
  229. package/themes/default/draggable/src/draglist/draglist.scss +5 -0
  230. package/themes/default/draggable/src/draglist-item/draglist-item.scss +56 -0
  231. package/themes/default/draggable/src/dropzone/dropzone.scss +5 -0
  232. package/themes/default/drawer/index.scss +1 -0
  233. package/themes/default/drawer/src/drawer/drawer.scss +25 -0
  234. package/themes/default/durationpicker/index.scss +1 -0
  235. package/themes/default/durationpicker/src/durationpicker/durationpicker.scss +39 -0
  236. package/themes/default/empty/index.scss +1 -0
  237. package/themes/default/empty/src/empty-icon/empty-icon.scss +17 -0
  238. package/themes/default/example.scss +29 -0
  239. package/themes/default/file/index.scss +1 -0
  240. package/themes/default/file/src/file/file.scss +1 -0
  241. package/themes/default/form/index.scss +4 -0
  242. package/themes/default/form/src/form/form.scss +17 -0
  243. package/themes/default/form/src/form-frame/form-frame.scss +25 -0
  244. package/themes/default/form/src/form-group/form-group.scss +42 -0
  245. package/themes/default/form/src/form-item/form-item.scss +25 -0
  246. package/themes/default/index.scss +43 -0
  247. package/themes/default/info/index.scss +3 -0
  248. package/themes/default/info/src/info/info.scss +5 -0
  249. package/themes/default/info/src/info-column/info-column.scss +5 -0
  250. package/themes/default/info/src/info-field/info-field.scss +5 -0
  251. package/themes/default/input/index.scss +1 -0
  252. package/themes/default/input/src/input/input.scss +27 -0
  253. package/themes/default/input-number/index.scss +1 -0
  254. package/themes/default/input-number/src/input-number/input-number.scss +30 -0
  255. package/themes/default/loader/index.scss +1 -0
  256. package/themes/default/loader/src/loader/loader.scss +10 -0
  257. package/themes/default/map/index.scss +1 -0
  258. package/themes/default/map/src/map/map.scss +1 -0
  259. package/themes/default/modal/index.scss +1 -0
  260. package/themes/default/modal/src/modal/modal.scss +25 -0
  261. package/themes/default/notification/index.scss +1 -0
  262. package/themes/default/notification/src/notification/notification.scss +11 -0
  263. package/themes/default/paginator/index.scss +1 -0
  264. package/themes/default/paginator/src/paginator/paginator.scss +5 -0
  265. package/themes/default/popover/index.scss +1 -0
  266. package/themes/default/popover/src/popover/popover.scss +131 -0
  267. package/themes/default/preview/index.scss +4 -0
  268. package/themes/default/preview/src/preview-image/preview-image.scss +5 -0
  269. package/themes/default/preview/src/preview-modal/preview-modal.scss +39 -0
  270. package/themes/default/preview/src/preview-plain/preview-plain.scss +9 -0
  271. package/themes/default/preview/src/preview-video/preview-video.scss +5 -0
  272. package/themes/default/radio/index.scss +2 -0
  273. package/themes/default/radio/src/radio/radio.scss +32 -0
  274. package/themes/default/radio/src/radio-group/radio-group.scss +1 -0
  275. package/themes/default/rating/index.scss +1 -0
  276. package/themes/default/rating/src/rating/rating.scss +14 -0
  277. package/themes/default/resizer/index.scss +1 -0
  278. package/themes/default/resizer/src/resizer/resizer.scss +5 -0
  279. package/themes/default/root/helpers.scss +41 -0
  280. package/themes/default/root/image/angle-down-shadow.svg +3 -0
  281. package/themes/default/root/image/angle-down.svg +3 -0
  282. package/themes/default/root/image/angle-left-shadow.svg +3 -0
  283. package/themes/default/root/image/angle-left.svg +3 -0
  284. package/themes/default/root/image/angle-right-shadow.svg +3 -0
  285. package/themes/default/root/image/angle-right.svg +3 -0
  286. package/themes/default/root/image/angle-up-shadow.svg +3 -0
  287. package/themes/default/root/image/angle-up.svg +3 -0
  288. package/themes/default/root/image/empty-ufo.svg +8 -0
  289. package/themes/default/root/image/empty.svg +10 -0
  290. package/themes/default/root/image/star.svg +5 -0
  291. package/themes/default/root/vars/colors-dark-bluish.scss +457 -0
  292. package/themes/default/root/vars/colors-dark.scss +457 -0
  293. package/themes/default/root/vars/colors-light-bluish.scss +479 -0
  294. package/themes/default/root/vars/colors-light.scss +479 -0
  295. package/themes/default/root/vars/sizes-default.scss +101 -0
  296. package/themes/default/scrollbar/index.scss +1 -0
  297. package/themes/default/scrollbar/src/scrollbar/scrollbar.scss +7 -0
  298. package/themes/default/select/index.scss +2 -0
  299. package/themes/default/select/src/select/select.scss +32 -0
  300. package/themes/default/select/src/select-option/select-option.scss +1 -0
  301. package/themes/default/slider/index.scss +1 -0
  302. package/themes/default/slider/src/slider/slider.scss +30 -0
  303. package/themes/default/switch/index.scss +1 -0
  304. package/themes/default/switch/src/switch/switch.scss +19 -0
  305. package/themes/default/table/index.scss +4 -0
  306. package/themes/default/table/src/table/table.scss +14 -0
  307. package/themes/default/table/src/table-cell/table-cell.scss +34 -0
  308. package/themes/{macos → default}/table/src/table-column/table-column.scss +9 -10
  309. package/themes/default/table/src/table-filter/table-filter.scss +1 -0
  310. package/themes/default/tabs/index.scss +2 -0
  311. package/themes/default/tabs/src/tabs/tabs.scss +9 -0
  312. package/themes/default/tabs/src/tabs-item/tabs-item.scss +23 -0
  313. package/themes/default/tags/index.scss +2 -0
  314. package/themes/default/tags/src/tags/tags.scss +1 -0
  315. package/themes/default/tags/src/tags-item/tags-item.scss +17 -0
  316. package/themes/default/textarea/index.scss +1 -0
  317. package/themes/default/textarea/src/textarea/textarea.scss +18 -0
  318. package/themes/default/timepicker/index.scss +2 -0
  319. package/themes/default/timepicker/src/timepicker/timepicker.scss +44 -0
  320. package/themes/default/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
  321. package/themes/default/transfer/index.scss +1 -0
  322. package/themes/default/transfer/src/transfer/transfer.scss +20 -0
  323. package/themes/default/virtualscroller/index.scss +1 -0
  324. package/themes/default/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
  325. package/themes/webservy/alert/index.scss +1 -0
  326. package/themes/webservy/alert/src/alert/alert.scss +29 -0
  327. package/themes/webservy/button/index.scss +2 -0
  328. package/themes/webservy/button/src/button/button.scss +87 -0
  329. package/themes/webservy/button/src/button-group/button-group.scss +1 -0
  330. package/themes/webservy/cascader/index.scss +2 -0
  331. package/themes/webservy/cascader/src/cascader/cascader.scss +27 -0
  332. package/themes/webservy/cascader/src/cascader-panel/cascader-panel.scss +21 -0
  333. package/themes/webservy/chart/index.scss +2 -0
  334. package/themes/webservy/chart/src/chart-donut/chart-donut.scss +22 -0
  335. package/themes/webservy/chart/src/chart-item/chart-item.scss +11 -0
  336. package/themes/webservy/checkbox/index.scss +2 -0
  337. package/themes/webservy/checkbox/src/checkbox/checkbox.scss +25 -0
  338. package/themes/webservy/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
  339. package/themes/webservy/collapse/index.scss +2 -0
  340. package/themes/webservy/collapse/src/collapse/collapse.scss +14 -0
  341. package/themes/webservy/collapse/src/collapse-item/collapse-item.scss +14 -0
  342. package/themes/webservy/confirm/index.scss +1 -0
  343. package/themes/webservy/confirm/src/confirm/confirm.scss +35 -0
  344. package/themes/webservy/datepicker/index.scss +2 -0
  345. package/themes/webservy/datepicker/src/datepicker/datepicker.scss +40 -0
  346. package/themes/webservy/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
  347. package/themes/webservy/datetimepicker/index.scss +1 -0
  348. package/themes/webservy/datetimepicker/src/datetimepicker/datetimepicker.scss +47 -0
  349. package/themes/webservy/demo/index.scss +1 -0
  350. package/themes/webservy/demo/src/demo/demo.scss +34 -0
  351. package/themes/webservy/draggable/index.scss +9 -0
  352. package/themes/webservy/draggable/src/draggrid/draggrid.scss +5 -0
  353. package/themes/webservy/draggable/src/draggrid-item/draggrid-item.scss +51 -0
  354. package/themes/webservy/draggable/src/draghandler/draghandler.scss +15 -0
  355. package/themes/webservy/draggable/src/draglist/draglist.scss +5 -0
  356. package/themes/webservy/draggable/src/draglist-item/draglist-item.scss +55 -0
  357. package/themes/webservy/draggable/src/dropzone/dropzone.scss +5 -0
  358. package/themes/webservy/drawer/index.scss +1 -0
  359. package/themes/webservy/drawer/src/drawer/drawer.scss +23 -0
  360. package/themes/webservy/durationpicker/index.scss +1 -0
  361. package/themes/webservy/durationpicker/src/durationpicker/durationpicker.scss +35 -0
  362. package/themes/webservy/empty/index.scss +1 -0
  363. package/themes/webservy/empty/src/empty-icon/empty-icon.scss +17 -0
  364. package/themes/webservy/example.scss +29 -0
  365. package/themes/webservy/file/index.scss +1 -0
  366. package/themes/webservy/file/src/file/file.scss +1 -0
  367. package/themes/webservy/form/index.scss +4 -0
  368. package/themes/webservy/form/src/form/form.scss +17 -0
  369. package/themes/webservy/form/src/form-frame/form-frame.scss +25 -0
  370. package/themes/webservy/form/src/form-group/form-group.scss +42 -0
  371. package/themes/webservy/form/src/form-item/form-item.scss +25 -0
  372. package/themes/webservy/index.scss +43 -0
  373. package/themes/webservy/info/index.scss +3 -0
  374. package/themes/webservy/info/src/info/info.scss +5 -0
  375. package/themes/webservy/info/src/info-column/info-column.scss +5 -0
  376. package/themes/webservy/info/src/info-field/info-field.scss +5 -0
  377. package/themes/webservy/input/index.scss +1 -0
  378. package/themes/webservy/input/src/input/input.scss +23 -0
  379. package/themes/webservy/input-number/index.scss +1 -0
  380. package/themes/webservy/input-number/src/input-number/input-number.scss +27 -0
  381. package/themes/webservy/loader/index.scss +1 -0
  382. package/themes/webservy/loader/src/loader/loader.scss +10 -0
  383. package/themes/webservy/map/index.scss +1 -0
  384. package/themes/webservy/map/src/map/map.scss +1 -0
  385. package/themes/webservy/modal/index.scss +1 -0
  386. package/themes/webservy/modal/src/modal/modal.scss +23 -0
  387. package/themes/webservy/notification/index.scss +1 -0
  388. package/themes/webservy/notification/src/notification/notification.scss +11 -0
  389. package/themes/webservy/paginator/index.scss +1 -0
  390. package/themes/webservy/paginator/src/paginator/paginator.scss +5 -0
  391. package/themes/webservy/popover/index.scss +1 -0
  392. package/themes/webservy/popover/src/popover/popover.scss +131 -0
  393. package/themes/webservy/preview/index.scss +4 -0
  394. package/themes/webservy/preview/src/preview-image/preview-image.scss +5 -0
  395. package/themes/webservy/preview/src/preview-modal/preview-modal.scss +39 -0
  396. package/themes/webservy/preview/src/preview-plain/preview-plain.scss +9 -0
  397. package/themes/webservy/preview/src/preview-video/preview-video.scss +5 -0
  398. package/themes/webservy/radio/index.scss +2 -0
  399. package/themes/webservy/radio/src/radio/radio.scss +31 -0
  400. package/themes/webservy/radio/src/radio-group/radio-group.scss +1 -0
  401. package/themes/webservy/rating/index.scss +1 -0
  402. package/themes/webservy/rating/src/rating/rating.scss +14 -0
  403. package/themes/webservy/resizer/index.scss +1 -0
  404. package/themes/webservy/resizer/src/resizer/resizer.scss +5 -0
  405. package/themes/webservy/root/helpers.scss +41 -0
  406. package/themes/webservy/root/image/angle-down-shadow.svg +3 -0
  407. package/themes/webservy/root/image/angle-down.svg +3 -0
  408. package/themes/webservy/root/image/angle-left-shadow.svg +3 -0
  409. package/themes/webservy/root/image/angle-left.svg +3 -0
  410. package/themes/webservy/root/image/angle-right-shadow.svg +3 -0
  411. package/themes/webservy/root/image/angle-right.svg +3 -0
  412. package/themes/webservy/root/image/angle-up-shadow.svg +3 -0
  413. package/themes/webservy/root/image/angle-up.svg +3 -0
  414. package/themes/webservy/root/image/empty-ufo.svg +8 -0
  415. package/themes/webservy/root/image/empty.svg +10 -0
  416. package/themes/webservy/root/image/star.svg +5 -0
  417. package/themes/webservy/root/vars/colors-dark-bluish.scss +461 -0
  418. package/themes/webservy/root/vars/colors-dark.scss +461 -0
  419. package/themes/webservy/root/vars/colors-light-bluish.scss +483 -0
  420. package/themes/webservy/root/vars/colors-light.scss +483 -0
  421. package/themes/webservy/root/vars/sizes-default.scss +101 -0
  422. package/themes/webservy/scrollbar/index.scss +1 -0
  423. package/themes/webservy/scrollbar/src/scrollbar/scrollbar.scss +7 -0
  424. package/themes/webservy/select/index.scss +2 -0
  425. package/themes/webservy/select/src/select/select.scss +28 -0
  426. package/themes/webservy/select/src/select-option/select-option.scss +1 -0
  427. package/themes/webservy/slider/index.scss +1 -0
  428. package/themes/webservy/slider/src/slider/slider.scss +30 -0
  429. package/themes/webservy/switch/index.scss +1 -0
  430. package/themes/webservy/switch/src/switch/switch.scss +19 -0
  431. package/themes/webservy/table/index.scss +4 -0
  432. package/themes/webservy/table/src/table/table.scss +14 -0
  433. package/themes/webservy/table/src/table-cell/table-cell.scss +34 -0
  434. package/themes/webservy/table/src/table-column/table-column.scss +31 -0
  435. package/themes/webservy/table/src/table-filter/table-filter.scss +1 -0
  436. package/themes/webservy/tabs/index.scss +2 -0
  437. package/themes/webservy/tabs/src/tabs/tabs.scss +9 -0
  438. package/themes/webservy/tabs/src/tabs-item/tabs-item.scss +23 -0
  439. package/themes/webservy/tags/index.scss +2 -0
  440. package/themes/webservy/tags/src/tags/tags.scss +1 -0
  441. package/themes/webservy/tags/src/tags-item/tags-item.scss +17 -0
  442. package/themes/webservy/textarea/index.scss +1 -0
  443. package/themes/webservy/textarea/src/textarea/textarea.scss +14 -0
  444. package/themes/webservy/timepicker/index.scss +2 -0
  445. package/themes/webservy/timepicker/src/timepicker/timepicker.scss +40 -0
  446. package/themes/webservy/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
  447. package/themes/webservy/transfer/index.scss +1 -0
  448. package/themes/webservy/transfer/src/transfer/transfer.scss +24 -0
  449. package/themes/webservy/virtualscroller/index.scss +1 -0
  450. package/themes/webservy/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
  451. package/dist/themes/dark.css +0 -1
  452. package/dist/themes/glossy.dark.css +0 -1
  453. package/dist/themes/glossy.light.css +0 -1
  454. package/dist/themes/light.css +0 -1
  455. package/src/alert/src/alert/alert.js +0 -133
  456. package/src/notification/src/notification/notification.js +0 -165
  457. package/src/root/image/empty-default.svg +0 -30
  458. package/src/root/image/empty-space.svg +0 -34
  459. package/src/root/image/star-default.svg +0 -10
  460. package/src/scrollbar/src/scrollbar-next/scrollbar-next.jsx +0 -640
  461. package/src/scrollbar/src/scrollbar-next/scrollbar-next.scss +0 -148
  462. package/themes/glossy/button/index.scss +0 -2
  463. package/themes/glossy/button/src/button/button.scss +0 -116
  464. package/themes/glossy/button/src/button-group/button-group.scss +0 -1
  465. package/themes/glossy/index-dark.scss +0 -3
  466. package/themes/glossy/index-light.scss +0 -3
  467. package/themes/glossy/index.scss +0 -43
  468. package/themes/glossy/root/image/empty-default.svg +0 -30
  469. package/themes/glossy/root/image/empty-space.svg +0 -34
  470. package/themes/glossy/root/image/star-default.svg +0 -10
  471. package/themes/glossy/root/image/test.svg +0 -1
  472. package/themes/glossy/root/vars-dark.scss +0 -234
  473. package/themes/glossy/root/vars-light.scss +0 -234
  474. package/themes/glossy/root/vars.scss +0 -233
  475. package/themes/macos/alert/index.scss +0 -1
  476. package/themes/macos/alert/src/alert/alert.scss +0 -27
  477. package/themes/macos/button/index.scss +0 -2
  478. package/themes/macos/button/src/button/button.scss +0 -98
  479. package/themes/macos/button/src/button-group/button-group.scss +0 -1
  480. package/themes/macos/cascader/index.scss +0 -2
  481. package/themes/macos/cascader/src/cascader/cascader.scss +0 -47
  482. package/themes/macos/cascader/src/cascader-panel/cascader-panel.scss +0 -14
  483. package/themes/macos/checkbox/index.scss +0 -2
  484. package/themes/macos/checkbox/src/checkbox/checkbox.scss +0 -45
  485. package/themes/macos/checkbox/src/checkbox-group/checkbox-group.scss +0 -1
  486. package/themes/macos/collapse/index.scss +0 -2
  487. package/themes/macos/collapse/src/collapse/collapse.scss +0 -22
  488. package/themes/macos/collapse/src/collapse-item/collapse-item.scss +0 -22
  489. package/themes/macos/confirm/index.scss +0 -1
  490. package/themes/macos/confirm/src/confirm/confirm.scss +0 -14
  491. package/themes/macos/datepicker/index.scss +0 -2
  492. package/themes/macos/datepicker/src/datepicker/datepicker.scss +0 -51
  493. package/themes/macos/datepicker/src/datepicker-panel/datepicker-panel.scss +0 -45
  494. package/themes/macos/datetimepicker/index.scss +0 -1
  495. package/themes/macos/datetimepicker/src/datetimepicker/datetimepicker.scss +0 -69
  496. package/themes/macos/demo/index.scss +0 -1
  497. package/themes/macos/demo/src/demo/demo.scss +0 -22
  498. package/themes/macos/draggable/index.scss +0 -9
  499. package/themes/macos/draggable/src/draggrid/draggrid.scss +0 -14
  500. package/themes/macos/draggable/src/draggrid-item/draggrid-item.scss +0 -66
  501. package/themes/macos/draggable/src/draghandler/draghandler.scss +0 -15
  502. package/themes/macos/draggable/src/draglist/draglist.scss +0 -14
  503. package/themes/macos/draggable/src/draglist-item/draglist-item.scss +0 -73
  504. package/themes/macos/draggable/src/dropzone/dropzone.scss +0 -14
  505. package/themes/macos/drawer/index.scss +0 -1
  506. package/themes/macos/drawer/src/drawer/drawer.scss +0 -35
  507. package/themes/macos/durationpicker/index.scss +0 -1
  508. package/themes/macos/durationpicker/src/durationpicker/durationpicker.scss +0 -53
  509. package/themes/macos/empty/index.scss +0 -1
  510. package/themes/macos/empty/src/empty-icon/empty-icon.scss +0 -13
  511. package/themes/macos/file/index.scss +0 -1
  512. package/themes/macos/file/src/file/file.scss +0 -39
  513. package/themes/macos/form/index.scss +0 -4
  514. package/themes/macos/form/src/form/form.scss +0 -1
  515. package/themes/macos/form/src/form-frame/form-frame.scss +0 -34
  516. package/themes/macos/form/src/form-group/form-group.scss +0 -43
  517. package/themes/macos/form/src/form-item/form-item.scss +0 -29
  518. package/themes/macos/index-dark.scss +0 -3
  519. package/themes/macos/index-light.scss +0 -3
  520. package/themes/macos/index.scss +0 -41
  521. package/themes/macos/info/index.scss +0 -3
  522. package/themes/macos/info/src/info/info.scss +0 -5
  523. package/themes/macos/info/src/info-column/info-column.scss +0 -5
  524. package/themes/macos/info/src/info-field/info-field.scss +0 -5
  525. package/themes/macos/input/index.scss +0 -1
  526. package/themes/macos/input/src/input/input.scss +0 -39
  527. package/themes/macos/input-number/index.scss +0 -1
  528. package/themes/macos/input-number/src/input-number/input-number.scss +0 -48
  529. package/themes/macos/loader/index.scss +0 -1
  530. package/themes/macos/loader/src/loader/loader.scss +0 -22
  531. package/themes/macos/map/index.scss +0 -1
  532. package/themes/macos/map/src/map/map.scss +0 -1
  533. package/themes/macos/modal/index.scss +0 -1
  534. package/themes/macos/modal/src/modal/modal.scss +0 -35
  535. package/themes/macos/notification/index.scss +0 -1
  536. package/themes/macos/notification/src/notification/notification.scss +0 -25
  537. package/themes/macos/paginator/index.scss +0 -1
  538. package/themes/macos/paginator/src/paginator/paginator.scss +0 -5
  539. package/themes/macos/popover/index.scss +0 -1
  540. package/themes/macos/popover/src/popover/popover.scss +0 -84
  541. package/themes/macos/preview/index.scss +0 -1
  542. package/themes/macos/preview/src/preview-modal/preview-modal.scss +0 -28
  543. package/themes/macos/radio/index.scss +0 -2
  544. package/themes/macos/radio/src/radio/radio.scss +0 -46
  545. package/themes/macos/radio/src/radio-group/radio-group.scss +0 -1
  546. package/themes/macos/rating/index.scss +0 -1
  547. package/themes/macos/rating/src/rating/rating.scss +0 -19
  548. package/themes/macos/resizer/index.scss +0 -1
  549. package/themes/macos/resizer/src/resizer/resizer.scss +0 -5
  550. package/themes/macos/root/image/empty-default.svg +0 -30
  551. package/themes/macos/root/image/empty-space.svg +0 -34
  552. package/themes/macos/root/image/star-default.svg +0 -10
  553. package/themes/macos/root/vars-dark.scss +0 -234
  554. package/themes/macos/root/vars-light.scss +0 -234
  555. package/themes/macos/root/vars.scss +0 -233
  556. package/themes/macos/scrollbar/index.scss +0 -1
  557. package/themes/macos/scrollbar/src/scrollbar/scrollbar.scss +0 -7
  558. package/themes/macos/select/index.scss +0 -2
  559. package/themes/macos/select/src/select/select.scss +0 -49
  560. package/themes/macos/select/src/select-option/select-option.scss +0 -1
  561. package/themes/macos/slider/index.scss +0 -1
  562. package/themes/macos/slider/src/slider/slider.scss +0 -41
  563. package/themes/macos/switch/index.scss +0 -1
  564. package/themes/macos/switch/src/switch/switch.scss +0 -30
  565. package/themes/macos/table/index.scss +0 -4
  566. package/themes/macos/table/src/table/table.scss +0 -20
  567. package/themes/macos/table/src/table-cell/table-cell.scss +0 -51
  568. package/themes/macos/table/src/table-filter/table-filter.scss +0 -1
  569. package/themes/macos/tabs/index.scss +0 -2
  570. package/themes/macos/tabs/src/tabs/tabs.scss +0 -39
  571. package/themes/macos/tabs/src/tabs-item/tabs-item.scss +0 -19
  572. package/themes/macos/tags/index.scss +0 -2
  573. package/themes/macos/tags/src/tags/tags.scss +0 -1
  574. package/themes/macos/tags/src/tags-item/tags-item.scss +0 -32
  575. package/themes/macos/textarea/index.scss +0 -1
  576. package/themes/macos/textarea/src/textarea/textarea.scss +0 -31
  577. package/themes/macos/timepicker/index.scss +0 -2
  578. package/themes/macos/timepicker/src/timepicker/timepicker.scss +0 -51
  579. package/themes/macos/timepicker/src/timepicker-panel/timepicker-panel.scss +0 -28
  580. package/themes/macos/transfer/index.scss +0 -1
  581. package/themes/macos/transfer/src/transfer/transfer.scss +0 -18
  582. package/themes/macos/virtualscroller/index.scss +0 -1
  583. package/themes/macos/virtualscroller/src/virtualscroller/virtualscroller.scss +0 -1
@@ -1,14 +1,148 @@
1
- @use 'sass:map';
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 ease-out;
7
+ transition: opacity 0.1s;
8
+ font-size: size('base-fnt');
9
9
  }
10
10
 
11
- .n-popover:not(.n-ready) {
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
- @each $suffix, $values in $form {
103
-
104
- $-popover-font: map.get($values, 'font');
105
- $-popover-size: map.get($values, 'size');
106
- $-popover-radius: map.get($values, 'radius');
107
- $-popover-ratio: map.get($values, 'ratio');
108
-
109
- .n-popover--#{$suffix} {
110
- font-size: $-popover-font;
111
- }
112
-
113
- .n-popover--#{$suffix} .n-popover__frame {
114
- border-radius: $-popover-radius;
115
- }
116
-
117
- $-popover-padding: $-popover-size * $-popover-ratio;
118
-
119
- .n-popover--#{$suffix} .n-popover__header {
120
- padding: $-popover-padding $-popover-padding * 1.2;
121
- }
122
-
123
- .n-popover--#{$suffix} .n-popover__body {
124
- padding: $-popover-padding $-popover-padding * 1.2;
125
- }
126
-
127
- .n-popover--#{$suffix} .n-popover__footer {
128
- padding: $-popover-padding $-popover-padding * 1.2;
129
- }
130
-
131
- .n-popover-group.n-popover-group--#{$suffix} {
132
- font-size: $-popover-font - 2;
133
- padding: $-popover-padding * 0.8 $-popover-padding * 1.2 $-popover-padding * 0.4;
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
  }
@@ -4,11 +4,51 @@ import PreviewImage from "./src/preview-image/preview-image.jsx";
4
4
  import PreviewVideo from "./src/preview-video/preview-video.jsx";
5
5
  import PreviewModal from "./src/preview-modal/preview-modal.jsx";
6
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
+ };
30
+
7
31
  export default function (App) {
8
- App.component(Preview.name, Preview);
9
- App.component(PreviewModal.name, PreviewModal);
10
- App.component(PreviewPlain.name, PreviewPlain);
11
- App.component(PreviewImage.name, PreviewImage);
12
- App.component(PreviewVideo.name, PreviewVideo);
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
+
13
53
  }
14
54
 
@@ -1,5 +1,5 @@
1
- @import "./src/preview/preview";
2
- @import "./src/preview-modal/preview-modal";
3
- @import "./src/preview-plain/preview-plain";
4
- @import "./src/preview-image/preview-image";
5
- @import "./src/preview-video/preview-video";
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";
@@ -1,32 +1,34 @@
1
1
  import { Any, Arr, Obj, Dom } from "@kizmann/pico-js";
2
2
 
3
- window.NPreviewCacheGroups = {};
3
+ window.PreviewGroups = {};
4
4
 
5
- export class NPreviewHandler
5
+ export class PreviewHandler
6
6
  {
7
- current = null;
7
+ static alias = 'PreviewHandler';
8
+
9
+ static current = null;
8
10
 
9
11
  static append(item)
10
12
  {
11
- if ( !window.NPreviewCacheGroups[item.group] ) {
12
- window.NPreviewCacheGroups[item.group] = {};
13
+ if ( !window.PreviewGroups[item.group] ) {
14
+ window.PreviewGroups[item.group] = {};
13
15
  }
14
16
 
15
- window.NPreviewCacheGroups[item.group][item.uid] = item;
17
+ window.PreviewGroups[item.group][item.uid] = item;
16
18
  }
17
19
 
18
20
  static remove(item)
19
21
  {
20
- delete window.NPreviewCacheGroups[item.group][item.uid];
22
+ delete window.PreviewGroups[item.group][item.uid];
21
23
  }
22
24
 
23
25
  static get(group)
24
26
  {
25
- if ( !window.NPreviewCacheGroups[group] ) {
26
- window.NPreviewCacheGroups[group] = {};
27
+ if ( !window.PreviewGroups[group] ) {
28
+ window.PreviewGroups[group] = {};
27
29
  }
28
30
 
29
- return Arr.sort(window.NPreviewCacheGroups[group], 'index');
31
+ return Arr.sort(window.PreviewGroups[group], 'index');
30
32
  }
31
33
 
32
34
  static next()
@@ -35,7 +37,7 @@ export class NPreviewHandler
35
37
  return null;
36
38
  }
37
39
 
38
- let items = NPreviewHandler.get(this.current.group);
40
+ let items = this.get(this.current.group);
39
41
 
40
42
  let index = Arr.findIndex(items, {
41
43
  uid: this.current.uid
@@ -47,7 +49,7 @@ export class NPreviewHandler
47
49
  next = Arr.get(items, index + 1);
48
50
  }
49
51
 
50
- return NPreviewHandler.switch(next);
52
+ return this.switch(next);
51
53
  }
52
54
 
53
55
  static prev()
@@ -56,7 +58,7 @@ export class NPreviewHandler
56
58
  return null;
57
59
  }
58
60
 
59
- let items = NPreviewHandler.get(this.current.group);
61
+ let items = this.get(this.current.group);
60
62
 
61
63
  let index = Arr.findIndex(items, {
62
64
  uid: this.current.uid
@@ -68,7 +70,7 @@ export class NPreviewHandler
68
70
  prev = Arr.get(items, index - 1);
69
71
  }
70
72
 
71
- return NPreviewHandler.switch(prev);
73
+ return this.switch(prev);
72
74
  }
73
75
 
74
76
  static create()
@@ -79,8 +81,15 @@ export class NPreviewHandler
79
81
  return el;
80
82
  }
81
83
 
84
+ let classList = [
85
+ 'n-preview-modal',
86
+ 'n-preview-modal--md',
87
+ 'n-preview-modal--primary',
88
+ 'n-theme--dark'
89
+ ];
90
+
82
91
  let el = Dom.make('div', {
83
- classList: 'n-preview-modal'
92
+ classList: classList.join(' ')
84
93
  });
85
94
 
86
95
  el.attr('data-preview', 'nano');
@@ -91,7 +100,7 @@ export class NPreviewHandler
91
100
  });
92
101
 
93
102
  close.on('click', () => {
94
- NPreviewHandler.close()
103
+ this.close()
95
104
  });
96
105
 
97
106
  close.appendTo(el);
@@ -102,7 +111,7 @@ export class NPreviewHandler
102
111
  });
103
112
 
104
113
  prev.on('click', () => {
105
- NPreviewHandler.prev()
114
+ this.prev()
106
115
  });
107
116
 
108
117
  prev.appendTo(el);
@@ -113,7 +122,7 @@ export class NPreviewHandler
113
122
  });
114
123
 
115
124
  next.on('click', () => {
116
- NPreviewHandler.next()
125
+ this.next()
117
126
  });
118
127
 
119
128
  next.appendTo(el);
@@ -125,24 +134,23 @@ export class NPreviewHandler
125
134
 
126
135
  static open(item)
127
136
  {
128
- let el = NPreviewHandler.create();
129
-
130
- el.css({
131
- 'z-index': window.zIndex++
132
- });
137
+ let el = this.create();
133
138
 
134
139
  let keydownFn = (e) => {
135
140
 
136
141
  if ( e.keyCode === 27 ) {
137
- return NPreviewHandler.close();
142
+ e.stopPropagation();
143
+ return this.close();
138
144
  }
139
145
 
140
146
  if ( e.keyCode === 37 ) {
141
- return NPreviewHandler.prev();
147
+ e.stopPropagation();
148
+ return this.prev();
142
149
  }
143
150
 
144
151
  if ( e.keyCode === 39 ) {
145
- return NPreviewHandler.next();
152
+ e.stopPropagation();
153
+ return this.next();
146
154
  }
147
155
 
148
156
  }
@@ -151,22 +159,26 @@ export class NPreviewHandler
151
159
  uid: 'n-preview-modal'
152
160
  });
153
161
 
154
- NPreviewHandler.switch(item);
162
+ this.switch(item);
163
+
164
+ if ( this.get(item.group).length > 1 ) {
165
+ el.addClass('n-multi');
166
+ }
155
167
 
156
168
  el.addClass('n-ready');
157
169
  }
158
170
 
159
171
  static close()
160
172
  {
161
- let el = NPreviewHandler.create();
173
+ let el = this.create();
162
174
 
163
175
  Dom.find(window).off('keydown', null, {
164
176
  uid: 'n-preview-modal'
165
177
  });
166
178
 
167
- NPreviewHandler.switch(null);
179
+ this.switch(null);
168
180
 
169
- el.removeClass('n-ready');
181
+ el.removeClass(['n-ready', 'n-multi']);
170
182
  }
171
183
 
172
184
  static switch(item)
@@ -186,8 +198,8 @@ export class NPreviewHandler
186
198
 
187
199
  }
188
200
 
189
- export default { NPreviewHandler }
201
+ if ( ! window.PreviewHandler ) {
202
+ window.PreviewHandler = PreviewHandler;
203
+ }
190
204
 
191
- if ( ! window.NPreviewHandler ) {
192
- window.NPreviewHandler = NPreviewHandler;
193
- }
205
+ export default PreviewHandler;
@@ -1,41 +1,25 @@
1
1
  import { Any, Arr, Dom, Obj } from "@kizmann/pico-js";
2
2
 
3
- window.NPreviewMimes = {
4
- image: [
5
- 'jpg', 'jpeg', 'gif', 'svg', 'png', 'bmp'
6
- ],
7
- video: [
8
- 'mp4', 'webm', 'mov'
9
- ],
10
- audio: [
11
- 'mp3', 'aac',
12
- ],
13
- font: [
14
- 'woff', 'ttf', 'otf'
15
- ],
16
- text: [
17
- 'csv', 'txt', 'html'
18
- ],
19
- application: [
20
- 'pdf', 'doc', 'xls'
21
- ]
22
- };
23
-
24
- export class NPreviewHelper
3
+ export class PreviewHelper
25
4
  {
26
- static getExtension(source, fallback = 'plain')
5
+ static alias = 'PreviewHelper';
6
+
7
+ static getExt(source, fallback = 'plain')
27
8
  {
28
- let extension = source.replace(/^.*?\.([^.?]+)(\?.*?)?$/,
29
- '$1');
9
+ let match = source.match(/\.([^.?]+)(\?.*?)?$/);
30
10
 
31
- if ( Any.isEmpty(extension) ) {
11
+ if ( ! match ) {
32
12
  return fallback;
33
13
  }
34
14
 
35
- return extension;
15
+ if ( Any.isEmpty(match[1]) ) {
16
+ return fallback;
17
+ }
18
+
19
+ return match[1];
36
20
  }
37
21
 
38
- static getMime(source, fallback = 'text')
22
+ static getType(source, fallback = 'text')
39
23
  {
40
24
  let file = Obj.get(source, 'name', source);
41
25
 
@@ -43,24 +27,24 @@ export class NPreviewHelper
43
27
  return fallback;
44
28
  }
45
29
 
46
- let extension = NPreviewHelper.getExtension(file);
30
+ let extension = PreviewHelper.getExt(file);
47
31
 
48
- if ( NPreviewHelper.getYoutubeKey(file) ) {
32
+ if ( PreviewHelper.getYoutubeKey(file) ) {
49
33
  return 'video';
50
34
  }
51
35
 
52
- if ( NPreviewHelper.getVimeoKey(file) ) {
36
+ if ( PreviewHelper.getVimeoKey(file) ) {
53
37
  return 'video';
54
38
  }
55
39
 
56
- Obj.each(window.NPreviewMimes, (exts, key) => {
40
+ Obj.each(window.PreviewMimes, (exts, key) => {
57
41
  if ( Arr.has(exts, extension) ) fallback = key;
58
42
  });
59
43
 
60
44
  return fallback;
61
45
  }
62
46
 
63
- static getFullMime(source, fallback = 'text/plain')
47
+ static getMime(source, fallback = 'text/plain')
64
48
  {
65
49
  let file = Obj.get(source, 'name', source);
66
50
 
@@ -68,15 +52,15 @@ export class NPreviewHelper
68
52
  return fallback;
69
53
  }
70
54
 
71
- if ( NPreviewHelper.getYoutubeKey(source) ) {
55
+ if ( PreviewHelper.getYoutubeKey(source) ) {
72
56
  return 'video/youtube';
73
57
  }
74
58
 
75
- if ( NPreviewHelper.getVimeoKey(source) ) {
59
+ if ( PreviewHelper.getVimeoKey(source) ) {
76
60
  return 'video/vimeo';
77
61
  }
78
62
 
79
- return NPreviewHelper.getMime(file) + '/' + NPreviewHelper.getExtension(file);
63
+ return PreviewHelper.getType(file) + '/' + PreviewHelper.getExt(file);
80
64
  }
81
65
 
82
66
  static getVimeoKey(source, fallback = null)
@@ -135,8 +119,8 @@ export class NPreviewHelper
135
119
 
136
120
  }
137
121
 
138
- export default { NPreviewHelper }
122
+ if ( ! window[PreviewHelper.alias] ) {
123
+ window[PreviewHelper.alias] = PreviewHelper;
124
+ }
139
125
 
140
- if ( ! window.NPreviewHelper ) {
141
- window.NPreviewHelper = NPreviewHelper;
142
- }
126
+ export default PreviewHelper;