@riil-frontend/component-topology 6.0.0-alpha.9 → 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 (376) 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 +5 -19
  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 +11 -30
  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/buttons.js +2 -2
  44. package/es/core/editor/components/Toolbar/widgets/AddResourceButton.js +1 -1
  45. package/es/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  46. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +46 -2
  47. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +98 -6
  48. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +59 -25
  49. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +3 -5
  50. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +77 -0
  51. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +52 -5
  52. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +166 -16
  53. package/es/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  54. package/es/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +26 -12
  55. package/es/core/editor/components/Toolbar/widgets/FontSizeWidget.js +37 -12
  56. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +92 -39
  57. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +4 -2
  58. package/es/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +1 -2
  59. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +99 -0
  60. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  61. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +42 -0
  62. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  63. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +75 -0
  64. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  65. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +23 -0
  66. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +10 -0
  67. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  68. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  69. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  70. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  71. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +31 -0
  72. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  73. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +130 -15
  74. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +107 -23
  75. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  76. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +2 -2
  77. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +20 -7
  78. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +40 -35
  79. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  80. package/es/core/editor/components/Toolbar/widgets/WidgetBox.js +10 -4
  81. package/es/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  82. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  83. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  84. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  85. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +21 -7
  86. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +52 -0
  87. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +67 -0
  88. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +41 -0
  89. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +65 -0
  90. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +65 -0
  91. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +14 -0
  92. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +73 -0
  93. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +69 -0
  94. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +37 -0
  95. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +124 -0
  96. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +31 -0
  97. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +98 -0
  98. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +20 -0
  99. package/es/core/editor/components/plugins/AddElementThemePlugin.js +11 -0
  100. package/es/core/editor/components/settings/CloseablePanel.js +33 -0
  101. package/es/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  102. package/es/core/editor/components/settings/PropertyView.js +50 -11
  103. package/es/core/editor/components/settings/Settings.js +37 -122
  104. package/es/core/editor/components/settings/Settings.module.scss +7 -11
  105. package/es/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  106. package/es/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +80 -0
  107. package/es/core/editor/components/settings/common/AlignSetting/index.js +20 -72
  108. package/es/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  109. package/es/core/editor/components/settings/common/LineType/index.js +11 -102
  110. package/es/core/editor/components/settings/common/NameInput.js +24 -0
  111. package/es/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +21 -18
  112. package/es/core/editor/components/settings/common/text/fontStyleUtil.js +21 -19
  113. package/es/core/editor/components/settings/core/PropertyViewManager.js +81 -0
  114. package/es/core/editor/components/settings/core/edgePropertyViewAdapter.js +22 -0
  115. package/es/core/editor/components/settings/core/getPropertyViewType.js +34 -0
  116. package/es/core/editor/components/settings/core/updateElementProperty.js +21 -0
  117. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  118. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +58 -0
  119. package/es/core/editor/components/settings/propertyViews/box/NameInput.js +5 -4
  120. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +12 -3
  121. package/es/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +7 -8
  122. package/es/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +9 -23
  123. package/es/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +10 -0
  124. package/es/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  125. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +13 -21
  126. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  127. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +28 -0
  128. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +75 -0
  129. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +9 -15
  130. package/es/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +8 -6
  131. package/es/core/editor/components/settings/propertyViews/index.js +4 -6
  132. package/es/core/editor/components/settings/propertyViews/layer/BasicSetting.js +57 -0
  133. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +11 -17
  134. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  135. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +27 -0
  136. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -7
  137. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  138. package/es/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -32
  139. package/es/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +53 -0
  140. package/es/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +49 -0
  141. package/es/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +5 -4
  142. package/es/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  143. package/es/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  144. package/es/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  145. package/es/core/editor/components/titlebar/TopoEditorTitleBar.js +8 -4
  146. package/es/core/editor/config/themes.js +105 -0
  147. package/es/core/editor/hooks/useKeyboardShortcut.js +39 -0
  148. package/es/core/editor/hooks/useNewElementTheme.js +46 -0
  149. package/es/core/editor/store/topoEdit.js +44 -37
  150. package/es/core/editor/utils/edgeTypeStyleUtil.js +34 -11
  151. package/es/core/editor/utils/textStyleUtil.js +0 -0
  152. package/es/core/editor/utils/themeUtil.js +32 -0
  153. package/es/core/hooks/useCanvasTheme.js +54 -0
  154. package/es/core/hooks/useManageStatus.js +1 -9
  155. package/es/core/hooks/usePolling.js +2 -5
  156. package/es/core/hooks/useTopoEdit.js +15 -8
  157. package/es/core/models/Alarm.js +2 -2
  158. package/es/core/models/AttributeMetricDisplay.js +4 -0
  159. package/es/core/models/HistoryManager.js +13 -8
  160. package/es/core/models/{SelectionManager.js → SelectionModel.js} +55 -22
  161. package/es/core/models/TopoApp.js +6 -5
  162. package/es/core/models/selection/ignoreList.js +1 -0
  163. package/es/core/models/utils/linkUtils.js +5 -6
  164. package/es/core/store/models/customIcon.js +1 -3
  165. package/es/core/store/models/selection.js +2 -1
  166. package/es/core/store/models/topoBizMod.js +0 -3
  167. package/es/core/store/models/topoConfig.js +10 -12
  168. package/es/core/store/models/topoMod.js +26 -28
  169. package/es/core/utils/edgeUtil.js +6 -0
  170. package/es/core/utils/showGraphManageStatusUtil.js +7 -1
  171. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  172. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  173. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  174. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  175. package/es/core/viewer/components/plugins/ViewerPlugin.js +10 -4
  176. package/es/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  177. package/es/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  178. package/es/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +2 -1
  179. package/es/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +39 -6
  180. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -16
  181. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +37 -0
  182. package/es/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  183. package/es/networkTopo/components/editor/useEditorProps.js +1 -3
  184. package/es/networkTopo/createTopo.js +2 -0
  185. package/es/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  186. package/es/networkTopo/services/link.js +2 -2
  187. package/es/networkTopo/store/topoTreeMod.js +6 -7
  188. package/es/style.js +28 -27
  189. package/es/utils/htElementUtils.js +3 -0
  190. package/es/utils/topoData.js +1 -0
  191. package/lib/components/ColorPanel/components/ColorBlock/index.js +47 -0
  192. package/lib/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  193. package/lib/components/ColorPanel/components/FontColorRange/index.js +49 -0
  194. package/lib/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  195. package/lib/components/ColorPanel/index.js +278 -0
  196. package/lib/components/ColorPanel/index.module.scss +35 -0
  197. package/lib/components/VerticalIconTab/VerticalIconTab.js +14 -1
  198. package/lib/components/VerticalIconTab/VerticalIconTab.module.scss +2 -0
  199. package/lib/components/collapse/Collapse.js +28 -3
  200. package/lib/components/collapse/Collapse.module.scss +24 -0
  201. package/lib/components/collapse/index.js +11 -0
  202. package/lib/core/common/hooks/useHtElements.js +27 -0
  203. package/lib/core/common/icons/icon.js +47 -0
  204. package/lib/core/common/icons/useIcons.js +7 -18
  205. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  206. package/lib/core/components/AlarmListPanel/components/index.module.scss +5 -5
  207. package/lib/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  208. package/lib/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +10 -3
  209. package/lib/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +147 -0
  210. package/lib/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  211. package/lib/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +84 -22
  212. package/lib/core/components/TopoView/GraphViewPanel.js +32 -0
  213. package/lib/core/components/TopoView/editor.module.scss +1 -0
  214. package/lib/core/components/TopoView/topoView.js +36 -67
  215. package/lib/core/components/titlebar/TitleBar.module.scss +1 -1
  216. package/lib/core/editor/components/EditorPlugin.js +26 -2
  217. package/lib/core/editor/components/Sidebar/Sidebar.js +28 -6
  218. package/lib/core/editor/components/Sidebar/panes.js +10 -5
  219. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +12 -31
  220. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useCanvasThemeConfig.js +123 -0
  221. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useUpdateHtTopoDefaultTagStyle.js +37 -0
  222. package/lib/core/editor/components/Sidebar/views/CanvasPanel/utils/elementThemeUtil.js +1 -0
  223. package/lib/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +1 -1
  224. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +13 -1
  225. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +13 -1
  226. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +3 -3
  227. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +36 -12
  228. package/lib/core/editor/components/Toolbar/buttons.js +2 -2
  229. package/lib/core/editor/components/Toolbar/widgets/AddResourceButton.js +1 -1
  230. package/lib/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  231. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +48 -2
  232. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +100 -6
  233. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +58 -24
  234. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +3 -3
  235. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +83 -0
  236. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +53 -4
  237. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +172 -16
  238. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  239. package/lib/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +27 -11
  240. package/lib/core/editor/components/Toolbar/widgets/FontSizeWidget.js +38 -11
  241. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +96 -39
  242. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +4 -2
  243. package/lib/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +1 -2
  244. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +116 -0
  245. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  246. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +55 -0
  247. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  248. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +93 -0
  249. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  250. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +32 -0
  251. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +22 -0
  252. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  253. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  254. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  255. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  256. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +44 -0
  257. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  258. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +135 -16
  259. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +110 -23
  260. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  261. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +2 -2
  262. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +21 -7
  263. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +40 -34
  264. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  265. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.js +13 -4
  266. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  267. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  268. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  269. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  270. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +22 -7
  271. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +66 -0
  272. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +82 -0
  273. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +58 -0
  274. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +86 -0
  275. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +88 -0
  276. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +28 -0
  277. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +90 -0
  278. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +90 -0
  279. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +54 -0
  280. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +141 -0
  281. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +46 -0
  282. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +111 -0
  283. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +31 -0
  284. package/lib/core/editor/components/plugins/AddElementThemePlugin.js +20 -0
  285. package/lib/core/editor/components/settings/CloseablePanel.js +46 -0
  286. package/lib/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  287. package/lib/core/editor/components/settings/PropertyView.js +59 -12
  288. package/lib/core/editor/components/settings/Settings.js +40 -122
  289. package/lib/core/editor/components/settings/Settings.module.scss +7 -11
  290. package/lib/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  291. package/lib/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +97 -0
  292. package/lib/core/editor/components/settings/common/AlignSetting/index.js +21 -80
  293. package/lib/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  294. package/lib/core/editor/components/settings/common/LineType/index.js +11 -109
  295. package/lib/core/editor/components/settings/common/NameInput.js +38 -0
  296. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +21 -19
  297. package/lib/core/editor/components/settings/common/text/fontStyleUtil.js +25 -20
  298. package/lib/core/editor/components/settings/core/PropertyViewManager.js +91 -0
  299. package/lib/core/editor/components/settings/core/edgePropertyViewAdapter.js +33 -0
  300. package/lib/core/editor/components/settings/core/getPropertyViewType.js +40 -0
  301. package/lib/core/editor/components/settings/core/updateElementProperty.js +27 -0
  302. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  303. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +76 -0
  304. package/lib/core/editor/components/settings/propertyViews/box/NameInput.js +6 -5
  305. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +15 -3
  306. package/lib/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +9 -12
  307. package/lib/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +7 -23
  308. package/lib/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +19 -0
  309. package/lib/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  310. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +14 -25
  311. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  312. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +43 -0
  313. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +98 -0
  314. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +8 -14
  315. package/lib/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +9 -7
  316. package/lib/core/editor/components/settings/propertyViews/index.js +4 -9
  317. package/lib/core/editor/components/settings/propertyViews/layer/BasicSetting.js +75 -0
  318. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +12 -20
  319. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  320. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +40 -0
  321. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +4 -6
  322. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  323. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -35
  324. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +68 -0
  325. package/lib/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +64 -0
  326. package/lib/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +6 -5
  327. package/lib/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  328. package/lib/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  329. package/lib/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  330. package/lib/core/editor/components/titlebar/TopoEditorTitleBar.js +9 -1
  331. package/lib/core/editor/config/themes.js +114 -0
  332. package/lib/core/editor/hooks/useKeyboardShortcut.js +49 -0
  333. package/lib/core/editor/hooks/useNewElementTheme.js +57 -0
  334. package/lib/core/editor/store/topoEdit.js +46 -40
  335. package/lib/core/editor/utils/edgeTypeStyleUtil.js +38 -11
  336. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  337. package/lib/core/editor/utils/themeUtil.js +39 -0
  338. package/lib/core/hooks/useCanvasTheme.js +68 -0
  339. package/lib/core/hooks/useManageStatus.js +1 -9
  340. package/lib/core/hooks/usePolling.js +2 -5
  341. package/lib/core/hooks/useTopoEdit.js +16 -8
  342. package/lib/core/models/Alarm.js +2 -2
  343. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  344. package/lib/core/models/HistoryManager.js +13 -8
  345. package/lib/core/models/{SelectionManager.js → SelectionModel.js} +57 -22
  346. package/lib/core/models/TopoApp.js +7 -5
  347. package/lib/core/models/selection/ignoreList.js +6 -0
  348. package/lib/core/models/utils/linkUtils.js +5 -6
  349. package/lib/core/store/models/customIcon.js +1 -3
  350. package/lib/core/store/models/selection.js +2 -1
  351. package/lib/core/store/models/topoBizMod.js +0 -3
  352. package/lib/core/store/models/topoConfig.js +9 -18
  353. package/lib/core/store/models/topoMod.js +27 -29
  354. package/lib/core/utils/edgeUtil.js +6 -0
  355. package/lib/core/utils/showGraphManageStatusUtil.js +7 -1
  356. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  357. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  358. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  359. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  360. package/lib/core/viewer/components/plugins/ViewerPlugin.js +11 -3
  361. package/lib/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  362. package/lib/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  363. package/lib/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +1 -0
  364. package/lib/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +45 -7
  365. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -18
  366. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +50 -0
  367. package/lib/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  368. package/lib/networkTopo/components/editor/useEditorProps.js +1 -4
  369. package/lib/networkTopo/createTopo.js +3 -0
  370. package/lib/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  371. package/lib/networkTopo/services/link.js +2 -2
  372. package/lib/networkTopo/store/topoTreeMod.js +6 -8
  373. package/lib/style.js +28 -27
  374. package/lib/utils/htElementUtils.js +5 -0
  375. package/lib/utils/topoData.js +1 -0
  376. 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,7 +1,7 @@
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;
@@ -10,16 +10,17 @@ var START_TYPE_OPTIONS = [{
10
10
  value: 'nil',
11
11
  label: '无',
12
12
  icon: 'topo_startEndPoint_icon_nothing'
13
- }, {
14
- value: 'hollowCrcial',
15
- label: '空心圆',
16
- icon: 'topo_startPoint_icon_hollow_cricle'
17
- }, {
18
- value: 'solidCricle',
13
+ }, // {
14
+ // value: 'sourceNoneCircle',
15
+ // label: '空心圆',
16
+ // icon: 'topo_startPoint_icon_hollow_cricle',
17
+ // },
18
+ {
19
+ value: 'sourceSolidCircle',
19
20
  label: '实心圆',
20
21
  icon: 'topo_startPoint_icon_solid_cricle'
21
22
  }, {
22
- value: 'arrowPoint',
23
+ value: 'sourceArrow',
23
24
  label: '箭头',
24
25
  icon: 'topo_startPoint_icon_arrow'
25
26
  }];
