@quillsql/react 2.12.52 → 2.13.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 (263) hide show
  1. package/dist/cjs/Chart.d.ts.map +1 -1
  2. package/dist/cjs/Chart.js +5 -3
  3. package/dist/cjs/ChartBuilder.d.ts +10 -3
  4. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  5. package/dist/cjs/ChartBuilder.js +62 -26
  6. package/dist/cjs/ChartEditor.d.ts +3 -1
  7. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  8. package/dist/cjs/ChartEditor.js +74 -16
  9. package/dist/cjs/Context.d.ts +17 -6
  10. package/dist/cjs/Context.d.ts.map +1 -1
  11. package/dist/cjs/Context.js +138 -73
  12. package/dist/cjs/Dashboard.d.ts +8 -4
  13. package/dist/cjs/Dashboard.d.ts.map +1 -1
  14. package/dist/cjs/Dashboard.js +146 -367
  15. package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  16. package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +20 -14
  17. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +1 -0
  18. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  19. package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -1
  20. package/dist/cjs/QuillProvider.js +1 -1
  21. package/dist/cjs/ReportBuilder.d.ts +8 -12
  22. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  23. package/dist/cjs/ReportBuilder.js +163 -83
  24. package/dist/cjs/SQLEditor.d.ts +8 -1
  25. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  26. package/dist/cjs/SQLEditor.js +81 -28
  27. package/dist/cjs/Table.d.ts.map +1 -1
  28. package/dist/cjs/Table.js +6 -3
  29. package/dist/cjs/assets/AdjustmentsIcon.d.ts +5 -0
  30. package/dist/cjs/assets/AdjustmentsIcon.d.ts.map +1 -0
  31. package/dist/cjs/assets/AdjustmentsIcon.js +5 -0
  32. package/dist/cjs/assets/ArrowDownHeadIcon.d.ts.map +1 -1
  33. package/dist/cjs/components/Chart/ChartError.js +2 -2
  34. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +4 -3
  35. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  36. package/dist/cjs/components/Dashboard/DashboardFilter.js +12 -12
  37. package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts +2 -2
  38. package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  39. package/dist/cjs/components/Dashboard/DataLoader.d.ts +11 -5
  40. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  41. package/dist/cjs/components/Dashboard/DataLoader.js +91 -32
  42. package/dist/cjs/components/Dashboard/TableComponent.d.ts +2 -1
  43. package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
  44. package/dist/cjs/components/Dashboard/TableComponent.js +10 -3
  45. package/dist/cjs/components/Dashboard/util.d.ts +2 -2
  46. package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
  47. package/dist/cjs/components/Dashboard/util.js +2 -2
  48. package/dist/cjs/components/QuillMultiSelect.d.ts.map +1 -1
  49. package/dist/cjs/components/QuillMultiSelect.js +18 -13
  50. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  51. package/dist/cjs/components/QuillMultiSelectWithCombo.js +67 -45
  52. package/dist/cjs/components/QuillSelect.d.ts +1 -1
  53. package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
  54. package/dist/cjs/components/QuillSelect.js +29 -7
  55. package/dist/cjs/components/QuillSelectWithCombo.d.ts +1 -1
  56. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  57. package/dist/cjs/components/QuillSelectWithCombo.js +47 -26
  58. package/dist/cjs/components/QuillTable.d.ts +3 -2
  59. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  60. package/dist/cjs/components/QuillTable.js +32 -19
  61. package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts +2 -1
  62. package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  63. package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +2 -2
  64. package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts +2 -1
  65. package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  66. package/dist/cjs/components/ReportBuilder/AddSortPopover.js +2 -2
  67. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts +2 -1
  68. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts.map +1 -1
  69. package/dist/cjs/components/ReportBuilder/FilterModal.js +17 -4
  70. package/dist/cjs/components/ReportBuilder/ui.d.ts +13 -8
  71. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  72. package/dist/cjs/components/ReportBuilder/ui.js +15 -24
  73. package/dist/cjs/components/UiComponents.d.ts +17 -9
  74. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  75. package/dist/cjs/components/UiComponents.js +30 -24
  76. package/dist/cjs/hooks/useAstToFilterTree.d.ts +2 -2
  77. package/dist/cjs/hooks/useAstToFilterTree.d.ts.map +1 -1
  78. package/dist/cjs/hooks/useDashboard.d.ts +13 -5
  79. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  80. package/dist/cjs/hooks/useDashboard.js +158 -70
  81. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  82. package/dist/cjs/hooks/useExport.js +9 -3
  83. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  84. package/dist/cjs/hooks/useQuill.js +15 -15
  85. package/dist/cjs/hooks/useVirtualTables.d.ts +12 -3
  86. package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
  87. package/dist/cjs/hooks/useVirtualTables.js +105 -1
  88. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts +3 -1
  89. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  90. package/dist/cjs/internals/ReportBuilder/PivotForm.js +9 -9
  91. package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  92. package/dist/cjs/internals/ReportBuilder/PivotList.js +21 -15
  93. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +3 -2
  94. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  95. package/dist/cjs/internals/ReportBuilder/PivotModal.js +9 -9
  96. package/dist/cjs/models/Client.d.ts +16 -2
  97. package/dist/cjs/models/Client.d.ts.map +1 -1
  98. package/dist/cjs/models/Dashboard.d.ts +1 -1
  99. package/dist/cjs/models/Dashboard.d.ts.map +1 -1
  100. package/dist/cjs/models/Filter.d.ts +4 -3
  101. package/dist/cjs/models/Filter.d.ts.map +1 -1
  102. package/dist/cjs/models/Filter.js +38 -1
  103. package/dist/cjs/utils/astProcessing.d.ts +3 -3
  104. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  105. package/dist/cjs/utils/client.d.ts.map +1 -1
  106. package/dist/cjs/utils/client.js +2 -7
  107. package/dist/cjs/utils/dashboard.d.ts +5 -5
  108. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  109. package/dist/cjs/utils/dashboard.js +90 -9
  110. package/dist/cjs/utils/dataFetcher.d.ts +4 -4
  111. package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
  112. package/dist/cjs/utils/dataFetcher.js +1 -1
  113. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  114. package/dist/cjs/utils/filterProcessing.js +2 -8
  115. package/dist/cjs/utils/paginationProcessing.js +1 -1
  116. package/dist/cjs/utils/pivotConstructor.d.ts +2 -2
  117. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  118. package/dist/cjs/utils/pivotConstructor.js +1 -1
  119. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  120. package/dist/cjs/utils/pivotProcessing.js +6 -2
  121. package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
  122. package/dist/cjs/utils/queryConstructor.js +12 -9
  123. package/dist/cjs/utils/report.d.ts +6 -5
  124. package/dist/cjs/utils/report.d.ts.map +1 -1
  125. package/dist/cjs/utils/report.js +71 -25
  126. package/dist/cjs/utils/schema.d.ts +3 -3
  127. package/dist/cjs/utils/schema.d.ts.map +1 -1
  128. package/dist/cjs/utils/schema.js +39 -35
  129. package/dist/cjs/utils/tableProcessing.d.ts +18 -11
  130. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  131. package/dist/cjs/utils/tableProcessing.js +44 -23
  132. package/dist/esm/Chart.d.ts.map +1 -1
  133. package/dist/esm/Chart.js +6 -4
  134. package/dist/esm/ChartBuilder.d.ts +10 -3
  135. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  136. package/dist/esm/ChartBuilder.js +59 -26
  137. package/dist/esm/ChartEditor.d.ts +3 -1
  138. package/dist/esm/ChartEditor.d.ts.map +1 -1
  139. package/dist/esm/ChartEditor.js +76 -18
  140. package/dist/esm/Context.d.ts +17 -6
  141. package/dist/esm/Context.d.ts.map +1 -1
  142. package/dist/esm/Context.js +139 -74
  143. package/dist/esm/Dashboard.d.ts +8 -4
  144. package/dist/esm/Dashboard.d.ts.map +1 -1
  145. package/dist/esm/Dashboard.js +146 -367
  146. package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  147. package/dist/esm/DateRangePicker/QuillDateRangePicker.js +21 -15
  148. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +1 -0
  149. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  150. package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -1
  151. package/dist/esm/QuillProvider.js +1 -1
  152. package/dist/esm/ReportBuilder.d.ts +8 -12
  153. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  154. package/dist/esm/ReportBuilder.js +167 -87
  155. package/dist/esm/SQLEditor.d.ts +8 -1
  156. package/dist/esm/SQLEditor.d.ts.map +1 -1
  157. package/dist/esm/SQLEditor.js +84 -31
  158. package/dist/esm/Table.d.ts.map +1 -1
  159. package/dist/esm/Table.js +7 -4
  160. package/dist/esm/assets/AdjustmentsIcon.d.ts +5 -0
  161. package/dist/esm/assets/AdjustmentsIcon.d.ts.map +1 -0
  162. package/dist/esm/assets/AdjustmentsIcon.js +3 -0
  163. package/dist/esm/assets/ArrowDownHeadIcon.d.ts.map +1 -1
  164. package/dist/esm/components/Chart/ChartError.js +2 -2
  165. package/dist/esm/components/Dashboard/DashboardFilter.d.ts +4 -3
  166. package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  167. package/dist/esm/components/Dashboard/DashboardFilter.js +12 -12
  168. package/dist/esm/components/Dashboard/DashboardTemplate.d.ts +2 -2
  169. package/dist/esm/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  170. package/dist/esm/components/Dashboard/DataLoader.d.ts +11 -5
  171. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  172. package/dist/esm/components/Dashboard/DataLoader.js +94 -35
  173. package/dist/esm/components/Dashboard/TableComponent.d.ts +2 -1
  174. package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
  175. package/dist/esm/components/Dashboard/TableComponent.js +10 -3
  176. package/dist/esm/components/Dashboard/util.d.ts +2 -2
  177. package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
  178. package/dist/esm/components/Dashboard/util.js +2 -2
  179. package/dist/esm/components/QuillMultiSelect.d.ts.map +1 -1
  180. package/dist/esm/components/QuillMultiSelect.js +19 -14
  181. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  182. package/dist/esm/components/QuillMultiSelectWithCombo.js +68 -46
  183. package/dist/esm/components/QuillSelect.d.ts +1 -1
  184. package/dist/esm/components/QuillSelect.d.ts.map +1 -1
  185. package/dist/esm/components/QuillSelect.js +30 -8
  186. package/dist/esm/components/QuillSelectWithCombo.d.ts +1 -1
  187. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  188. package/dist/esm/components/QuillSelectWithCombo.js +48 -27
  189. package/dist/esm/components/QuillTable.d.ts +3 -2
  190. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  191. package/dist/esm/components/QuillTable.js +32 -19
  192. package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts +2 -1
  193. package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  194. package/dist/esm/components/ReportBuilder/AddLimitPopover.js +2 -2
  195. package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts +2 -1
  196. package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  197. package/dist/esm/components/ReportBuilder/AddSortPopover.js +2 -2
  198. package/dist/esm/components/ReportBuilder/FilterModal.d.ts +2 -1
  199. package/dist/esm/components/ReportBuilder/FilterModal.d.ts.map +1 -1
  200. package/dist/esm/components/ReportBuilder/FilterModal.js +17 -4
  201. package/dist/esm/components/ReportBuilder/ui.d.ts +13 -8
  202. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  203. package/dist/esm/components/ReportBuilder/ui.js +14 -19
  204. package/dist/esm/components/UiComponents.d.ts +17 -9
  205. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  206. package/dist/esm/components/UiComponents.js +30 -24
  207. package/dist/esm/hooks/useAstToFilterTree.d.ts +2 -2
  208. package/dist/esm/hooks/useAstToFilterTree.d.ts.map +1 -1
  209. package/dist/esm/hooks/useDashboard.d.ts +13 -5
  210. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  211. package/dist/esm/hooks/useDashboard.js +158 -73
  212. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  213. package/dist/esm/hooks/useExport.js +10 -4
  214. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  215. package/dist/esm/hooks/useQuill.js +17 -17
  216. package/dist/esm/hooks/useVirtualTables.d.ts +12 -3
  217. package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
  218. package/dist/esm/hooks/useVirtualTables.js +106 -2
  219. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts +3 -1
  220. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  221. package/dist/esm/internals/ReportBuilder/PivotForm.js +9 -9
  222. package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  223. package/dist/esm/internals/ReportBuilder/PivotList.js +21 -15
  224. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +3 -2
  225. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  226. package/dist/esm/internals/ReportBuilder/PivotModal.js +9 -9
  227. package/dist/esm/models/Client.d.ts +16 -2
  228. package/dist/esm/models/Client.d.ts.map +1 -1
  229. package/dist/esm/models/Dashboard.d.ts +1 -1
  230. package/dist/esm/models/Dashboard.d.ts.map +1 -1
  231. package/dist/esm/models/Filter.d.ts +4 -3
  232. package/dist/esm/models/Filter.d.ts.map +1 -1
  233. package/dist/esm/models/Filter.js +36 -0
  234. package/dist/esm/utils/astProcessing.d.ts +3 -3
  235. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  236. package/dist/esm/utils/client.d.ts.map +1 -1
  237. package/dist/esm/utils/client.js +2 -7
  238. package/dist/esm/utils/dashboard.d.ts +5 -5
  239. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  240. package/dist/esm/utils/dashboard.js +90 -9
  241. package/dist/esm/utils/dataFetcher.d.ts +4 -4
  242. package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
  243. package/dist/esm/utils/dataFetcher.js +1 -1
  244. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  245. package/dist/esm/utils/filterProcessing.js +2 -8
  246. package/dist/esm/utils/paginationProcessing.js +1 -1
  247. package/dist/esm/utils/pivotConstructor.d.ts +2 -2
  248. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  249. package/dist/esm/utils/pivotConstructor.js +1 -1
  250. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  251. package/dist/esm/utils/pivotProcessing.js +6 -2
  252. package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
  253. package/dist/esm/utils/queryConstructor.js +12 -9
  254. package/dist/esm/utils/report.d.ts +6 -5
  255. package/dist/esm/utils/report.d.ts.map +1 -1
  256. package/dist/esm/utils/report.js +70 -25
  257. package/dist/esm/utils/schema.d.ts +3 -3
  258. package/dist/esm/utils/schema.d.ts.map +1 -1
  259. package/dist/esm/utils/schema.js +39 -35
  260. package/dist/esm/utils/tableProcessing.d.ts +18 -11
  261. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  262. package/dist/esm/utils/tableProcessing.js +41 -20
  263. package/package.json +1 -1
