@nocobase/flow-engine 2.0.0-alpha.2

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 (597) hide show
  1. package/LICENSE +661 -0
  2. package/README.md +30 -0
  3. package/lib/ContextPathProxy.d.ts +17 -0
  4. package/lib/ContextPathProxy.js +65 -0
  5. package/lib/ElementProxy.d.ts +17 -0
  6. package/lib/ElementProxy.js +93 -0
  7. package/lib/FlowContextProvider.d.ts +24 -0
  8. package/lib/FlowContextProvider.js +82 -0
  9. package/lib/FlowDefinition.d.ts +423 -0
  10. package/lib/FlowDefinition.js +257 -0
  11. package/lib/JSRunner.d.ts +32 -0
  12. package/lib/JSRunner.js +95 -0
  13. package/lib/ReactView.d.ts +20 -0
  14. package/lib/ReactView.js +120 -0
  15. package/lib/ViewScopedFlowEngine.d.ts +23 -0
  16. package/lib/ViewScopedFlowEngine.js +81 -0
  17. package/lib/acl/Acl.d.ts +31 -0
  18. package/lib/acl/Acl.js +115 -0
  19. package/lib/action-registry/BaseActionRegistry.d.ts +23 -0
  20. package/lib/action-registry/BaseActionRegistry.js +57 -0
  21. package/lib/action-registry/EngineActionRegistry.d.ts +20 -0
  22. package/lib/action-registry/EngineActionRegistry.js +47 -0
  23. package/lib/action-registry/ModelActionRegistry.d.ts +34 -0
  24. package/lib/action-registry/ModelActionRegistry.js +79 -0
  25. package/lib/components/DynamicFlowsEditor.d.ts +17 -0
  26. package/lib/components/DynamicFlowsEditor.js +49 -0
  27. package/lib/components/FieldModelRenderer.d.ts +10 -0
  28. package/lib/components/FieldModelRenderer.js +94 -0
  29. package/lib/components/FlowContextSelector.d.ts +11 -0
  30. package/lib/components/FlowContextSelector.js +221 -0
  31. package/lib/components/FlowErrorFallback.d.ts +25 -0
  32. package/lib/components/FlowErrorFallback.js +264 -0
  33. package/lib/components/FlowModelRenderer.d.ts +64 -0
  34. package/lib/components/FlowModelRenderer.js +254 -0
  35. package/lib/components/FormItem.d.ts +18 -0
  36. package/lib/components/FormItem.js +147 -0
  37. package/lib/components/common/FlowSettingsButton.d.ts +11 -0
  38. package/lib/components/common/FlowSettingsButton.js +66 -0
  39. package/lib/components/common/index.d.ts +9 -0
  40. package/lib/components/common/index.js +30 -0
  41. package/lib/components/common/withFlowDesignMode.d.ts +26 -0
  42. package/lib/components/common/withFlowDesignMode.js +61 -0
  43. package/lib/components/dnd/getMousePositionOnElement.d.ts +50 -0
  44. package/lib/components/dnd/getMousePositionOnElement.js +95 -0
  45. package/lib/components/dnd/index.d.ts +24 -0
  46. package/lib/components/dnd/index.js +164 -0
  47. package/lib/components/dnd/moveBlock.d.ts +33 -0
  48. package/lib/components/dnd/moveBlock.js +302 -0
  49. package/lib/components/index.d.ts +18 -0
  50. package/lib/components/index.js +48 -0
  51. package/lib/components/settings/independents/dropdown/FlowsDropdownButton.d.ts +46 -0
  52. package/lib/components/settings/independents/dropdown/FlowsDropdownButton.js +225 -0
  53. package/lib/components/settings/independents/dropdown/index.d.ts +9 -0
  54. package/lib/components/settings/independents/dropdown/index.js +30 -0
  55. package/lib/components/settings/independents/index.d.ts +1 -0
  56. package/lib/components/settings/independents/index.js +30 -0
  57. package/lib/components/settings/index.d.ts +10 -0
  58. package/lib/components/settings/index.js +32 -0
  59. package/lib/components/settings/wrappers/contextual/DefaultSettingsIcon.d.ts +24 -0
  60. package/lib/components/settings/wrappers/contextual/DefaultSettingsIcon.js +501 -0
  61. package/lib/components/settings/wrappers/contextual/FlowsContextMenu.d.ts +45 -0
  62. package/lib/components/settings/wrappers/contextual/FlowsContextMenu.js +231 -0
  63. package/lib/components/settings/wrappers/contextual/FlowsFloatContextMenu.d.ts +111 -0
  64. package/lib/components/settings/wrappers/contextual/FlowsFloatContextMenu.js +484 -0
  65. package/lib/components/settings/wrappers/contextual/StepRequiredSettingsDialog.d.ts +26 -0
  66. package/lib/components/settings/wrappers/contextual/StepRequiredSettingsDialog.js +342 -0
  67. package/lib/components/settings/wrappers/contextual/StepSettings.d.ts +23 -0
  68. package/lib/components/settings/wrappers/contextual/StepSettings.js +110 -0
  69. package/lib/components/settings/wrappers/contextual/StepSettingsDialog.d.ts +20 -0
  70. package/lib/components/settings/wrappers/contextual/StepSettingsDialog.js +206 -0
  71. package/lib/components/settings/wrappers/contextual/StepSettingsDrawer.d.ts +20 -0
  72. package/lib/components/settings/wrappers/contextual/StepSettingsDrawer.js +47 -0
  73. package/lib/components/settings/wrappers/contextual/index.d.ts +14 -0
  74. package/lib/components/settings/wrappers/contextual/index.js +40 -0
  75. package/lib/components/settings/wrappers/embedded/FlowSettings.d.ts +33 -0
  76. package/lib/components/settings/wrappers/embedded/FlowSettings.js +207 -0
  77. package/lib/components/settings/wrappers/embedded/FlowsSettings.d.ts +41 -0
  78. package/lib/components/settings/wrappers/embedded/FlowsSettings.js +84 -0
  79. package/lib/components/settings/wrappers/embedded/FlowsSettingsContent.d.ts +16 -0
  80. package/lib/components/settings/wrappers/embedded/FlowsSettingsContent.js +88 -0
  81. package/lib/components/settings/wrappers/embedded/index.d.ts +10 -0
  82. package/lib/components/settings/wrappers/embedded/index.js +32 -0
  83. package/lib/components/settings/wrappers/index.d.ts +2 -0
  84. package/lib/components/settings/wrappers/index.js +32 -0
  85. package/lib/components/subModel/AddSubModelButton.d.ts +62 -0
  86. package/lib/components/subModel/AddSubModelButton.js +415 -0
  87. package/lib/components/subModel/LazyDropdown.d.ts +55 -0
  88. package/lib/components/subModel/LazyDropdown.js +524 -0
  89. package/lib/components/subModel/index.d.ts +10 -0
  90. package/lib/components/subModel/index.js +32 -0
  91. package/lib/components/subModel/utils.d.ts +34 -0
  92. package/lib/components/subModel/utils.js +287 -0
  93. package/lib/components/variables/InlineVariableTag.d.ts +21 -0
  94. package/lib/components/variables/InlineVariableTag.js +123 -0
  95. package/lib/components/variables/SlateVariableEditor.d.ts +46 -0
  96. package/lib/components/variables/SlateVariableEditor.js +302 -0
  97. package/lib/components/variables/VariableInput.d.ts +11 -0
  98. package/lib/components/variables/VariableInput.js +322 -0
  99. package/lib/components/variables/VariableTag.d.ts +11 -0
  100. package/lib/components/variables/VariableTag.js +148 -0
  101. package/lib/components/variables/VariableTrigger.d.ts +20 -0
  102. package/lib/components/variables/VariableTrigger.js +136 -0
  103. package/lib/components/variables/index.d.ts +15 -0
  104. package/lib/components/variables/index.js +53 -0
  105. package/lib/components/variables/types.d.ts +93 -0
  106. package/lib/components/variables/types.js +24 -0
  107. package/lib/components/variables/useResolvedMetaTree.d.ts +19 -0
  108. package/lib/components/variables/useResolvedMetaTree.js +91 -0
  109. package/lib/components/variables/utils.d.ts +22 -0
  110. package/lib/components/variables/utils.js +177 -0
  111. package/lib/data-source/index.d.ts +180 -0
  112. package/lib/data-source/index.js +733 -0
  113. package/lib/data-source/jioToJoiSchema.d.ts +19 -0
  114. package/lib/data-source/jioToJoiSchema.js +114 -0
  115. package/lib/decorators/index.d.ts +9 -0
  116. package/lib/decorators/index.js +36 -0
  117. package/lib/decorators/largeField.d.ts +9 -0
  118. package/lib/decorators/largeField.js +42 -0
  119. package/lib/emitter.d.ts +16 -0
  120. package/lib/emitter.js +58 -0
  121. package/lib/event-registry/BaseEventRegistry.d.ts +22 -0
  122. package/lib/event-registry/BaseEventRegistry.js +57 -0
  123. package/lib/event-registry/EngineEventRegistry.d.ts +19 -0
  124. package/lib/event-registry/EngineEventRegistry.js +47 -0
  125. package/lib/event-registry/ModelEventRegistry.d.ts +33 -0
  126. package/lib/event-registry/ModelEventRegistry.js +79 -0
  127. package/lib/executor/FlowExecutor.d.ts +26 -0
  128. package/lib/executor/FlowExecutor.js +262 -0
  129. package/lib/flow-registry/BaseFlowRegistry.d.ts +46 -0
  130. package/lib/flow-registry/BaseFlowRegistry.js +86 -0
  131. package/lib/flow-registry/GlobalFlowRegistry.d.ts +22 -0
  132. package/lib/flow-registry/GlobalFlowRegistry.js +95 -0
  133. package/lib/flow-registry/InstanceFlowRegistry.d.ts +21 -0
  134. package/lib/flow-registry/InstanceFlowRegistry.js +59 -0
  135. package/lib/flow-registry/index.d.ts +11 -0
  136. package/lib/flow-registry/index.js +34 -0
  137. package/lib/flowContext.d.ts +215 -0
  138. package/lib/flowContext.js +1266 -0
  139. package/lib/flowEngine.d.ts +340 -0
  140. package/lib/flowEngine.js +781 -0
  141. package/lib/flowI18n.d.ts +46 -0
  142. package/lib/flowI18n.js +117 -0
  143. package/lib/flowSettings.d.ts +266 -0
  144. package/lib/flowSettings.js +850 -0
  145. package/lib/hooks/index.d.ts +14 -0
  146. package/lib/hooks/index.js +40 -0
  147. package/lib/hooks/useApplyAutoFlows.d.ts +21 -0
  148. package/lib/hooks/useApplyAutoFlows.js +62 -0
  149. package/lib/hooks/useFlowModel.d.ts +29 -0
  150. package/lib/hooks/useFlowModel.js +72 -0
  151. package/lib/hooks/useFlowModelById.d.ts +11 -0
  152. package/lib/hooks/useFlowModelById.js +61 -0
  153. package/lib/hooks/useFlowSettingsContext.d.ts +20 -0
  154. package/lib/hooks/useFlowSettingsContext.js +61 -0
  155. package/lib/hooks/useFlowStep.d.ts +17 -0
  156. package/lib/hooks/useFlowStep.js +56 -0
  157. package/lib/hooks/useNiceDropdownMaxHeight.d.ts +13 -0
  158. package/lib/hooks/useNiceDropdownMaxHeight.js +52 -0
  159. package/lib/index.d.ts +27 -0
  160. package/lib/index.js +73 -0
  161. package/lib/locale/en-US.json +61 -0
  162. package/lib/locale/index.d.ts +141 -0
  163. package/lib/locale/index.js +70 -0
  164. package/lib/locale/zh-CN.json +61 -0
  165. package/lib/models/CollectionFieldModel.d.ts +50 -0
  166. package/lib/models/CollectionFieldModel.js +242 -0
  167. package/lib/models/DisplayItemModel.d.ts +12 -0
  168. package/lib/models/DisplayItemModel.js +41 -0
  169. package/lib/models/EditableItemModel.d.ts +12 -0
  170. package/lib/models/EditableItemModel.js +41 -0
  171. package/lib/models/FilterableItemModel.d.ts +12 -0
  172. package/lib/models/FilterableItemModel.js +41 -0
  173. package/lib/models/flowModel.d.ts +344 -0
  174. package/lib/models/flowModel.js +1133 -0
  175. package/lib/models/forkFlowModel.d.ts +83 -0
  176. package/lib/models/forkFlowModel.js +257 -0
  177. package/lib/models/index.d.ts +14 -0
  178. package/lib/models/index.js +40 -0
  179. package/lib/provider.d.ts +22 -0
  180. package/lib/provider.js +114 -0
  181. package/lib/resources/apiResource.d.ts +34 -0
  182. package/lib/resources/apiResource.js +153 -0
  183. package/lib/resources/baseRecordResource.d.ts +61 -0
  184. package/lib/resources/baseRecordResource.js +264 -0
  185. package/lib/resources/filterItem.d.ts +33 -0
  186. package/lib/resources/filterItem.js +93 -0
  187. package/lib/resources/flowResource.d.ts +45 -0
  188. package/lib/resources/flowResource.js +146 -0
  189. package/lib/resources/index.d.ts +15 -0
  190. package/lib/resources/index.js +42 -0
  191. package/lib/resources/multiRecordResource.d.ts +53 -0
  192. package/lib/resources/multiRecordResource.js +230 -0
  193. package/lib/resources/singleRecordResource.d.ts +23 -0
  194. package/lib/resources/singleRecordResource.js +111 -0
  195. package/lib/resources/sqlResource.d.ts +73 -0
  196. package/lib/resources/sqlResource.js +294 -0
  197. package/lib/runjs-context/contexts/FlowRunJSContext.d.ts +38 -0
  198. package/lib/runjs-context/contexts/FlowRunJSContext.js +217 -0
  199. package/lib/runjs-context/contexts/FormJSFieldItemRunJSContext.d.ts +16 -0
  200. package/lib/runjs-context/contexts/FormJSFieldItemRunJSContext.js +66 -0
  201. package/lib/runjs-context/contexts/JSBlockRunJSContext.d.ts +16 -0
  202. package/lib/runjs-context/contexts/JSBlockRunJSContext.js +78 -0
  203. package/lib/runjs-context/contexts/JSCollectionActionRunJSContext.d.ts +12 -0
  204. package/lib/runjs-context/contexts/JSCollectionActionRunJSContext.js +59 -0
  205. package/lib/runjs-context/contexts/JSFieldRunJSContext.d.ts +16 -0
  206. package/lib/runjs-context/contexts/JSFieldRunJSContext.js +70 -0
  207. package/lib/runjs-context/contexts/JSItemRunJSContext.d.ts +16 -0
  208. package/lib/runjs-context/contexts/JSItemRunJSContext.js +66 -0
  209. package/lib/runjs-context/contexts/JSRecordActionRunJSContext.d.ts +12 -0
  210. package/lib/runjs-context/contexts/JSRecordActionRunJSContext.js +61 -0
  211. package/lib/runjs-context/contexts/LinkageRunJSContext.d.ts +12 -0
  212. package/lib/runjs-context/contexts/LinkageRunJSContext.js +62 -0
  213. package/lib/runjs-context/helpers.d.ts +17 -0
  214. package/lib/runjs-context/helpers.js +79 -0
  215. package/lib/runjs-context/index.d.ts +19 -0
  216. package/lib/runjs-context/index.js +57 -0
  217. package/lib/runjs-context/registry.d.ts +17 -0
  218. package/lib/runjs-context/registry.js +93 -0
  219. package/lib/runjs-context/snippets/global/api-request-get.snippet.d.ts +16 -0
  220. package/lib/runjs-context/snippets/global/api-request-get.snippet.js +42 -0
  221. package/lib/runjs-context/snippets/global/api-request-post.snippet.d.ts +16 -0
  222. package/lib/runjs-context/snippets/global/api-request-post.snippet.js +42 -0
  223. package/lib/runjs-context/snippets/global/console-log-ctx.snippet.d.ts +16 -0
  224. package/lib/runjs-context/snippets/global/console-log-ctx.snippet.js +41 -0
  225. package/lib/runjs-context/snippets/global/copy-record-json.snippet.d.ts +11 -0
  226. package/lib/runjs-context/snippets/global/copy-record-json.snippet.js +42 -0
  227. package/lib/runjs-context/snippets/global/copy-to-clipboard.snippet.d.ts +11 -0
  228. package/lib/runjs-context/snippets/global/copy-to-clipboard.snippet.js +42 -0
  229. package/lib/runjs-context/snippets/global/log-json-record.snippet.d.ts +11 -0
  230. package/lib/runjs-context/snippets/global/log-json-record.snippet.js +42 -0
  231. package/lib/runjs-context/snippets/global/message-error.snippet.d.ts +11 -0
  232. package/lib/runjs-context/snippets/global/message-error.snippet.js +41 -0
  233. package/lib/runjs-context/snippets/global/message-success.snippet.d.ts +11 -0
  234. package/lib/runjs-context/snippets/global/message-success.snippet.js +41 -0
  235. package/lib/runjs-context/snippets/global/notification-open.snippet.d.ts +16 -0
  236. package/lib/runjs-context/snippets/global/notification-open.snippet.js +43 -0
  237. package/lib/runjs-context/snippets/global/open-view-dialog.snippet.d.ts +11 -0
  238. package/lib/runjs-context/snippets/global/open-view-dialog.snippet.js +47 -0
  239. package/lib/runjs-context/snippets/global/open-view-drawer.snippet.d.ts +11 -0
  240. package/lib/runjs-context/snippets/global/open-view-drawer.snippet.js +47 -0
  241. package/lib/runjs-context/snippets/global/requireAsync.snippet.d.ts +16 -0
  242. package/lib/runjs-context/snippets/global/requireAsync.snippet.js +46 -0
  243. package/lib/runjs-context/snippets/global/sleep.snippet.d.ts +16 -0
  244. package/lib/runjs-context/snippets/global/sleep.snippet.js +43 -0
  245. package/lib/runjs-context/snippets/global/try-catch-async.snippet.d.ts +16 -0
  246. package/lib/runjs-context/snippets/global/try-catch-async.snippet.js +44 -0
  247. package/lib/runjs-context/snippets/global/view-navigation-push.snippet.d.ts +11 -0
  248. package/lib/runjs-context/snippets/global/view-navigation-push.snippet.js +44 -0
  249. package/lib/runjs-context/snippets/global/window-open.snippet.d.ts +16 -0
  250. package/lib/runjs-context/snippets/global/window-open.snippet.js +41 -0
  251. package/lib/runjs-context/snippets/index.d.ts +11 -0
  252. package/lib/runjs-context/snippets/index.js +94 -0
  253. package/lib/runjs-context/snippets/libs/echarts-init.snippet.d.ts +15 -0
  254. package/lib/runjs-context/snippets/libs/echarts-init.snippet.js +46 -0
  255. package/lib/runjs-context/snippets/scene/actions/collection-selected-count.snippet.d.ts +15 -0
  256. package/lib/runjs-context/snippets/scene/actions/collection-selected-count.snippet.js +44 -0
  257. package/lib/runjs-context/snippets/scene/actions/iterate-selected-rows.snippet.d.ts +15 -0
  258. package/lib/runjs-context/snippets/scene/actions/iterate-selected-rows.snippet.js +43 -0
  259. package/lib/runjs-context/snippets/scene/actions/record-id-message.snippet.d.ts +15 -0
  260. package/lib/runjs-context/snippets/scene/actions/record-id-message.snippet.js +43 -0
  261. package/lib/runjs-context/snippets/scene/actions/run-action-basic.snippet.d.ts +15 -0
  262. package/lib/runjs-context/snippets/scene/actions/run-action-basic.snippet.js +40 -0
  263. package/lib/runjs-context/snippets/scene/jsblock/add-event-listener.snippet.d.ts +15 -0
  264. package/lib/runjs-context/snippets/scene/jsblock/add-event-listener.snippet.js +46 -0
  265. package/lib/runjs-context/snippets/scene/jsblock/append-style.snippet.d.ts +15 -0
  266. package/lib/runjs-context/snippets/scene/jsblock/append-style.snippet.js +42 -0
  267. package/lib/runjs-context/snippets/scene/jsblock/jsx-mount.snippet.d.ts +15 -0
  268. package/lib/runjs-context/snippets/scene/jsblock/jsx-mount.snippet.js +46 -0
  269. package/lib/runjs-context/snippets/scene/jsblock/jsx-unmount.snippet.d.ts +15 -0
  270. package/lib/runjs-context/snippets/scene/jsblock/jsx-unmount.snippet.js +41 -0
  271. package/lib/runjs-context/snippets/scene/jsblock/render-basic.snippet.d.ts +15 -0
  272. package/lib/runjs-context/snippets/scene/jsblock/render-basic.snippet.js +41 -0
  273. package/lib/runjs-context/snippets/scene/jsblock/render-button-handler.snippet.d.ts +15 -0
  274. package/lib/runjs-context/snippets/scene/jsblock/render-button-handler.snippet.js +46 -0
  275. package/lib/runjs-context/snippets/scene/jsblock/render-card.snippet.d.ts +11 -0
  276. package/lib/runjs-context/snippets/scene/jsblock/render-card.snippet.js +45 -0
  277. package/lib/runjs-context/snippets/scene/jsblock/render-react.snippet.d.ts +15 -0
  278. package/lib/runjs-context/snippets/scene/jsblock/render-react.snippet.js +56 -0
  279. package/lib/runjs-context/snippets/scene/jsfield/color-by-value.snippet.d.ts +15 -0
  280. package/lib/runjs-context/snippets/scene/jsfield/color-by-value.snippet.js +42 -0
  281. package/lib/runjs-context/snippets/scene/jsfield/format-number.snippet.d.ts +15 -0
  282. package/lib/runjs-context/snippets/scene/jsfield/format-number.snippet.js +41 -0
  283. package/lib/runjs-context/snippets/scene/jsfield/innerHTML-value.snippet.d.ts +15 -0
  284. package/lib/runjs-context/snippets/scene/jsfield/innerHTML-value.snippet.js +40 -0
  285. package/lib/runjs-context/snippets/scene/jsitem/render-basic.snippet.d.ts +15 -0
  286. package/lib/runjs-context/snippets/scene/jsitem/render-basic.snippet.js +44 -0
  287. package/lib/runjs-context/snippets/scene/linkage/set-disabled.snippet.d.ts +15 -0
  288. package/lib/runjs-context/snippets/scene/linkage/set-disabled.snippet.js +60 -0
  289. package/lib/runjs-context/snippets/scene/linkage/set-field-value.snippet.d.ts +15 -0
  290. package/lib/runjs-context/snippets/scene/linkage/set-field-value.snippet.js +59 -0
  291. package/lib/runjs-context/snippets/scene/linkage/set-required.snippet.d.ts +15 -0
  292. package/lib/runjs-context/snippets/scene/linkage/set-required.snippet.js +60 -0
  293. package/lib/runjs-context/snippets/scene/linkage/toggle-visible.snippet.d.ts +15 -0
  294. package/lib/runjs-context/snippets/scene/linkage/toggle-visible.snippet.js +60 -0
  295. package/lib/runjs-context/snippets/types.d.ts +16 -0
  296. package/lib/runjs-context/snippets/types.js +24 -0
  297. package/lib/types.d.ts +398 -0
  298. package/lib/types.js +43 -0
  299. package/lib/utils/autoFlowError.d.ts +16 -0
  300. package/lib/utils/autoFlowError.js +53 -0
  301. package/lib/utils/constants.d.ts +29 -0
  302. package/lib/utils/constants.js +77 -0
  303. package/lib/utils/context.d.ts +40 -0
  304. package/lib/utils/context.js +63 -0
  305. package/lib/utils/createCollectionContextMeta.d.ts +11 -0
  306. package/lib/utils/createCollectionContextMeta.js +117 -0
  307. package/lib/utils/exceptions.d.ts +22 -0
  308. package/lib/utils/exceptions.js +62 -0
  309. package/lib/utils/flow-definitions.d.ts +11 -0
  310. package/lib/utils/flow-definitions.js +40 -0
  311. package/lib/utils/index.d.ts +22 -0
  312. package/lib/utils/index.js +117 -0
  313. package/lib/utils/inheritance.d.ts +16 -0
  314. package/lib/utils/inheritance.js +53 -0
  315. package/lib/utils/params-resolvers.d.ts +51 -0
  316. package/lib/utils/params-resolvers.js +309 -0
  317. package/lib/utils/parsePathnameToViewParams.d.ts +34 -0
  318. package/lib/utils/parsePathnameToViewParams.js +84 -0
  319. package/lib/utils/safeGlobals.d.ts +16 -0
  320. package/lib/utils/safeGlobals.js +179 -0
  321. package/lib/utils/schema-utils.d.ts +40 -0
  322. package/lib/utils/schema-utils.js +161 -0
  323. package/lib/utils/serverContextParams.d.ts +28 -0
  324. package/lib/utils/serverContextParams.js +106 -0
  325. package/lib/utils/setupRuntimeContextSteps.d.ts +19 -0
  326. package/lib/utils/setupRuntimeContextSteps.js +88 -0
  327. package/lib/utils/translation.d.ts +18 -0
  328. package/lib/utils/translation.js +58 -0
  329. package/lib/utils/variablesParams.d.ts +51 -0
  330. package/lib/utils/variablesParams.js +150 -0
  331. package/lib/views/DialogComponent.d.ts +22 -0
  332. package/lib/views/DialogComponent.js +98 -0
  333. package/lib/views/DrawerComponent.d.ts +11 -0
  334. package/lib/views/DrawerComponent.js +101 -0
  335. package/lib/views/FlowView.d.ts +76 -0
  336. package/lib/views/FlowView.js +81 -0
  337. package/lib/views/PageComponent.d.ts +10 -0
  338. package/lib/views/PageComponent.js +167 -0
  339. package/lib/views/ViewNavigation.d.ts +45 -0
  340. package/lib/views/ViewNavigation.js +97 -0
  341. package/lib/views/createViewMeta.d.ts +16 -0
  342. package/lib/views/createViewMeta.js +171 -0
  343. package/lib/views/index.d.ts +13 -0
  344. package/lib/views/index.js +48 -0
  345. package/lib/views/useDialog.d.ts +32 -0
  346. package/lib/views/useDialog.js +199 -0
  347. package/lib/views/useDrawer.d.ts +33 -0
  348. package/lib/views/useDrawer.js +206 -0
  349. package/lib/views/usePage.d.ts +32 -0
  350. package/lib/views/usePage.js +193 -0
  351. package/lib/views/usePatchElement.d.ts +10 -0
  352. package/lib/views/usePatchElement.js +54 -0
  353. package/lib/views/usePopover.d.ts +17 -0
  354. package/lib/views/usePopover.js +159 -0
  355. package/package.json +37 -0
  356. package/src/ContextPathProxy.ts +45 -0
  357. package/src/ElementProxy.ts +69 -0
  358. package/src/FlowContextProvider.tsx +40 -0
  359. package/src/FlowDefinition.ts +275 -0
  360. package/src/JSRunner.ts +84 -0
  361. package/src/ReactView.tsx +104 -0
  362. package/src/ViewScopedFlowEngine.ts +75 -0
  363. package/src/__tests__/ElementProxy.test.ts +51 -0
  364. package/src/__tests__/JSRunner.test.ts +92 -0
  365. package/src/__tests__/ReactView.test.tsx +63 -0
  366. package/src/__tests__/context-path-proxy.test.ts +35 -0
  367. package/src/__tests__/flow-engine.test.ts +189 -0
  368. package/src/__tests__/flowContext.test.ts +2012 -0
  369. package/src/__tests__/flowEngine.saveModel.test.ts +171 -0
  370. package/src/__tests__/flowI18n.test.ts +28 -0
  371. package/src/__tests__/flowModel.getFlows.test.ts +61 -0
  372. package/src/__tests__/flowModel.openView.navigation.test.ts +78 -0
  373. package/src/__tests__/flowRuntimeContext.test.ts +187 -0
  374. package/src/__tests__/flowSettings.open.test.tsx +1920 -0
  375. package/src/__tests__/flowSettings.test.ts +566 -0
  376. package/src/__tests__/globalFlowRegistry.test.ts +77 -0
  377. package/src/__tests__/isFieldInterfaceMatch.test.ts +51 -0
  378. package/src/__tests__/metaTreeNodeCache.test.ts +234 -0
  379. package/src/__tests__/path-aggregation.test.ts +85 -0
  380. package/src/__tests__/provider.test.tsx +28 -0
  381. package/src/__tests__/renderHiddenInConfig.test.tsx +91 -0
  382. package/src/__tests__/runjsContext.test.ts +60 -0
  383. package/src/__tests__/viewScopedFlowEngine.test.ts +212 -0
  384. package/src/acl/Acl.tsx +109 -0
  385. package/src/acl/__tests__/Acl.test.tsx +72 -0
  386. package/src/action-registry/BaseActionRegistry.ts +46 -0
  387. package/src/action-registry/EngineActionRegistry.ts +32 -0
  388. package/src/action-registry/ModelActionRegistry.ts +75 -0
  389. package/src/action-registry/__tests__/engineActionRegistry.test.ts +43 -0
  390. package/src/action-registry/__tests__/modelActionRegistry.test.ts +107 -0
  391. package/src/components/DynamicFlowsEditor.tsx +318 -0
  392. package/src/components/FieldModelRenderer.tsx +62 -0
  393. package/src/components/FlowContextSelector.tsx +255 -0
  394. package/src/components/FlowErrorFallback.tsx +316 -0
  395. package/src/components/FlowModelRenderer.tsx +428 -0
  396. package/src/components/FormItem.tsx +130 -0
  397. package/src/components/__tests__/flow-model-render-error-fallback.test.tsx +226 -0
  398. package/src/components/common/FlowSettingsButton.tsx +30 -0
  399. package/src/components/common/index.ts +10 -0
  400. package/src/components/common/withFlowDesignMode.tsx +49 -0
  401. package/src/components/dnd/getMousePositionOnElement.ts +115 -0
  402. package/src/components/dnd/index.tsx +128 -0
  403. package/src/components/dnd/moveBlock.ts +379 -0
  404. package/src/components/index.ts +20 -0
  405. package/src/components/settings/independents/dropdown/FlowsDropdownButton.tsx +279 -0
  406. package/src/components/settings/independents/dropdown/index.ts +10 -0
  407. package/src/components/settings/independents/index.ts +2 -0
  408. package/src/components/settings/index.ts +11 -0
  409. package/src/components/settings/wrappers/contextual/DefaultSettingsIcon.tsx +617 -0
  410. package/src/components/settings/wrappers/contextual/FlowsContextMenu.tsx +292 -0
  411. package/src/components/settings/wrappers/contextual/FlowsFloatContextMenu.tsx +655 -0
  412. package/src/components/settings/wrappers/contextual/StepRequiredSettingsDialog.tsx +446 -0
  413. package/src/components/settings/wrappers/contextual/StepSettings.tsx +109 -0
  414. package/src/components/settings/wrappers/contextual/StepSettingsDialog.tsx +217 -0
  415. package/src/components/settings/wrappers/contextual/StepSettingsDrawer.tsx +32 -0
  416. package/src/components/settings/wrappers/contextual/index.ts +15 -0
  417. package/src/components/settings/wrappers/embedded/FlowSettings.tsx +258 -0
  418. package/src/components/settings/wrappers/embedded/FlowsSettings.tsx +111 -0
  419. package/src/components/settings/wrappers/embedded/FlowsSettingsContent.tsx +96 -0
  420. package/src/components/settings/wrappers/embedded/index.ts +11 -0
  421. package/src/components/settings/wrappers/index.ts +5 -0
  422. package/src/components/subModel/AddSubModelButton.tsx +575 -0
  423. package/src/components/subModel/LazyDropdown.tsx +714 -0
  424. package/src/components/subModel/__tests__/AddSubModelButton.test.tsx +1185 -0
  425. package/src/components/subModel/__tests__/buildWrapperFieldChildren.test.ts +192 -0
  426. package/src/components/subModel/__tests__/utils.test.ts +425 -0
  427. package/src/components/subModel/index.ts +12 -0
  428. package/src/components/subModel/utils.ts +278 -0
  429. package/src/components/variables/InlineVariableTag.tsx +97 -0
  430. package/src/components/variables/SlateVariableEditor.tsx +384 -0
  431. package/src/components/variables/VariableInput.tsx +342 -0
  432. package/src/components/variables/VariableTag.tsx +123 -0
  433. package/src/components/variables/VariableTrigger.tsx +116 -0
  434. package/src/components/variables/__tests__/FlowContextSelector.test.tsx +553 -0
  435. package/src/components/variables/__tests__/VariableInput.test.tsx +550 -0
  436. package/src/components/variables/__tests__/VariableTag.test.tsx +347 -0
  437. package/src/components/variables/__tests__/test-utils.tsx +62 -0
  438. package/src/components/variables/__tests__/utils.test.ts +310 -0
  439. package/src/components/variables/index.ts +16 -0
  440. package/src/components/variables/types.ts +100 -0
  441. package/src/components/variables/useResolvedMetaTree.ts +76 -0
  442. package/src/components/variables/utils.ts +192 -0
  443. package/src/data-source/__tests__/collection.test.ts +58 -0
  444. package/src/data-source/__tests__/index.test.ts +82 -0
  445. package/src/data-source/__tests__/jioToJoiSchema.test.ts +56 -0
  446. package/src/data-source/index.ts +812 -0
  447. package/src/data-source/jioToJoiSchema.ts +103 -0
  448. package/src/decorators/index.ts +10 -0
  449. package/src/decorators/largeField.ts +14 -0
  450. package/src/emitter.ts +33 -0
  451. package/src/event-registry/BaseEventRegistry.ts +40 -0
  452. package/src/event-registry/EngineEventRegistry.ts +26 -0
  453. package/src/event-registry/ModelEventRegistry.ts +69 -0
  454. package/src/event-registry/__tests__/engineEventRegistry.test.ts +48 -0
  455. package/src/executor/FlowExecutor.ts +256 -0
  456. package/src/executor/__tests__/eventStep.test.ts +157 -0
  457. package/src/executor/__tests__/flowExecutor.test.ts +163 -0
  458. package/src/flow-registry/BaseFlowRegistry.ts +91 -0
  459. package/src/flow-registry/GlobalFlowRegistry.ts +82 -0
  460. package/src/flow-registry/InstanceFlowRegistry.ts +39 -0
  461. package/src/flow-registry/__tests__/globalFlowRegistry.test.ts +141 -0
  462. package/src/flow-registry/__tests__/instance-and-global-registry.test.ts +67 -0
  463. package/src/flow-registry/__tests__/instanceFlowRegistry.test.ts +83 -0
  464. package/src/flow-registry/index.ts +12 -0
  465. package/src/flowContext.ts +1639 -0
  466. package/src/flowEngine.ts +905 -0
  467. package/src/flowI18n.ts +96 -0
  468. package/src/flowSettings.ts +1045 -0
  469. package/src/hooks/index.ts +15 -0
  470. package/src/hooks/useApplyAutoFlows.ts +51 -0
  471. package/src/hooks/useFlowModel.tsx +59 -0
  472. package/src/hooks/useFlowModelById.ts +37 -0
  473. package/src/hooks/useFlowSettingsContext.tsx +37 -0
  474. package/src/hooks/useFlowStep.tsx +19 -0
  475. package/src/hooks/useNiceDropdownMaxHeight.ts +34 -0
  476. package/src/index.ts +38 -0
  477. package/src/locale/en-US.json +61 -0
  478. package/src/locale/index.ts +38 -0
  479. package/src/locale/zh-CN.json +61 -0
  480. package/src/models/CollectionFieldModel.tsx +269 -0
  481. package/src/models/DisplayItemModel.tsx +13 -0
  482. package/src/models/EditableItemModel.tsx +13 -0
  483. package/src/models/FilterableItemModel.tsx +13 -0
  484. package/src/models/__tests__/CollectionFieldModel.test.ts +122 -0
  485. package/src/models/__tests__/defaultParams-on-create.test.ts +83 -0
  486. package/src/models/__tests__/flow-model-oninit.test.ts +44 -0
  487. package/src/models/__tests__/flowModel.actions.integration.test.ts +100 -0
  488. package/src/models/__tests__/flowModel.getFlows.sort.test.ts +100 -0
  489. package/src/models/__tests__/flowModel.test.ts +2746 -0
  490. package/src/models/__tests__/flowRegistry.test.ts +512 -0
  491. package/src/models/__tests__/forkFlowModel.test.ts +1047 -0
  492. package/src/models/__tests__/model-actions.test.ts +70 -0
  493. package/src/models/__tests__/model-events.test.ts +69 -0
  494. package/src/models/flowModel.tsx +1398 -0
  495. package/src/models/forkFlowModel.ts +287 -0
  496. package/src/models/index.ts +17 -0
  497. package/src/provider.tsx +101 -0
  498. package/src/resources/__tests__/apiResource.test.ts +201 -0
  499. package/src/resources/__tests__/baseRecordResource.test.ts +262 -0
  500. package/src/resources/__tests__/filterItem.test.ts +260 -0
  501. package/src/resources/__tests__/flowResource.test.ts +127 -0
  502. package/src/resources/apiResource.ts +148 -0
  503. package/src/resources/baseRecordResource.ts +279 -0
  504. package/src/resources/filterItem.ts +74 -0
  505. package/src/resources/flowResource.ts +143 -0
  506. package/src/resources/index.ts +17 -0
  507. package/src/resources/multiRecordResource.ts +219 -0
  508. package/src/resources/singleRecordResource.ts +83 -0
  509. package/src/resources/sqlResource.ts +299 -0
  510. package/src/runjs-context/contexts/FlowRunJSContext.ts +190 -0
  511. package/src/runjs-context/contexts/FormJSFieldItemRunJSContext.ts +39 -0
  512. package/src/runjs-context/contexts/JSBlockRunJSContext.ts +52 -0
  513. package/src/runjs-context/contexts/JSCollectionActionRunJSContext.ts +32 -0
  514. package/src/runjs-context/contexts/JSFieldRunJSContext.ts +43 -0
  515. package/src/runjs-context/contexts/JSItemRunJSContext.ts +39 -0
  516. package/src/runjs-context/contexts/JSRecordActionRunJSContext.ts +34 -0
  517. package/src/runjs-context/contexts/LinkageRunJSContext.ts +35 -0
  518. package/src/runjs-context/helpers.ts +56 -0
  519. package/src/runjs-context/index.ts +20 -0
  520. package/src/runjs-context/registry.ts +65 -0
  521. package/src/runjs-context/snippets/global/api-request-get.snippet.ts +20 -0
  522. package/src/runjs-context/snippets/global/api-request-post.snippet.ts +20 -0
  523. package/src/runjs-context/snippets/global/console-log-ctx.snippet.ts +19 -0
  524. package/src/runjs-context/snippets/global/copy-record-json.snippet.ts +21 -0
  525. package/src/runjs-context/snippets/global/copy-to-clipboard.snippet.ts +21 -0
  526. package/src/runjs-context/snippets/global/log-json-record.snippet.ts +21 -0
  527. package/src/runjs-context/snippets/global/message-error.snippet.ts +20 -0
  528. package/src/runjs-context/snippets/global/message-success.snippet.ts +20 -0
  529. package/src/runjs-context/snippets/global/notification-open.snippet.ts +21 -0
  530. package/src/runjs-context/snippets/global/open-view-dialog.snippet.ts +26 -0
  531. package/src/runjs-context/snippets/global/open-view-drawer.snippet.ts +26 -0
  532. package/src/runjs-context/snippets/global/requireAsync.snippet.ts +24 -0
  533. package/src/runjs-context/snippets/global/sleep.snippet.ts +21 -0
  534. package/src/runjs-context/snippets/global/try-catch-async.snippet.ts +22 -0
  535. package/src/runjs-context/snippets/global/view-navigation-push.snippet.ts +23 -0
  536. package/src/runjs-context/snippets/global/window-open.snippet.ts +19 -0
  537. package/src/runjs-context/snippets/index.ts +59 -0
  538. package/src/runjs-context/snippets/libs/echarts-init.snippet.ts +24 -0
  539. package/src/runjs-context/snippets/scene/actions/collection-selected-count.snippet.ts +22 -0
  540. package/src/runjs-context/snippets/scene/actions/iterate-selected-rows.snippet.ts +21 -0
  541. package/src/runjs-context/snippets/scene/actions/record-id-message.snippet.ts +21 -0
  542. package/src/runjs-context/snippets/scene/actions/run-action-basic.snippet.ts +18 -0
  543. package/src/runjs-context/snippets/scene/jsblock/add-event-listener.snippet.ts +29 -0
  544. package/src/runjs-context/snippets/scene/jsblock/append-style.snippet.ts +20 -0
  545. package/src/runjs-context/snippets/scene/jsblock/jsx-mount.snippet.ts +24 -0
  546. package/src/runjs-context/snippets/scene/jsblock/jsx-unmount.snippet.ts +19 -0
  547. package/src/runjs-context/snippets/scene/jsblock/render-basic.snippet.ts +24 -0
  548. package/src/runjs-context/snippets/scene/jsblock/render-button-handler.snippet.ts +24 -0
  549. package/src/runjs-context/snippets/scene/jsblock/render-card.snippet.ts +30 -0
  550. package/src/runjs-context/snippets/scene/jsblock/render-react.snippet.ts +34 -0
  551. package/src/runjs-context/snippets/scene/jsfield/color-by-value.snippet.ts +20 -0
  552. package/src/runjs-context/snippets/scene/jsfield/format-number.snippet.ts +19 -0
  553. package/src/runjs-context/snippets/scene/jsfield/innerHTML-value.snippet.ts +18 -0
  554. package/src/runjs-context/snippets/scene/jsitem/render-basic.snippet.ts +27 -0
  555. package/src/runjs-context/snippets/scene/linkage/set-disabled.snippet.ts +38 -0
  556. package/src/runjs-context/snippets/scene/linkage/set-field-value.snippet.ts +37 -0
  557. package/src/runjs-context/snippets/scene/linkage/set-required.snippet.ts +38 -0
  558. package/src/runjs-context/snippets/scene/linkage/toggle-visible.snippet.ts +38 -0
  559. package/src/runjs-context/snippets/types.ts +17 -0
  560. package/src/types.ts +474 -0
  561. package/src/utils/__tests__/context.test.ts +93 -0
  562. package/src/utils/__tests__/params-resolvers.test.ts +652 -0
  563. package/src/utils/__tests__/parsePathnameToViewParams.test.ts +104 -0
  564. package/src/utils/__tests__/safeGlobals.test.ts +29 -0
  565. package/src/utils/__tests__/utils.test.ts +1021 -0
  566. package/src/utils/__tests__/variablesParams.test.ts +52 -0
  567. package/src/utils/autoFlowError.ts +29 -0
  568. package/src/utils/constants.ts +60 -0
  569. package/src/utils/context.ts +70 -0
  570. package/src/utils/createCollectionContextMeta.ts +122 -0
  571. package/src/utils/exceptions.ts +36 -0
  572. package/src/utils/flow-definitions.ts +16 -0
  573. package/src/utils/index.ts +63 -0
  574. package/src/utils/inheritance.ts +39 -0
  575. package/src/utils/params-resolvers.ts +482 -0
  576. package/src/utils/parsePathnameToViewParams.ts +103 -0
  577. package/src/utils/safeGlobals.ts +188 -0
  578. package/src/utils/schema-utils.ts +201 -0
  579. package/src/utils/serverContextParams.ts +111 -0
  580. package/src/utils/setupRuntimeContextSteps.ts +89 -0
  581. package/src/utils/translation.ts +37 -0
  582. package/src/utils/variablesParams.ts +175 -0
  583. package/src/views/DialogComponent.tsx +79 -0
  584. package/src/views/DrawerComponent.tsx +72 -0
  585. package/src/views/FlowView.tsx +103 -0
  586. package/src/views/PageComponent.tsx +150 -0
  587. package/src/views/ViewNavigation.ts +122 -0
  588. package/src/views/__tests__/FlowView.test.ts +31 -0
  589. package/src/views/__tests__/ViewNavigation.test.ts +191 -0
  590. package/src/views/__tests__/usePatchElement.test.tsx +28 -0
  591. package/src/views/createViewMeta.ts +157 -0
  592. package/src/views/index.tsx +14 -0
  593. package/src/views/useDialog.tsx +192 -0
  594. package/src/views/useDrawer.tsx +205 -0
  595. package/src/views/usePage.tsx +182 -0
  596. package/src/views/usePatchElement.tsx +27 -0
  597. package/src/views/usePopover.tsx +131 -0
