@_tc/template-core 0.0.1-bate.35 → 0.0.1-bate.37

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 (418) hide show
  1. package/cjs/app/controller/base.js +3 -3
  2. package/cjs/app/controller/project.js +1 -1
  3. package/cjs/app/controller/view.js +16 -7
  4. package/cjs/app/middleware/api-params-verify.js +10 -1
  5. package/cjs/app/middleware/error-handle.js +9 -3
  6. package/cjs/app/middleware/project-handler.js +1 -1
  7. package/cjs/app/router/view.js +3 -1
  8. package/cjs/app/router-schema/project.js +1 -1
  9. package/cjs/app/service/project.js +5 -0
  10. package/cjs/bundler/defaultAlias.js +5 -0
  11. package/cjs/bundler/dev.js +4 -3
  12. package/cjs/bundler/index.js +2 -1
  13. package/cjs/bundler/prod.js +4 -3
  14. package/cjs/bundler/utils.js +53 -24
  15. package/cjs/packages/common/LRUCache.js +4 -0
  16. package/cjs/packages/common/array/index.js +43 -0
  17. package/cjs/packages/common/cache/LRUCache.js +45 -0
  18. package/cjs/packages/common/cache/index.js +4 -0
  19. package/cjs/packages/common/guards/index.js +34 -0
  20. package/cjs/packages/common/i18n/default.js +95 -0
  21. package/cjs/packages/common/i18n/en-US.js +95 -0
  22. package/cjs/packages/common/i18n/index.js +178 -0
  23. package/cjs/packages/common/i18n/locales.js +17 -0
  24. package/cjs/packages/common/i18n/types.js +1 -0
  25. package/cjs/packages/common/index.js +65 -0
  26. package/cjs/packages/common/log/index.js +160 -0
  27. package/cjs/packages/common/number/index.js +14 -0
  28. package/cjs/packages/common/object/filterEmpty.js +32 -0
  29. package/cjs/packages/common/object/filtereEmpty.js +5 -0
  30. package/cjs/packages/common/object/index.js +26 -0
  31. package/cjs/packages/common/string/index.js +17 -0
  32. package/cjs/packages/common/types/index.js +1 -0
  33. package/cjs/packages/core/index.js +17 -12
  34. package/cjs/packages/core/loader/model.js +3 -3
  35. package/cjs/packages/core/loader/router.js +14 -5
  36. package/esm/app/controller/base.js +3 -3
  37. package/esm/app/controller/project.js +3 -3
  38. package/esm/app/controller/view.js +16 -7
  39. package/esm/app/middleware/api-params-verify.js +10 -1
  40. package/esm/app/middleware/error-handle.js +9 -3
  41. package/esm/app/middleware/project-handler.js +1 -1
  42. package/esm/app/router/view.js +3 -1
  43. package/esm/app/router-schema/project.js +1 -1
  44. package/esm/app/service/project.js +5 -0
  45. package/esm/bundler/defaultAlias.js +4 -0
  46. package/esm/bundler/dev.js +4 -3
  47. package/esm/bundler/index.js +2 -1
  48. package/esm/bundler/prod.js +4 -3
  49. package/esm/bundler/utils.js +53 -24
  50. package/esm/index.js +2 -2
  51. package/esm/packages/common/LRUCache.js +2 -0
  52. package/esm/packages/common/array/index.js +37 -0
  53. package/esm/packages/common/cache/LRUCache.js +43 -0
  54. package/esm/packages/common/cache/index.js +2 -0
  55. package/esm/packages/common/guards/index.js +26 -0
  56. package/esm/packages/common/i18n/default.js +93 -0
  57. package/esm/packages/common/i18n/en-US.js +93 -0
  58. package/esm/packages/common/i18n/index.js +162 -0
  59. package/esm/packages/common/i18n/locales.js +11 -0
  60. package/esm/packages/common/i18n/types.js +0 -0
  61. package/esm/packages/common/index.js +13 -0
  62. package/esm/packages/common/log/index.js +146 -0
  63. package/esm/packages/common/number/index.js +11 -0
  64. package/esm/packages/common/object/filterEmpty.js +29 -0
  65. package/esm/packages/common/object/filtereEmpty.js +2 -0
  66. package/esm/packages/common/object/index.js +20 -0
  67. package/esm/packages/common/string/index.js +13 -0
  68. package/esm/packages/common/types/index.js +0 -0
  69. package/esm/packages/core/index.js +17 -12
  70. package/esm/packages/core/loader/model.js +3 -3
  71. package/esm/packages/core/loader/router.js +14 -5
  72. package/fe/frontend/dash/Dashboard.d.ts +7 -0
  73. package/fe/frontend/dash/Dashboard.js +63 -0
  74. package/fe/frontend/dash/dash.entry.d.ts +2 -0
  75. package/fe/frontend/dash/dash.entry.js +62 -0
  76. package/fe/frontend/index.d.ts +3 -0
  77. package/fe/frontend/index.js +1 -0
  78. package/fe/frontend/main.css +5 -1
  79. package/fe/frontend/main.d.ts +10 -3
  80. package/fe/frontend/main.js +13 -4
  81. package/fe/frontend/testPage/testPage.entry.js +1 -2
  82. package/fe/frontend/typing/window.d.ts +7 -0
  83. package/fe/frontend/typing/window.js +1 -0
  84. package/fe/frontend/widgets/api/baseInfo.d.ts +31 -0
  85. package/fe/frontend/widgets/api/baseInfo.js +15 -0
  86. package/fe/frontend/widgets/common/CRUD/CRUD.d.ts +70 -0
  87. package/fe/frontend/widgets/common/CRUD/CRUD.js +207 -0
  88. package/fe/frontend/widgets/common/CRUD/index.d.ts +2 -0
  89. package/fe/frontend/widgets/common/CRUD/index.js +1 -0
  90. package/fe/frontend/widgets/common/auth/index.d.ts +7 -0
  91. package/fe/frontend/widgets/common/auth/index.js +20 -0
  92. package/fe/frontend/widgets/common/generateMenuData.d.ts +4 -0
  93. package/fe/frontend/widgets/common/generateMenuData.js +14 -0
  94. package/fe/frontend/widgets/common/importComponent.d.ts +5 -0
  95. package/fe/frontend/widgets/common/importComponent.js +7 -0
  96. package/fe/frontend/widgets/common/language.d.ts +2 -0
  97. package/fe/frontend/widgets/common/language.js +8 -0
  98. package/fe/frontend/widgets/common/logFn/index.d.ts +4 -0
  99. package/fe/frontend/widgets/common/logFn/index.js +8 -0
  100. package/fe/frontend/widgets/common/menu.d.ts +22 -0
  101. package/fe/frontend/widgets/common/menu.js +80 -0
  102. package/fe/frontend/widgets/common/request.d.ts +33 -0
  103. package/fe/frontend/widgets/common/request.js +127 -0
  104. package/fe/frontend/widgets/components/BasePage/HeaderView.d.ts +9 -0
  105. package/fe/frontend/widgets/components/BasePage/HeaderView.js +14 -0
  106. package/fe/frontend/widgets/components/Router/index.d.ts +9 -0
  107. package/fe/frontend/widgets/components/Router/index.js +11 -0
  108. package/fe/frontend/widgets/components/Router/type.d.ts +2 -0
  109. package/fe/frontend/widgets/components/Router/type.js +1 -0
  110. package/fe/frontend/widgets/defaultPages/Iframe/index.d.ts +3 -0
  111. package/fe/frontend/widgets/defaultPages/Iframe/index.js +14 -0
  112. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.d.ts +7 -0
  113. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/DetailPanel.js +94 -0
  114. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.d.ts +13 -0
  115. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/PopFrom.js +109 -0
  116. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.d.ts +3 -0
  117. package/fe/frontend/widgets/defaultPages/Schema/components/CallCom/data.js +6 -0
  118. package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.d.ts +3 -0
  119. package/fe/frontend/widgets/defaultPages/Schema/components/SchemaSearch/index.js +58 -0
  120. package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.d.ts +11 -0
  121. package/fe/frontend/widgets/defaultPages/Schema/components/SchemaTable/index.js +176 -0
  122. package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.d.ts +8 -0
  123. package/fe/frontend/widgets/defaultPages/Schema/data/eventInfo.js +6 -0
  124. package/fe/frontend/widgets/defaultPages/Schema/data/index.d.ts +3 -0
  125. package/fe/frontend/widgets/defaultPages/Schema/data/index.js +1 -0
  126. package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.d.ts +10 -0
  127. package/fe/frontend/widgets/defaultPages/Schema/hooks/useComConfig.js +14 -0
  128. package/fe/frontend/widgets/defaultPages/Schema/index.d.ts +3 -0
  129. package/fe/frontend/widgets/defaultPages/Schema/index.js +67 -0
  130. package/fe/frontend/widgets/defaultPages/Schema/schemaType.d.ts +41 -0
  131. package/fe/frontend/widgets/defaultPages/Schema/schemaType.js +4 -0
  132. package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.d.ts +23 -0
  133. package/fe/frontend/widgets/defaultPages/Schema/stores/schemaEventBus.js +66 -0
  134. package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.d.ts +33 -0
  135. package/fe/frontend/widgets/defaultPages/Schema/stores/schemaStore.js +24 -0
  136. package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.d.ts +3 -0
  137. package/fe/frontend/widgets/defaultPages/Schema/utils/fetchErrorShow.js +8 -0
  138. package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.d.ts +3 -0
  139. package/fe/frontend/widgets/defaultPages/Schema/utils/permissions.js +3 -0
  140. package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.d.ts +3 -0
  141. package/fe/frontend/widgets/defaultPages/Schema/utils/schemaConversion.js +72 -0
  142. package/fe/frontend/widgets/defaultPages/Schema/utils/validator.d.ts +4 -0
  143. package/fe/frontend/widgets/defaultPages/Schema/utils/validator.js +31 -0
  144. package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.d.ts +10 -0
  145. package/fe/frontend/widgets/defaultPages/SidebarSlotPage/SidebarSlotContainer.js +31 -0
  146. package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.d.ts +3 -0
  147. package/fe/frontend/widgets/defaultPages/SidebarSlotPage/index.js +15 -0
  148. package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.d.ts +3 -0
  149. package/fe/frontend/widgets/defaultPages/SidebarSlotPageTmp.js +17 -0
  150. package/fe/frontend/widgets/defaultPages/SlotPage/index.d.ts +3 -0
  151. package/fe/frontend/widgets/defaultPages/SlotPage/index.js +24 -0
  152. package/fe/frontend/widgets/defaultPages/Todo.d.ts +3 -0
  153. package/fe/frontend/widgets/defaultPages/Todo.js +5 -0
  154. package/fe/frontend/widgets/hooks/useCurrentMenuData.d.ts +11 -0
  155. package/fe/frontend/widgets/hooks/useCurrentMenuData.js +20 -0
  156. package/fe/frontend/widgets/hooks/useRouterParams.d.ts +5 -0
  157. package/fe/frontend/widgets/hooks/useRouterParams.js +11 -0
  158. package/fe/frontend/widgets/store/mode.d.ts +16 -0
  159. package/fe/frontend/widgets/store/mode.js +36 -0
  160. package/fe/model/types/data/button.d.ts +23 -0
  161. package/fe/model/types/data/button.js +1 -0
  162. package/fe/model/types/data/component.d.ts +37 -0
  163. package/fe/model/types/data/component.js +1 -0
  164. package/fe/model/types/data/fetchInfo.d.ts +8 -0
  165. package/fe/model/types/data/fetchInfo.js +1 -0
  166. package/fe/model/types/data/schema.d.ts +47 -0
  167. package/fe/model/types/data/schema.js +1 -0
  168. package/fe/model/types/data/search.d.ts +7 -0
  169. package/fe/model/types/data/search.js +1 -0
  170. package/fe/model/types/menuType.d.ts +44 -0
  171. package/fe/model/types/menuType.js +1 -0
  172. package/fe/model/types/model.d.ts +20 -0
  173. package/fe/model/types/model.js +1 -0
  174. package/fe/packages/common/array/index.d.ts +7 -0
  175. package/fe/packages/common/array/index.js +40 -0
  176. package/fe/packages/common/cache/LRUCache.d.ts +13 -0
  177. package/fe/packages/common/cache/LRUCache.js +47 -0
  178. package/fe/packages/common/cache/index.d.ts +2 -0
  179. package/fe/packages/common/cache/index.js +1 -0
  180. package/fe/packages/common/guards/index.d.ts +9 -0
  181. package/fe/packages/common/guards/index.js +24 -0
  182. package/fe/packages/common/i18n/default.d.ts +87 -0
  183. package/fe/packages/common/i18n/default.js +85 -0
  184. package/fe/packages/common/i18n/en-US.d.ts +87 -0
  185. package/fe/packages/common/i18n/en-US.js +85 -0
  186. package/fe/packages/common/i18n/index.d.ts +19 -0
  187. package/fe/packages/common/i18n/index.js +142 -0
  188. package/fe/packages/common/i18n/locales.d.ts +8 -0
  189. package/fe/packages/common/i18n/locales.js +10 -0
  190. package/fe/packages/common/i18n/types.d.ts +47 -0
  191. package/fe/packages/common/i18n/types.js +1 -0
  192. package/fe/packages/common/index.d.ts +10 -0
  193. package/fe/packages/common/index.js +9 -0
  194. package/fe/packages/common/log/index.d.ts +33 -0
  195. package/fe/packages/common/log/index.js +176 -0
  196. package/fe/packages/common/number/index.d.ts +3 -0
  197. package/fe/packages/common/number/index.js +10 -0
  198. package/fe/packages/common/object/filterEmpty.d.ts +3 -0
  199. package/fe/packages/common/object/filterEmpty.js +33 -0
  200. package/fe/packages/common/object/index.d.ts +5 -0
  201. package/fe/packages/common/object/index.js +25 -0
  202. package/fe/packages/common/string/index.d.ts +4 -0
  203. package/fe/packages/common/string/index.js +17 -0
  204. package/fe/packages/common/types/index.d.ts +4 -0
  205. package/fe/packages/common/types/index.js +1 -0
  206. package/fe/packages/ui/react/components/Button/Button.d.ts +16 -30
  207. package/fe/packages/ui/react/components/Button/Button.js +53 -26
  208. package/fe/packages/ui/react/components/Button/SumbitButton.d.ts +2 -6
  209. package/fe/packages/ui/react/components/Button/SumbitButton.js +3 -14
  210. package/fe/packages/ui/react/components/Button/index.d.ts +1 -1
  211. package/fe/packages/ui/react/components/Checkbox/Checkbox.d.ts +1 -1
  212. package/fe/packages/ui/react/components/Checkbox/Checkbox.js +5 -3
  213. package/fe/packages/ui/react/components/{ConfirmDialog.d.ts → ConfirmDialog/ConfirmDialog.d.ts} +0 -8
  214. package/fe/packages/ui/react/components/ConfirmDialog/ConfirmDialog.js +11 -0
  215. package/fe/packages/ui/react/components/ConfirmDialog/index.d.ts +2 -0
  216. package/fe/packages/ui/react/components/ConfirmDialog/index.js +1 -0
  217. package/fe/packages/ui/react/components/DataTable/ActionBtn.d.ts +3 -1
  218. package/fe/packages/ui/react/components/DataTable/ActionBtn.js +85 -4
  219. package/fe/packages/ui/react/components/DataTable/{data-table.d.ts → index.d.ts} +10 -23
  220. package/fe/packages/ui/react/components/DataTable/{data-table.js → index.js} +57 -47
  221. package/fe/packages/ui/react/components/Date/Calendar.d.ts +0 -13
  222. package/fe/packages/ui/react/components/Date/Calendar.js +5 -13
  223. package/fe/packages/ui/react/components/Date/Date.d.ts +4 -13
  224. package/fe/packages/ui/react/components/Date/Date.js +70 -66
  225. package/fe/packages/ui/react/components/Date/LocaleContext.d.ts +0 -4
  226. package/fe/packages/ui/react/components/Date/LocaleContext.js +0 -4
  227. package/fe/packages/ui/react/components/Date/LocaleProvider.d.ts +0 -11
  228. package/fe/packages/ui/react/components/Date/LocaleProvider.js +0 -11
  229. package/fe/packages/ui/react/components/Date/TimePicker.js +3 -2
  230. package/fe/packages/ui/react/components/Date/dateLocaleStore.d.ts +0 -6
  231. package/fe/packages/ui/react/components/Date/dropdownPositioning.d.ts +3 -0
  232. package/fe/packages/ui/react/components/Date/dropdownPositioning.js +12 -0
  233. package/fe/packages/ui/react/components/Date/locales.d.ts +1 -19
  234. package/fe/packages/ui/react/components/Date/locales.js +7 -47
  235. package/fe/packages/ui/react/components/Drawer/Drawer.d.ts +23 -0
  236. package/fe/packages/ui/react/components/Drawer/Drawer.js +100 -0
  237. package/fe/packages/ui/react/components/Drawer/index.d.ts +3 -0
  238. package/fe/packages/ui/react/components/Drawer/index.js +1 -0
  239. package/fe/packages/ui/react/components/Dropdown/Dropdown.d.ts +24 -0
  240. package/fe/packages/ui/react/components/Dropdown/Dropdown.js +28 -0
  241. package/fe/packages/ui/react/components/Dropdown/index.d.ts +2 -0
  242. package/fe/packages/ui/react/components/Dropdown/index.js +1 -0
  243. package/fe/packages/ui/react/components/Form/Form.d.ts +0 -6
  244. package/fe/packages/ui/react/components/Form/Form.js +1 -1
  245. package/fe/packages/ui/react/components/Form/FormItem.d.ts +0 -21
  246. package/fe/packages/ui/react/components/Form/FormItem.js +2 -9
  247. package/fe/packages/ui/react/components/Form/SchemaForm/data.d.ts +45 -0
  248. package/fe/packages/ui/react/components/Form/{SchemeForm → SchemaForm}/data.js +8 -1
  249. package/fe/packages/ui/react/components/Form/SchemaForm/index.d.ts +60 -0
  250. package/fe/packages/ui/react/components/Form/SchemaForm/index.js +75 -0
  251. package/fe/packages/ui/react/components/Form/index.d.ts +1 -1
  252. package/fe/packages/ui/react/components/Form/index.js +1 -1
  253. package/fe/packages/ui/react/components/ImagePreview/ImagePreview.js +15 -20
  254. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.d.ts +0 -3
  255. package/fe/packages/ui/react/components/ImagePreview/PreviewImage.js +5 -2
  256. package/fe/packages/ui/react/components/Input/Input.d.ts +3 -21
  257. package/fe/packages/ui/react/components/Input/Input.js +5 -7
  258. package/fe/packages/ui/react/components/InputNumber/InputNumber.d.ts +26 -0
  259. package/fe/packages/ui/react/components/InputNumber/InputNumber.js +144 -0
  260. package/fe/packages/ui/react/components/InputNumber/index.d.ts +2 -0
  261. package/fe/packages/ui/react/components/InputNumber/index.js +1 -0
  262. package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.d.ts +30 -0
  263. package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.js +63 -0
  264. package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.d.ts +2 -0
  265. package/fe/packages/ui/react/components/InputNumber/inputNumberUtils.test.js +27 -0
  266. package/fe/packages/ui/react/components/Label/Label.d.ts +0 -29
  267. package/fe/packages/ui/react/components/Label/Label.js +2 -4
  268. package/fe/packages/ui/react/components/Menu/Menu.d.ts +18 -0
  269. package/fe/packages/ui/react/components/Menu/Menu.js +98 -0
  270. package/fe/packages/ui/react/components/Menu/MenuContext.d.ts +39 -0
  271. package/fe/packages/ui/react/components/Menu/MenuContext.js +97 -0
  272. package/fe/packages/ui/react/components/Menu/MenuItem.d.ts +3 -0
  273. package/fe/packages/ui/react/components/Menu/MenuItem.js +33 -0
  274. package/fe/packages/ui/react/components/Menu/SubMenu.d.ts +3 -0
  275. package/fe/packages/ui/react/components/Menu/SubMenu.js +124 -0
  276. package/fe/packages/ui/react/components/Menu/index.d.ts +9 -0
  277. package/fe/packages/ui/react/components/Menu/index.js +5 -0
  278. package/fe/packages/ui/react/components/Menu/menuTypes.d.ts +58 -0
  279. package/fe/packages/ui/react/components/Menu/menuTypes.js +1 -0
  280. package/fe/packages/ui/react/components/Menu/utils.d.ts +2 -0
  281. package/fe/packages/ui/react/components/Menu/utils.js +7 -0
  282. package/fe/packages/ui/react/components/Message/Message.d.ts +0 -7
  283. package/fe/packages/ui/react/components/Message/Message.js +4 -4
  284. package/fe/packages/ui/react/components/Message/MessageManager.js +0 -8
  285. package/fe/packages/ui/react/components/Modal/Modal.d.ts +3 -7
  286. package/fe/packages/ui/react/components/Modal/Modal.js +6 -44
  287. package/fe/packages/ui/react/components/Modal/ModalManager.d.ts +0 -12
  288. package/fe/packages/ui/react/components/Modal/ModalManager.js +5 -7
  289. package/fe/packages/ui/react/components/Overlay/Overlay.d.ts +20 -0
  290. package/fe/packages/ui/react/components/Overlay/Overlay.js +53 -0
  291. package/fe/packages/ui/react/components/Overlay/index.d.ts +3 -0
  292. package/fe/packages/ui/react/components/Overlay/index.js +1 -0
  293. package/fe/packages/ui/react/components/{Pagination.d.ts → Pagination/Pagination.d.ts} +0 -7
  294. package/fe/packages/ui/react/components/{Pagination.js → Pagination/Pagination.js} +5 -12
  295. package/fe/packages/ui/react/components/Pagination/index.d.ts +2 -0
  296. package/fe/packages/ui/react/components/Pagination/index.js +1 -0
  297. package/fe/packages/ui/react/components/Popup/Popup.d.ts +26 -0
  298. package/fe/packages/ui/react/components/Popup/Popup.js +69 -0
  299. package/fe/packages/ui/react/components/Popup/index.d.ts +2 -0
  300. package/fe/packages/ui/react/components/Popup/index.js +1 -0
  301. package/fe/packages/ui/react/components/Search/Search.d.ts +2 -5
  302. package/fe/packages/ui/react/components/Search/Search.js +3 -3
  303. package/fe/packages/ui/react/components/Select/Select.d.ts +2 -2
  304. package/fe/packages/ui/react/components/Select/Select.js +52 -113
  305. package/fe/packages/ui/react/components/Select/dropdownPositioning.d.ts +3 -0
  306. package/fe/packages/ui/react/components/Select/dropdownPositioning.js +13 -0
  307. package/fe/packages/ui/react/components/Skeleton/Skeleton.d.ts +0 -15
  308. package/fe/packages/ui/react/components/Skeleton/Skeleton.js +3 -3
  309. package/fe/packages/ui/react/components/Switch/Switch.js +3 -1
  310. package/fe/packages/ui/react/components/TableSearch/TableSearch.d.ts +5 -41
  311. package/fe/packages/ui/react/components/TableSearch/TableSearch.js +21 -22
  312. package/fe/packages/ui/react/components/TableSearch/lang.js +5 -14
  313. package/fe/packages/ui/react/components/Textarea/Textarea.d.ts +21 -0
  314. package/fe/packages/ui/react/components/Textarea/Textarea.js +36 -0
  315. package/fe/packages/ui/react/components/Textarea/index.d.ts +2 -0
  316. package/fe/packages/ui/react/components/Textarea/index.js +1 -0
  317. package/fe/packages/ui/react/components/Tooltip/Tooltip.d.ts +9 -0
  318. package/fe/packages/ui/react/components/Tooltip/Tooltip.js +71 -0
  319. package/fe/packages/ui/react/components/Tooltip/index.d.ts +2 -0
  320. package/fe/packages/ui/react/components/Tooltip/index.js +1 -0
  321. package/fe/packages/ui/react/components/{TreeSelect.d.ts → TreeSelect/TreeSelect.d.ts} +0 -6
  322. package/fe/packages/ui/react/components/{TreeSelect.js → TreeSelect/TreeSelect.js} +9 -17
  323. package/fe/packages/ui/react/components/TreeSelect/index.d.ts +2 -0
  324. package/fe/packages/ui/react/components/TreeSelect/index.js +1 -0
  325. package/fe/packages/ui/react/components/Upload/ImageUpload.js +18 -6
  326. package/fe/packages/ui/react/components/Upload/Upload.d.ts +0 -27
  327. package/fe/packages/ui/react/components/Upload/Upload.js +2 -1
  328. package/fe/packages/ui/react/components/{breadcrumb.js → breadcrumb/breadcrumb.js} +15 -21
  329. package/fe/packages/ui/react/components/breadcrumb/index.d.ts +2 -0
  330. package/fe/packages/ui/react/components/breadcrumb/index.js +1 -0
  331. package/fe/packages/ui/react/components/hooks/useDropdownPositioning.d.ts +43 -0
  332. package/fe/packages/ui/react/components/hooks/useDropdownPositioning.js +123 -0
  333. package/fe/packages/ui/react/components/hooks/useInputController.d.ts +0 -3
  334. package/fe/packages/ui/react/components/hooks/useInputController.js +0 -7
  335. package/fe/packages/ui/react/components/index.d.ts +7 -1
  336. package/fe/packages/ui/react/components/index.js +7 -1
  337. package/fe/packages/ui/react/components/table/index.d.ts +2 -0
  338. package/fe/packages/ui/react/components/table/index.js +1 -0
  339. package/fe/packages/ui/react/components/table/table.js +20 -0
  340. package/fe/packages/ui/react/components/testPage/MenuTestPage.d.ts +2 -0
  341. package/fe/packages/ui/react/components/testPage/MenuTestPage.js +101 -0
  342. package/fe/packages/ui/react/components/testPage/index.js +251 -81
  343. package/fe/packages/ui/react/hooks/useExecuteOnce.d.ts +12 -0
  344. package/fe/packages/ui/react/hooks/useExecuteOnce.js +36 -0
  345. package/fe/packages/ui/react/hooks/useInit.d.ts +1 -1
  346. package/fe/packages/ui/react/hooks/useInit.js +1 -1
  347. package/fe/packages/ui/react/hooks/useLanguage.d.ts +1 -6
  348. package/fe/packages/ui/react/hooks/useRefState.d.ts +18 -0
  349. package/fe/packages/ui/react/hooks/useRefState.js +28 -0
  350. package/fe/packages/ui/react/hooks/useWatch.d.ts +15 -0
  351. package/fe/packages/ui/react/hooks/useWatch.js +87 -0
  352. package/fe/packages/ui/react/hooks/useWatch.test.d.ts +2 -0
  353. package/fe/packages/ui/react/hooks/useWatch.test.js +22 -0
  354. package/fe/packages/ui/react/i18n/I18nProvider.d.ts +13 -0
  355. package/fe/packages/ui/react/i18n/I18nProvider.js +25 -0
  356. package/fe/packages/ui/react/i18n/index.d.ts +4 -0
  357. package/fe/packages/ui/react/i18n/index.js +3 -0
  358. package/fe/packages/ui/react/i18n/useI18n.d.ts +9 -0
  359. package/fe/packages/ui/react/i18n/useI18n.js +14 -0
  360. package/fe/packages/ui/react/index.css +238 -0
  361. package/fe/packages/ui/react/index.d.ts +2 -0
  362. package/fe/packages/ui/react/index.js +2 -2
  363. package/fe/packages/ui/react/lib/createStoreHook.d.ts +9 -0
  364. package/fe/packages/ui/react/lib/createStoreHook.js +6 -0
  365. package/fe/packages/ui/react/lib/export.d.ts +2 -46
  366. package/fe/packages/ui/react/lib/export.js +0 -40
  367. package/fe/packages/ui/react/lib/utils.d.ts +0 -24
  368. package/fe/packages/ui/react/lib/utils.js +0 -25
  369. package/fe/packages/ui/react/stores/breadcrumb.js +0 -2
  370. package/fe/packages/ui/react/stores/language.d.ts +3 -12
  371. package/fe/packages/ui/react/stores/language.js +2 -51
  372. package/fe/typings/type.d.ts +5 -0
  373. package/fe/typings/type.js +1 -0
  374. package/package.json +14 -2
  375. package/types/app/controller/base.d.ts +3 -3
  376. package/types/app/router/view.d.ts +2 -3
  377. package/types/app/service/project.d.ts +29 -4
  378. package/types/app/type.d.ts +1 -0
  379. package/types/app/typings.d.ts +12 -21
  380. package/types/bundler/defaultAlias.d.ts +3 -0
  381. package/types/bundler/utils.d.ts +1 -1
  382. package/types/config/config.default.d.ts +14 -0
  383. package/types/packages/common/LRUCache.d.ts +1 -0
  384. package/types/packages/common/array/index.d.ts +6 -0
  385. package/types/packages/common/cache/LRUCache.d.ts +12 -0
  386. package/types/packages/common/cache/index.d.ts +1 -0
  387. package/types/packages/common/guards/index.d.ts +8 -0
  388. package/types/packages/common/i18n/default.d.ts +86 -0
  389. package/types/packages/common/i18n/en-US.d.ts +86 -0
  390. package/types/packages/common/i18n/index.d.ts +18 -0
  391. package/types/packages/common/i18n/locales.d.ts +7 -0
  392. package/types/packages/common/i18n/types.d.ts +46 -0
  393. package/types/packages/common/index.d.ts +9 -0
  394. package/types/packages/common/log/index.d.ts +32 -0
  395. package/types/packages/common/number/index.d.ts +2 -0
  396. package/types/packages/common/object/filterEmpty.d.ts +2 -0
  397. package/types/packages/common/object/filtereEmpty.d.ts +1 -0
  398. package/types/packages/common/object/index.d.ts +4 -0
  399. package/types/packages/common/string/index.d.ts +3 -0
  400. package/types/packages/common/types/index.d.ts +3 -0
  401. package/types/packages/core/index.d.ts +1 -1
  402. package/types/packages/core/loader/router.d.ts +1 -1
  403. package/types/packages/core/types.d.ts +12 -3
  404. package/fe/packages/ui/react/components/ConfirmDialog.js +0 -9
  405. package/fe/packages/ui/react/components/Dropdown.d.ts +0 -16
  406. package/fe/packages/ui/react/components/Dropdown.js +0 -54
  407. package/fe/packages/ui/react/components/Form/SchemeForm/data.d.ts +0 -51
  408. package/fe/packages/ui/react/components/Form/SchemeForm/index.d.ts +0 -152
  409. package/fe/packages/ui/react/components/Form/SchemeForm/index.js +0 -69
  410. package/fe/packages/ui/react/components/Textarea.d.ts +0 -59
  411. package/fe/packages/ui/react/components/Textarea.js +0 -35
  412. package/fe/packages/ui/react/components/Tooltip.d.ts +0 -25
  413. package/fe/packages/ui/react/components/Tooltip.js +0 -118
  414. package/fe/packages/ui/react/components/table.js +0 -20
  415. package/fe/packages/ui/react/locales/index.d.ts +0 -8
  416. package/fe/packages/ui/react/locales/index.js +0 -6
  417. /package/fe/packages/ui/react/components/{breadcrumb.d.ts → breadcrumb/breadcrumb.d.ts} +0 -0
  418. /package/fe/packages/ui/react/components/{table.d.ts → table/table.d.ts} +0 -0
