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