@riil-frontend/component-topology 6.0.0-alpha.4 → 6.0.0-alpha.41

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 (335) 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/es/components/ColorPanel/components/ColorBlock/index.js +37 -0
  6. package/es/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  7. package/es/components/ColorPanel/components/FontColorRange/index.js +35 -0
  8. package/es/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  9. package/es/components/ColorPanel/index.js +237 -0
  10. package/es/components/ColorPanel/index.module.scss +35 -0
  11. package/es/components/VerticalIconTab/VerticalIconTab.module.scss +5 -1
  12. package/es/components/collapse/Collapse.js +22 -3
  13. package/es/components/collapse/Collapse.module.scss +24 -0
  14. package/es/components/collapse/index.js +2 -0
  15. package/es/core/common/hooks/useHtElements.js +21 -0
  16. package/es/core/common/icons/icon.js +41 -0
  17. package/es/core/common/icons/useIcons.js +8 -16
  18. package/es/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  19. package/es/core/components/AlarmListPanel/components/index.module.scss +5 -5
  20. package/es/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  21. package/es/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +9 -3
  22. package/es/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +122 -0
  23. package/es/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  24. package/es/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +76 -19
  25. package/es/core/components/TopoView/GraphViewPanel.js +21 -0
  26. package/es/core/components/TopoView/editor.module.scss +1 -0
  27. package/es/core/components/TopoView/topoView.js +29 -49
  28. package/es/core/components/titlebar/TitleBar.module.scss +1 -1
  29. package/es/core/editor/components/EditorPlugin.js +2 -1
  30. package/es/core/editor/components/Sidebar/Sidebar.js +41 -50
  31. package/es/core/editor/components/Sidebar/panes.js +32 -0
  32. package/es/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +38 -0
  33. package/es/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.module.scss +74 -0
  34. package/es/core/editor/components/Sidebar/views/CanvasPanel/index.js +1 -1
  35. package/es/core/editor/components/Sidebar/views/CanvasPanel/themes.js +63 -0
  36. package/es/core/editor/components/Sidebar/views/CanvasPanel/useCanvasThemeConfig.js +115 -0
  37. package/es/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +3 -3
  38. package/es/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +14 -6
  39. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +14 -5
  40. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +5 -0
  41. package/es/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +20 -7
  42. package/es/core/editor/components/Toolbar/EditorToolbar.js +23 -13
  43. package/es/core/editor/components/Toolbar/Toolbar.js +1 -1
  44. package/es/core/editor/components/Toolbar/Toolbar.module.scss +14 -3
  45. package/es/core/editor/components/Toolbar/buttons.js +20 -18
  46. package/es/core/editor/components/Toolbar/widgets/AddResourceButton.js +8 -7
  47. package/es/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +2 -2
  48. package/es/core/editor/components/Toolbar/widgets/CanvasMoveWidget.js +13 -2
  49. package/es/core/editor/components/Toolbar/widgets/CanvasSelectWidget.js +11 -2
  50. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +46 -2
  51. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +98 -6
  52. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +184 -3
  53. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +44 -0
  54. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +53 -0
  55. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.module.scss +31 -0
  56. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +77 -0
  57. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +74 -6
  58. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +70 -16
  59. package/es/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +43 -0
  60. package/es/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +25 -11
  61. package/es/core/editor/components/Toolbar/widgets/FontSizeWidget.js +29 -13
  62. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +100 -39
  63. package/es/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +3 -2
  64. package/es/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +5 -4
  65. package/es/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +109 -0
  66. package/es/core/editor/components/Toolbar/widgets/IconSelect/constant.js +64 -0
  67. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.js +101 -0
  68. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  69. package/es/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +49 -0
  70. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +99 -0
  71. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  72. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +42 -0
  73. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  74. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +75 -0
  75. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  76. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +23 -0
  77. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +10 -0
  78. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  79. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  80. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  81. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  82. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +31 -0
  83. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  84. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +128 -15
  85. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +95 -23
  86. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  87. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +15 -5
  88. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +41 -7
  89. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +98 -13
  90. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  91. package/es/core/editor/components/Toolbar/widgets/WidgetBox.js +15 -22
  92. package/es/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +11 -1
  93. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.js +5 -3
  94. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +3 -0
  95. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +21 -3
  96. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +16 -6
  97. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +49 -0
  98. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +59 -0
  99. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +30 -0
  100. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +25 -0
  101. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +41 -0
  102. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +14 -0
  103. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +49 -0
  104. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +36 -0
  105. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +32 -0
  106. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +71 -0
  107. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +25 -0
  108. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +52 -0
  109. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +20 -0
  110. package/es/core/editor/components/settings/CloseablePanel.js +33 -0
  111. package/es/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  112. package/es/core/editor/components/settings/OpenPropertyPanelListener.js +33 -0
  113. package/es/core/editor/components/settings/PropertyView.js +29 -8
  114. package/es/core/editor/components/settings/Settings.js +4 -44
  115. package/es/core/editor/components/settings/Settings.module.scss +8 -4
  116. package/es/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +2 -2
  117. package/es/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +80 -0
  118. package/es/core/editor/components/settings/common/AlignSetting/index.js +20 -72
  119. package/es/core/editor/components/settings/common/LineType/index.js +12 -119
  120. package/es/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +3 -3
  121. package/es/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +31 -21
  122. package/es/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +7 -6
  123. package/es/core/editor/components/settings/common/text/fontStyleUtil.js +11 -19
  124. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  125. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +0 -8
  126. package/es/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +8 -9
  127. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -42
  128. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  129. package/es/core/editor/components/settings/propertyViews/text/TextPropertyView.js +1 -1
  130. package/es/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +9 -6
  131. package/es/core/editor/components/titlebar/TopoEditorTitleBar.js +8 -4
  132. package/es/core/editor/hooks/useKeyboardShortcut.js +42 -0
  133. package/es/core/{store/models → editor/store}/background.js +0 -0
  134. package/es/core/{store/models → editor/store}/historyManager.js +0 -0
  135. package/es/core/editor/store/topoEdit.js +49 -0
  136. package/es/core/editor/utils/edgeTypeStyleUtil.js +96 -0
  137. package/es/core/editor/utils/textStyleUtil.js +0 -0
  138. package/es/core/hooks/useCanvasTheme.js +61 -0
  139. package/es/core/hooks/usePolling.js +2 -5
  140. package/es/core/hooks/useTopoEdit.js +38 -58
  141. package/es/core/models/Alarm.js +2 -2
  142. package/es/core/models/AttributeMetricDisplay.js +4 -0
  143. package/es/core/models/HistoryManager.js +11 -3
  144. package/es/core/models/SelectionManager.js +28 -9
  145. package/es/core/models/TopoApp.js +1 -1
  146. package/es/core/models/TopoGraphView.js +8 -2
  147. package/es/core/models/selection/ignoreList.js +1 -0
  148. package/es/core/models/utils/linkUtils.js +5 -6
  149. package/es/core/store/coreModels.js +6 -7
  150. package/es/core/store/models/selection.js +2 -1
  151. package/es/core/store/models/topoBizMod.js +0 -3
  152. package/es/core/store/models/topoConfig.js +10 -12
  153. package/es/core/store/models/topoMod.js +26 -28
  154. package/es/core/utils/edgeUtil.js +6 -0
  155. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +3 -4
  156. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +19 -5
  157. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  158. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  159. package/es/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  160. package/es/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  161. package/es/networkTopo/createTopo.js +2 -0
  162. package/es/networkTopo/services/link.js +2 -2
  163. package/es/networkTopo/store/topoTreeMod.js +6 -7
  164. package/es/style.js +1 -0
  165. package/es/utils/htElementUtils.js +3 -0
  166. package/es/utils/topoData.js +1 -0
  167. package/lib/components/ColorPanel/components/ColorBlock/index.js +47 -0
  168. package/lib/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  169. package/lib/components/ColorPanel/components/FontColorRange/index.js +49 -0
  170. package/lib/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  171. package/lib/components/ColorPanel/index.js +255 -0
  172. package/lib/components/ColorPanel/index.module.scss +35 -0
  173. package/lib/components/VerticalIconTab/VerticalIconTab.module.scss +5 -1
  174. package/lib/components/collapse/Collapse.js +28 -3
  175. package/lib/components/collapse/Collapse.module.scss +24 -0
  176. package/lib/components/collapse/index.js +11 -0
  177. package/lib/core/common/hooks/useHtElements.js +27 -0
  178. package/lib/core/common/icons/icon.js +48 -0
  179. package/lib/core/common/icons/useIcons.js +10 -15
  180. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  181. package/lib/core/components/AlarmListPanel/components/index.module.scss +5 -5
  182. package/lib/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  183. package/lib/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +10 -3
  184. package/lib/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +147 -0
  185. package/lib/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  186. package/lib/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +76 -19
  187. package/lib/core/components/TopoView/GraphViewPanel.js +31 -0
  188. package/lib/core/components/TopoView/editor.module.scss +1 -0
  189. package/lib/core/components/TopoView/topoView.js +32 -50
  190. package/lib/core/components/titlebar/TitleBar.module.scss +1 -1
  191. package/lib/core/editor/components/EditorPlugin.js +3 -1
  192. package/lib/core/editor/components/Sidebar/Sidebar.js +40 -53
  193. package/lib/core/editor/components/Sidebar/panes.js +45 -0
  194. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +53 -0
  195. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.module.scss +74 -0
  196. package/lib/core/editor/components/Sidebar/views/CanvasPanel/index.js +2 -2
  197. package/lib/core/editor/components/Sidebar/views/CanvasPanel/themes.js +72 -0
  198. package/lib/core/editor/components/Sidebar/views/CanvasPanel/useCanvasThemeConfig.js +128 -0
  199. package/lib/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +1 -1
  200. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +15 -6
  201. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +16 -5
  202. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +5 -0
  203. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +29 -11
  204. package/lib/core/editor/components/Toolbar/EditorToolbar.js +22 -11
  205. package/lib/core/editor/components/Toolbar/Toolbar.js +1 -1
  206. package/lib/core/editor/components/Toolbar/Toolbar.module.scss +14 -3
  207. package/lib/core/editor/components/Toolbar/buttons.js +21 -20
  208. package/lib/core/editor/components/Toolbar/widgets/AddResourceButton.js +8 -7
  209. package/lib/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +2 -2
  210. package/lib/core/editor/components/Toolbar/widgets/CanvasMoveWidget.js +13 -2
  211. package/lib/core/editor/components/Toolbar/widgets/CanvasSelectWidget.js +11 -2
  212. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +48 -2
  213. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +100 -6
  214. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +194 -3
  215. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +44 -0
  216. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +71 -0
  217. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.module.scss +31 -0
  218. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +83 -0
  219. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +76 -5
  220. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +75 -16
  221. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +43 -0
  222. package/lib/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +26 -10
  223. package/lib/core/editor/components/Toolbar/widgets/FontSizeWidget.js +30 -12
  224. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +105 -39
  225. package/lib/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +4 -2
  226. package/lib/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +5 -3
  227. package/lib/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +126 -0
  228. package/lib/core/editor/components/Toolbar/widgets/IconSelect/constant.js +69 -0
  229. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.js +117 -0
  230. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  231. package/lib/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +61 -0
  232. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +116 -0
  233. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  234. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +55 -0
  235. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  236. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +93 -0
  237. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  238. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +32 -0
  239. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +22 -0
  240. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  241. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  242. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  243. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  244. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +44 -0
  245. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  246. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +133 -16
  247. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +98 -23
  248. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  249. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +21 -5
  250. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +41 -6
  251. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +99 -12
  252. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  253. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.js +16 -22
  254. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +11 -1
  255. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.js +5 -3
  256. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +3 -0
  257. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +21 -3
  258. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +17 -6
  259. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +63 -0
  260. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +72 -0
  261. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +45 -0
  262. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +40 -0
  263. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +57 -0
  264. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +28 -0
  265. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +64 -0
  266. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +52 -0
  267. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +47 -0
  268. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +83 -0
  269. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +39 -0
  270. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +65 -0
  271. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +31 -0
  272. package/lib/core/editor/components/settings/CloseablePanel.js +46 -0
  273. package/lib/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  274. package/lib/core/editor/components/settings/OpenPropertyPanelListener.js +43 -0
  275. package/lib/core/editor/components/settings/PropertyView.js +32 -8
  276. package/lib/core/editor/components/settings/Settings.js +4 -44
  277. package/lib/core/editor/components/settings/Settings.module.scss +8 -4
  278. package/lib/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +2 -2
  279. package/lib/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +97 -0
  280. package/lib/core/editor/components/settings/common/AlignSetting/index.js +21 -80
  281. package/lib/core/editor/components/settings/common/LineType/index.js +13 -126
  282. package/lib/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +2 -2
  283. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +32 -23
  284. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +6 -6
  285. package/lib/core/editor/components/settings/common/text/fontStyleUtil.js +12 -20
  286. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  287. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +0 -8
  288. package/lib/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +6 -8
  289. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -42
  290. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  291. package/lib/core/editor/components/settings/propertyViews/text/TextPropertyView.js +1 -1
  292. package/lib/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +7 -5
  293. package/lib/core/editor/components/titlebar/TopoEditorTitleBar.js +9 -1
  294. package/lib/core/editor/hooks/useKeyboardShortcut.js +52 -0
  295. package/lib/core/{store/models → editor/store}/background.js +0 -0
  296. package/lib/core/{store/models → editor/store}/historyManager.js +0 -0
  297. package/lib/core/editor/store/topoEdit.js +59 -0
  298. package/lib/core/editor/utils/edgeTypeStyleUtil.js +109 -0
  299. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  300. package/lib/core/hooks/useCanvasTheme.js +75 -0
  301. package/lib/core/hooks/usePolling.js +2 -5
  302. package/lib/core/hooks/useTopoEdit.js +39 -60
  303. package/lib/core/models/Alarm.js +2 -2
  304. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  305. package/lib/core/models/HistoryManager.js +11 -3
  306. package/lib/core/models/SelectionManager.js +30 -9
  307. package/lib/core/models/TopoApp.js +1 -1
  308. package/lib/core/models/TopoGraphView.js +8 -2
  309. package/lib/core/models/selection/ignoreList.js +6 -0
  310. package/lib/core/models/utils/linkUtils.js +5 -6
  311. package/lib/core/store/coreModels.js +5 -7
  312. package/lib/core/store/models/selection.js +2 -1
  313. package/lib/core/store/models/topoBizMod.js +0 -3
  314. package/lib/core/store/models/topoConfig.js +9 -18
  315. package/lib/core/store/models/topoMod.js +27 -29
  316. package/lib/core/utils/edgeUtil.js +6 -0
  317. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +3 -4
  318. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +19 -5
  319. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  320. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  321. package/lib/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  322. package/lib/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  323. package/lib/networkTopo/createTopo.js +3 -0
  324. package/lib/networkTopo/services/link.js +2 -2
  325. package/lib/networkTopo/store/topoTreeMod.js +6 -8
  326. package/lib/style.js +1 -0
  327. package/lib/utils/htElementUtils.js +5 -0
  328. package/lib/utils/topoData.js +1 -0
  329. package/package.json +5 -4
  330. package/es/core/editor/components/Sidebar/views/CanvasPanel/ImagePanel.js +0 -4
  331. package/es/core/store/models/topoEdit.js +0 -39
  332. package/es/core/store/models/topoView.js +0 -36
  333. package/lib/core/editor/components/Sidebar/views/CanvasPanel/ImagePanel.js +0 -12
  334. package/lib/core/store/models/topoEdit.js +0 -51
  335. package/lib/core/store/models/topoView.js +0 -47
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports["default"] = void 0;
7
+
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+
10
+ var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
+
12
+ var _react = _interopRequireWildcard(require("react"));
13
+
14
+ var _globalTag = require("./globalTag");
15
+
16
+ var _excluded = ["Component"];
17
+
18
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
+
20
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
21
+
22
+ function GlobalTagStyleSetting(props) {
23
+ var topo = props.topo;
24
+ var Component = props.Component,
25
+ widgetProps = (0, _objectWithoutPropertiesLoose2["default"])(props, _excluded);
26
+ var values = (0, _globalTag.useValues)(topo);
27
+ var setStyle = (0, _react.useMemo)(function () {
28
+ return function (style) {
29
+ return (0, _globalTag.setGlobalTagStyle)(topo, style);
30
+ };
31
+ }, []);
32
+ return /*#__PURE__*/_react["default"].createElement(Component, (0, _extends2["default"])({
33
+ style: values,
34
+ setStyle: setStyle
35
+ }, widgetProps));
36
+ }
37
+
38
+ var _default = GlobalTagStyleSetting;
39
+ exports["default"] = _default;
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports.setGlobalTagStyle = void 0;
7
+ exports.setStyle = setStyle;
8
+ exports.useValues = useValues;
9
+
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+
12
+ var _colorUtil = require("../ElementTextStyleSetting/colorUtil");
13
+
14
+ var defaultStyle = {
15
+ color: '#AFB9C2',
16
+ fontFamily: '微软雅黑'
17
+ };
18
+
19
+ function useValues(topo) {
20
+ var displayConfigState = topo.store.useModelState('displayConfig');
21
+ var nodeLabelStyle = displayConfigState.nodeLabelStyle,
22
+ defaultEdgeLabelStyle = displayConfigState.defaultEdgeLabelStyle;
23
+ return (0, _extends2["default"])({
24
+ color: (nodeLabelStyle === null || nodeLabelStyle === void 0 ? void 0 : nodeLabelStyle.color) || defaultStyle.color,
25
+ fontFamily: (nodeLabelStyle === null || nodeLabelStyle === void 0 ? void 0 : nodeLabelStyle.fontFamily) || defaultStyle.fontFamily,
26
+ fontSize: nodeLabelStyle === null || nodeLabelStyle === void 0 ? void 0 : nodeLabelStyle.fontSize
27
+ }, (0, _colorUtil.parseBackground)(nodeLabelStyle === null || nodeLabelStyle === void 0 ? void 0 : nodeLabelStyle.background));
28
+ }
29
+
30
+ var setGlobalTagStyle = function setGlobalTagStyle(topo, styleData) {
31
+ var _topo$store$getModel = topo.store.getModel('displayConfig'),
32
+ displayConfigState = _topo$store$getModel[0],
33
+ displayConfigDispatchers = _topo$store$getModel[1];
34
+
35
+ var nodeLabelStyle = displayConfigState.nodeLabelStyle,
36
+ defaultEdgeLabelStyle = displayConfigState.defaultEdgeLabelStyle;
37
+ var style = buildStyle(styleData, nodeLabelStyle);
38
+ var globalNodeLabelStyle = (0, _extends2["default"])({}, nodeLabelStyle, style);
39
+ topo.getHtTopo().setGlobalNodeLabelStyle(globalNodeLabelStyle);
40
+ var globalEdgeTagStyle = globalNodeLabelStyle;
41
+ topo.getHtTopo().setGlobalEdgeTagStyle(globalEdgeTagStyle);
42
+ displayConfigDispatchers.update({
43
+ nodeLabelStyle: globalNodeLabelStyle,
44
+ defaultEdgeLabelStyle: globalEdgeTagStyle
45
+ });
46
+ };
47
+
48
+ exports.setGlobalTagStyle = setGlobalTagStyle;
49
+
50
+ function buildStyle(styleData, prevTagStyle) {
51
+ var style = {};
52
+
53
+ if ('color' in styleData) {
54
+ style.color = styleData.color.hex;
55
+ }
56
+
57
+ if ('background' in styleData || 'opacity' in styleData) {
58
+ var prevBackgroundStyle = (0, _colorUtil.parseBackground)(prevTagStyle === null || prevTagStyle === void 0 ? void 0 : prevTagStyle.background);
59
+ style.background = (0, _colorUtil.formatBackgroundRgbaColor)(prevBackgroundStyle, styleData);
60
+ }
61
+
62
+ return style;
63
+ }
64
+
65
+ function setStyle() {}
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports["default"] = void 0;
7
+
8
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
+
10
+ var _react = _interopRequireDefault(require("react"));
11
+
12
+ var _ElementTextStyleSetting = _interopRequireDefault(require("./ElementTextStyleSetting/ElementTextStyleSetting"));
13
+
14
+ var _GlobalTagStyleSetting = _interopRequireDefault(require("./GlobalTagStyleSetting/GlobalTagStyleSetting"));
15
+
16
+ function textStyleSettingRouter(Component, options) {
17
+ var names = (options === null || options === void 0 ? void 0 : options.names) || [];
18
+ return function TextStyleSettingButton(props) {
19
+ var topo = props.topo;
20
+ var selection = topo.selectionManager.useHtSelection();
21
+ var Widget = !selection.length ? _GlobalTagStyleSetting["default"] : _ElementTextStyleSetting["default"];
22
+ return /*#__PURE__*/_react["default"].createElement(Widget, (0, _extends2["default"])({
23
+ Component: Component
24
+ }, props, {
25
+ styleNames: names
26
+ }));
27
+ };
28
+ }
29
+
30
+ var _default = textStyleSettingRouter;
31
+ exports["default"] = _default;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports["default"] = void 0;
7
+
8
+ var _configProvider = _interopRequireDefault(require("@alifd/next/lib/config-provider"));
9
+
10
+ var _icon = _interopRequireDefault(require("@alifd/next/lib/icon"));
11
+
12
+ var _react = _interopRequireDefault(require("react"));
13
+
14
+ var _CloseablePanelModule = _interopRequireDefault(require("./CloseablePanel.module.scss"));
15
+
16
+ function CloseablePanel(props) {
17
+ var prefix = props.prefix,
18
+ title = props.title,
19
+ onClose = props.onClose,
20
+ children = props.children;
21
+ return /*#__PURE__*/_react["default"].createElement("div", {
22
+ className: _CloseablePanelModule["default"].panel
23
+ }, /*#__PURE__*/_react["default"].createElement("div", {
24
+ className: prefix + "drawer-header",
25
+ role: "heading",
26
+ "aria-level": "1"
27
+ }, title, /*#__PURE__*/_react["default"].createElement("a", {
28
+ role: "button",
29
+ "aria-label": "\u5173\u95ED",
30
+ className: prefix + "drawer-close",
31
+ onClick: onClose
32
+ }, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
33
+ type: "close",
34
+ className: "next-drawer-close-icon"
35
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
36
+ className: _CloseablePanelModule["default"].body
37
+ }, children));
38
+ }
39
+
40
+ CloseablePanel.defaultProps = {
41
+ prefix: 'next-'
42
+ };
43
+
44
+ var _default = _configProvider["default"].config(CloseablePanel);
45
+
46
+ exports["default"] = _default;
@@ -0,0 +1,9 @@
1
+ .panel {
2
+ height: 100%;
3
+ display: flex;
4
+ flex-direction: column;
5
+ background: #FFFFFF;
6
+ }
7
+ .body {
8
+ flex: 1;
9
+ }
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports["default"] = OpenPropertyPanelListener;
5
+
6
+ var _react = _interopRequireWildcard(require("react"));
7
+
8
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
9
+
10
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
11
+
12
+ function OpenPropertyPanelListener(props) {
13
+ var topo = props.topo;
14
+ var topoEditDispatchers = topo.store.useModelDispatchers('topoEdit'); // 双击打开
15
+
16
+ (0, _react.useEffect)(function () {
17
+ var notifier = topo.view.topoClient.notifier;
18
+ notifier.on('topo_element_double_click', handleDblClick);
19
+
20
+ function handleDblClick(element) {
21
+ topoEditDispatchers.update({
22
+ propertyPanelVisible: true
23
+ });
24
+ }
25
+
26
+ return function () {
27
+ notifier.off('topo_element_double_click', handleDblClick);
28
+ topoEditDispatchers.update({
29
+ propertyPanelVisible: false
30
+ });
31
+ };
32
+ }, []); // 未选择元素关闭
33
+
34
+ var selection = topo.selectionManager.useHtSelection();
35
+ (0, _react.useEffect)(function () {
36
+ if (!selection.length) {
37
+ topoEditDispatchers.update({
38
+ propertyPanelVisible: false
39
+ });
40
+ }
41
+ }, [selection]);
42
+ return props.children;
43
+ }
@@ -5,43 +5,67 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  exports.__esModule = true;
6
6
  exports["default"] = PropertyView;
