@datarecce/ui 0.1.41 → 0.2.1-nightly.20260402

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 (717) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-B38pWD3T.js +7 -0
  3. package/dist/AuthModal-B38pWD3T.js.map +1 -0
  4. package/dist/RouteConfigContext-DWFg6bll.d.ts +171 -0
  5. package/dist/RouteConfigContext-DWFg6bll.d.ts.map +1 -0
  6. package/dist/RunProgress-BCFXvUsE.d.ts +429 -0
  7. package/dist/RunProgress-BCFXvUsE.d.ts.map +1 -0
  8. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts +63 -0
  9. package/dist/ScreenshotDataGrid-BAsPWcde.d.ts.map +1 -0
  10. package/dist/SplitPane-g8w-XF2_.d.ts +1607 -0
  11. package/dist/SplitPane-g8w-XF2_.d.ts.map +1 -0
  12. package/dist/advanced.d.ts +17 -0
  13. package/dist/advanced.d.ts.map +1 -0
  14. package/dist/advanced.js +3 -0
  15. package/dist/advanced.js.map +1 -0
  16. package/dist/api-BwiRz6pD.d.ts +254 -0
  17. package/dist/api-BwiRz6pD.d.ts.map +1 -0
  18. package/dist/api-CbzeUNef.js +3 -0
  19. package/dist/api-CbzeUNef.js.map +1 -0
  20. package/dist/api.d.ts +3 -2
  21. package/dist/api.js +2 -100
  22. package/dist/colors-BbPSDR1X.js +3 -0
  23. package/dist/colors-BbPSDR1X.js.map +1 -0
  24. package/dist/components-run.d.ts +5 -0
  25. package/dist/components-run.js +2 -0
  26. package/dist/components.d.ts +9 -2
  27. package/dist/components.js +2 -86
  28. package/dist/constants-D-hOGDbU.js +3 -0
  29. package/dist/constants-D-hOGDbU.js.map +1 -0
  30. package/dist/constants.d.ts +3 -0
  31. package/dist/constants.js +2 -0
  32. package/dist/contexts.d.ts +6 -0
  33. package/dist/contexts.js +2 -0
  34. package/dist/fetchClient-Bqjx8inP.js +3 -0
  35. package/dist/fetchClient-Bqjx8inP.js.map +1 -0
  36. package/dist/fetchClient-CTnJ39EA.d.ts +19 -0
  37. package/dist/fetchClient-CTnJ39EA.d.ts.map +1 -0
  38. package/dist/hooks.d.ts +3 -2
  39. package/dist/hooks.js +2 -43
  40. package/dist/index-B1IyNkDA.d.ts +472 -0
  41. package/dist/index-B1IyNkDA.d.ts.map +1 -0
  42. package/dist/index-BJOCIgE1.d.ts +148 -0
  43. package/dist/index-BJOCIgE1.d.ts.map +1 -0
  44. package/dist/index-C9nBECPv.d.ts +212 -0
  45. package/dist/index-C9nBECPv.d.ts.map +1 -0
  46. package/dist/index-CHJ0PCEg.d.ts +380 -0
  47. package/dist/index-CHJ0PCEg.d.ts.map +1 -0
  48. package/dist/index-CZ7gueQV.d.ts +13 -0
  49. package/dist/index-CZ7gueQV.d.ts.map +1 -0
  50. package/dist/index-CaKcjGJC.d.ts +1536 -0
  51. package/dist/index-CaKcjGJC.d.ts.map +1 -0
  52. package/dist/index-D-H3NTdf.d.ts +744 -0
  53. package/dist/index-D-H3NTdf.d.ts.map +1 -0
  54. package/dist/index-Dh6gw0NG.d.ts +351 -0
  55. package/dist/index-Dh6gw0NG.d.ts.map +1 -0
  56. package/dist/index-Dp-BUtpt.d.ts +704 -0
  57. package/dist/index-Dp-BUtpt.d.ts.map +1 -0
  58. package/dist/index.d.ts +17 -2
  59. package/dist/index.js +2 -198
  60. package/dist/instanceInfo-DNLFhkK8.d.ts +909 -0
  61. package/dist/instanceInfo-DNLFhkK8.d.ts.map +1 -0
  62. package/dist/keepAlive-Dj0q3fC9.js +3 -0
  63. package/dist/keepAlive-Dj0q3fC9.js.map +1 -0
  64. package/dist/lib/api/queryClient.d.ts +8 -0
  65. package/dist/lib/api/queryClient.d.ts.map +1 -0
  66. package/dist/lib/api/queryClient.js +3 -0
  67. package/dist/lib/api/queryClient.js.map +1 -0
  68. package/dist/lib/api/track.d.ts +137 -0
  69. package/dist/lib/api/track.d.ts.map +1 -0
  70. package/dist/lib/api/track.js +3 -0
  71. package/dist/lib/api/track.js.map +1 -0
  72. package/dist/lib/api/user.d.ts +16 -0
  73. package/dist/lib/api/user.d.ts.map +1 -0
  74. package/dist/lib/api/user.js +3 -0
  75. package/dist/lib/api/user.js.map +1 -0
  76. package/dist/lib/const.d.ts +8 -0
  77. package/dist/lib/const.d.ts.map +1 -0
  78. package/dist/lib/const.js +3 -0
  79. package/dist/lib/const.js.map +1 -0
  80. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  81. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  82. package/dist/lib/result/ResultErrorFallback.js +3 -0
  83. package/dist/lib/result/ResultErrorFallback.js.map +1 -0
  84. package/dist/lineage-DsKqx9yh.d.ts +1299 -0
  85. package/dist/lineage-DsKqx9yh.d.ts.map +1 -0
  86. package/dist/primitives-D8s_Rs5T.d.ts +1089 -0
  87. package/dist/primitives-D8s_Rs5T.d.ts.map +1 -0
  88. package/dist/primitives.d.ts +8 -0
  89. package/dist/primitives.js +2 -0
  90. package/dist/result.d.ts +3 -0
  91. package/dist/result.js +2 -0
  92. package/dist/src-BH-TT0Mt.js +12 -0
  93. package/dist/src-BH-TT0Mt.js.map +1 -0
  94. package/dist/style.css +290 -0
  95. package/dist/styles.css +478 -4
  96. package/dist/theme-B_XT39eO.js +3 -0
  97. package/dist/theme-B_XT39eO.js.map +1 -0
  98. package/dist/theme.d.ts +2 -2
  99. package/dist/theme.js +2 -9
  100. package/dist/types-DLRfpcrV.d.ts +234 -0
  101. package/dist/types-DLRfpcrV.d.ts.map +1 -0
  102. package/dist/types-qpgIe7MT.d.ts +171 -0
  103. package/dist/types-qpgIe7MT.d.ts.map +1 -0
  104. package/dist/types.d.ts +10 -2
  105. package/dist/types.js +3 -9
  106. package/dist/types.js.map +1 -0
  107. package/dist/useThemeColors-OwCMwSrx.d.ts +79 -0
  108. package/dist/useThemeColors-OwCMwSrx.d.ts.map +1 -0
  109. package/dist/utils-BwEuAiEd.js +3 -0
  110. package/dist/utils-BwEuAiEd.js.map +1 -0
  111. package/dist/utils-Crcz1Rb5.js +6 -0
  112. package/dist/utils-Crcz1Rb5.js.map +1 -0
  113. package/dist/utils.d.ts +3 -0
  114. package/dist/utils.js +2 -0
  115. package/package.json +142 -108
  116. package/LICENSE +0 -201
  117. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  118. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  119. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  120. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  121. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  122. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  123. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  124. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  125. package/dist/api.d.mts +0 -3
  126. package/dist/api.js.map +0 -1
  127. package/dist/api.mjs +0 -46
  128. package/dist/api.mjs.map +0 -1
  129. package/dist/components-BeAjVBV3.css +0 -70
  130. package/dist/components-BeAjVBV3.css.map +0 -1
  131. package/dist/components-DfXnN1Hx.js +0 -14689
  132. package/dist/components-DfXnN1Hx.js.map +0 -1
  133. package/dist/components-iUxcqtUB.css +0 -70
  134. package/dist/components-iUxcqtUB.css.map +0 -1
  135. package/dist/components-jh6r4tQn.mjs +0 -12348
  136. package/dist/components-jh6r4tQn.mjs.map +0 -1
  137. package/dist/components.d.mts +0 -3
  138. package/dist/components.mjs +0 -9
  139. package/dist/const-CaIm1Z8g.mjs +0 -12
  140. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  141. package/dist/const-CvdZO0FN.js +0 -24
  142. package/dist/const-CvdZO0FN.js.map +0 -1
  143. package/dist/hooks-cQsBXBd1.js +0 -40
  144. package/dist/hooks-cQsBXBd1.js.map +0 -1
  145. package/dist/hooks-eaHm_yEp.mjs +0 -33
  146. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  147. package/dist/hooks.d.mts +0 -3
  148. package/dist/hooks.mjs +0 -8
  149. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  150. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  151. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  152. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  153. package/dist/index-B5bpmv0i.d.mts +0 -2172
  154. package/dist/index-B5bpmv0i.d.mts.map +0 -1
  155. package/dist/index-B9lSPJTi.d.ts +0 -2170
  156. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  157. package/dist/index.d.mts +0 -3
  158. package/dist/index.js.map +0 -1
  159. package/dist/index.mjs +0 -20
  160. package/dist/index.mjs.map +0 -1
  161. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  162. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  163. package/dist/mui-theme-iBHkjXJq.js +0 -732
  164. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  165. package/dist/state-CTITyT0R.js +0 -795
  166. package/dist/state-CTITyT0R.js.map +0 -1
  167. package/dist/state-Sc2b4jri.mjs +0 -382
  168. package/dist/state-Sc2b4jri.mjs.map +0 -1
  169. package/dist/theme.d.mts +0 -3
  170. package/dist/theme.mjs +0 -4
  171. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  172. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  173. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  174. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  175. package/dist/types.d.mts +0 -3
  176. package/dist/types.mjs +0 -6
  177. package/dist/urls-BQW5wjg-.js +0 -13
  178. package/dist/urls-BQW5wjg-.js.map +0 -1
  179. package/dist/urls-DT7FVEcS.mjs +0 -7
  180. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  181. package/dist/version-B9s8yne-.js +0 -300
  182. package/dist/version-B9s8yne-.js.map +0 -1
  183. package/dist/version-DP1kU_7v.mjs +0 -162
  184. package/dist/version-DP1kU_7v.mjs.map +0 -1
  185. package/recce-source/.editorconfig +0 -26
  186. package/recce-source/.flake8 +0 -37
  187. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  188. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  189. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  190. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  191. package/recce-source/.github/copilot-instructions.md +0 -331
  192. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  193. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  194. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  195. package/recce-source/.github/workflows/bump.yaml +0 -48
  196. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  197. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  198. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  199. package/recce-source/.github/workflows/nightly.yaml +0 -246
  200. package/recce-source/.github/workflows/release.yaml +0 -196
  201. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  202. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  203. package/recce-source/.pre-commit-config.yaml +0 -26
  204. package/recce-source/CLAUDE.md +0 -483
  205. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  206. package/recce-source/CONTRIBUTING.md +0 -107
  207. package/recce-source/LICENSE +0 -201
  208. package/recce-source/Makefile +0 -126
  209. package/recce-source/README.md +0 -182
  210. package/recce-source/RECCE_CLOUD.md +0 -81
  211. package/recce-source/SECURITY.md +0 -25
  212. package/recce-source/docs/PACKAGING.md +0 -340
  213. package/recce-source/docs/README.md +0 -1
  214. package/recce-source/docs/plans/2024-12-31-csv-download-design.md +0 -121
  215. package/recce-source/docs/plans/2024-12-31-csv-download-implementation.md +0 -930
  216. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  217. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  218. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  219. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  220. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  221. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  222. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  223. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  224. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  225. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  226. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  227. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  228. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  229. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  230. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  231. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  232. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  233. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  234. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  235. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  236. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  237. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  238. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  239. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  240. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  241. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  242. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  243. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  244. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  245. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  246. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  247. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  248. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  249. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  250. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  251. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  252. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  253. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  254. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  255. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  256. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  257. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  258. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  259. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  260. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  261. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  262. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  263. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  264. package/recce-source/js/.editorconfig +0 -27
  265. package/recce-source/js/.env.development +0 -5
  266. package/recce-source/js/.husky/pre-commit +0 -29
  267. package/recce-source/js/.nvmrc +0 -1
  268. package/recce-source/js/README.md +0 -39
  269. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  270. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  271. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  272. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  273. package/recce-source/js/app/@lineage/default.tsx +0 -20
  274. package/recce-source/js/app/@lineage/page.tsx +0 -14
  275. package/recce-source/js/app/MainLayout.tsx +0 -170
  276. package/recce-source/js/app/Providers.tsx +0 -49
  277. package/recce-source/js/app/checks/page.tsx +0 -296
  278. package/recce-source/js/app/error.tsx +0 -93
  279. package/recce-source/js/app/favicon.ico +0 -0
  280. package/recce-source/js/app/global-error.tsx +0 -115
  281. package/recce-source/js/app/global.css +0 -82
  282. package/recce-source/js/app/layout.tsx +0 -48
  283. package/recce-source/js/app/lineage/page.tsx +0 -15
  284. package/recce-source/js/app/page.tsx +0 -12
  285. package/recce-source/js/app/query/page.tsx +0 -8
  286. package/recce-source/js/biome.json +0 -313
  287. package/recce-source/js/jest.config.js +0 -34
  288. package/recce-source/js/jest.globals.d.ts +0 -32
  289. package/recce-source/js/jest.setup.js +0 -91
  290. package/recce-source/js/next.config.js +0 -16
  291. package/recce-source/js/package-lock.json +0 -13843
  292. package/recce-source/js/package.json +0 -123
  293. package/recce-source/js/pnpm-lock.yaml +0 -9235
  294. package/recce-source/js/pnpm-workspace.yaml +0 -6
  295. package/recce-source/js/postcss.config.js +0 -5
  296. package/recce-source/js/public/auth_callback.html +0 -68
  297. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  298. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  299. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  300. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  301. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  302. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  303. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  304. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  305. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  306. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  307. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  308. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  309. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  310. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  311. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  312. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  313. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  314. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  315. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  316. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  317. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  318. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  319. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  320. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  321. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  322. package/recce-source/js/src/components/check/check.ts +0 -25
  323. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  324. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  325. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  326. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  327. package/recce-source/js/src/components/check/utils.ts +0 -12
  328. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  329. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  330. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  331. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  332. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  333. package/recce-source/js/src/components/editor/index.ts +0 -12
  334. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  335. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  336. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  337. package/recce-source/js/src/components/icons/index.tsx +0 -142
  338. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  339. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  340. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  341. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  342. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  343. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  344. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  345. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  346. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  347. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  348. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  349. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  350. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  351. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  352. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  353. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  354. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  355. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  356. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  357. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  358. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  359. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  360. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  361. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  362. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  363. package/recce-source/js/src/components/lineage/styles.css +0 -42
  364. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  365. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  366. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  367. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  368. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  369. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  370. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  371. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  372. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  373. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  374. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  375. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  376. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  377. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  378. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  379. package/recce-source/js/src/components/query/styles.css +0 -21
  380. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  381. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  382. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  383. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  384. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  385. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  386. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  387. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  388. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  389. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -578
  390. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  391. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  392. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  393. package/recce-source/js/src/components/run/registry.ts +0 -214
  394. package/recce-source/js/src/components/run/types.ts +0 -14
  395. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  396. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  397. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  398. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  399. package/recce-source/js/src/components/schema/style.css +0 -134
  400. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  401. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  402. package/recce-source/js/src/components/split/Split.tsx +0 -40
  403. package/recce-source/js/src/components/split/styles.css +0 -24
  404. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  405. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  406. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  407. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  408. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  409. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  410. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  411. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  412. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  413. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  414. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  415. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  416. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  417. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  418. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  419. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  420. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  421. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  422. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  423. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  424. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  425. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  426. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  427. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  428. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  429. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  430. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  431. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  432. package/recce-source/js/src/constants/urls.ts +0 -1
  433. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  434. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  435. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  436. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  437. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  438. package/recce-source/js/src/lib/api/checks.ts +0 -129
  439. package/recce-source/js/src/lib/api/cll.ts +0 -53
  440. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  441. package/recce-source/js/src/lib/api/flag.ts +0 -37
  442. package/recce-source/js/src/lib/api/info.ts +0 -198
  443. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  444. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  445. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  446. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  447. package/recce-source/js/src/lib/api/models.ts +0 -59
  448. package/recce-source/js/src/lib/api/profile.ts +0 -65
  449. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  450. package/recce-source/js/src/lib/api/runs.ts +0 -174
  451. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  452. package/recce-source/js/src/lib/api/select.ts +0 -25
  453. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  454. package/recce-source/js/src/lib/api/state.ts +0 -117
  455. package/recce-source/js/src/lib/api/track.ts +0 -281
  456. package/recce-source/js/src/lib/api/types.ts +0 -284
  457. package/recce-source/js/src/lib/api/user.ts +0 -42
  458. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  459. package/recce-source/js/src/lib/api/version.ts +0 -40
  460. package/recce-source/js/src/lib/const.ts +0 -9
  461. package/recce-source/js/src/lib/csv/extractors.test.ts +0 -456
  462. package/recce-source/js/src/lib/csv/extractors.ts +0 -468
  463. package/recce-source/js/src/lib/csv/format.test.ts +0 -211
  464. package/recce-source/js/src/lib/csv/format.ts +0 -44
  465. package/recce-source/js/src/lib/csv/index.test.ts +0 -155
  466. package/recce-source/js/src/lib/csv/index.ts +0 -109
  467. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  468. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  469. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  470. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  471. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  472. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  473. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  474. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  475. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  476. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  477. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  479. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  480. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  481. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  482. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  483. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  485. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  486. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  487. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  488. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  489. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  490. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  491. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  492. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  493. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  494. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  495. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  496. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  497. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  498. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  499. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  500. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  501. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  502. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  503. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  504. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  505. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  506. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  507. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  508. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  509. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  510. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  511. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  512. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  513. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  514. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  515. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  516. package/recce-source/js/src/lib/hooks/useCSVExport.ts +0 -136
  517. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  518. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  519. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  520. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  521. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  522. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  523. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  524. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  525. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  526. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  527. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  528. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  529. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  530. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  531. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  532. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  533. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  534. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  535. package/recce-source/js/src/utils/formatters.tsx +0 -237
  536. package/recce-source/js/src/utils/transforms.ts +0 -81
  537. package/recce-source/js/tsconfig.json +0 -47
  538. package/recce-source/macros/README.md +0 -8
  539. package/recce-source/macros/recce_athena.sql +0 -73
  540. package/recce-source/pyproject.toml +0 -109
  541. package/recce-source/recce/VERSION +0 -1
  542. package/recce-source/recce/__init__.py +0 -84
  543. package/recce-source/recce/adapter/__init__.py +0 -0
  544. package/recce-source/recce/adapter/base.py +0 -109
  545. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  546. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  547. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  548. package/recce-source/recce/apis/__init__.py +0 -0
  549. package/recce-source/recce/apis/check_api.py +0 -203
  550. package/recce-source/recce/apis/check_events_api.py +0 -353
  551. package/recce-source/recce/apis/check_func.py +0 -130
  552. package/recce-source/recce/apis/run_api.py +0 -130
  553. package/recce-source/recce/apis/run_func.py +0 -258
  554. package/recce-source/recce/artifact.py +0 -266
  555. package/recce-source/recce/cli.py +0 -1846
  556. package/recce-source/recce/config.py +0 -127
  557. package/recce-source/recce/connect_to_cloud.py +0 -138
  558. package/recce-source/recce/core.py +0 -334
  559. package/recce-source/recce/diff.py +0 -26
  560. package/recce-source/recce/event/CONFIG +0 -1
  561. package/recce-source/recce/event/SENTRY_DNS +0 -1
  562. package/recce-source/recce/event/__init__.py +0 -304
  563. package/recce-source/recce/event/collector.py +0 -184
  564. package/recce-source/recce/event/track.py +0 -158
  565. package/recce-source/recce/exceptions.py +0 -21
  566. package/recce-source/recce/git.py +0 -77
  567. package/recce-source/recce/github.py +0 -222
  568. package/recce-source/recce/mcp_server.py +0 -885
  569. package/recce-source/recce/models/__init__.py +0 -6
  570. package/recce-source/recce/models/check.py +0 -481
  571. package/recce-source/recce/models/run.py +0 -46
  572. package/recce-source/recce/models/types.py +0 -218
  573. package/recce-source/recce/pull_request.py +0 -124
  574. package/recce-source/recce/run.py +0 -390
  575. package/recce-source/recce/server.py +0 -877
  576. package/recce-source/recce/state/__init__.py +0 -31
  577. package/recce-source/recce/state/cloud.py +0 -644
  578. package/recce-source/recce/state/const.py +0 -26
  579. package/recce-source/recce/state/local.py +0 -56
  580. package/recce-source/recce/state/state.py +0 -119
  581. package/recce-source/recce/state/state_loader.py +0 -174
  582. package/recce-source/recce/summary.py +0 -575
  583. package/recce-source/recce/tasks/__init__.py +0 -23
  584. package/recce-source/recce/tasks/core.py +0 -134
  585. package/recce-source/recce/tasks/dataframe.py +0 -170
  586. package/recce-source/recce/tasks/histogram.py +0 -433
  587. package/recce-source/recce/tasks/lineage.py +0 -19
  588. package/recce-source/recce/tasks/profile.py +0 -298
  589. package/recce-source/recce/tasks/query.py +0 -450
  590. package/recce-source/recce/tasks/rowcount.py +0 -277
  591. package/recce-source/recce/tasks/schema.py +0 -65
  592. package/recce-source/recce/tasks/top_k.py +0 -172
  593. package/recce-source/recce/tasks/utils.py +0 -147
  594. package/recce-source/recce/tasks/valuediff.py +0 -497
  595. package/recce-source/recce/util/__init__.py +0 -4
  596. package/recce-source/recce/util/api_token.py +0 -80
  597. package/recce-source/recce/util/breaking.py +0 -330
  598. package/recce-source/recce/util/cache.py +0 -25
  599. package/recce-source/recce/util/cll.py +0 -355
  600. package/recce-source/recce/util/cloud/__init__.py +0 -15
  601. package/recce-source/recce/util/cloud/base.py +0 -115
  602. package/recce-source/recce/util/cloud/check_events.py +0 -190
  603. package/recce-source/recce/util/cloud/checks.py +0 -242
  604. package/recce-source/recce/util/io.py +0 -120
  605. package/recce-source/recce/util/lineage.py +0 -83
  606. package/recce-source/recce/util/logger.py +0 -25
  607. package/recce-source/recce/util/onboarding_state.py +0 -45
  608. package/recce-source/recce/util/perf_tracking.py +0 -85
  609. package/recce-source/recce/util/pydantic_model.py +0 -22
  610. package/recce-source/recce/util/recce_cloud.py +0 -454
  611. package/recce-source/recce/util/singleton.py +0 -18
  612. package/recce-source/recce/util/startup_perf.py +0 -121
  613. package/recce-source/recce/yaml/__init__.py +0 -58
  614. package/recce-source/recce_cloud/README.md +0 -780
  615. package/recce-source/recce_cloud/VERSION +0 -1
  616. package/recce-source/recce_cloud/__init__.py +0 -24
  617. package/recce-source/recce_cloud/api/__init__.py +0 -17
  618. package/recce-source/recce_cloud/api/base.py +0 -132
  619. package/recce-source/recce_cloud/api/client.py +0 -186
  620. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  621. package/recce-source/recce_cloud/api/factory.py +0 -63
  622. package/recce-source/recce_cloud/api/github.py +0 -106
  623. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  624. package/recce-source/recce_cloud/artifact.py +0 -57
  625. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  626. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  627. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  628. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  629. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  630. package/recce-source/recce_cloud/cli.py +0 -434
  631. package/recce-source/recce_cloud/download.py +0 -230
  632. package/recce-source/recce_cloud/hatch_build.py +0 -20
  633. package/recce-source/recce_cloud/pyproject.toml +0 -49
  634. package/recce-source/recce_cloud/upload.py +0 -214
  635. package/recce-source/test.py +0 -0
  636. package/recce-source/tests/__init__.py +0 -0
  637. package/recce-source/tests/adapter/__init__.py +0 -0
  638. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  639. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  640. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  641. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  642. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  643. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  644. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  648. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  649. package/recce-source/tests/apis/__init__.py +0 -0
  650. package/recce-source/tests/apis/row_count_diff.json +0 -59
  651. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  652. package/recce-source/tests/apis/test_run_func.py +0 -433
  653. package/recce-source/tests/catalog.json +0 -527
  654. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  655. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  656. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  658. package/recce-source/tests/manifest.json +0 -10655
  659. package/recce-source/tests/models/__init__.py +0 -0
  660. package/recce-source/tests/models/test_check.py +0 -731
  661. package/recce-source/tests/models/test_run_models.py +0 -295
  662. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  663. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  664. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  665. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  666. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  667. package/recce-source/tests/recce_state.json +0 -1
  668. package/recce-source/tests/state/test_cloud.py +0 -719
  669. package/recce-source/tests/state/test_local.py +0 -164
  670. package/recce-source/tests/state/test_state_loader.py +0 -211
  671. package/recce-source/tests/tasks/__init__.py +0 -0
  672. package/recce-source/tests/tasks/conftest.py +0 -4
  673. package/recce-source/tests/tasks/test_histogram.py +0 -129
  674. package/recce-source/tests/tasks/test_lineage.py +0 -55
  675. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  676. package/recce-source/tests/tasks/test_profile.py +0 -397
  677. package/recce-source/tests/tasks/test_query.py +0 -528
  678. package/recce-source/tests/tasks/test_row_count.py +0 -133
  679. package/recce-source/tests/tasks/test_schema.py +0 -122
  680. package/recce-source/tests/tasks/test_top_k.py +0 -77
  681. package/recce-source/tests/tasks/test_utils.py +0 -439
  682. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  683. package/recce-source/tests/test_cli.py +0 -236
  684. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  685. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  686. package/recce-source/tests/test_config.py +0 -43
  687. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  688. package/recce-source/tests/test_core.py +0 -174
  689. package/recce-source/tests/test_dbt.py +0 -36
  690. package/recce-source/tests/test_mcp_server.py +0 -505
  691. package/recce-source/tests/test_pull_request.py +0 -130
  692. package/recce-source/tests/test_server.py +0 -202
  693. package/recce-source/tests/test_server_lifespan.py +0 -138
  694. package/recce-source/tests/test_summary.py +0 -73
  695. package/recce-source/tests/util/__init__.py +0 -0
  696. package/recce-source/tests/util/cloud/__init__.py +0 -0
  697. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  698. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  699. package/recce-source/tests/util/test_api_token.py +0 -119
  700. package/recce-source/tests/util/test_breaking.py +0 -1427
  701. package/recce-source/tests/util/test_cll.py +0 -706
  702. package/recce-source/tests/util/test_lineage.py +0 -122
  703. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  704. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  705. package/recce-source/tox.ini +0 -40
  706. package/recce-source/uv.lock +0 -3928
  707. package/src/api/index.ts +0 -32
  708. package/src/components/index.ts +0 -154
  709. package/src/global.d.ts +0 -14
  710. package/src/hooks/index.ts +0 -56
  711. package/src/index.ts +0 -17
  712. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  713. package/src/lib/hooks/useAppRouter.ts +0 -240
  714. package/src/mui-augmentation.d.ts +0 -139
  715. package/src/theme/index.ts +0 -13
  716. package/src/theme.ts +0 -23
  717. package/src/types/index.ts +0 -23
