@kizmann/nano-ui 0.9.10 → 1.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 (270) hide show
  1. package/.github/workflows/compile-deploy-publish.yml +65 -0
  2. package/README.md +1 -1
  3. package/assets/nano-ui-dark.svg +19 -0
  4. package/assets/nano-ui-light.svg +19 -0
  5. package/assets/pico-js-dark.svg +19 -0
  6. package/assets/pico-js-light.svg +19 -0
  7. package/demos/form.html +462 -0
  8. package/demos/overview.html +97 -45
  9. package/docs/_sidebar.md +11 -10
  10. package/docs/files/form/button.md +10 -1
  11. package/docs/files/form/switch.md +6 -0
  12. package/docs/files/others/config.md +261 -8
  13. package/docs/files/others/drawer.md +32 -0
  14. package/docs/files/others/map.md +32 -0
  15. package/docs/index.template.html +76 -0
  16. package/docs/src/js/backup.js +128 -0
  17. package/docs/src/js/helper/item-helper.js +0 -0
  18. package/docs/src/js/index.js +21 -0
  19. package/docs/src/js/plugin/title-plugin.js +0 -0
  20. package/docs/src/js/plugin/vue-demo-plugin.js +97 -0
  21. package/docs/src/js/theme/basic.js +31 -0
  22. package/docs/src/js/theme/docsify.js +11 -0
  23. package/docs/src/scss/index-dark.scss +3 -0
  24. package/docs/src/scss/index-light.scss +3 -0
  25. package/docs/src/scss/index.scss +10 -443
  26. package/docs/src/scss/mixins/grid.scss +12 -11
  27. package/docs/src/scss/mixins/media.scss +2 -1
  28. package/docs/src/scss/root/vars-dark.scss +15 -0
  29. package/docs/src/scss/root/vars-light.scss +15 -0
  30. package/docs/src/scss/root/vars.scss +110 -0
  31. package/docs/src/scss/theme/default.scss +123 -0
  32. package/docs/src/scss/theme/header.scss +147 -0
  33. package/docs/src/scss/theme/layout.scss +186 -0
  34. package/docs/src/scss/theme/loader.scss +63 -0
  35. package/docs/src/scss/theme/markdown.scss +79 -0
  36. package/docs/src/scss/theme/navigation.scss +58 -0
  37. package/docs/src/scss/theme/progress.scss +9 -0
  38. package/docs/src/scss/theme/search.scss +119 -0
  39. package/docs/src/scss/{docsify → theme}/syntax.scss +18 -15
  40. package/docs/src/scss/theme/table.scss +63 -0
  41. package/favicon/apple-touch-icon.png +0 -0
  42. package/favicon/favicon-96x96.png +0 -0
  43. package/favicon/favicon.ico +0 -0
  44. package/favicon/favicon.svg +3 -0
  45. package/favicon/site.webmanifest +21 -0
  46. package/favicon/web-app-manifest-192x192.png +0 -0
  47. package/favicon/web-app-manifest-512x512.png +0 -0
  48. package/package.json +19 -12
  49. package/postcss.config.js +1 -1
  50. package/src/alert/src/alert/alert.scss +5 -4
  51. package/src/button/src/button/button.scss +5 -5
  52. package/src/button/src/button-group/button-group.scss +5 -4
  53. package/src/cascader/src/cascader/cascader.scss +5 -4
  54. package/src/cascader/src/cascader-panel/cascader-panel.scss +5 -4
  55. package/src/checkbox/src/checkbox/checkbox.scss +5 -4
  56. package/src/checkbox/src/checkbox-group/checkbox-group.scss +5 -4
  57. package/src/collapse/src/collapse/collapse.scss +5 -4
  58. package/src/collapse/src/collapse-item/collapse-item.scss +5 -4
  59. package/src/config/src/builder/builder.scss +17 -13
  60. package/src/config/src/reference-panel/reference-panel.scss +7 -4
  61. package/src/confirm/src/confirm/confirm.scss +5 -4
  62. package/src/datepicker/src/datepicker/datepicker.scss +5 -4
  63. package/src/datepicker/src/datepicker-panel/datepicker-panel.scss +5 -4
  64. package/src/datetimepicker/src/datetimepicker/datetimepicker.js +0 -4
  65. package/src/datetimepicker/src/datetimepicker/datetimepicker.scss +5 -4
  66. package/src/draggable/src/draggrid/draggrid.scss +5 -4
  67. package/src/draggable/src/draggrid-item/draggrid-item.scss +5 -4
  68. package/src/draggable/src/draglist/draglist.scss +5 -4
  69. package/src/draggable/src/draglist-item/draglist-item.scss +5 -4
  70. package/src/draggable/src/dropzone/dropzone.scss +5 -4
  71. package/src/drawer/index.js +5 -0
  72. package/src/drawer/index.scss +1 -0
  73. package/src/drawer/src/drawer/drawer.js +431 -0
  74. package/src/drawer/src/drawer/drawer.scss +136 -0
  75. package/src/durationpicker/src/durationpicker/durationpicker.scss +5 -4
  76. package/src/empty/src/empty-icon/empty-icon.scss +5 -4
  77. package/src/form/index.js +6 -0
  78. package/src/form/index.scss +2 -0
  79. package/src/form/src/form/form.js +11 -1
  80. package/src/form/src/form-frame/form-frame.js +42 -0
  81. package/src/form/src/form-frame/form-frame.scss +28 -0
  82. package/src/form/src/form-frame-item/form-frame-item.js +114 -0
  83. package/src/form/src/form-group/form-group.js +33 -1
  84. package/src/form/src/form-group/form-group.scss +5 -4
  85. package/src/form/src/form-item/form-item.scss +5 -4
  86. package/src/form/src/form-menu/form-menu.js +89 -0
  87. package/src/form/src/form-menu/form-menu.scss +9 -0
  88. package/src/index.js +1 -0
  89. package/src/index.scss +1 -0
  90. package/src/info/src/info/info.scss +5 -4
  91. package/src/info/src/info-column/info-column.scss +7 -4
  92. package/src/input/src/input/input.scss +5 -4
  93. package/src/input-number/src/input-number/input-number.scss +5 -4
  94. package/src/loader/src/loader/loader.scss +5 -4
  95. package/src/modal/src/modal/modal.scss +5 -4
  96. package/src/notification/src/notification/notification.scss +5 -4
  97. package/src/paginator/src/paginator/paginator.scss +5 -4
  98. package/src/popover/src/popover/popover.scss +5 -4
  99. package/src/radio/src/radio/radio.scss +5 -4
  100. package/src/radio/src/radio-group/radio-group.scss +5 -4
  101. package/src/rating/src/rating/rating.scss +5 -4
  102. package/src/root/vars.scss +84 -81
  103. package/src/select/src/select/select.scss +5 -4
  104. package/src/slider/src/slider/slider.scss +5 -4
  105. package/src/switch/src/switch/switch.scss +6 -4
  106. package/src/table/src/table/table.scss +15 -0
  107. package/src/table/src/table-cell/table-cell.scss +5 -4
  108. package/src/tabs/src/tabs/tabs.scss +5 -4
  109. package/src/tabs/src/tabs-item/tabs-item.scss +5 -4
  110. package/src/tags/src/tags-item/tags-item.scss +5 -4
  111. package/src/textarea/src/textarea/textarea.scss +5 -4
  112. package/src/timepicker/src/timepicker/timepicker.scss +5 -4
  113. package/src/timepicker/src/timepicker-panel/timepicker-panel.scss +5 -4
  114. package/src/transfer/src/transfer/transfer.scss +5 -4
  115. package/themes/macos/alert/src/alert/alert.scss +4 -3
  116. package/themes/macos/button/src/button/button.scss +8 -3
  117. package/themes/macos/cascader/src/cascader/cascader.scss +5 -4
  118. package/themes/macos/checkbox/src/checkbox/checkbox.scss +5 -4
  119. package/themes/macos/collapse/src/collapse/collapse.scss +4 -3
  120. package/themes/macos/collapse/src/collapse-item/collapse-item.scss +4 -3
  121. package/themes/macos/confirm/src/confirm/confirm.scss +4 -3
  122. package/themes/macos/datepicker/src/datepicker/datepicker.scss +5 -4
  123. package/themes/macos/datepicker/src/datepicker-panel/datepicker-panel.scss +4 -3
  124. package/themes/macos/datetimepicker/src/datetimepicker/datetimepicker.scss +14 -12
  125. package/themes/macos/draggable/src/draggrid/draggrid.scss +4 -3
  126. package/themes/macos/draggable/src/draggrid-item/draggrid-item.scss +4 -3
  127. package/themes/macos/draggable/src/draglist/draglist.scss +4 -3
  128. package/themes/macos/draggable/src/draglist-item/draglist-item.scss +6 -5
  129. package/themes/macos/draggable/src/dropzone/dropzone.scss +4 -3
  130. package/themes/macos/drawer/index.scss +1 -0
  131. package/themes/macos/drawer/src/drawer/drawer.scss +35 -0
  132. package/themes/macos/durationpicker/src/durationpicker/durationpicker.scss +5 -4
  133. package/themes/macos/file/src/file/file.scss +4 -3
  134. package/themes/macos/form/src/form-group/form-group.scss +4 -3
  135. package/themes/macos/index-dark.scss +1 -39
  136. package/themes/macos/index-light.scss +1 -39
  137. package/themes/macos/index.scss +1 -2
  138. package/themes/macos/input/src/input/input.scss +6 -5
  139. package/themes/macos/input-number/src/input-number/input-number.scss +6 -5
  140. package/themes/macos/loader/src/loader/loader.scss +4 -3
  141. package/themes/macos/modal/src/modal/modal.scss +6 -5
  142. package/themes/macos/notification/src/notification/notification.scss +4 -3
  143. package/themes/macos/popover/src/popover/popover.scss +9 -8
  144. package/themes/macos/radio/src/radio/radio.scss +5 -4
  145. package/themes/macos/rating/src/rating/rating.scss +4 -3
  146. package/themes/macos/root/vars-dark.scss +87 -74
  147. package/themes/macos/root/vars-light.scss +87 -74
  148. package/themes/macos/root/vars.scss +88 -74
  149. package/themes/macos/select/src/select/select.scss +5 -4
  150. package/themes/macos/switch/src/switch/switch.scss +6 -4
  151. package/themes/macos/table/src/table/table.scss +3 -3
  152. package/themes/macos/table/src/table-cell/table-cell.scss +5 -4
  153. package/themes/macos/tabs/src/tabs/tabs.scss +4 -3
  154. package/themes/macos/tabs/src/tabs-item/tabs-item.scss +4 -3
  155. package/themes/macos/tags/src/tags-item/tags-item.scss +6 -4
  156. package/themes/macos/textarea/src/textarea/textarea.scss +5 -4
  157. package/themes/macos/timepicker/src/timepicker/timepicker.scss +5 -4
  158. package/themes/macos/timepicker/src/timepicker-panel/timepicker-panel.scss +4 -3
  159. package/webpack.config.js +81 -13
  160. package/bun.lockb +0 -0
  161. package/dist/nano-ui.css +0 -2
  162. package/dist/nano-ui.js +0 -4
  163. package/dist/nano-ui.js.map +0 -1
  164. package/dist/themes/dark.css +0 -2
  165. package/dist/themes/light.css +0 -2
  166. package/docs/dist/docs.css +0 -2
  167. package/docs/index.html +0 -176
  168. package/docs/src/scss/docsify/basic/_coverpage.sass +0 -95
  169. package/docs/src/scss/docsify/basic/_layout.sass +0 -472
  170. package/docs/src/scss/docsify/vue.sass +0 -250
  171. package/nano.svg +0 -52
  172. package/themes/light/alert/index.scss +0 -1
  173. package/themes/light/alert/src/alert/alert.scss +0 -26
  174. package/themes/light/button/index.scss +0 -2
  175. package/themes/light/button/src/button/button.scss +0 -46
  176. package/themes/light/button/src/button-group/button-group.scss +0 -1
  177. package/themes/light/cascader/index.scss +0 -2
  178. package/themes/light/cascader/src/cascader/cascader.scss +0 -45
  179. package/themes/light/cascader/src/cascader-panel/cascader-panel.scss +0 -13
  180. package/themes/light/checkbox/index.scss +0 -2
  181. package/themes/light/checkbox/src/checkbox/checkbox.scss +0 -44
  182. package/themes/light/checkbox/src/checkbox-group/checkbox-group.scss +0 -1
  183. package/themes/light/collapse/index.scss +0 -2
  184. package/themes/light/collapse/src/collapse/collapse.scss +0 -21
  185. package/themes/light/collapse/src/collapse-item/collapse-item.scss +0 -21
  186. package/themes/light/confirm/index.scss +0 -1
  187. package/themes/light/confirm/src/confirm/confirm.scss +0 -13
  188. package/themes/light/datepicker/index.scss +0 -2
  189. package/themes/light/datepicker/src/datepicker/datepicker.scss +0 -49
  190. package/themes/light/datepicker/src/datepicker-panel/datepicker-panel.scss +0 -43
  191. package/themes/light/datetimepicker/index.scss +0 -1
  192. package/themes/light/datetimepicker/src/datetimepicker/datetimepicker.scss +0 -49
  193. package/themes/light/demo/index.scss +0 -1
  194. package/themes/light/demo/src/demo/demo.scss +0 -11
  195. package/themes/light/draggable/index.scss +0 -9
  196. package/themes/light/draggable/src/draggrid/draggrid.scss +0 -13
  197. package/themes/light/draggable/src/draggrid-item/draggrid-item.scss +0 -65
  198. package/themes/light/draggable/src/draghandler/draghandler.scss +0 -15
  199. package/themes/light/draggable/src/draglist/draglist.scss +0 -13
  200. package/themes/light/draggable/src/draglist-item/draglist-item.scss +0 -72
  201. package/themes/light/draggable/src/dropzone/dropzone.scss +0 -13
  202. package/themes/light/durationpicker/index.scss +0 -1
  203. package/themes/light/durationpicker/src/durationpicker/durationpicker.scss +0 -49
  204. package/themes/light/empty/index.scss +0 -1
  205. package/themes/light/empty/src/empty-icon/empty-icon.scss +0 -13
  206. package/themes/light/file/index.scss +0 -1
  207. package/themes/light/file/src/file/file.scss +0 -38
  208. package/themes/light/form/index.scss +0 -3
  209. package/themes/light/form/src/form/form.scss +0 -1
  210. package/themes/light/form/src/form-group/form-group.scss +0 -17
  211. package/themes/light/form/src/form-item/form-item.scss +0 -29
  212. package/themes/light/index.scss +0 -38
  213. package/themes/light/info/index.scss +0 -3
  214. package/themes/light/info/src/info/info.scss +0 -5
  215. package/themes/light/info/src/info-column/info-column.scss +0 -5
  216. package/themes/light/info/src/info-field/info-field.scss +0 -5
  217. package/themes/light/input/index.scss +0 -1
  218. package/themes/light/input/src/input/input.scss +0 -37
  219. package/themes/light/input-number/index.scss +0 -1
  220. package/themes/light/input-number/src/input-number/input-number.scss +0 -46
  221. package/themes/light/loader/index.scss +0 -1
  222. package/themes/light/loader/src/loader/loader.scss +0 -21
  223. package/themes/light/map/index.scss +0 -1
  224. package/themes/light/map/src/map/map.scss +0 -1
  225. package/themes/light/modal/index.scss +0 -1
  226. package/themes/light/modal/src/modal/modal.scss +0 -51
  227. package/themes/light/notification/index.scss +0 -1
  228. package/themes/light/notification/src/notification/notification.scss +0 -24
  229. package/themes/light/paginator/index.scss +0 -1
  230. package/themes/light/paginator/src/paginator/paginator.scss +0 -5
  231. package/themes/light/popover/index.scss +0 -1
  232. package/themes/light/popover/src/popover/popover.scss +0 -100
  233. package/themes/light/radio/index.scss +0 -2
  234. package/themes/light/radio/src/radio/radio.scss +0 -44
  235. package/themes/light/radio/src/radio-group/radio-group.scss +0 -1
  236. package/themes/light/rating/index.scss +0 -1
  237. package/themes/light/rating/src/rating/rating.scss +0 -18
  238. package/themes/light/resizer/index.scss +0 -1
  239. package/themes/light/resizer/src/resizer/resizer.scss +0 -5
  240. package/themes/light/root/vars.scss +0 -183
  241. package/themes/light/scrollbar/index.scss +0 -1
  242. package/themes/light/scrollbar/src/scrollbar/scrollbar.scss +0 -6
  243. package/themes/light/select/index.scss +0 -2
  244. package/themes/light/select/src/select/select.scss +0 -46
  245. package/themes/light/select/src/select-option/select-option.scss +0 -1
  246. package/themes/light/switch/index.scss +0 -1
  247. package/themes/light/switch/src/switch/switch.scss +0 -28
  248. package/themes/light/table/index.scss +0 -4
  249. package/themes/light/table/src/table/table.scss +0 -14
  250. package/themes/light/table/src/table-cell/table-cell.scss +0 -50
  251. package/themes/light/table/src/table-column/table-column.scss +0 -32
  252. package/themes/light/table/src/table-filter/table-filter.scss +0 -1
  253. package/themes/light/tabs/index.scss +0 -2
  254. package/themes/light/tabs/src/tabs/tabs.scss +0 -21
  255. package/themes/light/tabs/src/tabs-item/tabs-item.scss +0 -18
  256. package/themes/light/tags/index.scss +0 -2
  257. package/themes/light/tags/src/tags/tags.scss +0 -1
  258. package/themes/light/tags/src/tags-item/tags-item.scss +0 -28
  259. package/themes/light/textarea/index.scss +0 -1
  260. package/themes/light/textarea/src/textarea/textarea.scss +0 -29
  261. package/themes/light/timepicker/index.scss +0 -2
  262. package/themes/light/timepicker/src/timepicker/timepicker.scss +0 -49
  263. package/themes/light/timepicker/src/timepicker-panel/timepicker-panel.scss +0 -26
  264. package/themes/light/transfer/index.scss +0 -1
  265. package/themes/light/transfer/src/transfer/transfer.scss +0 -17
  266. package/themes/light/virtualscroller/index.scss +0 -1
  267. package/themes/light/virtualscroller/src/virtualscroller/virtualscroller.scss +0 -1
  268. /package/{themes/light → src}/root/image/empty-default.svg +0 -0
  269. /package/{themes/light → src}/root/image/empty-space.svg +0 -0
  270. /package/{themes/light → src}/root/image/star-default.svg +0 -0
