@quillsql/react 2.14.16 → 2.15.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 (253) hide show
  1. package/dist/cjs/Chart.d.ts.map +1 -1
  2. package/dist/cjs/Chart.js +12 -0
  3. package/dist/cjs/ChartBuilder.d.ts +3 -2
  4. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  5. package/dist/cjs/ChartBuilder.js +112 -18
  6. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  7. package/dist/cjs/ChartEditor.js +2 -0
  8. package/dist/cjs/Context.d.ts +6 -2
  9. package/dist/cjs/Context.d.ts.map +1 -1
  10. package/dist/cjs/Context.js +160 -33
  11. package/dist/cjs/Dashboard.d.ts.map +1 -1
  12. package/dist/cjs/Dashboard.js +99 -19
  13. package/dist/cjs/QuillProvider.d.ts +38 -1
  14. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  15. package/dist/cjs/QuillProvider.js +2 -2
  16. package/dist/cjs/ReportBuilder.d.ts +7 -2
  17. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  18. package/dist/cjs/ReportBuilder.js +104 -1271
  19. package/dist/cjs/SQLEditor.d.ts +9 -2
  20. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  21. package/dist/cjs/SQLEditor.js +67 -10
  22. package/dist/cjs/Table.d.ts.map +1 -1
  23. package/dist/cjs/Table.js +12 -0
  24. package/dist/cjs/components/Chart/InternalChart.d.ts.map +1 -1
  25. package/dist/cjs/components/Chart/InternalChart.js +24 -1
  26. package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  27. package/dist/cjs/components/Dashboard/DashboardTemplate.js +2 -1
  28. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  29. package/dist/cjs/components/Dashboard/DataLoader.js +73 -2
  30. package/dist/cjs/components/Dashboard/util.d.ts +2 -1
  31. package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
  32. package/dist/cjs/components/Dashboard/util.js +12 -1
  33. package/dist/cjs/components/QuillTable.d.ts +2 -1
  34. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  35. package/dist/cjs/components/QuillTable.js +2 -2
  36. package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts +2 -1
  37. package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
  38. package/dist/cjs/components/ReportBuilder/AddColumnModal.js +28 -3
  39. package/dist/cjs/components/ReportBuilder/ColumnComponent.d.ts +49 -0
  40. package/dist/cjs/components/ReportBuilder/ColumnComponent.d.ts.map +1 -0
  41. package/dist/cjs/components/ReportBuilder/ColumnComponent.js +46 -0
  42. package/dist/cjs/components/ReportBuilder/FilterComponent.d.ts +65 -0
  43. package/dist/cjs/components/ReportBuilder/FilterComponent.d.ts.map +1 -0
  44. package/dist/cjs/components/ReportBuilder/FilterComponent.js +51 -0
  45. package/dist/cjs/components/ReportBuilder/LimitComponent.d.ts +42 -0
  46. package/dist/cjs/components/ReportBuilder/LimitComponent.d.ts.map +1 -0
  47. package/dist/cjs/components/ReportBuilder/LimitComponent.js +50 -0
  48. package/dist/cjs/components/ReportBuilder/PivotComponent.d.ts +66 -0
  49. package/dist/cjs/components/ReportBuilder/PivotComponent.d.ts.map +1 -0
  50. package/dist/cjs/components/ReportBuilder/PivotComponent.js +47 -0
  51. package/dist/cjs/components/ReportBuilder/SaveReport.d.ts +162 -0
  52. package/dist/cjs/components/ReportBuilder/SaveReport.d.ts.map +1 -0
  53. package/dist/cjs/components/ReportBuilder/SaveReport.js +31 -0
  54. package/dist/cjs/components/ReportBuilder/SortComponent.d.ts +42 -0
  55. package/dist/cjs/components/ReportBuilder/SortComponent.d.ts.map +1 -0
  56. package/dist/cjs/components/ReportBuilder/SortComponent.js +50 -0
  57. package/dist/cjs/components/ReportBuilder/TableComponent.d.ts +28 -0
  58. package/dist/cjs/components/ReportBuilder/TableComponent.d.ts.map +1 -0
  59. package/dist/cjs/components/ReportBuilder/TableComponent.js +24 -0
  60. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  61. package/dist/cjs/components/ReportBuilder/ui.js +3 -1
  62. package/dist/cjs/components/UiComponents.d.ts +5 -2
  63. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  64. package/dist/cjs/components/UiComponents.js +7 -5
  65. package/dist/cjs/hooks/useAskQuill.d.ts.map +1 -1
  66. package/dist/cjs/hooks/useAskQuill.js +38 -0
  67. package/dist/cjs/hooks/useDashboard.d.ts +1 -1
  68. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  69. package/dist/cjs/hooks/useDashboard.js +62 -6
  70. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  71. package/dist/cjs/hooks/useExport.js +5 -2
  72. package/dist/cjs/hooks/useLongLoading.d.ts +13 -0
  73. package/dist/cjs/hooks/useLongLoading.d.ts.map +1 -0
  74. package/dist/cjs/hooks/useLongLoading.js +67 -0
  75. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  76. package/dist/cjs/hooks/useQuill.js +25 -1
  77. package/dist/cjs/hooks/useReportBuilder.d.ts +178 -0
  78. package/dist/cjs/hooks/useReportBuilder.d.ts.map +1 -0
  79. package/dist/cjs/hooks/useReportBuilder.js +1495 -0
  80. package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
  81. package/dist/cjs/hooks/useVirtualTables.js +27 -2
  82. package/dist/cjs/index.d.ts +11 -0
  83. package/dist/cjs/index.d.ts.map +1 -1
  84. package/dist/cjs/index.js +17 -1
  85. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts +14 -1
  86. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  87. package/dist/cjs/internals/ReportBuilder/PivotForm.js +86 -3
  88. package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  89. package/dist/cjs/internals/ReportBuilder/PivotList.js +3 -3
  90. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +18 -2
  91. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  92. package/dist/cjs/internals/ReportBuilder/PivotModal.js +438 -147
  93. package/dist/cjs/models/Filter.d.ts +1 -1
  94. package/dist/cjs/models/Filter.d.ts.map +1 -1
  95. package/dist/cjs/models/Filter.js +3 -3
  96. package/dist/cjs/utils/astFilterProcessing.d.ts.map +1 -1
  97. package/dist/cjs/utils/astFilterProcessing.js +25 -4
  98. package/dist/cjs/utils/astProcessing.d.ts +4 -2
  99. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  100. package/dist/cjs/utils/astProcessing.js +25 -2
  101. package/dist/cjs/utils/client.d.ts +2 -1
  102. package/dist/cjs/utils/client.d.ts.map +1 -1
  103. package/dist/cjs/utils/client.js +12 -1
  104. package/dist/cjs/utils/dashboard.d.ts +3 -1
  105. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  106. package/dist/cjs/utils/dashboard.js +44 -3
  107. package/dist/cjs/utils/filterProcessing.d.ts +2 -1
  108. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  109. package/dist/cjs/utils/filterProcessing.js +12 -1
  110. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  111. package/dist/cjs/utils/pivotConstructor.js +15 -10
  112. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  113. package/dist/cjs/utils/pivotProcessing.js +13 -3
  114. package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
  115. package/dist/cjs/utils/queryConstructor.js +30 -16
  116. package/dist/cjs/utils/report.d.ts +10 -5
  117. package/dist/cjs/utils/report.d.ts.map +1 -1
  118. package/dist/cjs/utils/report.js +55 -7
  119. package/dist/cjs/utils/reportBuilder.d.ts.map +1 -1
  120. package/dist/cjs/utils/reportBuilder.js +5 -2
  121. package/dist/cjs/utils/schema.d.ts +5 -2
  122. package/dist/cjs/utils/schema.d.ts.map +1 -1
  123. package/dist/cjs/utils/schema.js +14 -2
  124. package/dist/cjs/utils/tableProcessing.d.ts +17 -10
  125. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  126. package/dist/cjs/utils/tableProcessing.js +99 -17
  127. package/dist/esm/Chart.d.ts.map +1 -1
  128. package/dist/esm/Chart.js +13 -1
  129. package/dist/esm/ChartBuilder.d.ts +3 -2
  130. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  131. package/dist/esm/ChartBuilder.js +114 -20
  132. package/dist/esm/ChartEditor.d.ts.map +1 -1
  133. package/dist/esm/ChartEditor.js +3 -1
  134. package/dist/esm/Context.d.ts +6 -2
  135. package/dist/esm/Context.d.ts.map +1 -1
  136. package/dist/esm/Context.js +159 -32
  137. package/dist/esm/Dashboard.d.ts.map +1 -1
  138. package/dist/esm/Dashboard.js +100 -20
  139. package/dist/esm/QuillProvider.d.ts +38 -1
  140. package/dist/esm/QuillProvider.d.ts.map +1 -1
  141. package/dist/esm/QuillProvider.js +2 -2
  142. package/dist/esm/ReportBuilder.d.ts +7 -2
  143. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  144. package/dist/esm/ReportBuilder.js +107 -1271
  145. package/dist/esm/SQLEditor.d.ts +9 -2
  146. package/dist/esm/SQLEditor.d.ts.map +1 -1
  147. package/dist/esm/SQLEditor.js +68 -11
  148. package/dist/esm/Table.d.ts.map +1 -1
  149. package/dist/esm/Table.js +13 -1
  150. package/dist/esm/components/Chart/InternalChart.d.ts.map +1 -1
  151. package/dist/esm/components/Chart/InternalChart.js +25 -2
  152. package/dist/esm/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  153. package/dist/esm/components/Dashboard/DashboardTemplate.js +3 -2
  154. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  155. package/dist/esm/components/Dashboard/DataLoader.js +74 -3
  156. package/dist/esm/components/Dashboard/util.d.ts +2 -1
  157. package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
  158. package/dist/esm/components/Dashboard/util.js +12 -1
  159. package/dist/esm/components/QuillTable.d.ts +2 -1
  160. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  161. package/dist/esm/components/QuillTable.js +2 -2
  162. package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts +2 -1
  163. package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
  164. package/dist/esm/components/ReportBuilder/AddColumnModal.js +29 -4
  165. package/dist/esm/components/ReportBuilder/ColumnComponent.d.ts +49 -0
  166. package/dist/esm/components/ReportBuilder/ColumnComponent.d.ts.map +1 -0
  167. package/dist/esm/components/ReportBuilder/ColumnComponent.js +39 -0
  168. package/dist/esm/components/ReportBuilder/FilterComponent.d.ts +65 -0
  169. package/dist/esm/components/ReportBuilder/FilterComponent.d.ts.map +1 -0
  170. package/dist/esm/components/ReportBuilder/FilterComponent.js +44 -0
  171. package/dist/esm/components/ReportBuilder/LimitComponent.d.ts +42 -0
  172. package/dist/esm/components/ReportBuilder/LimitComponent.d.ts.map +1 -0
  173. package/dist/esm/components/ReportBuilder/LimitComponent.js +46 -0
  174. package/dist/esm/components/ReportBuilder/PivotComponent.d.ts +66 -0
  175. package/dist/esm/components/ReportBuilder/PivotComponent.d.ts.map +1 -0
  176. package/dist/esm/components/ReportBuilder/PivotComponent.js +40 -0
  177. package/dist/esm/components/ReportBuilder/SaveReport.d.ts +162 -0
  178. package/dist/esm/components/ReportBuilder/SaveReport.d.ts.map +1 -0
  179. package/dist/esm/components/ReportBuilder/SaveReport.js +31 -0
  180. package/dist/esm/components/ReportBuilder/SortComponent.d.ts +42 -0
  181. package/dist/esm/components/ReportBuilder/SortComponent.d.ts.map +1 -0
  182. package/dist/esm/components/ReportBuilder/SortComponent.js +46 -0
  183. package/dist/esm/components/ReportBuilder/TableComponent.d.ts +28 -0
  184. package/dist/esm/components/ReportBuilder/TableComponent.d.ts.map +1 -0
  185. package/dist/esm/components/ReportBuilder/TableComponent.js +20 -0
  186. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  187. package/dist/esm/components/ReportBuilder/ui.js +4 -2
  188. package/dist/esm/components/UiComponents.d.ts +5 -2
  189. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  190. package/dist/esm/components/UiComponents.js +7 -5
  191. package/dist/esm/hooks/useAskQuill.d.ts.map +1 -1
  192. package/dist/esm/hooks/useAskQuill.js +39 -1
  193. package/dist/esm/hooks/useDashboard.d.ts +1 -1
  194. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  195. package/dist/esm/hooks/useDashboard.js +63 -7
  196. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  197. package/dist/esm/hooks/useExport.js +6 -3
  198. package/dist/esm/hooks/useLongLoading.d.ts +13 -0
  199. package/dist/esm/hooks/useLongLoading.d.ts.map +1 -0
  200. package/dist/esm/hooks/useLongLoading.js +64 -0
  201. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  202. package/dist/esm/hooks/useQuill.js +26 -2
  203. package/dist/esm/hooks/useReportBuilder.d.ts +178 -0
  204. package/dist/esm/hooks/useReportBuilder.d.ts.map +1 -0
  205. package/dist/esm/hooks/useReportBuilder.js +1490 -0
  206. package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
  207. package/dist/esm/hooks/useVirtualTables.js +28 -3
  208. package/dist/esm/index.d.ts +11 -0
  209. package/dist/esm/index.d.ts.map +1 -1
  210. package/dist/esm/index.js +8 -0
  211. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts +14 -1
  212. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  213. package/dist/esm/internals/ReportBuilder/PivotForm.js +87 -4
  214. package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  215. package/dist/esm/internals/ReportBuilder/PivotList.js +3 -3
  216. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +18 -2
  217. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  218. package/dist/esm/internals/ReportBuilder/PivotModal.js +440 -149
  219. package/dist/esm/models/Filter.d.ts +1 -1
  220. package/dist/esm/models/Filter.d.ts.map +1 -1
  221. package/dist/esm/models/Filter.js +3 -3
  222. package/dist/esm/utils/astFilterProcessing.d.ts.map +1 -1
  223. package/dist/esm/utils/astFilterProcessing.js +25 -4
  224. package/dist/esm/utils/astProcessing.d.ts +4 -2
  225. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  226. package/dist/esm/utils/astProcessing.js +25 -2
  227. package/dist/esm/utils/client.d.ts +2 -1
  228. package/dist/esm/utils/client.d.ts.map +1 -1
  229. package/dist/esm/utils/client.js +12 -1
  230. package/dist/esm/utils/dashboard.d.ts +3 -1
  231. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  232. package/dist/esm/utils/dashboard.js +44 -3
  233. package/dist/esm/utils/filterProcessing.d.ts +2 -1
  234. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  235. package/dist/esm/utils/filterProcessing.js +12 -1
  236. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  237. package/dist/esm/utils/pivotConstructor.js +15 -10
  238. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  239. package/dist/esm/utils/pivotProcessing.js +13 -3
  240. package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
  241. package/dist/esm/utils/queryConstructor.js +30 -16
  242. package/dist/esm/utils/report.d.ts +10 -5
  243. package/dist/esm/utils/report.d.ts.map +1 -1
  244. package/dist/esm/utils/report.js +55 -7
  245. package/dist/esm/utils/reportBuilder.d.ts.map +1 -1
  246. package/dist/esm/utils/reportBuilder.js +5 -2
  247. package/dist/esm/utils/schema.d.ts +5 -2
  248. package/dist/esm/utils/schema.d.ts.map +1 -1
  249. package/dist/esm/utils/schema.js +14 -2
  250. package/dist/esm/utils/tableProcessing.d.ts +17 -10
  251. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  252. package/dist/esm/utils/tableProcessing.js +99 -17
  253. package/package.json +1 -1
