@vef-framework/components 1.0.62 → 1.0.64

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 (586) hide show
  1. package/es/index.js +81 -2
  2. package/es/internal/index.js +2 -2
  3. package/es/internal/modern-normalize.css.js +4 -2
  4. package/es/internal/utils.js +6 -2
  5. package/es/vef-access-denied/access-denied-icon.js +928 -2
  6. package/es/vef-access-denied/index.js +45 -10
  7. package/es/vef-action-buttons/index.js +75 -2
  8. package/es/vef-auto-sizer/index.js +6 -2
  9. package/es/vef-avatar/index.js +20 -2
  10. package/es/vef-avatar-group/index.js +25 -2
  11. package/es/vef-badge/index.js +47 -2
  12. package/es/vef-bool/hooks/use-bool-instance.js +34 -2
  13. package/es/vef-bool/index.js +60 -2
  14. package/es/vef-breadcrumb/index.js +48 -2
  15. package/es/vef-button/components/base-button.js +73 -2
  16. package/es/vef-button/index.js +151 -2
  17. package/es/vef-card/index.js +25 -2
  18. package/es/vef-card-meta/index.js +12 -2
  19. package/es/vef-checkbox/hooks/use-checkbox-instance.js +20 -2
  20. package/es/vef-checkbox/hooks/use-data-options.js +40 -2
  21. package/es/vef-checkbox/index.js +88 -4
  22. package/es/vef-col/index.js +11 -2
  23. package/es/vef-color-picker/index.js +46 -2
  24. package/es/vef-compact/index.js +15 -2
  25. package/es/vef-config-provider/global-style.js +23 -16
  26. package/es/vef-config-provider/hooks/use-ui-config.js +125 -2
  27. package/es/vef-config-provider/index.js +121 -4
  28. package/es/vef-config-provider/store.js +21 -2
  29. package/es/vef-container/index.js +18 -2
  30. package/es/vef-crud-page/components/crud-actions.js +32 -2
  31. package/es/vef-crud-page/components/crud-filter.js +54 -2
  32. package/es/vef-crud-page/components/crud-footer.js +116 -4
  33. package/es/vef-crud-page/components/crud-form-modal.js +53 -2
  34. package/es/vef-crud-page/components/crud-header.js +29 -2
  35. package/es/vef-crud-page/components/crud-table.js +76 -2
  36. package/es/vef-crud-page/hooks/use-action-buttons.js +37 -2
  37. package/es/vef-crud-page/hooks/use-crud-context.js +20 -2
  38. package/es/vef-crud-page/hooks/use-crud-schema.js +114 -2
  39. package/es/vef-crud-page/hooks/use-operation-buttons.js +60 -2
  40. package/es/vef-crud-page/index.js +150 -2
  41. package/es/vef-crud-page/store.js +142 -2
  42. package/es/vef-divider/index.js +24 -2
  43. package/es/vef-drawer/components/action-button-wrapper.js +49 -2
  44. package/es/vef-drawer/components/button-props.js +2 -1
  45. package/es/vef-drawer/components/cancel-action-button.js +21 -2
  46. package/es/vef-drawer/components/ok-action-button.js +20 -2
  47. package/es/vef-drawer/context.js +15 -2
  48. package/es/vef-drawer/index.js +154 -4
  49. package/es/vef-dropdown/index.js +92 -2
  50. package/es/vef-dynamic-icon/index.js +46 -2
  51. package/es/vef-dynamic-icon/props.js +6 -2
  52. package/es/vef-empty/index.js +37 -2
  53. package/es/vef-empty-placeholder/index.js +19 -5
  54. package/es/vef-error/error-icon.js +757 -2
  55. package/es/vef-error/index.js +48 -10
  56. package/es/vef-filter/components/action-buttons.js +119 -6
  57. package/es/vef-filter/components/advanced-filter.js +71 -9
  58. package/es/vef-filter/components/basic-filter.js +35 -5
  59. package/es/vef-filter/components/fields/index.js +11 -2
  60. package/es/vef-filter/components/fields/input-number.js +90 -2
  61. package/es/vef-filter/components/fields/input.js +67 -2
  62. package/es/vef-filter/components/filter-field.js +19 -2
  63. package/es/vef-filter/components/filter-item.js +112 -2
  64. package/es/vef-filter/event.js +44 -2
  65. package/es/vef-filter/helper.js +15 -2
  66. package/es/vef-filter/hooks/use-action-handlers.js +70 -2
  67. package/es/vef-filter/hooks/use-computed-values.js +55 -2
  68. package/es/vef-filter/hooks/use-filter-context.js +18 -2
  69. package/es/vef-filter/hooks/use-filter-initialization.js +37 -2
  70. package/es/vef-filter/hooks/use-filter-instance.js +26 -2
  71. package/es/vef-filter/hooks/use-filter-items.js +23 -2
  72. package/es/vef-filter/hooks/use-filter-values-change.js +30 -2
  73. package/es/vef-filter/hooks/use-label-config.js +27 -2
  74. package/es/vef-filter/index.js +141 -3
  75. package/es/vef-filter/store.js +71 -2
  76. package/es/vef-flex/index.js +31 -2
  77. package/es/vef-float-button/index.js +49 -2
  78. package/es/vef-float-button-group/index.js +20 -2
  79. package/es/vef-form/components/fields/index.js +11 -2
  80. package/es/vef-form/components/fields/input-number.js +123 -2
  81. package/es/vef-form/components/fields/input.js +132 -2
  82. package/es/vef-form/components/form-actions.js +58 -4
  83. package/es/vef-form/components/form-content.js +144 -3
  84. package/es/vef-form/components/form-field.js +22 -2
  85. package/es/vef-form/components/form-group.js +64 -4
  86. package/es/vef-form/components/form-hidden-item.js +36 -2
  87. package/es/vef-form/components/form-item.js +79 -2
  88. package/es/vef-form/components/form-row.js +98 -2
  89. package/es/vef-form/event.js +44 -2
  90. package/es/vef-form/helper.js +15 -2
  91. package/es/vef-form/hooks/use-action-handlers.js +130 -2
  92. package/es/vef-form/hooks/use-columns-layout.js +122 -2
  93. package/es/vef-form/hooks/use-computed-values.js +55 -2
  94. package/es/vef-form/hooks/use-form-context.js +14 -2
  95. package/es/vef-form/hooks/use-form-initialization.js +45 -2
  96. package/es/vef-form/hooks/use-form-instance.js +26 -2
  97. package/es/vef-form/hooks/use-form-values-change.js +30 -2
  98. package/es/vef-form/hooks/use-label-width.js +18 -2
  99. package/es/vef-form/index.js +174 -4
  100. package/es/vef-form/store.js +65 -2
  101. package/es/vef-form/validation-rules.js +286 -2
  102. package/es/vef-form-drawer/index.js +98 -2
  103. package/es/vef-form-modal/index.js +95 -2
  104. package/es/vef-generic-select/index.js +81 -2
  105. package/es/vef-grid/index.js +83 -7
  106. package/es/vef-grid/props.js +4 -2
  107. package/es/vef-grid-item/index.js +52 -2
  108. package/es/vef-icon/index.js +45 -2
  109. package/es/vef-icon-select/index.js +146 -12
  110. package/es/vef-input/hooks/use-input-instance.js +15 -2
  111. package/es/vef-input/index.js +64 -2
  112. package/es/vef-input-number/hooks/use-input-number-instance.js +13 -2
  113. package/es/vef-input-number/index.js +148 -2
  114. package/es/vef-layout/common-styles.js +10 -5
  115. package/es/vef-layout/components/content.js +13 -2
  116. package/es/vef-layout/components/font-size.js +68 -2
  117. package/es/vef-layout/components/fullscreen.js +23 -2
  118. package/es/vef-layout/components/header-action-icons.js +29 -7
  119. package/es/vef-layout/components/header-content.js +19 -2
  120. package/es/vef-layout/components/header.js +69 -7
  121. package/es/vef-layout/components/icon-boy.js +69 -2
  122. package/es/vef-layout/components/icon-girl.js +76 -2
  123. package/es/vef-layout/components/icon-menu-fold-left.js +23 -2
  124. package/es/vef-layout/components/icon-menu-unfold-left.js +23 -2
  125. package/es/vef-layout/components/menu-groups.js +123 -16
  126. package/es/vef-layout/components/message.js +11 -2
  127. package/es/vef-layout/components/search.js +11 -2
  128. package/es/vef-layout/components/sider.js +54 -6
  129. package/es/vef-layout/components/title.js +53 -9
  130. package/es/vef-layout/components/user-avatar.js +80 -10
  131. package/es/vef-layout/hooks/use-layout-context.js +10 -2
  132. package/es/vef-layout/index.js +33 -3
  133. package/es/vef-layout/logo.svg.js +4 -2
  134. package/es/vef-layout/store.js +16 -2
  135. package/es/vef-loading-placeholder/index.js +42 -6
  136. package/es/vef-login/index.js +152 -22
  137. package/es/vef-login/login-icon.js +668 -2
  138. package/es/vef-menu/index.js +77 -5
  139. package/es/vef-modal/components/action-button-wrapper.js +49 -2
  140. package/es/vef-modal/components/button-props.js +2 -1
  141. package/es/vef-modal/components/cancel-action-button.js +18 -2
  142. package/es/vef-modal/components/ok-action-button.js +20 -2
  143. package/es/vef-modal/context.js +15 -2
  144. package/es/vef-modal/index.js +239 -3
  145. package/es/vef-not-found/index.js +45 -10
  146. package/es/vef-not-found/not-found-icon.js +844 -2
  147. package/es/vef-page/index.js +87 -11
  148. package/es/vef-pagination/index.js +57 -2
  149. package/es/vef-pagination/props.js +13 -2
  150. package/es/vef-paragraph/index.js +89 -2
  151. package/es/vef-password/hooks/use-password-instance.js +13 -2
  152. package/es/vef-password/index.js +67 -2
  153. package/es/vef-popconfirm/index.js +56 -2
  154. package/es/vef-popover/index.js +29 -2
  155. package/es/vef-radio/hooks/use-data-options.js +40 -2
  156. package/es/vef-radio/hooks/use-radio-instance.js +20 -2
  157. package/es/vef-radio/index.js +88 -4
  158. package/es/vef-rate/hooks/use-rate-instance.js +13 -2
  159. package/es/vef-rate/index.js +30 -2
  160. package/es/vef-responsive-container/index.js +54 -3
  161. package/es/vef-responsive-item/index.js +23 -3
  162. package/es/vef-ribbon/index.js +38 -2
  163. package/es/vef-row/index.js +12 -2
  164. package/es/vef-scroll-area/components/scrollbar.js +34 -8
  165. package/es/vef-scroll-area/index.js +69 -4
  166. package/es/vef-select/components/option.js +23 -4
  167. package/es/vef-select/hooks/use-data-options.js +47 -2
  168. package/es/vef-select/hooks/use-field-names.js +21 -2
  169. package/es/vef-select/hooks/use-render-label.js +23 -3
  170. package/es/vef-select/hooks/use-render-option.js +19 -2
  171. package/es/vef-select/hooks/use-select-instance.js +20 -2
  172. package/es/vef-select/index.js +100 -2
  173. package/es/vef-slider/hooks/use-slider-instance.js +13 -2
  174. package/es/vef-slider/index.js +34 -2
  175. package/es/vef-sortable-list/components/overlay-item.js +31 -3
  176. package/es/vef-sortable-list/components/sortable-item.js +75 -3
  177. package/es/vef-sortable-list/hooks/use-merged-items.js +21 -2
  178. package/es/vef-sortable-list/index.js +114 -2
  179. package/es/vef-space/index.js +25 -2
  180. package/es/vef-spin/index.js +12 -2
  181. package/es/vef-splitter/index.js +20 -2
  182. package/es/vef-splitter-panel/index.js +12 -2
  183. package/es/vef-status/index.js +37 -2
  184. package/es/vef-table/components/columns/bool.js +91 -2
  185. package/es/vef-table/components/columns/code.js +10 -2
  186. package/es/vef-table/components/columns/data-dictionary.js +92 -2
  187. package/es/vef-table/components/columns/enum.js +101 -2
  188. package/es/vef-table/components/columns/file.js +10 -2
  189. package/es/vef-table/components/columns/icon.js +10 -2
  190. package/es/vef-table/components/columns/id.js +82 -2
  191. package/es/vef-table/components/columns/image.js +11 -2
  192. package/es/vef-table/components/columns/index.js +33 -2
  193. package/es/vef-table/components/columns/markdown.js +10 -2
  194. package/es/vef-table/components/columns/number.js +83 -2
  195. package/es/vef-table/components/columns/render.js +28 -2
  196. package/es/vef-table/components/columns/rich-text.js +10 -2
  197. package/es/vef-table/components/columns/text.js +88 -2
  198. package/es/vef-table/components/columns-settings.js +195 -11
  199. package/es/vef-table/components/operation-buttons.js +230 -3
  200. package/es/vef-table/components/settings-icon.js +19 -4
  201. package/es/vef-table/components/table-footer.js +102 -4
  202. package/es/vef-table/helper.js +15 -2
  203. package/es/vef-table/hooks/use-computed-batch-buttons.js +33 -2
  204. package/es/vef-table/hooks/use-computed-columns.js +20 -2
  205. package/es/vef-table/hooks/use-computed-values.js +38 -2
  206. package/es/vef-table/hooks/use-data.js +53 -2
  207. package/es/vef-table/hooks/use-default-column-configs.js +27 -2
  208. package/es/vef-table/hooks/use-display-value.js +36 -2
  209. package/es/vef-table/hooks/use-helper-columns.js +67 -2
  210. package/es/vef-table/hooks/use-operation-column-width.js +50 -2
  211. package/es/vef-table/hooks/use-pagination-props.js +44 -2
  212. package/es/vef-table/hooks/use-row-props.js +39 -2
  213. package/es/vef-table/hooks/use-row-selection-config.js +112 -2
  214. package/es/vef-table/hooks/use-selected-rows.js +26 -2
  215. package/es/vef-table/hooks/use-table-columns.js +56 -2
  216. package/es/vef-table/hooks/use-table-context.js +21 -2
  217. package/es/vef-table/hooks/use-table-instance.js +15 -2
  218. package/es/vef-table/hooks/use-table-summary.js +42 -2
  219. package/es/vef-table/hooks/use-table-width.js +13 -2
  220. package/es/vef-table/index.js +227 -6
  221. package/es/vef-table/store.js +17 -2
  222. package/es/vef-tabs/index.js +25 -2
  223. package/es/vef-tag/index.js +28 -2
  224. package/es/vef-temporal-picker/helper.js +57 -2
  225. package/es/vef-temporal-picker/hooks/use-dayjs-value.js +18 -2
  226. package/es/vef-temporal-picker/hooks/use-temporal-limit.js +34 -2
  227. package/es/vef-temporal-picker/hooks/use-temporal-picker-instance.js +19 -2
  228. package/es/vef-temporal-picker/index.js +125 -2
  229. package/es/vef-temporal-range-picker/helper.js +57 -2
  230. package/es/vef-temporal-range-picker/hooks/use-dayjs-values.js +23 -2
  231. package/es/vef-temporal-range-picker/hooks/use-temporal-limit.js +34 -2
  232. package/es/vef-temporal-range-picker/hooks/use-temporal-range-picker-instance.js +19 -2
  233. package/es/vef-temporal-range-picker/index.js +128 -2
  234. package/es/vef-temporal-range-picker/props.js +4 -2
  235. package/es/vef-text/index.js +80 -2
  236. package/es/vef-textarea/hooks/use-textarea-instance.js +13 -2
  237. package/es/vef-textarea/index.js +67 -2
  238. package/es/vef-title/index.js +89 -7
  239. package/es/vef-tooltip/index.js +35 -2
  240. package/es/vef-tree-select/hooks/use-change-handler.js +33 -2
  241. package/es/vef-tree-select/hooks/use-data-options.js +45 -2
  242. package/es/vef-tree-select/hooks/use-tree-select-instance.js +20 -2
  243. package/es/vef-tree-select/index.js +86 -2
  244. package/es/vef-virtual-grid/index.js +107 -4
  245. package/es/vef-virtual-list/index.js +215 -5
  246. package/lib/index.cjs +168 -2
  247. package/lib/internal/index.cjs +10 -2
  248. package/lib/internal/modern-normalize.css.cjs +8 -2
  249. package/lib/internal/utils.cjs +10 -2
  250. package/lib/vef-access-denied/access-denied-icon.cjs +932 -2
  251. package/lib/vef-access-denied/index.cjs +49 -10
  252. package/lib/vef-access-denied/props.cjs +4 -2
  253. package/lib/vef-action-buttons/index.cjs +79 -2
  254. package/lib/vef-action-buttons/props.cjs +4 -2
  255. package/lib/vef-auto-sizer/index.cjs +10 -2
  256. package/lib/vef-auto-sizer/props.cjs +4 -2
  257. package/lib/vef-avatar/index.cjs +24 -2
  258. package/lib/vef-avatar/props.cjs +4 -2
  259. package/lib/vef-avatar-group/index.cjs +29 -2
  260. package/lib/vef-avatar-group/props.cjs +4 -2
  261. package/lib/vef-badge/index.cjs +51 -2
  262. package/lib/vef-badge/props.cjs +4 -2
  263. package/lib/vef-bool/hooks/use-bool-instance.cjs +38 -2
  264. package/lib/vef-bool/index.cjs +64 -2
  265. package/lib/vef-bool/props.cjs +4 -2
  266. package/lib/vef-breadcrumb/index.cjs +52 -2
  267. package/lib/vef-breadcrumb/props.cjs +4 -2
  268. package/lib/vef-button/components/base-button.cjs +77 -2
  269. package/lib/vef-button/index.cjs +155 -2
  270. package/lib/vef-button/props.cjs +4 -2
  271. package/lib/vef-card/index.cjs +29 -2
  272. package/lib/vef-card/props.cjs +4 -2
  273. package/lib/vef-card-meta/index.cjs +16 -2
  274. package/lib/vef-card-meta/props.cjs +4 -2
  275. package/lib/vef-checkbox/hooks/use-checkbox-instance.cjs +24 -2
  276. package/lib/vef-checkbox/hooks/use-data-options.cjs +44 -2
  277. package/lib/vef-checkbox/index.cjs +92 -4
  278. package/lib/vef-checkbox/props.cjs +4 -2
  279. package/lib/vef-col/index.cjs +15 -2
  280. package/lib/vef-col/props.cjs +4 -2
  281. package/lib/vef-color-picker/index.cjs +50 -2
  282. package/lib/vef-color-picker/props.cjs +4 -2
  283. package/lib/vef-compact/index.cjs +19 -2
  284. package/lib/vef-compact/props.cjs +4 -2
  285. package/lib/vef-config-provider/global-style.cjs +28 -16
  286. package/lib/vef-config-provider/hooks/use-ui-config.cjs +129 -2
  287. package/lib/vef-config-provider/index.cjs +125 -4
  288. package/lib/vef-config-provider/props.cjs +4 -2
  289. package/lib/vef-config-provider/store.cjs +27 -2
  290. package/lib/vef-container/index.cjs +22 -2
  291. package/lib/vef-container/props.cjs +4 -2
  292. package/lib/vef-crud-page/components/crud-actions.cjs +36 -2
  293. package/lib/vef-crud-page/components/crud-filter.cjs +58 -2
  294. package/lib/vef-crud-page/components/crud-footer.cjs +120 -4
  295. package/lib/vef-crud-page/components/crud-form-modal.cjs +57 -2
  296. package/lib/vef-crud-page/components/crud-header.cjs +33 -2
  297. package/lib/vef-crud-page/components/crud-table.cjs +80 -2
  298. package/lib/vef-crud-page/hooks/use-action-buttons.cjs +41 -2
  299. package/lib/vef-crud-page/hooks/use-crud-context.cjs +24 -2
  300. package/lib/vef-crud-page/hooks/use-crud-schema.cjs +118 -2
  301. package/lib/vef-crud-page/hooks/use-operation-buttons.cjs +64 -2
  302. package/lib/vef-crud-page/index.cjs +154 -2
  303. package/lib/vef-crud-page/props.cjs +4 -2
  304. package/lib/vef-crud-page/store.cjs +148 -2
  305. package/lib/vef-crud-page/types.cjs +4 -2
  306. package/lib/vef-divider/index.cjs +28 -2
  307. package/lib/vef-divider/props.cjs +4 -2
  308. package/lib/vef-drawer/components/action-button-wrapper.cjs +53 -2
  309. package/lib/vef-drawer/components/button-props.cjs +4 -2
  310. package/lib/vef-drawer/components/cancel-action-button.cjs +25 -2
  311. package/lib/vef-drawer/components/ok-action-button.cjs +24 -2
  312. package/lib/vef-drawer/context.cjs +21 -2
  313. package/lib/vef-drawer/index.cjs +159 -4
  314. package/lib/vef-drawer/props.cjs +4 -2
  315. package/lib/vef-dropdown/index.cjs +96 -2
  316. package/lib/vef-dropdown/props.cjs +4 -2
  317. package/lib/vef-dynamic-icon/index.cjs +50 -2
  318. package/lib/vef-dynamic-icon/props.cjs +10 -2
  319. package/lib/vef-empty/index.cjs +41 -2
  320. package/lib/vef-empty/props.cjs +4 -2
  321. package/lib/vef-empty-placeholder/index.cjs +23 -5
  322. package/lib/vef-empty-placeholder/props.cjs +4 -2
  323. package/lib/vef-error/error-icon.cjs +761 -2
  324. package/lib/vef-error/index.cjs +52 -10
  325. package/lib/vef-error/props.cjs +4 -2
  326. package/lib/vef-filter/components/action-buttons.cjs +123 -6
  327. package/lib/vef-filter/components/advanced-filter.cjs +75 -9
  328. package/lib/vef-filter/components/basic-filter.cjs +39 -5
  329. package/lib/vef-filter/components/fields/index.cjs +15 -2
  330. package/lib/vef-filter/components/fields/input-number.cjs +94 -2
  331. package/lib/vef-filter/components/fields/input.cjs +71 -2
  332. package/lib/vef-filter/components/fields/props.cjs +4 -2
  333. package/lib/vef-filter/components/filter-field.cjs +23 -2
  334. package/lib/vef-filter/components/filter-item.cjs +116 -2
  335. package/lib/vef-filter/event.cjs +48 -2
  336. package/lib/vef-filter/helper.cjs +19 -2
  337. package/lib/vef-filter/hooks/use-action-handlers.cjs +74 -2
  338. package/lib/vef-filter/hooks/use-computed-values.cjs +59 -2
  339. package/lib/vef-filter/hooks/use-filter-context.cjs +24 -2
  340. package/lib/vef-filter/hooks/use-filter-initialization.cjs +41 -2
  341. package/lib/vef-filter/hooks/use-filter-instance.cjs +30 -2
  342. package/lib/vef-filter/hooks/use-filter-items.cjs +27 -2
  343. package/lib/vef-filter/hooks/use-filter-values-change.cjs +34 -2
  344. package/lib/vef-filter/hooks/use-label-config.cjs +31 -2
  345. package/lib/vef-filter/index.cjs +145 -3
  346. package/lib/vef-filter/props.cjs +4 -2
  347. package/lib/vef-filter/store.cjs +77 -2
  348. package/lib/vef-filter/types.cjs +4 -2
  349. package/lib/vef-flex/index.cjs +35 -2
  350. package/lib/vef-flex/props.cjs +4 -2
  351. package/lib/vef-float-button/index.cjs +53 -2
  352. package/lib/vef-float-button/props.cjs +4 -2
  353. package/lib/vef-float-button-group/index.cjs +24 -2
  354. package/lib/vef-float-button-group/props.cjs +4 -2
  355. package/lib/vef-form/components/fields/index.cjs +15 -2
  356. package/lib/vef-form/components/fields/input-number.cjs +127 -2
  357. package/lib/vef-form/components/fields/input.cjs +136 -2
  358. package/lib/vef-form/components/fields/props.cjs +4 -2
  359. package/lib/vef-form/components/form-actions.cjs +62 -4
  360. package/lib/vef-form/components/form-content.cjs +148 -3
  361. package/lib/vef-form/components/form-field.cjs +26 -2
  362. package/lib/vef-form/components/form-group.cjs +68 -4
  363. package/lib/vef-form/components/form-hidden-item.cjs +40 -2
  364. package/lib/vef-form/components/form-item.cjs +83 -2
  365. package/lib/vef-form/components/form-row.cjs +102 -2
  366. package/lib/vef-form/event.cjs +48 -2
  367. package/lib/vef-form/helper.cjs +19 -2
  368. package/lib/vef-form/hooks/use-action-handlers.cjs +134 -2
  369. package/lib/vef-form/hooks/use-columns-layout.cjs +126 -2
  370. package/lib/vef-form/hooks/use-computed-values.cjs +59 -2
  371. package/lib/vef-form/hooks/use-form-context.cjs +20 -2
  372. package/lib/vef-form/hooks/use-form-initialization.cjs +49 -2
  373. package/lib/vef-form/hooks/use-form-instance.cjs +30 -2
  374. package/lib/vef-form/hooks/use-form-values-change.cjs +34 -2
  375. package/lib/vef-form/hooks/use-label-width.cjs +22 -2
  376. package/lib/vef-form/index.cjs +178 -4
  377. package/lib/vef-form/props.cjs +4 -2
  378. package/lib/vef-form/store.cjs +71 -2
  379. package/lib/vef-form/types.cjs +4 -2
  380. package/lib/vef-form/validation-rules.cjs +312 -2
  381. package/lib/vef-form-drawer/index.cjs +102 -2
  382. package/lib/vef-form-drawer/props.cjs +4 -2
  383. package/lib/vef-form-modal/index.cjs +99 -2
  384. package/lib/vef-form-modal/props.cjs +4 -2
  385. package/lib/vef-generic-select/index.cjs +85 -2
  386. package/lib/vef-generic-select/props.cjs +4 -2
  387. package/lib/vef-grid/index.cjs +87 -7
  388. package/lib/vef-grid/props.cjs +8 -2
  389. package/lib/vef-grid-item/index.cjs +56 -2
  390. package/lib/vef-grid-item/props.cjs +4 -2
  391. package/lib/vef-icon/index.cjs +49 -2
  392. package/lib/vef-icon/props.cjs +4 -2
  393. package/lib/vef-icon-select/index.cjs +150 -12
  394. package/lib/vef-icon-select/props.cjs +4 -2
  395. package/lib/vef-input/hooks/use-input-instance.cjs +19 -2
  396. package/lib/vef-input/index.cjs +68 -2
  397. package/lib/vef-input/props.cjs +4 -2
  398. package/lib/vef-input-number/hooks/use-input-number-instance.cjs +17 -2
  399. package/lib/vef-input-number/index.cjs +152 -2
  400. package/lib/vef-input-number/props.cjs +4 -2
  401. package/lib/vef-layout/common-styles.cjs +14 -5
  402. package/lib/vef-layout/components/content.cjs +17 -2
  403. package/lib/vef-layout/components/font-size.cjs +72 -2
  404. package/lib/vef-layout/components/fullscreen.cjs +27 -2
  405. package/lib/vef-layout/components/header-action-icons.cjs +33 -7
  406. package/lib/vef-layout/components/header-content.cjs +23 -2
  407. package/lib/vef-layout/components/header.cjs +73 -7
  408. package/lib/vef-layout/components/icon-boy.cjs +73 -2
  409. package/lib/vef-layout/components/icon-girl.cjs +80 -2
  410. package/lib/vef-layout/components/icon-menu-fold-left.cjs +27 -2
  411. package/lib/vef-layout/components/icon-menu-unfold-left.cjs +27 -2
  412. package/lib/vef-layout/components/menu-groups.cjs +127 -16
  413. package/lib/vef-layout/components/message.cjs +15 -2
  414. package/lib/vef-layout/components/search.cjs +15 -2
  415. package/lib/vef-layout/components/sider.cjs +58 -6
  416. package/lib/vef-layout/components/title.cjs +57 -9
  417. package/lib/vef-layout/components/user-avatar.cjs +84 -10
  418. package/lib/vef-layout/hooks/use-layout-context.cjs +16 -2
  419. package/lib/vef-layout/index.cjs +37 -3
  420. package/lib/vef-layout/logo.svg.cjs +8 -2
  421. package/lib/vef-layout/props.cjs +4 -2
  422. package/lib/vef-layout/store.cjs +22 -2
  423. package/lib/vef-loading-placeholder/index.cjs +46 -6
  424. package/lib/vef-loading-placeholder/props.cjs +4 -2
  425. package/lib/vef-login/index.cjs +156 -22
  426. package/lib/vef-login/login-icon.cjs +672 -2
  427. package/lib/vef-login/props.cjs +4 -2
  428. package/lib/vef-menu/index.cjs +81 -5
  429. package/lib/vef-menu/props.cjs +4 -2
  430. package/lib/vef-modal/components/action-button-wrapper.cjs +53 -2
  431. package/lib/vef-modal/components/button-props.cjs +4 -2
  432. package/lib/vef-modal/components/cancel-action-button.cjs +22 -2
  433. package/lib/vef-modal/components/ok-action-button.cjs +24 -2
  434. package/lib/vef-modal/context.cjs +21 -2
  435. package/lib/vef-modal/index.cjs +244 -3
  436. package/lib/vef-modal/props.cjs +4 -2
  437. package/lib/vef-not-found/index.cjs +49 -10
  438. package/lib/vef-not-found/not-found-icon.cjs +848 -2
  439. package/lib/vef-not-found/props.cjs +4 -2
  440. package/lib/vef-page/index.cjs +91 -11
  441. package/lib/vef-page/props.cjs +4 -2
  442. package/lib/vef-pagination/index.cjs +61 -2
  443. package/lib/vef-pagination/props.cjs +17 -2
  444. package/lib/vef-paragraph/index.cjs +93 -2
  445. package/lib/vef-paragraph/props.cjs +4 -2
  446. package/lib/vef-password/hooks/use-password-instance.cjs +17 -2
  447. package/lib/vef-password/index.cjs +71 -2
  448. package/lib/vef-password/props.cjs +4 -2
  449. package/lib/vef-popconfirm/index.cjs +60 -2
  450. package/lib/vef-popconfirm/props.cjs +4 -2
  451. package/lib/vef-popover/index.cjs +33 -2
  452. package/lib/vef-popover/props.cjs +4 -2
  453. package/lib/vef-radio/hooks/use-data-options.cjs +44 -2
  454. package/lib/vef-radio/hooks/use-radio-instance.cjs +24 -2
  455. package/lib/vef-radio/index.cjs +92 -4
  456. package/lib/vef-radio/props.cjs +4 -2
  457. package/lib/vef-rate/hooks/use-rate-instance.cjs +17 -2
  458. package/lib/vef-rate/index.cjs +34 -2
  459. package/lib/vef-rate/props.cjs +4 -2
  460. package/lib/vef-responsive-container/index.cjs +58 -3
  461. package/lib/vef-responsive-container/props.cjs +4 -2
  462. package/lib/vef-responsive-item/index.cjs +27 -3
  463. package/lib/vef-responsive-item/props.cjs +4 -2
  464. package/lib/vef-ribbon/index.cjs +42 -2
  465. package/lib/vef-ribbon/props.cjs +4 -2
  466. package/lib/vef-row/index.cjs +16 -2
  467. package/lib/vef-row/props.cjs +4 -2
  468. package/lib/vef-scroll-area/components/scrollbar.cjs +38 -8
  469. package/lib/vef-scroll-area/index.cjs +73 -4
  470. package/lib/vef-scroll-area/props.cjs +4 -2
  471. package/lib/vef-select/components/option.cjs +27 -4
  472. package/lib/vef-select/hooks/use-data-options.cjs +51 -2
  473. package/lib/vef-select/hooks/use-field-names.cjs +25 -2
  474. package/lib/vef-select/hooks/use-render-label.cjs +27 -3
  475. package/lib/vef-select/hooks/use-render-option.cjs +23 -2
  476. package/lib/vef-select/hooks/use-select-instance.cjs +24 -2
  477. package/lib/vef-select/index.cjs +104 -2
  478. package/lib/vef-select/props.cjs +4 -2
  479. package/lib/vef-slider/hooks/use-slider-instance.cjs +17 -2
  480. package/lib/vef-slider/index.cjs +38 -2
  481. package/lib/vef-slider/props.cjs +4 -2
  482. package/lib/vef-sortable-list/components/overlay-item.cjs +35 -3
  483. package/lib/vef-sortable-list/components/sortable-item.cjs +79 -3
  484. package/lib/vef-sortable-list/hooks/use-merged-items.cjs +25 -2
  485. package/lib/vef-sortable-list/index.cjs +118 -2
  486. package/lib/vef-sortable-list/props.cjs +4 -2
  487. package/lib/vef-space/index.cjs +29 -2
  488. package/lib/vef-space/props.cjs +4 -2
  489. package/lib/vef-spin/index.cjs +16 -2
  490. package/lib/vef-spin/props.cjs +4 -2
  491. package/lib/vef-splitter/index.cjs +24 -2
  492. package/lib/vef-splitter/props.cjs +4 -2
  493. package/lib/vef-splitter-panel/index.cjs +16 -2
  494. package/lib/vef-splitter-panel/props.cjs +4 -2
  495. package/lib/vef-status/index.cjs +41 -2
  496. package/lib/vef-status/props.cjs +4 -2
  497. package/lib/vef-table/components/columns/bool.cjs +95 -2
  498. package/lib/vef-table/components/columns/code.cjs +14 -2
  499. package/lib/vef-table/components/columns/data-dictionary.cjs +96 -2
  500. package/lib/vef-table/components/columns/enum.cjs +105 -2
  501. package/lib/vef-table/components/columns/file.cjs +14 -2
  502. package/lib/vef-table/components/columns/icon.cjs +14 -2
  503. package/lib/vef-table/components/columns/id.cjs +86 -2
  504. package/lib/vef-table/components/columns/image.cjs +15 -2
  505. package/lib/vef-table/components/columns/index.cjs +37 -2
  506. package/lib/vef-table/components/columns/markdown.cjs +14 -2
  507. package/lib/vef-table/components/columns/number.cjs +87 -2
  508. package/lib/vef-table/components/columns/props.cjs +4 -2
  509. package/lib/vef-table/components/columns/render.cjs +32 -2
  510. package/lib/vef-table/components/columns/rich-text.cjs +14 -2
  511. package/lib/vef-table/components/columns/text.cjs +92 -2
  512. package/lib/vef-table/components/columns-settings.cjs +199 -11
  513. package/lib/vef-table/components/operation-buttons.cjs +234 -3
  514. package/lib/vef-table/components/settings-icon.cjs +23 -4
  515. package/lib/vef-table/components/table-footer.cjs +106 -4
  516. package/lib/vef-table/helper.cjs +19 -2
  517. package/lib/vef-table/hooks/use-computed-batch-buttons.cjs +37 -2
  518. package/lib/vef-table/hooks/use-computed-columns.cjs +24 -2
  519. package/lib/vef-table/hooks/use-computed-values.cjs +42 -2
  520. package/lib/vef-table/hooks/use-data.cjs +57 -2
  521. package/lib/vef-table/hooks/use-default-column-configs.cjs +31 -2
  522. package/lib/vef-table/hooks/use-display-value.cjs +40 -2
  523. package/lib/vef-table/hooks/use-helper-columns.cjs +71 -2
  524. package/lib/vef-table/hooks/use-operation-column-width.cjs +54 -2
  525. package/lib/vef-table/hooks/use-pagination-props.cjs +48 -2
  526. package/lib/vef-table/hooks/use-row-props.cjs +43 -2
  527. package/lib/vef-table/hooks/use-row-selection-config.cjs +116 -2
  528. package/lib/vef-table/hooks/use-selected-rows.cjs +30 -2
  529. package/lib/vef-table/hooks/use-table-columns.cjs +60 -2
  530. package/lib/vef-table/hooks/use-table-context.cjs +27 -2
  531. package/lib/vef-table/hooks/use-table-instance.cjs +19 -2
  532. package/lib/vef-table/hooks/use-table-summary.cjs +46 -2
  533. package/lib/vef-table/hooks/use-table-width.cjs +17 -2
  534. package/lib/vef-table/index.cjs +231 -6
  535. package/lib/vef-table/props.cjs +4 -2
  536. package/lib/vef-table/store.cjs +23 -2
  537. package/lib/vef-table/types.cjs +4 -2
  538. package/lib/vef-tabs/index.cjs +29 -2
  539. package/lib/vef-tabs/props.cjs +4 -2
  540. package/lib/vef-tag/index.cjs +32 -2
  541. package/lib/vef-tag/props.cjs +4 -2
  542. package/lib/vef-temporal-picker/helper.cjs +61 -2
  543. package/lib/vef-temporal-picker/hooks/use-dayjs-value.cjs +22 -2
  544. package/lib/vef-temporal-picker/hooks/use-temporal-limit.cjs +38 -2
  545. package/lib/vef-temporal-picker/hooks/use-temporal-picker-instance.cjs +23 -2
  546. package/lib/vef-temporal-picker/index.cjs +129 -2
  547. package/lib/vef-temporal-picker/props.cjs +4 -2
  548. package/lib/vef-temporal-range-picker/helper.cjs +61 -2
  549. package/lib/vef-temporal-range-picker/hooks/use-dayjs-values.cjs +27 -2
  550. package/lib/vef-temporal-range-picker/hooks/use-temporal-limit.cjs +38 -2
  551. package/lib/vef-temporal-range-picker/hooks/use-temporal-range-picker-instance.cjs +23 -2
  552. package/lib/vef-temporal-range-picker/index.cjs +132 -2
  553. package/lib/vef-temporal-range-picker/props.cjs +8 -2
  554. package/lib/vef-text/index.cjs +84 -2
  555. package/lib/vef-text/props.cjs +4 -2
  556. package/lib/vef-textarea/hooks/use-textarea-instance.cjs +17 -2
  557. package/lib/vef-textarea/index.cjs +71 -2
  558. package/lib/vef-textarea/props.cjs +4 -2
  559. package/lib/vef-title/index.cjs +93 -7
  560. package/lib/vef-title/props.cjs +4 -2
  561. package/lib/vef-tooltip/index.cjs +39 -2
  562. package/lib/vef-tooltip/props.cjs +4 -2
  563. package/lib/vef-tree-select/hooks/use-change-handler.cjs +37 -2
  564. package/lib/vef-tree-select/hooks/use-data-options.cjs +49 -2
  565. package/lib/vef-tree-select/hooks/use-tree-select-instance.cjs +24 -2
  566. package/lib/vef-tree-select/index.cjs +90 -2
  567. package/lib/vef-tree-select/props.cjs +4 -2
  568. package/lib/vef-virtual-grid/index.cjs +111 -4
  569. package/lib/vef-virtual-grid/props.cjs +4 -2
  570. package/lib/vef-virtual-list/index.cjs +219 -5
  571. package/lib/vef-virtual-list/props.cjs +4 -2
  572. package/package.json +4 -4
  573. package/types/vef-crud-page/components/crud-actions.d.ts +4 -4
  574. package/types/vef-crud-page/components/crud-filter.d.ts +5 -5
  575. package/types/vef-crud-page/components/crud-footer.d.ts +4 -4
  576. package/types/vef-crud-page/components/crud-form-modal.d.ts +5 -5
  577. package/types/vef-crud-page/components/crud-header.d.ts +5 -5
  578. package/types/vef-crud-page/components/crud-table.d.ts +8 -8
  579. package/types/vef-crud-page/hooks/use-action-buttons.d.ts +3 -3
  580. package/types/vef-crud-page/hooks/use-crud-context.d.ts +2 -2
  581. package/types/vef-crud-page/hooks/use-crud-schema.d.ts +4 -4
  582. package/types/vef-crud-page/hooks/use-operation-buttons.d.ts +2 -2
  583. package/types/vef-crud-page/index.d.ts +2 -2
  584. package/types/vef-crud-page/props.d.ts +10 -10
  585. package/types/vef-crud-page/store.d.ts +13 -13
  586. package/types/vef-crud-page/types.d.ts +24 -19
