@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.
Files changed (50) hide show
  1. package/package.json +27 -0
  2. package/src/assets/big/dataSourceTypeIcon.ts +65 -0
  3. package/src/assets/big/entityType.ts +1 -0
  4. package/src/assets/big/index.ts +5 -0
  5. package/src/assets/big/lineageIcon.ts +35 -0
  6. package/src/assets/big/tableTypeIcon.ts +17 -0
  7. package/src/assets/big/tipIcon.ts +1 -0
  8. package/src/assets/index.ts +14 -0
  9. package/src/components/Edges/DefaultEdge.ts +196 -0
  10. package/src/components/Edges/FoldEdge.ts +97 -0
  11. package/src/components/Edges/LineageEdge.ts +24 -0
  12. package/src/components/Edges/index.ts +3 -0
  13. package/src/components/Nodes/AssetNode.ts +438 -0
  14. package/src/components/Nodes/ColumnNode.ts +491 -0
  15. package/src/components/Nodes/CustomNode.ts +63 -0
  16. package/src/components/Nodes/DefaultNode.ts +74 -0
  17. package/src/components/Nodes/DowngradeNode.ts +115 -0
  18. package/src/components/Nodes/TableNode.ts +534 -0
  19. package/src/components/Nodes/index.ts +4 -0
  20. package/src/components/index.ts +2 -0
  21. package/src/constant/index.ts +1 -0
  22. package/src/constant/nodeStyle.ts +141 -0
  23. package/src/index.ts +6 -0
  24. package/src/manager/BaseManager.ts +20 -0
  25. package/src/manager/DataProcessor.ts +782 -0
  26. package/src/manager/ExpandManager.ts +93 -0
  27. package/src/manager/FoldLineageManager.ts +196 -0
  28. package/src/manager/GraphEventManager.ts +90 -0
  29. package/src/manager/LineageManager.ts +680 -0
  30. package/src/manager/RightKeyMenuManager.ts +114 -0
  31. package/src/manager/SearchNodeManager.ts +188 -0
  32. package/src/manager/ToolbarManager.ts +42 -0
  33. package/src/manager/index.ts +8 -0
  34. package/src/manager/nodeManager/AssetEventManager.ts +442 -0
  35. package/src/manager/nodeManager/BaseEventManager.ts +68 -0
  36. package/src/manager/nodeManager/ColumnEventManager.ts +467 -0
  37. package/src/manager/nodeManager/CustomEventManager.ts +11 -0
  38. package/src/manager/nodeManager/TableEventManager.ts +87 -0
  39. package/src/manager/nodeManager/index.ts +3 -0
  40. package/src/types/NodeConfig.ts +69 -0
  41. package/src/types/eventEnum.ts +58 -0
  42. package/src/types/index.ts +3 -0
  43. package/src/types/manager.ts +75 -0
  44. package/src/types/node.ts +246 -0
  45. package/src/utils/downgradeNode.ts +22 -0
  46. package/src/utils/foldNode.ts +345 -0
  47. package/src/utils/getIconByType.ts +104 -0
  48. package/src/utils/index.ts +3 -0
  49. package/src/utils/node.ts +294 -0
  50. 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
+ }
@@ -0,0 +1,3 @@
1
+ export * from './DefaultEdge';
2
+ export * from './FoldEdge';
3
+ export * from './LineageEdge';