@riil-frontend/component-topology 6.0.0-alpha.30 → 6.0.0-alpha.31

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 (55) 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 +20 -20
  5. package/es/core/editor/components/EditorPlugin.js +2 -1
  6. package/es/core/editor/components/Sidebar/Sidebar.js +2 -1
  7. package/es/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +2 -3
  8. package/es/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +1 -0
  9. package/es/core/editor/components/Toolbar/buttons.js +5 -4
  10. package/es/core/editor/components/Toolbar/hooks/useFontStyleSetting.js +23 -6
  11. package/es/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +29 -9
  12. package/es/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +15 -0
  13. package/es/core/editor/components/Toolbar/widgets/FontColorButton.js +4 -0
  14. package/es/core/editor/components/Toolbar/widgets/FontStyleButton.js +82 -33
  15. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +20 -25
  16. package/es/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +22 -6
  17. package/es/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +12 -9
  18. package/es/core/editor/components/Toolbar/widgets/components/DropdownButton.js +19 -6
  19. package/es/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +8 -5
  20. package/es/core/editor/components/settings/CloseablePanel.js +7 -2
  21. package/es/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  22. package/es/core/editor/components/settings/PropertyView.js +2 -6
  23. package/es/core/editor/components/settings/common/AlignSetting/index.js +1 -2
  24. package/es/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  25. package/es/core/editor/utils/textStyleUtil.js +0 -0
  26. package/es/core/hooks/usePolling.js +2 -5
  27. package/es/core/models/AttributeMetricDisplay.js +4 -0
  28. package/es/core/models/TopoApp.js +1 -1
  29. package/es/utils/htElementUtils.js +3 -0
  30. package/lib/core/editor/components/EditorPlugin.js +3 -1
  31. package/lib/core/editor/components/Sidebar/Sidebar.js +2 -1
  32. package/lib/core/editor/components/Sidebar/views/CanvasPanel/CanvasPanel.js +2 -3
  33. package/lib/core/editor/components/Sidebar/views/ImagePanel/HtImagePalette.js +1 -0
  34. package/lib/core/editor/components/Toolbar/buttons.js +5 -4
  35. package/lib/core/editor/components/Toolbar/hooks/useFontStyleSetting.js +20 -6
  36. package/lib/core/editor/components/Toolbar/widgets/EdgeColorButton/EdgeColorButton.js +29 -8
  37. package/lib/core/editor/components/Toolbar/widgets/EdgeTypeButton/index.js +15 -0
  38. package/lib/core/editor/components/Toolbar/widgets/FontColorButton.js +5 -0
  39. package/lib/core/editor/components/Toolbar/widgets/FontStyleButton.js +88 -33
  40. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.js +20 -25
  41. package/lib/core/editor/components/Toolbar/widgets/NodeAlignWidget.module.scss +22 -6
  42. package/lib/core/editor/components/Toolbar/widgets/NodeSizeButton/NodeSizeButton.js +11 -9
  43. package/lib/core/editor/components/Toolbar/widgets/components/DropdownButton.js +18 -6
  44. package/lib/core/editor/components/Toolbar/widgets/components/DropdownMenu.js +10 -5
  45. package/lib/core/editor/components/settings/CloseablePanel.js +8 -2
  46. package/lib/core/editor/components/settings/CloseablePanel.module.scss +9 -0
  47. package/lib/core/editor/components/settings/PropertyView.js +3 -7
  48. package/lib/core/editor/components/settings/common/AlignSetting/index.js +1 -2
  49. package/lib/core/editor/components/settings/propertyViews/edge/CommonEdgePropertyView.js +7 -1
  50. package/lib/core/editor/utils/textStyleUtil.js +1 -0
  51. package/lib/core/hooks/usePolling.js +2 -5
  52. package/lib/core/models/AttributeMetricDisplay.js +4 -0
  53. package/lib/core/models/TopoApp.js +1 -1
  54. package/lib/utils/htElementUtils.js +5 -0
  55. package/package.json +2 -2
