@_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
@@ -0,0 +1,80 @@
1
+ import { modeStore } from "../../widgets/store/mode";
2
+ export var QK;
3
+ (function (QK) {
4
+ QK["pk"] = "projk";
5
+ QK["k"] = "key";
6
+ QK["sk"] = "sidek";
7
+ QK["ck"] = "custk";
8
+ })(QK || (QK = {}));
9
+ export const leftSidebarBasePath = "_sidebar_";
10
+ export const deserializationUrlSearch = (url = window.location.search) => {
11
+ const urls = new URLSearchParams(url);
12
+ const data = {};
13
+ for (const [k, v] of urls.entries()) {
14
+ data[k] = v;
15
+ }
16
+ return data;
17
+ };
18
+ export const serializationUrl = (url, data) => `${url}?${new URLSearchParams(data).toString()}`;
19
+ const generateMenuItem = (item) => {
20
+ let data = undefined;
21
+ if (item.menuType === "module") {
22
+ const pk = modeStore.getState().projestInfo?.key;
23
+ const query = {
24
+ [QK.pk]: pk,
25
+ };
26
+ switch (item.moduleType) {
27
+ case "custom":
28
+ query[QK.ck] = item.key;
29
+ data = {
30
+ ...item,
31
+ path: {
32
+ pathname: item.customConfig.path,
33
+ search: new URLSearchParams(query).toString(),
34
+ },
35
+ };
36
+ break;
37
+ case "iframe":
38
+ case "schema":
39
+ case "sidebar":
40
+ let path = `/${item.key}`;
41
+ let search = new URLSearchParams(query).toString();
42
+ if (item.moduleType === "sidebar") {
43
+ const sfMenu = findMenuItem(item.sidebarConfig.menu, item.sidebarConfig.menu[0].key);
44
+ path += `${sfMenu.path.pathname}`;
45
+ search = sfMenu.path.search ?? "";
46
+ }
47
+ data = {
48
+ ...item,
49
+ path: {
50
+ pathname: path,
51
+ search,
52
+ },
53
+ };
54
+ break;
55
+ default:
56
+ break;
57
+ }
58
+ }
59
+ return data;
60
+ };
61
+ export const findMenuItem = (menuData, key) => {
62
+ let data = undefined;
63
+ const useFirstAvailableMenu = typeof key === "undefined";
64
+ for (const item of menuData) {
65
+ if (item.menuType === "module") {
66
+ if (useFirstAvailableMenu || item.key === key) {
67
+ data = generateMenuItem(item);
68
+ break;
69
+ }
70
+ }
71
+ if (item.menuType === "group") {
72
+ const result = findMenuItem(item.subMenu, key);
73
+ if (result) {
74
+ data = { ...result };
75
+ break;
76
+ }
77
+ }
78
+ }
79
+ return data;
80
+ };
@@ -0,0 +1,33 @@
1
+ import { AxiosError, FetchAxios, RequestConfig, ResponseConfig } from './CRUD';
2
+ declare const api: FetchAxios;
3
+ export interface PageParams {
4
+ page?: number;
5
+ pageSize?: number;
6
+ [key: string]: string | number | boolean | undefined | null;
7
+ }
8
+ export type PageResponse<T> = {
9
+ data: T[];
10
+ total: number;
11
+ page: number;
12
+ pageSize: number;
13
+ };
14
+ export interface BaseResponse<T> {
15
+ data: T;
16
+ code: number;
17
+ message: string;
18
+ }
19
+ export declare function get<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<BaseResponse<T>, D>>;
20
+ export declare function post<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<BaseResponse<T>, D>>;
21
+ export declare function put<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<BaseResponse<T>, D>>;
22
+ export declare function patch<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<BaseResponse<T>, D>>;
23
+ export declare function del<T = unknown, D = unknown>(url: string, data?: D, config?: RequestConfig<D>): Promise<ResponseConfig<BaseResponse<T>, D>>;
24
+ export { api, FetchAxios };
25
+ export type { AxiosError, RequestConfig, ResponseConfig };
26
+ export declare const request: {
27
+ get: typeof get;
28
+ put: typeof put;
29
+ post: typeof post;
30
+ del: typeof del;
31
+ patch: typeof patch;
32
+ };
33
+ //# sourceMappingURL=request.d.ts.map
@@ -0,0 +1,127 @@
1
+ import md5 from 'md5';
2
+ import { API_AUTH_HEADER_KEY, AUTH_HEADER_KEY, clearAuthToken, getApiAuth, getAuthToken } from './auth';
3
+ import { FetchAxios } from './CRUD';
4
+ const BASE_URL = '/api';
5
+ const api = new FetchAxios({
6
+ baseURL: BASE_URL,
7
+ timeout: 15000,
8
+ credentials: 'include',
9
+ validateStatus: (status) => status >= 200 && status < 300,
10
+ });
11
+ const removeBaseurlFromURL = (config) => {
12
+ const { baseURL, url } = config;
13
+ if (!baseURL || !url)
14
+ return;
15
+ const origin = typeof window === 'undefined' ? 'http://localhost' : window.location.origin;
16
+ const baseURLObject = new URL(baseURL, origin);
17
+ const basePath = baseURLObject.pathname.replace(/\/+$/, '');
18
+ const requestURL = new URL(url, baseURLObject.origin);
19
+ if (requestURL.origin !== baseURLObject.origin || !basePath)
20
+ return;
21
+ const normalizedPathname = requestURL.pathname.replace(/\/+$/, '');
22
+ if (normalizedPathname !== basePath && !requestURL.pathname.startsWith(`${basePath}/`))
23
+ return;
24
+ const pathname = requestURL.pathname.slice(basePath.length) || '/';
25
+ config.url = `${pathname}${requestURL.search}${requestURL.hash}`;
26
+ };
27
+ api.interceptors.request.use(async (config) => {
28
+ removeBaseurlFromURL(config);
29
+ const token = await getAuthToken();
30
+ const aauto = getApiAuth();
31
+ const time = new Date().getTime();
32
+ config.headers = {
33
+ ...config.headers,
34
+ s_t: time + '',
35
+ s_sign: md5(`sakjdfnkjwjfnfkjkjldljksndf_${time}`),
36
+ [API_AUTH_HEADER_KEY]: aauto,
37
+ };
38
+ if (token) {
39
+ config.headers = {
40
+ ...config.headers,
41
+ [AUTH_HEADER_KEY]: `Bearer ${token}`,
42
+ };
43
+ }
44
+ return config;
45
+ });
46
+ api.interceptors.request.use((config) => {
47
+ console.debug(`[API] ${config.method?.toUpperCase()} ${config.url}`);
48
+ return config;
49
+ });
50
+ api.interceptors.response.use((res) => res, async (err) => {
51
+ const axiosErr = err;
52
+ if (axiosErr.response?.status === 401) {
53
+ await clearAuthToken();
54
+ if (typeof window !== 'undefined') {
55
+ window.location.href = '/login';
56
+ }
57
+ }
58
+ const message = extractErrorMessage(err);
59
+ console.error(`[API Error] ${message}`, {
60
+ url: err.config.url,
61
+ status: err.response?.status,
62
+ });
63
+ return Promise.reject(err);
64
+ });
65
+ function extractErrorMessage(err) {
66
+ if (!(err instanceof Error))
67
+ return 'Unknown error';
68
+ const axiosErr = err;
69
+ if (axiosErr.response?.data && typeof axiosErr.response.data === 'object' && axiosErr.response.data !== null) {
70
+ const data = axiosErr.response.data;
71
+ if (typeof data.message === 'string')
72
+ return data.message;
73
+ if (typeof data.msg === 'string')
74
+ return data.msg;
75
+ if (Array.isArray(data.errors) && data.errors.length > 0) {
76
+ return String(data.errors[0]);
77
+ }
78
+ }
79
+ if (axiosErr.message)
80
+ return axiosErr.message;
81
+ if (axiosErr.code === 'ECONNABORTED')
82
+ return 'Request timed out';
83
+ return 'Network error';
84
+ }
85
+ export function get(url, data, config) {
86
+ const hasDataParams = data !== undefined && data !== null && typeof data === 'object';
87
+ const getConfig = hasDataParams
88
+ ? {
89
+ ...config,
90
+ params: {
91
+ ...config?.params,
92
+ ...data,
93
+ },
94
+ }
95
+ : config;
96
+ return api.get(url, getConfig);
97
+ }
98
+ export function post(url, data, config) {
99
+ return api.post(url, data, config);
100
+ }
101
+ export function put(url, data, config) {
102
+ return api.put(url, data, config);
103
+ }
104
+ export function patch(url, data, config) {
105
+ return api.patch(url, data, config);
106
+ }
107
+ export function del(url, data, config) {
108
+ const hasDataParams = data !== undefined && data !== null && typeof data === 'object';
109
+ const delConfig = hasDataParams
110
+ ? {
111
+ ...config,
112
+ params: {
113
+ ...config?.params,
114
+ ...data,
115
+ },
116
+ }
117
+ : config;
118
+ return api.delete(url, delConfig);
119
+ }
120
+ export { api, FetchAxios };
121
+ export const request = {
122
+ get,
123
+ put,
124
+ post,
125
+ del,
126
+ patch,
127
+ };
@@ -0,0 +1,9 @@
1
+ import { PropsWithChildren, ReactNode } from "react";
2
+ export interface HeaderViewProps extends PropsWithChildren {
3
+ menu?: ReactNode;
4
+ title?: ReactNode;
5
+ userArea?: ReactNode;
6
+ }
7
+ declare const HeaderView: (props?: HeaderViewProps) => import("react/jsx-runtime").JSX.Element;
8
+ export default HeaderView;
9
+ //# sourceMappingURL=HeaderView.d.ts.map
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cn } from "../../../../packages/ui/react/index";
3
+ const defaultTitle = _jsx("span", { children: "Template Core" });
4
+ const defaultProps = {};
5
+ const headerThemeStyle = {
6
+ "--header-fg": "hsl(var(--theme-text))",
7
+ "--header-bg": "hsl(var(--theme-bg))",
8
+ "--header-shadow": "hsl(var(--theme-primary) / 0.18)",
9
+ };
10
+ const HeaderView = (props) => {
11
+ const { title, menu, userArea, children } = props ?? defaultProps;
12
+ return (_jsxs("div", { className: "header-view", style: headerThemeStyle, children: [_jsxs("header", { className: cn("header flex h-16 items-center border-b", "shadow-[0_10px_30px_var(--header-shadow)]"), children: [_jsx("div", { className: "brand flex w-60 items-center border-r border-[hsl(var(--theme-bg)/0.14)] px-6 text-base font-semibold tracking-[0.02em] text-(--header-fg)", children: title ?? defaultTitle }), _jsx("div", { className: "top-menu flex flex-1 items-center px-6 text-(--header-fg)", children: menu }), _jsx("div", { className: "user-area flex items-center justify-end border-l border-[hsl(var(--theme-bg)/0.14)] px-6 text-(--header-fg)", children: userArea })] }), children] }));
13
+ };
14
+ export default HeaderView;
@@ -0,0 +1,9 @@
1
+ import { ReactNode } from 'react';
2
+ import { RouterType } from './type';
3
+ export type RouteInfo = {
4
+ path: string;
5
+ component: ReactNode;
6
+ children?: RouteInfo[];
7
+ };
8
+ export declare const generateRouter: (routes: RouteInfo[], type: RouterType) => import("react/jsx-runtime").JSX.Element;
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { BrowserRouter, HashRouter, Route, Routes } from 'react-router-dom';
3
+ export const generateRouter = (routes, type) => {
4
+ const RouterComponent = type === 'browser' ? BrowserRouter : HashRouter;
5
+ const renderDom = (routes) => {
6
+ return routes.map((route) => {
7
+ return (_jsx(Route, { path: route.path, element: route.component, children: route.children && renderDom(route.children) }, route.path));
8
+ });
9
+ };
10
+ return (_jsx(RouterComponent, { basename: window._basePath, children: _jsx(Routes, { children: renderDom(routes) }) }));
11
+ };
@@ -0,0 +1,2 @@
1
+ export type RouterType = "hash" | "browser";
2
+ //# sourceMappingURL=type.d.ts.map
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,3 @@
1
+ declare const Iframe: () => import("react/jsx-runtime").JSX.Element;
2
+ export default Iframe;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import useCurrentMenuData from "../../../widgets/hooks/useCurrentMenuData";
3
+ import { useMemo } from "react";
4
+ const Iframe = () => {
5
+ const { menu } = useCurrentMenuData(true);
6
+ const ifUrl = useMemo(() => {
7
+ if (menu.moduleType === "iframe") {
8
+ return menu.iframeConfig.path;
9
+ }
10
+ return "";
11
+ }, []);
12
+ return (_jsx("div", { className: "iframe w-full h-full", children: _jsx("iframe", { className: " w-full h-full", src: ifUrl }) }));
13
+ };
14
+ export default Iframe;
@@ -0,0 +1,7 @@
1
+ import type { CallComNames, SchemaDefaultValue } from '../../schemaType';
2
+ declare const DetailPanel: import("react").MemoExoticComponent<(props: {
3
+ data: SchemaDefaultValue;
4
+ comName: CallComNames;
5
+ }) => import("react/jsx-runtime").JSX.Element>;
6
+ export default DetailPanel;
7
+ //# sourceMappingURL=DetailPanel.d.ts.map
@@ -0,0 +1,94 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { getText } from '../../../../../widgets/common/language';
3
+ import { Drawer } from '../../../../../../packages/ui/react/components';
4
+ import { memo, useMemo, useState } from 'react';
5
+ import { request } from '../../../../../widgets/common/request';
6
+ import useExecuteOnce from '../../../../../../packages/ui/react/hooks/useExecuteOnce';
7
+ import { eventsInfo } from '../../data/eventInfo';
8
+ import useComConfig from '../../hooks/useComConfig';
9
+ import { schemaEventBus } from '../../stores/schemaEventBus';
10
+ import { handlingRequestErrors } from '../../utils/fetchErrorShow';
11
+ import { merge } from '../../utils/permissions';
12
+ const EMPTY_TEXT = '-';
13
+ const isEmptyValue = (value) => value === undefined || value === null || value === '';
14
+ const stringifyValue = (value) => {
15
+ if (isEmptyValue(value))
16
+ return EMPTY_TEXT;
17
+ if (typeof value === 'object')
18
+ return JSON.stringify(value);
19
+ return String(value);
20
+ };
21
+ const getOptionLabel = (options, value) => {
22
+ if (!Array.isArray(options))
23
+ return undefined;
24
+ const matchedOption = options.find((option) => {
25
+ if (!option || typeof option !== 'object')
26
+ return false;
27
+ return option.value === value;
28
+ });
29
+ if (!matchedOption || typeof matchedOption !== 'object')
30
+ return undefined;
31
+ const label = matchedOption.label;
32
+ return label ?? stringifyValue(value);
33
+ };
34
+ const formatValue = (value, fieldInfo) => {
35
+ if (isEmptyValue(value))
36
+ return EMPTY_TEXT;
37
+ const option = fieldInfo.option;
38
+ const optionLabel = getOptionLabel(option?.options ?? option?.enumList, value);
39
+ if (optionLabel !== undefined)
40
+ return optionLabel;
41
+ if (Array.isArray(value)) {
42
+ if (value.length === 0)
43
+ return EMPTY_TEXT;
44
+ return value
45
+ .map((item) => {
46
+ return stringifyValue(item);
47
+ })
48
+ .join(', ');
49
+ }
50
+ if (typeof value === 'boolean')
51
+ return value ? getText('是') : getText('否');
52
+ return stringifyValue(value);
53
+ };
54
+ const generateFields = (schema, data) => {
55
+ if (!schema?.properties)
56
+ return [];
57
+ return Object.keys(schema.properties)
58
+ .reduce((fields, key) => {
59
+ const fieldInfo = schema.properties[key];
60
+ if (!fieldInfo.option || fieldInfo.option.visible === false)
61
+ return fields;
62
+ fields.push({
63
+ key,
64
+ label: getText(fieldInfo.label),
65
+ value: formatValue(data?.[key], fieldInfo),
66
+ level: fieldInfo.level ?? 10,
67
+ });
68
+ return fields;
69
+ }, [])
70
+ .sort((a, b) => a.level - b.level);
71
+ };
72
+ const DetailPanel = memo((props) => {
73
+ const [open, setOpen] = useState(true);
74
+ const [data, setData] = useState(props.data);
75
+ const { config, schema, api } = useComConfig({ comName: props.comName });
76
+ const fields = useMemo(() => generateFields(schema, data), [data, schema]);
77
+ useExecuteOnce(async () => {
78
+ const fetchKey = config?.fetchKey;
79
+ if (fetchKey) {
80
+ const params = {
81
+ [fetchKey]: props.data[fetchKey],
82
+ };
83
+ const { url: furl = api, method = 'get' } = config.fetchConfig ?? {};
84
+ const res = await handlingRequestErrors(request[method](furl, params));
85
+ if (res.data.code === 0)
86
+ setData(res.data.data);
87
+ }
88
+ }, { executionPhase: 'mount' });
89
+ return (_jsx("div", { className: "detail-panel", children: _jsx(Drawer, { title: getText(config?.title ?? ''), open: open, onClose: () => {
90
+ setOpen(false);
91
+ schemaEventBus.getState().emitCom({ type: merge(eventsInfo.closeCom) });
92
+ }, children: fields.length > 0 ? (_jsx("div", { className: "grid grid-cols-1 gap-x-6 gap-y-4 sm:grid-cols-2", children: fields.map((field) => (_jsxs("div", { className: "min-w-0 border-b border-border pb-3", children: [_jsx("div", { className: "mb-1 text-xs text-muted-foreground", children: field.label }), _jsx("div", { className: "break-words text-sm leading-6 text-foreground", children: field.value })] }, field.key))) })) : (_jsx("div", { className: "py-8 text-center text-sm text-muted-foreground", children: getText('暂无数据') })) }) }));
93
+ });
94
+ export default DetailPanel;
@@ -0,0 +1,13 @@
1
+ import type { CallComNames, ComponentConfig, SchemaDefaultValue } from '../../schemaType';
2
+ type PopFormComName = keyof ComponentConfig;
3
+ export interface PopFormValue {
4
+ comName: PopFormComName;
5
+ data?: SchemaDefaultValue;
6
+ }
7
+ export interface PopFormProps {
8
+ data: SchemaDefaultValue;
9
+ comName: CallComNames;
10
+ }
11
+ declare const PopForm: import("react").MemoExoticComponent<(props: PopFormProps) => import("react/jsx-runtime").JSX.Element>;
12
+ export default PopForm;
13
+ //# sourceMappingURL=PopFrom.d.ts.map
@@ -0,0 +1,109 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { getText } from '../../../../../widgets/common/language';
3
+ import { Modal, SchemaForm } from '../../../../../../packages/ui/react/components';
4
+ import { post, put, request } from '../../../../../widgets/common/request';
5
+ import useExecuteOnce from '../../../../../../packages/ui/react/hooks/useExecuteOnce';
6
+ import { memo, useCallback, useMemo, useRef, useState } from 'react';
7
+ import { eventsInfo } from '../../data/eventInfo';
8
+ import useComConfig from '../../hooks/useComConfig';
9
+ import { schemaEventBus } from '../../stores/schemaEventBus';
10
+ import { handlingRequestErrors } from '../../utils/fetchErrorShow';
11
+ import { merge } from '../../utils/permissions';
12
+ import { createAjvValidator } from '../../utils/validator';
13
+ const generateSchemas = (schema) => {
14
+ if (!schema?.properties)
15
+ return [];
16
+ return Object.keys(schema.properties).reduce((schemas, key) => {
17
+ const fieldInfo = schema.properties[key];
18
+ const option = fieldInfo.option;
19
+ if (!option || option.visible === false)
20
+ return schemas;
21
+ const { comType = 'input', default: _defaultValue, visible: _visible, ...fieldProps } = option;
22
+ schemas.push({
23
+ key,
24
+ label: getText(fieldInfo.label),
25
+ type: comType,
26
+ required: schema.required?.includes(key),
27
+ rules: [
28
+ ...(schema.required?.includes(key)
29
+ ? [{ required: true, message: `请输入${getText(fieldInfo.label)}` }]
30
+ : []),
31
+ {
32
+ validator: createAjvValidator(fieldInfo),
33
+ },
34
+ ],
35
+ fieldProps: {
36
+ ...fieldProps,
37
+ ...(comType === 'select'
38
+ ? {
39
+ getPopupContainer: 'parent',
40
+ }
41
+ : []),
42
+ },
43
+ });
44
+ return schemas;
45
+ }, []);
46
+ };
47
+ const generateDefaultValue = (schema, data) => {
48
+ const defaultValue = { ...(data ?? {}) };
49
+ if (!schema?.properties)
50
+ return defaultValue;
51
+ Object.keys(schema.properties).forEach((key) => {
52
+ const defaultFieldValue = schema.properties[key].option?.default;
53
+ if (typeof defaultFieldValue !== 'undefined' && typeof defaultValue[key] === 'undefined') {
54
+ defaultValue[key] = defaultFieldValue;
55
+ }
56
+ });
57
+ return defaultValue;
58
+ };
59
+ const PopForm = memo((props) => {
60
+ const [open, setOpen] = useState(true);
61
+ const [submitting, setSubmitting] = useState(false);
62
+ const { schema, config, api } = useComConfig({ comName: props.comName });
63
+ const formRef = useRef(null);
64
+ const [loading, setLoading] = useState(false);
65
+ const schemas = useMemo(() => {
66
+ return generateSchemas(schema);
67
+ }, [schema]);
68
+ const closed = submitting
69
+ ? undefined
70
+ : () => {
71
+ schemaEventBus.getState().emitCom({ type: merge(eventsInfo.closeCom) });
72
+ setOpen(false);
73
+ };
74
+ const defaultValue = useMemo(() => generateDefaultValue(schema, props.data), [schema, props.data]);
75
+ useExecuteOnce(async () => {
76
+ if (props.comName === 'editForm' && 'fetchKey' in config) {
77
+ const { fetchKey } = config;
78
+ const params = {
79
+ [fetchKey]: props.data[fetchKey],
80
+ };
81
+ const { url = api, method = 'get' } = config?.fetchConfig ?? {};
82
+ setLoading(true);
83
+ const res = await handlingRequestErrors(request[method](url, params));
84
+ res.data.code === 0 && formRef.current?.setFieldsValue(res.data.data);
85
+ setLoading(false);
86
+ }
87
+ }, { executionPhase: 'mount' });
88
+ const handleSubmit = useCallback(async (v) => {
89
+ setSubmitting(true);
90
+ let fetchFn = put;
91
+ if (props.comName === 'createForm') {
92
+ fetchFn = post;
93
+ }
94
+ try {
95
+ const res = await handlingRequestErrors(fetchFn(api, v));
96
+ if (res.data.code === 0) {
97
+ schemaEventBus.getState().emitCom({
98
+ type: merge(eventsInfo.closeCom, eventsInfo.initTable, props.comName === 'createForm' ? eventsInfo.resetSearch : eventsInfo.none),
99
+ });
100
+ }
101
+ }
102
+ finally {
103
+ setSubmitting(false);
104
+ }
105
+ }, [api, props.comName]);
106
+ return (_jsx(Modal, { open: open, onClose: closed, title: getText(config?.title ?? ''), width: 640, maskClosable: !submitting, children: _jsx(SchemaForm, { schemas: schemas, initialValues: defaultValue, getForm: (f) => (formRef.current = f), onFinish: handleSubmit, onCancel: closed, buttonClassName: "justify-end", submitText: config?.saveBtnText, submitButtonProps: { loading: submitting }, cancelButtonProps: { disabled: submitting } }, `${String(props?.comName ?? '')}-${JSON.stringify(defaultValue)}`) }));
107
+ });
108
+ PopForm.displayName = 'PopForm';
109
+ export default PopForm;
@@ -0,0 +1,3 @@
1
+ import { CallComponent } from '../../schemaType';
2
+ export declare const components: CallComponent<any>;
3
+ //# sourceMappingURL=data.d.ts.map
@@ -0,0 +1,6 @@
1
+ import { lazy } from 'react';
2
+ export const components = {
3
+ editForm: lazy(() => import('./PopFrom')),
4
+ createForm: lazy(() => import('./PopFrom')),
5
+ detailPanel: lazy(() => import('./DetailPanel')),
6
+ };
@@ -0,0 +1,3 @@
1
+ declare const SchemaSearch: import("react").MemoExoticComponent<() => import("react/jsx-runtime").JSX.Element>;
2
+ export default SchemaSearch;
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,58 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { getText } from '../../../../../widgets/common/language';
3
+ import { filterEmpty } from '../../../../../../packages/common/index.js';
4
+ import { TableSearch } from '../../../../../../packages/ui/react/components';
5
+ import useInit from '../../../../../../packages/ui/react/hooks/useInit';
6
+ import { memo, useState } from 'react';
7
+ import { schemaEventBus } from '../../stores/schemaEventBus';
8
+ import { useSchemaStore } from '../../stores/schemaStore';
9
+ const generateSchemas = (config) => {
10
+ const keys = Object.keys(config);
11
+ const schemas = [];
12
+ let defaultValue = undefined;
13
+ keys.forEach((k) => {
14
+ const fieldInfo = config[k];
15
+ if (fieldInfo.option) {
16
+ const { comType = 'input', default: defaultFieldValue, ...fieldProps } = fieldInfo.option;
17
+ if (typeof defaultFieldValue !== 'undefined') {
18
+ if (!defaultValue) {
19
+ defaultValue = {};
20
+ }
21
+ defaultValue[k] = defaultFieldValue;
22
+ }
23
+ schemas.push({
24
+ label: getText(fieldInfo.label),
25
+ key: k,
26
+ type: comType,
27
+ fieldProps,
28
+ });
29
+ }
30
+ });
31
+ return { schemas, defaultValue };
32
+ };
33
+ const SchemaSearch = memo(() => {
34
+ const schema = useSchemaStore((s) => s.searchSchema);
35
+ const [schemas, setSchemas] = useState([]);
36
+ const [defaultValue, setSchemaDefaultValue] = useState(undefined);
37
+ useInit(() => {
38
+ const { schemas, defaultValue } = generateSchemas(schema.properties);
39
+ setSchemas(schemas);
40
+ setSchemaDefaultValue(defaultValue);
41
+ });
42
+ const tsProps = {
43
+ schemas,
44
+ defaultValue,
45
+ onSearch(values) {
46
+ schemaEventBus.getState().emitSearch(filterEmpty(values));
47
+ },
48
+ onReset() {
49
+ schemaEventBus.getState().emitSearch(undefined);
50
+ },
51
+ renderActionBtnArea: () => {
52
+ return undefined;
53
+ },
54
+ };
55
+ return (_jsx("div", { className: "schema-search", children: _jsx(TableSearch, { ...tsProps }) }));
56
+ });
57
+ SchemaSearch.displayName = 'SchemaSearch';
58
+ export default SchemaSearch;
@@ -0,0 +1,11 @@
1
+ import { Ref } from 'react';
2
+ import { SchemaDefaultValue } from '../../schemaType';
3
+ export type SchemaTableRef = {
4
+ initData: (query?: SchemaDefaultValue) => Promise<void>;
5
+ };
6
+ export interface SchemaTableProps {
7
+ ref?: Ref<SchemaTableRef>;
8
+ }
9
+ declare const SchemaTable: import("react").MemoExoticComponent<({ ref }: SchemaTableProps) => import("react/jsx-runtime").JSX.Element>;
10
+ export default SchemaTable;
11
+ //# sourceMappingURL=index.d.ts.map