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

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 (327) 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 +22 -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 +72 -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 +21 -18
  46. package/es/core/editor/components/Toolbar/widgets/AddResourceButton.js +8 -7
  47. package/es/core/editor/components/Toolbar/widgets/CanvasMoveWidget.js +13 -2
  48. package/es/core/editor/components/Toolbar/widgets/CanvasSelectWidget.js +11 -2
  49. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +46 -2
  50. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +96 -5
  51. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +184 -3
  52. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +44 -0
  53. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +53 -0
  54. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.module.scss +31 -0
  55. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +77 -0
  56. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +74 -6
  57. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +78 -14
  58. package/es/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +43 -0
  59. package/es/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +25 -11
  60. package/es/core/editor/components/Toolbar/widgets/FontSizeWidget.js +29 -13
  61. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +100 -39
  62. package/es/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +3 -2
  63. package/es/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +5 -4
  64. package/es/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +109 -0
  65. package/es/core/editor/components/Toolbar/widgets/IconSelect/constant.js +64 -0
  66. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.js +101 -0
  67. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  68. package/es/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +49 -0
  69. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +99 -0
  70. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  71. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +42 -0
  72. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  73. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +75 -0
  74. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  75. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +23 -0
  76. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +10 -0
  77. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  78. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  79. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  80. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  81. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +31 -0
  82. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  83. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +128 -15
  84. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +95 -23
  85. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  86. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +15 -5
  87. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +41 -7
  88. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +98 -13
  89. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  90. package/es/core/editor/components/Toolbar/widgets/WidgetBox.js +15 -22
  91. package/es/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +11 -1
  92. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.js +5 -3
  93. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +3 -0
  94. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +21 -3
  95. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +16 -6
  96. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +49 -0
  97. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +61 -0
  98. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +30 -0
  99. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +18 -0
  100. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +41 -0
  101. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +14 -0
  102. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +47 -0
  103. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +25 -0
  104. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +32 -0
  105. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +71 -0
  106. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +25 -0
  107. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +38 -0
  108. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +20 -0
  109. package/es/core/editor/components/settings/CloseablePanel.js +33 -0
  110. package/es/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  111. package/es/core/editor/components/settings/OpenPropertyPanelListener.js +33 -0
  112. package/es/core/editor/components/settings/PropertyView.js +29 -8
  113. package/es/core/editor/components/settings/Settings.js +4 -44
  114. package/es/core/editor/components/settings/Settings.module.scss +8 -4
  115. package/es/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +2 -2
  116. package/es/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +80 -0
  117. package/es/core/editor/components/settings/common/AlignSetting/index.js +20 -72
  118. package/es/core/editor/components/settings/common/LineType/index.js +12 -119
  119. package/es/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +3 -3
  120. package/es/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +31 -21
  121. package/es/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +7 -6
  122. package/es/core/editor/components/settings/common/text/fontStyleUtil.js +11 -19
  123. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  124. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +0 -8
  125. package/es/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +8 -9
  126. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -42
  127. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  128. package/es/core/editor/components/settings/propertyViews/text/TextPropertyView.js +1 -1
  129. package/es/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +9 -6
  130. package/es/core/editor/components/titlebar/TopoEditorTitleBar.js +8 -4
  131. package/es/core/editor/hooks/useKeyboardShortcut.js +42 -0
  132. package/es/core/{store/models → editor/store}/background.js +0 -0
  133. package/es/core/{store/models → editor/store}/historyManager.js +0 -0
  134. package/es/core/editor/store/topoEdit.js +49 -0
  135. package/es/core/editor/utils/edgeTypeStyleUtil.js +96 -0
  136. package/es/core/editor/utils/textStyleUtil.js +0 -0
  137. package/es/core/hooks/useCanvasTheme.js +49 -0
  138. package/es/core/hooks/usePolling.js +2 -5
  139. package/es/core/hooks/useTopoEdit.js +38 -58
  140. package/es/core/models/Alarm.js +2 -2
  141. package/es/core/models/AttributeMetricDisplay.js +4 -0
  142. package/es/core/models/HistoryManager.js +10 -3
  143. package/es/core/models/SelectionManager.js +16 -1
  144. package/es/core/models/TopoApp.js +1 -1
  145. package/es/core/models/TopoGraphView.js +8 -2
  146. package/es/core/models/utils/linkUtils.js +1 -1
  147. package/es/core/store/coreModels.js +6 -7
  148. package/es/core/store/models/selection.js +2 -1
  149. package/es/core/store/models/topoBizMod.js +0 -3
  150. package/es/core/store/models/topoMod.js +26 -28
  151. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +3 -4
  152. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +19 -5
  153. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  154. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  155. package/es/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  156. package/es/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  157. package/es/networkTopo/createTopo.js +2 -0
  158. package/es/networkTopo/services/link.js +2 -2
  159. package/es/networkTopo/store/topoTreeMod.js +6 -7
  160. package/es/style.js +1 -0
  161. package/es/utils/htElementUtils.js +3 -0
  162. package/es/utils/topoData.js +1 -0
  163. package/lib/components/ColorPanel/components/ColorBlock/index.js +47 -0
  164. package/lib/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  165. package/lib/components/ColorPanel/components/FontColorRange/index.js +49 -0
  166. package/lib/components/ColorPanel/components/FontColorRange/index.module.scss +22 -0
  167. package/lib/components/ColorPanel/index.js +255 -0
  168. package/lib/components/ColorPanel/index.module.scss +35 -0
  169. package/lib/components/VerticalIconTab/VerticalIconTab.module.scss +5 -1
  170. package/lib/components/collapse/Collapse.js +28 -3
  171. package/lib/components/collapse/Collapse.module.scss +24 -0
  172. package/lib/components/collapse/index.js +11 -0
  173. package/lib/core/common/hooks/useHtElements.js +27 -0
  174. package/lib/core/common/icons/icon.js +48 -0
  175. package/lib/core/common/icons/useIcons.js +10 -15
  176. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  177. package/lib/core/components/AlarmListPanel/components/index.module.scss +5 -5
  178. package/lib/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  179. package/lib/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +10 -3
  180. package/lib/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +147 -0
  181. package/lib/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  182. package/lib/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +76 -19
  183. package/lib/core/components/TopoView/GraphViewPanel.js +31 -0
  184. package/lib/core/components/TopoView/editor.module.scss +1 -0
  185. package/lib/core/components/TopoView/topoView.js +32 -50
  186. package/lib/core/components/titlebar/TitleBar.module.scss +1 -1
  187. package/lib/core/editor/components/EditorPlugin.js +3 -1
  188. package/lib/core/editor/components/Sidebar/Sidebar.js +40 -53
  189. package/lib/core/editor/components/Sidebar/panes.js +45 -0
  190. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +53 -0
  191. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.module.scss +74 -0
  192. package/lib/core/editor/components/Sidebar/views/CanvasPanel/index.js +2 -2
  193. package/lib/core/editor/components/Sidebar/views/CanvasPanel/themes.js +77 -0
  194. package/lib/core/editor/components/Sidebar/views/CanvasPanel/useCanvasThemeConfig.js +128 -0
  195. package/lib/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +1 -1
  196. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +15 -6
  197. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +16 -5
  198. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +5 -0
  199. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +29 -11
  200. package/lib/core/editor/components/Toolbar/EditorToolbar.js +22 -11
  201. package/lib/core/editor/components/Toolbar/Toolbar.js +1 -1
  202. package/lib/core/editor/components/Toolbar/Toolbar.module.scss +14 -3
  203. package/lib/core/editor/components/Toolbar/buttons.js +22 -20
  204. package/lib/core/editor/components/Toolbar/widgets/AddResourceButton.js +8 -7
  205. package/lib/core/editor/components/Toolbar/widgets/CanvasMoveWidget.js +13 -2
  206. package/lib/core/editor/components/Toolbar/widgets/CanvasSelectWidget.js +11 -2
  207. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +48 -2
  208. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +98 -5
  209. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +194 -3
  210. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +44 -0
  211. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +71 -0
  212. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.module.scss +31 -0
  213. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +83 -0
  214. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +76 -5
  215. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +83 -14
  216. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +43 -0
  217. package/lib/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +26 -10
  218. package/lib/core/editor/components/Toolbar/widgets/FontSizeWidget.js +30 -12
  219. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +105 -39
  220. package/lib/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +4 -2
  221. package/lib/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +5 -3
  222. package/lib/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +126 -0
  223. package/lib/core/editor/components/Toolbar/widgets/IconSelect/constant.js +69 -0
  224. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.js +117 -0
  225. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  226. package/lib/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +61 -0
  227. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +116 -0
  228. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  229. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +55 -0
  230. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  231. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +93 -0
  232. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  233. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +32 -0
  234. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +22 -0
  235. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  236. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  237. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  238. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  239. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +44 -0
  240. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  241. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +133 -16
  242. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +98 -23
  243. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  244. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +21 -5
  245. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +41 -6
  246. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +99 -12
  247. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  248. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.js +16 -22
  249. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +11 -1
  250. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.js +5 -3
  251. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +3 -0
  252. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +21 -3
  253. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +17 -6
  254. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +63 -0
  255. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +74 -0
  256. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +45 -0
  257. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +28 -0
  258. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +57 -0
  259. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +28 -0
  260. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +62 -0
  261. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +40 -0
  262. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +47 -0
  263. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +83 -0
  264. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +39 -0
  265. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +49 -0
  266. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +31 -0
  267. package/lib/core/editor/components/settings/CloseablePanel.js +46 -0
  268. package/lib/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  269. package/lib/core/editor/components/settings/OpenPropertyPanelListener.js +43 -0
  270. package/lib/core/editor/components/settings/PropertyView.js +32 -8
  271. package/lib/core/editor/components/settings/Settings.js +4 -44
  272. package/lib/core/editor/components/settings/Settings.module.scss +8 -4
  273. package/lib/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +2 -2
  274. package/lib/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +97 -0
  275. package/lib/core/editor/components/settings/common/AlignSetting/index.js +21 -80
  276. package/lib/core/editor/components/settings/common/LineType/index.js +13 -126
  277. package/lib/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +2 -2
  278. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +32 -23
  279. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +6 -6
  280. package/lib/core/editor/components/settings/common/text/fontStyleUtil.js +12 -20
  281. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  282. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +0 -8
  283. package/lib/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +6 -8
  284. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -42
  285. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  286. package/lib/core/editor/components/settings/propertyViews/text/TextPropertyView.js +1 -1
  287. package/lib/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +7 -5
  288. package/lib/core/editor/components/titlebar/TopoEditorTitleBar.js +9 -1
  289. package/lib/core/editor/hooks/useKeyboardShortcut.js +52 -0
  290. package/lib/core/{store/models → editor/store}/background.js +0 -0
  291. package/lib/core/{store/models → editor/store}/historyManager.js +0 -0
  292. package/lib/core/editor/store/topoEdit.js +59 -0
  293. package/lib/core/editor/utils/edgeTypeStyleUtil.js +109 -0
  294. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  295. package/lib/core/hooks/useCanvasTheme.js +63 -0
  296. package/lib/core/hooks/usePolling.js +2 -5
  297. package/lib/core/hooks/useTopoEdit.js +39 -60
  298. package/lib/core/models/Alarm.js +2 -2
  299. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  300. package/lib/core/models/HistoryManager.js +10 -3
  301. package/lib/core/models/SelectionManager.js +17 -1
  302. package/lib/core/models/TopoApp.js +1 -1
  303. package/lib/core/models/TopoGraphView.js +8 -2
  304. package/lib/core/models/utils/linkUtils.js +1 -1
  305. package/lib/core/store/coreModels.js +5 -7
  306. package/lib/core/store/models/selection.js +2 -1
  307. package/lib/core/store/models/topoBizMod.js +0 -3
  308. package/lib/core/store/models/topoMod.js +27 -29
  309. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +3 -4
  310. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +19 -5
  311. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  312. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  313. package/lib/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  314. package/lib/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  315. package/lib/networkTopo/createTopo.js +3 -0
  316. package/lib/networkTopo/services/link.js +2 -2
  317. package/lib/networkTopo/store/topoTreeMod.js +6 -8
  318. package/lib/style.js +1 -0
  319. package/lib/utils/htElementUtils.js +5 -0
  320. package/lib/utils/topoData.js +1 -0
  321. package/package.json +5 -4
  322. package/es/core/editor/components/Sidebar/views/CanvasPanel/ImagePanel.js +0 -4
  323. package/es/core/store/models/topoEdit.js +0 -39
  324. package/es/core/store/models/topoView.js +0 -36
  325. package/lib/core/editor/components/Sidebar/views/CanvasPanel/ImagePanel.js +0 -12
  326. package/lib/core/store/models/topoEdit.js +0 -51
  327. package/lib/core/store/models/topoView.js +0 -47