@@ -27,16 +28,17 @@ var END_TYPE_OPTIONS = [{
27
28
  value: 'nil',
28
29
  label: '无',
29
30
  icon: 'topo_startEndPoint_icon_nothing'
30
- }, {
31
- value: 'hollowCrcial',
32
- label: '空心圆',
33
- icon: 'topo_endPoint_icon_hollow_cricle'
34
- }, {
35
- value: 'solidCricle',
31
+ }, // {
32
+ // value: 'targetNoneCircle',
33
+ // label: '空心圆',
34
+ // icon: 'topo_endPoint_icon_hollow_cricle',
35
+ // },
36
+ {
37
+ value: 'targetSolidCircle',
36
38
  label: '实心圆',
37
39
  icon: 'topo_endPoint_icon_solid_cricle'
38
40
  }, {
39
- value: 'arrowPoint',
41
+ value: 'targetArrow',
40
42
  label: '箭头',
41
43
  icon: 'topo_endPoint_icon_arrow'
42
44
  }];
@@ -58,16 +60,43 @@ var LINE_MOLD_OPTIONS = [{
58
60
  icon: 'topo_lineMold_dotted_two'
59
61
  }];
60
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
+
61
93
  function EdgeType(props) {
62
- var _onChange = props.onChange;
94
+ var selection = props.selection,
95
+ _onChange = props.onChange;
63
96
 
64
97
  var field = _Field.useField({
65
98
  autoUnmount: false,
66
- values: {
67
- startPoint: 'nil',
68
- endPoint: 'nil',
69
- type: 'solidLine'
70
- },
99
+ values: getValuesBySelection(selection),
71
100
  onChange: function onChange(name, value) {
72
101
  if (['startPoint', 'endPoint'].includes(name) && value === 'nil') {
73
102
  _onChange(name, null);
@@ -77,6 +106,9 @@ function EdgeType(props) {
77
106
  }
78
107
  });
79
108
 
109
+ useEffect(function () {
110
+ field.setValues(getValuesBySelection(selection));
111
+ }, [selection]);
80
112
  return /*#__PURE__*/React.createElement("div", {
81
113
  className: styles.lineBox
82
114
  }, /*#__PURE__*/React.createElement(_Form, {
@@ -89,6 +121,7 @@ function EdgeType(props) {
89
121
  label: "\u8D77\u70B9"
90
122
  }, /*#__PURE__*/React.createElement(_Select, {
91
123
  name: "startPoint",
124
+ placeholder: " ",
92
125
  popupProps: {
93
126
  container: function container(trigger) {
94
127
  return trigger.parentNode;
@@ -109,6 +142,7 @@ function EdgeType(props) {
109
142
  label: "\u7EC8\u70B9"
110
143
  }, /*#__PURE__*/React.createElement(_Select, {
111
144
  name: "endPoint",
145
+ placeholder: " ",
112
146
  popupProps: {
113
147
  container: function container(trigger) {
114
148
  return trigger.parentNode;
@@ -128,18 +162,18 @@ function EdgeType(props) {
128
162
  }))), /*#__PURE__*/React.createElement(FormItem, {
129
163
  label: "\u7C7B\u578B"
130
164
  }, /*#__PURE__*/React.createElement(_Select, {
131
- name: "type",
165
+ name: "lineMold",
132
166
  popupProps: {
133
167
  container: function container(trigger) {
134
168
  return trigger.parentNode;
135
169
  }
136
170
  },
137
- placeholder: ""
171
+ placeholder: " "
138
172
  }, LINE_MOLD_OPTIONS.map(function (item, index) {
139
173
  return /*#__PURE__*/React.createElement(Option, {
140
174
  value: item.value,
141
- key: index,
142
- title: item.label,
175
+ key: index // title={item.label}
176
+ ,
143
177
  onchange: _onChange
144
178
  }, /*#__PURE__*/React.createElement("img", {
145
179
  src: "/img/topo/editor/lineType/" + item.icon + ".svg",
@@ -13,7 +13,7 @@ var LINE_TYPE_OPTIONS = [{
13
13
  icon: 'topo_linear_icon_narrow_straightline'
14
14
  }, {
15
15
  value: 'h.v',
16
- label: '纵向折线',
16
+ label: '折线',
17
17
  icon: 'topo_linear_icon_vertical_foldline'
18
18
  }, {
19
19
  value: 'ortho',
@@ -24,8 +24,7 @@ var LINE_TYPE_OPTIONS = [{
24
24
  label: '双弧线',
25
25
  icon: 'topo_linear_icon_arcline'
26
26
  }];
27
-
28
- function LineType(props) {
27
+ var LineType = /*#__PURE__*/React.forwardRef(function (props, ref) {
29
28
  var onChange = props.onChange;
30
29
 
31
30
  function lineButton(item) {
@@ -50,6 +49,5 @@ function LineType(props) {
50
49
  key: index
51
50
  }, item.label);
52
51
  }));
53
- }
54
-
52
+ });
55
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
  }
@@ -1,15 +1,121 @@
1
+ import _asyncToGenerator from "@babel/runtime/helpers/asyncToGenerator";
2
+ import _regeneratorRuntime from "@babel/runtime/regenerator";
3
+
4
+ /* eslint-disable jsx-a11y/alt-text */
1
5
  import React, { useState } from 'react';
2
6
  import DropdownButton from "./components/DropdownButton";
3
7
  import WidgetBox from "./WidgetBox";
8
+ import ColorPanel from "../../../../../components/ColorPanel";
9
+ import FontColorRange from "../../../../../components/ColorPanel/components/FontColorRange";
10
+ import styles from "./FontColorButton.module.scss";
11
+ import textStyleSettingRouter from "./components/textStyleSetting/textStyleSettingRouter.js";
4
12
 
5
- function FontFamilySelect(props) {
6
- var value = props.value,
7
- onChange = props.onChange;
13
+ function FontColorDropdown(props) {
14
+ var color = props.color,
15
+ onChange = props.onChange,
16
+ topo = props.topo,
17
+ opacity = props.opacity,
18
+ background = props.background,
19
+ setStyle = props.setStyle;
8
20
 
9
21
  var _useState = useState(false),
10
22
  disabled = _useState[0],
11
23
  setDisabled = _useState[1];
12
24
 
25
+ var backOpacityChange = function backOpacityChange(value) {
26
+ topo.historyManager.beginTransaction();
27
+ onChange({
28
+ opacity: Math.round(value / 100)
29
+ });
30
+ topo.historyManager.endTransaction();
31
+ };
32
+
33
+ var colorChang = /*#__PURE__*/function () {
34
+ var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee(value, type) {
35
+ return _regeneratorRuntime.wrap(function _callee$(_context) {
36
+ while (1) {
37
+ switch (_context.prev = _context.next) {
38
+ case 0:
39
+ if (!(type === 'select')) {
40
+ _context.next = 7;
41
+ break;
42
+ }
43
+
44
+ topo.historyManager.beginTransaction();
45
+ _context.next = 4;
46
+ return setStyle({
47
+ color: value
48
+ });
49
+
50
+ case 4:
51
+ topo.historyManager.endTransaction();
52
+ _context.next = 8;
53
+ break;
54
+
55
+ case 7:
56
+ setStyle({
57
+ background: value
58
+ });
59
+
60
+ case 8:
61
+ case "end":
62
+ return _context.stop();
63
+ }
64
+ }
65
+ }, _callee);
66
+ }));
67
+
68
+ return function colorChang(_x, _x2) {
69
+ return _ref.apply(this, arguments);
70
+ };
71
+ }();
72
+
73
+ var backgroundChang = /*#__PURE__*/function () {
74
+ var _ref2 = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime.mark(function _callee2(value, type) {
75
+ return _regeneratorRuntime.wrap(function _callee2$(_context2) {
76
+ while (1) {
77
+ switch (_context2.prev = _context2.next) {
78
+ case 0:
79
+ if (!(type === 'select')) {
80
+ _context2.next = 7;
81
+ break;
82
+ }
83
+
84
+ topo.historyManager.beginTransaction();
85
+ _context2.next = 4;
86
+ return setStyle({
87
+ background: value
88
+ });
89
+
90
+ case 4:
91
+ topo.historyManager.endTransaction();
92
+ _context2.next = 8;
93
+ break;
94
+
95
+ case 7:
96
+ setStyle({
97
+ background: value
98
+ });
99
+
100
+ case 8:
101
+ case "end":
102
+ return _context2.stop();
103
+ }
104
+ }
105
+ }, _callee2);
106
+ }));
107
+
108
+ return function backgroundChang(_x3, _x4) {
109
+ return _ref2.apply(this, arguments);
110
+ };
111
+ }();
112
+
113
+ var onFocus = function onFocus() {// topo.historyManager.beginTransaction();
114
+ };
115
+
116
+ var onBlur = function onBlur() {// topo.historyManager.endTransaction();
117
+ };
118
+
13
119
  var icon = disabled ? /*#__PURE__*/React.createElement("img", {
14
120
  src: "/img/topo/editor/toolbar/\u6587\u5B57\u989C\u8272\u53CA\u586B\u5145/Disable.svg",
15
121
  alt: ""
@@ -19,26 +125,70 @@ function FontFamilySelect(props) {
19
125
  });
20
126
  return /*#__PURE__*/React.createElement(DropdownButton, {
21
127
  disabled: disabled,
22
- trigger: icon,
23
- onChange: onChange
24
- }, "xxxx");
128
+ trigger: icon
129
+ }, /*#__PURE__*/React.createElement("div", {
130
+ className: styles.content
131
+ }, /*#__PURE__*/React.createElement("div", {
132
+ className: styles.fontColor
133
+ }, /*#__PURE__*/React.createElement("span", null, "\u5B57\u4F53\u989C\u8272"), /*#__PURE__*/React.createElement("div", {
134
+ style: {
135
+ marginTop: '10px',
136
+ marginLeft: '-4px'
137
+ }
138
+ }, /*#__PURE__*/React.createElement(ColorPanel, {
139
+ value: color,
140
+ onChange: colorChang,
141
+ onPickerFocus: onFocus,
142
+ onPickerBlur: onBlur
143
+ }))), /*#__PURE__*/React.createElement("div", {
144
+ className: styles.backgroundColor
145
+ }, /*#__PURE__*/React.createElement("span", null, "\u80CC\u666F\u586B\u5145"), /*#__PURE__*/React.createElement("div", {
146
+ className: styles.backOpacity
147
+ }, /*#__PURE__*/React.createElement("img", {
148
+ src: "/img/topo/editor/toolbar/\u6587\u5B57\u989C\u8272\u53CA\u586B\u5145/\u80CC\u666F\u586B\u5145.svg"
149
+ }), /*#__PURE__*/React.createElement(FontColorRange, {
150
+ max: 100,
151
+ min: 0,
152
+ unit: "%",
153
+ list: [0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100],
154
+ onChange: backOpacityChange,
155
+ defaultValue: opacity === undefined ? opacity : Math.round(opacity * 100)
156
+ })), /*#__PURE__*/React.createElement("div", {
157
+ style: {
158
+ marginTop: '10px',
159
+ marginLeft: '-4px',
160
+ marginBottom: '3px'
161
+ }
162
+ }, /*#__PURE__*/React.createElement(ColorPanel, {
163
+ showClear: true,
164
+ value: background,
165
+ onChange: backgroundChang,
166
+ onPickerFocus: onFocus,
167
+ onPickerBlur: onBlur
168
+ })))));
25
169
  }
26
170
 
27
171
  function FontColorButton(props) {
28
- var showLabel = props.showLabel;
29
-
30
- var _useState2 = useState('微软雅黑'),
31
- value = _useState2[0],
32
- setValue = _useState2[1];
33
-
172
+ var showLabel = props.showLabel,
173
+ topo = props.topo,
174
+ style = props.style,
175
+ setStyle = props.setStyle;
34
176
  return /*#__PURE__*/React.createElement(WidgetBox, {
35
177
  label: "\u6587\u5B57\u989C\u8272",
36
178
  tooltip: "\u6587\u5B57\u989C\u8272",
37
179
  showLabel: showLabel
38
- }, /*#__PURE__*/React.createElement(FontFamilySelect, {
39
- value: value,
40
- onChange: setValue
180
+ }, /*#__PURE__*/React.createElement(FontColorDropdown, {
181
+ color: style.color,
182
+ background: style.background,
183
+ opacity: style.opacity,
184
+ setStyle: setStyle,
185
+ onChange: function onChange(val) {
186
+ setStyle(val);
187
+ },
188
+ topo: topo
41
189
  }));
42
190
  }
43
191
 
44
- export default FontColorButton;
192
+ export default textStyleSettingRouter(FontColorButton, {
193
+ names: ['color', 'background', 'opacity']
194
+ });