@@ -317,24 +317,24 @@
317
317
 
318
318
  <div class="grid grid--row grid--wrap grid--10-10">
319
319
  <div class="col--1-1 col--1-3@md">
320
- <n-input-number v-model="n_number.test" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count USD" type="primary" :precision="2" :clearable="true"></n-input-number>
321
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count USD" type="primary"></n-input-number>-->
322
- </div>
323
- <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
324
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count €" :precision="2" :step-size="0.1" type="secondary"></n-input-number>-->
325
- <!-- </div>-->
326
- <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
327
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="success" :clearable="true"></n-input-number>-->
328
- <!-- </div>-->
329
- <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
330
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="warning"></n-input-number>-->
331
- <!-- </div>-->
332
- <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
333
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="danger"></n-input-number>-->
334
- <!-- </div>-->
335
- <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
336
- <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="info"></n-input-number>-->
337
- <!-- </div>-->
320
+ <n-input-number v-model="n_number.test" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count USD" type="primary" :precision="2" :clearable="true"></n-input-number>
321
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count USD" type="primary"></n-input-number>-->
322
+ </div>
323
+ <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
324
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" format=":count €" :precision="2" :step-size="0.1" type="secondary"></n-input-number>-->
325
+ <!-- </div>-->
326
+ <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
327
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="success" :clearable="true"></n-input-number>-->
328
+ <!-- </div>-->
329
+ <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
330
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="warning"></n-input-number>-->
331
+ <!-- </div>-->
332
+ <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
333
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="danger"></n-input-number>-->
334
+ <!-- </div>-->
335
+ <!-- <div class="col&#45;&#45;1-1 col&#45;&#45;1-3@md">-->
336
+ <!-- <n-input-number v-model="n_number.value" :min="n_number.minValue" :max="n_number.maxValue" v-bind="n_number" type="info"></n-input-number>-->
337
+ <!-- </div>-->
338
338
  </div>
