@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.
Files changed (569) 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 +30 -31
  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 +43 -9
  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 +4 -4
  57. package/src/draggable/src/draglist/draglist.scss +3 -20
  58. package/src/draggable/src/draglist-item/draglist-item.jsx +5 -2
  59. package/src/draggable/src/draglist-item/draglist-item.scss +15 -36
  60. package/src/draggable/src/dropzone/dropzone.scss +6 -19
  61. package/src/drawer/index.scss +1 -1
  62. package/src/drawer/src/drawer/drawer.jsx +6 -3
  63. package/src/drawer/src/drawer/drawer.scss +27 -31
  64. package/src/durationpicker/index.scss +1 -1
  65. package/src/durationpicker/src/durationpicker/durationpicker.jsx +3 -3
  66. package/src/durationpicker/src/durationpicker/durationpicker.scss +18 -55
  67. package/src/empty/index.scss +1 -1
  68. package/src/empty/src/empty-icon/empty-icon.jsx +1 -1
  69. package/src/empty/src/empty-icon/empty-icon.scss +13 -26
  70. package/src/file/index.scss +1 -1
  71. package/src/file/src/file/file.jsx +9 -0
  72. package/src/file/src/file/file.scss +2 -2
  73. package/src/form/index.js +2 -0
  74. package/src/form/index.scss +5 -4
  75. package/src/form/src/form/form-rules.mjs +182 -0
  76. package/src/form/src/form/form.jsx +108 -4
  77. package/src/form/src/form/form.scss +33 -1
  78. package/src/form/src/form-bag/form-bag.jsx +90 -0
  79. package/src/form/src/form-bag/form-bag.scss +59 -0
  80. package/src/form/src/form-frame/form-frame.jsx +17 -9
  81. package/src/form/src/form-frame/form-frame.scss +25 -38
  82. package/src/form/src/form-group/form-group.jsx +24 -6
  83. package/src/form/src/form-group/form-group.scss +85 -66
  84. package/src/form/src/form-item/form-item.jsx +79 -68
  85. package/src/form/src/form-item/form-item.scss +23 -32
  86. package/src/grid/index.scss +1 -0
  87. package/src/grid/src/grid/grid.scss +146 -0
  88. package/src/index.js +4 -1
  89. package/src/index.scss +45 -39
  90. package/src/info/index.scss +3 -3
  91. package/src/info/src/info/info.jsx +1 -1
  92. package/src/info/src/info/info.scss +7 -26
  93. package/src/info/src/info-column/info-column.scss +2 -16
  94. package/src/info/src/info-field/info-field.scss +1 -1
  95. package/src/input/index.scss +1 -1
  96. package/src/input/src/input/input.jsx +1 -1
  97. package/src/input/src/input/input.scss +15 -40
  98. package/src/input-number/index.scss +1 -1
  99. package/src/input-number/src/input-number/input-number.jsx +39 -23
  100. package/src/input-number/src/input-number/input-number.scss +14 -59
  101. package/src/loader/index.scss +1 -1
  102. package/src/loader/src/loader/loader.scss +16 -29
  103. package/src/map/index.scss +1 -1
  104. package/src/map/src/map/map.scss +1 -2
  105. package/src/modal/index.scss +1 -1
  106. package/src/modal/src/modal/modal.jsx +7 -4
  107. package/src/modal/src/modal/modal.scss +27 -40
  108. package/src/notification/index.js +23 -3
  109. package/src/notification/index.scss +1 -1
  110. package/src/notification/src/notification/notification-element.mjs +74 -0
  111. package/src/notification/src/notification/notification-handler.mjs +75 -0
  112. package/src/notification/src/notification/notification.scss +13 -25
  113. package/src/paginator/index.scss +1 -1
  114. package/src/paginator/src/paginator/paginator.jsx +24 -29
  115. package/src/paginator/src/paginator/paginator.scss +39 -44
  116. package/src/popover/index.js +20 -3
  117. package/src/popover/index.scss +1 -1
  118. package/src/popover/src/popover/popover-element.mjs +578 -0
  119. package/src/popover/src/popover/popover-handler.mjs +116 -0
  120. package/src/popover/src/popover/popover-helper.mjs +75 -0
  121. package/src/popover/src/popover/popover.jsx +78 -550
  122. package/src/popover/src/popover/popover.scss +186 -78
  123. package/src/preview/index.js +46 -4
  124. package/src/preview/index.scss +5 -4
  125. package/src/preview/src/preview/preview-handler.mjs +205 -0
  126. package/src/preview/src/preview/preview-helper.mjs +126 -0
  127. package/src/preview/src/preview/preview.jsx +87 -117
  128. package/src/preview/src/preview/preview.scss +29 -2
  129. package/src/preview/src/preview-image/preview-image.scss +1 -3
  130. package/src/preview/src/preview-modal/preview-modal.jsx +126 -0
  131. package/src/preview/src/preview-modal/preview-modal.scss +69 -0
  132. package/src/preview/src/preview-plain/preview-plain.jsx +32 -20
  133. package/src/preview/src/preview-plain/preview-plain.scss +5 -3
  134. package/src/preview/src/preview-video/preview-video.jsx +3 -60
  135. package/src/preview/src/preview-video/preview-video.scss +1 -2
  136. package/src/radio/index.scss +2 -2
  137. package/src/radio/src/radio/radio.scss +13 -32
  138. package/src/radio/src/radio-group/radio-group.scss +18 -28
  139. package/src/rating/index.scss +1 -1
  140. package/src/rating/src/rating/rating.scss +15 -33
  141. package/src/resizer/index.js +3 -1
  142. package/src/resizer/index.scss +1 -1
  143. package/src/resizer/src/resizer/resizer-next.jsx +556 -0
  144. package/src/resizer/src/resizer/resizer.scss +1 -1
  145. package/src/root/helpers.scss +41 -0
  146. package/src/root/image/angle-down-shadow.svg +3 -0
  147. package/src/root/image/angle-down.svg +3 -0
  148. package/src/root/image/angle-left-shadow.svg +3 -0
  149. package/src/root/image/angle-left.svg +3 -0
  150. package/src/root/image/angle-right-shadow.svg +3 -0
  151. package/src/root/image/angle-right.svg +3 -0
  152. package/src/root/image/angle-up-shadow.svg +3 -0
  153. package/src/root/image/angle-up.svg +3 -0
  154. package/src/root/image/empty-ufo.svg +8 -0
  155. package/src/root/image/empty.svg +10 -0
  156. package/src/root/image/star.svg +5 -0
  157. package/src/root/vars.scss +5 -3
  158. package/src/scrollbar/index.scss +1 -1
  159. package/src/scrollbar/src/scrollbar/scrollbar.jsx +213 -376
  160. package/src/scrollbar/src/scrollbar/scrollbar.scss +23 -19
  161. package/src/select/index.scss +2 -2
  162. package/src/select/src/select/select.jsx +30 -26
  163. package/src/select/src/select/select.scss +49 -104
  164. package/src/select/src/select-option/select-option.scss +1 -1
  165. package/src/slider/index.scss +1 -1
  166. package/src/slider/src/slider/slider.jsx +5 -3
  167. package/src/slider/src/slider/slider.scss +37 -46
  168. package/src/switch/index.scss +1 -1
  169. package/src/switch/src/switch/switch.scss +17 -44
  170. package/src/table/index.scss +4 -4
  171. package/src/table/src/table/table.jsx +9 -9
  172. package/src/table/src/table/table.scss +19 -25
  173. package/src/table/src/table-cell/table-cell.scss +7 -18
  174. package/src/table/src/table-cell/types/table-cell-image.jsx +9 -3
  175. package/src/table/src/table-column/table-column.jsx +12 -24
  176. package/src/table/src/table-column/table-column.scss +14 -13
  177. package/src/table/src/table-filter/table-filter.jsx +4 -4
  178. package/src/table/src/table-filter/table-filter.scss +10 -4
  179. package/src/tabs/index.scss +2 -2
  180. package/src/tabs/src/tabs/tabs.scss +20 -29
  181. package/src/tabs/src/tabs-item/tabs-item.jsx +15 -7
  182. package/src/tabs/src/tabs-item/tabs-item.scss +17 -25
  183. package/src/tags/index.scss +2 -2
  184. package/src/tags/src/tags/tags.jsx +1 -0
  185. package/src/tags/src/tags/tags.scss +6 -2
  186. package/src/tags/src/tags-item/tags-item.jsx +8 -9
  187. package/src/tags/src/tags-item/tags-item.scss +10 -31
  188. package/src/textarea/index.scss +1 -1
  189. package/src/textarea/src/textarea/textarea.jsx +2 -0
  190. package/src/textarea/src/textarea/textarea.scss +6 -23
  191. package/src/timepicker/index.scss +2 -2
  192. package/src/timepicker/src/timepicker/timepicker.jsx +6 -3
  193. package/src/timepicker/src/timepicker/timepicker.scss +21 -53
  194. package/src/timepicker/src/timepicker-panel/timepicker-panel.jsx +15 -3
  195. package/src/timepicker/src/timepicker-panel/timepicker-panel.scss +34 -41
  196. package/src/tooltip/index.scss +1 -0
  197. package/src/tooltip/src/tooltip/tooltip.scss +116 -0
  198. package/src/transfer/index.scss +1 -1
  199. package/src/transfer/src/transfer/transfer.jsx +2 -2
  200. package/src/transfer/src/transfer/transfer.scss +33 -53
  201. package/src/virtualscroller/index.scss +1 -1
  202. package/src/virtualscroller/src/virtualscroller/virtualscroller.jsx +71 -44
  203. package/src/virtualscroller/src/virtualscroller/virtualscroller.scss +4 -2
  204. package/themes/default/alert/index.scss +1 -0
  205. package/themes/default/alert/src/alert/alert.scss +29 -0
  206. package/themes/default/button/index.scss +2 -0
  207. package/themes/default/button/src/button/button.scss +87 -0
  208. package/themes/default/button/src/button-group/button-group.scss +1 -0
  209. package/themes/default/cascader/index.scss +2 -0
  210. package/themes/default/cascader/src/cascader/cascader.scss +31 -0
  211. package/themes/default/cascader/src/cascader-panel/cascader-panel.scss +21 -0
  212. package/themes/default/chart/index.scss +2 -0
  213. package/themes/default/chart/src/chart-donut/chart-donut.scss +22 -0
  214. package/themes/default/chart/src/chart-item/chart-item.scss +11 -0
  215. package/themes/default/checkbox/index.scss +2 -0
  216. package/themes/default/checkbox/src/checkbox/checkbox.scss +26 -0
  217. package/themes/default/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
  218. package/themes/default/collapse/index.scss +2 -0
  219. package/themes/default/collapse/src/collapse/collapse.scss +14 -0
  220. package/themes/default/collapse/src/collapse-item/collapse-item.scss +14 -0
  221. package/themes/default/confirm/index.scss +1 -0
  222. package/themes/default/confirm/src/confirm/confirm.scss +35 -0
  223. package/themes/default/datepicker/index.scss +2 -0
  224. package/themes/default/datepicker/src/datepicker/datepicker.scss +44 -0
  225. package/themes/default/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
  226. package/themes/default/datetimepicker/index.scss +1 -0
  227. package/themes/default/datetimepicker/src/datetimepicker/datetimepicker.scss +51 -0
  228. package/themes/default/demo/index.scss +1 -0
  229. package/themes/default/demo/src/demo/demo.scss +34 -0
  230. package/themes/default/draggable/index.scss +9 -0
  231. package/themes/default/draggable/src/draggrid/draggrid.scss +5 -0
  232. package/themes/default/draggable/src/draggrid-item/draggrid-item.scss +52 -0
  233. package/themes/default/draggable/src/draghandler/draghandler.scss +15 -0
  234. package/themes/default/draggable/src/draglist/draglist.scss +5 -0
  235. package/themes/default/draggable/src/draglist-item/draglist-item.scss +56 -0
  236. package/themes/default/draggable/src/dropzone/dropzone.scss +5 -0
  237. package/themes/default/drawer/index.scss +1 -0
  238. package/themes/default/drawer/src/drawer/drawer.scss +25 -0
  239. package/themes/default/durationpicker/index.scss +1 -0
  240. package/themes/default/durationpicker/src/durationpicker/durationpicker.scss +39 -0
  241. package/themes/default/empty/index.scss +1 -0
  242. package/themes/default/empty/src/empty-icon/empty-icon.scss +17 -0
  243. package/themes/default/example.scss +29 -0
  244. package/themes/default/file/index.scss +1 -0
  245. package/themes/default/file/src/file/file.scss +1 -0
  246. package/themes/default/form/index.scss +4 -0
  247. package/themes/default/form/src/form/form.scss +17 -0
  248. package/themes/default/form/src/form-frame/form-frame.scss +25 -0
  249. package/themes/default/form/src/form-group/form-group.scss +42 -0
  250. package/themes/default/form/src/form-item/form-item.scss +25 -0
  251. package/themes/default/index.scss +43 -0
  252. package/themes/default/info/index.scss +3 -0
  253. package/themes/default/info/src/info/info.scss +5 -0
  254. package/themes/default/info/src/info-column/info-column.scss +5 -0
  255. package/themes/default/info/src/info-field/info-field.scss +5 -0
  256. package/themes/default/input/index.scss +1 -0
  257. package/themes/default/input/src/input/input.scss +27 -0
  258. package/themes/default/input-number/index.scss +1 -0
  259. package/themes/default/input-number/src/input-number/input-number.scss +30 -0
  260. package/themes/default/loader/index.scss +1 -0
  261. package/themes/default/loader/src/loader/loader.scss +10 -0
  262. package/themes/default/map/index.scss +1 -0
  263. package/themes/default/map/src/map/map.scss +1 -0
  264. package/themes/default/modal/index.scss +1 -0
  265. package/themes/default/modal/src/modal/modal.scss +25 -0
  266. package/themes/default/notification/index.scss +1 -0
  267. package/themes/default/notification/src/notification/notification.scss +11 -0
  268. package/themes/default/paginator/index.scss +1 -0
  269. package/themes/default/paginator/src/paginator/paginator.scss +5 -0
  270. package/themes/default/popover/index.scss +1 -0
  271. package/themes/default/popover/src/popover/popover.scss +131 -0
  272. package/themes/default/preview/index.scss +4 -0
  273. package/themes/default/preview/src/preview-image/preview-image.scss +5 -0
  274. package/themes/default/preview/src/preview-modal/preview-modal.scss +39 -0
  275. package/themes/default/preview/src/preview-plain/preview-plain.scss +9 -0
  276. package/themes/default/preview/src/preview-video/preview-video.scss +5 -0
  277. package/themes/default/radio/index.scss +2 -0
  278. package/themes/default/radio/src/radio/radio.scss +32 -0
  279. package/themes/default/radio/src/radio-group/radio-group.scss +1 -0
  280. package/themes/default/rating/index.scss +1 -0
  281. package/themes/default/rating/src/rating/rating.scss +14 -0
  282. package/themes/default/resizer/index.scss +1 -0
  283. package/themes/default/resizer/src/resizer/resizer.scss +5 -0
  284. package/themes/default/root/helpers.scss +41 -0
  285. package/themes/default/root/image/angle-down-shadow.svg +3 -0
  286. package/themes/default/root/image/angle-down.svg +3 -0
  287. package/themes/default/root/image/angle-left-shadow.svg +3 -0
  288. package/themes/default/root/image/angle-left.svg +3 -0
  289. package/themes/default/root/image/angle-right-shadow.svg +3 -0
  290. package/themes/default/root/image/angle-right.svg +3 -0
  291. package/themes/default/root/image/angle-up-shadow.svg +3 -0
  292. package/themes/default/root/image/angle-up.svg +3 -0
  293. package/themes/default/root/image/empty-ufo.svg +8 -0
  294. package/themes/default/root/image/empty.svg +10 -0
  295. package/themes/default/root/image/star.svg +5 -0
  296. package/themes/default/root/vars/colors-dark-bluish.scss +457 -0
  297. package/themes/default/root/vars/colors-dark.scss +457 -0
  298. package/themes/default/root/vars/colors-light-bluish.scss +479 -0
  299. package/themes/default/root/vars/colors-light.scss +479 -0
  300. package/themes/default/root/vars/sizes-default.scss +101 -0
  301. package/themes/default/scrollbar/index.scss +1 -0
  302. package/themes/default/scrollbar/src/scrollbar/scrollbar.scss +7 -0
  303. package/themes/default/select/index.scss +2 -0
  304. package/themes/default/select/src/select/select.scss +32 -0
  305. package/themes/default/select/src/select-option/select-option.scss +1 -0
  306. package/themes/default/slider/index.scss +1 -0
  307. package/themes/default/slider/src/slider/slider.scss +30 -0
  308. package/themes/default/switch/index.scss +1 -0
  309. package/themes/default/switch/src/switch/switch.scss +19 -0
  310. package/themes/default/table/index.scss +4 -0
  311. package/themes/default/table/src/table/table.scss +14 -0
  312. package/themes/default/table/src/table-cell/table-cell.scss +34 -0
  313. package/themes/{macos → default}/table/src/table-column/table-column.scss +9 -10
  314. package/themes/default/table/src/table-filter/table-filter.scss +1 -0
  315. package/themes/default/tabs/index.scss +2 -0
  316. package/themes/default/tabs/src/tabs/tabs.scss +9 -0
  317. package/themes/default/tabs/src/tabs-item/tabs-item.scss +23 -0
  318. package/themes/default/tags/index.scss +2 -0
  319. package/themes/default/tags/src/tags/tags.scss +1 -0
  320. package/themes/default/tags/src/tags-item/tags-item.scss +17 -0
  321. package/themes/default/textarea/index.scss +1 -0
  322. package/themes/default/textarea/src/textarea/textarea.scss +18 -0
  323. package/themes/default/timepicker/index.scss +2 -0
  324. package/themes/default/timepicker/src/timepicker/timepicker.scss +44 -0
  325. package/themes/default/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
  326. package/themes/default/transfer/index.scss +1 -0
  327. package/themes/default/transfer/src/transfer/transfer.scss +20 -0
  328. package/themes/default/virtualscroller/index.scss +1 -0
  329. package/themes/default/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
  330. package/themes/webservy/alert/index.scss +1 -0
  331. package/themes/webservy/alert/src/alert/alert.scss +29 -0
  332. package/themes/webservy/button/index.scss +2 -0
  333. package/themes/webservy/button/src/button/button.scss +87 -0
  334. package/themes/webservy/button/src/button-group/button-group.scss +1 -0
  335. package/themes/webservy/cascader/index.scss +2 -0
  336. package/themes/webservy/cascader/src/cascader/cascader.scss +27 -0
  337. package/themes/webservy/cascader/src/cascader-panel/cascader-panel.scss +21 -0
  338. package/themes/webservy/chart/index.scss +2 -0
  339. package/themes/webservy/chart/src/chart-donut/chart-donut.scss +22 -0
  340. package/themes/webservy/chart/src/chart-item/chart-item.scss +11 -0
  341. package/themes/webservy/checkbox/index.scss +2 -0
  342. package/themes/webservy/checkbox/src/checkbox/checkbox.scss +25 -0
  343. package/themes/webservy/checkbox/src/checkbox-group/checkbox-group.scss +1 -0
  344. package/themes/webservy/collapse/index.scss +2 -0
  345. package/themes/webservy/collapse/src/collapse/collapse.scss +14 -0
  346. package/themes/webservy/collapse/src/collapse-item/collapse-item.scss +14 -0
  347. package/themes/webservy/confirm/index.scss +1 -0
  348. package/themes/webservy/confirm/src/confirm/confirm.scss +35 -0
  349. package/themes/webservy/datepicker/index.scss +2 -0
  350. package/themes/webservy/datepicker/src/datepicker/datepicker.scss +40 -0
  351. package/themes/webservy/datepicker/src/datepicker-panel/datepicker-panel.scss +44 -0
  352. package/themes/webservy/datetimepicker/index.scss +1 -0
  353. package/themes/webservy/datetimepicker/src/datetimepicker/datetimepicker.scss +47 -0
  354. package/themes/webservy/demo/index.scss +1 -0
  355. package/themes/webservy/demo/src/demo/demo.scss +34 -0
  356. package/themes/webservy/draggable/index.scss +9 -0
  357. package/themes/webservy/draggable/src/draggrid/draggrid.scss +5 -0
  358. package/themes/webservy/draggable/src/draggrid-item/draggrid-item.scss +51 -0
  359. package/themes/webservy/draggable/src/draghandler/draghandler.scss +15 -0
  360. package/themes/webservy/draggable/src/draglist/draglist.scss +5 -0
  361. package/themes/webservy/draggable/src/draglist-item/draglist-item.scss +55 -0
  362. package/themes/webservy/draggable/src/dropzone/dropzone.scss +5 -0
  363. package/themes/webservy/drawer/index.scss +1 -0
  364. package/themes/webservy/drawer/src/drawer/drawer.scss +23 -0
  365. package/themes/webservy/durationpicker/index.scss +1 -0
  366. package/themes/webservy/durationpicker/src/durationpicker/durationpicker.scss +35 -0
  367. package/themes/webservy/empty/index.scss +1 -0
  368. package/themes/webservy/empty/src/empty-icon/empty-icon.scss +17 -0
  369. package/themes/webservy/example.scss +29 -0
  370. package/themes/webservy/file/index.scss +1 -0
  371. package/themes/webservy/file/src/file/file.scss +1 -0
  372. package/themes/webservy/form/index.scss +4 -0
  373. package/themes/webservy/form/src/form/form.scss +17 -0
  374. package/themes/webservy/form/src/form-frame/form-frame.scss +25 -0
  375. package/themes/webservy/form/src/form-group/form-group.scss +42 -0
  376. package/themes/webservy/form/src/form-item/form-item.scss +25 -0
  377. package/themes/webservy/index.scss +43 -0
  378. package/themes/webservy/info/index.scss +3 -0
  379. package/themes/webservy/info/src/info/info.scss +5 -0
  380. package/themes/webservy/info/src/info-column/info-column.scss +5 -0
  381. package/themes/webservy/info/src/info-field/info-field.scss +5 -0
  382. package/themes/webservy/input/index.scss +1 -0
  383. package/themes/webservy/input/src/input/input.scss +23 -0
  384. package/themes/webservy/input-number/index.scss +1 -0
  385. package/themes/webservy/input-number/src/input-number/input-number.scss +27 -0
  386. package/themes/webservy/loader/index.scss +1 -0
  387. package/themes/webservy/loader/src/loader/loader.scss +10 -0
  388. package/themes/webservy/map/index.scss +1 -0
  389. package/themes/webservy/map/src/map/map.scss +1 -0
  390. package/themes/webservy/modal/index.scss +1 -0
  391. package/themes/webservy/modal/src/modal/modal.scss +23 -0
  392. package/themes/webservy/notification/index.scss +1 -0
  393. package/themes/webservy/notification/src/notification/notification.scss +11 -0
  394. package/themes/webservy/paginator/index.scss +1 -0
  395. package/themes/webservy/paginator/src/paginator/paginator.scss +5 -0
  396. package/themes/webservy/popover/index.scss +1 -0
  397. package/themes/webservy/popover/src/popover/popover.scss +131 -0
  398. package/themes/webservy/preview/index.scss +4 -0
  399. package/themes/webservy/preview/src/preview-image/preview-image.scss +5 -0
  400. package/themes/webservy/preview/src/preview-modal/preview-modal.scss +39 -0
  401. package/themes/webservy/preview/src/preview-plain/preview-plain.scss +9 -0
  402. package/themes/webservy/preview/src/preview-video/preview-video.scss +5 -0
  403. package/themes/webservy/radio/index.scss +2 -0
  404. package/themes/webservy/radio/src/radio/radio.scss +31 -0
  405. package/themes/webservy/radio/src/radio-group/radio-group.scss +1 -0
  406. package/themes/webservy/rating/index.scss +1 -0
  407. package/themes/webservy/rating/src/rating/rating.scss +14 -0
  408. package/themes/webservy/resizer/index.scss +1 -0
  409. package/themes/webservy/resizer/src/resizer/resizer.scss +5 -0
  410. package/themes/webservy/root/helpers.scss +41 -0
  411. package/themes/webservy/root/image/angle-down-shadow.svg +3 -0
  412. package/themes/webservy/root/image/angle-down.svg +3 -0
  413. package/themes/webservy/root/image/angle-left-shadow.svg +3 -0
  414. package/themes/webservy/root/image/angle-left.svg +3 -0
  415. package/themes/webservy/root/image/angle-right-shadow.svg +3 -0
  416. package/themes/webservy/root/image/angle-right.svg +3 -0
  417. package/themes/webservy/root/image/angle-up-shadow.svg +3 -0
  418. package/themes/webservy/root/image/angle-up.svg +3 -0
  419. package/themes/webservy/root/image/empty-ufo.svg +8 -0
  420. package/themes/webservy/root/image/empty.svg +10 -0
  421. package/themes/webservy/root/image/star.svg +5 -0
  422. package/themes/webservy/root/vars/colors-dark-bluish.scss +461 -0
  423. package/themes/webservy/root/vars/colors-dark.scss +461 -0
  424. package/themes/webservy/root/vars/colors-light-bluish.scss +483 -0
  425. package/themes/webservy/root/vars/colors-light.scss +483 -0
  426. package/themes/webservy/root/vars/sizes-default.scss +101 -0
  427. package/themes/webservy/scrollbar/index.scss +1 -0
  428. package/themes/webservy/scrollbar/src/scrollbar/scrollbar.scss +7 -0
  429. package/themes/webservy/select/index.scss +2 -0
  430. package/themes/webservy/select/src/select/select.scss +28 -0
  431. package/themes/webservy/select/src/select-option/select-option.scss +1 -0
  432. package/themes/webservy/slider/index.scss +1 -0
  433. package/themes/webservy/slider/src/slider/slider.scss +30 -0
  434. package/themes/webservy/switch/index.scss +1 -0
  435. package/themes/webservy/switch/src/switch/switch.scss +19 -0
  436. package/themes/webservy/table/index.scss +4 -0
  437. package/themes/webservy/table/src/table/table.scss +14 -0
  438. package/themes/webservy/table/src/table-cell/table-cell.scss +34 -0
  439. package/themes/webservy/table/src/table-column/table-column.scss +31 -0
  440. package/themes/webservy/table/src/table-filter/table-filter.scss +1 -0
  441. package/themes/webservy/tabs/index.scss +2 -0
  442. package/themes/webservy/tabs/src/tabs/tabs.scss +9 -0
  443. package/themes/webservy/tabs/src/tabs-item/tabs-item.scss +23 -0
  444. package/themes/webservy/tags/index.scss +2 -0
  445. package/themes/webservy/tags/src/tags/tags.scss +1 -0
  446. package/themes/webservy/tags/src/tags-item/tags-item.scss +17 -0
  447. package/themes/webservy/textarea/index.scss +1 -0
  448. package/themes/webservy/textarea/src/textarea/textarea.scss +14 -0
  449. package/themes/webservy/timepicker/index.scss +2 -0
  450. package/themes/webservy/timepicker/src/timepicker/timepicker.scss +40 -0
  451. package/themes/webservy/timepicker/src/timepicker-panel/timepicker-panel.scss +26 -0
  452. package/themes/webservy/transfer/index.scss +1 -0
  453. package/themes/webservy/transfer/src/transfer/transfer.scss +24 -0
  454. package/themes/webservy/virtualscroller/index.scss +1 -0
  455. package/themes/webservy/virtualscroller/src/virtualscroller/virtualscroller.scss +1 -0
  456. package/dist/themes/dark.css +0 -1
  457. package/dist/themes/light.css +0 -1
  458. package/src/alert/src/alert/alert.js +0 -133
  459. package/src/notification/src/notification/notification.js +0 -165
  460. package/src/root/image/empty-default.svg +0 -30
  461. package/src/root/image/empty-space.svg +0 -34
  462. package/src/root/image/star-default.svg +0 -10
  463. package/themes/macos/alert/index.scss +0 -1
  464. package/themes/macos/alert/src/alert/alert.scss +0 -27
  465. package/themes/macos/button/index.scss +0 -2
  466. package/themes/macos/button/src/button/button.scss +0 -98
  467. package/themes/macos/button/src/button-group/button-group.scss +0 -1
  468. package/themes/macos/cascader/index.scss +0 -2
  469. package/themes/macos/cascader/src/cascader/cascader.scss +0 -47
  470. package/themes/macos/cascader/src/cascader-panel/cascader-panel.scss +0 -14
  471. package/themes/macos/checkbox/index.scss +0 -2
  472. package/themes/macos/checkbox/src/checkbox/checkbox.scss +0 -45
  473. package/themes/macos/checkbox/src/checkbox-group/checkbox-group.scss +0 -1
  474. package/themes/macos/collapse/index.scss +0 -2
  475. package/themes/macos/collapse/src/collapse/collapse.scss +0 -22
  476. package/themes/macos/collapse/src/collapse-item/collapse-item.scss +0 -22
  477. package/themes/macos/confirm/index.scss +0 -1
  478. package/themes/macos/confirm/src/confirm/confirm.scss +0 -14
  479. package/themes/macos/datepicker/index.scss +0 -2
  480. package/themes/macos/datepicker/src/datepicker/datepicker.scss +0 -51
  481. package/themes/macos/datepicker/src/datepicker-panel/datepicker-panel.scss +0 -45
  482. package/themes/macos/datetimepicker/index.scss +0 -1
  483. package/themes/macos/datetimepicker/src/datetimepicker/datetimepicker.scss +0 -69
  484. package/themes/macos/demo/index.scss +0 -1
  485. package/themes/macos/demo/src/demo/demo.scss +0 -22
  486. package/themes/macos/draggable/index.scss +0 -9
  487. package/themes/macos/draggable/src/draggrid/draggrid.scss +0 -14
  488. package/themes/macos/draggable/src/draggrid-item/draggrid-item.scss +0 -66
  489. package/themes/macos/draggable/src/draghandler/draghandler.scss +0 -15
  490. package/themes/macos/draggable/src/draglist/draglist.scss +0 -14
  491. package/themes/macos/draggable/src/draglist-item/draglist-item.scss +0 -73
  492. package/themes/macos/draggable/src/dropzone/dropzone.scss +0 -14
  493. package/themes/macos/drawer/index.scss +0 -1
  494. package/themes/macos/drawer/src/drawer/drawer.scss +0 -35
  495. package/themes/macos/durationpicker/index.scss +0 -1
  496. package/themes/macos/durationpicker/src/durationpicker/durationpicker.scss +0 -53
  497. package/themes/macos/empty/index.scss +0 -1
  498. package/themes/macos/empty/src/empty-icon/empty-icon.scss +0 -13
  499. package/themes/macos/file/index.scss +0 -1
  500. package/themes/macos/file/src/file/file.scss +0 -39
  501. package/themes/macos/form/index.scss +0 -4
  502. package/themes/macos/form/src/form/form.scss +0 -1
  503. package/themes/macos/form/src/form-frame/form-frame.scss +0 -34
  504. package/themes/macos/form/src/form-group/form-group.scss +0 -43
  505. package/themes/macos/form/src/form-item/form-item.scss +0 -29
  506. package/themes/macos/index-dark.scss +0 -3
  507. package/themes/macos/index-light.scss +0 -3
  508. package/themes/macos/index.scss +0 -40
  509. package/themes/macos/info/index.scss +0 -3
  510. package/themes/macos/info/src/info/info.scss +0 -5
  511. package/themes/macos/info/src/info-column/info-column.scss +0 -5
  512. package/themes/macos/info/src/info-field/info-field.scss +0 -5
  513. package/themes/macos/input/index.scss +0 -1
  514. package/themes/macos/input/src/input/input.scss +0 -39
  515. package/themes/macos/input-number/index.scss +0 -1
  516. package/themes/macos/input-number/src/input-number/input-number.scss +0 -48
  517. package/themes/macos/loader/index.scss +0 -1
  518. package/themes/macos/loader/src/loader/loader.scss +0 -22
  519. package/themes/macos/map/index.scss +0 -1
  520. package/themes/macos/map/src/map/map.scss +0 -1
  521. package/themes/macos/modal/index.scss +0 -1
  522. package/themes/macos/modal/src/modal/modal.scss +0 -35
  523. package/themes/macos/notification/index.scss +0 -1
  524. package/themes/macos/notification/src/notification/notification.scss +0 -25
  525. package/themes/macos/paginator/index.scss +0 -1
  526. package/themes/macos/paginator/src/paginator/paginator.scss +0 -5
  527. package/themes/macos/popover/index.scss +0 -1
  528. package/themes/macos/popover/src/popover/popover.scss +0 -84
  529. package/themes/macos/radio/index.scss +0 -2
  530. package/themes/macos/radio/src/radio/radio.scss +0 -46
  531. package/themes/macos/radio/src/radio-group/radio-group.scss +0 -1
  532. package/themes/macos/rating/index.scss +0 -1
  533. package/themes/macos/rating/src/rating/rating.scss +0 -19
  534. package/themes/macos/resizer/index.scss +0 -1
  535. package/themes/macos/resizer/src/resizer/resizer.scss +0 -5
  536. package/themes/macos/root/image/empty-default.svg +0 -30
  537. package/themes/macos/root/image/empty-space.svg +0 -34
  538. package/themes/macos/root/image/star-default.svg +0 -10
  539. package/themes/macos/root/vars-dark.scss +0 -234
  540. package/themes/macos/root/vars-light.scss +0 -234
  541. package/themes/macos/root/vars.scss +0 -233
  542. package/themes/macos/scrollbar/index.scss +0 -1
  543. package/themes/macos/scrollbar/src/scrollbar/scrollbar.scss +0 -6
  544. package/themes/macos/select/index.scss +0 -2
  545. package/themes/macos/select/src/select/select.scss +0 -49
  546. package/themes/macos/select/src/select-option/select-option.scss +0 -1
  547. package/themes/macos/slider/index.scss +0 -1
  548. package/themes/macos/slider/src/slider/slider.scss +0 -41
  549. package/themes/macos/switch/index.scss +0 -1
  550. package/themes/macos/switch/src/switch/switch.scss +0 -30
  551. package/themes/macos/table/index.scss +0 -4
  552. package/themes/macos/table/src/table/table.scss +0 -15
  553. package/themes/macos/table/src/table-cell/table-cell.scss +0 -51
  554. package/themes/macos/table/src/table-filter/table-filter.scss +0 -1
  555. package/themes/macos/tabs/index.scss +0 -2
  556. package/themes/macos/tabs/src/tabs/tabs.scss +0 -39
  557. package/themes/macos/tabs/src/tabs-item/tabs-item.scss +0 -19
  558. package/themes/macos/tags/index.scss +0 -2
  559. package/themes/macos/tags/src/tags/tags.scss +0 -1
  560. package/themes/macos/tags/src/tags-item/tags-item.scss +0 -32
  561. package/themes/macos/textarea/index.scss +0 -1
  562. package/themes/macos/textarea/src/textarea/textarea.scss +0 -31
  563. package/themes/macos/timepicker/index.scss +0 -2
  564. package/themes/macos/timepicker/src/timepicker/timepicker.scss +0 -51
  565. package/themes/macos/timepicker/src/timepicker-panel/timepicker-panel.scss +0 -28
  566. package/themes/macos/transfer/index.scss +0 -1
  567. package/themes/macos/transfer/src/transfer/transfer.scss +0 -18
  568. package/themes/macos/virtualscroller/index.scss +0 -1
  569. package/themes/macos/virtualscroller/src/virtualscroller/virtualscroller.scss +0 -1