@@ -1,24 +1,20 @@
1
1
  import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
2
- import { cn } from '../lib/utils';
2
+ import { cn } from '../../lib/utils';
3
3
  import { ChevronLeft, ChevronRight } from 'lucide-react';
4
- import { Button } from './Button';
5
- import { Select } from './Select';
4
+ import { Button } from '../Button';
5
+ import { Select } from '../Select';
6
6
  export function Pagination({ current, pageSize, total, onChange, onPageSizeChange, pageSizeOptions = [10, 20, 50, 100], className, }) {
7
7
  const totalPages = Math.ceil(total / pageSize);
8
- // 生成页码数组
9
8
  const getPageNumbers = () => {
10
9
  const pages = [];
11
- const maxVisible = 7; // 最多显示7个页码
10
+ const maxVisible = 7;
12
11
  if (totalPages <= maxVisible) {
13
- // 总页数少于等于7,显示所有页码
14
12
  for (let i = 1; i <= totalPages; i++) {
15
13
  pages.push(i);
16
14
  }
17
15
  }
18
16
  else {
19
- // 总页数大于7,需要省略
20
17
  if (current <= 4) {
21
- // 当前页在前面
22
18
  for (let i = 1; i <= 5; i++) {
23
19
  pages.push(i);
24
20
  }
@@ -26,7 +22,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
26
22
  pages.push(totalPages);
27
23
  }
28
24
  else if (current >= totalPages - 3) {
29
- // 当前页在后面
30
25
  pages.push(1);
31
26
  pages.push('...');
32
27
  for (let i = totalPages - 4; i <= totalPages; i++) {
@@ -34,7 +29,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
34
29
  }
35
30
  }
36
31
  else {
37
- // 当前页在中间
38
32
  pages.push(1);
39
33
  pages.push('...');
40
34
  for (let i = current - 1; i <= current + 1; i++) {
@@ -64,7 +58,6 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
64
58
  const handlePageSizeChange = (newPageSize) => {
65
59
  if (newPageSize !== undefined && typeof newPageSize === 'number' && newPageSize !== pageSize && onPageSizeChange) {
66
60
  onPageSizeChange(newPageSize);
67
- // 当改变 pageSize 时,通常需要重置到第一页
68
61
  if (current !== 1) {
69
62
  onChange(1);
70
63
  }
@@ -72,7 +65,7 @@ export function Pagination({ current, pageSize, total, onChange, onPageSizeChang
72
65
  };
73
66
  if (totalPages === 0)
74
67
  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) => {
68
+ return (_jsxs("div", { className: cn('tc-ui-pagination 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
69
  if (page === '...') {
77
70
  return (_jsx("span", { className: "px-2 text-muted-foreground", children: "..." }, `ellipsis-${index}`));
78
71
  }
@@ -0,0 +1,2 @@
1
+ export * from './Pagination';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ export * from './Pagination';
@@ -0,0 +1,26 @@
1
+ import type { CSSProperties, ReactNode, RefObject } from "react";
2
+ import { type DropdownPlacement, type DropdownPosition, type DropdownPositioningStrategy, type UseDropdownPositioningResult } from "../hooks/useDropdownPositioning";
3
+ export interface PopupProps {
4
+ open: boolean;
5
+ anchorRef: RefObject<HTMLElement | null>;
6
+ children: ReactNode;
7
+ className?: string;
8
+ style?: CSSProperties;
9
+ placement?: DropdownPlacement;
10
+ offset?: number;
11
+ keepMounted?: boolean;
12
+ closeOnClickOutside?: boolean;
13
+ closeOnEscape?: boolean;
14
+ matchAnchorWidth?: boolean;
15
+ position?: DropdownPosition;
16
+ positioning?: UseDropdownPositioningResult;
17
+ strategy?: DropdownPositioningStrategy;
18
+ contentRef?: RefObject<HTMLDivElement | null>;
19
+ container?: HTMLElement;
20
+ positionMode?: "fixed" | "absolute";
21
+ hoverBridge?: number;
22
+ hoverBridgePlacement?: "auto" | "horizontal";
23
+ onOpenChange?: (open: boolean) => void;
24
+ }
25
+ export declare function Popup({ open, anchorRef, children, className, style, placement, offset, keepMounted, closeOnClickOutside, closeOnEscape, matchAnchorWidth, position, positioning, strategy, contentRef, container, positionMode, hoverBridge, hoverBridgePlacement, onOpenChange, }: PopupProps): import("react").ReactPortal | null;
26
+ //# sourceMappingURL=Popup.d.ts.map
@@ -0,0 +1,69 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from "../../lib/utils";
3
+ import { useEffect, useMemo, useRef } from "react";
4
+ import { createPortal } from "react-dom";
5
+ import { getDefaultDropdownPosition, useDropdownPositioning, } from "../hooks/useDropdownPositioning";
6
+ const DEFAULT_POPUP_CLASSNAME = cn("fixed z-[9999]", "bg-background rounded-lg shadow-lg border border-gray-200", "animate-in fade-in-0 zoom-in-95");
7
+ const canUseDocument = () => typeof document !== "undefined";
8
+ export function Popup({ open, anchorRef, children, className, style, placement = "bottom-end", offset = 8, keepMounted = false, closeOnClickOutside = true, closeOnEscape = true, matchAnchorWidth = false, position, positioning, strategy = getDefaultDropdownPosition, contentRef, container, positionMode = "fixed", hoverBridge = 0, hoverBridgePlacement = "auto", onOpenChange, }) {
9
+ const internalContentRef = useRef(null);
10
+ const panelRef = contentRef ?? internalContentRef;
11
+ const containerRef = useMemo(() => ({ current: container ?? null }), [container]);
12
+ const internalPositioning = useDropdownPositioning({
13
+ open,
14
+ anchorRef,
15
+ contentRef: panelRef,
16
+ placement,
17
+ offset,
18
+ matchAnchorWidth,
19
+ strategy,
20
+ containerRef,
21
+ positionMode,
22
+ });
23
+ const resolvedPositioning = position
24
+ ? null
25
+ : (positioning ?? internalPositioning);
26
+ useEffect(() => {
27
+ if (!open || !closeOnClickOutside)
28
+ return;
29
+ const handleClickOutside = (event) => {
30
+ const target = event.target;
31
+ const clickedAnchor = anchorRef.current?.contains(target);
32
+ const clickedPanel = panelRef.current?.contains(target);
33
+ if (!clickedAnchor && !clickedPanel) {
34
+ onOpenChange?.(false);
35
+ }
36
+ };
37
+ document.addEventListener("mousedown", handleClickOutside);
38
+ return () => document.removeEventListener("mousedown", handleClickOutside);
39
+ }, [anchorRef, closeOnClickOutside, onOpenChange, open, panelRef]);
40
+ useEffect(() => {
41
+ if (!open || !closeOnEscape)
42
+ return;
43
+ const handleKeyDown = (event) => {
44
+ if (event.key === "Escape") {
45
+ onOpenChange?.(false);
46
+ }
47
+ };
48
+ document.addEventListener("keydown", handleKeyDown);
49
+ return () => document.removeEventListener("keydown", handleKeyDown);
50
+ }, [closeOnEscape, onOpenChange, open]);
51
+ const mergedStyle = useMemo(() => ({
52
+ ...resolvedPositioning?.position,
53
+ ...position,
54
+ ...style,
55
+ }), [position, resolvedPositioning?.position, style]);
56
+ const showHorizontalHoverBridge = hoverBridge > 0 &&
57
+ (placement.startsWith("right") || placement.startsWith("left"));
58
+ const showBothHorizontalHoverBridges = showHorizontalHoverBridge && hoverBridgePlacement === "horizontal";
59
+ if (!keepMounted && !open) {
60
+ return null;
61
+ }
62
+ const portalContainer = container ?? (canUseDocument() ? document.body : undefined);
63
+ if (!portalContainer) {
64
+ return null;
65
+ }
66
+ return createPortal(_jsxs("div", { ref: panelRef, className: cn("tc-ui-popup", DEFAULT_POPUP_CLASSNAME, positionMode === "absolute" && "absolute", !resolvedPositioning?.ready && "invisible", keepMounted && !open && "hidden", className), style: mergedStyle, children: [hoverBridge > 0 && (_jsx("div", { "aria-hidden": "true", className: cn("absolute bg-transparent", placement.startsWith("bottom") && "left-0 right-0 top-0 -translate-y-full", placement.startsWith("top") && "bottom-0 left-0 right-0 translate-y-full", placement.startsWith("right") && "bottom-0 left-0 top-0 -translate-x-full", placement.startsWith("left") && "bottom-0 right-0 top-0 translate-x-full"), style: placement.startsWith("right") || placement.startsWith("left")
67
+ ? { width: hoverBridge }
68
+ : { height: hoverBridge } })), showBothHorizontalHoverBridges && (_jsx("div", { "aria-hidden": "true", className: "absolute bottom-0 right-0 top-0 translate-x-full bg-transparent", style: { width: hoverBridge } })), children] }), portalContainer);
69
+ }
@@ -0,0 +1,2 @@
1
+ export * from './Popup';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ export * from './Popup';
@@ -1,14 +1,11 @@
1
1
  import type { MOmit } from '../../types';
2
2
  import type { FormInstance } from 'rc-field-form';
3
3
  import { type ReactNode } from 'react';
4
- import { type FormFieldScheme } from '../Form';
4
+ import { type FormFieldSchema } from '../Form';
5
5
  export type SearchProps<T> = {
6
6
  defaultValue?: T;
7
- schemes: MOmit<FormFieldScheme<T>, 'rules' | 'required'>[];
7
+ schemas: MOmit<FormFieldSchema<T>, 'rules' | 'required'>[];
8
8
  children?: ReactNode;
9
- /**
10
- * 获取表单实例的回调
11
- */
12
9
  getForm?: (form: FormInstance<T>) => void;
13
10
  btnsClassName?: string;
14
11
  };
@@ -1,12 +1,12 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { cn } from '../../lib/utils';
3
3
  import { useMemo } from 'react';
4
- import { SchemeForm } from '../Form';
4
+ import { SchemaForm } from '../Form';
5
5
  const Search = (props) => {
6
- const { defaultValue: pDefaultValue, schemes, children, getForm, btnsClassName } = props;
6
+ const { defaultValue: pDefaultValue, schemas, children, getForm, btnsClassName } = props;
7
7
  const defaultValue = useMemo(() => {
8
8
  return pDefaultValue;
9
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 })] }));
10
+ return (_jsxs("div", { className: "tc-ui-search flex items-end justify-between gap-4 flex-wrap", children: [_jsx(SchemaForm, { preserve: true, layout: "horizontal", schemas: schemas, 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
11
  };
12
12
  export default Search;
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  export type SelectOption = {
3
3
  label: React.ReactNode;
4
4
  value: string | number;
5
+ searchText?: string;
5
6
  };
6
7
  export type SelectProps = {
7
8
  options: SelectOption[];
@@ -11,10 +12,9 @@ export type SelectProps = {
11
12
  onChange?: (value: string | number | undefined) => void;
12
13
  className?: string;
13
14
  disabled?: boolean;
14
- /** 开启清除 默认开启*/
15
15
  clearable?: boolean;
16
- /** 是否支持搜索 默认开启 */
17
16
  searchable?: boolean;
17
+ getPopupContainer?: 'parent' | (() => HTMLElement);
18
18
  };
19
19
  declare const Select: React.ForwardRefExoticComponent<SelectProps & React.RefAttributes<HTMLDivElement>>;
20
20
  export { Select };
@@ -1,18 +1,39 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useI18n } from '../../i18n';
2
3
  import { cn } from '../../lib/utils';
3
4
  import { ChevronUp, X } from 'lucide-react';
4
5
  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) => {
6
+ import { Button } from '../Button';
7
+ import { Input } from '../Input';
8
+ import { Popup } from '../Popup';
9
+ import { useDropdownPositioning } from '../hooks/useDropdownPositioning';
10
+ import { getSelectDropdownPosition } from './dropdownPositioning';
11
+ const Select = forwardRef(({ options, value: controlledValue, defaultValue, placeholder, onChange, className, disabled, clearable = true, searchable = true, getPopupContainer, }, ref) => {
12
+ const t = useI18n();
7
13
  const [isOpen, setIsOpen] = useState(false);
8
14
  const [internalValue, setInternalValue] = useState(defaultValue);
9
15
  const [isHover, setIsHover] = useState(false);
10
16
  const [searchTerm, setSearchTerm] = useState('');
11
- const [position, setPosition] = useState({ top: 0, left: 0, width: 0 });
17
+ const rootRef = useRef(null);
12
18
  const selectRef = useRef(null);
13
19
  const dropdownRef = useRef(null);
14
20
  const inputRef = useRef(null);
15
- // 合并 refs
21
+ const popupContainerRef = useRef(null);
22
+ const isParentPopupContainer = getPopupContainer === 'parent';
23
+ popupContainerRef.current = isParentPopupContainer ? (rootRef.current?.parentElement ?? null) : null;
24
+ useEffect(() => {
25
+ if (!isParentPopupContainer)
26
+ return;
27
+ const container = rootRef.current?.parentElement;
28
+ popupContainerRef.current = container ?? null;
29
+ if (!container || window.getComputedStyle(container).position !== 'static')
30
+ return;
31
+ const previousPosition = container.style.position;
32
+ container.style.position = 'relative';
33
+ return () => {
34
+ container.style.position = previousPosition;
35
+ };
36
+ }, [isParentPopupContainer]);
16
37
  const setRefs = useCallback((node) => {
17
38
  selectRef.current = node;
18
39
  if (typeof ref === 'function') {
@@ -24,119 +45,42 @@ const Select = forwardRef(({ options, value: controlledValue, defaultValue, plac
24
45
  }, [ref]);
25
46
  const isControlled = controlledValue !== undefined;
26
47
  const value = isControlled ? controlledValue : internalValue;
27
- // 获取当前选中的选项
28
48
  const selectedOption = options.find((opt) => opt.value === value);
29
49
  const displayText = selectedOption ? selectedOption.label : placeholder || '';
30
50
  const filteredOptions = useMemo(() => {
31
51
  if (!searchable || !searchTerm.trim())
32
52
  return options;
33
53
  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,
54
+ return options.filter((opt) => {
55
+ const searchText = opt.searchText ??
56
+ (typeof opt.label === 'string' || typeof opt.label === 'number' ? String(opt.label) : '');
57
+ return searchText.toLowerCase().includes(lower);
110
58
  });
111
- }, [filteredOptions.length]);
112
- // 展开时更新位置并获取焦点
59
+ }, [options, searchTerm, searchable]);
60
+ const positioning = useDropdownPositioning({
61
+ open: isOpen,
62
+ anchorRef: selectRef,
63
+ contentRef: dropdownRef,
64
+ placement: 'bottom-start',
65
+ offset: 4,
66
+ matchAnchorWidth: true,
67
+ strategy: getSelectDropdownPosition,
68
+ estimateSize: () => ({
69
+ height: Math.min(filteredOptions.length * 40 + 8, 240),
70
+ }),
71
+ watchDeps: [filteredOptions.length, searchTerm, searchable],
72
+ containerRef: isParentPopupContainer ? popupContainerRef : undefined,
73
+ positionMode: isParentPopupContainer ? 'absolute' : 'fixed',
74
+ });
113
75
  useEffect(() => {
114
76
  if (isOpen) {
115
- // 使用双重 requestAnimationFrame 确保 DOM 已完全渲染
116
77
  requestAnimationFrame(() => {
117
- requestAnimationFrame(() => {
118
- updatePosition();
119
- if (searchable) {
120
- inputRef.current?.focus();
121
- }
122
- });
78
+ if (searchable) {
79
+ inputRef.current?.focus();
80
+ }
123
81
  });
124
82
  }
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]);
83
+ }, [isOpen, searchable]);
140
84
  const handleToggle = useCallback(() => {
141
85
  if (disabled)
142
86
  return;
@@ -159,22 +103,17 @@ const Select = forwardRef(({ options, value: controlledValue, defaultValue, plac
159
103
  event.stopPropagation();
160
104
  if (disabled)
161
105
  return;
162
- // 清除时 重置内外状态
163
106
  setInternalValue(undefined);
164
107
  onChange?.(undefined);
165
108
  }, [disabled, onChange]);
166
109
  const handleSearchChange = useCallback((event) => {
167
110
  setSearchTerm(event.target.value);
168
111
  }, []);
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) => {
112
+ const popupContainer = getPopupContainer === 'parent' ? (rootRef.current?.parentElement ?? undefined) : getPopupContainer?.();
113
+ return (_jsxs("div", { ref: rootRef, className: cn('tc-ui-select relative w-full', 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: (_, e) => handleSearchChange(e), onClick: (e) => e.stopPropagation(), placeholder: typeof displayText === 'string' ? displayText : placeholder, className: "min-w-0 flex-1", inputClassName: cn('h-5 min-w-0 flex-1 rounded-none border-0 bg-transparent px-0 py-0 text-left leading-5 outline-none', 'placeholder:text-muted-foreground', disabled && 'text-muted-foreground cursor-not-allowed'), disabled: disabled })) : (_jsx("span", { className: cn('min-h-5 min-w-0 flex-1 text-left truncate leading-5', disabled ? 'text-muted-foreground' : !selectedOption && 'text-muted-foreground'), children: displayText })), clearable && !disabled && value !== undefined && isHover ? (_jsx(Button, { variant: "text", type: "button", onClick: handleClear, className: "ml-2 flex items-center justify-center text-muted-foreground hover:text-foreground cursor-pointer", "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') }))] }), _jsx(Popup, { open: isOpen, anchorRef: selectRef, contentRef: dropdownRef, positioning: positioning, keepMounted: true, onOpenChange: setIsOpen, container: popupContainer, positionMode: isParentPopupContainer ? 'absolute' : 'fixed', className: cn('z-[1000] w-full rounded-lg bg-background shadow-lg', 'border border-border', 'max-h-60 overflow-auto'), children: _jsx("div", { className: cn('w-full', !isOpen && 'hidden'), children: _jsx("div", { className: "p-1", children: filteredOptions.length > 0 ? (filteredOptions.map((option) => {
175
114
  const isSelected = option.value === value;
176
115
  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)] }));
116
+ })) : (_jsx("div", { className: "px-4 py-2 text-sm text-muted-foreground text-center", children: t('components.select.empty') })) }) }) })] }));
178
117
  });
179
118
  Select.displayName = 'Select';
180
119
  export { Select };
@@ -0,0 +1,3 @@
1
+ import type { DropdownPositioningStrategy } from '../hooks/useDropdownPositioning';
2
+ export declare const getSelectDropdownPosition: DropdownPositioningStrategy;
3
+ //# sourceMappingURL=dropdownPositioning.d.ts.map
@@ -0,0 +1,13 @@
1
+ export const getSelectDropdownPosition = ({ anchorRect, contentRect, containerRect, viewportHeight, offset, matchAnchorWidth, }) => {
2
+ const dropdownHeight = contentRect?.height ?? 240;
3
+ const spaceBelow = viewportHeight - anchorRect.bottom;
4
+ const spaceAbove = anchorRect.top;
5
+ const shouldPlaceTop = spaceBelow < dropdownHeight && spaceAbove > spaceBelow;
6
+ const containerTop = containerRect?.top ?? 0;
7
+ const containerLeft = containerRect?.left ?? 0;
8
+ return {
9
+ top: (shouldPlaceTop ? anchorRect.top - dropdownHeight - offset : anchorRect.bottom + offset) - containerTop,
10
+ left: anchorRect.left - containerLeft,
11
+ width: matchAnchorWidth ? anchorRect.width : undefined,
12
+ };
13
+ };
@@ -1,24 +1,9 @@
1
1
  import type { HTMLAttributes } from 'react';
2
2
  export type SkeletonMode = 'pageloading' | 'tableloading' | 'componentsloading';
3
3
  export interface SkeletonProps extends HTMLAttributes<HTMLDivElement> {
4
- /**
5
- * 骨架屏模式
6
- * @default 'componentsloading'
7
- */
8
4
  mode?: SkeletonMode;
9
- /**
10
- * 行数(仅对 pageloading 和 tableloading 有效)
11
- */
12
5
  rows?: number;
13
- /**
14
- * 是否显示标题骨架(仅对 pageloading 有效)
15
- * @default true
16
- */
17
6
  showTitle?: boolean;
18
- /**
19
- * 是否显示操作栏骨架(仅对 pageloading 有效)
20
- * @default true
21
- */
22
7
  showActions?: boolean;
23
8
  }
24
9
  export declare const Skeleton: {
@@ -7,8 +7,8 @@ const PageLoadingSkeleton = ({ rows = 5, showTitle = true, showActions = true })
7
7
  return (_jsxs("div", { className: "w-full space-y-6 p-6", children: [showTitle && (_jsxs("div", { className: "flex items-center justify-between", children: [_jsx(SkeletonItem, { className: "h-8 w-48" }), showActions && (_jsxs("div", { className: "flex gap-3", children: [_jsx(SkeletonItem, { className: "h-10 w-24" }), _jsx(SkeletonItem, { className: "h-10 w-24" })] }))] })), _jsxs("div", { className: "flex gap-4", children: [_jsx(SkeletonItem, { className: "h-10 flex-1" }), _jsx(SkeletonItem, { className: "h-10 w-24" }), _jsx(SkeletonItem, { className: "h-10 w-24" })] }), _jsx("div", { className: "space-y-4", children: Array.from({ length: rows }).map((_, index) => (_jsxs("div", { className: "flex gap-4", children: [_jsx(SkeletonItem, { className: "h-20 flex-1" }), _jsx(SkeletonItem, { className: "h-20 w-32" }), _jsx(SkeletonItem, { className: "h-20 w-32" })] }, index))) }), _jsxs("div", { className: "flex items-center justify-between", children: [_jsx(SkeletonItem, { className: "h-4 w-32" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(SkeletonItem, { className: "h-8 w-8" }), _jsx(SkeletonItem, { className: "h-8 w-8" }), _jsx(SkeletonItem, { className: "h-8 w-8" })] })] })] }));
8
8
  };
9
9
  const TableLoadingSkeleton = ({ rows = 5 }) => {
10
- const columnCount = 6; // 默认列数,可以根据需要调整
11
- return (_jsx("div", { className: "w-full", children: _jsx("div", { className: "bg-white rounded-[20px] overflow-hidden", children: _jsxs(Table, { containerClassName: "rounded-b-none", children: [_jsx(TableHeader, { children: _jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, index) => (_jsx(TableHead, { children: _jsx(SkeletonText, { width: index === 0 ? 120 : index === columnCount - 1 ? 80 : 150 }) }, index))) }) }), _jsx(TableBody, { children: Array.from({ length: rows }).map((_, rowIndex) => (_jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, colIndex) => (_jsx(TableCell, { children: colIndex === columnCount - 1 ? (_jsxs("div", { className: "flex gap-2", children: [_jsx(SkeletonItem, { className: "h-8 w-16" }), _jsx(SkeletonItem, { className: "h-8 w-16" })] })) : (_jsx(SkeletonText, { width: colIndex === 0 ? 120 : colIndex === 1 ? '80%' : 150 })) }, colIndex))) }, rowIndex))) })] }) }) }));
10
+ const columnCount = 6;
11
+ return (_jsx("div", { className: "w-full", children: _jsx("div", { className: "bg-background rounded-[20px] overflow-hidden", children: _jsxs(Table, { containerClassName: "rounded-b-none", children: [_jsx(TableHeader, { children: _jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, index) => (_jsx(TableHead, { children: _jsx(SkeletonText, { width: index === 0 ? 120 : index === columnCount - 1 ? 80 : 150 }) }, index))) }) }), _jsx(TableBody, { children: Array.from({ length: rows }).map((_, rowIndex) => (_jsx(TableRow, { children: Array.from({ length: columnCount }).map((_, colIndex) => (_jsx(TableCell, { children: colIndex === columnCount - 1 ? (_jsxs("div", { className: "flex gap-2", children: [_jsx(SkeletonItem, { className: "h-8 w-16" }), _jsx(SkeletonItem, { className: "h-8 w-16" })] })) : (_jsx(SkeletonText, { width: colIndex === 0 ? 120 : colIndex === 1 ? '80%' : 150 })) }, colIndex))) }, rowIndex))) })] }) }) }));
12
12
  };
