@quillsql/react 2.11.16 → 2.11.18
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 +109 -42
- package/dist/cjs/Chart.d.ts.map +1 -1
- package/dist/cjs/Chart.js +44 -18
- package/dist/cjs/ChartBuilder.d.ts +204 -30
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +124 -63
- package/dist/cjs/ChartEditor.d.ts +123 -19
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +47 -15
- package/dist/cjs/Dashboard.d.ts +148 -91
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +51 -159
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts +21 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +5 -2
- package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/cjs/QuillProvider.d.ts +105 -2
- package/dist/cjs/QuillProvider.d.ts.map +1 -1
- package/dist/cjs/QuillProvider.js +59 -0
- package/dist/cjs/ReportBuilder.d.ts +194 -42
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +563 -416
- package/dist/cjs/SQLEditor.d.ts +160 -23
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +36 -30
- package/dist/cjs/Table.d.ts +119 -15
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +37 -6
- package/dist/cjs/TableChart.d.ts.map +1 -1
- package/dist/cjs/TableChart.js +0 -194
- package/dist/cjs/{BarList.d.ts → components/Chart/BarList.d.ts} +1 -1
- package/dist/cjs/components/Chart/BarList.d.ts.map +1 -0
- package/dist/cjs/{BarList.js → components/Chart/BarList.js} +1 -1
- package/dist/cjs/components/Chart/LineChart.d.ts +2 -3
- package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/cjs/components/Chart/LineChart.js +3 -3
- package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -0
- package/dist/cjs/{PieChart.js → components/Chart/PieChart.js} +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts +2 -1
- package/dist/cjs/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/ChartComponent.js +6 -7
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +22 -0
- package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -0
- package/dist/cjs/components/Dashboard/DashboardFilter.js +75 -0
- package/dist/cjs/components/Dashboard/DataLoader.d.ts +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts +2 -12
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.js +39 -17
- package/dist/cjs/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.js +6 -9
- package/dist/cjs/components/QuillCard.d.ts +2 -7
- package/dist/cjs/components/QuillCard.d.ts.map +1 -1
- package/dist/cjs/components/QuillCard.js +15 -9
- package/dist/cjs/components/QuillSelect.d.ts +4 -1
- package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
- package/dist/cjs/components/QuillSelect.js +13 -8
- package/dist/cjs/components/QuillTable.d.ts +16 -2
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +4 -4
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts +9 -3
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddColumnPopover.js +10 -6
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts +13 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +5 -15
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts +21 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/AddSortPopover.js +15 -17
- package/dist/cjs/components/ReportBuilder/bigDateMap.js +1 -1
- package/dist/cjs/components/ReportBuilder/convert.d.ts +3 -1
- package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/convert.js +60 -21
- package/dist/cjs/components/ReportBuilder/operators.d.ts +15 -10
- package/dist/cjs/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/operators.js +23 -10
- package/dist/cjs/components/ReportBuilder/pivot.d.ts +2 -1
- package/dist/cjs/components/ReportBuilder/pivot.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.d.ts +82 -18
- package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/ui.js +55 -103
- package/dist/cjs/components/ReportBuilder/util.d.ts +10 -4
- package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/cjs/components/ReportBuilder/util.js +124 -71
- package/dist/cjs/components/UiComponents.d.ts +81 -87
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +76 -103
- package/dist/cjs/hooks/index.d.ts +1 -0
- package/dist/cjs/hooks/index.d.ts.map +1 -1
- package/dist/cjs/hooks/index.js +3 -1
- package/dist/cjs/hooks/useTheme.d.ts +7 -0
- package/dist/cjs/hooks/useTheme.d.ts.map +1 -0
- package/dist/cjs/hooks/useTheme.js +12 -0
- package/dist/cjs/index.d.ts +10 -2
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts +5 -2
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.js +21 -21
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +30 -14
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +77 -52
- package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
- package/dist/cjs/utils/dataFetcher.js +2 -0
- package/dist/cjs/utils/parserBigQuery.d.ts +6 -0
- package/dist/cjs/utils/parserBigQuery.d.ts.map +1 -0
- package/dist/cjs/utils/parserBigQuery.js +60 -0
- package/dist/cjs/utils/parserPostgres.d.ts +3 -0
- package/dist/cjs/utils/parserPostgres.d.ts.map +1 -0
- package/dist/cjs/utils/parserPostgres.js +42 -0
- package/dist/esm/Chart.d.ts +109 -42
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +45 -19
- package/dist/esm/ChartBuilder.d.ts +204 -30
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +124 -63
- package/dist/esm/ChartEditor.d.ts +123 -19
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +51 -19
- package/dist/esm/Dashboard.d.ts +148 -91
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +54 -160
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts +21 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
- package/dist/esm/DateRangePicker/QuillDateRangePicker.js +6 -3
- package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -1
- package/dist/esm/QuillProvider.d.ts +105 -2
- package/dist/esm/QuillProvider.d.ts.map +1 -1
- package/dist/esm/QuillProvider.js +59 -0
- package/dist/esm/ReportBuilder.d.ts +194 -42
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +566 -419
- package/dist/esm/SQLEditor.d.ts +160 -23
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +36 -30
- package/dist/esm/Table.d.ts +119 -15
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +38 -7
- package/dist/esm/TableChart.d.ts.map +1 -1
- package/dist/esm/TableChart.js +0 -194
- package/dist/esm/{BarList.d.ts → components/Chart/BarList.d.ts} +1 -1
- package/dist/esm/components/Chart/BarList.d.ts.map +1 -0
- package/dist/esm/{BarList.js → components/Chart/BarList.js} +1 -1
- package/dist/esm/components/Chart/LineChart.d.ts +2 -3
- package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
- package/dist/esm/components/Chart/LineChart.js +3 -3
- package/dist/esm/components/Chart/PieChart.d.ts.map +1 -0
- package/dist/esm/{PieChart.js → components/Chart/PieChart.js} +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.d.ts +2 -1
- package/dist/esm/components/Dashboard/ChartComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/ChartComponent.js +5 -6
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts +22 -0
- package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -0
- package/dist/esm/components/Dashboard/DashboardFilter.js +71 -0
- package/dist/esm/components/Dashboard/DataLoader.d.ts +1 -1
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.d.ts +2 -12
- package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.js +39 -17
- package/dist/esm/components/Dashboard/TableComponent.d.ts +2 -1
- package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/TableComponent.js +6 -9
- package/dist/esm/components/QuillCard.d.ts +2 -7
- package/dist/esm/components/QuillCard.d.ts.map +1 -1
- package/dist/esm/components/QuillCard.js +15 -9
- package/dist/esm/components/QuillSelect.d.ts +4 -1
- package/dist/esm/components/QuillSelect.d.ts.map +1 -1
- package/dist/esm/components/QuillSelect.js +14 -9
- package/dist/esm/components/QuillTable.d.ts +16 -2
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +4 -4
- package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts +9 -3
- package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddColumnPopover.js +10 -6
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts +13 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddLimitPopover.js +5 -15
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts +21 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/AddSortPopover.js +17 -19
- package/dist/esm/components/ReportBuilder/bigDateMap.js +1 -1
- package/dist/esm/components/ReportBuilder/convert.d.ts +3 -1
- package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/convert.js +51 -13
- package/dist/esm/components/ReportBuilder/operators.d.ts +15 -10
- package/dist/esm/components/ReportBuilder/operators.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/operators.js +23 -10
- package/dist/esm/components/ReportBuilder/pivot.d.ts +2 -1
- package/dist/esm/components/ReportBuilder/pivot.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.d.ts +82 -18
- package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/ui.js +53 -101
- package/dist/esm/components/ReportBuilder/util.d.ts +10 -4
- package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -1
- package/dist/esm/components/ReportBuilder/util.js +114 -67
- package/dist/esm/components/UiComponents.d.ts +81 -87
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +71 -102
- package/dist/esm/hooks/index.d.ts +1 -0
- package/dist/esm/hooks/index.d.ts.map +1 -1
- package/dist/esm/hooks/index.js +1 -0
- package/dist/esm/hooks/useTheme.d.ts +7 -0
- package/dist/esm/hooks/useTheme.d.ts.map +1 -0
- package/dist/esm/hooks/useTheme.js +10 -0
- package/dist/esm/index.d.ts +10 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts +5 -2
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.js +21 -21
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +30 -14
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +77 -52
- package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
- package/dist/esm/utils/dataFetcher.js +2 -0
- package/dist/esm/utils/parserBigQuery.d.ts +6 -0
- package/dist/esm/utils/parserBigQuery.d.ts.map +1 -0
- package/dist/esm/utils/parserBigQuery.js +52 -0
- package/dist/esm/utils/parserPostgres.d.ts +3 -0
- package/dist/esm/utils/parserPostgres.d.ts.map +1 -0
- package/dist/esm/utils/parserPostgres.js +37 -0
- package/package.json +1 -1
- package/dist/cjs/BarList.d.ts.map +0 -1
- package/dist/cjs/PieChart.d.ts.map +0 -1
- package/dist/esm/BarList.d.ts.map +0 -1
- package/dist/esm/PieChart.d.ts.map +0 -1
- /package/dist/cjs/{PieChart.d.ts → components/Chart/PieChart.d.ts} +0 -0
- /package/dist/esm/{PieChart.d.ts → components/Chart/PieChart.d.ts} +0 -0
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
-
|
|
2
|
+
// @ts-nocheck
|
|
3
3
|
import { quillFormat } from '../../utils/valueFormatter';
|
|
4
4
|
import { snakeCaseToTitleCase } from '../../utils/textProcessing';
|
|
5
|
-
|
|
5
|
+
import { QuillCard } from '../../components/QuillCard';
|
|
6
|
+
export const PivotCard = ({ pivotTable, theme, index, onSelectPivot, selectedPivotIndex, onEditPivot, ButtonComponent, showEdit = false, clickable = true, onClose = () => { }, minHeight = 0, CardComponent = QuillCard, LabelComponent, TextComponent, HeaderComponent, }) => {
|
|
6
7
|
const maxRowsInPivotPeak = 5;
|
|
7
|
-
return (_jsx(
|
|
8
|
+
return (_jsx(CardComponent, { onClick: () => onSelectPivot(pivotTable.pivot, index), onDelete: onClose, children: _jsxs("div", { style: {
|
|
8
9
|
fontSize: 14,
|
|
9
10
|
display: 'flex',
|
|
10
11
|
flexDirection: 'column',
|
|
@@ -18,21 +19,21 @@ export const PivotCard = ({ pivotTable, theme, index, onSelectPivot, selectedPiv
|
|
|
18
19
|
whiteSpace: 'nowrap',
|
|
19
20
|
textOverflow: 'ellipsis',
|
|
20
21
|
paddingBottom: 6,
|
|
21
|
-
}, children: _jsx(HeaderComponent, {
|
|
22
|
+
}, children: _jsx(HeaderComponent, { label: pivotTable.pivot.title }) })), pivotTable.columns.length === 0 ? (_jsxs("table", { children: [_jsx("thead", { children: _jsxs("tr", { children: [pivotTable.pivot.rowField && (_jsx("th", { style: {
|
|
22
23
|
fontWeight: 600,
|
|
23
24
|
paddingRight: 5,
|
|
24
25
|
flex: 1,
|
|
25
26
|
textAlign: 'left',
|
|
26
27
|
whiteSpace: 'nowrap',
|
|
27
28
|
textOverflow: 'ellipsis',
|
|
28
|
-
}, children: _jsx(LabelComponent, {
|
|
29
|
+
}, children: _jsx(LabelComponent, { label: snakeCaseToTitleCase(pivotTable.pivot.rowField) }) }, pivotTable.pivot.rowField)), pivotTable.pivot.columnField && (_jsx("th", { style: {
|
|
29
30
|
fontWeight: 600,
|
|
30
31
|
paddingRight: 5,
|
|
31
32
|
flex: 1,
|
|
32
33
|
textAlign: 'left',
|
|
33
34
|
whiteSpace: 'nowrap',
|
|
34
35
|
textOverflow: 'ellipsis',
|
|
35
|
-
}, children: _jsx(LabelComponent, {
|
|
36
|
+
}, children: _jsx(LabelComponent, { label: snakeCaseToTitleCase(pivotTable.pivot.columnField) }) }, pivotTable.pivot.columnField)), !pivotTable.pivot.columnField &&
|
|
36
37
|
pivotTable.pivot.valueField && (_jsx("th", { style: {
|
|
37
38
|
fontWeight: 600,
|
|
38
39
|
paddingRight: 5,
|
|
@@ -40,24 +41,24 @@ export const PivotCard = ({ pivotTable, theme, index, onSelectPivot, selectedPiv
|
|
|
40
41
|
textAlign: 'left',
|
|
41
42
|
whiteSpace: 'nowrap',
|
|
42
43
|
textOverflow: 'ellipsis',
|
|
43
|
-
}, children: _jsx(LabelComponent, {
|
|
44
|
+
}, children: _jsx(LabelComponent, { label: snakeCaseToTitleCase(pivotTable.pivot.valueField) }) }, pivotTable.pivot.valueField))] }) }), _jsx("div", { style: {
|
|
44
45
|
paddingLeft: '2px',
|
|
45
46
|
width: '100%',
|
|
46
|
-
}, children: _jsx(TextComponent, {
|
|
47
|
+
}, children: _jsx(TextComponent, { label: 'No results' }) })] })) : (_jsxs("table", { children: [_jsx("thead", { children: _jsx("tr", { children: pivotTable.columns.map((column) => (_jsx("th", { style: {
|
|
47
48
|
fontWeight: 600,
|
|
48
49
|
paddingRight: 5,
|
|
49
50
|
flex: 1,
|
|
50
51
|
textAlign: 'left',
|
|
51
52
|
whiteSpace: 'nowrap',
|
|
52
53
|
textOverflow: 'ellipsis',
|
|
53
|
-
}, children: _jsx(LabelComponent, {
|
|
54
|
+
}, children: _jsx(LabelComponent, { label: column.label }) }, column.field))) }) }), _jsx("tbody", { children: pivotTable.rows
|
|
54
55
|
.slice(0, maxRowsInPivotPeak)
|
|
55
56
|
.map((row, index) => (_jsx("tr", { children: pivotTable.columns.map((colum, i) => (_jsx("td", { style: {
|
|
56
57
|
paddingRight: 5,
|
|
57
58
|
flex: 1,
|
|
58
59
|
whiteSpace: 'nowrap',
|
|
59
60
|
textOverflow: 'ellipsis',
|
|
60
|
-
}, children: _jsx(TextComponent, {
|
|
61
|
+
}, children: _jsx(TextComponent, { label: pivotTable.pivot.valueFieldType && i !== 0
|
|
61
62
|
? quillFormat({
|
|
62
63
|
value: row[colum.field],
|
|
63
64
|
format: pivotTable.pivot.valueFieldType,
|
|
@@ -65,24 +66,23 @@ export const PivotCard = ({ pivotTable, theme, index, onSelectPivot, selectedPiv
|
|
|
65
66
|
: row[colum.field] }) }, i))) }, index))) })] }))] }), _jsxs("div", { style: {
|
|
66
67
|
display: 'flex',
|
|
67
68
|
justifyContent: 'space-between',
|
|
68
|
-
}, children: [pivotTable.rows.length > maxRowsInPivotPeak ? (_jsx("div", { children:
|
|
69
|
-
|
|
70
|
-
|
|
69
|
+
}, children: [pivotTable.rows.length > maxRowsInPivotPeak ? (_jsx("div", { children: _jsx(TextComponent, { label: `... ${pivotTable.rows.length - maxRowsInPivotPeak < 5
|
|
70
|
+
? ''
|
|
71
|
+
: pivotTable.rows.length - maxRowsInPivotPeak} more rows` }) })) : (_jsx("div", {})), showEdit && (_jsx("div", { children: _jsx(ButtonComponent, { id: "edit-pivot", primary: false, onClick: (e) => {
|
|
71
72
|
e.stopPropagation();
|
|
72
73
|
onEditPivot(pivotTable.pivot, index);
|
|
73
74
|
}, label: 'Edit' }) }))] })] }) }));
|
|
74
75
|
};
|
|
75
|
-
export const PivotList = ({ recommendedPivotTables, createdPivotTables, onSelectRecommendedPivot, onSelectCreatedPivot, theme, selectedPivotIndex, selectedPivotType, ButtonComponent, showCreatePivot = false, onEditRecommendedPivot, onEditCreatedPivot, showPivotEditButton = false, LabelComponent, TextComponent, HeaderComponent, }) => {
|
|
76
|
+
export const PivotList = ({ recommendedPivotTables, createdPivotTables, onSelectRecommendedPivot, onSelectCreatedPivot, theme, selectedPivotIndex, selectedPivotType, ButtonComponent, showCreatePivot = false, onEditRecommendedPivot, onEditCreatedPivot, showPivotEditButton = false, CardComponent = QuillCard, LabelComponent, TextComponent, HeaderComponent, }) => {
|
|
76
77
|
return (_jsx("div", { children: _jsxs("div", { style: {
|
|
77
78
|
display: 'grid',
|
|
78
79
|
gridTemplateColumns: 'repeat(2, 1fr)',
|
|
79
80
|
gap: 16,
|
|
80
81
|
gridAutoRows: '220px',
|
|
81
|
-
}, children: [recommendedPivotTables.map((pivotTable, index) => (_jsx(PivotCard, { pivotTable: pivotTable, theme: theme, index: index, onSelectPivot: onSelectRecommendedPivot, selectedPivotIndex: selectedPivotType === 'recommended' ? selectedPivotIndex : -1, onEditPivot: onEditRecommendedPivot, ButtonComponent: ButtonComponent, showPivotEditButton: showPivotEditButton, minHeight: 180, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }, index))), createdPivotTables.map((pivotTable, index) => (_jsx(PivotCard, { pivotTable: pivotTable, theme: theme, index: index, onSelectPivot: onSelectCreatedPivot, selectedPivotIndex: selectedPivotType === 'created' ? selectedPivotIndex : -1, onEditPivot: onEditCreatedPivot, ButtonComponent: ButtonComponent, showPivotEditButton: showPivotEditButton, minHeight: 180, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }, index))), showCreatePivot && (_jsx(
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
}, children: "Create pivot +" }))] }) }));
|
|
82
|
+
}, children: [recommendedPivotTables.map((pivotTable, index) => (_jsx(PivotCard, { pivotTable: pivotTable, theme: theme, index: index, onSelectPivot: onSelectRecommendedPivot, selectedPivotIndex: selectedPivotType === 'recommended' ? selectedPivotIndex : -1, onEditPivot: onEditRecommendedPivot, ButtonComponent: ButtonComponent, showPivotEditButton: showPivotEditButton, minHeight: 180, CardComponent: CardComponent, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }, index))), createdPivotTables.map((pivotTable, index) => (_jsx(PivotCard, { pivotTable: pivotTable, theme: theme, index: index, onSelectPivot: onSelectCreatedPivot, selectedPivotIndex: selectedPivotType === 'created' ? selectedPivotIndex : -1, onEditPivot: onEditCreatedPivot, ButtonComponent: ButtonComponent, showPivotEditButton: showPivotEditButton, minHeight: 180, CardComponent: CardComponent, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }, index))), showCreatePivot && (_jsx(CardComponent, { onClick: () => onEditCreatedPivot({}, null), children: _jsx("div", { style: {
|
|
83
|
+
display: 'flex',
|
|
84
|
+
justifyContent: 'center',
|
|
85
|
+
alignItems: 'center',
|
|
86
|
+
width: '100%',
|
|
87
|
+
}, children: "Create pivot +" }) }))] }) }));
|
|
88
88
|
};
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { ButtonComponentProps } from '../../components/UiComponents';
|
|
1
3
|
export interface Pivot {
|
|
2
4
|
rowField: string;
|
|
3
5
|
rowFieldType: string;
|
|
@@ -8,7 +10,7 @@ export interface Pivot {
|
|
|
8
10
|
title?: string;
|
|
9
11
|
triggerButtonText?: string;
|
|
10
12
|
}
|
|
11
|
-
export
|
|
13
|
+
export interface PivotModalProps {
|
|
12
14
|
pivotRowField: any;
|
|
13
15
|
setPivotRowField: any;
|
|
14
16
|
pivotColumnField: any;
|
|
@@ -22,11 +24,24 @@ export declare const PivotModal: ({ pivotRowField, setPivotRowField, pivotColumn
|
|
|
22
24
|
selectedTable: any;
|
|
23
25
|
SelectComponent: any;
|
|
24
26
|
ButtonComponent: any;
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
CardComponent: any;
|
|
28
|
+
SecondaryButtonComponent: (props: ButtonComponentProps) => JSX.Element;
|
|
29
|
+
PopoverComponent: (props: {
|
|
30
|
+
isOpen: boolean;
|
|
31
|
+
setIsOpen: (isOpen: boolean) => void;
|
|
32
|
+
triggerLabel?: string | undefined;
|
|
33
|
+
popoverTitle?: string | undefined;
|
|
34
|
+
popoverChildren: ReactNode;
|
|
35
|
+
}) => JSX.Element;
|
|
36
|
+
HeaderComponent: (props: {
|
|
37
|
+
label: string;
|
|
38
|
+
}) => JSX.Element;
|
|
39
|
+
LabelComponent: (props: {
|
|
40
|
+
label: string;
|
|
41
|
+
}) => JSX.Element;
|
|
42
|
+
TextComponent: (props: {
|
|
43
|
+
label: string;
|
|
44
|
+
}) => JSX.Element;
|
|
30
45
|
selectedPivotIndex: any;
|
|
31
46
|
setSelectedPivotIndex: any;
|
|
32
47
|
removePivot: any;
|
|
@@ -43,15 +58,16 @@ export declare const PivotModal: ({ pivotRowField, setPivotRowField, pivotColumn
|
|
|
43
58
|
setCreatedPivots: any;
|
|
44
59
|
recommendedPivots: any;
|
|
45
60
|
setRecommendedPivots: any;
|
|
46
|
-
triggerButtonText?: string
|
|
47
|
-
showPivotEditButton?: boolean
|
|
48
|
-
showEditOnPivotClick?: boolean
|
|
49
|
-
selectPivotOnEdit?: boolean
|
|
50
|
-
showTrigger?: boolean
|
|
51
|
-
rightAlign?: boolean
|
|
61
|
+
triggerButtonText?: string;
|
|
62
|
+
showPivotEditButton?: boolean;
|
|
63
|
+
showEditOnPivotClick?: boolean;
|
|
64
|
+
selectPivotOnEdit?: boolean;
|
|
65
|
+
showTrigger?: boolean;
|
|
66
|
+
rightAlign?: boolean;
|
|
52
67
|
parentRef: any;
|
|
53
|
-
recommendPivotCount?: number
|
|
54
|
-
}
|
|
68
|
+
recommendPivotCount?: number;
|
|
69
|
+
}
|
|
70
|
+
export declare const PivotModal: ({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, popUpTitle, setPopUpTitle, selectedTable, SelectComponent, ButtonComponent, SecondaryButtonComponent, PopoverComponent, CardComponent, HeaderComponent, LabelComponent, TextComponent, selectedPivotIndex, setSelectedPivotIndex, removePivot, selectPivot, showUpdatePivot, setShowUpdatePivot, data, columns, theme, isOpen, setIsOpen, dateRange, createdPivots, setCreatedPivots, recommendedPivots, setRecommendedPivots, triggerButtonText, showPivotEditButton, showEditOnPivotClick, selectPivotOnEdit, showTrigger, rightAlign, parentRef, recommendPivotCount, }: PivotModalProps) => import("react/jsx-runtime").JSX.Element;
|
|
55
71
|
export declare function generatePivotTableYAxis(pivot: any, cols: any, format: any): any;
|
|
56
72
|
export declare function isDateField(fieldType: any): boolean;
|
|
57
73
|
export declare function generatePivotTable(pivot: Pivot, data: any, dateRange: any, isComparison: boolean, rowLimit?: number, compRange?: any): {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"AACA,OAAc,EAOZ,SAAS,EACV,MAAM,OAAO,CAAC;AAuBf,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAGrE,MAAM,WAAW,KAAK;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAkBD,MAAM,WAAW,eAAe;IAC9B,aAAa,EAAE,GAAG,CAAC;IACnB,gBAAgB,EAAE,GAAG,CAAC;IACtB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,eAAe,EAAE,GAAG,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,gBAAgB,EAAE,GAAG,CAAC;IACtB,mBAAmB,EAAE,GAAG,CAAC;IACzB,UAAU,EAAE,GAAG,CAAC;IAChB,aAAa,EAAE,GAAG,CAAC;IACnB,aAAa,EAAE,GAAG,CAAC;IACnB,eAAe,EAAE,GAAG,CAAC;IACrB,eAAe,EAAE,GAAG,CAAC;IACrB,aAAa,EAAE,GAAG,CAAC;IACnB,wBAAwB,EAAE,CAAC,KAAK,EAAE,oBAAoB,KAAK,GAAG,CAAC,OAAO,CAAC;IACvE,gBAAgB,EAAE,CAAC,KAAK,EAAE;QACxB,MAAM,EAAE,OAAO,CAAC;QAChB,SAAS,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,IAAI,CAAC;QACrC,YAAY,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;QAClC,YAAY,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;QAClC,eAAe,EAAE,SAAS,CAAC;KAC5B,KAAK,GAAG,CAAC,OAAO,CAAC;IAClB,eAAe,EAAE,CAAC,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IAC3D,cAAc,EAAE,CAAC,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IAC1D,aAAa,EAAE,CAAC,KAAK,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,GAAG,CAAC,OAAO,CAAC;IACzD,kBAAkB,EAAE,GAAG,CAAC;IACxB,qBAAqB,EAAE,GAAG,CAAC;IAC3B,WAAW,EAAE,GAAG,CAAC;IACjB,WAAW,EAAE,GAAG,CAAC;IACjB,eAAe,EAAE,GAAG,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,IAAI,EAAE,GAAG,CAAC;IACV,OAAO,EAAE,GAAG,CAAC;IACb,KAAK,EAAE,GAAG,CAAC;IACX,MAAM,EAAE,GAAG,CAAC;IACZ,SAAS,EAAE,GAAG,CAAC;IACf,SAAS,EAAE,GAAG,CAAC;IACf,aAAa,EAAE,GAAG,CAAC;IACnB,gBAAgB,EAAE,GAAG,CAAC;IACtB,iBAAiB,EAAE,GAAG,CAAC;IACvB,oBAAoB,EAAE,GAAG,CAAC;IAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,SAAS,EAAE,GAAG,CAAC;IACf,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B;AAED,eAAO,MAAM,UAAU,qsBA4CpB,eAAe,4CAwqBjB,CAAC;AAEF,wBAAgB,uBAAuB,CAAC,KAAK,KAAA,EAAE,IAAI,KAAA,EAAE,MAAM,KAAA,OAyB1D;AAkHD,wBAAgB,WAAW,CAAC,SAAS,KAAA,WAYpC;AAgCD,wBAAgB,kBAAkB,CAChC,KAAK,EAAE,KAAK,EACZ,IAAI,EAAE,GAAG,EACT,SAAS,EAAE,GAAG,EACd,YAAY,EAAE,OAAO,EACrB,QAAQ,SAAK,EACb,SAAS,GAAE,GAAU;;;;;;EAubtB"}
|
|
@@ -8,6 +8,9 @@ import { differenceInDays, eachDayOfInterval, eachMonthOfInterval, eachWeekOfInt
|
|
|
8
8
|
import { valueFormatter } from '../../utils/valueFormatter';
|
|
9
9
|
import { numberFormatOptions, dateFormatOptions } from '../../ChartBuilder';
|
|
10
10
|
import { snakeCaseToTitleCase } from '../../utils/textProcessing';
|
|
11
|
+
import { isIdColumn } from '../../components/ReportBuilder/util';
|
|
12
|
+
import { isNumericColumnType } from '../../components/ReportBuilder/ast';
|
|
13
|
+
import { QuillCard } from '../../components/QuillCard';
|
|
11
14
|
const QuillHover = () => {
|
|
12
15
|
return (_jsx("style", { children: `
|
|
13
16
|
.quill-hover {
|
|
@@ -21,7 +24,7 @@ const QuillHover = () => {
|
|
|
21
24
|
}
|
|
22
25
|
` }));
|
|
23
26
|
};
|
|
24
|
-
export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, popUpTitle, setPopUpTitle, selectedTable, SelectComponent, ButtonComponent, SecondaryButtonComponent, PopoverComponent, HeaderComponent, LabelComponent, TextComponent, selectedPivotIndex, setSelectedPivotIndex, removePivot, selectPivot, showUpdatePivot, setShowUpdatePivot, data, columns, theme, isOpen, setIsOpen, dateRange, createdPivots, setCreatedPivots, recommendedPivots, setRecommendedPivots, triggerButtonText = 'Pivot', showPivotEditButton = false, showEditOnPivotClick = true, selectPivotOnEdit = false, showTrigger = true, rightAlign = false, parentRef, recommendPivotCount = 6, }) => {
|
|
27
|
+
export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField, setPivotColumnField, pivotValueField, setPivotValueField, pivotAggregation, setPivotAggregation, popUpTitle, setPopUpTitle, selectedTable, SelectComponent, ButtonComponent, SecondaryButtonComponent, PopoverComponent, CardComponent = QuillCard, HeaderComponent, LabelComponent, TextComponent, selectedPivotIndex, setSelectedPivotIndex, removePivot, selectPivot, showUpdatePivot, setShowUpdatePivot, data, columns, theme, isOpen, setIsOpen, dateRange, createdPivots, setCreatedPivots, recommendedPivots, setRecommendedPivots, triggerButtonText = 'Pivot', showPivotEditButton = false, showEditOnPivotClick = true, selectPivotOnEdit = false, showTrigger = true, rightAlign = false, parentRef, recommendPivotCount = 6, }) => {
|
|
25
28
|
const [isLoading, setIsLoading] = useState(false);
|
|
26
29
|
const [pivotUpdateIndex, setPivotUpdateIndex] = useState(null);
|
|
27
30
|
const [selectedPivotType, setSelectedPivotType] = useState('recommended');
|
|
@@ -70,7 +73,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
70
73
|
return (columns || []).reduce((map, col) => {
|
|
71
74
|
// only use columns shown in the report builder's table
|
|
72
75
|
// also filter out id
|
|
73
|
-
if (col.field !== 'id'
|
|
76
|
+
if (col.field !== 'id') {
|
|
74
77
|
map[col.field] = col.fieldType || col.format;
|
|
75
78
|
}
|
|
76
79
|
return map;
|
|
@@ -190,7 +193,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
190
193
|
return pts;
|
|
191
194
|
}, [createdPivots, data]);
|
|
192
195
|
const samplePivotTable = useMemo(() => {
|
|
193
|
-
if (!pivotAggregation
|
|
196
|
+
if (!pivotAggregation) {
|
|
194
197
|
return null;
|
|
195
198
|
}
|
|
196
199
|
const pivot = {
|
|
@@ -226,10 +229,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
226
229
|
position: 'absolute',
|
|
227
230
|
top: -2,
|
|
228
231
|
right: -2,
|
|
229
|
-
} })) }), _jsx(
|
|
230
|
-
setShowUpdatePivot(false);
|
|
231
|
-
setPopUpTitle('Add Pivot');
|
|
232
|
-
}, style: rightAlign ? { right: 0 } : {}, parentRef: parentRef, showTrigger: showTrigger, label: triggerButtonText, isOpen: isOpen, setIsOpen: setIsOpen, onClick: () => {
|
|
232
|
+
} })) }), showTrigger && (_jsx(SecondaryButtonComponent, { onClick: () => {
|
|
233
233
|
if (columns.length === 0) {
|
|
234
234
|
setIsOpen(false);
|
|
235
235
|
}
|
|
@@ -240,15 +240,19 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
240
240
|
if (!isOpen && recommendedPivots.length === 0) {
|
|
241
241
|
refreshPivots();
|
|
242
242
|
}
|
|
243
|
+
setIsOpen(!isOpen);
|
|
243
244
|
setShowUpdatePivot(false);
|
|
244
|
-
},
|
|
245
|
+
}, label: triggerButtonText })), _jsx(PopoverComponent, { isOpen: isOpen, setIsOpen: (isOpen) => {
|
|
246
|
+
if (!isOpen) {
|
|
247
|
+
setShowUpdatePivot(false);
|
|
248
|
+
setPopUpTitle('Add Pivot');
|
|
249
|
+
}
|
|
250
|
+
setIsOpen(isOpen);
|
|
251
|
+
}, popoverChildren: _jsx("div", { children: showUpdatePivot ? (_jsxs("div", { className: "ref-in-use", ref: editModalRef, style: {
|
|
245
252
|
backgroundColor: 'rgb(255, 255, 255)',
|
|
246
253
|
display: 'flex',
|
|
247
254
|
flexDirection: 'column',
|
|
248
|
-
}, children: [_jsx(HeaderComponent, {
|
|
249
|
-
marginBottom: 20,
|
|
250
|
-
minHeight: 160,
|
|
251
|
-
}, children: _jsx(PivotCard, { pivotTable: samplePivotTable, theme: theme, index: 0, onSelectPivot: () => { }, selectedPivotIndex: -1, onEditPivot: () => { }, ButtonComponent: ButtonComponent, showEdit: false, clickable: false, minHeight: 140, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }) })) }), _jsxs("div", { style: {
|
|
255
|
+
}, children: [_jsx(HeaderComponent, { label: popUpTitle }), _jsx("div", { style: { height: 12 } }), _jsxs("div", { style: {
|
|
252
256
|
display: 'flex',
|
|
253
257
|
flexDirection: 'column',
|
|
254
258
|
gap: 10,
|
|
@@ -259,49 +263,55 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
259
263
|
flexDirection: 'row',
|
|
260
264
|
gap: 20,
|
|
261
265
|
marginBottom: 5,
|
|
262
|
-
}, children: [_jsxs("div", { children: [_jsx(LabelComponent, {
|
|
263
|
-
setPivotRowField(e === ''
|
|
266
|
+
}, children: [_jsxs("div", { children: [_jsx(LabelComponent, { label: "Row Field" }), _jsx(SelectComponent, { id: "pivot-row-field", value: pivotRowField, onChange: (e) => {
|
|
267
|
+
setPivotRowField(e.target.value === ''
|
|
268
|
+
? undefined
|
|
269
|
+
: e.target.value);
|
|
264
270
|
}, options: [
|
|
265
271
|
...columnSelectOptions.filter((option) => {
|
|
266
272
|
const format = columns.find((col) => col.field === option.value)?.format;
|
|
267
273
|
return (format === 'string' ||
|
|
268
|
-
dateFormatOptions.includes(format)
|
|
274
|
+
dateFormatOptions.includes(format) ||
|
|
275
|
+
isIdColumn(option.value));
|
|
269
276
|
}),
|
|
270
|
-
]
|
|
271
|
-
setPivotColumnField(e === ''
|
|
277
|
+
] })] }), _jsxs("div", { children: [_jsx(LabelComponent, { label: "Column Field" }), _jsx(SelectComponent, { id: "pivot-row-field", value: pivotColumnField, onChange: (e) => {
|
|
278
|
+
setPivotColumnField(e.target.value === ''
|
|
279
|
+
? undefined
|
|
280
|
+
: e.target.value);
|
|
272
281
|
}, options: [
|
|
273
282
|
...columnSelectOptions.filter((option) => {
|
|
274
|
-
return (columns.find((col) => col.field === option.value)
|
|
275
|
-
?.format === 'string');
|
|
283
|
+
return (columns.find((col) => col.field === option.value)?.format === 'string');
|
|
276
284
|
}),
|
|
277
|
-
]
|
|
285
|
+
] })] })] }), _jsxs("div", { style: {
|
|
278
286
|
display: 'flex',
|
|
279
287
|
flexDirection: 'row',
|
|
280
288
|
gap: 20,
|
|
281
289
|
marginBottom: 20,
|
|
282
|
-
}, children: [_jsxs("div", { children: [_jsx(LabelComponent, {
|
|
283
|
-
setPivotValueField(e === ''
|
|
290
|
+
}, children: [_jsxs("div", { children: [_jsx(LabelComponent, { label: "Value Field" }), _jsx(SelectComponent, { id: "pivot-row-field", value: pivotValueField, onChange: (e) => {
|
|
291
|
+
setPivotValueField(e.target.value === ''
|
|
292
|
+
? undefined
|
|
293
|
+
: e.target.value);
|
|
284
294
|
}, options: [
|
|
285
295
|
...columnSelectOptions.filter((option) => {
|
|
286
|
-
return (option.value === '' ||
|
|
287
|
-
numberFormatOptions.includes(columns.find((col) => col.field === option.value)?.format))
|
|
296
|
+
return ((option.value === '' ||
|
|
297
|
+
numberFormatOptions.includes(columns.find((col) => col.field === option.value)?.format)) &&
|
|
298
|
+
!isIdColumn(option.value));
|
|
288
299
|
}),
|
|
289
|
-
]
|
|
290
|
-
if (e !== 'count' &&
|
|
300
|
+
] })] }), _jsxs("div", { children: [_jsx(LabelComponent, { label: "Aggregation Type" }), _jsx(SelectComponent, { id: "pivot-row-field", value: pivotAggregation, onChange: (e) => {
|
|
301
|
+
if (e.target.value !== 'count' &&
|
|
291
302
|
pivotValueField &&
|
|
292
303
|
!numberFormatOptions.includes(columns.find((col) => col.field === pivotValueField)?.format)) {
|
|
293
304
|
setPivotValueField(null);
|
|
294
305
|
}
|
|
295
|
-
setPivotAggregation(e === ''
|
|
306
|
+
setPivotAggregation(e.target.value === ''
|
|
307
|
+
? undefined
|
|
308
|
+
: e.target.value);
|
|
296
309
|
}, options: [
|
|
297
310
|
...['sum', 'average', 'count', 'max', 'min'].map((option) => {
|
|
298
311
|
return { label: option, value: option };
|
|
299
312
|
}),
|
|
300
313
|
] })] })] })] }), _jsx("div", { children: _jsx(ButtonComponent, { id: "custom-button", onClick: () => {
|
|
301
314
|
const errors = [];
|
|
302
|
-
if (!pivotRowField) {
|
|
303
|
-
errors.push('Row field cannot be empty');
|
|
304
|
-
}
|
|
305
315
|
if (!pivotValueField && pivotAggregation !== 'count') {
|
|
306
316
|
errors.push("Value field cannot be empty when aggregation is not 'count'");
|
|
307
317
|
}
|
|
@@ -356,7 +366,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
356
366
|
columns: selectedPivotTable?.columns,
|
|
357
367
|
}, theme: theme, index: 0, onSelectPivot: () => { }, selectedPivotIndex: -1, onEditPivot: () => { }, ButtonComponent: ButtonComponent, showEdit: false, onClose: () => {
|
|
358
368
|
removePivot();
|
|
359
|
-
}, clickable: true, minHeight: 180, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }) }) })) : (_jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [_jsxs("div", { style: {
|
|
369
|
+
}, clickable: true, minHeight: 180, CardComponent: CardComponent, LabelComponent: LabelComponent, TextComponent: TextComponent, HeaderComponent: HeaderComponent }) }) })) : (_jsxs("div", { style: { display: 'flex', flexDirection: 'column' }, children: [_jsxs("div", { style: {
|
|
360
370
|
display: 'flex',
|
|
361
371
|
flexDirection: 'row',
|
|
362
372
|
width: '100%',
|
|
@@ -384,7 +394,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
|
|
|
384
394
|
display: 'flex',
|
|
385
395
|
margin: '0px auto',
|
|
386
396
|
justifyContent: 'center',
|
|
387
|
-
}, children: [_jsx("div", { style: { height: 100 } }), _jsxs("svg", { width: "24", height: "24", children: [_jsx("circle", { cx: "12", cy: "12", r: "9.375", strokeWidth: "3.75", strokeDasharray: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 2 / 3)", strokeDashoffset: "calc(2 * 3.14 * 9.375 / 6)", stroke: theme?.primaryTextColor || '#364153', fill: "none", transform: "rotate(-90 12 12)", children: _jsx("animateTransform", { attributeName: "transform", attributeType: "XML", type: "rotate", from: "-180 12 12", to: "180 12 12", dur: "0.8s", repeatCount: "indefinite" }) }), _jsx("circle", { cx: "12", cy: "12", r: "9.375", strokeWidth: "3.75", strokeDasharray: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 1 / 3)", strokeDashoffset: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 2 / 3)", stroke: '#ADB1B9', fill: "none", transform: "rotate(90 12 12)", children: _jsx("animateTransform", { attributeName: "transform", attributeType: "XML", type: "rotate", from: "0 12 12", to: "360 12 12", dur: "0.8s", repeatCount: "indefinite" }) })] })] })) : (_jsx("div", { children: _jsx(PivotList, { recommendedPivotTables: recommendedPivotTables, createdPivotTables: createdPivotTables, theme: theme, onSelectRecommendedPivot: onSelectRecommendedPivot, onSelectCreatedPivot: onSelectCreatedPivot, selectedPivotIndex: selectedPivotIndex, selectedPivotType: selectedPivotType, ButtonComponent: ButtonComponent, HeaderComponent: HeaderComponent, onEditRecommendedPivot: onEditRecommendedPivot, onEditCreatedPivot: onEditPivot, showCreatePivot: true, showPivotEditButton: showPivotEditButton, LabelComponent: LabelComponent, TextComponent: TextComponent }) }))] })) })) }) })] }) }));
|
|
397
|
+
}, children: [_jsx("div", { style: { height: 100 } }), _jsxs("svg", { width: "24", height: "24", children: [_jsx("circle", { cx: "12", cy: "12", r: "9.375", strokeWidth: "3.75", strokeDasharray: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 2 / 3)", strokeDashoffset: "calc(2 * 3.14 * 9.375 / 6)", stroke: theme?.primaryTextColor || '#364153', fill: "none", transform: "rotate(-90 12 12)", children: _jsx("animateTransform", { attributeName: "transform", attributeType: "XML", type: "rotate", from: "-180 12 12", to: "180 12 12", dur: "0.8s", repeatCount: "indefinite" }) }), _jsx("circle", { cx: "12", cy: "12", r: "9.375", strokeWidth: "3.75", strokeDasharray: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 1 / 3)", strokeDashoffset: "calc(2 * 3.14 * 9.375 / 3) calc(2 * 3.14 * 9.375 * 2 / 3)", stroke: '#ADB1B9', fill: "none", transform: "rotate(90 12 12)", children: _jsx("animateTransform", { attributeName: "transform", attributeType: "XML", type: "rotate", from: "0 12 12", to: "360 12 12", dur: "0.8s", repeatCount: "indefinite" }) })] })] })) : (_jsx("div", { children: _jsx(PivotList, { recommendedPivotTables: recommendedPivotTables, createdPivotTables: createdPivotTables, theme: theme, onSelectRecommendedPivot: onSelectRecommendedPivot, onSelectCreatedPivot: onSelectCreatedPivot, selectedPivotIndex: selectedPivotIndex, selectedPivotType: selectedPivotType, ButtonComponent: ButtonComponent, HeaderComponent: HeaderComponent, onEditRecommendedPivot: onEditRecommendedPivot, onEditCreatedPivot: onEditPivot, showCreatePivot: true, showPivotEditButton: showPivotEditButton, LabelComponent: LabelComponent, TextComponent: TextComponent, CardComponent: CardComponent }) }))] })) })) }) })] }) }));
|
|
388
398
|
};
|
|
389
399
|
export function generatePivotTableYAxis(pivot, cols, format) {
|
|
390
400
|
// Use the column field for the field and label if there is one
|
|
@@ -541,7 +551,7 @@ const fixBigQueryData = (data = []) => {
|
|
|
541
551
|
export function generatePivotTable(pivot, data, dateRange, isComparison, rowLimit = -1, compRange = null) {
|
|
542
552
|
// If there is no rowField, aggregate on the valueField
|
|
543
553
|
if (!pivot.rowField) {
|
|
544
|
-
return valueFieldAggregation(data, pivot.valueField, pivot.aggregationType);
|
|
554
|
+
return valueFieldAggregation(data, pivot.valueField, pivot.aggregationType, isComparison);
|
|
545
555
|
}
|
|
546
556
|
// Handle edge-case for BigQuery objects.
|
|
547
557
|
data = fixBigQueryData(data);
|
|
@@ -761,15 +771,6 @@ export function generatePivotTable(pivot, data, dateRange, isComparison, rowLimi
|
|
|
761
771
|
}
|
|
762
772
|
break;
|
|
763
773
|
case 'average':
|
|
764
|
-
value = filteredData.length
|
|
765
|
-
? filteredData.reduce((sum, item) => sum + parseFloat(item[key] ?? 0), 0) / filteredData.length
|
|
766
|
-
: 0;
|
|
767
|
-
if (isComparison) {
|
|
768
|
-
comparisonValue = comparisonFilteredData.length
|
|
769
|
-
? comparisonFilteredData.reduce((sum, item) => sum + parseFloat(item[key] ?? 0), 0) / comparisonFilteredData.length
|
|
770
|
-
: 0;
|
|
771
|
-
}
|
|
772
|
-
break;
|
|
773
774
|
case 'avg':
|
|
774
775
|
value = filteredData.length
|
|
775
776
|
? filteredData.reduce((sum, item) => sum + parseFloat(item[key] ?? 0), 0) / filteredData.length
|
|
@@ -873,42 +874,63 @@ export function generatePivotTable(pivot, data, dateRange, isComparison, rowLimi
|
|
|
873
874
|
if (pivot.rowFieldType === 'date') {
|
|
874
875
|
return new Date(a[pivot.rowField]) - new Date(b[pivot.rowField]);
|
|
875
876
|
}
|
|
877
|
+
else if (isNumericColumnType(pivot.rowFieldType)) {
|
|
878
|
+
return a[pivot.rowField] - b[pivot.rowField];
|
|
879
|
+
}
|
|
876
880
|
return a[pivot.rowField].localeCompare(b[pivot.rowField]);
|
|
877
881
|
}
|
|
878
882
|
else {
|
|
879
883
|
if (pivot.rowFieldType === 'date') {
|
|
880
884
|
return new Date(b[pivot.rowField]) - new Date(a[pivot.rowField]);
|
|
881
885
|
}
|
|
886
|
+
else if (isNumericColumnType(pivot.rowFieldType)) {
|
|
887
|
+
return a[pivot.rowField] - b[pivot.rowField];
|
|
888
|
+
}
|
|
882
889
|
return b[pivot.rowField].localeCompare(a[pivot.rowField]);
|
|
883
890
|
}
|
|
884
891
|
});
|
|
885
892
|
}
|
|
886
893
|
return { rows: pivotRows, columns };
|
|
887
894
|
}
|
|
888
|
-
function valueFieldAggregation(data, valueField, aggregationType) {
|
|
889
|
-
let value;
|
|
895
|
+
function valueFieldAggregation(data, valueField, aggregationType, isComparison) {
|
|
896
|
+
let value = 0;
|
|
897
|
+
let comparisonValue = 0;
|
|
890
898
|
switch (aggregationType) {
|
|
891
899
|
case 'sum':
|
|
892
900
|
value = data.reduce((sum, item) => sum + parseFloat(item[valueField] ?? 0), 0);
|
|
901
|
+
if (isComparison) {
|
|
902
|
+
comparisonValue = data.reduce((sum, item) => sum + parseFloat(item[`comparison_${valueField}`] ?? 0), 0);
|
|
903
|
+
}
|
|
893
904
|
break;
|
|
894
905
|
case 'count':
|
|
895
|
-
value = data.
|
|
906
|
+
value = data.reduce((count, item) => count + (item[valueField] ? 1 : 0), 0);
|
|
907
|
+
if (isComparison) {
|
|
908
|
+
comparisonValue = data.reduce((count, item) => count + (item[`comparison_${valueField}`] ? 1 : 0), 0);
|
|
909
|
+
}
|
|
896
910
|
break;
|
|
897
911
|
case 'avg':
|
|
898
|
-
value = data.length
|
|
899
|
-
? data.reduce((sum, item) => sum + parseFloat(item[valueField] ?? 0), 0) / data.length
|
|
900
|
-
: 0;
|
|
901
|
-
break;
|
|
902
912
|
case 'average':
|
|
903
|
-
|
|
904
|
-
|
|
905
|
-
|
|
913
|
+
const count = data.reduce((count, item) => count + (item[valueField] ? 1 : 0), 0);
|
|
914
|
+
value =
|
|
915
|
+
data.reduce((sum, item) => sum + parseFloat(item[valueField] ?? 0), 0) /
|
|
916
|
+
(count === 0 ? 1 : count);
|
|
917
|
+
if (isComparison) {
|
|
918
|
+
const comparisonCount = data.reduce((count, item) => count + (item[`comparison_${valueField}`] ? 1 : 0), 0);
|
|
919
|
+
comparisonValue =
|
|
920
|
+
data.reduce((sum, item) => sum + parseFloat(item[`comparison_${valueField}`] ?? 0), 0) / (comparisonCount === 0 ? 1 : comparisonCount);
|
|
921
|
+
}
|
|
906
922
|
break;
|
|
907
923
|
case 'max':
|
|
908
924
|
value = data.reduce((max, item) => Math.max(max, parseFloat(item[valueField] ?? 0)), -Infinity);
|
|
925
|
+
if (isComparison) {
|
|
926
|
+
comparisonValue = data.reduce((max, item) => Math.max(max, parseFloat(item[`comparison_${valueField}`] ?? 0)), -Infinity);
|
|
927
|
+
}
|
|
909
928
|
break;
|
|
910
929
|
case 'min':
|
|
911
930
|
value = data.reduce((min, item) => Math.min(min, parseFloat(item[valueField] ?? 0)), Infinity);
|
|
931
|
+
if (isComparison) {
|
|
932
|
+
comparisonValue = data.reduce((min, item) => Math.min(min, parseFloat(item[`comparison_${valueField}`] ?? 0)), Infinity);
|
|
933
|
+
}
|
|
912
934
|
break;
|
|
913
935
|
// Implement other aggregation types as needed
|
|
914
936
|
default:
|
|
@@ -916,6 +938,9 @@ function valueFieldAggregation(data, valueField, aggregationType) {
|
|
|
916
938
|
}
|
|
917
939
|
const row = {};
|
|
918
940
|
row[valueField] = value;
|
|
941
|
+
if (isComparison) {
|
|
942
|
+
row[`comparison_${valueField}`] = comparisonValue;
|
|
943
|
+
}
|
|
919
944
|
return {
|
|
920
945
|
rows: [row],
|
|
921
946
|
columns: [{ label: snakeCaseToTitleCase(valueField), field: valueField }],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dataFetcher.d.ts","sourceRoot":"","sources":["../../../src/utils/dataFetcher.tsx"],"names":[],"mappings":"AAEA,wBAAsB,OAAO,CAC3B,MAAM,EAAE,GAAG,EACX,kBAAkB,EAAE,MAAM,EAC1B,MAAM,EAAE,kBAAkB,EAC1B,iBAAiB,EAAE,GAAG,EACtB,gBAAgB,EAAE,GAAG,EACrB,MAAM,SAAS,
|
|
1
|
+
{"version":3,"file":"dataFetcher.d.ts","sourceRoot":"","sources":["../../../src/utils/dataFetcher.tsx"],"names":[],"mappings":"AAEA,wBAAsB,OAAO,CAC3B,MAAM,EAAE,GAAG,EACX,kBAAkB,EAAE,MAAM,EAC1B,MAAM,EAAE,kBAAkB,EAC1B,iBAAiB,EAAE,GAAG,EACtB,gBAAgB,EAAE,GAAG,EACrB,MAAM,SAAS,gBAgEhB;AAED,wBAAsB,gBAAgB,CACpC,MAAM,EAAE,GAAG,EACX,kBAAkB,EAAE,MAAM,EAC1B,gBAAgB,EAAE,GAAG,EACrB,MAAM,SAAS,gBA+BhB"}
|
|
@@ -20,6 +20,7 @@ export async function getData(client, cloudQueryEndpoint, noCred, hostedRequestB
|
|
|
20
20
|
let result;
|
|
21
21
|
if (responseJson.data?.data) {
|
|
22
22
|
result = {
|
|
23
|
+
fields: responseJson?.data.queries?.queryResults[0]?.fields,
|
|
23
24
|
...responseJson.data.data,
|
|
24
25
|
rows: responseJson?.data.queries?.queryResults[0]?.rows,
|
|
25
26
|
compareRows: responseJson?.data.queries?.queryResults[1]?.rows,
|
|
@@ -27,6 +28,7 @@ export async function getData(client, cloudQueryEndpoint, noCred, hostedRequestB
|
|
|
27
28
|
}
|
|
28
29
|
else {
|
|
29
30
|
result = {
|
|
31
|
+
fields: responseJson?.queries?.queryResults[0]?.fields,
|
|
30
32
|
...responseJson.data,
|
|
31
33
|
rows: responseJson?.queries?.queryResults[0]?.rows,
|
|
32
34
|
compareRows: responseJson?.queries?.queryResults[1]?.rows,
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const isInTheLastIntervalBigQuery: (node: any) => boolean;
|
|
2
|
+
export declare const isAfterBigQuery: (node: any) => boolean;
|
|
3
|
+
export declare const isBeforeBigQuery: (node: any) => boolean;
|
|
4
|
+
export declare const isTheCurrentIntervalBigQuery: (node: any) => boolean;
|
|
5
|
+
export declare const isEqualsBigQuery: (node: any) => any;
|
|
6
|
+
//# sourceMappingURL=parserBigQuery.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parserBigQuery.d.ts","sourceRoot":"","sources":["../../../src/utils/parserBigQuery.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,2BAA2B,SAAU,GAAG,YAYpD,CAAC;AAEF,eAAO,MAAM,eAAe,SAAU,GAAG,YAUxC,CAAC;AAEF,eAAO,MAAM,gBAAgB,SAAU,GAAG,YAUzC,CAAC;AAEF,eAAO,MAAM,4BAA4B,SAAU,GAAG,KAAG,OAUxD,CAAC;AAEF,eAAO,MAAM,gBAAgB,SAAU,GAAG,QASzC,CAAC"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
// Functions use to parse BigQuery SQL
|
|
2
|
+
export const isInTheLastIntervalBigQuery = (node) => {
|
|
3
|
+
const isOutsideOfDateTrunc = ['>=', '>'].includes(node.operator) &&
|
|
4
|
+
(node.left.type === 'column_ref' ||
|
|
5
|
+
(node.left.type === 'function' &&
|
|
6
|
+
node.left.name.toLowerCase() === 'timestamp')) &&
|
|
7
|
+
node.right.type === 'function' &&
|
|
8
|
+
node.right.name.toLowerCase() === 'timestamp_sub' &&
|
|
9
|
+
node.right.args.value[0].type === 'function' &&
|
|
10
|
+
node.right.args.value[1].type === 'interval' &&
|
|
11
|
+
['current_timestamp'].includes(node.right.args.value[0].name.toLowerCase());
|
|
12
|
+
return isOutsideOfDateTrunc;
|
|
13
|
+
};
|
|
14
|
+
export const isAfterBigQuery = (node) => {
|
|
15
|
+
const isOutsideOfDateTrunc = ['>=', '>'].includes(node.operator) &&
|
|
16
|
+
(node.left.type === 'column_ref' ||
|
|
17
|
+
(node.left.type === 'function' &&
|
|
18
|
+
node.left.name.toLowerCase() === 'timestamp')) &&
|
|
19
|
+
((node.right.type === 'function' &&
|
|
20
|
+
node.right.name.toLowerCase() === 'timestamp') ||
|
|
21
|
+
node.right.type === 'timestamp');
|
|
22
|
+
return isOutsideOfDateTrunc;
|
|
23
|
+
};
|
|
24
|
+
export const isBeforeBigQuery = (node) => {
|
|
25
|
+
const isOutsideOfDateTrunc = ['<=', '<'].includes(node.operator) &&
|
|
26
|
+
(node.left.type === 'column_ref' ||
|
|
27
|
+
(node.left.type === 'function' &&
|
|
28
|
+
node.left.name.toLowerCase() === 'timestamp')) &&
|
|
29
|
+
((node.right.type === 'function' &&
|
|
30
|
+
node.right.name.toLowerCase() === 'timestamp') ||
|
|
31
|
+
node.right.type === 'timestamp');
|
|
32
|
+
return isOutsideOfDateTrunc;
|
|
33
|
+
};
|
|
34
|
+
export const isTheCurrentIntervalBigQuery = (node) => {
|
|
35
|
+
const isInsideOfDateTrunc = ['='].includes(node.operator) &&
|
|
36
|
+
node.left.type === 'function' &&
|
|
37
|
+
node.left.name &&
|
|
38
|
+
node.left.name.toLowerCase() === 'timestamp_trunc' &&
|
|
39
|
+
node.right.type === 'function' &&
|
|
40
|
+
node.right.name.toLowerCase() === 'timestamp_trunc' &&
|
|
41
|
+
node.right.args?.value[0]?.name?.toLowerCase() === 'current_timestamp';
|
|
42
|
+
return isInsideOfDateTrunc;
|
|
43
|
+
};
|
|
44
|
+
export const isEqualsBigQuery = (node) => {
|
|
45
|
+
const isEquals = ['='].includes(node.operator) &&
|
|
46
|
+
node.left.type === 'function' &&
|
|
47
|
+
node.left.name &&
|
|
48
|
+
node.left.name.toLowerCase() === 'timestamp_trunc' &&
|
|
49
|
+
node.right.name.toLowerCase() === 'timestamp_trunc' &&
|
|
50
|
+
node.right.args.value[0].type.toLowerCase() === 'timestamp';
|
|
51
|
+
return isEquals;
|
|
52
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parserPostgres.d.ts","sourceRoot":"","sources":["../../../src/utils/parserPostgres.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,2BAA2B,SAAU,GAAG,KAAG,OAyBvD,CAAC;AAEF,eAAO,MAAM,4BAA4B,SAAU,GAAG,KAAG,OAiBxD,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
export const isInTheLastIntervalPostgres = (node) => {
|
|
2
|
+
const isOutsideOfDateTrunc = ['>=', '>'].includes(node.operator) &&
|
|
3
|
+
node.left.type === 'column_ref' &&
|
|
4
|
+
node.right.type === 'binary_expr' &&
|
|
5
|
+
node.right.operator === '-' &&
|
|
6
|
+
node.right.left.type === 'function' &&
|
|
7
|
+
node.right.left.name.toLowerCase() === 'date_trunc' &&
|
|
8
|
+
node.right.left.args.value[0].type === 'single_quote_string' &&
|
|
9
|
+
node.right.left.args.value[1].type === 'function' &&
|
|
10
|
+
['current_date', 'now'].includes(node.right.left.args.value[1].name.toLowerCase()) &&
|
|
11
|
+
node.right.right.type.toLowerCase() === 'interval' &&
|
|
12
|
+
node.right.right.expr.type === 'single_quote_string';
|
|
13
|
+
const noDateTrunc = ['>=', '>'].includes(node.operator) &&
|
|
14
|
+
node.left.type === 'column_ref' &&
|
|
15
|
+
node.right.type === 'binary_expr' &&
|
|
16
|
+
node.right.operator === '-' &&
|
|
17
|
+
node.right.left.type === 'function' &&
|
|
18
|
+
['current_date', 'now'].includes(node.right.left.name.toLowerCase()) &&
|
|
19
|
+
node.right.right.type.toLowerCase() === 'interval' &&
|
|
20
|
+
node.right.right.expr.type === 'single_quote_string';
|
|
21
|
+
return isOutsideOfDateTrunc || noDateTrunc;
|
|
22
|
+
};
|
|
23
|
+
export const isTheCurrentIntervalPostgres = (node) => {
|
|
24
|
+
const isInsideOfDateTrunc = ['AND'].includes(node.operator) &&
|
|
25
|
+
(node.left.operator === '=' || node.left.type === 'double_quote_string') &&
|
|
26
|
+
node.right.operator === '=' &&
|
|
27
|
+
node.right.name &&
|
|
28
|
+
node.right.name.toLowerCase() === 'date_trunc' &&
|
|
29
|
+
node.args.value[0].type === 'single_quote_string' &&
|
|
30
|
+
node.args.value[1].type === 'binary_expr' &&
|
|
31
|
+
node.args.value[1].operator === '-' &&
|
|
32
|
+
node.args.value[1].left.type === 'function' &&
|
|
33
|
+
['now', 'current_date'].includes(node.args.value[1].left.name.toLowerCase()) &&
|
|
34
|
+
node.args.value[1].right.type === 'interval' &&
|
|
35
|
+
node.args.value[1].right.expr.type === 'single_quote_string';
|
|
36
|
+
return isInsideOfDateTrunc;
|
|
37
|
+
};
|