@riil-frontend/component-topology 6.0.0-alpha.8 → 6.0.1

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 (398) hide show
  1. package/build/1.js +2 -2
  2. package/build/2.js +1 -1
  3. package/build/index.css +1 -1
  4. package/build/index.js +35 -35
  5. package/demo/CHANGELOG/CHANGELOG.md +5 -0
  6. package/es/components/ColorPanel/components/ColorBlock/index.js +37 -0
  7. package/es/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  8. package/es/components/ColorPanel/components/FontColorRange/index.js +35 -0
  9. package/es/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  10. package/es/components/ColorPanel/index.js +259 -0
  11. package/es/components/ColorPanel/index.module.scss +35 -0
  12. package/es/components/VerticalIconTab/VerticalIconTab.js +11 -1
  13. package/es/components/VerticalIconTab/VerticalIconTab.module.scss +2 -0
  14. package/es/components/collapse/Collapse.js +22 -3
  15. package/es/components/collapse/Collapse.module.scss +24 -0
  16. package/es/components/collapse/index.js +2 -0
  17. package/es/core/common/hooks/useHtElements.js +21 -0
  18. package/es/core/common/icons/icon.js +40 -0
  19. package/es/core/common/icons/useIcons.js +8 -16
  20. package/es/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  21. package/es/core/components/AlarmListPanel/components/index.module.scss +5 -5
  22. package/es/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  23. package/es/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +9 -3
  24. package/es/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +122 -0
  25. package/es/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  26. package/es/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +84 -22
  27. package/es/core/components/TopoView/GraphViewPanel.js +22 -0
  28. package/es/core/components/TopoView/editor.module.scss +1 -0
  29. package/es/core/components/TopoView/topoView.js +30 -60
  30. package/es/core/components/titlebar/TitleBar.module.scss +1 -1
  31. package/es/core/editor/components/EditorPlugin.js +18 -2
  32. package/es/core/editor/components/Sidebar/Sidebar.js +29 -7
  33. package/es/core/editor/components/Sidebar/panes.js +10 -5
  34. package/es/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +13 -37
  35. package/es/core/editor/components/Sidebar/views/CanvasPanel/hooks/useCanvasThemeConfig.js +109 -0
  36. package/es/core/editor/components/Sidebar/views/CanvasPanel/hooks/useUpdateHtTopoDefaultTagStyle.js +27 -0
  37. package/es/core/editor/components/Sidebar/views/CanvasPanel/utils/elementThemeUtil.js +0 -0
  38. package/es/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +3 -3
  39. package/es/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +12 -1
  40. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +12 -1
  41. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +3 -3
  42. package/es/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +27 -8
  43. package/es/core/editor/components/Toolbar/EditorToolbar.js +16 -9
  44. package/es/core/editor/components/Toolbar/buttons.js +20 -18
  45. package/es/core/editor/components/Toolbar/widgets/AddResourceButton.js +3 -3
  46. package/es/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  47. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +46 -2
  48. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +98 -6
  49. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +74 -23
  50. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +1 -3
  51. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +17 -10
  52. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +77 -0
  53. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +52 -5
  54. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +166 -16
  55. package/es/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  56. package/es/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +26 -12
  57. package/es/core/editor/components/Toolbar/widgets/FontSizeWidget.js +37 -12
  58. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +92 -39
  59. package/es/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +1 -1
  60. package/es/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +2 -2
  61. package/es/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +109 -0
  62. package/es/core/editor/components/Toolbar/widgets/IconSelect/constant.js +64 -0
  63. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.js +101 -0
  64. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  65. package/es/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +49 -0
  66. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +99 -0
  67. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  68. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +42 -0
  69. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  70. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +75 -0
  71. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  72. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +23 -0
  73. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +10 -0
  74. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  75. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  76. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  77. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  78. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +31 -0
  79. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  80. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +130 -15
  81. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +107 -23
  82. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  83. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +15 -5
  84. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +50 -7
  85. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +99 -15
  86. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  87. package/es/core/editor/components/Toolbar/widgets/WidgetBox.js +10 -4
  88. package/es/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  89. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  90. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  91. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  92. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +21 -7
  93. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +52 -0
  94. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +67 -0
  95. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +41 -0
  96. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +65 -0
  97. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +65 -0
  98. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +14 -0
  99. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +73 -0
  100. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +69 -0
  101. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +37 -0
  102. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +124 -0
  103. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +31 -0
  104. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +98 -0
  105. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +20 -0
  106. package/es/core/editor/components/plugins/AddElementThemePlugin.js +11 -0
  107. package/es/core/editor/components/settings/CloseablePanel.js +33 -0
  108. package/es/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  109. package/es/core/editor/components/settings/PropertyView.js +50 -11
  110. package/es/core/editor/components/settings/Settings.js +37 -122
  111. package/es/core/editor/components/settings/Settings.module.scss +7 -11
  112. package/es/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  113. package/es/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +80 -0
  114. package/es/core/editor/components/settings/common/AlignSetting/index.js +20 -72
  115. package/es/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  116. package/es/core/editor/components/settings/common/LineType/index.js +11 -102
  117. package/es/core/editor/components/settings/common/NameInput.js +24 -0
  118. package/es/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +3 -3
  119. package/es/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +31 -24
  120. package/es/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +7 -6
  121. package/es/core/editor/components/settings/common/text/fontStyleUtil.js +21 -19
  122. package/es/core/editor/components/settings/core/PropertyViewManager.js +81 -0
  123. package/es/core/editor/components/settings/core/edgePropertyViewAdapter.js +22 -0
  124. package/es/core/editor/components/settings/core/getPropertyViewType.js +34 -0
  125. package/es/core/editor/components/settings/core/updateElementProperty.js +21 -0
  126. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  127. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +58 -0
  128. package/es/core/editor/components/settings/propertyViews/box/NameInput.js +5 -4
  129. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +12 -3
  130. package/es/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +7 -8
  131. package/es/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +9 -23
  132. package/es/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +10 -0
  133. package/es/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  134. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +13 -21
  135. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  136. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +28 -0
  137. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +75 -0
  138. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +9 -15
  139. package/es/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +8 -6
  140. package/es/core/editor/components/settings/propertyViews/index.js +4 -6
  141. package/es/core/editor/components/settings/propertyViews/layer/BasicSetting.js +57 -0
  142. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +11 -17
  143. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  144. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +27 -0
  145. package/es/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +8 -9
  146. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -7
  147. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  148. package/es/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -32
  149. package/es/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +53 -0
  150. package/es/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +49 -0
  151. package/es/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +5 -4
  152. package/es/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  153. package/es/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  154. package/es/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  155. package/es/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +9 -6
  156. package/es/core/editor/components/titlebar/TopoEditorTitleBar.js +8 -4
  157. package/es/core/editor/config/themes.js +105 -0
  158. package/es/core/editor/hooks/useKeyboardShortcut.js +39 -0
  159. package/es/core/editor/hooks/useNewElementTheme.js +46 -0
  160. package/es/core/editor/store/topoEdit.js +44 -37
  161. package/es/core/editor/utils/edgeTypeStyleUtil.js +34 -11
  162. package/es/core/editor/utils/textStyleUtil.js +0 -0
  163. package/es/core/editor/utils/themeUtil.js +32 -0
  164. package/es/core/hooks/useCanvasTheme.js +54 -0
  165. package/es/core/hooks/useManageStatus.js +1 -9
  166. package/es/core/hooks/usePolling.js +2 -5
  167. package/es/core/hooks/useTopoEdit.js +15 -8
  168. package/es/core/models/Alarm.js +2 -2
  169. package/es/core/models/AttributeMetricDisplay.js +4 -0
  170. package/es/core/models/HistoryManager.js +13 -8
  171. package/es/core/models/{SelectionManager.js → SelectionModel.js} +55 -22
  172. package/es/core/models/TopoApp.js +6 -5
  173. package/es/core/models/selection/ignoreList.js +1 -0
  174. package/es/core/models/utils/linkUtils.js +5 -6
  175. package/es/core/store/models/customIcon.js +1 -3
  176. package/es/core/store/models/selection.js +2 -1
  177. package/es/core/store/models/topoBizMod.js +0 -3
  178. package/es/core/store/models/topoConfig.js +10 -12
  179. package/es/core/store/models/topoMod.js +26 -28
  180. package/es/core/utils/edgeUtil.js +6 -0
  181. package/es/core/utils/showGraphManageStatusUtil.js +7 -1
  182. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  183. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  184. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  185. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  186. package/es/core/viewer/components/plugins/ViewerPlugin.js +10 -4
  187. package/es/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  188. package/es/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  189. package/es/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +2 -1
  190. package/es/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +39 -6
  191. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -16
  192. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +37 -0
  193. package/es/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  194. package/es/networkTopo/components/editor/useEditorProps.js +1 -3
  195. package/es/networkTopo/createTopo.js +2 -0
  196. package/es/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  197. package/es/networkTopo/services/link.js +2 -2
  198. package/es/networkTopo/store/topoTreeMod.js +6 -7
  199. package/es/style.js +28 -27
  200. package/es/utils/htElementUtils.js +3 -0
  201. package/es/utils/topoData.js +1 -0
  202. package/lib/components/ColorPanel/components/ColorBlock/index.js +47 -0
  203. package/lib/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  204. package/lib/components/ColorPanel/components/FontColorRange/index.js +49 -0
  205. package/lib/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  206. package/lib/components/ColorPanel/index.js +278 -0
  207. package/lib/components/ColorPanel/index.module.scss +35 -0
  208. package/lib/components/VerticalIconTab/VerticalIconTab.js +14 -1
  209. package/lib/components/VerticalIconTab/VerticalIconTab.module.scss +2 -0
  210. package/lib/components/collapse/Collapse.js +28 -3
  211. package/lib/components/collapse/Collapse.module.scss +24 -0
  212. package/lib/components/collapse/index.js +11 -0
  213. package/lib/core/common/hooks/useHtElements.js +27 -0
  214. package/lib/core/common/icons/icon.js +47 -0
  215. package/lib/core/common/icons/useIcons.js +10 -15
  216. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  217. package/lib/core/components/AlarmListPanel/components/index.module.scss +5 -5
  218. package/lib/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  219. package/lib/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +10 -3
  220. package/lib/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +147 -0
  221. package/lib/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  222. package/lib/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +84 -22
  223. package/lib/core/components/TopoView/GraphViewPanel.js +32 -0
  224. package/lib/core/components/TopoView/editor.module.scss +1 -0
  225. package/lib/core/components/TopoView/topoView.js +36 -67
  226. package/lib/core/components/titlebar/TitleBar.module.scss +1 -1
  227. package/lib/core/editor/components/EditorPlugin.js +26 -2
  228. package/lib/core/editor/components/Sidebar/Sidebar.js +28 -6
  229. package/lib/core/editor/components/Sidebar/panes.js +10 -5
  230. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +14 -38
  231. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useCanvasThemeConfig.js +123 -0
  232. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useUpdateHtTopoDefaultTagStyle.js +37 -0
  233. package/lib/core/editor/components/Sidebar/views/CanvasPanel/utils/elementThemeUtil.js +1 -0
  234. package/lib/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +1 -1
  235. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +13 -1
  236. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +13 -1
  237. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +3 -3
  238. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +36 -12
  239. package/lib/core/editor/components/Toolbar/EditorToolbar.js +14 -7
  240. package/lib/core/editor/components/Toolbar/buttons.js +21 -20
  241. package/lib/core/editor/components/Toolbar/widgets/AddResourceButton.js +3 -3
  242. package/lib/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  243. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +48 -2
  244. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +100 -6
  245. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +73 -22
  246. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +1 -3
  247. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +18 -8
  248. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +83 -0
  249. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +53 -4
  250. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +172 -16
  251. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  252. package/lib/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +27 -11
  253. package/lib/core/editor/components/Toolbar/widgets/FontSizeWidget.js +38 -11
  254. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +96 -39
  255. package/lib/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +1 -1
  256. package/lib/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +2 -2
  257. package/lib/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +126 -0
  258. package/lib/core/editor/components/Toolbar/widgets/IconSelect/constant.js +69 -0
  259. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.js +117 -0
  260. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  261. package/lib/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +61 -0
  262. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +116 -0
  263. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  264. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +55 -0
  265. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  266. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +93 -0
  267. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  268. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +32 -0
  269. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +22 -0
  270. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  271. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  272. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  273. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  274. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +44 -0
  275. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  276. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +135 -16
  277. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +110 -23
  278. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  279. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +21 -5
  280. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +50 -6
  281. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +100 -14
  282. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  283. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.js +13 -4
  284. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  285. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  286. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  287. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  288. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +22 -7
  289. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +66 -0
  290. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +82 -0
  291. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +58 -0
  292. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +86 -0
  293. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +88 -0
  294. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +28 -0
  295. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +90 -0
  296. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +90 -0
  297. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +54 -0
  298. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +141 -0
  299. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +46 -0
  300. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +111 -0
  301. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +31 -0
  302. package/lib/core/editor/components/plugins/AddElementThemePlugin.js +20 -0
  303. package/lib/core/editor/components/settings/CloseablePanel.js +46 -0
  304. package/lib/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  305. package/lib/core/editor/components/settings/PropertyView.js +59 -12
  306. package/lib/core/editor/components/settings/Settings.js +40 -122
  307. package/lib/core/editor/components/settings/Settings.module.scss +7 -11
  308. package/lib/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  309. package/lib/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +97 -0
  310. package/lib/core/editor/components/settings/common/AlignSetting/index.js +21 -80
  311. package/lib/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  312. package/lib/core/editor/components/settings/common/LineType/index.js +11 -109
  313. package/lib/core/editor/components/settings/common/NameInput.js +38 -0
  314. package/lib/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +2 -2
  315. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +32 -26
  316. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +6 -6
  317. package/lib/core/editor/components/settings/common/text/fontStyleUtil.js +25 -20
  318. package/lib/core/editor/components/settings/core/PropertyViewManager.js +91 -0
  319. package/lib/core/editor/components/settings/core/edgePropertyViewAdapter.js +33 -0
  320. package/lib/core/editor/components/settings/core/getPropertyViewType.js +40 -0
  321. package/lib/core/editor/components/settings/core/updateElementProperty.js +27 -0
  322. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  323. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +76 -0
  324. package/lib/core/editor/components/settings/propertyViews/box/NameInput.js +6 -5
  325. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +15 -3
  326. package/lib/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +9 -12
  327. package/lib/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +7 -23
  328. package/lib/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +19 -0
  329. package/lib/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  330. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +14 -25
  331. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  332. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +43 -0
  333. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +98 -0
  334. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +8 -14
  335. package/lib/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +9 -7
  336. package/lib/core/editor/components/settings/propertyViews/index.js +4 -9
  337. package/lib/core/editor/components/settings/propertyViews/layer/BasicSetting.js +75 -0
  338. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +12 -20
  339. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  340. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +40 -0
  341. package/lib/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +6 -8
  342. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +4 -6
  343. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  344. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -35
  345. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +68 -0
  346. package/lib/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +64 -0
  347. package/lib/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +6 -5
  348. package/lib/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  349. package/lib/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  350. package/lib/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  351. package/lib/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +7 -5
  352. package/lib/core/editor/components/titlebar/TopoEditorTitleBar.js +9 -1
  353. package/lib/core/editor/config/themes.js +114 -0
  354. package/lib/core/editor/hooks/useKeyboardShortcut.js +49 -0
  355. package/lib/core/editor/hooks/useNewElementTheme.js +57 -0
  356. package/lib/core/editor/store/topoEdit.js +46 -40
  357. package/lib/core/editor/utils/edgeTypeStyleUtil.js +38 -11
  358. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  359. package/lib/core/editor/utils/themeUtil.js +39 -0
  360. package/lib/core/hooks/useCanvasTheme.js +68 -0
  361. package/lib/core/hooks/useManageStatus.js +1 -9
  362. package/lib/core/hooks/usePolling.js +2 -5
  363. package/lib/core/hooks/useTopoEdit.js +16 -8
  364. package/lib/core/models/Alarm.js +2 -2
  365. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  366. package/lib/core/models/HistoryManager.js +13 -8
  367. package/lib/core/models/{SelectionManager.js → SelectionModel.js} +57 -22
  368. package/lib/core/models/TopoApp.js +7 -5
  369. package/lib/core/models/selection/ignoreList.js +6 -0
  370. package/lib/core/models/utils/linkUtils.js +5 -6
  371. package/lib/core/store/models/customIcon.js +1 -3
  372. package/lib/core/store/models/selection.js +2 -1
  373. package/lib/core/store/models/topoBizMod.js +0 -3
  374. package/lib/core/store/models/topoConfig.js +9 -18
  375. package/lib/core/store/models/topoMod.js +27 -29
  376. package/lib/core/utils/edgeUtil.js +6 -0
  377. package/lib/core/utils/showGraphManageStatusUtil.js +7 -1
  378. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  379. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  380. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  381. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  382. package/lib/core/viewer/components/plugins/ViewerPlugin.js +11 -3
  383. package/lib/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  384. package/lib/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  385. package/lib/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +1 -0
  386. package/lib/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +45 -7
  387. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -18
  388. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +50 -0
  389. package/lib/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  390. package/lib/networkTopo/components/editor/useEditorProps.js +1 -4
  391. package/lib/networkTopo/createTopo.js +3 -0
  392. package/lib/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  393. package/lib/networkTopo/services/link.js +2 -2
  394. package/lib/networkTopo/store/topoTreeMod.js +6 -8
  395. package/lib/style.js +28 -27
  396. package/lib/utils/htElementUtils.js +5 -0
  397. package/lib/utils/topoData.js +1 -0
  398. package/package.json +5 -4