@@ -1,1384 +0,0 @@
1
- import Box from "@mui/material/Box";
2
- import Button from "@mui/material/Button";
3
- import CircularProgress from "@mui/material/CircularProgress";
4
- import Divider from "@mui/material/Divider";
5
- import Stack from "@mui/material/Stack";
6
- import Typography from "@mui/material/Typography";
7
- import {
8
- Background,
9
- BackgroundVariant,
10
- ControlButton,
11
- Controls,
12
- getNodesBounds,
13
- MiniMap,
14
- Node,
15
- Panel,
16
- ReactFlow,
17
- useEdgesState,
18
- useNodesState,
19
- useReactFlow,
20
- } from "@xyflow/react";
21
- import React, {
22
- forwardRef,
23
- Ref,
24
- RefObject,
25
- useCallback,
26
- useEffect,
27
- useImperativeHandle,
28
- useLayoutEffect,
29
- useMemo,
30
- useRef,
31
- useState,
32
- } from "react";
33
- import {
34
- isLineageGraphColumnNode,
35
- isLineageGraphNode,
36
- LineageGraphColumnNode,
37
- LineageGraphEdge,
38
- LineageGraphNode,
39
- LineageGraphNodes,
40
- layout,
41
- NodeColumnSetMap,
42
- selectDownstream,
43
- selectUpstream,
44
- toReactFlow,
45
- } from "./lineage";
46
- import "@xyflow/react/dist/style.css";
47
- import "./styles.css";
48
- import { useMutation } from "@tanstack/react-query";
49
- import { AxiosError } from "axios";
50
- import { FiCopy } from "react-icons/fi";
51
- import { colors } from "@/components/ui/mui-theme";
52
- import { toaster } from "@/components/ui/toaster";
53
- import { Check } from "@/lib/api/checks";
54
- import { CllInput, ColumnLineageData, getCll } from "@/lib/api/cll";
55
- import {
56
- createLineageDiffCheck,
57
- LineageDiffViewOptions,
58
- } from "@/lib/api/lineagecheck";
59
- import { createSchemaDiffCheck } from "@/lib/api/schemacheck";
60
- import { select } from "@/lib/api/select";
61
- import {
62
- type LineageViewRenderProps,
63
- trackCopyToClipboard,
64
- trackLineageViewRender,
65
- trackMultiNodesAction,
66
- } from "@/lib/api/track";
67
- import {
68
- isHistogramDiffRun,
69
- isProfileDiffRun,
70
- isTopKDiffRun,
71
- isValueDiffDetailRun,
72
- isValueDiffRun,
73
- } from "@/lib/api/types";
74
- import { useApiConfig } from "@/lib/hooks/ApiConfigContext";
75
- import { useLineageGraphContext } from "@/lib/hooks/LineageGraphContext";
76
- import { useRecceActionContext } from "@/lib/hooks/RecceActionContext";
77
- import { useRecceInstanceContext } from "@/lib/hooks/RecceInstanceContext";
78
- import {
79
- IGNORE_SCREENSHOT_CLASS,
80
- useCopyToClipboard,
81
- } from "@/lib/hooks/ScreenShot";
82
- import { useAppLocation } from "@/lib/hooks/useAppRouter";
83
- import { useClipBoardToast } from "@/lib/hooks/useClipBoardToast";
84
- import { useRun } from "@/lib/hooks/useRun";
85
- import { useThemeColors } from "@/lib/hooks/useThemeColors";
86
- import { HSplit } from "../split/Split";
87
- import { ActionControl } from "./ActionControl";
88
- import { ChangeStatusLegend } from "./ChangeStatusLegend";
89
- import { ColumnLevelLineageControl } from "./ColumnLevelLineageControl";
90
- import { ColumnLevelLineageLegend } from "./ColumnLevelLineageLegend";
91
- import { GraphColumnNode } from "./GraphColumnNode";
92
- import GraphEdge from "./GraphEdge";
93
- import { GraphNode } from "./GraphNode";
94
- import { union } from "./graph";
95
- import {
96
- LineageViewContext,
97
- LineageViewContextType,
98
- } from "./LineageViewContext";
99
- import {
100
- LineageViewContextMenu,
101
- useLineageViewContextMenu,
102
- } from "./LineageViewContextMenu";
103
- import { LineageViewNotification } from "./LineageViewNotification";
104
- import { LineageViewTopBar } from "./LineageViewTopBar";
105
- import { NodeView } from "./NodeView";
106
- import SetupConnectionBanner from "./SetupConnectionBanner";
107
- import { BaseEnvironmentSetupNotification } from "./SingleEnvironmentQueryView";
108
- import { getIconForChangeStatus } from "./styles";
109
- import { useMultiNodesAction } from "./useMultiNodesAction";
110
- import useValueDiffAlertDialog from "./useValueDiffAlertDialog";
111
-
112
- export interface LineageViewProps {
113
- viewOptions?: LineageDiffViewOptions;
114
- interactive?: boolean;
115
- weight?: number;
116
- height?: number;
117
-
118
- // to be removed
119
- // viewMode?: "changed_models" | "all"; // deprecated
120
- filterNodes?: (key: string, node: LineageGraphNode) => boolean;
121
- }
122
-
123
- export interface LineageViewRef {
124
- copyToClipboard: () => void;
125
- }
126
-
127
- const nodeTypes = {
128
- lineageGraphNode: GraphNode,
129
- lineageGraphColumnNode: GraphColumnNode,
130
- };
131
- const initialNodes: LineageGraphNode[] = [];
132
- const edgeTypes = {
133
- lineageGraphEdge: GraphEdge,
134
- };
135
- const nodeColor = (node: LineageGraphNode) => {
136
- return node.data.changeStatus
137
- ? getIconForChangeStatus(node.data.changeStatus).hexColor
138
- : colors.neutral[400];
139
- };
140
-
141
- const useResizeObserver = (
142
- ref: RefObject<HTMLElement | null>,
143
- handler: () => void,
144
- ) => {
145
- const size = useRef({
146
- width: 0,
147
- height: 0,
148
- });
149
-
150
- useEffect(() => {
151
- const target = ref.current;
152
- const handleResize = (entries: ResizeObserverEntry[]) => {
153
- for (const entry of entries) {
154
- const newWidth = entry.contentRect.width;
155
- const newHeight = entry.contentRect.height;
156
-
157
- if (
158
- Math.abs(newHeight - size.current.height) > 10 ||
159
- Math.abs(newWidth - size.current.width) > 10
160
- ) {
161
- if (
162
- size.current.height > 0 &&
163
- newHeight > 0 &&
164
- size.current.width > 0 &&
165
- newWidth > 0
166
- ) {
167
- handler();
168
- }
169
- }
170
- size.current = {
171
- width: newWidth,
172
- height: newHeight,
173
- };
174
- }
175
- };
176
-
177
- const resizeObserver = new ResizeObserver(handleResize);
178
-
179
- if (target) {
180
- resizeObserver.observe(target);
181
- }
182
-
183
- return () => {
184
- if (target) {
185
- resizeObserver.unobserve(target);
186
- }
187
- };
188
- }, [handler, ref]);
189
- };
190
-
191
- const useNavToCheck = () => {
192
- const [, setLocation] = useAppLocation();
193
- return useCallback(
194
- (check: Check) => {
195
- if (check.check_id) {
196
- setLocation(`/checks/?id=${check.check_id}`);
197
- }
198
- },
199
- [setLocation],
200
- );
201
- };
202
-
203
- export function PrivateLineageView(
204
- { interactive = false, ...props }: LineageViewProps,
205
- ref: Ref<LineageViewRef>,
206
- ) {
207
- const { isDark } = useThemeColors();
208
- const { apiClient } = useApiConfig();
209
- const reactFlow = useReactFlow();
210
- const refResize = useRef<HTMLDivElement>(null);
211
- const { successToast, failToast } = useClipBoardToast();
212
- const {
213
- copyToClipboard,
214
- ImageDownloadModal,
215
- ref: refReactFlow,
216
- } = useCopyToClipboard({
217
- renderLibrary: "html-to-image",
218
- imageType: "png",
219
- shadowEffect: true,
220
- backgroundColor: isDark ? colors.neutral[900] : colors.neutral[50],
221
- ignoreElements: (element: Element) => {
222
- try {
223
- return element.classList.contains(IGNORE_SCREENSHOT_CLASS);
224
- } catch {
225
- if (element.className) {
226
- return element.className.includes(IGNORE_SCREENSHOT_CLASS);
227
- }
228
- return false;
229
- }
230
- },
231
- onSuccess: () => {
232
- successToast("Copied the Lineage View as an image to clipboard");
233
- },
234
- onError: (error) => {
235
- console.error("Error taking screenshot", error);
236
- failToast("Failed to copy image to clipboard", error);
237
- },
238
- });
239
- const [nodes, setNodes, onNodesChange] =
240
- useNodesState<LineageGraphNodes>(initialNodes);
241
- const [edges, setEdges, onEdgesChange] = useEdgesState<LineageGraphEdge>([]);
242
-
243
- const {
244
- lineageGraph,
245
- retchLineageGraph,
246
- isLoading,
247
- error,
248
- refetchRunsAggregated,
249
- } = useLineageGraphContext();
250
-
251
- const { featureToggles, singleEnv } = useRecceInstanceContext();
252
- const { runId, showRunId, closeRunResult, runAction, isRunResultOpen } =
253
- useRecceActionContext();
254
- const { run } = useRun(runId);
255
-
256
- const [viewOptions, setViewOptions] = useState<LineageDiffViewOptions>({
257
- ...props.viewOptions,
258
- });
259
-
260
- // Helper to track lineage view render with node counts
261
- const trackLineageRender = useCallback(
262
- (
263
- nodes: LineageGraphNodes[],
264
- currentViewMode: string,
265
- impactRadiusEnabled: boolean,
266
- cllColumnActive: boolean,
267
- rightSidebarOpen: boolean,
268
- ) => {
269
- const lineageGraphNodesOnly = nodes.filter(isLineageGraphNode);
270
- const grouped = Object.groupBy(
271
- lineageGraphNodesOnly,
272
- (node) => node.data.changeStatus ?? "unchanged",
273
- );
274
- // Prefix status counts with "nodes_"
275
- const statusCounts = Object.fromEntries(
276
- Object.entries(grouped).map(([status, nodes]) => [
277
- `nodes_${status}`,
278
- nodes?.length ?? 0,
279
- ]),
280
- );
281
- const trackingData = {
282
- node_count: lineageGraphNodesOnly.length,
283
- view_mode: currentViewMode,
284
- impact_radius_enabled: impactRadiusEnabled,
285
- right_sidebar_open: rightSidebarOpen,
286
- ...statusCounts,
287
- } as LineageViewRenderProps;
288
- // Only include cll_column_active when a column is being viewed
289
- if (cllColumnActive) {
290
- trackingData.cll_column_active = true;
291
- }
292
- trackLineageViewRender(trackingData);
293
- },
294
- [],
295
- );
296
-
297
- const cllHistory = useRef<(CllInput | undefined)[]>([]).current;
298
-
299
- const [cll, setCll] = useState<ColumnLineageData | undefined>(undefined);
300
- const actionGetCll = useMutation({
301
- mutationFn: (input: CllInput) => getCll(input, apiClient),
302
- });
303
- const [nodeColumnSetMap, setNodeColumSetMap] = useState<NodeColumnSetMap>({});
304
-
305
- const findNodeByName = useCallback(
306
- (name: string) => {
307
- return nodes.filter(isLineageGraphNode).find((n) => n.data.name === name);
308
- },
309
- [nodes],
310
- );
311
-
312
- // Expose the function to the parent via the ref
313
- useImperativeHandle(ref, () => ({
314
- copyToClipboard,
315
- }));
316
-
317
- const isModelsChanged = useMemo(() => {
318
- return !!(lineageGraph && lineageGraph.modifiedSet.length > 0);
319
- }, [lineageGraph]);
320
-
321
- /**
322
- * View mode
323
- * - all: show all nodes
324
- * - changed_models: show only changed models
325
- */
326
- const viewMode = viewOptions.view_mode ?? "changed_models";
327
- const filteredNodeIds: string[] = useMemo(() => {
328
- return nodes
329
- .filter((node) => node.type === "lineageGraphNode")
330
- .map((node) => node.id);
331
- }, [nodes]);
332
- const filteredNodes = useMemo(() => {
333
- if (!lineageGraph) {
334
- return [];
335
- }
336
-
337
- return filteredNodeIds.map((nodeId) => lineageGraph.nodes[nodeId]);
338
- }, [lineageGraph, filteredNodeIds]);
339
-
340
- /**
341
- * Focused node: the node that is currently focused. Show the NodeView when a node is focused
342
- */
343
- const [focusedNodeId, setFocusedNodeId] = useState<string>();
344
- const focusedNode = focusedNodeId
345
- ? lineageGraph?.nodes[focusedNodeId]
346
- : undefined;
347
-
348
- /**
349
- * Select mode: the behavior of clicking on nodes
350
- * - (undefined): no selection
351
- * - selecting: selecting nodes
352
- * - action_result: take action on selected nodes
353
- */
354
- const [selectMode, setSelectMode] = useState<"selecting" | "action_result">();
355
- const [selectedNodeIds, setSelectedNodeIds] = useState<Set<string>>(
356
- new Set(),
357
- );
358
- const selectedNodes = useMemo(() => {
359
- if (!lineageGraph) {
360
- return [];
361
- }
362
-
363
- const nodeIds = Array.from(selectedNodeIds);
364
- return nodeIds.map((nodeId) => lineageGraph.nodes[nodeId]);
365
- }, [lineageGraph, selectedNodeIds]);
366
- const multiNodeAction = useMultiNodesAction(
367
- selectedNodes.length > 0 ? selectedNodes : filteredNodes,
368
- {
369
- onActionStarted: () => {
370
- setSelectMode("action_result");
371
- },
372
- onActionNodeUpdated: (updated: LineageGraphNode) => {
373
- // trigger a re-render by updating the nodes
374
- setNodes((nodes) =>
375
- nodes.map((node) => {
376
- if (node.id === updated.id) {
377
- return {
378
- ...node,
379
- };
380
- }
381
- return node;
382
- }),
383
- );
384
- },
385
- onActionCompleted: () => {
386
- return void 0;
387
- },
388
- },
389
- );
390
-
391
- /**
392
- * Highlighted nodes: the nodes that are highlighted. The behavior of highlighting depends on the select mode
393
- *
394
- * - Default: nodes in the impact radius, or all nodes if the impact radius is not available
395
- * - Focus: upstream/downstream nodes of the focused node
396
- * - Multi-select: nodes in the impact radius, or all nodes if the impact radius is not available
397
- * - Action Result: selected nodes
398
- */
399
- const highlighted = useMemo<Set<string>>(() => {
400
- if (!lineageGraph) {
401
- return new Set<string>();
402
- }
403
-
404
- let highlightedModels: Set<string> = new Set<string>();
405
- if (cll) {
406
- for (const [nodeId, node] of Object.entries(cll.current.nodes)) {
407
- if (node.impacted !== false) {
408
- highlightedModels.add(nodeId);
409
- }
410
- }
411
- for (const columnId of Object.keys(cll.current.columns)) {
412
- highlightedModels.add(columnId);
413
- }
414
- } else if (selectMode === "action_result") {
415
- const nodeIds = Object.keys(multiNodeAction.actionState.actions);
416
- highlightedModels = new Set(nodeIds);
417
- } else if (focusedNode) {
418
- highlightedModels = union(
419
- selectUpstream(lineageGraph, [focusedNode.id]),
420
- selectDownstream(lineageGraph, [focusedNode.id]),
421
- );
422
- } else if (isModelsChanged) {
423
- highlightedModels = selectDownstream(
424
- lineageGraph,
425
- lineageGraph.modifiedSet,
426
- );
427
- } else {
428
- highlightedModels = new Set(filteredNodeIds);
429
- }
430
-
431
- // Add columns in the highlighted models
432
- return new Set<string>(highlightedModels);
433
- }, [
434
- lineageGraph,
435
- cll,
436
- selectMode,
437
- focusedNode,
438
- isModelsChanged,
439
- multiNodeAction.actionState.actions,
440
- filteredNodeIds,
441
- ]);
442
-
443
- const lineageViewContextMenu = useLineageViewContextMenu();
444
-
445
- const closeContextMenu = () => {
446
- lineageViewContextMenu.closeContextMenu();
447
- };
448
-
449
- // biome-ignore lint/correctness/useExhaustiveDependencies: Intentionally only run when lineageGraph changes (initial load/refetch).
450
- useLayoutEffect(() => {
451
- const t = async () => {
452
- let filteredNodeIds: string[] | undefined = undefined;
453
-
454
- if (!lineageGraph) {
455
- return;
456
- }
457
-
458
- if (viewOptions.node_ids) {
459
- filteredNodeIds = viewOptions.node_ids;
460
- } else {
461
- const packageName = lineageGraph.manifestMetadata.current?.project_name;
462
- const viewMode =
463
- viewOptions.view_mode ?? (isModelsChanged ? "changed_models" : "all");
464
-
465
- const newViewOptions: LineageDiffViewOptions = {
466
- view_mode: viewMode,
467
- packages: packageName ? [packageName] : undefined,
468
- ...props.viewOptions,
469
- };
470
-
471
- try {
472
- const result = await select(
473
- {
474
- select: newViewOptions.select,
475
- exclude: newViewOptions.exclude,
476
- packages: newViewOptions.packages,
477
- view_mode: newViewOptions.view_mode,
478
- },
479
- apiClient,
480
- );
481
- filteredNodeIds = result.nodes;
482
- } catch (_) {
483
- // fallback behavior
484
- newViewOptions.view_mode = "all";
485
- const result = await select(
486
- {
487
- select: newViewOptions.select,
488
- exclude: newViewOptions.exclude,
489
- packages: newViewOptions.packages,
490
- view_mode: newViewOptions.view_mode,
491
- },
492
- apiClient,
493
- );
494
- filteredNodeIds = result.nodes;
495
- }
496
-
497
- setViewOptions(newViewOptions);
498
- }
499
-
500
- let cll: ColumnLineageData | undefined;
501
- if (viewOptions.column_level_lineage) {
502
- try {
503
- cll = await actionGetCll.mutateAsync(
504
- viewOptions.column_level_lineage,
505
- );
506
- } catch (e) {
507
- if (e instanceof AxiosError) {
508
- const e2 = e as AxiosError<{ detail?: string }>;
509
- toaster.create({
510
- title: "Column Level Lineage error",
511
- description: e2.response?.data.detail ?? e.message,
512
- type: "error",
513
- closable: true,
514
- });
515
- return;
516
- }
517
- }
518
- }
519
-
520
- const [nodes, edges, nodeColumnSetMap] = toReactFlow(lineageGraph, {
521
- selectedNodes: filteredNodeIds,
522
- cll: cll,
523
- });
524
- layout(nodes, edges);
525
- setNodes(nodes);
526
- setEdges(edges);
527
- setNodeColumSetMap(nodeColumnSetMap);
528
- setCll(cll);
529
-
530
- // TODO : code smell: vioates DRY. This really shouldn't hit both here and below
531
-
532
- // Track lineage view render
533
- trackLineageRender(
534
- nodes,
535
- viewOptions.view_mode ?? "changed_models",
536
- viewOptions.column_level_lineage?.change_analysis ?? false,
537
- !!viewOptions.column_level_lineage?.column,
538
- !!focusedNodeId || !!run,
539
- );
540
- };
541
-
542
- void t();
543
- // Intentionally only run when lineageGraph changes (initial load/refetch).
544
- // viewOptions changes are handled separately by handleViewOptionsChanged.
545
- // Other dependencies (setNodes, setEdges, actionGetCll) are stable.
546
- // eslint-disable-next-line react-hooks/exhaustive-deps
547
- }, [lineageGraph]);
548
-
549
- const onNodeViewClosed = () => {
550
- setFocusedNodeId(undefined);
551
- };
552
-
553
- const centerNode = async (nodeId: string) => {
554
- let node = nodes.find((n) => n.id === nodeId);
555
- if (!node) {
556
- return;
557
- }
558
-
559
- if (node.parentId) {
560
- const parentId = node.parentId;
561
- node = nodes.find((n) => n.id === parentId) ?? node;
562
- }
563
-
564
- if (node.measured != null) {
565
- const { width, height } = node.measured;
566
- if (width && height) {
567
- const x = node.position.x + width / 2;
568
- const y = node.position.y + height / 2;
569
- const zoom = reactFlow.getZoom();
570
-
571
- await reactFlow.setCenter(x, y, { zoom, duration: 200 });
572
- }
573
- }
574
- };
575
-
576
- const navToCheck = useNavToCheck();
577
-
578
- useResizeObserver(refResize, async () => {
579
- if (selectMode !== "selecting") {
580
- if (!focusedNodeId) {
581
- await reactFlow.fitView({ nodes, duration: 200 });
582
- } else {
583
- await centerNode(focusedNodeId);
584
- }
585
- }
586
- });
587
-
588
- const showColumnLevelLineage = async (
589
- columnLevelLineage?: CllInput,
590
- previous = false,
591
- ) => {
592
- const previousColumnLevelLineage = viewOptions.column_level_lineage;
593
-
594
- await handleViewOptionsChanged(
595
- {
596
- ...viewOptions,
597
- column_level_lineage: columnLevelLineage,
598
- },
599
- false,
600
- );
601
-
602
- if (!previous) {
603
- cllHistory.push(previousColumnLevelLineage);
604
- }
605
- if (columnLevelLineage?.node_id) {
606
- setFocusedNodeId(columnLevelLineage.node_id);
607
- } else {
608
- setFocusedNodeId(undefined);
609
- }
610
- };
611
-
612
- const resetColumnLevelLineage = async (previous?: boolean) => {
613
- if (previous) {
614
- if (cllHistory.length === 0) {
615
- return;
616
- }
617
- const previousCll = cllHistory.pop();
618
- if (previousCll) {
619
- await showColumnLevelLineage(previousCll, true);
620
- } else {
621
- await showColumnLevelLineage(undefined, true);
622
- }
623
- } else {
624
- await showColumnLevelLineage(undefined, true);
625
- }
626
- };
627
-
628
- const onColumnNodeClick = (
629
- event: React.MouseEvent,
630
- node: LineageGraphColumnNode,
631
- ) => {
632
- if (selectMode) {
633
- return;
634
- }
635
-
636
- void showColumnLevelLineage({
637
- node_id: node.data.node.id,
638
- column: node.data.column,
639
- });
640
- };
641
-
642
- const onNodeClick = (event: React.MouseEvent, node: Node) => {
643
- if (!interactive) return;
644
- if (!lineageGraph) {
645
- return;
646
- }
647
-
648
- if (isLineageGraphColumnNode(node as LineageGraphNodes)) {
649
- onColumnNodeClick(event, node as LineageGraphColumnNode);
650
- return;
651
- }
652
-
653
- closeContextMenu();
654
- if (!selectMode) {
655
- setFocusedNodeId(node.id);
656
- } else if (selectMode === "action_result") {
657
- const action = multiNodeAction.actionState.actions[node.id];
658
- if (action.run?.run_id) {
659
- showRunId(action.run.run_id);
660
- }
661
- setFocusedNodeId(node.id);
662
- } else {
663
- const newSet = new Set(selectedNodeIds);
664
- if (selectedNodeIds.has(node.id)) {
665
- newSet.delete(node.id);
666
- } else {
667
- newSet.add(node.id);
668
- }
669
- setSelectedNodeIds(newSet);
670
- if (newSet.size === 0) {
671
- setSelectMode(undefined);
672
- }
673
- }
674
- };
675
-
676
- const refreshLayout = async (options: {
677
- viewOptions?: LineageDiffViewOptions;
678
- fitView?: boolean;
679
- }) => {
680
- let { viewOptions: newViewOptions = viewOptions } = options;
681
- const { fitView } = options;
682
-
683
- let selectedNodes: string[] | undefined = undefined;
684
-
685
- if (!lineageGraph) {
686
- return;
687
- }
688
-
689
- const reselect =
690
- viewOptions.select !== newViewOptions.select ||
691
- viewOptions.exclude !== newViewOptions.exclude ||
692
- viewOptions.packages !== newViewOptions.packages ||
693
- viewOptions.view_mode !== newViewOptions.view_mode;
694
-
695
- if (reselect) {
696
- try {
697
- const result = await select(
698
- {
699
- select: newViewOptions.select,
700
- exclude: newViewOptions.exclude,
701
- packages: newViewOptions.packages,
702
- view_mode: newViewOptions.view_mode,
703
- },
704
- apiClient,
705
- );
706
- // focus to unfocus the model or column node
707
- newViewOptions = { ...newViewOptions, column_level_lineage: undefined };
708
- selectedNodes = result.nodes;
709
- } catch (e) {
710
- if (e instanceof AxiosError) {
711
- const e2 = e as AxiosError<{ detail?: string }>;
712
- toaster.create({
713
- title: "Select node error",
714
- description: e2.response?.data.detail ?? e.message,
715
- type: "error",
716
- closable: true,
717
- });
718
- }
719
- return;
720
- }
721
- setFocusedNodeId(undefined);
722
- } else {
723
- selectedNodes = nodes.map((n) => n.id);
724
- }
725
-
726
- let cll: ColumnLineageData | undefined;
727
- if (newViewOptions.column_level_lineage) {
728
- try {
729
- cll = await actionGetCll.mutateAsync(
730
- newViewOptions.column_level_lineage,
731
- );
732
- } catch (e) {
733
- if (e instanceof AxiosError) {
734
- const e2 = e as AxiosError<{ detail?: string }>;
735
- toaster.create({
736
- title: "Column Level Lineage error",
737
- description: e2.response?.data.detail ?? e.message,
738
- type: "error",
739
- closable: true,
740
- });
741
- return;
742
- }
743
- }
744
- }
745
-
746
- const [newNodes, newEdges, newNodeColumnSetMap] = toReactFlow(
747
- lineageGraph,
748
- {
749
- selectedNodes,
750
- cll,
751
- },
752
- );
753
- setNodes(newNodes);
754
- setEdges(newEdges);
755
- setNodeColumSetMap(newNodeColumnSetMap);
756
- setCll(cll);
757
-
758
- // Track lineage view render
759
- trackLineageRender(
760
- newNodes,
761
- newViewOptions.view_mode ?? "changed_models",
762
- newViewOptions.column_level_lineage?.change_analysis ?? false,
763
- !!newViewOptions.column_level_lineage?.column,
764
- !!focusedNodeId || !!run,
765
- );
766
-
767
- // Close the run result view if the run result node is not in the new nodes
768
- if (
769
- run &&
770
- (isTopKDiffRun(run) ||
771
- isProfileDiffRun(run) ||
772
- isHistogramDiffRun(run) ||
773
- isValueDiffRun(run) ||
774
- isValueDiffDetailRun(run))
775
- ) {
776
- if (run.params?.model && !findNodeByName(run.params.model)) {
777
- closeRunResult();
778
- }
779
- }
780
-
781
- if (fitView) {
782
- await new Promise((resolve) => setTimeout(resolve, 1));
783
- (() => {
784
- void reactFlow.fitView({ nodes: newNodes, duration: 200 });
785
- })();
786
- }
787
- };
788
-
789
- const handleViewOptionsChanged = async (
790
- newViewOptions: LineageDiffViewOptions,
791
- fitView = true,
792
- ) => {
793
- setViewOptions(newViewOptions);
794
- await refreshLayout({
795
- viewOptions: newViewOptions,
796
- fitView,
797
- });
798
- };
799
-
800
- const valueDiffAlertDialog = useValueDiffAlertDialog();
801
-
802
- // biome-ignore lint/correctness/useExhaustiveDependencies: handleViewOptionsChanged and onNodeClick are intentionally omitted
803
- useEffect(() => {
804
- const runResultType = run?.type;
805
- if (!interactive) {
806
- // Skip the following logic if the view is not interactive
807
- return;
808
- }
809
- if (!isRunResultOpen) {
810
- // Skip the following logic if the run result is not open
811
- return;
812
- }
813
- if (
814
- !runResultType ||
815
- ["query_diff", "query", "row_count"].includes(runResultType)
816
- ) {
817
- // Skip the following logic if the run result type is not related to a node
818
- return;
819
- }
820
-
821
- if (!selectMode) {
822
- // Skip the following logic if the select mode is not single
823
- let selectedRunModel = undefined;
824
- if (
825
- isTopKDiffRun(run) ||
826
- isProfileDiffRun(run) ||
827
- isHistogramDiffRun(run) ||
828
- isValueDiffRun(run) ||
829
- isValueDiffDetailRun(run)
830
- ) {
831
- selectedRunModel = run.params?.model;
832
- }
833
-
834
- // Create a mock MouseEvent
835
- const mockEvent = new MouseEvent("click", {
836
- bubbles: true,
837
- cancelable: true,
838
- view: window,
839
- }) as unknown as React.MouseEvent;
840
-
841
- if (selectedRunModel) {
842
- // If the run result is related to a node, select the node to show NodeView
843
- const node = findNodeByName(selectedRunModel);
844
- if (!node) {
845
- // Cannot find the node in the current nodes, try to change the view mode to 'all'
846
- void handleViewOptionsChanged({
847
- ...viewOptions,
848
- view_mode: "all",
849
- });
850
- } else if (isLineageGraphNode(node) && focusedNode !== node.data.data) {
851
- // Only select the node if it is not already selected
852
- onNodeClick(mockEvent, node);
853
- }
854
- } else {
855
- // If the run result is not related to a node, close the NodeView
856
- onNodeViewClosed();
857
- }
858
- }
859
- // handleViewOptionsChanged and onNodeClick are intentionally omitted to prevent
860
- // unnecessary re-runs. These functions are called conditionally within the effect
861
- // and don't need to trigger the effect when they change.
862
- // eslint-disable-next-line react-hooks/exhaustive-deps
863
- }, [
864
- run,
865
- viewOptions,
866
- isRunResultOpen,
867
- selectMode,
868
- findNodeByName,
869
- focusedNode,
870
- interactive,
871
- ]);
872
-
873
- const selectParentNodes = (nodeId: string, degree = 1000) => {
874
- if (selectMode === "action_result" || lineageGraph === undefined) return;
875
-
876
- if (!selectMode) {
877
- setSelectMode("selecting");
878
- multiNodeAction.reset();
879
- if (viewOptions.column_level_lineage) {
880
- void handleViewOptionsChanged({
881
- ...viewOptions,
882
- column_level_lineage: undefined,
883
- });
884
- }
885
- }
886
-
887
- const upstream = selectUpstream(lineageGraph, [nodeId], degree);
888
- setSelectedNodeIds(union(selectedNodeIds, upstream));
889
- };
890
-
891
- const selectChildNodes = (nodeId: string, degree = 1000) => {
892
- if (selectMode === "action_result" || lineageGraph === undefined) return;
893
-
894
- if (!selectMode) {
895
- setSelectMode("selecting");
896
- multiNodeAction.reset();
897
- if (viewOptions.column_level_lineage) {
898
- void handleViewOptionsChanged({
899
- ...viewOptions,
900
- column_level_lineage: undefined,
901
- });
902
- }
903
- }
904
-
905
- const downstream = selectDownstream(lineageGraph, [nodeId], degree);
906
- setSelectedNodeIds(union(selectedNodeIds, downstream));
907
- };
908
-
909
- const onNodeContextMenu = (
910
- event: React.MouseEvent,
911
- node: LineageGraphNodes,
912
- ) => {
913
- if (!interactive) {
914
- return;
915
- }
916
- if (selectMode === "action_result") {
917
- return;
918
- }
919
- // Only show context menu when selectMode is action
920
- // Prevent native context menu from showing
921
- event.preventDefault();
922
- const reactFlowDiv = refReactFlow.current as unknown as HTMLDivElement;
923
- const pane = reactFlowDiv.getBoundingClientRect();
924
- const x = event.clientX - pane.left;
925
- const y = event.clientY - pane.top + reactFlowDiv.offsetTop;
926
- lineageViewContextMenu.showContextMenu(x, y, node);
927
- };
928
-
929
- const selectNode = (nodeId: string) => {
930
- if (!selectMode) {
931
- if (!lineageGraph) {
932
- return;
933
- }
934
-
935
- setSelectedNodeIds(new Set([nodeId]));
936
- setSelectMode("selecting");
937
- setFocusedNodeId(undefined);
938
- multiNodeAction.reset();
939
- } else if (selectMode === "selecting") {
940
- const newSelectedNodeIds = new Set(selectedNodeIds);
941
- if (selectedNodeIds.has(nodeId)) {
942
- newSelectedNodeIds.delete(nodeId);
943
- } else {
944
- newSelectedNodeIds.add(nodeId);
945
- }
946
-
947
- setSelectedNodeIds(newSelectedNodeIds);
948
- if (newSelectedNodeIds.size === 0) {
949
- setSelectMode(undefined);
950
- }
951
- }
952
- };
953
- const deselect = () => {
954
- setSelectMode(undefined);
955
- setSelectedNodeIds(new Set());
956
- setFocusedNodeId(undefined);
957
- closeRunResult();
958
- refetchRunsAggregated?.();
959
- };
960
-
961
- const contextValue: LineageViewContextType = {
962
- interactive,
963
- nodes,
964
- focusedNode,
965
- selectedNodes,
966
- viewOptions,
967
- showContextMenu: onNodeContextMenu,
968
- onViewOptionsChanged: handleViewOptionsChanged,
969
- selectMode,
970
- selectNode,
971
- selectParentNodes,
972
- selectChildNodes,
973
- deselect,
974
- isNodeHighlighted: (nodeId: string) => highlighted.has(nodeId),
975
- isNodeSelected: (nodeId: string) => selectedNodeIds.has(nodeId),
976
- isEdgeHighlighted: (source, target) => {
977
- if (!cll) {
978
- return highlighted.has(source) && highlighted.has(target);
979
- } else {
980
- if (!(source in cll.current.parent_map)) {
981
- return false;
982
- }
983
- return target in cll.current.parent_map[source];
984
- }
985
- },
986
- isNodeShowingChangeAnalysis: (nodeId: string) => {
987
- if (!lineageGraph) {
988
- return false;
989
- }
990
-
991
- const node =
992
- nodeId in lineageGraph.nodes ? lineageGraph.nodes[nodeId] : undefined;
993
-
994
- if (viewOptions.column_level_lineage?.change_analysis) {
995
- const cll = viewOptions.column_level_lineage;
996
-
997
- if (cll.node_id && !cll.column) {
998
- return cll.node_id === nodeId && !!node?.data.changeStatus;
999
- } else {
1000
- return !!node?.data.changeStatus;
1001
- }
1002
- }
1003
-
1004
- return false;
1005
- },
1006
- getNodeAction: (nodeId: string) => {
1007
- return multiNodeAction.actionState.actions[nodeId];
1008
- },
1009
- getNodeColumnSet: (nodeId: string) => {
1010
- if (!(nodeId in nodeColumnSetMap)) {
1011
- return new Set<string>();
1012
- }
1013
-
1014
- return new Set(nodeColumnSetMap[nodeId]);
1015
- },
1016
- runRowCount: async () => {
1017
- if (selectMode === "selecting") {
1018
- await multiNodeAction.runRowCount();
1019
- trackMultiNodesAction({ type: "row_count", selected: "multi" });
1020
- } else if (focusedNode) {
1021
- runAction(
1022
- "row_count",
1023
- { node_names: [focusedNode.data.name] },
1024
- { showForm: false, showLast: false },
1025
- );
1026
- trackMultiNodesAction({ type: "row_count", selected: "single" });
1027
- } else {
1028
- runAction("row_count", {
1029
- select: viewOptions.select,
1030
- exclude: viewOptions.exclude,
1031
- packages: viewOptions.packages,
1032
- view_mode: viewOptions.view_mode,
1033
- });
1034
- trackMultiNodesAction({ type: "row_count", selected: "none" });
1035
- }
1036
- },
1037
- runRowCountDiff: async () => {
1038
- if (selectMode === "selecting") {
1039
- await multiNodeAction.runRowCountDiff();
1040
- trackMultiNodesAction({ type: "row_count_diff", selected: "multi" });
1041
- } else if (focusedNode) {
1042
- runAction(
1043
- "row_count_diff",
1044
- { node_names: [focusedNode.data.name] },
1045
- { showForm: false, showLast: false },
1046
- );
1047
- trackMultiNodesAction({ type: "row_count_diff", selected: "single" });
1048
- } else {
1049
- runAction("row_count_diff", {
1050
- select: viewOptions.select,
1051
- exclude: viewOptions.exclude,
1052
- packages: viewOptions.packages,
1053
- view_mode: viewOptions.view_mode,
1054
- });
1055
- trackMultiNodesAction({ type: "row_count_diff", selected: "none" });
1056
- }
1057
- },
1058
- runValueDiff: async () => {
1059
- if (focusedNode) {
1060
- runAction(
1061
- "value_diff",
1062
- {
1063
- model: focusedNode.data.name,
1064
- },
1065
- { showForm: true, showLast: false },
1066
- );
1067
- trackMultiNodesAction({ type: "value_diff", selected: "single" });
1068
- } else {
1069
- const nodeCount =
1070
- selectMode === "selecting"
1071
- ? selectedNodes.length
1072
- : filteredNodeIds.length;
1073
- if (await valueDiffAlertDialog.confirm(nodeCount)) {
1074
- await multiNodeAction.runValueDiff();
1075
- trackMultiNodesAction({
1076
- type: "value_diff",
1077
- selected: selectMode === "selecting" ? "multi" : "none",
1078
- });
1079
- }
1080
- }
1081
- },
1082
- addLineageDiffCheck: async () => {
1083
- let check: Check | undefined = undefined;
1084
- if (selectMode === "selecting") {
1085
- check = await multiNodeAction.addLineageDiffCheck();
1086
- deselect();
1087
- trackMultiNodesAction({ type: "lineage_diff", selected: "multi" });
1088
- } else if (!focusedNode) {
1089
- check = await createLineageDiffCheck(viewOptions, apiClient);
1090
- trackMultiNodesAction({ type: "lineage_diff", selected: "none" });
1091
- }
1092
-
1093
- if (check) {
1094
- navToCheck(check);
1095
- }
1096
- },
1097
- addSchemaDiffCheck: async () => {
1098
- let check: Check | undefined = undefined;
1099
-
1100
- if (selectMode === "selecting") {
1101
- if (selectedNodes.length > 0) {
1102
- check = await multiNodeAction.addSchemaDiffCheck();
1103
- deselect();
1104
- trackMultiNodesAction({ type: "schema_diff", selected: "multi" });
1105
- }
1106
- } else if (focusedNode) {
1107
- check = await createSchemaDiffCheck(
1108
- {
1109
- node_id: focusedNode.id,
1110
- },
1111
- apiClient,
1112
- );
1113
- trackMultiNodesAction({ type: "schema_diff", selected: "single" });
1114
- } else {
1115
- check = await createSchemaDiffCheck(
1116
- {
1117
- select: viewOptions.select,
1118
- exclude: viewOptions.exclude,
1119
- packages: viewOptions.packages,
1120
- view_mode: viewOptions.view_mode,
1121
- },
1122
- apiClient,
1123
- );
1124
- trackMultiNodesAction({ type: "schema_diff", selected: "none" });
1125
- }
1126
-
1127
- if (check) {
1128
- navToCheck(check);
1129
- }
1130
- },
1131
- cancel: multiNodeAction.cancel,
1132
- actionState: multiNodeAction.actionState,
1133
-
1134
- // Column Level Lineage
1135
- centerNode,
1136
- cll,
1137
- showColumnLevelLineage,
1138
- resetColumnLevelLineage,
1139
- };
1140
-
1141
- if (isLoading) {
1142
- return (
1143
- <Box
1144
- sx={{
1145
- width: "100%",
1146
- height: "100%",
1147
- display: "flex",
1148
- alignItems: "center",
1149
- justifyContent: "center",
1150
- }}
1151
- >
1152
- <CircularProgress size={48} />
1153
- </Box>
1154
- );
1155
- }
1156
-
1157
- if (error) {
1158
- return (
1159
- <Box
1160
- sx={{
1161
- height: "100%",
1162
- display: "flex",
1163
- alignItems: "center",
1164
- justifyContent: "center",
1165
- }}
1166
- >
1167
- <Stack alignItems="center" spacing={1}>
1168
- <Box>
1169
- Failed to load lineage data. This could be because the server has
1170
- been terminated or there is a network error.
1171
- </Box>
1172
- <Box>[Reason: {error}]</Box>
1173
- <Button
1174
- color="iochmara"
1175
- variant="contained"
1176
- onClick={() => {
1177
- if (retchLineageGraph) {
1178
- retchLineageGraph();
1179
- }
1180
- }}
1181
- >
1182
- Retry
1183
- </Button>
1184
- </Stack>
1185
- </Box>
1186
- );
1187
- }
1188
-
1189
- if (!lineageGraph || nodes == initialNodes) {
1190
- return <></>;
1191
- }
1192
-
1193
- if (viewMode === "changed_models" && !lineageGraph.modifiedSet.length) {
1194
- return (
1195
- <Box
1196
- sx={{
1197
- height: "100%",
1198
- display: "flex",
1199
- alignItems: "center",
1200
- justifyContent: "center",
1201
- }}
1202
- >
1203
- <Stack alignItems="center" spacing={1}>
1204
- <>No change detected</>
1205
- <Button
1206
- color="iochmara"
1207
- variant="contained"
1208
- onClick={async () => {
1209
- await handleViewOptionsChanged({
1210
- ...viewOptions,
1211
- view_mode: "all",
1212
- });
1213
- }}
1214
- >
1215
- Show all nodes
1216
- </Button>
1217
- </Stack>
1218
- </Box>
1219
- );
1220
- }
1221
- return (
1222
- <LineageViewContext.Provider value={contextValue}>
1223
- <HSplit
1224
- sizes={focusedNode ? [70, 30] : [100, 0]}
1225
- minSize={focusedNode ? 400 : 0}
1226
- gutterSize={focusedNode ? 5 : 0}
1227
- style={{ height: "100%", width: "100%" }}
1228
- >
1229
- <Stack
1230
- ref={refResize}
1231
- divider={<Divider sx={{ borderColor: "grey.200" }} />}
1232
- spacing={0}
1233
- sx={{ contain: "strict", position: "relative" }}
1234
- >
1235
- {interactive && (
1236
- <>
1237
- <LineageViewTopBar />
1238
- {featureToggles.mode === "metadata only" && (
1239
- <SetupConnectionBanner />
1240
- )}
1241
- </>
1242
- )}
1243
- <ReactFlow
1244
- proOptions={{
1245
- hideAttribution: true,
1246
- }}
1247
- nodeTypes={nodeTypes}
1248
- edgeTypes={edgeTypes}
1249
- nodes={nodes}
1250
- edges={edges}
1251
- onNodesChange={onNodesChange}
1252
- onEdgesChange={onEdgesChange}
1253
- onNodeClick={onNodeClick}
1254
- onNodeContextMenu={onNodeContextMenu}
1255
- onClick={closeContextMenu}
1256
- onInit={async () => {
1257
- if (isModelsChanged) {
1258
- await reactFlow.fitView();
1259
- } else {
1260
- const bounds = getNodesBounds(nodes, {});
1261
- await reactFlow.setCenter(
1262
- bounds.x + bounds.width / 2,
1263
- bounds.y + bounds.height / 2,
1264
- {
1265
- zoom: 1,
1266
- },
1267
- );
1268
- }
1269
- }}
1270
- maxZoom={1}
1271
- minZoom={0.1}
1272
- nodesDraggable={interactive}
1273
- ref={refReactFlow as unknown as Ref<HTMLDivElement>}
1274
- colorMode={isDark ? "dark" : "light"}
1275
- >
1276
- <Background
1277
- id="lineage-bg"
1278
- variant={BackgroundVariant.Dots}
1279
- color={isDark ? colors.neutral[700] : colors.neutral[300]}
1280
- gap={20}
1281
- size={2}
1282
- />
1283
- <Controls
1284
- showInteractive={false}
1285
- position="top-right"
1286
- className={IGNORE_SCREENSHOT_CLASS}
1287
- style={{
1288
- backgroundColor: isDark ? colors.neutral[700] : undefined,
1289
- borderColor: isDark ? colors.neutral[600] : undefined,
1290
- }}
1291
- >
1292
- <ControlButton
1293
- title="copy image"
1294
- onClick={async () => {
1295
- await copyToClipboard();
1296
- trackCopyToClipboard({
1297
- type: viewMode,
1298
- from: "lineage_view",
1299
- });
1300
- }}
1301
- style={{
1302
- backgroundColor: isDark ? colors.neutral[700] : undefined,
1303
- color: isDark ? colors.neutral[200] : undefined,
1304
- }}
1305
- >
1306
- <Box component={FiCopy} />
1307
- </ControlButton>
1308
- </Controls>
1309
- <ImageDownloadModal />
1310
- <Panel position="bottom-left">
1311
- <Stack spacing="5px">
1312
- {isModelsChanged && <ChangeStatusLegend />}
1313
- {viewOptions.column_level_lineage && (
1314
- <ColumnLevelLineageLegend />
1315
- )}
1316
- </Stack>
1317
- </Panel>
1318
- <Panel position="top-center">
1319
- <LineageViewNotification
1320
- notification={
1321
- singleEnv ? <BaseEnvironmentSetupNotification /> : null
1322
- }
1323
- type={"info"}
1324
- />
1325
- </Panel>
1326
- <Panel position="top-left">
1327
- <Stack spacing="5px">
1328
- <ColumnLevelLineageControl action={actionGetCll} />
1329
- {nodes.length == 0 && (
1330
- <Typography
1331
- sx={{ fontSize: "1.25rem", color: "grey", opacity: 0.5 }}
1332
- >
1333
- No nodes
1334
- </Typography>
1335
- )}
1336
- </Stack>
1337
- </Panel>
1338
- <MiniMap
1339
- nodeColor={nodeColor}
1340
- nodeStrokeWidth={3}
1341
- zoomable
1342
- pannable
1343
- bgColor={isDark ? colors.neutral[800] : undefined}
1344
- maskColor={
1345
- isDark ? `${colors.neutral[900]}99` : `${colors.neutral[100]}99`
1346
- }
1347
- />
1348
- {selectMode === "action_result" && (
1349
- <Panel
1350
- position="bottom-center"
1351
- className={IGNORE_SCREENSHOT_CLASS}
1352
- >
1353
- <ActionControl
1354
- onClose={() => {
1355
- deselect();
1356
- }}
1357
- />
1358
- </Panel>
1359
- )}
1360
- </ReactFlow>
1361
- <LineageViewContextMenu {...lineageViewContextMenu.props} />
1362
- </Stack>
1363
- {focusedNode ? (
1364
- <Box
1365
- sx={{
1366
- borderLeft: "solid 1px",
1367
- borderColor: "divider",
1368
- height: "100%",
1369
- }}
1370
- >
1371
- <NodeView node={focusedNode} onCloseNode={onNodeViewClosed} />
1372
- </Box>
1373
- ) : (
1374
- <Box></Box>
1375
- )}
1376
- </HSplit>
1377
- {valueDiffAlertDialog.AlertDialog}
1378
- </LineageViewContext.Provider>
1379
- );
1380
- }
1381
-
1382
- export const LineageView = forwardRef<LineageViewRef, LineageViewProps>(
1383
- PrivateLineageView,
1384
- );