@@ -0,0 +1,182 @@
1
+ import { Any, Arr, Locale, Obj } from "@kizmann/pico-js";
2
+
3
+ export const FormMessage = {
4
+
5
+ required(field, value) {
6
+ return Locale.trans('Field is required');
7
+ },
8
+
9
+ required_if(field, value, key = '') {
10
+
11
+ let label = Arr.find(this.elements, (item) => {
12
+ return item.prop === key;
13
+ }) || key;
14
+
15
+ return Locale.trans('Field is required if :label isset', {
16
+ label: label.label || key
17
+ });
18
+ },
19
+
20
+ required_unless(field, value, key = '') {
21
+
22
+ let label = Arr.find(this.elements, (item) => {
23
+ return item.prop === key;
24
+ });
25
+
26
+ return Locale.trans('Field is required unless :label isset', {
27
+ label: label.label || key
28
+ });
29
+ },
30
+
31
+ same(field, value, key = '')
32
+ {
33
+ let label = Arr.find(this.elements, (item) => {
34
+ return item.prop === key;
35
+ }) || key;
36
+
37
+ return Locale.trans('Must be same as :label', {
38
+ label: label.label || key
39
+ });
40
+ },
41
+
42
+ diffrent(field, value, key = '')
43
+ {
44
+ let label = Arr.find(this.elements, (item) => {
45
+ return item.prop === key;
46
+ }) || key;
47
+
48
+ return Locale.trans('Must be diffrent from :label', {
49
+ label: label.label || key
50
+ });
51
+ },
52
+
53
+ value(field, value, val = 'foobar') {
54
+ return Locale.trans('Must be exact value :val', { val });
55
+ },
56
+
57
+ min(field, value, min = Number.MIN_VALUE) {
58
+ return Locale.trans('Must be greather than :min', { min });
59
+ },
60
+
61
+ max(field, value, max = Number.MAX_VALUE) {
62
+ return Locale.trans('Must be lesser than :max', { max });
63
+ },
64
+
65
+ minlength(field, value, min = Number.MIN_VALUE) {
66
+ return Locale.trans('Length must be greater than :min', { min });
67
+ },
68
+
69
+ maxlength(field, value, max = Number.MAX_VALUE) {
70
+ return Locale.trans('Length must be lesser than :max', { max });
71
+ },
72
+
73
+ email(field, value) {
74
+ return Locale.trans('Must be a valid email');
75
+ }
76
+
77
+ };
78
+
79
+ export const FormRules = {
80
+
81
+ required(field, value) {
82
+
83
+ if ( Any.isBool(value) ) {
84
+ return value === true;
85
+ }
86
+
87
+ return ! Any.isEmpty(value);
88
+ },
89
+
90
+ required_if(field, value, key = '') {
91
+
92
+ let target = Obj.get(this.form, key);
93
+
94
+ if ( Any.isEmpty(target) ) {
95
+ return true;
96
+ }
97
+
98
+ if ( Any.isBool(value) ) {
99
+ return value === true;
100
+ }
101
+
102
+ return ! Any.isEmpty(value);
103
+ },
104
+
105
+ required_unless(field, value, key = '') {
106
+
107
+ let target = Obj.get(this.form, key);
108
+
109
+ if ( ! Any.isEmpty(target) ) {
110
+ return true;
111
+ }
112
+
113
+ if ( Any.isBool(value) ) {
114
+ return value === true;
115
+ }
116
+
117
+ return ! Any.isEmpty(value);
118
+ },
119
+
120
+ same(field, value, key = '') {
121
+ return value === Obj.get(this.form, key);
122
+ },
123
+
124
+ diffrent(field, value, key = '') {
125
+ return value !== Obj.get(this.form, key);
126
+ },
127
+
128
+ value(field, value, val = 'foobar') {
129
+
130
+ if ( Any.isString(value) ) {
131
+ return value === val;
132
+ }
133
+
134
+ return false;
135
+ },
136
+
137
+ min(field, value, min = Number.MIN_VALUE) {
138
+
139
+ if ( Any.isNumber(value) ) {
140
+ return value >= min;
141
+ }
142
+
143
+ return false;
144
+ },
145
+
146
+ max(field, value, max = Number.MAX_VALUE) {
147
+
148
+ if ( Any.isNumber(value) ) {
149
+ return value <= max;
150
+ }
151
+
152
+ return false;
153
+ },
154
+
155
+ minlength(field, value, min = Number.MIN_VALUE) {
156
+
157
+ if ( Any.isString(value) || Any.isArray(value) ) {
158
+ return value.length > min;
159
+ }
160
+
161
+ return false;
162
+ },
163
+
164
+ maxlength(field, value, max = Number.MAX_VALUE) {
165
+
166
+ if ( Any.isString(value) || Any.isArray(value) ) {
167
+ return value.length < max;
168
+ }
169
+
170
+ return false;
171
+ },
172
+
173
+ email(field, value) {
174
+
175
+ if ( Any.isString(value) ) {
176
+ return value.match(/^.*?@.*?\.[a-z]{2,}$/);
177
+ }
178
+
179
+ return false;
180
+ }
181
+
182
+ };
@@ -1,5 +1,6 @@
1
1
  import { UUID, Num, Arr, Obj, Any, Dom, Locale } from "@kizmann/pico-js";