339
339
 
340
340
  <h2>NTextarea</h2>
@@ -446,7 +446,7 @@
446
446
  <div class="col--1-1">
447
447
  <n-button-group>
448
448
  <n-input v-model="n_input.value" v-bind="n_input" type="primary"></n-input>
449
- <n-datepicker v-bind="n_datepicker" ></n-datepicker>
449
+ <n-datepicker v-bind="n_datepicker"></n-datepicker>
450
450
  <n-select v-bind="n_select" :multiple="true" type="primary" :options="icons"></n-select>
451
451
  <n-button v-bind="n_button" type="primary">Button</n-button>
452
452
  </n-button-group>
@@ -587,7 +587,7 @@
587
587
  <n-datepicker-panel v-bind="n_datepicker" min-date="now" :month-panels="2" :range="true"></n-datepicker-panel>
588
588
  </div>
589
589
  <div class="col--1-1 col--1-3@md">
590
- <n-datepicker v-bind="n_datepicker" ></n-datepicker>
590
+ <n-datepicker v-bind="n_datepicker"></n-datepicker>
591
591
  </div>
592
592
  <div class="col--1-1 col--1-3@md">
593
593
  <n-datepicker v-bind="n_datepicker" :range="true" :month-panels="2"></n-datepicker>
@@ -616,7 +616,7 @@
616
616
  <n-timepicker-panel v-bind="n_timepicker"></n-timepicker-panel>
