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