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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (398) hide show
  1. package/build/1.js +2 -2
  2. package/build/2.js +1 -1
  3. package/build/index.css +1 -1
  4. package/build/index.js +35 -35
  5. package/demo/CHANGELOG/CHANGELOG.md +5 -0
  6. package/es/components/ColorPanel/components/ColorBlock/index.js +37 -0
  7. package/es/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  8. package/es/components/ColorPanel/components/FontColorRange/index.js +35 -0
  9. package/es/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  10. package/es/components/ColorPanel/index.js +259 -0
  11. package/es/components/ColorPanel/index.module.scss +35 -0
  12. package/es/components/VerticalIconTab/VerticalIconTab.js +11 -1
  13. package/es/components/VerticalIconTab/VerticalIconTab.module.scss +2 -0
  14. package/es/components/collapse/Collapse.js +22 -3
  15. package/es/components/collapse/Collapse.module.scss +24 -0
  16. package/es/components/collapse/index.js +2 -0
  17. package/es/core/common/hooks/useHtElements.js +21 -0
  18. package/es/core/common/icons/icon.js +40 -0
  19. package/es/core/common/icons/useIcons.js +8 -16
  20. package/es/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  21. package/es/core/components/AlarmListPanel/components/index.module.scss +5 -5
  22. package/es/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  23. package/es/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +9 -3
  24. package/es/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +122 -0
  25. package/es/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  26. package/es/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +84 -22
  27. package/es/core/components/TopoView/GraphViewPanel.js +22 -0
  28. package/es/core/components/TopoView/editor.module.scss +1 -0
  29. package/es/core/components/TopoView/topoView.js +30 -60
  30. package/es/core/components/titlebar/TitleBar.module.scss +1 -1
  31. package/es/core/editor/components/EditorPlugin.js +18 -2
  32. package/es/core/editor/components/Sidebar/Sidebar.js +29 -7
  33. package/es/core/editor/components/Sidebar/panes.js +10 -5
  34. package/es/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +13 -37
  35. package/es/core/editor/components/Sidebar/views/CanvasPanel/hooks/useCanvasThemeConfig.js +109 -0
  36. package/es/core/editor/components/Sidebar/views/CanvasPanel/hooks/useUpdateHtTopoDefaultTagStyle.js +27 -0
  37. package/es/core/editor/components/Sidebar/views/CanvasPanel/utils/elementThemeUtil.js +0 -0
  38. package/es/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +3 -3
  39. package/es/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +12 -1
  40. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +12 -1
  41. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +3 -3
  42. package/es/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +27 -8
  43. package/es/core/editor/components/Toolbar/EditorToolbar.js +16 -9
  44. package/es/core/editor/components/Toolbar/buttons.js +20 -18
  45. package/es/core/editor/components/Toolbar/widgets/AddResourceButton.js +3 -3
  46. package/es/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  47. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +46 -2
  48. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +98 -6
  49. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +74 -23
  50. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +1 -3
  51. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +17 -10
  52. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +77 -0
  53. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +52 -5
  54. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +166 -16
  55. package/es/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  56. package/es/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +26 -12
  57. package/es/core/editor/components/Toolbar/widgets/FontSizeWidget.js +37 -12
  58. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +92 -39
  59. package/es/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +1 -1
  60. package/es/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +2 -2
  61. package/es/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +109 -0
  62. package/es/core/editor/components/Toolbar/widgets/IconSelect/constant.js +64 -0
  63. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.js +101 -0
  64. package/es/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  65. package/es/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +49 -0
  66. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +99 -0
  67. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  68. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +42 -0
  69. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  70. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +75 -0
  71. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  72. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +23 -0
  73. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +10 -0
  74. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  75. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  76. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  77. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  78. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +31 -0
  79. package/es/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  80. package/es/core/editor/components/Toolbar/widgets/Layout/index.js +130 -15
  81. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +107 -23
  82. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  83. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +15 -5
  84. package/es/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +50 -7
  85. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +99 -15
  86. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  87. package/es/core/editor/components/Toolbar/widgets/WidgetBox.js +10 -4
  88. package/es/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  89. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  90. package/es/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  91. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  92. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +21 -7
  93. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +52 -0
  94. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +67 -0
  95. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +41 -0
  96. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +65 -0
  97. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +65 -0
  98. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +14 -0
  99. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +73 -0
  100. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +69 -0
  101. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +37 -0
  102. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +124 -0
  103. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +31 -0
  104. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +98 -0
  105. package/es/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +20 -0
  106. package/es/core/editor/components/plugins/AddElementThemePlugin.js +11 -0
  107. package/es/core/editor/components/settings/CloseablePanel.js +33 -0
  108. package/es/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  109. package/es/core/editor/components/settings/PropertyView.js +50 -11
  110. package/es/core/editor/components/settings/Settings.js +37 -122
  111. package/es/core/editor/components/settings/Settings.module.scss +7 -11
  112. package/es/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  113. package/es/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +80 -0
  114. package/es/core/editor/components/settings/common/AlignSetting/index.js +20 -72
  115. package/es/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  116. package/es/core/editor/components/settings/common/LineType/index.js +11 -102
  117. package/es/core/editor/components/settings/common/NameInput.js +24 -0
  118. package/es/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +3 -3
  119. package/es/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +31 -24
  120. package/es/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +7 -6
  121. package/es/core/editor/components/settings/common/text/fontStyleUtil.js +21 -19
  122. package/es/core/editor/components/settings/core/PropertyViewManager.js +81 -0
  123. package/es/core/editor/components/settings/core/edgePropertyViewAdapter.js +22 -0
  124. package/es/core/editor/components/settings/core/getPropertyViewType.js +34 -0
  125. package/es/core/editor/components/settings/core/updateElementProperty.js +21 -0
  126. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  127. package/es/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +58 -0
  128. package/es/core/editor/components/settings/propertyViews/box/NameInput.js +5 -4
  129. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +12 -3
  130. package/es/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +7 -8
  131. package/es/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +9 -23
  132. package/es/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +10 -0
  133. package/es/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  134. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +13 -21
  135. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  136. package/es/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +28 -0
  137. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +75 -0
  138. package/es/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +9 -15
  139. package/es/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +8 -6
  140. package/es/core/editor/components/settings/propertyViews/index.js +4 -6
  141. package/es/core/editor/components/settings/propertyViews/layer/BasicSetting.js +57 -0
  142. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +11 -17
  143. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  144. package/es/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +27 -0
  145. package/es/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +8 -9
  146. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +5 -7
  147. package/es/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  148. package/es/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -32
  149. package/es/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +53 -0
  150. package/es/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +49 -0
  151. package/es/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +5 -4
  152. package/es/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  153. package/es/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  154. package/es/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  155. package/es/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +9 -6
  156. package/es/core/editor/components/titlebar/TopoEditorTitleBar.js +8 -4
  157. package/es/core/editor/config/themes.js +105 -0
  158. package/es/core/editor/hooks/useKeyboardShortcut.js +39 -0
  159. package/es/core/editor/hooks/useNewElementTheme.js +46 -0
  160. package/es/core/editor/store/topoEdit.js +44 -37
  161. package/es/core/editor/utils/edgeTypeStyleUtil.js +34 -11
  162. package/es/core/editor/utils/textStyleUtil.js +0 -0
  163. package/es/core/editor/utils/themeUtil.js +32 -0
  164. package/es/core/hooks/useCanvasTheme.js +54 -0
  165. package/es/core/hooks/useManageStatus.js +1 -9
  166. package/es/core/hooks/usePolling.js +2 -5
  167. package/es/core/hooks/useTopoEdit.js +15 -8
  168. package/es/core/models/Alarm.js +2 -2
  169. package/es/core/models/AttributeMetricDisplay.js +4 -0
  170. package/es/core/models/HistoryManager.js +13 -8
  171. package/es/core/models/{SelectionManager.js → SelectionModel.js} +55 -22
  172. package/es/core/models/TopoApp.js +6 -5
  173. package/es/core/models/selection/ignoreList.js +1 -0
  174. package/es/core/models/utils/linkUtils.js +5 -6
  175. package/es/core/store/models/customIcon.js +1 -3
  176. package/es/core/store/models/selection.js +2 -1
  177. package/es/core/store/models/topoBizMod.js +0 -3
  178. package/es/core/store/models/topoConfig.js +10 -12
  179. package/es/core/store/models/topoMod.js +26 -28
  180. package/es/core/utils/edgeUtil.js +6 -0
  181. package/es/core/utils/showGraphManageStatusUtil.js +7 -1
  182. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  183. package/es/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  184. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  185. package/es/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  186. package/es/core/viewer/components/plugins/ViewerPlugin.js +10 -4
  187. package/es/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  188. package/es/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  189. package/es/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +2 -1
  190. package/es/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +39 -6
  191. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -16
  192. package/es/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +37 -0
  193. package/es/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  194. package/es/networkTopo/components/editor/useEditorProps.js +1 -3
  195. package/es/networkTopo/createTopo.js +2 -0
  196. package/es/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  197. package/es/networkTopo/services/link.js +2 -2
  198. package/es/networkTopo/store/topoTreeMod.js +6 -7
  199. package/es/style.js +28 -27
  200. package/es/utils/htElementUtils.js +3 -0
  201. package/es/utils/topoData.js +1 -0
  202. package/lib/components/ColorPanel/components/ColorBlock/index.js +47 -0
  203. package/lib/components/ColorPanel/components/ColorBlock/index.module.scss +9 -0
  204. package/lib/components/ColorPanel/components/FontColorRange/index.js +49 -0
  205. package/lib/components/ColorPanel/components/FontColorRange/index.module.scss +25 -0
  206. package/lib/components/ColorPanel/index.js +278 -0
  207. package/lib/components/ColorPanel/index.module.scss +35 -0
  208. package/lib/components/VerticalIconTab/VerticalIconTab.js +14 -1
  209. package/lib/components/VerticalIconTab/VerticalIconTab.module.scss +2 -0
  210. package/lib/components/collapse/Collapse.js +28 -3
  211. package/lib/components/collapse/Collapse.module.scss +24 -0
  212. package/lib/components/collapse/index.js +11 -0
  213. package/lib/core/common/hooks/useHtElements.js +27 -0
  214. package/lib/core/common/icons/icon.js +47 -0
  215. package/lib/core/common/icons/useIcons.js +10 -15
  216. package/lib/core/components/AlarmListPanel/components/AlarmListItem.js +14 -13
  217. package/lib/core/components/AlarmListPanel/components/index.module.scss +5 -5
  218. package/lib/core/components/DisplaySettingDrawer/DisplaySetting.js +2 -1
  219. package/lib/core/components/DisplaySettingDrawer/DisplaySettingDrawer.js +10 -3
  220. package/lib/core/components/DisplaySettingDrawer/EditorDisplaySetting.js +147 -0
  221. package/lib/core/components/DisplaySettingDrawer/LineExpandAllRadioGroup.js +0 -3
  222. package/lib/core/components/DisplaySettingDrawer/hooks/useDisplaySetting.js +84 -22
  223. package/lib/core/components/TopoView/GraphViewPanel.js +32 -0
  224. package/lib/core/components/TopoView/editor.module.scss +1 -0
  225. package/lib/core/components/TopoView/topoView.js +36 -67
  226. package/lib/core/components/titlebar/TitleBar.module.scss +1 -1
  227. package/lib/core/editor/components/EditorPlugin.js +26 -2
  228. package/lib/core/editor/components/Sidebar/Sidebar.js +28 -6
  229. package/lib/core/editor/components/Sidebar/panes.js +10 -5
  230. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +14 -38
  231. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useCanvasThemeConfig.js +123 -0
  232. package/lib/core/editor/components/Sidebar/views/CanvasPanel/hooks/useUpdateHtTopoDefaultTagStyle.js +37 -0
  233. package/lib/core/editor/components/Sidebar/views/CanvasPanel/utils/elementThemeUtil.js +1 -0
  234. package/lib/core/editor/components/Sidebar/views/ImagePanel/CiTypeImagePanel.js +1 -1
  235. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtCustomImagePanel.js +13 -1
  236. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +13 -1
  237. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.module.scss +3 -3
  238. package/lib/core/editor/components/Sidebar/views/ImagePanel/ImagePanel.js +36 -12
  239. package/lib/core/editor/components/Toolbar/EditorToolbar.js +14 -7
  240. package/lib/core/editor/components/Toolbar/buttons.js +21 -20
  241. package/lib/core/editor/components/Toolbar/widgets/AddResourceButton.js +3 -3
  242. package/lib/core/editor/components/Toolbar/widgets/BoxBackgroundButton/BoxBackgroundButton.js +3 -3
  243. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/Content.js +48 -2
  244. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +100 -6
  245. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.js +73 -22
  246. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/EdgeType.module.scss +1 -3
  247. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/LineType.js +18 -8
  248. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/constants.js +83 -0
  249. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +53 -4
  250. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +172 -16
  251. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.module.scss +42 -0
  252. package/lib/core/editor/components/Toolbar/widgets/FontFamilyWidget.js +27 -11
  253. package/lib/core/editor/components/Toolbar/widgets/FontSizeWidget.js +38 -11
  254. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +96 -39
  255. package/lib/core/editor/components/Toolbar/widgets/HistoryRedoButton.js +1 -1
  256. package/lib/core/editor/components/Toolbar/widgets/HistoryUndoButton.js +2 -2
  257. package/lib/core/editor/components/Toolbar/widgets/IconSelect/IconSelect.js +126 -0
  258. package/lib/core/editor/components/Toolbar/widgets/IconSelect/constant.js +69 -0
  259. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.js +117 -0
  260. package/lib/core/editor/components/Toolbar/widgets/IconSelect/index.module.scss +153 -0
  261. package/lib/core/editor/components/Toolbar/widgets/IconSelect/popUpContent.js +61 -0
  262. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.js +116 -0
  263. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutSettings.module.scss +70 -0
  264. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.js +55 -0
  265. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagImageSelect/index.module.scss +7 -0
  266. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.js +93 -0
  267. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTagSelect/index.scss +32 -0
  268. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/Icon.js +32 -0
  269. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/index.js +22 -0
  270. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_circular.svg +10 -0
  271. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_hierarchical.svg +10 -0
  272. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_rectangle.svg +12 -0
  273. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/assets/topo_layout_toward.svg +16 -0
  274. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.js +44 -0
  275. package/lib/core/editor/components/Toolbar/widgets/Layout/components/LayoutTemplateButton/index.module.scss +53 -0
  276. package/lib/core/editor/components/Toolbar/widgets/Layout/index.js +135 -16
  277. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +110 -23
  278. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +33 -0
  279. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/BoxBackgroundSetting.js +21 -5
  280. package/lib/core/editor/components/Toolbar/widgets/NodeImageButton/NodeImageButton.js +50 -6
  281. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +100 -14
  282. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.module.scss +28 -0
  283. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.js +13 -4
  284. package/lib/core/editor/components/Toolbar/widgets/WidgetBox.module.scss +10 -1
  285. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.js +2 -2
  286. package/lib/core/editor/components/Toolbar/widgets/components/ButtonBox.module.scss +4 -0
  287. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -8
  288. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +22 -7
  289. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/ElementTextStyleSetting.js +66 -0
  290. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/colorUtil.js +82 -0
  291. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/box.js +58 -0
  292. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/edgeTag.js +86 -0
  293. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/groupTitle.js +88 -0
  294. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/index.js +28 -0
  295. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/layerTitle.js +90 -0
  296. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/nodeTag.js +90 -0
  297. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/elements/text.js +54 -0
  298. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/ElementTextStyleSetting/textStyleUtil.js +141 -0
  299. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/GlobalTagStyleSetting.js +46 -0
  300. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/GlobalTagStyleSetting/globalTag.js +111 -0
  301. package/lib/core/editor/components/Toolbar/widgets/components/textStyleSetting/textStyleSettingRouter.js +31 -0
  302. package/lib/core/editor/components/plugins/AddElementThemePlugin.js +20 -0
  303. package/lib/core/editor/components/settings/CloseablePanel.js +46 -0
  304. package/lib/core/editor/components/settings/CloseablePanel.module.scss +21 -0
  305. package/lib/core/editor/components/settings/PropertyView.js +59 -12
  306. package/lib/core/editor/components/settings/Settings.js +40 -122
  307. package/lib/core/editor/components/settings/Settings.module.scss +7 -11
  308. package/lib/core/editor/components/settings/common/AlignSetting/AlignSetting.module.scss +3 -3
  309. package/lib/core/editor/components/settings/common/AlignSetting/AlignTypeList.js +97 -0
  310. package/lib/core/editor/components/settings/common/AlignSetting/index.js +21 -80
  311. package/lib/core/editor/components/settings/common/GroupNodeList/ResourceList.module.scss +1 -0
  312. package/lib/core/editor/components/settings/common/LineType/index.js +11 -109
  313. package/lib/core/editor/components/settings/common/NameInput.js +38 -0
  314. package/lib/core/editor/components/settings/common/NodeSizeInput/NodeSizeInput.js +2 -2
  315. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeInput.js +32 -26
  316. package/lib/core/editor/components/settings/common/SizeInput/NodeSizeNumberPicker.js +6 -6
  317. package/lib/core/editor/components/settings/common/text/fontStyleUtil.js +25 -20
  318. package/lib/core/editor/components/settings/core/PropertyViewManager.js +91 -0
  319. package/lib/core/editor/components/settings/core/edgePropertyViewAdapter.js +33 -0
  320. package/lib/core/editor/components/settings/core/getPropertyViewType.js +40 -0
  321. package/lib/core/editor/components/settings/core/updateElementProperty.js +27 -0
  322. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyView.js +6 -13
  323. package/lib/core/editor/components/settings/propertyViews/box/BoxPropertyViewV1.js +76 -0
  324. package/lib/core/editor/components/settings/propertyViews/box/NameInput.js +6 -5
  325. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +15 -3
  326. package/lib/core/editor/components/settings/propertyViews/edge/EdgeGroupPropertyView.js +9 -12
  327. package/lib/core/editor/components/settings/propertyViews/edge/EdgePropertyView.js +7 -23
  328. package/lib/core/editor/components/settings/propertyViews/edge/addEdgeProps.js +19 -0
  329. package/lib/core/editor/components/settings/propertyViews/edge/edgeGroup/EdgeGroupSetting.js +1 -6
  330. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.js +14 -25
  331. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyView.module.scss +8 -1
  332. package/lib/core/editor/components/settings/propertyViews/group/GroupPropertyViewV1.js +43 -0
  333. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupBasicSetting.js +98 -0
  334. package/lib/core/editor/components/settings/propertyViews/group/SettingTab/GroupExpandSetting.js +8 -14
  335. package/lib/core/editor/components/settings/propertyViews/group/cluster/ClusterGroupRelateData.js +9 -7
  336. package/lib/core/editor/components/settings/propertyViews/index.js +4 -9
  337. package/lib/core/editor/components/settings/propertyViews/layer/BasicSetting.js +75 -0
  338. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.js +12 -20
  339. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyView.module.scss +10 -0
  340. package/lib/core/editor/components/settings/propertyViews/layer/LayerPropertyViewV1.js +40 -0
  341. package/lib/core/editor/components/settings/propertyViews/multipleElements/BatchSetNodeSize/BatchSetNodeSize.js +6 -8
  342. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementLineType.js +4 -6
  343. package/lib/core/editor/components/settings/propertyViews/multipleElements/MultipleElementPropertyView.js +2 -15
  344. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyView.js +8 -35
  345. package/lib/core/editor/components/settings/propertyViews/node/NodePropertyViewV1.js +68 -0
  346. package/lib/core/editor/components/settings/propertyViews/node/Setting/BasicSetting.js +64 -0
  347. package/lib/core/editor/components/settings/propertyViews/node/Setting/NameInput.js +6 -5
  348. package/lib/core/editor/components/settings/propertyViews/node/data/Data.js +2 -1
  349. package/lib/core/editor/components/settings/propertyViews/node/data/NodeRelateResourceButton.js +1 -0
  350. package/lib/core/editor/components/settings/propertyViews/text/TextPropertyView.js +5 -20
  351. package/lib/core/editor/components/settings/propertyViews/view/BatchSetNodeSize.js +7 -5
  352. package/lib/core/editor/components/titlebar/TopoEditorTitleBar.js +9 -1
  353. package/lib/core/editor/config/themes.js +114 -0
  354. package/lib/core/editor/hooks/useKeyboardShortcut.js +49 -0
  355. package/lib/core/editor/hooks/useNewElementTheme.js +57 -0
  356. package/lib/core/editor/store/topoEdit.js +46 -40
  357. package/lib/core/editor/utils/edgeTypeStyleUtil.js +38 -11
  358. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  359. package/lib/core/editor/utils/themeUtil.js +39 -0
  360. package/lib/core/hooks/useCanvasTheme.js +68 -0
  361. package/lib/core/hooks/useManageStatus.js +1 -9
  362. package/lib/core/hooks/usePolling.js +2 -5
  363. package/lib/core/hooks/useTopoEdit.js +16 -8
  364. package/lib/core/models/Alarm.js +2 -2
  365. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  366. package/lib/core/models/HistoryManager.js +13 -8
  367. package/lib/core/models/{SelectionManager.js → SelectionModel.js} +57 -22
  368. package/lib/core/models/TopoApp.js +7 -5
  369. package/lib/core/models/selection/ignoreList.js +6 -0
  370. package/lib/core/models/utils/linkUtils.js +5 -6
  371. package/lib/core/store/models/customIcon.js +1 -3
  372. package/lib/core/store/models/selection.js +2 -1
  373. package/lib/core/store/models/topoBizMod.js +0 -3
  374. package/lib/core/store/models/topoConfig.js +9 -18
  375. package/lib/core/store/models/topoMod.js +27 -29
  376. package/lib/core/utils/edgeUtil.js +6 -0
  377. package/lib/core/utils/showGraphManageStatusUtil.js +7 -1
  378. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/hooks/useMetricPolling.js +18 -13
  379. package/lib/core/viewer/components/plugins/ResourceDetail/components/ResourceOverview/components/LinkTopo/services/index.js +38 -19
  380. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/WebConsoleForm.js +13 -29
  381. package/lib/core/viewer/components/plugins/ResourceDetail/components/WebConsole/WebConsoleForm/hooks/useWebConsole.js +6 -5
  382. package/lib/core/viewer/components/plugins/ViewerPlugin.js +11 -3
  383. package/lib/core/viewer/components/titlebar/widgets/SettingButton.js +3 -1
  384. package/lib/core/viewer/components/titlebar/widgets/SettingButtonWidget.js +4 -2
  385. package/lib/networkTopo/components/editor/propertyViews/edge/EdgeGroupPropertyView.js +1 -0
  386. package/lib/networkTopo/components/editor/propertyViews/edge/EdgePropertyView.js +45 -7
  387. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyView.js +10 -18
  388. package/lib/networkTopo/components/editor/propertyViews/edge/LinkPropertyView/LinkPropertyViewV1.js +50 -0
  389. package/lib/networkTopo/components/editor/propertyViews/edge/link/LinkInfoPreview.module.scss +1 -1
  390. package/lib/networkTopo/components/editor/useEditorProps.js +1 -4
  391. package/lib/networkTopo/createTopo.js +3 -0
  392. package/lib/networkTopo/models/LinkDynamicStyleExecutor.js +2 -2
  393. package/lib/networkTopo/services/link.js +2 -2
  394. package/lib/networkTopo/store/topoTreeMod.js +6 -8
  395. package/lib/style.js +28 -27
  396. package/lib/utils/htElementUtils.js +5 -0
  397. package/lib/utils/topoData.js +1 -0
  398. package/package.json +5 -4