617
617
  </div>
618
618
  <div class="col--1-1 col--1-3@md">
619
- <n-timepicker v-bind="n_timepicker" ></n-timepicker>
619
+ <n-timepicker v-bind="n_timepicker"></n-timepicker>
620
620
  </div>
621
621
  </div>
622
622
 
@@ -639,7 +639,7 @@
639
639
 
640
640
  <div class="grid grid--row grid--wrap grid--10-10">
641
641
  <div class="col--1-1 col--1-3@md">
642
- <n-datetimepicker v-bind="n_datetimepicker" ></n-datetimepicker>
642
+ <n-datetimepicker v-bind="n_datetimepicker"></n-datetimepicker>
643
643
  </div>
644
644
  </div>
645
645
 
@@ -662,10 +662,10 @@
662
662
 
663
663
  <div class="grid grid--row grid--wrap grid--10-10">
664
664
  <div class="col--1-1 col--1-3@md">
665
- <n-durationpicker v-bind="n_durationpicker" ></n-durationpicker>
665
+ <n-durationpicker v-bind="n_durationpicker"></n-durationpicker>
666
666
  </div>
667
667
  <div class="col--1-1 col--1-3@md">
668
- <n-durationpicker v-model="n_durationpicker.modelValue" v-bind="n_durationpicker" ></n-durationpicker>
668
+ <n-durationpicker v-model="n_durationpicker.modelValue" v-bind="n_durationpicker"></n-durationpicker>
669
669
  </div>
