@quillsql/react 2.13.48 → 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 +28 -41
- package/dist/cjs/ChartBuilder.d.ts +2 -2
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +157 -134
- package/dist/cjs/ChartEditor.d.ts +2 -2
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +3 -1
- package/dist/cjs/Context.d.ts +10 -3
- package/dist/cjs/Context.d.ts.map +1 -1
- package/dist/cjs/Context.js +324 -249
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +10 -23
- 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 +19 -10
- package/dist/cjs/SQLEditor.d.ts +1 -1
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +50 -16
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +20 -7
- 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 +62 -35
- 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 +31 -14
- 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/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/hooks/useAskQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useAskQuill.js +5 -1
- package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
- package/dist/cjs/hooks/useDashboard.js +96 -58
- package/dist/cjs/hooks/useExport.d.ts.map +1 -1
- package/dist/cjs/hooks/useExport.js +23 -13
- package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.js +8 -10
- package/dist/cjs/hooks/useReport.d.ts.map +1 -1
- 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/pivotConstructor.d.ts +2 -1
- package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/pivotConstructor.js +15 -11
- 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 +91 -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 +30 -43
- package/dist/esm/ChartBuilder.d.ts +2 -2
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +158 -135
- package/dist/esm/ChartEditor.d.ts +2 -2
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +4 -2
- package/dist/esm/Context.d.ts +10 -3
- package/dist/esm/Context.d.ts.map +1 -1
- package/dist/esm/Context.js +326 -251
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +12 -25
- 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 +21 -12
- package/dist/esm/SQLEditor.d.ts +1 -1
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +53 -19
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +21 -8
- 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 +64 -37
- 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 +32 -15
- 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/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/hooks/useAskQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useAskQuill.js +6 -2
- package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
- package/dist/esm/hooks/useDashboard.js +98 -60
- package/dist/esm/hooks/useExport.d.ts.map +1 -1
- package/dist/esm/hooks/useExport.js +25 -15
- package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.js +9 -11
- package/dist/esm/hooks/useReport.d.ts.map +1 -1
- package/dist/esm/hooks/useReport.js +1 -1
- 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/pivotConstructor.d.ts +2 -1
- package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/esm/utils/pivotConstructor.js +16 -12
- 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 +93 -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
|
@@ -75,11 +75,13 @@ const parseData = (data, colors, categoryKey, valueKey) => {
|
|
|
75
75
|
// .toNumber(),
|
|
76
76
|
acc + parseFloat(dataPoint[valueKey] ?? '0'), 0);
|
|
77
77
|
slicedData.forEach((dataPoint) => {
|
|
78
|
+
const rawValue = parseFloat(dataPoint[valueKey] ?? '0');
|
|
78
79
|
dataPoint[valueKey] = totalValue
|
|
79
|
-
? (
|
|
80
|
+
? (rawValue * 100) / totalValue
|
|
80
81
|
: data.length > maxItems
|
|
81
82
|
? 100 / (maxItems + 1)
|
|
82
83
|
: 100 / slicedData.length; // if totalValue is 0, divide datapoints evenly
|
|
84
|
+
dataPoint[`raw_${valueKey}`] = parseFloat(rawValue.toFixed(2));
|
|
83
85
|
});
|
|
84
86
|
const parsedData = slicedData.map((dataPoint, idx) => {
|
|
85
87
|
const baseColor = idx < colors.length ? colors[idx] : colors[colors.length - 1];
|
|
@@ -103,6 +105,7 @@ const parseData = (data, colors, categoryKey, valueKey) => {
|
|
|
103
105
|
parsedData.push({
|
|
104
106
|
[categoryKey]: 'Other',
|
|
105
107
|
[valueKey]: normalizedOtherSum,
|
|
108
|
+
[`raw_${valueKey}`]: parseFloat(otherSum.toFixed(2)),
|
|
106
109
|
color: otherColor,
|
|
107
110
|
fill: otherColor,
|
|
108
111
|
});
|
|
@@ -125,57 +128,95 @@ const ChartTooltipFrame = ({ children, theme, }) => ((0, jsx_runtime_1.jsx)("div
|
|
|
125
128
|
boxShadow: '0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)',
|
|
126
129
|
}, children: children }));
|
|
127
130
|
exports.ChartTooltipFrame = ChartTooltipFrame;
|
|
128
|
-
const ChartTooltipRow = ({ value, name, color, theme, }) => ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
131
|
+
const ChartTooltipRow = ({ value, rawValue, valueKey, name, color, theme, }) => ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
129
132
|
display: 'flex',
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
}, children: [(0, jsx_runtime_1.
|
|
133
|
+
flexDirection: 'column',
|
|
134
|
+
gap: 2,
|
|
135
|
+
minWidth: 150,
|
|
136
|
+
position: 'relative',
|
|
137
|
+
}, children: [(0, jsx_runtime_1.jsx)("span", { style: {
|
|
138
|
+
position: 'absolute',
|
|
139
|
+
top: '50%',
|
|
140
|
+
transform: 'translateY(-50%)',
|
|
141
|
+
}, children: (0, jsx_runtime_1.jsx)("span", { style: {
|
|
142
|
+
background: color,
|
|
143
|
+
borderWidth: 2,
|
|
144
|
+
borderStyle: 'solid',
|
|
145
|
+
borderColor: 'white',
|
|
146
|
+
height: '8px',
|
|
147
|
+
width: '8px',
|
|
148
|
+
display: 'block',
|
|
149
|
+
boxShadow: '0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06)',
|
|
150
|
+
borderRadius: '9999px',
|
|
151
|
+
} }) }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
135
152
|
display: 'flex',
|
|
136
153
|
alignItems: 'center',
|
|
154
|
+
width: '100%',
|
|
155
|
+
paddingLeft: '24px',
|
|
156
|
+
}, children: (0, jsx_runtime_1.jsxs)("span", { style: {
|
|
157
|
+
flex: 1,
|
|
158
|
+
display: 'flex',
|
|
159
|
+
alignItems: 'center',
|
|
160
|
+
justifyContent: 'space-between',
|
|
161
|
+
}, children: [(0, jsx_runtime_1.jsx)("p", { style: {
|
|
162
|
+
marginTop: 0,
|
|
163
|
+
marginBottom: 0,
|
|
164
|
+
marginRight: '24px',
|
|
165
|
+
fontFamily: theme?.fontFamily,
|
|
166
|
+
color: theme?.primaryTextColor,
|
|
167
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
168
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
169
|
+
minWidth: '60px',
|
|
170
|
+
}, children: name }), (0, jsx_runtime_1.jsx)("p", { style: {
|
|
171
|
+
marginTop: 0,
|
|
172
|
+
marginBottom: 0,
|
|
173
|
+
fontFamily: theme?.fontFamily,
|
|
174
|
+
color: theme?.primaryTextColor,
|
|
175
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
176
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
177
|
+
minWidth: '40px',
|
|
178
|
+
textAlign: 'right',
|
|
179
|
+
}, children: value })] }) }), (rawValue || valueKey) && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
180
|
+
display: 'flex',
|
|
181
|
+
alignItems: 'center',
|
|
182
|
+
width: '100%',
|
|
183
|
+
paddingLeft: '24px',
|
|
137
184
|
justifyContent: 'space-between',
|
|
138
|
-
}, children:
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
whiteSpace: 'nowrap',
|
|
163
|
-
overflow: 'hidden',
|
|
164
|
-
textOverflow: 'ellipsis',
|
|
165
|
-
textAlign: 'right',
|
|
166
|
-
fontSize: theme?.fontSizeSmall || '14px',
|
|
167
|
-
fontWeight: theme?.fontWeightNormal || '400',
|
|
168
|
-
}, children: name })] }));
|
|
185
|
+
}, children: (0, jsx_runtime_1.jsxs)("span", { style: {
|
|
186
|
+
flex: 1,
|
|
187
|
+
display: 'flex',
|
|
188
|
+
alignItems: 'center',
|
|
189
|
+
justifyContent: 'space-between',
|
|
190
|
+
}, children: [(0, jsx_runtime_1.jsx)("p", { style: {
|
|
191
|
+
marginTop: 0,
|
|
192
|
+
marginBottom: 0,
|
|
193
|
+
marginRight: '24px',
|
|
194
|
+
fontFamily: theme?.fontFamily,
|
|
195
|
+
color: theme?.primaryTextColor,
|
|
196
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
197
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
198
|
+
minWidth: '60px',
|
|
199
|
+
}, children: valueKey }), (0, jsx_runtime_1.jsx)("p", { style: {
|
|
200
|
+
marginTop: 0,
|
|
201
|
+
marginBottom: 0,
|
|
202
|
+
fontFamily: theme?.fontFamily,
|
|
203
|
+
color: theme?.primaryTextColor,
|
|
204
|
+
fontSize: theme?.fontSizeSmall || '14px',
|
|
205
|
+
fontWeight: theme?.fontWeightMedium || '500',
|
|
206
|
+
minWidth: '40px',
|
|
207
|
+
textAlign: 'right',
|
|
208
|
+
}, children: rawValue })] }) }))] }));
|
|
169
209
|
exports.ChartTooltipRow = ChartTooltipRow;
|
|
170
210
|
const DonutChartTooltip = ({ active, payload, valueFormatter, theme, }) => {
|
|
171
211
|
if (active && payload[0]) {
|
|
172
212
|
const payloadRow = payload[0];
|
|
213
|
+
const rawValue = payloadRow.payload[`raw_${payloadRow.dataKey}`];
|
|
173
214
|
return ((0, jsx_runtime_1.jsx)(exports.ChartTooltipFrame, { theme: theme, children: (0, jsx_runtime_1.jsx)("div", { style: {
|
|
174
215
|
paddingLeft: '1rem',
|
|
175
216
|
paddingRight: '1rem',
|
|
176
217
|
paddingTop: '8px',
|
|
177
218
|
paddingBottom: '8px',
|
|
178
|
-
}, children: (0, jsx_runtime_1.jsx)(exports.ChartTooltipRow, { value: valueFormatter(payloadRow.value), name: payloadRow.name, color: payloadRow.payload.color, theme: theme }) }) }));
|
|
219
|
+
}, children: (0, jsx_runtime_1.jsx)(exports.ChartTooltipRow, { value: valueFormatter(payloadRow.value), rawValue: rawValue ? rawValue.toString() : undefined, valueKey: payloadRow.dataKey, name: payloadRow.name, color: payloadRow.payload.color, theme: theme }) }) }));
|
|
179
220
|
}
|
|
180
221
|
return null;
|
|
181
222
|
};
|
|
@@ -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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"}
|
|
@@ -9,29 +9,13 @@ const QuillMultiSelectWithCombo_1 = require("../QuillMultiSelectWithCombo");
|
|
|
9
9
|
const QuillSelectWithCombo_1 = require("../QuillSelectWithCombo");
|
|
10
10
|
function DashboardFilter({ filter, onChangeFilter, SelectComponent = QuillSelectWithCombo_1.QuillSelectComponentWithCombo, MultiSelectComponent = QuillMultiSelectWithCombo_1.QuillMultiSelectComponentWithCombo, DateRangePickerComponent = QuillDateRangePicker_1.QuillDateRangePicker, theme, isLoading, disabled, containerStyle, }) {
|
|
11
11
|
const preset = (0, react_1.useMemo)(() => {
|
|
12
|
-
if (
|
|
13
|
-
'startDate' in filter &&
|
|
14
|
-
'endDate' in filter) {
|
|
15
|
-
if (!filter.preset && !filter.primaryRange)
|
|
16
|
-
return '';
|
|
17
|
-
if (!filter.startDate || !filter.endDate)
|
|
18
|
-
return filter.preset?.value ?? filter.primaryRange.value;
|
|
19
|
-
const presetRange = filter.presetRanges?.find((range) => range.value === (filter.preset?.value ?? filter.primaryRange.value)) ?? dateRangePickerUtils_1.PRIMARY_RANGE[filter.preset?.value ?? filter.primaryRange.value];
|
|
20
|
-
if (!presetRange)
|
|
21
|
-
return filter.preset?.value ?? filter.primaryRange.value;
|
|
22
|
-
// if (
|
|
23
|
-
// presetRange.startDate !== filter.startDate ||
|
|
24
|
-
// presetRange.endDate !== filter.endDate
|
|
25
|
-
// ) {
|
|
26
|
-
// return '';
|
|
27
|
-
// }
|
|
12
|
+
if ('preset' in filter && 'primaryRange' in filter) {
|
|
28
13
|
return filter.preset?.value ?? filter.primaryRange.value;
|
|
29
14
|
}
|
|
30
|
-
|
|
15
|
+
else {
|
|
16
|
+
return '';
|
|
17
|
+
}
|
|
31
18
|
}, [filter]);
|
|
32
|
-
// if (!filter.options && !isLoading && !(filter.filterType === 'date_range')) {
|
|
33
|
-
// return null;
|
|
34
|
-
// }
|
|
35
19
|
if (filter.filterType === 'string') {
|
|
36
20
|
if (filter.stringFilterType === 'multiselect') {
|
|
37
21
|
return ((0, jsx_runtime_1.jsx)("div", { style: containerStyle, children: (0, jsx_runtime_1.jsx)(MultiSelectComponent, { label: filter.label, value: filter.values ?? [], onChange: (e) => {
|
|
@@ -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"}
|
|
@@ -12,6 +12,7 @@ const Context_1 = require("../../Context");
|
|
|
12
12
|
const Dashboard_1 = __importDefault(require("../../Dashboard"));
|
|
13
13
|
function QuillDashboardTemplate({ name, originDashboard, client, appliedFilters, ModalComponent, TemplateChartComponent, TemplateMetricComponent, TemplateTableComponent, ButtonComponent, }) {
|
|
14
14
|
const { isLoading, data } = (0, useDashboard_1.useDashboard)(name ?? '');
|
|
15
|
+
const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
|
|
15
16
|
const { dashboardConfig, dashboardConfigDispatch } = (0, react_1.useContext)(Context_1.DashboardConfigContext);
|
|
16
17
|
const [addItemModalIsOpen, setAddItemModalIsOpen] = (0, react_1.useState)(false);
|
|
17
18
|
const [selectedTemplates, setSelectedTemplates] = (0, react_1.useState)([]);
|
|
@@ -29,7 +30,7 @@ function QuillDashboardTemplate({ name, originDashboard, client, appliedFilters,
|
|
|
29
30
|
setAddItemModalIsOpen(false);
|
|
30
31
|
const newTemplates = selectedTemplates;
|
|
31
32
|
setSelectedTemplates([]);
|
|
32
|
-
const newData = await (0, util_1.addTemplatesToDashboard)(originDashboard, newTemplates, client, dashboardConfig);
|
|
33
|
+
const newData = await (0, util_1.addTemplatesToDashboard)(originDashboard, newTemplates, client, dashboardConfig, getToken);
|
|
33
34
|
if (newData) {
|
|
34
35
|
// Dispatch the action to update the dashboard state
|
|
35
36
|
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"}
|
|
@@ -40,9 +40,13 @@ function filterValuesEquivalent(filters1, filters2) {
|
|
|
40
40
|
// Find the odd filters out and return false ONLY if they have a selected value or are a date filter
|
|
41
41
|
const filters1Labels = filters1.map((f) => f.label);
|
|
42
42
|
const filters2Labels = filters2.map((f) => f.label);
|
|
43
|
-
const oddFilters = filters1Labels.length > filters2Labels.length
|
|
43
|
+
const oddFilters = filters1Labels.length > filters2Labels.length
|
|
44
|
+
? filters1Labels.filter((label) => !filters2Labels.includes(label))
|
|
45
|
+
: filters2Labels.filter((label) => !filters1Labels.includes(label));
|
|
44
46
|
for (const filter of oddFilters) {
|
|
45
|
-
const filter1 = filters1Labels.length > filters2Labels.length
|
|
47
|
+
const filter1 = filters1Labels.length > filters2Labels.length
|
|
48
|
+
? filters1.find((f) => f.label === filter)
|
|
49
|
+
: filters2.find((f) => f.label === filter);
|
|
46
50
|
if (filter1?.selectedValue || filter1?.startDate || filter1?.endDate) {
|
|
47
51
|
return false;
|
|
48
52
|
}
|
|
@@ -164,13 +168,14 @@ function userFilterValuesEquivalent(filters1, filters2) {
|
|
|
164
168
|
function customFieldsEquivalent(customFields1, customFields2) {
|
|
165
169
|
return (0, fast_deep_equal_1.default)(customFields1, customFields2);
|
|
166
170
|
}
|
|
167
|
-
function DataLoader({ item, children, filters, userFilters, additionalProcessing: defaultAdditionalProcessing, dashboardName,
|
|
171
|
+
function DataLoader({ item, children, filters, userFilters, additionalProcessing: defaultAdditionalProcessing, dashboardName, propagateChanges, }) {
|
|
168
172
|
const [client] = (0, react_1.useContext)(Context_1.ClientContext);
|
|
169
|
-
const { dashboardReports: dashboard, addReport, updateReport } = (0, useDashboard_1.useDashboardReports)(dashboardName);
|
|
173
|
+
const { dashboardReports: dashboard, addReport, updateReport, } = (0, useDashboard_1.useDashboardReports)(dashboardName);
|
|
170
174
|
const { dashboardFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
|
|
171
175
|
const { tenants, flags } = (0, react_1.useContext)(Context_1.TenantContext);
|
|
172
176
|
const { reports, reportsDispatch, fetchIndividualReport } = (0, react_1.useContext)(Context_1.ReportsContext);
|
|
173
177
|
const { reportFilters } = (0, react_1.useContext)(Context_1.ReportFiltersContext);
|
|
178
|
+
const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
|
|
174
179
|
const contextFilters = (0, react_1.useMemo)(() => {
|
|
175
180
|
return dashboardName
|
|
176
181
|
? Object.values(dashboardFilters[dashboardName] ?? {}).map((f) => f.filter)
|
|
@@ -217,7 +222,7 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
217
222
|
rowCountAbortController.current?.abort();
|
|
218
223
|
rowCountAbortController.current = new AbortController();
|
|
219
224
|
try {
|
|
220
|
-
const rowCount = await (0, report_1.fetchReportRowCount)(item.id, client, tenants, flags, true, filters.concat(userFilters ?? []), processing, schemaData.customFields, rowCountAbortController.current.signal);
|
|
225
|
+
const rowCount = await (0, report_1.fetchReportRowCount)(item.id, client, getToken, tenants, flags, true, filters.concat(userFilters ?? []), processing, schemaData.customFields, rowCountAbortController.current.signal);
|
|
221
226
|
rowCountAbortController.current = null;
|
|
222
227
|
if (rowCount) {
|
|
223
228
|
if (dashboardName) {
|
|
@@ -288,8 +293,7 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
288
293
|
const updatedProcessing = { ...additionalProcessing, ...processing };
|
|
289
294
|
const pivotQuery = (dashboardName ? dashboard : reports)[item.id]
|
|
290
295
|
?.pivotQuery;
|
|
291
|
-
const comparisonPivotQuery = (dashboardName ? dashboard : reports)[item.id]
|
|
292
|
-
?.comparisonPivotQuery;
|
|
296
|
+
const comparisonPivotQuery = (dashboardName ? dashboard : reports)[item.id]?.comparisonPivotQuery;
|
|
293
297
|
const paginatedRows = await (0, tableProcessing_1.fetchResultsByReport)({
|
|
294
298
|
reportId: item.id,
|
|
295
299
|
client,
|
|
@@ -303,6 +307,7 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
303
307
|
pivotQuery,
|
|
304
308
|
comparisonPivotQuery,
|
|
305
309
|
getPivotRowCount: false,
|
|
310
|
+
getToken,
|
|
306
311
|
});
|
|
307
312
|
updateTableRowsAbortController.current = null;
|
|
308
313
|
if (paginatedRows.error) {
|
|
@@ -374,6 +379,7 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
374
379
|
rowsOnly: true,
|
|
375
380
|
rowCountOnly: false,
|
|
376
381
|
abortSignal: rowsAbortController.current.signal,
|
|
382
|
+
getToken,
|
|
377
383
|
});
|
|
378
384
|
addReport({
|
|
379
385
|
...fetchedReport,
|
|
@@ -397,7 +403,7 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
397
403
|
additionalProcessing: processing,
|
|
398
404
|
reportAbortController: rowsAbortController.current,
|
|
399
405
|
customFields: schemaData.customFields,
|
|
400
|
-
|
|
406
|
+
propagateChanges,
|
|
401
407
|
});
|
|
402
408
|
rowsAbortController.current = null;
|
|
403
409
|
setError(undefined);
|
|
@@ -432,7 +438,8 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
432
438
|
userFilterValuesEquivalent(previousUserFilters.current ?? [], userFilters ?? []) &&
|
|
433
439
|
// tenantsEquivalent(previousTenants.current ?? [], tenants ?? []) &&
|
|
434
440
|
customFieldsEquivalent(previousCustomFields.current, schemaData.customFields) &&
|
|
435
|
-
((dashboardName ? dashboard : reports)[item.id]?.rows !== undefined ||
|
|
441
|
+
((dashboardName ? dashboard : reports)[item.id]?.rows !== undefined ||
|
|
442
|
+
rowsAbortController.current))) {
|
|
436
443
|
if (!rowsAbortController.current && !schemaData.isSchemaLoading)
|
|
437
444
|
setLoading(false);
|
|
438
445
|
return;
|
|
@@ -459,7 +466,10 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
459
466
|
else if (tempReport?.error) {
|
|
460
467
|
setError(tempReport.error);
|
|
461
468
|
}
|
|
462
|
-
}, [
|
|
469
|
+
}, [
|
|
470
|
+
(dashboardName ? dashboard : reports)[item.id]?.triggerReload,
|
|
471
|
+
(dashboardName ? dashboard : reports)[item.id]?.error,
|
|
472
|
+
]);
|
|
463
473
|
return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children({
|
|
464
474
|
isLoading: loading,
|
|
465
475
|
error,
|
|
@@ -472,10 +482,11 @@ function DataLoader({ item, children, filters, userFilters, additionalProcessing
|
|
|
472
482
|
}
|
|
473
483
|
// The same data-loader pattern as above, but with special logic for charts
|
|
474
484
|
// At some point these may be able to get merged into one function.
|
|
475
|
-
const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, filters, userFilters, dashboardName,
|
|
485
|
+
const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, filters, userFilters, dashboardName, propagateChanges, }) => {
|
|
476
486
|
const { dashboardReports: dashboard, addReport } = (0, useDashboard_1.useDashboardReports)(dashboardName);
|
|
477
487
|
const { dashboardFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
|
|
478
488
|
const { reports, fetchIndividualReport } = (0, react_1.useContext)(Context_1.ReportsContext);
|
|
489
|
+
const { getToken } = (0, react_1.useContext)(Context_1.FetchContext);
|
|
479
490
|
const { reportFilters } = (0, react_1.useContext)(Context_1.ReportFiltersContext);
|
|
480
491
|
const { tenants, flags } = (0, react_1.useContext)(Context_1.TenantContext);
|
|
481
492
|
const contextFilters = (0, react_1.useMemo)(() => {
|
|
@@ -534,6 +545,7 @@ const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, fil
|
|
|
534
545
|
dateBucket,
|
|
535
546
|
customFields: schemaData.customFields,
|
|
536
547
|
abortSignal: fetchReportAbortController.current.signal,
|
|
548
|
+
getToken,
|
|
537
549
|
});
|
|
538
550
|
addReport({
|
|
539
551
|
...report,
|
|
@@ -559,7 +571,7 @@ const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, fil
|
|
|
559
571
|
dateBucket,
|
|
560
572
|
reportAbortController: fetchReportAbortController.current,
|
|
561
573
|
customFields: schemaData.customFields,
|
|
562
|
-
|
|
574
|
+
propagateChanges,
|
|
563
575
|
});
|
|
564
576
|
setError(undefined);
|
|
565
577
|
}
|
|
@@ -593,7 +605,9 @@ const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, fil
|
|
|
593
605
|
// tenantsEquivalent(tenants ?? [], previousTenants.current ?? []) &&
|
|
594
606
|
previousDateBucket.current === dateBucket &&
|
|
595
607
|
customFieldsEquivalent(previousCustomFields.current, schemaData.customFields) &&
|
|
596
|
-
((dashboardName ? dashboard : reports)[item.id]?.rows?.length !==
|
|
608
|
+
((dashboardName ? dashboard : reports)[item.id]?.rows?.length !==
|
|
609
|
+
undefined ||
|
|
610
|
+
fetchReportAbortController.current))) {
|
|
597
611
|
if (!fetchReportAbortController.current && !schemaData.isSchemaLoading)
|
|
598
612
|
setLoading(false);
|
|
599
613
|
return;
|
|
@@ -621,7 +635,10 @@ const ChartDataLoader = ({ item, children, dateBucket, additionalProcessing, fil
|
|
|
621
635
|
else if (tempReport?.error) {
|
|
622
636
|
setError(tempReport.error);
|
|
623
637
|
}
|
|
624
|
-
}, [
|
|
638
|
+
}, [
|
|
639
|
+
(dashboardName ? dashboard : reports)[item.id]?.triggerReload,
|
|
640
|
+
(dashboardName ? dashboard : reports)[item.id]?.error,
|
|
641
|
+
]);
|
|
625
642
|
return children({
|
|
626
643
|
isLoading: !chartReport || loading,
|
|
627
644
|
data: chartReport,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MetricComponent.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/MetricComponent.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAMnD,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAAC,EAC3C,MAAM,EACN,OAAO,EACP,KAAK,EACL,SAAS,EACT,QAAQ,GACT,EAAE,gBAAgB,GAAG,GAAG,CAAC,OAAO,
|
|
1
|
+
{"version":3,"file":"MetricComponent.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/MetricComponent.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAMnD,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAAC,EAC3C,MAAM,EACN,OAAO,EACP,KAAK,EACL,SAAS,EACT,QAAQ,GACT,EAAE,gBAAgB,GAAG,GAAG,CAAC,OAAO,CA4HhC"}
|
|
@@ -80,7 +80,7 @@ function QuillMetricComponent({ report, onClick, error, isLoading, children, })
|
|
|
80
80
|
}, children: "No results" })) : ((0, jsx_runtime_1.jsx)(MetricDisplay, { dateFilter: dateFilter, primaryMetricLabel: primaryMetricLabel, comparisonLabel: comparisonLabel, theme: theme, children: children }))] }) }) }, report?.name));
|
|
81
81
|
}
|
|
82
82
|
const MetricDisplay = ({ children, dateFilter, primaryMetricLabel, comparisonLabel, theme, }) => {
|
|
83
|
-
return (0, jsx_runtime_1.jsx)("div", { style: {
|
|
83
|
+
return ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
84
84
|
padding: 0,
|
|
85
85
|
height: '100%',
|
|
86
86
|
width: '100%',
|
|
@@ -133,5 +133,5 @@ const MetricDisplay = ({ children, dateFilter, primaryMetricLabel, comparisonLab
|
|
|
133
133
|
marginLeft: 2,
|
|
134
134
|
}, children: comparisonLabel
|
|
135
135
|
? 'in ' + comparisonLabel.toLowerCase()
|
|
136
|
-
: 'previous period' })] }))] }) });
|
|
136
|
+
: 'previous period' })] }))] }) }));
|
|
137
137
|
};
|
|
@@ -3,5 +3,5 @@ export declare function validateTemplatesAgainstFilters(filters: any[], template
|
|
|
3
3
|
valid: boolean;
|
|
4
4
|
error: string;
|
|
5
5
|
};
|
|
6
|
-
export declare function addTemplatesToDashboard(name: any, newTemplates: any[], client: QuillProviderClient, dashboardData: any): Promise<any>;
|
|
6
|
+
export declare function addTemplatesToDashboard(name: any, newTemplates: any[], client: QuillProviderClient, dashboardData: any, getToken: () => Promise<string>): Promise<any>;
|
|
7
7
|
//# sourceMappingURL=util.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAK1D,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,GAAG,EAAE,EACd,SAAS,EAAE,GAAG,EAAE,GACf;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAiCnC;
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../src/components/Dashboard/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAK1D,wBAAgB,+BAA+B,CAC7C,OAAO,EAAE,GAAG,EAAE,EACd,SAAS,EAAE,GAAG,EAAE,GACf;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,CAiCnC;AAGD,wBAAsB,uBAAuB,CAC3C,IAAI,EAAE,GAAG,EACT,YAAY,EAAE,GAAG,EAAE,EACnB,MAAM,EAAE,mBAAmB,EAC3B,aAAa,EAAE,GAAG,EAClB,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,CAAC,GAC9B,OAAO,CAAC,GAAG,CAAC,CA8Cd"}
|
|
@@ -39,23 +39,24 @@ function validateTemplatesAgainstFilters(filters, templates) {
|
|
|
39
39
|
return { valid: false, error };
|
|
40
40
|
}
|
|
41
41
|
}
|
|
42
|
-
|
|
42
|
+
// TODO: Outdated, revisit and retest
|
|
43
|
+
async function addTemplatesToDashboard(name, newTemplates, client, dashboardData, getToken) {
|
|
43
44
|
try {
|
|
44
45
|
const { publicKey, tenants } = client;
|
|
45
46
|
if (tenants) {
|
|
46
47
|
// need to implement a way to specify report tenant id
|
|
47
48
|
throw new Error('Adding from template not yet supported for tenants');
|
|
48
49
|
}
|
|
49
|
-
const
|
|
50
|
+
const { data: resp } = await (0, dataFetcher_1.quillFetch)({
|
|
51
|
+
client,
|
|
52
|
+
task: 'add-from-template',
|
|
50
53
|
metadata: {
|
|
51
54
|
dashboardName: name,
|
|
52
|
-
task: 'add-from-template',
|
|
53
55
|
clientId: publicKey,
|
|
54
56
|
templateReportIds: newTemplates.map((template) => template._id),
|
|
55
57
|
},
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
'omit', hostedBody, null);
|
|
58
|
+
getToken,
|
|
59
|
+
});
|
|
59
60
|
if (resp.success && resp.newItems && resp.newItems.length > 0) {
|
|
60
61
|
const newData = {
|
|
61
62
|
newQueries: {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"QuillMultiSelectSectionList.d.ts","sourceRoot":"","sources":["../../../src/components/QuillMultiSelectSectionList.tsx"],"names":[],"mappings":"AAEA,OAAc,EACZ,aAAa,EAKd,MAAM,OAAO,CAAC;AAGf;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,EAC1C,OAAO,EACP,KAAK,EACL,QAAQ,EACR,KAAK,EACL,gBAAgB,EAChB,KAAK,EACL,SAAS,EACT,QAAQ,EACR,UAAU,EACV,gBAAgB,EAChB,KAAK,EACL,KAAK,GACN,EAAE;IACD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE;
|
|
1
|
+
{"version":3,"file":"QuillMultiSelectSectionList.d.ts","sourceRoot":"","sources":["../../../src/components/QuillMultiSelectSectionList.tsx"],"names":[],"mappings":"AAEA,OAAc,EACZ,aAAa,EAKd,MAAM,OAAO,CAAC;AAGf;;GAEG;AACH,wBAAgB,2BAA2B,CAAC,EAC1C,OAAO,EACP,KAAK,EACL,QAAQ,EACR,KAAK,EACL,gBAAgB,EAChB,KAAK,EACL,SAAS,EACT,QAAQ,EACR,UAAU,EACV,gBAAgB,EAChB,KAAK,EACL,KAAK,GACN,EAAE;IACD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE;QAAE,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;KAAE,CAAC;IAC3C,OAAO,EAAE;QACP,CAAC,WAAW,EAAE,MAAM,GAAG;YACrB,KAAK,EAAE,MAAM,CAAC;YACd,KAAK,EAAE,MAAM,CAAC;SACf,EAAE,CAAC;KACL,CAAC;IACF,gBAAgB,CAAC,EAAE;QAAE,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IACrD,QAAQ,EAAE,CAAC,KAAK,EAAE;QAChB,MAAM,EAAE;YAAE,KAAK,EAAE;gBAAE,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,EAAE,CAAA;aAAE,CAAA;SAAE,CAAC;KACxD,KAAK,IAAI,CAAC;IACX,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,KAAK,CAAC,EAAE,aAAa,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,2CA8bA;AAED,eAAO,MAAM,gBAAgB,sCAI1B;IACD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,WAAW,EAAE,MAAM,CAAC;CACrB,4CAwDA,CAAC"}
|
|
@@ -75,19 +75,23 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
75
75
|
const isUuid = sample.value?.match(uuidRegex);
|
|
76
76
|
const isNumber = !isNaN(parseInt(sample.value));
|
|
77
77
|
const filteredOptions = Object.keys(options).reduce((acc, key) => {
|
|
78
|
-
acc[key] =
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
78
|
+
acc[key] =
|
|
79
|
+
options[key]?.filter((option) => {
|
|
80
|
+
if (!option) {
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
return (searchQuery === '' ||
|
|
84
|
+
option.label
|
|
85
|
+
.toLowerCase()
|
|
86
|
+
.replace(/\s+/g, '')
|
|
87
|
+
.includes(searchQuery.toLowerCase().replace(/\s+/g, '')) ||
|
|
88
|
+
(isNumber || isUuid
|
|
89
|
+
? option.value
|
|
90
|
+
.toLowerCase()
|
|
91
|
+
.replace(/\s+/g, '')
|
|
92
|
+
.includes(searchQuery.toLowerCase().replace(/\s+/g, ''))
|
|
93
|
+
: false));
|
|
94
|
+
}) ?? [];
|
|
91
95
|
return acc;
|
|
92
96
|
}, {});
|
|
93
97
|
const sliceSize = Math.ceil(20 / Object.keys(filteredOptions).length);
|
|
@@ -96,7 +100,9 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
96
100
|
filteredOptions[key] = filteredOptions[key].slice(0, sliceSize);
|
|
97
101
|
}
|
|
98
102
|
});
|
|
99
|
-
return Object.fromEntries(Object.entries(filteredOptions)
|
|
103
|
+
return Object.fromEntries(Object.entries(filteredOptions)
|
|
104
|
+
.filter(([, value]) => !!value?.length)
|
|
105
|
+
.sort(([key]) => (key === owner ? -1 : 1)));
|
|
100
106
|
}, [options, searchQuery]);
|
|
101
107
|
const filteredLength = react_1.default.useMemo(() => {
|
|
102
108
|
return Object.values(filteredItems).reduce((a, b) => a + b.length, 0);
|
|
@@ -128,7 +134,7 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
128
134
|
borderRadius: '6px',
|
|
129
135
|
width: width,
|
|
130
136
|
minWidth: width,
|
|
131
|
-
...style
|
|
137
|
+
...style,
|
|
132
138
|
}, children: [label && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
133
139
|
fontSize: 14,
|
|
134
140
|
color: theme?.secondaryTextColor,
|
|
@@ -194,8 +200,7 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
194
200
|
height: 9,
|
|
195
201
|
width: 230,
|
|
196
202
|
borderTop: '1px solid #e7e7e7',
|
|
197
|
-
} })] })), !isLoading &&
|
|
198
|
-
(!filteredItems || filteredLength === 0) && ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
203
|
+
} })] })), !isLoading && (!filteredItems || filteredLength === 0) && ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
199
204
|
display: 'flex',
|
|
200
205
|
alignItems: 'center',
|
|
201
206
|
padding: 8,
|
|
@@ -225,7 +230,7 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
225
230
|
whiteSpace: 'nowrap',
|
|
226
231
|
overflow: 'hidden',
|
|
227
232
|
cursor: 'default',
|
|
228
|
-
}, children: emptyLabel ?? 'No options available' })] })), !isLoading ? Object.keys(filteredItems).map((key) => ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("button", { style: {
|
|
233
|
+
}, children: emptyLabel ?? 'No options available' })] })), !isLoading ? (Object.keys(filteredItems).map((key) => ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsxs)("button", { style: {
|
|
229
234
|
display: 'flex',
|
|
230
235
|
alignItems: 'center',
|
|
231
236
|
padding: 8,
|
|
@@ -245,7 +250,8 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
245
250
|
overflow: 'hidden',
|
|
246
251
|
}, className: "quill-option", onClick: () => {
|
|
247
252
|
const updatedValue = options[key]?.length === value[key]?.length
|
|
248
|
-
? []
|
|
253
|
+
? []
|
|
254
|
+
: (options[key]?.map((option) => option.value) ?? []);
|
|
249
255
|
const updatedChangeEvent = {
|
|
250
256
|
target: {
|
|
251
257
|
value: {
|
|
@@ -268,7 +274,7 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
268
274
|
whiteSpace: 'nowrap',
|
|
269
275
|
overflow: 'hidden',
|
|
270
276
|
fontWeight: 600,
|
|
271
|
-
}, children: sectionHeaderMap?.[key] ?? key })] },
|
|
277
|
+
}, children: sectionHeaderMap?.[key] ?? key })] }, 'sh-' + key), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
272
278
|
height: 1,
|
|
273
279
|
borderTop: '1px solid #e7e7e7',
|
|
274
280
|
marginTop: 2,
|
|
@@ -313,11 +319,15 @@ function QuillMultiSelectSectionList({ options, width, onChange, label, sectionH
|
|
|
313
319
|
.quill-option:hover {
|
|
314
320
|
background: #F4F4F5;
|
|
315
321
|
}
|
|
316
|
-
` }), (0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: value[key]?.includes(option.value) ?? false, style: {
|
|
322
|
+
` }), (0, jsx_runtime_1.jsx)("input", { type: "checkbox", checked: value[key]?.includes(option.value) ?? false, style: {
|
|
323
|
+
width: '14px',
|
|
324
|
+
height: '14px',
|
|
325
|
+
margin: 'auto 0',
|
|
326
|
+
}, readOnly: true }), (0, jsx_runtime_1.jsx)("span", { style: {
|
|
317
327
|
textOverflow: 'ellipsis',
|
|
318
328
|
whiteSpace: 'nowrap',
|
|
319
329
|
overflow: 'hidden',
|
|
320
|
-
}, children: option.label })] },
|
|
330
|
+
}, children: option.label })] }, 'v-' + key + '-' + option.value)))] }, 'sp-' + key)))) : ((0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)(UiComponents_1.LoadingSpinner, {}) }))] }))] }));
|
|
321
331
|
}
|
|
322
332
|
const ListboxTextInput = ({ value, onChange, placeholder, }) => {
|
|
323
333
|
return ((0, jsx_runtime_1.jsxs)("div", { style: {
|