@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,9 +1,14 @@
1
1
  "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
2
5
  Object.defineProperty(exports, "__esModule", { value: true });
3
6
  exports.useDashboard = exports.useReports = void 0;
4
7
  const react_1 = require("react");
5
8
  const Context_1 = require("../Context");
6
9
  const dashboard_1 = require("../utils/dashboard");
10
+ const dateRangePickerUtils_1 = require("../DateRangePicker/dateRangePickerUtils");
11
+ const fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
7
12
  const useReports = () => {
8
13
  const [dashboard, dispatch] = (0, react_1.useContext)(Context_1.DashboardContext);
9
14
  const reloadReport = (id) => {
@@ -27,110 +32,193 @@ const useReports = () => {
27
32
  exports.useReports = useReports;
28
33
  const useDashboard = (dashboardName) => {
29
34
  const [dashboardConfig, dashboardConfigContext] = (0, react_1.useContext)(Context_1.DashboardConfigContext);
30
- // if (dashboardName === undefined || dashboardName === null) {
31
- // throw new Error('useDashboard requires a dashboard name parameter');
32
- // }
35
+ const { dashboardFilters, loadFiltersForDashboard } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
36
+ const [dashboard] = (0, react_1.useContext)(Context_1.DashboardContext);
33
37
  const [isLoading, setIsLoading] = (0, react_1.useState)(true);
34
38
  const [error, setError] = (0, react_1.useState)(null);
35
39
  const [client, isClientLoading] = (0, react_1.useContext)(Context_1.ClientContext);
36
- const [dashboardFilters, setDashboardFilters] = (0, react_1.useState)(null);
37
- const [dashboardFiltersLoading, setDashboardFiltersLoading] = (0, react_1.useState)(true);
38
40
  const loading = (0, react_1.useMemo)(() => isLoading ||
39
41
  isClientLoading ||
40
42
  (dashboardConfig[dashboardName] &&
41
43
  !dashboardConfig[dashboardName]?.sections), [isLoading, isClientLoading, dashboardConfig, dashboardName]);
42
- const handleReload = async (overrideDashboardName, fetchFromServer = false) => {
43
- await Promise.allSettled([
44
- getDashboardFilters(overrideDashboardName ?? dashboardName),
45
- getDashboards(overrideDashboardName ?? dashboardName, fetchFromServer),
44
+ const handleReload = async (overrideDashboardName, fetchFromServer = false, reportAction, overrideFilters) => {
45
+ if (!fetchFromServer && isLoading)
46
+ return;
47
+ if (overrideFilters) {
48
+ // Pull the date filter out of the override filters, process it, and append it to the filters
49
+ const dateFilter = overrideFilters.filters.find((f) => f.filterType === 'date_range');
50
+ loadFiltersForDashboard(dashboardName, [
51
+ ...(dateFilter
52
+ ? [
53
+ {
54
+ ...dateFilter,
55
+ dateField: [
56
+ ...new Map(Object.values(dashboardConfig[overrideDashboardName ?? dashboardName]
57
+ ?.sections ?? {})
58
+ .flat()
59
+ .map((report) => {
60
+ const key = JSON.stringify(report.dateField);
61
+ return [key, report.dateField];
62
+ })).values(),
63
+ ],
64
+ },
65
+ ]
66
+ : []),
67
+ ...(overrideFilters.filters.filter((f) => f.filterType !== 'date_range') ?? []),
68
+ ], overrideFilters.editedFilterLabel);
69
+ return;
70
+ }
71
+ const dashboard = await getDashboards(overrideDashboardName ?? dashboardName, fetchFromServer, reportAction);
72
+ if (!fetchFromServer &&
73
+ Object.keys(dashboardFilters[dashboardName] ?? {}).length)
74
+ return;
75
+ const dateFilter = dashboard?.dateFilter
76
+ ? {
77
+ ...dashboard?.dateFilter,
78
+ startDate: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ?? 'LAST_30_DAYS']?.start,
79
+ endDate: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ?? 'LAST_30_DAYS']?.end,
80
+ filterType: 'date_range',
81
+ dateField: [
82
+ ...new Map(Object.values(dashboard?.sections ?? {})
83
+ .flat()
84
+ .map((report) => {
85
+ const key = JSON.stringify(report.dateField);
86
+ return [key, report.dateField];
87
+ })).values(),
88
+ ],
89
+ preset: dashboard?.dateFilter.primaryRange,
90
+ dashboardName: overrideDashboardName ?? dashboardName,
91
+ comparisonRange: dashboard?.dateFilter.comparison
92
+ ? {
93
+ startDate: dashboard?.dateFilter.comparsionRange?.startDate ??
94
+ dateRangePickerUtils_1.COMPARISON_RANGE[dashboard?.dateFilter
95
+ .defaultComparisonRange ??
96
+ 'NO_COMPARISON']({
97
+ start: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
98
+ 'LAST_30_DAYS']?.start,
99
+ end: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
100
+ 'LAST_30_DAYS']?.end,
101
+ })?.start,
102
+ endDate: dashboard?.dateFilter.comparsionRange?.endDate ??
103
+ dateRangePickerUtils_1.COMPARISON_RANGE[dashboard?.dateFilter
104
+ .defaultComparisonRange ??
105
+ 'NO_COMPARISON']({
106
+ start: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
107
+ 'LAST_30_DAYS']?.start,
108
+ end: dateRangePickerUtils_1.PRIMARY_RANGE[dashboard?.dateFilter.primaryRange?.value ??
109
+ 'LAST_30_DAYS']?.end,
110
+ })?.end,
111
+ value: dashboard?.dateFilter.comparsionRange?.value ??
112
+ dashboard.dateFilter?.defaultComparisonRange,
113
+ }
114
+ : undefined,
115
+ }
116
+ : undefined;
117
+ // Append dateFilter to the filters unless it's undefined
118
+ loadFiltersForDashboard(dashboardName, [
119
+ ...(dateFilter ? [dateFilter] : []),
120
+ ...(dashboard?.filters ?? []),
46
121
  ]);
47
122
  };
48
- async function getDashboards(dashboardName, fetchFromServer = false) {
49
- if (!fetchFromServer && dashboardConfig) {
123
+ async function getDashboards(dashboardName, fetchFromServer = false, reportAction) {
124
+ const curDashboardConfig = dashboardConfig[dashboardName];
125
+ if (!fetchFromServer && curDashboardConfig?.sections) {
126
+ if (reportAction?.action === 'delete') {
127
+ dashboardConfigContext({
128
+ type: 'UPDATE_DASHBOARD',
129
+ id: dashboardName,
130
+ data: {
131
+ ...curDashboardConfig,
132
+ sections: Object.fromEntries(Object.entries(curDashboardConfig?.sections ?? {}).map(([sectionKey, reports]) => [
133
+ sectionKey,
134
+ reports.filter((report) => report.id !== reportAction.report.id),
135
+ ])),
136
+ },
137
+ });
138
+ }
139
+ else if (reportAction?.action === 'upsert') {
140
+ const containsReport = Object.values(curDashboardConfig?.sections ?? {})
141
+ .flat()
142
+ .some((report) => (report.id ?? report._id) === reportAction?.report.id);
143
+ dashboardConfigContext({
144
+ type: 'UPDATE_DASHBOARD',
145
+ id: dashboardName,
146
+ data: {
147
+ ...curDashboardConfig,
148
+ sections: Object.fromEntries(Object.entries(curDashboardConfig?.sections ?? {}).map(([sectionKey, reports]) => [
149
+ sectionKey,
150
+ containsReport
151
+ ? reports.map((report) => {
152
+ return {
153
+ report,
154
+ ...(reportAction?.report.id === report.id
155
+ ? reportAction?.report
156
+ : dashboard[report.id]),
157
+ _id: report.id,
158
+ id: report.id,
159
+ };
160
+ })
161
+ : [
162
+ ...(reports ?? []),
163
+ {
164
+ report: reportAction?.report,
165
+ ...dashboard[reportAction?.report.id],
166
+ id: reportAction?.report.id,
167
+ _id: reportAction?.report.id,
168
+ },
169
+ ],
170
+ ])),
171
+ },
172
+ });
173
+ }
50
174
  setIsLoading(false);
51
- return;
175
+ return curDashboardConfig;
52
176
  }
53
- const curDashboardConfig = dashboardConfig[dashboardName];
54
177
  if (!fetchFromServer &&
55
178
  curDashboardConfig &&
56
179
  curDashboardConfig.newQueries) {
57
180
  setIsLoading(false);
58
- return;
181
+ return curDashboardConfig;
59
182
  }
60
- setIsLoading(true);
61
- if (!client || !client.publicKey || !client.customerId) {
62
- return;
183
+ if (!client || !client.publicKey || !client.organizationId) {
184
+ return curDashboardConfig;
63
185
  }
64
186
  if (dashboardName === null || dashboardName === undefined)
65
- return;
187
+ return curDashboardConfig;
66
188
  try {
189
+ setIsLoading(true);
67
190
  const resp = await (0, dashboard_1.getDashboard)(dashboardName, client);
68
- dashboardConfigContext({
69
- type: 'ADD_DASHBOARD',
70
- id: dashboardName,
71
- data: { ...resp },
72
- });
73
- setIsLoading(false);
191
+ // if dashboard has changed
192
+ if (!(0, fast_deep_equal_1.default)(resp, curDashboardConfig)) {
193
+ dashboardConfigContext({
194
+ type: 'ADD_DASHBOARD',
195
+ id: dashboardName,
196
+ data: { ...resp },
197
+ });
198
+ }
74
199
  setError(null);
200
+ return resp;
75
201
  }
76
202
  catch (error) {
77
- setError(null);
78
- setIsLoading(false);
79
203
  setError(error);
80
204
  console.error('Error fetching data:', error);
81
205
  }
82
- }
83
- async function getDashboardFilters(dashboardName) {
84
- setDashboardFiltersLoading(true);
85
- if (!client || !client.publicKey || !client.customerId) {
86
- return;
87
- }
88
- if (dashboardName === null || dashboardName === undefined)
89
- return;
90
- try {
91
- const resp = await (0, dashboard_1.getDashboardFilters)(dashboardName, client);
92
- setDashboardFilters(resp);
93
- }
94
- catch (error) {
95
- console.error('Error fetching data:', error);
96
- }
97
206
  finally {
98
- setDashboardFiltersLoading(false);
207
+ setIsLoading(false);
99
208
  }
100
209
  }
101
- useEffectAwaitingLoad(() => {
102
- getDashboards(dashboardName, true);
103
- }, [dashboardName, client], isClientLoading);
210
+ function isDashboardFilterLoading(filterName) {
211
+ return dashboardFilters[dashboardName]?.[filterName]?.loading;
212
+ }
104
213
  return {
105
214
  data: loading ? null : dashboardConfig[dashboardName],
106
- dashboardFilters: dashboardFilters,
215
+ dashboardFilters: dashboardFilters[dashboardName] !== undefined
216
+ ? Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter)
217
+ : null,
107
218
  isLoading: loading,
108
- isDashboardFiltersLoading: dashboardFiltersLoading,
219
+ isDashboardFilterLoading,
109
220
  error,
110
221
  reload: handleReload,
111
222
  };
112
223
  };
113
224
  exports.useDashboard = useDashboard;
114
- function useEffectAwaitingLoad(effectCallback, dependencies, isLoading) {
115
- const latestEffectRef = (0, react_1.useRef)(null);
116
- (0, react_1.useEffect)(() => {
117
- let isEffectCanceled = false;
118
- const waitForLoading = async () => {
119
- while (isLoading) {
120
- await new Promise((resolve) => setTimeout(resolve, 16)); // Wait for 16ms (roughly one frame at 60fps)
121
- if (isEffectCanceled)
122
- return;
123
- }
124
- };
125
- const effectPromise = waitForLoading().then(() => {
126
- if (!isEffectCanceled) {
127
- effectCallback();
128
- }
129
- });
130
- latestEffectRef.current = effectPromise;
131
- return () => {
132
- isEffectCanceled = true;
133
- latestEffectRef.current = null;
134
- };
135
- }, [...dependencies, isLoading]);
136
- }
@@ -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"}
@@ -29,7 +29,7 @@ async function getExportData(client, dashboardFilters, reportId) {
29
29
  const hostedBody = {
30
30
  metadata: {
31
31
  dashboardItemId: reportId,
32
- orgId: client.customerId || '*',
32
+ orgId: client.organizationId || '*',
33
33
  clientId: client.publicKey,
34
34
  task: 'item',
35
35
  databaseType: client?.databaseType,
@@ -50,6 +50,12 @@ async function getExportData(client, dashboardFilters, reportId) {
50
50
  }
51
51
  const useExport = (reportId) => {
52
52
  const { dashboardFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
53
+ const specificDashboardFilters = (0, react_1.useMemo)(() => {
54
+ //FIXME: Pretty sure this won't work with multiple dashboards
55
+ Object.values(dashboardFilters).map((dashboardFilter) => {
56
+ return dashboardFilter.filter;
57
+ });
58
+ }, [dashboardFilters]);
53
59
  const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
54
60
  const [client] = (0, react_1.useContext)(Context_1.ClientContext);
55
61
  const [isLoading, setIsLoading] = (0, react_1.useState)(false);
@@ -62,7 +68,7 @@ const useExport = (reportId) => {
62
68
  return;
63
69
  }
64
70
  setIsLoading(true);
65
- const resp = await getExportData(client, dashboardFilters, reportId);
71
+ const resp = await getExportData(client, specificDashboardFilters, reportId);
66
72
  (0, csv_1.downloadCSV)({
67
73
  rows: resp.rows,
68
74
  fields: resp.columns,
@@ -75,7 +81,7 @@ const useExport = (reportId) => {
75
81
  return;
76
82
  }
77
83
  setIsLoading(true);
78
- const resp = await getExportData(client, dashboardFilters, reportId);
84
+ const resp = await getExportData(client, specificDashboardFilters, reportId);
79
85
  const iframe = document.createElement('iframe');
80
86
  document.body.appendChild(iframe);
81
87
  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"}
@@ -11,6 +11,14 @@ const dataProcessing_1 = require("../utils/dataProcessing");
11
11
  const useQuill = (reportId, pagination) => {
12
12
  const [dashboard, dispatch] = (0, react_1.useContext)(Context_1.DashboardContext);
13
13
  const { dashboardFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
14
+ const specificDashboardFilters = (0, react_1.useMemo)(() => {
15
+ if (!reportId)
16
+ return [];
17
+ const dashboardName = dashboard[reportId]?.dashboardName;
18
+ if (!dashboardName)
19
+ return [];
20
+ return Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter);
21
+ }, [dashboardFilters, reportId, dashboard]);
14
22
  const [schemaData] = (0, react_1.useContext)(Context_1.SchemaDataContext);
15
23
  const [client] = (0, react_1.useContext)(Context_1.ClientContext);
16
24
  const [data, setData] = (0, react_1.useState)(null);
@@ -76,13 +84,8 @@ const useQuill = (reportId, pagination) => {
76
84
  if (!loading && reportId && data) {
77
85
  setLoading(true);
78
86
  try {
79
- const specificDashboardFilter = dashboardFilters.filter((f) => f &&
80
- reportId &&
81
- dashboard[reportId] &&
82
- // @ts-ignore
83
- dashboard[reportId].dashboardName === f.dashboardName);
84
87
  const updatedProcessing = { ...additionalProcessing, ...processing };
85
- const paginatedRows = await (0, tableProcessing_1.fetchTableByReport)(reportId, client, updatedProcessing, specificDashboardFilter, schemaData.customFields);
88
+ const paginatedRows = await (0, tableProcessing_1.fetchResultsByReport)(reportId, client, updatedProcessing, specificDashboardFilters, schemaData.customFields);
86
89
  if (paginatedRows.error) {
87
90
  throw new Error('Error fetching chart');
88
91
  }
@@ -111,23 +114,18 @@ const useQuill = (reportId, pagination) => {
111
114
  (0, merge_1.mergeComparisonRange)(dashboard[curReportId]);
112
115
  }
113
116
  // @ts-ignore
114
- setData({ ...dashboard[curReportId] });
117
+ setData((0, report_1.convertInternalReportToReport)(dashboard[curReportId]));
115
118
  setLoading(false);
116
119
  return;
117
120
  }
118
- const specificDashboardFilter = dashboardFilters.filter((f) => f &&
119
- reportId &&
120
- dashboard[curReportId] &&
121
- // @ts-ignore
122
- dashboard[curReportId].dashboardName === f.dashboardName);
123
121
  setLoading(true);
124
- const { report, error } = await (0, report_1.fetchReport)(curReportId, client, useReportTask, specificDashboardFilter, additionalProcessing, undefined, schemaData.customFields);
122
+ const { report, error } = await (0, report_1.fetchReport)(curReportId, client, useReportTask, specificDashboardFilters, additionalProcessing, undefined, schemaData.customFields);
125
123
  dispatch({
126
124
  type: 'ADD_DASHBOARD_ITEM',
127
125
  id: reportId,
128
126
  data: {
129
127
  ...report,
130
- filtersApplied: specificDashboardFilter,
128
+ filtersApplied: specificDashboardFilters,
131
129
  triggerReload: false,
132
130
  },
133
131
  });
@@ -137,7 +135,9 @@ const useQuill = (reportId, pagination) => {
137
135
  };
138
136
  (0, react_1.useEffect)(() => {
139
137
  if (reportId) {
140
- fetchReportHelper(reportId, pagination ? true : false, pagination);
138
+ fetchReportHelper(reportId, pagination ? true : false, {
139
+ page: pagination,
140
+ });
141
141
  }
142
142
  }, [reportId, dashboard]);
143
143
  (0, react_1.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"}
@@ -6,24 +6,128 @@ const Context_1 = require("../Context");
6
6
  const schema_1 = require("../utils/schema");
7
7
  const useVirtualTables = () => {
8
8
  const [schemaData, setSchemaData] = (0, react_1.useContext)(Context_1.SchemaDataContext);
9
+ const [loadingTables, setLoadingTables] = (0, react_1.useState)({});
9
10
  const handleReload = async (client, caller) => {
10
11
  setSchemaData({ ...schemaData, isSchemaLoading: true });
12
+ // For each table in schemData.schema, set loadingTables[table] to true
13
+ setLoadingTables(schemaData.schema.reduce((acc, table) => {
14
+ acc[table._id] = true;
15
+ return acc;
16
+ }, {}));
11
17
  const { schemaData: schema, customFieldsByTable } = await (0, schema_1.getSchemaInfoWithCustomFields)(client, caller);
12
18
  setSchemaData({
13
19
  schema,
14
20
  customFields: customFieldsByTable,
15
21
  isSchemaLoading: false,
16
22
  });
23
+ setLoadingTables({});
17
24
  return {
18
25
  schema,
19
26
  customFields: customFieldsByTable,
20
27
  isSchemaLoading: false,
21
28
  };
22
29
  };
30
+ const handleReloadSome = async (client, tableIds, caller) => {
31
+ const { schemaData: schema, customFieldsByTable } = await (0, schema_1.getSchemaInfoWithCustomFields)(client, caller, tableIds);
32
+ // Only replace the tables that were reloaded
33
+ setSchemaData({
34
+ schema: schemaData.schema.map((table) => {
35
+ if (tableIds.includes(table._id)) {
36
+ return schema.find((newTable) => newTable._id === table._id) || table;
37
+ }
38
+ return table;
39
+ }, {}),
40
+ customFields: customFieldsByTable,
41
+ isSchemaLoading: false,
42
+ });
43
+ return {
44
+ schema,
45
+ customFields: customFieldsByTable,
46
+ isSchemaLoading: false,
47
+ };
48
+ };
49
+ const handleRefreshSome = async (client, tables) => {
50
+ if (!client.clientId)
51
+ return schemaData;
52
+ // For each table in tableIds, set loadingTables[table] to true
53
+ setLoadingTables({
54
+ ...loadingTables,
55
+ ...tables.reduce((acc, table) => {
56
+ acc[table._id] = true;
57
+ return acc;
58
+ }, {}),
59
+ });
60
+ try {
61
+ const promises = tables.map(async (table) => {
62
+ return await fetch(`${client.queryEndpoint}?update-view`, {
63
+ method: 'POST',
64
+ headers: {
65
+ ...client.queryHeaders,
66
+ 'Content-Type': 'application/json',
67
+ },
68
+ credentials: client.withCredentials ? 'include' : 'omit',
69
+ body: JSON.stringify({
70
+ metadata: {
71
+ preQueries: [table.viewQuery.replace(/;/, '')],
72
+ clientId: client.clientId,
73
+ publicKey: client.publicKey,
74
+ task: 'update-view',
75
+ name: table.name,
76
+ id: table._id,
77
+ runQueryConfig: { getColumns: true },
78
+ },
79
+ }),
80
+ })
81
+ .then((res) => res.json())
82
+ .then(async (res) => {
83
+ if (res.status === 'success') {
84
+ return await fetch(client.queryEndpoint, {
85
+ method: 'POST',
86
+ headers: {
87
+ 'Content-Type': 'application/json',
88
+ ...client.queryHeaders,
89
+ },
90
+ body: JSON.stringify({
91
+ metadata: {
92
+ preQueries: [table.viewQuery.replace(/;/, '')],
93
+ name: table.name,
94
+ customFieldInfo: table.customFieldInfo,
95
+ task: 'view',
96
+ id: table._id,
97
+ clientId: client.clientId,
98
+ runQueryConfig: { getColumns: true },
99
+ databaseType: client.databaseType,
100
+ useNewNodeSql: true,
101
+ },
102
+ }),
103
+ credentials: client.withCredentials ? 'include' : 'omit', // If withCredentials is true, set to 'include'. Otherwise, set to 'omit'.
104
+ });
105
+ }
106
+ });
107
+ });
108
+ await Promise.all(promises);
109
+ return await handleReloadSome(client, tables.map((table) => table._id));
110
+ }
111
+ catch (e) {
112
+ console.error(e);
113
+ throw e;
114
+ }
115
+ finally {
116
+ setLoadingTables((prevLoadingTables) => {
117
+ const newLoadingTables = { ...prevLoadingTables };
118
+ tables.forEach((table) => {
119
+ delete newLoadingTables[table._id];
120
+ });
121
+ return newLoadingTables;
122
+ });
123
+ }
124
+ };
23
125
  return {
24
126
  data: schemaData.schema,
25
127
  isLoading: schemaData.isSchemaLoading,
26
- reload: handleReload,
128
+ loadingTables,
129
+ reloadAll: handleReload,
130
+ refreshSome: handleRefreshSome,
27
131
  };
28
132
  };
29
133
  exports.useVirtualTables = useVirtualTables;
@@ -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"}
@@ -8,7 +8,7 @@ const ChartBuilder_1 = require("../../ChartBuilder");
8
8
  const pivotProcessing_1 = require("../../utils/pivotProcessing");
9
9
  const ui_1 = require("../../components/ReportBuilder/ui");
10
10
  const QuillSelectWithCombo_1 = require("../../components/QuillSelectWithCombo");
11
- function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, columns, uniqueValues, onDelete, SecondaryButtonComponent = ui_1.QuillSecondaryButton, SelectComponent = QuillSelectWithCombo_1.QuillSelectComponentWithCombo, PivotColumnContainer = UiComponents_1.QuillPivotColumnContainer, }) {
11
+ function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, columns, uniqueValues, uniqueValuesIsLoading, onDelete, SecondaryButtonComponent = ui_1.QuillSecondaryButton, SelectComponent = QuillSelectWithCombo_1.QuillSelectComponentWithCombo, PivotColumnContainer = UiComponents_1.QuillPivotColumnContainer, isLoading, }) {
12
12
  const [allowedColumnFields, setAllowedColumnFields] = (0, react_1.useState)([]);
13
13
  const [allowedRowFields, setAllowedRowFields] = (0, react_1.useState)([]);
14
14
  const [allowedValueFields, setAllowedValueFields] = (0, react_1.useState)([]);
@@ -20,26 +20,26 @@ function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivot
20
20
  }, [columns, uniqueValues]);
21
21
  return ((0, jsx_runtime_1.jsxs)(PivotColumnContainer, { children: [(0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Row field", value: pivotRowField, onChange: (e) => {
22
22
  setPivotRowField(e.target.value === '' ? undefined : e.target.value);
23
- }, options: allowedRowFields.map((field) => {
23
+ }, isLoading: uniqueValuesIsLoading, options: allowedRowFields.map((field) => {
24
24
  return {
25
25
  label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(field),
26
26
  value: field,
27
27
  };
28
- }), width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Column field", value: pivotColumnField, onChange: (e) => {
28
+ }), disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Column field", value: pivotColumnField, onChange: (e) => {
29
29
  setPivotColumnField(e.target.value === '' ? undefined : e.target.value);
30
- }, options: allowedColumnFields.map((field) => {
30
+ }, isLoading: uniqueValuesIsLoading, options: allowedColumnFields.map((field) => {
31
31
  return {
32
32
  label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(field),
33
33
  value: field,
34
34
  };
35
- }), width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Value field", value: pivotValueField, onChange: (e) => {
35
+ }), disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Value field", value: pivotValueField, onChange: (e) => {
36
36
  setPivotValueField(e.target.value === '' ? undefined : e.target.value);
37
- }, options: allowedValueFields.map((field) => {
37
+ }, isLoading: uniqueValuesIsLoading, options: allowedValueFields.map((field) => {
38
38
  return {
39
39
  label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(field),
40
40
  value: field,
41
41
  };
42
- }), width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Aggregation type", value: pivotAggregation, onChange: (e) => {
42
+ }), disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", label: "Aggregation type", value: pivotAggregation, onChange: (e) => {
43
43
  if (e.target.value !== 'count' &&
44
44
  pivotValueField &&
45
45
  !ChartBuilder_1.numberFormatOptions.includes(columns.find((col) => col.field === pivotValueField)
@@ -58,10 +58,10 @@ function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivot
58
58
  }
59
59
  return true;
60
60
  }),
61
- ], width: 200 }), (0, jsx_runtime_1.jsx)("div", { style: {
61
+ ], disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsx)("div", { style: {
62
62
  display: 'flex',
63
63
  alignItems: 'flex-start',
64
64
  flexDirection: 'column',
65
- }, children: onDelete && ((0, jsx_runtime_1.jsx)(SecondaryButtonComponent, { onClick: onDelete, label: "Delete Pivot" })) })] }));
65
+ }, children: onDelete && ((0, jsx_runtime_1.jsx)(SecondaryButtonComponent, { onClick: onDelete, disabled: isLoading, label: "Delete Pivot" })) })] }));
66
66
  }