670
670
  </div>
671
671
 
@@ -730,6 +730,47 @@
730
730
  </div>
731
731
  </div>
732
732
 
733
+ <h2>NDrawer</h2>
734
+
735
+ <div class="app-options grid grid--row grid--wrap grid--30-30">
736
+ <div class="col--auto">
737
+ <n-select style="width: 100px;" v-model="n_drawer.size" :options="sizes"></n-select>
738
+ </div>
739
+ <div class="col--auto">
740
+ <n-select style="width: 210px;" v-model="n_drawer.position" :options="drawers"></n-select>
741
+ </div>
742
+ <div class="col--auto">
743
+ <n-checkbox v-model="n_drawer.disabled">Disabled</n-checkbox>
744
+ </div>
745
+ </div>
746
+
747
+ <div class="grid grid--row grid--wrap grid--10-10">
748
+ <div class="col--1-1 col--1-3@md">
749
+ <n-button>Open drawer</n-button>
750
+ <n-drawer v-bind="n_drawer">
751
+ <template v-slot:header>
752
+ Im the header
753
+ </template>
754
+ <div style="height: 2100px;">
755
+ <n-form>
756
+ <n-form-item label="Test">
757
+ <n-input placeholder="Fill me"></n-input>
758
+ </n-form-item>
759
+ <n-form-item label="Test">
760
+ <n-input placeholder="Fill me"></n-input>
761
+ </n-form-item>
762
+ <n-form-item label="Test">
763
+ <n-input placeholder="Fill me"></n-input>
764
+ </n-form-item>
765
+ </n-form>
766
+ </div>
767
+ <template v-slot:footer>
768
+ Im the footer
769
+ </template>
770
+ </n-drawer>
771
+ </div>
772
+ </div>
773
+
733
774
  <h2>NConfirm</h2>
734
775
 
735
776
  <div class="app-options grid grid--row grid--wrap grid--30-30">
@@ -921,7 +962,9 @@
921
962
  <template v-for="index in Arr.make(n_draggable.count)">
922
963
  <n-draglist v-model:items="virtualTree" :render-expand="true" :render-select="true" style="height: 500px; margin-top: 30px; border: 2px solid rgba(110, 110, 110, 0.5); border-radius: 4px;">
923
964
  <template v-slot:default="{ value, item }">
924
- <div style="padding: 0 5px; line-height: 34px;"><n-input v-model="item.label"></n-input></div>
965
+ <div style="padding: 0 5px; line-height: 34px;">
966
+ <n-input v-model="item.label"></n-input>
967
+ </div>
925
968
  </template>
926
969
  </n-draglist>
927
970
  </template>
@@ -930,7 +973,7 @@
930
973
 
931
974
  <n-dropzone v-model:item="virtualItem" style="height: 500px; margin-top: 30px; border: 2px solid rgba(110, 110, 110, 0.5); border-radius: 4px;">
932
975
  <template v-slot:default="item">
933
- <div style="padding: 0 5px; line-height: 34px;">{{item.label}}</div>
976
+ <div style="padding: 0 5px; line-height: 34px;">{{ item.label }}</div>
934
977
  </template>
935
978
  </n-dropzone>
936
979
 
@@ -966,7 +1009,7 @@
966
1009
 
967
1010
  <n-table ref="table" v-model:items="virtualTree" :handle="true" :render-handle="true" :render-expand="true" :item-height="100" style="margin-top: 30px; min-height: 500px;">
968
1011
  <n-table-column label="Label" type="string" prop="label" align="center" :sort="true" :filter="true">
969
- <!-- <template v-slot:default="{item}">{{ item.value }}</template>-->
1012
+ <!-- <template v-slot:default="{item}">{{ item.value }}</template>-->
970
1013
  </n-table-column>
971
1014
  <n-table-column label="Image" type="image" prop="image" :fixed-width="130"></n-table-column>
972
1015
  <n-table-column label="Date" type="datetime" prop="date" :disabled="true" :sort="true" :width="50" :filter="true"></n-table-column>
@@ -1082,24 +1125,29 @@
1082
1125
  let data = {};
1083
1126
 
1084
1127
  data.sizes = {
1085
- xs: 'XS',
1086
- sm: 'SM',
1087
- md: 'MD',
1128
+ xs: 'XS',
1129
+ sm: 'SM',
1130
+ md: 'MD',
1088
1131
  lg: 'LG'
1089
1132
  };
