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

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 +39 -3
  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,162 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from '../lib/utils';
3
+ import { Check, ChevronDown, ChevronRight } from 'lucide-react';
4
+ import { useCallback, useMemo, useState } from 'react';
5
+ export function TreeSelect({ data, value = [], onChange, labelField = 'name', checkable = true, className, }) {
6
+ const [expandedKeys, setExpandedKeys] = useState(new Set());
7
+ const { nodeMap, parentMap } = useMemo(() => {
8
+ const nodeM = new Map();
9
+ const parentM = new Map();
10
+ const traverse = (nodes, parentId) => {
11
+ nodes.forEach((node) => {
12
+ nodeM.set(node.id, node);
13
+ parentM.set(node.id, parentId);
14
+ if (node.children && node.children.length > 0) {
15
+ traverse(node.children, node.id);
16
+ }
17
+ });
18
+ };
19
+ traverse(data, null);
20
+ return { nodeMap: nodeM, parentMap: parentM };
21
+ }, [data]);
22
+ // 获取节点的所有子节点 ID
23
+ const getDescendantIds = useCallback((node) => {
24
+ const ids = [];
25
+ const traverse = (n) => {
26
+ if (n.children && n.children.length > 0) {
27
+ n.children.forEach((child) => {
28
+ ids.push(child.id);
29
+ traverse(child);
30
+ });
31
+ }
32
+ };
33
+ traverse(node);
34
+ return ids;
35
+ }, []);
36
+ const updateParentSelection = useCallback((checkedSet) => {
37
+ const traverseUp = (nodeId) => {
38
+ const parentId = parentMap.get(nodeId);
39
+ if (parentId === undefined || parentId === null)
40
+ return;
41
+ const parentNode = nodeMap.get(parentId);
42
+ if (!parentNode || !parentNode.children)
43
+ return;
44
+ const childIds = parentNode.children.map((child) => child.id);
45
+ const checkedCount = childIds.filter((id) => checkedSet.has(id)).length;
46
+ if (checkedCount === childIds.length) {
47
+ checkedSet.add(parentId);
48
+ }
49
+ else {
50
+ checkedSet.delete(parentId);
51
+ }
52
+ traverseUp(parentId);
53
+ };
54
+ checkedSet.forEach((id) => traverseUp(id));
55
+ }, [nodeMap, parentMap]);
56
+ // 切换展开/折叠
57
+ const toggleExpand = useCallback((nodeId) => {
58
+ setExpandedKeys((prev) => {
59
+ const newSet = new Set(prev);
60
+ if (newSet.has(nodeId)) {
61
+ newSet.delete(nodeId);
62
+ }
63
+ else {
64
+ newSet.add(nodeId);
65
+ }
66
+ return newSet;
67
+ });
68
+ }, []);
69
+ const getIndeterminateKeys = useCallback((checkedSet) => {
70
+ const indeterminateKeys = [];
71
+ const getDescendantCount = (node) => {
72
+ if (!node.children || node.children.length === 0) {
73
+ return { total: 1, checked: checkedSet.has(node.id) ? 1 : 0 };
74
+ }
75
+ return node.children.reduce((acc, child) => {
76
+ const childResult = getDescendantCount(child);
77
+ return { total: acc.total + childResult.total, checked: acc.checked + childResult.checked };
78
+ }, { total: 0, checked: 0 });
79
+ };
80
+ const traverse = (nodes) => {
81
+ nodes.forEach((node) => {
82
+ if (node.children && node.children.length > 0) {
83
+ const { total, checked } = getDescendantCount(node);
84
+ if (checked > 0 && checked < total) {
85
+ indeterminateKeys.push(node.id);
86
+ }
87
+ traverse(node.children);
88
+ }
89
+ });
90
+ };
91
+ traverse(data);
92
+ return indeterminateKeys;
93
+ }, [data]);
94
+ // 切换选中状态
95
+ const toggleCheck = useCallback((node) => {
96
+ if (!checkable || !onChange)
97
+ return;
98
+ const isChecked = value.includes(node.id);
99
+ const nextChecked = new Set(value);
100
+ const descendantIds = getDescendantIds(node);
101
+ if (isChecked) {
102
+ nextChecked.delete(node.id);
103
+ descendantIds.forEach((id) => nextChecked.delete(id));
104
+ }
105
+ else {
106
+ nextChecked.add(node.id);
107
+ descendantIds.forEach((id) => nextChecked.add(id));
108
+ }
109
+ updateParentSelection(nextChecked);
110
+ const indeterminateKeys = getIndeterminateKeys(nextChecked);
111
+ onChange({ checked: Array.from(nextChecked), indeterminate: indeterminateKeys });
112
+ }, [value, onChange, checkable, getDescendantIds, updateParentSelection, getIndeterminateKeys]);
113
+ // 判断节点是否选中
114
+ const isNodeChecked = useCallback((nodeId) => {
115
+ return value.includes(nodeId);
116
+ }, [value]);
117
+ const isNodeIndeterminate = useCallback((node) => {
118
+ if (!node.children || node.children.length === 0)
119
+ return false;
120
+ const getDescendantCount = (n) => {
121
+ if (!n.children || n.children.length === 0) {
122
+ return { total: 1, checked: value.includes(n.id) ? 1 : 0 };
123
+ }
124
+ return n.children.reduce((acc, child) => {
125
+ const childResult = getDescendantCount(child);
126
+ return { total: acc.total + childResult.total, checked: acc.checked + childResult.checked };
127
+ }, { total: 0, checked: 0 });
128
+ };
129
+ const { total, checked } = getDescendantCount(node);
130
+ return checked > 0 && checked < total;
131
+ }, [value]);
132
+ // 渲染树节点
133
+ function renderTreeNode(node, level = 0) {
134
+ const hasChildren = node.children && node.children.length > 0;
135
+ const isExpanded = expandedKeys.has(node.id);
136
+ const isChecked = isNodeChecked(node.id);
137
+ const isIndeterminate = isNodeIndeterminate(node);
138
+ return (_jsxs("div", { children: [_jsxs("div", { className: cn('flex items-center gap-2 py-2 px-2 hover:bg-muted/50 rounded-md cursor-pointer transition-colors', 'group'), style: { paddingLeft: `${level * 20 + 8}px` }, children: [hasChildren ? (_jsx("button", { type: "button", onClick: (e) => {
139
+ e.stopPropagation();
140
+ toggleExpand(node.id);
141
+ }, className: "flex-shrink-0 p-0.5 hover:bg-muted rounded", children: isExpanded ? _jsx(ChevronDown, { className: "h-4 w-4" }) : _jsx(ChevronRight, { className: "h-4 w-4" }) })) : (_jsx("span", { className: "w-5" })), checkable && (_jsx("button", { type: "button", onClick: (e) => {
142
+ e.stopPropagation();
143
+ toggleCheck(node);
144
+ }, className: cn('flex-shrink-0 w-4 h-4 rounded border-2 flex items-center justify-center transition-colors', isChecked
145
+ ? 'bg-black border-black'
146
+ : isIndeterminate
147
+ ? 'bg-gray-400 border-gray-400'
148
+ : 'border-border hover:border-foreground'), children: (isChecked || isIndeterminate) && _jsx(Check, { className: "h-3 w-3 text-white", strokeWidth: 3 }) })), _jsx("span", { className: "flex-1 text-sm select-none", onClick: () => {
149
+ if (hasChildren) {
150
+ toggleExpand(node.id);
151
+ }
152
+ else {
153
+ toggleCheck(node);
154
+ }
155
+ }, children: labelField === 'desctext' ? node.desctext || node.name : node.name })] }), hasChildren && isExpanded && _jsx("div", { children: node.children.map((child) => renderTreeNode(child, level + 1)) })] }, node.id));
156
+ }
157
+ // 如果没有数据
158
+ if (!data || data.length === 0) {
159
+ return _jsx("div", { className: cn('p-8 text-center text-sm text-muted-foreground', className), children: "No data" });
160
+ }
161
+ return (_jsx("div", { className: cn('border border-border rounded-lg p-2 max-h-[400px] overflow-y-auto', className), children: data.map((node) => renderTreeNode(node)) }));
162
+ }
@@ -0,0 +1,9 @@
1
+ export interface ImageUploadProps {
2
+ accept?: string;
3
+ maxCount?: number;
4
+ value?: string[];
5
+ onChange?: (urls: string[]) => void;
6
+ beforeChange?: (file: File) => boolean | void;
7
+ }
8
+ export declare function ImageUpload({ accept, maxCount, value, onChange, beforeChange }: ImageUploadProps): import("react/jsx-runtime").JSX.Element;
9
+ //# sourceMappingURL=ImageUpload.d.ts.map
@@ -0,0 +1,63 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Camera, X } from 'lucide-react';
3
+ import { useEffect, useMemo, useRef, useState } from 'react';
4
+ import { FileUpload } from './Upload';
5
+ export function ImageUpload({ accept = '.jpg,.png', maxCount = 1, value, onChange, beforeChange }) {
6
+ const inputRef = useRef(null);
7
+ const [internalUrls, setInternalUrls] = useState([]);
8
+ const urls = value ?? internalUrls;
9
+ const setUrls = onChange ?? setInternalUrls;
10
+ const mAccept = useMemo(() => {
11
+ const aType = accept
12
+ .split(',')
13
+ .map((item) => item.trim().replace(/\./g, ''))
14
+ .filter(Boolean);
15
+ return aType.map((a) => `image/${a}`).join(', ');
16
+ }, [accept]);
17
+ const handleFileChange = (e) => {
18
+ const files = e.target.files;
19
+ if (!files || files.length === 0)
20
+ return;
21
+ const newUrls = [];
22
+ const fileArray = Array.from(files);
23
+ const remainingCount = maxCount - urls.length;
24
+ fileArray.forEach((file) => {
25
+ if (newUrls.length < remainingCount) {
26
+ if (beforeChange) {
27
+ const result = beforeChange(file);
28
+ if (result === false) {
29
+ return;
30
+ }
31
+ }
32
+ const url = URL.createObjectURL(file);
33
+ newUrls.push(url);
34
+ }
35
+ });
36
+ if (maxCount > 1) {
37
+ setUrls([...urls, ...newUrls]);
38
+ }
39
+ else {
40
+ urls.forEach((url) => URL.revokeObjectURL(url));
41
+ setUrls(newUrls.slice(0, 1));
42
+ }
43
+ if (inputRef.current) {
44
+ inputRef.current.value = '';
45
+ }
46
+ };
47
+ const handleRemove = (index) => {
48
+ const urlToRemove = urls[index];
49
+ URL.revokeObjectURL(urlToRemove);
50
+ setUrls(urls.filter((_, i) => i !== index));
51
+ };
52
+ useEffect(() => {
53
+ return () => {
54
+ if (!onChange) {
55
+ internalUrls.forEach((url) => URL.revokeObjectURL(url));
56
+ }
57
+ };
58
+ }, [onChange, internalUrls]);
59
+ return (_jsxs("div", { className: "flex flex-wrap gap-3", children: [urls.map((url, index) => (_jsxs("div", { className: "relative w-24 h-24 rounded-lg overflow-hidden border border-gray-200 group cursor-pointer", children: [_jsx("img", { src: url, alt: "", className: "w-full h-full object-cover" }), _jsx("div", { className: "absolute inset-0 bg-black/0 group-hover:bg-black/40 transition-colors flex items-center justify-center", children: _jsx("button", { type: "button", onClick: (e) => {
60
+ e.stopPropagation();
61
+ handleRemove(index);
62
+ }, className: "opacity-0 group-hover:opacity-100 transition-opacity p-1.5 rounded-full bg-red-500 hover:bg-red-600 text-white", "aria-label": "\u5220\u9664\u56FE\u7247", title: "\u5220\u9664\u56FE\u7247", children: _jsx(X, { size: 16 }) }) })] }, index))), urls.length < maxCount && (_jsx(FileUpload, { inputRef: inputRef, accept: mAccept, multiple: maxCount > 1, onChange: handleFileChange, labelClassName: "w-24 h-24 p-0 border-0 cursor-pointer", selectLabel: _jsxs("div", { className: "w-full h-full rounded-[8px] bg-[#F5F5F5] border border-gray-200 flex flex-col items-center justify-center gap-1 hover:bg-gray-50 transition-colors", children: [_jsx(Camera, { className: "text-gray-500", size: 24 }), _jsx("span", { className: "text-xs text-gray-500", children: "\u4E0A\u4F20" })] }) }))] }));
63
+ }
@@ -0,0 +1,41 @@
1
+ import type { ChangeEvent, ReactNode, RefObject } from 'react';
2
+ export interface FileUploadProps {
3
+ /**
4
+ * 文件 input 的 ref,用于父组件重置 value 等
5
+ */
6
+ inputRef?: RefObject<HTMLInputElement | null>;
7
+ /**
8
+ * input 的 accept 属性,默认接收任意文件
9
+ */
10
+ accept?: string;
11
+ /**
12
+ * 是否支持多选
13
+ */
14
+ multiple?: boolean;
15
+ /**
16
+ * 选择文件时的回调
17
+ */
18
+ onChange?: (event: ChangeEvent<HTMLInputElement>) => void;
19
+ /**
20
+ * 选择文件按钮文案
21
+ */
22
+ selectLabel: ReactNode;
23
+ /**
24
+ * label 的自定义 className
25
+ */
26
+ labelClassName?: string;
27
+ /**
28
+ * 是否展示清空按钮
29
+ */
30
+ showClear?: boolean;
31
+ /**
32
+ * 清空按钮点击回调
33
+ */
34
+ onClear?: () => void;
35
+ /**
36
+ * 清空按钮文案
37
+ */
38
+ clearLabel?: ReactNode;
39
+ }
40
+ export declare function FileUpload({ inputRef, accept, multiple, onChange, selectLabel, labelClassName, showClear, onClear, clearLabel, }: FileUploadProps): import("react/jsx-runtime").JSX.Element;
41
+ //# sourceMappingURL=Upload.d.ts.map
@@ -0,0 +1,5 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button } from '../Button';
3
+ export function FileUpload({ inputRef, accept = '*', multiple, onChange, selectLabel, labelClassName, showClear, onClear, clearLabel, }) {
4
+ return (_jsxs("div", { className: "flex items-center gap-3", children: [_jsxs("label", { className: labelClassName ?? 'flex items-center gap-2 px-4 py-2 border rounded-lg cursor-pointer bg-white', children: [_jsx("input", { ref: inputRef, type: "file", accept: accept, multiple: multiple, className: "hidden", onChange: onChange }), selectLabel] }), showClear && onClear && (_jsx(Button, { size: "sm", variant: "link", onClick: onClear, children: clearLabel }))] }));
5
+ }
@@ -0,0 +1,3 @@
1
+ export * from './ImageUpload';
2
+ export * from './Upload';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,2 @@
1
+ export * from './ImageUpload';
2
+ export * from './Upload';
@@ -0,0 +1,35 @@
1
+ declare const Breadcrumb: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, "ref"> & {
2
+ separator?: React.ReactNode;
3
+ } & import("react").RefAttributes<HTMLElement>>;
4
+ declare const BreadcrumbList: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").OlHTMLAttributes<HTMLOListElement>, HTMLOListElement>, "ref"> & import("react").RefAttributes<HTMLOListElement>>;
5
+ declare const BreadcrumbItem: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>, "ref"> & import("react").RefAttributes<HTMLLIElement>>;
6
+ declare const BreadcrumbLink: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>, "ref"> & {
7
+ asChild?: boolean;
8
+ } & import("react").RefAttributes<HTMLAnchorElement>>;
9
+ declare const BreadcrumbPage: import("react").ForwardRefExoticComponent<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "ref"> & {
10
+ active?: boolean;
11
+ onClose?: () => void;
12
+ closable?: boolean;
13
+ } & import("react").RefAttributes<HTMLSpanElement>>;
14
+ declare const BreadcrumbSeparator: {
15
+ ({ children, className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
16
+ displayName: string;
17
+ };
18
+ declare const BreadcrumbEllipsis: {
19
+ ({ className, ...props }: React.ComponentProps<"span">): import("react/jsx-runtime").JSX.Element;
20
+ displayName: string;
21
+ };
22
+ export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, };
23
+ export interface BreadcrumbItemData {
24
+ label: string;
25
+ desctext?: string;
26
+ id: string | number;
27
+ path?: string;
28
+ active?: boolean;
29
+ closable?: boolean;
30
+ }
31
+ export interface SimpleBreadcrumbProps {
32
+ className?: string;
33
+ }
34
+ export declare function SimpleBreadcrumb({ className }: SimpleBreadcrumbProps): import("react/jsx-runtime").JSX.Element;
35
+ //# sourceMappingURL=breadcrumb.d.ts.map
@@ -0,0 +1,78 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useBreadcrumb } from '../hooks/useBreadcrumb';
3
+ import { useLanguage } from '../hooks/useLanguage';
4
+ import { cn } from '../lib/utils';
5
+ // import useUserStore from '@tc/ui-react/stores/user'
6
+ import { ChevronRight, MoreHorizontal } from 'lucide-react';
7
+ import { forwardRef } from 'react';
8
+ import { useNavigate } from 'react-router-dom';
9
+ const Breadcrumb = forwardRef(({ ...props }, ref) => _jsx("nav", { ref: ref, "aria-label": "breadcrumb", ...props }));
10
+ Breadcrumb.displayName = 'Breadcrumb';
11
+ const BreadcrumbList = forwardRef(({ className, ...props }, ref) => (_jsx("ol", { ref: ref, className: cn('flex items-center gap-3 flex-wrap', className), ...props })));
12
+ BreadcrumbList.displayName = 'BreadcrumbList';
13
+ const BreadcrumbItem = forwardRef(({ className, ...props }, ref) => _jsx("li", { ref: ref, className: cn('inline-flex items-center', className), ...props }));
14
+ BreadcrumbItem.displayName = 'BreadcrumbItem';
15
+ const BreadcrumbLink = forwardRef(({ className, ...props }, ref) => {
16
+ return _jsx("a", { ref: ref, className: cn('transition-colors hover:text-foreground', className), ...props });
17
+ });
18
+ BreadcrumbLink.displayName = 'BreadcrumbLink';
19
+ const BreadcrumbPage = forwardRef(({ className, active, onClose, closable = true, children, ...props }, ref) => {
20
+ return (_jsxs("span", { ref: ref, role: "link", "aria-disabled": "true", "aria-current": "page", className: cn('inline-flex items-center gap-2 px-4 py-2 rounded-lg border transition-all duration-200 text-sm', active
21
+ ? 'bg-breadcrumb-active-bg text-breadcrumb-active-text border-breadcrumb-active-bg shadow-sm'
22
+ : 'bg-white text-breadcrumb-text border-breadcrumb-border hover:border-gray-400', className), ...props, children: [_jsx("span", { className: "font-normal", children: children }), onClose && closable && (_jsx("button", { onClick: (e) => {
23
+ e.stopPropagation();
24
+ onClose();
25
+ }, className: "inline-flex items-center justify-center hover:opacity-70 transition-opacity", "aria-label": "\u5173\u95ED", children: _jsxs("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg", children: [_jsxs("g", { clipPath: "url(#clip0_228_519)", children: [_jsx("circle", { cx: "8", cy: "8", r: "6.66667", stroke: "currentColor", strokeWidth: "1" }), _jsx("path", { d: "M9.66669 6.33302L6.33337 9.66634M6.33336 6.33301L9.66668 9.66633", stroke: "currentColor", strokeWidth: "1", strokeLinecap: "round" })] }), _jsx("defs", { children: _jsx("clipPath", { id: "clip0_228_519", children: _jsx("rect", { width: "16", height: "16", fill: "white" }) }) })] }) }))] }));
26
+ });
27
+ BreadcrumbPage.displayName = 'BreadcrumbPage';
28
+ const BreadcrumbSeparator = ({ children, className, ...props }) => (_jsx("li", { role: "presentation", "aria-hidden": "true", className: cn('[&>svg]:size-3.5', className), ...props, children: children ?? _jsx(ChevronRight, {}) }));
29
+ BreadcrumbSeparator.displayName = 'BreadcrumbSeparator';
30
+ const BreadcrumbEllipsis = ({ className, ...props }) => (_jsxs("span", { role: "presentation", "aria-hidden": "true", "aria-label": "More", className: cn('flex h-9 w-9 items-center justify-center', className), ...props, children: [_jsx(MoreHorizontal, { className: "h-4 w-4" }), _jsx("span", { className: "sr-only", children: "More" })] }));
31
+ BreadcrumbEllipsis.displayName = 'BreadcrumbEllipsis';
32
+ export { Breadcrumb, BreadcrumbEllipsis, BreadcrumbItem, BreadcrumbLink, BreadcrumbList, BreadcrumbPage, BreadcrumbSeparator, };
33
+ export function SimpleBreadcrumb({ className }) {
34
+ const { language } = useLanguage();
35
+ const navigate = useNavigate();
36
+ const { items, setActiveItem, removeItem } = useBreadcrumb();
37
+ const handleBreadcrumbClick = (id) => {
38
+ const item = items.find((item) => item.id === id);
39
+ if (item?.path) {
40
+ navigate(item.path);
41
+ setActiveItem(id);
42
+ }
43
+ };
44
+ const handleBreadcrumbClose = (id) => {
45
+ const itemToRemove = items.find((item) => item.id === id);
46
+ const isActive = itemToRemove?.active;
47
+ // 先计算剩余的面包屑项(在删除之前)
48
+ const remainingItems = items.filter((item) => item.id !== id);
49
+ // 立即删除该项,确保状态及时更新
50
+ removeItem(id);
51
+ // 如果删除的是当前激活的项,需要跳转
52
+ if (isActive) {
53
+ if (remainingItems.length > 0) {
54
+ // 有剩余项,跳转到最后一个
55
+ const targetItem = remainingItems.at(-1);
56
+ const targetPath = targetItem.path;
57
+ if (targetPath) {
58
+ // 使用 setTimeout 确保删除操作先完成
59
+ setTimeout(() => {
60
+ navigate(targetPath);
61
+ setActiveItem(targetItem.id);
62
+ }, 0);
63
+ }
64
+ }
65
+ else {
66
+ // 获取首页路径(第一个权限页面)
67
+ setTimeout(() => {
68
+ // todo
69
+ // navigate(useUserStore.getState().userPagePermissions[0]?.menuUrl || '/')
70
+ }, 0);
71
+ }
72
+ }
73
+ };
74
+ const getItemLabel = (item) => {
75
+ return language === 'zh-CN' ? item.label : item.desctext || item.label;
76
+ };
77
+ return (_jsx(Breadcrumb, { className: className, children: _jsx(BreadcrumbList, { children: items.map((item) => (_jsx(BreadcrumbItem, { children: _jsx(BreadcrumbPage, { active: item.active, closable: item.closable !== false, onClose: () => handleBreadcrumbClose(item.id), onClick: () => handleBreadcrumbClick(item.id), className: 'cursor-pointer', "data-active": item.active ? 'true' : undefined, children: getItemLabel(item) }) }, item.id))) }) }));
78
+ }
@@ -0,0 +1,24 @@
1
+ interface IParams<T> {
2
+ ref: React.ForwardedRef<T>;
3
+ defaultValue?: string;
4
+ controlledValue?: string;
5
+ disabled?: boolean;
6
+ }
7
+ /**
8
+ * 处理ref & 判断是否受控 & 使用的value & value.length
9
+ */
10
+ export declare const useInputController: <T>(params: IParams<T>) => {
11
+ setRefs: (node: T | null) => void;
12
+ setIsFocused: import("react").Dispatch<import("react").SetStateAction<boolean>>;
13
+ setInternalValue: import("react").Dispatch<import("react").SetStateAction<string>>;
14
+ controllerRef: import("react").RefObject<T | null>;
15
+ isControlledRef: import("react").RefObject<boolean>;
16
+ isControlled: boolean;
17
+ isFocused: boolean;
18
+ currentLength: number;
19
+ hasValue: boolean;
20
+ internalValue: string;
21
+ value: string | undefined;
22
+ };
23
+ export {};
24
+ //# sourceMappingURL=useInputController.d.ts.map
@@ -0,0 +1,45 @@
1
+ import { useCallback, useMemo, useRef, useState } from 'react';
2
+ /**
3
+ * 处理ref & 判断是否受控 & 使用的value & value.length
4
+ */
5
+ export const useInputController = (params) => {
6
+ const { defaultValue, ref, controlledValue } = params;
7
+ const [isFocused, setIsFocused] = useState(false);
8
+ const [internalValue, setInternalValue] = useState(defaultValue || '');
9
+ const controllerRef = useRef(null);
10
+ // 合并 refs
11
+ const setRefs = useCallback((node) => {
12
+ controllerRef.current = node;
13
+ if (typeof ref === 'function') {
14
+ ref(node);
15
+ }
16
+ else if (ref) {
17
+ // eslint-disable-next-line react-hooks/immutability
18
+ ref.current = node;
19
+ }
20
+ }, [ref]);
21
+ const isControlledRef = useRef(false);
22
+ // 外部传了value
23
+ const isControlled = useMemo(() => {
24
+ const r = controlledValue !== undefined;
25
+ // 当传入的value改变时,更新ref值
26
+ isControlledRef.current = r;
27
+ return r;
28
+ }, [controlledValue]);
29
+ const value = isControlled ? controlledValue : internalValue;
30
+ const hasValue = Boolean(value && String(value).length > 0);
31
+ const currentLength = value ? String(value).length : 0;
32
+ return {
33
+ setRefs,
34
+ setIsFocused,
35
+ setInternalValue,
36
+ controllerRef,
37
+ isControlledRef,
38
+ isControlled,
39
+ isFocused,
40
+ currentLength,
41
+ hasValue,
42
+ internalValue,
43
+ value,
44
+ };
45
+ };
@@ -0,0 +1,24 @@
1
+ export * from './breadcrumb';
2
+ export * from './Button';
3
+ export * from './Checkbox';
4
+ export * from './ConfirmDialog';
5
+ export * from './DataTable/data-table';
6
+ export * from './Dropdown';
7
+ export * from './Form';
8
+ export * from './ImagePreview';
9
+ export * from './Input';
10
+ export * from './Label';
11
+ export * from './Message';
12
+ export * from './Modal';
13
+ export * from './Pagination';
14
+ export * from './Search';
15
+ export * from './Select';
16
+ export * from './Skeleton';
17
+ export * from './Switch';
18
+ export * from './table';
19
+ export * from './TableSearch';
20
+ export * from './Textarea';
21
+ export * from './Tooltip';
22
+ export * from './TreeSelect';
23
+ export * from './Upload';
24
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,23 @@
1
+ export * from './breadcrumb';
2
+ export * from './Button';
3
+ export * from './Checkbox';
4
+ export * from './ConfirmDialog';
5
+ export * from './DataTable/data-table';
6
+ export * from './Dropdown';
7
+ export * from './Form';
8
+ export * from './ImagePreview';
9
+ export * from './Input';
10
+ export * from './Label';
11
+ export * from './Message';
12
+ export * from './Modal';
13
+ export * from './Pagination';
14
+ export * from './Search';
15
+ export * from './Select';
16
+ export * from './Skeleton';
17
+ export * from './Switch';
18
+ export * from './table';
19
+ export * from './TableSearch';
20
+ export * from './Textarea';
21
+ export * from './Tooltip';
22
+ export * from './TreeSelect';
23
+ export * from './Upload';
@@ -0,0 +1,17 @@
1
+ import * as React from 'react';
2
+ declare const Table: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableElement> & {
3
+ containerClassName?: string;
4
+ } & React.RefAttributes<HTMLTableElement>>;
5
+ declare const TableHeader: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
6
+ declare const TableBody: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
7
+ declare const TableFooter: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableSectionElement> & React.RefAttributes<HTMLTableSectionElement>>;
8
+ declare const TableRow: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableRowElement> & React.RefAttributes<HTMLTableRowElement>>;
9
+ declare const TableHead: React.ForwardRefExoticComponent<React.ThHTMLAttributes<HTMLTableCellElement> & {
10
+ isAction?: boolean;
11
+ } & React.RefAttributes<HTMLTableCellElement>>;
12
+ declare const TableCell: React.ForwardRefExoticComponent<React.TdHTMLAttributes<HTMLTableCellElement> & {
13
+ isAction?: boolean;
14
+ } & React.RefAttributes<HTMLTableCellElement>>;
15
+ declare const TableCaption: React.ForwardRefExoticComponent<React.HTMLAttributes<HTMLTableCaptionElement> & React.RefAttributes<HTMLTableCaptionElement>>;
16
+ export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
17
+ //# sourceMappingURL=table.d.ts.map
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from '../lib/utils';
3
+ import * as React from 'react';
4
+ const Table = React.forwardRef(({ className, containerClassName, ...props }, ref) => (_jsx("div", { className: cn('relative w-full overflow-auto rounded-[20px]', containerClassName), children: _jsx("table", { ref: ref, className: cn('w-full caption-bottom text-sm', className), ...props }) })));
5
+ Table.displayName = 'Table';
6
+ const TableHeader = React.forwardRef(({ className, ...props }, ref) => _jsx("thead", { ref: ref, className: cn('bg-table-header', className), ...props }));
7
+ TableHeader.displayName = 'TableHeader';
8
+ const TableBody = React.forwardRef(({ className, ...props }, ref) => (_jsx("tbody", { ref: ref, className: cn('[&_tr:last-child]:border-0', className), ...props })));
9
+ TableBody.displayName = 'TableBody';
10
+ const TableFooter = React.forwardRef(({ className, ...props }, ref) => (_jsx("tfoot", { ref: ref, className: cn('border-t bg-muted/50 font-medium [&>tr]:last:border-b-0', className), ...props })));
11
+ TableFooter.displayName = 'TableFooter';
12
+ const TableRow = React.forwardRef(({ className, ...props }, ref) => (_jsx("tr", { ref: ref, className: cn('border-b transition-colors hover:bg-muted/50 data-[state=selected]:bg-muted', className), ...props })));
13
+ TableRow.displayName = 'TableRow';
14
+ const TableHead = React.forwardRef(({ className, isAction, ...props }, ref) => (_jsx("th", { ref: ref, className: cn('h-12 px-4 text-left align-middle text-xs font-normal', 'text-table-head-text', isAction && 'bg-table-action text-table-action-text w-[85px] text-center', className), ...props })));
15
+ TableHead.displayName = 'TableHead';
16
+ const TableCell = React.forwardRef(({ className, isAction, ...props }, ref) => (_jsx("td", { ref: ref, className: cn('p-4 align-middle text-sm font-normal', 'text-table-cell-text', isAction && 'bg-table-action text-table-action-text w-[85px] text-center', className), ...props })));
17
+ TableCell.displayName = 'TableCell';
18
+ const TableCaption = React.forwardRef(({ className, ...props }, ref) => (_jsx("caption", { ref: ref, className: cn('mt-4 text-sm text-muted-foreground', className), ...props })));
19
+ TableCaption.displayName = 'TableCaption';
20
+ export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
@@ -0,0 +1,3 @@
1
+ declare const TestPage: () => import("react/jsx-runtime").JSX.Element;
2
+ export default TestPage;
3
+ //# sourceMappingURL=index.d.ts.map