@@ -5,12 +5,28 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  exports.__esModule = true;
6
6
  exports["default"] = void 0;
7
7
 
8
- var _react = _interopRequireDefault(require("react"));
8
+ var _react = _interopRequireWildcard(require("react"));
9
9
 
10
- function BoxBackgroundSetting(props) {
11
- // const { } = props
12
- return /*#__PURE__*/_react["default"].createElement("div", null, "xxx");
10
+ var _IconSelect = _interopRequireDefault(require("../IconSelect"));
11
+
12
+ var _useIcons = require("../../../../../common/icons/useIcons");
13
+
14
+ 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); }
15
+
16
+ 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; }
17
+
18
+ function NodeImageList(props, ref) {
19
+ var value = props.value,
20
+ onChange = props.onChange,
21
+ topo = props.topo;
22
+ (0, _react.useEffect)(function () {}, []);
23
+ var icons = (0, _useIcons.useNodeIcons)(topo);
24
+ return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement(_IconSelect["default"], {
25
+ value: value,
26
+ iconList: icons,
27
+ onChange: onChange
28
+ }));
13
29
  }
14
30
 
15
- var _default = BoxBackgroundSetting;
31
+ var _default = NodeImageList;
16
32
  exports["default"] = _default;
@@ -9,6 +9,8 @@ var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runt
9
9
 