@@ -1,6 +1,8 @@
1
+ import _extends from "@babel/runtime/helpers/extends";
1
2
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose";
2
3
  var _excluded = ["topo", "showLabel"];
3
4
  import React, { useEffect, useState } from 'react';
5
+ import { getEdgesBySelection } from "../../../../utils/edgeTypeStyleUtil";
4
6
  import DropdownButton from "../components/DropdownButton";
5
7
  import WidgetBox from "../WidgetBox";
6
8
  import Content from "./Content";
@@ -17,13 +19,97 @@ function EdgeColorButton(props) {
17
19
 
18
20
  var _useState = useState(true),
19
21
  disabled = _useState[0],
20
- setDisabled = _useState[1]; // 选中的元素
22
+ setDisabled = _useState[1];
21
23
 
24
+ var _useState2 = useState(1),
25
+ lineWidth = _useState2[0],
26
+ setLineWidth = _useState2[1]; // 拓扑图是否加载
27
+
28
+
29
+ var _topo$store$useModelS = topo.store.useModelState('topoMod'),
30
+ graphLoaded = _topo$store$useModelS.graphLoaded; // 选中的元素
31
+
32
+
33
+ var selection = topo.selectionModel.useHtSelection();
34
+
35
+ var loopEdges = function loopEdges(edges, operateEdgeFn) {
36
+ edges.forEach(function (edge) {
37
+ operateEdgeFn(edge);
38
+ });
39
+ };
40
+
41
+ var getLines = function getLines(list) {
42
+ // eslint-disable-next-line prefer-const
43
+ var arr = [];
44
+ loopEdges(list, function (edge) {
45
+ // eslint-disable-next-line eqeqeq
46
+ if (edge.getAttrObject().type == 'line') {
47
+ arr.push(edge);
48
+ }
49
+ });
50
+ return arr;
51
+ };
22
52
 
23
- var selection = topo.selectionManager.useSelection();
24
53
  useEffect(function () {
25
- setDisabled(false);
26
- }, [selection]);
54
+ if (graphLoaded) {
55
+ var edges = getEdgesBySelection(topo);
56
+ var list = getLines(edges);
57
+ setLineWidth(1); // eslint-disable-next-line eqeqeq
58
+
59
+ if (selection.length == 1 && selection[0].a('type') == 'line') {
60
+ setLineWidth(list[0] && (list[0].a('styles') && list[0].a('styles').width || list[0].getStyleMap()['edge.width']) || 2);
61
+ }
62
+
63
+ setDisabled(!list.length);
64
+ }
65
+ }, [selection, graphLoaded]);
66
+
67
+ var colorOnChange = function colorOnChange(colors, type) {
68
+ // eslint-disable-next-line eqeqeq
69
+ if (type == 'select') topo.historyManager.beginTransaction();
70
+ var edges = getEdgesBySelection(topo);
71
+ loopEdges(edges, function (edge) {
72
+ // eslint-disable-next-line eqeqeq
73
+ if (edge.getAttrObject().type == 'line') {
74
+ var color = colors.hex;
75
+ edge.s('edge.color', color);
76
+ edge.s('edge.dash.color', color);
77
+ var style = edge.a('styles') || {};
78
+ edge.a('styles', _extends({}, style, {
79
+ color: color
80
+ }));
81
+ }
82
+ }); // eslint-disable-next-line eqeqeq
83
+
84
+ if (type == 'select') topo.historyManager.endTransaction();
85
+ };
86
+
87
+ var onPickerFocus = function onPickerFocus() {
88
+ // topo.getHtTopo().getGraphView().dm().sm().ld()
89
+ topo.historyManager.beginTransaction();
90
+ };
91
+
92
+ var onPickerBlur = function onPickerBlur() {
93
+ topo.historyManager.endTransaction();
94
+ };
95
+
96
+ var lineSizeChange = function lineSizeChange(width) {
97
+ var edges = getEdgesBySelection(topo);
98
+ topo.historyManager.beginTransaction();
99
+ loopEdges(edges, function (edge) {
100
+ // eslint-disable-next-line eqeqeq
101
+ if (edge.getAttrObject().type == 'line') {
102
+ edge.s('edge.dash.width', width);
103
+ edge.s('edge.width', width);
104
+ var style = edge.a('styles') || {};
105
+ edge.a('styles', _extends({}, style, {
106
+ width: width
107
+ }));
108
+ }
109
+ });
110
+ topo.historyManager.endTransaction();
111
+ };
112
+
27
113
  var icon = disabled ? /*#__PURE__*/React.createElement("img", {
28
114
  src: "/img/topo/editor/toolbar/\u7EBF\u6761\u586B\u5145/Disable.svg",
29
115
  alt: ""
@@ -34,12 +120,18 @@ function EdgeColorButton(props) {
34
120
  return /*#__PURE__*/React.createElement(WidgetBox, {
35
121
  label: "\u7EBF\u6761\u989C\u8272",
36
122
  tooltip: "\u7EBF\u6761\u989C\u8272",
37
- showLabel: showLabel
123
+ showLabel: showLabel,
124
+ disabled: disabled
38
125
  }, /*#__PURE__*/React.createElement(DropdownButton, {
39
126
  disabled: disabled,
40
127
  trigger: icon
41
128
  }, /*#__PURE__*/React.createElement(Content, {
42
- topo: topo
129
+ topo: topo,
130
+ onChange: colorOnChange,
131
+ onPickerFocus: onPickerFocus,
132
+ onPickerBlur: onPickerBlur,
133
+ lineSizeChange: lineSizeChange,
134
+ lineWidth: lineWidth
43
135
  })));
44
136
  }
45
137
 
@@ -1,27 +1,46 @@
1
1
  import _Field from "@alifd/next/es/field";
2
2
  import _Select from "@alifd/next/es/select";
3
3
  import _Form from "@alifd/next/es/form";
4
- import React, { useState } from 'react';
4
+ import React, { useEffect } from 'react';
5
5
  import styles from "./EdgeType.module.scss";
6
6
  import LineType from "./LineType";
7
7
  var FormItem = _Form.Item;
8
8
  var Option = _Select.Option;
9
- var START_END_TYPE_OPTIONS = [{
9
+ var START_TYPE_OPTIONS = [{
10
10
  value: 'nil',
11
11
  label: '无',
12
12
  icon: 'topo_startEndPoint_icon_nothing'
13
+ }, // {
14
+ // value: 'sourceNoneCircle',
15
+ // label: '空心圆',
16
+ // icon: 'topo_startPoint_icon_hollow_cricle',
17
+ // },
18
+ {
19
+ value: 'sourceSolidCircle',
20
+ label: '实心圆',
21
+ icon: 'topo_startPoint_icon_solid_cricle'
13
22
  }, {
14
- value: 'hollowCrcial',
15
- label: '空心圆',
16
- icon: 'topo_startEndPoint_icon_hollow_cricle'
17
- }, {
18
- value: 'solidCricle',
23
+ value: 'sourceArrow',
24
+ label: '箭头',
25
+ icon: 'topo_startPoint_icon_arrow'
26
+ }];
27
+ var END_TYPE_OPTIONS = [{
28
+ value: 'nil',
29
+ label: '无',
30
+ icon: 'topo_startEndPoint_icon_nothing'
31
+ }, // {
32
+ // value: 'targetNoneCircle',
33
+ // label: '空心圆',
34
+ // icon: 'topo_endPoint_icon_hollow_cricle',
35
+ // },
36
+ {
37
+ value: 'targetSolidCircle',
19
38
  label: '实心圆',
20
- icon: 'topo_startEndPoint_icon_solid_cricle'
39
+ icon: 'topo_endPoint_icon_solid_cricle'
21
40
  }, {
22
- value: 'arrowPoint',
41
+ value: 'targetArrow',
23
42
  label: '箭头',
24
- icon: 'topo_startEndPoint_icon_arrow'
43
+ icon: 'topo_endPoint_icon_arrow'
25
44
  }];
26
45
  var LINE_MOLD_OPTIONS = [{
27
46
  value: 'solidLine',
@@ -41,16 +60,43 @@ var LINE_MOLD_OPTIONS = [{
41
60
  icon: 'topo_lineMold_dotted_two'
42
61
  }];
43
62
 
63
+ function getValuesBySelection(selection) {
64
+ var values = {
65
+ startPoint: undefined,
66
+ endPoint: undefined,
67
+ lineMold: undefined
68
+ }; // 仅一条连线选中时回显
69
+
70
+ if (selection.length === 1) {
71
+ var edge = selection[0];
72
+ values = {
73
+ startPoint: 'nil',
74
+ endPoint: 'nil',
75
+ lineMold: edge.a('lineMode') || 'solidLine'
76
+ };
77
+ var icons = edge.s('icons') || {};
78
+ ['sourceArrow', 'sourceSolidCircle', 'sourceNoneCircle'].forEach(function (name) {
79
+ if (icons[name]) {
80
+ values.startPoint = name;
81
+ }
82
+ });
83
+ ['targetArrow', 'targetSolidCircle', 'targetNoneCircle'].forEach(function (name) {
84
+ if (icons[name]) {
85
+ values.endPoint = name;
86
+ }
87
+ });
88
+ }
89
+
90
+ return values;
91
+ }
92
+
44
93
  function EdgeType(props) {
45
- var _onChange = props.onChange;
94
+ var selection = props.selection,
95
+ _onChange = props.onChange;
46
96
 
47
97
  var field = _Field.useField({
48
98
  autoUnmount: false,
49
- values: {
50
- startPoint: 'nil',
51
- endPoint: 'nil',
52
- type: null
53
- },
99
+ values: getValuesBySelection(selection),
54
100
  onChange: function onChange(name, value) {
55
101
  if (['startPoint', 'endPoint'].includes(name) && value === 'nil') {
56
102
  _onChange(name, null);
@@ -60,6 +106,9 @@ function EdgeType(props) {
60
106
  }
61
107
  });
62
108
 
109
+ useEffect(function () {
110
+ field.setValues(getValuesBySelection(selection));
111
+ }, [selection]);
63
112
  return /*#__PURE__*/React.createElement("div", {
64
113
  className: styles.lineBox
65
114
  }, /*#__PURE__*/React.createElement(_Form, {
@@ -72,12 +121,13 @@ function EdgeType(props) {
72
121
  label: "\u8D77\u70B9"
73
122
  }, /*#__PURE__*/React.createElement(_Select, {
74
123
  name: "startPoint",
124
+ placeholder: " ",
75
125
  popupProps: {
76
126
  container: function container(trigger) {
77
127
  return trigger.parentNode;
78
128
  }
79
129
  }
80
- }, START_END_TYPE_OPTIONS.map(function (item, index, array) {
130
+ }, START_TYPE_OPTIONS.map(function (item, index) {
81
131
  return /*#__PURE__*/React.createElement(Option, {
82
132
  value: item.value,
83
133
  key: index,
@@ -92,12 +142,13 @@ function EdgeType(props) {
92
142
  label: "\u7EC8\u70B9"
93
143
  }, /*#__PURE__*/React.createElement(_Select, {
94
144
  name: "endPoint",
145
+ placeholder: " ",
95
146
  popupProps: {
96
147
  container: function container(trigger) {
97
148
  return trigger.parentNode;
98
149
  }
99
150
  }
100
- }, START_END_TYPE_OPTIONS.map(function (item, index, array) {
151
+ }, END_TYPE_OPTIONS.map(function (item, index) {
101
152
  return /*#__PURE__*/React.createElement(Option, {
102
153
  value: item.value,
103
154
  key: index,
@@ -111,18 +162,18 @@ function EdgeType(props) {
111
162
  }))), /*#__PURE__*/React.createElement(FormItem, {
112
163
  label: "\u7C7B\u578B"
113
164
  }, /*#__PURE__*/React.createElement(_Select, {
114
- name: "type",
165
+ name: "lineMold",
115
166
  popupProps: {
116
167
  container: function container(trigger) {
117
168
  return trigger.parentNode;
118
169
  }
119
170
  },
120
- placeholder: ""
121
- }, LINE_MOLD_OPTIONS.map(function (item, index, array) {
171
+ placeholder: " "
172
+ }, LINE_MOLD_OPTIONS.map(function (item, index) {
122
173
  return /*#__PURE__*/React.createElement(Option, {
123
174
  value: item.value,
124
- key: index,
125
- title: item.label,
175
+ key: index // title={item.label}
176
+ ,
126
177
  onchange: _onChange
127
178
  }, /*#__PURE__*/React.createElement("img", {
128
179
  src: "/img/topo/editor/lineType/" + item.icon + ".svg",
@@ -38,9 +38,7 @@
38
38
  }
39
39
  .#{$css-prefix}input.#{$css-prefix}medium .#{$css-prefix}input-text-field {
40
40
  line-height: calc(28px - 10px * 2);
41
- }
42
- .#{$css-prefix}select-trigger-search {
43
- height: 12px;
41
+ padding: 0 7px;
44
42
  }
45
43
  }
46
44
  }
@@ -1,6 +1,8 @@
1
1
  import _Button from "@alifd/next/es/button";
2
+ import _Balloon from "@alifd/next/es/balloon";
2
3
  import React, { useState } from 'react';
3
4
  import styles from "./LineType.module.scss";
5
+ var Tooltip = _Balloon.Tooltip;
4
6
  var LINE_TYPE_OPTIONS = [{
5
7
  value: 'boundary',
6
8
  label: '直线',
@@ -11,7 +13,7 @@ var LINE_TYPE_OPTIONS = [{
11
13
  icon: 'topo_linear_icon_narrow_straightline'
12
14
  }, {
13
15
  value: 'h.v',
14
- label: '纵向折线',
16
+ label: '折线',
15
17
  icon: 'topo_linear_icon_vertical_foldline'
16
18
  }, {
17
19
  value: 'ortho',
@@ -22,15 +24,11 @@ var LINE_TYPE_OPTIONS = [{
22
24
  label: '双弧线',
23
25
  icon: 'topo_linear_icon_arcline'
24
26
  }];
25
-
26
- function LineType(props) {
27
+ var LineType = /*#__PURE__*/React.forwardRef(function (props, ref) {
27
28
  var onChange = props.onChange;
28
- return /*#__PURE__*/React.createElement("div", {
29
- className: styles.lineType
30
- }, LINE_TYPE_OPTIONS.map(function (item, index, array) {
29
+
30
+ function lineButton(item) {
31
31
  return /*#__PURE__*/React.createElement(_Button, {
32
- key: index,
33
- title: item.label,
34
32
  className: "" + styles.redioBtn,
35
33
  onClick: function onClick() {
36
34
  onChange(item.value);
@@ -40,7 +38,16 @@ function LineType(props) {
40
38
  alt: "",
41
39
  className: styles.iconImg
42
40
  }));
43
- }));
44
- }
41
+ }
45
42
 
43
+ return /*#__PURE__*/React.createElement("div", {
44
+ className: styles.lineType
45
+ }, LINE_TYPE_OPTIONS.map(function (item, index) {
46
+ return /*#__PURE__*/React.createElement(Tooltip, {
47
+ trigger: lineButton(item),
48
+ align: "br",
49
+ key: index
50
+ }, item.label);
51
+ }));
52
+ });
46
53
  export default LineType;
@@ -0,0 +1,77 @@
1
+ export var EDGE_END_POINT_TYPE_MAP = {
2
+ // 起点箭头
3
+ sourceArrow: {
4
+ names: ['sourceArrow'],
5
+ position: 15,
6
+ height: 15,
7
+ width: 37.5,
8
+ offsetX: -2,
9
+ keepOrien: true
10
+ },
11
+ // 起点实心圆
12
+ sourceSolidCircle: {
13
+ names: ['sourceSolidCircle'],
14
+ position: 15,
15
+ height: 12.5,
16
+ width: 25,
17
+ offsetX: 3,
18
+ keepOrien: true
19
+ },
20
+ // 起点空心圆
21
+ sourceNoneCircle: {
22
+ names: ['sourceNoneCircle'],
23
+ position: 15,
24
+ height: 12.5,
25
+ width: 25,
26
+ offsetX: 2.5,
27
+ keepOrien: true
28
+ },
29
+ // 终点箭头
30
+ targetArrow: {
31
+ names: ['targetArrow'],
32
+ position: 19,
33
+ height: 15,
34
+ width: 37.5,
35
+ offsetX: 3,
36
+ keepOrien: true
37
+ },
38
+ // 终点实心圆
39
+ targetSolidCircle: {
40
+ names: ['targetSolidCircle'],
41
+ position: 19,
42
+ height: 12.5,
43
+ width: 25,
44
+ offsetX: 0.5,
45
+ keepOrien: true
46
+ },
47
+ // 终点空心圆
48
+ targetNoneCircle: {
49
+ names: ['targetNoneCircle'],
50
+ position: 19,
51
+ height: 12.5,
52
+ width: 25,
53
+ offsetX: -0.5,
54
+ keepOrien: true
55
+ }
56
+ };
57
+ export var LINE_MOLD_MAP = {
58
+ solidLine: {
59
+ lineType: 'solid',
60
+ dashPattern: null
61
+ },
62
+ dottedLine: {
63
+ lineType: 'dash',
64
+ dashPattern: 1 // lineType为dash生效。为空默认为1。值:1/2/3
65
+
66
+ },
67
+ dottedLine1: {
68
+ lineType: 'dash',
69
+ dashPattern: 3 // lineType为dash生效。为空默认为1。值:1/2/3
70
+
71
+ },
72
+ dottedLine2: {
73
+ lineType: 'dash',
74
+ dashPattern: 2 // lineType为dash生效。为空默认为1。值:1/2/3
75
+
76
+ }
77
+ };
@@ -1,9 +1,11 @@
1
+ import _extends from "@babel/runtime/helpers/extends";
1
2
  import _objectWithoutPropertiesLoose from "@babel/runtime/helpers/objectWithoutPropertiesLoose";
2
3
  var _excluded = ["topo", "showLabel"];
3
4
  import React, { useEffect, useMemo, useState } from 'react';
4
- import { getEdgesBySelection, setEdgesType } from "../../../../utils/edgeTypeStyleUtil";
5
+ import { getEdgesBySelection, setEdgesAndChildren, setEdgesType } from "../../../../utils/edgeTypeStyleUtil";
5
6
  import DropdownButton from "../components/DropdownButton";
6
7
  import WidgetBox from "../WidgetBox";
8
+ import { EDGE_END_POINT_TYPE_MAP, LINE_MOLD_MAP } from "./constants";
7
9
  import EdgeType from "./EdgeType";
8
10
  /**
9
11
  * 线形设置
@@ -16,7 +18,7 @@ function EdgeTypeButton(props) {
16
18
  showLabel = props.showLabel,
17
19
  otherProps = _objectWithoutPropertiesLoose(props, _excluded);
18
20
 
19
- var _useState = useState(false),
21
+ var _useState = useState(true),
20
22
  disabled = _useState[0],
21
23
  setDisabled = _useState[1]; // 拓扑图是否加载
22
24
 
@@ -25,21 +27,65 @@ function EdgeTypeButton(props) {
25
27
  graphLoaded = _topo$store$useModelS.graphLoaded; // 选中的元素
26
28
 
27
29
 
28
- var selection = topo.selectionManager.useSelection();
30
+ var selection = topo.selectionModel.useHtSelection();
29
31
  useEffect(function () {
30
32
  if (graphLoaded) {
31
33
  var edges = getEdgesBySelection(topo);
32
- console.info('xxxx', edges, selection);
33
34
  setDisabled(!edges.length);
34
35
  }
35
36
  }, [selection, graphLoaded]);
36
37
 
37
38
  var handleChange = function handleChange(name, value) {
38
39
  var edges = getEdgesBySelection(topo);
40
+ var htTopo = topo.getHtTopo();
39
41
 
40
42
  if (name === 'lineButton') {
41
43
  setEdgesType(edges, value, topo);
44
+ return;
42
45
  }
46
+
47
+ setEdgesAndChildren(topo, edges, function (edge) {
48
+ if (name === 'startPoint') {
49
+ // 删除设置
50
+ ['sourceArrow', 'sourceSolidCircle', 'sourceNoneCircle'].forEach(function (iconName) {
51
+ return edge.removeStyleIcon(iconName);
52
+ }); // 设置
53
+
54
+ var scolor = edge.a('styles') && edge.a('styles').color || edge.getStyleMap()['edge.color'];
55
+ edge.a('arrow.color', scolor || '#00B779');
56
+ edge.s('icons', _extends({}, edge.s('icons')));
57
+ edge.addStyleIcon(value, EDGE_END_POINT_TYPE_MAP[value]);
58
+ } else if (name === 'endPoint') {
59
+ // 删除设置
60
+ ['targetArrow', 'targetSolidCircle', 'targetNoneCircle'].forEach(function (iconName) {
61
+ return edge.removeStyleIcon(iconName);
62
+ }); // 设置
63
+
64
+ var _scolor = edge.a('styles') && edge.a('styles').color || edge.getStyleMap()['edge.color'];
65
+
66
+ edge.a('arrow.color', _scolor || '#00B779');
67
+ edge.s('icons', _extends({}, edge.s('icons')));
68
+ edge.addStyleIcon(value, EDGE_END_POINT_TYPE_MAP[value]);
69
+ } else if (name === 'lineMold') {
70
+ // 修改实线虚线
71
+ edge.a('lineMode', value);
72
+ htTopo.setElementStyle(edge, LINE_MOLD_MAP[value]);
73
+
74
+ if (value !== 'solid') {
75
+ var edgeWidth = edge.s('edge.width');
76
+
77
+ if (edgeWidth) {
78
+ edge.s('edge.dash.width', edgeWidth);
79
+ }
80
+
81
+ var color = edge.s('edge.color');
82
+
83
+ if (edgeWidth) {
84
+ edge.s('edge.dash.color', color);
85
+ }
86
+ }
87
+ }
88
+ });
43
89
  };
44
90
 
45
91
  var icon = disabled ? /*#__PURE__*/React.createElement("img", {
@@ -57,7 +103,8 @@ function EdgeTypeButton(props) {
57
103
  }, /*#__PURE__*/React.createElement(DropdownButton, {
58
104
  disabled: disabled,
59
105
  trigger: icon
60
- }, /*#__PURE__*/React.createElement(EdgeType, {
106
+ }, !disabled && /*#__PURE__*/React.createElement(EdgeType, {
107
+ selection: selection,
61
108
  onChange: handleChange
62
109
  })));
63
110
  }