67
67
  exports.default = PivotForm;
@@ -1 +1 @@
1
- {"version":3,"file":"PivotList.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotList.tsx"],"names":[],"mappings":"AAKA,KAAK,cAAc,GAAG;IACpB,UAAU,EAAE,GAAG,CAAC;IAChB,KAAK,EAAE,GAAG,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,kBAAkB,EAAE,MAAM,CAAC;IAC3B,WAAW,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACjD,eAAe,EAAE,GAAG,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,GAAG,CAAC;CACtB,CAAC;AAEF,eAAO,MAAM,SAAS,qKAanB,cAAc,4CA8MhB,CAAC;AAEF,KAAK,cAAc,GAAG;IACpB,sBAAsB,EAAE,GAAG,EAAE,CAAC;IAC9B,kBAAkB,EAAE,GAAG,EAAE,CAAC;IAC1B,wBAAwB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9D,oBAAoB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1D,KAAK,EAAE,GAAG,CAAC;IACX,kBAAkB,EAAE,MAAM,CAAC;IAC3B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,GAAG,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,sBAAsB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IACnE,kBAAkB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/D,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,GAAG,CAAC;CACtB,CAAC;AAEF,eAAO,MAAM,SAAS,8QAenB,cAAc,4CAoDhB,CAAC"}
1
+ {"version":3,"file":"PivotList.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotList.tsx"],"names":[],"mappings":"AAKA,KAAK,cAAc,GAAG;IACpB,UAAU,EAAE,GAAG,CAAC;IAChB,KAAK,EAAE,GAAG,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACpD,kBAAkB,EAAE,MAAM,CAAC;IAC3B,WAAW,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACjD,eAAe,EAAE,GAAG,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,GAAG,CAAC;CACtB,CAAC;AAEF,eAAO,MAAM,SAAS,qKAanB,cAAc,4CA6NhB,CAAC;AAEF,KAAK,cAAc,GAAG;IACpB,sBAAsB,EAAE,GAAG,EAAE,CAAC;IAC9B,kBAAkB,EAAE,GAAG,EAAE,CAAC;IAC1B,wBAAwB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9D,oBAAoB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAC1D,KAAK,EAAE,GAAG,CAAC;IACX,kBAAkB,EAAE,MAAM,CAAC;IAC3B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,eAAe,EAAE,GAAG,CAAC;IACrB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,sBAAsB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IACnE,kBAAkB,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAC/D,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,GAAG,CAAC;CACtB,CAAC;AAEF,eAAO,MAAM,SAAS,8QAenB,cAAc,4CAoDhB,CAAC"}