@@ -1,3 +1,34 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("@emotion/react/jsx-runtime"),t=require("react"),r=require("./crud-filter.cjs");const i=t.memo((function({title:t,tableApi:i,tableApiParams:l,filterItems:a,actionButtons:o}){return a.length>0?e.jsx(r.default,{actionButtons:o,filterSchema:a,tableApi:i,tableApiParams:l,title:t}):null}));exports.default=i;
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
5
+
6
+ const jsxRuntime = require('@emotion/react/jsx-runtime');
7
+ const react = require('react');
8
+ const crudFilter = require('./crud-filter.cjs');
9
+
10
+ function VefCrudHeaderBase({
11
+ title,
12
+ tableApi,
13
+ tableApiParams,
14
+ filterItems,
15
+ actionButtons
16
+ }) {
17
+ if (filterItems.length > 0) {
18
+ return /* @__PURE__ */ jsxRuntime.jsx(
19
+ crudFilter.default,
20
+ {
21
+ actionButtons,
22
+ filterSchema: filterItems,
23
+ tableApi,
24
+ tableApiParams,
25
+ title
26
+ }
27
+ );
28
+ }
29
+ return null;
30
+ }
31
+ const VefCrudHeader = react.memo(VefCrudHeaderBase);
32
+
33
+ exports.default = VefCrudHeader;
3
34
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,81 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("@emotion/react/jsx-runtime"),t=require("react"),s=require("../../vef-table/index.cjs"),o=require("../hooks/use-crud-context.cjs"),a=require("../hooks/use-operation-buttons.cjs"),r=require("../store.cjs");const n=t.memo((function({api:n,apiParams:l,deletionApi:u,paginated:c,schema:i,selectable:d,operationButtons:m,...p}){const[f,x,S]=r.useCrudStore((e=>[e.confirmedFilterValues,e.selectedInfo,e.setSelectedInfo])),b=t.useMemo((()=>({...l,...f})),[l,f]),C=t.useCallback(((e,t)=>{S({selectedKeys:e,selectedRecords:t})}),[S]),j=a.useOperationButtons(u,m),y=t.useRef(null),h=r.useCrudStoreApi();t.useEffect((()=>{h.setState({tableInstanceRef:y})}),[h]);const g=o.useCrudContext();return c?e.jsx(s.default,{ref:y,multipleSelection:!0,paginated:!0,api:n,apiParams:b,externalContext:g,operationButtons:j,schema:i,selectable:d,selectedKeys:x.selectedKeys,selectionSummary:!1,onRowSelectionChange:C,...p}):e.jsx(s.default,{ref:y,multipleSelection:!0,api:n,apiParams:b,externalContext:g,schema:i,selectable:d,selectedKeys:x.selectedKeys,selectionSummary:!1,onRowSelectionChange:C,...p})}));exports.default=n;
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
5
+
6
+ const jsxRuntime = require('@emotion/react/jsx-runtime');
7
+ const react = require('react');
8
+ const index = require('../../vef-table/index.cjs');
9
+ const useCrudContext = require('../hooks/use-crud-context.cjs');
10
+ const useOperationButtons = require('../hooks/use-operation-buttons.cjs');
11
+ const store = require('../store.cjs');
12
+
13
+ function VefCrudTableBase({
14
+ api,
15
+ apiParams,
16
+ deletionApi,
17
+ paginated,
18
+ schema,
19
+ selectable,
20
+ operationButtons,
21
+ ...tableProps
22
+ }) {
23
+ const [confirmedFilterValues, selectedInfo, setSelectedInfo] = store.useCrudStore((state) => [state.confirmedFilterValues, state.selectedInfo, state.setSelectedInfo]);
24
+ const mergedApiParams = react.useMemo(() => ({
25
+ ...apiParams,
26
+ ...confirmedFilterValues
27
+ }), [apiParams, confirmedFilterValues]);
28
+ const handleSelectionChange = react.useCallback((selectedKeys, selectedRecords) => {
29
+ setSelectedInfo({
30
+ selectedKeys,
31
+ selectedRecords
32
+ });
33
+ }, [setSelectedInfo]);
34
+ const operationButtonsToUse = useOperationButtons.useOperationButtons(deletionApi, operationButtons);
35
+ const tableInstanceRef = react.useRef(null);
36
+ const crudStore = store.useCrudStoreApi();
37
+ react.useEffect(() => {
38
+ crudStore.setState({ tableInstanceRef });
39
+ }, [crudStore]);
40
+ const crudContext = useCrudContext.useCrudContext();
41
+ if (paginated) {
42
+ return /* @__PURE__ */ jsxRuntime.jsx(
43
+ index.default,
44
+ {
45
+ ref: tableInstanceRef,
46
+ multipleSelection: true,
47
+ paginated: true,
48
+ api,
49
+ apiParams: mergedApiParams,
50
+ externalContext: crudContext,
51
+ operationButtons: operationButtonsToUse,
52
+ schema,
53
+ selectable,
54
+ selectedKeys: selectedInfo.selectedKeys,
55
+ selectionSummary: false,
56
+ onRowSelectionChange: handleSelectionChange,
57
+ ...tableProps
58
+ }
59
+ );
60
+ }
61
+ return /* @__PURE__ */ jsxRuntime.jsx(
62
+ index.default,
63
+ {
64
+ ref: tableInstanceRef,
65
+ multipleSelection: true,
66
+ api,
67
+ apiParams: mergedApiParams,
68
+ externalContext: crudContext,
69
+ schema,
70
+ selectable,
71
+ selectedKeys: selectedInfo.selectedKeys,
72
+ selectionSummary: false,
73
+ onRowSelectionChange: handleSelectionChange,
74
+ ...tableProps
75
+ }
76
+ );
77
+ }
78
+ const VefCrudTable = react.memo(VefCrudTableBase);
79
+
80
+ exports.default = VefCrudTable;
3
81
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,42 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("@emotion/react/jsx-runtime"),r=require("@vef-framework/shared"),o=require("lucide-react"),t=require("react"),c=require("../../vef-icon/index.cjs"),i=require("../store.cjs");exports.useActionButtons=function(n){const s=i.useCrudStore((e=>e.formApiKeys)),u=Reflect.has(s,r.creationFormScene),a=Reflect.get(s,r.creationFormScene);return t.useMemo((()=>u?[...n??[],{label:"创建",key:`_${r.creationFormScene}`,icon:e.jsx(c.default,{children:e.jsx(o.PlusIcon,{})}),color:"primary",permissions:[a],onClick:({openForm:e,refetch:o})=>e({scene:r.creationFormScene,title:"创建",onSubmitSuccess:()=>{o()}})}]:n??[]),[u,n,a])};
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('@emotion/react/jsx-runtime');
7
+ const shared = require('@vef-framework/shared');
8
+ const lucideReact = require('lucide-react');
9
+ const react = require('react');
10
+ const index = require('../../vef-icon/index.cjs');
11
+ const store = require('../store.cjs');
12
+
13
+ function useActionButtons(actionButtons) {
14
+ const formApiKeys = store.useCrudStore((state) => state.formApiKeys);
15
+ const showCreationActionButton = Reflect.has(formApiKeys, shared.creationFormScene);
16
+ const creationFormApiKey = Reflect.get(formApiKeys, shared.creationFormScene);
17
+ return react.useMemo(() => {
18
+ if (showCreationActionButton) {
19
+ return [
20
+ ...actionButtons ?? [],
21
+ {
22
+ label: "\u521B\u5EFA",
23
+ key: `_${shared.creationFormScene}`,
24
+ icon: /* @__PURE__ */ jsxRuntime.jsx(index.default, { children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.PlusIcon, {}) }),
25
+ color: "primary",
26
+ permissions: [creationFormApiKey],
27
+ onClick: ({ openForm, refetch }) => openForm({
28
+ scene: shared.creationFormScene,
29
+ title: "\u521B\u5EFA",
30
+ onSubmitSuccess: () => {
31
+ refetch();
32
+ }
33
+ })
34
+ }
35
+ ];
36
+ }
37
+ return actionButtons ?? [];
38
+ }, [showCreationActionButton, actionButtons, creationFormApiKey]);
39
+ }
40
+
41
+ exports.useActionButtons = useActionButtons;
3
42
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,25 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("react"),r=require("../store.cjs");exports.useCrudContext=function(){const[t,o,s]=r.useCrudStore((e=>[e.openForm,e.filterValues,e.tableInstanceRef]));return e.useMemo((()=>({openForm:t,filterValues:o,refetch:async()=>{await(s.current?.refetch())}})),[t,o,s])};
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const react = require('react');
7
+ const store = require('../store.cjs');
8
+
9
+ function useCrudContext() {
10
+ const [openForm, filterValues, tableInstanceRef] = store.useCrudStore((state) => [
11
+ state.openForm,
12
+ state.filterValues,
13
+ state.tableInstanceRef
14
+ ]);
15
+ return react.useMemo(() => ({
16
+ openForm,
17
+ filterValues,
18
+ refetch: async () => {
19
+ await tableInstanceRef.current?.refetch();
20
+ }
21
+ }), [openForm, filterValues, tableInstanceRef]);
22
+ }
23
+
24
+ exports.useCrudContext = useCrudContext;
3
25
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,119 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("@vef-framework/shared"),s=require("react");exports.useCrudSchema=function(t){return s.useMemo((()=>{const s=[],o=[],r=new Set,l={};for(const n of t){const{filter:t,form:u,...c}=n,{name:a,title:i}=c;if(s.push(c),t){const{label:s,advanced:r,...l}=t,n={name:a,label:r&&e.isNullish(s)?i:s,advanced:r,...l};("Input"===n.type||"InputNumber"===n.type)&&e.isNullish(s)&&e.isNullish(n.placeholder)&&(n.placeholder=e.isString(i)?`请输入${i}`:"请输入"),o.push(n)}if(u){const{group:s,row:t,column:o,filterValueAsDefault:n,label:c,...f}=u,p=`${s??1}`,m=l[p]??{};l[p]||(l[p]=m);const h=`${t??1}`,d=m[h]??{};m[h]||(m[h]=d);const y=`${o??1}`,b=d[y]??[];d[y]||(d[y]=b),"Hidden"===f.type?b.push({name:a,...f}):b.push({name:a,label:e.isNullish(c)?i:c,...f}),n&&r.add(a)}}const n=[],u=Object.keys(l).sort();for(const e of u){const s=l[e],t=[],o=Object.keys(s).sort();for(const e of o){const o=s[e],r=[],l=Object.keys(o).sort();for(const e of l){const s={key:e,items:o[e]};r.push(s)}t.push({key:e,columns:r})}n.push({key:e,rows:t})}return{tableSchema:s,filterItems:o,formGroups:n,filterValueAsDefaultKeys:Array.from(r)}}),[t])};
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const shared = require('@vef-framework/shared');
7
+ const react = require('react');
8
+
9
+ function useCrudSchema(schema) {
10
+ return react.useMemo(() => {
11
+ const tableColumns = [];
12
+ const filterItems = [];
13
+ const filterValueAsDefaultSet = /* @__PURE__ */ new Set();
14
+ const formGroupMap = {};
15
+ for (const item of schema) {
16
+ const {
17
+ filter,
18
+ form,
19
+ ...column
20
+ } = item;
21
+ const { name, title } = column;
22
+ tableColumns.push(column);
23
+ if (filter) {
24
+ const {
25
+ label,
26
+ advanced,
27
+ ...rest
28
+ } = filter;
29
+ const filterItem = {
30
+ name,
31
+ label: advanced && shared.isNullish(label) ? title : label,
32
+ advanced,
33
+ ...rest
34
+ };
35
+ if ((filterItem.type === "Input" || filterItem.type === "InputNumber") && shared.isNullish(label) && shared.isNullish(filterItem.placeholder)) {
36
+ filterItem.placeholder = shared.isString(title) ? `\u8BF7\u8F93\u5165${title}` : "\u8BF7\u8F93\u5165";
37
+ }
38
+ filterItems.push(filterItem);
39
+ }
40
+ if (form) {
41
+ const {
42
+ group,
43
+ row,
44
+ column: column2,
45
+ filterValueAsDefault,
46
+ label,
47
+ ...rest
48
+ } = form;
49
+ const groupKey = `${group ?? 1}`;
50
+ const groupSchema = formGroupMap[groupKey] ?? {};
51
+ if (!formGroupMap[groupKey]) {
52
+ formGroupMap[groupKey] = groupSchema;
53
+ }
54
+ const rowKey = `${row ?? 1}`;
55
+ const rowSchema = groupSchema[rowKey] ?? {};
56
+ if (!groupSchema[rowKey]) {
57
+ groupSchema[rowKey] = rowSchema;
58
+ }
59
+ const columnKey = `${column2 ?? 1}`;
60
+ const columnSchema = rowSchema[columnKey] ?? [];
61
+ if (!rowSchema[columnKey]) {
62
+ rowSchema[columnKey] = columnSchema;
63
+ }
64
+ if (rest.type === "Hidden") {
65
+ columnSchema.push({
66
+ name,
67
+ ...rest
68
+ });
69
+ } else {
70
+ columnSchema.push({
71
+ name,
72
+ label: shared.isNullish(label) ? title : label,
73
+ ...rest
74
+ });
75
+ }
76
+ if (filterValueAsDefault ?? false) {
77
+ filterValueAsDefaultSet.add(name);
78
+ }
79
+ }
80
+ }
81
+ const formGroups = [];
82
+ const groupKeys = Object.keys(formGroupMap).sort();
83
+ for (const groupKey of groupKeys) {
84
+ const groupSchemaMap = formGroupMap[groupKey];
85
+ const formRows = [];
86
+ const rowKeys = Object.keys(groupSchemaMap).sort();
87
+ for (const rowKey of rowKeys) {
88
+ const rowSchema = groupSchemaMap[rowKey];
89
+ const formColumns = [];
90
+ const columnKeys = Object.keys(rowSchema).sort();
91
+ for (const columnKey of columnKeys) {
92
+ const columnSchema = rowSchema[columnKey];
93
+ const formColumn = {
94
+ key: columnKey,
95
+ items: columnSchema
96
+ };
97
+ formColumns.push(formColumn);
98
+ }
99
+ formRows.push({
100
+ key: rowKey,
101
+ columns: formColumns
102
+ });
103
+ }
104
+ formGroups.push({
105
+ key: groupKey,
106
+ rows: formRows
107
+ });
108
+ }
109
+ return {
110
+ tableSchema: tableColumns,
111
+ filterItems,
112
+ formGroups,
113
+ filterValueAsDefaultKeys: Array.from(filterValueAsDefaultSet)
114
+ };
115
+ }, [schema]);
116
+ }
117
+
118
+ exports.useCrudSchema = useCrudSchema;
3
119
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,65 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("@emotion/react/jsx-runtime"),r=require("@vef-framework/core"),o=require("@vef-framework/shared"),i=require("lucide-react"),t=require("react"),c=require("../../vef-icon/index.cjs"),n=require("../store.cjs");exports.useOperationButtons=function(s,u){const{useApiMutation:a,stubMutationApi:l}=r.useApiContext(),m=a(s??l),f=n.useCrudStore((e=>e.formApiKeys)),d=Reflect.has(f,o.modificationFormScene);return t.useMemo((()=>{const r=[...u??[]];return d&&r.push({key:"_modification",label:"修改",icon:e.jsx(c.default,{children:e.jsx(i.PencilIcon,{})}),color:"primary",onClick:({record:e,openForm:r,refetch:i})=>{r({scene:o.modificationFormScene,title:"修改",initialValues:e,onSubmitSuccess:()=>{i()}})}}),s&&r.push({key:"_deletion",label:"删除",icon:e.jsx(c.default,{children:e.jsx(i.TrashIcon,{})}),color:"error",requireConfirmation:!0,confirmationMode:"simple",onClick:async({record:e,refetch:r})=>{const{message:i}=await m.mutate(e);o.showSuccessMessage(i),r()}}),r}),[s,m,u,d])};
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
5
+
6
+ const jsxRuntime = require('@emotion/react/jsx-runtime');
7
+ const core = require('@vef-framework/core');
8
+ const shared = require('@vef-framework/shared');
9
+ const lucideReact = require('lucide-react');
10
+ const react = require('react');
11
+ const index = require('../../vef-icon/index.cjs');
12
+ const store = require('../store.cjs');
13
+
14
+ function useOperationButtons(deletionApi, operationButtons) {
15
+ const { useApiMutation, stubMutationApi } = core.useApiContext();
16
+ const deletionMutation = useApiMutation(deletionApi ?? stubMutationApi);
17
+ const formApiKeys = store.useCrudStore((state) => state.formApiKeys);
18
+ const showModificationButton = Reflect.has(formApiKeys, shared.modificationFormScene);
19
+ return react.useMemo(() => {
20
+ const buttons = [
21
+ ...operationButtons ?? []
22
+ ];
23
+ if (showModificationButton) {
24
+ buttons.push({
25
+ key: "_modification",
26
+ label: "\u4FEE\u6539",
27
+ icon: /* @__PURE__ */ jsxRuntime.jsx(index.default, { children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.PencilIcon, {}) }),
28
+ color: "primary",
29
+ onClick: ({
30
+ record,
31
+ openForm,
32
+ refetch
33
+ }) => {
34
+ openForm({
35
+ scene: shared.modificationFormScene,
36
+ title: "\u4FEE\u6539",
37
+ initialValues: record,
38
+ onSubmitSuccess: () => {
39
+ refetch();
40
+ }
41
+ });
42
+ }
43
+ });
44
+ }
45
+ if (deletionApi) {
46
+ buttons.push({
47
+ key: "_deletion",
48
+ label: "\u5220\u9664",
49
+ icon: /* @__PURE__ */ jsxRuntime.jsx(index.default, { children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.TrashIcon, {}) }),
50
+ color: "error",
51
+ requireConfirmation: true,
52
+ confirmationMode: "simple",
53
+ onClick: async ({ record, refetch }) => {
54
+ const { message } = await deletionMutation.mutate(record);
55
+ shared.showSuccessMessage(message);
56
+ refetch();
57
+ }
58
+ });
59
+ }
60
+ return buttons;
61
+ }, [deletionApi, deletionMutation, operationButtons, showModificationButton]);
62
+ }
63
+
64
+ exports.useOperationButtons = useOperationButtons;
3
65
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,155 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("@emotion/react/jsx-runtime"),t=require("@vef-framework/shared"),s=require("react"),r=require("../vef-card/index.cjs"),o=require("../vef-page/index.cjs"),i=require("./components/crud-actions.cjs"),a=require("./components/crud-footer.cjs"),l=require("./components/crud-form-modal.cjs"),c=require("./components/crud-header.cjs"),u=require("./components/crud-table.cjs"),n=require("./hooks/use-crud-schema.cjs"),m=require("./store.cjs");function f({title:s,actionButtons:n,batchActionButtons:f,tableSchema:d,filterItems:p,formGroups:b,tableApiParams:h,formApis:A,deletionApi:j,batchDeletionApi:S,selectionSummary:x,...q}){const{selectedKeys:y}=m.useCrudStore((e=>e.selectedInfo)),g=!t.isNullish(S)||!t.isNullish(f)&&f.length>0;let P;if(q.paginated){const{tableApi:t,...s}=q;P=e.jsx(u.default,{showRowNumber:!0,api:t,apiParams:h,deletionApi:j,schema:d,selectable:g,...s})}else{const{tableApi:t,...s}=q;P=e.jsx(u.default,{showRowNumber:!0,api:t,apiParams:h,deletionApi:j,schema:d,selectable:g,...s})}const{tableApi:B}=q;return e.jsx(o.default,{scrollable:!0,title:s,actions:e.jsx(i.default,{actionButtons:n,tableApi:B,tableApiParams:h}),footer:y.length>0&&e.jsx(a.default,{batchActionButtons:f,batchDeletionApi:S,selectionSummary:x,tableApi:B,tableApiParams:h}),header:e.jsx(c.default,{actionButtons:n,filterItems:p,tableApi:B,tableApiParams:h,title:s}),children:e.jsxs(r.default,{children:[P,A&&Object.keys(A).length>0&&b.length>0&&e.jsx(l.default,{formApis:A,formSchema:b})]})})}exports.default=function({schema:t,formApis:r,onFormOpen:o,onBeforeSubmit:i,onSubmitSuccess:a,...l}){const{tableSchema:c,filterItems:u,formGroups:d,filterValueAsDefaultKeys:p}=n.useCrudSchema(t),b=s.useMemo((()=>{const e=r??{};return Object.keys(e).reduce(((t,s)=>(e[s]&&(t[s]=e[s].key),t)),{})}),[r]),h=s.useMemo((()=>({filterValueAsDefaultKeys:p,formApiKeys:b,onBeforeSubmit:i,onFormOpen:o,onSubmitSuccess:a})),[p,b,i,o,a]);return e.jsx(m.CrudStoreProvider,{initialState:h,children:e.jsx(f,{filterItems:u,formApis:r,formGroups:d,tableSchema:c,...l})})};
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: 'Module' } });
5
+
6
+ const jsxRuntime = require('@emotion/react/jsx-runtime');
7
+ const shared = require('@vef-framework/shared');
8
+ const react = require('react');
9
+ const index$1 = require('../vef-card/index.cjs');
10
+ const index = require('../vef-page/index.cjs');
11
+ const crudActions = require('./components/crud-actions.cjs');
12
+ const crudFooter = require('./components/crud-footer.cjs');
13
+ const crudFormModal = require('./components/crud-form-modal.cjs');
14
+ const crudHeader = require('./components/crud-header.cjs');
15
+ const crudTable = require('./components/crud-table.cjs');
16
+ const useCrudSchema = require('./hooks/use-crud-schema.cjs');
17
+ const store = require('./store.cjs');
18
+
19
+ function VefCrudPageBase({
20
+ title,
21
+ actionButtons,
22
+ batchActionButtons,
23
+ tableSchema,
24
+ filterItems,
25
+ formGroups,
26
+ tableApiParams,
27
+ formApis,
28
+ deletionApi,
29
+ batchDeletionApi,
30
+ selectionSummary,
31
+ ...tableProps
32
+ }) {
33
+ const { selectedKeys } = store.useCrudStore((state) => state.selectedInfo);
34
+ const selectable = !shared.isNullish(batchDeletionApi) || !shared.isNullish(batchActionButtons) && batchActionButtons.length > 0;
35
+ let tableNode;
36
+ if (tableProps.paginated) {
37
+ const { tableApi: tableApi2, ...restTableProps } = tableProps;
38
+ tableNode = /* @__PURE__ */ jsxRuntime.jsx(
39
+ crudTable.default,
40
+ {
41
+ showRowNumber: true,
42
+ api: tableApi2,
43
+ apiParams: tableApiParams,
44
+ deletionApi,
45
+ schema: tableSchema,
46
+ selectable,
47
+ ...restTableProps
48
+ }
49
+ );
50
+ } else {
51
+ const { tableApi: tableApi2, ...restTableProps } = tableProps;
52
+ tableNode = /* @__PURE__ */ jsxRuntime.jsx(
53
+ crudTable.default,
54
+ {
55
+ showRowNumber: true,
56
+ api: tableApi2,
57
+ apiParams: tableApiParams,
58
+ deletionApi,
59
+ schema: tableSchema,
60
+ selectable,
61
+ ...restTableProps
62
+ }
63
+ );
64
+ }
65
+ const { tableApi } = tableProps;
66
+ return /* @__PURE__ */ jsxRuntime.jsx(
67
+ index.default,
68
+ {
69
+ scrollable: true,
70
+ title,
71
+ actions: /* @__PURE__ */ jsxRuntime.jsx(
72
+ crudActions.default,
73
+ {
74
+ actionButtons,
75
+ tableApi,
76
+ tableApiParams
77
+ }
78
+ ),
79
+ footer: selectedKeys.length > 0 && /* @__PURE__ */ jsxRuntime.jsx(
80
+ crudFooter.default,
81
+ {
82
+ batchActionButtons,
83
+ batchDeletionApi,
84
+ selectionSummary,
85
+ tableApi,
86
+ tableApiParams
87
+ }
88
+ ),
89
+ header: /* @__PURE__ */ jsxRuntime.jsx(
90
+ crudHeader.default,
91
+ {
92
+ actionButtons,
93
+ filterItems,
94
+ tableApi,
95
+ tableApiParams,
96
+ title
97
+ }
98
+ ),
99
+ children: /* @__PURE__ */ jsxRuntime.jsxs(index$1.default, { children: [
100
+ tableNode,
101
+ formApis && Object.keys(formApis).length > 0 && formGroups.length > 0 && /* @__PURE__ */ jsxRuntime.jsx(
102
+ crudFormModal.default,
103
+ {
104
+ formApis,
105
+ formSchema: formGroups
106
+ }
107
+ )
108
+ ] })
109
+ }
110
+ );
111
+ }
112
+ function VefCrudPage({
113
+ schema,
114
+ formApis,
115
+ onFormOpen,
116
+ onBeforeSubmit,
117
+ onSubmitSuccess,
118
+ ...restProps
119
+ }) {
120
+ const {
121
+ tableSchema,
122
+ filterItems,
123
+ formGroups,
124
+ filterValueAsDefaultKeys
125
+ } = useCrudSchema.useCrudSchema(schema);
126
+ const formApiKeys = react.useMemo(() => {
127
+ const apis = formApis ?? {};
128
+ return Object.keys(apis).reduce((acc, key) => {
129
+ if (apis[key]) {
130
+ acc[key] = apis[key].key;
131
+ }
132
+ return acc;
133
+ }, {});
134
+ }, [formApis]);
135
+ const initialState = react.useMemo(() => ({
136
+ filterValueAsDefaultKeys,
137
+ formApiKeys,
138
+ onBeforeSubmit,
139
+ onFormOpen,
140
+ onSubmitSuccess
141
+ }), [filterValueAsDefaultKeys, formApiKeys, onBeforeSubmit, onFormOpen, onSubmitSuccess]);
142
+ return /* @__PURE__ */ jsxRuntime.jsx(store.CrudStoreProvider, { initialState, children: /* @__PURE__ */ jsxRuntime.jsx(
143
+ VefCrudPageBase,
144
+ {
145
+ filterItems,
146
+ formApis,
147
+ formGroups,
148
+ tableSchema,
149
+ ...restProps
150
+ }
151
+ ) });
152
+ }
153
+
154
+ exports.default = VefCrudPage;
3
155
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */
@@ -1,3 +1,5 @@
1
- /*! VefFramework version: 1.0.62, build time: 2025-01-09T07:31:10.823Z, made by Venus. */
2
- "use strict";
1
+ /*! VefFramework version: 1.0.64, build time: 2025-01-10T01:26:01.691Z, made by Venus. */
2
+ 'use strict';
3
+
4
+
3
5
  /*! VefFramework is a blazingly high-level, modern, flexible, easy-to-use UI framework made by Venus. Follow me on Github: https://github.com/ilxqx! @ilxqx */