@lightdash/common 0.2104.7 → 0.2104.9

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 (752) hide show
  1. package/dist/cjs/.tsbuildinfo +1 -0
  2. package/dist/cjs/authorization/index.d.ts +1 -4
  3. package/dist/cjs/authorization/index.d.ts.map +1 -1
  4. package/dist/cjs/authorization/index.js +0 -4
  5. package/dist/cjs/authorization/index.js.map +1 -1
  6. package/dist/cjs/ee/AiAgent/chartConfig/web/getWebAiChartConfig.d.ts +8 -8
  7. package/dist/cjs/ee/AiAgent/index.d.ts +2 -2
  8. package/dist/cjs/ee/AiAgent/schemas/parser.d.ts +24 -24
  9. package/dist/cjs/ee/AiAgent/schemas/tools/toolDashboardV2Args.d.ts +96 -96
  10. package/dist/cjs/ee/AiAgent/schemas/tools/toolRunQueryArgs.d.ts +48 -48
  11. package/dist/cjs/ee/AiAgent/utils.d.ts +8 -8
  12. package/dist/cjs/index.d.ts +23 -449
  13. package/dist/cjs/index.d.ts.map +1 -1
  14. package/dist/cjs/index.js +21 -55
  15. package/dist/cjs/index.js.map +1 -1
  16. package/dist/cjs/pivot/index.d.ts +1 -0
  17. package/dist/cjs/pivot/index.d.ts.map +1 -1
  18. package/dist/cjs/pivot/index.js +1 -0
  19. package/dist/cjs/pivot/index.js.map +1 -1
  20. package/dist/cjs/pivot/pivotConfig.d.ts +7 -0
  21. package/dist/cjs/pivot/pivotConfig.d.ts.map +1 -0
  22. package/dist/cjs/pivot/pivotConfig.js +32 -0
  23. package/dist/cjs/pivot/pivotConfig.js.map +1 -0
  24. package/dist/cjs/types/api.d.ts +447 -0
  25. package/dist/cjs/types/api.d.ts.map +1 -1
  26. package/dist/cjs/types/api.js +50 -1
  27. package/dist/cjs/types/api.js.map +1 -1
  28. package/dist/cjs/types/auth.d.ts +2 -1
  29. package/dist/cjs/types/auth.d.ts.map +1 -1
  30. package/dist/cjs/types/auth.js +4 -4
  31. package/dist/cjs/types/auth.js.map +1 -1
  32. package/dist/cjs/types/changeset.d.ts +10 -10
  33. package/dist/cjs/types/pivot.d.ts +0 -2
  34. package/dist/cjs/types/pivot.d.ts.map +1 -1
  35. package/dist/cjs/types/pivot.js +0 -29
  36. package/dist/cjs/types/pivot.js.map +1 -1
  37. package/dist/cjs/types/resourceViewItem.d.ts +1 -1
  38. package/dist/esm/.tsbuildinfo +1 -0
  39. package/dist/esm/authorization/index.d.ts +1 -4
  40. package/dist/esm/authorization/index.d.ts.map +1 -1
  41. package/dist/esm/authorization/index.js +0 -4
  42. package/dist/esm/authorization/index.js.map +1 -1
  43. package/dist/esm/ee/AiAgent/chartConfig/web/getWebAiChartConfig.d.ts +8 -8
  44. package/dist/esm/ee/AiAgent/index.d.ts +2 -2
  45. package/dist/esm/ee/AiAgent/schemas/parser.d.ts +24 -24
  46. package/dist/esm/ee/AiAgent/schemas/tools/toolDashboardV2Args.d.ts +96 -96
  47. package/dist/esm/ee/AiAgent/schemas/tools/toolRunQueryArgs.d.ts +48 -48
  48. package/dist/esm/ee/AiAgent/utils.d.ts +8 -8
  49. package/dist/esm/index.d.ts +23 -449
  50. package/dist/esm/index.d.ts.map +1 -1
  51. package/dist/esm/index.js +16 -50
  52. package/dist/esm/index.js.map +1 -1
  53. package/dist/esm/pivot/index.d.ts +1 -0
  54. package/dist/esm/pivot/index.d.ts.map +1 -1
  55. package/dist/esm/pivot/index.js +1 -0
  56. package/dist/esm/pivot/index.js.map +1 -1
  57. package/dist/esm/pivot/pivotConfig.d.ts +7 -0
  58. package/dist/esm/pivot/pivotConfig.d.ts.map +1 -0
  59. package/dist/esm/pivot/pivotConfig.js +28 -0
  60. package/dist/esm/pivot/pivotConfig.js.map +1 -0
  61. package/dist/esm/types/api.d.ts +447 -0
  62. package/dist/esm/types/api.d.ts.map +1 -1
  63. package/dist/esm/types/api.js +46 -0
  64. package/dist/esm/types/api.js.map +1 -1
  65. package/dist/esm/types/auth.d.ts +2 -1
  66. package/dist/esm/types/auth.d.ts.map +1 -1
  67. package/dist/esm/types/auth.js +2 -2
  68. package/dist/esm/types/auth.js.map +1 -1
  69. package/dist/esm/types/changeset.d.ts +10 -10
  70. package/dist/esm/types/pivot.d.ts +0 -2
  71. package/dist/esm/types/pivot.d.ts.map +1 -1
  72. package/dist/esm/types/pivot.js +1 -27
  73. package/dist/esm/types/pivot.js.map +1 -1
  74. package/dist/esm/types/resourceViewItem.d.ts +1 -1
  75. package/dist/types/.tsbuildinfo +1 -0
  76. package/dist/types/authorization/buildAccountHelpers.js +11 -0
  77. package/dist/types/authorization/buildAccountHelpers.js.map +1 -0
  78. package/dist/types/authorization/index.d.ts +1 -4
  79. package/dist/types/authorization/index.d.ts.map +1 -1
  80. package/dist/types/authorization/index.js +62 -0
  81. package/dist/types/authorization/index.js.map +1 -0
  82. package/dist/types/authorization/index.mock.js +42 -0
  83. package/dist/types/authorization/index.mock.js.map +1 -0
  84. package/dist/types/authorization/index.test.js +220 -0
  85. package/dist/types/authorization/index.test.js.map +1 -0
  86. package/dist/types/authorization/jwtAbility.js +77 -0
  87. package/dist/types/authorization/jwtAbility.js.map +1 -0
  88. package/dist/types/authorization/jwtAbility.test.js +416 -0
  89. package/dist/types/authorization/jwtAbility.test.js.map +1 -0
  90. package/dist/types/authorization/organizationMemberAbility.js +318 -0
  91. package/dist/types/authorization/organizationMemberAbility.js.map +1 -0
  92. package/dist/types/authorization/organizationMemberAbility.mock.js +34 -0
  93. package/dist/types/authorization/organizationMemberAbility.mock.js.map +1 -0
  94. package/dist/types/authorization/organizationMemberAbility.test.js +1265 -0
  95. package/dist/types/authorization/organizationMemberAbility.test.js.map +1 -0
  96. package/dist/types/authorization/parseAccount.js +28 -0
  97. package/dist/types/authorization/parseAccount.js.map +1 -0
  98. package/dist/types/authorization/parseScopes.js +31 -0
  99. package/dist/types/authorization/parseScopes.js.map +1 -0
  100. package/dist/types/authorization/parseScopes.test.js +102 -0
  101. package/dist/types/authorization/parseScopes.test.js.map +1 -0
  102. package/dist/types/authorization/projectMemberAbility.js +239 -0
  103. package/dist/types/authorization/projectMemberAbility.js.map +1 -0
  104. package/dist/types/authorization/projectMemberAbility.mock.js +27 -0
  105. package/dist/types/authorization/projectMemberAbility.mock.js.map +1 -0
  106. package/dist/types/authorization/projectMemberAbility.test.js +1031 -0
  107. package/dist/types/authorization/projectMemberAbility.test.js.map +1 -0
  108. package/dist/types/authorization/roleToScopeMapping.js +150 -0
  109. package/dist/types/authorization/roleToScopeMapping.js.map +1 -0
  110. package/dist/types/authorization/roleToScopeMapping.test.js +561 -0
  111. package/dist/types/authorization/roleToScopeMapping.test.js.map +1 -0
  112. package/dist/types/authorization/roleToScopeMapping.testUtils.js +319 -0
  113. package/dist/types/authorization/roleToScopeMapping.testUtils.js.map +1 -0
  114. package/dist/types/authorization/roleToScopeParity.test.js +194 -0
  115. package/dist/types/authorization/roleToScopeParity.test.js.map +1 -0
  116. package/dist/types/authorization/scopeAbilityBuilder.js +57 -0
  117. package/dist/types/authorization/scopeAbilityBuilder.js.map +1 -0
  118. package/dist/types/authorization/scopeAbilityBuilder.test.js +1348 -0
  119. package/dist/types/authorization/scopeAbilityBuilder.test.js.map +1 -0
  120. package/dist/types/authorization/scopes.js +613 -0
  121. package/dist/types/authorization/scopes.js.map +1 -0
  122. package/dist/types/authorization/serviceAccountAbility.js +303 -0
  123. package/dist/types/authorization/serviceAccountAbility.js.map +1 -0
  124. package/dist/types/authorization/types.js +2 -0
  125. package/dist/types/authorization/types.js.map +1 -0
  126. package/dist/types/compiler/exploreCompiler.js +462 -0
  127. package/dist/types/compiler/exploreCompiler.js.map +1 -0
  128. package/dist/types/compiler/exploreCompiler.mock.js +2016 -0
  129. package/dist/types/compiler/exploreCompiler.mock.js.map +1 -0
  130. package/dist/types/compiler/exploreCompiler.test.js +679 -0
  131. package/dist/types/compiler/exploreCompiler.test.js.map +1 -0
  132. package/dist/types/compiler/fieldSetExpander.js +119 -0
  133. package/dist/types/compiler/fieldSetExpander.js.map +1 -0
  134. package/dist/types/compiler/fieldSetExpander.test.js +184 -0
  135. package/dist/types/compiler/fieldSetExpander.test.js.map +1 -0
  136. package/dist/types/compiler/filtersCompiler.js +337 -0
  137. package/dist/types/compiler/filtersCompiler.js.map +1 -0
  138. package/dist/types/compiler/filtersCompiler.mock.js +496 -0
  139. package/dist/types/compiler/filtersCompiler.mock.js.map +1 -0
  140. package/dist/types/compiler/filtersCompiler.test.js +570 -0
  141. package/dist/types/compiler/filtersCompiler.test.js.map +1 -0
  142. package/dist/types/compiler/lightdashProjectConfig.js +37 -0
  143. package/dist/types/compiler/lightdashProjectConfig.js.map +1 -0
  144. package/dist/types/compiler/parameters.js +75 -0
  145. package/dist/types/compiler/parameters.js.map +1 -0
  146. package/dist/types/compiler/parameters.test.js +216 -0
  147. package/dist/types/compiler/parameters.test.js.map +1 -0
  148. package/dist/types/compiler/translator.js +707 -0
  149. package/dist/types/compiler/translator.js.map +1 -0
  150. package/dist/types/compiler/translator.mock.js +1901 -0
  151. package/dist/types/compiler/translator.mock.js.map +1 -0
  152. package/dist/types/compiler/translator.test.js +323 -0
  153. package/dist/types/compiler/translator.test.js.map +1 -0
  154. package/dist/types/constants/pivot.js +7 -0
  155. package/dist/types/constants/pivot.js.map +1 -0
  156. package/dist/types/constants/sessionStorageKeys.js +6 -0
  157. package/dist/types/constants/sessionStorageKeys.js.map +1 -0
  158. package/dist/types/constants/sqlRunner.js +3 -0
  159. package/dist/types/constants/sqlRunner.js.map +1 -0
  160. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.js +285 -0
  161. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.js.map +1 -0
  162. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.mock.js +224 -0
  163. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.mock.js.map +1 -0
  164. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.test.js +129 -0
  165. package/dist/types/dbt/DbtSchemaEditor/DbtSchemaEditor.test.js.map +1 -0
  166. package/dist/types/dbt/schemas/lightdashMetadata.json +385 -0
  167. package/dist/types/dbt/schemas/lightdashV10.json +72 -0
  168. package/dist/types/dbt/schemas/lightdashV11.json +72 -0
  169. package/dist/types/dbt/schemas/lightdashV12.json +63 -0
  170. package/dist/types/dbt/schemas/lightdashV7.json +72 -0
  171. package/dist/types/dbt/schemas/lightdashV8.json +76 -0
  172. package/dist/types/dbt/schemas/lightdashV9.json +72 -0
  173. package/dist/types/dbt/schemas/manifestV10.json +5545 -0
  174. package/dist/types/dbt/schemas/manifestV11.json +6041 -0
  175. package/dist/types/dbt/schemas/manifestV12.json +22567 -0
  176. package/dist/types/dbt/schemas/manifestV7.json +6481 -0
  177. package/dist/types/dbt/schemas/manifestV8.json +4358 -0
  178. package/dist/types/dbt/schemas/manifestV9.json +4879 -0
  179. package/dist/types/dbt/validation.js +67 -0
  180. package/dist/types/dbt/validation.js.map +1 -0
  181. package/dist/types/ee/AiAgent/adminTypes.js +2 -0
  182. package/dist/types/ee/AiAgent/adminTypes.js.map +1 -0
  183. package/dist/types/ee/AiAgent/chartConfig/shared/formatFieldLabel.js +10 -0
  184. package/dist/types/ee/AiAgent/chartConfig/shared/formatFieldLabel.js.map +1 -0
  185. package/dist/types/ee/AiAgent/chartConfig/slack/generateBarVizConfigTool/getVerticalBarChartEchartsConfig.js +60 -0
  186. package/dist/types/ee/AiAgent/chartConfig/slack/generateBarVizConfigTool/getVerticalBarChartEchartsConfig.js.map +1 -0
  187. package/dist/types/ee/AiAgent/chartConfig/slack/generateTimeSeriesVizConfigTool/getTimeSeriesChartEchartsConfig.js +60 -0
  188. package/dist/types/ee/AiAgent/chartConfig/slack/generateTimeSeriesVizConfigTool/getTimeSeriesChartEchartsConfig.js.map +1 -0
  189. package/dist/types/ee/AiAgent/chartConfig/slack/getSlackAiEchartsConfig.js +33 -0
  190. package/dist/types/ee/AiAgent/chartConfig/slack/getSlackAiEchartsConfig.js.map +1 -0
  191. package/dist/types/ee/AiAgent/chartConfig/slack/index.js +2 -0
  192. package/dist/types/ee/AiAgent/chartConfig/slack/index.js.map +1 -0
  193. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/getRunQueryEchartsConfig.js +43 -0
  194. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/getRunQueryEchartsConfig.js.map +1 -0
  195. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/bar.js +98 -0
  196. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/bar.js.map +1 -0
  197. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/funnel.js +38 -0
  198. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/funnel.js.map +1 -0
  199. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/horizontalBar.js +65 -0
  200. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/horizontalBar.js.map +1 -0
  201. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/line.js +105 -0
  202. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/line.js.map +1 -0
  203. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/pie.js +34 -0
  204. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/pie.js.map +1 -0
  205. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/scatter.js +66 -0
  206. package/dist/types/ee/AiAgent/chartConfig/slack/runQueryTool/viz/scatter.js.map +1 -0
  207. package/dist/types/ee/AiAgent/chartConfig/slack/shared/getCommonEChartsConfig.js +104 -0
  208. package/dist/types/ee/AiAgent/chartConfig/slack/shared/getCommonEChartsConfig.js.map +1 -0
  209. package/dist/types/ee/AiAgent/chartConfig/slack/types.js +2 -0
  210. package/dist/types/ee/AiAgent/chartConfig/slack/types.js.map +1 -0
  211. package/dist/types/ee/AiAgent/chartConfig/web/generateBarVizConfigTool/getVerticalBarChartConfig.js +65 -0
  212. package/dist/types/ee/AiAgent/chartConfig/web/generateBarVizConfigTool/getVerticalBarChartConfig.js.map +1 -0
  213. package/dist/types/ee/AiAgent/chartConfig/web/generateTableVizConfigTool/getTableChartConfig.js +5 -0
  214. package/dist/types/ee/AiAgent/chartConfig/web/generateTableVizConfigTool/getTableChartConfig.js.map +1 -0
  215. package/dist/types/ee/AiAgent/chartConfig/web/generateTimeSeriesVizConfigTool/getTimeSeriesChartConfig.js +63 -0
  216. package/dist/types/ee/AiAgent/chartConfig/web/generateTimeSeriesVizConfigTool/getTimeSeriesChartConfig.js.map +1 -0
  217. package/dist/types/ee/AiAgent/chartConfig/web/getWebAiChartConfig.d.ts +8 -8
  218. package/dist/types/ee/AiAgent/chartConfig/web/getWebAiChartConfig.js +51 -0
  219. package/dist/types/ee/AiAgent/chartConfig/web/getWebAiChartConfig.js.map +1 -0
  220. package/dist/types/ee/AiAgent/chartConfig/web/index.js +6 -0
  221. package/dist/types/ee/AiAgent/chartConfig/web/index.js.map +1 -0
  222. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/getRunQueryChartConfig.js +73 -0
  223. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/getRunQueryChartConfig.js.map +1 -0
  224. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/bar.js +91 -0
  225. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/bar.js.map +1 -0
  226. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/funnel.js +17 -0
  227. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/funnel.js.map +1 -0
  228. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/horizontalBar.js +52 -0
  229. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/horizontalBar.js.map +1 -0
  230. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/line.js +96 -0
  231. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/line.js.map +1 -0
  232. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/pie.js +15 -0
  233. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/pie.js.map +1 -0
  234. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/scatter.js +66 -0
  235. package/dist/types/ee/AiAgent/chartConfig/web/runQueryTool/viz/scatter.js.map +1 -0
  236. package/dist/types/ee/AiAgent/chartConfig/web/shared/canRenderAsChart.js +24 -0
  237. package/dist/types/ee/AiAgent/chartConfig/web/shared/canRenderAsChart.js.map +1 -0
  238. package/dist/types/ee/AiAgent/chartConfig/web/shared/formatPivotValueLabel.js +15 -0
  239. package/dist/types/ee/AiAgent/chartConfig/web/shared/formatPivotValueLabel.js.map +1 -0
  240. package/dist/types/ee/AiAgent/chartConfig/web/shared/getAvailableChartTypes.js +11 -0
  241. package/dist/types/ee/AiAgent/chartConfig/web/shared/getAvailableChartTypes.js.map +1 -0
  242. package/dist/types/ee/AiAgent/chartConfig/web/shared/getGroupByDimensions.js +15 -0
  243. package/dist/types/ee/AiAgent/chartConfig/web/shared/getGroupByDimensions.js.map +1 -0
  244. package/dist/types/ee/AiAgent/chartConfig/web/types.js +2 -0
  245. package/dist/types/ee/AiAgent/chartConfig/web/types.js.map +1 -0
  246. package/dist/types/ee/AiAgent/constants.js +2 -0
  247. package/dist/types/ee/AiAgent/constants.js.map +1 -0
  248. package/dist/types/ee/AiAgent/filterExploreByTags.js +94 -0
  249. package/dist/types/ee/AiAgent/filterExploreByTags.js.map +1 -0
  250. package/dist/types/ee/AiAgent/filterExploreByTags.test.js +634 -0
  251. package/dist/types/ee/AiAgent/filterExploreByTags.test.js.map +1 -0
  252. package/dist/types/ee/AiAgent/followUpTools.js +33 -0
  253. package/dist/types/ee/AiAgent/followUpTools.js.map +1 -0
  254. package/dist/types/ee/AiAgent/index.d.ts +2 -2
  255. package/dist/types/ee/AiAgent/index.js +43 -0
  256. package/dist/types/ee/AiAgent/index.js.map +1 -0
  257. package/dist/types/ee/AiAgent/requestTypes.js +2 -0
  258. package/dist/types/ee/AiAgent/requestTypes.js.map +1 -0
  259. package/dist/types/ee/AiAgent/schemas/customMetrics.js +50 -0
  260. package/dist/types/ee/AiAgent/schemas/customMetrics.js.map +1 -0
  261. package/dist/types/ee/AiAgent/schemas/fieldId.js +11 -0
  262. package/dist/types/ee/AiAgent/schemas/fieldId.js.map +1 -0
  263. package/dist/types/ee/AiAgent/schemas/filters/booleanFilters.js +29 -0
  264. package/dist/types/ee/AiAgent/schemas/filters/booleanFilters.js.map +1 -0
  265. package/dist/types/ee/AiAgent/schemas/filters/dateFilters.js +84 -0
  266. package/dist/types/ee/AiAgent/schemas/filters/dateFilters.js.map +1 -0
  267. package/dist/types/ee/AiAgent/schemas/filters/index.js +98 -0
  268. package/dist/types/ee/AiAgent/schemas/filters/index.js.map +1 -0
  269. package/dist/types/ee/AiAgent/schemas/filters/numberFilters.js +53 -0
  270. package/dist/types/ee/AiAgent/schemas/filters/numberFilters.js.map +1 -0
  271. package/dist/types/ee/AiAgent/schemas/filters/stringFilters.js +33 -0
  272. package/dist/types/ee/AiAgent/schemas/filters/stringFilters.js.map +1 -0
  273. package/dist/types/ee/AiAgent/schemas/index.js +9 -0
  274. package/dist/types/ee/AiAgent/schemas/index.js.map +1 -0
  275. package/dist/types/ee/AiAgent/schemas/outputMetadata.js +5 -0
  276. package/dist/types/ee/AiAgent/schemas/outputMetadata.js.map +1 -0
  277. package/dist/types/ee/AiAgent/schemas/parser.d.ts +24 -24
  278. package/dist/types/ee/AiAgent/schemas/parser.js +43 -0
  279. package/dist/types/ee/AiAgent/schemas/parser.js.map +1 -0
  280. package/dist/types/ee/AiAgent/schemas/sortField.js +14 -0
  281. package/dist/types/ee/AiAgent/schemas/sortField.js.map +1 -0
  282. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcBaseSchemas.js +28 -0
  283. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcBaseSchemas.js.map +1 -0
  284. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentChangeFromPrevious.js +14 -0
  285. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentChangeFromPrevious.js.map +1 -0
  286. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentOfColumnTotal.js +14 -0
  287. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentOfColumnTotal.js.map +1 -0
  288. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentOfPreviousValue.js +14 -0
  289. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcPercentOfPreviousValue.js.map +1 -0
  290. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcRankInColumn.js +10 -0
  291. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcRankInColumn.js.map +1 -0
  292. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcRunningTotal.js +10 -0
  293. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcRunningTotal.js.map +1 -0
  294. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcWindowFunction.js +105 -0
  295. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcWindowFunction.js.map +1 -0
  296. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcs.js +168 -0
  297. package/dist/types/ee/AiAgent/schemas/tableCalcs/tableCalcs.js.map +1 -0
  298. package/dist/types/ee/AiAgent/schemas/toolSchemaBuilder.js +37 -0
  299. package/dist/types/ee/AiAgent/schemas/toolSchemaBuilder.js.map +1 -0
  300. package/dist/types/ee/AiAgent/schemas/tools/index.js +16 -0
  301. package/dist/types/ee/AiAgent/schemas/tools/index.js.map +1 -0
  302. package/dist/types/ee/AiAgent/schemas/tools/toolDashboardArgs.js +103 -0
  303. package/dist/types/ee/AiAgent/schemas/tools/toolDashboardArgs.js.map +1 -0
  304. package/dist/types/ee/AiAgent/schemas/tools/toolDashboardV2Args.d.ts +96 -96
  305. package/dist/types/ee/AiAgent/schemas/tools/toolDashboardV2Args.js +50 -0
  306. package/dist/types/ee/AiAgent/schemas/tools/toolDashboardV2Args.js.map +1 -0
  307. package/dist/types/ee/AiAgent/schemas/tools/toolFindChartsArgs.js +34 -0
  308. package/dist/types/ee/AiAgent/schemas/tools/toolFindChartsArgs.js.map +1 -0
  309. package/dist/types/ee/AiAgent/schemas/tools/toolFindContentArgs.js +33 -0
  310. package/dist/types/ee/AiAgent/schemas/tools/toolFindContentArgs.js.map +1 -0
  311. package/dist/types/ee/AiAgent/schemas/tools/toolFindDashboardsArgs.js +36 -0
  312. package/dist/types/ee/AiAgent/schemas/tools/toolFindDashboardsArgs.js.map +1 -0
  313. package/dist/types/ee/AiAgent/schemas/tools/toolFindExploresArgs.js +45 -0
  314. package/dist/types/ee/AiAgent/schemas/tools/toolFindExploresArgs.js.map +1 -0
  315. package/dist/types/ee/AiAgent/schemas/tools/toolFindFieldsArgs.js +34 -0
  316. package/dist/types/ee/AiAgent/schemas/tools/toolFindFieldsArgs.js.map +1 -0
  317. package/dist/types/ee/AiAgent/schemas/tools/toolImproveContextArgs.js +60 -0
  318. package/dist/types/ee/AiAgent/schemas/tools/toolImproveContextArgs.js.map +1 -0
  319. package/dist/types/ee/AiAgent/schemas/tools/toolProposeChangeArgs.js +157 -0
  320. package/dist/types/ee/AiAgent/schemas/tools/toolProposeChangeArgs.js.map +1 -0
  321. package/dist/types/ee/AiAgent/schemas/tools/toolRunMetricQueryArgs.js +41 -0
  322. package/dist/types/ee/AiAgent/schemas/tools/toolRunMetricQueryArgs.js.map +1 -0
  323. package/dist/types/ee/AiAgent/schemas/tools/toolRunQueryArgs.d.ts +48 -48
  324. package/dist/types/ee/AiAgent/schemas/tools/toolRunQueryArgs.js +151 -0
  325. package/dist/types/ee/AiAgent/schemas/tools/toolRunQueryArgs.js.map +1 -0
  326. package/dist/types/ee/AiAgent/schemas/tools/toolSearchFieldValuesArgs.js +46 -0
  327. package/dist/types/ee/AiAgent/schemas/tools/toolSearchFieldValuesArgs.js.map +1 -0
  328. package/dist/types/ee/AiAgent/schemas/tools/toolTableVizArgs.js +53 -0
  329. package/dist/types/ee/AiAgent/schemas/tools/toolTableVizArgs.js.map +1 -0
  330. package/dist/types/ee/AiAgent/schemas/tools/toolTimeSeriesArgs.js +58 -0
  331. package/dist/types/ee/AiAgent/schemas/tools/toolTimeSeriesArgs.js.map +1 -0
  332. package/dist/types/ee/AiAgent/schemas/tools/toolVerticalBarArgs.js +53 -0
  333. package/dist/types/ee/AiAgent/schemas/tools/toolVerticalBarArgs.js.map +1 -0
  334. package/dist/types/ee/AiAgent/schemas/visualizationMetadata.js +9 -0
  335. package/dist/types/ee/AiAgent/schemas/visualizationMetadata.js.map +1 -0
  336. package/dist/types/ee/AiAgent/schemas/visualizations/index.js +58 -0
  337. package/dist/types/ee/AiAgent/schemas/visualizations/index.js.map +1 -0
  338. package/dist/types/ee/AiAgent/schemas/visualizations/tableViz.js +38 -0
  339. package/dist/types/ee/AiAgent/schemas/visualizations/tableViz.js.map +1 -0
  340. package/dist/types/ee/AiAgent/schemas/visualizations/timeSeriesViz.js +63 -0
  341. package/dist/types/ee/AiAgent/schemas/visualizations/timeSeriesViz.js.map +1 -0
  342. package/dist/types/ee/AiAgent/schemas/visualizations/verticalBarViz.js +68 -0
  343. package/dist/types/ee/AiAgent/schemas/visualizations/verticalBarViz.js.map +1 -0
  344. package/dist/types/ee/AiAgent/types.js +12 -0
  345. package/dist/types/ee/AiAgent/types.js.map +1 -0
  346. package/dist/types/ee/AiAgent/utils.d.ts +8 -8
  347. package/dist/types/ee/AiAgent/utils.js +82 -0
  348. package/dist/types/ee/AiAgent/utils.js.map +1 -0
  349. package/dist/types/ee/AiAgent/validators.js +10 -0
  350. package/dist/types/ee/AiAgent/validators.js.map +1 -0
  351. package/dist/types/ee/commercialFeatureFlags.js +10 -0
  352. package/dist/types/ee/commercialFeatureFlags.js.map +1 -0
  353. package/dist/types/ee/embed/index.js +90 -0
  354. package/dist/types/ee/embed/index.js.map +1 -0
  355. package/dist/types/ee/index.js +19 -0
  356. package/dist/types/ee/index.js.map +1 -0
  357. package/dist/types/ee/scim/errors.js +22 -0
  358. package/dist/types/ee/scim/errors.js.map +1 -0
  359. package/dist/types/ee/scim/types.js +2 -0
  360. package/dist/types/ee/scim/types.js.map +1 -0
  361. package/dist/types/ee/serviceAccounts/types.js +8 -0
  362. package/dist/types/ee/serviceAccounts/types.js.map +1 -0
  363. package/dist/types/index.d.ts +23 -449
  364. package/dist/types/index.d.ts.map +1 -1
  365. package/dist/types/index.js +652 -0
  366. package/dist/types/index.js.map +1 -0
  367. package/dist/types/index.mock.js +44 -0
  368. package/dist/types/index.mock.js.map +1 -0
  369. package/dist/types/index.test.js +123 -0
  370. package/dist/types/index.test.js.map +1 -0
  371. package/dist/types/pivot/derivePivotConfigFromChart.js +206 -0
  372. package/dist/types/pivot/derivePivotConfigFromChart.js.map +1 -0
  373. package/dist/types/pivot/derivePivotConfigFromChart.mock.js +112 -0
  374. package/dist/types/pivot/derivePivotConfigFromChart.mock.js.map +1 -0
  375. package/dist/types/pivot/derivePivotConfigFromChart.test.js +418 -0
  376. package/dist/types/pivot/derivePivotConfigFromChart.test.js.map +1 -0
  377. package/dist/types/pivot/index.d.ts +1 -0
  378. package/dist/types/pivot/index.d.ts.map +1 -1
  379. package/dist/types/pivot/index.js +5 -0
  380. package/dist/types/pivot/index.js.map +1 -0
  381. package/dist/types/pivot/pivotConfig.d.ts +7 -0
  382. package/dist/types/pivot/pivotConfig.d.ts.map +1 -0
  383. package/dist/types/pivot/pivotConfig.js +28 -0
  384. package/dist/types/pivot/pivotConfig.js.map +1 -0
  385. package/dist/types/pivot/pivotQueryResults.js +1034 -0
  386. package/dist/types/pivot/pivotQueryResults.js.map +1 -0
  387. package/dist/types/pivot/pivotQueryResults.mock.js +2412 -0
  388. package/dist/types/pivot/pivotQueryResults.mock.js.map +1 -0
  389. package/dist/types/pivot/pivotQueryResults.test.js +1222 -0
  390. package/dist/types/pivot/pivotQueryResults.test.js.map +1 -0
  391. package/dist/types/pivot/utils.js +14 -0
  392. package/dist/types/pivot/utils.js.map +1 -0
  393. package/dist/types/schemas/json/chart-as-code-1.0.json +436 -0
  394. package/dist/types/schemas/json/dashboard-as-code-1.0.json +349 -0
  395. package/dist/types/schemas/json/lightdash-dbt-2.0.json +1417 -0
  396. package/dist/types/schemas/json/lightdash-project-config-1.0.json +138 -0
  397. package/dist/types/templating/template.js +30 -0
  398. package/dist/types/templating/template.js.map +1 -0
  399. package/dist/types/templating/template.mock.js +45 -0
  400. package/dist/types/templating/template.mock.js.map +1 -0
  401. package/dist/types/templating/template.test.js +21 -0
  402. package/dist/types/templating/template.test.js.map +1 -0
  403. package/dist/types/types/SshKeyPair.js +2 -0
  404. package/dist/types/types/SshKeyPair.js.map +1 -0
  405. package/dist/types/types/account.js +2 -0
  406. package/dist/types/types/account.js.map +1 -0
  407. package/dist/types/types/analytics.js +29 -0
  408. package/dist/types/types/analytics.js.map +1 -0
  409. package/dist/types/types/any.js +2 -0
  410. package/dist/types/types/any.js.map +1 -0
  411. package/dist/types/types/api/comments.js +2 -0
  412. package/dist/types/types/api/comments.js.map +1 -0
  413. package/dist/types/types/api/email.js +2 -0
  414. package/dist/types/types/api/email.js.map +1 -0
  415. package/dist/types/types/api/errors.js +2 -0
  416. package/dist/types/types/api/errors.js.map +1 -0
  417. package/dist/types/types/api/notifications.js +5 -0
  418. package/dist/types/types/api/notifications.js.map +1 -0
  419. package/dist/types/types/api/paginatedQuery.js +3 -0
  420. package/dist/types/types/api/paginatedQuery.js.map +1 -0
  421. package/dist/types/types/api/parameters.js +2 -0
  422. package/dist/types/types/api/parameters.js.map +1 -0
  423. package/dist/types/types/api/share.js +2 -0
  424. package/dist/types/types/api/share.js.map +1 -0
  425. package/dist/types/types/api/sort.js +2 -0
  426. package/dist/types/types/api/sort.js.map +1 -0
  427. package/dist/types/types/api/spotlight.js +2 -0
  428. package/dist/types/types/api/spotlight.js.map +1 -0
  429. package/dist/types/types/api/success.js +2 -0
  430. package/dist/types/types/api/success.js.map +1 -0
  431. package/dist/types/types/api/uuid.js +2 -0
  432. package/dist/types/types/api/uuid.js.map +1 -0
  433. package/dist/types/types/api.d.ts +447 -0
  434. package/dist/types/types/api.d.ts.map +1 -1
  435. package/dist/types/types/api.js +57 -0
  436. package/dist/types/types/api.js.map +1 -0
  437. package/dist/types/types/applyDimensionOverrides.test.js +338 -0
  438. package/dist/types/types/applyDimensionOverrides.test.js.map +1 -0
  439. package/dist/types/types/auth.d.ts +2 -1
  440. package/dist/types/types/auth.d.ts.map +1 -1
  441. package/dist/types/types/auth.js +42 -0
  442. package/dist/types/types/auth.js.map +1 -0
  443. package/dist/types/types/bigQuerySSO.js +2 -0
  444. package/dist/types/types/bigQuerySSO.js.map +1 -0
  445. package/dist/types/types/catalog.js +50 -0
  446. package/dist/types/types/catalog.js.map +1 -0
  447. package/dist/types/types/changeset.d.ts +10 -10
  448. package/dist/types/types/changeset.js +72 -0
  449. package/dist/types/types/changeset.js.map +1 -0
  450. package/dist/types/types/coder.js +2 -0
  451. package/dist/types/types/coder.js.map +1 -0
  452. package/dist/types/types/comments.js +2 -0
  453. package/dist/types/types/comments.js.map +1 -0
  454. package/dist/types/types/conditionalFormatting.js +25 -0
  455. package/dist/types/types/conditionalFormatting.js.map +1 -0
  456. package/dist/types/types/content.js +19 -0
  457. package/dist/types/types/content.js.map +1 -0
  458. package/dist/types/types/csv.js +2 -0
  459. package/dist/types/types/csv.js.map +1 -0
  460. package/dist/types/types/dashboard.js +46 -0
  461. package/dist/types/types/dashboard.js.map +1 -0
  462. package/dist/types/types/dbt.js +262 -0
  463. package/dist/types/types/dbt.js.map +1 -0
  464. package/dist/types/types/dbtFromSchema.js +2 -0
  465. package/dist/types/types/dbtFromSchema.js.map +1 -0
  466. package/dist/types/types/deepPartial.js +7 -0
  467. package/dist/types/types/deepPartial.js.map +1 -0
  468. package/dist/types/types/downloadFile.js +9 -0
  469. package/dist/types/types/downloadFile.js.map +1 -0
  470. package/dist/types/types/email.js +2 -0
  471. package/dist/types/types/email.js.map +1 -0
  472. package/dist/types/types/errors.js +496 -0
  473. package/dist/types/types/errors.js.map +1 -0
  474. package/dist/types/types/explore.js +24 -0
  475. package/dist/types/types/explore.js.map +1 -0
  476. package/dist/types/types/featureFlags.js +62 -0
  477. package/dist/types/types/featureFlags.js.map +1 -0
  478. package/dist/types/types/field.js +473 -0
  479. package/dist/types/types/field.js.map +1 -0
  480. package/dist/types/types/field.test.js +90 -0
  481. package/dist/types/types/field.test.js.map +1 -0
  482. package/dist/types/types/fieldMatch.js +2 -0
  483. package/dist/types/types/fieldMatch.js.map +1 -0
  484. package/dist/types/types/filter.js +287 -0
  485. package/dist/types/types/filter.js.map +1 -0
  486. package/dist/types/types/filter.test.js +372 -0
  487. package/dist/types/types/filter.test.js.map +1 -0
  488. package/dist/types/types/filterGrammar.js +358 -0
  489. package/dist/types/types/filterGrammar.js.map +1 -0
  490. package/dist/types/types/filterGrammar.test.js +549 -0
  491. package/dist/types/types/filterGrammar.test.js.map +1 -0
  492. package/dist/types/types/filterGrammarConversion.js +94 -0
  493. package/dist/types/types/filterGrammarConversion.js.map +1 -0
  494. package/dist/types/types/filterGrammarConversion.test.js +260 -0
  495. package/dist/types/types/filterGrammarConversion.test.js.map +1 -0
  496. package/dist/types/types/gdrive.js +2 -0
  497. package/dist/types/types/gdrive.js.map +1 -0
  498. package/dist/types/types/gitIntegration.js +2 -0
  499. package/dist/types/types/gitIntegration.js.map +1 -0
  500. package/dist/types/types/groups.js +4 -0
  501. package/dist/types/types/groups.js.map +1 -0
  502. package/dist/types/types/job.js +67 -0
  503. package/dist/types/types/job.js.map +1 -0
  504. package/dist/types/types/knex-paginate.js +2 -0
  505. package/dist/types/types/knex-paginate.js.map +1 -0
  506. package/dist/types/types/lightdashProjectConfig.js +4 -0
  507. package/dist/types/types/lightdashProjectConfig.js.map +1 -0
  508. package/dist/types/types/metricQuery.js +20 -0
  509. package/dist/types/types/metricQuery.js.map +1 -0
  510. package/dist/types/types/metricsExplorer.js +12 -0
  511. package/dist/types/types/metricsExplorer.js.map +1 -0
  512. package/dist/types/types/notifications.js +2 -0
  513. package/dist/types/types/notifications.js.map +1 -0
  514. package/dist/types/types/oauth.js +2 -0
  515. package/dist/types/types/oauth.js.map +1 -0
  516. package/dist/types/types/openIdIdentity.js +12 -0
  517. package/dist/types/types/openIdIdentity.js.map +1 -0
  518. package/dist/types/types/organization.js +20 -0
  519. package/dist/types/types/organization.js.map +1 -0
  520. package/dist/types/types/organizationMemberProfile.js +30 -0
  521. package/dist/types/types/organizationMemberProfile.js.map +1 -0
  522. package/dist/types/types/organizationWarehouseCredentials.js +2 -0
  523. package/dist/types/types/organizationWarehouseCredentials.js.map +1 -0
  524. package/dist/types/types/paginateResults.js +2 -0
  525. package/dist/types/types/paginateResults.js.map +1 -0
  526. package/dist/types/types/parameters.js +2 -0
  527. package/dist/types/types/parameters.js.map +1 -0
  528. package/dist/types/types/personalAccessToken.js +2 -0
  529. package/dist/types/types/personalAccessToken.js.map +1 -0
  530. package/dist/types/types/pinning.js +5 -0
  531. package/dist/types/types/pinning.js.map +1 -0
  532. package/dist/types/types/pivot.d.ts +0 -2
  533. package/dist/types/types/pivot.d.ts.map +1 -1
  534. package/dist/types/types/pivot.js +2 -0
  535. package/dist/types/types/pivot.js.map +1 -0
  536. package/dist/types/types/projectGroupAccess.js +2 -0
  537. package/dist/types/types/projectGroupAccess.js.map +1 -0
  538. package/dist/types/types/projectMemberProfile.js +2 -0
  539. package/dist/types/types/projectMemberProfile.js.map +1 -0
  540. package/dist/types/types/projectMemberRole.js +30 -0
  541. package/dist/types/types/projectMemberRole.js.map +1 -0
  542. package/dist/types/types/projects.js +149 -0
  543. package/dist/types/types/projects.js.map +1 -0
  544. package/dist/types/types/promotion.js +8 -0
  545. package/dist/types/types/promotion.js.map +1 -0
  546. package/dist/types/types/queryHistory.js +8 -0
  547. package/dist/types/types/queryHistory.js.map +1 -0
  548. package/dist/types/types/rename.js +6 -0
  549. package/dist/types/types/rename.js.map +1 -0
  550. package/dist/types/types/resourceViewItem.d.ts +1 -1
  551. package/dist/types/types/resourceViewItem.js +103 -0
  552. package/dist/types/types/resourceViewItem.js.map +1 -0
  553. package/dist/types/types/results.js +51 -0
  554. package/dist/types/types/results.js.map +1 -0
  555. package/dist/types/types/roles.js +2 -0
  556. package/dist/types/types/roles.js.map +1 -0
  557. package/dist/types/types/savedCharts.js +225 -0
  558. package/dist/types/types/savedCharts.js.map +1 -0
  559. package/dist/types/types/scheduler.js +87 -0
  560. package/dist/types/types/scheduler.js.map +1 -0
  561. package/dist/types/types/schedulerLog.js +2 -0
  562. package/dist/types/types/schedulerLog.js.map +1 -0
  563. package/dist/types/types/schedulerTaskList.js +31 -0
  564. package/dist/types/types/schedulerTaskList.js.map +1 -0
  565. package/dist/types/types/scopes.js +14 -0
  566. package/dist/types/types/scopes.js.map +1 -0
  567. package/dist/types/types/search.js +53 -0
  568. package/dist/types/types/search.js.map +1 -0
  569. package/dist/types/types/share.js +2 -0
  570. package/dist/types/types/share.js.map +1 -0
  571. package/dist/types/types/slack.js +2 -0
  572. package/dist/types/types/slack.js.map +1 -0
  573. package/dist/types/types/slackSettings.js +2 -0
  574. package/dist/types/types/slackSettings.js.map +1 -0
  575. package/dist/types/types/space.js +7 -0
  576. package/dist/types/types/space.js.map +1 -0
  577. package/dist/types/types/spotlightTableConfig.js +17 -0
  578. package/dist/types/types/spotlightTableConfig.js.map +1 -0
  579. package/dist/types/types/sqlRunner.js +41 -0
  580. package/dist/types/types/sqlRunner.js.map +1 -0
  581. package/dist/types/types/table.js +6 -0
  582. package/dist/types/types/table.js.map +1 -0
  583. package/dist/types/types/tags.js +2 -0
  584. package/dist/types/types/tags.js.map +1 -0
  585. package/dist/types/types/timeFrames.js +42 -0
  586. package/dist/types/types/timeFrames.js.map +1 -0
  587. package/dist/types/types/timezone.js +33 -0
  588. package/dist/types/types/timezone.js.map +1 -0
  589. package/dist/types/types/user.js +23 -0
  590. package/dist/types/types/user.js.map +1 -0
  591. package/dist/types/types/userAttributes.js +2 -0
  592. package/dist/types/types/userAttributes.js.map +1 -0
  593. package/dist/types/types/userWarehouseCredentials.js +2 -0
  594. package/dist/types/types/userWarehouseCredentials.js.map +1 -0
  595. package/dist/types/types/validation.js +29 -0
  596. package/dist/types/types/validation.js.map +1 -0
  597. package/dist/types/types/warehouse.js +6 -0
  598. package/dist/types/types/warehouse.js.map +1 -0
  599. package/dist/types/types/yamlSchema.js +2 -0
  600. package/dist/types/types/yamlSchema.js.map +1 -0
  601. package/dist/types/utils/accessors.js +27 -0
  602. package/dist/types/utils/accessors.js.map +1 -0
  603. package/dist/types/utils/accessors.test.js +45 -0
  604. package/dist/types/utils/accessors.test.js.map +1 -0
  605. package/dist/types/utils/additionalMetrics.js +54 -0
  606. package/dist/types/utils/additionalMetrics.js.map +1 -0
  607. package/dist/types/utils/api.js +5 -0
  608. package/dist/types/utils/api.js.map +1 -0
  609. package/dist/types/utils/assertUnreachable.js +10 -0
  610. package/dist/types/utils/assertUnreachable.js.map +1 -0
  611. package/dist/types/utils/booleanConverter.js +27 -0
  612. package/dist/types/utils/booleanConverter.js.map +1 -0
  613. package/dist/types/utils/booleanConverter.test.js +59 -0
  614. package/dist/types/utils/booleanConverter.test.js.map +1 -0
  615. package/dist/types/utils/catalogMetricsTree.js +2 -0
  616. package/dist/types/utils/catalogMetricsTree.js.map +1 -0
  617. package/dist/types/utils/changeset.js +132 -0
  618. package/dist/types/utils/changeset.js.map +1 -0
  619. package/dist/types/utils/changeset.mock.js +146 -0
  620. package/dist/types/utils/changeset.mock.js.map +1 -0
  621. package/dist/types/utils/changeset.test.js +248 -0
  622. package/dist/types/utils/changeset.test.js.map +1 -0
  623. package/dist/types/utils/charts.js +74 -0
  624. package/dist/types/utils/charts.js.map +1 -0
  625. package/dist/types/utils/colors.js +15 -0
  626. package/dist/types/utils/colors.js.map +1 -0
  627. package/dist/types/utils/colors.test.js +85 -0
  628. package/dist/types/utils/colors.test.js.map +1 -0
  629. package/dist/types/utils/conditionalFormatting.js +436 -0
  630. package/dist/types/utils/conditionalFormatting.js.map +1 -0
  631. package/dist/types/utils/conditionalFormatting.test.js +105 -0
  632. package/dist/types/utils/conditionalFormatting.test.js.map +1 -0
  633. package/dist/types/utils/convertCustomDimensionsToYaml.js +115 -0
  634. package/dist/types/utils/convertCustomDimensionsToYaml.js.map +1 -0
  635. package/dist/types/utils/convertCustomMetricsToYaml.js +15 -0
  636. package/dist/types/utils/convertCustomMetricsToYaml.js.map +1 -0
  637. package/dist/types/utils/customDimensions.js +27 -0
  638. package/dist/types/utils/customDimensions.js.map +1 -0
  639. package/dist/types/utils/dashboard.js +35 -0
  640. package/dist/types/utils/dashboard.js.map +1 -0
  641. package/dist/types/utils/dashboard.test.js +36 -0
  642. package/dist/types/utils/dashboard.test.js.map +1 -0
  643. package/dist/types/utils/dbt.js +4 -0
  644. package/dist/types/utils/dbt.js.map +1 -0
  645. package/dist/types/utils/dbt.test.js +39 -0
  646. package/dist/types/utils/dbt.test.js.map +1 -0
  647. package/dist/types/utils/dependencyGraph.js +51 -0
  648. package/dist/types/utils/dependencyGraph.js.map +1 -0
  649. package/dist/types/utils/dependencyGraph.test.js +113 -0
  650. package/dist/types/utils/dependencyGraph.test.js.map +1 -0
  651. package/dist/types/utils/email.js +76 -0
  652. package/dist/types/utils/email.js.map +1 -0
  653. package/dist/types/utils/email.test.js +49 -0
  654. package/dist/types/utils/email.test.js.map +1 -0
  655. package/dist/types/utils/fields.js +183 -0
  656. package/dist/types/utils/fields.js.map +1 -0
  657. package/dist/types/utils/fields.mock.js +150 -0
  658. package/dist/types/utils/fields.mock.js.map +1 -0
  659. package/dist/types/utils/fields.test.js +259 -0
  660. package/dist/types/utils/fields.test.js.map +1 -0
  661. package/dist/types/utils/filters.js +763 -0
  662. package/dist/types/utils/filters.js.map +1 -0
  663. package/dist/types/utils/filters.mock.js +450 -0
  664. package/dist/types/utils/filters.mock.js.map +1 -0
  665. package/dist/types/utils/filters.test.js +360 -0
  666. package/dist/types/utils/filters.test.js.map +1 -0
  667. package/dist/types/utils/formatting.js +552 -0
  668. package/dist/types/utils/formatting.js.map +1 -0
  669. package/dist/types/utils/formatting.mock.js +28 -0
  670. package/dist/types/utils/formatting.mock.js.map +1 -0
  671. package/dist/types/utils/formatting.test.js +1047 -0
  672. package/dist/types/utils/formatting.test.js.map +1 -0
  673. package/dist/types/utils/github.js +11 -0
  674. package/dist/types/utils/github.js.map +1 -0
  675. package/dist/types/utils/i18n/abstract.js +3 -0
  676. package/dist/types/utils/i18n/abstract.js.map +1 -0
  677. package/dist/types/utils/i18n/chartAsCode.js +132 -0
  678. package/dist/types/utils/i18n/chartAsCode.js.map +1 -0
  679. package/dist/types/utils/i18n/chartAsCode.test.js +350 -0
  680. package/dist/types/utils/i18n/chartAsCode.test.js.map +1 -0
  681. package/dist/types/utils/i18n/dashboardAsCode.js +58 -0
  682. package/dist/types/utils/i18n/dashboardAsCode.js.map +1 -0
  683. package/dist/types/utils/i18n/index.js +5 -0
  684. package/dist/types/utils/i18n/index.js.map +1 -0
  685. package/dist/types/utils/i18n/merge.js +20 -0
  686. package/dist/types/utils/i18n/merge.js.map +1 -0
  687. package/dist/types/utils/i18n/types.js +2 -0
  688. package/dist/types/utils/i18n/types.js.map +1 -0
  689. package/dist/types/utils/item.js +154 -0
  690. package/dist/types/utils/item.js.map +1 -0
  691. package/dist/types/utils/loadLightdashProjectConfig.js +49 -0
  692. package/dist/types/utils/loadLightdashProjectConfig.js.map +1 -0
  693. package/dist/types/utils/loadLightdashProjectConfig.mock.js +127 -0
  694. package/dist/types/utils/loadLightdashProjectConfig.mock.js.map +1 -0
  695. package/dist/types/utils/loadLightdashProjectConfig.test.js +137 -0
  696. package/dist/types/utils/loadLightdashProjectConfig.test.js.map +1 -0
  697. package/dist/types/utils/metricsExplorer.js +365 -0
  698. package/dist/types/utils/metricsExplorer.js.map +1 -0
  699. package/dist/types/utils/oauth.js +242 -0
  700. package/dist/types/utils/oauth.js.map +1 -0
  701. package/dist/types/utils/organization.js +23 -0
  702. package/dist/types/utils/organization.js.map +1 -0
  703. package/dist/types/utils/projectMemberRole.js +85 -0
  704. package/dist/types/utils/projectMemberRole.js.map +1 -0
  705. package/dist/types/utils/projectMemberRole.test.js +36 -0
  706. package/dist/types/utils/projectMemberRole.test.js.map +1 -0
  707. package/dist/types/utils/promises.js +5 -0
  708. package/dist/types/utils/promises.js.map +1 -0
  709. package/dist/types/utils/sanitizeHtml.js +111 -0
  710. package/dist/types/utils/sanitizeHtml.js.map +1 -0
  711. package/dist/types/utils/sanitizeHtml.test.js +101 -0
  712. package/dist/types/utils/sanitizeHtml.test.js.map +1 -0
  713. package/dist/types/utils/scheduler.js +85 -0
  714. package/dist/types/utils/scheduler.js.map +1 -0
  715. package/dist/types/utils/scheduler.test.js +41 -0
  716. package/dist/types/utils/scheduler.test.js.map +1 -0
  717. package/dist/types/utils/searchParams.js +8 -0
  718. package/dist/types/utils/searchParams.js.map +1 -0
  719. package/dist/types/utils/sleep.js +6 -0
  720. package/dist/types/utils/sleep.js.map +1 -0
  721. package/dist/types/utils/slug.test.js +129 -0
  722. package/dist/types/utils/slug.test.js.map +1 -0
  723. package/dist/types/utils/slugs.js +55 -0
  724. package/dist/types/utils/slugs.js.map +1 -0
  725. package/dist/types/utils/subtotals.js +4 -0
  726. package/dist/types/utils/subtotals.js.map +1 -0
  727. package/dist/types/utils/time.js +25 -0
  728. package/dist/types/utils/time.js.map +1 -0
  729. package/dist/types/utils/timeFrames.js +529 -0
  730. package/dist/types/utils/timeFrames.js.map +1 -0
  731. package/dist/types/utils/timeFrames.test.js +50 -0
  732. package/dist/types/utils/timeFrames.test.js.map +1 -0
  733. package/dist/types/utils/virtualView.js +98 -0
  734. package/dist/types/utils/virtualView.js.map +1 -0
  735. package/dist/types/utils/warehouse.js +57 -0
  736. package/dist/types/utils/warehouse.js.map +1 -0
  737. package/dist/types/visualizations/CartesianChartDataModel.js +515 -0
  738. package/dist/types/visualizations/CartesianChartDataModel.js.map +1 -0
  739. package/dist/types/visualizations/PieChartDataModel.js +258 -0
  740. package/dist/types/visualizations/PieChartDataModel.js.map +1 -0
  741. package/dist/types/visualizations/TableDataModel.js +96 -0
  742. package/dist/types/visualizations/TableDataModel.js.map +1 -0
  743. package/dist/types/visualizations/chartTransformations.js +107 -0
  744. package/dist/types/visualizations/chartTransformations.js.map +1 -0
  745. package/dist/types/visualizations/helpers/getCartesianAxisFormatterConfig.js +142 -0
  746. package/dist/types/visualizations/helpers/getCartesianAxisFormatterConfig.js.map +1 -0
  747. package/dist/types/visualizations/types/IResultsRunner.js +2 -0
  748. package/dist/types/visualizations/types/IResultsRunner.js.map +1 -0
  749. package/dist/types/visualizations/types/index.js +78 -0
  750. package/dist/types/visualizations/types/index.js.map +1 -0
  751. package/package.json +1 -1
  752. package/dist/tsconfig.types.tsbuildinfo +0 -1
