@kizmann/nano-ui 2.0.2 → 3.0.0

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 (716) hide show
  1. package/dist/nano-ui.css +1 -1
  2. package/dist/nano-ui.esm.js +1 -1
  3. package/dist/nano-ui.esm.js.map +1 -1
  4. package/dist/themes/default.css +1 -1
  5. package/package.json +6 -8
  6. package/src/button/{src/button-group → css}/button-group.scss +1 -1
  7. package/src/button/{src/button → css}/button.scss +3 -3
  8. package/src/button/index.scss +2 -2
  9. package/src/button/index.ts +8 -0
  10. package/src/button/js/button/NButton.ts +82 -0
  11. package/src/button/js/button/NButtonController.ts +45 -0
  12. package/src/button/js/button/NButtonData.ts +61 -0
  13. package/src/button/js/button/NButtonView.ts +69 -0
  14. package/src/button/js/button-group/NButtonGroup.ts +35 -0
  15. package/src/button/js/button-group/NButtonGroupController.ts +44 -0
  16. package/src/button/js/button-group/NButtonGroupData.ts +16 -0
  17. package/src/button/js/button-group/NButtonGroupView.ts +36 -0
  18. package/src/cascader/{src/cascader-panel → css}/cascader-panel.scss +1 -1
  19. package/src/cascader/{src/cascader → css}/cascader.scss +7 -1
  20. package/src/cascader/index.scss +2 -2
  21. package/src/cascader/index.ts +8 -0
  22. package/src/cascader/js/cascader/NCascader.ts +76 -0
  23. package/src/cascader/js/cascader/NCascaderController.ts +69 -0
  24. package/src/cascader/js/cascader/NCascaderData.ts +74 -0
  25. package/src/cascader/js/cascader/NCascaderView.ts +151 -0
  26. package/src/cascader/js/cascader-panel/NCascaderPanel.ts +101 -0
  27. package/src/cascader/js/cascader-panel/NCascaderPanelController.ts +126 -0
  28. package/src/cascader/js/cascader-panel/NCascaderPanelData.ts +70 -0
  29. package/src/cascader/js/cascader-panel/NCascaderPanelView.ts +106 -0
  30. package/src/cascader/js/helper/NCascaderHelper.ts +76 -0
  31. package/src/chart/NChart.md +3 -0
  32. package/src/chart/{src/chart-bar → css}/chart-bar.scss +108 -38
  33. package/src/chart/{src/chart-donut → css}/chart-donut.scss +13 -28
  34. package/src/chart/{src/chart-item → css}/chart-item.scss +6 -3
  35. package/src/chart/index.scss +3 -3
  36. package/src/chart/index.ts +10 -0
  37. package/src/chart/js/chart-bar/NChartBar.ts +91 -0
  38. package/src/chart/js/chart-bar/NChartBarController.ts +136 -0
  39. package/src/chart/js/chart-bar/NChartBarData.ts +74 -0
  40. package/src/chart/js/chart-bar/NChartBarView.ts +221 -0
  41. package/src/chart/js/chart-donut/NChartDonut.ts +98 -0
  42. package/src/chart/js/chart-donut/NChartDonutController.ts +145 -0
  43. package/src/chart/js/chart-donut/NChartDonutData.ts +89 -0
  44. package/src/chart/js/chart-donut/NChartDonutView.ts +226 -0
  45. package/src/chart/js/chart-item/NChartItem.ts +57 -0
  46. package/src/chart/js/chart-item/NChartItemController.ts +68 -0
  47. package/src/chart/js/chart-item/NChartItemData.ts +21 -0
  48. package/src/chart/js/chart-item/NChartItemView.ts +23 -0
  49. package/src/checkbox/{src/checkbox-group → css}/checkbox-group.scss +1 -1
  50. package/src/checkbox/{src/checkbox → css}/checkbox.scss +1 -1
  51. package/src/checkbox/index.scss +2 -2
  52. package/src/checkbox/index.ts +8 -0
  53. package/src/checkbox/js/checkbox/NCheckbox.ts +82 -0
  54. package/src/checkbox/js/checkbox/NCheckboxController.ts +67 -0
  55. package/src/checkbox/js/checkbox/NCheckboxControllerGlobal.ts +35 -0
  56. package/src/checkbox/js/checkbox/NCheckboxControllerSingle.ts +70 -0
  57. package/src/checkbox/js/checkbox/NCheckboxData.ts +56 -0
  58. package/src/checkbox/js/checkbox/NCheckboxView.ts +60 -0
  59. package/src/checkbox/js/checkbox-group/NCheckboxGroup.ts +57 -0
  60. package/src/checkbox/js/checkbox-group/NCheckboxGroupController.ts +101 -0
  61. package/src/checkbox/js/checkbox-group/NCheckboxGroupData.ts +42 -0
  62. package/src/checkbox/js/checkbox-group/NCheckboxGroupView.ts +32 -0
  63. package/src/collapse/NCollapse.md +4 -0
  64. package/src/collapse/css/collapse-item.scss +83 -0
  65. package/src/collapse/css/collapse.scss +11 -0
  66. package/src/collapse/index.scss +2 -2
  67. package/src/collapse/index.ts +8 -0
  68. package/src/collapse/js/collapse/NCollapse.ts +78 -0
  69. package/src/collapse/js/collapse/NCollapseController.ts +101 -0
  70. package/src/collapse/js/collapse/NCollapseData.ts +54 -0
  71. package/src/collapse/js/collapse/NCollapseView.ts +44 -0
  72. package/src/collapse/js/collapse-item/NCollapseItem.ts +88 -0
  73. package/src/collapse/js/collapse-item/NCollapseItemController.ts +133 -0
  74. package/src/collapse/js/collapse-item/NCollapseItemData.ts +56 -0
  75. package/src/collapse/js/collapse-item/NCollapseItemView.ts +143 -0
  76. package/src/config/index.ts +6 -0
  77. package/src/config/js/config/NConfig.ts +67 -0
  78. package/src/config/js/config/NConfigController.ts +241 -0
  79. package/src/config/js/config/NConfigData.ts +33 -0
  80. package/src/config/js/config/NConfigView.ts +140 -0
  81. package/src/datetime/NDatetime.md +4 -0
  82. package/src/{datepicker/src/datepicker-panel → datetime/css}/datepicker-panel.scss +58 -75
  83. package/src/{datepicker/src/datepicker → datetime/css}/datepicker.scss +12 -2
  84. package/src/{datetimepicker/src/datetimepicker → datetime/css}/datetimepicker.scss +12 -2
  85. package/src/{durationpicker/src/durationpicker → datetime/css}/durationpicker.scss +21 -3
  86. package/src/{timepicker/src/timepicker-panel → datetime/css}/timepicker-panel.scss +5 -5
  87. package/src/{timepicker/src/timepicker → datetime/css}/timepicker.scss +12 -2
  88. package/src/datetime/index.scss +6 -0
  89. package/src/datetime/index.ts +16 -0
  90. package/src/datetime/js/datepicker/NDatepicker.ts +89 -0
  91. package/src/datetime/js/datepicker/NDatepickerController.ts +224 -0
  92. package/src/datetime/js/datepicker/NDatepickerData.ts +98 -0
  93. package/src/datetime/js/datepicker/NDatepickerView.ts +176 -0
  94. package/src/datetime/js/datepicker-panel/NDatepickerPanel.ts +116 -0
  95. package/src/datetime/js/datepicker-panel/NDatepickerPanelController.ts +254 -0
  96. package/src/datetime/js/datepicker-panel/NDatepickerPanelData.ts +159 -0
  97. package/src/datetime/js/datepicker-panel/NDatepickerPanelView.ts +362 -0
  98. package/src/datetime/js/datetimepicker/NDatetimepicker.ts +102 -0
  99. package/src/datetime/js/datetimepicker/NDatetimepickerController.ts +109 -0
  100. package/src/datetime/js/datetimepicker/NDatetimepickerData.ts +61 -0
  101. package/src/datetime/js/datetimepicker/NDatetimepickerView.ts +121 -0
  102. package/src/datetime/js/durationpicker/NDurationpicker.ts +155 -0
  103. package/src/datetime/js/durationpicker/NDurationpickerController.ts +157 -0
  104. package/src/datetime/js/durationpicker/NDurationpickerData.ts +57 -0
  105. package/src/datetime/js/durationpicker/NDurationpickerView.ts +130 -0
  106. package/src/datetime/js/helper/NDateHelper.ts +137 -0
  107. package/src/datetime/js/timepicker/NTimepicker.ts +52 -0
  108. package/src/datetime/js/timepicker/NTimepickerController.ts +100 -0
  109. package/src/datetime/js/timepicker/NTimepickerData.ts +48 -0
  110. package/src/datetime/js/timepicker/NTimepickerView.ts +79 -0
  111. package/src/datetime/js/timepicker-panel/NTimepickerPanel.ts +93 -0
  112. package/src/datetime/js/timepicker-panel/NTimepickerPanelController.ts +64 -0
  113. package/src/datetime/js/timepicker-panel/NTimepickerPanelData.ts +81 -0
  114. package/src/datetime/js/timepicker-panel/NTimepickerPanelView.ts +167 -0
  115. package/src/draggable/NDraggable.md +4 -0
  116. package/src/draggable/{src/draggrid-item → css}/draggrid-item.scss +10 -9
  117. package/src/draggable/{src/draggrid → css}/draggrid.scss +1 -1
  118. package/src/draggable/css/draghandler.scss +84 -0
  119. package/src/draggable/{src/draglist-item → css}/draglist-item.scss +8 -11
  120. package/src/draggable/{src/draglist → css}/draglist.scss +6 -1
  121. package/src/draggable/{src/dropzone → css}/dropzone.scss +1 -1
  122. package/src/draggable/index.scss +6 -10
  123. package/src/draggable/index.ts +20 -0
  124. package/src/draggable/js/drag/NDragCounter.ts +140 -0
  125. package/src/draggable/js/drag/NDragHandler.ts +240 -0
  126. package/src/draggable/js/drag/NDragIndicator.ts +142 -0
  127. package/src/draggable/js/drag/NDragReciever.ts +136 -0
  128. package/src/draggable/js/drag/NDropTarget.ts +0 -0
  129. package/src/draggable/js/draglist/NDraglist.ts +83 -0
  130. package/src/draggable/js/draglist/NDraglistController.ts +573 -0
  131. package/src/draggable/js/draglist/NDraglistData.ts +94 -0
  132. package/src/draggable/js/draglist/NDraglistView.ts +339 -0
  133. package/src/draggable/js/dropzone/NDropzone.ts +56 -0
  134. package/src/draggable/js/dropzone/NDropzoneController.ts +118 -0
  135. package/src/draggable/js/dropzone/NDropzoneData.ts +28 -0
  136. package/src/draggable/js/dropzone/NDropzoneView.ts +43 -0
  137. package/src/draggable/js/helper/NDragHelper.ts +196 -0
  138. package/src/draggable/js/helper/NVirtualHelper.ts +87 -0
  139. package/src/empty/{src/empty-icon → css}/empty-icon.scss +7 -10
  140. package/src/empty/index.scss +1 -1
  141. package/src/empty/index.ts +6 -0
  142. package/src/empty/js/empty-icon/NEmptyIcon.ts +62 -0
  143. package/src/empty/js/empty-icon/NEmptyIconController.ts +44 -0
  144. package/src/empty/js/empty-icon/NEmptyIconData.ts +39 -0
  145. package/src/empty/js/empty-icon/NEmptyIconView.ts +59 -0
  146. package/src/form/{src/form-bag → css}/form-bag.scss +10 -10
  147. package/src/form/{src/form-frame → css}/form-frame.scss +17 -17
  148. package/src/form/{src/form-group → css}/form-group.scss +7 -8
  149. package/src/form/{src/form-item → css}/form-item.scss +1 -1
  150. package/src/form/{src/form → css}/form.scss +1 -1
  151. package/src/form/index.scss +5 -5
  152. package/src/form/index.ts +14 -0
  153. package/src/form/js/form/NForm.ts +93 -0
  154. package/src/form/js/form/NFormController.ts +125 -0
  155. package/src/form/js/form/NFormData.ts +71 -0
  156. package/src/form/js/form/NFormView.ts +33 -0
  157. package/src/form/js/form-bag/NFormBag.ts +39 -0
  158. package/src/form/js/form-bag/NFormBagController.ts +49 -0
  159. package/src/form/js/form-bag/NFormBagData.ts +20 -0
  160. package/src/form/js/form-bag/NFormBagView.ts +78 -0
  161. package/src/form/js/form-frame/NFormFrame.ts +53 -0
  162. package/src/form/js/form-frame/NFormFrameController.ts +66 -0
  163. package/src/form/js/form-frame/NFormFrameData.ts +23 -0
  164. package/src/form/js/form-frame/NFormFrameView.ts +114 -0
  165. package/src/form/js/form-group/NFormGroup.ts +98 -0
  166. package/src/form/js/form-group/NFormGroupController.ts +102 -0
  167. package/src/form/js/form-group/NFormGroupData.ts +76 -0
  168. package/src/form/js/form-group/NFormGroupView.ts +129 -0
  169. package/src/form/js/form-item/NFormItem.ts +88 -0
  170. package/src/form/js/form-item/NFormItemController.ts +95 -0
  171. package/src/form/js/form-item/NFormItemData.ts +41 -0
  172. package/src/form/js/form-item/NFormItemView.ts +105 -0
  173. package/src/form/js/form-rules/NFormRuleHandler.ts +79 -0
  174. package/src/form/js/form-rules/module/NFormRuleDiffrent.ts +27 -0
  175. package/src/form/js/form-rules/module/NFormRuleEmail.ts +25 -0
  176. package/src/form/js/form-rules/module/NFormRuleMax.ts +29 -0
  177. package/src/form/js/form-rules/module/NFormRuleMaxlength.ts +29 -0
  178. package/src/form/js/form-rules/module/NFormRuleMin.ts +29 -0
  179. package/src/form/js/form-rules/module/NFormRuleMinlength.ts +29 -0
  180. package/src/form/js/form-rules/module/NFormRuleRequired.ts +25 -0
  181. package/src/form/js/form-rules/module/NFormRuleRequiredIf.ts +37 -0
  182. package/src/form/js/form-rules/module/NFormRuleRequiredUnless.ts +37 -0
  183. package/src/form/js/form-rules/module/NFormRuleSame.ts +27 -0
  184. package/src/form/js/form-rules/module/NFormRuleValue.ts +21 -0
  185. package/src/index.esm.ts +137 -0
  186. package/src/index.scss +4 -18
  187. package/src/info/css/info-column.scss +9 -0
  188. package/src/info/{src/info-field → css}/info-field.scss +3 -2
  189. package/src/info/{src/info → css}/info.scss +1 -5
  190. package/src/info/index.scss +3 -3
  191. package/src/info/index.ts +21 -0
  192. package/src/info/js/info/NInfo.ts +78 -0
  193. package/src/info/js/info/NInfoController.ts +47 -0
  194. package/src/info/js/info/NInfoData.ts +39 -0
  195. package/src/info/js/info/NInfoView.ts +54 -0
  196. package/src/info/js/info-cell/NInfoCellString.ts +15 -0
  197. package/src/info/js/info-column/NInfoColumn.ts +80 -0
  198. package/src/info/js/info-column/NInfoColumnController.ts +103 -0
  199. package/src/info/js/info-column/NInfoColumnData.ts +43 -0
  200. package/src/info/js/info-column/NInfoColumnView.ts +83 -0
  201. package/src/{file/src/file/file.scss → input/css/input-file.scss} +6 -6
  202. package/src/{input-number/src/input-number → input/css}/input-number.scss +12 -11
  203. package/src/input/{src/input → css}/input.scss +36 -6
  204. package/src/{textarea/src/textarea → input/css}/textarea.scss +1 -1
  205. package/src/input/index.scss +4 -1
  206. package/src/input/index.ts +12 -0
  207. package/src/input/js/input/NInput.ts +108 -0
  208. package/src/input/js/input/NInputController.ts +52 -0
  209. package/src/input/js/input/NInputData.ts +51 -0
  210. package/src/input/js/input/NInputView.ts +160 -0
  211. package/src/input/js/input-file/NInputFile.ts +93 -0
  212. package/src/input/js/input-file/NInputFileController.ts +67 -0
  213. package/src/input/js/input-file/NInputFileData.ts +50 -0
  214. package/src/input/js/input-file/NInputFileView.ts +94 -0
  215. package/src/input/js/input-number/NInputNumber.ts +108 -0
  216. package/src/input/js/input-number/NInputNumberController.ts +126 -0
  217. package/src/input/js/input-number/NInputNumberData.ts +105 -0
  218. package/src/input/js/input-number/NInputNumberView.ts +169 -0
  219. package/src/input/js/textarea/NTextarea.ts +96 -0
  220. package/src/input/js/textarea/NTextareaController.ts +51 -0
  221. package/src/input/js/textarea/NTextareaData.ts +94 -0
  222. package/src/input/js/textarea/NTextareaView.ts +98 -0
  223. package/src/loader/{src/loader → css}/loader.scss +1 -1
  224. package/src/loader/index.scss +1 -1
  225. package/src/loader/index.ts +6 -0
  226. package/src/loader/js/loader/NLoader.ts +63 -0
  227. package/src/loader/js/loader/NLoaderController.ts +110 -0
  228. package/src/loader/js/loader/NLoaderData.ts +44 -0
  229. package/src/loader/js/loader/NLoaderView.ts +32 -0
  230. package/src/map/NMap.md +4 -0
  231. package/src/map/{src/map → css}/map.scss +1 -1
  232. package/src/map/index.scss +1 -1
  233. package/src/map/index.ts +8 -0
  234. package/src/map/js/map/NMap.ts +60 -0
  235. package/src/map/js/map/NMapController.ts +78 -0
  236. package/src/map/js/map/NMapData.ts +33 -0
  237. package/src/map/js/map/NMapView.ts +33 -0
  238. package/src/map/js/map-marker/NMapMarker.ts +64 -0
  239. package/src/map/js/map-marker/NMapMarkerController.ts +110 -0
  240. package/src/map/js/map-marker/NMapMarkerData.ts +31 -0
  241. package/src/map/js/map-marker/NMapMarkerView.ts +32 -0
  242. package/src/modal/NModal.md +6 -0
  243. package/src/{drawer/src/drawer → modal/css}/drawer.scss +3 -16
  244. package/src/modal/{src/modal → css}/modal.scss +21 -16
  245. package/src/modal/index.scss +2 -1
  246. package/src/modal/index.ts +8 -0
  247. package/src/modal/js/drawer/NDrawer.ts +122 -0
  248. package/src/modal/js/drawer/NDrawerController.ts +114 -0
  249. package/src/modal/js/drawer/NDrawerData.ts +13 -0
  250. package/src/modal/js/drawer/NDrawerView.ts +18 -0
  251. package/src/modal/js/handler/NModalElement.ts +253 -0
  252. package/src/modal/js/handler/NModalHandler.ts +127 -0
  253. package/src/modal/js/modal/NModal.ts +115 -0
  254. package/src/modal/js/modal/NModalController.ts +113 -0
  255. package/src/modal/js/modal/NModalData.ts +74 -0
  256. package/src/modal/js/modal/NModalView.ts +99 -0
  257. package/src/popover/NPopover.md +9 -0
  258. package/src/popover/{src/popover → css}/popover.scss +17 -9
  259. package/src/popover/index.scss +1 -1
  260. package/src/popover/index.ts +10 -0
  261. package/src/popover/js/handler/NPopoverElement.ts +327 -0
  262. package/src/popover/js/handler/NPopoverHandler.ts +111 -0
  263. package/src/popover/js/popover/NPopover.ts +108 -0
  264. package/src/popover/js/popover/NPopoverController.ts +113 -0
  265. package/src/popover/js/popover/NPopoverData.ts +67 -0
  266. package/src/popover/js/popover/NPopoverView.ts +76 -0
  267. package/src/popover/js/popover-group/NPopoverGroup.ts +32 -0
  268. package/src/popover/js/popover-group/NPopoverGroupController.ts +48 -0
  269. package/src/popover/js/popover-group/NPopoverGroupData.ts +16 -0
  270. package/src/popover/js/popover-group/NPopoverGroupView.ts +32 -0
  271. package/src/popover/js/popover-option/NPopoverOption.ts +65 -0
  272. package/src/popover/js/popover-option/NPopoverOptionController.ts +70 -0
  273. package/src/popover/js/popover-option/NPopoverOptionData.ts +41 -0
  274. package/src/popover/js/popover-option/NPopoverOptionView.ts +40 -0
  275. package/src/popover/js/popover-panel/NPopoverPanel.ts +34 -0
  276. package/src/popover/js/popover-panel/NPopoverPanelController.ts +80 -0
  277. package/src/popover/js/popover-panel/NPopoverPanelData.ts +29 -0
  278. package/src/popover/js/popover-panel/NPopoverPanelView.ts +106 -0
  279. package/src/preview/NPreview.md +6 -0
  280. package/src/preview/css/preview-modal.scss +132 -0
  281. package/src/preview/css/preview.scss +216 -0
  282. package/src/preview/index.scss +2 -5
  283. package/src/preview/index.ts +16 -0
  284. package/src/preview/js/handler/NPreviewElement.ts +122 -0
  285. package/src/preview/js/handler/NPreviewHandler.ts +299 -0
  286. package/src/preview/{src/preview/preview-helper.mjs → js/helper/NPreviewHelper.ts} +62 -28
  287. package/src/preview/js/preview/NPreview.ts +143 -0
  288. package/src/preview/js/preview/NPreviewController.ts +121 -0
  289. package/src/preview/js/preview/NPreviewData.ts +117 -0
  290. package/src/preview/js/preview/NPreviewView.ts +237 -0
  291. package/src/preview/js/preview-module/NPreviewFileModule.ts +7 -0
  292. package/src/preview/js/preview-module/NPreviewImageModule.ts +28 -0
  293. package/src/preview/js/preview-module/NPreviewVideoModule.ts +23 -0
  294. package/src/radio/{src/radio-group → css}/radio-group.scss +1 -1
  295. package/src/radio/{src/radio → css}/radio.scss +1 -1
  296. package/src/radio/index.scss +2 -2
  297. package/src/radio/index.ts +8 -0
  298. package/src/radio/js/radio/NRadio.ts +54 -0
  299. package/src/radio/js/radio/NRadioController.ts +71 -0
  300. package/src/radio/js/radio/NRadioData.ts +33 -0
  301. package/src/radio/js/radio/NRadioView.ts +50 -0
  302. package/src/radio/js/radio-group/NRadioGroup.ts +55 -0
  303. package/src/radio/js/radio-group/NRadioGroupController.ts +53 -0
  304. package/src/radio/js/radio-group/NRadioGroupData.ts +32 -0
  305. package/src/radio/js/radio-group/NRadioGroupView.ts +32 -0
  306. package/src/resizer/css/resizer.scss +58 -0
  307. package/src/resizer/index.scss +1 -1
  308. package/src/resizer/index.ts +6 -0
  309. package/src/resizer/js/resizer/NResizer.ts +92 -0
  310. package/src/resizer/js/resizer/NResizerController.ts +189 -0
  311. package/src/resizer/js/resizer/NResizerData.ts +92 -0
  312. package/src/resizer/js/resizer/NResizerView.ts +71 -0
  313. package/src/{grid/src/grid → root/css}/grid.scss +1 -1
  314. package/src/{tooltip/src/tooltip → root/css}/tooltip.scss +1 -1
  315. package/src/root/index.scss +2 -0
  316. package/src/root/index.ts +58 -0
  317. package/src/root/js/controller/GroupController.ts +76 -0
  318. package/src/root/js/data/AlignData.ts +31 -0
  319. package/src/root/js/data/BaseData.ts +141 -0
  320. package/src/root/js/data/DragData.ts +204 -0
  321. package/src/root/js/data/IconData.ts +62 -0
  322. package/src/root/js/data/OptionData.ts +60 -0
  323. package/src/root/js/data/PositionData.ts +64 -0
  324. package/src/root/js/data/TextData.ts +76 -0
  325. package/src/root/js/helper/OptionHelper.ts +102 -0
  326. package/src/root/js/legacy/cmer.ts +34 -0
  327. package/src/root/js/legacy/cslo.ts +14 -0
  328. package/src/root/js/legacy/ctor.ts +23 -0
  329. package/src/root/js/module/Pointer.ts +243 -0
  330. package/src/root/js/module/Styler.ts +119 -0
  331. package/src/root/js/prop/AlignProps.ts +63 -0
  332. package/src/root/js/prop/BaseProps.ts +89 -0
  333. package/src/root/js/prop/DragProps.ts +152 -0
  334. package/src/root/js/prop/IconProps.ts +51 -0
  335. package/src/root/js/prop/OptionProps.ts +26 -0
  336. package/src/root/js/prop/PositionProps.ts +77 -0
  337. package/src/root/js/prop/TextProps.ts +46 -0
  338. package/src/root/js/proto/ProtoController.ts +430 -0
  339. package/src/root/js/proto/ProtoData.ts +108 -0
  340. package/src/root/js/proto/ProtoExtend.ts +20 -0
  341. package/src/root/js/proto/ProtoView.ts +152 -0
  342. package/src/scrollbar/NScrollbar.md +7 -0
  343. package/src/scrollbar/{src/scrollbar → css}/scrollbar.scss +26 -25
  344. package/src/scrollbar/css/vitrualbar.scss +47 -0
  345. package/src/scrollbar/index.scss +2 -1
  346. package/src/scrollbar/index.ts +8 -0
  347. package/src/scrollbar/js/handler/NScrollbarElement.ts +441 -0
  348. package/src/scrollbar/js/handler/NScrollbarHelper.ts +51 -0
  349. package/src/scrollbar/js/scrollbar/NScrollbar.ts +61 -0
  350. package/src/scrollbar/js/scrollbar/NScrollbarController.ts +151 -0
  351. package/src/scrollbar/js/scrollbar/NScrollbarData.ts +56 -0
  352. package/src/scrollbar/js/scrollbar/NScrollbarView.ts +60 -0
  353. package/src/scrollbar/js/virtualbar/NVirtualbar.ts +107 -0
  354. package/src/scrollbar/js/virtualbar/NVirtualbarController.ts +212 -0
  355. package/src/scrollbar/js/virtualbar/NVirtualbarData.ts +138 -0
  356. package/src/scrollbar/js/virtualbar/NVirtualbarView.ts +242 -0
  357. package/src/select/css/select-option.scss +1 -0
  358. package/src/select/{src/select → css}/select.scss +1 -1
  359. package/src/select/index.scss +2 -2
  360. package/src/select/index.ts +6 -0
  361. package/src/select/js/select/NSelect.ts +89 -0
  362. package/src/select/js/select/NSelectController.ts +200 -0
  363. package/src/select/js/select/NSelectData.ts +87 -0
  364. package/src/select/js/select/NSelectView.ts +220 -0
  365. package/src/{alert/src/alert → signal/css}/alert.scss +21 -19
  366. package/src/{confirm/src/confirm → signal/css}/confirm.scss +5 -5
  367. package/src/{notification/src/notification/notification.scss → signal/css/notify.scss} +19 -19
  368. package/src/signal/index.scss +3 -0
  369. package/src/signal/index.ts +20 -0
  370. package/src/signal/js/alert/NAlertElement.ts +155 -0
  371. package/src/signal/js/alert/NAlertHandler.ts +26 -0
  372. package/src/signal/js/confirm/NConfirmElement.ts +204 -0
  373. package/src/signal/js/confirm/NConfirmHandler.ts +26 -0
  374. package/src/signal/js/notify/NNotifyElement.ts +106 -0
  375. package/src/signal/js/notify/NNotifyHandler.ts +64 -0
  376. package/src/slider/NSlider.md +3 -0
  377. package/src/slider/{src/slider → css}/slider.scss +1 -1
  378. package/src/slider/index.scss +1 -1
  379. package/src/slider/index.ts +6 -0
  380. package/src/slider/js/slider/NSlider.ts +86 -0
  381. package/src/slider/js/slider/NSliderController.ts +204 -0
  382. package/src/slider/js/slider/NSliderData.ts +86 -0
  383. package/src/slider/js/slider/NSliderView.ts +107 -0
  384. package/src/switch/{src/switch → css}/switch.scss +1 -1
  385. package/src/switch/index.scss +1 -1
  386. package/src/switch/index.ts +6 -0
  387. package/src/switch/js/switch/NSwitch.ts +84 -0
  388. package/src/switch/js/switch/NSwitchController.ts +71 -0
  389. package/src/switch/js/switch/NSwitchData.ts +84 -0
  390. package/src/switch/js/switch/NSwitchView.ts +50 -0
  391. package/src/{paginator/src/paginator → table/css}/paginator.scss +1 -1
  392. package/src/table/{src/table-cell → css}/table-cell.scss +1 -1
  393. package/src/table/{src/table-column → css}/table-column.scss +26 -4
  394. package/src/table/{src/table-filter → css}/table-filter.scss +1 -1
  395. package/src/table/{src/table → css}/table.scss +18 -4
  396. package/src/table/index.scss +5 -4
  397. package/src/table/index.ts +46 -0
  398. package/src/table/js/paginator/NPaginator.ts +115 -0
  399. package/src/table/js/paginator/NPaginatorController.ts +77 -0
  400. package/src/table/js/paginator/NPaginatorData.ts +68 -0
  401. package/src/table/js/paginator/NPaginatorView.ts +210 -0
  402. package/src/table/js/plugin/NTableMatrixPlugin.ts +146 -0
  403. package/src/table/js/plugin/NTableSelectPlugin.ts +92 -0
  404. package/src/table/js/table/NTable.ts +88 -0
  405. package/src/table/js/table/NTableController.ts +237 -0
  406. package/src/table/js/table/NTableData.ts +94 -0
  407. package/src/table/js/table/NTableView.ts +395 -0
  408. package/src/table/js/table-cell/NTableCellBoolean.ts +19 -0
  409. package/src/table/js/table-cell/NTableCellDatetime.ts +19 -0
  410. package/src/table/js/table-cell/NTableCellImage.ts +34 -0
  411. package/src/table/js/table-cell/NTableCellMatrix.ts +33 -0
  412. package/src/table/js/table-cell/NTableCellOption.ts +18 -0
  413. package/src/table/js/table-cell/NTableCellSelect.ts +33 -0
  414. package/src/table/js/table-cell/NTableCellString.ts +15 -0
  415. package/src/table/js/table-column/NTableColumn.ts +185 -0
  416. package/src/table/js/table-column/NTableColumnController.ts +132 -0
  417. package/src/table/js/table-column/NTableColumnData.ts +120 -0
  418. package/src/table/js/table-column/NTableColumnView.ts +23 -0
  419. package/src/table/js/table-filter/NTableFilterDatetime.ts +53 -0
  420. package/src/table/js/table-filter/NTableFilterOption.ts +53 -0
  421. package/src/table/js/table-filter/NTableFilterString.ts +54 -0
  422. package/src/tabs/NTabs.md +5 -0
  423. package/src/tabs/css/tabs-item.scss +62 -0
  424. package/src/tabs/{src/tabs → css}/tabs.scss +6 -34
  425. package/src/tabs/index.scss +2 -2
  426. package/src/tabs/index.ts +8 -0
  427. package/src/tabs/js/tabs/NTabs.ts +85 -0
  428. package/src/tabs/js/tabs/NTabsController.ts +140 -0
  429. package/src/tabs/js/tabs/NTabsData.ts +65 -0
  430. package/src/tabs/js/tabs/NTabsView.ts +64 -0
  431. package/src/tabs/js/tabs-item/NTabsItem.ts +88 -0
  432. package/src/tabs/js/tabs-item/NTabsItemController.ts +120 -0
  433. package/src/tabs/js/tabs-item/NTabsItemData.ts +56 -0
  434. package/src/tabs/js/tabs-item/NTabsItemView.ts +111 -0
  435. package/src/transfer/{src/transfer → css}/transfer.scss +6 -4
  436. package/src/transfer/index.scss +1 -1
  437. package/src/transfer/index.ts +6 -0
  438. package/src/transfer/js/transfer/NTransfer.ts +100 -0
  439. package/src/transfer/js/transfer/NTransferController.ts +189 -0
  440. package/src/transfer/js/transfer/NTransferData.ts +101 -0
  441. package/src/transfer/js/transfer/NTransferView.ts +203 -0
  442. package/src/{rating/src/rating → visuals/css}/rating.scss +1 -1
  443. package/src/{tags/src/tags-item/tags-item.scss → visuals/css/tag.scss} +6 -6
  444. package/src/visuals/index.scss +2 -0
  445. package/src/visuals/index.ts +8 -0
  446. package/src/visuals/js/rating/NRating.ts +84 -0
  447. package/src/visuals/js/rating/NRatingController.ts +45 -0
  448. package/src/visuals/js/rating/NRatingData.ts +59 -0
  449. package/src/visuals/js/rating/NRatingView.ts +84 -0
  450. package/src/visuals/js/tag/NTag.ts +45 -0
  451. package/src/visuals/js/tag/NTagController.ts +45 -0
  452. package/src/visuals/js/tag/NTagData.ts +18 -0
  453. package/src/visuals/js/tag/NTagView.ts +43 -0
  454. package/themes/default/alert/src/alert/alert.scss +3 -4
  455. package/themes/default/chart/src/chart-donut/chart-donut.scss +15 -6
  456. package/themes/default/collapse/src/collapse/collapse.scss +0 -9
  457. package/themes/default/collapse/src/collapse-item/collapse-item.scss +15 -4
  458. package/themes/default/confirm/src/confirm/confirm.scss +5 -6
  459. package/themes/default/datepicker/src/datepicker/datepicker.scss +0 -13
  460. package/themes/default/datepicker/src/datepicker-panel/datepicker-panel.scss +15 -5
  461. package/themes/default/demo/src/demo/demo.scss +2 -2
  462. package/themes/default/draggable/src/draggrid-item/draggrid-item.scss +6 -14
  463. package/themes/default/draggable/src/draghandler/draghandler.scss +59 -3
  464. package/themes/default/draggable/src/draglist-item/draglist-item.scss +5 -13
  465. package/themes/default/drawer/src/drawer/drawer.scss +1 -1
  466. package/themes/default/durationpicker/src/durationpicker/durationpicker.scss +3 -2
  467. package/themes/default/empty/src/empty-icon/empty-icon.scss +3 -3
  468. package/themes/default/example.scss +3 -3
  469. package/themes/default/form/src/form/form.scss +4 -0
  470. package/themes/default/form/src/form-frame/form-frame.scss +6 -6
  471. package/themes/default/info/src/info-column/info-column.scss +1 -1
  472. package/themes/default/info/src/info-field/info-field.scss +1 -1
  473. package/themes/default/input/src/input/input.scss +9 -2
  474. package/themes/default/modal/src/modal/modal.scss +1 -1
  475. package/themes/default/notification/src/notification/notification.scss +3 -3
  476. package/themes/default/popover/src/popover/popover.scss +5 -2
  477. package/themes/default/preview/index.scss +1 -3
  478. package/themes/default/preview/src/preview/preview.scss +35 -0
  479. package/themes/default/preview/src/preview-modal/preview-modal.scss +6 -4
  480. package/themes/default/resizer/src/resizer/resizer.scss +7 -1
  481. package/themes/default/root/vars/colors-dark-bluish.scss +8 -2
  482. package/themes/default/root/vars/colors-dark.scss +8 -2
  483. package/themes/default/root/vars/colors-light-bluish.scss +8 -25
  484. package/themes/default/root/vars/colors-light.scss +8 -25
  485. package/themes/default/root/vars/sizes-default.scss +1 -1
  486. package/themes/default/switch/src/switch/switch.scss +2 -2
  487. package/themes/default/table/src/table-column/table-column.scss +2 -2
  488. package/themes/default/tabs/src/tabs-item/tabs-item.scss +7 -7
  489. package/themes/default/tags/src/tags-item/tags-item.scss +2 -8
  490. package/themes/default/transfer/src/transfer/transfer.scss +2 -3
  491. package/dist/themes/webservy.css +0 -1
  492. package/src/alert/index.js +0 -16
  493. package/src/alert/index.scss +0 -1
  494. package/src/alert/src/alert/alert-handler.mjs +0 -143
  495. package/src/button/index.js +0 -7
  496. package/src/button/src/button/button.jsx +0 -164
  497. package/src/button/src/button-group/button-group.jsx +0 -30
  498. package/src/cascader/index.js +0 -7
  499. package/src/cascader/src/cascader/cascader.jsx +0 -346
  500. package/src/cascader/src/cascader-panel/cascader-panel.jsx +0 -362
  501. package/src/chart/index.js +0 -9
  502. package/src/chart/src/chart-bar/chart-bar.jsx +0 -344
  503. package/src/chart/src/chart-donut/chart-donut.jsx +0 -404
  504. package/src/chart/src/chart-item/chart-item.jsx +0 -110
  505. package/src/checkbox/index.js +0 -7
  506. package/src/checkbox/src/checkbox/checkbox.jsx +0 -317
  507. package/src/checkbox/src/checkbox-group/checkbox-group.jsx +0 -237
  508. package/src/collapse/index.js +0 -7
  509. package/src/collapse/src/collapse/collapse.jsx +0 -163
  510. package/src/collapse/src/collapse/collapse.scss +0 -44
  511. package/src/collapse/src/collapse-item/collapse-item.jsx +0 -290
  512. package/src/collapse/src/collapse-item/collapse-item.scss +0 -56
  513. package/src/config/index.js +0 -13
  514. package/src/config/index.scss +0 -3
  515. package/src/config/src/builder/builder.jsx +0 -935
  516. package/src/config/src/builder/builder.scss +0 -284
  517. package/src/config/src/builder/prototypes/button/n-button-group.js +0 -11
  518. package/src/config/src/builder/prototypes/button/n-button.js +0 -37
  519. package/src/config/src/builder/prototypes/cascader/n-cascader.js +0 -11
  520. package/src/config/src/builder/prototypes/checkbox/n-checkbox-group.js +0 -11
  521. package/src/config/src/builder/prototypes/checkbox/n-checkbox.js +0 -11
  522. package/src/config/src/builder/prototypes/confirm/n-confirm.js +0 -11
  523. package/src/config/src/builder/prototypes/datepicker/n-datepicker.js +0 -11
  524. package/src/config/src/builder/prototypes/datetimepicker/n-datetimepicker.js +0 -11
  525. package/src/config/src/builder/prototypes/durationpicker/n-durationpicker.js +0 -11
  526. package/src/config/src/builder/prototypes/empty/n-empty.js +0 -11
  527. package/src/config/src/builder/prototypes/form/n-form-group.js +0 -13
  528. package/src/config/src/builder/prototypes/form/n-form-item.js +0 -13
  529. package/src/config/src/builder/prototypes/form/n-form.js +0 -11
  530. package/src/config/src/builder/prototypes/html/div.js +0 -13
  531. package/src/config/src/builder/prototypes/html/nano.js +0 -11
  532. package/src/config/src/builder/prototypes/html/span.js +0 -11
  533. package/src/config/src/builder/prototypes/info/n-info-column.js +0 -11
  534. package/src/config/src/builder/prototypes/info/n-info.js +0 -11
  535. package/src/config/src/builder/prototypes/input/n-input.js +0 -40
  536. package/src/config/src/builder/prototypes/input-number/n-input-number.js +0 -49
  537. package/src/config/src/builder/prototypes/loader/n-loader.js +0 -11
  538. package/src/config/src/builder/prototypes/modal/n-modal.js +0 -11
  539. package/src/config/src/builder/prototypes/popover/n-popover-group.js +0 -11
  540. package/src/config/src/builder/prototypes/popover/n-popover-item.js +0 -11
  541. package/src/config/src/builder/prototypes/popover/n-popover.js +0 -11
  542. package/src/config/src/builder/prototypes/radio/n-radio-group.js +0 -11
  543. package/src/config/src/builder/prototypes/radio/n-radio.js +0 -11
  544. package/src/config/src/builder/prototypes/rating/n-rating.js +0 -11
  545. package/src/config/src/builder/prototypes/select/n-select.js +0 -11
  546. package/src/config/src/builder/prototypes/slider/n-slider.js +0 -11
  547. package/src/config/src/builder/prototypes/switch/n-switch.js +0 -31
  548. package/src/config/src/builder/prototypes/table/n-table-column.js +0 -11
  549. package/src/config/src/builder/prototypes/table/n-table.js +0 -11
  550. package/src/config/src/builder/prototypes/tabs/n-tabs-item.js +0 -11
  551. package/src/config/src/builder/prototypes/tabs/n-tabs.js +0 -11
  552. package/src/config/src/builder/prototypes/tags/n-tags-item.js +0 -11
  553. package/src/config/src/builder/prototypes/tags/n-tags.js +0 -11
  554. package/src/config/src/builder/prototypes/textarea/n-textarea.js +0 -11
  555. package/src/config/src/builder/prototypes/timepicker/n-timepicker.js +0 -11
  556. package/src/config/src/builder/prototypes/transfer/n-transfer.js +0 -11
  557. package/src/config/src/config/config-next.jsx +0 -355
  558. package/src/config/src/config/config.jsx +0 -261
  559. package/src/config/src/reference-panel/reference-panel.jsx +0 -196
  560. package/src/config/src/reference-panel/reference-panel.scss +0 -197
  561. package/src/config/src/reference-picker/reference-picker.jsx +0 -146
  562. package/src/config/src/reference-picker/reference-picker.scss +0 -3
  563. package/src/confirm/index.js +0 -27
  564. package/src/confirm/index.scss +0 -1
  565. package/src/confirm/src/confirm/confirm-handler.mjs +0 -227
  566. package/src/confirm/src/confirm/confirm.jsx +0 -214
  567. package/src/datepicker/index.js +0 -7
  568. package/src/datepicker/index.scss +0 -2
  569. package/src/datepicker/src/datepicker/datepicker.jsx +0 -623
  570. package/src/datepicker/src/datepicker-panel/datepicker-panel.jsx +0 -705
  571. package/src/datetimepicker/index.js +0 -5
  572. package/src/datetimepicker/index.scss +0 -1
  573. package/src/datetimepicker/src/datetimepicker/datetimepicker.jsx +0 -418
  574. package/src/draggable/index.js +0 -13
  575. package/src/draggable/src/draggrid/draggrid.jsx +0 -754
  576. package/src/draggable/src/draggrid-item/draggrid-item.jsx +0 -268
  577. package/src/draggable/src/draghandler/draghandler.js +0 -860
  578. package/src/draggable/src/draghandler/draghandler.scss +0 -26
  579. package/src/draggable/src/draglist/draglist.jsx +0 -923
  580. package/src/draggable/src/draglist-item/draglist-item.jsx +0 -343
  581. package/src/draggable/src/dropzone/dropzone.jsx +0 -194
  582. package/src/drawer/index.js +0 -5
  583. package/src/drawer/index.scss +0 -1
  584. package/src/drawer/src/drawer/drawer.jsx +0 -440
  585. package/src/durationpicker/index.js +0 -5
  586. package/src/durationpicker/index.scss +0 -1
  587. package/src/durationpicker/src/durationpicker/durationpicker.jsx +0 -463
  588. package/src/empty/index.js +0 -5
  589. package/src/empty/src/empty-icon/empty-icon.jsx +0 -69
  590. package/src/file/index.js +0 -6
  591. package/src/file/index.scss +0 -1
  592. package/src/file/src/file/file.jsx +0 -219
  593. package/src/form/index.js +0 -13
  594. package/src/form/src/form/form-rules.mjs +0 -212
  595. package/src/form/src/form/form.jsx +0 -346
  596. package/src/form/src/form-bag/form-bag.jsx +0 -90
  597. package/src/form/src/form-frame/form-frame.jsx +0 -313
  598. package/src/form/src/form-group/form-group.jsx +0 -332
  599. package/src/form/src/form-item/form-item.jsx +0 -305
  600. package/src/grid/index.scss +0 -1
  601. package/src/index.esm.js +0 -177
  602. package/src/info/index.js +0 -17
  603. package/src/info/src/info/info.jsx +0 -208
  604. package/src/info/src/info-column/info-column.jsx +0 -171
  605. package/src/info/src/info-column/info-column.scss +0 -5
  606. package/src/info/src/info-field/info-field.jsx +0 -43
  607. package/src/info/src/info-field/types/info-field-boolean.jsx +0 -25
  608. package/src/info/src/info-field/types/info-field-datetime.jsx +0 -25
  609. package/src/info/src/info-field/types/info-field-image.jsx +0 -38
  610. package/src/info/src/info-field/types/info-field-option.jsx +0 -54
  611. package/src/info/src/info-field/types/info-field-string.jsx +0 -25
  612. package/src/input/index.js +0 -5
  613. package/src/input/src/input/input.jsx +0 -257
  614. package/src/input-number/index.js +0 -5
  615. package/src/input-number/index.scss +0 -1
  616. package/src/input-number/src/input-number/input-number.jsx +0 -441
  617. package/src/loader/index.js +0 -5
  618. package/src/loader/src/loader/loader.jsx +0 -136
  619. package/src/map/index.js +0 -8
  620. package/src/map/src/map/map.jsx +0 -98
  621. package/src/map/src/map-marker/map-marker.jsx +0 -145
  622. package/src/mixins/src/cmer.js +0 -36
  623. package/src/mixins/src/cslo.js +0 -17
  624. package/src/mixins/src/ctor.js +0 -25
  625. package/src/mixins/src/node.js +0 -15
  626. package/src/modal/index.js +0 -5
  627. package/src/modal/src/modal/modal.jsx +0 -442
  628. package/src/notification/index.js +0 -25
  629. package/src/notification/index.scss +0 -1
  630. package/src/notification/src/notification/notification-element.mjs +0 -74
  631. package/src/notification/src/notification/notification-handler.mjs +0 -75
  632. package/src/paginator/index.js +0 -5
  633. package/src/paginator/index.scss +0 -1
  634. package/src/paginator/src/paginator/paginator.jsx +0 -416
  635. package/src/popover/index.js +0 -26
  636. package/src/popover/src/popover/popover-element.mjs +0 -576
  637. package/src/popover/src/popover/popover-handler.mjs +0 -122
  638. package/src/popover/src/popover/popover-helper.mjs +0 -75
  639. package/src/popover/src/popover/popover.jsx +0 -307
  640. package/src/popover/src/popover-group/popover-group.jsx +0 -51
  641. package/src/popover/src/popover-option/popover-option.jsx +0 -204
  642. package/src/preview/index.js +0 -54
  643. package/src/preview/src/preview/preview-handler.mjs +0 -205
  644. package/src/preview/src/preview/preview.jsx +0 -234
  645. package/src/preview/src/preview/preview.scss +0 -41
  646. package/src/preview/src/preview-image/preview-image.jsx +0 -115
  647. package/src/preview/src/preview-image/preview-image.scss +0 -68
  648. package/src/preview/src/preview-modal/preview-modal.jsx +0 -126
  649. package/src/preview/src/preview-modal/preview-modal.scss +0 -69
  650. package/src/preview/src/preview-plain/preview-plain.jsx +0 -87
  651. package/src/preview/src/preview-plain/preview-plain.scss +0 -44
  652. package/src/preview/src/preview-video/preview-video.jsx +0 -142
  653. package/src/preview/src/preview-video/preview-video.scss +0 -33
  654. package/src/radio/index.js +0 -7
  655. package/src/radio/src/radio/radio.jsx +0 -186
  656. package/src/radio/src/radio-group/radio-group.jsx +0 -109
  657. package/src/rating/index.js +0 -5
  658. package/src/rating/index.scss +0 -1
  659. package/src/rating/src/rating/rating.jsx +0 -145
  660. package/src/resizer/index.js +0 -7
  661. package/src/resizer/src/resizer/resizer-next.jsx +0 -556
  662. package/src/resizer/src/resizer/resizer.jsx +0 -527
  663. package/src/resizer/src/resizer/resizer.scss +0 -56
  664. package/src/scrollbar/index.js +0 -5
  665. package/src/scrollbar/src/scrollbar/scrollbar.jsx +0 -659
  666. package/src/select/index.js +0 -7
  667. package/src/select/src/select/select.jsx +0 -933
  668. package/src/select/src/select-option/select-option.jsx +0 -162
  669. package/src/select/src/select-option/select-option.scss +0 -1
  670. package/src/slider/index.js +0 -5
  671. package/src/slider/src/slider/slider.jsx +0 -392
  672. package/src/switch/index.js +0 -5
  673. package/src/switch/src/switch/switch.jsx +0 -188
  674. package/src/table/index.js +0 -30
  675. package/src/table/src/table/table.jsx +0 -678
  676. package/src/table/src/table-cell/table-cell.jsx +0 -91
  677. package/src/table/src/table-cell/types/table-cell-boolean.jsx +0 -29
  678. package/src/table/src/table-cell/types/table-cell-datetime.jsx +0 -29
  679. package/src/table/src/table-cell/types/table-cell-image.jsx +0 -53
  680. package/src/table/src/table-cell/types/table-cell-matrix.jsx +0 -155
  681. package/src/table/src/table-cell/types/table-cell-option.jsx +0 -58
  682. package/src/table/src/table-cell/types/table-cell-select.jsx +0 -105
  683. package/src/table/src/table-cell/types/table-cell-string.jsx +0 -29
  684. package/src/table/src/table-column/table-column.jsx +0 -506
  685. package/src/table/src/table-filter/table-filter.jsx +0 -242
  686. package/src/table/src/table-filter/types/table-filter-boolean.jsx +0 -40
  687. package/src/table/src/table-filter/types/table-filter-datetime.jsx +0 -43
  688. package/src/table/src/table-filter/types/table-filter-option.jsx +0 -66
  689. package/src/table/src/table-filter/types/table-filter-string.jsx +0 -45
  690. package/src/tabs/index.js +0 -7
  691. package/src/tabs/src/tabs/tabs.jsx +0 -219
  692. package/src/tabs/src/tabs-item/tabs-item.jsx +0 -201
  693. package/src/tabs/src/tabs-item/tabs-item.scss +0 -30
  694. package/src/tags/index.js +0 -7
  695. package/src/tags/index.scss +0 -2
  696. package/src/tags/src/tags/tags.jsx +0 -110
  697. package/src/tags/src/tags/tags.scss +0 -9
  698. package/src/tags/src/tags-item/tags-item.jsx +0 -119
  699. package/src/textarea/index.js +0 -5
  700. package/src/textarea/index.scss +0 -1
  701. package/src/textarea/src/textarea/textarea.jsx +0 -157
  702. package/src/timepicker/index.js +0 -7
  703. package/src/timepicker/index.scss +0 -2
  704. package/src/timepicker/src/timepicker/timepicker.jsx +0 -335
  705. package/src/timepicker/src/timepicker-panel/timepicker-panel.jsx +0 -317
  706. package/src/tooltip/index.scss +0 -1
  707. package/src/transfer/index.js +0 -5
  708. package/src/transfer/src/transfer/transfer.jsx +0 -543
  709. package/src/virtualscroller/index.js +0 -5
  710. package/src/virtualscroller/index.scss +0 -1
  711. package/src/virtualscroller/src/virtualscroller/virtualscroller.jsx +0 -547
  712. package/src/virtualscroller/src/virtualscroller/virtualscroller.scss +0 -52
  713. package/themes/default/preview/src/preview-image/preview-image.scss +0 -5
  714. package/types/index.d.ts +0 -61
  715. /package/src/root/{helpers.scss → css/helpers.scss} +0 -0
  716. /package/src/root/{vars.scss → css/vars-delete.scss} +0 -0
