@aloudata/ink-lineage 0.0.1-beta.2 → 0.0.1-beta.21
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 +10 -7
- package/src/assets/big/dataSourceTypeIcon.ts +0 -65
- package/src/assets/big/entityType.ts +0 -1
- package/src/assets/big/index.ts +0 -5
- package/src/assets/big/lineageIcon.ts +0 -35
- package/src/assets/big/tableTypeIcon.ts +0 -17
- package/src/assets/big/tipIcon.ts +0 -1
- package/src/assets/index.ts +0 -14
- package/src/components/Edges/DefaultEdge.ts +0 -196
- package/src/components/Edges/FoldEdge.ts +0 -97
- package/src/components/Edges/LineageEdge.ts +0 -24
- package/src/components/Edges/index.ts +0 -3
- package/src/components/Nodes/AssetNode.ts +0 -438
- package/src/components/Nodes/ColumnNode.ts +0 -491
- package/src/components/Nodes/CustomNode.ts +0 -63
- package/src/components/Nodes/DefaultNode.ts +0 -74
- package/src/components/Nodes/DowngradeNode.ts +0 -115
- package/src/components/Nodes/TableNode.ts +0 -534
- package/src/components/Nodes/index.ts +0 -4
- package/src/components/index.ts +0 -2
- package/src/constant/index.ts +0 -1
- package/src/constant/nodeStyle.ts +0 -141
- package/src/index.ts +0 -6
- package/src/manager/BaseManager.ts +0 -20
- package/src/manager/DataProcessor.ts +0 -782
- package/src/manager/ExpandManager.ts +0 -93
- package/src/manager/FoldLineageManager.ts +0 -196
- package/src/manager/GraphEventManager.ts +0 -90
- package/src/manager/LineageManager.ts +0 -680
- package/src/manager/RightKeyMenuManager.ts +0 -114
- package/src/manager/SearchNodeManager.ts +0 -188
- package/src/manager/ToolbarManager.ts +0 -42
- package/src/manager/index.ts +0 -8
- package/src/manager/nodeManager/AssetEventManager.ts +0 -442
- package/src/manager/nodeManager/BaseEventManager.ts +0 -68
- package/src/manager/nodeManager/ColumnEventManager.ts +0 -467
- package/src/manager/nodeManager/CustomEventManager.ts +0 -11
- package/src/manager/nodeManager/TableEventManager.ts +0 -87
- package/src/manager/nodeManager/index.ts +0 -3
- package/src/types/NodeConfig.ts +0 -69
- package/src/types/eventEnum.ts +0 -58
- package/src/types/index.ts +0 -3
- package/src/types/manager.ts +0 -75
- package/src/types/node.ts +0 -246
- package/src/utils/downgradeNode.ts +0 -22
- package/src/utils/foldNode.ts +0 -345
- package/src/utils/getIconByType.ts +0 -104
- package/src/utils/index.ts +0 -3
- package/src/utils/node.ts +0 -294
- package/tsconfig.json +0 -30
|
@@ -1,17 +0,0 @@
|
|
|
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
|
-
'';
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
export const hotspot = "data:image/svg+xml;charset=utf-8;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHBhdGggZD0iTTguNDc5MDUgMTguMzMzNEg4LjIyOTE5QzcuNDI0MTkgMTguMDY1IDYuNjc5MzcgMTcuNzM3MyA2LjAxNTYyIDE3LjM1OTVDNS42Nzg5MyAxNy4xNjg3IDUuMzU0MTcgMTYuOTU3NSA1LjA0MzEzIDE2LjcyNzJDNC43NDI1IDE2LjUwNDUgNC40NTgyOSAxNi4yNjA1IDQuMTkyNzEgMTUuOTk3QzQuMDYzMzcgMTUuODY4IDMuOTM5MzMgMTUuNzMzOSAzLjgyMDkgMTUuNTk0OUMzLjcwNDAxIDE1LjQ1NzYgMy41OTMxOSAxNS4zMTUyIDMuNDg4NzYgMTUuMTY4MkMzLjM4NTI2IDE1LjAyMjIgMy4yODg2OSAxNC44NzE1IDMuMTk5MzYgMTQuNzE2NkMzLjExMDI5IDE0LjU2MTkgMy4wMjg5OCAxNC40MDI4IDIuOTU1NzIgMTQuMjQwMUMyLjgwNzI4IDEzLjkxMDIgMi42OTQwOCAxMy41NjU2IDIuNjE3OTkgMTMuMjEyQzIuNTc4OSAxMy4wMjk4IDIuNTQ5NTMgMTIuODQ1NiAyLjUzIDEyLjY2MDNDMi41MDk5NCAxMi40Njg2IDIuNDk5OTMgMTIuMjc2MSAyLjUgMTIuMDgzM0MyLjUgMTEuODk2OSAyLjUwNTk4IDExLjcxMjggMi41MTc3OCAxMS41MzYzQzIuNTI4OTggMTEuMzY2NyAyLjU0NjI2IDExLjE5NzYgMi41Njk1NiAxMS4wMjkyQzIuNTkxNDcgMTAuODcxNiAyLjYxOTM0IDEwLjcxNSAyLjY1MzEzIDEwLjU1OTVDMi42ODUwNSAxMC40MTMxIDIuNzIyNzggMTAuMjY3OSAyLjc2NjIzIDEwLjEyNDVDMi44MDc1NyA5Ljk4ODI5IDIuODU0MzkgOS44NTM4MSAyLjkwNjU5IDkuNzIxMzhDMi45NTY2OCA5LjU5NDYyIDMuMDExODUgOS40Njk5NCAzLjA3MTk5IDkuMzQ3NjNDMy4xMzAxNSA5LjIyOTUyIDMuMTkyOTIgOS4xMTM3MiAzLjI2MDE0IDkuMDAwNTFDMy4zMjU3MiA4Ljg5MDI3IDMuMzk1MzIgOC43ODI0NyAzLjQ2ODgxIDguNjc3MzRDMy42MTI2NCA4LjQ3MjMzIDMuNzY5NTggOC4yNzY4NSAzLjkzODY3IDguMDkyMTJDNC4wOTU4MSA3LjkxOTQzIDQuMjY3NSA3Ljc0ODggNC40NjM1NSA3LjU3MDQ5QzQuODI3ODEgNy4yMzkxOCA1LjIyMzU3IDYuOTMwNjMgNS42MDYyOSA2LjYzMjI2QzUuOTY2NTUgNi4zNTEzOSA2LjMzOTA4IDYuMDYwOTcgNi42ODYyOSA1Ljc1MDlDNi44NzMyOCA1LjU4NDAzIDcuMDM4MTEgNS40MjQ5MyA3LjE5MDE5IDUuMjY0NzNDNy4zNTM1OSA1LjA5MzUxIDcuNTA3MTMgNC45MTMxNCA3LjY1MDA2IDQuNzI0NDlDNy45NTQ3NiA0LjMyMzkxIDguMTk5ODkgMy44ODEzNCA4LjM3NzgyIDMuNDEwNTVDOC40NzY5NyAzLjE0NzAxIDguNTU2NTEgMi44NzY1IDguNjE1NzkgMi42MDEyNEM4LjY4MTcgMi4yOTMxMyA4LjcyNjUzIDEuOTgwODkgOC43NDk5OSAxLjY2NjY5TDguNzUwNTEgMS42NjY4NEM4Ljc2NjIgMS42NzE4MSA4Ljg1MTMzIDEuNjk5MjcgOC45ODY2MyAxLjc1MTQ2QzkuMTIzMjQgMS44MDQxNCA5LjM0MDU3IDEuODkzNTggOS42MDAwMyAyLjAyMDQ2QzkuODkwNzEgMi4xNjI1NSAxMC4xNzMgMi4zMjEyOCAxMC40NDU0IDIuNDk1ODVDMTAuNzc0IDIuNzA1ODUgMTEuMDg1OCAyLjk0MTE5IDExLjM3NzggMy4xOTk3QzEyLjA5NiAzLjgzODc0IDEyLjYxNjUgNC41NzI3MyAxMi45MjQ3IDUuMzgxM0MxMy4wMTQzIDUuNjE2NTIgMTMuMDg2MSA1Ljg1ODEyIDEzLjEzOTYgNi4xMDQwNkMxMy4xOTY1IDYuMzY3MjggMTMuMjMzMyA2LjYzNDQ2IDEzLjI0OTYgNi45MDMyN0MxMy4yNjY5IDcuMTk2MDEgMTMuMjYyNSA3LjQ4OTY0IDEzLjIzNjUgNy43ODE3M0MxMy4yMDczIDguMTA1MDQgMTMuMTU1NyA4LjQyNTk1IDEzLjA4MjIgOC43NDIxNkMxMy4yMTc4IDguNjMyNDEgMTMuMzQ2MyA4LjUxNDI1IDEzLjQ2NyA4LjM4ODM4QzEzLjYwMSA4LjI1MTUxIDEzLjczMzYgOC4xMDI2NyAxMy44NjEzIDcuOTQ2MTdDMTQuMDIyOCA3Ljc0NzkgMTQuMTczNiA3LjU0MTI1IDE0LjMxMzMgNy4zMjcwNkwxNC4zMTM2IDcuMzI3MjVDMTQuMzMyIDcuMzQyMDQgMTQuNTAwOCA3LjQ3ODc1IDE0Ljc0NjEgNy43MjAxNUMxNC44OTY5IDcuODY4NSAxNS4wNDYxIDguMDI2MzggMTUuMTg5NyA4LjE4OTM5QzE1LjM2ODUgOC4zOTIyNCAxNS41MzgyIDguNjAyOTEgMTUuNjk4MyA4LjgyMDc4QzE2LjEwMDMgOS4zNjg1MiAxNi40MjA3IDkuOTM3MjEgMTYuNjUwNCAxMC41MTFDMTYuNzE2MyAxMC42NzU1IDE2Ljc3NTQgMTAuODQyNiAxNi44Mjc2IDExLjAxMTlDMTYuODgxMSAxMS4xODU5IDE2LjkyNjcgMTEuMzYyMyAxNi45NjQyIDExLjU0MDRDMTcuMDAyNiAxMS43MjM2IDE3LjAzMiAxMS45MDg2IDE3LjA1MjEgMTIuMDk0N0MxNy4wNzI4IDEyLjI4NjggMTcuMDgzMiAxMi40Nzk4IDE3LjA4MzMgMTIuNjcyOUMxNy4wODMzIDEyLjgwOTYgMTcuMDc2MSAxMi45NDYxIDE3LjA2MTcgMTMuMDgyQzE3LjA0NzIgMTMuMjE2OSAxNy4wMjU2IDEzLjM1MSAxNi45OTY4IDEzLjQ4MzdDMTYuOTY3NyAxMy42MTY5IDE2LjkzMTYgMTMuNzQ4NSAxNi44ODg2IDEzLjg3OEMxNi44NDQ3IDE0LjAwOTUgMTYuNzk0MiAxNC4xMzg2IDE2LjczNzEgMTQuMjY0OUMxNi42Nzk3IDE0LjM5MjEgMTYuNjE0MSAxNC41MTk4IDE2LjU0MjMgMTQuNjQ0NUMxNi40NzA1IDE0Ljc2OTIgMTYuMzkwNSAxNC44OTQ0IDE2LjMwNDIgMTUuMDE2N0MxNi4xMjE4IDE1LjI3MzIgMTUuOTE5MiAxNS41MTQ4IDE1LjY5ODMgMTUuNzM5QzE1LjQ1NCAxNS45ODY3IDE1LjE5MzggMTYuMjE4MSAxNC45MTkzIDE2LjQzMThDMTQuNjEzOCAxNi42Njk1IDE0LjI5NiAxNi44OTA5IDEzLjk2NzEgMTcuMDk1MUMxMy42MjI1IDE3LjMxMDMgMTMuMjQzOSAxNy41MjM1IDEyLjg0MTkgMTcuNzI4OUMxMi40Mzk4IDE3LjkzNDIgMTIuMDAzIDE4LjEzNzYgMTEuNTQzNSAxOC4zMzMySDExLjA5NUMxMS4xOTAxIDE4LjE4OTcgMTEuMjc3NiAxOC4wNDEzIDExLjM1NzEgMTcuODg4NUMxMS40NDE5IDE3LjcyOCAxMS41MTk3IDE3LjU2MzcgMTEuNTkgMTcuMzk2M0MxMS42NzQ2IDE3LjE5NTYgMTEuNzQ3IDE2Ljk5IDExLjgwNjcgMTYuNzgwNkMxMS45NTE5IDE2LjI2NyAxMS45OTY0IDE1Ljc4NTIgMTEuOTM4OSAxNS4zNDgzQzExLjg3MjEgMTQuODEyNCAxMS42Mjk1IDE0LjMxMzkgMTEuMjQ4OSAxMy45MzA4QzEwLjk3MjUgMTMuNjY4NSAxMC43MTYzIDEzLjM4NTcgMTAuNDgyNSAxMy4wODQ3QzEwLjI5NyAxMi44NDU1IDEwLjEzMzUgMTIuNTkwMSA5Ljk5Mzg0IDEyLjMyMTZDOS43NzY4NyAxMS44OTc4IDkuNjU1NDYgMTEuNDgwNCA5LjYzMzEzIDExLjA4MUM5LjYyNDIgMTAuOTI3NyA5LjYzMDg0IDEwLjc3MzkgOS42NTI5NyAxMC42MjE5QzkuNjY5ODIgMTAuNTA2NiA5LjY5Njk4IDEwLjM5MyA5LjczNDEyIDEwLjI4MjZDOS43NjU2OSAxMC4xODM0IDkuODA5MyAxMC4wODg2IDkuODYzOTYgMTBDOS44NjI2MSAxMC4wMDA3IDkuNjk2NTQgMTAuMDgxOSA5LjQ0ODgzIDEwLjIzNDRDOS4zMDAxOCAxMC4zMjYxIDkuMTU0NyAxMC40MjI4IDkuMDEyNjQgMTAuNTI0NEM4LjgzNTI1IDEwLjY1MTIgOC42NjM0IDEwLjc4NTUgOC40OTc1NiAxMC45MjdDOC4wODI1MSAxMS4yODE2IDcuNzMwNTEgMTEuNjYzMyA3LjQ1MTMxIDEyLjA2MTNDNy4xMDIzMyAxMi41NTkgNi44NjY4MyAxMy4wODM4IDYuNzUxMzEgMTMuNjIxM0M2LjQzMjMgMTUuMTA1OCA3LjAxMzU5IDE2LjY5MTEgOC40Nzg5OSAxOC4zMzMyTDguNDc5MDUgMTguMzMzNFoiIGZpbGw9IiNFRjQ0NDQiLz4KPC9zdmc+Cg=="
|
package/src/assets/index.ts
DELETED
|
@@ -1,14 +0,0 @@
|
|
|
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';
|
|
@@ -1,196 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,97 +0,0 @@
|
|
|
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
|
-
}
|
|
@@ -1,24 +0,0 @@
|
|
|
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
|
-
}
|