@teambit/graph 0.0.752 → 0.0.755
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.
- package/dist/graph.compare.section.d.ts +13 -0
- package/dist/graph.compare.section.js +57 -0
- package/dist/graph.compare.section.js.map +1 -0
- package/dist/graph.ui.runtime.d.ts +2 -1
- package/dist/graph.ui.runtime.js +28 -2
- package/dist/graph.ui.runtime.js.map +1 -1
- package/dist/index.d.ts +12 -7
- package/dist/index.js +149 -9
- package/dist/index.js.map +1 -1
- package/dist/ui/component-node/component-node.js +27 -1
- package/dist/ui/component-node/component-node.js.map +1 -1
- package/dist/ui/component-node/component-node.module.scss +8 -0
- package/dist/ui/component-node/index.d.ts +12 -1
- package/dist/ui/component-node/index.js +56 -0
- package/dist/ui/component-node/index.js.map +1 -1
- package/dist/ui/component-node/variants.d.ts +2 -2
- package/dist/ui/component-node/variants.js +3 -1
- package/dist/ui/component-node/variants.js.map +1 -1
- package/dist/ui/dependencies-compare/compare-graph-model.d.ts +7 -0
- package/dist/ui/dependencies-compare/compare-graph-model.js +29 -0
- package/dist/ui/dependencies-compare/compare-graph-model.js.map +1 -0
- package/dist/ui/dependencies-compare/compare-node-model.d.ts +9 -0
- package/dist/ui/dependencies-compare/compare-node-model.js +45 -0
- package/dist/ui/dependencies-compare/compare-node-model.js.map +1 -0
- package/dist/ui/dependencies-compare/dependencies-compare.d.ts +2 -0
- package/dist/ui/dependencies-compare/dependencies-compare.js +205 -0
- package/dist/ui/dependencies-compare/dependencies-compare.js.map +1 -0
- package/dist/ui/dependencies-compare/dependencies-compare.module.scss +12 -0
- package/dist/ui/dependencies-compare/dependency-compare-node.d.ts +7 -0
- package/dist/ui/dependencies-compare/dependency-compare-node.js +271 -0
- package/dist/ui/dependencies-compare/dependency-compare-node.js.map +1 -0
- package/dist/ui/dependencies-compare/dependency-compare-node.module.scss +21 -0
- package/dist/ui/dependencies-compare/dependency-compare-variants.module.scss +21 -0
- package/dist/ui/dependencies-compare/diff-graph.d.ts +4 -0
- package/dist/ui/dependencies-compare/diff-graph.js +96 -0
- package/dist/ui/dependencies-compare/diff-graph.js.map +1 -0
- package/dist/ui/dependencies-compare/index.d.ts +1 -0
- package/dist/ui/dependencies-compare/index.js +23 -0
- package/dist/ui/dependencies-compare/index.js.map +1 -0
- package/dist/ui/dependencies-graph/calc-elements.d.ts +3 -3
- package/dist/ui/dependencies-graph/calc-elements.js.map +1 -1
- package/dist/ui/dependencies-graph/calc-layout.d.ts +2 -2
- package/dist/ui/dependencies-graph/calc-layout.js.map +1 -1
- package/dist/ui/dependencies-graph/dependencies-graph.d.ts +2 -2
- package/dist/ui/dependencies-graph/dependencies-graph.js.map +1 -1
- package/dist/ui/dependencies-graph/index.d.ts +9 -0
- package/dist/ui/dependencies-graph/index.js +96 -0
- package/dist/ui/dependencies-graph/index.js.map +1 -1
- package/dist/ui/graph-page/index.d.ts +5 -0
- package/dist/ui/graph-page/index.js +40 -0
- package/dist/ui/graph-page/index.js.map +1 -1
- package/dist/ui/query/graph-model.d.ts +5 -5
- package/dist/ui/query/graph-model.js.map +1 -1
- package/dist/ui/query/index.d.ts +1 -0
- package/dist/ui/query/index.js +16 -0
- package/dist/ui/query/index.js.map +1 -1
- package/dist/ui/query/use-graph-query.d.ts +2 -2
- package/dist/ui/query/use-graph-query.js +2 -1
- package/dist/ui/query/use-graph-query.js.map +1 -1
- package/dist/ui/query/use-graph.d.ts +1 -1
- package/graph.compare.section.tsx +16 -0
- package/graph.ui.runtime.tsx +14 -4
- package/package-tar/teambit-graph-0.0.755.tgz +0 -0
- package/package.json +15 -8
- package/{preview-1654399579544.js → preview-1654697373869.js} +2 -2
- package/ui/component-node/component-node.module.scss +8 -0
- package/ui/component-node/component-node.tsx +5 -1
- package/ui/component-node/index.ts +6 -1
- package/ui/component-node/variants.ts +2 -2
- package/ui/dependencies-compare/compare-graph-model.ts +8 -0
- package/ui/dependencies-compare/compare-node-model.ts +11 -0
- package/ui/dependencies-compare/dependencies-compare.module.scss +12 -0
- package/ui/dependencies-compare/dependencies-compare.tsx +109 -0
- package/ui/dependencies-compare/dependency-compare-node.module.scss +21 -0
- package/ui/dependencies-compare/dependency-compare-node.tsx +99 -0
- package/ui/dependencies-compare/dependency-compare-variants.module.scss +21 -0
- package/ui/dependencies-compare/diff-graph.ts +69 -0
- package/ui/dependencies-compare/index.ts +1 -0
- package/ui/dependencies-graph/calc-elements.tsx +3 -3
- package/ui/dependencies-graph/calc-layout.tsx +2 -2
- package/ui/dependencies-graph/dependencies-graph.tsx +8 -8
- package/ui/dependencies-graph/index.ts +9 -0
- package/ui/graph-page/index.ts +6 -0
- package/ui/query/graph-model.ts +3 -2
- package/ui/query/index.ts +1 -0
- package/ui/query/use-graph-query.ts +3 -2
- package/package-tar/teambit-graph-0.0.752.tgz +0 -0
@@ -0,0 +1,21 @@
|
|
1
|
+
$success: #37b26c;
|
2
|
+
$borderLabelHeight: 20px;
|
3
|
+
|
4
|
+
.root {
|
5
|
+
border-color: $success;
|
6
|
+
border-top-width: 20px;
|
7
|
+
|
8
|
+
border-radius: 10px;
|
9
|
+
box-shadow: 0px 0px 0px 2px #d0f1de, var(--bit-shadow-hover-medium);
|
10
|
+
|
11
|
+
&:before {
|
12
|
+
content: 'Current component';
|
13
|
+
position: absolute;
|
14
|
+
top: 1px;
|
15
|
+
left: 10px;
|
16
|
+
|
17
|
+
font-size: $borderLabelHeight * 0.5;
|
18
|
+
color: white;
|
19
|
+
line-height: $borderLabelHeight;
|
20
|
+
}
|
21
|
+
}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
import { ComponentID } from '@teambit/component';
|
2
|
+
import { EdgeModel, GraphModel, NodeModel } from '@teambit/graph';
|
3
|
+
import { CompareGraphModel } from './compare-graph-model';
|
4
|
+
export declare function diffGraph(baseGraph?: GraphModel<NodeModel, EdgeModel>, compareGraph?: GraphModel<NodeModel, EdgeModel>, baseId?: ComponentID): CompareGraphModel | null;
|
@@ -0,0 +1,96 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
|
5
|
+
require("core-js/modules/es.array.iterator.js");
|
6
|
+
|
7
|
+
require("core-js/modules/es.regexp.exec.js");
|
8
|
+
|
9
|
+
Object.defineProperty(exports, "__esModule", {
|
10
|
+
value: true
|
11
|
+
});
|
12
|
+
exports.diffGraph = diffGraph;
|
13
|
+
|
14
|
+
function _defineProperty2() {
|
15
|
+
const data = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
16
|
+
|
17
|
+
_defineProperty2 = function () {
|
18
|
+
return data;
|
19
|
+
};
|
20
|
+
|
21
|
+
return data;
|
22
|
+
}
|
23
|
+
|
24
|
+
function _compareGraphModel() {
|
25
|
+
const data = require("./compare-graph-model");
|
26
|
+
|
27
|
+
_compareGraphModel = function () {
|
28
|
+
return data;
|
29
|
+
};
|
30
|
+
|
31
|
+
return data;
|
32
|
+
}
|
33
|
+
|
34
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
35
|
+
|
36
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2().default)(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
|
37
|
+
|
38
|
+
const toShortId = node => node.component.id.toStringWithoutVersion(); // this is to get a key with versions ignored so that we'll have a unique set of component nodes
|
39
|
+
|
40
|
+
|
41
|
+
const toShortIdFromNodeId = nodeId => nodeId.split('@')[0];
|
42
|
+
|
43
|
+
const delim = '::';
|
44
|
+
|
45
|
+
const getEdgeId = _e => {
|
46
|
+
return `${toShortIdFromNodeId(_e.sourceId)}${delim}${toShortIdFromNodeId(_e.targetId)}`;
|
47
|
+
};
|
48
|
+
|
49
|
+
function diffGraph(baseGraph, compareGraph, baseId) {
|
50
|
+
if (!baseGraph || !compareGraph || !baseId) return null;
|
51
|
+
const baseNodes = baseGraph.nodes;
|
52
|
+
const compareNodes = compareGraph.nodes;
|
53
|
+
const baseNodesMap = new Map(baseNodes.map(n => [toShortId(n), n]));
|
54
|
+
const compareNodesMap = new Map(compareNodes.map(n => [toShortId(n), n]));
|
55
|
+
const allNodes = [];
|
56
|
+
|
57
|
+
for (const baseNode of baseNodes) {
|
58
|
+
const compareNode = compareNodesMap.get(toShortId(baseNode));
|
59
|
+
|
60
|
+
if (compareNode) {
|
61
|
+
allNodes.push(_objectSpread(_objectSpread({}, baseNode), {}, {
|
62
|
+
compareVersion: compareNode.component.version,
|
63
|
+
status: compareNode.component.id.isEqual(baseNode.component.id) ? undefined : 'modified'
|
64
|
+
}));
|
65
|
+
} else {
|
66
|
+
allNodes.push(_objectSpread(_objectSpread({}, baseNode), {}, {
|
67
|
+
compareVersion: baseNode.component.version,
|
68
|
+
status: 'deleted'
|
69
|
+
}));
|
70
|
+
}
|
71
|
+
}
|
72
|
+
|
73
|
+
const newNodes = compareNodes.filter(n => !baseNodesMap.has(toShortId(n)));
|
74
|
+
|
75
|
+
for (const node of newNodes) {
|
76
|
+
allNodes.push(_objectSpread(_objectSpread({}, node), {}, {
|
77
|
+
compareVersion: '',
|
78
|
+
status: 'new'
|
79
|
+
}));
|
80
|
+
}
|
81
|
+
|
82
|
+
const allNodesMap = new Map(allNodes.map(n => [toShortId(n), n]));
|
83
|
+
const baseEdgesMap = new Map(baseGraph.edges.map(baseEdge => [getEdgeId(baseEdge), baseEdge]));
|
84
|
+
const edgesOnlyInCompare = compareGraph.edges.filter(compareEdge => !baseEdgesMap.has(getEdgeId(compareEdge))).map(compareEdge => {
|
85
|
+
var _allNodesMap$get, _allNodesMap$get2;
|
86
|
+
|
87
|
+
return _objectSpread(_objectSpread({}, compareEdge), {}, {
|
88
|
+
sourceId: ((_allNodesMap$get = allNodesMap.get(toShortIdFromNodeId(compareEdge.sourceId))) === null || _allNodesMap$get === void 0 ? void 0 : _allNodesMap$get.id.toString()) || baseId.toString(),
|
89
|
+
targetId: ((_allNodesMap$get2 = allNodesMap.get(toShortIdFromNodeId(compareEdge.targetId))) === null || _allNodesMap$get2 === void 0 ? void 0 : _allNodesMap$get2.id.toString()) || baseId.toString()
|
90
|
+
});
|
91
|
+
});
|
92
|
+
const allEdges = [...baseGraph.edges, ...edgesOnlyInCompare];
|
93
|
+
return new (_compareGraphModel().CompareGraphModel)(allNodes, allEdges);
|
94
|
+
}
|
95
|
+
|
96
|
+
//# sourceMappingURL=diff-graph.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":["toShortId","node","component","id","toStringWithoutVersion","toShortIdFromNodeId","nodeId","split","delim","getEdgeId","_e","sourceId","targetId","diffGraph","baseGraph","compareGraph","baseId","baseNodes","nodes","compareNodes","baseNodesMap","Map","map","n","compareNodesMap","allNodes","baseNode","compareNode","get","push","compareVersion","version","status","isEqual","undefined","newNodes","filter","has","allNodesMap","baseEdgesMap","edges","baseEdge","edgesOnlyInCompare","compareEdge","toString","allEdges","CompareGraphModel"],"sources":["diff-graph.ts"],"sourcesContent":["import { ComponentID } from '@teambit/component';\nimport { EdgeModel, GraphModel, NodeModel } from '@teambit/graph';\nimport { CompareGraphModel } from './compare-graph-model';\nimport { CompareNodeModel } from './compare-node-model';\n\nconst toShortId = (node: NodeModel) => node.component.id.toStringWithoutVersion();\n\n// this is to get a key with versions ignored so that we'll have a unique set of component nodes\nconst toShortIdFromNodeId = (nodeId: string) => nodeId.split('@')[0];\n\nconst delim = '::';\n\nconst getEdgeId = (_e: EdgeModel) => {\n return `${toShortIdFromNodeId(_e.sourceId)}${delim}${toShortIdFromNodeId(_e.targetId)}`;\n};\n\nexport function diffGraph(\n baseGraph?: GraphModel<NodeModel, EdgeModel>,\n compareGraph?: GraphModel<NodeModel, EdgeModel>,\n baseId?: ComponentID\n) {\n if (!baseGraph || !compareGraph || !baseId) return null;\n\n const baseNodes = baseGraph.nodes;\n const compareNodes = compareGraph.nodes;\n\n const baseNodesMap = new Map<string, NodeModel>(baseNodes.map((n) => [toShortId(n), n]));\n const compareNodesMap = new Map<string, NodeModel>(compareNodes.map((n) => [toShortId(n), n]));\n\n const allNodes: Array<CompareNodeModel> = [];\n for (const baseNode of baseNodes) {\n const compareNode = compareNodesMap.get(toShortId(baseNode));\n if (compareNode) {\n allNodes.push({\n ...baseNode,\n compareVersion: compareNode.component.version,\n status: compareNode.component.id.isEqual(baseNode.component.id) ? undefined : 'modified',\n });\n } else {\n allNodes.push({\n ...baseNode,\n compareVersion: baseNode.component.version,\n status: 'deleted',\n });\n }\n }\n\n const newNodes = compareNodes.filter((n) => !baseNodesMap.has(toShortId(n)));\n\n for (const node of newNodes) {\n allNodes.push({\n ...node,\n compareVersion: '',\n status: 'new',\n });\n }\n const allNodesMap = new Map<string, CompareNodeModel>(allNodes.map((n) => [toShortId(n), n]));\n\n const baseEdgesMap = new Map<string, EdgeModel>(baseGraph.edges.map((baseEdge) => [getEdgeId(baseEdge), baseEdge]));\n const edgesOnlyInCompare = compareGraph.edges\n .filter((compareEdge) => !baseEdgesMap.has(getEdgeId(compareEdge)))\n .map((compareEdge) => ({\n ...compareEdge,\n sourceId: allNodesMap.get(toShortIdFromNodeId(compareEdge.sourceId))?.id.toString() || baseId.toString(),\n targetId: allNodesMap.get(toShortIdFromNodeId(compareEdge.targetId))?.id.toString() || baseId.toString(),\n }));\n const allEdges = [...baseGraph.edges, ...edgesOnlyInCompare];\n return new CompareGraphModel(allNodes, allEdges);\n}\n"],"mappings":"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"}
|
@@ -0,0 +1 @@
|
|
1
|
+
export { DependenciesCompare } from './dependencies-compare';
|
@@ -0,0 +1,23 @@
|
|
1
|
+
"use strict";
|
2
|
+
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
4
|
+
value: true
|
5
|
+
});
|
6
|
+
Object.defineProperty(exports, "DependenciesCompare", {
|
7
|
+
enumerable: true,
|
8
|
+
get: function () {
|
9
|
+
return _dependenciesCompare().DependenciesCompare;
|
10
|
+
}
|
11
|
+
});
|
12
|
+
|
13
|
+
function _dependenciesCompare() {
|
14
|
+
const data = require("./dependencies-compare");
|
15
|
+
|
16
|
+
_dependenciesCompare = function () {
|
17
|
+
return data;
|
18
|
+
};
|
19
|
+
|
20
|
+
return data;
|
21
|
+
}
|
22
|
+
|
23
|
+
//# sourceMappingURL=index.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { DependenciesCompare } from './dependencies-compare';\n"],"mappings":";;;;;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA"}
|
@@ -1,11 +1,11 @@
|
|
1
|
-
import {
|
1
|
+
import { Edge, Node } from 'react-flow-renderer';
|
2
2
|
import { ComponentID } from '@teambit/component';
|
3
|
-
import { GraphModel } from '../query';
|
3
|
+
import { EdgeModel, GraphModel, NodeModel } from '../query';
|
4
4
|
declare type ElementsOptions = {
|
5
5
|
rootNode?: ComponentID;
|
6
6
|
};
|
7
7
|
/**
|
8
8
|
* generate Nodes and Edges for the ReactFlowRenderer graph renderer
|
9
9
|
*/
|
10
|
-
export declare function calcElements(graph: GraphModel | undefined, { rootNode }: ElementsOptions): (Node<any> | Edge<any>)[];
|
10
|
+
export declare function calcElements(graph: GraphModel<NodeModel, EdgeModel> | undefined, { rootNode }: ElementsOptions): (Node<any> | Edge<any>)[];
|
11
11
|
export {};
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["calcElements","graph","rootNode","useMemo","positions","calcLayout","nodes","Array","from","values","map","x","id","type","data","node","component","isEqual","ignoreVersion","undefined","position","get","y","edges","e","sourceId","targetId","source","target","label","depTypeToLabel","dependencyLifecycleType","labelBgPadding","className","depTypeToClass","arrowHeadType","ArrowHeadType","Arrow"],"sources":["calc-elements.tsx"],"sourcesContent":["import { useMemo } from 'react';\nimport {
|
1
|
+
{"version":3,"names":["calcElements","graph","rootNode","useMemo","positions","calcLayout","nodes","Array","from","values","map","x","id","type","data","node","component","isEqual","ignoreVersion","undefined","position","get","y","edges","e","sourceId","targetId","source","target","label","depTypeToLabel","dependencyLifecycleType","labelBgPadding","className","depTypeToClass","arrowHeadType","ArrowHeadType","Arrow"],"sources":["calc-elements.tsx"],"sourcesContent":["import { useMemo } from 'react';\nimport { ArrowHeadType, Edge, Node } from 'react-flow-renderer';\nimport { ComponentID } from '@teambit/component';\nimport { calcLayout } from './calc-layout';\nimport { EdgeModel, GraphModel, NodeModel } from '../query';\n\nimport { depTypeToClass, depTypeToLabel } from './dep-edge';\n\ntype ElementsOptions = {\n rootNode?: ComponentID;\n};\n\n/**\n * generate Nodes and Edges for the ReactFlowRenderer graph renderer\n */\nexport function calcElements(graph: GraphModel<NodeModel, EdgeModel> | undefined, { rootNode }: ElementsOptions) {\n return useMemo(() => {\n if (!graph) return [];\n\n const positions = calcLayout(graph);\n\n const nodes: Node[] = Array.from(graph.nodes.values()).map((x) => {\n return {\n id: x.id,\n type: 'ComponentNode',\n data: {\n node: x,\n type: rootNode && x.component.id.isEqual(rootNode, { ignoreVersion: true }) ? 'root' : undefined,\n },\n position: positions.get(x.id) || { x: 0, y: 0 },\n };\n });\n\n const edges: Edge[] = graph.edges.map((e) => ({\n id: `_${e.sourceId}__${e.targetId}`,\n source: e.sourceId,\n target: e.targetId,\n label: depTypeToLabel(e.dependencyLifecycleType),\n labelBgPadding: [4, 4],\n type: 'smoothstep',\n className: depTypeToClass(e.dependencyLifecycleType),\n arrowHeadType: ArrowHeadType.Arrow,\n }));\n\n return [...nodes, ...edges];\n }, [graph]);\n}\n"],"mappings":";;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAGA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAMA;AACA;AACA;AACO,SAASA,YAAT,CAAsBC,KAAtB,EAA2E;EAAEC;AAAF,CAA3E,EAA0G;EAC/G,OAAO,IAAAC,gBAAA,EAAQ,MAAM;IACnB,IAAI,CAACF,KAAL,EAAY,OAAO,EAAP;IAEZ,MAAMG,SAAS,GAAG,IAAAC,wBAAA,EAAWJ,KAAX,CAAlB;IAEA,MAAMK,KAAa,GAAGC,KAAK,CAACC,IAAN,CAAWP,KAAK,CAACK,KAAN,CAAYG,MAAZ,EAAX,EAAiCC,GAAjC,CAAsCC,CAAD,IAAO;MAChE,OAAO;QACLC,EAAE,EAAED,CAAC,CAACC,EADD;QAELC,IAAI,EAAE,eAFD;QAGLC,IAAI,EAAE;UACJC,IAAI,EAAEJ,CADF;UAEJE,IAAI,EAAEX,QAAQ,IAAIS,CAAC,CAACK,SAAF,CAAYJ,EAAZ,CAAeK,OAAf,CAAuBf,QAAvB,EAAiC;YAAEgB,aAAa,EAAE;UAAjB,CAAjC,CAAZ,GAAwE,MAAxE,GAAiFC;QAFnF,CAHD;QAOLC,QAAQ,EAAEhB,SAAS,CAACiB,GAAV,CAAcV,CAAC,CAACC,EAAhB,KAAuB;UAAED,CAAC,EAAE,CAAL;UAAQW,CAAC,EAAE;QAAX;MAP5B,CAAP;IASD,CAVqB,CAAtB;IAYA,MAAMC,KAAa,GAAGtB,KAAK,CAACsB,KAAN,CAAYb,GAAZ,CAAiBc,CAAD,KAAQ;MAC5CZ,EAAE,EAAG,IAAGY,CAAC,CAACC,QAAS,KAAID,CAAC,CAACE,QAAS,EADU;MAE5CC,MAAM,EAAEH,CAAC,CAACC,QAFkC;MAG5CG,MAAM,EAAEJ,CAAC,CAACE,QAHkC;MAI5CG,KAAK,EAAE,IAAAC,yBAAA,EAAeN,CAAC,CAACO,uBAAjB,CAJqC;MAK5CC,cAAc,EAAE,CAAC,CAAD,EAAI,CAAJ,CAL4B;MAM5CnB,IAAI,EAAE,YANsC;MAO5CoB,SAAS,EAAE,IAAAC,yBAAA,EAAeV,CAAC,CAACO,uBAAjB,CAPiC;MAQ5CI,aAAa,EAAEC,kCAAA,CAAcC;IARe,CAAR,CAAhB,CAAtB;IAWA,OAAO,CAAC,GAAG/B,KAAJ,EAAW,GAAGiB,KAAd,CAAP;EACD,CA7BM,EA6BJ,CAACtB,KAAD,CA7BI,CAAP;AA8BD"}
|
@@ -1,8 +1,8 @@
|
|
1
|
-
import { GraphModel } from '../query';
|
1
|
+
import { EdgeModel, GraphModel, NodeModel } from '../query';
|
2
2
|
/**
|
3
3
|
* calculate the specific location of each node in the graph
|
4
4
|
*/
|
5
|
-
export declare function calcLayout(graph: GraphModel): Map<string, {
|
5
|
+
export declare function calcLayout(graph: GraphModel<NodeModel, EdgeModel>): Map<string, {
|
6
6
|
x: number;
|
7
7
|
y: number;
|
8
8
|
}>;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["NODE_WIDTH","NODE_HEIGHT","BOTTOM_TO_TOP","calcLayout","graph","g","graphlib","Graph","setGraph","rankdir","setDefaultEdgeLabel","nodes","forEach","n","setNode","id","width","height","edges","e","setEdge","v","sourceId","w","targetId","dagre","layout","positionsArr","map","nodeId","node","pos","x","y","Map"],"sources":["calc-layout.tsx"],"sourcesContent":["import dagre, { graphlib } from 'dagre';\nimport { GraphModel } from '../query';\n\nconst NODE_WIDTH = 260;\nconst NODE_HEIGHT = 90;\n\nconst BOTTOM_TO_TOP = 'BT';\n\n/**\n * calculate the specific location of each node in the graph\n */\nexport function calcLayout(graph: GraphModel) {\n const g = new graphlib.Graph();\n g.setGraph({ rankdir: BOTTOM_TO_TOP });\n g.setDefaultEdgeLabel(() => ({}));\n\n // make a new instance of { width, height } per node, or dagre will get confused and place all nodes in the same spot\n graph.nodes.forEach((n) => g.setNode(n.id, { width: NODE_WIDTH, height: NODE_HEIGHT }));\n graph.edges.forEach((e) => g.setEdge({ v: e.sourceId, w: e.targetId }));\n\n // position items in graph\n dagre.layout(g);\n\n const positionsArr: [string, { x: number; y: number }][] = g.nodes().map((nodeId) => {\n const node = g.node(nodeId);\n\n const pos = {\n x: node.x - node.width / 2,\n y: node.y - node.height / 2,\n };\n\n return [nodeId, pos];\n });\n\n return new Map(positionsArr);\n}\n"],"mappings":";;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;;;;;AAGA,MAAMA,UAAU,GAAG,GAAnB;AACA,MAAMC,WAAW,GAAG,EAApB;AAEA,MAAMC,aAAa,GAAG,IAAtB;AAEA;AACA;AACA;;AACO,SAASC,UAAT,CAAoBC,KAApB,
|
1
|
+
{"version":3,"names":["NODE_WIDTH","NODE_HEIGHT","BOTTOM_TO_TOP","calcLayout","graph","g","graphlib","Graph","setGraph","rankdir","setDefaultEdgeLabel","nodes","forEach","n","setNode","id","width","height","edges","e","setEdge","v","sourceId","w","targetId","dagre","layout","positionsArr","map","nodeId","node","pos","x","y","Map"],"sources":["calc-layout.tsx"],"sourcesContent":["import dagre, { graphlib } from 'dagre';\nimport { EdgeModel, GraphModel, NodeModel } from '../query';\n\nconst NODE_WIDTH = 260;\nconst NODE_HEIGHT = 90;\n\nconst BOTTOM_TO_TOP = 'BT';\n\n/**\n * calculate the specific location of each node in the graph\n */\nexport function calcLayout(graph: GraphModel<NodeModel, EdgeModel>) {\n const g = new graphlib.Graph();\n g.setGraph({ rankdir: BOTTOM_TO_TOP });\n g.setDefaultEdgeLabel(() => ({}));\n\n // make a new instance of { width, height } per node, or dagre will get confused and place all nodes in the same spot\n graph.nodes.forEach((n) => g.setNode(n.id, { width: NODE_WIDTH, height: NODE_HEIGHT }));\n graph.edges.forEach((e) => g.setEdge({ v: e.sourceId, w: e.targetId }));\n\n // position items in graph\n dagre.layout(g);\n\n const positionsArr: [string, { x: number; y: number }][] = g.nodes().map((nodeId) => {\n const node = g.node(nodeId);\n\n const pos = {\n x: node.x - node.width / 2,\n y: node.y - node.height / 2,\n };\n\n return [nodeId, pos];\n });\n\n return new Map(positionsArr);\n}\n"],"mappings":";;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;;;;;AAGA,MAAMA,UAAU,GAAG,GAAnB;AACA,MAAMC,WAAW,GAAG,EAApB;AAEA,MAAMC,aAAa,GAAG,IAAtB;AAEA;AACA;AACA;;AACO,SAASC,UAAT,CAAoBC,KAApB,EAA6D;EAClE,MAAMC,CAAC,GAAG,KAAIC,iBAAA,CAASC,KAAb,GAAV;EACAF,CAAC,CAACG,QAAF,CAAW;IAAEC,OAAO,EAAEP;EAAX,CAAX;EACAG,CAAC,CAACK,mBAAF,CAAsB,OAAO,EAAP,CAAtB,EAHkE,CAKlE;;EACAN,KAAK,CAACO,KAAN,CAAYC,OAAZ,CAAqBC,CAAD,IAAOR,CAAC,CAACS,OAAF,CAAUD,CAAC,CAACE,EAAZ,EAAgB;IAAEC,KAAK,EAAEhB,UAAT;IAAqBiB,MAAM,EAAEhB;EAA7B,CAAhB,CAA3B;EACAG,KAAK,CAACc,KAAN,CAAYN,OAAZ,CAAqBO,CAAD,IAAOd,CAAC,CAACe,OAAF,CAAU;IAAEC,CAAC,EAAEF,CAAC,CAACG,QAAP;IAAiBC,CAAC,EAAEJ,CAAC,CAACK;EAAtB,CAAV,CAA3B,EAPkE,CASlE;;EACAC,gBAAA,CAAMC,MAAN,CAAarB,CAAb;;EAEA,MAAMsB,YAAkD,GAAGtB,CAAC,CAACM,KAAF,GAAUiB,GAAV,CAAeC,MAAD,IAAY;IACnF,MAAMC,IAAI,GAAGzB,CAAC,CAACyB,IAAF,CAAOD,MAAP,CAAb;IAEA,MAAME,GAAG,GAAG;MACVC,CAAC,EAAEF,IAAI,CAACE,CAAL,GAASF,IAAI,CAACd,KAAL,GAAa,CADf;MAEViB,CAAC,EAAEH,IAAI,CAACG,CAAL,GAASH,IAAI,CAACb,MAAL,GAAc;IAFhB,CAAZ;IAKA,OAAO,CAACY,MAAD,EAASE,GAAT,CAAP;EACD,CAT0D,CAA3D;EAWA,OAAO,IAAIG,GAAJ,CAAQP,YAAR,CAAP;AACD"}
|
@@ -2,10 +2,10 @@
|
|
2
2
|
import { OnLoadParams, ReactFlowProps } from 'react-flow-renderer';
|
3
3
|
import { ComponentID } from '@teambit/component';
|
4
4
|
import { ComponentWidgetSlot } from '../../graph.ui.runtime';
|
5
|
-
import { GraphModel } from '../query';
|
5
|
+
import { EdgeModel, GraphModel, NodeModel } from '../query';
|
6
6
|
export declare type DependenciesGraphProps = {
|
7
7
|
rootNode: ComponentID;
|
8
|
-
graph: GraphModel
|
8
|
+
graph: GraphModel<NodeModel, EdgeModel>;
|
9
9
|
componentWidgets: ComponentWidgetSlot;
|
10
10
|
onLoad?: (instance: OnLoadParams) => void;
|
11
11
|
} & Omit<ReactFlowProps, 'elements'>;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["ComponentNodeContainer","props","sourcePosition","Position","Top","targetPosition","Bottom","data","id","node","type","NodeTypes","ComponentNode","DependenciesGraph","graph","rootNode","componentWidgets","className","onLoad","children","rest","graphRef","useRef","elements","calcElements","context","useMemo","handleLoad","useCallback","instance","current","fitView","useEffect","undefined","classnames","styles","controls","calcMinimapColors","minimap"],"sources":["dependencies-graph.tsx"],"sourcesContent":["import React, {
|
1
|
+
{"version":3,"names":["ComponentNodeContainer","props","sourcePosition","Position","Top","targetPosition","Bottom","data","id","node","type","NodeTypes","ComponentNode","DependenciesGraph","graph","rootNode","componentWidgets","className","onLoad","children","rest","graphRef","useRef","elements","calcElements","context","useMemo","handleLoad","useCallback","instance","current","fitView","useEffect","undefined","classnames","styles","controls","calcMinimapColors","minimap"],"sources":["dependencies-graph.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useMemo, useRef } from 'react';\nimport classnames from 'classnames';\nimport ReactFlow, {\n Background,\n Controls,\n Handle,\n MiniMap,\n NodeProps,\n NodeTypesType,\n OnLoadParams,\n Position,\n ReactFlowProps,\n ReactFlowProvider,\n} from 'react-flow-renderer';\nimport { ComponentID } from '@teambit/component';\n\nimport { ComponentWidgetSlot } from '../../graph.ui.runtime';\nimport { ComponentNode } from '../component-node';\nimport { EdgeModel, GraphModel, NodeModel } from '../query';\nimport { calcElements } from './calc-elements';\nimport { calcMinimapColors } from './minimap';\nimport { ComponentGraphContext } from './graph-context';\n\nimport styles from './dependencies-graph.module.scss';\n\nfunction ComponentNodeContainer(props: NodeProps) {\n const { sourcePosition = Position.Top, targetPosition = Position.Bottom, data, id } = props;\n\n return (\n <div key={id}>\n <Handle type=\"target\" position={targetPosition} isConnectable={false} />\n <Handle type=\"source\" position={sourcePosition} isConnectable={false} />\n <ComponentNode node={data.node} type={data.type} />\n </div>\n );\n}\n\n// @ts-ignore - incorrect NodeTypes https://github.com/wbkd/react-flow/issues/2101 (#5746)\nconst NodeTypes: NodeTypesType = { ComponentNode: ComponentNodeContainer };\n\nexport type DependenciesGraphProps = {\n rootNode: ComponentID;\n graph: GraphModel<NodeModel, EdgeModel>;\n componentWidgets: ComponentWidgetSlot;\n onLoad?: (instance: OnLoadParams) => void;\n} & Omit<ReactFlowProps, 'elements'>;\n\nexport function DependenciesGraph({\n graph,\n rootNode,\n componentWidgets,\n className,\n onLoad,\n children,\n ...rest\n}: DependenciesGraphProps) {\n const graphRef = useRef<OnLoadParams>();\n const elements = calcElements(graph, { rootNode });\n const context = useMemo(() => ({ componentWidgets }), [componentWidgets]);\n\n const handleLoad = useCallback(\n (instance: OnLoadParams) => {\n graphRef.current = instance;\n instance.fitView();\n onLoad?.(instance);\n },\n [onLoad]\n );\n\n // clear ref on unmount\n useEffect(() => () => (graphRef.current = undefined), []);\n\n useEffect(() => {\n graphRef.current?.fitView();\n }, [graph]);\n\n return (\n <ComponentGraphContext.Provider value={context}>\n {/* @ts-ignore - TODO - remove when ReactFlowProvider will be of type `FC<PropsWithChildren<{}>>` instead of `FC` (#5746) */}\n <ReactFlowProvider>\n <ReactFlow\n draggable={false}\n nodesDraggable={true}\n selectNodesOnDrag={false}\n nodesConnectable={false}\n zoomOnDoubleClick={false}\n elementsSelectable={false}\n maxZoom={1}\n {...rest}\n className={classnames(styles.graph, className)}\n elements={elements}\n nodeTypes={NodeTypes}\n onLoad={handleLoad}\n >\n <Background />\n <Controls className={styles.controls} />\n <MiniMap nodeColor={calcMinimapColors} className={styles.minimap} />\n {children}\n </ReactFlow>\n </ReactFlowProvider>\n </ComponentGraphContext.Provider>\n );\n}\n"],"mappings":"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"}
|
@@ -1,3 +1,12 @@
|
|
1
1
|
export { DependenciesGraph } from './dependencies-graph';
|
2
2
|
export { ComponentGraphContext, ComponentGraph } from './graph-context';
|
3
3
|
export type { DependenciesGraphProps } from './dependencies-graph';
|
4
|
+
export { depTypeToClass, depTypeToLabel } from './dep-edge';
|
5
|
+
export { calcMinimapColors } from './minimap';
|
6
|
+
export { calcLayout } from './calc-layout';
|
7
|
+
export { calcElements } from './calc-elements';
|
8
|
+
export declare const styles: {
|
9
|
+
graph: string;
|
10
|
+
minimap: string;
|
11
|
+
controls: string;
|
12
|
+
};
|
@@ -1,5 +1,7 @@
|
|
1
1
|
"use strict";
|
2
2
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
|
3
5
|
Object.defineProperty(exports, "__esModule", {
|
4
6
|
value: true
|
5
7
|
});
|
@@ -21,6 +23,47 @@ Object.defineProperty(exports, "DependenciesGraph", {
|
|
21
23
|
return _dependenciesGraph().DependenciesGraph;
|
22
24
|
}
|
23
25
|
});
|
26
|
+
Object.defineProperty(exports, "calcElements", {
|
27
|
+
enumerable: true,
|
28
|
+
get: function () {
|
29
|
+
return _calcElements().calcElements;
|
30
|
+
}
|
31
|
+
});
|
32
|
+
Object.defineProperty(exports, "calcLayout", {
|
33
|
+
enumerable: true,
|
34
|
+
get: function () {
|
35
|
+
return _calcLayout().calcLayout;
|
36
|
+
}
|
37
|
+
});
|
38
|
+
Object.defineProperty(exports, "calcMinimapColors", {
|
39
|
+
enumerable: true,
|
40
|
+
get: function () {
|
41
|
+
return _minimap().calcMinimapColors;
|
42
|
+
}
|
43
|
+
});
|
44
|
+
Object.defineProperty(exports, "depTypeToClass", {
|
45
|
+
enumerable: true,
|
46
|
+
get: function () {
|
47
|
+
return _depEdge().depTypeToClass;
|
48
|
+
}
|
49
|
+
});
|
50
|
+
Object.defineProperty(exports, "depTypeToLabel", {
|
51
|
+
enumerable: true,
|
52
|
+
get: function () {
|
53
|
+
return _depEdge().depTypeToLabel;
|
54
|
+
}
|
55
|
+
});
|
56
|
+
exports.styles = void 0;
|
57
|
+
|
58
|
+
function _dependenciesGraphModule() {
|
59
|
+
const data = _interopRequireDefault(require("./dependencies-graph.module.scss"));
|
60
|
+
|
61
|
+
_dependenciesGraphModule = function () {
|
62
|
+
return data;
|
63
|
+
};
|
64
|
+
|
65
|
+
return data;
|
66
|
+
}
|
24
67
|
|
25
68
|
function _dependenciesGraph() {
|
26
69
|
const data = require("./dependencies-graph");
|
@@ -42,4 +85,57 @@ function _graphContext() {
|
|
42
85
|
return data;
|
43
86
|
}
|
44
87
|
|
88
|
+
function _depEdge() {
|
89
|
+
const data = require("./dep-edge");
|
90
|
+
|
91
|
+
_depEdge = function () {
|
92
|
+
return data;
|
93
|
+
};
|
94
|
+
|
95
|
+
return data;
|
96
|
+
}
|
97
|
+
|
98
|
+
function _minimap() {
|
99
|
+
const data = require("./minimap");
|
100
|
+
|
101
|
+
_minimap = function () {
|
102
|
+
return data;
|
103
|
+
};
|
104
|
+
|
105
|
+
return data;
|
106
|
+
}
|
107
|
+
|
108
|
+
function _calcLayout() {
|
109
|
+
const data = require("./calc-layout");
|
110
|
+
|
111
|
+
_calcLayout = function () {
|
112
|
+
return data;
|
113
|
+
};
|
114
|
+
|
115
|
+
return data;
|
116
|
+
}
|
117
|
+
|
118
|
+
function _calcElements() {
|
119
|
+
const data = require("./calc-elements");
|
120
|
+
|
121
|
+
_calcElements = function () {
|
122
|
+
return data;
|
123
|
+
};
|
124
|
+
|
125
|
+
return data;
|
126
|
+
}
|
127
|
+
|
128
|
+
const {
|
129
|
+
graph,
|
130
|
+
minimap,
|
131
|
+
controls
|
132
|
+
} = _dependenciesGraphModule().default;
|
133
|
+
|
134
|
+
const styles = {
|
135
|
+
graph,
|
136
|
+
minimap,
|
137
|
+
controls
|
138
|
+
};
|
139
|
+
exports.styles = styles;
|
140
|
+
|
45
141
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["
|
1
|
+
{"version":3,"names":["graph","minimap","controls","componentStyles","styles"],"sources":["index.ts"],"sourcesContent":["import componentStyles from './dependencies-graph.module.scss';\n\nexport { DependenciesGraph } from './dependencies-graph';\nexport { ComponentGraphContext, ComponentGraph } from './graph-context';\nexport type { DependenciesGraphProps } from './dependencies-graph';\nexport { depTypeToClass, depTypeToLabel } from './dep-edge';\nexport { calcMinimapColors } from './minimap';\nexport { calcLayout } from './calc-layout';\nexport { calcElements } from './calc-elements';\n\nconst { graph, minimap, controls } = componentStyles;\nexport const styles = { graph, minimap, controls };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA,MAAM;EAAEA,KAAF;EAASC,OAAT;EAAkBC;AAAlB,IAA+BC,kCAArC;;AACO,MAAMC,MAAM,GAAG;EAAEJ,KAAF;EAASC,OAAT;EAAkBC;AAAlB,CAAf"}
|
@@ -1,14 +1,33 @@
|
|
1
1
|
"use strict";
|
2
2
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
4
|
+
|
3
5
|
Object.defineProperty(exports, "__esModule", {
|
4
6
|
value: true
|
5
7
|
});
|
8
|
+
Object.defineProperty(exports, "GraphFilters", {
|
9
|
+
enumerable: true,
|
10
|
+
get: function () {
|
11
|
+
return _graphFilters().GraphFilters;
|
12
|
+
}
|
13
|
+
});
|
6
14
|
Object.defineProperty(exports, "GraphPage", {
|
7
15
|
enumerable: true,
|
8
16
|
get: function () {
|
9
17
|
return _graphPage().GraphPage;
|
10
18
|
}
|
11
19
|
});
|
20
|
+
exports.styles = void 0;
|
21
|
+
|
22
|
+
function _graphPageModule() {
|
23
|
+
const data = _interopRequireDefault(require("./graph-page.module.scss"));
|
24
|
+
|
25
|
+
_graphPageModule = function () {
|
26
|
+
return data;
|
27
|
+
};
|
28
|
+
|
29
|
+
return data;
|
30
|
+
}
|
12
31
|
|
13
32
|
function _graphPage() {
|
14
33
|
const data = require("./graph-page");
|
@@ -20,4 +39,25 @@ function _graphPage() {
|
|
20
39
|
return data;
|
21
40
|
}
|
22
41
|
|
42
|
+
function _graphFilters() {
|
43
|
+
const data = require("./graph-filters");
|
44
|
+
|
45
|
+
_graphFilters = function () {
|
46
|
+
return data;
|
47
|
+
};
|
48
|
+
|
49
|
+
return data;
|
50
|
+
}
|
51
|
+
|
52
|
+
const {
|
53
|
+
graph,
|
54
|
+
filters
|
55
|
+
} = _graphPageModule().default;
|
56
|
+
|
57
|
+
const styles = {
|
58
|
+
graph,
|
59
|
+
filters
|
60
|
+
};
|
61
|
+
exports.styles = styles;
|
62
|
+
|
23
63
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["
|
1
|
+
{"version":3,"names":["graph","filters","pageStyles","styles"],"sources":["index.ts"],"sourcesContent":["import pageStyles from './graph-page.module.scss';\n\nexport { GraphPage } from './graph-page';\nexport { GraphFilters } from './graph-filters';\n\nconst { graph, filters } = pageStyles;\nexport const styles = { graph, filters };\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA,MAAM;EAAEA,KAAF;EAASC;AAAT,IAAqBC,0BAA3B;;AACO,MAAMC,MAAM,GAAG;EAAEH,KAAF;EAASC;AAAT,CAAf"}
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import { RawGraph } from './get-graph.query';
|
2
2
|
import { NodeModel } from './node-model';
|
3
3
|
import { EdgeModel } from './edge-model';
|
4
|
-
export declare class GraphModel {
|
5
|
-
nodes:
|
6
|
-
edges:
|
7
|
-
constructor(nodes:
|
8
|
-
static from(rawGraph: RawGraph): GraphModel
|
4
|
+
export declare class GraphModel<N extends NodeModel, E extends EdgeModel> {
|
5
|
+
nodes: N[];
|
6
|
+
edges: E[];
|
7
|
+
constructor(nodes: N[], edges: E[]);
|
8
|
+
static from(rawGraph: RawGraph): GraphModel<NodeModel, EdgeModel>;
|
9
9
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["GraphModel","constructor","nodes","edges","from","rawGraph","map","NodeModel","EdgeModel"],"sources":["graph-model.ts"],"sourcesContent":["import { RawGraph } from './get-graph.query';\nimport { NodeModel } from './node-model';\nimport { EdgeModel } from './edge-model';\n\nexport class GraphModel {\n constructor(public nodes:
|
1
|
+
{"version":3,"names":["GraphModel","constructor","nodes","edges","from","rawGraph","map","NodeModel","EdgeModel"],"sources":["graph-model.ts"],"sourcesContent":["import { RawGraph } from './get-graph.query';\nimport { NodeModel } from './node-model';\nimport { EdgeModel } from './edge-model';\n\nexport class GraphModel<N extends NodeModel, E extends EdgeModel> {\n constructor(public nodes: N[], public edges: E[]) {}\n\n static from(rawGraph: RawGraph) {\n const nodes = rawGraph.nodes.map(NodeModel.from);\n const edges = rawGraph.edges.map(EdgeModel.from);\n return new GraphModel(nodes, edges);\n }\n}\n"],"mappings":";;;;;;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEO,MAAMA,UAAN,CAA2D;EAChEC,WAAW,CAAQC,KAAR,EAA2BC,KAA3B,EAAuC;IAAA,KAA/BD,KAA+B,GAA/BA,KAA+B;IAAA,KAAZC,KAAY,GAAZA,KAAY;EAAE;;EAEzC,OAAJC,IAAI,CAACC,QAAD,EAAqB;IAC9B,MAAMH,KAAK,GAAGG,QAAQ,CAACH,KAAT,CAAeI,GAAf,CAAmBC,sBAAA,CAAUH,IAA7B,CAAd;IACA,MAAMD,KAAK,GAAGE,QAAQ,CAACF,KAAT,CAAeG,GAAf,CAAmBE,sBAAA,CAAUJ,IAA7B,CAAd;IACA,OAAO,IAAIJ,UAAJ,CAAeE,KAAf,EAAsBC,KAAtB,CAAP;EACD;;AAP+D"}
|
package/dist/ui/query/index.d.ts
CHANGED
package/dist/ui/query/index.js
CHANGED
@@ -21,6 +21,12 @@ Object.defineProperty(exports, "NodeModel", {
|
|
21
21
|
return _nodeModel().NodeModel;
|
22
22
|
}
|
23
23
|
});
|
24
|
+
Object.defineProperty(exports, "RawGraph", {
|
25
|
+
enumerable: true,
|
26
|
+
get: function () {
|
27
|
+
return _getGraph().RawGraph;
|
28
|
+
}
|
29
|
+
});
|
24
30
|
Object.defineProperty(exports, "useGraph", {
|
25
31
|
enumerable: true,
|
26
32
|
get: function () {
|
@@ -84,4 +90,14 @@ function _nodeModel() {
|
|
84
90
|
return data;
|
85
91
|
}
|
86
92
|
|
93
|
+
function _getGraph() {
|
94
|
+
const data = require("./get-graph.query");
|
95
|
+
|
96
|
+
_getGraph = function () {
|
97
|
+
return data;
|
98
|
+
};
|
99
|
+
|
100
|
+
return data;
|
101
|
+
}
|
102
|
+
|
87
103
|
//# sourceMappingURL=index.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { useGraphQuery } from './use-graph-query';\nexport { useGraph } from './use-graph';\n\nexport { GraphModel } from './graph-model';\nexport { EdgeModel } from './edge-model';\nexport { NodeModel } from './node-model';\n"],"mappings":"
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { useGraphQuery } from './use-graph-query';\nexport { useGraph } from './use-graph';\n\nexport { GraphModel } from './graph-model';\nexport { EdgeModel } from './edge-model';\nexport { NodeModel } from './node-model';\nexport { RawGraph } from './get-graph.query';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAEA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA"}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
import { GraphQlError } from '@teambit/graphql';
|
2
2
|
import { GraphModel } from './graph-model';
|
3
3
|
/** provides dependencies graph data from graphQL */
|
4
|
-
export declare function useGraphQuery(componentId
|
5
|
-
graph: GraphModel | undefined;
|
4
|
+
export declare function useGraphQuery(componentId?: string[], filter?: string): {
|
5
|
+
graph: GraphModel<import("./node-model").NodeModel, import("./edge-model").EdgeModel> | undefined;
|
6
6
|
error: GraphQlError | undefined;
|
7
7
|
loading: boolean;
|
8
8
|
};
|
@@ -65,7 +65,8 @@ function useGraphQuery(componentId, filter) {
|
|
65
65
|
variables: {
|
66
66
|
ids: componentId,
|
67
67
|
filter
|
68
|
-
}
|
68
|
+
},
|
69
|
+
skip: !componentId
|
69
70
|
});
|
70
71
|
const rawGraph = data === null || data === void 0 ? void 0 : data.graph;
|
71
72
|
const clientError = !rawGraph && !loading ? new (_graphql().GraphQlError)(404) : undefined;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"names":["useGraphQuery","componentId","filter","data","error","loading","useDataQuery","GET_GRAPH","variables","ids","rawGraph","graph","clientError","GraphQlError","undefined","serverError","message","useMemo","GraphModel","from"],"sources":["use-graph-query.ts"],"sourcesContent":["import { useMemo } from 'react';\nimport { useDataQuery } from '@teambit/ui-foundation.ui.hooks.use-data-query';\nimport { GraphQlError } from '@teambit/graphql';\nimport { GET_GRAPH, RawGraphQuery } from './get-graph.query';\nimport { GraphModel } from './graph-model';\n\ntype QueryVariables = {\n ids
|
1
|
+
{"version":3,"names":["useGraphQuery","componentId","filter","data","error","loading","useDataQuery","GET_GRAPH","variables","ids","skip","rawGraph","graph","clientError","GraphQlError","undefined","serverError","message","useMemo","GraphModel","from"],"sources":["use-graph-query.ts"],"sourcesContent":["import { useMemo } from 'react';\nimport { useDataQuery } from '@teambit/ui-foundation.ui.hooks.use-data-query';\nimport { GraphQlError } from '@teambit/graphql';\nimport { GET_GRAPH, RawGraphQuery } from './get-graph.query';\nimport { GraphModel } from './graph-model';\n\ntype QueryVariables = {\n ids?: string[];\n filter?: string;\n};\n\n/** provides dependencies graph data from graphQL */\nexport function useGraphQuery(componentId?: string[], filter?: string) {\n const { data, error, loading } = useDataQuery<RawGraphQuery, QueryVariables>(GET_GRAPH, {\n variables: { ids: componentId, filter },\n skip: !componentId,\n });\n\n const rawGraph = data?.graph;\n const clientError = !rawGraph && !loading ? new GraphQlError(404) : undefined;\n const serverError = error ? new GraphQlError(500, error.message) : undefined;\n\n return useMemo(() => {\n return {\n graph: rawGraph ? GraphModel.from(rawGraph) : undefined,\n error: serverError || clientError,\n loading,\n };\n }, [rawGraph, error]);\n}\n"],"mappings":";;;;;;;AAAA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AACA;EAAA;;EAAA;IAAA;EAAA;;EAAA;AAAA;;AAOA;AACO,SAASA,aAAT,CAAuBC,WAAvB,EAA+CC,MAA/C,EAAgE;EACrE,MAAM;IAAEC,IAAF;IAAQC,KAAR;IAAeC;EAAf,IAA2B,IAAAC,mCAAA,EAA4CC,qBAA5C,EAAuD;IACtFC,SAAS,EAAE;MAAEC,GAAG,EAAER,WAAP;MAAoBC;IAApB,CAD2E;IAEtFQ,IAAI,EAAE,CAACT;EAF+E,CAAvD,CAAjC;EAKA,MAAMU,QAAQ,GAAGR,IAAH,aAAGA,IAAH,uBAAGA,IAAI,CAAES,KAAvB;EACA,MAAMC,WAAW,GAAG,CAACF,QAAD,IAAa,CAACN,OAAd,GAAwB,KAAIS,uBAAJ,EAAiB,GAAjB,CAAxB,GAAgDC,SAApE;EACA,MAAMC,WAAW,GAAGZ,KAAK,GAAG,KAAIU,uBAAJ,EAAiB,GAAjB,EAAsBV,KAAK,CAACa,OAA5B,CAAH,GAA0CF,SAAnE;EAEA,OAAO,IAAAG,gBAAA,EAAQ,MAAM;IACnB,OAAO;MACLN,KAAK,EAAED,QAAQ,GAAGQ,wBAAA,CAAWC,IAAX,CAAgBT,QAAhB,CAAH,GAA+BI,SADzC;MAELX,KAAK,EAAEY,WAAW,IAAIH,WAFjB;MAGLR;IAHK,CAAP;EAKD,CANM,EAMJ,CAACM,QAAD,EAAWP,KAAX,CANI,CAAP;AAOD"}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
export declare function useGraph(): {
|
2
|
-
graph: import("./graph-model").GraphModel | undefined;
|
2
|
+
graph: import("./graph-model").GraphModel<import("./node-model").NodeModel, import("./edge-model").EdgeModel> | undefined;
|
3
3
|
error: import("@teambit/graphql").GraphQlError | undefined;
|
4
4
|
loading: boolean;
|
5
5
|
};
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
import { Section } from '@teambit/component';
|
3
|
+
import { DependenciesCompare } from '@teambit/graph';
|
4
|
+
|
5
|
+
export class GraphCompareSection implements Section {
|
6
|
+
navigationLink = {
|
7
|
+
href: 'dependencies',
|
8
|
+
children: 'Dependencies',
|
9
|
+
order: 3,
|
10
|
+
};
|
11
|
+
|
12
|
+
route = {
|
13
|
+
path: 'dependencies/*',
|
14
|
+
element: <DependenciesCompare />,
|
15
|
+
};
|
16
|
+
}
|