@luck-design-biz/luckda 0.0.25-7 → 0.0.25-9

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 (329) hide show
  1. package/es/components/ComplexItem/index.js +92 -0
  2. package/es/components/ComplexItem/service.js +21 -0
  3. package/es/components/LDActions/index.js +8 -10
  4. package/es/components/LDActions/index.less +7 -4
  5. package/es/components/LdAutoForm/index.js +18 -11
  6. package/es/components/LdFormList/index.js +14 -5
  7. package/es/components/LdGrid/index.js +19 -6
  8. package/es/components/LdGridForm/index.js +20 -9
  9. package/es/components/LdTree/index.js +30 -13
  10. package/es/helper/FromItems.js +177 -94
  11. package/es/helper/form.js +49 -11
  12. package/es/helper/props_config.js +17 -0
  13. package/es/locales/zh-CN.js +16 -11
  14. package/es/lowcode/constants/api-url.js +192 -28
  15. package/es/lowcode/constants/event-topics.js +2 -0
  16. package/es/lowcode/constants/index.js +2 -1
  17. package/es/lowcode/engine/meta/box.props.json +3 -3
  18. package/es/lowcode/engine/meta/button.props.json +3 -3
  19. package/es/lowcode/engine/meta/cardlist.props.json +13 -3
  20. package/es/lowcode/engine/meta/components-list.json +108 -0
  21. package/es/lowcode/engine/meta/dialog.props.default.json +1 -0
  22. package/es/lowcode/engine/meta/dialog.props.json +12 -5
  23. package/es/lowcode/engine/meta/drawer.props.json +8 -20
  24. package/es/lowcode/engine/meta/fieldcolor.props.default.json +14 -0
  25. package/es/lowcode/engine/meta/fieldcolor.props.json +63 -0
  26. package/es/lowcode/engine/meta/fieldcomplex.props.default.json +13 -0
  27. package/es/lowcode/engine/meta/fieldcomplex.props.json +39 -0
  28. package/es/lowcode/engine/meta/fielddate.props.default.json +12 -0
  29. package/es/lowcode/engine/meta/fielddate.props.json +47 -0
  30. package/es/lowcode/engine/meta/fielddict.props.default.json +14 -0
  31. package/es/lowcode/engine/meta/fielddict.props.json +44 -0
  32. package/es/lowcode/engine/meta/fieldeditor.props.default.json +13 -0
  33. package/es/lowcode/engine/meta/fieldeditor.props.json +44 -0
  34. package/es/lowcode/engine/meta/fieldgroup.props.default.json +15 -0
  35. package/es/lowcode/engine/meta/fieldgroup.props.json +73 -0
  36. package/es/lowcode/engine/meta/fieldnumber.props.default.json +14 -0
  37. package/es/lowcode/engine/meta/fieldnumber.props.json +48 -0
  38. package/es/lowcode/engine/meta/fieldradio.props.default.json +12 -0
  39. package/es/lowcode/engine/meta/fieldradio.props.json +20 -0
  40. package/es/lowcode/engine/meta/fieldregion.props.default.json +12 -0
  41. package/es/lowcode/engine/meta/fieldregion.props.json +26 -0
  42. package/es/lowcode/engine/meta/fieldselect.props.default.json +14 -0
  43. package/es/lowcode/engine/meta/fieldselect.props.json +58 -0
  44. package/es/lowcode/engine/meta/fieldstring.props.default.json +16 -0
  45. package/es/lowcode/engine/meta/fieldstring.props.json +62 -0
  46. package/es/lowcode/engine/meta/fieldswitch.props.default.json +12 -0
  47. package/es/lowcode/engine/meta/fieldswitch.props.json +31 -0
  48. package/es/lowcode/engine/meta/fieldtextarea.props.default.json +13 -0
  49. package/es/lowcode/engine/meta/fieldtextarea.props.json +49 -0
  50. package/es/lowcode/engine/meta/fieldupload.props.default.json +15 -0
  51. package/es/lowcode/engine/meta/fieldupload.props.json +71 -0
  52. package/es/lowcode/engine/meta/fielduser.props.default.json +16 -0
  53. package/es/lowcode/engine/meta/fielduser.props.json +82 -0
  54. package/es/lowcode/engine/meta/fieldyear.props.default.json +12 -0
  55. package/es/lowcode/engine/meta/fieldyear.props.json +20 -0
  56. package/es/lowcode/engine/meta/form.props.json +15 -9
  57. package/es/lowcode/engine/meta/imex.props.default.json +8 -1
  58. package/es/lowcode/engine/meta/imex.props.json +54 -22
  59. package/es/lowcode/engine/meta/js-editor/auto-complete.json +53 -3
  60. package/es/lowcode/engine/meta/layout.props.json +2 -2
  61. package/es/lowcode/engine/meta/page.props.json +2 -2
  62. package/es/lowcode/engine/meta/pagelayout.props.default.json +14 -0
  63. package/es/lowcode/engine/meta/pagelayout.props.json +47 -0
  64. package/es/lowcode/engine/meta/section.props.json +2 -2
  65. package/es/lowcode/engine/meta/split.props.default.json +1 -1
  66. package/es/lowcode/engine/meta/split.props.json +4 -4
  67. package/es/lowcode/engine/meta/table.props.json +17 -11
  68. package/es/lowcode/engine/meta/tabs.props.json +3 -3
  69. package/es/lowcode/engine/meta/tree.props.default.json +1 -0
  70. package/es/lowcode/engine/meta/tree.props.json +62 -6
  71. package/es/lowcode/engine/provider/ContextProvider/index.js +13 -3
  72. package/es/lowcode/engine/provider/RemoteSourceProvider.js +61 -18
  73. package/es/lowcode/engine/tools/dataProcess.js +4 -0
  74. package/es/lowcode/engine/tools/helper.js +24 -2
  75. package/es/lowcode/engine/tools/usePageDataStore.js +4 -2
  76. package/es/lowcode/painter/Design.js +4 -4
  77. package/es/lowcode/painter/DesignOperator.js +103 -66
  78. package/es/lowcode/painter/DesignToolbar.js +15 -16
  79. package/es/lowcode/painter/Outline.js +10 -6
  80. package/es/lowcode/painter/Panel.js +60 -22
  81. package/es/lowcode/painter/components/ActionBindModal.js +33 -16
  82. package/es/lowcode/painter/components/AdvancePanel.js +37 -21
  83. package/es/lowcode/painter/components/AttrsPanel.js +16 -12
  84. package/es/lowcode/painter/components/FieldSelector.js +26 -13
  85. package/es/lowcode/painter/components/code-editor/JSEditor.js +5 -9
  86. package/es/lowcode/painter/components/field-setting/CheckFrontRules.js +108 -0
  87. package/es/lowcode/painter/components/field-setting/CheckRules.js +1 -26
  88. package/es/lowcode/painter/components/field-setting/FieldRulesModal.js +33 -13
  89. package/es/lowcode/painter/components/field-setting/SettingUI.js +156 -24
  90. package/es/lowcode/painter/components/field-setting/index.js +32 -63
  91. package/es/lowcode/painter/components/field-setting/meta/frontRules.js +53 -0
  92. package/es/lowcode/painter/panel-section/BlocksEditor/index.js +9 -15
  93. package/es/lowcode/painter/panel-section/DataSetSelector.js +29 -9
  94. package/es/lowcode/painter/panel-section/FieldsSetting.js +77 -33
  95. package/es/lowcode/painter/panel-section/ImpExp.js +99 -14
  96. package/es/lowcode/painter/panel-section/ImpExpAlone.js +108 -0
  97. package/es/lowcode/painter/panel-section/PageLayoutDisplay.js +95 -0
  98. package/es/lowcode/painter/panel-section/SplitDisplay.js +25 -110
  99. package/es/lowcode/painter/panel-section/StylePanel/index.js +10 -4
  100. package/es/lowcode/painter/panel-section/TableTopFilter.js +23 -13
  101. package/es/lowcode/painter/style/action-bind-modal.less +3 -3
  102. package/es/lowcode/painter/style/page-layout-display.less +28 -0
  103. package/es/lowcode/painter/style/split-display.less +0 -9
  104. package/es/lowcode/preview/index.js +4 -2
  105. package/es/lowcode/view/Page.js +4 -4
  106. package/es/lowcode/view/lc-components/Box/FunctionDesign.js +3 -2
  107. package/es/lowcode/view/lc-components/Box/meta.json +3 -3
  108. package/es/lowcode/view/lc-components/Button/index.js +2 -6
  109. package/es/lowcode/view/lc-components/Button/meta.json +3 -3
  110. package/es/lowcode/view/lc-components/CardList/meta.json +13 -3
  111. package/es/lowcode/view/lc-components/Dialog/index.js +30 -3
  112. package/es/lowcode/view/lc-components/Dialog/meta.json +12 -5
  113. package/es/lowcode/view/lc-components/Drawer/meta.json +8 -20
  114. package/es/lowcode/view/lc-components/FieldColor/meta.json +63 -0
  115. package/es/lowcode/view/lc-components/FieldComplex/meta.json +39 -0
  116. package/es/lowcode/view/lc-components/FieldDate/meta.json +45 -0
  117. package/es/lowcode/view/lc-components/FieldDict/meta.json +44 -0
  118. package/es/lowcode/view/lc-components/FieldEditor/meta.json +44 -0
  119. package/es/lowcode/view/lc-components/FieldGroup/meta.json +73 -0
  120. package/es/lowcode/view/lc-components/FieldNumber/meta.json +48 -0
  121. package/es/lowcode/view/lc-components/FieldRadio/meta.json +20 -0
  122. package/es/lowcode/view/lc-components/FieldRegion/meta.json +26 -0
  123. package/es/lowcode/view/lc-components/FieldSelect/meta.json +58 -0
  124. package/es/lowcode/view/lc-components/FieldString/meta.json +62 -0
  125. package/es/lowcode/view/lc-components/FieldSwitch/meta.json +31 -0
  126. package/es/lowcode/view/lc-components/FieldTextarea/meta.json +49 -0
  127. package/es/lowcode/view/lc-components/FieldUpload/meta.json +71 -0
  128. package/es/lowcode/view/lc-components/FieldUser/meta.json +82 -0
  129. package/es/lowcode/view/lc-components/FieldYear/meta.json +20 -0
  130. package/es/lowcode/view/lc-components/Form/FunctionPreview.js +8 -1
  131. package/es/lowcode/view/lc-components/Form/index.js +188 -38
  132. package/es/lowcode/view/lc-components/Form/meta.json +15 -9
  133. package/es/lowcode/view/lc-components/ImEx/FunctionDesign.js +8 -3
  134. package/es/lowcode/view/lc-components/ImEx/index.js +470 -11
  135. package/es/lowcode/view/lc-components/ImEx/index.less +7 -0
  136. package/es/lowcode/view/lc-components/ImEx/meta.json +55 -23
  137. package/es/lowcode/view/lc-components/Layout/meta.json +2 -2
  138. package/es/lowcode/view/lc-components/Page/meta.json +2 -2
  139. package/es/lowcode/view/lc-components/PageLayout/FunctionDesign.js +63 -0
  140. package/es/lowcode/view/lc-components/PageLayout/FunctionLive.js +10 -0
  141. package/es/lowcode/view/lc-components/PageLayout/FunctionPreview.js +10 -0
  142. package/es/lowcode/view/lc-components/PageLayout/index.js +32 -0
  143. package/es/lowcode/view/lc-components/PageLayout/meta.json +47 -0
  144. package/es/lowcode/view/lc-components/Section/meta.json +2 -2
  145. package/es/lowcode/view/lc-components/Split/FunctionDesign.js +11 -5
  146. package/es/lowcode/view/lc-components/Split/index.js +5 -9
  147. package/es/lowcode/view/lc-components/Split/meta.json +4 -4
  148. package/es/lowcode/view/lc-components/Table/components/TopFilter.js +78 -57
  149. package/es/lowcode/view/lc-components/Table/components/TopImex.js +420 -0
  150. package/es/lowcode/view/lc-components/Table/index.js +228 -24
  151. package/es/lowcode/view/lc-components/Table/meta.json +17 -11
  152. package/es/lowcode/view/lc-components/Tabs/FunctionDesign.js +2 -1
  153. package/es/lowcode/view/lc-components/Tabs/index.js +3 -1
  154. package/es/lowcode/view/lc-components/Tabs/meta.json +3 -3
  155. package/es/lowcode/view/lc-components/Tree/FunctionDesign.js +2 -3
  156. package/es/lowcode/view/lc-components/Tree/index.js +96 -29
  157. package/es/lowcode/view/lc-components/Tree/meta.json +62 -7
  158. package/es/upload/FilesWall/index.js +13 -13
  159. package/es/upload/FilesWall/index.less +74 -74
  160. package/es/upload/Form/gridForm.js +3 -2
  161. package/es/upload/FormItem/index.js +3 -5
  162. package/es/utils/form.js +16 -3
  163. package/es/utils/grid.js +8 -5
  164. package/lib/components/ComplexItem/index.js +100 -0
  165. package/lib/components/ComplexItem/service.js +28 -0
  166. package/lib/components/LDActions/index.js +7 -9
  167. package/lib/components/LDActions/index.less +7 -4
  168. package/lib/components/LdAutoForm/index.js +17 -10
  169. package/lib/components/LdFormList/index.js +13 -4
  170. package/lib/components/LdGrid/index.js +19 -6
  171. package/lib/components/LdGridForm/index.js +19 -8
  172. package/lib/components/LdTree/index.js +30 -13
  173. package/lib/helper/FromItems.js +175 -92
  174. package/lib/helper/form.js +47 -10
  175. package/lib/helper/props_config.js +23 -0
  176. package/lib/locales/zh-CN.js +16 -11
  177. package/lib/lowcode/constants/api-url.js +192 -28
  178. package/lib/lowcode/constants/event-topics.js +3 -1
  179. package/lib/lowcode/constants/index.js +3 -2
  180. package/lib/lowcode/engine/meta/box.props.json +3 -3
  181. package/lib/lowcode/engine/meta/button.props.json +3 -3
  182. package/lib/lowcode/engine/meta/cardlist.props.json +13 -3
  183. package/lib/lowcode/engine/meta/components-list.json +108 -0
  184. package/lib/lowcode/engine/meta/dialog.props.default.json +1 -0
  185. package/lib/lowcode/engine/meta/dialog.props.json +12 -5
  186. package/lib/lowcode/engine/meta/drawer.props.json +8 -20
  187. package/lib/lowcode/engine/meta/fieldcolor.props.default.json +14 -0
  188. package/lib/lowcode/engine/meta/fieldcolor.props.json +63 -0
  189. package/lib/lowcode/engine/meta/fieldcomplex.props.default.json +13 -0
  190. package/lib/lowcode/engine/meta/fieldcomplex.props.json +39 -0
  191. package/lib/lowcode/engine/meta/fielddate.props.default.json +12 -0
  192. package/lib/lowcode/engine/meta/fielddate.props.json +47 -0
  193. package/lib/lowcode/engine/meta/fielddict.props.default.json +14 -0
  194. package/lib/lowcode/engine/meta/fielddict.props.json +44 -0
  195. package/lib/lowcode/engine/meta/fieldeditor.props.default.json +13 -0
  196. package/lib/lowcode/engine/meta/fieldeditor.props.json +44 -0
  197. package/lib/lowcode/engine/meta/fieldgroup.props.default.json +15 -0
  198. package/lib/lowcode/engine/meta/fieldgroup.props.json +73 -0
  199. package/lib/lowcode/engine/meta/fieldnumber.props.default.json +14 -0
  200. package/lib/lowcode/engine/meta/fieldnumber.props.json +48 -0
  201. package/lib/lowcode/engine/meta/fieldradio.props.default.json +12 -0
  202. package/lib/lowcode/engine/meta/fieldradio.props.json +20 -0
  203. package/lib/lowcode/engine/meta/fieldregion.props.default.json +12 -0
  204. package/lib/lowcode/engine/meta/fieldregion.props.json +26 -0
  205. package/lib/lowcode/engine/meta/fieldselect.props.default.json +14 -0
  206. package/lib/lowcode/engine/meta/fieldselect.props.json +58 -0
  207. package/lib/lowcode/engine/meta/fieldstring.props.default.json +16 -0
  208. package/lib/lowcode/engine/meta/fieldstring.props.json +62 -0
  209. package/lib/lowcode/engine/meta/fieldswitch.props.default.json +12 -0
  210. package/lib/lowcode/engine/meta/fieldswitch.props.json +31 -0
  211. package/lib/lowcode/engine/meta/fieldtextarea.props.default.json +13 -0
  212. package/lib/lowcode/engine/meta/fieldtextarea.props.json +49 -0
  213. package/lib/lowcode/engine/meta/fieldupload.props.default.json +15 -0
  214. package/lib/lowcode/engine/meta/fieldupload.props.json +71 -0
  215. package/lib/lowcode/engine/meta/fielduser.props.default.json +16 -0
  216. package/lib/lowcode/engine/meta/fielduser.props.json +82 -0
  217. package/lib/lowcode/engine/meta/fieldyear.props.default.json +12 -0
  218. package/lib/lowcode/engine/meta/fieldyear.props.json +20 -0
  219. package/lib/lowcode/engine/meta/form.props.json +15 -9
  220. package/lib/lowcode/engine/meta/imex.props.default.json +8 -1
  221. package/lib/lowcode/engine/meta/imex.props.json +54 -22
  222. package/lib/lowcode/engine/meta/js-editor/auto-complete.json +53 -3
  223. package/lib/lowcode/engine/meta/layout.props.json +2 -2
  224. package/lib/lowcode/engine/meta/page.props.json +2 -2
  225. package/lib/lowcode/engine/meta/pagelayout.props.default.json +14 -0
  226. package/lib/lowcode/engine/meta/pagelayout.props.json +47 -0
  227. package/lib/lowcode/engine/meta/section.props.json +2 -2
  228. package/lib/lowcode/engine/meta/split.props.default.json +1 -1
  229. package/lib/lowcode/engine/meta/split.props.json +4 -4
  230. package/lib/lowcode/engine/meta/table.props.json +17 -11
  231. package/lib/lowcode/engine/meta/tabs.props.json +3 -3
  232. package/lib/lowcode/engine/meta/tree.props.default.json +1 -0
  233. package/lib/lowcode/engine/meta/tree.props.json +62 -6
  234. package/lib/lowcode/engine/provider/ContextProvider/index.js +12 -2
  235. package/lib/lowcode/engine/provider/RemoteSourceProvider.js +60 -17
  236. package/lib/lowcode/engine/tools/dataProcess.js +4 -0
  237. package/lib/lowcode/engine/tools/helper.js +25 -1
  238. package/lib/lowcode/engine/tools/usePageDataStore.js +4 -2
  239. package/lib/lowcode/painter/Design.js +4 -4
  240. package/lib/lowcode/painter/DesignOperator.js +101 -64
  241. package/lib/lowcode/painter/DesignToolbar.js +14 -15
  242. package/lib/lowcode/painter/Outline.js +9 -5
  243. package/lib/lowcode/painter/Panel.js +59 -21
  244. package/lib/lowcode/painter/components/ActionBindModal.js +31 -14
  245. package/lib/lowcode/painter/components/AdvancePanel.js +36 -20
  246. package/lib/lowcode/painter/components/AttrsPanel.js +15 -11
  247. package/lib/lowcode/painter/components/FieldSelector.js +26 -13
  248. package/lib/lowcode/painter/components/code-editor/JSEditor.js +5 -9
  249. package/lib/lowcode/painter/components/field-setting/CheckFrontRules.js +116 -0
  250. package/lib/lowcode/painter/components/field-setting/CheckRules.js +1 -26
  251. package/lib/lowcode/painter/components/field-setting/FieldRulesModal.js +34 -13
  252. package/lib/lowcode/painter/components/field-setting/SettingUI.js +153 -21
  253. package/lib/lowcode/painter/components/field-setting/index.js +32 -63
  254. package/lib/lowcode/painter/components/field-setting/meta/frontRules.js +59 -0
  255. package/lib/lowcode/painter/panel-section/BlocksEditor/index.js +9 -15
  256. package/lib/lowcode/painter/panel-section/DataSetSelector.js +29 -9
  257. package/lib/lowcode/painter/panel-section/FieldsSetting.js +76 -32
  258. package/lib/lowcode/painter/panel-section/ImpExp.js +99 -13
  259. package/lib/lowcode/painter/panel-section/ImpExpAlone.js +114 -0
  260. package/lib/lowcode/painter/panel-section/PageLayoutDisplay.js +103 -0
  261. package/lib/lowcode/painter/panel-section/SplitDisplay.js +24 -109
  262. package/lib/lowcode/painter/panel-section/StylePanel/index.js +10 -4
  263. package/lib/lowcode/painter/panel-section/TableTopFilter.js +22 -12
  264. package/lib/lowcode/painter/style/action-bind-modal.less +3 -3
  265. package/lib/lowcode/painter/style/page-layout-display.less +28 -0
  266. package/lib/lowcode/painter/style/split-display.less +0 -9
  267. package/lib/lowcode/preview/index.js +4 -2
  268. package/lib/lowcode/view/Page.js +4 -4
  269. package/lib/lowcode/view/lc-components/Box/FunctionDesign.js +3 -2
  270. package/lib/lowcode/view/lc-components/Box/meta.json +3 -3
  271. package/lib/lowcode/view/lc-components/Button/index.js +2 -6
  272. package/lib/lowcode/view/lc-components/Button/meta.json +3 -3
  273. package/lib/lowcode/view/lc-components/CardList/meta.json +13 -3
  274. package/lib/lowcode/view/lc-components/Dialog/index.js +32 -5
  275. package/lib/lowcode/view/lc-components/Dialog/meta.json +12 -5
  276. package/lib/lowcode/view/lc-components/Drawer/meta.json +8 -20
  277. package/lib/lowcode/view/lc-components/FieldColor/meta.json +63 -0
  278. package/lib/lowcode/view/lc-components/FieldComplex/meta.json +39 -0
  279. package/lib/lowcode/view/lc-components/FieldDate/meta.json +45 -0
  280. package/lib/lowcode/view/lc-components/FieldDict/meta.json +44 -0
  281. package/lib/lowcode/view/lc-components/FieldEditor/meta.json +44 -0
  282. package/lib/lowcode/view/lc-components/FieldGroup/meta.json +73 -0
  283. package/lib/lowcode/view/lc-components/FieldNumber/meta.json +48 -0
  284. package/lib/lowcode/view/lc-components/FieldRadio/meta.json +20 -0
  285. package/lib/lowcode/view/lc-components/FieldRegion/meta.json +26 -0
  286. package/lib/lowcode/view/lc-components/FieldSelect/meta.json +58 -0
  287. package/lib/lowcode/view/lc-components/FieldString/meta.json +62 -0
  288. package/lib/lowcode/view/lc-components/FieldSwitch/meta.json +31 -0
  289. package/lib/lowcode/view/lc-components/FieldTextarea/meta.json +49 -0
  290. package/lib/lowcode/view/lc-components/FieldUpload/meta.json +71 -0
  291. package/lib/lowcode/view/lc-components/FieldUser/meta.json +82 -0
  292. package/lib/lowcode/view/lc-components/FieldYear/meta.json +20 -0
  293. package/lib/lowcode/view/lc-components/Form/FunctionPreview.js +8 -1
  294. package/lib/lowcode/view/lc-components/Form/index.js +185 -35
  295. package/lib/lowcode/view/lc-components/Form/meta.json +15 -9
  296. package/lib/lowcode/view/lc-components/ImEx/FunctionDesign.js +8 -3
  297. package/lib/lowcode/view/lc-components/ImEx/index.js +468 -9
  298. package/lib/lowcode/view/lc-components/ImEx/index.less +7 -0
  299. package/lib/lowcode/view/lc-components/ImEx/meta.json +55 -23
  300. package/lib/lowcode/view/lc-components/Layout/meta.json +2 -2
  301. package/lib/lowcode/view/lc-components/Page/meta.json +2 -2
  302. package/lib/lowcode/view/lc-components/PageLayout/FunctionDesign.js +71 -0
  303. package/lib/lowcode/view/lc-components/PageLayout/FunctionLive.js +17 -0
  304. package/lib/lowcode/view/lc-components/PageLayout/FunctionPreview.js +17 -0
  305. package/lib/lowcode/view/lc-components/PageLayout/index.js +40 -0
  306. package/lib/lowcode/view/lc-components/PageLayout/meta.json +47 -0
  307. package/lib/lowcode/view/lc-components/Section/meta.json +2 -2
  308. package/lib/lowcode/view/lc-components/Split/FunctionDesign.js +12 -6
  309. package/lib/lowcode/view/lc-components/Split/index.js +2 -6
  310. package/lib/lowcode/view/lc-components/Split/meta.json +4 -4
  311. package/lib/lowcode/view/lc-components/Table/components/TopFilter.js +75 -55
  312. package/lib/lowcode/view/lc-components/Table/components/TopImex.js +428 -0
  313. package/lib/lowcode/view/lc-components/Table/index.js +226 -22
  314. package/lib/lowcode/view/lc-components/Table/meta.json +17 -11
  315. package/lib/lowcode/view/lc-components/Tabs/FunctionDesign.js +4 -3
  316. package/lib/lowcode/view/lc-components/Tabs/index.js +3 -1
  317. package/lib/lowcode/view/lc-components/Tabs/meta.json +3 -3
  318. package/lib/lowcode/view/lc-components/Tree/FunctionDesign.js +2 -3
  319. package/lib/lowcode/view/lc-components/Tree/index.js +93 -26
  320. package/lib/lowcode/view/lc-components/Tree/meta.json +62 -7
  321. package/lib/upload/FilesWall/index.js +13 -13
  322. package/lib/upload/FilesWall/index.less +74 -74
  323. package/lib/upload/Form/gridForm.js +3 -2
  324. package/lib/upload/FormItem/index.js +3 -5
  325. package/lib/utils/form.js +16 -3
  326. package/lib/utils/grid.js +8 -5
  327. package/package.json +3 -3
  328. package/es/lowcode/engine/meta/local/local.zh-cn.js +0 -97
  329. package/lib/lowcode/engine/meta/local/local.zh-cn.js +0 -103