@@ -1,935 +0,0 @@
1
- import { Arr, Dom, Mix, Locale, Obj, Hash, Num } from "@kizmann/pico-js";
2
-
3
- window.NanoBuilderPropType = {
4
- 'root': Locale.trans('Root'),
5
- 'binds': Locale.trans('Bind'),
6
- 'props': Locale.trans('Property'),
7
- 'attrs': Locale.trans('Attribute'),
8
- 'on': Locale.trans('Event'),
9
- };
10
-
11
- window.NanoBuilderPropCode = {
12
- 'string': Locale.trans('String'),
13
- 'number': Locale.trans('Number'),
14
- 'boolean': Locale.trans('Boolean'),
15
- 'object': Locale.trans('Object'),
16
- 'function': Locale.trans('Function'),
17
- };
18
-
19
- window.NanoBuilderProps = {
20
- classList: {
21
- for: ['root', 'attrs', 'props'], type: 'String'
22
- },
23
- vIf: {
24
- for: ['root'], type: 'String'
25
- },
26
- vShow: {
27
- for: ['root'], type: 'String'
28
- },
29
- };
30
-
31
- window.NanoBuilderTypes = {
32
- //
33
- };
34
-
35
- window.NanoBuilderIndexies = {
36
- //
37
- };
38
-
39
- // DOM elements
40
- require('./prototypes/html/nano');
41
- require('./prototypes/html/div');
42
- require('./prototypes/html/span');
43
-
44
- // Nano elements
45
- require('./prototypes/button/n-button');
46
- require('./prototypes/button/n-button-group');
47
- require('./prototypes/cascader/n-cascader');
48
- require('./prototypes/checkbox/n-checkbox');
49
- require('./prototypes/checkbox/n-checkbox-group');
50
- require('./prototypes/confirm/n-confirm');
51
- require('./prototypes/datepicker/n-datepicker');
52
- require('./prototypes/datetimepicker/n-datetimepicker');
53
- require('./prototypes/durationpicker/n-durationpicker');
54
- require('./prototypes/empty/n-empty');
55
- require('./prototypes/form/n-form');
56
- require('./prototypes/form/n-form-group');
57
- require('./prototypes/form/n-form-item');
58
- require('./prototypes/input/n-input');
59
- require('./prototypes/input-number/n-input-number');
60
- require('./prototypes/loader/n-loader');
61
- require('./prototypes/modal/n-modal');
62
- require('./prototypes/radio/n-radio');
63
- require('./prototypes/radio/n-radio-group');
64
- require('./prototypes/rating/n-rating');
65
- require('./prototypes/select/n-select');
66
- require('./prototypes/slider/n-slider');
67
- require('./prototypes/switch/n-switch');
68
- require('./prototypes/table/n-table');
69
- require('./prototypes/table/n-table-column');
70
- require('./prototypes/tabs/n-tabs');
71
- require('./prototypes/tabs/n-tabs-item');
72
- require('./prototypes/tags/n-tags');
73
- require('./prototypes/tags/n-tags-item');
74
- require('./prototypes/timepicker/n-timepicker');
75
- require('./prototypes/transfer/n-transfer');
76
-
77
- export default {
78
-
79
- name: 'NBuilder',
80
-
81
- props: {
82
-
83
- modelValue: {
84
- default()
85
- {
86
- return {};
87
- },
88
- type: [Object]
89
- },
90
-
91
- scope: {
92
- default()
93
- {
94
- return {};
95
- },
96
- type: [Object]
97
- },
98
-
99
- model: {
100
- default()
101
- {
102
- return {};
103
- },
104
- type: [Object]
105
- },
106
-
107
- renderDemo: {
108
- default()
109
- {
110
- return true;
111
- },
112
- type: [Boolean]
113
- },
114
-
115
- renderExport: {
116
- default()
117
- {
118
- return true;
119
- },
120
- type: [Boolean]
121
- },
122
-
123
- },
124
-
125
- data()
126
- {
127
- return {
128
- init: false, demo: false, collapse: [], safevar: this.normalizeModel(this.modelValue)
129
- };
130
- },
131
-
132
- watch: {
133
- modelValue: function () {
134
- this.safevar = this.normalizeModel(this.modelValue)
135
- }
136
- },
137
-
138
- mounted()
139
- {
140
- this.init = true;
141
- },
142
-
143
- methods: {
144
-
145
- exportJson(value)
146
- {
147
- return JSON.stringify(Obj.clone(value), null, 4).replace(/"!FUNC:(.*?):FUNC!"/g, (matches) => {
148
- return matches.replace(/^"!FUNC:/, '').replace(/:FUNC!"$/, '').replace(/\\"/, '"').replace(/\\n/g, "\n");
149
- });
150
- },
151
-
152
- exportExecutable(value)
153
- {
154
- return new Function(`return ${this.exportJson(value)};`)();
155
- },
156
-
157
- normalizeModel(model)
158
- {
159
- let result = {};
160
-
161
- Obj.each(model, (value, key) => {
162
- result[key] = Obj.assign(this.normalizeChild(value), {
163
- order: (Mix.vals(result).length + 1) * 100
164
- });
165
- });
166
-
167
- return result;
168
- },
169
-
170
- normalizeChild(child)
171
- {
172
- let result = this.applyProps(null, {
173
- ...Obj.except(child, ['content']), content: {}, builder: this.buildProps(child),
174
- });
175
-
176
- if ( Mix.isArray(child.content) ) {
177
- child.content = Arr.first(child.content);
178
- }
179
-
180
- if ( ! Mix.isObj(child.content) && ! Mix.isString(child.content) ) {
181
- child.content = {};
182
- }
183
-
184
- result.builder["null"] = {
185
- type: typeof child.content
186
- }
187
-
188
- if (Mix.isObj(child.content)) {
189
- Obj.each(child.content || {}, (value, key) => {
190
-
191
- if ( ! key.match(':') ) {
192
- key += ':' + Hash.uuid();
193
- }
194
-
195
- result['content'][key] = Obj.assign(this.normalizeChild(value), {
196
- order: (Mix.vals(result['content']).length + 1) * 100
197
- });
198
- });
199
- } else {
200
- result.content = child.content;
201
- }
202
-
203
- return result;
204
- },
205
-
206
- getOriginalValue(prop)
207
- {
208
- let safevalue = prop.value;
209
-
210
- if ( typeof prop.value === 'function' ) {
211
- safevalue = btoa("!FUNC:" + prop.value.toString() + ":FUNC!");
212
- }
213
-
214
- return safevalue;
215
- },
216
-
217
- getSafeValue(prop)
218
- {
219
- let safevalue = '';
220
-
221
- if ( typeof prop.value === 'string' ) {
222
- safevalue = Mix.string(prop.value);
223
- }
224
-
225
- if ( typeof prop.value === 'boolean' ) {
226
- safevalue = Mix.string(prop.value);
227
- }
228
-
229
- if ( typeof prop.value === 'number' ) {
230
- safevalue = Mix.string(prop.value);
231
- }
232
-
233
- if ( typeof prop.value === 'object' ) {
234
- safevalue = JSON.stringify(prop.value);
235
- }
236
-
237
- if ( typeof prop.value === 'function' ) {
238
- safevalue = btoa("!FUNC:" + prop.value.toString() + ":FUNC!");
239
- }
240
-
241
- return safevalue;
242
- },
243
-
244
- getRealValue(prop)
245
- {
246
- let realvalue = '';
247
-
248
- if ( prop.code === 'string' ) {
249
- realvalue = Mix.string(prop.value);
250
- }
251
-
252
- if ( prop.code === 'boolean' ) {
253
- realvalue = Mix.boolean(prop.value);
254
- }
255
-
256
- if ( prop.code === 'number' ) {
257
- realvalue = Mix.number(prop.value, 0);
258
- }
259
-
260
- if ( prop.code === 'object' ) {
261
- realvalue = JSON.parse(prop.value);
262
- }
263
-
264
- if ( prop.code === 'function' ) {
265
- realvalue = atob(prop.original);
266
- }
267
-
268
- return realvalue;
269
- },
270
-
271
- changeElement(key, update)
272
- {
273
- if ( Mix.isEmpty(update) ) {
274
- return;
275
- }
276
-
277
- let newKey = key.replace(/^(.*?)([^\.]+):([^\.]+)$/, `$1${update}:$3`);
278
-
279
- let value = Obj.get(this, key, {});
280
-
281
- Obj.unset(this, key);
282
- Obj.set(this, newKey, value);
283
-
284
- this.collapse = Arr.each(this.collapse, (k) => {
285
- return k.replace(key, newKey);
286
- });
287
- },
288
-
289
- changeAlias(key, update)
290
- {
291
- if ( Mix.isEmpty(update) ) {
292
- return;
293
- }
294
-
295
- let newKey = key.replace(/^(.*?)([^\.]+):([^\.]+)$/, `$1$2:${update}`);
296
-
297
- let value = Obj.get(this, key, {});
298
-
299
- Obj.unset(this, key);
300
- Obj.set(this, newKey, value);
301
-
302
- this.collapse = Arr.each(this.collapse, (k) => {
303
- return k.replace(key, newKey);
304
- });
305
- },
306
-
307
- changeType(key, type)
308
- {
309
- let value = Obj.get(this, key, {});
310
-
311
- let original = Obj.get(value, 'builder.null.type');
312
-
313
- if ( type === 'object' ) {
314
- value.content = {};
315
- }
316
-
317
- if ( type === 'string' ) {
318
- value.content = '';
319
- }
320
-
321
- Obj.set(value, 'builder.null.type', typeof value.content);
322
- },
323
-
324
- applyProps(key = null, value = {})
325
- {
326
- if ( ! Mix.isEmpty(key) ) {
327
- value = Obj.get(this, key, {});
328
- }
329
-
330
- let reset = [
331
- 'vIf', 'vShow', 'classList', 'vLocale', 'binds', 'attrs', 'props', 'on',
332
- ];
333
-
334
- Obj.each(reset, (prop) => {
335
- Obj.unset(value, prop);
336
- });
337
-
338
- Obj.each(value.builder || {}, (val) => {
339
-
340
- if ( Mix.isEmpty(val.key) ) {
341
- return;
342
- }
343
-
344
- let bindValue = {
345
- value: val.value, fallback: null
346
- };
347
-
348
- if ( val.code === 'string' ) {
349
- bindValue.fallback = Mix.string(val.fallback || '');
350
- }
351
-
352
- if ( val.code === 'boolean' ) {
353
- bindValue.fallback = Mix.boolean(val.fallback || 'false');
354
- }
355
-
356
- if ( val.code === 'object' ) {
357
- bindValue.fallback = JSON.parse(val.fallback || '{}');
358
- }
359
-
360
- if ( val.type === 'binds' ) {
361
- return Obj.set(value, [val.type, val.key], bindValue);
362
- }
363
-
364
- let realvalue = '';
365
-
366
- try {
367
- realvalue = this.getRealValue(val);
368
- } catch (e) {
369
- if ( ! Mix.isEmpty(val.value) ) {
370
- console.error('Invalid JSON: ' + val.value);
371
- }
372
- }
373
-
374
- if ( val.type === 'root' ) {
375
- return Obj.set(value, val.key, realvalue);
376
- }
377
-
378
- if ( val.type === 'attrs' ) {
379
- return Obj.set(value, [val.type, val.key], realvalue);
380
- }
381
-
382
- if ( val.type === 'props' ) {
383
- return Obj.set(value, [val.type, val.key], realvalue);
384
- }
385
-
386
- if ( val.type === 'on' ) {
387
- return Obj.set(value, [val.type, val.key], realvalue);
388
- }
389
-
390
- });
391
-
392
- if ( Mix.isEmpty(key) ) {
393
- return value;
394
- }
395
-
396
- return Obj.set(this, key, value);
397
- },
398
-
399
- buildProps(el, key = null)
400
- {
401
- let builder = {};
402
-
403
- Obj.each(Obj.only(el, ['vIf', 'vShow', 'classList']), (value, sey) => {
404
- builder[Hash.uuid()] = {
405
- type: 'root', code: typeof value, key: sey, value: this.getSafeValue({ value }), fallback: null, original: this.getOriginalValue({ value })
406
- };
407
- });
408
-
409
- Obj.each(Obj.get(el, `binds`, {}), (value, sey) => {
410
-
411
- let result = {
412
- type: 'binds', code: typeof value, key: sey, fallback: null, original: this.getOriginalValue({ value })
413
- }
414
-
415
- if ( Mix.isString(value) ) {
416
- result.value = this.getSafeValue({ value });
417
- }
418
-
419
- if ( Mix.isRef(value) ) {
420
- Obj.assign(result, { value: this.getSafeValue(value), fallback: Obj.get(value, 'fallback', null) })
421
- }
422
-
423
- builder[Hash.uuid()] = result;
424
- });
425
-
426
- Obj.each(Obj.get(el, `props`, {}), (value, sey) => {
427
- builder[Hash.uuid()] = { type: 'props', code: typeof value, key: sey, value: this.getSafeValue({ value }), fallback: null, original: this.getOriginalValue({ value }) };
428
- });
429
-
430
- Obj.each(Obj.get(el, `attrs`, {}), (value, sey) => {
431
- builder[Hash.uuid()] = { type: 'attrs', code: typeof value, key: sey, value: this.getSafeValue({ value }), fallback: null, original: this.getOriginalValue({ value }) };
432
- });
433
-
434
- Obj.each(Obj.get(el, `on`, {}), (value, sey) => {
435
- builder[Hash.uuid()] = { type: 'on', code: typeof value, key: sey, value: this.getSafeValue({ value }), fallback: null, original: this.getOriginalValue({ value }) };
436
- });
437
-
438
- if ( Mix.isEmpty(key) ) {
439
- return builder;
440
- }
441
-
442
- this.$nextTick(() => {
443
- Obj.set(this, `${key}.builder`, builder);
444
- });
445
-
446
- return builder;
447
- },
448
-
449
- addProp(key)
450
- {
451
- let value = Obj.get(this, `${key}.builder`, {});
452
-
453
- Obj.set(value, Hash.uuid(), {
454
- type: 'props', code: 'string', key: '', value: '', fallback: null
455
- });
456
-
457
- Obj.set(this, `${key}.builder`, value);
458
- },
459
-
460
- removeProp(key, prop)
461
- {
462
- Obj.unset(this, `${key}.builder.${prop}`);
463
-
464
- this.applyProps(key);
465
- },
466
-
467
- collapseElement(key)
468
- {
469
- Arr.toggle(this.collapse, key);
470
- },
471
-
472
- addElement(key)
473
- {
474
- let value = Obj.get(this, key, {});
475
-
476
- Obj.set(value, 'div:' + Hash.uuid(), {
477
- order: (Mix.vals(value).length + 1) * 100, props: { modelValue: '$scope.list' }, content: {}
478
- });
479
-
480
- Obj.assign(this, key, value);
481
- },
482
-
483
- removeElement(key)
484
- {
485
- Obj.unset(this, key);
486
- },
487
-
488
- moveupElement(key)
489
- {
490
- let [el, childs] = [
491
- Obj.get(this, key), Obj.get(this, key.replace(/\.[^.]+$/, ''))
492
- ];
493
-
494
- let close = Number.MIN_VALUE;
495
-
496
- Arr.each(childs, (sub) => {
497
- if ( sub.order < el.order ) close = Math.max(close, sub.order);
498
- });
499
-
500
- if ( close === Number.MIN_VALUE ) {
501
- return;
502
- }
503
-
504
- let replacement = Arr.find(childs, {
505
- order: close
506
- });
507
-
508
- Obj.assign(replacement, {
509
- order: el.order
510
- });
511
-
512
- Obj.assign(el, { order: close });
513
- },
514
-
515
- movedownElement(key)
516
- {
517
- let [el, childs] = [
518
- Obj.get(this, key), Obj.get(this, key.replace(/\.[^.]+$/, ''))
519
- ];
520
-
521
- let close = Number.MAX_VALUE;
522
-
523
- Arr.each(childs, (sub) => {
524
- if ( sub.order > el.order ) close = Math.min(close, sub.order);
525
- });
526
-
527
- if ( close === Number.MAX_VALUE ) {
528
- return;
529
- }
530
-
531
- let replacement = Arr.find(childs, {
532
- order: close
533
- });
534
-
535
- Obj.assign(replacement, {
536
- order: el.order
537
- });
538
-
539
- Obj.assign(el, { order: close });
540
- },
541
-
542
- },
543
-
544
- renderTools(el, value, key)
545
- {
546
- let rootProps = {
547
- //
548
- };
549
-
550
- rootProps['onDblclick'] = () => {
551
- this.collapseElement(key);
552
- };
553
-
554
- let collapseProps = {
555
- href: 'javascript:void(0)',
556
- };
557
-
558
- collapseProps['onClick'] = () => {
559
- this.collapseElement(key);
560
- };
561
-
562
- let addProps = {
563
- href: 'javascript:void(0)',
564
- };
565
-
566
- addProps['onClick'] = () => {
567
- this.addElement(`${key}.content`);
568
- };
569
-
570
- let removeProps = {
571
- href: 'javascript:void(0)',
572
- };
573
-
574
- removeProps['onClick'] = () => {
575
- this.removeElement(key);
576
- };
577
-
578
- let moveupProps = {
579
- href: 'javascript:void(0)',
580
- };
581
-
582
- moveupProps['onClick'] = () => {
583
- this.moveupElement(key);
584
- };
585
-
586
- let movedownProps = {
587
- href: 'javascript:void(0)',
588
- };
589
-
590
- movedownProps['onClick'] = () => {
591
- this.movedownElement(key);
592
- };
593
-
594
-
595
- return (
596
- <div class="n-builder__tools" {...rootProps}>
597
- <div class="n-builder__collapse">
598
- <a {...collapseProps}><i class="fa fa-bars"></i></a>
599
- </div>
600
- <div class="n-builder__name">
601
- {key.replace(/^.*?([^\.:]+):([^\.:]+)$/, '$1')}<span>{key.replace(/^.*?([^\.:]+):([^\.:]+)$/, '$2')}</span>
602
- </div>
603
- <div class="n-builder__move">
604
- <a {...moveupProps}><i class="fa fa-angle-up"></i></a>
605
- <a {...movedownProps}><i class="fa fa-angle-down"></i></a>
606
- </div>
607
- <div class="n-builder__add">
608
- <a {...addProps}><i class="fa fa-plus"></i></a>
609
- </div>
610
- <div class="n-builder__remove">
611
- <a {...removeProps}><i class="fa fa-trash"></i></a>
612
- </div>
613
- </div>
614
- );
615
- },
616
-
617
- renderProp(el, sub, key)
618
- {
619
- if ( sub === "null" ) {
620
- return null;
621
- }
622
-
623
- let group = key.replace(/^.*?([^\.]+):([^\.]+)$/, '$1')
624
- let value = Obj.get(this.$data, `${key}.builder.${sub}`, {});
625
-
626
- let props = Obj.clone(Obj.get(window.NanoBuilderIndexies, `${group}.props`, {}));
627
-
628
- props = Obj.assign({}, window.NanoBuilderProps, props);
629
-
630
- Obj.each(props, (prop, index) => {
631
- if ( ! Mix.isEmpty(prop.for) && ! Arr.has(prop.for, value.type) ) {
632
- props = Obj.unset(props, index);
633
- }
634
- });
635
-
636
- let typeProps = {
637
- size: 'sm', options: window.NanoBuilderPropType
638
- };
639
-
640
- typeProps['onUpdate:modelValue'] = () => {
641
- this.$nextTick(() => this.applyProps(key));
642
- };
643
-
644
- let keyProps = {
645
- size: 'sm', allowCreate: true, options: props, optionsLabel: '$index'
646
- };
647
-
648
- keyProps['onUpdate:modelValue'] = () => {
649
- this.$nextTick(() => this.applyProps(key));
650
- };
651
-
652
- let codeProps = {
653
- size: 'sm', options: window.NanoBuilderPropCode
654
- };
655
-
656
- codeProps['onUpdate:modelValue'] = () => {
657
- this.$nextTick(() => this.applyProps(key));
658
- };
659
-
660
- let values = Obj.get(props, `${value.key}.options`, []);
661
-
662
- let valueInputProps = {
663
- size: 'sm', model: this.model, scope: this.scope
664
- };
665
-
666
- valueInputProps['onUpdate:modelValue'] = () => {
667
- this.$nextTick(() => this.applyProps(key));
668
- };
669
-
670
- let valueHtml = (
671
- <NReferencePicker vModel={value.value} {...valueInputProps} />
672
- );
673
-
674
- let fallbackProps = {
675
- size: 'sm', minRows: 1, autoRows: true
676
- };
677
-
678
- fallbackProps['onUpdate:modelValue'] = () => {
679
- this.$nextTick(() => this.applyProps(key));
680
- };
681
-
682
- let tooltipHtml = (
683
- <div class="n-builder_prop-text">
684
- <p>{Obj.get(props, `${value.key}.desc`, '')}</p>
685
- </div>
686
- );
687
-
688
- return (
689
- <div class="n-builder_prop">
690
- <div class="n-builder_prop-type">
691
- <NSelect vModel={value.type} {...typeProps} />
692
- </div>
693
- <div class="n-builder_prop-key">
694
- <NSelect vModel={value.key} {...keyProps} />
695
- </div>
696
- <div class="n-builder_prop-func">
697
- <NSelect vModel={value.code} {...codeProps} />
698
- </div>
699
- <div class="n-builder_prop-value">
700
- {valueHtml}
701
- </div>
702
- <div class="n-builder_prop-fallback">
703
- <NInput vModel={value.fallback} {...fallbackProps} />
704
- </div>
705
- <div class="n-builder_prop-button">
706
- <NButton size="sm" type="danger" onClick={() => this.removeProp(key, sub)}>Remove</NButton>
707
- </div>
708
- </div>
709
- );
710
- },
711
-
712
- renderProps(el, value, key)
713
- {
714
- if ( !Arr.has(this.collapse, key) ) {
715
- return null;
716
- }
717
-
718
- let elementProps = {
719
- options: window.NanoBuilderTypes, allowCreate: true, modelValue: key.replace(/^.*?([^\.]+):([^\.]+)$/, '$1'),
720
- };
721
-
722
- elementProps['onUpdate:modelValue'] = (value) => {
723
- this.changeElement(key, value);
724
- };
725
-
726
- let aliasProps = {
727
- modelValue: key.replace(/^.*?([^\.]+):([^\.]+)$/, '$2'),
728
- };
729
-
730
- aliasProps['onUpdate:modelValue'] = (value) => {
731
- this.changeAlias(key, value);
732
- };
733
-
734
- let plainProps = {
735
- modelValue: Obj.get(value, 'builder.null.type'),
736
- options: {
737
- 'object': this.trans('Object'),
738
- 'string': this.trans('String'),
739
- }
740
- };
741
-
742
- plainProps['onUpdate:modelValue'] = (value) => {
743
- this.changeType(key, value);
744
- };
745
-
746
- let addProps = {
747
- type: 'primary', size: 'sm', link: true
748
- };
749
-
750
- addProps['onClick'] = () => {
751
- this.addProp(key, value);
752
- };
753
-
754
- let props = Obj.get(value, `builder`);
755
-
756
- if ( ! Obj.has(value, 'builder') ) {
757
- props = this.buildProps(el, key, value);
758
- }
759
-
760
- return (
761
- <NForm class="n-builder__props">
762
- <NFormItem class="n-builder__element-type" label={this.trans('Type')}>
763
- <NSelect {...elementProps} />
764
- </NFormItem>
765
- <NFormItem class="n-builder__element-alias" label={this.trans('Alias')}>
766
- <NInput {...aliasProps} />
767
- </NFormItem>
768
- <NFormItem class="n-builder__element-plain" label={this.trans('Content')}>
769
- <NSelect {...plainProps}>{this.trans('Enable plain')}</NSelect>
770
- </NFormItem>
771
- <div class="n-builder__element-prop">
772
- <NButton {...addProps}>Add property</NButton>
773
- </div>
774
- <div class="n-builder__element-list">
775
- {Arr.each(props, (prop, sub) => this.ctor('renderProp')(el, sub, key))}
776
- </div>
777
- </NForm>
778
- );
779
- },
780
-
781
- renderElement(el, value, key)
782
- {
783
- let classList = [
784
- 'n-builder__element'
785
- ];
786
-
787
- if ( Arr.has(this.collapse, key) ) {
788
- classList.push('is-open');
789
- }
790
-
791
- let builderHtml = () => {
792
- return this.ctor('renderBuilder')(value.content || {}, `${key}.content`);
793
- };
794
-
795
- if ( value.builder["null"]["type"] === 'string' ) {
796
- builderHtml = () => {
797
- return (<div><NInput vModel={value.content} /></div>);
798
- };
799
- }
800
-
801
- return (
802
- <div class={classList}>
803
- {this.ctor('renderTools')(el, value, key)}
804
- {this.ctor('renderProps')(el, value, key)}
805
- {builderHtml()}
806
- </div>
807
- );
808
- },
809
-
810
- renderBuilder(el, key)
811
- {
812
- if ( Mix.isEmpty(el) ) {
813
- return null;
814
- }
815
-
816
- let items = Arr.each(Obj.sort(Obj.clone(el), 'order'), (v) => {
817
-
818
- let args = [
819
- Obj.get(this.$data, key, {}),
820
- Obj.get(this.$data, [key, v._key], {}),
821
- `${key}.${v._key}`
822
- ];
823
-
824
- return this.ctor('renderElement')(...args);
825
- });
826
-
827
- return (
828
- <div class="n-builder__frame">
829
- {items}
830
- </div>
831
- );
832
- },
833
-
834
- renderBody()
835
- {
836
- return (
837
- <div class="n-builder__body">
838
- {this.ctor('renderBuilder')(this.safevar, 'safevar')}
839
- </div>
840
- );
841
- },
842
-
843
- renderHead()
844
- {
845
- let addProps = {
846
- type: 'primary'
847
- };
848
-
849
- addProps['onClick'] = () => {
850
- this.addElement('safevar');
851
- };
852
-
853
- let addHtml = (
854
- <div class="n-builder__head-add">
855
- <NButton {...addProps}>{this.trans('Add root element')}</NButton>
856
- </div>
857
- );
858
-
859
- let demoProps = {
860
- type: 'primary'
861
- };
862
-
863
- demoProps['onClick'] = () => {
864
- this.demo = true;
865
- };
866
-
867
- let demoHtml = (
868
- <div class="n-builder__head-demo">
869
- <NButton {...demoProps}>{this.trans('Render demo')}</NButton>
870
- </div>
871
- );
872
-
873
- return (
874
- <div class="n-builder__head">
875
- {[addHtml, demoHtml]}
876
- </div>
877
- );
878
- },
879
-
880
- renderOutput()
881
- {
882
- return (
883
- <div class="n-builder__output">
884
- <pre>{this.exportJson(this.safevar)}</pre>
885
- </div>
886
- );
887
- },
888
-
889
- renderDemo()
890
- {
891
- if ( ! this.renderDemo || ! this.demo ) {
892
- return null;
893
- }
894
-
895
- let renderFunction = this.$slots.default;
896
-
897
- if ( Mix.isEmpty(renderFunction) ) {
898
- renderFunction = ({ render }) => render();
899
- }
900
-
901
- let modalProps = {
902
- width: '100%',
903
- height: '100%'
904
- };
905
-
906
- let configProps = {
907
- modelValue: this.model, scope: this.scope, config: this.exportExecutable(this.safevar)
908
- };
909
-
910
- let renderContent = () => {
911
- return ( <NConfigNext {...configProps} />);
912
- };
913
-
914
- return (
915
- <NModal vModel={this.demo} {...modalProps}>
916
- {renderFunction({ render: renderContent })}
917
- </NModal>
918
- );
919
- },
920
-
921
- render()
922
- {
923
- let classList = [
924
- 'n-builder',
925
- ];
926
-
927
- return (
928
- <div class={classList}>
929
- {[
930
- this.ctor('renderBody')(), this.ctor('renderHead')(), this.ctor('renderOutput')(), this.ctor('renderDemo')(),
931
- ]}
932
- </div>
933
- );
934
- }
935
- }