@@ -68,7 +68,7 @@ export declare const useDashboard: (dashboardName: string) => {
68
68
  sections: Record<string, QuillReport[]> | null;
69
69
  filters: DashboardFilter[];
70
70
  applyFilters: (filters: Array<{
71
- id: string;
71
+ label: string;
72
72
  value: string | string[] | {
73
73
  startDate?: Date;
74
74
  endDate?: Date;
@@ -1 +1 @@
1
- {"version":3,"file":"useDashboard.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDashboard.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,EAGL,uBAAuB,EAGvB,MAAM,EACN,cAAc,EAGd,eAAe,EAGhB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAMtD,eAAO,MAAM,oBAAoB,kBAChB,MAAM,GAAG,IAAI,kBACZ,cAAc,EAAE;;;;2CA0Mc,MAAM;qCAtK1B,MAAM,4CAEf;QACb,MAAM,EAAE,WAAW,GAAG;YAAE,EAAE,EAAE,MAAM,CAAA;SAAE,CAAC;QACrC,MAAM,EAAE,QAAQ,GAAG,QAAQ,CAAC;KAC7B,oBACiB;QAChB,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,cAAc,CAAC,EAAE,OAAO,CAAC;KAC1B;oCAmFa;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,EAAE,CAAA;KAAE,EAAE;CAwF3E,CAAC;AAEF,eAAO,MAAM,mBAAmB,mBAAoB,MAAM;;;;yBAK5B,OAAO,CAAC,mBAAmB,CAAC;sBAiB/B,mBAAmB;CAoB7C,CAAC;AAEF,eAAO,MAAM,aAAa;;;;CAqBzB,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;uEAsCrB;QACD,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,eAAe,EAAE,MAAM,EAAE,CAAC;QAC1B,UAAU,CAAC,EAAE,uBAAuB,CAAC;KACtC;4BAqDO,MAAM,gEAOT;QACD,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,UAAU,CAAC,EAAE,uBAAuB,CAAC;QACrC,aAAa,CAAC,EAAE,cAAc,EAAE,CAAC;QACjC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;KACvB;4BAyOkC,MAAM;CAwB5C,CAAC;AAGF,eAAO,MAAM,YAAY,kBACR,MAAM,KAEpB;IACD,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,GAAG,IAAI,CAAC;IAC/C,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,YAAY,EAAE,CACZ,OAAO,EAAE,KAAK,CACV;QACE,EAAE,EAAE,MAAM,CAAC;QACX,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG;YAAE,SAAS,CAAC,EAAE,IAAI,CAAC;YAAC,OAAO,CAAC,EAAE,IAAI,CAAA;SAAE,CAAC;KACjE,GACD,MAAM,CACT,KACE,IAAI,CAAC;CAyPX,CAAC;AAGF,eAAO,MAAM,kBAAkB,aACnB,MAAM,WACP;IACP,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B,KACA;IACD,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAC1C,YAAY,EAAE,MAAM,IAAI,CAAC;CA4I1B,CAAC"}
1
+ {"version":3,"file":"useDashboard.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDashboard.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AACpE,OAAO,EAGL,uBAAuB,EAGvB,MAAM,EACN,cAAc,EAGd,eAAe,EAGhB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAMtD,eAAO,MAAM,oBAAoB,kBAChB,MAAM,GAAG,IAAI,kBACZ,cAAc,EAAE;;;;2CAoNc,MAAM;qCAjL1B,MAAM,4CAEf;QACb,MAAM,EAAE,WAAW,GAAG;YAAE,EAAE,EAAE,MAAM,CAAA;SAAE,CAAC;QACrC,MAAM,EAAE,QAAQ,GAAG,QAAQ,CAAC;KAC7B,oBACiB;QAChB,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,cAAc,CAAC,EAAE,OAAO,CAAC;KAC1B;oCAmFa;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,EAAE,CAAA;KAAE,EAAE;CAmG3E,CAAC;AAEF,eAAO,MAAM,mBAAmB,mBAAoB,MAAM;;;;yBAK5B,OAAO,CAAC,mBAAmB,CAAC;sBAiB/B,mBAAmB;CAoB7C,CAAC;AAEF,eAAO,MAAM,aAAa;;;;CAqBzB,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;;;;;;;;;;uEAuCrB;QACD,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,eAAe,EAAE,MAAM,EAAE,CAAC;QAC1B,UAAU,CAAC,EAAE,uBAAuB,CAAC;KACtC;4BA2EO,MAAM,gEAOT;QACD,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,uBAAuB,EAAE,CAAC;QACnC,UAAU,CAAC,EAAE,uBAAuB,CAAC;QACrC,aAAa,CAAC,EAAE,cAAc,EAAE,CAAC;QACjC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;KACvB;4BAiQkC,MAAM;CAwB5C,CAAC;AAGF,eAAO,MAAM,YAAY,kBACR,MAAM,KAEpB;IACD,SAAS,EAAE,OAAO,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,EAAE,CAAC,GAAG,IAAI,CAAC;IAC/C,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,YAAY,EAAE,CACZ,OAAO,EAAE,KAAK,CACV;QACE,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG;YAAE,SAAS,CAAC,EAAE,IAAI,CAAC;YAAC,OAAO,CAAC,EAAE,IAAI,CAAA;SAAE,CAAC;KACjE,GACD,MAAM,CACT,KACE,IAAI,CAAC;CA2PX,CAAC;AAGF,eAAO,MAAM,kBAAkB,aACnB,MAAM,WACP;IACP,cAAc,CAAC,EAAE,MAAM,EAAE,CAAC;CAC3B,KACA;IACD,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAC3B,OAAO,EAAE,OAAO,CAAC;IACjB,YAAY,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,IAAI,CAAC;IAC1C,YAAY,EAAE,MAAM,IAAI,CAAC;CA+I1B,CAAC"}
@@ -17,13 +17,12 @@ const useDashboardInternal = (dashboardName, customFilters) => {
17
17
  // const [error, setError] = useState<any>(null);
18
18
  const [client, isClientLoading] = (0, react_1.useContext)(Context_1.ClientContext);
19
19
  const { quillFetchWithToken } = (0, react_1.useContext)(Context_1.FetchContext);
20
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
20
21
  const loading = (0, react_1.useMemo)(() => {
21
22
  return (!dashboardName ||
22
23
  isClientLoading ||
23
24
  isDashboardsLoading ||
24
- dashboardConfig[dashboardName]?.loading ||
25
- (dashboardConfig[dashboardName] &&
26
- !dashboardConfig[dashboardName]?.config.sections));
25
+ dashboardConfig[dashboardName]?.loading);
27
26
  }, [isClientLoading, dashboardConfig, dashboardName, isDashboardsLoading]);
28
27
  const populatedDashboardFilters = (0, react_1.useMemo)(() => {
29
28
  return dashboardName && dashboardFilters[dashboardName] !== undefined
@@ -143,6 +142,17 @@ const useDashboardInternal = (dashboardName, customFilters) => {
143
142
  }
144
143
  catch (e) {
145
144
  console.error(e);
145
+ eventTracking?.logError?.({
146
+ type: 'bug', // TODO: determine type
147
+ severity: 'high',
148
+ message: 'Error setting section order',
149
+ errorMessage: e.message,
150
+ errorStack: e.stack,
151
+ errorData: {
152
+ caller: 'useDashboard',
153
+ function: 'setSectionOrder',
154
+ },
155
+ });
146
156
  }
147
157
  }
148
158
  };
@@ -234,6 +244,7 @@ const useDashboards = () => {
234
244
  const { reportFiltersDispatch } = (0, react_1.useContext)(Context_1.ReportFiltersContext);
235
245
  const [client, isLoading] = (0, react_1.useContext)(Context_1.ClientContext);
236
246
  const { quillFetchWithToken } = (0, react_1.useContext)(Context_1.FetchContext);
247
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
237
248
  const dashboards = (0, react_1.useMemo)(() => {
238
249
  return Object.values(dashboardConfig)
239
250
  .map((dashboard) => {
@@ -283,6 +294,15 @@ const useDashboards = () => {
283
294
  task: 'edit-dashboard',
284
295
  metadata: body,
285
296
  });
297
+ eventTracking?.logEvent?.('create-dashboard', {
298
+ dashboardName: name,
299
+ });
300
+ if (filters.length > 0 || dateFilter) {
301
+ eventTracking?.logEvent?.('update-dashboard-filters', {
302
+ dashboardName: name,
303
+ numFilters: filters.length + (dateFilter ? 1 : 0),
304
+ });
305
+ }
286
306
  dashboardConfigDispatch({
287
307
  type: 'UPDATE_DASHBOARD',
288
308
  id: name,
@@ -297,6 +317,17 @@ const useDashboards = () => {
297
317
  }
298
318
  catch (e) {
299
319
  console.error(e);
320
+ eventTracking?.logError?.({
321
+ type: 'bug', // TODO: determine type
322
+ severity: 'high',
323
+ message: 'Error creating dashboard',
324
+ errorMessage: e.message,
325
+ errorStack: e.stack,
326
+ errorData: {
327
+ caller: 'useDashboards',
328
+ function: 'createDashboard',
329
+ },
330
+ });
300
331
  }
301
332
  };
302
333
  const updateDashboard = async (name, { newName, filters, dateFilter, customFilters, tenantKeys, }) => {
@@ -330,6 +361,16 @@ const useDashboards = () => {
330
361
  task: 'edit-dashboard',
331
362
  metadata: body,
332
363
  });
364
+ eventTracking?.logEvent?.('update-dashboard', {
365
+ dashboardName: updated.data.dashboard.name,
366
+ dashboardId: updated.data.dashboard.dashboardId,
367
+ });
368
+ if (filters.length > 0 || dateFilter) {
369
+ eventTracking?.logEvent?.('update-dashboard-filters', {
370
+ dashboardName: name,
371
+ numFilters: filters.length + (dateFilter ? 1 : 0),
372
+ });
373
+ }
333
374
  dashboardConfigDispatch({
334
375
  type: 'UPDATE_DASHBOARD',
335
376
  id: updated.data.dashboard.name,
@@ -481,6 +522,17 @@ const useDashboards = () => {
481
522
  }
482
523
  catch (e) {
483
524
  console.error(e);
525
+ eventTracking?.logError?.({
526
+ type: 'bug', // TODO: determine type
527
+ severity: 'high',
528
+ message: 'Error updating dashboard',
529
+ errorMessage: e.message,
530
+ errorStack: e.stack,
531
+ errorData: {
532
+ caller: 'useDashboards',
533
+ function: 'updateDashboard',
534
+ },
535
+ });
484
536
  }
485
537
  };
486
538
  const deleteDashboard = async (name) => {
@@ -520,6 +572,7 @@ const useDashboard = (dashboardName) => {
520
572
  const { tenants, flags } = (0, react_1.useContext)(Context_1.TenantContext);
521
573
  const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
522
574
  const { customReportFilters } = (0, react_1.useContext)(Context_1.ReportFiltersContext);
575
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
523
576
  const customFiltersRef = (0, react_1.useRef)(customReportFilters);
524
577
  // Keep ref updated with latest filters
525
578
  (0, react_1.useEffect)(() => {
@@ -557,7 +610,7 @@ const useDashboard = (dashboardName) => {
557
610
  }, [fetchedInitialReports, data, dashboardFilters]);
558
611
  const applyDashboardFilters = (filtersToUpdate) => {
559
612
  const newFilters = (dashboardFilters ?? []).map((f) => {
560
- const update = filtersToUpdate.find((u) => u.id === f.label);
613
+ const update = filtersToUpdate.find((u) => u.label === f.label);
561
614
  if (!update)
562
615
  return f;
563
616
  if (f.filterType === Filter_1.InternalDashboardFilterType.String) {
@@ -638,7 +691,7 @@ const useDashboard = (dashboardName) => {
638
691
  return f && typeof f === 'object' && 'filterType' in f && !('id' in f);
639
692
  };
640
693
  const isDashboardFilter = (f) => {
641
- return f && typeof f === 'object' && 'id' in f;
694
+ return f && typeof f === 'object' && 'label' in f;
642
695
  };
643
696
  const applyFilters = (filters) => {
644
697
  const dashboardFilters = filters.filter(isDashboardFilter);
@@ -681,6 +734,7 @@ const useDashboard = (dashboardName) => {
681
734
  .concat(customFilters)
682
735
  .concat(customReportFiltersArray),
683
736
  getToken,
737
+ eventTracking,
684
738
  });
685
739
  if (error) {
686
740
  console.error(error);
@@ -714,6 +768,7 @@ const useDashboardReport = (reportId, config) => {
714
768
  const { tenants, flags } = (0, react_1.useContext)(Context_1.TenantContext);
715
769
  const [client] = (0, react_1.useContext)(Context_1.ClientContext);
716
770
  const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
771
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
717
772
  const { customReportFiltersDispatch } = (0, react_1.useContext)(Context_1.ReportFiltersContext);
718
773
  const { dashboardCustomFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
719
774
  const { data: dashboardData, dashboardFilters: dashboardFiltersInternal, reload: reloadDashboard, } = (0, exports.useDashboardInternal)(reports[reportId]?.dashboardName ?? null);
@@ -731,7 +786,7 @@ const useDashboardReport = (reportId, config) => {
731
786
  if (!reports[reportId])
732
787
  return null;
733
788
  const dashboardName = reports[reportId].dashboardName;
734
- return (0, report_1.convertInternalReportToReport)((0, merge_1.mergeComparisonRange)(reports[reportId]), Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter), 'useDashboardReport');
789
+ return (0, report_1.convertInternalReportToReport)((0, merge_1.mergeComparisonRange)(reports[reportId]), Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter), eventTracking, 'useDashboardReport');
735
790
  }, [reports, reportId, dashboardFilters]);
736
791
  const setReportFilters = (filters) => {
737
792
  updateReport(filters);
@@ -762,6 +817,7 @@ const useDashboardReport = (reportId, config) => {
762
817
  flags,
763
818
  filters: requestFilters,
764
819
  getToken,
820
+ eventTracking,
765
821
  });
766
822
  if (error) {
767
823
  console.error(error);
@@ -1 +1 @@
1
- {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAaA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAkE/C,UAAU,eAAe;IACvB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,eAAO,MAAM,SAAS,cACT,MAAM,mEAMd;IACD,uBAAuB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,GAAG,CAAC,OAAO,CAAC;IAChE,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA;IACD,WAAW,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,YAAY,EAAE,OAAO,CAAC;CA4RvB,CAAC;AAEF,UAAU,aAAa;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
1
+ {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAcA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAqE/C,UAAU,eAAe;IACvB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,eAAO,MAAM,SAAS,cACT,MAAM,mEAMd;IACD,uBAAuB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,GAAG,CAAC,OAAO,CAAC;IAChE,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA;IACD,WAAW,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,CAAC,eAAe,CAAC,EAAE,eAAe,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAClE,YAAY,EAAE,OAAO,CAAC;CA+RvB,CAAC;AAEF,UAAU,aAAa;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
@@ -16,7 +16,7 @@ const report_1 = require("../utils/report");
16
16
  const jspdf_1 = __importDefault(require("jspdf"));
17
17
  const valueFormatter_1 = require("../utils/valueFormatter");
18
18
  const useDashboard_1 = require("./useDashboard");
19
- async function getExportData(client, dashboardFilters, reportId, getToken, tenants, flags, customFields) {
19
+ async function getExportData(client, dashboardFilters, reportId, getToken, eventTracking, tenants, flags, customFields) {
20
20
  const minimalFilters = Object.values(dashboardFilters).length
21
21
  ? Object.values(dashboardFilters).map((filter) => {
22
22
  const newFilter = { ...filter };
@@ -51,6 +51,7 @@ async function getExportData(client, dashboardFilters, reportId, getToken, tenan
51
51
  customFields,
52
52
  getToken,
53
53
  tenants,
54
+ eventTracking,
54
55
  });
55
56
  if (cleanedReport.chartType === 'table' && cleanedReport.pivot) {
56
57
  cleanedReport.columns = cleanedReport.yAxisFields;
@@ -68,6 +69,7 @@ sectionField, } = {}) => {
68
69
  const [schemaData] = (0, react_1.useContext)(Context_1.SchemaDataContext);
69
70
  const { tenants, flags } = (0, react_1.useContext)(Context_1.TenantContext);
70
71
  const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
72
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
71
73
  const specificDashboardFilters = (0, react_1.useMemo)(() => {
72
74
  if (!reportId) {
73
75
  return [];
@@ -111,7 +113,7 @@ sectionField, } = {}) => {
111
113
  : specificDashboardFilters.concat([
112
114
  ...(customReportFilters[reportId] ?? []),
113
115
  ...(dashboardCustomFilters[dashboardReport?.dashboardName ?? ''] ?? []),
114
- ]), reportId, getToken, tenants, flags, schemaData?.customFields);
116
+ ]), reportId, getToken, eventTracking, tenants, flags, schemaData?.customFields);
115
117
  (0, csv_1.downloadCSV)({
116
118
  rows: resp.pivot && resp.pivotRows && downloadOptions?.usePivotRows
117
119
  ? resp.pivotRows
@@ -141,6 +143,7 @@ sectionField, } = {}) => {
141
143
  ]),
142
144
  customFields: schemaData?.customFields,
143
145
  getToken,
146
+ eventTracking,
144
147
  });
145
148
  if (error) {
146
149
  console.error(error);
@@ -0,0 +1,13 @@
1
+ type LongLoadingMeta = {
2
+ origin: string;
3
+ loadDescription: string;
4
+ expectedLoadTime?: number;
5
+ abnormalLoadTime?: number;
6
+ };
7
+ type LoadingState = {
8
+ isLongLoading: boolean;
9
+ isAbnormalLoading: boolean;
10
+ };
11
+ export declare function useLongLoading(isLoading: boolean, meta: LongLoadingMeta): LoadingState;
12
+ export {};
13
+ //# sourceMappingURL=useLongLoading.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useLongLoading.d.ts","sourceRoot":"","sources":["../../../src/hooks/useLongLoading.tsx"],"names":[],"mappings":"AAGA,KAAK,eAAe,GAAG;IACrB,MAAM,EAAE,MAAM,CAAC;IACf,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,KAAK,YAAY,GAAG;IAClB,aAAa,EAAE,OAAO,CAAC;IACvB,iBAAiB,EAAE,OAAO,CAAC;CAC5B,CAAC;AAEF,wBAAgB,cAAc,CAC5B,SAAS,EAAE,OAAO,EAClB,IAAI,EAAE,eAAe,GACpB,YAAY,CAoEd"}
@@ -0,0 +1,67 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useLongLoading = useLongLoading;
4
+ const react_1 = require("react");
5
+ const Context_1 = require("../Context");
6
+ function useLongLoading(isLoading, meta) {
7
+ const { origin, expectedLoadTime = 5000, abnormalLoadTime = 15000, loadDescription, } = meta;
8
+ const [isLongLoading, setIsLongLoading] = (0, react_1.useState)(false);
9
+ const [isAbnormalLoading, setIsAbnormalLoading] = (0, react_1.useState)(false);
10
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
11
+ (0, react_1.useEffect)(() => {
12
+ let longTimer = null;
13
+ let abnormalTimer = null;
14
+ if (isLoading) {
15
+ // Set timer for long loading
16
+ longTimer = setTimeout(() => {
17
+ setIsLongLoading(true);
18
+ eventTracking?.logError?.({
19
+ type: 'timeout',
20
+ severity: 'medium',
21
+ message: `${origin} loading is taking longer than expected`,
22
+ errorData: {
23
+ loadDescription,
24
+ expectedLoadTime,
25
+ currentTime: Date.now(),
26
+ },
27
+ });
28
+ // Set timer for abnormal loading
29
+ abnormalTimer = setTimeout(() => {
30
+ setIsAbnormalLoading(true);
31
+ eventTracking?.logError?.({
32
+ type: 'timeout',
33
+ severity: 'high',
34
+ message: `${origin} loading is taking abnormally long`,
35
+ errorData: {
36
+ loadDescription,
37
+ expectedLoadTime,
38
+ abnormalLoadTime,
39
+ currentTime: Date.now(),
40
+ },
41
+ });
42
+ }, abnormalLoadTime - expectedLoadTime);
43
+ }, expectedLoadTime);
44
+ }
45
+ else {
46
+ setIsLongLoading(false);
47
+ setIsAbnormalLoading(false);
48
+ }
49
+ return () => {
50
+ if (longTimer)
51
+ clearTimeout(longTimer);
52
+ if (abnormalTimer)
53
+ clearTimeout(abnormalTimer);
54
+ };
55
+ }, [
56
+ isLoading,
57
+ origin,
58
+ expectedLoadTime,
59
+ abnormalLoadTime,
60
+ loadDescription,
61
+ eventTracking,
62
+ ]);
63
+ return {
64
+ isLongLoading,
65
+ isAbnormalLoading,
66
+ };
67
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,WAAW,EAIZ,MAAM,yBAAyB,CAAC;AAKjC,MAAM,WAAW,KAAK;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,QAAQ,cACR,MAAM,eACJ;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,KAC3D;IACD,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,SAAS,EACL,CAAC,CAAC,QAAQ,EAAE,WAAW,KAAK,MAAM,GAAG,SAAS,CAAC,GAC/C,CAAC,MAAM,SAAS,CAAC,CAAC;IACtB,YAAY,EAAE,MAAM,IAAI,CAAC;CAsO1B,CAAC"}
1
+ {"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,WAAW,EAIZ,MAAM,yBAAyB,CAAC;AAKjC,MAAM,WAAW,KAAK;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,QAAQ,cACR,MAAM,eACJ;IAAE,WAAW,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,CAAA;CAAE,KAC3D;IACD,IAAI,EAAE,WAAW,GAAG,IAAI,CAAC;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,SAAS,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,SAAS,EACL,CAAC,CAAC,QAAQ,EAAE,WAAW,KAAK,MAAM,GAAG,SAAS,CAAC,GAC/C,CAAC,MAAM,SAAS,CAAC,CAAC;IACtB,YAAY,EAAE,MAAM,IAAI,CAAC;CA+P1B,CAAC"}
@@ -26,12 +26,13 @@ const useQuill = (reportId, pagination) => {
26
26
  const [schemaData] = (0, react_1.useContext)(Context_1.SchemaDataContext);
27
27
  const [client, isClientLoading] = (0, react_1.useContext)(Context_1.ClientContext);
28
28
  const { tenants } = (0, react_1.useContext)(Context_1.TenantContext);
29
+ const { eventTracking } = (0, react_1.useContext)(Context_1.EventTrackingContext);
29
30
  const [loading, setLoading] = (0, react_1.useState)(true);
30
31
  const [error, setError] = (0, react_1.useState)(undefined);
31
32
  const [previousPage, setPreviousPage] = (0, react_1.useState)(0);
32
33
  const processedReport = (0, react_1.useMemo)(() => {
33
34
  return reportId && allReportsById[reportId]
34
- ? (0, report_1.convertInternalReportToReport)((0, merge_1.mergeComparisonRange)(allReportsById[reportId]), specificReportFilters ?? [], 'useQuill')
35
+ ? (0, report_1.convertInternalReportToReport)((0, merge_1.mergeComparisonRange)(allReportsById[reportId]), specificReportFilters ?? [], eventTracking, 'useQuill')
35
36
  : undefined;
36
37
  }, [reportId, reportId && allReportsById[reportId], specificReportFilters]);
37
38
  const [additionalProcessing, setAdditionProcessing] = (0, react_1.useState)(pagination
@@ -98,6 +99,7 @@ const useQuill = (reportId, pagination) => {
98
99
  filters: reportFilters[reportId],
99
100
  customFields: schemaData.customFields,
100
101
  getToken,
102
+ eventTracking,
101
103
  });
102
104
  if (paginatedRows.error) {
103
105
  throw new Error('Error fetching chart');
@@ -117,6 +119,17 @@ const useQuill = (reportId, pagination) => {
117
119
  }
118
120
  catch (e) {
119
121
  console.log(e);
122
+ eventTracking?.logError?.({
123
+ type: 'bug', // TODO: determine type
124
+ severity: 'high',
125
+ message: 'Error fetching report',
126
+ errorMessage: e.message,
127
+ errorStack: e.stack,
128
+ errorData: {
129
+ caller: 'useQuill',
130
+ function: 'updateTableRows',
131
+ },
132
+ });
120
133
  }
121
134
  finally {
122
135
  setTimeout(() => {
@@ -159,6 +172,17 @@ const useQuill = (reportId, pagination) => {
159
172
  }
160
173
  catch (error) {
161
174
  setError(error.message ?? 'Error fetching report');
175
+ eventTracking?.logError?.({
176
+ type: 'bug', // TODO: determine type
177
+ severity: 'high',
178
+ message: 'Error fetching report',
179
+ errorMessage: error.message,
180
+ errorStack: error.stack,
181
+ errorData: {
182
+ caller: 'useQuill',
183
+ function: 'fetchReportHelper',
184
+ },
185
+ });
162
186
  }
163
187
  finally {
164
188
  setLoading(false);
@@ -0,0 +1,178 @@
1
+ import { Column, ColumnInternal } from '../models/Columns';
2
+ import { AggregationType, Pivot, PivotData } from '../models/Pivot';
3
+ import { QuillReportInternal } from '../models/Report';
4
+ import { Table, UniqueValuesByColumn, UniqueValuesByTable } from '../models/Tables';
5
+ import { ReportBuilderColumn, ReportBuilderLimit, ReportBuilderSort, ReportBuilderState, ReportBuilderTable } from '../models/ReportBuilder';
6
+ import { FilterTreeNode } from '../utils/astFilterProcessing';
7
+ import { Filter, InternalFilter } from '../models/Filter';
8
+ import { ForeignKeyMap } from '../components/ReportBuilder/schema';
9
+ export type ReportBuilder = {
10
+ columns: ReportBuilderColumn[];
11
+ tables: ReportBuilderTable[];
12
+ sort: ReportBuilderSort[];
13
+ limit: ReportBuilderLimit | null;
14
+ filterStack: FilterTreeNode[];
15
+ state: ReportBuilderState;
16
+ activeQuery: string;
17
+ tempReport: QuillReportInternal;
18
+ stateStack: ReportBuilderState[];
19
+ poppedStateStack: ReportBuilderState[];
20
+ openPopover: string | null;
21
+ setOpenPopover: React.Dispatch<React.SetStateAction<string | null>>;
22
+ errorMessage: string;
23
+ unresolvedReportMessage: string;
24
+ loading: boolean;
25
+ tableLoading: boolean;
26
+ askAILoading: boolean;
27
+ rowCountIsLoading: boolean;
28
+ unfilteredUniqueValuesIsLoading: boolean;
29
+ filteredUniqueValuesIsLoading: boolean;
30
+ mssqlSortWarning: string | undefined;
31
+ reportColumnsToStateColumns: ColumnInternal[];
32
+ reportRows: any[];
33
+ formattedRows: any[];
34
+ numberOfRows: number;
35
+ unfilteredUniqueValues: UniqueValuesByTable;
36
+ filteredUniqueValues: UniqueValuesByTable | null;
37
+ columnUniqueValues: UniqueValuesByColumn;
38
+ rowsPerPage: number;
39
+ rowsPerRequest: number;
40
+ pivot: Pivot | null;
41
+ pivotData: PivotData | null;
42
+ pivotRowField: string | undefined;
43
+ pivotColumnField: string | undefined;
44
+ pivotAggregations: Partial<{
45
+ valueField: string;
46
+ valueField2?: string;
47
+ aggregationType: AggregationType;
48
+ }>[];
49
+ pivotLimit: number | undefined;
50
+ pivotSort: {
51
+ sortField: string;
52
+ sortDirection: 'ASC' | 'DESC';
53
+ } | undefined;
54
+ pivotHint: string;
55
+ pivotError: string;
56
+ createdPivots: Pivot[];
57
+ recommendedPivots: Pivot[];
58
+ pivotPopUpTitle: string;
59
+ showPivotPopover: boolean;
60
+ isEditingPivot: boolean;
61
+ selectedPivotIndex: number;
62
+ pivotRecommendationsEnabledState: boolean | undefined;
63
+ setCreatedPivots: React.Dispatch<React.SetStateAction<Pivot[]>>;
64
+ setRecommendedPivots: React.Dispatch<React.SetStateAction<Pivot[]>>;
65
+ setPivotPopUpTitle: React.Dispatch<React.SetStateAction<string>>;
66
+ setShowPivotPopover: React.Dispatch<React.SetStateAction<boolean>>;
67
+ setIsEditingPivot: React.Dispatch<React.SetStateAction<boolean>>;
68
+ setSelectedPivotIndex: React.Dispatch<React.SetStateAction<number>>;
69
+ setPivotRowField: React.Dispatch<React.SetStateAction<string | undefined>>;
70
+ setPivotColumnField: React.Dispatch<React.SetStateAction<string | undefined>>;
71
+ setPivotAggregations: React.Dispatch<React.SetStateAction<Partial<{
72
+ valueField: string;
73
+ valueField2?: string;
74
+ aggregationType: AggregationType;
75
+ }>[]>>;
76
+ setPivotLimit: React.Dispatch<React.SetStateAction<number | undefined>>;
77
+ setPivotSort: React.Dispatch<React.SetStateAction<{
78
+ sortField: string;
79
+ sortDirection: 'ASC' | 'DESC';
80
+ } | undefined>>;
81
+ setPivotError: React.Dispatch<React.SetStateAction<string>>;
82
+ handlePivotChange: (newPivot: Pivot | null, fetchData?: boolean, updateStateStack?: boolean) => void;
83
+ updatePivot: (changeField: string | Partial<{
84
+ valueField: string;
85
+ valueField2: string;
86
+ aggregationType: AggregationType;
87
+ }>[] | number | {
88
+ sortField: string;
89
+ sortDirection: 'ASC' | 'DESC';
90
+ } | undefined, fieldKey: 'rowField' | 'columnField' | 'aggregations' | 'rowLimit' | 'sort') => Promise<void>;
91
+ filteredSchema: Table[];
92
+ foreignKeyMap: ForeignKeyMap;
93
+ schemaData: any;
94
+ client: any;
95
+ getToken: () => Promise<string>;
96
+ reportId?: string;
97
+ initialTableName?: string;
98
+ destinationDashboard: string;
99
+ aiPrompt: string;
100
+ setAiPrompt: React.Dispatch<React.SetStateAction<string>>;
101
+ fetchAstFromPromptHelper: (overridePrompt?: string) => Promise<void>;
102
+ clearAllState: (resetStateStack?: boolean) => void;
103
+ handleMultiStateChange: ({ state, fetchData, updateStateStack, report, skipPivotColumnFetch, }: {
104
+ state: Partial<ReportBuilderState>;
105
+ fetchData?: boolean;
106
+ updateStateStack?: boolean;
107
+ report?: QuillReportInternal;
108
+ skipPivotColumnFetch?: boolean;
109
+ }) => void;
110
+ handleTablesChange: (newTables: ReportBuilderTable[], updateStateStack?: boolean) => void;
111
+ handleColumnsChange: (newColumns: ReportBuilderColumn[], fetchData?: boolean, updateStateStack?: boolean, bypassConfirmation?: boolean) => void;
112
+ handleFilterInsertion: (newFilter: InternalFilter) => void;
113
+ handleFilterStackChange: (newFilterStack: FilterTreeNode[], fetchData?: boolean, updateStateStack?: boolean) => void;
114
+ handleUndo: () => void;
115
+ handleRedo: () => void;
116
+ onSortChange: (newSort: {
117
+ field: string;
118
+ direction: string;
119
+ }, isPivotSort: boolean, isDelete?: boolean) => void;
120
+ onLimitChange: (limit: number | null, isPivotLimit: boolean) => void;
121
+ handleSortChange: (newSort: ReportBuilderSort[], fetchData?: boolean, updateStateStack?: boolean) => void;
122
+ handleLimitChange: (newLimit: ReportBuilderLimit | null, fetchData?: boolean, updateStateStack?: boolean) => void;
123
+ onPageChange: (page: number) => void;
124
+ onSaveQuery: () => Promise<void>;
125
+ onSaveReport: () => Promise<void>;
126
+ };
127
+ export declare const useReportBuilderInternal: ({ reportId, initialTableName, destinationDashboard, pivotRecommendationsEnabled, onSaveChanges, rowsPerPage, rowsPerRequest, }: {
128
+ reportId?: string;
129
+ initialTableName?: string;
130
+ destinationDashboard: string;
131
+ pivotRecommendationsEnabled?: boolean;
132
+ onSaveChanges?: () => void;
133
+ rowsPerPage?: number;
134
+ rowsPerRequest?: number;
135
+ }) => ReportBuilder;
136
+ interface UseReportBuilderConfig {
137
+ rowsPerPage?: number;
138
+ rowsPerRequest?: number;
139
+ initialTableName?: string;
140
+ pivotRecommendationsEnabled?: boolean;
141
+ onSaveChanges?: () => void;
142
+ }
143
+ interface UseReportBuilder {
144
+ reportBuilder: ReportBuilder;
145
+ state: {
146
+ schema: Record<string, ColumnInternal[]>;
147
+ columns: ReportBuilderColumn[];
148
+ filters: Filter[];
149
+ pivot: Pivot | null;
150
+ sort: ReportBuilderSort[];
151
+ limit: ReportBuilderLimit | null;
152
+ reportBuilderLoading: boolean;
153
+ tableColumns: Column[];
154
+ tableLoading: boolean;
155
+ tableRows: any[];
156
+ tableRowsCount: number;
157
+ errorMessage: string;
158
+ };
159
+ actions: {
160
+ setColumns: (newColumns: {
161
+ table: string;
162
+ field: string;
163
+ }[]) => void;
164
+ setFilters: (filters: Filter[]) => void;
165
+ setPivot: (newPivot: Pivot | null) => void;
166
+ setSort: (sort: ReportBuilderSort[]) => void;
167
+ setLimit: (limit: ReportBuilderLimit | null) => void;
168
+ onPageChange: (page: number) => void;
169
+ applyAIPrompt: (prompt: string) => Promise<void>;
170
+ };
171
+ }
172
+ export declare const useReportBuilder: ({ reportId, ownerDashboard, config, }: {
173
+ ownerDashboard: string;
174
+ reportId?: string;
175
+ config?: UseReportBuilderConfig;
176
+ }) => UseReportBuilder;
177
+ export {};
178
+ //# sourceMappingURL=useReportBuilder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useReportBuilder.d.ts","sourceRoot":"","sources":["../../../src/hooks/useReportBuilder.tsx"],"names":[],"mappings":"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"}