@@ -1,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
+ });
@@ -0,0 +1,42 @@
1
+ .content {
2
+ margin: 4px 0px 0px 6px;
3
+ .fontColor{
4
+ width: 100%;
5
+ margin-bottom: 16px;
6
+ .colorPanelBox{
7
+ padding: 9px;
8
+ padding-top: 8px;
9
+ }
10
+ &>span{
11
+ font-size: 12px;
12
+ font-family: PingFangSC-Regular, PingFang SC;
13
+ font-weight: 400;
14
+ color: #4D6277;
15
+ line-height: 17px;
16
+ }
17
+
18
+ }
19
+ .backgroundColor{
20
+ width: 100%;
21
+ height: 159px;
22
+ .colorPanelBox{
23
+ padding: 9px;
24
+ padding-top: 0px;
25
+ }
26
+ &>span{
27
+ font-size: 12px;
28
+ color: black;
29
+ font-family: PingFangSC-Regular, PingFang SC;
30
+ font-weight: 400;
31
+ color: #4D6277;
32
+ line-height: 17px;
33
+ }
34
+ .backOpacity{
35
+ margin-top: 5px;
36
+ margin-bottom: 5px;
37
+ line-height: 8px;
38
+ display: flex;
39
+ flex-direction: row;
40
+ }
41
+ }
42
+ }
@@ -1,5 +1,6 @@
1
- import React, { useState } from 'react';
1
+ import React, { useState, useEffect } from 'react';
2
2
  import DropdownMenu from "./components/DropdownMenu";
