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