10
10
  var _react = _interopRequireWildcard(require("react"));
11
11
 
12
+ var _htElementUtils = require("../../../../../../utils/htElementUtils");
13
+
12
14
  var _DropdownButton = _interopRequireDefault(require("../components/DropdownButton"));
13
15
 
14
16
  var _WidgetBox = _interopRequireDefault(require("../WidgetBox"));
@@ -23,8 +25,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
23
25
 
24
26
  /**
25
27
  * 替换图片设置
26
- * @param {*} props
27
- * @returns
28
+ * @param {*} props
29
+ * @returns
28
30
  */
29
31
  function NodeImageButton(props) {
30
32
  var topo = props.topo,
@@ -33,13 +35,43 @@ function NodeImageButton(props) {
33
35
 
34
36
  var _useState = (0, _react.useState)(true),
35
37
  disabled = _useState[0],
36
- setDisabled = _useState[1]; // 选中的元素
38
+ setDisabled = _useState[1];
39
+
40
+ var _useState2 = (0, _react.useState)(),
41
+ imgVal = _useState2[0],
42
+ setImgVal = _useState2[1]; // 选中的元素
37
43
 
38
44
 
39
- var selection = topo.selectionManager.useSelection();
45
+ var selection = topo.selectionManager.useHtSelection();
40
46
  (0, _react.useEffect)(function () {
41
- setDisabled(false);
47
+ var nodes = selection.filter(function (ele) {
48
+ return (0, _htElementUtils.isGroup)(ele) || (0, _htElementUtils.isNode)(ele);
49
+ });
50
+
51
+ if (nodes.length > 0) {
52
+ setDisabled(false);
53
+ setImgVal(nodes[0].getImage());
54
+ } else {
55
+ setDisabled(true);
56
+ }
42
57
  }, [selection]);
58
+
59
+ var onChange = function onChange(prop) {
60
+ console.log("onChange-prop", prop, selection); //const { name, value } = prop;
61
+ // const gv = topo.view.topoClient.getGraphView();
62
+ //const element = topo.getSelectionModel().getFirstData();
63
+
64
+ var elements = topo.getSelectionModel();
65
+ console.log("onChange-elements", elements);
66
+ elements.each(function (element) {
67
+ element.setImage(prop);
68
+ }); // selection.map((element) => {
69
+ // element.setImage(prop);
70
+ // });
71
+ // if (name === "image") {
72
+ // }
73
+ };
74
+
43
75
  var icon = disabled ? /*#__PURE__*/_react["default"].createElement("img", {
44
76
  src: "/img/topo/editor/toolbar/\u66FF\u6362\u56FE\u7247/Disable.svg",
45
77
  alt: ""
@@ -50,12 +82,15 @@ function NodeImageButton(props) {
50
82
  return /*#__PURE__*/_react["default"].createElement(_WidgetBox["default"], {
51
83
  label: "\u66FF\u6362\u56FE\u7247",
52
84
  tooltip: "\u66FF\u6362\u56FE\u7247",
85
+ disabled: disabled,
53
86
  showLabel: showLabel
54
87
  }, /*#__PURE__*/_react["default"].createElement(_DropdownButton["default"], {
55
88
  disabled: disabled,
56
89
  trigger: icon
57
90
  }, /*#__PURE__*/_react["default"].createElement(_BoxBackgroundSetting["default"], {
58
- topo: topo
91
+ topo: topo,
92
+ onChange: onChange,
93
+ value: imgVal
59
94
  })));
60
95
  }
61
96
 
@@ -9,11 +9,17 @@ var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runt
9
9
 
10
10
  var _react = _interopRequireWildcard(require("react"));
11
11
 
12
- var _BatchSetNodeSize = _interopRequireDefault(require("../../../settings/propertyViews/view/BatchSetNodeSize"));
12
+ var _BatchSetNodeSize = _interopRequireDefault(require("../../../settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize"));
13
+
14
+ var _NodeSizeInput = _interopRequireDefault(require("../../../settings/common/NodeSizeInput/NodeSizeInput"));
15
+
16
+ var _useSettingRuntimeState = _interopRequireDefault(require("../../../settings/useSettingRuntimeState"));
13
17
 
14
18
  var _WidgetBox = _interopRequireDefault(require("../WidgetBox"));
15
19
 
16
- var _BoxBackgroundSetting = _interopRequireDefault(require("./BoxBackgroundSetting"));
20
+ var _NodeSizeButtonModule = _interopRequireDefault(require("./NodeSizeButton.module.scss"));
21
+
22
+ var _htElementUtils = require("../../../../../../utils/htElementUtils");
17
23
 
18
24
  var _excluded = ["topo", "showLabel"];
19
25
 
@@ -23,8 +29,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
23
29
 
24
30
  /**
25
31
  * 图片尺寸设置
26
- * @param {*} props
27
- * @returns
32
+ * @param {*} props
33
+ * @returns
28
34
  */
29
35
  function NodeSizeButton(props) {
30
36
  var topo = props.topo,
@@ -33,25 +39,106 @@ function NodeSizeButton(props) {
33
39
 
34
40
  var _useState = (0, _react.useState)(true),
35
41
  disabled = _useState[0],
36
- setDisabled = _useState[1]; // 选中的元素
42
+ setDisabled = _useState[1];
43
+
44
+ var _useState2 = (0, _react.useState)(),
45
+ size = _useState2[0],
46
+ setSize = _useState2[1]; // 选中的元素
37
47
 
38
48
 
39
49
  var selection = topo.selectionManager.useSelection();
50
+ var settingRuntimeState = (0, _useSettingRuntimeState["default"])();
40
51
  (0, _react.useEffect)(function () {
41
- setDisabled(false);
52
+ var elements = selection.map(function (item) {
53
+ return item.id;
54
+ }).map(function (id) {
55
+ return topo.getDataModel().getDataById(id);
56
+ });
57
+ var nodes = elements.filter(function (ele) {
58
+ return (0, _htElementUtils.isGroup)(ele) || (0, _htElementUtils.isNode)(ele);
59
+ });
60
+
61
+ if (nodes.length > 0) {
62
+ setDisabled(false);
63
+
64
+ if (selection.length === 1) {
65
+ var element = nodes[0];
66
+ setSize({
67
+ width: element.getWidth(),
68
+ height: element.getHeight()
69
+ });
70
+ }
71
+ } else {
72
+ setDisabled(true);
73
+ setSize({
74
+ width: null,
75
+ height: null
76
+ });
77
+ }
42
78
  }, [selection]);
79
+
80
+ var _onChange = function onChange(prop) {
81
+ var name = prop.name,
82
+ value = prop.value;
83
+ var element = topo.getSelectionModel().getFirstData();
84
+
85
+ if (name === 'width') {
86
+ element.setWidth(value);
87
+ } else if (name === 'height') {
88
+ element.setHeight(value);
89
+ }
90
+ };
91
+
43
92
  return /*#__PURE__*/_react["default"].createElement(_WidgetBox["default"], {
44
93
  label: "\u56FE\u7247\u5C3A\u5BF8",
94
+ disabled: disabled,
45
95
  tooltip: "\u56FE\u7247\u5C3A\u5BF8",
46
96
  showLabel: showLabel
47
97
  }, /*#__PURE__*/_react["default"].createElement("div", {
48
- style: {
49
- width: 136
98
+ className: _NodeSizeButtonModule["default"].toolbarNodeSizeSetting
99
+ }, selection.length > 1 ? /*#__PURE__*/_react["default"].createElement(_BatchSetNodeSize["default"], {
100
+ topo: topo // size="small"
101
+ ,
102
+ value: size,
103
+ disabled: disabled,
104
+ showLabel: false,
105
+ numberPickerProps: {
106
+ hasTrigger: false,
107
+ placeholder: '-'
108
+ } // onChange={(size) => {
109
+ // topo.historyManager.beginTransaction();
110
+ // onChange({ name: "width", value: size.width });
111
+ // onChange({ name: "height", value: size.height });
112
+ // topo.historyManager.endTransaction();
113
+ // }}
114
+
115
+ }) : /*#__PURE__*/_react["default"].createElement(_NodeSizeInput["default"], {
116
+ topo: topo // size="small"
117
+ ,
118
+ value: size,
119
+ disabled: disabled,
120
+ showLabel: false,
121
+ hasTrigger: false,
122
+ numberPickerProps: {
123
+ hasTrigger: false,
124
+ placeholder: '-'
125
+ },
126
+ settingRuntimeState: settingRuntimeState,
127
+ onChange: function onChange(size) {
128
+ topo.historyManager.beginTransaction();
129
+
130
+ _onChange({
131
+ name: 'width',
132
+ value: size.width
133
+ });
134
+
135
+ _onChange({
136
+ name: 'height',
137
+ value: size.height
138
+ });
139
+
140
+ topo.historyManager.endTransaction();
50
141
  }
51
- }, /*#__PURE__*/_react["default"].createElement(_BatchSetNodeSize["default"], {
52
- topo: topo,
53
- size: "small",
54
- showLabel: false
55
142
  })));
56
143
  }
57
144
 
@@ -0,0 +1,28 @@
1
+ @import '~@alifd/next/variables.scss';
2
+
3
+ .toolbarNodeSizeSetting {
4
+ width: 144px;
5
+
6
+ // 图片尺寸输入框
7
+ :global {
8
+ .#{$css-prefix}input-inner {
9
+ padding-right: 8px;
10
+ }
11
+
12
+ .#{$css-prefix}input.#{$css-prefix}medium {
13
+ height: 24px;
14
+ }
15
+
16
+ .#{$css-prefix}input {
17
+ border: none;
18
+
19
+ &:hover:not(.#{$css-prefix}disabled) {
20
+ background: #F2F7FD;
21
+ }
22
+ }
23
+
24
+ .#{$css-prefix}input.#{$css-prefix}medium input {
25
+ height: 24px;
26
+ }
27
+ }
28
+ }
@@ -5,35 +5,37 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
5
5
  exports.__esModule = true;
6
6
  exports["default"] = void 0;
7
7
 
8
+ var _balloon = _interopRequireDefault(require("@alifd/next/lib/balloon"));
9
+
8
10
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
9
11
 
10
12
  var _objectWithoutPropertiesLoose2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutPropertiesLoose"));
11
13
 
12
- var _balloon = _interopRequireDefault(require("@alifd/next/lib/balloon"));
14
+ var _react = _interopRequireDefault(require("react"));
13
15
 
14
16
  var _classnames = _interopRequireDefault(require("classnames"));
15
17
 
16
- var _react = _interopRequireDefault(require("react"));
18
+ var _ButtonBox = _interopRequireDefault(require("./components/ButtonBox"));
17
19
 
18
20
  var _WidgetBoxModule = _interopRequireDefault(require("./WidgetBox.module.scss"));
19
21
 
20
- var _excluded = ["active", "disabled", "children"];
22
+ var _excluded = ["label", "showLabel", "tooltip", "disabled", "children"];
21
23
 
22
24
  function WidgetBox(props) {
23
25
  var label = props.label,
24
26
  showLabel = props.showLabel,
25
27
  tooltip = props.tooltip,
26
28
  disabled = props.disabled,
27
- children = props.children;
29
+ children = props.children,
30
+ otherProps = (0, _objectWithoutPropertiesLoose2["default"])(props, _excluded);
28
31
 
29
- var button = /*#__PURE__*/_react["default"].createElement("button", {
32
+ var button = /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
30
33
  disabled: disabled,
31
- type: "button",
32
34
  className: _WidgetBoxModule["default"].container
33
- }, /*#__PURE__*/_react["default"].createElement("div", {
35
+ }, otherProps), /*#__PURE__*/_react["default"].createElement("div", {
34
36
  className: _WidgetBoxModule["default"].content
35
37
  }, children), showLabel !== false && /*#__PURE__*/_react["default"].createElement("div", {
36
- className: _WidgetBoxModule["default"].label
38
+ className: (0, _classnames["default"])(_WidgetBoxModule["default"].label, disabled ? _WidgetBoxModule["default"].disabledLabel : _WidgetBoxModule["default"].normalLabel)
37
39
  }, label));
38
40
 
39
41
  if (!tooltip) {
@@ -42,22 +44,14 @@ function WidgetBox(props) {
42
44
 
43
45
  return /*#__PURE__*/_react["default"].createElement(_balloon["default"].Tooltip, {
44
46
  trigger: button,
45
- align: "b"
47
+ align: "b" // 解决遮挡下拉浮层问题
48
+ ,
49
+ popupStyle: {
50
+ zIndex: 1000
51
+ }
46
52
  }, tooltip);
47
53
  }
48
54
 
49
- function ButtonBox(props) {
50
- var _classNames;
51
-
52
- var active = props.active,
53
- disabled = props.disabled,
54
- children = props.children,
55
- otherProps = (0, _objectWithoutPropertiesLoose2["default"])(props, _excluded);
56
- return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
57
- className: (0, _classnames["default"])(_WidgetBoxModule["default"].ButtonBox, (_classNames = {}, _classNames[_WidgetBoxModule["default"].ButtonBoxActive] = active, _classNames[_WidgetBoxModule["default"].ButtonBoxDisabled] = disabled, _classNames))
58
- }, otherProps), children);
59
- }
60
-
61
- WidgetBox.ButtonBox = ButtonBox;
55
+ WidgetBox.ButtonBox = _ButtonBox["default"];
62
56
  var _default = WidgetBox;
63
57
  exports["default"] = _default;
@@ -8,6 +8,7 @@
8
8
  border-width: 0;
9
9
  background-color: transparent;
10
10
  border-color: transparent;
11
+ user-select: none;
11
12
 
12
13
  &[disabled] {
13
14
  cursor: not-allowed;
@@ -43,6 +44,14 @@
43
44
  text-align: center;
44
45
  }
45
46
 
47
+ .disabledLabel {
48
+ color: #C9CED2;
49
+ }
50
+
51
+ .normalLabel {
52
+ color: #78849C;
53
+ }
54
+
46
55
  .ButtonBox {
47
56
  height: 24px;
48
57
  display: flex;
@@ -56,9 +65,10 @@
56
65
  background: rgba(76, 137, 255, 0.1);
57
66
  border-radius: 4px;
58
67
  }
68
+
59
69
  &.ButtonBoxDisabled:hover {
60
70
  background: transparent;
61
71
  cursor: not-allowed;
62
72
  }
63
-
73
+
64
74
  }
@@ -19,7 +19,7 @@ var _classnames = _interopRequireDefault(require("classnames"));
19
19
 
20
20
  var _ButtonBoxModule = _interopRequireDefault(require("./ButtonBox.module.scss"));
21
21
 
22
- var _excluded = ["active", "disabled", "showArrow", "children"];
22
+ var _excluded = ["active", "disabled", "showArrow", "children", "onClick"];
23
23
 
24
24
  function ButtonBox(props) {
25
25
  var _classNames, _classNames2;
@@ -28,13 +28,15 @@ function ButtonBox(props) {
28
28
  disabled = props.disabled,
29
29
  showArrow = props.showArrow,
30
30
  children = props.children,
31
+ onClick = props.onClick,
31
32
  otherProps = (0, _objectWithoutPropertiesLoose2["default"])(props, _excluded);
32
33
  return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({
33
- className: (0, _classnames["default"])(_ButtonBoxModule["default"].ButtonBox, (_classNames = {}, _classNames[_ButtonBoxModule["default"].ButtonBoxActive] = active, _classNames[_ButtonBoxModule["default"].ButtonBoxDisabled] = disabled, _classNames))
34
+ className: (0, _classnames["default"])(_ButtonBoxModule["default"].ButtonBox, (_classNames = {}, _classNames[_ButtonBoxModule["default"].ButtonBoxActive] = active, _classNames[_ButtonBoxModule["default"].ButtonBoxDisabled] = disabled, _classNames)),
35
+ onClick: disabled ? undefined : onClick
34
36
  }, otherProps), children, showArrow && /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, "\xA0", /*#__PURE__*/_react["default"].createElement(_icon["default"], {
35
37
  type: "tree_fold_arrow",
36
38
  size: "xxs",
37
- className: (0, _classnames["default"])(_ButtonBoxModule["default"].icon, (_classNames2 = {}, _classNames2[_ButtonBoxModule["default"].active] = active, _classNames2))
39
+ className: (0, _classnames["default"])(_ButtonBoxModule["default"].icon, (_classNames2 = {}, _classNames2[_ButtonBoxModule["default"].active] = active, _classNames2[_ButtonBoxModule["default"].disabled] = disabled, _classNames2))
38
40
  })));
39
41
  }