1090
1133
 
1091
1134
  data.types = {
1092
- primary: 'Primary',
1093
- secondary: 'Secondary',
1094
- success: 'Success',
1095
- warning: 'Warning',
1096
- danger: 'Danger',
1097
- info: 'Info'
1135
+ primary: 'Primary',
1136
+ secondary: 'Secondary',
1137
+ success: 'Success',
1138
+ warning: 'Warning',
1139
+ danger: 'Danger',
1140
+ info: 'Info'
1098
1141
  };
1099
1142
 
1100
1143
  data.modals = {
1101
- default: 'Default',
1102
- preview: 'Preview',
1144
+ default: 'Default',
1145
+ preview: 'Preview',
1146
+ };
1147
+
1148
+ data.drawers = {
1149
+ left: 'Left',
1150
+ right: 'Right',
1103
1151
  };
1104
1152
 
1105
1153
  pi.Obj.set(data, 'demoConfigNext.NFormGroup:root', {
@@ -1198,13 +1246,13 @@
1198
1246
  let id = pi.UUID();
1199
1247
 
1200
1248
  return {
1201
- id: id,
1202
- value: id,
1249
+ id: id,
1250
+ value: id,
1203
1251
  matrix: 10,
1204
- label: `Item ${index++}`,
1205
- image: 'https://picsum.photos/300/300.jpg?' + id,
1252
+ label: `Item ${index ++}`,
1253
+ image: 'https://picsum.photos/300/300.jpg?' + id,
1206
1254
  date: pi.Now.make('now').format('YYYY-MM-DD HH:mm:ss', true),
1207
- enabled: !! Math.floor(Math.random() * 2)
1255
+ enabled: !!Math.floor(Math.random() * 2)
1208
1256
  };
1209
1257
  });
1210
1258
  };
@@ -1212,7 +1260,7 @@
1212
1260
 
