@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.
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +5 -3
- package/dist/cjs/ChartBuilder.d.ts +10 -3
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +62 -26
- package/dist/cjs/ChartEditor.d.ts +3 -1
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +74 -16
- package/dist/cjs/Context.d.ts +17 -6
- package/dist/cjs/Context.d.ts.map +1 -1
- package/dist/cjs/Context.js +138 -73
- package/dist/cjs/Dashboard.d.ts +8 -4
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +146 -367
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +20 -14
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +1 -0
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/cjs/QuillProvider.js +1 -1
- package/dist/cjs/ReportBuilder.d.ts +8 -12
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +163 -83
- package/dist/cjs/SQLEditor.d.ts +8 -1
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +81 -28
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +6 -3
- package/dist/cjs/assets/AdjustmentsIcon.d.ts +5 -0
- package/dist/cjs/assets/AdjustmentsIcon.d.ts.map +1 -0
- package/dist/cjs/assets/AdjustmentsIcon.js +5 -0
- package/dist/cjs/assets/ArrowDownHeadIcon.d.ts.map +1 -1
- package/dist/cjs/components/Chart/ChartError.js +2 -2
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +4 -3
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DashboardFilter.js +12 -12
- package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts +2 -2
- package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.d.ts +11 -5
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +91 -32
- package/dist/cjs/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.js +10 -3
- package/dist/cjs/components/Dashboard/util.d.ts +2 -2
- package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/util.js +2 -2
- package/dist/cjs/components/QuillMultiSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelect.js +18 -13
- package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelectWithCombo.js +67 -45
- package/dist/cjs/components/QuillSelect.d.ts +1 -1
- package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelect.js +29 -7
- package/dist/cjs/components/QuillSelectWithCombo.d.ts +1 -1
- package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelectWithCombo.js +47 -26
- package/dist/cjs/components/QuillTable.d.ts +3 -2
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +32 -19
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +2 -2
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.js +2 -2
- package/dist/cjs/components/ReportBuilder/FilterModal.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/FilterModal.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/FilterModal.js +17 -4
- package/dist/cjs/components/ReportBuilder/ui.d.ts +13 -8
- package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.js +15 -24
- package/dist/cjs/components/UiComponents.d.ts +17 -9
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +30 -24
- package/dist/cjs/hooks/useAstToFilterTree.d.ts +2 -2
- package/dist/cjs/hooks/useAstToFilterTree.d.ts.map +1 -1
- package/dist/cjs/hooks/useDashboard.d.ts +13 -5
- package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
- package/dist/cjs/hooks/useDashboard.js +158 -70
- package/dist/cjs/hooks/useExport.d.ts.map +1 -1
- package/dist/cjs/hooks/useExport.js +9 -3
- package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.js +15 -15
- package/dist/cjs/hooks/useVirtualTables.d.ts +12 -3
- package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
- package/dist/cjs/hooks/useVirtualTables.js +105 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts +3 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.js +9 -9
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.js +21 -15
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +3 -2
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +9 -9
- package/dist/cjs/models/Client.d.ts +16 -2
- package/dist/cjs/models/Client.d.ts.map +1 -1
- package/dist/cjs/models/Dashboard.d.ts +1 -1
- package/dist/cjs/models/Dashboard.d.ts.map +1 -1
- package/dist/cjs/models/Filter.d.ts +4 -3
- package/dist/cjs/models/Filter.d.ts.map +1 -1
- package/dist/cjs/models/Filter.js +38 -1
- package/dist/cjs/utils/astProcessing.d.ts +3 -3
- package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/client.d.ts.map +1 -1
- package/dist/cjs/utils/client.js +2 -7
- package/dist/cjs/utils/dashboard.d.ts +5 -5
- package/dist/cjs/utils/dashboard.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.js +90 -9
- package/dist/cjs/utils/dataFetcher.d.ts +4 -4
- package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
- package/dist/cjs/utils/dataFetcher.js +1 -1
- package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/filterProcessing.js +2 -8
- package/dist/cjs/utils/paginationProcessing.js +1 -1
- package/dist/cjs/utils/pivotConstructor.d.ts +2 -2
- package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/pivotConstructor.js +1 -1
- package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/pivotProcessing.js +6 -2
- package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/queryConstructor.js +12 -9
- package/dist/cjs/utils/report.d.ts +6 -5
- package/dist/cjs/utils/report.d.ts.map +1 -1
- package/dist/cjs/utils/report.js +71 -25
- package/dist/cjs/utils/schema.d.ts +3 -3
- package/dist/cjs/utils/schema.d.ts.map +1 -1
- package/dist/cjs/utils/schema.js +39 -35
- package/dist/cjs/utils/tableProcessing.d.ts +18 -11
- package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.js +44 -23
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +6 -4
- package/dist/esm/ChartBuilder.d.ts +10 -3
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +59 -26
- package/dist/esm/ChartEditor.d.ts +3 -1
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +76 -18
- package/dist/esm/Context.d.ts +17 -6
- package/dist/esm/Context.d.ts.map +1 -1
- package/dist/esm/Context.js +139 -74
- package/dist/esm/Dashboard.d.ts +8 -4
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +146 -367
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.js +21 -15
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +1 -0
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/esm/QuillProvider.js +1 -1
- package/dist/esm/ReportBuilder.d.ts +8 -12
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +167 -87
- package/dist/esm/SQLEditor.d.ts +8 -1
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +84 -31
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +7 -4
- package/dist/esm/assets/AdjustmentsIcon.d.ts +5 -0
- package/dist/esm/assets/AdjustmentsIcon.d.ts.map +1 -0
- package/dist/esm/assets/AdjustmentsIcon.js +3 -0
- package/dist/esm/assets/ArrowDownHeadIcon.d.ts.map +1 -1
- package/dist/esm/components/Chart/ChartError.js +2 -2
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts +4 -3
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DashboardFilter.js +12 -12
- package/dist/esm/components/Dashboard/DashboardTemplate.d.ts +2 -2
- package/dist/esm/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.d.ts +11 -5
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +94 -35
- package/dist/esm/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/TableComponent.js +10 -3
- package/dist/esm/components/Dashboard/util.d.ts +2 -2
- package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/util.js +2 -2
- package/dist/esm/components/QuillMultiSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelect.js +19 -14
- package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelectWithCombo.js +68 -46
- package/dist/esm/components/QuillSelect.d.ts +1 -1
- package/dist/esm/components/QuillSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillSelect.js +30 -8
- package/dist/esm/components/QuillSelectWithCombo.d.ts +1 -1
- package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
- package/dist/esm/components/QuillSelectWithCombo.js +48 -27
- package/dist/esm/components/QuillTable.d.ts +3 -2
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +32 -19
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.js +2 -2
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.js +2 -2
- package/dist/esm/components/ReportBuilder/FilterModal.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/FilterModal.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/FilterModal.js +17 -4
- package/dist/esm/components/ReportBuilder/ui.d.ts +13 -8
- package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.js +14 -19
- package/dist/esm/components/UiComponents.d.ts +17 -9
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +30 -24
- package/dist/esm/hooks/useAstToFilterTree.d.ts +2 -2
- package/dist/esm/hooks/useAstToFilterTree.d.ts.map +1 -1
- package/dist/esm/hooks/useDashboard.d.ts +13 -5
- package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
- package/dist/esm/hooks/useDashboard.js +158 -73
- package/dist/esm/hooks/useExport.d.ts.map +1 -1
- package/dist/esm/hooks/useExport.js +10 -4
- package/dist/esm/hooks/useQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.js +17 -17
- package/dist/esm/hooks/useVirtualTables.d.ts +12 -3
- package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
- package/dist/esm/hooks/useVirtualTables.js +106 -2
- package/dist/esm/internals/ReportBuilder/PivotForm.d.ts +3 -1
- package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotForm.js +9 -9
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.js +21 -15
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +3 -2
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +9 -9
- package/dist/esm/models/Client.d.ts +16 -2
- package/dist/esm/models/Client.d.ts.map +1 -1
- package/dist/esm/models/Dashboard.d.ts +1 -1
- package/dist/esm/models/Dashboard.d.ts.map +1 -1
- package/dist/esm/models/Filter.d.ts +4 -3
- package/dist/esm/models/Filter.d.ts.map +1 -1
- package/dist/esm/models/Filter.js +36 -0
- package/dist/esm/utils/astProcessing.d.ts +3 -3
- package/dist/esm/utils/astProcessing.d.ts.map +1 -1
- package/dist/esm/utils/client.d.ts.map +1 -1
- package/dist/esm/utils/client.js +2 -7
- package/dist/esm/utils/dashboard.d.ts +5 -5
- package/dist/esm/utils/dashboard.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.js +90 -9
- package/dist/esm/utils/dataFetcher.d.ts +4 -4
- package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
- package/dist/esm/utils/dataFetcher.js +1 -1
- package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
- package/dist/esm/utils/filterProcessing.js +2 -8
- package/dist/esm/utils/paginationProcessing.js +1 -1
- package/dist/esm/utils/pivotConstructor.d.ts +2 -2
- package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/esm/utils/pivotConstructor.js +1 -1
- package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/esm/utils/pivotProcessing.js +6 -2
- package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
- package/dist/esm/utils/queryConstructor.js +12 -9
- package/dist/esm/utils/report.d.ts +6 -5
- package/dist/esm/utils/report.d.ts.map +1 -1
- package/dist/esm/utils/report.js +70 -25
- package/dist/esm/utils/schema.d.ts +3 -3
- package/dist/esm/utils/schema.d.ts.map +1 -1
- package/dist/esm/utils/schema.js +39 -35
- package/dist/esm/utils/tableProcessing.d.ts +18 -11
- package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.js +41 -20
- 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
|
-
|
|
31
|
-
|
|
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
|
-
|
|
44
|
-
|
|
45
|
-
|
|
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
|
-
|
|
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
|
-
|
|
61
|
-
|
|
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
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
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
|
-
|
|
207
|
+
setIsLoading(false);
|
|
99
208
|
}
|
|
100
209
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
}
|
|
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
|
-
|
|
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;;;;
|
|
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.
|
|
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,
|
|
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,
|
|
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;
|
|
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.
|
|
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(
|
|
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,
|
|
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:
|
|
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,
|
|
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:
|
|
3
|
+
data: Table[];
|
|
3
4
|
isLoading: boolean;
|
|
4
|
-
|
|
5
|
-
|
|
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":"
|
|
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
|
-
|
|
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;
|
|
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,
|
|
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"}
|