@quillsql/react 2.13.47 → 2.13.49
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 +2 -2
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +56 -49
- package/dist/cjs/ChartBuilder.d.ts +3 -2
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +172 -138
- package/dist/cjs/ChartEditor.d.ts +2 -2
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +5 -2
- package/dist/cjs/Context.d.ts +121 -41
- package/dist/cjs/Context.d.ts.map +1 -1
- package/dist/cjs/Context.js +449 -261
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +26 -25
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +0 -3
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +472 -96
- package/dist/cjs/QuillProvider.d.ts +3 -1
- package/dist/cjs/QuillProvider.d.ts.map +1 -1
- package/dist/cjs/QuillProvider.js +2 -2
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +25 -14
- package/dist/cjs/SQLEditor.d.ts +1 -1
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +51 -16
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +85 -14
- package/dist/cjs/assets/ExclamationFilledIcon.d.ts.map +1 -1
- package/dist/cjs/components/Chart/BarChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/BarChart.js +2 -1
- package/dist/cjs/components/Chart/CustomReferenceLine.d.ts +1 -1
- package/dist/cjs/components/Chart/CustomReferenceLine.d.ts.map +1 -1
- package/dist/cjs/components/Chart/CustomReferenceLine.js +7 -6
- package/dist/cjs/components/Chart/GaugeChart.d.ts +1 -1
- package/dist/cjs/components/Chart/GaugeChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/GaugeChart.js +63 -36
- package/dist/cjs/components/Chart/InternalChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/InternalChart.js +30 -33
- package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/LineChart.js +3 -1
- package/dist/cjs/components/Chart/MapChart.d.ts +3 -3
- package/dist/cjs/components/Chart/MapChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/MapChart.js +62 -34
- package/dist/cjs/components/Chart/PieChart.d.ts +3 -1
- package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/PieChart.js +80 -39
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DashboardFilter.js +4 -20
- 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 +4 -4
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +101 -65
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.js +2 -2
- package/dist/cjs/components/Dashboard/util.d.ts +1 -1
- package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/util.js +7 -6
- package/dist/cjs/components/QuillMultiSelectSectionList.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelectSectionList.js +32 -22
- package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/cjs/components/QuillMultiSelectWithCombo.js +186 -159
- package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelect.js +83 -75
- package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelectWithCombo.js +18 -11
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +59 -61
- package/dist/cjs/components/ReportBuilder/FilterStack.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/FilterStack.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/FilterStack.js +3 -4
- package/dist/cjs/components/ReportBuilder/ui.d.ts +2 -2
- package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.js +4 -7
- package/dist/cjs/components/UiComponents.d.ts +1 -1
- package/dist/cjs/hooks/useAskQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useAskQuill.js +5 -1
- package/dist/cjs/hooks/useDashboard.d.ts +2 -2
- package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
- package/dist/cjs/hooks/useDashboard.js +160 -69
- package/dist/cjs/hooks/useExport.d.ts.map +1 -1
- package/dist/cjs/hooks/useExport.js +29 -15
- package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.d.ts +1 -0
- package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.js +22 -12
- package/dist/cjs/hooks/useReport.d.ts +2 -2
- package/dist/cjs/hooks/useReport.d.ts.map +1 -1
- package/dist/cjs/hooks/useReport.js +3 -4
- package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
- package/dist/cjs/hooks/useVirtualTables.js +16 -22
- package/dist/cjs/index.d.ts +2 -2
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +2 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +2 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +19 -7
- package/dist/cjs/models/Client.d.ts +0 -1
- package/dist/cjs/models/Client.d.ts.map +1 -1
- package/dist/cjs/models/Data.d.ts +20 -0
- package/dist/cjs/models/Data.d.ts.map +1 -0
- package/dist/cjs/models/Data.js +2 -0
- package/dist/cjs/models/Filter.d.ts +42 -4
- package/dist/cjs/models/Filter.d.ts.map +1 -1
- package/dist/cjs/models/Pivot.d.ts.map +1 -1
- package/dist/cjs/utils/astProcessing.d.ts +3 -2
- package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/astProcessing.js +28 -37
- package/dist/cjs/utils/client.d.ts +3 -2
- package/dist/cjs/utils/client.d.ts.map +1 -1
- package/dist/cjs/utils/client.js +38 -39
- package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/columnProcessing.js +14 -3
- package/dist/cjs/utils/constants.d.ts +1 -0
- package/dist/cjs/utils/constants.d.ts.map +1 -1
- package/dist/cjs/utils/constants.js +2 -1
- package/dist/cjs/utils/dashboard.d.ts +3 -2
- package/dist/cjs/utils/dashboard.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.js +30 -12
- package/dist/cjs/utils/dataFetcher.d.ts +8 -5
- package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
- package/dist/cjs/utils/dataFetcher.js +189 -65
- 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 +24 -38
- package/dist/cjs/utils/getDomain.d.ts.map +1 -1
- package/dist/cjs/utils/paginationProcessing.d.ts +1 -0
- package/dist/cjs/utils/paginationProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/paginationProcessing.js +6 -1
- package/dist/cjs/utils/pivotConstructor.d.ts +2 -1
- package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/pivotConstructor.js +15 -9
- package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/pivotProcessing.js +3 -5
- package/dist/cjs/utils/queryConstructor.js +1 -1
- package/dist/cjs/utils/report.d.ts +10 -7
- package/dist/cjs/utils/report.d.ts.map +1 -1
- package/dist/cjs/utils/report.js +52 -60
- package/dist/cjs/utils/schema.d.ts +4 -3
- package/dist/cjs/utils/schema.d.ts.map +1 -1
- package/dist/cjs/utils/schema.js +30 -44
- package/dist/cjs/utils/tableProcessing.d.ts +16 -10
- package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.js +92 -90
- package/dist/cjs/utils/textProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/textProcessing.js +2 -1
- package/dist/cjs/utils/ui.d.ts.map +1 -1
- package/dist/esm/Chart.d.ts +2 -2
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +60 -53
- package/dist/esm/ChartBuilder.d.ts +3 -2
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +173 -139
- package/dist/esm/ChartEditor.d.ts +2 -2
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +6 -3
- package/dist/esm/Context.d.ts +121 -41
- package/dist/esm/Context.d.ts.map +1 -1
- package/dist/esm/Context.js +450 -262
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +28 -27
- package/dist/esm/DateRangePicker/QuillDateRangePicker.js +0 -3
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
- package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/dateRangePickerUtils.js +471 -95
- package/dist/esm/QuillProvider.d.ts +3 -1
- package/dist/esm/QuillProvider.d.ts.map +1 -1
- package/dist/esm/QuillProvider.js +2 -2
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +28 -17
- package/dist/esm/SQLEditor.d.ts +1 -1
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +54 -19
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +88 -17
- package/dist/esm/assets/ExclamationFilledIcon.d.ts.map +1 -1
- package/dist/esm/components/Chart/BarChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/BarChart.js +2 -1
- package/dist/esm/components/Chart/CustomReferenceLine.d.ts +1 -1
- package/dist/esm/components/Chart/CustomReferenceLine.d.ts.map +1 -1
- package/dist/esm/components/Chart/CustomReferenceLine.js +8 -7
- package/dist/esm/components/Chart/GaugeChart.d.ts +1 -1
- package/dist/esm/components/Chart/GaugeChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/GaugeChart.js +65 -38
- package/dist/esm/components/Chart/InternalChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/InternalChart.js +32 -35
- package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/LineChart.js +3 -1
- package/dist/esm/components/Chart/MapChart.d.ts +3 -3
- package/dist/esm/components/Chart/MapChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/MapChart.js +67 -39
- package/dist/esm/components/Chart/PieChart.d.ts +3 -1
- package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/PieChart.js +80 -39
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DashboardFilter.js +5 -21
- package/dist/esm/components/Dashboard/DashboardSection.js +2 -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 +4 -4
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +102 -66
- package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.js +2 -2
- package/dist/esm/components/Dashboard/util.d.ts +1 -1
- package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/util.js +8 -7
- package/dist/esm/components/QuillMultiSelectSectionList.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelectSectionList.js +32 -22
- package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
- package/dist/esm/components/QuillMultiSelectWithCombo.js +187 -160
- package/dist/esm/components/QuillSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillSelect.js +85 -77
- package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
- package/dist/esm/components/QuillSelectWithCombo.js +18 -11
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +59 -61
- package/dist/esm/components/ReportBuilder/FilterStack.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/FilterStack.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/FilterStack.js +3 -4
- package/dist/esm/components/ReportBuilder/ui.d.ts +2 -2
- package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.js +4 -7
- package/dist/esm/components/UiComponents.d.ts +1 -1
- package/dist/esm/hooks/useAskQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useAskQuill.js +6 -2
- package/dist/esm/hooks/useDashboard.d.ts +2 -2
- package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
- package/dist/esm/hooks/useDashboard.js +162 -71
- package/dist/esm/hooks/useExport.d.ts.map +1 -1
- package/dist/esm/hooks/useExport.js +31 -17
- package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.d.ts +1 -0
- package/dist/esm/hooks/useQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.js +23 -13
- package/dist/esm/hooks/useReport.d.ts +2 -2
- package/dist/esm/hooks/useReport.d.ts.map +1 -1
- package/dist/esm/hooks/useReport.js +4 -5
- package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
- package/dist/esm/hooks/useVirtualTables.js +17 -23
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +2 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +20 -8
- package/dist/esm/models/Client.d.ts +0 -1
- package/dist/esm/models/Client.d.ts.map +1 -1
- package/dist/esm/models/Data.d.ts +20 -0
- package/dist/esm/models/Data.d.ts.map +1 -0
- package/dist/esm/models/Data.js +1 -0
- package/dist/esm/models/Filter.d.ts +42 -4
- package/dist/esm/models/Filter.d.ts.map +1 -1
- package/dist/esm/models/Pivot.d.ts.map +1 -1
- package/dist/esm/utils/astProcessing.d.ts +3 -2
- package/dist/esm/utils/astProcessing.d.ts.map +1 -1
- package/dist/esm/utils/astProcessing.js +28 -37
- package/dist/esm/utils/client.d.ts +3 -2
- package/dist/esm/utils/client.d.ts.map +1 -1
- package/dist/esm/utils/client.js +38 -39
- package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
- package/dist/esm/utils/columnProcessing.js +14 -3
- package/dist/esm/utils/constants.d.ts +1 -0
- package/dist/esm/utils/constants.d.ts.map +1 -1
- package/dist/esm/utils/constants.js +1 -0
- package/dist/esm/utils/dashboard.d.ts +3 -2
- package/dist/esm/utils/dashboard.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.js +31 -13
- package/dist/esm/utils/dataFetcher.d.ts +8 -5
- package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
- package/dist/esm/utils/dataFetcher.js +187 -65
- 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 +25 -39
- package/dist/esm/utils/getDomain.d.ts.map +1 -1
- package/dist/esm/utils/paginationProcessing.d.ts +1 -0
- package/dist/esm/utils/paginationProcessing.d.ts.map +1 -1
- package/dist/esm/utils/paginationProcessing.js +5 -0
- package/dist/esm/utils/pivotConstructor.d.ts +2 -1
- package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/esm/utils/pivotConstructor.js +16 -10
- package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/esm/utils/pivotProcessing.js +5 -7
- package/dist/esm/utils/queryConstructor.js +1 -1
- package/dist/esm/utils/report.d.ts +10 -7
- package/dist/esm/utils/report.d.ts.map +1 -1
- package/dist/esm/utils/report.js +53 -61
- package/dist/esm/utils/schema.d.ts +4 -3
- package/dist/esm/utils/schema.d.ts.map +1 -1
- package/dist/esm/utils/schema.js +30 -44
- package/dist/esm/utils/tableProcessing.d.ts +16 -10
- package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.js +94 -92
- package/dist/esm/utils/textProcessing.d.ts.map +1 -1
- package/dist/esm/utils/textProcessing.js +2 -1
- package/dist/esm/utils/ui.d.ts.map +1 -1
- package/package.json +2 -1
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { ComposableMap, Geographies, Geography, useMapContext } from
|
|
3
|
-
import { useEffect, useMemo, useRef, useState } from
|
|
4
|
-
import ChartTooltipFrame from
|
|
5
|
-
import ChartTooltipRow from
|
|
6
|
-
import { valueFormatter } from
|
|
7
|
-
const statesUrl =
|
|
8
|
-
const countriesUrl =
|
|
2
|
+
import { ComposableMap, Geographies, Geography, useMapContext, } from 'react-simple-maps';
|
|
3
|
+
import { useEffect, useMemo, useRef, useState } from 'react';
|
|
4
|
+
import ChartTooltipFrame from './ChartTooltipFrame';
|
|
5
|
+
import ChartTooltipRow from './ChartTooltipRow';
|
|
6
|
+
import { valueFormatter } from '../../utils/valueFormatter';
|
|
7
|
+
const statesUrl = 'https://cdn.jsdelivr.net/npm/us-atlas@3/states-10m.json';
|
|
8
|
+
const countriesUrl = 'https://cdn.jsdelivr.net/npm/world-atlas@2/countries-50m.json';
|
|
9
9
|
const fipsToNames = {
|
|
10
10
|
'01': { name: 'Alabama', abbreviation: 'AL' },
|
|
11
11
|
'02': { name: 'Alaska', abbreviation: 'AK' },
|
|
@@ -130,7 +130,10 @@ const isoToNames = {
|
|
|
130
130
|
'233': { name: 'Estonia', abbreviation: 'EE' },
|
|
131
131
|
'234': { name: 'Faroe Islands', abbreviation: 'FO' },
|
|
132
132
|
'238': { name: 'Falkland Islands', abbreviation: 'FK' },
|
|
133
|
-
'239': {
|
|
133
|
+
'239': {
|
|
134
|
+
name: 'South Georgia and the South Sandwich Islands',
|
|
135
|
+
abbreviation: 'GS',
|
|
136
|
+
},
|
|
134
137
|
'242': { name: 'Fiji', abbreviation: 'FJ' },
|
|
135
138
|
'246': { name: 'Finland', abbreviation: 'FI' },
|
|
136
139
|
'248': { name: 'Åland Islands', abbreviation: 'AX' },
|
|
@@ -247,7 +250,10 @@ const isoToNames = {
|
|
|
247
250
|
'643': { name: 'Russia', abbreviation: 'RU' },
|
|
248
251
|
'646': { name: 'Rwanda', abbreviation: 'RW' },
|
|
249
252
|
'652': { name: 'Saint Barthélemy', abbreviation: 'BL' },
|
|
250
|
-
'654': {
|
|
253
|
+
'654': {
|
|
254
|
+
name: 'Saint Helena, Ascension and Tristan da Cunha',
|
|
255
|
+
abbreviation: 'SH',
|
|
256
|
+
},
|
|
251
257
|
'659': { name: 'Saint Kitts and Nevis', abbreviation: 'KN' },
|
|
252
258
|
'660': { name: 'Anguilla', abbreviation: 'AI' },
|
|
253
259
|
'662': { name: 'Saint Lucia', abbreviation: 'LC' },
|
|
@@ -322,7 +328,7 @@ export function USMap({ theme, data, xAxisField, xAxisFormat, yAxisFields, onCli
|
|
|
322
328
|
// These must be dynamically loaded as they are not available as CommonJS modules.
|
|
323
329
|
const [scaleLog, setScaleLog] = useState(null);
|
|
324
330
|
useEffect(() => {
|
|
325
|
-
import(
|
|
331
|
+
import('d3-scale').then((scale) => {
|
|
326
332
|
setScaleLog(() => scale.scaleLog);
|
|
327
333
|
});
|
|
328
334
|
}, []);
|
|
@@ -355,24 +361,34 @@ export function USMap({ theme, data, xAxisField, xAxisFormat, yAxisFields, onCli
|
|
|
355
361
|
colors[0];
|
|
356
362
|
return scaleLog()
|
|
357
363
|
.domain([minValue, maxValue])
|
|
358
|
-
.range([gradientStart ??
|
|
359
|
-
}, [
|
|
364
|
+
.range([gradientStart ?? '#f7fbff', gradientStop ?? '#08306b']);
|
|
365
|
+
}, [
|
|
366
|
+
mappedData,
|
|
367
|
+
measureField,
|
|
368
|
+
colorMap,
|
|
369
|
+
yAxisFields,
|
|
370
|
+
xAxisField,
|
|
371
|
+
colors,
|
|
372
|
+
scaleLog,
|
|
373
|
+
]);
|
|
360
374
|
const hoveredValue = useMemo(() => {
|
|
361
|
-
return !hoveredState
|
|
362
|
-
|
|
363
|
-
mappedData[fipsToNames[hoveredState]?.abbreviation
|
|
364
|
-
|
|
375
|
+
return !hoveredState
|
|
376
|
+
? undefined
|
|
377
|
+
: (mappedData[fipsToNames[hoveredState]?.abbreviation ?? '']?.[measureField] ??
|
|
378
|
+
mappedData[fipsToNames[hoveredState]?.name ?? '']?.[measureField] ??
|
|
379
|
+
mappedData[fipsToNames[hoveredState]?.abbreviation?.toLowerCase() ?? '']?.[measureField] ??
|
|
380
|
+
mappedData[fipsToNames[hoveredState]?.name?.toLowerCase() ?? '']?.[measureField]);
|
|
365
381
|
}, [hoveredState, mappedData, measureField]);
|
|
366
382
|
return (_jsxs("div", { ref: containerRef, className: className, style: {
|
|
367
|
-
width:
|
|
368
|
-
height:
|
|
383
|
+
width: '100%',
|
|
384
|
+
height: 'auto',
|
|
369
385
|
marginTop: '-6.5%',
|
|
370
386
|
zIndex: 0,
|
|
371
387
|
...containerStyle,
|
|
372
|
-
position:
|
|
388
|
+
position: 'relative',
|
|
373
389
|
}, children: [_jsx(ComposableMap, { projection: "geoAlbersUsa", children: _jsx(MapLayout, { hoveredRegion: hoveredState, setHoveredRegion: setHoveredState, setHoveredCoords: setHoveredCoords, containerRef: containerRef, mappedData: mappedData, measureField: measureField, colorScale: colorScale, onClickChartElement: onClickChartElement, regionNames: fipsToNames, geographyUrl: statesUrl }) }), hoveredCoords && hoveredState && (_jsx("div", { style: {
|
|
374
|
-
position:
|
|
375
|
-
pointerEvents:
|
|
390
|
+
position: 'absolute',
|
|
391
|
+
pointerEvents: 'none',
|
|
376
392
|
left: hoveredCoords[0],
|
|
377
393
|
top: hoveredCoords[1],
|
|
378
394
|
}, children: _jsxs(ChartTooltipFrame, { theme: theme, children: [_jsx("div", { style: {
|
|
@@ -425,7 +441,7 @@ export function WorldMap({ theme, data, xAxisField, xAxisFormat, yAxisFields, on
|
|
|
425
441
|
// These must be dynamically loaded as they are not available as CommonJS modules.
|
|
426
442
|
const [scaleLog, setScaleLog] = useState(null);
|
|
427
443
|
useEffect(() => {
|
|
428
|
-
import(
|
|
444
|
+
import('d3-scale').then((scale) => {
|
|
429
445
|
setScaleLog(() => scale.scaleLog);
|
|
430
446
|
});
|
|
431
447
|
}, []);
|
|
@@ -458,25 +474,35 @@ export function WorldMap({ theme, data, xAxisField, xAxisFormat, yAxisFields, on
|
|
|
458
474
|
colors[0];
|
|
459
475
|
return scaleLog()
|
|
460
476
|
.domain([minValue, maxValue])
|
|
461
|
-
.range([gradientStart ??
|
|
462
|
-
}, [
|
|
477
|
+
.range([gradientStart ?? '#f7fbff', gradientStop ?? '#08306b']);
|
|
478
|
+
}, [
|
|
479
|
+
mappedData,
|
|
480
|
+
measureField,
|
|
481
|
+
colorMap,
|
|
482
|
+
yAxisFields,
|
|
483
|
+
xAxisField,
|
|
484
|
+
colors,
|
|
485
|
+
scaleLog,
|
|
486
|
+
]);
|
|
463
487
|
const hoveredValue = useMemo(() => {
|
|
464
|
-
return !hoveredCountry
|
|
465
|
-
|
|
466
|
-
mappedData[isoToNames[hoveredCountry]?.abbreviation
|
|
467
|
-
|
|
488
|
+
return !hoveredCountry
|
|
489
|
+
? undefined
|
|
490
|
+
: (mappedData[isoToNames[hoveredCountry]?.abbreviation ?? '']?.[measureField] ??
|
|
491
|
+
mappedData[isoToNames[hoveredCountry]?.name ?? '']?.[measureField] ??
|
|
492
|
+
mappedData[isoToNames[hoveredCountry]?.abbreviation?.toLowerCase() ?? '']?.[measureField] ??
|
|
493
|
+
mappedData[isoToNames[hoveredCountry]?.name?.toLowerCase() ?? '']?.[measureField]);
|
|
468
494
|
}, [hoveredCountry, mappedData, measureField]);
|
|
469
495
|
return (_jsxs("div", { ref: containerRef, className: className, style: {
|
|
470
|
-
width:
|
|
471
|
-
height:
|
|
496
|
+
width: '100%',
|
|
497
|
+
height: 'auto',
|
|
472
498
|
marginTop: '-5%',
|
|
473
499
|
marginBottom: '-6.5%',
|
|
474
500
|
zIndex: 0,
|
|
475
501
|
...containerStyle,
|
|
476
|
-
position:
|
|
502
|
+
position: 'relative',
|
|
477
503
|
}, children: [_jsx(ComposableMap, { projection: "geoEqualEarth", children: _jsx(MapLayout, { hoveredRegion: hoveredCountry, setHoveredRegion: setHoveredCountry, setHoveredCoords: setHoveredCoords, containerRef: containerRef, mappedData: mappedData, measureField: measureField, colorScale: colorScale, onClickChartElement: onClickChartElement, geographyUrl: countriesUrl, regionNames: isoToNames }) }), hoveredCoords && hoveredCountry && (_jsx("div", { style: {
|
|
478
|
-
position:
|
|
479
|
-
pointerEvents:
|
|
504
|
+
position: 'absolute',
|
|
505
|
+
pointerEvents: 'none',
|
|
480
506
|
left: hoveredCoords[0],
|
|
481
507
|
top: hoveredCoords[1],
|
|
482
508
|
}, children: _jsxs(ChartTooltipFrame, { theme: theme, children: [_jsx("div", { style: {
|
|
@@ -522,7 +548,7 @@ function MapLayout({ geographyUrl, hoveredRegion, setHoveredRegion, setHoveredCo
|
|
|
522
548
|
// These must be dynamically loaded as they are not available as CommonJS modules.
|
|
523
549
|
const [geoCentroid, setGeoCentroid] = useState(null);
|
|
524
550
|
useEffect(() => {
|
|
525
|
-
import(
|
|
551
|
+
import('d3-geo').then((geo) => {
|
|
526
552
|
setGeoCentroid(() => geo.geoCentroid);
|
|
527
553
|
});
|
|
528
554
|
}, []);
|
|
@@ -532,16 +558,18 @@ function MapLayout({ geographyUrl, hoveredRegion, setHoveredRegion, setHoveredCo
|
|
|
532
558
|
mappedData[regionNames[geo.id]?.name ?? ''] ??
|
|
533
559
|
mappedData[regionNames[geo.id]?.abbreviation?.toLowerCase() ?? ''] ??
|
|
534
560
|
mappedData[regionNames[geo.id]?.name?.toLowerCase() ?? ''];
|
|
535
|
-
const value = regionData
|
|
536
|
-
|
|
537
|
-
|
|
561
|
+
const value = regionData
|
|
562
|
+
? parseFloat(regionData[measureField])
|
|
563
|
+
: null;
|
|
564
|
+
const fill = value != null ? colorScale(value) : '#D6D6DA';
|
|
565
|
+
return (_jsx(Geography, { geography: geo, fill: fill, stroke: "#FFFFFF", strokeWidth: 0.5, onMouseEnter: () => {
|
|
538
566
|
if (!geoCentroid)
|
|
539
567
|
return;
|
|
540
568
|
const centroid = geoCentroid(geo);
|
|
541
569
|
const projected = projection(centroid);
|
|
542
570
|
if (projected && containerRef.current) {
|
|
543
571
|
const [x, y] = projected;
|
|
544
|
-
const svg = containerRef.current.querySelector(
|
|
572
|
+
const svg = containerRef.current.querySelector('svg');
|
|
545
573
|
if (svg) {
|
|
546
574
|
const svgRect = svg.getBoundingClientRect();
|
|
547
575
|
const viewBoxWidth = 800, viewBoxHeight = 600;
|
|
@@ -561,6 +589,6 @@ function MapLayout({ geographyUrl, hoveredRegion, setHoveredRegion, setHoveredCo
|
|
|
561
589
|
if (regionData) {
|
|
562
590
|
onClickChartElement?.(regionData);
|
|
563
591
|
}
|
|
564
|
-
} }, geo.id + index.toString());
|
|
592
|
+
} }, geo.id + index.toString()));
|
|
565
593
|
}) }));
|
|
566
594
|
}
|
|
@@ -29,11 +29,13 @@ export declare const ChartTooltipFrame: ({ children, theme, }: {
|
|
|
29
29
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
30
30
|
export interface ChartTooltipRowProps {
|
|
31
31
|
value: string;
|
|
32
|
+
rawValue?: string;
|
|
33
|
+
valueKey?: string;
|
|
32
34
|
name: string;
|
|
33
35
|
color: Color;
|
|
34
36
|
theme: any;
|
|
35
37
|
}
|
|
36
|
-
export declare const ChartTooltipRow: ({ value, name, color, theme, }: ChartTooltipRowProps) => import("react/jsx-runtime").JSX.Element;
|
|
38
|
+
export declare const ChartTooltipRow: ({ value, rawValue, valueKey, name, color, theme, }: ChartTooltipRowProps) => import("react/jsx-runtime").JSX.Element;
|
|
37
39
|
export interface DonutChartTooltipProps {
|
|
38
40
|
active: boolean | undefined;
|
|
39
41
|
payload: any;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PieChart.d.ts","sourceRoot":"","sources":["../../../../src/components/Chart/PieChart.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AAG7C,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAGjD,MAAM,MAAM,cAAc,GAAG;IAC3B,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;CACzB,CAAC;AAEF,QAAA,MAAM,iBAAiB,6DAMb,CAAC;AAEX,MAAM,MAAM,WAAW,GAAG,CAAC,OAAO,iBAAiB,CAAC,CAAC,MAAM,CAAC,CAAC;AAE7D,MAAM,MAAM,kBAAkB,GAAG,MAAM,GAAG,OAAO,CAAC;AAElD,MAAM,MAAM,gBAAgB,GAAG,KAAK,GAAG,QAAQ,CAAC;AAEhD,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,WAAW,GAAG,OAAO,CAAC;AAE9D,QAAA,MAAM,eAAe,wFAMX,CAAC;AAEX,MAAM,MAAM,SAAS,GAAG,CAAC,OAAO,eAAe,CAAC,CAAC,MAAM,CAAC,CAAC;AAEzD,QAAA,MAAM,UAAU,yCAA0C,CAAC;AAE3D,MAAM,MAAM,IAAI,GAAG,CAAC,OAAO,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC;AAE/C,QAAA,MAAM,WAAW,gNAuBP,CAAC;AAEX,MAAM,MAAM,KAAK,GAAG,CAAC,OAAO,WAAW,CAAC,CAAC,MAAM,CAAC,CAAC;AAEjD,QAAA,MAAM,oBAAoB,oEAOhB,CAAC;AACX,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,oBAAoB,CAAC,CAAC,MAAM,CAAC,CAAC;AAEnE,QAAA,MAAM,gBAAgB,4DAMZ,CAAC;AACX,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,gBAAgB,CAAC,CAAC,MAAM,CAAC,CAAC;AAE3D,MAAM,MAAM,aAAa,GAAG,KAAK,GAAG,KAAK,GAAG,aAAa,GAAG,aAAa,CAAC;AAE1E,eAAO,MAAM,qBAAqB,EAAE,cACN,CAAC;AAE/B,eAAO,MAAM,eAAe,QAAS,MAAM,EAAE,WACO,CAAC;AAErD,eAAO,MAAM,SAAS,SACd,GAAG,EAAE,UACH,MAAM,EAAE,eACH,MAAM,YACT,MAAM,
|
|
1
|
+
{"version":3,"file":"PieChart.d.ts","sourceRoot":"","sources":["../../../../src/components/Chart/PieChart.tsx"],"names":[],"mappings":"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"}
|
|
@@ -67,11 +67,13 @@ export const parseData = (data, colors, categoryKey, valueKey) => {
|
|
|
67
67
|
// .toNumber(),
|
|
68
68
|
acc + parseFloat(dataPoint[valueKey] ?? '0'), 0);
|
|
69
69
|
slicedData.forEach((dataPoint) => {
|
|
70
|
+
const rawValue = parseFloat(dataPoint[valueKey] ?? '0');
|
|
70
71
|
dataPoint[valueKey] = totalValue
|
|
71
|
-
? (
|
|
72
|
+
? (rawValue * 100) / totalValue
|
|
72
73
|
: data.length > maxItems
|
|
73
74
|
? 100 / (maxItems + 1)
|
|
74
75
|
: 100 / slicedData.length; // if totalValue is 0, divide datapoints evenly
|
|
76
|
+
dataPoint[`raw_${valueKey}`] = parseFloat(rawValue.toFixed(2));
|
|
75
77
|
});
|
|
76
78
|
const parsedData = slicedData.map((dataPoint, idx) => {
|
|
77
79
|
const baseColor = idx < colors.length ? colors[idx] : colors[colors.length - 1];
|
|
@@ -95,6 +97,7 @@ export const parseData = (data, colors, categoryKey, valueKey) => {
|
|
|
95
97
|
parsedData.push({
|
|
96
98
|
[categoryKey]: 'Other',
|
|
97
99
|
[valueKey]: normalizedOtherSum,
|
|
100
|
+
[`raw_${valueKey}`]: parseFloat(otherSum.toFixed(2)),
|
|
98
101
|
color: otherColor,
|
|
99
102
|
fill: otherColor,
|
|
100
103
|
});
|
|
@@ -114,56 +117,94 @@ export const ChartTooltipFrame = ({ children, theme, }) => (_jsx("div", { style:
|
|
|
114
117
|
borderRadius: '6px',
|
|
115
118
|
boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',
|
|
116
119
|
}, children: children }));
|
|
117
|
-
export const ChartTooltipRow = ({ value, name, color, theme, }) => (_jsxs("div", { style: {
|
|
120
|
+
export const ChartTooltipRow = ({ value, rawValue, valueKey, name, color, theme, }) => (_jsxs("div", { style: {
|
|
118
121
|
display: 'flex',
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
}, children: [
|
|
122
|
+
flexDirection: 'column',
|
|
123
|
+
gap: 2,
|
|
124
|
+
minWidth: 150,
|
|
125
|
+
position: 'relative',
|
|
126
|
+
}, children: [_jsx("span", { style: {
|
|
127
|
+
position: 'absolute',
|
|
128
|
+
top: '50%',
|
|
129
|
+
transform: 'translateY(-50%)',
|
|
130
|
+
}, children: _jsx("span", { style: {
|
|
131
|
+
background: color,
|
|
132
|
+
borderWidth: 2,
|
|
133
|
+
borderStyle: 'solid',
|
|
134
|
+
borderColor: 'white',
|
|
135
|
+
height: '8px',
|
|
136
|
+
width: '8px',
|
|
137
|
+
display: 'block',
|
|
138
|
+
boxShadow: '0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)',
|
|
139
|
+
borderRadius: '9999px',
|
|
140
|
+
} }) }), _jsx("div", { style: {
|
|
124
141
|
display: 'flex',
|
|
125
142
|
alignItems: 'center',
|
|
143
|
+
width: '100%',
|
|
144
|
+
paddingLeft: '24px',
|
|
145
|
+
}, children: _jsxs("span", { style: {
|
|
146
|
+
flex: 1,
|
|
147
|
+
display: 'flex',
|
|
148
|
+
alignItems: 'center',
|
|
149
|
+
justifyContent: 'space-between',
|
|
150
|
+
}, children: [_jsx("p", { style: {
|
|
151
|
+
marginTop: 0,
|
|
152
|
+
marginBottom: 0,
|
|
153
|
+
marginRight: '24px',
|
|
154
|
+
fontFamily: theme?.fontFamily,
|
|
155
|
+
color: theme?.primaryTextColor,
|
|
156
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
157
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
158
|
+
minWidth: '60px',
|
|
159
|
+
}, children: name }), _jsx("p", { style: {
|
|
160
|
+
marginTop: 0,
|
|
161
|
+
marginBottom: 0,
|
|
162
|
+
fontFamily: theme?.fontFamily,
|
|
163
|
+
color: theme?.primaryTextColor,
|
|
164
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
165
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
166
|
+
minWidth: '40px',
|
|
167
|
+
textAlign: 'right',
|
|
168
|
+
}, children: value })] }) }), (rawValue || valueKey) && (_jsx("div", { style: {
|
|
169
|
+
display: 'flex',
|
|
170
|
+
alignItems: 'center',
|
|
171
|
+
width: '100%',
|
|
172
|
+
paddingLeft: '24px',
|
|
126
173
|
justifyContent: 'space-between',
|
|
127
|
-
}, children:
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
whiteSpace: 'nowrap',
|
|
152
|
-
overflow: 'hidden',
|
|
153
|
-
textOverflow: 'ellipsis',
|
|
154
|
-
textAlign: 'right',
|
|
155
|
-
fontSize: theme?.fontSizeSmall || '14px',
|
|
156
|
-
fontWeight: theme?.fontWeightNormal || '400',
|
|
157
|
-
}, children: name })] }));
|
|
174
|
+
}, children: _jsxs("span", { style: {
|
|
175
|
+
flex: 1,
|
|
176
|
+
display: 'flex',
|
|
177
|
+
alignItems: 'center',
|
|
178
|
+
justifyContent: 'space-between',
|
|
179
|
+
}, children: [_jsx("p", { style: {
|
|
180
|
+
marginTop: 0,
|
|
181
|
+
marginBottom: 0,
|
|
182
|
+
marginRight: '24px',
|
|
183
|
+
fontFamily: theme?.fontFamily,
|
|
184
|
+
color: theme?.primaryTextColor,
|
|
185
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
186
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
187
|
+
minWidth: '60px',
|
|
188
|
+
}, children: valueKey }), _jsx("p", { style: {
|
|
189
|
+
marginTop: 0,
|
|
190
|
+
marginBottom: 0,
|
|
191
|
+
fontFamily: theme?.fontFamily,
|
|
192
|
+
color: theme?.primaryTextColor,
|
|
193
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
194
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
195
|
+
minWidth: '40px',
|
|
196
|
+
textAlign: 'right',
|
|
197
|
+
}, children: rawValue })] }) }))] }));
|
|
158
198
|
export const DonutChartTooltip = ({ active, payload, valueFormatter, theme, }) => {
|
|
159
199
|
if (active && payload[0]) {
|
|
160
200
|
const payloadRow = payload[0];
|
|
201
|
+
const rawValue = payloadRow.payload[`raw_${payloadRow.dataKey}`];
|
|
161
202
|
return (_jsx(ChartTooltipFrame, { theme: theme, children: _jsx("div", { style: {
|
|
162
203
|
paddingLeft: '1rem',
|
|
163
204
|
paddingRight: '1rem',
|
|
164
205
|
paddingTop: '8px',
|
|
165
206
|
paddingBottom: '8px',
|
|
166
|
-
}, children: _jsx(ChartTooltipRow, { value: valueFormatter(payloadRow.value), name: payloadRow.name, color: payloadRow.payload.color, theme: theme }) }) }));
|
|
207
|
+
}, children: _jsx(ChartTooltipRow, { value: valueFormatter(payloadRow.value), rawValue: rawValue ? rawValue.toString() : undefined, valueKey: payloadRow.dataKey, name: payloadRow.name, color: payloadRow.payload.color, theme: theme }) }) }));
|
|
167
208
|
}
|
|
168
209
|
return null;
|
|
169
210
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardFilter.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DashboardFilter.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,aAAa,EAAW,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"DashboardFilter.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DashboardFilter.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,34 +1,18 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
2
|
import { useMemo } from 'react';
|
|
3
|
-
import { COMPARISON_OPTIONS
|
|
3
|
+
import { COMPARISON_OPTIONS } from '../../DateRangePicker/dateRangePickerUtils';
|
|
4
4
|
import { QuillDateRangePicker, } from '../../DateRangePicker/QuillDateRangePicker';
|
|
5
5
|
import { QuillMultiSelectComponentWithCombo } from '../QuillMultiSelectWithCombo';
|
|
6
6
|
import { QuillSelectComponentWithCombo } from '../QuillSelectWithCombo';
|
|
7
7
|
export function DashboardFilter({ filter, onChangeFilter, SelectComponent = QuillSelectComponentWithCombo, MultiSelectComponent = QuillMultiSelectComponentWithCombo, DateRangePickerComponent = QuillDateRangePicker, theme, isLoading, disabled, containerStyle, }) {
|
|
8
8
|
const preset = useMemo(() => {
|
|
9
|
-
if (
|
|
10
|
-
'startDate' in filter &&
|
|
11
|
-
'endDate' in filter) {
|
|
12
|
-
if (!filter.preset && !filter.primaryRange)
|
|
13
|
-
return '';
|
|
14
|
-
if (!filter.startDate || !filter.endDate)
|
|
15
|
-
return filter.preset?.value ?? filter.primaryRange.value;
|
|
16
|
-
const presetRange = filter.presetRanges?.find((range) => range.value === (filter.preset?.value ?? filter.primaryRange.value)) ?? PRIMARY_RANGE[filter.preset?.value ?? filter.primaryRange.value];
|
|
17
|
-
if (!presetRange)
|
|
18
|
-
return filter.preset?.value ?? filter.primaryRange.value;
|
|
19
|
-
// if (
|
|
20
|
-
// presetRange.startDate !== filter.startDate ||
|
|
21
|
-
// presetRange.endDate !== filter.endDate
|
|
22
|
-
// ) {
|
|
23
|
-
// return '';
|
|
24
|
-
// }
|
|
9
|
+
if ('preset' in filter && 'primaryRange' in filter) {
|
|
25
10
|
return filter.preset?.value ?? filter.primaryRange.value;
|
|
26
11
|
}
|
|
27
|
-
|
|
12
|
+
else {
|
|
13
|
+
return '';
|
|
14
|
+
}
|
|
28
15
|
}, [filter]);
|
|
29
|
-
// if (!filter.options && !isLoading && !(filter.filterType === 'date_range')) {
|
|
30
|
-
// return null;
|
|
31
|
-
// }
|
|
32
16
|
if (filter.filterType === 'string') {
|
|
33
17
|
if (filter.stringFilterType === 'multiselect') {
|
|
34
18
|
return (_jsx("div", { style: containerStyle, children: _jsx(MultiSelectComponent, { label: filter.label, value: filter.values ?? [], onChange: (e) => {
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
import { useContext } from
|
|
3
|
-
import { ThemeContext } from
|
|
2
|
+
import { useContext } from 'react';
|
|
3
|
+
import { ThemeContext } from '../../Context';
|
|
4
4
|
export default function DashboardSection({ section, children, }) {
|
|
5
5
|
const [theme] = useContext(ThemeContext);
|
|
6
6
|
return (_jsxs(_Fragment, { children: [section && (_jsx("div", { style: { display: 'flex', flexDirection: 'column' }, children: _jsx("h1", { style: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DashboardTemplate.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DashboardTemplate.tsx"],"names":[],"mappings":"AAQA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1D,MAAM,CAAC,OAAO,UAAU,sBAAsB,CAAC,EAC7C,IAAI,EACJ,eAAe,EACf,MAAM,EACN,cAAc,EACd,cAAc,EACd,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,GAChB,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,mBAAmB,CAAC;IAC5B,cAAc,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,sBAAsB,EAAE,GAAG,CAAC;IAC5B,uBAAuB,EAAE,GAAG,CAAC;IAC7B,sBAAsB,EAAE,GAAG,CAAC;IAC5B,eAAe,EAAE,GAAG,CAAC;CACtB,
|
|
1
|
+
{"version":3,"file":"DashboardTemplate.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DashboardTemplate.tsx"],"names":[],"mappings":"AAQA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1D,MAAM,CAAC,OAAO,UAAU,sBAAsB,CAAC,EAC7C,IAAI,EACJ,eAAe,EACf,MAAM,EACN,cAAc,EACd,cAAc,EACd,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,EACtB,eAAe,GAChB,EAAE;IACD,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,EAAE,MAAM,CAAC;IACxB,MAAM,EAAE,mBAAmB,CAAC;IAC5B,cAAc,EAAE,GAAG,CAAC;IACpB,cAAc,EAAE,GAAG,CAAC;IACpB,sBAAsB,EAAE,GAAG,CAAC;IAC5B,uBAAuB,EAAE,GAAG,CAAC;IAC7B,sBAAsB,EAAE,GAAG,CAAC;IAC5B,eAAe,EAAE,GAAG,CAAC;CACtB,kDA2GA"}
|
|
@@ -2,10 +2,11 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
2
2
|
import { useContext, useState } from 'react';
|
|
3
3
|
import { addTemplatesToDashboard, validateTemplatesAgainstFilters, } from './util';
|
|
4
4
|
import { useDashboard } from '../../hooks/useDashboard';
|
|
5
|
-
import { DashboardConfigContext } from '../../Context';
|
|
5
|
+
import { DashboardConfigContext, FetchContext } from '../../Context';
|
|
6
6
|
import Dashboard from '../../Dashboard';
|
|
7
7
|
export default function QuillDashboardTemplate({ name, originDashboard, client, appliedFilters, ModalComponent, TemplateChartComponent, TemplateMetricComponent, TemplateTableComponent, ButtonComponent, }) {
|
|
8
8
|
const { isLoading, data } = useDashboard(name ?? '');
|
|
9
|
+
const { getToken } = useContext(FetchContext);
|
|
9
10
|
const { dashboardConfig, dashboardConfigDispatch } = useContext(DashboardConfigContext);
|
|
10
11
|
const [addItemModalIsOpen, setAddItemModalIsOpen] = useState(false);
|
|
11
12
|
const [selectedTemplates, setSelectedTemplates] = useState([]);
|
|
@@ -23,7 +24,7 @@ export default function QuillDashboardTemplate({ name, originDashboard, client,
|
|
|
23
24
|
setAddItemModalIsOpen(false);
|
|
24
25
|
const newTemplates = selectedTemplates;
|
|
25
26
|
setSelectedTemplates([]);
|
|
26
|
-
const newData = await addTemplatesToDashboard(originDashboard, newTemplates, client, dashboardConfig);
|
|
27
|
+
const newData = await addTemplatesToDashboard(originDashboard, newTemplates, client, dashboardConfig, getToken);
|
|
27
28
|
if (newData) {
|
|
28
29
|
// Dispatch the action to update the dashboard state
|
|
29
30
|
dashboardConfigDispatch({
|
|
@@ -14,13 +14,13 @@ export type DataLoaderChildProps = {
|
|
|
14
14
|
rowCount?: number;
|
|
15
15
|
rowCountIsLoading?: boolean;
|
|
16
16
|
};
|
|
17
|
-
export default function DataLoader({ item, children, filters, userFilters, additionalProcessing: defaultAdditionalProcessing, dashboardName,
|
|
17
|
+
export default function DataLoader({ item, children, filters, userFilters, additionalProcessing: defaultAdditionalProcessing, dashboardName, propagateChanges, }: {
|
|
18
18
|
item: QuillReportInternal;
|
|
19
19
|
filters: DashboardFilter[];
|
|
20
20
|
userFilters?: InternalFilter[];
|
|
21
21
|
additionalProcessing: AdditionalProcessing;
|
|
22
22
|
dashboardName?: string;
|
|
23
|
-
|
|
23
|
+
propagateChanges?: boolean;
|
|
24
24
|
children: ({ isLoading, error, onPageChange, onSortChange, data, }: DataLoaderChildProps) => JSX.Element;
|
|
25
25
|
}): JSX.Element;
|
|
26
26
|
type ColorMapType = {
|
|
@@ -41,7 +41,7 @@ export type ChartDataLoaderChildProps = {
|
|
|
41
41
|
rowCount?: number;
|
|
42
42
|
rowCountIsLoading?: boolean;
|
|
43
43
|
};
|
|
44
|
-
export declare const ChartDataLoader: ({ item, children, dateBucket, additionalProcessing, filters, userFilters, dashboardName,
|
|
44
|
+
export declare const ChartDataLoader: ({ item, children, dateBucket, additionalProcessing, filters, userFilters, dashboardName, propagateChanges, }: {
|
|
45
45
|
item: QuillReportInternal;
|
|
46
46
|
dateBucket?: string;
|
|
47
47
|
mapColorsToFields?: (_report: QuillReport, _theme: QuillTheme) => ColorMapType;
|
|
@@ -49,7 +49,7 @@ export declare const ChartDataLoader: ({ item, children, dateBucket, additionalP
|
|
|
49
49
|
filters: DashboardFilter[];
|
|
50
50
|
userFilters?: InternalFilter[];
|
|
51
51
|
dashboardName?: string;
|
|
52
|
-
|
|
52
|
+
propagateChanges?: boolean;
|
|
53
53
|
children: ({ isLoading, error, data, dateBucket, rowCount, rowCountIsLoading, }: ChartDataLoaderChildProps) => JSX.Element;
|
|
54
54
|
}) => JSX.Element;
|
|
55
55
|
export {};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DataLoader.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DataLoader.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DataLoader.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/DataLoader.tsx"],"names":[],"mappings":"AAUA,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AACvE,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAajD,OAAO,EACL,oBAAoB,EAErB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AA4BtE,MAAM,MAAM,oBAAoB,GAAG;IACjC,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACrC,YAAY,EAAE,CAAC,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,KAAK,IAAI,CAAC;IACnE,IAAI,EAAE,WAAW,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AA6KF,MAAM,CAAC,OAAO,UAAU,UAAU,CAAC,EACjC,IAAI,EACJ,QAAQ,EACR,OAAO,EACP,WAAW,EACX,oBAAoB,EAAE,2BAA2B,EACjD,aAAa,EACb,gBAAgB,GACjB,EAAE;IACD,IAAI,EAAE,mBAAmB,CAAC;IAC1B,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,WAAW,CAAC,EAAE,cAAc,EAAE,CAAC;IAC/B,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,QAAQ,EAAE,CAAC,EACT,SAAS,EACT,KAAK,EACL,YAAY,EACZ,YAAY,EACZ,IAAI,GACL,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;CACzC,GAAG,GAAG,CAAC,OAAO,CAwWd;AAED,KAAK,YAAY,GAAG;IAClB,CAAC,GAAG,EAAE,MAAM,GAAG;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,oBAAoB,CAAC,EAAE,MAAM,CAAC;QAC9B,mBAAmB,CAAC,EAAE,MAAM,CAAC;QAC7B,uBAAuB,CAAC,EAAE,MAAM,CAAC;QACjC,sBAAsB,CAAC,EAAE,MAAM,CAAC;KACjC,CAAC;CACH,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,SAAS,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,WAAW,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,iBAAiB,CAAC,EAAE,OAAO,CAAC;CAC7B,CAAC;AAIF,eAAO,MAAM,eAAe,iHASzB;IACD,IAAI,EAAE,mBAAmB,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,iBAAiB,CAAC,EAAE,CAClB,OAAO,EAAE,WAAW,EACpB,MAAM,EAAE,UAAU,KACf,YAAY,CAAC;IAClB,oBAAoB,EAAE,oBAAoB,CAAC;IAC3C,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,WAAW,CAAC,EAAE,cAAc,EAAE,CAAC;IAC/B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,QAAQ,EAAE,CAAC,EACT,SAAS,EACT,KAAK,EACL,IAAI,EACJ,UAAU,EACV,QAAQ,EACR,iBAAiB,GAClB,EAAE,yBAAyB,KAAK,GAAG,CAAC,OAAO,CAAC;CAC9C,KAAG,GAAG,CAAC,OAyLP,CAAC"}
|