@@ -1,12 +1,28 @@
1
1
  .leftInput{
2
- background: url('/img/topo/editor/toolbar/对齐/Disable.svg')no-repeat 5px center;
3
- background-position: right center;
4
- width: 100px;
2
+ width: 100px !important;
5
3
  margin-right: 10px;
6
4
  margin-left: 5px;
5
+ :global{
6
+ input{
7
+ background: url('/img/topo/editor/toolbar/对齐/水平间距_normal.svg')no-repeat 5px center !important;
8
+ background-position: right center !important;
9
+ }
10
+ .next-disabled input{
11
+ background: url('/img/topo/editor/toolbar/对齐/水平间距_disable.svg')no-repeat 5px center !important;
12
+ background-position: right center !important;
13
+ }
14
+ }
7
15
  }
8
16
  .rightInput{
9
- width: 100px;
10
- background: url('/img/topo/editor/toolbar/对齐/Disable.svg')no-repeat 5px center;
11
- background-position: right center;
17
+ width: 100px !important;
18
+ :global{
19
+ input{
20
+ background: url('/img/topo/editor/toolbar/对齐/垂直间距 _normal.svg')no-repeat 5px center !important;
21
+ background-position: right center !important;
22
+ }
23
+ .next-disabled input{
24
+ background: url('/img/topo/editor/toolbar/对齐/垂直间距_disable.svg')no-repeat 5px center !important;
25
+ background-position: right center !important;
26
+ }
27
+ }
12
28
  }