7
7
 
8
+ var _classnames = _interopRequireDefault(require("classnames"));
9
+
8
10
  var _react = _interopRequireDefault(require("react"));
9
11
 
12
+ var _CloseablePanel = _interopRequireDefault(require("./CloseablePanel"));
13
+
14
+ var _OpenPropertyPanelListener = _interopRequireDefault(require("./OpenPropertyPanelListener"));
15
+
10
16
  var _Settings = _interopRequireDefault(require("./Settings"));
11
17
 
12
18
  var _SettingsModule = _interopRequireDefault(require("./Settings.module.scss"));
13
19
 
14
20
  function PropertyView(props) {
21
+ var _classNames;
22
+
15
23
  var topo = props.topo,
16
24
  editorProps = props.editorProps;
17
25
  var store = topo.store;
18
26
  var topoState = store.useModelState('topoMod');
27
+ var topoShowType = topoState.type,
28
+ graphLoaded = topoState.graphLoaded;
19
29
 
20
30
  var _store$useModelState = store.useModelState('selection'),
21
31
  selection = _store$useModelState.selection;
22
32
 
23
- var topoId = topoState.topoId,
24
- topoShowType = topoState.type;
33
+ var _topo$store$useModel = topo.store.useModel('topoEdit'),
34
+ topoEditState = _topo$store$useModel[0],
35
+ topoEditDispatchers = _topo$store$useModel[1];
36
+
37
+ var propertyPanelVisible = topoEditState.propertyPanelVisible;
25
38
 
26
- if (!topoId || !topoShowType) {
39
+ if (!graphLoaded) {
27
40
  return null;
28
41
  }
29
42
 
30
43
  var renderContent = function renderContent() {
31
- if (!topoId || !topoShowType) {
44
+ if (!propertyPanelVisible) {
32
45
  return null;
33
46
  }
34
47
 
35
- return /*#__PURE__*/_react["default"].createElement(_Settings["default"], {
48
+ return /*#__PURE__*/_react["default"].createElement(_OpenPropertyPanelListener["default"], {
49
+ topo: topo
50
+ }, /*#__PURE__*/_react["default"].createElement(_Settings["default"], {
36
51
  topo: topo,
37
52
  topoShowType: topoShowType,
38
53
  topoEditApi: topo.topoEdit,
39
54
  selection: selection,
40
55
  editorProps: editorProps
41
- });
56
+ }));
42
57
  };
43
58
 
44
59
  return /*#__PURE__*/_react["default"].createElement("div", {
45
- className: _SettingsModule["default"].settingsPanel
46
- }, renderContent());
60
+ className: (0, _classnames["default"])(_SettingsModule["default"].settingsPanel, (_classNames = {}, _classNames[_SettingsModule["default"].settingsPanelHide] = !propertyPanelVisible, _classNames))
61
+ }, /*#__PURE__*/_react["default"].createElement(_CloseablePanel["default"], {
62
+ title: "\u6570\u636E\u5C5E\u6027",
63
+ onClose: function onClose() {
64
+ topoEditDispatchers.update({
65
+ propertyPanelVisible: false
66
+ });
67
+ }
68
+ }, /*#__PURE__*/_react["default"].createElement(_OpenPropertyPanelListener["default"], {
69
+ topo: topo
70
+ }, renderContent())));
47
71
  }
