@datarecce/ui 0.1.40 → 0.2.0

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 (719) hide show
  1. package/README.md +28 -133
  2. package/dist/AuthModal-C8LetZNB.js +23 -0
  3. package/dist/AuthModal-C8LetZNB.js.map +1 -0
  4. package/dist/LineageCanvas-CR38SDYr.d.ts +41 -0
  5. package/dist/LineageCanvas-CR38SDYr.d.ts.map +1 -0
  6. package/dist/ResultErrorFallback-C7c-TN1p.js +3 -0
  7. package/dist/ResultErrorFallback-C7c-TN1p.js.map +1 -0
  8. package/dist/RouteConfigContext-z8YNimdP.d.ts +172 -0
  9. package/dist/RouteConfigContext-z8YNimdP.d.ts.map +1 -0
  10. package/dist/RunProgress-DyFIALbI.d.ts +429 -0
  11. package/dist/RunProgress-DyFIALbI.d.ts.map +1 -0
  12. package/dist/ScreenshotDataGrid-BfxYUThx.d.ts +64 -0
  13. package/dist/ScreenshotDataGrid-BfxYUThx.d.ts.map +1 -0
  14. package/dist/SplitPane-B-BLxZaQ.d.ts +1427 -0
  15. package/dist/SplitPane-B-BLxZaQ.d.ts.map +1 -0
  16. package/dist/advanced.d.ts +18 -0
  17. package/dist/advanced.d.ts.map +1 -0
  18. package/dist/advanced.js +3 -0
  19. package/dist/advanced.js.map +1 -0
  20. package/dist/api-ZZ4cc9b9.d.ts +255 -0
  21. package/dist/api-ZZ4cc9b9.d.ts.map +1 -0
  22. package/dist/api-_i6BZPkM.js +3 -0
  23. package/dist/api-_i6BZPkM.js.map +1 -0
  24. package/dist/api.d.ts +3 -2
  25. package/dist/api.js +2 -100
  26. package/dist/colors--47Kkns4.js +3 -0
  27. package/dist/colors--47Kkns4.js.map +1 -0
  28. package/dist/colors-vY9Yzui0.d.ts +255 -0
  29. package/dist/colors-vY9Yzui0.d.ts.map +1 -0
  30. package/dist/components-run.d.ts +8 -0
  31. package/dist/components-run.js +2 -0
  32. package/dist/components.d.ts +22 -2
  33. package/dist/components.js +2 -86
  34. package/dist/const-DbXBkrxT.js +3 -0
  35. package/dist/const-DbXBkrxT.js.map +1 -0
  36. package/dist/constants-DD5vJv2q.js +3 -0
  37. package/dist/constants-DD5vJv2q.js.map +1 -0
  38. package/dist/constants.d.ts +3 -0
  39. package/dist/constants.js +2 -0
  40. package/dist/contexts.d.ts +7 -0
  41. package/dist/contexts.js +2 -0
  42. package/dist/flag-CiR2E5oz.d.ts +898 -0
  43. package/dist/flag-CiR2E5oz.d.ts.map +1 -0
  44. package/dist/flag-koeDAqr3.js +3 -0
  45. package/dist/flag-koeDAqr3.js.map +1 -0
  46. package/dist/hooks.d.ts +15 -2
  47. package/dist/hooks.js +2 -43
  48. package/dist/index-BFkbe0aF.d.ts +698 -0
  49. package/dist/index-BFkbe0aF.d.ts.map +1 -0
  50. package/dist/index-Ba3hp2Ng.d.ts +471 -0
  51. package/dist/index-Ba3hp2Ng.d.ts.map +1 -0
  52. package/dist/index-C_kD4ZQ3.d.ts +1079 -0
  53. package/dist/index-C_kD4ZQ3.d.ts.map +1 -0
  54. package/dist/index-CiPcALu4.d.ts +146 -0
  55. package/dist/index-CiPcALu4.d.ts.map +1 -0
  56. package/dist/index-CkXLPYZY.d.ts +13 -0
  57. package/dist/index-CkXLPYZY.d.ts.map +1 -0
  58. package/dist/index-DTCpHvX_.d.ts +211 -0
  59. package/dist/index-DTCpHvX_.d.ts.map +1 -0
  60. package/dist/index-DVoQsx5c.d.ts +349 -0
  61. package/dist/index-DVoQsx5c.d.ts.map +1 -0
  62. package/dist/index-DmwYRgDR.d.ts +192 -0
  63. package/dist/index-DmwYRgDR.d.ts.map +1 -0
  64. package/dist/index-N8N7XmRj.d.ts +130 -0
  65. package/dist/index-N8N7XmRj.d.ts.map +1 -0
  66. package/dist/index-h_fw6R9U.d.ts +1501 -0
  67. package/dist/index-h_fw6R9U.d.ts.map +1 -0
  68. package/dist/index-o48TPoFN.d.ts +734 -0
  69. package/dist/index-o48TPoFN.d.ts.map +1 -0
  70. package/dist/index.d.ts +24 -2
  71. package/dist/index.js +2 -198
  72. package/dist/keepAlive-CEzyrDfg.js +3 -0
  73. package/dist/keepAlive-CEzyrDfg.js.map +1 -0
  74. package/dist/lib/api/axiosClient.d.ts +8 -0
  75. package/dist/lib/api/axiosClient.d.ts.map +1 -0
  76. package/dist/lib/api/axiosClient.js +3 -0
  77. package/dist/lib/api/axiosClient.js.map +1 -0
  78. package/dist/lib/api/track.d.ts +137 -0
  79. package/dist/lib/api/track.d.ts.map +1 -0
  80. package/dist/lib/api/track.js +2 -0
  81. package/dist/lib/api/user.d.ts +16 -0
  82. package/dist/lib/api/user.d.ts.map +1 -0
  83. package/dist/lib/api/user.js +2 -0
  84. package/dist/lib/const.d.ts +8 -0
  85. package/dist/lib/const.d.ts.map +1 -0
  86. package/dist/lib/const.js +2 -0
  87. package/dist/lib/result/ResultErrorFallback.d.ts +8 -0
  88. package/dist/lib/result/ResultErrorFallback.d.ts.map +1 -0
  89. package/dist/lib/result/ResultErrorFallback.js +2 -0
  90. package/dist/primitives-CgGUvwHB.d.ts +914 -0
  91. package/dist/primitives-CgGUvwHB.d.ts.map +1 -0
  92. package/dist/primitives.d.ts +12 -0
  93. package/dist/primitives.js +2 -0
  94. package/dist/result.d.ts +4 -0
  95. package/dist/result.js +2 -0
  96. package/dist/src-BgHSbbHk.js +67 -0
  97. package/dist/src-BgHSbbHk.js.map +1 -0
  98. package/dist/styles.css +478 -4
  99. package/dist/theme-CeWzymUn.js +64 -0
  100. package/dist/theme-CeWzymUn.js.map +1 -0
  101. package/dist/theme.d.ts +3 -2
  102. package/dist/theme.js +2 -9
  103. package/dist/track-9ZQpBlUK.js +3 -0
  104. package/dist/track-9ZQpBlUK.js.map +1 -0
  105. package/dist/types-CFbNxrx2.d.ts +171 -0
  106. package/dist/types-CFbNxrx2.d.ts.map +1 -0
  107. package/dist/types-CZre3j02.d.ts +231 -0
  108. package/dist/types-CZre3j02.d.ts.map +1 -0
  109. package/dist/types.d.ts +14 -2
  110. package/dist/types.js +3 -9
  111. package/dist/types.js.map +1 -0
  112. package/dist/useRecceServerFlag-Bg5R67J4.js +3 -0
  113. package/dist/useRecceServerFlag-Bg5R67J4.js.map +1 -0
  114. package/dist/useThemeColors--prVbMmM.js +3 -0
  115. package/dist/useThemeColors--prVbMmM.js.map +1 -0
  116. package/dist/useThemeColors-DHEroo8f.d.ts +104 -0
  117. package/dist/useThemeColors-DHEroo8f.d.ts.map +1 -0
  118. package/dist/user-DMT7E0fc.js +3 -0
  119. package/dist/user-DMT7E0fc.js.map +1 -0
  120. package/dist/utils-CW2skXm_.js +3 -0
  121. package/dist/utils-CW2skXm_.js.map +1 -0
  122. package/dist/utils-CXWhfyxC.js +5 -0
  123. package/dist/utils-CXWhfyxC.js.map +1 -0
  124. package/dist/utils.d.ts +7 -0
  125. package/dist/utils.js +2 -0
  126. package/package.json +115 -107
  127. package/LICENSE +0 -201
  128. package/dist/RecceCheckContext-BJprb2xR.js +0 -7968
  129. package/dist/RecceCheckContext-BJprb2xR.js.map +0 -1
  130. package/dist/RecceCheckContext-DPnWB_aU.css +0 -215
  131. package/dist/RecceCheckContext-DPnWB_aU.css.map +0 -1
  132. package/dist/RecceCheckContext-DbZ7BdRy.mjs +0 -7426
  133. package/dist/RecceCheckContext-DbZ7BdRy.mjs.map +0 -1
  134. package/dist/RecceCheckContext-DyxOeUsX.css +0 -215
  135. package/dist/RecceCheckContext-DyxOeUsX.css.map +0 -1
  136. package/dist/api.d.mts +0 -3
  137. package/dist/api.js.map +0 -1
  138. package/dist/api.mjs +0 -46
  139. package/dist/api.mjs.map +0 -1
  140. package/dist/components-B6oaPB5f.mjs +0 -11769
  141. package/dist/components-B6oaPB5f.mjs.map +0 -1
  142. package/dist/components-BeAjVBV3.css +0 -70
  143. package/dist/components-BeAjVBV3.css.map +0 -1
  144. package/dist/components-DTLQ2djq.js +0 -14110
  145. package/dist/components-DTLQ2djq.js.map +0 -1
  146. package/dist/components-iUxcqtUB.css +0 -70
  147. package/dist/components-iUxcqtUB.css.map +0 -1
  148. package/dist/components.d.mts +0 -3
  149. package/dist/components.mjs +0 -9
  150. package/dist/const-CaIm1Z8g.mjs +0 -12
  151. package/dist/const-CaIm1Z8g.mjs.map +0 -1
  152. package/dist/const-CvdZO0FN.js +0 -24
  153. package/dist/const-CvdZO0FN.js.map +0 -1
  154. package/dist/hooks-cQsBXBd1.js +0 -40
  155. package/dist/hooks-cQsBXBd1.js.map +0 -1
  156. package/dist/hooks-eaHm_yEp.mjs +0 -33
  157. package/dist/hooks-eaHm_yEp.mjs.map +0 -1
  158. package/dist/hooks.d.mts +0 -3
  159. package/dist/hooks.mjs +0 -8
  160. package/dist/html2canvas-pro.esm-CsuSOHXp.js +0 -7250
  161. package/dist/html2canvas-pro.esm-CsuSOHXp.js.map +0 -1
  162. package/dist/html2canvas-pro.esm-E7kpobrC.mjs +0 -7249
  163. package/dist/html2canvas-pro.esm-E7kpobrC.mjs.map +0 -1
  164. package/dist/index-B9lSPJTi.d.ts +0 -2170
  165. package/dist/index-B9lSPJTi.d.ts.map +0 -1
  166. package/dist/index-CbF0x3kW.d.mts +0 -2172
  167. package/dist/index-CbF0x3kW.d.mts.map +0 -1
  168. package/dist/index.d.mts +0 -3
  169. package/dist/index.js.map +0 -1
  170. package/dist/index.mjs +0 -20
  171. package/dist/index.mjs.map +0 -1
  172. package/dist/mui-theme-CUhybmBq.mjs +0 -696
  173. package/dist/mui-theme-CUhybmBq.mjs.map +0 -1
  174. package/dist/mui-theme-iBHkjXJq.js +0 -732
  175. package/dist/mui-theme-iBHkjXJq.js.map +0 -1
  176. package/dist/state-CTITyT0R.js +0 -795
  177. package/dist/state-CTITyT0R.js.map +0 -1
  178. package/dist/state-Sc2b4jri.mjs +0 -382
  179. package/dist/state-Sc2b4jri.mjs.map +0 -1
  180. package/dist/theme.d.mts +0 -3
  181. package/dist/theme.mjs +0 -4
  182. package/dist/tooltipMessage-BC5W7H3X.js +0 -13
  183. package/dist/tooltipMessage-BC5W7H3X.js.map +0 -1
  184. package/dist/tooltipMessage-B_xMIKWL.mjs +0 -7
  185. package/dist/tooltipMessage-B_xMIKWL.mjs.map +0 -1
  186. package/dist/types.d.mts +0 -3
  187. package/dist/types.mjs +0 -6
  188. package/dist/urls-BQW5wjg-.js +0 -13
  189. package/dist/urls-BQW5wjg-.js.map +0 -1
  190. package/dist/urls-DT7FVEcS.mjs +0 -7
  191. package/dist/urls-DT7FVEcS.mjs.map +0 -1
  192. package/dist/version-B9s8yne-.js +0 -300
  193. package/dist/version-B9s8yne-.js.map +0 -1
  194. package/dist/version-DP1kU_7v.mjs +0 -162
  195. package/dist/version-DP1kU_7v.mjs.map +0 -1
  196. package/recce-source/.editorconfig +0 -26
  197. package/recce-source/.flake8 +0 -37
  198. package/recce-source/.github/ISSUE_TEMPLATE/bug_report.yml +0 -67
  199. package/recce-source/.github/ISSUE_TEMPLATE/custom.md +0 -10
  200. package/recce-source/.github/ISSUE_TEMPLATE/feature_request.yml +0 -42
  201. package/recce-source/.github/PULL_REQUEST_TEMPLATE.md +0 -21
  202. package/recce-source/.github/copilot-instructions.md +0 -331
  203. package/recce-source/.github/instructions/backend-instructions.md +0 -541
  204. package/recce-source/.github/instructions/frontend-instructions.md +0 -317
  205. package/recce-source/.github/workflows/build-statics.yaml +0 -72
  206. package/recce-source/.github/workflows/bump.yaml +0 -48
  207. package/recce-source/.github/workflows/integration-tests-cloud.yaml +0 -92
  208. package/recce-source/.github/workflows/integration-tests-sqlmesh.yaml +0 -33
  209. package/recce-source/.github/workflows/integration-tests.yaml +0 -52
  210. package/recce-source/.github/workflows/nightly.yaml +0 -246
  211. package/recce-source/.github/workflows/release.yaml +0 -196
  212. package/recce-source/.github/workflows/tests-js.yaml +0 -58
  213. package/recce-source/.github/workflows/tests-python.yaml +0 -128
  214. package/recce-source/.pre-commit-config.yaml +0 -26
  215. package/recce-source/CLAUDE.md +0 -483
  216. package/recce-source/CODE_OF_CONDUCT.md +0 -128
  217. package/recce-source/CONTRIBUTING.md +0 -107
  218. package/recce-source/LICENSE +0 -201
  219. package/recce-source/Makefile +0 -126
  220. package/recce-source/README.md +0 -182
  221. package/recce-source/RECCE_CLOUD.md +0 -81
  222. package/recce-source/SECURITY.md +0 -25
  223. package/recce-source/docs/PACKAGING.md +0 -340
  224. package/recce-source/docs/README.md +0 -1
  225. package/recce-source/integration_tests/dbt/dbt_project.yml +0 -26
  226. package/recce-source/integration_tests/dbt/models/customers.sql +0 -69
  227. package/recce-source/integration_tests/dbt/models/docs.md +0 -14
  228. package/recce-source/integration_tests/dbt/models/orders.sql +0 -56
  229. package/recce-source/integration_tests/dbt/models/schema.yml +0 -82
  230. package/recce-source/integration_tests/dbt/models/staging/schema.yml +0 -31
  231. package/recce-source/integration_tests/dbt/models/staging/stg_customers.sql +0 -22
  232. package/recce-source/integration_tests/dbt/models/staging/stg_orders.sql +0 -23
  233. package/recce-source/integration_tests/dbt/models/staging/stg_payments.sql +0 -25
  234. package/recce-source/integration_tests/dbt/packages.yml +0 -7
  235. package/recce-source/integration_tests/dbt/profiles.yml +0 -8
  236. package/recce-source/integration_tests/dbt/seeds/raw_customers.csv +0 -101
  237. package/recce-source/integration_tests/dbt/seeds/raw_orders.csv +0 -100
  238. package/recce-source/integration_tests/dbt/seeds/raw_payments.csv +0 -114
  239. package/recce-source/integration_tests/dbt/seeds/raw_statuses.csv +0 -5
  240. package/recce-source/integration_tests/dbt/smoke_test.sh +0 -72
  241. package/recce-source/integration_tests/dbt/smoke_test_cloud.sh +0 -71
  242. package/recce-source/integration_tests/sqlmesh/__init__.py +0 -0
  243. package/recce-source/integration_tests/sqlmesh/audits/assert_item_price_above_zero.sql +0 -9
  244. package/recce-source/integration_tests/sqlmesh/audits/items.sql +0 -7
  245. package/recce-source/integration_tests/sqlmesh/audits/order_items.sql +0 -7
  246. package/recce-source/integration_tests/sqlmesh/config.py +0 -171
  247. package/recce-source/integration_tests/sqlmesh/helper.py +0 -20
  248. package/recce-source/integration_tests/sqlmesh/hooks/__init__.py +0 -0
  249. package/recce-source/integration_tests/sqlmesh/macros/__init__.py +0 -0
  250. package/recce-source/integration_tests/sqlmesh/macros/macros.py +0 -8
  251. package/recce-source/integration_tests/sqlmesh/macros/macros.sql +0 -8
  252. package/recce-source/integration_tests/sqlmesh/macros/utils.py +0 -11
  253. package/recce-source/integration_tests/sqlmesh/metrics/metrics.sql +0 -25
  254. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_by_day.sql +0 -41
  255. package/recce-source/integration_tests/sqlmesh/models/customer_revenue_lifetime.sql +0 -60
  256. package/recce-source/integration_tests/sqlmesh/models/customers.sql +0 -32
  257. package/recce-source/integration_tests/sqlmesh/models/items.py +0 -95
  258. package/recce-source/integration_tests/sqlmesh/models/marketing.sql +0 -15
  259. package/recce-source/integration_tests/sqlmesh/models/order_items.py +0 -95
  260. package/recce-source/integration_tests/sqlmesh/models/orders.py +0 -70
  261. package/recce-source/integration_tests/sqlmesh/models/raw_marketing.py +0 -62
  262. package/recce-source/integration_tests/sqlmesh/models/top_waiters.sql +0 -23
  263. package/recce-source/integration_tests/sqlmesh/models/waiter_as_customer_by_day.sql +0 -29
  264. package/recce-source/integration_tests/sqlmesh/models/waiter_names.sql +0 -10
  265. package/recce-source/integration_tests/sqlmesh/models/waiter_revenue_by_day.sql +0 -29
  266. package/recce-source/integration_tests/sqlmesh/models/waiters.py +0 -62
  267. package/recce-source/integration_tests/sqlmesh/prep_env.sh +0 -16
  268. package/recce-source/integration_tests/sqlmesh/schema.yaml +0 -5
  269. package/recce-source/integration_tests/sqlmesh/seeds/waiter_names.csv +0 -11
  270. package/recce-source/integration_tests/sqlmesh/test_server.sh +0 -29
  271. package/recce-source/integration_tests/sqlmesh/tests/test_customer_revenue_by_day.yaml +0 -63
  272. package/recce-source/integration_tests/sqlmesh/tests/test_order_items.yaml +0 -72
  273. package/recce-source/js/.editorconfig +0 -27
  274. package/recce-source/js/.env.development +0 -5
  275. package/recce-source/js/.husky/pre-commit +0 -29
  276. package/recce-source/js/.nvmrc +0 -1
  277. package/recce-source/js/README.md +0 -39
  278. package/recce-source/js/app/(mainComponents)/DisplayModeToggle.tsx +0 -65
  279. package/recce-source/js/app/(mainComponents)/NavBar.tsx +0 -228
  280. package/recce-source/js/app/(mainComponents)/RecceVersionBadge.tsx +0 -107
  281. package/recce-source/js/app/(mainComponents)/TopBar.tsx +0 -252
  282. package/recce-source/js/app/@lineage/default.tsx +0 -20
  283. package/recce-source/js/app/@lineage/page.tsx +0 -14
  284. package/recce-source/js/app/MainLayout.tsx +0 -170
  285. package/recce-source/js/app/Providers.tsx +0 -49
  286. package/recce-source/js/app/checks/page.tsx +0 -296
  287. package/recce-source/js/app/error.tsx +0 -93
  288. package/recce-source/js/app/favicon.ico +0 -0
  289. package/recce-source/js/app/global-error.tsx +0 -115
  290. package/recce-source/js/app/global.css +0 -82
  291. package/recce-source/js/app/layout.tsx +0 -48
  292. package/recce-source/js/app/lineage/page.tsx +0 -15
  293. package/recce-source/js/app/page.tsx +0 -12
  294. package/recce-source/js/app/query/page.tsx +0 -8
  295. package/recce-source/js/biome.json +0 -313
  296. package/recce-source/js/jest.config.js +0 -34
  297. package/recce-source/js/jest.globals.d.ts +0 -32
  298. package/recce-source/js/jest.setup.js +0 -91
  299. package/recce-source/js/next.config.js +0 -16
  300. package/recce-source/js/package-lock.json +0 -13843
  301. package/recce-source/js/package.json +0 -123
  302. package/recce-source/js/pnpm-lock.yaml +0 -9235
  303. package/recce-source/js/pnpm-workspace.yaml +0 -6
  304. package/recce-source/js/postcss.config.js +0 -5
  305. package/recce-source/js/public/auth_callback.html +0 -68
  306. package/recce-source/js/public/imgs/feedback/thumbs-down.png +0 -0
  307. package/recce-source/js/public/imgs/feedback/thumbs-up.png +0 -0
  308. package/recce-source/js/public/imgs/reload-image.svg +0 -4
  309. package/recce-source/js/public/logo/recce-logo-white.png +0 -0
  310. package/recce-source/js/src/components/AuthModal/AuthModal.tsx +0 -202
  311. package/recce-source/js/src/components/app/AvatarDropdown.tsx +0 -159
  312. package/recce-source/js/src/components/app/EnvInfo.tsx +0 -357
  313. package/recce-source/js/src/components/app/Filename.tsx +0 -388
  314. package/recce-source/js/src/components/app/SetupConnectionPopover.tsx +0 -91
  315. package/recce-source/js/src/components/app/StateExporter.tsx +0 -57
  316. package/recce-source/js/src/components/app/StateImporter.tsx +0 -198
  317. package/recce-source/js/src/components/app/StateSharing.tsx +0 -145
  318. package/recce-source/js/src/components/app/StateSynchronizer.tsx +0 -205
  319. package/recce-source/js/src/components/charts/HistogramChart.tsx +0 -291
  320. package/recce-source/js/src/components/charts/SquareIcon.tsx +0 -51
  321. package/recce-source/js/src/components/charts/TopKSummaryList.tsx +0 -457
  322. package/recce-source/js/src/components/charts/chartTheme.ts +0 -74
  323. package/recce-source/js/src/components/check/CheckBreadcrumb.tsx +0 -97
  324. package/recce-source/js/src/components/check/CheckDescription.tsx +0 -134
  325. package/recce-source/js/src/components/check/CheckDetail.tsx +0 -797
  326. package/recce-source/js/src/components/check/CheckEmptyState.tsx +0 -84
  327. package/recce-source/js/src/components/check/CheckList.tsx +0 -320
  328. package/recce-source/js/src/components/check/LineageDiffView.tsx +0 -32
  329. package/recce-source/js/src/components/check/PresetCheckTemplateView.tsx +0 -48
  330. package/recce-source/js/src/components/check/SchemaDiffView.tsx +0 -290
  331. package/recce-source/js/src/components/check/check.ts +0 -25
  332. package/recce-source/js/src/components/check/timeline/CheckTimeline.tsx +0 -163
  333. package/recce-source/js/src/components/check/timeline/CommentInput.tsx +0 -84
  334. package/recce-source/js/src/components/check/timeline/TimelineEvent.tsx +0 -468
  335. package/recce-source/js/src/components/check/timeline/index.ts +0 -12
  336. package/recce-source/js/src/components/check/utils.ts +0 -12
  337. package/recce-source/js/src/components/data-grid/ScreenshotDataGrid.tsx +0 -333
  338. package/recce-source/js/src/components/data-grid/agGridStyles.css +0 -55
  339. package/recce-source/js/src/components/data-grid/agGridTheme.ts +0 -43
  340. package/recce-source/js/src/components/editor/CodeEditor.tsx +0 -107
  341. package/recce-source/js/src/components/editor/DiffEditor.tsx +0 -162
  342. package/recce-source/js/src/components/editor/index.ts +0 -12
  343. package/recce-source/js/src/components/errorboundary/ErrorBoundary.tsx +0 -87
  344. package/recce-source/js/src/components/histogram/HistogramDiffForm.tsx +0 -147
  345. package/recce-source/js/src/components/histogram/HistogramDiffResultView.tsx +0 -63
  346. package/recce-source/js/src/components/icons/index.tsx +0 -142
  347. package/recce-source/js/src/components/lineage/ActionControl.tsx +0 -63
  348. package/recce-source/js/src/components/lineage/ActionTag.tsx +0 -141
  349. package/recce-source/js/src/components/lineage/ChangeStatusLegend.tsx +0 -46
  350. package/recce-source/js/src/components/lineage/ColumnLevelLineageControl.tsx +0 -327
  351. package/recce-source/js/src/components/lineage/ColumnLevelLineageLegend.tsx +0 -57
  352. package/recce-source/js/src/components/lineage/GraphColumnNode.tsx +0 -199
  353. package/recce-source/js/src/components/lineage/GraphEdge.tsx +0 -59
  354. package/recce-source/js/src/components/lineage/GraphNode.tsx +0 -555
  355. package/recce-source/js/src/components/lineage/LineagePage.tsx +0 -10
  356. package/recce-source/js/src/components/lineage/LineageView.tsx +0 -1384
  357. package/recce-source/js/src/components/lineage/LineageViewContext.tsx +0 -86
  358. package/recce-source/js/src/components/lineage/LineageViewContextMenu.tsx +0 -637
  359. package/recce-source/js/src/components/lineage/LineageViewNotification.tsx +0 -64
  360. package/recce-source/js/src/components/lineage/LineageViewTopBar.tsx +0 -596
  361. package/recce-source/js/src/components/lineage/NodeSqlView.tsx +0 -136
  362. package/recce-source/js/src/components/lineage/NodeTag.tsx +0 -278
  363. package/recce-source/js/src/components/lineage/NodeView.tsx +0 -642
  364. package/recce-source/js/src/components/lineage/SandboxView.tsx +0 -436
  365. package/recce-source/js/src/components/lineage/ServerDisconnectedModalContent.tsx +0 -105
  366. package/recce-source/js/src/components/lineage/SetupConnectionBanner.tsx +0 -52
  367. package/recce-source/js/src/components/lineage/SingleEnvironmentQueryView.tsx +0 -152
  368. package/recce-source/js/src/components/lineage/graph.test.ts +0 -31
  369. package/recce-source/js/src/components/lineage/graph.ts +0 -58
  370. package/recce-source/js/src/components/lineage/lineage.test.ts +0 -169
  371. package/recce-source/js/src/components/lineage/lineage.ts +0 -521
  372. package/recce-source/js/src/components/lineage/styles.css +0 -42
  373. package/recce-source/js/src/components/lineage/styles.tsx +0 -165
  374. package/recce-source/js/src/components/lineage/useMultiNodesAction.ts +0 -352
  375. package/recce-source/js/src/components/lineage/useValueDiffAlertDialog.tsx +0 -108
  376. package/recce-source/js/src/components/onboarding-guide/Notification.tsx +0 -62
  377. package/recce-source/js/src/components/profile/ProfileDiffForm.tsx +0 -134
  378. package/recce-source/js/src/components/profile/ProfileDiffResultView.tsx +0 -243
  379. package/recce-source/js/src/components/query/ChangedOnlyCheckbox.tsx +0 -29
  380. package/recce-source/js/src/components/query/DiffText.tsx +0 -120
  381. package/recce-source/js/src/components/query/QueryDiffResultView.tsx +0 -468
  382. package/recce-source/js/src/components/query/QueryForm.tsx +0 -80
  383. package/recce-source/js/src/components/query/QueryPage.tsx +0 -282
  384. package/recce-source/js/src/components/query/QueryResultView.tsx +0 -180
  385. package/recce-source/js/src/components/query/SetupConnectionGuide.tsx +0 -57
  386. package/recce-source/js/src/components/query/SqlEditor.tsx +0 -245
  387. package/recce-source/js/src/components/query/ToggleSwitch.tsx +0 -84
  388. package/recce-source/js/src/components/query/styles.css +0 -21
  389. package/recce-source/js/src/components/routing/DirectUrlAccess.test.tsx +0 -428
  390. package/recce-source/js/src/components/routing/LineageStatePreservation.test.tsx +0 -311
  391. package/recce-source/js/src/components/routing/Navigation.test.tsx +0 -256
  392. package/recce-source/js/src/components/rowcount/RowCountDiffResultView.tsx +0 -108
  393. package/recce-source/js/src/components/rowcount/delta.test.ts +0 -51
  394. package/recce-source/js/src/components/rowcount/delta.ts +0 -16
  395. package/recce-source/js/src/components/run/RunList.tsx +0 -303
  396. package/recce-source/js/src/components/run/RunModal.tsx +0 -191
  397. package/recce-source/js/src/components/run/RunPage.tsx +0 -26
  398. package/recce-source/js/src/components/run/RunResultPane.tsx +0 -454
  399. package/recce-source/js/src/components/run/RunStatusAndDate.tsx +0 -106
  400. package/recce-source/js/src/components/run/RunToolbar.tsx +0 -70
  401. package/recce-source/js/src/components/run/RunView.tsx +0 -196
  402. package/recce-source/js/src/components/run/registry.ts +0 -214
  403. package/recce-source/js/src/components/run/types.ts +0 -14
  404. package/recce-source/js/src/components/schema/ColumnNameCell.test.tsx +0 -169
  405. package/recce-source/js/src/components/schema/ColumnNameCell.tsx +0 -198
  406. package/recce-source/js/src/components/schema/SchemaView.tsx +0 -336
  407. package/recce-source/js/src/components/schema/schemaDiff.ts +0 -32
  408. package/recce-source/js/src/components/schema/style.css +0 -134
  409. package/recce-source/js/src/components/screenshot/ScreenshotBox.tsx +0 -39
  410. package/recce-source/js/src/components/shared/HistoryToggle.tsx +0 -35
  411. package/recce-source/js/src/components/split/Split.tsx +0 -40
  412. package/recce-source/js/src/components/split/styles.css +0 -24
  413. package/recce-source/js/src/components/summary/ChangeSummary.tsx +0 -264
  414. package/recce-source/js/src/components/summary/SchemaSummary.tsx +0 -123
  415. package/recce-source/js/src/components/summary/SummaryView.tsx +0 -29
  416. package/recce-source/js/src/components/timeout/IdleTimeoutBadge.tsx +0 -48
  417. package/recce-source/js/src/components/top-k/TopKDiffForm.tsx +0 -58
  418. package/recce-source/js/src/components/top-k/TopKDiffResultView.tsx +0 -73
  419. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnGroupHeader.tsx +0 -228
  420. package/recce-source/js/src/components/ui/dataGrid/DataFrameColumnHeader.tsx +0 -113
  421. package/recce-source/js/src/components/ui/dataGrid/defaultRenderCell.tsx +0 -72
  422. package/recce-source/js/src/components/ui/dataGrid/index.ts +0 -23
  423. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.test.tsx +0 -607
  424. package/recce-source/js/src/components/ui/dataGrid/inlineRenderCell.tsx +0 -211
  425. package/recce-source/js/src/components/ui/dataGrid/schemaCells.test.tsx +0 -452
  426. package/recce-source/js/src/components/ui/dataGrid/schemaCells.tsx +0 -142
  427. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.test.tsx +0 -178
  428. package/recce-source/js/src/components/ui/dataGrid/valueDiffCells.tsx +0 -275
  429. package/recce-source/js/src/components/ui/markdown/ExternalLinkConfirmDialog.tsx +0 -134
  430. package/recce-source/js/src/components/ui/markdown/MarkdownContent.tsx +0 -364
  431. package/recce-source/js/src/components/ui/mui/index.ts +0 -13
  432. package/recce-source/js/src/components/ui/mui-provider.tsx +0 -67
  433. package/recce-source/js/src/components/ui/mui-theme.ts +0 -1039
  434. package/recce-source/js/src/components/ui/mui-utils.ts +0 -113
  435. package/recce-source/js/src/components/ui/toaster.tsx +0 -288
  436. package/recce-source/js/src/components/valuediff/ValueDiffDetailResultView.tsx +0 -216
  437. package/recce-source/js/src/components/valuediff/ValueDiffForm.tsx +0 -246
  438. package/recce-source/js/src/components/valuediff/ValueDiffResultView.tsx +0 -81
  439. package/recce-source/js/src/components/valuediff/shared.ts +0 -33
  440. package/recce-source/js/src/constants/tooltipMessage.ts +0 -3
  441. package/recce-source/js/src/constants/urls.ts +0 -1
  442. package/recce-source/js/src/lib/UrlHash.ts +0 -12
  443. package/recce-source/js/src/lib/api/adhocQuery.ts +0 -70
  444. package/recce-source/js/src/lib/api/axiosClient.ts +0 -9
  445. package/recce-source/js/src/lib/api/cacheKeys.ts +0 -13
  446. package/recce-source/js/src/lib/api/checkEvents.ts +0 -252
  447. package/recce-source/js/src/lib/api/checks.ts +0 -129
  448. package/recce-source/js/src/lib/api/cll.ts +0 -53
  449. package/recce-source/js/src/lib/api/connectToCloud.ts +0 -13
  450. package/recce-source/js/src/lib/api/flag.ts +0 -37
  451. package/recce-source/js/src/lib/api/info.ts +0 -198
  452. package/recce-source/js/src/lib/api/instanceInfo.ts +0 -25
  453. package/recce-source/js/src/lib/api/keepAlive.ts +0 -108
  454. package/recce-source/js/src/lib/api/lineagecheck.ts +0 -35
  455. package/recce-source/js/src/lib/api/localStorageKeys.ts +0 -7
  456. package/recce-source/js/src/lib/api/models.ts +0 -59
  457. package/recce-source/js/src/lib/api/profile.ts +0 -65
  458. package/recce-source/js/src/lib/api/rowcount.ts +0 -19
  459. package/recce-source/js/src/lib/api/runs.ts +0 -174
  460. package/recce-source/js/src/lib/api/schemacheck.ts +0 -31
  461. package/recce-source/js/src/lib/api/select.ts +0 -25
  462. package/recce-source/js/src/lib/api/sessionStorageKeys.ts +0 -8
  463. package/recce-source/js/src/lib/api/state.ts +0 -117
  464. package/recce-source/js/src/lib/api/track.ts +0 -281
  465. package/recce-source/js/src/lib/api/types.ts +0 -284
  466. package/recce-source/js/src/lib/api/user.ts +0 -42
  467. package/recce-source/js/src/lib/api/valuediff.ts +0 -46
  468. package/recce-source/js/src/lib/api/version.ts +0 -40
  469. package/recce-source/js/src/lib/const.ts +0 -9
  470. package/recce-source/js/src/lib/dataGrid/crossFunctionConsistency.test.ts +0 -626
  471. package/recce-source/js/src/lib/dataGrid/dataGridFactory.test.ts +0 -2140
  472. package/recce-source/js/src/lib/dataGrid/dataGridFactory.ts +0 -397
  473. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.test.ts +0 -132
  474. package/recce-source/js/src/lib/dataGrid/generators/rowCountUtils.ts +0 -126
  475. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.test.ts +0 -1627
  476. package/recce-source/js/src/lib/dataGrid/generators/toDataDiffGrid.ts +0 -140
  477. package/recce-source/js/src/lib/dataGrid/generators/toDataGrid.ts +0 -67
  478. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.test.ts +0 -142
  479. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDataGrid.ts +0 -71
  480. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.test.ts +0 -258
  481. package/recce-source/js/src/lib/dataGrid/generators/toRowCountDiffDataGrid.ts +0 -153
  482. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.test.ts +0 -951
  483. package/recce-source/js/src/lib/dataGrid/generators/toSchemaDataGrid.ts +0 -221
  484. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.test.ts +0 -395
  485. package/recce-source/js/src/lib/dataGrid/generators/toValueDataGrid.ts +0 -184
  486. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.test.ts +0 -884
  487. package/recce-source/js/src/lib/dataGrid/generators/toValueDiffGrid.ts +0 -113
  488. package/recce-source/js/src/lib/dataGrid/index.ts +0 -51
  489. package/recce-source/js/src/lib/dataGrid/propertyBased.test.ts +0 -858
  490. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.test.ts +0 -482
  491. package/recce-source/js/src/lib/dataGrid/shared/columnBuilders.ts +0 -345
  492. package/recce-source/js/src/lib/dataGrid/shared/dataTypeEdgeCases.test.ts +0 -698
  493. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.test.tsx +0 -820
  494. package/recce-source/js/src/lib/dataGrid/shared/diffColumnBuilder.tsx +0 -277
  495. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.test.ts +0 -785
  496. package/recce-source/js/src/lib/dataGrid/shared/gridUtils.ts +0 -370
  497. package/recce-source/js/src/lib/dataGrid/shared/index.ts +0 -81
  498. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.test.ts +0 -909
  499. package/recce-source/js/src/lib/dataGrid/shared/rowBuilders.ts +0 -325
  500. package/recce-source/js/src/lib/dataGrid/shared/simpleColumnBuilder.tsx +0 -240
  501. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.test.tsx +0 -719
  502. package/recce-source/js/src/lib/dataGrid/shared/toDiffColumn.tsx +0 -231
  503. package/recce-source/js/src/lib/dataGrid/shared/validation.test.ts +0 -559
  504. package/recce-source/js/src/lib/dataGrid/shared/validation.ts +0 -367
  505. package/recce-source/js/src/lib/dataGrid/warehouseNamingConventions.test.ts +0 -1117
  506. package/recce-source/js/src/lib/formatSelect.ts +0 -50
  507. package/recce-source/js/src/lib/hooks/ApiConfigContext.tsx +0 -181
  508. package/recce-source/js/src/lib/hooks/IdleTimeoutContext.tsx +0 -177
  509. package/recce-source/js/src/lib/hooks/LineageGraphContext.tsx +0 -512
  510. package/recce-source/js/src/lib/hooks/RecceActionContext.tsx +0 -269
  511. package/recce-source/js/src/lib/hooks/RecceCheckContext.tsx +0 -33
  512. package/recce-source/js/src/lib/hooks/RecceContextProvider.tsx +0 -54
  513. package/recce-source/js/src/lib/hooks/RecceInstanceContext.tsx +0 -129
  514. package/recce-source/js/src/lib/hooks/RecceQueryContext.tsx +0 -98
  515. package/recce-source/js/src/lib/hooks/RecceShareStateContext.tsx +0 -59
  516. package/recce-source/js/src/lib/hooks/ScreenShot.tsx +0 -399
  517. package/recce-source/js/src/lib/hooks/useAppRouter.test.ts +0 -211
  518. package/recce-source/js/src/lib/hooks/useAppRouter.ts +0 -200
  519. package/recce-source/js/src/lib/hooks/useCheckEvents.ts +0 -99
  520. package/recce-source/js/src/lib/hooks/useCheckToast.tsx +0 -14
  521. package/recce-source/js/src/lib/hooks/useClipBoardToast.tsx +0 -27
  522. package/recce-source/js/src/lib/hooks/useCountdownToast.tsx +0 -102
  523. package/recce-source/js/src/lib/hooks/useFeedbackCollectionToast.tsx +0 -130
  524. package/recce-source/js/src/lib/hooks/useGuideToast.tsx +0 -45
  525. package/recce-source/js/src/lib/hooks/useIdleDetection.tsx +0 -185
  526. package/recce-source/js/src/lib/hooks/useModelColumns.tsx +0 -113
  527. package/recce-source/js/src/lib/hooks/useRecceInstanceInfo.tsx +0 -13
  528. package/recce-source/js/src/lib/hooks/useRecceServerFlag.tsx +0 -13
  529. package/recce-source/js/src/lib/hooks/useRun.tsx +0 -89
  530. package/recce-source/js/src/lib/hooks/useThemeColors.ts +0 -115
  531. package/recce-source/js/src/lib/mergeKeys.test.ts +0 -89
  532. package/recce-source/js/src/lib/mergeKeys.ts +0 -86
  533. package/recce-source/js/src/lib/result/ResultErrorFallback.tsx +0 -9
  534. package/recce-source/js/src/lib/utils/formatTime.ts +0 -84
  535. package/recce-source/js/src/lib/utils/urls.ts +0 -16
  536. package/recce-source/js/src/utils/DropdownValuesInput.tsx +0 -297
  537. package/recce-source/js/src/utils/formatters.tsx +0 -237
  538. package/recce-source/js/src/utils/transforms.ts +0 -81
  539. package/recce-source/js/tsconfig.json +0 -47
  540. package/recce-source/macros/README.md +0 -8
  541. package/recce-source/macros/recce_athena.sql +0 -73
  542. package/recce-source/pyproject.toml +0 -109
  543. package/recce-source/recce/VERSION +0 -1
  544. package/recce-source/recce/__init__.py +0 -84
  545. package/recce-source/recce/adapter/__init__.py +0 -0
  546. package/recce-source/recce/adapter/base.py +0 -109
  547. package/recce-source/recce/adapter/dbt_adapter/__init__.py +0 -1699
  548. package/recce-source/recce/adapter/dbt_adapter/dbt_version.py +0 -42
  549. package/recce-source/recce/adapter/sqlmesh_adapter.py +0 -141
  550. package/recce-source/recce/apis/__init__.py +0 -0
  551. package/recce-source/recce/apis/check_api.py +0 -203
  552. package/recce-source/recce/apis/check_events_api.py +0 -353
  553. package/recce-source/recce/apis/check_func.py +0 -130
  554. package/recce-source/recce/apis/run_api.py +0 -130
  555. package/recce-source/recce/apis/run_func.py +0 -258
  556. package/recce-source/recce/artifact.py +0 -266
  557. package/recce-source/recce/cli.py +0 -1846
  558. package/recce-source/recce/config.py +0 -127
  559. package/recce-source/recce/connect_to_cloud.py +0 -138
  560. package/recce-source/recce/core.py +0 -334
  561. package/recce-source/recce/diff.py +0 -26
  562. package/recce-source/recce/event/CONFIG +0 -1
  563. package/recce-source/recce/event/SENTRY_DNS +0 -1
  564. package/recce-source/recce/event/__init__.py +0 -304
  565. package/recce-source/recce/event/collector.py +0 -184
  566. package/recce-source/recce/event/track.py +0 -158
  567. package/recce-source/recce/exceptions.py +0 -21
  568. package/recce-source/recce/git.py +0 -77
  569. package/recce-source/recce/github.py +0 -222
  570. package/recce-source/recce/mcp_server.py +0 -861
  571. package/recce-source/recce/models/__init__.py +0 -6
  572. package/recce-source/recce/models/check.py +0 -473
  573. package/recce-source/recce/models/run.py +0 -46
  574. package/recce-source/recce/models/types.py +0 -218
  575. package/recce-source/recce/pull_request.py +0 -124
  576. package/recce-source/recce/run.py +0 -390
  577. package/recce-source/recce/server.py +0 -877
  578. package/recce-source/recce/state/__init__.py +0 -31
  579. package/recce-source/recce/state/cloud.py +0 -644
  580. package/recce-source/recce/state/const.py +0 -26
  581. package/recce-source/recce/state/local.py +0 -56
  582. package/recce-source/recce/state/state.py +0 -119
  583. package/recce-source/recce/state/state_loader.py +0 -174
  584. package/recce-source/recce/summary.py +0 -575
  585. package/recce-source/recce/tasks/__init__.py +0 -23
  586. package/recce-source/recce/tasks/core.py +0 -134
  587. package/recce-source/recce/tasks/dataframe.py +0 -170
  588. package/recce-source/recce/tasks/histogram.py +0 -433
  589. package/recce-source/recce/tasks/lineage.py +0 -19
  590. package/recce-source/recce/tasks/profile.py +0 -298
  591. package/recce-source/recce/tasks/query.py +0 -450
  592. package/recce-source/recce/tasks/rowcount.py +0 -277
  593. package/recce-source/recce/tasks/schema.py +0 -65
  594. package/recce-source/recce/tasks/top_k.py +0 -172
  595. package/recce-source/recce/tasks/utils.py +0 -147
  596. package/recce-source/recce/tasks/valuediff.py +0 -497
  597. package/recce-source/recce/util/__init__.py +0 -4
  598. package/recce-source/recce/util/api_token.py +0 -80
  599. package/recce-source/recce/util/breaking.py +0 -330
  600. package/recce-source/recce/util/cache.py +0 -25
  601. package/recce-source/recce/util/cll.py +0 -355
  602. package/recce-source/recce/util/cloud/__init__.py +0 -15
  603. package/recce-source/recce/util/cloud/base.py +0 -115
  604. package/recce-source/recce/util/cloud/check_events.py +0 -190
  605. package/recce-source/recce/util/cloud/checks.py +0 -242
  606. package/recce-source/recce/util/io.py +0 -120
  607. package/recce-source/recce/util/lineage.py +0 -83
  608. package/recce-source/recce/util/logger.py +0 -25
  609. package/recce-source/recce/util/onboarding_state.py +0 -45
  610. package/recce-source/recce/util/perf_tracking.py +0 -85
  611. package/recce-source/recce/util/pydantic_model.py +0 -22
  612. package/recce-source/recce/util/recce_cloud.py +0 -454
  613. package/recce-source/recce/util/singleton.py +0 -18
  614. package/recce-source/recce/util/startup_perf.py +0 -121
  615. package/recce-source/recce/yaml/__init__.py +0 -58
  616. package/recce-source/recce_cloud/README.md +0 -780
  617. package/recce-source/recce_cloud/VERSION +0 -1
  618. package/recce-source/recce_cloud/__init__.py +0 -24
  619. package/recce-source/recce_cloud/api/__init__.py +0 -17
  620. package/recce-source/recce_cloud/api/base.py +0 -132
  621. package/recce-source/recce_cloud/api/client.py +0 -186
  622. package/recce-source/recce_cloud/api/exceptions.py +0 -26
  623. package/recce-source/recce_cloud/api/factory.py +0 -63
  624. package/recce-source/recce_cloud/api/github.py +0 -106
  625. package/recce-source/recce_cloud/api/gitlab.py +0 -111
  626. package/recce-source/recce_cloud/artifact.py +0 -57
  627. package/recce-source/recce_cloud/ci_providers/__init__.py +0 -9
  628. package/recce-source/recce_cloud/ci_providers/base.py +0 -82
  629. package/recce-source/recce_cloud/ci_providers/detector.py +0 -147
  630. package/recce-source/recce_cloud/ci_providers/github_actions.py +0 -136
  631. package/recce-source/recce_cloud/ci_providers/gitlab_ci.py +0 -130
  632. package/recce-source/recce_cloud/cli.py +0 -434
  633. package/recce-source/recce_cloud/download.py +0 -230
  634. package/recce-source/recce_cloud/hatch_build.py +0 -20
  635. package/recce-source/recce_cloud/pyproject.toml +0 -49
  636. package/recce-source/recce_cloud/upload.py +0 -214
  637. package/recce-source/test.py +0 -0
  638. package/recce-source/tests/__init__.py +0 -0
  639. package/recce-source/tests/adapter/__init__.py +0 -0
  640. package/recce-source/tests/adapter/dbt_adapter/__init__.py +0 -0
  641. package/recce-source/tests/adapter/dbt_adapter/conftest.py +0 -17
  642. package/recce-source/tests/adapter/dbt_adapter/dbt_test_helper.py +0 -298
  643. package/recce-source/tests/adapter/dbt_adapter/test_dbt_adapter.py +0 -25
  644. package/recce-source/tests/adapter/dbt_adapter/test_dbt_cll.py +0 -717
  645. package/recce-source/tests/adapter/dbt_adapter/test_proj/dbt_project.yml +0 -4
  646. package/recce-source/tests/adapter/dbt_adapter/test_proj/manifest.json +0 -1
  647. package/recce-source/tests/adapter/dbt_adapter/test_proj/package-lock.yml +0 -8
  648. package/recce-source/tests/adapter/dbt_adapter/test_proj/packages.yml +0 -7
  649. package/recce-source/tests/adapter/dbt_adapter/test_proj/profiles.yml +0 -6
  650. package/recce-source/tests/adapter/dbt_adapter/test_selector.py +0 -205
  651. package/recce-source/tests/apis/__init__.py +0 -0
  652. package/recce-source/tests/apis/row_count_diff.json +0 -59
  653. package/recce-source/tests/apis/test_check_events_api.py +0 -615
  654. package/recce-source/tests/apis/test_run_func.py +0 -433
  655. package/recce-source/tests/catalog.json +0 -527
  656. package/recce-source/tests/data/manifest/base/catalog.json +0 -1
  657. package/recce-source/tests/data/manifest/base/manifest.json +0 -1
  658. package/recce-source/tests/data/manifest/pr2/catalog.json +0 -1
  659. package/recce-source/tests/data/manifest/pr2/manifest.json +0 -1
  660. package/recce-source/tests/manifest.json +0 -10655
  661. package/recce-source/tests/models/__init__.py +0 -0
  662. package/recce-source/tests/models/test_check.py +0 -731
  663. package/recce-source/tests/models/test_run_models.py +0 -295
  664. package/recce-source/tests/recce_cloud/__init__.py +0 -0
  665. package/recce-source/tests/recce_cloud/test_ci_providers.py +0 -351
  666. package/recce-source/tests/recce_cloud/test_cli.py +0 -735
  667. package/recce-source/tests/recce_cloud/test_client.py +0 -379
  668. package/recce-source/tests/recce_cloud/test_platform_clients.py +0 -483
  669. package/recce-source/tests/recce_state.json +0 -1
  670. package/recce-source/tests/state/test_cloud.py +0 -719
  671. package/recce-source/tests/state/test_local.py +0 -164
  672. package/recce-source/tests/state/test_state_loader.py +0 -211
  673. package/recce-source/tests/tasks/__init__.py +0 -0
  674. package/recce-source/tests/tasks/conftest.py +0 -4
  675. package/recce-source/tests/tasks/test_histogram.py +0 -129
  676. package/recce-source/tests/tasks/test_lineage.py +0 -55
  677. package/recce-source/tests/tasks/test_preset_checks.py +0 -64
  678. package/recce-source/tests/tasks/test_profile.py +0 -397
  679. package/recce-source/tests/tasks/test_query.py +0 -528
  680. package/recce-source/tests/tasks/test_row_count.py +0 -133
  681. package/recce-source/tests/tasks/test_schema.py +0 -122
  682. package/recce-source/tests/tasks/test_top_k.py +0 -77
  683. package/recce-source/tests/tasks/test_utils.py +0 -439
  684. package/recce-source/tests/tasks/test_valuediff.py +0 -361
  685. package/recce-source/tests/test_cli.py +0 -236
  686. package/recce-source/tests/test_cli_mcp_optional.py +0 -45
  687. package/recce-source/tests/test_cloud_listing_cli.py +0 -324
  688. package/recce-source/tests/test_config.py +0 -43
  689. package/recce-source/tests/test_connect_to_cloud.py +0 -82
  690. package/recce-source/tests/test_core.py +0 -174
  691. package/recce-source/tests/test_dbt.py +0 -36
  692. package/recce-source/tests/test_mcp_server.py +0 -505
  693. package/recce-source/tests/test_pull_request.py +0 -130
  694. package/recce-source/tests/test_server.py +0 -202
  695. package/recce-source/tests/test_server_lifespan.py +0 -138
  696. package/recce-source/tests/test_summary.py +0 -73
  697. package/recce-source/tests/util/__init__.py +0 -0
  698. package/recce-source/tests/util/cloud/__init__.py +0 -0
  699. package/recce-source/tests/util/cloud/test_check_events.py +0 -255
  700. package/recce-source/tests/util/cloud/test_checks.py +0 -204
  701. package/recce-source/tests/util/test_api_token.py +0 -119
  702. package/recce-source/tests/util/test_breaking.py +0 -1427
  703. package/recce-source/tests/util/test_cll.py +0 -706
  704. package/recce-source/tests/util/test_lineage.py +0 -122
  705. package/recce-source/tests/util/test_onboarding_state.py +0 -84
  706. package/recce-source/tests/util/test_recce_cloud.py +0 -231
  707. package/recce-source/tox.ini +0 -40
  708. package/recce-source/uv.lock +0 -3928
  709. package/src/api/index.ts +0 -32
  710. package/src/components/index.ts +0 -154
  711. package/src/global.d.ts +0 -14
  712. package/src/hooks/index.ts +0 -56
  713. package/src/index.ts +0 -17
  714. package/src/lib/hooks/RouteConfigContext.ts +0 -139
  715. package/src/lib/hooks/useAppRouter.ts +0 -240
  716. package/src/mui-augmentation.d.ts +0 -139
  717. package/src/theme/index.ts +0 -13
  718. package/src/theme.ts +0 -23
  719. 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
- );