@@ -17,8 +17,6 @@ var _useSettingRuntimeState = _interopRequireDefault(require("../../../settings/
17
17
 
18
18
  var _WidgetBox = _interopRequireDefault(require("../WidgetBox"));
19
19
 
20
- var _BoxBackgroundSetting = _interopRequireDefault(require("./BoxBackgroundSetting"));
21
-
22
20
  var _NodeSizeButtonModule = _interopRequireDefault(require("./NodeSizeButton.module.scss"));
23
21
 
24
22
  var _htElementUtils = require("../../../../../../utils/htElementUtils");
@@ -48,10 +46,15 @@ function NodeSizeButton(props) {
48
46
  setSize = _useState2[1]; // 选中的元素
49
47
 
50
48
 
51
- var selection = topo.selectionManager.useHtSelection();
49
+ var selection = topo.selectionManager.useSelection();
52
50
  var settingRuntimeState = (0, _useSettingRuntimeState["default"])();
53
51
  (0, _react.useEffect)(function () {
54
- var nodes = selection.filter(function (ele) {
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) {
55
58
  return (0, _htElementUtils.isGroup)(ele) || (0, _htElementUtils.isNode)(ele);
56
59
  });
57
60
 
@@ -76,12 +79,11 @@ function NodeSizeButton(props) {
76
79
  var _onChange = function onChange(prop) {
77
80
  var name = prop.name,
78
81
  value = prop.value;
79
- var gv = topo.view.topoClient.getGraphView();
80
82
  var element = topo.getSelectionModel().getFirstData();
81
83
 
82
- if (name === "width") {
84
+ if (name === 'width') {
83
85
  element.setWidth(value);
84
- } else if (name === "height") {
86
+ } else if (name === 'height') {
85
87
  element.setHeight(value);
86
88
  }
87
89
  };
@@ -125,12 +127,12 @@ function NodeSizeButton(props) {
125
127
  topo.historyManager.beginTransaction();
126
128
 
127
129
  _onChange({
128
- name: "width",
130
+ name: 'width',
129
131
  value: size.width
130
132
  });
131
133
 
132
134
  _onChange({
133
- name: "height",
135
+ name: 'height',
134
136
  value: size.height
135
137
  });
136
138
 
@@ -29,22 +29,34 @@ function DropdownButton(props) {
29
29
  children = props.children;
30
30
 
31
31
  var _useState = (0, _react.useState)(false),
32
- active = _useState[0],
33
- setActive = _useState[1];
32
+ visible = _useState[0],
33
+ setVisible = _useState[1];
34
34
 
35
35
  var button = /*#__PURE__*/_react["default"].createElement(_ButtonBox["default"], {
36
- active: active,
36
+ active: visible,
37
37
  disabled: disabled,
38
38
  showArrow: showArrow
39
39
  }, trigger);
40
40
 
41
+ var renderContent = function renderContent() {
42
+ if (!visible) {
43
+ return /*#__PURE__*/_react["default"].createElement("div", null);
44
+ }
45
+
46
+ if (showContainer) {
47
+ return /*#__PURE__*/_react["default"].createElement(PopupCard, null, children);
48
+ }
49
+
50
+ return children;
51
+ };
52
+
41
53
  return /*#__PURE__*/_react["default"].createElement(_dropdown["default"], {
42
- visible: active,
54
+ visible: visible,
43
55
  disabled: disabled,
44
56
  trigger: button,
45
57
  triggerType: "click",
46
- onVisibleChange: setActive
47
- }, !showContainer ? children : /*#__PURE__*/_react["default"].createElement(PopupCard, null, children));
58
+ onVisibleChange: setVisible
59
+ }, renderContent());
48
60
  }
49
61
 
50
62
  DropdownButton.propTypes = {
@@ -16,18 +16,23 @@ 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
21
  valueRender = props.valueRender;
21
22
  var selectedKeys = Array.isArray(value) ? value : [value];
22
23
  var valueDisplay = valueRender ? valueRender(value) : value;
24
+ var selectMode = multiple ? 'multiple' : 'single';
25
+
26
+ var menu = /*#__PURE__*/_react["default"].createElement(_menu["default"], {
27
+ selectMode: selectMode,
28
+ selectedKeys: selectedKeys,
29
+ onSelect: onChange
30
+ }, children);
31
+
23
32
  return /*#__PURE__*/_react["default"].createElement(_DropdownButton["default"], {
24
33
  trigger: valueDisplay,
25
34
  showContainer: false
26
- }, /*#__PURE__*/_react["default"].createElement(_menu["default"], {
27
- selectMode: "single",
28
- selectedKeys: selectedKeys,
29
- onSelect: onChange
30
- }, children));
35
+ }, multiple ? /*#__PURE__*/_react["default"].createElement("div", null, menu) : menu);
31
36
  }
32
37
 
33
38
  _DropdownButton["default"].propTypes = {
@@ -11,12 +11,16 @@ var _icon = _interopRequireDefault(require("@alifd/next/lib/icon"));
11
11
 
12
12
  var _react = _interopRequireDefault(require("react"));
13
13
 
14
+ var _CloseablePanelModule = _interopRequireDefault(require("./CloseablePanel.module.scss"));
15
+
14
16
  function CloseablePanel(props) {
15
17
  var prefix = props.prefix,
16
18
  title = props.title,
17
19
  onClose = props.onClose,
18
20
  children = props.children;
19
- return /*#__PURE__*/_react["default"].createElement("div", null, /*#__PURE__*/_react["default"].createElement("div", {
21
+ return /*#__PURE__*/_react["default"].createElement("div", {
22
+ className: _CloseablePanelModule["default"].panel
23
+ }, /*#__PURE__*/_react["default"].createElement("div", {
20
24
  className: prefix + "drawer-header",
21
25
  role: "heading",
22
26
  "aria-level": "1"
@@ -28,7 +32,9 @@ function CloseablePanel(props) {
28
32
  }, /*#__PURE__*/_react["default"].createElement(_icon["default"], {
29
33
  type: "close",
30
34
  className: "next-drawer-close-icon"
31
- }))), /*#__PURE__*/_react["default"].createElement("div", null, children));
35
+ }))), /*#__PURE__*/_react["default"].createElement("div", {
36
+ className: _CloseablePanelModule["default"].body
37
+ }, children));
32
38
  }
33
39
 
34
40
  CloseablePanel.defaultProps = {
@@ -0,0 +1,9 @@
1
+ .panel {
2
+ height: 100%;
3
+ display: flex;
4
+ flex-direction: column;
5
+ background: #FFFFFF;
6
+ }
7
+ .body {
8
+ flex: 1;
9
+ }
@@ -11,12 +11,12 @@ var _classnames = _interopRequireDefault(require("classnames"));
11
11
 
12
12
  var _Settings = _interopRequireDefault(require("./Settings"));
13
13
 
14
- var _SettingsModule = _interopRequireDefault(require("./Settings.module.scss"));
15
-
16
14
  var _OpenPropertyPanelListener = _interopRequireDefault(require("./OpenPropertyPanelListener"));
17
15
 
18
16
  var _CloseablePanel = _interopRequireDefault(require("./CloseablePanel"));
19
17
 
18
+ var _SettingsModule = _interopRequireDefault(require("./Settings.module.scss"));
19
+
20
20
  function PropertyView(props) {
21
21
  var _classNames;
22
22
 
@@ -41,10 +41,6 @@ function PropertyView(props) {
41
41
  }
42
42
 
43
43
  var renderContent = function renderContent() {
44
- if (!graphLoaded) {
45
- return null;
46
- }
47
-
48
44
  return /*#__PURE__*/_react["default"].createElement(_OpenPropertyPanelListener["default"], {
49
45
  topo: topo
50
46
  }, /*#__PURE__*/_react["default"].createElement(_Settings["default"], {
@@ -65,5 +61,5 @@ function PropertyView(props) {
65
61
  propertyPanelVisible: false
66
62
  });
67
63
  }
68
- }), renderContent());
64
+ }, renderContent()));
69
65
  }