2
2
  import { h } from "vue";
3
+ import {FormMessage, FormRules} from "./form-rules.mjs";
3
4
 
4
5
  export default {
5
6
 
@@ -13,6 +14,14 @@ export default {
13
14
 
14
15
  props: {
15
16
 
17
+ ready: {
18
+ default()
19
+ {
20
+ return true;
21
+ },
22
+ type: [Boolean]
23
+ },
24
+
16
25
  dom: {
17
26
  default()
18
27
  {
@@ -45,6 +54,14 @@ export default {
45
54
  type: [String]
46
55
  },
47
56
 
57
+ type: {
58
+ default()
59
+ {
60
+ return 'primary';
61
+ },
62
+ type: [String]
63
+ },
64
+
48
65
  kind: {
49
66
  default()
50
67
  {
@@ -112,7 +129,7 @@ export default {
112
129
  data()
113
130
  {
114
131
  return {
115
- uid: UUID(), elements: [], groups: {}, blocked: true,
132
+ uid: UUID(), elements: [], rules: [], groups: {}, ruleErrors: {}, blocked: true,
116
133
  };
117
134
  },
118
135
 
@@ -130,8 +147,9 @@ export default {
130
147
 
131
148
  ready()
132
149
  {
133
- this.$watch('form', this.emitChange,
134
- { deep: true });
150
+ this.$watch('form', this.emitChange, {
151
+ deep: true
152
+ });
135
153
 
136
154
  this.resetChange();
137
155
  },
@@ -167,7 +185,7 @@ export default {
167
185
  return this.prevent;
168
186
  },
169
187
 
170
- addItem(item)
188
+ appendItem(item)
171
189
  {
172
190
  Arr.add(this.elements, item, {
173
191
  uid: item.uid
@@ -212,17 +230,103 @@ export default {
212
230
  return;
213
231
  }
214
232
 
233
+ this.validate();
234
+
215
235
  this.prevState = nextState;
216
236
 
217
237
  this.$emit('change');
218
238
  },
219
239
 
240
+ validateField(field)
241
+ {
242
+ let errors = [];
243
+
244
+ Arr.each(field.rules, (rule) => {
245
+ let [name, ...args] = rule.split(':');
246
+
247
+ if ( ! FormRules[name] || !FormMessage[name] ) {
248
+ return;
249
+ }
250
+
251
+ let value = Obj.get(this.form, field.prop);
252
+
253
+ if ( FormRules[name].call(this, field, value, ...args) ) {
254
+ return;
255
+ }
256
+
257
+ let message = FormMessage[name].call(this, field, value, ...args);
258
+
259
+ if ( Any.isEmpty(message) ) {
260
+ return;
261
+ }
262
+
263
+ errors.push(message);
264
+ });
265
+
266
+ return errors;
267
+ },
268
+
269
+ validate()
270
+ {
271
+ let errors = {};
272
+
273
+ Arr.each(this.elements, (field) => {
274
+ errors[field.prop] = this.validateField(field);
275
+ });
276
+
277
+ this.ruleErrors = Obj.filter(errors, (err) => {
278
+ return ! Any.isEmpty(err);
279
+ });
280
+
281
+ return this.ruleErrors;
282
+ },
283
+
284
+ isValid(includeErrors = false)
285
+ {
286
+ this.validate();
287
+
288
+ let count = Any.keys(this.ruleErrors).length;
289
+
290
+ if ( includeErrors ) {
291
+ count += Any.keys(this.errors).length;
292
+ }
293
+
294
+ return count === 0;
295
+ },
296
+
297
+ getErrors()
298
+ {
299
+ let errors = {};
300
+
301
+ Obj.each(this.errors, (err, key) => {
302
+
303
+ if ( ! Any.isArray(err) ) {
304
+ err = [err];
305
+ }
306
+
307
+ errors[key] = err;
308
+ });
309
+
310
+ Obj.each(this.ruleErrors, (err, key) => {
311
+
312
+ if ( Obj.has(errors, key) ) {
313
+ err = Arr.merge(errors[key], err);
314
+ }
315
+
316
+ errors[key] = err;
317
+ });
318
+
319
+ return errors;
320
+ },
321
+
220
322
  },
221
323
 
222
324
  render()
223
325
  {
224
326
  let classList = [
225
327
  'n-form',
328
+ 'n-form--' + this.size,
329
+ 'n-form--' + this.type,
226
330
  'n-form--' + this.align,
227
331
  ];
228
332
 
@@ -1 +1,33 @@
1
- @import "../../../root/vars";
1
+ @use "../../../root/helpers" as *;
2
+
3
+ .n-disabled .n-form-clear {
4
+ display: none !important;
5
+ }
6
+
7
+ .n-disabled .n-form-angle {
8
+ display: inline-flex !important;
9
+ }
10
+
11
+ .n-form-clear,
12
+ .n-form-angle {
13
+ position: relative;
14
+ }
15
+
16
+ .n-form-clear i,
17
+ .n-form-angle i {
18
+ position: absolute;
19
+ top: 50%;
20
+ left: 50%;
21
+ transform: translate(-50%, -50%);
22
+ width: size('base-hgt', 'calc($ - 14px)');
23
+ height: size('base-hgt', 'calc($ - 14px)');
24
+ }
25
+
26
+ .n-form-clear i,
27
+ .n-form-angle i {
28
+ display: inline-flex;
29
+ align-items: center;
30
+ justify-content: center;
31
+ font-size: 0.8em;
32
+ border-radius: size('base-rad-circle');
33
+ }
@@ -0,0 +1,90 @@
1
+ import { Any, Arr, Obj, UUID } from "@kizmann/pico-js";
2
+
3
+ export default {
4
+
5
+ name: 'NFormBag',
6
+
7
+ inject: {
8
+
9
+ NForm: {
10
+ default: undefined
11
+ }
12
+
13
+ },
14
+
15
+ data()
16
+ {
17
+ return {
18
+ uid: UUID()
19
+ };
20
+ },
21
+
22
+
23
+ methods: {
24
+
25
+ gotoField(field)
26
+ {
27
+ //
28
+ }
29
+
30
+ },
31
+
32
+
33
+ renderField(field)
34
+ {
35
+ let errors = Obj.get(this.NForm.getErrors(),
36
+ field.prop, []);
37
+
38
+ console.log('err', field.prop, errors)
39
+
40
+ if ( Any.isEmpty(errors) ) {
41
+ return null;
42
+ }
43
+
44
+ let items = Arr.each(errors, (error) => {
45
+ return (<li>{error}</li>);
46
+ });
47
+
48
+ let itemProps = {
49
+ //
50
+ };
51
+
52
+ itemProps['onClick'] = () => {
53
+ console.log('click');
54
+ field.gotoInput();
55
+ };
56
+
57
+ return (
58
+ <div class="n-form-bag-item" {...itemProps}>
59
+ <div class="n-form-bag-item__label">
60
+ <i class="n-icon fa fa-location-crosshairs"></i> <span>{field.label}</span>
61
+ </div>
62
+ <div class="n-form-bag-item__errors">
63
+ <ul>{items}</ul>
64
+ </div>
65
+ </div>
66
+ )
67
+ },
68
+
69
+ render()
70
+ {
71
+ if ( !this.NForm ) {
72
+ return null;
73
+ }
74
+
75
+ let classList = [
76
+ 'n-form-bag',
77
+ 'n-form-bag--' + this.NForm.size,
78
+ ];
79
+
80
+ let items = Arr.each(this.NForm.elements, (field) => {
81
+ return this.ctor('renderField')(field);
82
+ });
83
+
84
+ return (
85
+ <div class={classList}>
86
+ {items}
87
+ </div>
88
+ );
89
+ }
90
+ }
@@ -0,0 +1,59 @@
1
+ @use "../../../root/helpers" as *;
2
+
3
+ .n-form-bag {
4
+ display: flex;
5
+ flex-direction: column;
6
+ font-size: size('base-fnt');
7
+ }
8
+
9
+ .n-form-bag-item {
10
+ cursor: pointer;
11
+ display: flex;
12
+ flex-direction: column;
13
+ border-radius: size('base-rad');
14
+ background: color('danger-color', 0.15);
15
+ padding: size('base-pad-vertical') size('base-pad');
16
+ }
17
+
18
+ .n-form-bag-item:not(:last-child) {
19
+ margin-bottom: size('base-pad-vertical');
20
+ }
21
+
22
+ .n-form-bag-item__label {
23
+ position: relative;
24
+ display: flex;
25
+ flex-direction: row;
26
+ align-items: center;
27
+ }
28
+
29
+ .n-form-bag-item__label i {
30
+ display: inline-flex;
31
+ justify-content: center;
32
+ opacity: 0.7;
33
+ width: size('base-hgt-inline');
34
+ color: color('danger-color');
35
+ }
36
+
37
+ .n-form-bag-item:hover .n-form-bag-item__label i {
38
+ opacity: 1;
39
+ }
40
+
41
+ .n-form-bag-item__label span {
42
+ display: inline-flex;
43
+ color: color('danger-color');
44
+ padding-left: size('base-pad', 'calc($ * 0.5)');
45
+ }
46
+
47
+ .n-form-bag-item__errors ul {
48
+ list-style: none;
49
+ }
50
+
51
+ .n-form-bag-item__errors ul {
52
+ padding-left: size('base-hgt-inline');
53
+ }
54
+
55
+ .n-form-bag-item__errors ul li {
56
+ padding-left: size('base-pad', 'calc($ * 0.5)');
57
+ color: color('text', 0.6);
58
+ font-size: size('base-fnt-label');
59
+ }
@@ -63,7 +63,9 @@ export default {
63
63
 
64
64
  data()
65
65
  {
66
- return { search: '', star: '', block: false };
66
+ return {
67
+ search: ''
68
+ };
67
69
  },
68
70
 
69
71
  mounted()
@@ -87,21 +89,31 @@ export default {
87
89
  return;
88
90
  }
89
91
 
90
- this.block = block;
91
-
92
92
  if ( ! Any.isEmpty(this.timeout) ) {
93
93
  clearTimeout(this.timeout);
94
94
  }
95
95
 
96
96
  if ( block ) {
97
- this.star = id;
97
+ this.onApplyStar(id, block);
98
98
  }
99
99
 
100
100
  this.timeout = setTimeout(() => {
101
- this.star = id; this.block = false;
101
+ this.onApplyStar(id, false);
102
102
  }, 500);
103
103
  },
104
104
 
105
+ onApplyStar(id, block = false)
106
+ {
107
+ this.block = block;
108
+
109
+ Dom.find(this.$el).find(`[data-menu-key]`).each((el) => {
110
+ Dom.find(el).removeClass('is-star');
111
+ });
112
+
113
+ Dom.find(this.$el).find(`[data-menu-key="${id}"]`)
114
+ .addClass('is-star');
115
+ },
116
+
105
117
  onMoveEvent()
106
118
  {
107
119
  Dom.find(window).on('mousemove', Any.debounce(e => {
@@ -244,10 +256,6 @@ export default {
244
256
  'n-form-frame__menu--' + item.type
245
257
  ];
246
258
 
247
- if ( this.star === item.key ) {
248
- classList.push('is-star');
249
- }
250
-
251
259
  return (
252
260
  <a class={classList} data-menu-key={item.key} {...buttonProps}>
253
261
  {[iconHtml, labelHtml]}
@@ -1,5 +1,4 @@
1
- @use "sass:map";
2
- @import "../../../root/vars";
1
+ @use "../../../root/helpers" as *;
3
2
 
4
3
  .n-form-frame {
5
4
  display: flex;
@@ -24,7 +23,7 @@
24
23
  display: flex;
25
24
  align-items: center;
26
25
  width: 100%;
27
- border-radius: $md-radius;
26
+ border-radius: size('base-rad');
28
27
  text-decoration: none;
29
28
  transition: opacity 0.3s;
30
29
  }
@@ -81,45 +80,33 @@
81
80
  min-height: 0;
82
81
  }
83
82
 
83
+ .n-form-frame__menus {
84
+ width: size('base-hgt', 'calc($ * 9)');
85
+ }
84
86
 
87
+ .n-form-frame__menus .n-scrollbar__wrap {
88
+ padding: size('base-pad-vertical', 'calc($ * 2)') size('base-pad', 'calc($ * 2)');
89
+ }
85
90
 
86
- @each $suffix, $values in $form {
87
-
88
- $-form-frame-font: map.get($values, 'font');
89
- $-form-frame-size: map.get($values, 'size');
90
- $-form-frame-radius: map.get($values, 'radius');
91
- $-form-frame-ratio: map.get($values, 'ratio');
92
-
93
- .n-form-frame--#{$suffix} .n-form-frame__menus {
94
- width: $-form-frame-size * 8;
95
- }
96
-
97
- .n-form-frame--#{$suffix} .n-form-frame__menus .n-scrollbar__wrap {
98
- padding: $-form-frame-size * 0.5 $-form-frame-size * 0.6;
99
- }
100
-
101
- .n-form-frame--#{$suffix} .n-form-frame__search {
102
- margin-bottom: $-form-frame-size * 0.4;
103
- }
104
-
105
- .n-form-frame--#{$suffix} .n-form-frame__menu {
106
- height: $-form-frame-size;
107
- font-size: $-form-frame-font - 1;
108
- border-radius: $-form-frame-radius;
109
- padding-right: $-form-frame-size * 0.6;
110
- }
91
+ .n-form-frame__search {
92
+ margin-bottom: size('base-pad-vertical')
93
+ }
111
94
 
112
- .n-form-frame--#{$suffix} .n-form-frame__menu:before {
113
- right: $-form-frame-size * 0.3;
114
- }
95
+ .n-form-frame__menu {
96
+ height: size('base-hgt', 'calc($ * 1.2)');
97
+ font-size: size('base-fnt');
98
+ border-radius: size('base-rad');
99
+ padding: 0 size('base-pad');
100
+ }
115
101
 
116
- .n-form-frame--#{$suffix} .n-form-frame__menu i {
117
- width: $-form-frame-size * 0.6;
118
- margin: 0 $-form-frame-size * 0.3;
119
- }
102
+ .n-form-frame__menu:before {
103
+ right: size('base-pad');
104
+ }
120
105
 
121
- .n-form-frame--#{$suffix} .n-form-frame__body .n-scrollbar__wrap {
122
- padding: $-form-frame-size * 0.2 $-form-frame-size * 0.6 $-form-frame-size * 0.2 0;
123
- }
106
+ .n-form-frame__menu i {
107
+ width: size('base-hgt');
108
+ }
124
109
 
110
+ .n-form-frame__body > .n-scrollbar-content > .n-scrollbar__wrap {
111
+ padding: size('base-pad-vertical', 'calc($ * 2)') size('base-pad', 'calc($ * 2)');
125
112
  }