@@ -53,17 +53,10 @@ function Settings(props) {
53
53
  topoEditApi = props.topoEditApi,
54
54
  selection = props.selection,
55
55
  editorProps = props.editorProps;
56
- var settingRuntimeState = (0, _useSettingRuntimeState["default"])(); // const selectionSize = selection.length;
57
- // const selectionIds = selection.map((item) => item.id).join(",");
58
- // useEffect(() => {
59
- // const selectionModel = topo.getSelectionModel();
60
- // console.info('selection change', selection)
61
- // }, [selection]);
62
- // TODO 待优化
56
+ var settingRuntimeState = (0, _useSettingRuntimeState["default"])(); // TODO 待优化
63
57
 
64
58
  var updateElementProperty = function updateElementProperty(name, value) {
65
59
  // const element = topo.getDataModel().getDataById(selection[0].id);
66
- var gv = topo.view.topoClient.getGraphView();
67
60
  var element = topo.getSelectionModel().getFirstData(); // console.info("updateElementProperty",topo.getSelectionModel().getSelection(), { selection, element, name, value });
68
61
 
69
62
  if (name.startsWith("attrObject.")) {
@@ -82,41 +75,8 @@ function Settings(props) {
82
75
  element.setImage(value);
83
76
  } else if (name === "layout") {
84
77
  // console.info("element----layout", element, value);
85
- var layouType = value.id === "toward" ? "" + value.id + value.options.subId : value.id; // console.info(
86
- // "element----layout",
87
- // topo.view.topoClient.htTopoClient,
88
- // layouType
89
- // );
90
-
91
- topo.getHtTopo().layoutInContainer(layouType); // let autoLayout = new ht.layout.AutoLayout(gv);
92
- // const layouType=value.id==='toward'?`${value.id}${value.options.subId}`:value.id;
93
- // gv.dm().sm().ss(element.getChildren());
94
- // autoLayout.layout(layouType, function () {
95
- // gv.dm().sm().ss(element);
96
- // });
97
- } else if (name === "groupAlign") {
98
- var selectList = [];
99
-
100
- if (selection.length === 1) {
101
- // 选择分层
102
- if (element instanceof ht.Grid) {
103
- // selectList = gv
104
- // .dm()
105
- // .toDatas((d) => d.getHost() === gv.dm().sm().ld())
106
- // .toArray();
107
- selectList = element.getChildren().toArray();
108
- } // 选择分区
109
-
110
-
111
- if (element instanceof ht.Group) {
112
- selectList = element.getChildren().toArray();
113
- }
114
- } else {
115
- selectList = topo.getSelectionModel().getSelection().toArray();
116
- } // console.info("element--selectList", element, selectList);
117
-
118
-
119
- topo.view.topoClient.htTopoClient.setAlignmentBySelectionNodes(value, selectList);
78
+ var layouType = value.id === "toward" ? "" + value.id + value.options.subId : value.id;
79
+ topo.getHtTopo().layoutInContainer(layouType);
120
80
  }
121
81
  };
122
82
 
@@ -135,7 +95,7 @@ function Settings(props) {
135
95
  });
136
96
  });