@@ -23,8 +23,7 @@ function AlignSetting(props) {
23
23
  return !(0, _htElementUtils.isLayer)(ele) && !(0, _htElementUtils.isEdge)(ele);
24
24
  }); // console.info("element--selectList", element, selectList);
25
25
 
26
- topo.view.topoClient.htTopoClient.setAlignmentBySelectionNodes(type, nodes); // topo.view.topoClient.htTopoClient.setElementsSpace(nodes,'h',300)
27
-
26
+ topo.view.topoClient.htTopoClient.setAlignmentBySelectionNodes(type, nodes);
28
27
  topo.historyManager.endTransaction();
29
28
  };
30
29
 
@@ -62,8 +62,10 @@ function CommonEdgePropertyView(props) {
62
62
  }, [values]);
63
63
 
64
64
  var setLineColor = function setLineColor(color) {
65
- var style = edge.a("styles") || {};
65
+ // 同时修改实线、虚线
66
66
  edge.s("edge.color", color);
67
+ edge.s("edge.dash.color", color);
68
+ var style = edge.a("styles") || {};
67
69
  edge.a("styles", (0, _extends2["default"])({}, style, {
68
70
  color: color
69
71
  }));
@@ -114,6 +116,10 @@ function CommonEdgePropertyView(props) {
114
116
  style: {
115
117
  width: "100%"
116
118
  },
119
+ onChange: function onChange(val) {
120
+ // 同时修改实线、虚线的线宽
121
+ edge.s('edge.dash.width', val);
122
+ },
117
123
  onFocus: function onFocus() {
118
124
  topo.historyManager.beginTransaction();
119
125
  },
@@ -0,0 +1 @@
1
+ "use strict";
@@ -74,11 +74,8 @@ var usePolling = function usePolling(props) {
74
74
 
75
75
 
76
76
  (0, _react.useEffect)(function () {
77
- var isViewer = topoState.viewState === 'view';
78
-
79
- if (topo.options.enableDefaultMetricLoader && isViewer) {
77
+ if (topo.options.enableDefaultMetricLoader) {
80
78
  _rlog["default"].debug('usePolling.useEffect: 开始轮询', {
81
- isViewer: isViewer,
82
79
  pollingSwitch: pollingSwitch,
83
80
  resIdsList: resIdsList,
84
81
  resourceOverviewState: resourceOverviewState,
@@ -95,7 +92,7 @@ var usePolling = function usePolling(props) {
95
92
  stopPoll();
96
93
  }
97
94
  };
98
- }, [topoState.viewState, pollingSwitch, resIdsList, displayConfig, resourceOverviewState.id, resourceOverviewState.metricCodes]);
95
+ }, [pollingSwitch, resIdsList, displayConfig, resourceOverviewState.id, resourceOverviewState.metricCodes]);
99
96
  /**
100
97
  *
101
98
  * @returns {{id, attributes: object[], metrics: object[]}[]} 属性和指标
@@ -668,7 +668,11 @@ var AttributeMetricDisplay = /*#__PURE__*/function () {
668
668
  var htTopo = topo.getHtTopo();
669
669
 
670
670
  if (htTopo) {
671
+ var _topo$historyManager, _topo$historyManager2;
672
+
673
+ (_topo$historyManager = topo.historyManager) === null || _topo$historyManager === void 0 ? void 0 : _topo$historyManager.setDisabled(true, '加载标注');
671
674
  htTopo.loadTagAndTip(JSON.parse(JSON.stringify(elementTagsAndTips)));
675
+ (_topo$historyManager2 = topo.historyManager) === null || _topo$historyManager2 === void 0 ? void 0 : _topo$historyManager2.setDisabled(false, '加载标注');
672
676
  }
673
677
  }
674
678
  /**
@@ -52,7 +52,7 @@ var _ElementTagTipConfig = _interopRequireDefault(require("./tagstips/ElementTag
52
52
  var _SelectionManager = _interopRequireDefault(require("./SelectionManager"));
53
53
 
54
54
  // eslint-disable-next-line no-undef
55
- var version = typeof "6.0.0-alpha.30" === 'string' ? "6.0.0-alpha.30" : null;
55
+ var version = typeof "6.0.0-alpha.31" === 'string' ? "6.0.0-alpha.31" : null;
56
56
  console.info("\u62D3\u6251\u7248\u672C: " + version);
57
57
  /**
58
58
  * 拓扑显示和编辑
@@ -31,6 +31,7 @@ exports.isExistedElement = isExistedElement;
31
31
  exports.isGroup = isGroup;
32
32
  exports.isLayer = isLayer;
33
33
  exports.isNode = isNode;
34
+ exports.isText = isText;
34
35
  exports.isValidEdge = isValidEdge;
35
36
  exports.setElementRuntimeStyle = setElementRuntimeStyle;
36
37
 
@@ -95,6 +96,10 @@ function isLayer(element) {
95
96
  return element instanceof ht.Grid;
96
97
  }
97
98
 
99
+ function isText(element) {
100
+ return element instanceof ht.Text && element.a('isText');
101
+ }
102
+
98
103
  function getElements(dataModel) {
99
104
  // console.error(111, dataModel.getDatas().getArray())
100
105
  return dataModel.getDatas().getArray();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@riil-frontend/component-topology",
3
- "version": "6.0.0-alpha.30",
3
+ "version": "6.0.0-alpha.31",
4
4
  "description": "拓扑",
5
5
  "scripts": {
6
6
  "start": "build-scripts start",
@@ -115,6 +115,6 @@
115
115
  "access": "public"
116
116
  },
117
117
  "license": "MIT",
118
- "homepage": "https://unpkg.com/@riil-frontend/component-topology@6.0.0-alpha.30/build/index.html",
118
+ "homepage": "https://unpkg.com/@riil-frontend/component-topology@6.0.0-alpha.31/build/index.html",
119
119
  "gitHead": "2da19ffccbb7ca60a8acf396e39f542c68bb33f5"
120
120
  }