@@ -0,0 +1,655 @@
1
+ /**
2
+ * This file is part of the NocoBase (R) project.
3
+ * Copyright (c) 2020-2024 NocoBase Co., Ltd.
4
+ * Authors: NocoBase Team.
5
+ *
6
+ * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
+ * For more information, please refer to: https://www.nocobase.com/agreement.
8
+ */
9
+
10
+ import React, { useState, useCallback, useRef, useEffect, useMemo } from 'react';
11
+ import { Alert, Space } from 'antd';
12
+ import { observer } from '@formily/react';
13
+ import { css } from '@emotion/css';
14
+ import { FlowModel } from '../../../../models';
15
+ import { ToolbarItemConfig } from '../../../../types';
16
+ import { useFlowModelById } from '../../../../hooks';
17
+ import { useFlowEngine } from '../../../../provider';
18
+ import { FlowEngine } from '../../../../flowEngine';
19
+ import { getT } from '../../../../utils';
20
+
21
+ // 检测DOM中直接子元素是否包含button元素的辅助函数
22
+ const detectButtonInDOM = (container: HTMLElement): boolean => {
23
+ if (!container) return false;
24
+
25
+ // 只检测直接子元素中的button
26
+ const directChildren = container.children;
27
+ for (let i = 0; i < directChildren.length; i++) {
28
+ const child = directChildren[i];
29
+ // 检查是否是button元素或具有button特征的元素
30
+ if (child.tagName === 'BUTTON' || child.getAttribute('role') === 'button' || child.classList.contains('ant-btn')) {
31
+ return true;
32
+ }
33
+ }
34
+
35
+ return false;
36
+ };
37
+
38
+ // 渲染工具栏项目的辅助函数
39
+ const renderToolbarItems = (
40
+ model: FlowModel,
41
+ showDeleteButton: boolean,
42
+ showCopyUidButton: boolean,
43
+ flowEngine: FlowEngine,
44
+ settingsMenuLevel?: number,
45
+ extraToolbarItems?: ToolbarItemConfig[],
46
+ ) => {
47
+ const toolbarItems = flowEngine?.flowSettings?.getToolbarItems?.() || [];
48
+
49
+ // 合并额外的工具栏项目
50
+ const allToolbarItems = [...toolbarItems, ...(extraToolbarItems || [])];
51
+
52
+ // 按 sort 字段排序
53
+ allToolbarItems.sort((a, b) => (a.sort || 0) - (b.sort || 0)).reverse();
54
+
55
+ return allToolbarItems
56
+ .filter((itemConfig: ToolbarItemConfig) => {
57
+ // 检查项目是否应该显示
58
+ return itemConfig.visible ? itemConfig.visible(model) : true;
59
+ })
60
+ .map((itemConfig: ToolbarItemConfig) => {
61
+ // 渲染项目组件
62
+ const ItemComponent = itemConfig.component;
63
+
64
+ // 对于默认设置项目,传递额外的 props
65
+ if (itemConfig.key === 'settings-menu') {
66
+ return (
67
+ <ItemComponent
68
+ key={itemConfig.key}
69
+ model={model}
70
+ id={model.uid} // 用于拖拽的 id
71
+ showDeleteButton={showDeleteButton}
72
+ showCopyUidButton={showCopyUidButton}
73
+ menuLevels={settingsMenuLevel}
74
+ />
75
+ );
76
+ }
77
+
78
+ // 其他项目只传递 model
79
+ return <ItemComponent key={itemConfig.key} model={model} />;
80
+ });
81
+ };
82
+
83
+ // 使用与 NocoBase 一致的悬浮工具栏样式
84
+ const floatContainerStyles = ({ showBackground, showBorder, ctx, toolbarPosition }) => css`
85
+ position: relative;
86
+ display: inline;
87
+
88
+ /* 当检测到button时使用inline-block */
89
+ &.has-button-child {
90
+ display: inline-block;
91
+ }
92
+
93
+ /* 正常的hover行为 - 添加延迟显示 */
94
+ &:hover > .nb-toolbar-container {
95
+ opacity: 1;
96
+ transition-delay: 0.1s;
97
+
98
+ .nb-toolbar-container-icons {
99
+ display: block;
100
+ }
101
+ }
102
+
103
+ /* 当有.hide-parent-menu类时隐藏菜单 */
104
+ &.hide-parent-menu > .nb-toolbar-container {
105
+ opacity: 0 !important;
106
+ }
107
+
108
+ > .nb-toolbar-container {
109
+ position: absolute;
110
+ top: 0;
111
+ bottom: 0;
112
+ left: 0;
113
+ right: 0;
114
+ z-index: 999;
115
+ opacity: 0;
116
+ background: ${showBackground ? 'var(--colorBgSettingsHover)' : ''};
117
+ border: ${showBorder ? '2px solid var(--colorBorderSettingsHover)' : ''};
118
+ border-radius: ${ctx.themeToken.borderRadiusLG}px;
119
+ pointer-events: none;
120
+
121
+ &.nb-in-template {
122
+ background: var(--colorTemplateBgSettingsHover);
123
+ }
124
+
125
+ > .nb-toolbar-container-title {
126
+ pointer-events: none;
127
+ position: absolute;
128
+ font-size: 12px;
129
+ padding: 0;
130
+ line-height: 16px;
131
+ height: 16px;
132
+ border-bottom-right-radius: 2px;
133
+ border-radius: 2px;
134
+ top: 2px;
135
+ left: 2px;
136
+
137
+ .title-tag {
138
+ padding: 0 3px;
139
+ border-radius: 2px;
140
+ background: var(--colorSettings);
141
+ color: #fff;
142
+ display: block;
143
+ }
144
+ }
145
+
146
+ > .nb-toolbar-container-icons {
147
+ display: none; // 防止遮挡其它 icons
148
+ position: absolute;
149
+ right: 2px;
150
+ top: ${toolbarPosition === 'above' ? '0px' : '2px'};
151
+ ${toolbarPosition === 'above' ? 'transform: translateY(-100%);' : ''}
152
+ ${toolbarPosition === 'above' ? 'padding-bottom: 2px;' : ''}
153
+ ${toolbarPosition === 'above' ? 'margin-bottom: -2px;' : ''}
154
+ line-height: 16px;
155
+ pointer-events: all;
156
+
157
+ .ant-space-item {
158
+ background-color: var(--colorSettings);
159
+ color: #fff;
160
+ line-height: 16px;
161
+ width: 16px;
162
+ height: 16px;
163
+ padding: 2px;
164
+ display: flex;
165
+ align-items: center;
166
+ justify-content: center;
167
+ }
168
+ }
169
+
170
+ /* 拖拽把手样式 - 参考 AirTable 样式 */
171
+ > .resize-handle {
172
+ position: absolute;
173
+ pointer-events: all;
174
+ background: var(--colorSettings);
175
+ opacity: 0.6;
176
+ border-radius: 4px;
177
+ display: flex;
178
+ align-items: center;
179
+ justify-content: center;
180
+
181
+ &:hover {
182
+ opacity: 0.9;
183
+ background: var(--colorSettingsHover, var(--colorSettings));
184
+ }
185
+
186
+ &::before {
187
+ content: '';
188
+ position: absolute;
189
+ background: rgba(255, 255, 255, 0.9);
190
+ border-radius: 50%;
191
+ }
192
+
193
+ &::after {
194
+ content: '';
195
+ position: absolute;
196
+ background: rgba(255, 255, 255, 0.9);
197
+ border-radius: 50%;
198
+ }
199
+ }
200
+
201
+ > .resize-handle-left {
202
+ left: -4px;
203
+ top: 50%;
204
+ transform: translateY(-50%);
205
+ width: 6px;
206
+ height: 20px;
207
+ cursor: ew-resize;
208
+
209
+ &::before {
210
+ width: 2px;
211
+ height: 2px;
212
+ top: 6px;
213
+ left: 50%;
214
+ transform: translateX(-50%);
215
+ box-shadow:
216
+ 0 4px 0 rgba(255, 255, 255, 0.9),
217
+ 0 8px 0 rgba(255, 255, 255, 0.9);
218
+ }
219
+ }
220
+
221
+ > .resize-handle-right {
222
+ right: -4px;
223
+ top: 50%;
224
+ transform: translateY(-50%);
225
+ width: 6px;
226
+ height: 20px;
227
+ cursor: ew-resize;
228
+
229
+ &::before {
230
+ width: 2px;
231
+ height: 2px;
232
+ top: 6px;
233
+ left: 50%;
234
+ transform: translateX(-50%);
235
+ box-shadow:
236
+ 0 4px 0 rgba(255, 255, 255, 0.9),
237
+ 0 8px 0 rgba(255, 255, 255, 0.9);
238
+ }
239
+ }
240
+
241
+ > .resize-handle-bottom {
242
+ bottom: -4px;
243
+ left: 50%;
244
+ transform: translateX(-50%);
245
+ width: 20px;
246
+ height: 6px;
247
+ cursor: ns-resize;
248
+
249
+ &::before {
250
+ width: 2px;
251
+ height: 2px;
252
+ left: 6px;
253
+ top: 50%;
254
+ transform: translateY(-50%);
255
+ box-shadow:
256
+ 4px 0 0 rgba(255, 255, 255, 0.9),
257
+ 8px 0 0 rgba(255, 255, 255, 0.9);
258
+ }
259
+ }
260
+ }
261
+ `;
262
+
263
+ // 悬浮右键菜单组件接口
264
+ interface ModelProvidedProps {
265
+ model: FlowModel<any>;
266
+ children?: React.ReactNode;
267
+ enabled?: boolean;
268
+ showDeleteButton?: boolean;
269
+ showCopyUidButton?: boolean;
270
+ containerStyle?: React.CSSProperties;
271
+ toolbarStyle?: React.CSSProperties;
272
+ className?: string;
273
+ /**
274
+ * @default true
275
+ */
276
+ showBorder?: boolean;
277
+ /**
278
+ * @default true
279
+ */
280
+ showBackground?: boolean;
281
+ /**
282
+ * @default false
283
+ */
284
+ showTitle?: boolean;
285
+ /**
286
+ * @default false
287
+ */
288
+ showDragHandle?: boolean;
289
+ /**
290
+ * Settings menu levels: 1=current model only (default), 2=include sub-models
291
+ */
292
+ settingsMenuLevel?: number;
293
+ /**
294
+ * Extra toolbar items to add to this context menu instance
295
+ */
296
+ extraToolbarItems?: ToolbarItemConfig[];
297
+ /**
298
+ * @default 'inside'
299
+ */
300
+ toolbarPosition?: 'inside' | 'above';
301
+ }
302
+
303
+ interface ModelByIdProps {
304
+ uid: string;
305
+ modelClassName: string;
306
+ children?: React.ReactNode;
307
+ enabled?: boolean;
308
+ showDeleteButton?: boolean;
309
+ showCopyUidButton?: boolean;
310
+ containerStyle?: React.CSSProperties;
311
+ className?: string;
312
+ /**
313
+ * @default true
314
+ */
315
+ showBorder?: boolean;
316
+ /**
317
+ * @default true
318
+ */
319
+ showBackground?: boolean;
320
+ /**
321
+ * @default false
322
+ */
323
+ showTitle?: boolean;
324
+ /**
325
+ * Settings menu levels: 1=current model only (default), 2=include sub-models
326
+ */
327
+ settingsMenuLevel?: number;
328
+ /**
329
+ * Extra toolbar items to add to this context menu instance
330
+ */
331
+ extraToolbarItems?: ToolbarItemConfig[];
332
+ /**
333
+ * @default 'inside'
334
+ */
335
+ toolbarPosition?: 'inside' | 'above';
336
+ }
337
+
338
+ type FlowsFloatContextMenuProps = ModelProvidedProps | ModelByIdProps;
339
+
340
+ // 判断是否是通过ID获取模型的props
341
+ const isModelByIdProps = (props: FlowsFloatContextMenuProps): props is ModelByIdProps => {
342
+ return 'uid' in props && 'modelClassName' in props && Boolean(props.uid) && Boolean(props.modelClassName);
343
+ };
344
+
345
+ /**
346
+ * FlowsFloatContextMenu组件 - 悬浮配置图标组件
347
+ *
348
+ * 功能特性:
349
+ * - 鼠标悬浮显示右上角配置图标
350
+ * - 点击图标显示配置菜单
351
+ * - 支持删除功能
352
+ * - Wrapper 模式支持
353
+ * - 使用与 NocoBase x-settings 一致的样式
354
+ * - 按flow分组显示steps
355
+ *
356
+ * 支持两种使用方式:
357
+ * 1. 直接提供model: <FlowsFloatContextMenu model={myModel}>{children}</FlowsFloatContextMenu>
358
+ * 2. 通过uid和modelClassName获取model: <FlowsFloatContextMenu uid="model1" modelClassName="MyModel">{children}</FlowsFloatContextMenu>
359
+ *
360
+ * @param props.children 子组件,必须提供
361
+ * @param props.enabled 是否启用悬浮菜单,默认为true
362
+ * @param props.showDeleteButton 是否显示删除按钮,默认为true
363
+ * @param props.showCopyUidButton 是否显示复制UID按钮,默认为true
364
+ * @param props.containerStyle 容器自定义样式
365
+ * @param props.className 容器自定义类名
366
+ * @param props.showTitle 是否在边框左上角显示模型title,默认为false
367
+ * @param props.settingsMenuLevel 设置菜单层级:1=仅当前模型(默认),2=包含子模型
368
+ * @param props.extraToolbarItems 额外的工具栏项目,仅应用于此实例
369
+ */
370
+ const FlowsFloatContextMenu: React.FC<FlowsFloatContextMenuProps> = observer((props) => {
371
+ const flowEngine = useFlowEngine();
372
+ // Only render if flowSettings is enabled
373
+ if (!flowEngine.flowSettings?.enabled) {
374
+ return <>{props.children}</>;
375
+ }
376
+ if (isModelByIdProps(props)) {
377
+ return <FlowsFloatContextMenuWithModelById {...props} />;
378
+ } else {
379
+ return <FlowsFloatContextMenuWithModel {...props} />;
380
+ }
381
+ });
382
+
383
+ const ResizeHandles: React.FC<{ model: FlowModel; onDragStart: () => void; onDragEnd: () => void }> = (props) => {
384
+ const isDraggingRef = useRef<boolean>(false);
385
+ const dragTypeRef = useRef<'left' | 'right' | 'bottom' | 'corner' | null>(null);
386
+ const dragStartPosRef = useRef<{ x: number; y: number }>({ x: 0, y: 0 });
387
+ const { onDragStart, onDragEnd } = props;
388
+
389
+ // 拖拽移动处理函数
390
+ const handleDragMove = useCallback(
391
+ (e: MouseEvent) => {
392
+ if (!isDraggingRef.current || !dragTypeRef.current) return;
393
+
394
+ const deltaX = e.clientX - dragStartPosRef.current.x;
395
+ const deltaY = e.clientY - dragStartPosRef.current.y;
396
+
397
+ let resizeDistance = 0;
398
+
399
+ switch (dragTypeRef.current) {
400
+ case 'left':
401
+ // 左侧把手:向左拖为正数,向右拖为负数
402
+ resizeDistance = -deltaX;
403
+ props.model.parent.emitter.emit('onResizeLeft', { resizeDistance, model: props.model });
404
+ break;
405
+
406
+ case 'right':
407
+ // 右侧把手:向右拖为正数,向左拖为负数
408
+ resizeDistance = deltaX;
409
+ props.model.parent.emitter.emit('onResizeRight', { resizeDistance, model: props.model });
410
+ break;
411
+
412
+ case 'bottom':
413
+ // 底部把手:向下拖为正数,向上拖为负数
414
+ resizeDistance = deltaY;
415
+ props.model.parent.emitter.emit('onResizeBottom', { resizeDistance, model: props.model });
416
+ break;
417
+
418
+ case 'corner': {
419
+ // 右下角把手:同时计算宽度和高度变化
420
+ const widthDelta = deltaX;
421
+ const heightDelta = deltaY;
422
+ props.model.parent.emitter.emit('onResizeCorner', { widthDelta, heightDelta, model: props.model });
423
+ break;
424
+ }
425
+ }
426
+ },
427
+ [props.model],
428
+ );
429
+
430
+ // 拖拽结束处理函数
431
+ const handleDragEnd = useCallback(() => {
432
+ isDraggingRef.current = false;
433
+ dragTypeRef.current = null;
434
+ dragStartPosRef.current = { x: 0, y: 0 };
435
+
436
+ // 移除全局事件监听
437
+ document.removeEventListener('mousemove', handleDragMove);
438
+ document.removeEventListener('mouseup', handleDragEnd);
439
+
440
+ props.model.parent.emitter.emit('onResizeEnd');
441
+ onDragEnd?.();
442
+ }, [handleDragMove, props.model, onDragEnd]);
443
+
444
+ // 拖拽开始处理函数
445
+ const handleDragStart = useCallback(
446
+ (e: React.MouseEvent, type: 'left' | 'right' | 'bottom' | 'corner') => {
447
+ e.preventDefault();
448
+ e.stopPropagation();
449
+
450
+ isDraggingRef.current = true;
451
+ dragTypeRef.current = type;
452
+ dragStartPosRef.current = { x: e.clientX, y: e.clientY };
453
+
454
+ // 添加全局事件监听
455
+ document.addEventListener('mousemove', handleDragMove);
456
+ document.addEventListener('mouseup', handleDragEnd);
457
+
458
+ onDragStart?.();
459
+ },
460
+ [handleDragMove, handleDragEnd, onDragStart],
461
+ );
462
+
463
+ return (
464
+ <>
465
+ {/* 拖拽把手 */}
466
+ <div
467
+ className="resize-handle resize-handle-left"
468
+ title="拖拽调节宽度"
469
+ onMouseDown={(e) => handleDragStart(e, 'left')}
470
+ ></div>
471
+ <div
472
+ className="resize-handle resize-handle-right"
473
+ title="拖拽调节宽度"
474
+ onMouseDown={(e) => handleDragStart(e, 'right')}
475
+ ></div>
476
+ {/* <div
477
+ className="resize-handle resize-handle-bottom"
478
+ title="拖拽调节高度"
479
+ onMouseDown={(e) => handleDragStart(e, 'bottom')}
480
+ ></div> */}
481
+ </>
482
+ );
483
+ };
484
+
485
+ // 使用传入的model
486
+ const FlowsFloatContextMenuWithModel: React.FC<ModelProvidedProps> = observer(
487
+ ({
488
+ model,
489
+ children,
490
+ enabled = true,
491
+ showDeleteButton = true,
492
+ showCopyUidButton = true,
493
+ containerStyle,
494
+ className,
495
+ showBackground = true,
496
+ showBorder = true,
497
+ showTitle = false,
498
+ showDragHandle = false,
499
+ settingsMenuLevel,
500
+ extraToolbarItems,
501
+ toolbarStyle,
502
+ toolbarPosition = 'inside',
503
+ }: ModelProvidedProps) => {
504
+ const [hideMenu, setHideMenu] = useState<boolean>(false);
505
+ const [hasButton, setHasButton] = useState<boolean>(false);
506
+ const containerRef = useRef<HTMLDivElement>(null);
507
+ const flowEngine = useFlowEngine();
508
+ const [style, setStyle] = useState<React.CSSProperties>({});
509
+ const toolbarContainerRef = useRef<HTMLDivElement>(null);
510
+ const toolbarContainerStyle: any = useMemo(() => ({ ...toolbarStyle, ...style }), [style, toolbarStyle]);
511
+
512
+ // 检测DOM中是否包含button元素
513
+ useEffect(() => {
514
+ if (containerRef.current) {
515
+ const hasButtonElement = detectButtonInDOM(containerRef.current);
516
+ setHasButton(hasButtonElement);
517
+ }
518
+ }, [children]); // 当children变化时重新检测
519
+
520
+ // 使用MutationObserver监听DOM变化
521
+ useEffect(() => {
522
+ if (!containerRef.current) return;
523
+
524
+ const observer = new MutationObserver(() => {
525
+ if (containerRef.current) {
526
+ const hasButtonElement = detectButtonInDOM(containerRef.current);
527
+ setHasButton(hasButtonElement);
528
+ }
529
+ });
530
+
531
+ observer.observe(containerRef.current, {
532
+ childList: true,
533
+ subtree: true,
534
+ attributes: true,
535
+ attributeFilter: ['class', 'role'],
536
+ });
537
+
538
+ return () => {
539
+ observer.disconnect();
540
+ };
541
+ }, []);
542
+
543
+ const handleChildHover = useCallback((e: React.MouseEvent) => {
544
+ const target = e.target as HTMLElement;
545
+ const childWithMenu = target.closest('[data-has-float-menu]');
546
+
547
+ // 如果悬浮的是子元素(且不是当前容器),则隐藏当前菜单
548
+ if (childWithMenu && childWithMenu !== containerRef.current) {
549
+ setHideMenu(true);
550
+ } else {
551
+ setHideMenu(false);
552
+ }
553
+ }, []);
554
+
555
+ if (!model) {
556
+ const t = getT(model || ({} as FlowModel));
557
+ return <Alert message={t('Invalid model provided')} type="error" />;
558
+ }
559
+
560
+ // 如果未启用或没有children,直接返回children
561
+ if (!enabled || !children) {
562
+ return <>{children}</>;
563
+ }
564
+
565
+ return (
566
+ <div
567
+ ref={containerRef}
568
+ className={`${floatContainerStyles({ showBackground, showBorder, ctx: model.context, toolbarPosition })} ${
569
+ hideMenu ? 'hide-parent-menu' : ''
570
+ } ${hasButton ? 'has-button-child' : ''} ${className || ''}`}
571
+ style={containerStyle}
572
+ data-has-float-menu="true"
573
+ onMouseMove={handleChildHover}
574
+ >
575
+ {children}
576
+
577
+ {/* 悬浮工具栏 - 使用与 NocoBase 一致的结构 */}
578
+ <div ref={toolbarContainerRef} className="nb-toolbar-container" style={toolbarContainerStyle}>
579
+ {showTitle && model.title && (
580
+ <div className="nb-toolbar-container-title">
581
+ <span className="title-tag">{model.title}</span>
582
+ </div>
583
+ )}
584
+ <div className="nb-toolbar-container-icons">
585
+ <Space size={3} align="center">
586
+ {renderToolbarItems(
587
+ model,
588
+ showDeleteButton,
589
+ showCopyUidButton,
590
+ flowEngine,
591
+ settingsMenuLevel,
592
+ extraToolbarItems,
593
+ )}
594
+ </Space>
595
+ </div>
596
+
597
+ {/* 拖拽把手 */}
598
+ {showDragHandle && (
599
+ <ResizeHandles model={model} onDragStart={() => setStyle({ opacity: 1 })} onDragEnd={() => setStyle({})} />
600
+ )}
601
+ </div>
602
+ </div>
603
+ );
604
+ },
605
+ {
606
+ displayName: 'FlowsFloatContextMenuWithModel',
607
+ },
608
+ );
609
+
610
+ // 通过useModelById hook获取model
611
+ const FlowsFloatContextMenuWithModelById: React.FC<ModelByIdProps> = observer(
612
+ ({
613
+ uid,
614
+ modelClassName,
615
+ children,
616
+ enabled = true,
617
+ showDeleteButton = true,
618
+ showCopyUidButton = true,
619
+ containerStyle,
620
+ className,
621
+ showTitle = false,
622
+ settingsMenuLevel,
623
+ extraToolbarItems: extraToolbarItems,
624
+ toolbarPosition,
625
+ }) => {
626
+ const model = useFlowModelById(uid, modelClassName);
627
+ const flowEngine = useFlowEngine();
628
+
629
+ if (!model) {
630
+ return <Alert message={flowEngine.translate('Model with ID {{uid}} not found', { uid })} type="error" />;
631
+ }
632
+
633
+ return (
634
+ <FlowsFloatContextMenuWithModel
635
+ model={model}
636
+ enabled={enabled}
637
+ showDeleteButton={showDeleteButton}
638
+ showCopyUidButton={showCopyUidButton}
639
+ containerStyle={containerStyle}
640
+ className={className}
641
+ showTitle={showTitle}
642
+ settingsMenuLevel={settingsMenuLevel}
643
+ extraToolbarItems={extraToolbarItems}
644
+ toolbarPosition={toolbarPosition}
645
+ >
646
+ {children}
647
+ </FlowsFloatContextMenuWithModel>
648
+ );
649
+ },
650
+ {
651
+ displayName: 'FlowsFloatContextMenuWithModelById',
652
+ },
653
+ );
654
+
655
+ export { FlowsFloatContextMenu };