@@ -3,32 +3,32 @@ import React, { useRef, useEffect, useState } from 'react';
3
3
  import { last, initial } from 'lodash';
4
4
  import { useEventListener, useSetState, useMemoizedFn, useCreation, useSize, useLatest } from 'ahooks';
5
5
  import { Icon, Dropdown, message } from 'luck-design/antd';
6
- import { reverse } from 'lodash';
6
+ import { reverse, isString, isNil } from 'lodash';
7
7
  import { suid } from '@luck-design-biz/base/utils';
8
8
  import { useContext, addNode, deleteNode } from "../engine/provider/ContextProvider";
9
- import { LC_BUILDIN_UNIT_KEY, LC_COMPONENT_UNIT_KEY, LC_COMPONENT_UNIT, CONTAINER_UNITS } from "../constants";
9
+ import { LC_BUILDIN_UNIT_KEY, LC_COMPONENT_UNIT_KEY, LC_COMPONENT_UNIT, LC_FORMITEM_UNIT, CONTAINER_UNITS } from "../constants";
10
10
  import styles from "./style/design.less";
11
11
  var _MODAL_COMPONENT_ = ['Dialog', 'Drawer'];
12
- var getOperatorStyle = function getOperatorStyle(page, cellNode) {
12
+ var getOperatorStyle = function getOperatorStyle(canvas, cellNode) {
13
13
  if (!cellNode) return {};
14
- var _page$getBoundingClie = page.getBoundingClientRect(),
15
- pageLeft = _page$getBoundingClie.left,
16
- pageTop = _page$getBoundingClie.top;
14
+ var _canvas$getBoundingCl = canvas.getBoundingClientRect(),
15
+ pageLeft = _canvas$getBoundingCl.left,
16
+ pageTop = _canvas$getBoundingCl.top;
17
17
  var _cellNode$getBounding = cellNode.getBoundingClientRect(),
18
18
  cellNodeLeft = _cellNode$getBounding.left,
19
19
  cellNodeTop = _cellNode$getBounding.top;
20
20
  return {
21
21
  left: "".concat(cellNodeLeft - pageLeft, "px"),
22
- top: "".concat(cellNodeTop - pageTop, "px"),
22
+ top: "".concat(cellNode.offsetTop, "px"),
23
23
  width: "".concat(cellNode.offsetWidth, "px"),
24
24
  height: "".concat(cellNode.offsetHeight, "px")
25
25
  };
26
26
  };
27
27
  var DesignOperator = function DesignOperator(_ref) {
28
- var _getDomById, _getDomById2;
29
- var target = _ref.target;
28
+ var _getElement, _getElement2;
29
+ var canvas = _ref.canvas;
30
30
  var context = useContext();
31
- var size = useSize(target);
31
+ var size = useSize(canvas);
32
32
  var _useState = useState(suid()),
33
33
  _useState2 = _slicedToArray(_useState, 2),
34
34
  positionKey = _useState2[0],
@@ -42,18 +42,18 @@ var DesignOperator = function DesignOperator(_ref) {
42
42
  setOperatorId = _useSetState2[1];
43
43
  var lastSelectorId = useLatest(operatorId.selector);
44
44
  var currentModal = useRef(null);
45
- var getDomById = useMemoizedFn(function (id) {
45
+ var getElement = useMemoizedFn(function (_target) {
46
46
  var _context$componentMap;
47
- return (_context$componentMap = context.componentMap.get(id)) === null || _context$componentMap === void 0 ? void 0 : _context$componentMap.api.getSelfDom();
47
+ return isString(_target) ? (_context$componentMap = context.componentMap.get(_target)) === null || _context$componentMap === void 0 ? void 0 : _context$componentMap.api.getSelfDom() : _target;
48
48
  });
49
- var handleSelect = useMemoizedFn(function (_key) {
50
- context.$publisher(context.topics.COMPONENT_ACTIVE, _key ? {
51
- id: _key
49
+ var handleSelect = useMemoizedFn(function (_target) {
50
+ context.$publisher(context.topics.COMPONENT_ACTIVE, _target ? {
51
+ target: _target
52
52
  } : null);
53
53
  });
54
- var handleHover = useMemoizedFn(function (_key) {
55
- context.$publisher(context.topics.COMPONENT_HOVER, _key ? {
56
- id: _key
54
+ var handleHover = useMemoizedFn(function (_target) {
55
+ context.$publisher(context.topics.COMPONENT_HOVER, _target ? {
56
+ target: _target
57
57
  } : null);
58
58
  });
59
59
  var handleDelete = useMemoizedFn(function (_ref2) {
@@ -69,9 +69,7 @@ var DesignOperator = function DesignOperator(_ref) {
69
69
  context.$publisher(context.topics.COMPONENT_APPEND, {
70
70
  id: _id
71
71
  });
72
- context.$publisher(context.topics.COMPONENT_ACTIVE, {
73
- id: _id
74
- });
72
+ handleSelect(_id);
75
73
  }
76
74
  }).watch();
77
75
  var json = require("../engine/meta/".concat(data.component.toLowerCase(), ".props.default.json"));
@@ -80,7 +78,17 @@ var DesignOperator = function DesignOperator(_ref) {
80
78
  });
81
79
  var acticeProps = useCreation(function () {
82
80
  if (!operatorId.selector) return null;
83
- var levelNodes = context.componentMap.get(operatorId.selector).api.getLevelNodes();
81
+ var _id = isNil(operatorId.selectorTarget) ? operatorId.selector : operatorId.selectorTarget.ancestorId;
82
+ var levelNodes = context.componentMap.get(_id).api.getLevelNodes();
83
+ if (operatorId.selectorTarget) {
84
+ var _operatorId$selectorT = operatorId.selectorTarget,
85
+ id = _operatorId$selectorT.id,
86
+ label = _operatorId$selectorT.label;
87
+ levelNodes.push({
88
+ id: id,
89
+ name: label
90
+ });
91
+ }
84
92
  return {
85
93
  props: last(levelNodes),
86
94
  menu: /*#__PURE__*/React.createElement("div", {
@@ -102,50 +110,70 @@ var DesignOperator = function DesignOperator(_ref) {
102
110
  }))
103
111
  };
104
112
  }, [operatorId.selector]);
105
- var lastDetectorNode = useCreation(function () {
106
- return operatorId.detector ? last(context.componentMap.get(operatorId.detector).api.getLevelNodes()) : null;
113
+ var lastDetectorName = useCreation(function () {
114
+ var _last;
115
+ return operatorId.detector && isString(operatorId.detector) ? (_last = last(context.componentMap.get(operatorId.detector).api.getLevelNodes())) === null || _last === void 0 ? void 0 : _last.name : void 0;
107
116
  }, [operatorId.detector]);
108
117
  useEventListener('mousemove', function (event) {
109
118
  var elem = event.target;
119
+ var targetFormItem = elem.closest("[".concat(LC_COMPONENT_UNIT_KEY, "=\"").concat(LC_FORMITEM_UNIT, "\"]"));
120
+ if (targetFormItem) {
121
+ handleHover(targetFormItem);
122
+ return;
123
+ }
110
124
  var targetCell = elem.closest("[".concat(LC_COMPONENT_UNIT_KEY, "=\"").concat(LC_COMPONENT_UNIT, "\"]"));
111
125
  var targetCellId = targetCell === null || targetCell === void 0 ? void 0 : targetCell.id;
112
126
  if (targetCellId && targetCellId !== operatorId.detector && targetCellId !== operatorId.selector) {
113
- setOperatorId({
114
- detector: targetCellId
115
- });
116
- context.$publisher(context.topics.COMPONENT_HOVER, {
117
- id: targetCellId
118
- });
127
+ handleHover(targetCellId);
119
128
  } else if (!targetCell || targetCellId === operatorId.selector) {
120
- setOperatorId({
121
- detector: null
122
- });
123
- context.$publisher(context.topics.COMPONENT_HOVER, null);
129
+ handleHover();
124
130
  }
125
131
  }, {
126
- target: target
132
+ target: canvas
127
133
  });
128
134
  useEventListener('mouseleave', function () {
129
135
  if (operatorId.detector) {
130
- setOperatorId({
131
- detector: null
132
- });
133
- context.$publisher(context.topics.COMPONENT_HOVER, null);
136
+ handleHover();
134
137
  }
135
138
  }, {
136
- target: target
139
+ target: canvas
137
140
  });
138
141
  useEventListener('click', function (event) {
139
142
  var elem = event.target;
143
+ var targetFormItem = elem.closest("[".concat(LC_COMPONENT_UNIT_KEY, "=\"").concat(LC_FORMITEM_UNIT, "\"]"));
144
+ if (targetFormItem) {
145
+ var _fieldName = targetFormItem.getAttribute('data-__field');
146
+ var _fieldLabel = targetFormItem.getAttribute('data-__label');
147
+ var _masterId = targetFormItem.getAttribute('data-__master');
148
+ var _ancestorId = targetFormItem.closest("[".concat(LC_COMPONENT_UNIT_KEY, "=\"").concat(LC_COMPONENT_UNIT, "\"]")).getAttribute('id');
149
+ var _ancestor = context.componentMap.get(_ancestorId);
150
+ var ancestorData = _ancestor.api.getSelfData();
151
+ var blockIndex = ancestorData.props.blocks.findIndex(function (b) {
152
+ return b.id === _masterId;
153
+ });
154
+ var fieldIndex = ancestorData.props.blocks[blockIndex].fields.findIndex(function (f) {
155
+ return f.field === _fieldName;
156
+ });
157
+ var _target = {
158
+ element: targetFormItem,
159
+ id: "".concat(_ancestorId, ".").concat(_masterId, ".").concat(_fieldName),
160
+ field: _fieldName,
161
+ label: _fieldLabel,
162
+ masterId: _masterId,
163
+ ancestorId: _ancestorId,
164
+ keyPath: "blocks[".concat(blockIndex, "].fields[").concat(fieldIndex, "]")
165
+ };
166
+ handleHover();
167
+ handleSelect(_target);
168
+ return;
169
+ }
140
170
  var targetCell = elem.closest("[".concat(LC_COMPONENT_UNIT_KEY, "=\"").concat(LC_COMPONENT_UNIT, "\"]"));
141
171
  var targetCellId = targetCell === null || targetCell === void 0 ? void 0 : targetCell.id;
142
172
  if (!targetCellId || targetCellId === operatorId.selector) return;
143
- context.$publisher(context.topics.COMPONENT_HOVER, null);
144
- context.$publisher(context.topics.COMPONENT_ACTIVE, {
145
- id: targetCell.id
146
- });
173
+ handleHover();
174
+ handleSelect(targetCell.id);
147
175
  }, {
148
- target: target
176
+ target: canvas
149
177
  });
150
178
  useEffect(function () {
151
179
  var csid = context.$subscriber(context.topics.COMPONENT_SETTING_CLICK).on(function (_ref4) {
@@ -157,9 +185,7 @@ var DesignOperator = function DesignOperator(_ref) {
157
185
  toggle: true,
158
186
  id: compId
159
187
  });
160
- context.$publisher(context.topics.COMPONENT_ACTIVE, {
161
- id: compId
162
- });
188
+ handleSelect(compId);
163
189
  }).watch();
164
190
  addComponent(data, LC_BUILDIN_UNIT_KEY.PAGE_ROOT);
165
191
  return;
@@ -175,23 +201,34 @@ var DesignOperator = function DesignOperator(_ref) {
175
201
  addComponent(data, lastSelectorId.current);
176
202
  }).watch();
177
203
  var hcid = context.$subscriber(context.topics.COMPONENT_HOVER).on(function (payload) {
178
- if (payload.id) setOperatorId({
179
- detector: payload.id
204
+ if (payload.target) setOperatorId({
205
+ detector: payload.target
180
206
  });else setOperatorId({
181
207
  detector: null
182
208
  });
183
209
  }).watch();
184
210
  var acid = context.$subscriber(context.topics.COMPONENT_ACTIVE).on(function (payload) {
185
- if (payload.id) {
186
- var node = context.componentMap.get(payload.id).api.getSelfData();
187
- setOperatorId({
188
- selector: payload.id,
189
- deletable: node.props.buildIn !== true,
190
- detector: null
191
- });
211
+ if (payload.target) {
212
+ if (isString(payload.target)) {
213
+ var node = context.componentMap.get(payload.target).api.getSelfData();
214
+ setOperatorId({
215
+ selector: payload.target,
216
+ selectorTarget: null,
217
+ deletable: !node || node.props.buildIn !== true,
218
+ detector: null
219
+ });
220
+ } else {
221
+ setOperatorId({
222
+ selector: payload.target.id,
223
+ selectorTarget: payload.target,
224
+ deletable: false,
225
+ detector: null
226
+ });
227
+ }
192
228
  } else {
193
229
  setOperatorId({
194
- selector: null
230
+ selector: null,
231
+ selectorTarget: null
195
232
  });
196
233
  }
197
234
  }).watch();
@@ -199,14 +236,14 @@ var DesignOperator = function DesignOperator(_ref) {
199
236
  var toggle = _ref6.toggle,
200
237
  id = _ref6.id;
201
238
  if (toggle && id !== currentModal.current) {
202
- target.current.style.setProperty('overflow', 'hidden');
239
+ canvas.current.style.setProperty('overflow', 'hidden');
203
240
  var _modal = context.componentMap.get(id);
204
241
  var _prevModal = currentModal.current ? context.componentMap.get(currentModal.current) : null;
205
242
  _prevModal === null || _prevModal === void 0 || _prevModal.api.doClose();
206
243
  _modal.api.doOpen();
207
244
  currentModal.current = id;
208
245
  } else if (!toggle) {
209
- target.current.style.removeProperty('overflow');
246
+ canvas.current.style.removeProperty('overflow');
210
247
  var _id = id || currentModal.current;
211
248
  if (_id) {
212
249
  var _modal2 = context.componentMap.get(_id);
@@ -218,7 +255,7 @@ var DesignOperator = function DesignOperator(_ref) {
218
255
  var cdid = context.$subscriber(context.topics.COMPONENT_DELETE).on(function (_ref7) {
219
256
  var id = _ref7.id;
220
257
  if (lastSelectorId.current === id) {
221
- context.$publisher(context.topics.COMPONENT_ACTIVE, null);
258
+ handleSelect();
222
259
  }
223
260
  deleteNode(id);
224
261
  });
@@ -241,22 +278,22 @@ var DesignOperator = function DesignOperator(_ref) {
241
278
  return /*#__PURE__*/React.createElement(React.Fragment, null, operatorId.detector && /*#__PURE__*/React.createElement("div", {
242
279
  id: "lc-detector",
243
280
  className: styles['lc-painter-design-detector'],
244
- style: getOperatorStyle(target.current, getDomById(operatorId.detector), 'detector', operatorId.detector)
281
+ style: getOperatorStyle(canvas.current, getElement(operatorId.detector))
245
282
  }, /*#__PURE__*/React.createElement("span", {
246
283
  className: styles['lc-painter-design-detector-name'],
247
284
  style: {
248
- top: ((_getDomById = getDomById(operatorId.detector)) === null || _getDomById === void 0 ? void 0 : _getDomById.offsetTop) < 23 ? 0 : '-23px'
285
+ top: ((_getElement = getElement(operatorId.detector)) === null || _getElement === void 0 ? void 0 : _getElement.offsetTop) < 23 ? 0 : '-23px'
249
286
  }
250
- }, lastDetectorNode ? "".concat(lastDetectorNode.name, "(").concat(operatorId.detector, ")") : null)), operatorId.selector && /*#__PURE__*/React.createElement("div", {
287
+ }, lastDetectorName ? "".concat(lastDetectorName, "(").concat(operatorId.detector, ")") : null)), operatorId.selector && /*#__PURE__*/React.createElement("div", {
251
288
  id: "lc-selector",
252
289
  key: "".concat((size === null || size === void 0 ? void 0 : size.width) || 0, "-").concat((size === null || size === void 0 ? void 0 : size.height) || 0, "-").concat(positionKey),
253
290
  className: styles['lc-painter-design-selector'],
254
- style: getOperatorStyle(target.current, getDomById(operatorId.selector), 'selector', operatorId.selector)
291
+ style: getOperatorStyle(canvas.current, getElement(isNil(operatorId.selectorTarget) ? operatorId.selector : operatorId.selectorTarget.element))
255
292
  }, acticeProps && /*#__PURE__*/React.createElement("div", {
256
293
  className: styles['lc-borders-actions'],
257
294
  style: acticeProps.props.id === LC_BUILDIN_UNIT_KEY.PAGE_ROOT ? {
258
295
  top: 0
259
- } : ((_getDomById2 = getDomById(operatorId.selector)) === null || _getDomById2 === void 0 ? void 0 : _getDomById2.offsetTop) < 23 ? {
296
+ } : ((_getElement2 = getElement(isNil(operatorId.selectorTarget) ? operatorId.selector : operatorId.selectorTarget.element)) === null || _getElement2 === void 0 ? void 0 : _getElement2.offsetTop) < 23 ? {
260
297
  bottom: '-23px'
261
298
  } : {
262
299
  top: '-23px'
@@ -12,12 +12,13 @@ import classNames from 'classnames';
12
12
  import { useMemoizedFn, useRequest, useDebounceFn, useCookieState } from 'ahooks';
13
13
  import { Select, Button, Icon, Divider, Modal, message, Drawer } from 'luck-design/antd';
14
14
  import { showPop, formatMessage } from '@luck-design-biz/base/utils';
15
- import { useContext, useGet, resetPageData, useRemoteSource } from "../engine/provider/ContextProvider";
15
+ import { useContext, useGet, resetPageData } from "../engine/provider/ContextProvider";
16
16
  import JsonEditor from "../painter/components/code-editor/JsonEditor";
17
17
  import Preview from "../preview";
18
18
  import { LC_BUILDIN_UNIT_KEY, COOKIE_VIRTUAL_ACCOUNT_KEY } from "../constants";
19
19
  import styles from "./style/design.less";
20
20
  import { fetchClearCache, fetchUpdatePageData } from "../constants/api-url";
21
+ import { getLDMetaAttr } from "../engine/tools/helper";
21
22
  import { readAllUser } from '@luck-design-biz/base/lib/sys/services';
22
23
  var DesignToolbar = function DesignToolbar(_ref) {
23
24
  var locale = _ref.locale,
@@ -26,8 +27,6 @@ var DesignToolbar = function DesignToolbar(_ref) {
26
27
  var editorRef = useRef();
27
28
  var context = useContext();
28
29
  var pageData = useGet();
29
- var _ref2 = useRemoteSource() || {},
30
- pageinfo = _ref2.pageinfo;
31
30
  var _useState = useState(null),
32
31
  _useState2 = _slicedToArray(_useState, 2),
33
32
  langList = _useState2[0],
@@ -64,8 +63,8 @@ var DesignToolbar = function DesignToolbar(_ref) {
64
63
  updatePageDataLoading = _useRequest2.loading,
65
64
  runAsync = _useRequest2.runAsync;
66
65
  useEffect(function () {
67
- var topicId = context.$subscriber(context.topics.LANG_SETTING_SELECT).on(function (_ref3) {
68
- var _langList = _ref3.langList;
66
+ var topicId = context.$subscriber(context.topics.LANG_SETTING_SELECT).on(function (_ref2) {
67
+ var _langList = _ref2.langList;
69
68
  return setLangList(_langList);
70
69
  }).watch();
71
70
  return function () {
@@ -78,7 +77,6 @@ var DesignToolbar = function DesignToolbar(_ref) {
78
77
  }
79
78
  }, [showPreview]);
80
79
  var handleSave = useMemoizedFn( /*#__PURE__*/_asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee() {
81
- var _pageinfo$relationshi;
82
80
  var _yield$runAsync, code;
83
81
  return _regeneratorRuntime().wrap(function _callee$(_context) {
84
82
  while (1) switch (_context.prev = _context.next) {
@@ -86,7 +84,7 @@ var DesignToolbar = function DesignToolbar(_ref) {
86
84
  _context.next = 2;
87
85
  return runAsync({
88
86
  pageData: JSON.stringify(pageData),
89
- pageCode: pageinfo === null || pageinfo === void 0 || (_pageinfo$relationshi = pageinfo.relationship) === null || _pageinfo$relationshi === void 0 ? void 0 : _pageinfo$relationshi.pageCode
87
+ pageCode: getLDMetaAttr('pageCode')
90
88
  });
91
89
  case 2:
92
90
  _yield$runAsync = _context.sent;
@@ -118,7 +116,7 @@ var DesignToolbar = function DesignToolbar(_ref) {
118
116
  zIndex: 3000,
119
117
  onOk: function onOk() {
120
118
  return runClearCache({
121
- moduleCode: pageinfo.relationship.moduleCode
119
+ moduleCode: getLDMetaAttr('moduleCode')
122
120
  });
123
121
  }
124
122
  });
@@ -138,7 +136,7 @@ var DesignToolbar = function DesignToolbar(_ref) {
138
136
  }
139
137
  });
140
138
  var _useDebounceFn = useDebounceFn( /*#__PURE__*/function () {
141
- var _ref5 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(value) {
139
+ var _ref4 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee2(value) {
142
140
  var _yield$readAllUser, code, list, detail;
143
141
  return _regeneratorRuntime().wrap(function _callee2$(_context2) {
144
142
  while (1) switch (_context2.prev = _context2.next) {
@@ -168,7 +166,7 @@ var DesignToolbar = function DesignToolbar(_ref) {
168
166
  }, _callee2);
169
167
  }));
170
168
  return function (_x) {
171
- return _ref5.apply(this, arguments);
169
+ return _ref4.apply(this, arguments);
172
170
  };
173
171
  }(), {
174
172
  wait: 500
@@ -213,7 +211,7 @@ var DesignToolbar = function DesignToolbar(_ref) {
213
211
  className: styles['toolbar-item'],
214
212
  onClick: function onClick() {
215
213
  context.$publisher(context.topics.COMPONENT_ACTIVE, {
216
- id: LC_BUILDIN_UNIT_KEY.PAGE_ROOT
214
+ target: LC_BUILDIN_UNIT_KEY.PAGE_ROOT
217
215
  });
218
216
  }
219
217
  }, formatMessage({
@@ -327,10 +325,10 @@ var DesignToolbar = function DesignToolbar(_ref) {
327
325
  setUserId(void 0);
328
326
  }
329
327
  }
330
- }, userOptions.map(function (_ref6) {
331
- var key = _ref6.key,
332
- label = _ref6.label,
333
- rest = _objectWithoutProperties(_ref6, _excluded);
328
+ }, userOptions.map(function (_ref5) {
329
+ var key = _ref5.key,
330
+ label = _ref5.label,
331
+ rest = _objectWithoutProperties(_ref5, _excluded);
334
332
  return /*#__PURE__*/React.createElement(Select.Option, _extends({
335
333
  key: key,
336
334
  value: key
@@ -357,7 +355,8 @@ var DesignToolbar = function DesignToolbar(_ref) {
357
355
  }
358
356
  }, /*#__PURE__*/React.createElement(Preview, {
359
357
  code: location.query.code,
360
- userId: userId || 'no-user'
358
+ userId: userId || 'no-user',
359
+ debug: true
361
360
  })));
362
361
  };
363
362
  export default DesignToolbar;
@@ -5,7 +5,7 @@ import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
5
5
  var _excluded = ["props", "children"];
6
6
  import React, { useRef, useState, useEffect } from 'react';
7
7
  import { useMemoizedFn, useDeepCompareLayoutEffect, useLatest } from 'ahooks';
8
- import { uniq, split, reduce } from 'lodash';
8
+ import { uniq, split, reduce, isString } from 'lodash';
9
9
  import classNames from 'classnames';
10
10
  import { Card, Tree, Icon } from 'luck-design/antd';
11
11
  import { formatMessage } from '@luck-design-biz/base/utils';
@@ -40,18 +40,22 @@ var Outline = function Outline(_ref) {
40
40
  var lastPageExpandedKeysRef = useLatest(pageExpandedKeys);
41
41
  useEffect(function () {
42
42
  var _id = ctx.$subscriber(ctx.topics.COMPONENT_ACTIVE).on(function (payload) {
43
- setSelectedKey(payload.id);
43
+ if (!isString(payload.target)) {
44
+ setSelectedKey(null);
45
+ return;
46
+ }
47
+ setSelectedKey(payload.target);
44
48
  if (clickBySelf.current) {
45
49
  clickBySelf.current = false;
46
50
  return;
47
51
  }
48
- var _split = split(getPathById(pageData, payload.id), '/'),
52
+ var _split = split(getPathById(pageData, payload.target), '/'),
49
53
  _split2 = _slicedToArray(_split, 1),
50
54
  _root = _split2[0];
51
55
  if (!LC_BUILDIN_UNIT_KEY_LIST.includes(_root)) {
52
- setModalExpandedKeys(uniq([].concat(_toConsumableArray(latestModalExpandedKeysRef.current), _toConsumableArray(split(getPathById(pageData, payload.id), '/')))));
56
+ setModalExpandedKeys(uniq([].concat(_toConsumableArray(latestModalExpandedKeysRef.current), _toConsumableArray(split(getPathById(pageData, payload.target), '/')))));
53
57
  } else {
54
- setPageExpandedKeys(uniq([].concat(_toConsumableArray(lastPageExpandedKeysRef.current), _toConsumableArray(split(getPathById(pageData, payload.id), '/')))));
58
+ setPageExpandedKeys(uniq([].concat(_toConsumableArray(lastPageExpandedKeysRef.current), _toConsumableArray(split(getPathById(pageData, payload.target), '/')))));
55
59
  }
56
60
  }).watch();
57
61
  return function () {
@@ -61,7 +65,7 @@ var Outline = function Outline(_ref) {
61
65
  var handleSelect = useMemoizedFn(function (_key) {
62
66
  clickBySelf.current = true;
63
67
  ctx.$publisher(ctx.topics.COMPONENT_ACTIVE, _key ? {
64
- id: _key
68
+ target: _key
65
69
  } : null);
66
70
  });
67
71
  var render = useMemoizedFn(function (_ref2) {
@@ -1,3 +1,4 @@
1
+ import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
1
2
  import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
2
3
  import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
3
4
  import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
@@ -5,7 +6,7 @@ import React, { useRef, useState, useEffect, useLayoutEffect } from 'react';
5
6
  import { useCreation, useMemoizedFn } from 'ahooks';
6
7
  import { Breadcrumb } from 'luck-design/antd';
7
8
  import classNames from 'classnames';
8
- import { takeRight, isNil, reduce, get, set } from 'lodash';
9
+ import { takeRight, isNil, reduce, get, isString } from 'lodash';
9
10
  import { formatMessage } from '@luck-design-biz/base/utils';
10
11
  import { useContext, useTask, addNode, deleteNode } from "../engine/provider/ContextProvider";
11
12
  import AttrsPanel from "./components/AttrsPanel";
@@ -34,6 +35,7 @@ var _TAB_LIST_ = [{
34
35
  key: 'advance'
35
36
  }];
36
37
  var Panel = function Panel() {
38
+ var _activeNode$$target;
37
39
  var activeTabRef = useRef(null);
38
40
  var underLineRef = useRef(null);
39
41
  var _useState = useState(null),
@@ -47,8 +49,24 @@ var Panel = function Panel() {
47
49
  var context = useContext();
48
50
  var task = useTask('modify');
49
51
  var meta = useCreation(function () {
52
+ if (isNil(activeNode)) return null;
50
53
  try {
51
- return isNil(activeNode) ? null : require("../engine/meta/".concat(activeNode.node.component.toLowerCase(), ".props.json"));
54
+ var _meta = require("../engine/meta/".concat(activeNode.node.component.toLowerCase(), ".props.json"));
55
+ if (!isNil(activeNode === null || activeNode === void 0 ? void 0 : activeNode.$target)) {
56
+ var setValueKey = function setValueKey(items) {
57
+ items.forEach(function (item) {
58
+ if (item.next) {
59
+ setValueKey(item.next.props);
60
+ } else if (item.props) {
61
+ setValueKey(item.props);
62
+ } else {
63
+ item.valueKey = "".concat(activeNode.$target.keyPath, ".").concat(item.key);
64
+ }
65
+ });
66
+ };
67
+ setValueKey(_meta.props);
68
+ }
69
+ return _meta;
52
70
  } catch (e) {
53
71
  return null;
54
72
  }
@@ -76,41 +94,59 @@ var Panel = function Panel() {
76
94
  deleteNode(LC_BUILDIN_UNIT_KEY.PAGE_FOOTER);
77
95
  }
78
96
  }
79
- var component = context.componentMap.get(activeNode.node.id);
97
+ var targetId = isNil(activeNode.$target) ? activeNode.node.id : activeNode.$target.ancestorId;
98
+ var component = context.componentMap.get(targetId);
80
99
  var node = component.api.getSelfData();
81
100
  var oldValue = _defineProperty({}, field, get(node.props, field));
82
101
  var newValue = _defineProperty({}, field, value);
83
102
  if (before) {
84
103
  before(handleChange);
85
104
  }
86
- task(activeNode.node.id, newValue).then(function (a, b) {
105
+ task(targetId, newValue).then(function () {
87
106
  context.$publisher(context.topics.COMPONENT_MODIFY, {
88
- id: activeNode.node.id,
107
+ id: targetId,
89
108
  oldValue: oldValue,
90
109
  newValue: newValue
91
110
  });
92
111
  if (repositioning) context.$publisher(context.topics.COMPONENT_REPOSITIONING, {
93
- id: activeNode.node.id
112
+ id: targetId
94
113
  });
95
114
  });
96
115
  });
97
116
  useEffect(function () {
98
- var _id = context.$subscriber(context.topics.COMPONENT_ACTIVE).on(function (payload) {
117
+ var tid = context.$subscriber(context.topics.COMPONENT_ACTIVE).on(function (payload) {
99
118
  setActiveTabKey('attrs');
100
- if (!payload.id) {
119
+ if (!payload.target) {
101
120
  setActiveNode(null);
102
121
  return;
103
122
  }
104
- var component = context.componentMap.get(payload.id);
105
- var node = component.api.getSelfData();
106
- var levelNodes = takeRight(component.api.getLevelNodes(), 4);
107
- setActiveNode({
108
- node: node.props,
109
- level: levelNodes
110
- });
123
+ if (isString(payload.target)) {
124
+ var component = context.componentMap.get(payload.target);
125
+ var node = component.api.getSelfData();
126
+ var levelNodes = takeRight(component.api.getLevelNodes(), 4);
127
+ setActiveNode({
128
+ node: node.props,
129
+ level: levelNodes
130
+ });
131
+ } else {
132
+ var _component = payload.target.element.getAttribute('data-__component');
133
+ var ancestor = context.componentMap.get(payload.target.ancestorId);
134
+ var _levelNodes = takeRight(ancestor.api.getLevelNodes(), 3);
135
+ setActiveNode({
136
+ node: {
137
+ id: payload.target.id,
138
+ component: _component
139
+ },
140
+ level: [].concat(_toConsumableArray(_levelNodes), [{
141
+ id: payload.target.id,
142
+ name: payload.target.label
143
+ }]),
144
+ $target: payload.target
145
+ });
146
+ }
111
147
  }).watch();
112
148
  return function () {
113
- return context.$unsubscriber(context.topics.COMPONENT_ACTIVE, _id);
149
+ return context.$unsubscriber(context.topics.COMPONENT_ACTIVE, tid);
114
150
  };
115
151
  }, []);
116
152
  useLayoutEffect(function () {
@@ -134,7 +170,7 @@ var Panel = function Panel() {
134
170
  onMouseEnter: function onMouseEnter() {
135
171
  if (id === activeNode.node.id) return;
136
172
  context.$publisher(context.topics.COMPONENT_HOVER, {
137
- id: id
173
+ target: id
138
174
  });
139
175
  },
140
176
  onMouseLeave: function onMouseLeave() {
@@ -144,7 +180,7 @@ var Panel = function Panel() {
144
180
  onClick: function onClick() {
145
181
  if (id === activeNode.node.id) return;
146
182
  context.$publisher(context.topics.COMPONENT_ACTIVE, {
147
- id: id
183
+ target: id
148
184
  });
149
185
  }
150
186
  }, name);
@@ -175,23 +211,25 @@ var Panel = function Panel() {
175
211
  className: styles.underline
176
212
  })), activeTabKey === _TAB_LIST_[0].key && /*#__PURE__*/React.createElement(AttrsPanel, {
177
213
  key: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
214
+ nodeId: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
215
+ ancestorId: activeNode === null || activeNode === void 0 || (_activeNode$$target = activeNode.$target) === null || _activeNode$$target === void 0 ? void 0 : _activeNode$$target.ancestorId,
178
216
  meta: meta,
179
- value: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node,
180
217
  onChange: function onChange(field, value, params) {
181
218
  return handleChange(field, value, params);
182
219
  }
183
220
  }), activeTabKey === _TAB_LIST_[1].key && /*#__PURE__*/React.createElement(StylePanel, {
184
221
  key: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
185
- value: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.css,
222
+ nodeId: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
186
223
  onChange: function onChange(_, newCss) {
187
224
  return handleChange('css', newCss);
188
225
  }
189
226
  }), activeTabKey === _TAB_LIST_[2].key && /*#__PURE__*/React.createElement(AdvancePanel, {
190
227
  key: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
228
+ nodeId: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.id,
229
+ target: activeNode === null || activeNode === void 0 ? void 0 : activeNode.$target,
191
230
  meta: meta,
192
- value: activeNode === null || activeNode === void 0 ? void 0 : activeNode.node.advance,
193
231
  onChange: function onChange(val) {
194
- return handleChange('advance', val);
232
+ return handleChange(isNil(activeNode.$target) ? 'advance' : "".concat(activeNode.$target.keyPath, ".advance"), val);
195
233
  }
196
234
  }), /*#__PURE__*/React.createElement("div", {
197
235
  className: classNames(styles['lc-painter-panel-empty'], _defineProperty({}, styles.hidden, !!activeNode))