40
42
 
@@ -27,4 +27,7 @@
27
27
  &.active {
28
28
  transform: rotate(180deg) scale(0.5) !important;
29
29
  }
30
+ &.disabled {
31
+ color: #C9CED2;
32
+ }
30
33
  }
@@ -7,6 +7,8 @@ exports["default"] = void 0;
7
7
 
8
8
  var _dropdown = _interopRequireDefault(require("@alifd/next/lib/dropdown"));
9
9
 
10
+ var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
11
+
10
12
  var _react = _interopRequireWildcard(require("react"));
11
13
 
12
14
  var _propTypes = _interopRequireDefault(require("prop-types"));
@@ -21,27 +23,43 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
21
23
 
22
24
  function DropdownButton(props) {
23
25
  var trigger = props.trigger,
26
+ disabled = props.disabled,
24
27
  _props$showArrow = props.showArrow,
25
28
  showArrow = _props$showArrow === void 0 ? true : _props$showArrow,
26
29
  _props$showContainer = props.showContainer,
27
30
  showContainer = _props$showContainer === void 0 ? true : _props$showContainer,
31
+ buttonBoxProps = props.buttonBoxProps,
28
32
  children = props.children;
29
33
 
30
34
  var _useState = (0, _react.useState)(false),
31
35
  visible = _useState[0],
32
36
  setVisible = _useState[1];
33
37
 
34
- var button = /*#__PURE__*/_react["default"].createElement(_ButtonBox["default"], {
38
+ var button = /*#__PURE__*/_react["default"].createElement(_ButtonBox["default"], (0, _extends2["default"])({
35
39
  active: visible,
40
+ disabled: disabled,
36
41
  showArrow: showArrow
37
- }, trigger);
42
+ }, buttonBoxProps), trigger);
43
+
44
+ var renderContent = function renderContent() {
45
+ if (!visible) {
46
+ return /*#__PURE__*/_react["default"].createElement("div", null);
47
+ }
48
+
49
+ if (showContainer) {
50
+ return /*#__PURE__*/_react["default"].createElement(PopupCard, null, children);
51
+ }
52
+
53
+ return children;
54
+ };
38
55
 
39
56
  return /*#__PURE__*/_react["default"].createElement(_dropdown["default"], {
40
57
  visible: visible,
58
+ disabled: disabled,
41
59
  trigger: button,
42
60
  triggerType: "click",
43
61
  onVisibleChange: setVisible
44
- }, !showContainer ? children : /*#__PURE__*/_react["default"].createElement(PopupCard, null, children));
62
+ }, renderContent());
45
63
  }
