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