1213
1261
  data.cascaderData = pi.Arr.each(itemGenerator(5), function (item) {
1214
1262
 
1215
- let children = pi.Arr.each(itemGenerator(5), function (item) {
1263
+ let children = pi.Arr.each(itemGenerator(5), function (item) {
1216
1264
  return pi.Obj.assign(item, { children: itemGenerator(5) });
1217
1265
  });
1218
1266
 
@@ -1314,6 +1362,10 @@
1314
1362
  size: 'md', type: 'default', disabled: false
1315
1363
  };
1316
1364
 
1365
+ data.n_drawer = {
1366
+ size: 'md', position: 'right', disabled: false
1367
+ };
1368
+
1317
1369
  data.n_confirm = {
1318
1370
  size: 'md', type: 'primary', disabled: false
1319
1371
  };
@@ -1348,7 +1400,7 @@
1348
1400
 
1349
1401
  let methods = {};
1350
1402
 
1351
- methods.changeTheme = function(value) {
1403
+ methods.changeTheme = function (value) {
1352
1404
 
1353
1405
  pi.Cookie.set('theme', this.n_theme = value);
1354
1406
 
package/docs/_sidebar.md CHANGED
@@ -24,13 +24,14 @@
24
24
  - [Virtualscroller](files/data/virtualscroller.md)
25
25
 
26
26
  - Others
27
- - [Notification](others/notification.md)
28
- - [Loader](others/loader.md)
29
- - [Tabs](others/tabs.md)
30
- - [Popover](others/popover.md)
31
- - [Modal](others/modal.md)
32
- - [Map](data/map.md)
33
- - [Confirm](others/confirm.md)
34
- - [Scrollbar](others/scrollbar.md)
35
- - [Resizer](others/resizer.md)
36
- - [Config](others/config.md)
27
+ - [Notification](files/others/notification.md)
28
+ - [Loader](files/others/loader.md)
29
+ - [Tabs](files/others/tabs.md)
30
+ - [Popover](files/others/popover.md)
31
+ - [Modal](files/others/modal.md)
32
+ - [Drawer](files/others/drawer.md)
33
+ - [Map](files/others/map.md)
34
+ - [Confirm](files/others/confirm.md)
35
+ - [Scrollbar](files/others/scrollbar.md)
36
+ - [Resizer](files/others/resizer.md)
37
+ - [Config](files/others/config.md)
@@ -1,5 +1,5 @@
1
1
  # Button
2
-
2
+
3
3
  The `<n-button>` component is a versatile and customizable button component, providing various styling options and functionalities. Below is a detailed description of its props, methods, and usage.
4
4
 
5
5
  ## Demo
@@ -35,6 +35,9 @@ pi.Obj.assign(window.VueData, {
35
35
  </div>
36
36
  <div class="demo-display">
37
37
  <div class="grid grid--row grid--wrap grid--40-40 grid--middle">
38
+ <div class="col--1-1">
39
+ <h3>Default</h3>
40
+ </div>
38
41
  <div class="col--auto">
39
42
  <n-button v-bind="buttonBinds" type="primary">Primary</n-button>
40
43
  </div>
@@ -55,6 +58,9 @@ pi.Obj.assign(window.VueData, {
55
58
  </div>
56
59
  </div>
57
60
  <div class="grid grid--row grid--wrap grid--40-40 grid--middle">
61
+ <div class="col--1-1">
62
+ <h3>Link</h3>
63
+ </div>
58
64
  <div class="col--auto">
59
65
  <n-button v-bind="buttonBinds" :link="true" type="primary">Primary</n-button>
60
66
  </div>
@@ -75,6 +81,9 @@ pi.Obj.assign(window.VueData, {
75
81
  </div>
76
82
  </div>
77
83
  <div class="grid grid--row grid--wrap grid--40-40 grid--middle">
84
+ <div class="col--1-1">
85
+ <h3>Square</h3>
86
+ </div>
78
87
  <div class="col--auto">
79
88
  <n-button v-bind="buttonBinds" :square="true" icon="fa fa-search" type="primary">Primary</n-button>
80
89
  </div>
@@ -30,6 +30,9 @@ pi.Obj.assign(window.VueData, {
30
30
  </div>
31
31
  <div class="demo-display">
32
32
  <div class="grid grid--row grid--wrap grid--40-40 grid--middle">
33
+ <div class="col--1-1">
34
+ <h3>Default</h3>
35
+ </div>
33
36
  <div class="col--auto">
34
37
  <n-switch :model-value="true" v-bind="switchBinds" on-type="primary">Primary</n-switch>
35
38
  </div>
@@ -50,6 +53,9 @@ pi.Obj.assign(window.VueData, {
50
53
  </div>
51
54
  </div>
52
55
  <div class="grid grid--row grid--wrap grid--40-40 grid--middle">
56
+ <div class="col--1-1">
57
+ <h3>With custom values</h3>
58
+ </div>
53
59
  <div class="col--auto">
54
60
  <n-switch v-model="switchReact.model" v-bind="switchBinds" on-value="foo" off-value="bar">Switch between to strings</n-switch>
55
61
  </div>
@@ -1,8 +1,261 @@
1
- ---
2
- layout: default
3
- title: Config
4
- nav_order: 5
5
- parent: Others
6
- ---
7
-
8
- # Config
1
+
2
+ # pi.Arr Class
3
+
4
+ A lightweight utility class for working with arrays.
5
+
6
+ ```js
7
+ import { Arr } from "@kizmann/pico-js";
8
+ ```
9
+
10
+ <hr>
11
+
12
+ ### Arr.make(count)
13
+ Creates an array of a given count filled with incrementing integers starting from 1.
14
+
15
+ ```js
16
+ Arr.make(3);
17
+ // => [1, 2, 3]
18
+ ```
19
+
20
+ **Arguments:**
21
+ count `Int`: The number of elements in the new array.
22
+
23
+ **Returns:**
24
+ `Array<Int>`: An array of integers `[1, 2, ..., count]`.
25
+
26
+ <hr>
27
+
28
+ ### Arr.all(arr)
29
+ Ensures the input is always returned as an array.
30
+
31
+ ```js
32
+ Arr.all(5);
33
+ // => [5]
34
+
35
+ Arr.all([1, 2]);
36
+ // => [1, 2]
37
+ ```
38
+
39
+ **Arguments:**
40
+ arr `Any`: The value to wrap in an array if it isn't already.
41
+
42
+ **Returns:**
43
+ `Array`: The original array or a single-element array.
44
+
45
+ <hr>
46
+
47
+ ### Arr.get(arr, index, fallback = null)
48
+ Returns the value at a given index or a fallback if it doesn't exist.
49
+
50
+ ```js
51
+ Arr.get([1, 2, 3], 1);
52
+ // => 2
53
+
54
+ Arr.get([1, 2, 3], 5, null);
55
+ // => null
56
+ ```
57
+
58
+ **Arguments:**
59
+ arr `Array`: The array to query.
60
+ index `Int`: The index to access.
61
+ fallback `Any`: Value returned if the index is out of bounds.
62
+
63
+ **Returns:**
64
+ `Any`: The element at the index or the fallback.
65
+
66
+ <hr>
67
+
68
+ ### Arr.set(arr, index, value)
69
+ Sets a value at the specified index of the array.
70
+
71
+ ```js
72
+ Arr.set([0, 2, 44], 1, 42);
73
+ // => [0, 42, 44]
74
+ ```
75
+
76
+ **Arguments:**
77
+ arr `Array`: The array to modify.
78
+ index `Int`: The index to set.
79
+ value `Any`: The value to assign.
80
+
81
+ **Returns:**
82
+ `Any`: The assigned value.
83
+
84
+ <hr>
85
+
86
+ ### Arr.first(arr, fallback = null)
87
+ Gets the first element of the array or a fallback.
88
+
89
+ ```js
90
+ Arr.first([10, 20]);
91
+ // => 10
92
+
93
+ Arr.first([], null);
94
+ // => null
95
+ ```
96
+
97
+ **Arguments:**
98
+ arr `Array`: The array to query.
99
+ fallback `Any`: Returned if array is empty or invalid.
100
+
101
+ **Returns:**
102
+ `Any`: First element or fallback.
103
+
104
+ <hr>
105
+
106
+ ### Arr.second(arr, fallback = null)
107
+ Gets the second element of the array, falling back to the first or a fallback.
108
+
109
+ ```js
110
+ Arr.second([10, 20]);
111
+ // => 20
112
+
113
+ Arr.second([10], 'none');
114
+ // => 10
115
+ ```
116
+
117
+ **Arguments:**
118
+ arr `Array`: The array to query.
119
+ fallback `Any`: Returned if array is empty or invalid.
120
+
121
+ **Returns:**
122
+ `Any`: Second element or fallback.
123
+
124
+ <hr>
125
+
126
+ ### Arr.third(arr, fallback = null)
127
+ Gets the third element, or falls back to second, first, or fallback.
128
+
129
+ ```js
130
+ Arr.third([1, 2, 3]);
131
+ // => 3
132
+
133
+ Arr.third([1], 'none');
134
+ // => 1
135
+ ```
136
+
137
+ **Arguments:**
138
+ arr `Array`: The array to query.
139
+ fallback `Any`: Returned if array is empty or invalid.
140
+
141
+ **Returns:**
142
+ `Any`: Third element or fallback.
143
+
144
+ <hr>
145
+
146
+ ### Arr.last(arr, fallback = null)
147
+ Gets the last element of the array.
148
+
149
+ ```js
150
+ Arr.last([5, 6, 7]);
151
+ // => 7
152
+ ```
153
+
154
+ **Arguments:**
155
+ arr `Array`: The array to query.
156
+ fallback `Any`: Returned if array is empty or invalid.
157
+
158
+ **Returns:**
159
+ `Any`: Last element or fallback.
160
+
161
+ <hr>
162
+
163
+ ### Arr.prepend(arr, val)
164
+ Adds a value to the beginning of an array.
165
+
166
+ ```js
167
+ Arr.prepend([2, 3], 1);
168
+ // => [1, 2, 3]
169
+ ```
170
+
171
+ **Arguments:**
172
+ arr `Array`: The array to modify.
173
+ val `Any`: The value to prepend.
174
+
175
+ **Returns:**
176
+ `Array`: The updated array.
177
+
178
+ <hr>
179
+
180
+ ### Arr.append(arr, val)
181
+ Adds a value to the end of an array.
182
+
183
+ ```js
184
+ Arr.append([1, 2], 3);
185
+ // => [1, 2, 3]
186
+ ```
187
+
188
+ **Arguments:**
189
+ arr `Array`: The array to modify.
190
+ val `Any`: The value to append.
191
+
192
+ **Returns:**
193
+ `Array`: The updated array.
194
+
195
+ <hr>
196
+
197
+ ### Arr.sort(obj, key)
198
+ Sorts an object of keyed values by a key or a custom function.
199
+
200
+ ```js
201
+ Arr.sort([{ val: 2 }, { val: 1 }], 'val');
202
+ // => [{ val: 1, _key: 1 }, { val: 2, _key: 0 }]
203
+ ```
204
+
205
+ **Arguments:**
206
+ obj `Object`: The object to sort.
207
+ key `String|Function`: A key to sort by or a custom comparison function.
208
+
209
+ **Returns:**
210
+ `Array`: Sorted array of values, each augmented with `_key`.
211
+
212
+ <hr>
213
+
214
+ ### Arr.sortString(obj, key)
215
+ Sorts an object’s values alphabetically by a string key.
216
+
217
+ ```js
218
+ Arr.sortString([{ name: "Zoe" }, { name: "Anna" }], 'name');
219
+ // => [{ name: "Anna", _key: 1 }, { name: "Zoe", _key: 0 }]
220
+ ```
221
+
222
+ **Arguments:**
223
+ obj `Object`: The object to sort.
224
+ key `String`: Key to sort values by (case-insensitive).
225
+
226
+ **Returns:**
227
+ `Array`: Alphabetically sorted values.
228
+
229
+ <hr>
230
+
231
+ ### Arr.filter(arr, filter)
232
+ Filters array values by a function, object, or array.
233
+
234
+ ```js
235
+ Arr.filter([1, 2, 3, 4], n => n > 2);
236
+ // => [3, 4]
237
+ ```
238
+
239
+ **Arguments:**
240
+ arr `Array`: The array to filter.
241
+ filter `Function|Object|Array`: Filter logic.
242
+
243
+ **Returns:**
244
+ `Array`: Filtered array.
245
+
246
+ <hr>
247
+
248
+ ### Arr.filterIndex(arr, filter)
249
+ Gets indexes of values matching a filter.
250
+
251
+ ```js
252
+ Arr.filterIndex([1, 2, 3, 4], n => n > 2);
253
+ // => ['2', '3']
254
+ ```
255
+
256
+ **Arguments:**
257
+ arr `Array`: The array to filter.
258
+ filter `Function|Object|Array`: Filter logic.
259
+
260
+ **Returns:**
261
+ `Array<Number>`: Array of indexes matching the condition.
@@ -0,0 +1,32 @@
1
+ # Modal
2
+ Modal you know.
3
+
4
+ ```html
5
+ /*vue*/
6
+ <template>
7
+ <div>
8
+ <n-button>Open</n-button>
9
+ <n-modal ref="modal">
10
+ <div slot="header">
11
+ <h3>Hi</h3>
12
+ </div>
13
+ <div>
14
+ <p>Im the content</p>
15
+ </div>
16
+ <div slot="footer">
17
+ <n-button @click="$refs.modal.close()">Ok!</n-button>
18
+ </div>
19
+ </n-modal>
20
+ </div>
21
+ </template>
22
+ <script>
23
+ export default {
24
+ }
25
+ </script>
26
+ ```
27
+
28
+ ### Properties
29
+ coming soon
30
+
31
+ ### Events
32
+ coming soon
@@ -0,0 +1,32 @@
1
+ # Modal
2
+ Modal you know.
3
+
4
+ ```html
5
+ /*vue*/
6
+ <template>
7
+ <div>
8
+ <n-button>Open</n-button>
9
+ <n-modal ref="modal">
10
+ <div slot="header">
11
+ <h3>Hi</h3>
12
+ </div>
13
+ <div>
14
+ <p>Im the content</p>
15
+ </div>
16
+ <div slot="footer">
17
+ <n-button @click="$refs.modal.close()">Ok!</n-button>
18
+ </div>
19
+ </n-modal>
20
+ </div>
21
+ </template>
22
+ <script>
23
+ export default {
24
+ }
25
+ </script>
26
+ ```
27
+
28
+ ### Properties
29
+ coming soon
30
+
31
+ ### Events
32
+ coming soon