46
64
 
47
65
  DropdownButton.propTypes = {
@@ -16,18 +16,29 @@ var _DropdownButton = _interopRequireDefault(require("./DropdownButton"));
16
16
  function DropdownMenu(props) {
17
17
  var value = props.value,
18
18
  children = props.children,
19
+ multiple = props.multiple,
19
20
  onChange = props.onChange,
20
- valueRender = props.valueRender;
21
+ valueRender = props.valueRender,
22
+ disabled = props.disabled;
21
23
  var selectedKeys = Array.isArray(value) ? value : [value];
22
24
  var valueDisplay = valueRender ? valueRender(value) : value;
25
+ var selectMode = multiple ? 'multiple' : 'single';
26
+
27
+ var handleChange = function handleChange(keys) {
28
+ onChange(multiple ? keys : keys[0]);
29
+ };
30
+
31
+ var menu = /*#__PURE__*/_react["default"].createElement(_menu["default"], {
32
+ selectMode: selectMode,
33
+ selectedKeys: selectedKeys,
34
+ onSelect: handleChange
35
+ }, children);
36
+
23
37
  return /*#__PURE__*/_react["default"].createElement(_DropdownButton["default"], {
24
38
  trigger: valueDisplay,
39
+ disabled: disabled,
25
40
  showContainer: false
26
- }, /*#__PURE__*/_react["default"].createElement(_menu["default"], {
27
- selectMode: "single",
28
- selectedKeys: selectedKeys,
29
- onSelect: onChange
30
- }, children));
41
+ }, multiple ? /*#__PURE__*/_react["default"].createElement("div", null, menu) : menu);
31
42
  }
