@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,785 +0,0 @@
1
- /**
2
- * @file gridUtils.test.ts
3
- * @description Tests for shared grid utilities
4
- *
5
- * Tests cover:
6
- * - Column map builders (buildColumnMap, buildJoinedColumnMap, buildMergedColumnMap)
7
- * - Primary key utilities (validatePrimaryKeys, getPrimaryKeyValue)
8
- * - Row status detection (determineRowStatus)
9
- * - Cell class utilities (getCellClass, getHeaderCellClass)
10
- * - Value rendering (toRenderedValue, columnRenderedValue)
11
- */
12
-
13
- import { ColumnType, DataFrame, RowData, RowObjectType } from "@/lib/api/types";
14
- import {
15
- buildColumnMap,
16
- buildJoinedColumnMap,
17
- buildMergedColumnMap,
18
- ColumnMapEntry,
19
- columnRenderedValue,
20
- determineRowStatus,
21
- formatSmartDecimal,
22
- getCellClass,
23
- getHeaderCellClass,
24
- getPrimaryKeyValue,
25
- toRenderedValue,
26
- validatePrimaryKeys,
27
- } from "./gridUtils";
28
-
29
- // ============================================================================
30
- // Test Fixtures
31
- // ============================================================================
32
-
33
- /**
34
- * Creates a DataFrame for testing
35
- */
36
- const createDataFrame = (
37
- columns: Array<{ name: string; key: string; type: ColumnType }>,
38
- data: RowData[] = [],
39
- ): DataFrame => ({
40
- columns,
41
- data,
42
- });
43
-
44
- /**
45
- * Helper to create a valid RowObjectType with required __status
46
- */
47
- const createRow = (
48
- values: Record<string, number | string | boolean | null | undefined>,
49
- status: "added" | "removed" | "modified" | undefined = undefined,
50
- ): RowObjectType => ({
51
- ...values,
52
- __status: status,
53
- });
54
-
55
- /**
56
- * Standard DataFrame fixture
57
- */
58
- const standardDataFrame = createDataFrame([
59
- { name: "id", key: "id", type: "integer" },
60
- { name: "name", key: "name", type: "text" },
61
- { name: "value", key: "value", type: "number" },
62
- ]);
63
-
64
- /**
65
- * DataFrame with in_a/in_b columns for joined data
66
- */
67
- const joinedDataFrame = createDataFrame([
68
- { name: "id", key: "id", type: "integer" },
69
- { name: "value", key: "value", type: "number" },
70
- { name: "in_a", key: "in_a", type: "boolean" },
71
- { name: "in_b", key: "in_b", type: "boolean" },
72
- ]);
73
-
74
- /**
75
- * DataFrame with lowercase in_a/in_b columns
76
- */
77
- const joinedDataFrameLowercase = createDataFrame([
78
- { name: "id", key: "id", type: "integer" },
79
- { name: "value", key: "value", type: "number" },
80
- { name: "in_a", key: "in_a", type: "boolean" },
81
- { name: "in_b", key: "in_b", type: "boolean" },
82
- ]);
83
-
84
- // ============================================================================
85
- // buildColumnMap Tests
86
- // ============================================================================
87
-
88
- describe("buildColumnMap", () => {
89
- test("builds column map from DataFrame", () => {
90
- const result = buildColumnMap(standardDataFrame);
91
-
92
- expect(result).toEqual({
93
- id: { key: "id", colType: "integer", index: 0 },
94
- name: { key: "name", colType: "text", index: 1 },
95
- value: { key: "value", colType: "number", index: 2 },
96
- });
97
- });
98
-
99
- test("handles empty DataFrame", () => {
100
- const emptyDf = createDataFrame([]);
101
-
102
- const result = buildColumnMap(emptyDf);
103
-
104
- expect(result).toEqual({});
105
- });
106
-
107
- test("preserves column index", () => {
108
- const result = buildColumnMap(standardDataFrame);
109
-
110
- expect(result.id.index).toBe(0);
111
- expect(result.name.index).toBe(1);
112
- expect(result.value.index).toBe(2);
113
- });
114
-
115
- test("handles various column types", () => {
116
- const df = createDataFrame([
117
- { name: "bool_col", key: "bool_col", type: "boolean" },
118
- { name: "date_col", key: "date_col", type: "date" },
119
- { name: "unknown_col", key: "unknown_col", type: "unknown" },
120
- ]);
121
-
122
- const result = buildColumnMap(df);
123
-
124
- expect(result.bool_col.colType).toBe("boolean");
125
- expect(result.date_col.colType).toBe("date");
126
- expect(result.unknown_col.colType).toBe("unknown");
127
- });
128
- });
129
-
130
- // ============================================================================
131
- // buildJoinedColumnMap Tests
132
- // ============================================================================
133
-
134
- describe("buildJoinedColumnMap", () => {
135
- test("handles uppercase in_a/in_b columns", () => {
136
- const result = buildJoinedColumnMap(joinedDataFrame);
137
-
138
- expect(result.in_a).toBeDefined();
139
- expect(result.in_b).toBeDefined();
140
- expect(result.in_a.key).toBe("in_a");
141
- expect(result.in_b.key).toBe("in_b");
142
- });
143
-
144
- test("handles lowercase in_a/in_b columns", () => {
145
- const result = buildJoinedColumnMap(joinedDataFrameLowercase);
146
-
147
- expect(result.in_a).toBeDefined();
148
- expect(result.in_b).toBeDefined();
149
- });
150
-
151
- test("in_a and in_b entries reference same key", () => {
152
- const result = buildJoinedColumnMap(joinedDataFrame);
153
-
154
- // Both should have same internal structure
155
- expect(result.in_a.colType).toBe("boolean");
156
- expect(result.in_b.colType).toBe("boolean");
157
- });
158
-
159
- test("regular columns added normally", () => {
160
- const result = buildJoinedColumnMap(joinedDataFrame);
161
-
162
- expect(result.id).toBeDefined();
163
- expect(result.id.colType).toBe("integer");
164
- expect(result.value).toBeDefined();
165
- expect(result.value.colType).toBe("number");
166
- });
167
-
168
- test("throws on empty DataFrame", () => {
169
- const emptyDf = createDataFrame([]);
170
-
171
- expect(() => {
172
- buildJoinedColumnMap(emptyDf);
173
- }).toThrow("Joined DataFrame missing required 'in_a' column");
174
- });
175
- });
176
-
177
- // ============================================================================
178
- // buildMergedColumnMap Tests
179
- // ============================================================================
180
-
181
- describe("buildMergedColumnMap", () => {
182
- test("merges columns from base and current", () => {
183
- const baseDf = createDataFrame([
184
- { name: "id", key: "id", type: "integer" },
185
- { name: "name", key: "name", type: "text" },
186
- ]);
187
- const currentDf = createDataFrame([
188
- { name: "id", key: "id", type: "integer" },
189
- { name: "name", key: "name", type: "text" },
190
- ]);
191
-
192
- const result = buildMergedColumnMap(baseDf, currentDf);
193
-
194
- expect(result.id).toBeDefined();
195
- expect(result.name).toBeDefined();
196
- });
197
-
198
- test("detects added columns", () => {
199
- const baseDf = createDataFrame([
200
- { name: "id", key: "id", type: "integer" },
201
- ]);
202
- const currentDf = createDataFrame([
203
- { name: "id", key: "id", type: "integer" },
204
- { name: "new_col", key: "new_col", type: "text" },
205
- ]);
206
-
207
- const result = buildMergedColumnMap(baseDf, currentDf);
208
-
209
- expect(result.new_col).toBeDefined();
210
- expect(result.new_col.status).toBe("added");
211
- });
212
-
213
- test("detects removed columns", () => {
214
- const baseDf = createDataFrame([
215
- { name: "id", key: "id", type: "integer" },
216
- { name: "old_col", key: "old_col", type: "text" },
217
- ]);
218
- const currentDf = createDataFrame([
219
- { name: "id", key: "id", type: "integer" },
220
- ]);
221
-
222
- const result = buildMergedColumnMap(baseDf, currentDf);
223
-
224
- expect(result.old_col).toBeDefined();
225
- expect(result.old_col.status).toBe("removed");
226
- });
227
-
228
- test("tracks baseColumnKey and currentColumnKey", () => {
229
- const baseDf = createDataFrame([
230
- { name: "id", key: "id", type: "integer" },
231
- { name: "shared", key: "shared", type: "text" },
232
- ]);
233
- const currentDf = createDataFrame([
234
- { name: "id", key: "id", type: "integer" },
235
- { name: "shared", key: "shared", type: "text" },
236
- ]);
237
-
238
- const result = buildMergedColumnMap(baseDf, currentDf);
239
-
240
- expect(result.shared.baseColumnKey).toBe("shared");
241
- expect(result.shared.currentColumnKey).toBe("shared");
242
- });
243
-
244
- test("uses 'unknown' for missing column keys", () => {
245
- const baseDf = createDataFrame([
246
- { name: "id", key: "id", type: "integer" },
247
- ]);
248
- const currentDf = createDataFrame([
249
- { name: "id", key: "id", type: "integer" },
250
- { name: "new_col", key: "new_col", type: "text" },
251
- ]);
252
-
253
- const result = buildMergedColumnMap(baseDf, currentDf);
254
-
255
- // Added column should have 'unknown' for baseColumnKey
256
- expect(result.new_col.baseColumnKey).toBe("unknown");
257
- expect(result.new_col.currentColumnKey).toBe("new_col");
258
- });
259
-
260
- test("handles empty DataFrames", () => {
261
- const emptyDf = createDataFrame([]);
262
-
263
- const result = buildMergedColumnMap(emptyDf, emptyDf);
264
-
265
- expect(result).toEqual({});
266
- });
267
-
268
- test("preserves column type", () => {
269
- const baseDf = createDataFrame([
270
- { name: "num", key: "num", type: "number" },
271
- ]);
272
- const currentDf = createDataFrame([
273
- { name: "num", key: "num", type: "number" },
274
- ]);
275
-
276
- const result = buildMergedColumnMap(baseDf, currentDf);
277
-
278
- expect(result.num.colType).toBe("number");
279
- });
280
- });
281
-
282
- // ============================================================================
283
- // validatePrimaryKeys Tests
284
- // ============================================================================
285
-
286
- describe("validatePrimaryKeys", () => {
287
- test("validates existing primary keys", () => {
288
- const result = validatePrimaryKeys(standardDataFrame.columns, ["id"]);
289
-
290
- expect(result).toEqual(["id"]);
291
- });
292
-
293
- test("validates multiple primary keys", () => {
294
- const result = validatePrimaryKeys(standardDataFrame.columns, [
295
- "id",
296
- "name",
297
- ]);
298
-
299
- expect(result).toEqual(["id", "name"]);
300
- });
301
-
302
- test("throws error for missing primary key", () => {
303
- expect(() => {
304
- validatePrimaryKeys(standardDataFrame.columns, ["nonexistent"]);
305
- }).toThrow("Column nonexistent not found");
306
- });
307
-
308
- test("case-sensitive matching by default", () => {
309
- expect(() => {
310
- validatePrimaryKeys(standardDataFrame.columns, ["ID"]);
311
- }).toThrow("Column ID not found");
312
- });
313
-
314
- test("returns actual column keys", () => {
315
- const df = createDataFrame([
316
- { name: "UserId", key: "user_id", type: "integer" },
317
- ]);
318
-
319
- const result = validatePrimaryKeys(df.columns, ["user_id"]);
320
-
321
- expect(result).toEqual(["user_id"]);
322
- });
323
-
324
- test("handles empty primary keys array", () => {
325
- const result = validatePrimaryKeys(standardDataFrame.columns, []);
326
-
327
- expect(result).toEqual([]);
328
- });
329
- });
330
-
331
- // ============================================================================
332
- // getPrimaryKeyValue Tests
333
- // ============================================================================
334
-
335
- describe("getPrimaryKeyValue", () => {
336
- test("generates key from single primary key", () => {
337
- const row = createRow({ id: 1, name: "Alice", value: 100 });
338
-
339
- const result = getPrimaryKeyValue(standardDataFrame.columns, ["id"], row);
340
-
341
- expect(result).toBe("id=1");
342
- });
343
-
344
- test("generates key from multiple primary keys", () => {
345
- const row = createRow({ id: 1, name: "Alice", value: 100 });
346
-
347
- const result = getPrimaryKeyValue(
348
- standardDataFrame.columns,
349
- ["id", "name"],
350
- row,
351
- );
352
-
353
- expect(result).toBe("id=1|name=Alice");
354
- });
355
-
356
- test("uses _index when no primary keys", () => {
357
- const row = createRow({ id: 1, name: "Alice", _index: 5 });
358
-
359
- const result = getPrimaryKeyValue(standardDataFrame.columns, [], row);
360
-
361
- expect(result).toBe("5");
362
- });
363
-
364
- test("handles null values", () => {
365
- const row = createRow({ id: null, name: "Alice", value: 100 });
366
-
367
- const result = getPrimaryKeyValue(standardDataFrame.columns, ["id"], row);
368
-
369
- expect(result).toBe("id=null");
370
- });
371
-
372
- test("throws error for missing primary key column", () => {
373
- const row = createRow({ id: 1, name: "Alice" });
374
-
375
- expect(() => {
376
- getPrimaryKeyValue(standardDataFrame.columns, ["nonexistent"], row);
377
- }).toThrow("Primary Column nonexistent not found");
378
- });
379
- });
380
-
381
- // ============================================================================
382
- // determineRowStatus Tests
383
- // ============================================================================
384
-
385
- describe("determineRowStatus", () => {
386
- const columnMap: Record<string, ColumnMapEntry> = {
387
- id: { key: "id", colType: "integer" },
388
- name: { key: "name", colType: "text" },
389
- value: { key: "value", colType: "number" },
390
- };
391
-
392
- test("returns 'added' when baseRow is undefined", () => {
393
- const currentRow = createRow({ id: 1, name: "Alice" });
394
-
395
- const result = determineRowStatus(undefined, currentRow, columnMap, ["id"]);
396
-
397
- expect(result).toBe("added");
398
- });
399
-
400
- test("returns 'removed' when currentRow is undefined", () => {
401
- const baseRow = createRow({ id: 1, name: "Alice" });
402
-
403
- const result = determineRowStatus(baseRow, undefined, columnMap, ["id"]);
404
-
405
- expect(result).toBe("removed");
406
- });
407
-
408
- test("returns 'modified' when values differ", () => {
409
- const baseRow = createRow({ id: 1, name: "Alice", value: 100 });
410
- const currentRow = createRow({ id: 1, name: "Alice", value: 200 });
411
-
412
- const result = determineRowStatus(baseRow, currentRow, columnMap, ["id"]);
413
-
414
- expect(result).toBe("modified");
415
- });
416
-
417
- test("returns undefined when rows are identical", () => {
418
- const baseRow = createRow({ id: 1, name: "Alice", value: 100 });
419
- const currentRow = createRow({ id: 1, name: "Alice", value: 100 });
420
-
421
- const result = determineRowStatus(baseRow, currentRow, columnMap, ["id"]);
422
-
423
- expect(result).toBeUndefined();
424
- });
425
-
426
- test("ignores primary key columns when comparing", () => {
427
- const baseRow = createRow({ id: 1, name: "Alice" });
428
- const currentRow = createRow({ id: 1, name: "Alice" });
429
-
430
- const result = determineRowStatus(baseRow, currentRow, columnMap, [
431
- "id",
432
- "name",
433
- ]);
434
-
435
- expect(result).toBeUndefined();
436
- });
437
-
438
- test("ignores 'index' column", () => {
439
- const columnMapWithIndex: Record<string, ColumnMapEntry> = {
440
- ...columnMap,
441
- index: { key: "index", colType: "integer" },
442
- };
443
- const baseRow = createRow({ id: 1, name: "Alice", index: 0 });
444
- const currentRow = createRow({ id: 1, name: "Alice", index: 5 });
445
-
446
- const result = determineRowStatus(baseRow, currentRow, columnMapWithIndex, [
447
- "id",
448
- ]);
449
-
450
- expect(result).toBeUndefined();
451
- });
452
- });
453
-
454
- // ============================================================================
455
- // getCellClass Tests
456
- // ============================================================================
457
-
458
- describe("getCellClass", () => {
459
- test("returns 'diff-cell-removed' for removed row", () => {
460
- const row = createRow({}, "removed");
461
-
462
- const result = getCellClass(row, undefined, "value", false);
463
-
464
- expect(result).toBe("diff-cell-removed");
465
- });
466
-
467
- test("returns 'diff-cell-added' for added row", () => {
468
- const row = createRow({}, "added");
469
-
470
- const result = getCellClass(row, undefined, "value", false);
471
-
472
- expect(result).toBe("diff-cell-added");
473
- });
474
-
475
- test("returns undefined for added column status", () => {
476
- const row = createRow({});
477
-
478
- const result = getCellClass(row, "added", "value", false);
479
-
480
- expect(result).toBeUndefined();
481
- });
482
-
483
- test("returns undefined for removed column status", () => {
484
- const row = createRow({});
485
-
486
- const result = getCellClass(row, "removed", "value", false);
487
-
488
- expect(result).toBeUndefined();
489
- });
490
-
491
- test("returns 'diff-cell-removed' for base column when values differ", () => {
492
- const row = createRow({
493
- base__value: 100,
494
- current__value: 200,
495
- });
496
-
497
- const result = getCellClass(row, undefined, "value", true);
498
-
499
- expect(result).toBe("diff-cell-removed");
500
- });
501
-
502
- test("returns 'diff-cell-added' for current column when values differ", () => {
503
- const row = createRow({
504
- base__value: 100,
505
- current__value: 200,
506
- });
507
-
508
- const result = getCellClass(row, undefined, "value", false);
509
-
510
- expect(result).toBe("diff-cell-added");
511
- });
512
-
513
- test("returns undefined when base and current are equal", () => {
514
- const row = createRow({
515
- base__value: 100,
516
- current__value: 100,
517
- });
518
-
519
- const result = getCellClass(row, undefined, "value", false);
520
-
521
- expect(result).toBeUndefined();
522
- });
523
- });
524
-
525
- // ============================================================================
526
- // getHeaderCellClass Tests
527
- // ============================================================================
528
-
529
- describe("getHeaderCellClass", () => {
530
- test("returns 'diff-header-added' for added status", () => {
531
- const result = getHeaderCellClass("added");
532
-
533
- expect(result).toBe("diff-header-added");
534
- });
535
-
536
- test("returns 'diff-header-removed' for removed status", () => {
537
- const result = getHeaderCellClass("removed");
538
-
539
- expect(result).toBe("diff-header-removed");
540
- });
541
-
542
- test("returns undefined for empty status", () => {
543
- const result = getHeaderCellClass("");
544
-
545
- expect(result).toBeUndefined();
546
- });
547
-
548
- test("returns undefined for other statuses", () => {
549
- const result = getHeaderCellClass("modified");
550
-
551
- expect(result).toBeUndefined();
552
- });
553
- });
554
-
555
- // ============================================================================
556
- // columnRenderedValue Tests
557
- // ============================================================================
558
-
559
- describe("columnRenderedValue", () => {
560
- test("returns value as-is for 'raw' mode", () => {
561
- const result = columnRenderedValue(123.456, "raw");
562
-
563
- expect(result).toBe("123.456");
564
- });
565
-
566
- test("formats as percentage for 'percent' mode", () => {
567
- const result = columnRenderedValue(0.5, "percent");
568
-
569
- expect(result).toBe("50%");
570
- });
571
-
572
- test("formats with decimal places for numeric mode", () => {
573
- const result = columnRenderedValue(123.456789, 2);
574
-
575
- expect(result).toBe("123.46");
576
- });
577
- });
578
-
579
- // ============================================================================
580
- // toRenderedValue Tests
581
- // ============================================================================
582
-
583
- describe("toRenderedValue", () => {
584
- test("returns dash for null values", () => {
585
- const row = createRow({ value: null });
586
-
587
- const [renderedValue, grayOut] = toRenderedValue(row, "value");
588
-
589
- expect(renderedValue).toBe("-");
590
- expect(grayOut).toBe(true);
591
- });
592
-
593
- test("returns (empty) for empty string values", () => {
594
- const row = createRow({ value: "" });
595
-
596
- const [renderedValue, grayOut] = toRenderedValue(row, "value");
597
-
598
- expect(renderedValue).toBe("(empty)");
599
- expect(grayOut).toBe(true);
600
- });
601
-
602
- test("formats boolean as string", () => {
603
- const row = createRow({ flag: true });
604
-
605
- const [renderedValue, grayOut] = toRenderedValue(row, "flag");
606
-
607
- expect(renderedValue).toBe("true");
608
- expect(grayOut).toBe(false);
609
- });
610
-
611
- test("formats numbers with render mode", () => {
612
- const row = createRow({ value: 0.5 });
613
-
614
- const [renderedValue, grayOut] = toRenderedValue(
615
- row,
616
- "value",
617
- "number",
618
- "percent",
619
- );
620
-
621
- expect(renderedValue).toBe("50%");
622
- expect(grayOut).toBe(false);
623
- });
624
-
625
- test("handles string values", () => {
626
- const row = createRow({ name: "Alice" });
627
-
628
- const [renderedValue, grayOut] = toRenderedValue(row, "name", "text");
629
-
630
- expect(renderedValue).toBe("Alice");
631
- expect(grayOut).toBe(false);
632
- });
633
-
634
- test("parses string as number when column type is number", () => {
635
- const row = createRow({ value: "123.45" });
636
-
637
- const [renderedValue, grayOut] = toRenderedValue(row, "value", "number", 2);
638
-
639
- expect(renderedValue).toBe("123.45");
640
- expect(grayOut).toBe(false);
641
- });
642
-
643
- test("returns dash for undefined values", () => {
644
- const row = createRow({});
645
-
646
- const [renderedValue, grayOut] = toRenderedValue(row, "missing");
647
-
648
- expect(renderedValue).toBe("-");
649
- expect(grayOut).toBe(true);
650
- });
651
- });
652
-
653
- // ============================================================================
654
- // formatSmartDecimal Tests
655
- // ============================================================================
656
-
657
- describe("formatSmartDecimal", () => {
658
- // Import at top of file: import { formatSmartDecimal } from "./gridUtils";
659
-
660
- describe("basic formatting", () => {
661
- test("formats integer without trailing zeros", () => {
662
- expect(formatSmartDecimal(123)).toBe("123");
663
- });
664
-
665
- test("formats integer with decimal places specified", () => {
666
- expect(formatSmartDecimal(123, 2)).toBe("123");
667
- });
668
-
669
- test("formats number with fewer decimals than max", () => {
670
- expect(formatSmartDecimal(123.4, 2)).toBe("123.4");
671
- });
672
-
673
- test("rounds number with more decimals than max", () => {
674
- expect(formatSmartDecimal(123.456, 2)).toBe("123.46");
675
- });
676
-
677
- test("rounds to nearest even on .5 (banker's rounding)", () => {
678
- // Intl.NumberFormat uses "halfEven" rounding by default
679
- expect(formatSmartDecimal(123.445, 2)).toBe("123.44");
680
- expect(formatSmartDecimal(123.455, 2)).toBe("123.46");
681
- });
682
-
683
- test("formats with custom maxDecimals", () => {
684
- expect(formatSmartDecimal(123.456789, 4)).toBe("123.4568");
685
- });
686
-
687
- test("defaults to 2 decimal places", () => {
688
- expect(formatSmartDecimal(123.456)).toBe("123.46");
689
- });
690
- });
691
-
692
- describe("zero handling", () => {
693
- test("formats zero", () => {
694
- expect(formatSmartDecimal(0)).toBe("0");
695
- });
696
-
697
- test("normalizes negative zero to zero", () => {
698
- expect(formatSmartDecimal(-0)).toBe("0");
699
- });
700
-
701
- test("formats zero with decimals", () => {
702
- expect(formatSmartDecimal(0.0, 2)).toBe("0");
703
- });
704
- });
705
-
706
- describe("negative numbers", () => {
707
- test("formats negative integer", () => {
708
- expect(formatSmartDecimal(-123)).toBe("-123");
709
- });
710
-
711
- test("formats negative decimal", () => {
712
- expect(formatSmartDecimal(-123.456, 2)).toBe("-123.46");
713
- });
714
-
715
- test("formats small negative number", () => {
716
- expect(formatSmartDecimal(-0.001, 2)).toBe("0");
717
- });
718
-
719
- test("formats small negative number with more precision", () => {
720
- expect(formatSmartDecimal(-0.001, 3)).toBe("-0.001");
721
- });
722
- });
723
-
724
- describe("large numbers", () => {
725
- test("formats large numbers with thousand separators", () => {
726
- expect(formatSmartDecimal(1234567)).toBe("1,234,567");
727
- });
728
-
729
- test("formats large decimal numbers", () => {
730
- expect(formatSmartDecimal(1234567.89, 2)).toBe("1,234,567.89");
731
- });
732
-
733
- test("handles Number.MAX_SAFE_INTEGER", () => {
734
- const result = formatSmartDecimal(Number.MAX_SAFE_INTEGER);
735
- expect(result).toBe("9,007,199,254,740,991");
736
- });
737
- });
738
-
739
- describe("small numbers", () => {
740
- test("formats small decimal", () => {
741
- expect(formatSmartDecimal(0.1, 2)).toBe("0.1");
742
- });
743
-
744
- test("formats very small decimal with appropriate precision", () => {
745
- expect(formatSmartDecimal(0.001, 3)).toBe("0.001");
746
- });
747
-
748
- test("rounds very small decimal to zero when maxDecimals is small", () => {
749
- expect(formatSmartDecimal(0.001, 2)).toBe("0");
750
- });
751
- });
752
-
753
- describe("edge cases", () => {
754
- test("formats with maxDecimals = 0", () => {
755
- expect(formatSmartDecimal(123.456, 0)).toBe("123");
756
- });
757
-
758
- test("formats with maxDecimals = 0 rounds correctly", () => {
759
- expect(formatSmartDecimal(123.567, 0)).toBe("124");
760
- });
761
-
762
- test("handles trailing zeros in input", () => {
763
- expect(formatSmartDecimal(123.4, 2)).toBe("123.4");
764
- });
765
-
766
- test("handles exact boundary rounding", () => {
767
- expect(formatSmartDecimal(0.995, 2)).toBe("1");
768
- });
769
- });
770
-
771
- describe("special numeric values", () => {
772
- test("formats NaN", () => {
773
- // NaN passed through formatNumber returns fallback String(value)
774
- expect(formatSmartDecimal(NaN)).toBe("NaN");
775
- });
776
-
777
- test("formats Infinity", () => {
778
- expect(formatSmartDecimal(Infinity)).toBe("∞");
779
- });
780
-
781
- test("formats negative Infinity", () => {
782
- expect(formatSmartDecimal(-Infinity)).toBe("-∞");
783
- });
784
- });
785
- });