@aloudata/ink-lineage 0.0.1-beta.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.
- package/package.json +27 -0
- package/src/assets/big/dataSourceTypeIcon.ts +65 -0
- package/src/assets/big/entityType.ts +1 -0
- package/src/assets/big/index.ts +5 -0
- package/src/assets/big/lineageIcon.ts +35 -0
- package/src/assets/big/tableTypeIcon.ts +17 -0
- package/src/assets/big/tipIcon.ts +1 -0
- package/src/assets/index.ts +14 -0
- package/src/components/Edges/DefaultEdge.ts +196 -0
- package/src/components/Edges/FoldEdge.ts +97 -0
- package/src/components/Edges/LineageEdge.ts +24 -0
- package/src/components/Edges/index.ts +3 -0
- package/src/components/Nodes/AssetNode.ts +438 -0
- package/src/components/Nodes/ColumnNode.ts +491 -0
- package/src/components/Nodes/CustomNode.ts +63 -0
- package/src/components/Nodes/DefaultNode.ts +74 -0
- package/src/components/Nodes/DowngradeNode.ts +115 -0
- package/src/components/Nodes/TableNode.ts +534 -0
- package/src/components/Nodes/index.ts +4 -0
- package/src/components/index.ts +2 -0
- package/src/constant/index.ts +1 -0
- package/src/constant/nodeStyle.ts +141 -0
- package/src/index.ts +6 -0
- package/src/manager/BaseManager.ts +20 -0
- package/src/manager/DataProcessor.ts +782 -0
- package/src/manager/ExpandManager.ts +93 -0
- package/src/manager/FoldLineageManager.ts +196 -0
- package/src/manager/GraphEventManager.ts +90 -0
- package/src/manager/LineageManager.ts +680 -0
- package/src/manager/RightKeyMenuManager.ts +114 -0
- package/src/manager/SearchNodeManager.ts +188 -0
- package/src/manager/ToolbarManager.ts +42 -0
- package/src/manager/index.ts +8 -0
- package/src/manager/nodeManager/AssetEventManager.ts +442 -0
- package/src/manager/nodeManager/BaseEventManager.ts +68 -0
- package/src/manager/nodeManager/ColumnEventManager.ts +467 -0
- package/src/manager/nodeManager/CustomEventManager.ts +11 -0
- package/src/manager/nodeManager/TableEventManager.ts +87 -0
- package/src/manager/nodeManager/index.ts +3 -0
- package/src/types/NodeConfig.ts +69 -0
- package/src/types/eventEnum.ts +58 -0
- package/src/types/index.ts +3 -0
- package/src/types/manager.ts +75 -0
- package/src/types/node.ts +246 -0
- package/src/utils/downgradeNode.ts +22 -0
- package/src/utils/foldNode.ts +345 -0
- package/src/utils/getIconByType.ts +104 -0
- package/src/utils/index.ts +3 -0
- package/src/utils/node.ts +294 -0
- package/tsconfig.json +30 -0
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export const view24 =
|
|
2
|
+
"data:image/svg+xml;charset=utf-8;base64,Cjxzdmcgd2lkdGg9IjI2IiBoZWlnaHQ9IjI1IiB2aWV3Qm94PSIwIDAgMjYgMjUiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+CjxyZWN0IHg9IjEuNSIgeT0iMiIgd2lkdGg9IjIxIiBoZWlnaHQ9IjYiIGZpbGw9IiMxNUMzOTEiLz4KPHJlY3QgeD0iMS41IiB5PSI4IiB3aWR0aD0iMjEiIGhlaWdodD0iMTMiIGZpbGw9InVybCgjcGFpbnQwX2xpbmVhcl8zNjkxXzEyNzAwMykiLz4KPHBhdGggZD0iTTguNSA4VjIyIiBzdHJva2U9IiM5Q0EzQUYiLz4KPHBhdGggZD0iTTE1LjUgOFYyMiIgc3Ryb2tlPSIjOUNBM0FGIi8+CjxwYXRoIGQ9Ik0yMiAxMi41TDEgMTIuNSIgc3Ryb2tlPSIjOUNBM0FGIi8+CjxwYXRoIGQ9Ik0yMiA4TDEgOCIgc3Ryb2tlPSIjMDk4ODY0Ii8+CjxwYXRoIGQ9Ik0yMiAxN0gxIiBzdHJva2U9IiM5Q0EzQUYiLz4KPHJlY3QgeD0iMS41IiB5PSIyIiB3aWR0aD0iMjEiIGhlaWdodD0iMTkuNSIgcng9IjAuODMzMzMzIiBzdHJva2U9IiM2QjcyODAiLz4KPGNpcmNsZSBjeD0iMTEuNDU0OCIgY3k9IjE5LjM2MzkiIHI9IjUuMDc3OTkiIHRyYW5zZm9ybT0icm90YXRlKC00NSAxMS40NTQ4IDE5LjM2MzkpIiBmaWxsPSJ3aGl0ZSIvPgo8Y2lyY2xlIGN4PSIyMC4xODE0IiBjeT0iMTkuMzYzOSIgcj0iNS4wNzc5OSIgdHJhbnNmb3JtPSJyb3RhdGUoLTQ1IDIwLjE4MTQgMTkuMzYzOSkiIGZpbGw9IndoaXRlIi8+CjxwYXRoIGQ9Ik0xMyAxOUgxOCIgc3Ryb2tlPSIjNkI3MjgwIi8+CjxjaXJjbGUgY3g9IjExLjQ1NDgiIGN5PSIxOS4zNjM5IiByPSIzLjE1IiB0cmFuc2Zvcm09InJvdGF0ZSgtNDUgMTEuNDU0OCAxOS4zNjM5KSIgZmlsbD0idXJsKCNwYWludDFfbGluZWFyXzM2OTFfMTI3MDAzKSIgc3Ryb2tlPSIjNkI3MjgwIiBzdHJva2Utd2lkdGg9IjAuOSIvPgo8Y2lyY2xlIGN4PSIyMC4zNjQyIiBjeT0iMTkuMzYzOSIgcj0iMy4xNSIgdHJhbnNmb3JtPSJyb3RhdGUoLTQ1IDIwLjM2NDIgMTkuMzYzOSkiIGZpbGw9InVybCgjcGFpbnQyX2xpbmVhcl8zNjkxXzEyNzAwMykiIHN0cm9rZT0iIzZCNzI4MCIgc3Ryb2tlLXdpZHRoPSIwLjkiLz4KPGRlZnM+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQwX2xpbmVhcl8zNjkxXzEyNzAwMyIgeDE9IjEzLjUiIHkxPSI4IiB4Mj0iMTMuNSIgeTI9IjE1IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+CjxzdG9wIHN0b3AtY29sb3I9IiNCMEIwQjAiLz4KPHN0b3Agb2Zmc2V0PSIwLjAwMDEiIHN0b3AtY29sb3I9IiNFNkU2RTYiLz4KPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSJ3aGl0ZSIvPgo8L2xpbmVhckdyYWRpZW50Pgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MV9saW5lYXJfMzY5MV8xMjcwMDMiIHgxPSIxMS40NTQ4IiB5MT0iMTYuMjEzOSIgeDI9IjExLjQ1NDgiIHkyPSIyMi41MTM5IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+CjxzdG9wIHN0b3AtY29sb3I9IiNGMEZCRkYiLz4KPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjOEVERUY3Ii8+CjwvbGluZWFyR3JhZGllbnQ+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQyX2xpbmVhcl8zNjkxXzEyNzAwMyIgeDE9IjIwLjM2NDIiIHkxPSIxNi4yMTM5IiB4Mj0iMjAuMzY0MiIgeTI9IjIyLjUxMzkiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0YwRkJGRiIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiM4RURFRjciLz4KPC9saW5lYXJHcmFkaWVudD4KPC9kZWZzPgo8L3N2Zz4="
|
|
3
|
+
|
|
4
|
+
export const taskSql =
|
|
5
|
+
'';
|
|
6
|
+
|
|
7
|
+
export const tableTemporary =
|
|
8
|
+
'';
|
|
9
|
+
|
|
10
|
+
export const table24 =
|
|
11
|
+
'';
|
|
12
|
+
|
|
13
|
+
export const custom24 =
|
|
14
|
+
'';
|
|
15
|
+
|
|
16
|
+
export const column24 =
|
|
17
|
+
'';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export const hotspot = "data:image/svg+xml;charset=utf-8;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTguNDc5MDUgMTguMzMzNEg4LjIyOTE5QzcuNDI0MTkgMTguMDY1IDYuNjc5MzcgMTcuNzM3MyA2LjAxNTYyIDE3LjM1OTVDNS42Nzg5MyAxNy4xNjg3IDUuMzU0MTcgMTYuOTU3NSA1LjA0MzEzIDE2LjcyNzJDNC43NDI1IDE2LjUwNDUgNC40NTgyOSAxNi4yNjA1IDQuMTkyNzEgMTUuOTk3QzQuMDYzMzcgMTUuODY4IDMuOTM5MzMgMTUuNzMzOSAzLjgyMDkgMTUuNTk0OUMzLjcwNDAxIDE1LjQ1NzYgMy41OTMxOSAxNS4zMTUyIDMuNDg4NzYgMTUuMTY4MkMzLjM4NTI2IDE1LjAyMjIgMy4yODg2OSAxNC44NzE1IDMuMTk5MzYgMTQuNzE2NkMzLjExMDI5IDE0LjU2MTkgMy4wMjg5OCAxNC40MDI4IDIuOTU1NzIgMTQuMjQwMUMyLjgwNzI4IDEzLjkxMDIgMi42OTQwOCAxMy41NjU2IDIuNjE3OTkgMTMuMjEyQzIuNTc4OSAxMy4wMjk4IDIuNTQ5NTMgMTIuODQ1NiAyLjUzIDEyLjY2MDNDMi41MDk5NCAxMi40Njg2IDIuNDk5OTMgMTIuMjc2MSAyLjUgMTIuMDgzM0MyLjUgMTEuODk2OSAyLjUwNTk4IDExLjcxMjggMi41MTc3OCAxMS41MzYzQzIuNTI4OTggMTEuMzY2NyAyLjU0NjI2IDExLjE5NzYgMi41Njk1NiAxMS4wMjkyQzIuNTkxNDcgMTAuODcxNiAyLjYxOTM0IDEwLjcxNSAyLjY1MzEzIDEwLjU1OTVDMi42ODUwNSAxMC40MTMxIDIuNzIyNzggMTAuMjY3OSAyLjc2NjIzIDEwLjEyNDVDMi44MDc1NyA5Ljk4ODI5IDIuODU0MzkgOS44NTM4MSAyLjkwNjU5IDkuNzIxMzhDMi45NTY2OCA5LjU5NDYyIDMuMDExODUgOS40Njk5NCAzLjA3MTk5IDkuMzQ3NjNDMy4xMzAxNSA5LjIyOTUyIDMuMTkyOTIgOS4xMTM3MiAzLjI2MDE0IDkuMDAwNTFDMy4zMjU3MiA4Ljg5MDI3IDMuMzk1MzIgOC43ODI0NyAzLjQ2ODgxIDguNjc3MzRDMy42MTI2NCA4LjQ3MjMzIDMuNzY5NTggOC4yNzY4NSAzLjkzODY3IDguMDkyMTJDNC4wOTU4MSA3LjkxOTQzIDQuMjY3NSA3Ljc0ODggNC40NjM1NSA3LjU3MDQ5QzQuODI3ODEgNy4yMzkxOCA1LjIyMzU3IDYuOTMwNjMgNS42MDYyOSA2LjYzMjI2QzUuOTY2NTUgNi4zNTEzOSA2LjMzOTA4IDYuMDYwOTcgNi42ODYyOSA1Ljc1MDlDNi44NzMyOCA1LjU4NDAzIDcuMDM4MTEgNS40MjQ5MyA3LjE5MDE5IDUuMjY0NzNDNy4zNTM1OSA1LjA5MzUxIDcuNTA3MTMgNC45MTMxNCA3LjY1MDA2IDQuNzI0NDlDNy45NTQ3NiA0LjMyMzkxIDguMTk5ODkgMy44ODEzNCA4LjM3NzgyIDMuNDEwNTVDOC40NzY5NyAzLjE0NzAxIDguNTU2NTEgMi44NzY1IDguNjE1NzkgMi42MDEyNEM4LjY4MTcgMi4yOTMxMyA4LjcyNjUzIDEuOTgwODkgOC43NDk5OSAxLjY2NjY5TDguNzUwNTEgMS42NjY4NEM4Ljc2NjIgMS42NzE4MSA4Ljg1MTMzIDEuNjk5MjcgOC45ODY2MyAxLjc1MTQ2QzkuMTIzMjQgMS44MDQxNCA5LjM0MDU3IDEuODkzNTggOS42MDAwMyAyLjAyMDQ2QzkuODkwNzEgMi4xNjI1NSAxMC4xNzMgMi4zMjEyOCAxMC40NDU0IDIuNDk1ODVDMTAuNzc0IDIuNzA1ODUgMTEuMDg1OCAyLjk0MTE5IDExLjM3NzggMy4xOTk3QzEyLjA5NiAzLjgzODc0IDEyLjYxNjUgNC41NzI3MyAxMi45MjQ3IDUuMzgxM0MxMy4wMTQzIDUuNjE2NTIgMTMuMDg2MSA1Ljg1ODEyIDEzLjEzOTYgNi4xMDQwNkMxMy4xOTY1IDYuMzY3MjggMTMuMjMzMyA2LjYzNDQ2IDEzLjI0OTYgNi45MDMyN0MxMy4yNjY5IDcuMTk2MDEgMTMuMjYyNSA3LjQ4OTY0IDEzLjIzNjUgNy43ODE3M0MxMy4yMDczIDguMTA1MDQgMTMuMTU1NyA4LjQyNTk1IDEzLjA4MjIgOC43NDIxNkMxMy4yMTc4IDguNjMyNDEgMTMuMzQ2MyA4LjUxNDI1IDEzLjQ2NyA4LjM4ODM4QzEzLjYwMSA4LjI1MTUxIDEzLjczMzYgOC4xMDI2NyAxMy44NjEzIDcuOTQ2MTdDMTQuMDIyOCA3Ljc0NzkgMTQuMTczNiA3LjU0MTI1IDE0LjMxMzMgNy4zMjcwNkwxNC4zMTM2IDcuMzI3MjVDMTQuMzMyIDcuMzQyMDQgMTQuNTAwOCA3LjQ3ODc1IDE0Ljc0NjEgNy43MjAxNUMxNC44OTY5IDcuODY4NSAxNS4wNDYxIDguMDI2MzggMTUuMTg5NyA4LjE4OTM5QzE1LjM2ODUgOC4zOTIyNCAxNS41MzgyIDguNjAyOTEgMTUuNjk4MyA4LjgyMDc4QzE2LjEwMDMgOS4zNjg1MiAxNi40MjA3IDkuOTM3MjEgMTYuNjUwNCAxMC41MTFDMTYuNzE2MyAxMC42NzU1IDE2Ljc3NTQgMTAuODQyNiAxNi44Mjc2IDExLjAxMTlDMTYuODgxMSAxMS4xODU5IDE2LjkyNjcgMTEuMzYyMyAxNi45NjQyIDExLjU0MDRDMTcuMDAyNiAxMS43MjM2IDE3LjAzMiAxMS45MDg2IDE3LjA1MjEgMTIuMDk0N0MxNy4wNzI4IDEyLjI4NjggMTcuMDgzMiAxMi40Nzk4IDE3LjA4MzMgMTIuNjcyOUMxNy4wODMzIDEyLjgwOTYgMTcuMDc2MSAxMi45NDYxIDE3LjA2MTcgMTMuMDgyQzE3LjA0NzIgMTMuMjE2OSAxNy4wMjU2IDEzLjM1MSAxNi45OTY4IDEzLjQ4MzdDMTYuOTY3NyAxMy42MTY5IDE2LjkzMTYgMTMuNzQ4NSAxNi44ODg2IDEzLjg3OEMxNi44NDQ3IDE0LjAwOTUgMTYuNzk0MiAxNC4xMzg2IDE2LjczNzEgMTQuMjY0OUMxNi42Nzk3IDE0LjM5MjEgMTYuNjE0MSAxNC41MTk4IDE2LjU0MjMgMTQuNjQ0NUMxNi40NzA1IDE0Ljc2OTIgMTYuMzkwNSAxNC44OTQ0IDE2LjMwNDIgMTUuMDE2N0MxNi4xMjE4IDE1LjI3MzIgMTUuOTE5MiAxNS41MTQ4IDE1LjY5ODMgMTUuNzM5QzE1LjQ1NCAxNS45ODY3IDE1LjE5MzggMTYuMjE4MSAxNC45MTkzIDE2LjQzMThDMTQuNjEzOCAxNi42Njk1IDE0LjI5NiAxNi44OTA5IDEzLjk2NzEgMTcuMDk1MUMxMy42MjI1IDE3LjMxMDMgMTMuMjQzOSAxNy41MjM1IDEyLjg0MTkgMTcuNzI4OUMxMi40Mzk4IDE3LjkzNDIgMTIuMDAzIDE4LjEzNzYgMTEuNTQzNSAxOC4zMzMySDExLjA5NUMxMS4xOTAxIDE4LjE4OTcgMTEuMjc3NiAxOC4wNDEzIDExLjM1NzEgMTcuODg4NUMxMS40NDE5IDE3LjcyOCAxMS41MTk3IDE3LjU2MzcgMTEuNTkgMTcuMzk2M0MxMS42NzQ2IDE3LjE5NTYgMTEuNzQ3IDE2Ljk5IDExLjgwNjcgMTYuNzgwNkMxMS45NTE5IDE2LjI2NyAxMS45OTY0IDE1Ljc4NTIgMTEuOTM4OSAxNS4zNDgzQzExLjg3MjEgMTQuODEyNCAxMS42Mjk1IDE0LjMxMzkgMTEuMjQ4OSAxMy45MzA4QzEwLjk3MjUgMTMuNjY4NSAxMC43MTYzIDEzLjM4NTcgMTAuNDgyNSAxMy4wODQ3QzEwLjI5NyAxMi44NDU1IDEwLjEzMzUgMTIuNTkwMSA5Ljk5Mzg0IDEyLjMyMTZDOS43NzY4NyAxMS44OTc4IDkuNjU1NDYgMTEuNDgwNCA5LjYzMzEzIDExLjA4MUM5LjYyNDIgMTAuOTI3NyA5LjYzMDg0IDEwLjc3MzkgOS42NTI5NyAxMC42MjE5QzkuNjY5ODIgMTAuNTA2NiA5LjY5Njk4IDEwLjM5MyA5LjczNDEyIDEwLjI4MjZDOS43NjU2OSAxMC4xODM0IDkuODA5MyAxMC4wODg2IDkuODYzOTYgMTBDOS44NjI2MSAxMC4wMDA3IDkuNjk2NTQgMTAuMDgxOSA5LjQ0ODgzIDEwLjIzNDRDOS4zMDAxOCAxMC4zMjYxIDkuMTU0NyAxMC40MjI4IDkuMDEyNjQgMTAuNTI0NEM4LjgzNTI1IDEwLjY1MTIgOC42NjM0IDEwLjc4NTUgOC40OTc1NiAxMC45MjdDOC4wODI1MSAxMS4yODE2IDcuNzMwNTEgMTEuNjYzMyA3LjQ1MTMxIDEyLjA2MTNDNy4xMDIzMyAxMi41NTkgNi44NjY4MyAxMy4wODM4IDYuNzUxMzEgMTMuNjIxM0M2LjQzMjMgMTUuMTA1OCA3LjAxMzU5IDE2LjY5MTEgOC40Nzg5OSAxOC4zMzMyTDguNDc5MDUgMTguMzMzNFoiIGZpbGw9IiNFRjQ0NDQiLz4KPC9zdmc+Cg=="
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
// 放大
|
|
2
|
+
export const zoomInSVG =
|
|
3
|
+
'';
|
|
4
|
+
|
|
5
|
+
// 缩小
|
|
6
|
+
export const zoomOutSVG =
|
|
7
|
+
'';
|
|
8
|
+
|
|
9
|
+
// 重置定位
|
|
10
|
+
export const resetPositionSVG =
|
|
11
|
+
'';
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
export * from './big';
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
import { vec3 } from 'gl-matrix';
|
|
2
|
+
import { Cursor } from '@aloudata/ink/dist/displayObjects/types';
|
|
3
|
+
import {
|
|
4
|
+
Graph,
|
|
5
|
+
Group,
|
|
6
|
+
IBaseNodeConfig,
|
|
7
|
+
Path,
|
|
8
|
+
Rect,
|
|
9
|
+
BaseEdge,
|
|
10
|
+
bezierPath,
|
|
11
|
+
loopBackPath,
|
|
12
|
+
selfConnectPath,
|
|
13
|
+
} from '@aloudata/ink-graph-new';
|
|
14
|
+
import { InkLineageManager } from '../../manager';
|
|
15
|
+
import {
|
|
16
|
+
IColResBase,
|
|
17
|
+
IEdgeConfig,
|
|
18
|
+
TDataBase,
|
|
19
|
+
} from '../../types';
|
|
20
|
+
|
|
21
|
+
export interface IEdgeDataConfig {
|
|
22
|
+
name: string;
|
|
23
|
+
style: {
|
|
24
|
+
path: string;
|
|
25
|
+
fill: string;
|
|
26
|
+
stroke: string;
|
|
27
|
+
strokeDasharray: number[];
|
|
28
|
+
lineWidth: number;
|
|
29
|
+
zIndex: number;
|
|
30
|
+
cursor: Cursor;
|
|
31
|
+
markerMid?: Rect;
|
|
32
|
+
markerEnd?: Path;
|
|
33
|
+
markerEndOffset?: number;
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
export class DefaultEdge extends BaseEdge {
|
|
38
|
+
static lineageManager: InkLineageManager<TDataBase<IColResBase>, IColResBase>;
|
|
39
|
+
|
|
40
|
+
edgeConfig: IEdgeDataConfig;
|
|
41
|
+
|
|
42
|
+
get lineageManager(): InkLineageManager<TDataBase<IColResBase>, IColResBase> {
|
|
43
|
+
return DefaultEdge.lineageManager;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
constructor(graph: Graph, config: IEdgeConfig) {
|
|
47
|
+
super(graph, config);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
// 折叠边和普通边公用部分
|
|
51
|
+
renderContent(cfg: IEdgeConfig, container: Group) {
|
|
52
|
+
const { target, source, visible, style } = cfg;
|
|
53
|
+
|
|
54
|
+
if (visible === false) return;
|
|
55
|
+
|
|
56
|
+
const srcNodeConfig = this.lineageManager.getNodeConfigById(source);
|
|
57
|
+
const dstNodeConfig = this.lineageManager.getNodeConfigById(target);
|
|
58
|
+
|
|
59
|
+
if (!srcNodeConfig || !dstNodeConfig) return;
|
|
60
|
+
|
|
61
|
+
if (!visible || !srcNodeConfig?.visible || !dstNodeConfig?.visible) return;
|
|
62
|
+
|
|
63
|
+
const isSrcRelatedColumn = srcNodeConfig.isRelatedColumn;
|
|
64
|
+
const isDstRelatedColumn = dstNodeConfig.isRelatedColumn;
|
|
65
|
+
|
|
66
|
+
container.style.zIndex = style?.zIndex || -1;
|
|
67
|
+
|
|
68
|
+
const defaultPos = 0;
|
|
69
|
+
let srcTransform: vec3;
|
|
70
|
+
let dstTransform: vec3;
|
|
71
|
+
|
|
72
|
+
const srcParentNodeConfig = this.getParentNodeConfig(srcNodeConfig);
|
|
73
|
+
const dstParentNodeConfig = this.getParentNodeConfig(dstNodeConfig);
|
|
74
|
+
if (isSrcRelatedColumn && !srcParentNodeConfig) return;
|
|
75
|
+
if (isDstRelatedColumn && !dstParentNodeConfig) return;
|
|
76
|
+
|
|
77
|
+
const srcPositionX = isSrcRelatedColumn
|
|
78
|
+
? srcNodeConfig.position.x + srcParentNodeConfig?.position?.x
|
|
79
|
+
: srcNodeConfig.position.x;
|
|
80
|
+
|
|
81
|
+
const srcPositionY = isSrcRelatedColumn
|
|
82
|
+
? srcNodeConfig.position.y + 100 + 8 + srcParentNodeConfig?.position?.y
|
|
83
|
+
: srcNodeConfig.position.y;
|
|
84
|
+
|
|
85
|
+
const dstPositionX = isDstRelatedColumn
|
|
86
|
+
? dstNodeConfig.position.x + dstParentNodeConfig?.position?.x
|
|
87
|
+
: dstNodeConfig.position.x;
|
|
88
|
+
|
|
89
|
+
const dstPositionY = isDstRelatedColumn
|
|
90
|
+
? dstNodeConfig.position.y + 100 + 8 + dstParentNodeConfig?.position?.y
|
|
91
|
+
: dstNodeConfig.position.y;
|
|
92
|
+
srcTransform =
|
|
93
|
+
vec3.fromValues(srcPositionX, srcPositionY, 0) || vec3.create();
|
|
94
|
+
dstTransform =
|
|
95
|
+
vec3.fromValues(dstPositionX, dstPositionY, 0) || vec3.create();
|
|
96
|
+
|
|
97
|
+
// 剔除rootGroup的矩阵
|
|
98
|
+
let [rootX, rootY, rootScaleX, rootScaleY] = [0, 0, 1, 1];
|
|
99
|
+
const rootGroup = this.graph.rootGroup;
|
|
100
|
+
if (rootGroup && rootGroup.transformable) {
|
|
101
|
+
const rootGroupTrans = rootGroup.transformable;
|
|
102
|
+
|
|
103
|
+
rootScaleX = rootGroupTrans.scaling[0];
|
|
104
|
+
rootScaleY = rootGroupTrans.scaling[1];
|
|
105
|
+
rootX = rootGroupTrans.position[0];
|
|
106
|
+
rootY = rootGroupTrans.position[1];
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
const DEFAULT_ROOT_X = srcNodeConfig?.style?.width; // 目标节点的宽度
|
|
110
|
+
|
|
111
|
+
const DEFAULT_ROOT_Y =
|
|
112
|
+
(isSrcRelatedColumn
|
|
113
|
+
? srcNodeConfig?.style?.height
|
|
114
|
+
: (srcNodeConfig?.style?.headerHeight as number)) / 2; // 目标节点一半的高度
|
|
115
|
+
|
|
116
|
+
const startXOffset = 0;
|
|
117
|
+
|
|
118
|
+
// 起点原始位置
|
|
119
|
+
const [srcX = defaultPos, srcY = defaultPos] = [
|
|
120
|
+
(srcTransform[0] + (DEFAULT_ROOT_X + startXOffset) * rootScaleX - rootX) /
|
|
121
|
+
rootScaleX,
|
|
122
|
+
(srcTransform[1] + DEFAULT_ROOT_Y * rootScaleY - rootY) / rootScaleY,
|
|
123
|
+
];
|
|
124
|
+
|
|
125
|
+
// 终点原始位置
|
|
126
|
+
const target_height =
|
|
127
|
+
(isDstRelatedColumn
|
|
128
|
+
? dstNodeConfig.style.height
|
|
129
|
+
: (dstNodeConfig.style?.headerHeight as number)) / 2; // 目标节点一半的高度
|
|
130
|
+
|
|
131
|
+
const [dstX = defaultPos, dstY = defaultPos] = [
|
|
132
|
+
(dstTransform[0] - rootX) / rootScaleX,
|
|
133
|
+
(dstTransform[1] + target_height * rootScaleY - rootY) / rootScaleY,
|
|
134
|
+
];
|
|
135
|
+
|
|
136
|
+
const arrowOffsetX = 11;
|
|
137
|
+
|
|
138
|
+
const targetX = dstX - arrowOffsetX;
|
|
139
|
+
const targetY = dstY;
|
|
140
|
+
let d = '';
|
|
141
|
+
// 自环
|
|
142
|
+
if (srcNodeConfig.id === dstNodeConfig.id) {
|
|
143
|
+
d = selfConnectPath(srcX, srcY, dstX, dstY);
|
|
144
|
+
} else if (srcX > dstX) {
|
|
145
|
+
// 回环场景
|
|
146
|
+
d = loopBackPath(srcX, srcY, targetX, targetY);
|
|
147
|
+
// d += normalArrow;
|
|
148
|
+
} else {
|
|
149
|
+
// 普通场景
|
|
150
|
+
d = bezierPath(srcX, srcY, dstX, dstY);
|
|
151
|
+
// d += normalArrow;
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
if (!d) return;
|
|
155
|
+
|
|
156
|
+
const arrowConfig = {
|
|
157
|
+
name: 'arrow',
|
|
158
|
+
style: {
|
|
159
|
+
path: 'M 3,3 L -3,0 L 3,-3 Z',
|
|
160
|
+
anchor: '0.5 0.5',
|
|
161
|
+
transformOrigin: 'center',
|
|
162
|
+
fill: style?.stroke || '#B1B1B1',
|
|
163
|
+
stroke: style?.stroke || '#B1B1B1',
|
|
164
|
+
strokeDasharray: style?.strokeDasharray || [0],
|
|
165
|
+
lineWidth: style?.lineWidth || 1,
|
|
166
|
+
zIndex: style?.zIndex || -1,
|
|
167
|
+
cursor: 'pointer' as Cursor,
|
|
168
|
+
},
|
|
169
|
+
};
|
|
170
|
+
this.markerEnd = new Path(arrowConfig);
|
|
171
|
+
|
|
172
|
+
this.edgeConfig = {
|
|
173
|
+
name: 'big-edge',
|
|
174
|
+
style: {
|
|
175
|
+
path: d,
|
|
176
|
+
fill: style?.fill || 'rgb(255, 255, 255,0)',
|
|
177
|
+
stroke: style?.stroke || '#B1B1B1',
|
|
178
|
+
strokeDasharray: style?.strokeDasharray || [0],
|
|
179
|
+
lineWidth: style?.lineWidth || 1,
|
|
180
|
+
zIndex: style?.zIndex || -1,
|
|
181
|
+
cursor: 'pointer' as Cursor,
|
|
182
|
+
},
|
|
183
|
+
};
|
|
184
|
+
|
|
185
|
+
if (srcNodeConfig.id !== dstNodeConfig.id) {
|
|
186
|
+
this.edgeConfig.style.markerEnd = this.markerEnd;
|
|
187
|
+
this.edgeConfig.style.markerEndOffset = -3;
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
getParentNodeConfig(node: IBaseNodeConfig) {
|
|
192
|
+
let parentNode = this.graph.data.nodes.find((n) => n.id === node.tableId);
|
|
193
|
+
|
|
194
|
+
return parentNode;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Graph,
|
|
3
|
+
Group,
|
|
4
|
+
Path,
|
|
5
|
+
Rect,
|
|
6
|
+
Text,
|
|
7
|
+
} from '@aloudata/ink-graph-new';
|
|
8
|
+
import { DefaultEdge } from './DefaultEdge';
|
|
9
|
+
import { IEdgeConfig } from '../../types';
|
|
10
|
+
|
|
11
|
+
export class FoldEdge extends DefaultEdge {
|
|
12
|
+
constructor(public graph: Graph, public config: IEdgeConfig) {
|
|
13
|
+
super(graph, config);
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
render(cfg: IEdgeConfig, container: Group) {
|
|
17
|
+
this.renderContent(cfg, container);
|
|
18
|
+
|
|
19
|
+
if (!this.edgeConfig) return;
|
|
20
|
+
|
|
21
|
+
const markerRect = new Rect({
|
|
22
|
+
name: 'edge-marker-rect',
|
|
23
|
+
style: {
|
|
24
|
+
width: 32,
|
|
25
|
+
height: 16,
|
|
26
|
+
fill: '#FEFAF1',
|
|
27
|
+
stroke: '#F28E2C',
|
|
28
|
+
lineWidth: 1,
|
|
29
|
+
radius: 3,
|
|
30
|
+
},
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
const { foldNodeId, foldTableId } = this.config;
|
|
34
|
+
const { foldStatusMap, foldNodesGroupMap } = this.lineageManager.foldLineageManager;
|
|
35
|
+
const foldNodeLen = foldNodesGroupMap.get(foldNodeId)?.foldNodes.length;
|
|
36
|
+
let markerText = new Text({
|
|
37
|
+
name: 'edge-marker-text',
|
|
38
|
+
style: {
|
|
39
|
+
text: `...${foldNodeLen}`,
|
|
40
|
+
x: 16,
|
|
41
|
+
y: 8,
|
|
42
|
+
textAlign: 'center',
|
|
43
|
+
textBaseline: 'middle',
|
|
44
|
+
fontSize: 11,
|
|
45
|
+
fontFamily: 'PingFang SC',
|
|
46
|
+
fill: '#F28E2C',
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
if (foldStatusMap.get(foldNodeId || foldTableId) === false) {
|
|
50
|
+
markerText = new Text({
|
|
51
|
+
name: 'edge-marker-text',
|
|
52
|
+
style: {
|
|
53
|
+
text: '收起',
|
|
54
|
+
x: 16,
|
|
55
|
+
y: 8,
|
|
56
|
+
textAlign: 'center',
|
|
57
|
+
textBaseline: 'middle',
|
|
58
|
+
fontSize: 11,
|
|
59
|
+
fontFamily: 'PingFang SC',
|
|
60
|
+
fill: '#F28E2C',
|
|
61
|
+
},
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
markerRect.appendChild(markerText);
|
|
66
|
+
|
|
67
|
+
this.edgeConfig.style.markerMid = markerRect;
|
|
68
|
+
const path = new Path(this.edgeConfig);
|
|
69
|
+
path.addEventListener('click', () => {
|
|
70
|
+
this.onMarkerMidClick();
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
this.path = path;
|
|
74
|
+
(path as any).node = this;
|
|
75
|
+
|
|
76
|
+
container.appendChild(path);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
onMarkerMidClick() {
|
|
80
|
+
const key = this.id;
|
|
81
|
+
const { foldNodeId, foldTableId } = this.config;
|
|
82
|
+
const { foldStatusMap } = this.lineageManager.foldLineageManager;
|
|
83
|
+
|
|
84
|
+
const foldGroupKey = foldNodeId || foldTableId;
|
|
85
|
+
if (foldStatusMap.get(foldGroupKey) === false) {
|
|
86
|
+
this.lineageManager.foldNodeGroup(foldGroupKey, true);
|
|
87
|
+
this.lineageManager.update();
|
|
88
|
+
} else {
|
|
89
|
+
this.lineageManager.unfoldNodeGroup(key, false);
|
|
90
|
+
this.lineageManager.update();
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
onMarkerMidMouseEnter() {
|
|
95
|
+
this.config?.onMarkerMidMouseEnter?.(this);
|
|
96
|
+
}
|
|
97
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import {
|
|
2
|
+
Graph,
|
|
3
|
+
Group,
|
|
4
|
+
Path,
|
|
5
|
+
} from '@aloudata/ink-graph-new';
|
|
6
|
+
import { DefaultEdge } from './DefaultEdge';
|
|
7
|
+
import { IEdgeConfig } from '../../types';
|
|
8
|
+
|
|
9
|
+
export class LineageEdge extends DefaultEdge {
|
|
10
|
+
constructor(public graph: Graph, public config: IEdgeConfig) {
|
|
11
|
+
super(graph, config);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
render(cfg: IEdgeConfig, container: Group) {
|
|
15
|
+
this.renderContent(cfg, container);
|
|
16
|
+
if (!this.edgeConfig) return;
|
|
17
|
+
|
|
18
|
+
const path = new Path(this.edgeConfig);
|
|
19
|
+
this.path = path;
|
|
20
|
+
(path as any).node = this;
|
|
21
|
+
|
|
22
|
+
container.appendChild(path);
|
|
23
|
+
}
|
|
24
|
+
}
|