32
43
 
33
44
  _DropdownButton["default"].propTypes = {
@@ -0,0 +1,63 @@
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 _textStyleUtil = require("./textStyleUtil");
15
+
16
+ var _excluded = ["Component", "styleNames"];
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 ElementTextStyleSetting(props) {
23
+ var topo = props.topo;
24
+ var Component = props.Component,
25
+ styleNames = props.styleNames,
26
+ widgetProps = (0, _objectWithoutPropertiesLoose2["default"])(props, _excluded); // 拓扑图是否加载
27
+
28
+ var _topo$store$useModelS = topo.store.useModelState('topoMod'),
29
+ graphLoaded = _topo$store$useModelS.graphLoaded; // 选中的元素
30
+
31
+
32
+ var selection = topo.selectionManager.useSelection();
33
+ var htSelection = (0, _react.useMemo)(function () {
34
+ if (!selection.length) {
35
+ return [];
36
+ }
37
+
38
+ return topo.getHtTopo().getGraphView().getSelectionModel().getSelection().toArray();
39
+ }, [selection, topo]);
40
+ var value = (0, _react.useMemo)(function () {
41
+ if (!graphLoaded) {
42
+ return {};
43
+ }
44
+
45
+ return (0, _textStyleUtil.getTextStyle)(htSelection, styleNames, topo) || {};
46
+ }, [graphLoaded, htSelection, topo]);
47
+ var setStyle = (0, _react.useMemo)(function () {
48
+ return function (style) {
49
+ htSelection.forEach(function (element) {
50
+ (0, _textStyleUtil.setTextStyle)(element, style, topo);
51
+ });
52
+ };
53
+ }, [htSelection]);
54
+ return /*#__PURE__*/_react["default"].createElement(Component, (0, _extends2["default"])({
55
+ disabled: false,
56
+ htSelection: htSelection,
57
+ style: value,
58
+ setStyle: setStyle
59
+ }, widgetProps));
60
+ }
61
+
62
+ var _default = ElementTextStyleSetting;
63
+ exports["default"] = _default;
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+
5
+ exports.__esModule = true;
6
+ exports.formatBackgroundRgbaColor = formatBackgroundRgbaColor;
7
+ exports.formatHexColor = formatHexColor;
8
+ exports.parseBackground = parseBackground;
9
+ exports.parseColor = parseColor;
10
+
11
+ var _color = _interopRequireDefault(require("color"));
12
+
13
+ /**
14
+ * 解析颜色字符串为对象
15
+ *
16
+ * @param {string} colorStr
17
+ * @returns {null|{hex, rgb:{r,g,b,a}}}
18
+ */
19
+ function parseColor(colorStr) {
20
+ if (!colorStr) {
21
+ return null;
22
+ }
23
+
24
+ var color = (0, _color["default"])(colorStr);
25
+ var rgb = color.rgb();
26
+ return {
27
+ hex: color.hex(),
28
+ rgb: {
29
+ r: rgb.color[0],
30
+ g: rgb.color[1],
31
+ b: rgb.color[2],
32
+ a: rgb.valpha
33
+ }
34
+ };
35
+ }
36
+
37
+ function parseBackground(colorStr) {
38
+ var _background$rgb;
39
+
40
+ var background = parseColor(colorStr);
41
+ return {
42
+ background: background,
43
+ // 背景颜色,格式: {rgba: {}, hex: ''} | null
44
+ opacity: background === null || background === void 0 ? void 0 : (_background$rgb = background.rgb) === null || _background$rgb === void 0 ? void 0 : _background$rgb.a // 背景透明度。值范围 0-1, null,null表示无
45
+
46
+ };
47
+ }
48
+
49
+ function formatHexColor(color) {
50
+ return color ? color.hex : null;
51
+ }
52
+ /**
53
+ * 格式化背景rgba颜色
54
+ * @param {{background, opacity}} prevColor
55
+ * @param {{background, opacity}} currentColor
56
+ */
57
+
58
+
59
+ function formatBackgroundRgbaColor(prevColor, currentColor) {
60
+ if (!('background' in currentColor) && !('opacity' in currentColor)) {
61
+ return null;
62
+ }
63
+
64
+ var colorObj = Object.assign(prevColor, currentColor);
65
+ var background = colorObj.background,
66
+ opacity = colorObj.opacity;
67
+
68
+ if (!background) {
69
+ return null;
70
+ }
71
+
72
+ var rgb = background.rgb;
73
+ return "rgba(" + rgb.r + ", " + rgb.g + ", " + rgb.b + ", " + opacity + ")";
74
+ }