@_tc/template-core 0.0.1-bate.1 → 0.0.1-bate.10

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 (443) hide show
  1. package/{app → cjs/app}/controller/base.d.ts +1 -2
  2. package/{app → cjs/app}/controller/base.js +0 -3
  3. package/{app → cjs/app}/controller/project.d.ts +1 -2
  4. package/cjs/app/controller/project.js +50 -0
  5. package/{app → cjs/app}/controller/view.d.ts +1 -2
  6. package/{app → cjs/app}/controller/view.js +0 -1
  7. package/cjs/app/data/signKey.d.ts +1 -0
  8. package/{app → cjs/app}/data/signKey.js +0 -1
  9. package/cjs/app/extend/db.d.ts +2 -0
  10. package/cjs/app/extend/db.js +12 -0
  11. package/cjs/app/extend/generateErrorMessage.d.ts +7 -0
  12. package/{app → cjs/app}/extend/generateErrorMessage.js +3 -1
  13. package/cjs/app/extend/logger.d.ts +11 -0
  14. package/{app → cjs/app}/extend/logger.js +0 -1
  15. package/cjs/app/extend/parsingParamsOnUrl.d.ts +2 -0
  16. package/{app → cjs/app}/extend/parsingParamsOnUrl.js +0 -1
  17. package/{app → cjs/app}/extend/render-view.d.ts +1 -2
  18. package/{app → cjs/app}/extend/render-view.js +0 -1
  19. package/{app → cjs/app}/middleware/api-params-verify.d.ts +1 -2
  20. package/{app → cjs/app}/middleware/api-params-verify.js +0 -1
  21. package/{app → cjs/app}/middleware/api-sign-verify.d.ts +1 -2
  22. package/{app → cjs/app}/middleware/api-sign-verify.js +0 -1
  23. package/{app → cjs/app}/middleware/error-handle.d.ts +1 -2
  24. package/{app → cjs/app}/middleware/error-handle.js +0 -1
  25. package/{app → cjs/app}/middleware/project-handler.d.ts +1 -2
  26. package/{app → cjs/app}/middleware/project-handler.js +0 -1
  27. package/cjs/app/middleware.d.ts +5 -0
  28. package/{app → cjs/app}/middleware.js +23 -2
  29. package/cjs/app/router/project.d.ts +4 -0
  30. package/{app → cjs/app}/router/project.js +0 -1
  31. package/cjs/app/router/view.d.ts +4 -0
  32. package/{app → cjs/app}/router/view.js +0 -1
  33. package/cjs/app/router-schema/project.d.ts +3 -0
  34. package/{app → cjs/app}/router-schema/project.js +0 -1
  35. package/cjs/app/service/bese.d.ts +10 -0
  36. package/{app → cjs/app}/service/bese.js +0 -1
  37. package/cjs/app/service/project.d.ts +27 -0
  38. package/cjs/app/service/project.js +42 -0
  39. package/cjs/app/type.d.ts +2 -0
  40. package/{app → cjs/app}/type.js +0 -1
  41. package/cjs/app/typings.d.ts +49 -0
  42. package/{app → cjs/app}/typings.js +0 -1
  43. package/cjs/app/view/entry.tpl +30 -0
  44. package/cjs/bundler/dev.d.ts +1 -0
  45. package/cjs/bundler/dev.js +68 -0
  46. package/cjs/bundler/index.d.ts +1 -0
  47. package/cjs/bundler/index.js +18 -0
  48. package/cjs/bundler/prod.d.ts +1 -0
  49. package/cjs/bundler/prod.js +19 -0
  50. package/cjs/bundler/utils.d.ts +7 -0
  51. package/cjs/bundler/utils.js +127 -0
  52. package/cjs/index.d.ts +28 -0
  53. package/{index.js → cjs/index.js} +0 -1
  54. package/cjs/packages/core/env.d.ts +15 -0
  55. package/{packages → cjs/packages}/core/env.js +0 -1
  56. package/cjs/packages/core/index.d.ts +6 -0
  57. package/{packages → cjs/packages}/core/index.js +24 -1
  58. package/cjs/packages/core/loader/config.d.ts +9 -0
  59. package/{packages → cjs/packages}/core/loader/config.js +14 -1
  60. package/cjs/packages/core/loader/controller.d.ts +17 -0
  61. package/{packages → cjs/packages}/core/loader/controller.js +23 -1
  62. package/cjs/packages/core/loader/extend.d.ts +8 -0
  63. package/{packages → cjs/packages}/core/loader/extend.js +8 -1
  64. package/cjs/packages/core/loader/middleware.d.ts +11 -0
  65. package/cjs/packages/core/loader/middleware.js +38 -0
  66. package/cjs/packages/core/loader/model.d.ts +36 -0
  67. package/{packages → cjs/packages}/core/loader/model.js +43 -1
  68. package/cjs/packages/core/loader/router-schema.d.ts +18 -0
  69. package/{packages → cjs/packages}/core/loader/router-schema.js +16 -1
  70. package/{packages → cjs/packages}/core/loader/router.d.ts +5 -1
  71. package/{packages → cjs/packages}/core/loader/router.js +20 -4
  72. package/cjs/packages/core/loader/service.d.ts +17 -0
  73. package/{packages → cjs/packages}/core/loader/service.js +14 -1
  74. package/cjs/packages/core/paths.d.ts +11 -0
  75. package/{packages → cjs/packages}/core/paths.js +0 -1
  76. package/{packages → cjs/packages}/core/types.d.ts +1 -1
  77. package/{packages → cjs/packages}/core/types.js +0 -1
  78. package/{packages → cjs/packages}/utils/getAllFilesInFolder.d.ts +5 -1
  79. package/{packages → cjs/packages}/utils/getAllFilesInFolder.js +0 -1
  80. package/cjs/packages/utils/getAllFnReturnValue.d.ts +0 -0
  81. package/cjs/packages/utils/getAllFnReturnValue.js +6 -0
  82. package/cjs/packages/utils/index.d.ts +4 -0
  83. package/{packages → cjs/packages}/utils/index.js +0 -1
  84. package/{packages → cjs/packages}/utils/loadFile.d.ts +6 -1
  85. package/{packages → cjs/packages}/utils/loadFile.js +9 -1
  86. package/cjs/packages/utils/path.d.ts +24 -0
  87. package/{packages → cjs/packages}/utils/path.js +14 -1
  88. package/cjs/packages/utils/runFileFn.d.ts +5 -0
  89. package/{packages → cjs/packages}/utils/runFileFn.js +0 -1
  90. package/cjs/typings/type.d.ts +4 -0
  91. package/{typings → cjs/typings}/type.js +0 -1
  92. package/esm/app/controller/base.d.ts +14 -0
  93. package/esm/app/controller/base.js +21 -0
  94. package/esm/app/controller/project.d.ts +12 -0
  95. package/{app → esm/app}/controller/project.js +3 -9
  96. package/esm/app/controller/view.d.ts +9 -0
  97. package/esm/app/controller/view.js +12 -0
  98. package/esm/app/data/signKey.js +1 -0
  99. package/esm/app/extend/db.js +9 -0
  100. package/esm/app/extend/generateErrorMessage.js +12 -0
  101. package/esm/app/extend/logger.js +37 -0
  102. package/esm/app/extend/parsingParamsOnUrl.js +20 -0
  103. package/esm/app/extend/render-view.d.ts +5 -0
  104. package/esm/app/extend/render-view.js +16 -0
  105. package/esm/app/middleware/api-params-verify.d.ts +6 -0
  106. package/esm/app/middleware/api-params-verify.js +58 -0
  107. package/esm/app/middleware/api-sign-verify.d.ts +6 -0
  108. package/esm/app/middleware/api-sign-verify.js +23 -0
  109. package/esm/app/middleware/error-handle.d.ts +6 -0
  110. package/esm/app/middleware/error-handle.js +31 -0
  111. package/esm/app/middleware/project-handler.d.ts +5 -0
  112. package/esm/app/middleware/project-handler.js +19 -0
  113. package/esm/app/middleware.js +55 -0
  114. package/esm/app/router/project.js +6 -0
  115. package/esm/app/router/view.js +3 -0
  116. package/esm/app/router-schema/project.js +31 -0
  117. package/esm/app/service/bese.js +12 -0
  118. package/{app → esm/app}/service/project.js +6 -11
  119. package/esm/app/type.js +1 -0
  120. package/esm/app/typings.js +1 -0
  121. package/esm/app/view/entry.tpl +30 -0
  122. package/esm/bundler/dev.d.ts +2 -0
  123. package/esm/bundler/dev.js +29 -0
  124. package/esm/bundler/index.d.ts +2 -0
  125. package/esm/bundler/index.js +14 -0
  126. package/esm/bundler/prod.d.ts +2 -0
  127. package/esm/bundler/prod.js +16 -0
  128. package/esm/bundler/utils.d.ts +8 -0
  129. package/esm/bundler/utils.js +85 -0
  130. package/esm/index.js +13 -0
  131. package/esm/packages/core/env.js +23 -0
  132. package/esm/packages/core/index.js +109 -0
  133. package/esm/packages/core/loader/config.d.ts +10 -0
  134. package/esm/packages/core/loader/config.js +43 -0
  135. package/esm/packages/core/loader/controller.d.ts +18 -0
  136. package/esm/packages/core/loader/controller.js +38 -0
  137. package/esm/packages/core/loader/extend.d.ts +9 -0
  138. package/esm/packages/core/loader/extend.js +39 -0
  139. package/esm/packages/core/loader/middleware.d.ts +12 -0
  140. package/esm/packages/core/loader/middleware.js +36 -0
  141. package/esm/packages/core/loader/model.d.ts +37 -0
  142. package/esm/packages/core/loader/model.js +127 -0
  143. package/esm/packages/core/loader/router-schema.d.ts +19 -0
  144. package/esm/packages/core/loader/router-schema.js +33 -0
  145. package/esm/packages/core/loader/router.d.ts +9 -0
  146. package/esm/packages/core/loader/router.js +57 -0
  147. package/esm/packages/core/loader/service.d.ts +18 -0
  148. package/esm/packages/core/loader/service.js +28 -0
  149. package/esm/packages/core/paths.js +6 -0
  150. package/esm/packages/core/types.d.ts +75 -0
  151. package/esm/packages/core/types.js +1 -0
  152. package/esm/packages/utils/getAllFilesInFolder.d.ts +10 -0
  153. package/esm/packages/utils/getAllFilesInFolder.js +8 -0
  154. package/esm/packages/utils/getAllFnReturnValue.js +6 -0
  155. package/esm/packages/utils/index.js +4 -0
  156. package/esm/packages/utils/loadFile.d.ts +21 -0
  157. package/esm/packages/utils/loadFile.js +63 -0
  158. package/esm/packages/utils/path.d.ts +25 -0
  159. package/esm/packages/utils/path.js +27 -0
  160. package/esm/packages/utils/runFileFn.js +1 -0
  161. package/esm/typings/type.d.ts +5 -0
  162. package/esm/typings/type.js +1 -0
  163. package/fe/frontend/main.d.ts +3 -0
  164. package/fe/frontend/main.js +6 -0
  165. package/fe/frontend/testPage/index.d.ts +3 -0
  166. package/fe/frontend/testPage/index.js +6 -0
  167. package/fe/frontend/testPage/testPage.entry.d.ts +2 -0
  168. package/fe/frontend/testPage/testPage.entry.js +4 -0
  169. package/fe/packages/ui/react/assets/table/no-result.svg +5 -0
  170. package/fe/packages/ui/react/components/Button/Button.d.ts +39 -0
  171. package/fe/packages/ui/react/components/Button/Button.js +42 -0
  172. package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +13 -0
  173. package/fe/packages/ui/react/components/Button/SumbitButton.js +32 -0
  174. package/fe/packages/ui/react/components/Button/index.d.ts +4 -0
  175. package/fe/packages/ui/react/components/Button/index.js +2 -0
  176. package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +17 -0
  177. package/fe/packages/ui/react/components/Checkbox/Checkbox.js +37 -0
  178. package/fe/packages/ui/react/components/Checkbox/index.d.ts +2 -0
  179. package/fe/packages/ui/react/components/Checkbox/index.js +1 -0
  180. package/fe/packages/ui/react/components/ConfirmDialog.d.ts +20 -0
  181. package/fe/packages/ui/react/components/ConfirmDialog.js +9 -0
  182. package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +6 -0
  183. package/fe/packages/ui/react/components/DataTable/ActionBtn.js +13 -0
  184. package/fe/packages/ui/react/components/DataTable/data-table.d.ts +44 -0
  185. package/fe/packages/ui/react/components/DataTable/data-table.js +141 -0
  186. package/fe/packages/ui/react/components/Date/Calendar.d.ts +35 -0
  187. package/fe/packages/ui/react/components/Date/Calendar.js +215 -0
  188. package/fe/packages/ui/react/components/Date/Date.d.ts +36 -0
  189. package/fe/packages/ui/react/components/Date/Date.js +178 -0
  190. package/fe/packages/ui/react/components/Date/DateTestPage.d.ts +2 -0
  191. package/fe/packages/ui/react/components/Date/DateTestPage.js +29 -0
  192. package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +6 -0
  193. package/fe/packages/ui/react/components/Date/LocaleContext.js +8 -0
  194. package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +19 -0
  195. package/fe/packages/ui/react/components/Date/LocaleProvider.js +24 -0
  196. package/fe/packages/ui/react/components/Date/TimePicker.d.ts +7 -0
  197. package/fe/packages/ui/react/components/Date/TimePicker.js +76 -0
  198. package/fe/packages/ui/react/components/Date/data.d.ts +6 -0
  199. package/fe/packages/ui/react/components/Date/data.js +4 -0
  200. package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +16 -0
  201. package/fe/packages/ui/react/components/Date/dateLocaleStore.js +14 -0
  202. package/fe/packages/ui/react/components/Date/index.d.ts +6 -0
  203. package/fe/packages/ui/react/components/Date/index.js +5 -0
  204. package/fe/packages/ui/react/components/Date/locales.d.ts +42 -0
  205. package/fe/packages/ui/react/components/Date/locales.js +52 -0
  206. package/fe/packages/ui/react/components/Dropdown.d.ts +16 -0
  207. package/fe/packages/ui/react/components/Dropdown.js +54 -0
  208. package/fe/packages/ui/react/components/Form/Form.d.ts +18 -0
  209. package/fe/packages/ui/react/components/Form/Form.js +8 -0
  210. package/fe/packages/ui/react/components/Form/FormItem.d.ts +41 -0
  211. package/fe/packages/ui/react/components/Form/FormItem.js +43 -0
  212. package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +51 -0
  213. package/fe/packages/ui/react/components/Form/SchemeForm/data.js +8 -0
  214. package/fe/packages/ui/react/components/Form/SchemeForm/index.d.ts +152 -0
  215. package/fe/packages/ui/react/components/Form/SchemeForm/index.js +69 -0
  216. package/fe/packages/ui/react/components/Form/index.d.ts +5 -0
  217. package/fe/packages/ui/react/components/Form/index.js +4 -0
  218. package/fe/packages/ui/react/components/Form/useForm.d.ts +3 -0
  219. package/fe/packages/ui/react/components/Form/useForm.js +1 -0
  220. package/fe/packages/ui/react/components/ImagePreview/ImagePreview.d.ts +8 -0
  221. package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +166 -0
  222. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +11 -0
  223. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +25 -0
  224. package/fe/packages/ui/react/components/ImagePreview/index.d.ts +3 -0
  225. package/fe/packages/ui/react/components/ImagePreview/index.js +2 -0
  226. package/fe/packages/ui/react/components/Input/Input.d.ts +41 -0
  227. package/fe/packages/ui/react/components/Input/Input.js +60 -0
  228. package/fe/packages/ui/react/components/Input/index.d.ts +2 -0
  229. package/fe/packages/ui/react/components/Input/index.js +1 -0
  230. package/fe/packages/ui/react/components/Label/Label.d.ts +51 -0
  231. package/fe/packages/ui/react/components/Label/Label.js +35 -0
  232. package/fe/packages/ui/react/components/Label/index.d.ts +3 -0
  233. package/fe/packages/ui/react/components/Label/index.js +2 -0
  234. package/fe/packages/ui/react/components/Message/Message.d.ts +20 -0
  235. package/fe/packages/ui/react/components/Message/Message.js +55 -0
  236. package/fe/packages/ui/react/components/Message/MessageManager.d.ts +37 -0
  237. package/fe/packages/ui/react/components/Message/MessageManager.js +90 -0
  238. package/fe/packages/ui/react/components/Message/data.d.ts +2 -0
  239. package/fe/packages/ui/react/components/Message/data.js +1 -0
  240. package/fe/packages/ui/react/components/Message/index.d.ts +3 -0
  241. package/fe/packages/ui/react/components/Message/index.js +1 -0
  242. package/fe/packages/ui/react/components/Modal/Modal.d.ts +25 -0
  243. package/fe/packages/ui/react/components/Modal/Modal.js +51 -0
  244. package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +59 -0
  245. package/fe/packages/ui/react/components/Modal/ModalManager.js +89 -0
  246. package/fe/packages/ui/react/components/Modal/index.d.ts +4 -0
  247. package/fe/packages/ui/react/components/Modal/index.js +2 -0
  248. package/fe/packages/ui/react/components/Pagination.d.ts +18 -0
  249. package/fe/packages/ui/react/components/Pagination.js +88 -0
  250. package/fe/packages/ui/react/components/Search/Search.d.ts +17 -0
  251. package/fe/packages/ui/react/components/Search/Search.js +12 -0
  252. package/fe/packages/ui/react/components/Search/index.d.ts +2 -0
  253. package/fe/packages/ui/react/components/Search/index.js +1 -0
  254. package/fe/packages/ui/react/components/Select/Select.d.ts +21 -0
  255. package/fe/packages/ui/react/components/Select/Select.js +180 -0
  256. package/fe/packages/ui/react/components/Select/index.d.ts +2 -0
  257. package/fe/packages/ui/react/components/Select/index.js +1 -0
  258. package/fe/packages/ui/react/components/Skeleton/Skeleton.d.ts +28 -0
  259. package/fe/packages/ui/react/components/Skeleton/Skeleton.js +31 -0
  260. package/fe/packages/ui/react/components/Skeleton/index.d.ts +3 -0
  261. package/fe/packages/ui/react/components/Skeleton/index.js +1 -0
  262. package/fe/packages/ui/react/components/Switch/Switch.d.ts +11 -0
  263. package/fe/packages/ui/react/components/Switch/Switch.js +20 -0
  264. package/fe/packages/ui/react/components/Switch/index.d.ts +2 -0
  265. package/fe/packages/ui/react/components/Switch/index.js +1 -0
  266. package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +67 -0
  267. package/fe/packages/ui/react/components/TableSearch/TableSearch.js +119 -0
  268. package/fe/packages/ui/react/components/TableSearch/index.d.ts +2 -0
  269. package/fe/packages/ui/react/components/TableSearch/index.js +1 -0
  270. package/fe/packages/ui/react/components/TableSearch/lang.d.ts +15 -0
  271. package/fe/packages/ui/react/components/TableSearch/lang.js +23 -0
  272. package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.d.ts +9 -0
  273. package/fe/packages/ui/react/components/TableSearch/tableSearchLocaleStore.js +11 -0
  274. package/fe/packages/ui/react/components/Textarea.d.ts +59 -0
  275. package/fe/packages/ui/react/components/Textarea.js +35 -0
  276. package/fe/packages/ui/react/components/Tooltip.d.ts +25 -0
  277. package/fe/packages/ui/react/components/Tooltip.js +118 -0
  278. package/fe/packages/ui/react/components/TreeSelect.d.ts +25 -0
  279. package/fe/packages/ui/react/components/TreeSelect.js +162 -0
  280. package/fe/packages/ui/react/components/Upload/ImageUpload.d.ts +9 -0
  281. package/fe/packages/ui/react/components/Upload/ImageUpload.js +63 -0
  282. package/fe/packages/ui/react/components/Upload/Upload.d.ts +41 -0
  283. package/fe/packages/ui/react/components/Upload/Upload.js +5 -0
  284. package/fe/packages/ui/react/components/Upload/index.d.ts +3 -0
  285. package/fe/packages/ui/react/components/Upload/index.js +2 -0
  286. package/fe/packages/ui/react/components/breadcrumb.d.ts +35 -0
  287. package/fe/packages/ui/react/components/breadcrumb.js +78 -0
  288. package/fe/packages/ui/react/components/hooks/useInputController.d.ts +24 -0
  289. package/fe/packages/ui/react/components/hooks/useInputController.js +45 -0
  290. package/fe/packages/ui/react/components/index.d.ts +24 -0
  291. package/fe/packages/ui/react/components/index.js +23 -0
  292. package/fe/packages/ui/react/components/table.d.ts +17 -0
  293. package/fe/packages/ui/react/components/table.js +20 -0
  294. package/fe/packages/ui/react/components/testPage/index.d.ts +3 -0
  295. package/fe/packages/ui/react/components/testPage/index.js +118 -0
  296. package/fe/packages/ui/react/hooks/useBreadcrumb.d.ts +10 -0
  297. package/fe/packages/ui/react/hooks/useBreadcrumb.js +2 -0
  298. package/fe/packages/ui/react/hooks/useInit.d.ts +3 -0
  299. package/fe/packages/ui/react/hooks/useInit.js +9 -0
  300. package/fe/packages/ui/react/hooks/useLanguage.d.ts +7 -0
  301. package/fe/packages/ui/react/hooks/useLanguage.js +4 -0
  302. package/fe/packages/ui/react/hooks/usePagination.d.ts +16 -0
  303. package/fe/packages/ui/react/hooks/usePagination.js +27 -0
  304. package/fe/packages/ui/react/index.d.ts +3 -0
  305. package/fe/packages/ui/react/index.js +4 -0
  306. package/fe/packages/ui/react/lib/export.d.ts +66 -0
  307. package/fe/packages/ui/react/lib/export.js +138 -0
  308. package/fe/packages/ui/react/lib/utils.d.ts +34 -0
  309. package/fe/packages/ui/react/lib/utils.js +70 -0
  310. package/fe/packages/ui/react/locales/index.d.ts +8 -0
  311. package/fe/packages/ui/react/locales/index.js +6 -0
  312. package/fe/packages/ui/react/stores/breadcrumb.d.ts +15 -0
  313. package/fe/packages/ui/react/stores/breadcrumb.js +66 -0
  314. package/fe/packages/ui/react/stores/language.d.ts +13 -0
  315. package/fe/packages/ui/react/stores/language.js +51 -0
  316. package/{typings/type.d.ts → fe/packages/ui/react/types/index.d.ts} +1 -1
  317. package/fe/packages/ui/react/types/index.js +1 -0
  318. package/package.json +38 -4
  319. package/app/controller/base.d.ts.map +0 -1
  320. package/app/controller/base.js.map +0 -1
  321. package/app/controller/project.d.ts.map +0 -1
  322. package/app/controller/project.js.map +0 -1
  323. package/app/controller/view.d.ts.map +0 -1
  324. package/app/controller/view.js.map +0 -1
  325. package/app/data/signKey.d.ts.map +0 -1
  326. package/app/data/signKey.js.map +0 -1
  327. package/app/extend/db.d.ts.map +0 -1
  328. package/app/extend/db.js +0 -8
  329. package/app/extend/db.js.map +0 -1
  330. package/app/extend/generateErrorMessage.d.ts.map +0 -1
  331. package/app/extend/generateErrorMessage.js.map +0 -1
  332. package/app/extend/logger.d.ts.map +0 -1
  333. package/app/extend/logger.js.map +0 -1
  334. package/app/extend/parsingParamsOnUrl.d.ts.map +0 -1
  335. package/app/extend/parsingParamsOnUrl.js.map +0 -1
  336. package/app/extend/render-view.d.ts.map +0 -1
  337. package/app/extend/render-view.js.map +0 -1
  338. package/app/middleware/api-params-verify.d.ts.map +0 -1
  339. package/app/middleware/api-params-verify.js.map +0 -1
  340. package/app/middleware/api-sign-verify.d.ts.map +0 -1
  341. package/app/middleware/api-sign-verify.js.map +0 -1
  342. package/app/middleware/error-handle.d.ts.map +0 -1
  343. package/app/middleware/error-handle.js.map +0 -1
  344. package/app/middleware/project-handler.d.ts.map +0 -1
  345. package/app/middleware/project-handler.js.map +0 -1
  346. package/app/middleware.d.ts.map +0 -1
  347. package/app/middleware.js.map +0 -1
  348. package/app/router/project.d.ts.map +0 -1
  349. package/app/router/project.js.map +0 -1
  350. package/app/router/view.d.ts.map +0 -1
  351. package/app/router/view.js.map +0 -1
  352. package/app/router-schema/project.d.ts.map +0 -1
  353. package/app/router-schema/project.js.map +0 -1
  354. package/app/service/bese.d.ts.map +0 -1
  355. package/app/service/bese.js.map +0 -1
  356. package/app/service/project.d.ts.map +0 -1
  357. package/app/service/project.js.map +0 -1
  358. package/app/type.d.ts.map +0 -1
  359. package/app/type.js.map +0 -1
  360. package/app/typings.d.ts.map +0 -1
  361. package/app/typings.js.map +0 -1
  362. package/index.d.ts.map +0 -1
  363. package/index.js.map +0 -1
  364. package/model/index.d.ts +0 -2
  365. package/model/index.d.ts.map +0 -1
  366. package/model/index.js +0 -7
  367. package/model/index.js.map +0 -1
  368. package/model/test.d.ts +0 -6
  369. package/model/test.d.ts.map +0 -1
  370. package/model/test.js +0 -6
  371. package/model/test.js.map +0 -1
  372. package/model/test2.d.ts +0 -6
  373. package/model/test2.d.ts.map +0 -1
  374. package/model/test2.js +0 -6
  375. package/model/test2.js.map +0 -1
  376. package/packages/core/env.d.ts.map +0 -1
  377. package/packages/core/env.js.map +0 -1
  378. package/packages/core/index.d.ts.map +0 -1
  379. package/packages/core/index.js.map +0 -1
  380. package/packages/core/loader/config.d.ts +0 -4
  381. package/packages/core/loader/config.d.ts.map +0 -1
  382. package/packages/core/loader/config.js.map +0 -1
  383. package/packages/core/loader/controller.d.ts +0 -4
  384. package/packages/core/loader/controller.d.ts.map +0 -1
  385. package/packages/core/loader/controller.js.map +0 -1
  386. package/packages/core/loader/extend.d.ts +0 -4
  387. package/packages/core/loader/extend.d.ts.map +0 -1
  388. package/packages/core/loader/extend.js.map +0 -1
  389. package/packages/core/loader/middleware.d.ts +0 -4
  390. package/packages/core/loader/middleware.d.ts.map +0 -1
  391. package/packages/core/loader/middleware.js +0 -16
  392. package/packages/core/loader/middleware.js.map +0 -1
  393. package/packages/core/loader/model.d.ts +0 -15
  394. package/packages/core/loader/model.d.ts.map +0 -1
  395. package/packages/core/loader/model.js.map +0 -1
  396. package/packages/core/loader/router-schema.d.ts +0 -4
  397. package/packages/core/loader/router-schema.d.ts.map +0 -1
  398. package/packages/core/loader/router-schema.js.map +0 -1
  399. package/packages/core/loader/router.d.ts.map +0 -1
  400. package/packages/core/loader/router.js.map +0 -1
  401. package/packages/core/loader/service.d.ts +0 -4
  402. package/packages/core/loader/service.d.ts.map +0 -1
  403. package/packages/core/loader/service.js.map +0 -1
  404. package/packages/core/paths.d.ts.map +0 -1
  405. package/packages/core/paths.js.map +0 -1
  406. package/packages/core/types.d.ts.map +0 -1
  407. package/packages/core/types.js.map +0 -1
  408. package/packages/utils/getAllFilesInFolder.d.ts.map +0 -1
  409. package/packages/utils/getAllFilesInFolder.js.map +0 -1
  410. package/packages/utils/getAllFnReturnValue.d.ts.map +0 -1
  411. package/packages/utils/getAllFnReturnValue.js +0 -2
  412. package/packages/utils/getAllFnReturnValue.js.map +0 -1
  413. package/packages/utils/index.d.ts.map +0 -1
  414. package/packages/utils/index.js.map +0 -1
  415. package/packages/utils/loadFile.d.ts.map +0 -1
  416. package/packages/utils/loadFile.js.map +0 -1
  417. package/packages/utils/path.d.ts +0 -7
  418. package/packages/utils/path.d.ts.map +0 -1
  419. package/packages/utils/path.js.map +0 -1
  420. package/packages/utils/runFileFn.d.ts.map +0 -1
  421. package/packages/utils/runFileFn.js.map +0 -1
  422. package/typings/type.d.ts.map +0 -1
  423. package/typings/type.js.map +0 -1
  424. /package/{app → esm/app}/data/signKey.d.ts +0 -0
  425. /package/{app → esm/app}/extend/db.d.ts +0 -0
  426. /package/{app → esm/app}/extend/generateErrorMessage.d.ts +0 -0
  427. /package/{app → esm/app}/extend/logger.d.ts +0 -0
  428. /package/{app → esm/app}/extend/parsingParamsOnUrl.d.ts +0 -0
  429. /package/{app → esm/app}/middleware.d.ts +0 -0
  430. /package/{app → esm/app}/router/project.d.ts +0 -0
  431. /package/{app → esm/app}/router/view.d.ts +0 -0
  432. /package/{app → esm/app}/router-schema/project.d.ts +0 -0
  433. /package/{app → esm/app}/service/bese.d.ts +0 -0
  434. /package/{app → esm/app}/service/project.d.ts +0 -0
  435. /package/{app → esm/app}/type.d.ts +0 -0
  436. /package/{app → esm/app}/typings.d.ts +0 -0
  437. /package/{index.d.ts → esm/index.d.ts} +0 -0
  438. /package/{packages → esm/packages}/core/env.d.ts +0 -0
  439. /package/{packages → esm/packages}/core/index.d.ts +0 -0
  440. /package/{packages → esm/packages}/core/paths.d.ts +0 -0
  441. /package/{packages → esm/packages}/utils/getAllFnReturnValue.d.ts +0 -0
  442. /package/{packages → esm/packages}/utils/index.d.ts +0 -0
  443. /package/{packages → esm/packages}/utils/runFileFn.d.ts +0 -0