@@ -1,14 +1,22 @@
1
- import { QuillReportInternal } from '../models/Report';
2
- import { DashboardStringFilter } from '../models/Filter';
1
+ import { QuillReport, QuillReportInternal } from '../models/Report';
2
+ import { DashboardFilter } from '../models/Filter';
3
3
  export declare const useReports: () => {
4
4
  reloadFilteredReports: (predicate: (report: QuillReportInternal) => boolean) => void;
5
5
  };
6
6
  export declare const useDashboard: (dashboardName: string) => {
7
7
  data: import("../models/Dashboard").DashboardConfig | null | undefined;
8
- dashboardFilters: DashboardStringFilter[] | null;
8
+ dashboardFilters: DashboardFilter[] | null;
9
9
  isLoading: boolean | undefined;
10
- isDashboardFiltersLoading: boolean;
10
+ isDashboardFilterLoading: (filterName: string) => boolean | undefined;
11
11
  error: any;
12
- reload: (overrideDashboardName?: string, fetchFromServer?: boolean) => Promise<void>;
12
+ reload: (overrideDashboardName?: string, fetchFromServer?: boolean, reportAction?: {
13
+ report: QuillReport | {
14
+ id: string;
15
+ };
16
+ action: 'upsert' | 'delete';
17
+ }, overrideFilters?: {
18
+ filters: DashboardFilter[];
19
+ editedFilterLabel: string;
20
+ }) => Promise<void>;
13
21
  };