137
97
  return /*#__PURE__*/_react["default"].createElement("div", {
138
- className: _SettingsModule["default"].settings
98
+ className: _SettingsModule["default"].content
139
99
  }, /*#__PURE__*/_react["default"].createElement(PropertyView, {
140
100
  type: elementType,
141
101
  topo: topo,
@@ -7,14 +7,17 @@
7
7
  top: 0;
8
8
  right: 0;
9
9
  border-radius: 2px;
10
- //border: 1px solid #E6E7EB;
11
- //border-left: none;
10
+ border-left: 1px solid #E6E7EB;
12
11
 
13
12
  display: flex;
14
13
  flex-direction: column;
15
14
  overflow: hidden;
15
+ transition: width .1s linear;
16
16
 
17
- //margin-top: 47px;
17
+ &.settingsPanelHide {
18
+ width: 0;
19
+ border-left: none;
20
+ }
18
21
 
19
22
  :global {
20
23
  // 滚动条
@@ -72,9 +75,10 @@
72
75
  }
73
76
  }
74
77
 
75
- .settings {
78
+ .content {
76
79
  flex: 1;
77
80
  background: #FFFFFF;
78
81
  overflow: auto;
79
82
  // padding-bottom: 12px;
83
+
80
84
  }
@@ -6,7 +6,7 @@
6
6
  background: #EBECF0;
7
7
  margin-right: 3px;
8
8
  height: 16px;
9
-
9
+ width:1px;
10
10
  }
11
11
  }
12
12
 
@@ -16,7 +16,7 @@
16
16
  border-radius: 4px;
17
17
  border: none !important;
18
18
  color: #4D6277;
19
- padding-left: 6px;
19
+ padding-left: 2px;
20
20
  margin-right: 3px;
21
21
 
22
22
  &:active {
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports["default"] = void 0;
7
+
8
+ var _button = _interopRequireDefault(require("@alifd/next/lib/button"));
9
+
10
+ var _icon = _interopRequireDefault(require("@alifd/next/lib/icon"));
11
+
12
+ var _divider = _interopRequireDefault(require("@alifd/next/lib/divider"));
13
+
14
+ var _react = _interopRequireWildcard(require("react"));
15
+
16
+ var _AlignSettingModule = _interopRequireDefault(require("./AlignSetting.module.scss"));
17
+
18
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
+
20
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
21
+
22
+ var TREE_LAYOUT_OPTIONS = [{
23
+ value: 'left',
24
+ label: '左对齐',
25
+ icon: 'tuopu_zuoceduiqi'
26
+ }, {
27
+ value: 'center',
28
+ label: '水平居中',
29
+ icon: 'tuopu_shuipingjuzhongduiqi'
30
+ }, {
31
+ value: 'right',
32
+ label: '右对齐',
33
+ icon: 'tuopu_youceduiqi'
34
+ }, {
35
+ value: 'top',
36
+ label: '靠上对齐',
37
+ icon: 'tuopu_dingbuduiqi'
38
+ }, {
39
+ value: 'middle',
40
+ label: '垂直居中',
41
+ icon: 'tuopu_chuizhijuzhongduiqi'
42
+ }, {
43
+ value: 'bottom',
44
+ label: '靠下对齐',
45
+ icon: 'tuopu_dibuduiqi'
46
+ }, {
47
+ value: 'divide'
48
+ }, {
49
+ value: 'distributeHorizontal',
50
+ label: '横向分布',
51
+ icon: 'tuopu_shuipingdengjianjuduiqi'
52
+ }, {
53
+ value: 'distributeVertical',
54
+ label: '纵向分布',
55
+ icon: 'tuopu_chuizhidengjianjuduiqi'
56
+ }];
57
+
58
+ var AlignTypeList = function AlignTypeList(props) {
59
+ var _props$selected = props.selected,
60
+ selected = _props$selected === void 0 ? 'left' : _props$selected,
61
+ onChange = props.onChange,
62
+ distributionDisabled = props.distributionDisabled;
63
+
64
+ var _useState = (0, _react.useState)(selected),
65
+ value = _useState[0],
66
+ setValue = _useState[1];
67
+
68
+ var handleChange = function handleChange(data) {
69
+ // console.log("handleChange", data);
70
+ onChange && onChange(data.value);
71
+ setValue(data.value); // setValue(data)
72
+ };
73
+
74
+ return /*#__PURE__*/_react["default"].createElement("div", {
75
+ className: _AlignSettingModule["default"].AlignSetting
76
+ }, TREE_LAYOUT_OPTIONS.map(function (item, index, array) {
77
+ return item.value === 'divide' ? /*#__PURE__*/_react["default"].createElement(_divider["default"], {
78
+ key: index,
79
+ direction: "ver"
80
+ }) : /*#__PURE__*/_react["default"].createElement(_button["default"], {
81
+ key: index,
82
+ className: "" + _AlignSettingModule["default"].redioBtn,
83
+ text: true,
84
+ onClick: function onClick() {
85
+ handleChange(item);
86
+ },
87
+ title: item.label // eslint-disable-next-line no-unneeded-ternary
88
+ ,
89
+ disabled: (item.value === 'distributeHorizontal' || item.value === 'distributeVertical') && distributionDisabled
90
+ }, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
91
+ type: item.icon
92
+ }));
93
+ }));
94
+ };
95
+
96
+ var _default = AlignTypeList;
97
+ exports["default"] = _default;
@@ -3,91 +3,32 @@
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
4
 
