@quillsql/react 2.13.38 → 2.13.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +0 -1
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +73 -66
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +69 -51
- package/dist/cjs/components/Chart/ChartTooltip.d.ts +1 -1
- package/dist/cjs/components/Chart/ChartTooltip.d.ts.map +1 -1
- package/dist/cjs/components/Chart/ChartTooltip.js +3 -3
- package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/LineChart.js +4 -4
- package/dist/cjs/components/QuillMultiSelectSectionList.js +5 -5
- package/dist/cjs/components/ReportBuilder/convert.d.ts +1 -1
- package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/convert.js +73 -21
- package/dist/cjs/components/UiComponents.d.ts +2 -1
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +11 -4
- package/dist/cjs/hooks/useExport.d.ts.map +1 -1
- package/dist/cjs/hooks/useExport.js +4 -5
- package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts +19 -11
- package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotForm.js +62 -48
- package/dist/cjs/internals/ReportBuilder/PivotList.js +5 -4
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +28 -31
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +315 -633
- package/dist/cjs/models/Pivot.d.ts +27 -7
- package/dist/cjs/models/Pivot.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.d.ts.map +1 -1
- package/dist/cjs/utils/dashboard.js +36 -11
- package/dist/cjs/utils/merge.d.ts.map +1 -1
- package/dist/cjs/utils/merge.js +2 -1
- package/dist/cjs/utils/pivotConstructor.d.ts +1 -0
- package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/pivotConstructor.js +39 -8
- package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/pivotProcessing.js +10 -14
- package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
- package/dist/cjs/utils/queryConstructor.js +421 -134
- package/dist/cjs/utils/report.d.ts.map +1 -1
- package/dist/cjs/utils/report.js +2 -2
- package/dist/cjs/utils/textProcessing.d.ts +1 -1
- package/dist/cjs/utils/textProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/textProcessing.js +3 -0
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +0 -1
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +73 -66
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +69 -51
- package/dist/esm/components/Chart/ChartTooltip.d.ts +1 -1
- package/dist/esm/components/Chart/ChartTooltip.d.ts.map +1 -1
- package/dist/esm/components/Chart/ChartTooltip.js +3 -3
- package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/LineChart.js +4 -4
- package/dist/esm/components/QuillMultiSelectSectionList.js +5 -5
- package/dist/esm/components/ReportBuilder/convert.d.ts +1 -1
- package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/convert.js +74 -22
- package/dist/esm/components/UiComponents.d.ts +2 -1
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +11 -4
- package/dist/esm/hooks/useExport.d.ts.map +1 -1
- package/dist/esm/hooks/useExport.js +4 -5
- package/dist/esm/internals/ReportBuilder/PivotForm.d.ts +19 -11
- package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotForm.js +63 -49
- package/dist/esm/internals/ReportBuilder/PivotList.js +5 -4
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +28 -31
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +327 -635
- package/dist/esm/models/Pivot.d.ts +27 -7
- package/dist/esm/models/Pivot.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.d.ts.map +1 -1
- package/dist/esm/utils/dashboard.js +36 -11
- package/dist/esm/utils/merge.d.ts.map +1 -1
- package/dist/esm/utils/merge.js +2 -1
- package/dist/esm/utils/pivotConstructor.d.ts +1 -0
- package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
- package/dist/esm/utils/pivotConstructor.js +39 -9
- package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/esm/utils/pivotProcessing.js +10 -14
- package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
- package/dist/esm/utils/queryConstructor.js +421 -134
- package/dist/esm/utils/report.d.ts.map +1 -1
- package/dist/esm/utils/report.js +2 -2
- package/dist/esm/utils/textProcessing.d.ts +1 -1
- package/dist/esm/utils/textProcessing.d.ts.map +1 -1
- package/dist/esm/utils/textProcessing.js +3 -0
- package/package.json +1 -1
|
@@ -113,7 +113,7 @@ const MemoizedButton = ({ label, onClick, disabled, icon, tooltipText, isLoading
|
|
|
113
113
|
}, children: [icon, label] })] }) }));
|
|
114
114
|
};
|
|
115
115
|
exports.MemoizedButton = MemoizedButton;
|
|
116
|
-
const MemoizedSecondaryButton = ({ label, onClick, icon, disabled, tooltipText, }) => {
|
|
116
|
+
const MemoizedSecondaryButton = ({ label, onClick, icon, disabled, tooltipText, width, }) => {
|
|
117
117
|
const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
|
|
118
118
|
return ((0, jsx_runtime_1.jsx)(exports.QuillToolTip, { enabled: !!tooltipText && tooltipText !== '', text: tooltipText ?? '', children: (0, jsx_runtime_1.jsxs)("button", { className: "quill-secondary-button", onClick: onClick, style: {
|
|
119
119
|
fontFamily: theme?.fontFamily,
|
|
@@ -124,7 +124,7 @@ const MemoizedSecondaryButton = ({ label, onClick, icon, disabled, tooltipText,
|
|
|
124
124
|
borderRadius: '6px',
|
|
125
125
|
paddingLeft: '16px',
|
|
126
126
|
paddingRight: '16px',
|
|
127
|
-
boxSizing: 'content-box',
|
|
127
|
+
boxSizing: width ? 'border-box' : 'content-box',
|
|
128
128
|
fontSize: '14px',
|
|
129
129
|
cursor: 'pointer',
|
|
130
130
|
whiteSpace: 'nowrap',
|
|
@@ -132,6 +132,7 @@ const MemoizedSecondaryButton = ({ label, onClick, icon, disabled, tooltipText,
|
|
|
132
132
|
flexDirection: 'row',
|
|
133
133
|
alignItems: 'center',
|
|
134
134
|
gap: 6,
|
|
135
|
+
width: width,
|
|
135
136
|
}, disabled: disabled, children: [(0, jsx_runtime_1.jsx)("style", { children: `
|
|
136
137
|
.quill-secondary-button {
|
|
137
138
|
background-color: white;
|
|
@@ -142,7 +143,13 @@ const MemoizedSecondaryButton = ({ label, onClick, icon, disabled, tooltipText,
|
|
|
142
143
|
.quill-secondary-button:disabled {
|
|
143
144
|
opacity: 0.5;
|
|
144
145
|
}
|
|
145
|
-
` }), icon,
|
|
146
|
+
` }), icon, (0, jsx_runtime_1.jsx)("span", { style: {
|
|
147
|
+
flexGrow: 1,
|
|
148
|
+
minWidth: 0,
|
|
149
|
+
whiteSpace: 'nowrap',
|
|
150
|
+
textOverflow: 'ellipsis',
|
|
151
|
+
overflow: 'hidden',
|
|
152
|
+
}, children: label })] }) }));
|
|
146
153
|
};
|
|
147
154
|
exports.MemoizedSecondaryButton = MemoizedSecondaryButton;
|
|
148
155
|
const MemoizedHeader = ({ label }) => {
|
|
@@ -543,7 +550,7 @@ const QuillPivotColumnContainer = ({ children, }) => {
|
|
|
543
550
|
return ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
544
551
|
display: 'flex',
|
|
545
552
|
flexDirection: 'column',
|
|
546
|
-
gap:
|
|
553
|
+
gap: 32,
|
|
547
554
|
}, children: children }));
|
|
548
555
|
};
|
|
549
556
|
exports.QuillPivotColumnContainer = QuillPivotColumnContainer;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;
|
|
1
|
+
{"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAiE/C,eAAO,MAAM,SAAS,cACT,MAAM,mEAMd;IACD,uBAAuB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,GAAG,CAAC,OAAO,CAAC;IAChE,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA;IACD,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,YAAY,EAAE,OAAO,CAAC;CAqPvB,CAAC;AAEF,UAAU,aAAa;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
|
|
@@ -15,16 +15,15 @@ const react_dom_1 = require("react-dom");
|
|
|
15
15
|
const report_1 = require("../utils/report");
|
|
16
16
|
const jspdf_1 = __importDefault(require("jspdf"));
|
|
17
17
|
const valueFormatter_1 = require("../utils/valueFormatter");
|
|
18
|
-
const merge_1 = require("../utils/merge");
|
|
19
18
|
async function getExportData(client, dashboardFilters, reportId, tenants, flags) {
|
|
20
19
|
const minimalFilters = Object.values(dashboardFilters).length
|
|
21
20
|
? Object.values(dashboardFilters).map((filter) => {
|
|
22
21
|
const newFilter = { ...filter };
|
|
23
22
|
if (newFilter.filterType === 'date_range') {
|
|
24
23
|
delete newFilter['field'];
|
|
25
|
-
delete newFilter['options'];
|
|
26
24
|
delete newFilter['selectedValue'];
|
|
27
25
|
}
|
|
26
|
+
delete newFilter['options'];
|
|
28
27
|
return newFilter;
|
|
29
28
|
})
|
|
30
29
|
: [];
|
|
@@ -243,9 +242,9 @@ sectionField, } = {}) => {
|
|
|
243
242
|
exports.useExport = useExport;
|
|
244
243
|
function QuillCustomDocumentComponent({ report }) {
|
|
245
244
|
// const [theme] = useContext(ThemeContext);
|
|
246
|
-
const chartReport =
|
|
247
|
-
|
|
248
|
-
}, [report]);
|
|
245
|
+
// const chartReport = useMemo(() => {
|
|
246
|
+
// return mergeComparisonRange(report);
|
|
247
|
+
// }, [report]);
|
|
249
248
|
return ((0, jsx_runtime_1.jsxs)("div", { style: { display: 'flex', flexDirection: 'column', margin: '2rem' }, children: [(0, jsx_runtime_1.jsx)("div", { style: { display: 'flex', flexDirection: 'row', alignItems: 'center' }, children: (0, jsx_runtime_1.jsx)("h2", { style: {
|
|
250
249
|
fontSize: 18,
|
|
251
250
|
fontWeight: '600',
|
|
@@ -1,16 +1,21 @@
|
|
|
1
1
|
import { ReactNode } from 'react';
|
|
2
2
|
import { ColumnInternal } from '../../models/Columns';
|
|
3
|
+
import { AggregationType } from '../../models/Pivot';
|
|
3
4
|
interface PivotFormProps {
|
|
4
|
-
pivotRowField:
|
|
5
|
-
setPivotRowField:
|
|
6
|
-
pivotColumnField:
|
|
7
|
-
setPivotColumnField:
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
5
|
+
pivotRowField: string | undefined;
|
|
6
|
+
setPivotRowField: (value: string | undefined) => void;
|
|
7
|
+
pivotColumnField: string | undefined;
|
|
8
|
+
setPivotColumnField: (value: string | undefined) => void;
|
|
9
|
+
pivotAggregations: Partial<{
|
|
10
|
+
aggregationType: AggregationType;
|
|
11
|
+
valueField: string;
|
|
12
|
+
valueField2: string;
|
|
13
|
+
}>[];
|
|
14
|
+
setPivotAggregations: (value: Partial<{
|
|
15
|
+
aggregationType: AggregationType;
|
|
16
|
+
valueField: string;
|
|
17
|
+
valueField2: string;
|
|
18
|
+
}>[]) => void;
|
|
14
19
|
columns: ColumnInternal[];
|
|
15
20
|
uniqueValues?: any;
|
|
16
21
|
uniqueValuesIsLoading?: boolean;
|
|
@@ -21,6 +26,9 @@ interface PivotFormProps {
|
|
|
21
26
|
disabled?: boolean;
|
|
22
27
|
icon?: ReactNode;
|
|
23
28
|
}) => JSX.Element;
|
|
29
|
+
DeleteButtonComponent: (props: {
|
|
30
|
+
onClick: () => void;
|
|
31
|
+
}) => JSX.Element;
|
|
24
32
|
SelectComponent?: any;
|
|
25
33
|
PivotColumnContainer?: (props: {
|
|
26
34
|
children: ReactNode;
|
|
@@ -28,6 +36,6 @@ interface PivotFormProps {
|
|
|
28
36
|
isLoading?: boolean;
|
|
29
37
|
pivotHint?: string;
|
|
30
38
|
}
|
|
31
|
-
export default function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField,
|
|
39
|
+
export default function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotAggregations, setPivotAggregations, columns, uniqueValues, uniqueValuesIsLoading, onDelete, SecondaryButtonComponent, SelectComponent, PivotColumnContainer, DeleteButtonComponent, isLoading, pivotHint, }: PivotFormProps): import("react/jsx-runtime").JSX.Element;
|
|
32
40
|
export {};
|
|
33
41
|
//# sourceMappingURL=PivotForm.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PivotForm.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotForm.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAmC,MAAM,OAAO,CAAC;AAG1E,OAAO,
|
|
1
|
+
{"version":3,"file":"PivotForm.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotForm.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAmC,MAAM,OAAO,CAAC;AAG1E,OAAO,EAEL,cAAc,EACf,MAAM,sBAAsB,CAAC;AAM9B,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAErD,UAAU,cAAc;IACtB,aAAa,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,gBAAgB,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IACtD,gBAAgB,EAAE,MAAM,GAAG,SAAS,CAAC;IACrC,mBAAmB,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC;IAOzD,iBAAiB,EAAE,OAAO,CAAC;QAAC,eAAe,EAAE,eAAe,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAC,CAAC,EAAE,CAAC;IAC1G,oBAAoB,EAAE,CAAC,KAAK,EAAE,OAAO,CAAC;QAAC,eAAe,EAAE,eAAe,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAC,CAAC,EAAE,KAAK,IAAI,CAAC;IAC9H,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,YAAY,CAAC,EAAE,GAAG,CAAC;IACnB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,QAAQ,CAAC,EAAE,GAAG,CAAC;IACf,wBAAwB,CAAC,EAAE,CAAC,KAAK,EAAE;QACjC,OAAO,EAAE,MAAM,IAAI,CAAC;QACpB,KAAK,EAAE,MAAM,CAAC;QACd,QAAQ,CAAC,EAAE,OAAO,CAAC;QACnB,IAAI,CAAC,EAAE,SAAS,CAAC;KAClB,KAAK,GAAG,CAAC,OAAO,CAAC;IAClB,qBAAqB,EAAE,CAAC,KAAK,EAAE;QAAE,OAAO,EAAE,MAAM,IAAI,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IACvE,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,oBAAoB,CAAC,EAAE,CAAC,KAAK,EAAE;QAAE,QAAQ,EAAE,SAAS,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IACvE,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,CAAC,OAAO,UAAU,SAAS,CAAC,EAChC,aAAa,EACb,gBAAgB,EAChB,gBAAgB,EAChB,mBAAmB,EACnB,iBAAiB,EACjB,oBAAoB,EACpB,OAAO,EACP,YAAY,EACZ,qBAAqB,EACrB,QAAQ,EACR,wBAA+C,EAC/C,eAA+C,EAC/C,oBAAgD,EAChD,qBAA4C,EAC5C,SAAS,EACT,SAAS,GACV,EAAE,cAAc,2CA0RhB"}
|
|
@@ -5,12 +5,12 @@ const jsx_runtime_1 = require("react/jsx-runtime");
|
|
|
5
5
|
const react_1 = require("react");
|
|
6
6
|
const UiComponents_1 = require("../../components/UiComponents");
|
|
7
7
|
const textProcessing_1 = require("../../utils/textProcessing");
|
|
8
|
-
|
|
8
|
+
// import { numberFormatOptions } from '../../ChartBuilder';
|
|
9
9
|
const pivotProcessing_1 = require("../../utils/pivotProcessing");
|
|
10
10
|
const ui_1 = require("../../components/ReportBuilder/ui");
|
|
11
11
|
const QuillSelectWithCombo_1 = require("../../components/QuillSelectWithCombo");
|
|
12
12
|
const Context_1 = require("../../Context");
|
|
13
|
-
function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField,
|
|
13
|
+
function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotAggregations, setPivotAggregations, columns, uniqueValues, uniqueValuesIsLoading, onDelete, SecondaryButtonComponent = ui_1.QuillSecondaryButton, SelectComponent = QuillSelectWithCombo_1.QuillSelectComponentWithCombo, PivotColumnContainer = UiComponents_1.QuillPivotColumnContainer, DeleteButtonComponent = UiComponents_1.MemoizedDeleteButton, isLoading, pivotHint, }) {
|
|
14
14
|
const [allowedColumnFields, setAllowedColumnFields] = (0, react_1.useState)([]);
|
|
15
15
|
const [allowedRowFields, setAllowedRowFields] = (0, react_1.useState)([]);
|
|
16
16
|
const [allowedValueFields, setAllowedValueFields] = (0, react_1.useState)([]);
|
|
@@ -39,52 +39,66 @@ function PivotForm({ pivotRowField, setPivotRowField, pivotColumnField, setPivot
|
|
|
39
39
|
label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(field),
|
|
40
40
|
value: field,
|
|
41
41
|
};
|
|
42
|
-
}), disabled: isLoading, width: 200 }), (0, jsx_runtime_1.
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
42
|
+
}), disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsxs)("div", { style: {
|
|
43
|
+
display: 'flex',
|
|
44
|
+
width: '100%',
|
|
45
|
+
flexDirection: 'column',
|
|
46
|
+
alignItems: 'flex-start',
|
|
47
|
+
gap: 16,
|
|
48
|
+
}, children: [pivotAggregations.map((pivotAggregation, index) => ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
49
|
+
display: 'flex',
|
|
50
|
+
gap: 8,
|
|
51
|
+
flexDirection: 'row',
|
|
52
|
+
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
53
|
+
display: 'flex',
|
|
54
|
+
alignItems: 'flex-start',
|
|
55
|
+
flexDirection: 'column',
|
|
56
|
+
gap: 6,
|
|
57
|
+
}, children: [(0, jsx_runtime_1.jsx)(SelectComponent, { label: index === 0 ? 'Aggregations' : undefined, id: "pivot-row-field", value: pivotAggregation.aggregationType, onChange: (e) => {
|
|
58
|
+
setPivotAggregations([
|
|
59
|
+
...pivotAggregations.slice(0, index),
|
|
60
|
+
{
|
|
61
|
+
...pivotAggregations[index],
|
|
62
|
+
aggregationType: e.target.value === '' ? undefined : e.target.value,
|
|
63
|
+
},
|
|
64
|
+
...pivotAggregations.slice(index + 1),
|
|
65
|
+
]);
|
|
66
|
+
}, options: [
|
|
67
|
+
...['sum', 'average', 'count', 'max', 'min', ...(pivotRowField ? ['percentage'] : [])]
|
|
68
|
+
.map((option) => {
|
|
69
|
+
return { label: option, value: option };
|
|
70
|
+
})
|
|
71
|
+
], disabled: isLoading, width: 200 }), (0, jsx_runtime_1.jsx)(SelectComponent, { id: "pivot-row-field", value: pivotAggregation.valueField, onChange: (e) => {
|
|
72
|
+
setPivotAggregations([
|
|
73
|
+
...pivotAggregations.slice(0, index),
|
|
74
|
+
{
|
|
75
|
+
...pivotAggregations[index],
|
|
76
|
+
valueField: e.target.value === '' ? undefined : e.target.value,
|
|
77
|
+
},
|
|
78
|
+
...pivotAggregations.slice(index + 1),
|
|
79
|
+
]);
|
|
80
|
+
}, isLoading: uniqueValuesIsLoading, options: allowedValueFields
|
|
81
|
+
.filter((field) => field !== pivotColumnField)
|
|
82
|
+
.map((field) => {
|
|
83
|
+
return {
|
|
84
|
+
label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(field),
|
|
85
|
+
value: field,
|
|
86
|
+
};
|
|
87
|
+
}), disabled: isLoading, width: 200 })] }, index), index !== 0 &&
|
|
88
|
+
(0, jsx_runtime_1.jsx)(DeleteButtonComponent, { onClick: () => {
|
|
89
|
+
setPivotAggregations([
|
|
90
|
+
...pivotAggregations.slice(0, index),
|
|
91
|
+
...pivotAggregations.slice(index + 1),
|
|
92
|
+
]);
|
|
93
|
+
} })] }, index))), (0, jsx_runtime_1.jsx)(SecondaryButtonComponent, { onClick: () => {
|
|
94
|
+
setPivotAggregations([
|
|
95
|
+
...pivotAggregations,
|
|
96
|
+
{
|
|
97
|
+
valueField: undefined,
|
|
98
|
+
aggregationType: undefined,
|
|
99
|
+
},
|
|
100
|
+
]);
|
|
101
|
+
}, disabled: isLoading, label: 'Add Aggregation' })] }), pivotHint && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
88
102
|
borderRadius: 8,
|
|
89
103
|
border: 'solid 1px #FFA000',
|
|
90
104
|
backgroundColor: '#FFF8E1',
|
|
@@ -41,14 +41,14 @@ const PivotCard = ({ pivotTable, index, onSelectPivot, onEditPivot, ButtonCompon
|
|
|
41
41
|
whiteSpace: 'nowrap',
|
|
42
42
|
textOverflow: 'ellipsis',
|
|
43
43
|
}, children: (0, jsx_runtime_1.jsx)(LabelComponent, { label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(pivotTable.pivot.columnField) }) }, pivotTable.pivot.columnField)), !pivotTable.pivot.columnField &&
|
|
44
|
-
pivotTable.pivot.valueField && ((0, jsx_runtime_1.jsx)("th", { style: {
|
|
44
|
+
pivotTable.pivot.aggregations?.[0]?.valueField && ((0, jsx_runtime_1.jsx)("th", { style: {
|
|
45
45
|
fontWeight: 600,
|
|
46
46
|
paddingRight: 5,
|
|
47
47
|
flex: 1,
|
|
48
48
|
textAlign: 'left',
|
|
49
49
|
whiteSpace: 'nowrap',
|
|
50
50
|
textOverflow: 'ellipsis',
|
|
51
|
-
}, children: (0, jsx_runtime_1.jsx)(LabelComponent, { label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(pivotTable.pivot.valueField) }) }, pivotTable.pivot.valueField))] }) }), (0, jsx_runtime_1.jsx)("tr", { style: {
|
|
51
|
+
}, children: (0, jsx_runtime_1.jsx)(LabelComponent, { label: (0, textProcessing_1.snakeAndCamelCaseToTitleCase)(pivotTable.pivot.aggregations?.[0]?.valueField) }) }, pivotTable.pivot.aggregations?.[0]?.valueField))] }) }), (0, jsx_runtime_1.jsx)("tr", { style: {
|
|
52
52
|
paddingLeft: '2px',
|
|
53
53
|
width: '100%',
|
|
54
54
|
}, children: (0, jsx_runtime_1.jsx)(TextComponent, { label: 'No results' }) })] })) : ((0, jsx_runtime_1.jsxs)("table", { children: [(0, jsx_runtime_1.jsx)("thead", { children: (0, jsx_runtime_1.jsx)("tr", { children: pivotTable.columns.map((column) => ((0, jsx_runtime_1.jsx)("th", { style: {
|
|
@@ -75,8 +75,9 @@ const PivotCard = ({ pivotTable, index, onSelectPivot, onEditPivot, ButtonCompon
|
|
|
75
75
|
}, children: (0, jsx_runtime_1.jsx)(TextComponent, { label: i !== 0
|
|
76
76
|
? (0, valueFormatter_1.quillFormat)({
|
|
77
77
|
value: row[column.field],
|
|
78
|
-
format:
|
|
79
|
-
|
|
78
|
+
format:
|
|
79
|
+
// pivotTable.pivot.valueFieldType ||
|
|
80
|
+
defaultValueField,
|
|
80
81
|
})
|
|
81
82
|
: row[column.field] }) }, i))) }, index)))] })] }))] }), (0, jsx_runtime_1.jsxs)("div", { style: {
|
|
82
83
|
display: 'flex',
|
|
@@ -3,23 +3,27 @@ import { ButtonComponentProps } from '../../components/UiComponents';
|
|
|
3
3
|
import { AdditionalProcessing } from '../../utils/tableProcessing';
|
|
4
4
|
import { ColumnInternal } from '../../models/Columns';
|
|
5
5
|
import { AxisFormat } from '../../Dashboard';
|
|
6
|
-
import { Pivot, PivotData } from '../../models/Pivot';
|
|
6
|
+
import { AggregationType, Pivot, PivotData } from '../../models/Pivot';
|
|
7
7
|
import { QuillProviderClient } from '../../models/Client';
|
|
8
8
|
import { QuillReportInternal } from '../../models/Report';
|
|
9
9
|
import { DashboardDateFilter } from '../../models/Filter';
|
|
10
10
|
export interface PivotModalProps {
|
|
11
|
-
pivotRowField:
|
|
12
|
-
setPivotRowField:
|
|
13
|
-
pivotColumnField:
|
|
14
|
-
setPivotColumnField:
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
11
|
+
pivotRowField: string | undefined;
|
|
12
|
+
setPivotRowField: (field: string | undefined) => void;
|
|
13
|
+
pivotColumnField: string | undefined;
|
|
14
|
+
setPivotColumnField: (field: string | undefined) => void;
|
|
15
|
+
pivotAggregations: Partial<{
|
|
16
|
+
valueField?: string;
|
|
17
|
+
valueField2?: string;
|
|
18
|
+
aggregationType: AggregationType;
|
|
19
|
+
}>[];
|
|
20
|
+
setPivotAggregations: (aggregations: Partial<{
|
|
21
|
+
valueField?: string;
|
|
22
|
+
valueField2?: string;
|
|
23
|
+
aggregationType: AggregationType;
|
|
24
|
+
}>[]) => void;
|
|
25
|
+
popUpTitle: string;
|
|
26
|
+
setPopUpTitle: (title: string) => void;
|
|
23
27
|
selectedTable: any;
|
|
24
28
|
SelectComponent: any;
|
|
25
29
|
ButtonComponent: any;
|
|
@@ -36,6 +40,12 @@ export interface PivotModalProps {
|
|
|
36
40
|
HeaderComponent: (props: {
|
|
37
41
|
label: string;
|
|
38
42
|
}) => JSX.Element;
|
|
43
|
+
SubheaderComponent: (props: {
|
|
44
|
+
label: string;
|
|
45
|
+
}) => JSX.Element;
|
|
46
|
+
DeleteButtonComponent: (props: {
|
|
47
|
+
onClick: () => void;
|
|
48
|
+
}) => JSX.Element;
|
|
39
49
|
LabelComponent: (props: {
|
|
40
50
|
label: string;
|
|
41
51
|
}) => JSX.Element;
|
|
@@ -56,13 +66,13 @@ export interface PivotModalProps {
|
|
|
56
66
|
setSelectedPivotIndex: any;
|
|
57
67
|
removePivot: any;
|
|
58
68
|
selectPivot: any;
|
|
59
|
-
showUpdatePivot:
|
|
60
|
-
setShowUpdatePivot:
|
|
69
|
+
showUpdatePivot: boolean;
|
|
70
|
+
setShowUpdatePivot: (showUpdatePivot: boolean) => void;
|
|
61
71
|
data: any;
|
|
62
72
|
columns: ColumnInternal[];
|
|
63
73
|
theme: any;
|
|
64
|
-
isOpen:
|
|
65
|
-
setIsOpen:
|
|
74
|
+
isOpen: boolean;
|
|
75
|
+
setIsOpen: (isOpen: boolean) => void;
|
|
66
76
|
dateRange: any;
|
|
67
77
|
createdPivots: any;
|
|
68
78
|
setCreatedPivots: any;
|
|
@@ -86,7 +96,7 @@ export interface PivotModalProps {
|
|
|
86
96
|
dashboardName?: string;
|
|
87
97
|
dateFilter?: DashboardDateFilter;
|
|
88
98
|
}
|
|
89
|
-
export declare const PivotModal: ({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField,
|
|
99
|
+
export declare const PivotModal: ({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotAggregations, setPivotAggregations, popUpTitle, setPopUpTitle, selectedTable, SelectComponent, ButtonComponent, SecondaryButtonComponent, PopoverComponent, ErrorMessageComponent, PivotRowContainer, PivotColumnContainer, LoadingComponent, CardComponent, HeaderComponent, SubheaderComponent, DeleteButtonComponent, LabelComponent, TextComponent, selectedPivotIndex, setSelectedPivotIndex, removePivot, selectPivot, showUpdatePivot, setShowUpdatePivot, data, columns, theme, isOpen, setIsOpen, dateRange, createdPivots, setCreatedPivots, recommendedPivots, setRecommendedPivots, triggerButtonText, showPivotEditButton, showEditOnPivotClick, showTrigger, pivotCountRequest, query, initialUniqueValues, uniqueValuesIsLoading, initialSelectedPivotTable, disabled, pivotRecommendationsEnabled, report, dashboardName, dateFilter, }: PivotModalProps) => import("react/jsx-runtime").JSX.Element;
|
|
90
100
|
export declare function generatePivotTableYAxis(pivot: Pivot, cols: {
|
|
91
101
|
label: string;
|
|
92
102
|
field: string;
|
|
@@ -130,17 +140,4 @@ export declare function generatePivotTable({ pivot, dateBucket, dateFilter, repo
|
|
|
130
140
|
}[] | (string | number)[];
|
|
131
141
|
additionalProcessing?: AdditionalProcessing;
|
|
132
142
|
}): Promise<PivotData>;
|
|
133
|
-
export declare function generatePivotTableInMemory(pivot: Pivot, data: any[], dateRange: {
|
|
134
|
-
start: Date;
|
|
135
|
-
end: Date;
|
|
136
|
-
} | undefined, isComparison: boolean, rowLimit?: number, compRange?: {
|
|
137
|
-
start: Date;
|
|
138
|
-
end: Date;
|
|
139
|
-
} | undefined, dateBucket?: string, uniqueValues?: any): {
|
|
140
|
-
rows: any[];
|
|
141
|
-
columns: {
|
|
142
|
-
label: string;
|
|
143
|
-
field: any;
|
|
144
|
-
}[];
|
|
145
|
-
};
|
|
146
143
|
//# sourceMappingURL=PivotModal.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAOZ,SAAS,EACV,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"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"}
|