14
22
  //# sourceMappingURL=useDashboard.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useDashboard.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDashboard.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAKvD,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAEzD,eAAO,MAAM,UAAU;gDAYC,mBAAmB,KAAK,OAAO;CAYtD,CAAC;AAEF,eAAO,MAAM,YAAY,kBAAmB,MAAM;;;;;;qCAyBtB,MAAM;CA6EjC,CAAC"}
1
+ {"version":3,"file":"useDashboard.d.ts","sourceRoot":"","sources":["../../../src/hooks/useDashboard.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAOpE,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAC;AAGnD,eAAO,MAAM,UAAU;gDAYC,mBAAmB,KAAK,OAAO;CAYtD,CAAC;AAEF,eAAO,MAAM,YAAY,kBAAmB,MAAM;;;;2CAiQF,MAAM;;qCA3O1B,MAAM,4CAEf;QACb,MAAM,EAAE,WAAW,GAAG;YAAE,EAAE,EAAE,MAAM,CAAA;SAAE,CAAC;QACrC,MAAM,EAAE,QAAQ,GAAG,QAAQ,CAAC;KAC7B,oBACiB;QAAE,OAAO,EAAE,eAAe,EAAE,CAAC;QAAC,iBAAiB,EAAE,MAAM,CAAA;KAAE;CAqP9E,CAAC"}
@@ -1,6 +1,8 @@
1
- import { useContext, useEffect, useMemo, useRef, useState } from 'react';
2
- import { ClientContext, DashboardConfigContext, DashboardContext, } from '../Context';
3
- import { getDashboard, getDashboardFilters as getFilters, } from '../utils/dashboard';
1
+ import { useContext, useMemo, useState } from 'react';
2
+ import { ClientContext, DashboardConfigContext, DashboardContext, DashboardFiltersContext, } from '../Context';
3
+ import { getDashboard } from '../utils/dashboard';
4
+ import { COMPARISON_RANGE, PRIMARY_RANGE, } from '../DateRangePicker/dateRangePickerUtils';
5
+ import equal from 'fast-deep-equal';
4
6
  export const useReports = () => {
5
7
  const [dashboard, dispatch] = useContext(DashboardContext);
6
8
  const reloadReport = (id) => {
@@ -23,109 +25,192 @@ export const useReports = () => {
23
25
  };
24
26
  export const useDashboard = (dashboardName) => {
25
27
  const [dashboardConfig, dashboardConfigContext] = useContext(DashboardConfigContext);
26
- // if (dashboardName === undefined || dashboardName === null) {
27
- // throw new Error('useDashboard requires a dashboard name parameter');
28
- // }
28
+ const { dashboardFilters, loadFiltersForDashboard } = useContext(DashboardFiltersContext);
29
+ const [dashboard] = useContext(DashboardContext);
29
30
  const [isLoading, setIsLoading] = useState(true);
30
31
  const [error, setError] = useState(null);
31
32
  const [client, isClientLoading] = useContext(ClientContext);
32
- const [dashboardFilters, setDashboardFilters] = useState(null);
33
- const [dashboardFiltersLoading, setDashboardFiltersLoading] = useState(true);
34
33
  const loading = useMemo(() => isLoading ||
35
34
  isClientLoading ||
36
35
  (dashboardConfig[dashboardName] &&
37
36
  !dashboardConfig[dashboardName]?.sections), [isLoading, isClientLoading, dashboardConfig, dashboardName]);
38
- const handleReload = async (overrideDashboardName, fetchFromServer = false) => {
39
- await Promise.allSettled([
40
- getDashboardFilters(overrideDashboardName ?? dashboardName),
41
- getDashboards(overrideDashboardName ?? dashboardName, fetchFromServer),
37
+ const handleReload = async (overrideDashboardName, fetchFromServer = false, reportAction, overrideFilters) => {
38
+ if (!fetchFromServer && isLoading)
39
+ return;
40
+ if (overrideFilters) {
41
+ // Pull the date filter out of the override filters, process it, and append it to the filters
42
+ const dateFilter = overrideFilters.filters.find((f) => f.filterType === 'date_range');
43
+ loadFiltersForDashboard(dashboardName, [
44
+ ...(dateFilter
45
+ ? [
46
+ {
47
+ ...dateFilter,
48
+ dateField: [
49
+ ...new Map(Object.values(dashboardConfig[overrideDashboardName ?? dashboardName]
50
+ ?.sections ?? {})
51
+ .flat()
52
+ .map((report) => {
53
+ const key = JSON.stringify(report.dateField);
54
+ return [key, report.dateField];
55
+ })).values(),
56
+ ],
57
+ },
58
+ ]
59
+ : []),
60
+ ...(overrideFilters.filters.filter((f) => f.filterType !== 'date_range') ?? []),
61
+ ], overrideFilters.editedFilterLabel);
62
+ return;
63
+ }
64
+ const dashboard = await getDashboards(overrideDashboardName ?? dashboardName, fetchFromServer, reportAction);
65
+ if (!fetchFromServer &&
66
+ Object.keys(dashboardFilters[dashboardName] ?? {}).length)
67
+ return;
68
+ const dateFilter = dashboard?.dateFilter
69
+ ? {
70
+ ...dashboard?.dateFilter,
71
+ startDate: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ?? 'LAST_30_DAYS']?.start,
72
+ endDate: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ?? 'LAST_30_DAYS']?.end,
73
+ filterType: 'date_range',
74
+ dateField: [
75
+ ...new Map(Object.values(dashboard?.sections ?? {})
76
+ .flat()
77
+ .map((report) => {
78
+ const key = JSON.stringify(report.dateField);
79
+ return [key, report.dateField];
80
+ })).values(),
81
+ ],
82
+ preset: dashboard?.dateFilter.primaryRange,
83
+ dashboardName: overrideDashboardName ?? dashboardName,
84
+ comparisonRange: dashboard?.dateFilter.comparison
85
+ ? {
86
+ startDate: dashboard?.dateFilter.comparsionRange?.startDate ??
87
+ COMPARISON_RANGE[dashboard?.dateFilter
88
+ .defaultComparisonRange ??
89
+ 'NO_COMPARISON']({
90
+ start: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
91
+ 'LAST_30_DAYS']?.start,
92
+ end: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
93
+ 'LAST_30_DAYS']?.end,
94
+ })?.start,
95
+ endDate: dashboard?.dateFilter.comparsionRange?.endDate ??
96
+ COMPARISON_RANGE[dashboard?.dateFilter
97
+ .defaultComparisonRange ??
98
+ 'NO_COMPARISON']({
99
+ start: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
100
+ 'LAST_30_DAYS']?.start,
101
+ end: PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
102
+ 'LAST_30_DAYS']?.end,
103
+ })?.end,
104
+ value: dashboard?.dateFilter.comparsionRange?.value ??
105
+ dashboard.dateFilter?.defaultComparisonRange,
106
+ }
107
+ : undefined,
108
+ }
109
+ : undefined;
110
+ // Append dateFilter to the filters unless it's undefined
111
+ loadFiltersForDashboard(dashboardName, [
112
+ ...(dateFilter ? [dateFilter] : []),
113
+ ...(dashboard?.filters ?? []),
42
114
  ]);
43
115
  };
44
- async function getDashboards(dashboardName, fetchFromServer = false) {
45
- if (!fetchFromServer && dashboardConfig) {
116
+ async function getDashboards(dashboardName, fetchFromServer = false, reportAction) {
117
+ const curDashboardConfig = dashboardConfig[dashboardName];
118
+ if (!fetchFromServer && curDashboardConfig?.sections) {
119
+ if (reportAction?.action === 'delete') {
120
+ dashboardConfigContext({
121
+ type: 'UPDATE_DASHBOARD',
122
+ id: dashboardName,
123
+ data: {
124
+ ...curDashboardConfig,
125
+ sections: Object.fromEntries(Object.entries(curDashboardConfig?.sections ?? {}).map(([sectionKey, reports]) => [
126
+ sectionKey,
127
+ reports.filter((report) => report.id !== reportAction.report.id),
128
+ ])),
129
+ },
130
+ });
131
+ }
132
+ else if (reportAction?.action === 'upsert') {
133
+ const containsReport = Object.values(curDashboardConfig?.sections ?? {})
134
+ .flat()
135
+ .some((report) => (report.id ?? report._id) === reportAction?.report.id);
136
+ dashboardConfigContext({
137
+ type: 'UPDATE_DASHBOARD',
138
+ id: dashboardName,
139
+ data: {
140
+ ...curDashboardConfig,
141
+ sections: Object.fromEntries(Object.entries(curDashboardConfig?.sections ?? {}).map(([sectionKey, reports]) => [
142
+ sectionKey,
143
+ containsReport
144
+ ? reports.map((report) => {
145
+ return {
146
+ report,
147
+ ...(reportAction?.report.id === report.id
148
+ ? reportAction?.report
149
+ : dashboard[report.id]),
150
+ _id: report.id,
151
+ id: report.id,
152
+ };
153
+ })
154
+ : [
155
+ ...(reports ?? []),
156
+ {
157
+ report: reportAction?.report,
158
+ ...dashboard[reportAction?.report.id],
159
+ id: reportAction?.report.id,
160
+ _id: reportAction?.report.id,
161
+ },
162
+ ],
163
+ ])),
164
+ },
165
+ });
166
+ }
46
167
  setIsLoading(false);
47
- return;
168
+ return curDashboardConfig;
48
169
  }
49
- const curDashboardConfig = dashboardConfig[dashboardName];
50
170
  if (!fetchFromServer &&
51
171
  curDashboardConfig &&
52
172
  curDashboardConfig.newQueries) {
53
173
  setIsLoading(false);
54
- return;
174
+ return curDashboardConfig;
55
175
  }
56
- setIsLoading(true);
57
- if (!client || !client.publicKey || !client.customerId) {
58
- return;
176
+ if (!client || !client.publicKey || !client.organizationId) {
177
+ return curDashboardConfig;
59
178
  }
60
179
  if (dashboardName === null || dashboardName === undefined)
61
- return;
180
+ return curDashboardConfig;
62
181
  try {
182
+ setIsLoading(true);
63
183
  const resp = await getDashboard(dashboardName, client);
64
- dashboardConfigContext({
65
- type: 'ADD_DASHBOARD',
66
- id: dashboardName,
67
- data: { ...resp },
68
- });
69
- setIsLoading(false);
184
+ // if dashboard has changed
185
+ if (!equal(resp, curDashboardConfig)) {
186
+ dashboardConfigContext({
187
+ type: 'ADD_DASHBOARD',
188
+ id: dashboardName,
189
+ data: { ...resp },
190
+ });
191
+ }
70
192
  setError(null);
193
+ return resp;
71
194
  }
72
195
  catch (error) {
73
- setError(null);
74
- setIsLoading(false);
75
196
  setError(error);
76
197
  console.error('Error fetching data:', error);
77
198
  }
78
- }
79
- async function getDashboardFilters(dashboardName) {
80
- setDashboardFiltersLoading(true);
81
- if (!client || !client.publicKey || !client.customerId) {
82
- return;
83
- }
84
- if (dashboardName === null || dashboardName === undefined)
85
- return;
86
- try {
87
- const resp = await getFilters(dashboardName, client);
88
- setDashboardFilters(resp);
89
- }
90
- catch (error) {
91
- console.error('Error fetching data:', error);
92
- }
93
199
  finally {
94
- setDashboardFiltersLoading(false);
200
+ setIsLoading(false);
95
201
  }
96
202
  }
97
- useEffectAwaitingLoad(() => {
98
- getDashboards(dashboardName, true);
99
- }, [dashboardName, client], isClientLoading);
203
+ function isDashboardFilterLoading(filterName) {
204
+ return dashboardFilters[dashboardName]?.[filterName]?.loading;
205
+ }
100
206
  return {
101
207
  data: loading ? null : dashboardConfig[dashboardName],
102
- dashboardFilters: dashboardFilters,
208
+ dashboardFilters: dashboardFilters[dashboardName] !== undefined
209
+ ? Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter)
210
+ : null,
103
211
  isLoading: loading,
104
- isDashboardFiltersLoading: dashboardFiltersLoading,
212
+ isDashboardFilterLoading,
105
213
  error,
106
214
  reload: handleReload,
107
215
  };
108
216
  };
109
- function useEffectAwaitingLoad(effectCallback, dependencies, isLoading) {
110
- const latestEffectRef = useRef(null);
111
- useEffect(() => {
112
- let isEffectCanceled = false;
113
- const waitForLoading = async () => {
114
- while (isLoading) {
115
- await new Promise((resolve) => setTimeout(resolve, 16)); // Wait for 16ms (roughly one frame at 60fps)
116
- if (isEffectCanceled)
117
- return;
118
- }
119
- };
120
- const effectPromise = waitForLoading().then(() => {
121
- if (!isEffectCanceled) {
122
- effectCallback();
123
- }
124
- });
125
- latestEffectRef.current = effectPromise;
126
- return () => {
127
- isEffectCanceled = true;
128
- latestEffectRef.current = null;
129
- };
130
- }, [...dependencies, isLoading]);
131
- }
@@ -1 +1 @@
1
- {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AA8DA,eAAO,MAAM,SAAS,cAAe,MAAM;;;;CA6C1C,CAAC"}
1
+ {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AA8DA,eAAO,MAAM,SAAS,cAAe,MAAM;;;;CA2D1C,CAAC"}
@@ -1,6 +1,6 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { downloadCSV } from '../utils/csv';
3
- import { useContext, useLayoutEffect, useRef, useState } from 'react';
3
+ import { useContext, useLayoutEffect, useMemo, useRef, useState } from 'react';
4
4
  import { getData } from '../utils/dataFetcher';
5
5
  import { ClientContext, DashboardFiltersContext, ThemeContext, } from '../Context';
6
6
  import ReactDOM from 'react-dom';
@@ -23,7 +23,7 @@ async function getExportData(client, dashboardFilters, reportId) {
23
23
  const hostedBody = {
24
24
  metadata: {
25
25
  dashboardItemId: reportId,
26
- orgId: client.customerId || '*',
26
+ orgId: client.organizationId || '*',
27
27
  clientId: client.publicKey,
28
28
  task: 'item',
29
29
  databaseType: client?.databaseType,
@@ -44,6 +44,12 @@ async function getExportData(client, dashboardFilters, reportId) {
44
44
  }
45
45
  export const useExport = (reportId) => {
46
46
  const { dashboardFilters } = useContext(DashboardFiltersContext);
47
+ const specificDashboardFilters = useMemo(() => {
48
+ //FIXME: Pretty sure this won't work with multiple dashboards
49
+ Object.values(dashboardFilters).map((dashboardFilter) => {
50
+ return dashboardFilter.filter;
51
+ });
52
+ }, [dashboardFilters]);
47
53
  const [theme] = useContext(ThemeContext);
48
54
  const [client] = useContext(ClientContext);
49
55
  const [isLoading, setIsLoading] = useState(false);
@@ -56,7 +62,7 @@ export const useExport = (reportId) => {
56
62
  return;
57
63
  }
58
64
  setIsLoading(true);
59
- const resp = await getExportData(client, dashboardFilters, reportId);
65
+ const resp = await getExportData(client, specificDashboardFilters, reportId);
60
66
  downloadCSV({
61
67
  rows: resp.rows,
62
68
  fields: resp.columns,
@@ -69,7 +75,7 @@ export const useExport = (reportId) => {
69
75
  return;
70
76
  }
71
77
  setIsLoading(true);
72
- const resp = await getExportData(client, dashboardFilters, reportId);
78
+ const resp = await getExportData(client, specificDashboardFilters, reportId);
73
79
  const iframe = document.createElement('iframe');
74
80
  document.body.appendChild(iframe);
75
81
  if (iframe && iframe.contentDocument && theme) {
@@ -1 +1 @@
1
- {"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,WAAW,EAIZ,MAAM,yBAAyB,CAAC;AAEjC,UAAU,MAAM;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,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;UAEtD,WAAW,GAAG,IAAI;aACf,OAAO;WACT,MAAM,GAAG,SAAS;sBACP,MAAM,KAAK,IAAI;qBAChB,MAAM,aAAa,MAAM,KAAK,IAAI;2BAEnC,WAAW,KAAK,MAAM,GAAG,SAAS,WACvC,SAAS;CAyLrB,CAAC;AAEF,eAAO,MAAM,QAAQ,cACR,MAAM;UAEX;QAAE,IAAI,EAAE,GAAG,EAAE,CAAC;QAAC,OAAO,EAAE,MAAM,EAAE,CAAA;KAAE,GAAG,SAAS;WAC7C,MAAM,GAAG,SAAS;CAoD1B,CAAC"}
1
+ {"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAeA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EACL,WAAW,EAIZ,MAAM,yBAAyB,CAAC;AAGjC,UAAU,MAAM;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,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;UAEtD,WAAW,GAAG,IAAI;aACf,OAAO;WACT,MAAM,GAAG,SAAS;sBACP,MAAM,KAAK,IAAI;qBAChB,MAAM,aAAa,MAAM,KAAK,IAAI;2BAEnC,WAAW,KAAK,MAAM,GAAG,SAAS,WACvC,SAAS;CAmLrB,CAAC;AAEF,eAAO,MAAM,QAAQ,cACR,MAAM;UAEX;QAAE,IAAI,EAAE,GAAG,EAAE,CAAC;QAAC,OAAO,EAAE,MAAM,EAAE,CAAA;KAAE,GAAG,SAAS;WAC7C,MAAM,GAAG,SAAS;CAoD1B,CAAC"}
@@ -1,13 +1,21 @@
1
- import { useContext, useEffect, useState } from 'react';
1
+ import { useContext, useEffect, useMemo, useState } from 'react';
2
2
  import { ClientContext, DashboardContext, DashboardFiltersContext, SchemaDataContext, } from '../Context';
3
3
  import { mergeComparisonRange } from '../utils/merge';
4
4
  import { convertInternalReportToReport, fetchReport } from '../utils/report';
5
5
  import { shouldFetchMore } from '../utils/paginationProcessing';
6
- import { fetchTableByReport, } from '../utils/tableProcessing';
6
+ import { fetchResultsByReport, } from '../utils/tableProcessing';
7
7
  import { getPointToPointPercentageChange, getSimplePercentageChange, getSumOfFields, } from '../utils/dataProcessing';
8
8
  export const useQuill = (reportId, pagination) => {
9
9
  const [dashboard, dispatch] = useContext(DashboardContext);
10
10
  const { dashboardFilters } = useContext(DashboardFiltersContext);
11
+ const specificDashboardFilters = useMemo(() => {
12
+ if (!reportId)
13
+ return [];
14
+ const dashboardName = dashboard[reportId]?.dashboardName;
15
+ if (!dashboardName)
16
+ return [];
17
+ return Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter);
18
+ }, [dashboardFilters, reportId, dashboard]);
11
19
  const [schemaData] = useContext(SchemaDataContext);
12
20
  const [client] = useContext(ClientContext);
13
21
  const [data, setData] = useState(null);
@@ -73,13 +81,8 @@ export const useQuill = (reportId, pagination) => {
73
81
  if (!loading && reportId && data) {
74
82
  setLoading(true);
75
83
  try {
76
- const specificDashboardFilter = dashboardFilters.filter((f) => f &&
77
- reportId &&
78
- dashboard[reportId] &&
79
- // @ts-ignore
80
- dashboard[reportId].dashboardName === f.dashboardName);
81
84
  const updatedProcessing = { ...additionalProcessing, ...processing };
82
- const paginatedRows = await fetchTableByReport(reportId, client, updatedProcessing, specificDashboardFilter, schemaData.customFields);
85
+ const paginatedRows = await fetchResultsByReport(reportId, client, updatedProcessing, specificDashboardFilters, schemaData.customFields);
83
86
  if (paginatedRows.error) {
84
87
  throw new Error('Error fetching chart');
85
88
  }
@@ -108,23 +111,18 @@ export const useQuill = (reportId, pagination) => {
108
111
  mergeComparisonRange(dashboard[curReportId]);
109
112
  }
110
113
  // @ts-ignore
111
- setData({ ...dashboard[curReportId] });
114
+ setData(convertInternalReportToReport(dashboard[curReportId]));
112
115
  setLoading(false);
113
116
  return;
114
117
  }
115
- const specificDashboardFilter = dashboardFilters.filter((f) => f &&
116
- reportId &&
117
- dashboard[curReportId] &&
118
- // @ts-ignore
119
- dashboard[curReportId].dashboardName === f.dashboardName);
120
118
  setLoading(true);
121
- const { report, error } = await fetchReport(curReportId, client, useReportTask, specificDashboardFilter, additionalProcessing, undefined, schemaData.customFields);
119
+ const { report, error } = await fetchReport(curReportId, client, useReportTask, specificDashboardFilters, additionalProcessing, undefined, schemaData.customFields);
122
120
  dispatch({
123
121
  type: 'ADD_DASHBOARD_ITEM',
124
122
  id: reportId,
125
123
  data: {
126
124
  ...report,
127
- filtersApplied: specificDashboardFilter,
125
+ filtersApplied: specificDashboardFilters,
128
126
  triggerReload: false,
129
127
  },
130
128
  });
@@ -134,7 +132,9 @@ export const useQuill = (reportId, pagination) => {
134
132
  };
135
133
  useEffect(() => {
136
134
  if (reportId) {
137
- fetchReportHelper(reportId, pagination ? true : false, pagination);
135
+ fetchReportHelper(reportId, pagination ? true : false, {
136
+ page: pagination,
137
+ });
138
138
  }
139
139
  }, [reportId, dashboard]);
140
140
  useEffect(() => {
@@ -1,8 +1,17 @@
1
+ import { Table } from '../models/Tables';
1
2
  export declare const useVirtualTables: () => {
2
- data: import("../models/Tables").Table[];
3
+ data: Table[];
3
4
  isLoading: boolean;
4
- reload: (client: any, caller?: string) => Promise<{
5
- schema: import("../models/Tables").Table[];
5
+ loadingTables: {
6
+ [key: string]: boolean;
7
+ };
8
+ reloadAll: (client: any, caller?: string) => Promise<{
9
+ schema: Table[];
10
+ customFields: any;
11
+ isSchemaLoading: boolean;
12
+ }>;
13
+ refreshSome: (client: any, tables: Table[]) => Promise<{
14
+ schema: Table[];
6
15
  customFields: any;
7
16
  isSchemaLoading: boolean;
8
17
  }>;
@@ -1 +1 @@
1
- {"version":3,"file":"useVirtualTables.d.ts","sourceRoot":"","sources":["../../../src/hooks/useVirtualTables.tsx"],"names":[],"mappings":"AAIA,eAAO,MAAM,gBAAgB;;;qBAGS,GAAG,WAAW,MAAM;;;;;CAqBzD,CAAC"}
1
+ {"version":3,"file":"useVirtualTables.d.ts","sourceRoot":"","sources":["../../../src/hooks/useVirtualTables.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAE,KAAK,EAAE,MAAM,kBAAkB,CAAC;AAEzC,eAAO,MAAM,gBAAgB;;;;;;wBAMS,GAAG,WAAW,MAAM;;;;;0BAiDf,GAAG,UAAU,KAAK,EAAE;;;;;CAqF9D,CAAC"}
@@ -1,25 +1,129 @@
1
- import { useContext } from 'react';
1
+ import { useContext, useState } from 'react';
2
2
  import { SchemaDataContext } from '../Context';
3
3
  import { getSchemaInfoWithCustomFields } from '../utils/schema';
4
4
  export const useVirtualTables = () => {
5
5
  const [schemaData, setSchemaData] = useContext(SchemaDataContext);
6
+ const [loadingTables, setLoadingTables] = useState({});
6
7
  const handleReload = async (client, caller) => {
7
8
  setSchemaData({ ...schemaData, isSchemaLoading: true });
9
+ // For each table in schemData.schema, set loadingTables[table] to true
10
+ setLoadingTables(schemaData.schema.reduce((acc, table) => {
11
+ acc[table._id] = true;
12
+ return acc;
13
+ }, {}));
8
14
  const { schemaData: schema, customFieldsByTable } = await getSchemaInfoWithCustomFields(client, caller);
9
15
  setSchemaData({
10
16
  schema,
11
17
  customFields: customFieldsByTable,
12
18
  isSchemaLoading: false,
13
19
  });
20
+ setLoadingTables({});
14
21
  return {
15
22
  schema,
16
23
  customFields: customFieldsByTable,
17
24
  isSchemaLoading: false,
18
25
  };
19
26
  };
27
+ const handleReloadSome = async (client, tableIds, caller) => {
28
+ const { schemaData: schema, customFieldsByTable } = await getSchemaInfoWithCustomFields(client, caller, tableIds);
29
+ // Only replace the tables that were reloaded
30
+ setSchemaData({
31
+ schema: schemaData.schema.map((table) => {
32
+ if (tableIds.includes(table._id)) {
33
+ return schema.find((newTable) => newTable._id === table._id) || table;
34
+ }
35
+ return table;
36
+ }, {}),
37
+ customFields: customFieldsByTable,
38
+ isSchemaLoading: false,
39
+ });
40
+ return {
41
+ schema,
42
+ customFields: customFieldsByTable,
43
+ isSchemaLoading: false,
44
+ };
45
+ };
46
+ const handleRefreshSome = async (client, tables) => {
47
+ if (!client.clientId)
48
+ return schemaData;
49
+ // For each table in tableIds, set loadingTables[table] to true
50
+ setLoadingTables({
51
+ ...loadingTables,
52
+ ...tables.reduce((acc, table) => {
53
+ acc[table._id] = true;
54
+ return acc;
55
+ }, {}),
56
+ });
57
+ try {
58
+ const promises = tables.map(async (table) => {
59
+ return await fetch(`${client.queryEndpoint}?update-view`, {
60
+ method: 'POST',
61
+ headers: {
62
+ ...client.queryHeaders,
63
+ 'Content-Type': 'application/json',
64
+ },
65
+ credentials: client.withCredentials ? 'include' : 'omit',
66
+ body: JSON.stringify({
67
+ metadata: {
68
+ preQueries: [table.viewQuery.replace(/;/, '')],
69
+ clientId: client.clientId,
70
+ publicKey: client.publicKey,
71
+ task: 'update-view',
72
+ name: table.name,
73
+ id: table._id,
74
+ runQueryConfig: { getColumns: true },
75
+ },
76
+ }),
77
+ })
78
+ .then((res) => res.json())
79
+ .then(async (res) => {
80
+ if (res.status === 'success') {
81
+ return await fetch(client.queryEndpoint, {
82
+ method: 'POST',
83
+ headers: {
84
+ 'Content-Type': 'application/json',
85
+ ...client.queryHeaders,
86
+ },
87
+ body: JSON.stringify({
88
+ metadata: {
89
+ preQueries: [table.viewQuery.replace(/;/, '')],
90
+ name: table.name,
91
+ customFieldInfo: table.customFieldInfo,
92
+ task: 'view',
93
+ id: table._id,
94
+ clientId: client.clientId,
95
+ runQueryConfig: { getColumns: true },
96
+ databaseType: client.databaseType,
97
+ useNewNodeSql: true,
98
+ },
99
+ }),
100
+ credentials: client.withCredentials ? 'include' : 'omit', // If withCredentials is true, set to 'include'. Otherwise, set to 'omit'.
101
+ });
102
+ }
103
+ });
104
+ });
105
+ await Promise.all(promises);
106
+ return await handleReloadSome(client, tables.map((table) => table._id));
107
+ }
108
+ catch (e) {
109
+ console.error(e);
110
+ throw e;
111
+ }
112
+ finally {
113
+ setLoadingTables((prevLoadingTables) => {
114
+ const newLoadingTables = { ...prevLoadingTables };
115
+ tables.forEach((table) => {
116
+ delete newLoadingTables[table._id];
117
+ });
118
+ return newLoadingTables;
119
+ });
120
+ }
121
+ };
20
122
  return {
21
123
  data: schemaData.schema,
22
124
  isLoading: schemaData.isSchemaLoading,
23
- reload: handleReload,
125
+ loadingTables,
126
+ reloadAll: handleReload,
127
+ refreshSome: handleRefreshSome,
24
128
  };
25
129
  };
@@ -11,6 +11,7 @@ interface PivotFormProps {
11
11
  setPivotAggregation: any;
12
12
  columns: ColumnInternal[];
13
13
  uniqueValues?: any;
14
+ uniqueValuesIsLoading?: boolean;
14
15
  onDelete?: any;
15
16
  SecondaryButtonComponent?: (props: {
16
17
  onClick: () => void;
@@ -22,7 +23,8 @@ interface PivotFormProps {
22
23
  PivotColumnContainer?: (props: {
23
24
  children: ReactNode;
24
25
  }) => JSX.Element;
26
+ isLoading?: boolean;
25
27
  }
26
- export default function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, columns, uniqueValues, onDelete, SecondaryButtonComponent, SelectComponent, PivotColumnContainer, }: PivotFormProps): import("react/jsx-runtime").JSX.Element;
28
+ export default function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, columns, uniqueValues, uniqueValuesIsLoading, onDelete, SecondaryButtonComponent, SelectComponent, PivotColumnContainer, isLoading, }: PivotFormProps): import("react/jsx-runtime").JSX.Element;
27
29
  export {};
28
30
  //# sourceMappingURL=PivotForm.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"PivotForm.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotForm.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAuB,MAAM,OAAO,CAAC;AAG9D,OAAO,EAAU,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAM9D,UAAU,cAAc;IACtB,aAAa,EAAE,GAAG,CAAC;IACnB,gBAAgB,EAAE,GAAG,CAAC;IACtB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,eAAe,EAAE,GAAG,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,wBAAwB,CAAC,EAAE,CAAC,KAAK,EAAE;QACjC,OAAO,EAAE,MAAM,IAAI,CAAC;QACpB,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,IAAI,CAAC,EAAE,SAAS,CAAC;KAClB,KAAK,GAAG,CAAC,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,oBAAoB,CAAC,EAAE,CAAC,KAAK,EAAE;QAAE,QAAQ,EAAE,SAAS,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;CACxE;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAChC,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,eAAe,EACf,kBAAkB,EAClB,gBAAgB,EAChB,mBAAmB,EACnB,OAAO,EACP,YAAY,EACZ,QAAQ,EACR,wBAA+C,EAC/C,eAA+C,EAC/C,oBAAgD,GACjD,EAAE,cAAc,2CA4GhB"}
1
+ {"version":3,"file":"PivotForm.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotForm.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAuB,MAAM,OAAO,CAAC;AAG9D,OAAO,EAAU,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAM9D,UAAU,cAAc;IACtB,aAAa,EAAE,GAAG,CAAC;IACnB,gBAAgB,EAAE,GAAG,CAAC;IACtB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,eAAe,EAAE,GAAG,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,wBAAwB,CAAC,EAAE,CAAC,KAAK,EAAE;QACjC,OAAO,EAAE,MAAM,IAAI,CAAC;QACpB,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,IAAI,CAAC,EAAE,SAAS,CAAC;KAClB,KAAK,GAAG,CAAC,OAAO,CAAC;IAClB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,oBAAoB,CAAC,EAAE,CAAC,KAAK,EAAE;QAAE,QAAQ,EAAE,SAAS,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IACvE,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAChC,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,eAAe,EACf,kBAAkB,EAClB,gBAAgB,EAChB,mBAAmB,EACnB,OAAO,EACP,YAAY,EACZ,qBAAqB,EACrB,QAAQ,EACR,wBAA+C,EAC/C,eAA+C,EAC/C,oBAAgD,EAChD,SAAS,GACV,EAAE,cAAc,2CAuHhB"}