13
13
  const ComponentsLoadingSkeleton = ({ rows = 3 }) => {
14
14
  return (_jsx("div", { className: "w-full space-y-3", children: Array.from({ length: rows }).map((_, index) => (_jsx(SkeletonItem, { className: "h-4 w-full" }, index))) }));
@@ -26,6 +26,6 @@ export const Skeleton = ({ mode = 'componentsloading', className, rows, showTitl
26
26
  return _jsx(ComponentsLoadingSkeleton, { rows: rows });
27
27
  }
28
28
  };
29
- return (_jsx("div", { className: cn('w-full', className), ...props, children: renderSkeleton() }));
29
+ return (_jsx("div", { className: cn('tc-ui-skeleton w-full', className), ...props, children: renderSkeleton() }));
30
30
  };
31
31
  Skeleton.displayName = 'Skeleton';
@@ -14,7 +14,9 @@ const Switch = forwardRef(({ checked: controlledChecked, defaultChecked, onChang
14
14
  }
15
15
  onChange?.(newChecked);
16
16
  };
17
- return (_jsx("button", { ref: ref, type: "button", role: "switch", "aria-checked": checked, disabled: disabled, onClick: handleToggle, className: cn('relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-200', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-offset-2', disabled && 'cursor-not-allowed opacity-50', !disabled && 'cursor-pointer', checked ? 'bg-[hsl(var(--theme-primary))]' : 'bg-gray-300', className), children: _jsx("span", { className: cn('inline-block h-4 w-4 transform rounded-full bg-white transition-transform duration-200', checked ? 'translate-x-6' : 'translate-x-1') }) }));
17
+ return (_jsx("button", { ref: ref, type: "button", role: "switch", "aria-checked": checked, disabled: disabled, onClick: handleToggle, className: cn('tc-ui-switch relative inline-flex h-6 w-11 items-center rounded-full transition-colors duration-200', 'focus:outline-none focus-visible:ring-2 focus-visible:ring-offset-2', disabled && 'cursor-not-allowed opacity-50', !disabled && 'cursor-pointer', checked
18
+ ? 'bg-[hsl(var(--ring))] dark:bg-[hsl(var(--ring))]'
19
+ : 'bg-muted dark:bg-muted', className), children: _jsx("span", { className: cn('inline-block h-4 w-4 transform rounded-full bg-background transition-transform duration-200', checked ? 'translate-x-6' : 'translate-x-1') }) }));
18
20
  });
19
21
  Switch.displayName = 'Switch';
20
22
  export { Switch };
@@ -2,64 +2,28 @@ import { ExportType } from '../../lib/export';
2
2
  import type { MOmit } from '../../types';
3
3
  import { type ReactNode } from 'react';
4
4
  import { type DropdownItem } from '../Dropdown';
5
- import type { FormFieldScheme } from '../Form';
5
+ import type { FormFieldSchema } from '../Form';
6
6
  import type { SearchProps } from '../Search/Search';
7
- type TableSearchScheme<T> = MOmit<FormFieldScheme<T>, 'rules' | 'required'> & {
8
- /**
9
- * - 字段是否常驻
10
- * - 如果都没有则去前四个
11
- */
7
+ export type TableSearchSchema<T> = MOmit<FormFieldSchema<T>, 'rules' | 'required'> & {
12
8
  isPermanent?: boolean;
13
9
  };
14
- type TableSearchProps<T> = MOmit<SearchProps<T>, 'children' | 'schemes'> & {
10
+ type TableSearchProps<T> = MOmit<SearchProps<T>, 'children' | 'schemas'> & {
15
11
  onSearch?: (values: T) => void;
16
12
  onReset?: () => void;
17
- schemes: TableSearchScheme<T>[];
18
- /**
19
- * 导出Excel按钮的下拉菜单项
20
- */
13
+ renderActionBtnArea?: () => ReactNode;
14
+ schemas: TableSearchSchema<T>[];
21
15
  exportMenuItems?: DropdownItem[];
22
16
  btnConfig?: Partial<{
23
- /**
24
- * 导出Excel按钮的文案
25
- */
26
17
  export?: ReactNode;
27
- /**
28
- * 收起按钮的文案
29
- */
30
18
  collapse?: ReactNode;
31
- /**
32
- * 展开按钮的icon
33
- */
34
19
  expandIcon?: ReactNode;
35
- /**
36
- * 展开按钮的文案
37
- */
38
20
  expand?: ReactNode;
39
- /**
40
- * 重置按钮的文案
41
- */
42
21
  reset?: ReactNode;
43
- /**
44
- * 查询按钮的文案
45
- */
46
22
  search?: ReactNode;
47
23
  }>;
48
- /**
49
- * 备选边界
50
- */
51
24
  expandBoundaries?: number;
52
- /**
53
- *
54
- * @param exportType 导出类型
55
- * @param searchData 当前查询条件
56
- * @returns
57
- */
58
25
  onExport?: (exportType: ExportType, searchData: T) => void;
59
26
  additionalButtons?: ReactNode;
60
- /**
61
- * 默认是否展开 @default true
62
- */
63
27
  defaultExpand?: boolean;
64
28
  };
65
29
  declare const TableSearch: <T extends object>(props: TableSearchProps<T>) => import("react/jsx-runtime").JSX.Element;