5
5
  exports.__esModule = true;
6
- exports["default"] = void 0;
6
+ exports["default"] = AlignSetting;
7
7
 
8
- var _button = _interopRequireDefault(require("@alifd/next/lib/button"));
8
+ var _react = _interopRequireDefault(require("react"));
9
9
 
10
- var _icon = _interopRequireDefault(require("@alifd/next/lib/icon"));
10
+ var _htElementUtils = require("../../../../../../utils/htElementUtils");
11
11
 
12
- var _divider = _interopRequireDefault(require("@alifd/next/lib/divider"));
12
+ var _AlignTypeList = _interopRequireDefault(require("./AlignTypeList"));
13
13
 
14
- var _react = _interopRequireWildcard(require("react"));
14
+ function AlignSetting(props) {
15
+ var topo = props.topo,
16
+ distributionDisabled = props.distributionDisabled;
15
17
 
16
- var _AlignSettingModule = _interopRequireDefault(require("./AlignSetting.module.scss"));
18
+ var alignOnChange = function alignOnChange(type) {
19
+ topo.historyManager.beginTransaction();
20
+ var selection = topo.getHtTopo().getGraphView().getSelectionModel().getSelection().toArray();
21
+ var nodes = selection.filter(function (ele) {
22
+ return !(0, _htElementUtils.isLayer)(ele) && !(0, _htElementUtils.isEdge)(ele);
23
+ }); // console.info("element--selectList", element, selectList);
17
24
 
18
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
19
-
20
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
21
-
22
- var TREE_LAYOUT_OPTIONS = [{
23
- value: "left",
24
- label: "左对齐",
25
- icon: "tuopu_zuoceduiqi"
26
- }, {
27
- value: "center",
28
- label: "水平居中",
29
- icon: "tuopu_shuipingjuzhongduiqi"
30
- }, {
31
- value: "right",
32
- label: "右对齐",
33
- icon: "tuopu_youceduiqi"
34
- }, {
35
- value: "top",
36
- label: "靠上对齐",
37
- icon: "tuopu_dingbuduiqi"
38
- }, {
39
- value: "middle",
40
- label: "垂直居中",
41
- icon: "tuopu_chuizhijuzhongduiqi"
42
- }, {
43
- value: "bottom",
44
- label: "靠下对齐",
45
- icon: "tuopu_dibuduiqi"
46
- }, {
47
- value: "divide"
48
- }, {
49
- value: "distributeHorizontal",
50
- label: "横向分布",
51
- icon: "tuopu_shuipingdengjianjuduiqi"
52
- }, {
53
- value: "distributeVertical",
54
- label: "纵向分布",
55
- icon: "tuopu_chuizhidengjianjuduiqi"
56
- }];
57
-
58
- var AlignSetting = function AlignSetting(props) {
59
- var _props$selected = props.selected,
60
- selected = _props$selected === void 0 ? "left" : _props$selected,
61
- onChange = props.onChange;
62
-
63
- var _useState = (0, _react.useState)(selected),
64
- value = _useState[0],
65
- setValue = _useState[1];
66
-
67
- var handleChange = function handleChange(data) {
68
- // console.log("handleChange", data);
69
- onChange && onChange(data.value);
70
- setValue(data.value); // setValue(data)
25
+ topo.view.topoClient.htTopoClient.setAlignmentBySelectionNodes(type, nodes);
26
+ topo.historyManager.endTransaction();
71
27
  };
72
28
 
73
- return /*#__PURE__*/_react["default"].createElement("div", {
74
- className: _AlignSettingModule["default"].AlignSetting
75
- }, TREE_LAYOUT_OPTIONS.map(function (item, index, array) {
76
- return item.value === "divide" ? /*#__PURE__*/_react["default"].createElement(_divider["default"], {
77
- key: index,
78
- direction: "ver"
79
- }) : /*#__PURE__*/_react["default"].createElement(_button["default"], {
80
- key: index,
81
- className: "" + _AlignSettingModule["default"].redioBtn,
82
- onClick: function onClick() {
83
- handleChange(item);
84
- },
85
- title: item.label
86
- }, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
87
- type: item.icon
88
- }));
89
- }));
90
- };
91
-
92
- var _default = AlignSetting;
93
- exports["default"] = _default;
29
+ return /*#__PURE__*/_react["default"].createElement(_AlignTypeList["default"], {
30
+ onChange: alignOnChange,
31
+ selected: "left",
32
+ distributionDisabled: distributionDisabled
33
+ });
34
+ }