@@ -0,0 +1,1222 @@
1
+ import { convertSqlPivotedRowsToPivotData, pivotQueryResults, } from './pivotQueryResults';
2
+ import { COMPLEX_NON_PIVOTED_ROWS, COMPLEX_SQL_PIVOTED_ROWS, COMPLEX_SQL_PIVOT_DETAILS, EXPECTED_COMPLEX_PIVOT_DATA, EXPECTED_COMPLEX_PIVOT_DATA_WITH_METRICS_AS_ROWS, EXPECTED_PIVOT_DATA, EXPECTED_PIVOT_DATA_METRICS_AS_ROWS, EXPECTED_PIVOT_DATA_WITH_TOTALS, METRIC_QUERY_0DIM_2METRIC, METRIC_QUERY_1DIM_2METRIC, METRIC_QUERY_2DIM_2METRIC, NON_PIVOTED_ROWS, RESULT_ROWS_0DIM_2METRIC, RESULT_ROWS_1DIM_2METRIC, RESULT_ROWS_2DIM_2METRIC, SQL_PIVOTED_ROWS, SQL_PIVOT_DETAILS, getFieldMock, } from './pivotQueryResults.mock';
3
+ describe('Should pivot data', () => {
4
+ it('with 1 dimension, pivoted, metrics as cols (everything on columns)', () => {
5
+ const pivotConfig = {
6
+ pivotDimensions: ['page'],
7
+ metricsAsRows: false,
8
+ };
9
+ const expected = {
10
+ headerValueTypes: [
11
+ { type: 'dimension', fieldId: 'page' },
12
+ { type: 'metric' },
13
+ ],
14
+ headerValues: [
15
+ [
16
+ {
17
+ fieldId: 'page',
18
+ type: 'value',
19
+ value: { formatted: '/home', raw: '/home' },
20
+ colSpan: 2,
21
+ },
22
+ {
23
+ fieldId: 'page',
24
+ type: 'value',
25
+ value: { formatted: '/home', raw: '/home' },
26
+ colSpan: 0,
27
+ },
28
+ {
29
+ fieldId: 'page',
30
+ type: 'value',
31
+ value: { formatted: '/about', raw: '/about' },
32
+ colSpan: 2,
33
+ },
34
+ {
35
+ fieldId: 'page',
36
+ type: 'value',
37
+ value: { formatted: '/about', raw: '/about' },
38
+ colSpan: 0,
39
+ },
40
+ {
41
+ fieldId: 'page',
42
+ type: 'value',
43
+ value: { formatted: '/first-post', raw: '/first-post' },
44
+ colSpan: 2,
45
+ },
46
+ {
47
+ fieldId: 'page',
48
+ type: 'value',
49
+ value: { formatted: '/first-post', raw: '/first-post' },
50
+ colSpan: 0,
51
+ },
52
+ ],
53
+ [
54
+ { fieldId: 'views', type: 'label' },
55
+ { fieldId: 'devices', type: 'label' },
56
+ { fieldId: 'views', type: 'label' },
57
+ { fieldId: 'devices', type: 'label' },
58
+ { fieldId: 'views', type: 'label' },
59
+ { fieldId: 'devices', type: 'label' },
60
+ ],
61
+ ],
62
+ indexValueTypes: [],
63
+ indexValues: [],
64
+ dataColumnCount: 6,
65
+ dataValues: [
66
+ [
67
+ { raw: 6, formatted: '6.0' },
68
+ { raw: 7, formatted: '7.0' },
69
+ { raw: 12, formatted: '12.0' },
70
+ { raw: 0, formatted: '0.0' },
71
+ { raw: 11, formatted: '11.0' },
72
+ { raw: 1, formatted: '1.0' },
73
+ ],
74
+ ],
75
+ rowTotalFields: undefined,
76
+ rowTotals: undefined,
77
+ rowsCount: 1,
78
+ columnTotalFields: undefined,
79
+ columnTotals: undefined,
80
+ pivotConfig,
81
+ titleFields: [[{ direction: 'header', fieldId: 'page' }], [null]],
82
+ cellsCount: 7,
83
+ retrofitData: {
84
+ allCombinedData: [
85
+ {
86
+ page__views__0: {
87
+ value: { raw: 6, formatted: '6.0' },
88
+ },
89
+ page__devices__1: {
90
+ value: { raw: 7, formatted: '7.0' },
91
+ },
92
+ page__views__2: {
93
+ value: { raw: 12, formatted: '12.0' },
94
+ },
95
+ page__devices__3: {
96
+ value: { raw: 0, formatted: '0.0' },
97
+ },
98
+ page__views__4: {
99
+ value: { raw: 11, formatted: '11.0' },
100
+ },
101
+ page__devices__5: {
102
+ value: { raw: 1, formatted: '1.0' },
103
+ },
104
+ },
105
+ ],
106
+ pivotColumnInfo: [
107
+ {
108
+ baseId: 'views',
109
+ fieldId: 'page__views__0',
110
+ },
111
+ {
112
+ baseId: 'devices',
113
+ fieldId: 'page__devices__1',
114
+ },
115
+ {
116
+ baseId: 'views',
117
+ fieldId: 'page__views__2',
118
+ },
119
+ {
120
+ baseId: 'devices',
121
+ fieldId: 'page__devices__3',
122
+ },
123
+ {
124
+ baseId: 'views',
125
+ fieldId: 'page__views__4',
126
+ },
127
+ {
128
+ baseId: 'devices',
129
+ fieldId: 'page__devices__5',
130
+ },
131
+ ],
132
+ },
133
+ };
134
+ const result = pivotQueryResults({
135
+ pivotConfig,
136
+ metricQuery: METRIC_QUERY_1DIM_2METRIC,
137
+ rows: RESULT_ROWS_1DIM_2METRIC,
138
+ options: { maxColumns: 60 },
139
+ getFieldLabel: (fieldId) => fieldId,
140
+ getField: (_fieldId) => undefined,
141
+ });
142
+ expect(result).toEqual(expected);
143
+ });
144
+ it('with 1 dimension, metrics as cols', () => {
145
+ const pivotConfig = {
146
+ pivotDimensions: [],
147
+ metricsAsRows: false,
148
+ };
149
+ const expected = {
150
+ headerValueTypes: [{ type: 'metric' }],
151
+ headerValues: [
152
+ [
153
+ { type: 'label', fieldId: 'views' },
154
+ { type: 'label', fieldId: 'devices' },
155
+ ],
156
+ ],
157
+ indexValueTypes: [{ type: 'dimension', fieldId: 'page' }],
158
+ indexValues: [
159
+ [
160
+ {
161
+ type: 'value',
162
+ fieldId: 'page',
163
+ value: { raw: '/home', formatted: '/home' },
164
+ colSpan: 1,
165
+ },
166
+ ],
167
+ [
168
+ {
169
+ type: 'value',
170
+ fieldId: 'page',
171
+ value: {
172
+ raw: '/about',
173
+ formatted: '/about',
174
+ },
175
+ colSpan: 1,
176
+ },
177
+ ],
178
+ [
179
+ {
180
+ type: 'value',
181
+ fieldId: 'page',
182
+ value: {
183
+ raw: '/first-post',
184
+ formatted: '/first-post',
185
+ },
186
+ colSpan: 1,
187
+ },
188
+ ],
189
+ ],
190
+ dataColumnCount: 2,
191
+ dataValues: [
192
+ [
193
+ { raw: 6, formatted: '6.0' },
194
+ { raw: 7, formatted: '7.0' },
195
+ ],
196
+ [
197
+ { raw: 12, formatted: '12.0' },
198
+ { raw: 0, formatted: '0.0' },
199
+ ],
200
+ [
201
+ { raw: 11, formatted: '11.0' },
202
+ { raw: 1, formatted: '1.0' },
203
+ ],
204
+ ],
205
+ pivotConfig,
206
+ titleFields: [[{ fieldId: 'page', direction: 'index' }]],
207
+ cellsCount: 3,
208
+ rowsCount: 3,
209
+ retrofitData: {
210
+ allCombinedData: [
211
+ {
212
+ page: { value: { raw: '/home', formatted: '/home' } },
213
+ views__0: {
214
+ value: { raw: 6, formatted: '6.0' },
215
+ },
216
+ devices__1: {
217
+ value: { raw: 7, formatted: '7.0' },
218
+ },
219
+ },
220
+ {
221
+ page: { value: { raw: '/about', formatted: '/about' } },
222
+ views__0: {
223
+ value: { raw: 12, formatted: '12.0' },
224
+ },
225
+ devices__1: {
226
+ value: { raw: 0, formatted: '0.0' },
227
+ },
228
+ },
229
+ {
230
+ page: {
231
+ value: {
232
+ raw: '/first-post',
233
+ formatted: '/first-post',
234
+ },
235
+ },
236
+ views__0: {
237
+ value: { raw: 11, formatted: '11.0' },
238
+ },
239
+ devices__1: {
240
+ value: { raw: 1, formatted: '1.0' },
241
+ },
242
+ },
243
+ ],
244
+ pivotColumnInfo: [
245
+ {
246
+ fieldId: 'page',
247
+ columnType: 'indexValue',
248
+ },
249
+ {
250
+ baseId: 'views',
251
+ fieldId: 'views__0',
252
+ },
253
+ {
254
+ baseId: 'devices',
255
+ fieldId: 'devices__1',
256
+ },
257
+ ],
258
+ },
259
+ };
260
+ const result = pivotQueryResults({
261
+ pivotConfig,
262
+ metricQuery: METRIC_QUERY_1DIM_2METRIC,
263
+ rows: RESULT_ROWS_1DIM_2METRIC,
264
+ options: { maxColumns: 60 },
265
+ getFieldLabel: (fieldId) => fieldId,
266
+ getField: (_fieldId) => undefined,
267
+ });
268
+ expect(result).toEqual(expected);
269
+ });
270
+ it('with 1 dimension, 1 pivoted, metrics as rows', () => {
271
+ const pivotConfig = {
272
+ pivotDimensions: ['page'],
273
+ metricsAsRows: true,
274
+ };
275
+ const expected = {
276
+ headerValueTypes: [{ type: 'dimension', fieldId: 'page' }],
277
+ headerValues: [
278
+ [
279
+ {
280
+ type: 'value',
281
+ fieldId: 'page',
282
+ value: { raw: '/home', formatted: '/home' },
283
+ colSpan: 1,
284
+ },
285
+ {
286
+ type: 'value',
287
+ fieldId: 'page',
288
+ value: { raw: '/about', formatted: '/about' },
289
+ colSpan: 1,
290
+ },
291
+ {
292
+ type: 'value',
293
+ fieldId: 'page',
294
+ value: { raw: '/first-post', formatted: '/first-post' },
295
+ colSpan: 1,
296
+ },
297
+ ],
298
+ ],
299
+ indexValueTypes: [{ type: 'metric' }],
300
+ indexValues: [
301
+ [{ type: 'label', fieldId: 'views' }],
302
+ [{ type: 'label', fieldId: 'devices' }],
303
+ ],
304
+ dataColumnCount: 3,
305
+ dataValues: [
306
+ [
307
+ { raw: 6, formatted: '6.0' },
308
+ { raw: 12, formatted: '12.0' },
309
+ { raw: 11, formatted: '11.0' },
310
+ ],
311
+ [
312
+ { raw: 7, formatted: '7.0' },
313
+ { raw: 0, formatted: '0.0' },
314
+ { raw: 1, formatted: '1.0' },
315
+ ],
316
+ ],
317
+ pivotConfig: {
318
+ pivotDimensions: ['page'],
319
+ metricsAsRows: true,
320
+ },
321
+ titleFields: [[{ fieldId: 'page', direction: 'header' }]],
322
+ cellsCount: 4,
323
+ rowsCount: 2,
324
+ retrofitData: {
325
+ allCombinedData: [
326
+ {
327
+ 'label-0': {
328
+ value: { raw: 'views', formatted: 'views' },
329
+ },
330
+ page__0: {
331
+ value: { raw: 6, formatted: '6.0' },
332
+ },
333
+ page__1: {
334
+ value: { raw: 12, formatted: '12.0' },
335
+ },
336
+ page__2: {
337
+ value: { raw: 11, formatted: '11.0' },
338
+ },
339
+ },
340
+ {
341
+ 'label-0': {
342
+ value: { raw: 'devices', formatted: 'devices' },
343
+ },
344
+ page__0: {
345
+ value: { raw: 7, formatted: '7.0' },
346
+ },
347
+ page__1: {
348
+ value: { raw: 0, formatted: '0.0' },
349
+ },
350
+ page__2: {
351
+ value: { raw: 1, formatted: '1.0' },
352
+ },
353
+ },
354
+ ],
355
+ pivotColumnInfo: [
356
+ {
357
+ fieldId: 'label-0',
358
+ columnType: 'label',
359
+ },
360
+ {
361
+ baseId: 'page',
362
+ fieldId: 'page__0',
363
+ },
364
+ {
365
+ baseId: 'page',
366
+ fieldId: 'page__1',
367
+ },
368
+ {
369
+ baseId: 'page',
370
+ fieldId: 'page__2',
371
+ },
372
+ ],
373
+ },
374
+ };
375
+ const result = pivotQueryResults({
376
+ pivotConfig,
377
+ metricQuery: METRIC_QUERY_1DIM_2METRIC,
378
+ rows: RESULT_ROWS_1DIM_2METRIC,
379
+ options: { maxColumns: 60 },
380
+ getFieldLabel: (fieldId) => fieldId,
381
+ getField: (_fieldId) => undefined,
382
+ });
383
+ expect(result).toEqual(expected);
384
+ });
385
+ it('with 2 dimensions, 1 pivoted, metrics as columns', () => {
386
+ const pivotConfig = {
387
+ pivotDimensions: ['site'],
388
+ metricsAsRows: false,
389
+ };
390
+ const expected = {
391
+ headerValueTypes: [
392
+ { type: 'dimension', fieldId: 'site' },
393
+ { type: 'metric' },
394
+ ],
395
+ headerValues: [
396
+ [
397
+ {
398
+ type: 'value',
399
+ fieldId: 'site',
400
+ value: { raw: 'blog', formatted: 'Blog' },
401
+ colSpan: 2,
402
+ },
403
+ {
404
+ type: 'value',
405
+ fieldId: 'site',
406
+ value: { raw: 'blog', formatted: 'Blog' },
407
+ colSpan: 0,
408
+ },
409
+ {
410
+ type: 'value',
411
+ fieldId: 'site',
412
+ value: { raw: 'docs', formatted: 'Docs' },
413
+ colSpan: 2,
414
+ },
415
+ {
416
+ type: 'value',
417
+ fieldId: 'site',
418
+ value: { raw: 'docs', formatted: 'Docs' },
419
+ colSpan: 0,
420
+ },
421
+ ],
422
+ [
423
+ { type: 'label', fieldId: 'views' },
424
+ { type: 'label', fieldId: 'devices' },
425
+ { type: 'label', fieldId: 'views' },
426
+ { type: 'label', fieldId: 'devices' },
427
+ ],
428
+ ],
429
+ indexValueTypes: [{ type: 'dimension', fieldId: 'page' }],
430
+ indexValues: [
431
+ [
432
+ {
433
+ type: 'value',
434
+ fieldId: 'page',
435
+ value: { raw: '/home', formatted: '/home' },
436
+ colSpan: 1,
437
+ },
438
+ ],
439
+ [
440
+ {
441
+ type: 'value',
442
+ fieldId: 'page',
443
+ value: { raw: '/about', formatted: '/about' },
444
+ colSpan: 1,
445
+ },
446
+ ],
447
+ [
448
+ {
449
+ type: 'value',
450
+ fieldId: 'page',
451
+ value: { raw: '/first-post', formatted: '/first-post' },
452
+ colSpan: 1,
453
+ },
454
+ ],
455
+ ],
456
+ dataColumnCount: 4,
457
+ dataValues: [
458
+ [
459
+ { raw: 6, formatted: '6.0' },
460
+ { raw: 7, formatted: '7.0' },
461
+ { raw: 2, formatted: '2.0' },
462
+ { raw: 10, formatted: '10.0' },
463
+ ],
464
+ [
465
+ { raw: 12, formatted: '12.0' },
466
+ { raw: 0, formatted: '0.0' },
467
+ { raw: 2, formatted: '2.0' },
468
+ { raw: 13, formatted: '13.0' },
469
+ ],
470
+ [
471
+ { raw: 11, formatted: '11.0' },
472
+ { raw: 1, formatted: '1.0' },
473
+ null,
474
+ null,
475
+ ],
476
+ ],
477
+ pivotConfig: { pivotDimensions: ['site'], metricsAsRows: false },
478
+ titleFields: [
479
+ [{ fieldId: 'site', direction: 'header' }],
480
+ [{ fieldId: 'page', direction: 'index' }],
481
+ ],
482
+ columnTotals: undefined,
483
+ rowTotals: undefined,
484
+ cellsCount: 5,
485
+ rowsCount: 3,
486
+ retrofitData: {
487
+ allCombinedData: [
488
+ {
489
+ page: { value: { raw: '/home', formatted: '/home' } },
490
+ site__views__0: {
491
+ value: { raw: 6, formatted: '6.0' },
492
+ },
493
+ site__devices__1: {
494
+ value: { raw: 7, formatted: '7.0' },
495
+ },
496
+ site__views__2: {
497
+ value: { raw: 2, formatted: '2.0' },
498
+ },
499
+ site__devices__3: {
500
+ value: { raw: 10, formatted: '10.0' },
501
+ },
502
+ },
503
+ {
504
+ page: { value: { raw: '/about', formatted: '/about' } },
505
+ site__views__0: {
506
+ value: { raw: 12, formatted: '12.0' },
507
+ },
508
+ site__devices__1: {
509
+ value: { raw: 0, formatted: '0.0' },
510
+ },
511
+ site__views__2: {
512
+ value: { raw: 2, formatted: '2.0' },
513
+ },
514
+ site__devices__3: {
515
+ value: { raw: 13, formatted: '13.0' },
516
+ },
517
+ },
518
+ {
519
+ page: {
520
+ value: {
521
+ raw: '/first-post',
522
+ formatted: '/first-post',
523
+ },
524
+ },
525
+ site__views__0: {
526
+ value: { raw: 11, formatted: '11.0' },
527
+ },
528
+ site__devices__1: {
529
+ value: { raw: 1, formatted: '1.0' },
530
+ },
531
+ },
532
+ ],
533
+ pivotColumnInfo: [
534
+ {
535
+ fieldId: 'page',
536
+ columnType: 'indexValue',
537
+ },
538
+ {
539
+ baseId: 'views',
540
+ fieldId: 'site__views__0',
541
+ },
542
+ {
543
+ baseId: 'devices',
544
+ fieldId: 'site__devices__1',
545
+ },
546
+ {
547
+ baseId: 'views',
548
+ fieldId: 'site__views__2',
549
+ },
550
+ {
551
+ baseId: 'devices',
552
+ fieldId: 'site__devices__3',
553
+ },
554
+ ],
555
+ },
556
+ };
557
+ const result = pivotQueryResults({
558
+ pivotConfig,
559
+ metricQuery: METRIC_QUERY_2DIM_2METRIC,
560
+ rows: RESULT_ROWS_2DIM_2METRIC,
561
+ options: { maxColumns: 60 },
562
+ getFieldLabel: (fieldId) => fieldId,
563
+ getField: (_fieldId) => undefined,
564
+ });
565
+ expect(result).toEqual(expected);
566
+ });
567
+ it('with 2 dimensions, 1 pivoted, metrics as rows with totals', () => {
568
+ const pivotConfig = {
569
+ pivotDimensions: ['site'],
570
+ metricsAsRows: true,
571
+ rowTotals: true,
572
+ };
573
+ const expected = {
574
+ groupedSubtotals: undefined,
575
+ headerValueTypes: [{ type: 'dimension', fieldId: 'site' }],
576
+ headerValues: [
577
+ [
578
+ {
579
+ type: 'value',
580
+ fieldId: 'site',
581
+ value: { raw: 'blog', formatted: 'Blog' },
582
+ colSpan: 1,
583
+ },
584
+ {
585
+ type: 'value',
586
+ fieldId: 'site',
587
+ value: { raw: 'docs', formatted: 'Docs' },
588
+ colSpan: 1,
589
+ },
590
+ ],
591
+ ],
592
+ indexValueTypes: [
593
+ { type: 'dimension', fieldId: 'page' },
594
+ { type: 'metric' },
595
+ ],
596
+ indexValues: [
597
+ [
598
+ {
599
+ type: 'value',
600
+ fieldId: 'page',
601
+ value: { raw: '/home', formatted: '/home' },
602
+ colSpan: 1,
603
+ },
604
+ { type: 'label', fieldId: 'views' },
605
+ ],
606
+ [
607
+ {
608
+ type: 'value',
609
+ fieldId: 'page',
610
+ value: { raw: '/home', formatted: '/home' },
611
+ colSpan: 1,
612
+ },
613
+ { type: 'label', fieldId: 'devices' },
614
+ ],
615
+ [
616
+ {
617
+ type: 'value',
618
+ fieldId: 'page',
619
+ value: {
620
+ raw: '/about',
621
+ formatted: '/about',
622
+ },
623
+ colSpan: 1,
624
+ },
625
+ { type: 'label', fieldId: 'views' },
626
+ ],
627
+ [
628
+ {
629
+ type: 'value',
630
+ fieldId: 'page',
631
+ value: {
632
+ raw: '/about',
633
+ formatted: '/about',
634
+ },
635
+ colSpan: 1,
636
+ },
637
+ { type: 'label', fieldId: 'devices' },
638
+ ],
639
+ [
640
+ {
641
+ type: 'value',
642
+ fieldId: 'page',
643
+ value: {
644
+ raw: '/first-post',
645
+ formatted: '/first-post',
646
+ },
647
+ colSpan: 1,
648
+ },
649
+ { type: 'label', fieldId: 'views' },
650
+ ],
651
+ [
652
+ {
653
+ type: 'value',
654
+ fieldId: 'page',
655
+ value: { raw: '/first-post', formatted: '/first-post' },
656
+ colSpan: 1,
657
+ },
658
+ { type: 'label', fieldId: 'devices' },
659
+ ],
660
+ ],
661
+ dataColumnCount: 2,
662
+ dataValues: [
663
+ [
664
+ { raw: 6, formatted: '6.0' },
665
+ { raw: 2, formatted: '2.0' },
666
+ ],
667
+ [
668
+ { raw: 7, formatted: '7.0' },
669
+ { raw: 10, formatted: '10.0' },
670
+ ],
671
+ [
672
+ { raw: 12, formatted: '12.0' },
673
+ { raw: 2, formatted: '2.0' },
674
+ ],
675
+ [
676
+ { raw: 0, formatted: '0.0' },
677
+ { raw: 13, formatted: '13.0' },
678
+ ],
679
+ [{ raw: 11, formatted: '11.0' }, null],
680
+ [{ raw: 1, formatted: '1.0' }, null],
681
+ ],
682
+ pivotConfig: {
683
+ pivotDimensions: ['site'],
684
+ metricsAsRows: true,
685
+ rowTotals: true,
686
+ },
687
+ retrofitData: {
688
+ allCombinedData: [
689
+ {
690
+ page: { value: { raw: '/home', formatted: '/home' } },
691
+ 'label-1': {
692
+ value: { raw: 'views', formatted: 'views' },
693
+ },
694
+ site__0: {
695
+ value: { raw: 6, formatted: '6.0' },
696
+ },
697
+ site__1: {
698
+ value: { raw: 2, formatted: '2.0' },
699
+ },
700
+ },
701
+ {
702
+ page: { value: { raw: '/home', formatted: '/home' } },
703
+ 'label-1': {
704
+ value: { raw: 'devices', formatted: 'devices' },
705
+ },
706
+ site__0: {
707
+ value: { raw: 7, formatted: '7.0' },
708
+ },
709
+ site__1: {
710
+ value: { raw: 10, formatted: '10.0' },
711
+ },
712
+ },
713
+ {
714
+ page: { value: { raw: '/about', formatted: '/about' } },
715
+ 'label-1': {
716
+ value: { raw: 'views', formatted: 'views' },
717
+ },
718
+ site__0: {
719
+ value: { raw: 12, formatted: '12.0' },
720
+ },
721
+ site__1: {
722
+ value: { raw: 2, formatted: '2.0' },
723
+ },
724
+ },
725
+ {
726
+ page: { value: { raw: '/about', formatted: '/about' } },
727
+ 'label-1': {
728
+ value: { raw: 'devices', formatted: 'devices' },
729
+ },
730
+ site__0: {
731
+ value: { raw: 0, formatted: '0.0' },
732
+ },
733
+ site__1: {
734
+ value: { raw: 13, formatted: '13.0' },
735
+ },
736
+ },
737
+ {
738
+ page: {
739
+ value: {
740
+ raw: '/first-post',
741
+ formatted: '/first-post',
742
+ },
743
+ },
744
+ 'label-1': {
745
+ value: { raw: 'views', formatted: 'views' },
746
+ },
747
+ site__0: {
748
+ value: { raw: 11, formatted: '11.0' },
749
+ },
750
+ },
751
+ {
752
+ page: {
753
+ value: {
754
+ raw: '/first-post',
755
+ formatted: '/first-post',
756
+ },
757
+ },
758
+ 'label-1': {
759
+ value: { raw: 'devices', formatted: 'devices' },
760
+ },
761
+ site__0: {
762
+ value: { raw: 1, formatted: '1.0' },
763
+ },
764
+ },
765
+ ],
766
+ pivotColumnInfo: [
767
+ {
768
+ baseId: undefined,
769
+ fieldId: 'page',
770
+ columnType: 'indexValue',
771
+ underlyingId: undefined,
772
+ },
773
+ {
774
+ baseId: undefined,
775
+ fieldId: 'label-1',
776
+ columnType: 'label',
777
+ underlyingId: undefined,
778
+ },
779
+ {
780
+ baseId: 'site',
781
+ columnType: undefined,
782
+ fieldId: 'site__0',
783
+ underlyingId: undefined,
784
+ },
785
+ {
786
+ baseId: 'site',
787
+ columnType: undefined,
788
+ fieldId: 'site__1',
789
+ underlyingId: undefined,
790
+ },
791
+ {
792
+ baseId: 'row-total-0',
793
+ fieldId: 'row-total-0',
794
+ underlyingId: undefined,
795
+ columnType: 'rowTotal',
796
+ },
797
+ ],
798
+ },
799
+ titleFields: [
800
+ [
801
+ { fieldId: 'page', direction: 'index' },
802
+ { fieldId: 'site', direction: 'header' },
803
+ ],
804
+ ],
805
+ columnTotalFields: undefined,
806
+ rowTotalFields: [[{ fieldId: undefined }]],
807
+ columnTotals: undefined,
808
+ rowTotals: [[8], [17], [14], [13], [11], [1]],
809
+ cellsCount: 5,
810
+ rowsCount: 6,
811
+ };
812
+ const result = pivotQueryResults({
813
+ pivotConfig,
814
+ metricQuery: METRIC_QUERY_2DIM_2METRIC,
815
+ rows: RESULT_ROWS_2DIM_2METRIC,
816
+ options: { maxColumns: 60 },
817
+ getFieldLabel: (fieldId) => fieldId,
818
+ getField: (_fieldId) => undefined,
819
+ });
820
+ expect(result).toStrictEqual(expected);
821
+ });
822
+ it.skip('with 0 dimensions and 2 metrics as columns', () => {
823
+ const pivotConfig = {
824
+ pivotDimensions: [],
825
+ metricsAsRows: false,
826
+ };
827
+ const expected = {
828
+ headerValueTypes: [{ type: 'metric' }],
829
+ headerValues: [
830
+ [
831
+ { raw: 'views', formatted: 'views' },
832
+ { raw: 'devices', formatted: 'devices' },
833
+ ],
834
+ ],
835
+ indexValueTypes: [],
836
+ indexValues: [],
837
+ dataColumnCount: 2,
838
+ dataValues: [
839
+ [
840
+ { raw: 6, formatted: '6.0' },
841
+ { raw: 7, formatted: '7.0' },
842
+ ],
843
+ ],
844
+ pivotConfig,
845
+ };
846
+ const results = pivotQueryResults({
847
+ pivotConfig,
848
+ metricQuery: METRIC_QUERY_0DIM_2METRIC,
849
+ rows: RESULT_ROWS_0DIM_2METRIC,
850
+ options: { maxColumns: 60 },
851
+ getFieldLabel: (fieldId) => fieldId,
852
+ getField: (_fieldId) => undefined,
853
+ });
854
+ expect(results).toStrictEqual(expected);
855
+ });
856
+ });
857
+ describe('convertSqlPivotedRowsToPivotData', () => {
858
+ it('should convert SQL-pivoted rows to PivotData format', () => {
859
+ // Pivot "normal" rows (legacy way)
860
+ const resultLegacy = pivotQueryResults({
861
+ getField: getFieldMock,
862
+ getFieldLabel: (fieldId) => fieldId,
863
+ pivotConfig: {
864
+ pivotDimensions: ['payments_payment_method'],
865
+ metricsAsRows: false,
866
+ columnOrder: [
867
+ 'payments_payment_method',
868
+ 'orders_order_date_year',
869
+ 'payments_total_revenue',
870
+ ],
871
+ hiddenMetricFieldIds: [],
872
+ columnTotals: false,
873
+ rowTotals: false,
874
+ },
875
+ metricQuery: {
876
+ dimensions: [
877
+ 'payments_payment_method',
878
+ 'orders_order_date_year',
879
+ ],
880
+ metrics: ['payments_total_revenue'],
881
+ tableCalculations: [],
882
+ additionalMetrics: [],
883
+ customDimensions: [],
884
+ },
885
+ rows: NON_PIVOTED_ROWS,
886
+ options: {
887
+ maxColumns: 60,
888
+ },
889
+ });
890
+ // Convert SQL Pivoted rows to PivotData
891
+ const result = convertSqlPivotedRowsToPivotData({
892
+ rows: SQL_PIVOTED_ROWS,
893
+ pivotDetails: SQL_PIVOT_DETAILS,
894
+ pivotConfig: {
895
+ rowTotals: false,
896
+ columnTotals: false,
897
+ metricsAsRows: false,
898
+ columnOrder: [
899
+ 'payments_payment_method',
900
+ 'orders_order_date_year',
901
+ 'payments_total_revenue',
902
+ ],
903
+ },
904
+ getField: getFieldMock,
905
+ getFieldLabel: (fieldId) => fieldId,
906
+ groupedSubtotals: undefined,
907
+ });
908
+ // Verify legacy way to pivot in FE
909
+ expect(resultLegacy).toStrictEqual(EXPECTED_PIVOT_DATA);
910
+ // Verify the new conversion matches legacy method
911
+ expect(result).toStrictEqual(resultLegacy);
912
+ });
913
+ it('should convert SQL-pivoted rows with totals to PivotData format', () => {
914
+ // Pivot "normal" rows (legacy way)
915
+ const resultLegacy = pivotQueryResults({
916
+ getField: getFieldMock,
917
+ getFieldLabel: (fieldId) => fieldId,
918
+ pivotConfig: {
919
+ pivotDimensions: ['payments_payment_method'],
920
+ metricsAsRows: false,
921
+ columnOrder: [
922
+ 'payments_payment_method',
923
+ 'orders_order_date_year',
924
+ 'payments_total_revenue',
925
+ ],
926
+ hiddenMetricFieldIds: [],
927
+ columnTotals: true,
928
+ rowTotals: true,
929
+ },
930
+ metricQuery: {
931
+ dimensions: [
932
+ 'payments_payment_method',
933
+ 'orders_order_date_year',
934
+ ],
935
+ metrics: ['payments_total_revenue'],
936
+ tableCalculations: [],
937
+ additionalMetrics: [],
938
+ customDimensions: [],
939
+ },
940
+ rows: NON_PIVOTED_ROWS,
941
+ options: {
942
+ maxColumns: 60,
943
+ },
944
+ });
945
+ // Convert SQL Pivoted rows to PivotData
946
+ const result = convertSqlPivotedRowsToPivotData({
947
+ rows: SQL_PIVOTED_ROWS,
948
+ pivotDetails: SQL_PIVOT_DETAILS,
949
+ pivotConfig: {
950
+ rowTotals: true,
951
+ columnTotals: true,
952
+ metricsAsRows: false,
953
+ columnOrder: [
954
+ 'payments_payment_method',
955
+ 'orders_order_date_year',
956
+ 'payments_total_revenue',
957
+ ],
958
+ },
959
+ getField: getFieldMock,
960
+ getFieldLabel: (fieldId) => fieldId,
961
+ groupedSubtotals: undefined,
962
+ });
963
+ // Verify legacy way to pivot in FE
964
+ expect(resultLegacy).toStrictEqual(EXPECTED_PIVOT_DATA_WITH_TOTALS);
965
+ // Verify the new conversion matches legacy method
966
+ expect(result).toStrictEqual(resultLegacy);
967
+ });
968
+ it('should convert SQL-pivoted rows with metricsAsRows: true to PivotData format', () => {
969
+ // Pivot "normal" rows (legacy way) with metricsAsRows: true
970
+ const resultLegacy = pivotQueryResults({
971
+ getField: getFieldMock,
972
+ getFieldLabel: (fieldId) => {
973
+ if (fieldId === 'payments_total_revenue') {
974
+ return 'Payments Total revenue';
975
+ }
976
+ return fieldId;
977
+ },
978
+ pivotConfig: {
979
+ pivotDimensions: ['payments_payment_method'],
980
+ metricsAsRows: true,
981
+ columnOrder: [
982
+ 'payments_payment_method',
983
+ 'orders_order_date_year',
984
+ 'payments_total_revenue',
985
+ ],
986
+ hiddenMetricFieldIds: [],
987
+ columnTotals: true,
988
+ rowTotals: true,
989
+ },
990
+ metricQuery: {
991
+ dimensions: [
992
+ 'payments_payment_method',
993
+ 'orders_order_date_year',
994
+ ],
995
+ metrics: ['payments_total_revenue'],
996
+ tableCalculations: [],
997
+ additionalMetrics: [],
998
+ customDimensions: [],
999
+ },
1000
+ rows: NON_PIVOTED_ROWS,
1001
+ options: {
1002
+ maxColumns: 60,
1003
+ },
1004
+ });
1005
+ // Convert SQL Pivoted rows to PivotData with metricsAsRows: true
1006
+ const result = convertSqlPivotedRowsToPivotData({
1007
+ rows: SQL_PIVOTED_ROWS,
1008
+ pivotDetails: SQL_PIVOT_DETAILS,
1009
+ pivotConfig: {
1010
+ rowTotals: true,
1011
+ columnTotals: true,
1012
+ metricsAsRows: true,
1013
+ columnOrder: [
1014
+ 'payments_payment_method',
1015
+ 'orders_order_date_year',
1016
+ 'payments_total_revenue',
1017
+ ],
1018
+ },
1019
+ getField: getFieldMock,
1020
+ getFieldLabel: (fieldId) => {
1021
+ if (fieldId === 'payments_total_revenue') {
1022
+ return 'Payments Total revenue';
1023
+ }
1024
+ return fieldId;
1025
+ },
1026
+ groupedSubtotals: undefined,
1027
+ });
1028
+ // Verify legacy way to pivot in FE matches expected structure
1029
+ expect(resultLegacy).toStrictEqual(EXPECTED_PIVOT_DATA_METRICS_AS_ROWS);
1030
+ // Verify the new conversion matches legacy method
1031
+ expect(result).toStrictEqual(resultLegacy);
1032
+ });
1033
+ it('should convert complex SQL-pivoted rows to PivotData format', () => {
1034
+ // Pivot "normal" rows (legacy way) with metricsAsRows: true
1035
+ const resultLegacy = pivotQueryResults({
1036
+ getField: getFieldMock,
1037
+ getFieldLabel: (fieldId) => {
1038
+ if (fieldId === 'payments_total_revenue') {
1039
+ return 'Payments Total revenue';
1040
+ }
1041
+ if (fieldId === 'orders_average_order_size') {
1042
+ return 'Orders Average order size';
1043
+ }
1044
+ if (fieldId === 'orders_total_order_amount') {
1045
+ return 'Orders Total order amount';
1046
+ }
1047
+ return fieldId;
1048
+ },
1049
+ pivotConfig: {
1050
+ pivotDimensions: [
1051
+ 'payments_payment_method',
1052
+ 'orders_is_completed',
1053
+ ],
1054
+ metricsAsRows: false,
1055
+ columnOrder: [
1056
+ 'payments_payment_method',
1057
+ 'orders_order_date_year',
1058
+ 'orders_is_completed',
1059
+ 'orders_promo_code',
1060
+ 'payments_total_revenue',
1061
+ 'orders_average_order_size',
1062
+ 'orders_total_order_amount',
1063
+ ],
1064
+ hiddenMetricFieldIds: [],
1065
+ columnTotals: true,
1066
+ rowTotals: true,
1067
+ },
1068
+ metricQuery: {
1069
+ dimensions: [
1070
+ 'payments_payment_method',
1071
+ 'orders_order_date_year',
1072
+ 'orders_is_completed',
1073
+ 'orders_promo_code',
1074
+ ],
1075
+ metrics: [
1076
+ 'payments_total_revenue',
1077
+ 'orders_average_order_size',
1078
+ 'orders_total_order_amount',
1079
+ ],
1080
+ tableCalculations: [],
1081
+ additionalMetrics: [],
1082
+ customDimensions: [],
1083
+ },
1084
+ rows: COMPLEX_NON_PIVOTED_ROWS,
1085
+ options: {
1086
+ maxColumns: 60,
1087
+ },
1088
+ });
1089
+ // Convert SQL Pivoted rows to PivotData with metricsAsRows: true
1090
+ const result = convertSqlPivotedRowsToPivotData({
1091
+ rows: COMPLEX_SQL_PIVOTED_ROWS,
1092
+ pivotDetails: COMPLEX_SQL_PIVOT_DETAILS,
1093
+ pivotConfig: {
1094
+ rowTotals: true,
1095
+ columnTotals: true,
1096
+ metricsAsRows: false,
1097
+ columnOrder: [
1098
+ 'payments_payment_method',
1099
+ 'orders_order_date_year',
1100
+ 'orders_is_completed',
1101
+ 'orders_promo_code',
1102
+ 'payments_total_revenue',
1103
+ 'orders_average_order_size',
1104
+ 'orders_total_order_amount',
1105
+ ],
1106
+ },
1107
+ getField: getFieldMock,
1108
+ getFieldLabel: (fieldId) => {
1109
+ if (fieldId === 'payments_total_revenue') {
1110
+ return 'Payments Total revenue';
1111
+ }
1112
+ if (fieldId === 'orders_average_order_size') {
1113
+ return 'Orders Average order size';
1114
+ }
1115
+ if (fieldId === 'orders_total_order_amount') {
1116
+ return 'Orders Total order amount';
1117
+ }
1118
+ return fieldId;
1119
+ },
1120
+ groupedSubtotals: undefined,
1121
+ });
1122
+ // Verify legacy way to pivot in FE matches expected structure
1123
+ expect(resultLegacy).toStrictEqual(EXPECTED_COMPLEX_PIVOT_DATA);
1124
+ // Verify the new conversion matches legacy method
1125
+ expect(result).toStrictEqual(resultLegacy);
1126
+ });
1127
+ it('should convert complex SQL-pivoted rows with metric as rows to PivotData format', () => {
1128
+ // Pivot "normal" rows (legacy way) with metricsAsRows: true
1129
+ const resultLegacy = pivotQueryResults({
1130
+ getField: getFieldMock,
1131
+ getFieldLabel: (fieldId) => {
1132
+ if (fieldId === 'payments_total_revenue') {
1133
+ return 'Payments Total revenue';
1134
+ }
1135
+ if (fieldId === 'orders_average_order_size') {
1136
+ return 'Orders Average order size';
1137
+ }
1138
+ if (fieldId === 'orders_total_order_amount') {
1139
+ return 'Orders Total order amount';
1140
+ }
1141
+ return fieldId;
1142
+ },
1143
+ pivotConfig: {
1144
+ pivotDimensions: [
1145
+ 'payments_payment_method',
1146
+ 'orders_is_completed',
1147
+ ],
1148
+ metricsAsRows: true,
1149
+ columnOrder: [
1150
+ 'payments_payment_method',
1151
+ 'orders_order_date_year',
1152
+ 'orders_is_completed',
1153
+ 'orders_promo_code',
1154
+ 'payments_total_revenue',
1155
+ 'orders_average_order_size',
1156
+ 'orders_total_order_amount',
1157
+ ],
1158
+ hiddenMetricFieldIds: [],
1159
+ columnTotals: true,
1160
+ rowTotals: true,
1161
+ },
1162
+ metricQuery: {
1163
+ dimensions: [
1164
+ 'payments_payment_method',
1165
+ 'orders_order_date_year',
1166
+ 'orders_is_completed',
1167
+ 'orders_promo_code',
1168
+ ],
1169
+ metrics: [
1170
+ 'payments_total_revenue',
1171
+ 'orders_average_order_size',
1172
+ 'orders_total_order_amount',
1173
+ ],
1174
+ tableCalculations: [],
1175
+ additionalMetrics: [],
1176
+ customDimensions: [],
1177
+ },
1178
+ rows: COMPLEX_NON_PIVOTED_ROWS,
1179
+ options: {
1180
+ maxColumns: 60,
1181
+ },
1182
+ });
1183
+ // Convert SQL Pivoted rows to PivotData with metricsAsRows: true
1184
+ const result = convertSqlPivotedRowsToPivotData({
1185
+ rows: COMPLEX_SQL_PIVOTED_ROWS,
1186
+ pivotDetails: COMPLEX_SQL_PIVOT_DETAILS,
1187
+ pivotConfig: {
1188
+ rowTotals: true,
1189
+ columnTotals: true,
1190
+ metricsAsRows: true,
1191
+ columnOrder: [
1192
+ 'payments_payment_method',
1193
+ 'orders_order_date_year',
1194
+ 'orders_is_completed',
1195
+ 'orders_promo_code',
1196
+ 'payments_total_revenue',
1197
+ 'orders_average_order_size',
1198
+ 'orders_total_order_amount',
1199
+ ],
1200
+ },
1201
+ getField: getFieldMock,
1202
+ getFieldLabel: (fieldId) => {
1203
+ if (fieldId === 'payments_total_revenue') {
1204
+ return 'Payments Total revenue';
1205
+ }
1206
+ if (fieldId === 'orders_average_order_size') {
1207
+ return 'Orders Average order size';
1208
+ }
1209
+ if (fieldId === 'orders_total_order_amount') {
1210
+ return 'Orders Total order amount';
1211
+ }
1212
+ return fieldId;
1213
+ },
1214
+ groupedSubtotals: undefined,
1215
+ });
1216
+ // Verify legacy way to pivot in FE matches expected structure
1217
+ expect(resultLegacy).toStrictEqual(EXPECTED_COMPLEX_PIVOT_DATA_WITH_METRICS_AS_ROWS);
1218
+ // Verify the new conversion matches legacy method
1219
+ expect(result).toStrictEqual(resultLegacy);
1220
+ });
1221
+ });
1222
+ //# sourceMappingURL=pivotQueryResults.test.js.map