3
+ import textStyleSettingRouter from "./components/textStyleSetting/textStyleSettingRouter.js";
3
4
  import WidgetBox from "./WidgetBox";
4
5
 
5
6
  function FontFamilySelect(props) {
@@ -7,8 +8,15 @@ function FontFamilySelect(props) {
7
8
  onChange = props.onChange;
8
9
  var items = ['宋体', '微软雅黑', '黑体', 'Arial'];
9
10
  return /*#__PURE__*/React.createElement(DropdownMenu, {
10
- value: value,
11
- onChange: onChange
11
+ value: (items.includes(value) ? value : null) || '',
12
+ valueRender: function valueRender(val) {
13
+ return /*#__PURE__*/React.createElement("div", {
14
+ style: {
15
+ width: 48
16
+ }
17
+ }, val || '微软雅黑');
18
+ },
19
+ onSelect: onChange
12
20
  }, items.map(function (item) {
13
21
  return /*#__PURE__*/React.createElement(DropdownMenu.Item, {
14
22
  key: item
@@ -21,20 +29,26 @@ function FontFamilySelect(props) {
21
29
  }
22
30
 
23
31
  function FontFamilyWidget(props) {
24
- var showLabel = props.showLabel;
25
-
26
- var _useState = useState('微软雅黑'),
27
- value = _useState[0],
28
- setValue = _useState[1];
29
-
32
+ var topo = props.topo,
33
+ showLabel = props.showLabel,
34
+ style = props.style,
35
+ setStyle = props.setStyle;
30
36
  return /*#__PURE__*/React.createElement(WidgetBox, {
31
37
  label: "\u5B57\u4F53",
32
38
  tooltip: "\u5B57\u4F53",
33
39
  showLabel: showLabel
34
40
  }, /*#__PURE__*/React.createElement(FontFamilySelect, {
35
- value: value,
36
- onChange: setValue
41
+ value: style.fontFamily,
42
+ onChange: function onChange(val) {
43
+ topo.historyManager.beginTransaction();
44
+ setStyle({
45
+ fontFamily: val
46
+ });
47
+ topo.historyManager.endTransaction();
48
+ }
37
49
  }));
38
50
  }
39
51
 
40
- export default FontFamilyWidget;
52
+ export default textStyleSettingRouter(FontFamilyWidget, {
53
+ names: ['fontFamily']
54
+ });
@@ -1,14 +1,26 @@
1
- import React, { useState } from 'react';
1
+ import React, { useEffect, useState } from 'react';
2
2
  import DropdownMenu from "./components/DropdownMenu";
3
+ import textStyleSettingRouter from "./components/textStyleSetting/textStyleSettingRouter.js";
3
4
  import WidgetBox from "./WidgetBox";
4
5
 
5
6
  function FontSizeSelect(props) {
6
7
  var value = props.value,
8
+ disabled = props.disabled,
7
9
  onChange = props.onChange;
8
10
  var items = [9, 10, 11, 12, 14, 16, 18, 20, 24, 30, 36];
9
11
  return /*#__PURE__*/React.createElement(DropdownMenu, {
10
- value: value,
11
- onChange: onChange
12
+ value: "" + (value || ''),
13
+ valueRender: function valueRender(val) {
14
+ return /*#__PURE__*/React.createElement("div", {
15
+ style: {
16
+ width: 18
17
+ }
18
+ }, val || 12);
19
+ },
20
+ disabled: disabled,
21
+ onSelect: function onSelect(val) {
22
+ return onChange(parseInt(val, 10));
23
+ }
12
24
  }, items.map(function (item) {
13
25
  return /*#__PURE__*/React.createElement(DropdownMenu.Item, {
14
26
  key: item
@@ -17,19 +29,32 @@ function FontSizeSelect(props) {
17
29
  }
18
30
 
19
31
  function FontSizeWidget(props) {
20
- var showLabel = props.showLabel;
21
-
22
- var _useState = useState(12),
23
- fontSize = _useState[0],
24
- setFontSize = _useState[1];
32
+ var topo = props.topo,
33
+ showLabel = props.showLabel,
34
+ style = props.style,
35
+ fieldDisabled = props.fieldDisabled,
36
+ setStyle = props.setStyle;
37
+ var disabled = fieldDisabled.fontSize; // 选中的元素
25
38
 
39
+ var selection = topo.selectionModel.useHtSelection();
40
+ useEffect(function () {}, [selection]);
26
41
  return /*#__PURE__*/React.createElement(WidgetBox, {
27
42
  label: "\u5B57\u53F7",
28
- showLabel: showLabel
43
+ showLabel: showLabel,
44
+ disabled: disabled
29
45
  }, /*#__PURE__*/React.createElement(FontSizeSelect, {
30
- value: fontSize,
31
- onChange: setFontSize
46
+ value: style.fontSize,
47
+ disabled: disabled,
48
+ onChange: function onChange(val) {
49
+ topo.historyManager.beginTransaction();
50
+ setStyle({
51
+ fontSize: val
52
+ });
53
+ topo.historyManager.endTransaction();
54
+ }
32
55
  }));
33
56
  }
34
57
 
35
- export default FontSizeWidget;
58
+ export default textStyleSettingRouter(FontSizeWidget, {
59
+ names: ['fontSize']
60
+ });
@@ -1,62 +1,115 @@
1
1
  import React, { useState, useEffect } from 'react';
2
+ import { isText } from "../../../../../utils/htElementUtils";
2
3
  import DropdownMenu from "./components/DropdownMenu";
4
+ import textStyleSettingRouter from "./components/textStyleSetting/textStyleSettingRouter.js";
3
5
  import WidgetBox from "./WidgetBox";
6
+ var items = [{
7
+ key: 'bold',
8
+ label: '加粗',
9
+ icon: 'bold'
10
+ }, {
11
+ key: 'italic',
12
+ label: '斜体',
13
+ icon: 'Italics'
14
+ }, {
15
+ key: 'underline',
16
+ label: '下划线',
17
+ icon: 'Underline'
18
+ }];
4
19
 
5
- function FontFamilySelect(props) {
6
- var value = props.value,
7
- disabled = props.disabled,
8
- onChange = props.onChange;
9
- var items = ['宋体', '微软雅黑', '黑体', 'Arial'];
10
- var icon = disabled ? /*#__PURE__*/React.createElement("img", {
11
- src: "/img/topo/editor/toolbar/bold/Disable.svg",
12
- alt: ""
13
- }) : /*#__PURE__*/React.createElement("img", {
14
- src: "/img/topo/editor/toolbar/bold/Normal.svg",
15
- alt: ""
20
+ function buildValue(obj) {
21
+ return Object.keys(obj).filter(function (key) {
22
+ return !!obj[key];
16
23
  });
17
- return /*#__PURE__*/React.createElement(DropdownMenu, {
18
- value: value,
19
- valueRender: function valueRender() {
20
- return icon;
21
- },
22
- onChange: onChange
23
- }, items.map(function (item) {
24
- return /*#__PURE__*/React.createElement(DropdownMenu.Item, {
25
- key: item
26
- }, /*#__PURE__*/React.createElement("div", {
27
- style: {
28
- fontFamily: item
29
- }
30
- }, item));
31
- }));
32
24
  }
33
25
 
34
26
  function FontStyleButton(props) {
35
27
  var topo = props.topo,
36
- showLabel = props.showLabel;
28
+ showLabel = props.showLabel,
29
+ style = props.style,
30
+ setStyle = props.setStyle;
31
+
32
+ var _useState = useState(true),
33
+ disabled = _useState[0],
34
+ setDisabled = _useState[1];
37
35
 
38
- var _useState = useState('微软雅黑'),
39
- value = _useState[0],
40
- setValue = _useState[1];
36
+ var bold = style.bold,
37
+ italic = style.italic,
38
+ underline = style.underline;
41
39
 
42
- var _useState2 = useState(true),
43
- disabled = _useState2[0],
44
- setDisabled = _useState2[1]; // 选中的元素
40
+ var _useState2 = useState(buildValue({
41
+ bold: bold,
42
+ italic: italic,
43
+ underline: underline
44
+ })),
45
+ value = _useState2[0],
46
+ setValue = _useState2[1]; // 选中的元素
45
47
 
46
48
 
47
- var selection = topo.selectionManager.useSelection();
49
+ var selection = topo.selectionModel.useHtSelection();
48
50
  useEffect(function () {
49
- setDisabled(false);
51
+ var containText = selection.filter(function (ele) {
52
+ return isText(ele);
53
+ }).length;
54
+ setDisabled(!containText);
50
55
  }, [selection]);
56
+ useEffect(function () {
57
+ setValue(buildValue({
58
+ bold: bold,
59
+ italic: italic,
60
+ underline: underline
61
+ }));
62
+ }, [bold, italic, underline]);
63
+ /**
64
+ *
65
+ * @param {Array} selectedKeys
66
+ */
67
+
68
+ var handleSelect = function handleSelect(selectedKeys, item, extra) {
69
+ var _setStyle;
70
+
71
+ var key = extra.key,
72
+ select = extra.select;
73
+ topo.historyManager.beginTransaction();
74
+ setStyle((_setStyle = {}, _setStyle[key] = select, _setStyle));
75
+ topo.historyManager.endTransaction();
76
+ };
77
+
51
78
  return /*#__PURE__*/React.createElement(WidgetBox, {
52
79
  label: "\u6587\u5B57\u6837\u5F0F",
53
80
  tooltip: "\u6587\u5B57\u6837\u5F0F",
81
+ disabled: disabled,
54
82
  showLabel: showLabel
55
- }, /*#__PURE__*/React.createElement(FontFamilySelect, {
83
+ }, /*#__PURE__*/React.createElement(DropdownMenu, {
56
84
  value: value,
85
+ valueRender: function valueRender() {
86
+ return /*#__PURE__*/React.createElement("img", {
87
+ src: "/img/topo/editor/toolbar/bold/" + (disabled ? 'Disable' : 'Normal') + ".svg",
88
+ alt: ""
89
+ });
90
+ },
91
+ multiple: true,
57
92
  disabled: disabled,
58
- onChange: setValue
59
- }));
93
+ onSelect: handleSelect
94
+ }, items.map(function (item) {
95
+ return /*#__PURE__*/React.createElement(DropdownMenu.Item, {
96
+ key: item.key
97
+ }, /*#__PURE__*/React.createElement("div", {
98
+ style: {
99
+ display: 'flex',
100
+ alignItems: 'center'
101
+ }
102
+ }, /*#__PURE__*/React.createElement("img", {
103
+ src: "/img/topo/editor/toolbar/" + item.icon + "/Normal.svg",
104
+ alt: ""
105
+ }), /*#__PURE__*/React.createElement("span", {
106
+ style: {
107
+ color: '#4d6277'
108
+ }
109
+ }, item.label)));
110
+ })));
60
111
  }
61
112
 
62
- export default FontStyleButton;
113
+ export default textStyleSettingRouter(FontStyleButton, {
114
+ names: ['bold', 'italic', 'underline']
115
+ });
@@ -15,7 +15,7 @@ function HistoryRedoButton(props) {
15
15
  tooltip: "\u6062\u590D",
16
16
  showLabel: showLabel
17
17
  }, /*#__PURE__*/React.createElement(ButtonBox, null, /*#__PURE__*/React.createElement("img", {
18
- src: "/img/topo/editor/toolbar/redo/" + (disabled ? 'Disable' : 'Normal') + ".svg",
18
+ src: "/img/topo/editor/toolbar/undo/" + (disabled ? 'Disable' : 'Normal') + ".svg",
19
19
  alt: ""
20
20
  })));
21
21
  }
@@ -14,7 +14,7 @@ function HistoryUndoButton(props) {
14
14
  return /*#__PURE__*/React.createElement(WidgetBox, {
15
15
  disabled: disabled,
16
16
  label: "\u64A4\u9500",
17
- tooltip: "\u64A4\u9500",
17
+ tooltip: disabled ? '无法撤销' : '撤销(Ctrl/ ⌘+Z)',
18
18
  showLabel: showLabel
19
19
  }, /*#__PURE__*/React.createElement(ButtonBox, {
20
20
  disabled: disabled,
@@ -22,7 +22,7 @@ function HistoryUndoButton(props) {
22
22
  topo.historyManager.undo();
23
23
  }
24
24
  }, /*#__PURE__*/React.createElement("img", {
25
- src: "/img/topo/editor/toolbar/undo/" + (disabled ? 'Disable' : 'Normal') + ".svg",
25
+ src: "/img/topo/editor/toolbar/redo/" + (disabled ? 'Disable' : 'Normal') + ".svg",
26
26
  alt: ""
27
27
  })));
28
28
  }
@@ -0,0 +1,109 @@
1
+ import _Select from "@alifd/next/es/select";
2
+ import React, { useState, useEffect, useImperativeHandle } from 'react';
3
+ import styles from "./index.module.scss";
4
+ import PopUpContent from "./popUpContent";
5
+
6
+ var TopoIconSelect = function TopoIconSelect(props, ref) {
7
+ // 传入参数
8
+ var value = props.value,
9
+ iconList = props.iconList,
10
+ onChange = props.onChange;
11
+
12
+ var _useState = useState(value),
13
+ valueData = _useState[0],
14
+ setValue = _useState[1];
15
+
16
+ var _useState2 = useState(),
17
+ selectItem = _useState2[0],
18
+ setSelect = _useState2[1];
19
+
20
+ var _useState3 = useState(false),
21
+ visible = _useState3[0],
22
+ setVisible = _useState3[1];
23
+
24
+ useEffect(function () {
25
+ if (value) {
26
+ for (var i = 0; i < iconList.length; i++) {
27
+ var icons = iconList[i].icons;
28
+ var flag = false;
29
+
30
+ for (var m = 0; m < icons.length; m++) {
31
+ if (value === icons[m].id) {
32
+ flag = true;
33
+ setSelect(icons[m]);
34
+ break;
35
+ }
36
+ }
37
+
38
+ if (flag) {
39
+ break;
40
+ }
41
+ }
42
+ }
43
+ }, [value]);
44
+ useImperativeHandle(ref, function () {
45
+ return {
46
+ getSelectData: getSelectData
47
+ };
48
+ });
49
+
50
+ var handleChange = function handleChange(v) {
51
+ console.log('handleChange: ', v);
52
+
53
+ if (typeof onChange === 'function') {
54
+ onChange(v.id);
55
+ }
56
+
57
+ setSelect(v);
58
+ setValue(v.id);
59
+ setVisible(false);
60
+ };
61
+
62
+ var getSelectData = function getSelectData() {
63
+ return valueData;
64
+ };
65
+
66
+ var valueRender = function valueRender(v) {
67
+ return selectItem ? /*#__PURE__*/React.createElement("span", {
68
+ className: styles.selected
69
+ }, /*#__PURE__*/React.createElement("div", {
70
+ className: styles.iconImgWrapper
71
+ }, /*#__PURE__*/React.createElement("img", {
72
+ className: styles.iconImg,
73
+ alt: "",
74
+ src: selectItem === null || selectItem === void 0 ? void 0 : selectItem.url
75
+ })), /*#__PURE__*/React.createElement("span", {
76
+ className: styles.icontitle
77
+ }, selectItem === null || selectItem === void 0 ? void 0 : selectItem.name)) : null;
78
+ };
79
+
80
+ var onVisibleChange = function onVisibleChange(v) {
81
+ setVisible(v);
82
+ };
83
+
84
+ var popupContent = /*#__PURE__*/React.createElement(PopUpContent, {
85
+ iconList: iconList,
86
+ selectedId: selectItem === null || selectItem === void 0 ? void 0 : selectItem.id,
87
+ onChange: handleChange
88
+ });
89
+ var popupProps = {
90
+ triggerClickKeycode: [13, 32, 40] // space, enter, down-arrow
91
+
92
+ };
93
+ return /*#__PURE__*/React.createElement("div", {
94
+ className: styles.TopoIconSelect
95
+ }, /*#__PURE__*/React.createElement(_Select, {
96
+ placeholder: "\u8BF7\u9009\u62E9",
97
+ visible: visible,
98
+ className: styles.iconSelect,
99
+ onVisibleChange: onVisibleChange,
100
+ value: valueData,
101
+ valueRender: valueRender,
102
+ dataSource: iconList,
103
+ onChange: handleChange,
104
+ popupProps: popupProps,
105
+ popupContent: popupContent
106
+ }));
107
+ };
108
+
109
+ export default /*#__PURE__*/React.forwardRef(TopoIconSelect);