@@ -0,0 +1,25 @@
1
+ import type { ReactNode } from 'react';
2
+ export type ModalProps = {
3
+ open?: boolean;
4
+ onClose?: () => void;
5
+ title?: ReactNode;
6
+ children?: ReactNode;
7
+ footer?: ReactNode;
8
+ className?: string;
9
+ contentClassName?: string;
10
+ maskClosable?: boolean;
11
+ closable?: boolean;
12
+ width?: number | string;
13
+ centered?: boolean;
14
+ zIndex?: number;
15
+ /**
16
+ * @default document.body
17
+ */
18
+ renderNode?: HTMLElement | (() => HTMLElement);
19
+ /**
20
+ * 是否支持键盘关闭 默认开启
21
+ */
22
+ keyboard?: boolean;
23
+ };
24
+ export declare function Modal({ open, onClose, title, children, footer, className, contentClassName, maskClosable, closable, width, centered, renderNode, keyboard, zIndex, }: ModalProps): import("react").ReactPortal | null;
25
+ //# sourceMappingURL=Modal.d.ts.map
@@ -0,0 +1,51 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { X } from 'lucide-react';
4
+ import { useEffect, useRef } from 'react';
5
+ import { createPortal } from 'react-dom';
6
+ export function Modal({ open = false, onClose, title, children, footer, className, contentClassName, maskClosable = true, closable = true, width = 520, centered = true, renderNode = document.body, keyboard = true, zIndex = 1000, }) {
7
+ const modalRef = useRef(null);
8
+ const contentRef = useRef(null);
9
+ // 处理 ESC 键关闭
10
+ useEffect(() => {
11
+ if (!open || !keyboard)
12
+ return;
13
+ const handleEscape = (e) => {
14
+ if (e.key === 'Escape' && closable) {
15
+ onClose?.();
16
+ }
17
+ };
18
+ document.addEventListener('keydown', handleEscape);
19
+ return () => {
20
+ document.removeEventListener('keydown', handleEscape);
21
+ };
22
+ }, [open, closable, onClose, keyboard]);
23
+ // 阻止 body 滚动
24
+ useEffect(() => {
25
+ if (open) {
26
+ const originalOverflow = document.body.style.overflow;
27
+ document.body.style.overflow = 'hidden';
28
+ return () => {
29
+ document.body.style.overflow = originalOverflow;
30
+ };
31
+ }
32
+ else {
33
+ return () => { };
34
+ }
35
+ }, [open]);
36
+ // 点击遮罩层关闭
37
+ const handleMaskClick = (e) => {
38
+ if (maskClosable && e.target === e.currentTarget) {
39
+ onClose?.();
40
+ }
41
+ };
42
+ // 点击内容区域阻止冒泡
43
+ const handleContentClick = (e) => {
44
+ e.stopPropagation();
45
+ };
46
+ if (!open)
47
+ return null;
48
+ const modalContent = (_jsx("div", { ref: modalRef, className: cn('fixed inset-0 z-[1000] flex items-center justify-center', 'bg-black/50 backdrop-blur-sm', 'transition-opacity duration-200', open ? 'opacity-100' : 'opacity-0'), style: { zIndex }, onClick: handleMaskClick, children: _jsxs("div", { ref: contentRef, className: cn('relative bg-background rounded-lg shadow-lg', 'flex flex-col max-h-[90vh]', 'transition-all duration-200', open ? 'scale-100 opacity-100' : 'scale-95 opacity-0', centered ? 'my-auto' : 'mt-[10vh]', className), style: { width: typeof width === 'number' ? `${width}px` : width }, onClick: handleContentClick, children: [(title || closable) && (_jsxs("div", { className: "flex items-center justify-between px-6 py-4 border-border", children: [title && _jsx("div", { className: "text-lg font-semibold text-foreground", children: title }), closable && (_jsx("button", { type: "button", onClick: onClose, "aria-label": "\u5173\u95ED", className: cn('ml-auto p-1 rounded-md', 'text-muted-foreground hover:text-foreground', 'hover:bg-muted', 'transition-colors', 'focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2'), children: _jsx(X, { size: 20 }) }))] })), _jsx("div", { className: cn('flex-1 overflow-auto px-6 py-4', contentClassName), children: children }), footer && _jsx("div", { className: "px-6 py-4 border-border", children: footer })] }) }));
49
+ const parent = typeof renderNode === 'function' ? renderNode() : renderNode;
50
+ return createPortal(modalContent, parent);
51
+ }
@@ -0,0 +1,59 @@
1
+ import type { ReactNode } from 'react';
2
+ import { type SumbitButtonProps } from '../Button';
3
+ import { type ModalProps } from './Modal';
4
+ type ModalConfig = Omit<ModalProps, 'open' | 'onClose' | 'children'> & {
5
+ id: string;
6
+ onClose?: () => void;
7
+ content?: ReactNode;
8
+ };
9
+ declare class ModalManagerClass {
10
+ private modals;
11
+ private listeners;
12
+ private container;
13
+ private root;
14
+ private init;
15
+ private notify;
16
+ subscribe(listener: () => void): () => void;
17
+ open(config: Omit<ModalConfig, 'id'>): string;
18
+ close(id: string): void;
19
+ closeAll(): void;
20
+ getModals(): ModalConfig[];
21
+ private render;
22
+ }
23
+ type OpenModalConfig = Omit<ModalConfig, 'id'>;
24
+ export declare const openConfirmModal: (pConfig: Pick<OpenModalConfig, "content"> & {
25
+ /** 标题 */
26
+ title?: ReactNode;
27
+ /** 内容 */
28
+ content: ReactNode;
29
+ /** 确认按钮文本 */
30
+ okText?: string;
31
+ /** 取消按钮文本 */
32
+ cancelText?: string;
33
+ /** 确认回调 */
34
+ onOk?: SumbitButtonProps["onClick"];
35
+ /** 取消回调 */
36
+ onCancel?: () => void;
37
+ }) => string;
38
+ export declare const modalManager: ModalManagerClass;
39
+ export declare const modal: {
40
+ open: (config: OpenModalConfig) => string;
41
+ confirm: (pConfig: Pick<OpenModalConfig, "content"> & {
42
+ /** 标题 */
43
+ title?: ReactNode;
44
+ /** 内容 */
45
+ content: ReactNode;
46
+ /** 确认按钮文本 */
47
+ okText?: string;
48
+ /** 取消按钮文本 */
49
+ cancelText?: string;
50
+ /** 确认回调 */
51
+ onOk?: SumbitButtonProps["onClick"];
52
+ /** 取消回调 */
53
+ onCancel?: () => void;
54
+ }) => string;
55
+ close: (id: string) => void;
56
+ closeAll: () => void;
57
+ };
58
+ export {};
59
+ //# sourceMappingURL=ModalManager.d.ts.map
@@ -0,0 +1,89 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { createRoot } from 'react-dom/client';
3
+ import { AsynchronousButton, Button } from '../Button';
4
+ import { Modal } from './Modal';
5
+ class ModalManagerClass {
6
+ modals = new Map();
7
+ listeners = new Set();
8
+ container = null;
9
+ root = null;
10
+ init() {
11
+ if (typeof document === 'undefined' || this.container)
12
+ return;
13
+ this.container = document.createElement('div');
14
+ this.container.id = 'modal-container';
15
+ document.body.appendChild(this.container);
16
+ // 创建 React 根节点
17
+ this.root = createRoot(this.container);
18
+ this.render();
19
+ }
20
+ notify() {
21
+ this.listeners.forEach((listener) => listener());
22
+ this.render();
23
+ }
24
+ subscribe(listener) {
25
+ this.listeners.add(listener);
26
+ return () => {
27
+ this.listeners.delete(listener);
28
+ };
29
+ }
30
+ open(config) {
31
+ this.init(); // 确保已初始化
32
+ const id = `modal-${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
33
+ const modalConfig = {
34
+ ...config,
35
+ id,
36
+ onClose: () => {
37
+ config.onClose?.();
38
+ this.close(id);
39
+ },
40
+ };
41
+ this.modals.set(id, modalConfig);
42
+ this.notify();
43
+ return id;
44
+ }
45
+ close(id) {
46
+ this.modals.delete(id);
47
+ this.notify();
48
+ }
49
+ closeAll() {
50
+ this.modals.clear();
51
+ this.notify();
52
+ }
53
+ getModals() {
54
+ return Array.from(this.modals.values());
55
+ }
56
+ render() {
57
+ if (!this.root)
58
+ return;
59
+ const modals = this.getModals();
60
+ this.root.render(_jsx(_Fragment, { children: modals.map((modal) => (_jsx(Modal, { ...modal, open: true, children: modal.content }, modal.id))) }));
61
+ }
62
+ }
63
+ export const openConfirmModal = (pConfig) => {
64
+ const { onOk, onCancel, okText = '确认', cancelText = '取消', ...props } = pConfig;
65
+ const config = {
66
+ title: '提示',
67
+ footer: (_jsxs("div", { className: "flex justify-end gap-3", children: [_jsx(Button, { onClick: () => {
68
+ onCancel?.();
69
+ modalManager.close(currentModalId);
70
+ }, className: "min-w-[100px] bg-white border-[hsl(var(--theme-primary))] text-[hsl(var(--theme-primary))] hover:bg-[hsl(var(--theme-primary))]/5", children: cancelText }), _jsx(AsynchronousButton, { variant: "primary", onClick: async (e) => {
71
+ const result = await onOk?.(e);
72
+ if (typeof result === 'boolean' && !result)
73
+ return;
74
+ modalManager.close(currentModalId);
75
+ }, className: "min-w-[100px] bg-[hsl(var(--theme-primary))] hover:bg-[hsl(var(--theme-primary))]/90 border-[hsl(var(--theme-primary))] text-[hsl(var(--theme-primary-foreground))]", children: okText })] })),
76
+ ...props,
77
+ };
78
+ const currentModalId = modalManager.open(config);
79
+ return currentModalId;
80
+ };
81
+ // 单例模式
82
+ export const modalManager = new ModalManagerClass();
83
+ // 函数式 API
84
+ export const modal = {
85
+ open: (config) => modalManager.open(config),
86
+ confirm: openConfirmModal,
87
+ close: (id) => modalManager.close(id),
88
+ closeAll: () => modalManager.closeAll(),
89
+ };
@@ -0,0 +1,4 @@
1
+ export { Modal } from './Modal';
2
+ export type { ModalProps } from './Modal';
3
+ export { modal } from './ModalManager';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,2 @@
1
+ export { Modal } from './Modal';
2
+ export { modal } from './ModalManager';
@@ -0,0 +1,18 @@
1
+ export interface PaginationProps {
2
+ /** 当前页码 */
3
+ current: number;
4
+ /** 每页显示数量 */
5
+ pageSize: number;
6
+ /** 总数据量 */
7
+ total: number;
8
+ /** 页码改变回调 */
9
+ onChange: (page: number) => void;
10
+ /** 每页显示数量改变回调 */
11
+ onPageSizeChange?: (pageSize: number) => void;
12
+ /** 每页显示数量选项 */
13
+ pageSizeOptions?: number[];
14
+ /** 自定义类名 */
15
+ className?: string;
16
+ }
17
+ export declare function Pagination({ current, pageSize, total, onChange, onPageSizeChange, pageSizeOptions, className, }: PaginationProps): import("react/jsx-runtime").JSX.Element | null;
18
+ //# sourceMappingURL=Pagination.d.ts.map
@@ -0,0 +1,88 @@
1
+ import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from '../lib/utils';
3
+ import { ChevronLeft, ChevronRight } from 'lucide-react';
4
+ import { Button } from './Button';
5
+ import { Select } from './Select';
6
+ export function Pagination({ current, pageSize, total, onChange, onPageSizeChange, pageSizeOptions = [10, 20, 50, 100], className, }) {
7
+ const totalPages = Math.ceil(total / pageSize);
8
+ // 生成页码数组
9
+ const getPageNumbers = () => {
10
+ const pages = [];
11
+ const maxVisible = 7; // 最多显示7个页码
12
+ if (totalPages <= maxVisible) {
13
+ // 总页数少于等于7,显示所有页码
14
+ for (let i = 1; i <= totalPages; i++) {
15
+ pages.push(i);
16
+ }
17
+ }
18
+ else {
19
+ // 总页数大于7,需要省略
20
+ if (current <= 4) {
21
+ // 当前页在前面
22
+ for (let i = 1; i <= 5; i++) {
23
+ pages.push(i);
24
+ }
25
+ pages.push('...');
26
+ pages.push(totalPages);
27
+ }
28
+ else if (current >= totalPages - 3) {
29
+ // 当前页在后面
30
+ pages.push(1);
31
+ pages.push('...');
32
+ for (let i = totalPages - 4; i <= totalPages; i++) {
33
+ pages.push(i);
34
+ }
35
+ }
36
+ else {
37
+ // 当前页在中间
38
+ pages.push(1);
39
+ pages.push('...');
40
+ for (let i = current - 1; i <= current + 1; i++) {
41
+ pages.push(i);
42
+ }
43
+ pages.push('...');
44
+ pages.push(totalPages);
45
+ }
46
+ }
47
+ return pages;
48
+ };
49
+ const handlePrevious = () => {
50
+ if (current > 1) {
51
+ onChange(current - 1);
52
+ }
53
+ };
54
+ const handleNext = () => {
55
+ if (current < totalPages) {
56
+ onChange(current + 1);
57
+ }
58
+ };
59
+ const handlePageClick = (page) => {
60
+ if (typeof page === 'number' && page !== current) {
61
+ onChange(page);
62
+ }
63
+ };
64
+ const handlePageSizeChange = (newPageSize) => {
65
+ if (newPageSize !== undefined && typeof newPageSize === 'number' && newPageSize !== pageSize && onPageSizeChange) {
66
+ onPageSizeChange(newPageSize);
67
+ // 当改变 pageSize 时,通常需要重置到第一页
68
+ if (current !== 1) {
69
+ onChange(1);
70
+ }
71
+ }
72
+ };
73
+ if (totalPages === 0)
74
+ return null;
75
+ return (_jsxs("div", { className: cn('flex items-center gap-4', className), children: [_jsxs("div", { className: "text-sm text-muted-foreground", children: ["Total ", total] }), _jsxs("div", { className: "flex-1 flex items-center justify-center gap-2", children: [_jsx(Button, { onClick: handlePrevious, disabled: current === 1, size: "sm", className: cn('inline-flex items-center justify-center', 'h-8 px-3 rounded-md', 'text-sm font-medium', 'border border-border', 'transition-colors', current === 1 ? 'cursor-not-allowed opacity-50 bg-muted' : 'hover:bg-muted bg-background cursor-pointer'), children: _jsx(ChevronLeft, { className: "h-4 w-4" }) }), getPageNumbers().map((page, index) => {
76
+ if (page === '...') {
77
+ return (_jsx("span", { className: "px-2 text-muted-foreground", children: "..." }, `ellipsis-${index}`));
78
+ }
79
+ return (_jsx(Button, { onClick: () => handlePageClick(page), size: "sm", className: cn('inline-flex items-center justify-center', 'h-8 min-w-[32px] px-3 rounded-md', 'text-sm font-medium', 'border transition-colors', page === current
80
+ ? 'bg-theme text-theme-foreground border-theme cursor-default'
81
+ : 'bg-background border-border hover:bg-muted cursor-pointer'), children: page }, page));
82
+ }), _jsx(Button, { onClick: handleNext, size: "sm", disabled: current === totalPages, className: cn('inline-flex items-center justify-center', 'h-8 px-3 rounded-md', 'text-sm font-medium', 'border border-border', 'transition-colors', current === totalPages
83
+ ? 'cursor-not-allowed opacity-50 bg-muted'
84
+ : 'hover:bg-muted bg-background cursor-pointer'), children: _jsx(ChevronRight, { className: "h-4 w-4" }) })] }), onPageSizeChange && (_jsx("div", { className: "flex items-center gap-2", children: _jsx(Select, { value: pageSize, onChange: handlePageSizeChange, options: pageSizeOptions.map((size) => ({
85
+ label: `${size}`,
86
+ value: size,
87
+ })), className: "w-20 [&>div]:bg-muted [&>div]:border-border [&>div]:shadow-sm [&>div]:py-2 [&>div]:px-3 [&>div]:h-8", clearable: false, searchable: false }) }))] }));
88
+ }
@@ -0,0 +1,17 @@
1
+ import type { MOmit } from '../../types';
2
+ import type { FormInstance } from 'rc-field-form';
3
+ import { type ReactNode } from 'react';
4
+ import { type FormFieldScheme } from '../Form';
5
+ export type SearchProps<T> = {
6
+ defaultValue?: T;
7
+ schemes: MOmit<FormFieldScheme<T>, 'rules' | 'required'>[];
8
+ children?: ReactNode;
9
+ /**
10
+ * 获取表单实例的回调
11
+ */
12
+ getForm?: (form: FormInstance<T>) => void;
13
+ btnsClassName?: string;
14
+ };
15
+ declare const Search: <T extends object>(props: SearchProps<T>) => import("react/jsx-runtime").JSX.Element;
16
+ export default Search;
17
+ //# sourceMappingURL=Search.d.ts.map
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { useMemo } from 'react';
4
+ import { SchemeForm } from '../Form';
5
+ const Search = (props) => {
6
+ const { defaultValue: pDefaultValue, schemes, children, getForm, btnsClassName } = props;
7
+ const defaultValue = useMemo(() => {
8
+ return pDefaultValue;
9
+ }, []);
10
+ return (_jsxs("div", { className: "flex items-end justify-between gap-4 flex-wrap", children: [_jsx(SchemeForm, { preserve: true, layout: "horizontal", schemes: schemes, initialValues: defaultValue, getForm: getForm, footerButtons: false }), _jsx("div", { className: cn('flex items-center gap-2 self-end ml-auto flex-wrap', btnsClassName), children: children })] }));
11
+ };
12
+ export default Search;
@@ -0,0 +1,2 @@
1
+ export { default as Search } from './Search';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ export { default as Search } from './Search';
@@ -0,0 +1,21 @@
1
+ import React from 'react';
2
+ export type SelectOption = {
3
+ label: React.ReactNode;
4
+ value: string | number;
5
+ };
6
+ export type SelectProps = {
7
+ options: SelectOption[];
8
+ value?: string | number;
9
+ defaultValue?: string | number;
10
+ placeholder?: string;
11
+ onChange?: (value: string | number | undefined) => void;
12
+ className?: string;
13
+ disabled?: boolean;
14
+ /** 开启清除 默认开启*/
15
+ clearable?: boolean;
16
+ /** 是否支持搜索 默认开启 */
17
+ searchable?: boolean;
18
+ };
19
+ declare const Select: React.ForwardRefExoticComponent<SelectProps & React.RefAttributes<HTMLDivElement>>;
20
+ export { Select };
21
+ //# sourceMappingURL=Select.d.ts.map
@@ -0,0 +1,180 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../../lib/utils';
3
+ import { ChevronUp, X } from 'lucide-react';
4
+ import { forwardRef, useCallback, useEffect, useMemo, useRef, useState } from 'react';
5
+ import { createPortal } from 'react-dom';
6
+ const Select = forwardRef(({ options, value: controlledValue, defaultValue, placeholder, onChange, className, disabled, clearable = true, searchable = true, }, ref) => {
7
+ const [isOpen, setIsOpen] = useState(false);
8
+ const [internalValue, setInternalValue] = useState(defaultValue);
9
+ const [isHover, setIsHover] = useState(false);
10
+ const [searchTerm, setSearchTerm] = useState('');
11
+ const [position, setPosition] = useState({ top: 0, left: 0, width: 0 });
12
+ const selectRef = useRef(null);
13
+ const dropdownRef = useRef(null);
14
+ const inputRef = useRef(null);
15
+ // 合并 refs
16
+ const setRefs = useCallback((node) => {
17
+ selectRef.current = node;
18
+ if (typeof ref === 'function') {
19
+ ref(node);
20
+ }
21
+ else if (ref) {
22
+ ref.current = node;
23
+ }
24
+ }, [ref]);
25
+ const isControlled = controlledValue !== undefined;
26
+ const value = isControlled ? controlledValue : internalValue;
27
+ // 获取当前选中的选项
28
+ const selectedOption = options.find((opt) => opt.value === value);
29
+ const displayText = selectedOption ? selectedOption.label : placeholder || '';
30
+ const filteredOptions = useMemo(() => {
31
+ if (!searchable || !searchTerm.trim())
32
+ return options;
33
+ const lower = searchTerm.trim().toLowerCase();
34
+ return options.filter((opt) => String(opt.label).toLowerCase().includes(lower));
35
+ }, [options, searchTerm, searchable]);
36
+ // 点击其他区域关闭
37
+ useEffect(() => {
38
+ if (!isOpen)
39
+ return;
40
+ const handleClickOutside = (event) => {
41
+ // 点击不在 选择部分 以及 下拉部分 关闭下拉
42
+ if (selectRef.current &&
43
+ !selectRef.current.contains(event.target) &&
44
+ dropdownRef.current &&
45
+ !dropdownRef.current.contains(event.target)) {
46
+ setIsOpen(false);
47
+ }
48
+ };
49
+ document.addEventListener('mousedown', handleClickOutside);
50
+ return () => {
51
+ document.removeEventListener('mousedown', handleClickOutside);
52
+ };
53
+ }, [isOpen]);
54
+ // 键盘关闭
55
+ useEffect(() => {
56
+ const handleKeyDown = (event) => {
57
+ if (event.key === 'Escape' && isOpen) {
58
+ setIsOpen(false);
59
+ }
60
+ };
61
+ if (isOpen) {
62
+ document.addEventListener('keydown', handleKeyDown);
63
+ }
64
+ return () => {
65
+ document.removeEventListener('keydown', handleKeyDown);
66
+ };
67
+ }, [isOpen]);
68
+ // 计算下拉菜单位置和方向
69
+ const updatePosition = useCallback(() => {
70
+ if (!selectRef.current)
71
+ return;
72
+ const rect = selectRef.current.getBoundingClientRect();
73
+ const scrollX = window.scrollX;
74
+ const scrollY = window.scrollY;
75
+ const viewportHeight = window.innerHeight;
76
+ // 获取实际下拉菜单高度,如果还未渲染则使用估算值
77
+ let dropdownHeight = 240; // 默认最大高度 max-h-60
78
+ if (dropdownRef.current) {
79
+ dropdownHeight = dropdownRef.current.getBoundingClientRect().height;
80
+ }
81
+ else {
82
+ // 估算下拉菜单高度(最大高度为 240px,即 max-h-60)
83
+ dropdownHeight = Math.min(filteredOptions.length * 40 + 8, 240); // 每个选项约40px + padding
84
+ }
85
+ const spaceBelow = viewportHeight - rect.bottom;
86
+ const spaceAbove = rect.top;
87
+ // 决定向上还是向下展开
88
+ const shouldPlaceTop = spaceBelow < dropdownHeight && spaceAbove > spaceBelow;
89
+ // 计算位置
90
+ let top;
91
+ if (shouldPlaceTop) {
92
+ // 向上展开:下拉菜单底部对齐触发器顶部
93
+ top = rect.top + scrollY - dropdownHeight - 4; // 4px 间距
94
+ }
95
+ else {
96
+ // 向下展开:下拉菜单顶部对齐触发器底部
97
+ top = rect.bottom + scrollY + 4; // 4px 间距
98
+ }
99
+ // 确保不超出视口
100
+ if (top < scrollY) {
101
+ top = scrollY + 4;
102
+ }
103
+ if (top + dropdownHeight > scrollY + viewportHeight) {
104
+ top = scrollY + viewportHeight - dropdownHeight - 4;
105
+ }
106
+ setPosition({
107
+ top,
108
+ left: rect.left + scrollX,
109
+ width: rect.width,
110
+ });
111
+ }, [filteredOptions.length]);
112
+ // 展开时更新位置并获取焦点
113
+ useEffect(() => {
114
+ if (isOpen) {
115
+ // 使用双重 requestAnimationFrame 确保 DOM 已完全渲染
116
+ requestAnimationFrame(() => {
117
+ requestAnimationFrame(() => {
118
+ updatePosition();
119
+ if (searchable) {
120
+ inputRef.current?.focus();
121
+ }
122
+ });
123
+ });
124
+ }
125
+ }, [isOpen, searchable, updatePosition]);
126
+ // 监听滚动和窗口大小变化,更新位置
127
+ useEffect(() => {
128
+ if (!isOpen)
129
+ return;
130
+ const handleUpdate = () => {
131
+ updatePosition();
132
+ };
133
+ window.addEventListener('scroll', handleUpdate, true);
134
+ window.addEventListener('resize', handleUpdate);
135
+ return () => {
136
+ window.removeEventListener('scroll', handleUpdate, true);
137
+ window.removeEventListener('resize', handleUpdate);
138
+ };
139
+ }, [isOpen, updatePosition]);
140
+ const handleToggle = useCallback(() => {
141
+ if (disabled)
142
+ return;
143
+ setIsOpen((prev) => {
144
+ const next = !prev;
145
+ if (next && searchable) {
146
+ setSearchTerm('');
147
+ }
148
+ return next;
149
+ });
150
+ }, [disabled, searchable]);
151
+ const handleSelect = useCallback((optionValue) => {
152
+ if (!isControlled) {
153
+ setInternalValue(optionValue);
154
+ }
155
+ onChange?.(optionValue);
156
+ setIsOpen(false);
157
+ }, [isControlled, onChange]);
158
+ const handleClear = useCallback((event) => {
159
+ event.stopPropagation();
160
+ if (disabled)
161
+ return;
162
+ // 清除时 重置内外状态
163
+ setInternalValue(undefined);
164
+ onChange?.(undefined);
165
+ }, [disabled, onChange]);
166
+ const handleSearchChange = useCallback((event) => {
167
+ setSearchTerm(event.target.value);
168
+ }, []);
169
+ return (_jsxs("div", { className: cn('relative', className), children: [_jsxs("div", { ref: setRefs, onClick: handleToggle, onMouseEnter: () => setIsHover(true), onMouseLeave: () => setIsHover(false), className: cn('flex w-full items-center justify-between rounded-lg px-4 py-3 text-sm', 'border transition-colors duration-200', 'focus:outline-none', disabled ? 'cursor-not-allowed bg-muted border-border' : 'cursor-pointer bg-background', !disabled && isOpen && 'border-theme', !disabled && !isOpen && 'border-border'), children: [searchable && isOpen ? (_jsx("input", { ref: inputRef, value: searchTerm, onChange: handleSearchChange, onClick: (e) => e.stopPropagation(), placeholder: typeof displayText === 'string' ? displayText : placeholder, className: cn('flex-1 bg-transparent outline-none text-left', 'placeholder:text-muted-foreground', disabled && 'text-muted-foreground cursor-not-allowed'), disabled: disabled })) : (_jsx("span", { className: cn('flex-1 text-left truncate', disabled ? 'text-muted-foreground' : !selectedOption && 'text-muted-foreground'), children: displayText })), clearable && !disabled && value !== undefined && isHover ? (_jsx("button", { type: "button", onClick: handleClear, className: "ml-2 flex items-center justify-center text-muted-foreground hover:text-foreground", "aria-label": "Clear selection", title: "Clear", children: _jsx(X, { size: 14 }) })) : (_jsx(ChevronUp, { size: 16, className: cn('ml-2 transition-transform duration-200', isOpen ? 'rotate-0' : 'rotate-180') }))] }), isOpen &&
170
+ createPortal(_jsx("div", { ref: dropdownRef, className: cn('fixed z-[1000] w-full rounded-lg bg-background shadow-lg', 'border border-border', 'max-h-60 overflow-auto'), style: {
171
+ top: `${position.top}px`,
172
+ left: `${position.left}px`,
173
+ width: `${position.width}px`,
174
+ }, children: _jsx("div", { className: "p-1", children: filteredOptions.length > 0 ? (filteredOptions.map((option) => {
175
+ const isSelected = option.value === value;
176
+ return (_jsx("div", { onClick: () => handleSelect(option.value), className: cn('px-4 py-2 text-sm cursor-pointer transition-colors rounded-md', 'hover:bg-muted', isSelected && 'bg-muted'), children: option.label }, option.value));
177
+ })) : (_jsx("div", { className: "px-4 py-2 text-sm text-muted-foreground text-center", children: "\u6682\u65E0\u9009\u9879" })) }) }), document.body)] }));
178
+ });
179
+ Select.displayName = 'Select';
180
+ export { Select };
@@ -0,0 +1,2 @@
1
+ export * from './Select';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ export * from './Select';
@@ -0,0 +1,28 @@
1
+ import type { HTMLAttributes } from 'react';
2
+ export type SkeletonMode = 'pageloading' | 'tableloading' | 'componentsloading';
3
+ export interface SkeletonProps extends HTMLAttributes<HTMLDivElement> {
4
+ /**
5
+ * 骨架屏模式
6
+ * @default 'componentsloading'
7
+ */
8
+ mode?: SkeletonMode;
9
+ /**
10
+ * 行数(仅对 pageloading 和 tableloading 有效)
11
+ */
12
+ rows?: number;
13
+ /**
14
+ * 是否显示标题骨架(仅对 pageloading 有效)
15
+ * @default true
16
+ */
17
+ showTitle?: boolean;
18
+ /**
19
+ * 是否显示操作栏骨架(仅对 pageloading 有效)
20
+ * @default true
21
+ */
22
+ showActions?: boolean;
23
+ }
24
+ export declare const Skeleton: {
25
+ ({ mode, className, rows, showTitle, showActions, ...props }: SkeletonProps): import("react/jsx-runtime").JSX.Element;
26
+ displayName: string;
27
+ };
28
+ //# sourceMappingURL=Skeleton.d.ts.map