@quillsql/react 2.11.25 → 2.11.27
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 +16 -13
- package/dist/cjs/ChartBuilder.d.ts +7 -20
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +25 -25
- package/dist/cjs/ChartEditor.d.ts.map +1 -1
- package/dist/cjs/ChartEditor.js +3 -3
- package/dist/cjs/Dashboard.d.ts +2 -1
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.d.ts +11 -5
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +208 -127
- package/dist/cjs/SQLEditor.d.ts +4 -11
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +57 -124
- package/dist/cjs/Table.d.ts +1 -1
- package/dist/cjs/Table.js +4 -4
- package/dist/cjs/components/Dashboard/DashboardFilter.js +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/MetricComponent.js +9 -12
- package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/TableComponent.js +13 -11
- package/dist/cjs/components/QuillTable.d.ts +6 -3
- package/dist/cjs/components/QuillTable.d.ts.map +1 -1
- package/dist/cjs/components/QuillTable.js +3 -3
- package/dist/cjs/components/ReportBuilder/convert.d.ts +2 -2
- package/dist/cjs/components/ReportBuilder/ui.js +1 -1
- package/dist/cjs/components/UiComponents.d.ts +1 -0
- package/dist/cjs/components/UiComponents.d.ts.map +1 -1
- package/dist/cjs/components/UiComponents.js +17 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts +27 -24
- package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotList.js +9 -7
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +11 -3
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +52 -67
- package/dist/cjs/models/Columns.d.ts +11 -0
- package/dist/cjs/models/Columns.d.ts.map +1 -0
- package/dist/cjs/models/Columns.js +2 -0
- package/dist/cjs/models/Tables.d.ts +0 -8
- package/dist/cjs/models/Tables.d.ts.map +1 -1
- package/dist/cjs/utils/astProcessing.d.ts +3 -0
- package/dist/cjs/utils/astProcessing.d.ts.map +1 -0
- package/dist/cjs/utils/astProcessing.js +20 -0
- package/dist/cjs/utils/columnProcessing.d.ts +9 -0
- package/dist/cjs/utils/columnProcessing.d.ts.map +1 -0
- package/dist/cjs/utils/columnProcessing.js +207 -0
- package/dist/cjs/utils/dashboard.js +9 -9
- package/dist/cjs/utils/pivotProcessing.d.ts +2 -1
- package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/pivotProcessing.js +3 -8
- package/dist/cjs/utils/tableProcessing.d.ts +2 -2
- package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.js +1 -3
- package/dist/cjs/utils/valueFormatter.d.ts +2 -1
- package/dist/cjs/utils/valueFormatter.d.ts.map +1 -1
- package/dist/cjs/utils/valueFormatter.js +12 -1
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +16 -13
- package/dist/esm/ChartBuilder.d.ts +7 -20
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +25 -25
- package/dist/esm/ChartEditor.d.ts.map +1 -1
- package/dist/esm/ChartEditor.js +3 -3
- package/dist/esm/Dashboard.d.ts +2 -1
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.d.ts +11 -5
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +205 -124
- package/dist/esm/SQLEditor.d.ts +4 -11
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +57 -123
- package/dist/esm/Table.d.ts +1 -1
- package/dist/esm/Table.js +4 -4
- package/dist/esm/components/Dashboard/DashboardFilter.js +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/MetricComponent.js +9 -12
- package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/TableComponent.js +13 -11
- package/dist/esm/components/QuillTable.d.ts +6 -3
- package/dist/esm/components/QuillTable.d.ts.map +1 -1
- package/dist/esm/components/QuillTable.js +3 -3
- package/dist/esm/components/ReportBuilder/convert.d.ts +2 -2
- package/dist/esm/components/ReportBuilder/ui.js +1 -1
- package/dist/esm/components/UiComponents.d.ts +1 -0
- package/dist/esm/components/UiComponents.d.ts.map +1 -1
- package/dist/esm/components/UiComponents.js +15 -0
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts +27 -24
- package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotList.js +9 -7
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +11 -3
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +55 -70
- package/dist/esm/models/Columns.d.ts +11 -0
- package/dist/esm/models/Columns.d.ts.map +1 -0
- package/dist/esm/models/Columns.js +1 -0
- package/dist/esm/models/Tables.d.ts +0 -8
- package/dist/esm/models/Tables.d.ts.map +1 -1
- package/dist/esm/utils/astProcessing.d.ts +3 -0
- package/dist/esm/utils/astProcessing.d.ts.map +1 -0
- package/dist/esm/utils/astProcessing.js +16 -0
- package/dist/esm/utils/columnProcessing.d.ts +9 -0
- package/dist/esm/utils/columnProcessing.d.ts.map +1 -0
- package/dist/esm/utils/columnProcessing.js +201 -0
- package/dist/esm/utils/dashboard.js +9 -9
- package/dist/esm/utils/pivotProcessing.d.ts +2 -1
- package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
- package/dist/esm/utils/pivotProcessing.js +3 -8
- package/dist/esm/utils/tableProcessing.d.ts +2 -2
- package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.js +1 -3
- package/dist/esm/utils/valueFormatter.d.ts +2 -1
- package/dist/esm/utils/valueFormatter.d.ts.map +1 -1
- package/dist/esm/utils/valueFormatter.js +11 -0
- package/package.json +1 -1
- package/dist/cjs/utils/types.d.ts +0 -4
- package/dist/cjs/utils/types.d.ts.map +0 -1
- package/dist/cjs/utils/types.js +0 -52
- package/dist/cjs/utils/valueFormatterCSV.d.ts +0 -17
- package/dist/cjs/utils/valueFormatterCSV.d.ts.map +0 -1
- package/dist/cjs/utils/valueFormatterCSV.js +0 -99
- package/dist/esm/utils/types.d.ts +0 -4
- package/dist/esm/utils/types.d.ts.map +0 -1
- package/dist/esm/utils/types.js +0 -48
- package/dist/esm/utils/valueFormatterCSV.d.ts +0 -17
- package/dist/esm/utils/valueFormatterCSV.d.ts.map +0 -1
- package/dist/esm/utils/valueFormatterCSV.js +0 -95
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ColumnInfo } from '../components/ReportBuilder/schema';
|
|
2
|
+
import { Column, ColumnInternal } from '../models/Columns';
|
|
3
|
+
export declare function convertPostgresColumn(field: {
|
|
4
|
+
name: string;
|
|
5
|
+
dataTypeID: number;
|
|
6
|
+
}): ColumnInternal;
|
|
7
|
+
export declare function convertColumnInfoToColumnInternal(columnInfo: ColumnInfo): ColumnInternal;
|
|
8
|
+
export declare function convertFormatToJsType(column: Column): string;
|
|
9
|
+
//# sourceMappingURL=columnProcessing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"columnProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/columnProcessing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,oCAAoC,CAAC;AAChE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAE3D,wBAAgB,qBAAqB,CAAC,KAAK,EAAE;IAC3C,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;CACpB,GAAG,cAAc,CAyGjB;AAED,wBAAgB,iCAAiC,CAC/C,UAAU,EAAE,UAAU,GACrB,cAAc,CAShB;AAiFD,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAY5D"}
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.convertFormatToJsType = exports.convertColumnInfoToColumnInternal = exports.convertPostgresColumn = void 0;
|
|
4
|
+
function convertPostgresColumn(field) {
|
|
5
|
+
let format;
|
|
6
|
+
let fieldType;
|
|
7
|
+
let jsType;
|
|
8
|
+
switch (field.dataTypeID) {
|
|
9
|
+
case 16: // bool
|
|
10
|
+
format = 'string';
|
|
11
|
+
break;
|
|
12
|
+
case 20: // int8
|
|
13
|
+
case 21: // int2
|
|
14
|
+
case 23: // int4
|
|
15
|
+
format = 'whole_number';
|
|
16
|
+
break;
|
|
17
|
+
case 700: // float4
|
|
18
|
+
case 701: // float8
|
|
19
|
+
case 1700: // numeric
|
|
20
|
+
format = 'two_decimal_places';
|
|
21
|
+
break;
|
|
22
|
+
case 1082: // date
|
|
23
|
+
case 1083: // time
|
|
24
|
+
case 1184: // timestamptz
|
|
25
|
+
case 1114: // timestamp
|
|
26
|
+
format = 'MMM_dd_yyyy';
|
|
27
|
+
break;
|
|
28
|
+
case 1186: // interval
|
|
29
|
+
case 1043: // varchar
|
|
30
|
+
default:
|
|
31
|
+
format = 'string';
|
|
32
|
+
}
|
|
33
|
+
switch (field.dataTypeID) {
|
|
34
|
+
case 16: // boolean
|
|
35
|
+
fieldType = 'bool';
|
|
36
|
+
break;
|
|
37
|
+
case 20: // int8
|
|
38
|
+
fieldType = 'int8';
|
|
39
|
+
break;
|
|
40
|
+
case 21: // int2
|
|
41
|
+
fieldType = 'int2';
|
|
42
|
+
break;
|
|
43
|
+
case 23: // int4
|
|
44
|
+
fieldType = 'int4';
|
|
45
|
+
break;
|
|
46
|
+
case 700: // float4
|
|
47
|
+
fieldType = 'float4';
|
|
48
|
+
break;
|
|
49
|
+
case 701: // float8
|
|
50
|
+
fieldType = 'float8';
|
|
51
|
+
break;
|
|
52
|
+
case 1700: // numeric
|
|
53
|
+
fieldType = 'numeric';
|
|
54
|
+
break;
|
|
55
|
+
case 1082: // date
|
|
56
|
+
fieldType = 'date';
|
|
57
|
+
break;
|
|
58
|
+
case 1083: // time
|
|
59
|
+
fieldType = 'time';
|
|
60
|
+
break;
|
|
61
|
+
case 1184: // timestamptz
|
|
62
|
+
fieldType = 'timestamptz';
|
|
63
|
+
break;
|
|
64
|
+
case 1186: // interval
|
|
65
|
+
fieldType = 'interval';
|
|
66
|
+
break;
|
|
67
|
+
case 1114: // timestamp
|
|
68
|
+
fieldType = 'timestamp';
|
|
69
|
+
break;
|
|
70
|
+
case 1043: // varchar
|
|
71
|
+
default:
|
|
72
|
+
fieldType = 'varchar';
|
|
73
|
+
}
|
|
74
|
+
switch (field.dataTypeID) {
|
|
75
|
+
case 16: // boolean
|
|
76
|
+
jsType = 'bool';
|
|
77
|
+
break;
|
|
78
|
+
case 20: // int8
|
|
79
|
+
case 21: // int2
|
|
80
|
+
case 23: // int4
|
|
81
|
+
case 700: // float4
|
|
82
|
+
case 701: // float8
|
|
83
|
+
case 1700: // numeric
|
|
84
|
+
jsType = 'number';
|
|
85
|
+
break;
|
|
86
|
+
case 1082: // date
|
|
87
|
+
case 1083: // time
|
|
88
|
+
case 1184: // timestamptz
|
|
89
|
+
case 1186: // interval
|
|
90
|
+
case 1114: // timestamp
|
|
91
|
+
jsType = 'date';
|
|
92
|
+
break;
|
|
93
|
+
case 1043: // varchar
|
|
94
|
+
default:
|
|
95
|
+
jsType = 'string';
|
|
96
|
+
}
|
|
97
|
+
return {
|
|
98
|
+
label: field.name,
|
|
99
|
+
field: field.name,
|
|
100
|
+
format,
|
|
101
|
+
fieldType,
|
|
102
|
+
dataTypeID: field.dataTypeID,
|
|
103
|
+
jsType: jsType,
|
|
104
|
+
};
|
|
105
|
+
}
|
|
106
|
+
exports.convertPostgresColumn = convertPostgresColumn;
|
|
107
|
+
function convertColumnInfoToColumnInternal(columnInfo) {
|
|
108
|
+
return {
|
|
109
|
+
label: columnInfo.name,
|
|
110
|
+
field: columnInfo.name,
|
|
111
|
+
format: fieldTypeToFormat(columnInfo.fieldType),
|
|
112
|
+
fieldType: columnInfo.fieldType,
|
|
113
|
+
dataTypeID: fieldTypeToDataTypeID(columnInfo.fieldType),
|
|
114
|
+
jsType: convertFieldTypeToJSType(columnInfo.fieldType),
|
|
115
|
+
};
|
|
116
|
+
}
|
|
117
|
+
exports.convertColumnInfoToColumnInternal = convertColumnInfoToColumnInternal;
|
|
118
|
+
function fieldTypeToFormat(fieldType) {
|
|
119
|
+
switch (fieldType) {
|
|
120
|
+
case 'bool':
|
|
121
|
+
return 'string';
|
|
122
|
+
case 'int8':
|
|
123
|
+
case 'int2':
|
|
124
|
+
case 'int4':
|
|
125
|
+
return 'whole_number';
|
|
126
|
+
case 'float4':
|
|
127
|
+
case 'float8':
|
|
128
|
+
case 'numeric':
|
|
129
|
+
return 'two_decimal_places';
|
|
130
|
+
case 'date':
|
|
131
|
+
case 'time':
|
|
132
|
+
case 'timestamptz':
|
|
133
|
+
case 'timestamp':
|
|
134
|
+
return 'MMM_dd_yyyy';
|
|
135
|
+
case 'interval':
|
|
136
|
+
case 'varchar':
|
|
137
|
+
default:
|
|
138
|
+
return 'string';
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
function fieldTypeToDataTypeID(fieldType) {
|
|
142
|
+
switch (fieldType) {
|
|
143
|
+
case 'bool':
|
|
144
|
+
return 16;
|
|
145
|
+
case 'int8':
|
|
146
|
+
return 20;
|
|
147
|
+
case 'int2':
|
|
148
|
+
return 21;
|
|
149
|
+
case 'int4':
|
|
150
|
+
return 23;
|
|
151
|
+
case 'float4':
|
|
152
|
+
return 700;
|
|
153
|
+
case 'float8':
|
|
154
|
+
return 701;
|
|
155
|
+
case 'numeric':
|
|
156
|
+
return 1700;
|
|
157
|
+
case 'date':
|
|
158
|
+
return 1082;
|
|
159
|
+
case 'time':
|
|
160
|
+
return 1083;
|
|
161
|
+
case 'timestamptz':
|
|
162
|
+
return 1184;
|
|
163
|
+
case 'timestamp':
|
|
164
|
+
return 1114;
|
|
165
|
+
case 'interval':
|
|
166
|
+
return 1186;
|
|
167
|
+
case 'varchar':
|
|
168
|
+
default:
|
|
169
|
+
return 1043;
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
function convertFieldTypeToJSType(fieldType) {
|
|
173
|
+
switch (fieldType) {
|
|
174
|
+
case 'bool':
|
|
175
|
+
return 'bool';
|
|
176
|
+
case 'int8':
|
|
177
|
+
case 'int2':
|
|
178
|
+
case 'int4':
|
|
179
|
+
case 'float4':
|
|
180
|
+
case 'float8':
|
|
181
|
+
case 'numeric':
|
|
182
|
+
return 'number';
|
|
183
|
+
case 'date':
|
|
184
|
+
case 'time':
|
|
185
|
+
case 'timestamptz':
|
|
186
|
+
case 'timestamp':
|
|
187
|
+
return 'date';
|
|
188
|
+
case 'interval':
|
|
189
|
+
case 'varchar':
|
|
190
|
+
default:
|
|
191
|
+
return 'string';
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
function convertFormatToJsType(column) {
|
|
195
|
+
switch (column.format) {
|
|
196
|
+
case 'string':
|
|
197
|
+
return 'string';
|
|
198
|
+
case 'whole_number':
|
|
199
|
+
case 'two_decimal_places':
|
|
200
|
+
return 'number';
|
|
201
|
+
case 'MMM_dd_yyyy':
|
|
202
|
+
return 'date';
|
|
203
|
+
default:
|
|
204
|
+
return 'string';
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
exports.convertFormatToJsType = convertFormatToJsType;
|
|
@@ -121,15 +121,15 @@ function getPivotTable(itemInfo, dashboardFilters, config = undefined) {
|
|
|
121
121
|
const data = itemInfo ? itemInfo : config;
|
|
122
122
|
return pivot && data?.rows
|
|
123
123
|
? (0, PivotModal_1.generatePivotTable)(pivot, JSON.parse(JSON.stringify(data.rows)), // deep copy
|
|
124
|
-
dateFilter?.startDate
|
|
125
|
-
?
|
|
126
|
-
:
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
dateFilter
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
:
|
|
124
|
+
dateFilter?.startDate && dateFilter?.endDate
|
|
125
|
+
? { start: dateFilter.startDate, end: dateFilter.endDate }
|
|
126
|
+
: undefined, Boolean(dateFilter?.comparisonRange?.startDate), -1, dateFilter?.comparisonRange?.startDate &&
|
|
127
|
+
dateFilter?.comparisonRange?.endDate
|
|
128
|
+
? {
|
|
129
|
+
start: dateFilter.comparisonRange.startDate,
|
|
130
|
+
end: dateFilter.comparisonRange.endDate,
|
|
131
|
+
}
|
|
132
|
+
: undefined)
|
|
133
133
|
: null;
|
|
134
134
|
}
|
|
135
135
|
/**
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { Pivot } from '../internals/ReportBuilder/PivotModal';
|
|
2
|
+
import { Column } from '../models/Columns';
|
|
2
3
|
export declare function pivotToSql(pivot: Pivot, query: string, client: any): {
|
|
3
4
|
query: string;
|
|
4
5
|
preQueries?: string[];
|
|
5
6
|
runQueryConfig?: any;
|
|
6
7
|
} | undefined;
|
|
7
8
|
export declare function isValidPivot(pivot: Pivot): boolean;
|
|
8
|
-
export declare function getPossiblePivotFieldOptions(columns:
|
|
9
|
+
export declare function getPossiblePivotFieldOptions(columns: Column[], uniqueValues: {
|
|
9
10
|
[field: string]: any;
|
|
10
11
|
}): {
|
|
11
12
|
rowFields: string[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pivotProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/pivotProcessing.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"pivotProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/pivotProcessing.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,EAAE,MAAM,uCAAuC,CAAC;AAC9D,OAAO,EAAE,MAAM,EAAkB,MAAM,mBAAmB,CAAC;AAG3D,wBAAgB,UAAU,CACxB,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,GAAG,GACV;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,CAAC,EAAE,MAAM,EAAE,CAAC;IAAC,cAAc,CAAC,EAAE,GAAG,CAAA;CAAE,GAAG,SAAS,CAgD5E;AAmDD,wBAAgB,YAAY,CAAC,KAAK,EAAE,KAAK,WAgBxC;AAED,wBAAgB,4BAA4B,CAC1C,OAAO,EAAE,MAAM,EAAE,EACjB,YAAY,EAAE;IAAE,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG,CAAA;CAAE;;;;EAsCvC;AAED,wBAAgB,UAAU,CACxB,KAAK,EAAE,KAAK,EACZ,eAAe,EAAE;IACf,SAAS,EAAE,GAAG,CAAC;IACf,YAAY,EAAE,GAAG,CAAC;IAClB,WAAW,EAAE,GAAG,CAAC;CAClB,GACA,KAAK,CAqCP"}
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.cleanPivot = exports.getPossiblePivotFieldOptions = exports.isValidPivot = exports.pivotToSql = void 0;
|
|
4
|
-
const ChartBuilder_1 = require("../ChartBuilder");
|
|
5
|
-
const ast_1 = require("../components/ReportBuilder/ast");
|
|
6
4
|
const util_1 = require("../components/ReportBuilder/util");
|
|
5
|
+
const valueFormatter_1 = require("./valueFormatter");
|
|
7
6
|
function pivotToSql(pivot, query, client) {
|
|
8
7
|
const processedAggType = pivot.aggregationType?.toLowerCase() === 'average'
|
|
9
8
|
? 'avg'
|
|
@@ -110,9 +109,7 @@ function getPossiblePivotFieldOptions(columns, uniqueValues) {
|
|
|
110
109
|
let valueFields = [];
|
|
111
110
|
for (let column of columns) {
|
|
112
111
|
// row fields can be dates or strings
|
|
113
|
-
if (column.format
|
|
114
|
-
column.fieldType === 'date' ||
|
|
115
|
-
ChartBuilder_1.dateFormatOptions.includes(column.format)) {
|
|
112
|
+
if (valueFormatter_1.DATE_FORMAT_TYPES.includes(column.format)) {
|
|
116
113
|
rowFields.push(column.field);
|
|
117
114
|
}
|
|
118
115
|
// column fields can be strings
|
|
@@ -129,9 +126,7 @@ function getPossiblePivotFieldOptions(columns, uniqueValues) {
|
|
|
129
126
|
}
|
|
130
127
|
}
|
|
131
128
|
// value fields can be numbers
|
|
132
|
-
if (column.format
|
|
133
|
-
ChartBuilder_1.numberFormatOptions.includes(column.format) ||
|
|
134
|
-
(0, ast_1.isNumericColumnType)(column.fieldType)) {
|
|
129
|
+
if (valueFormatter_1.NUMBER_FORMAT_TYPES.includes(column.format)) {
|
|
135
130
|
if (!(0, util_1.isIdColumn)(column.field)) {
|
|
136
131
|
valueFields.push(column.field);
|
|
137
132
|
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
export declare const getUniqueValuesByColumns: (columns:
|
|
1
|
+
import { Column } from '../models/Columns';
|
|
2
|
+
export declare const getUniqueValuesByColumns: (columns: Column[], query: string, rows: any, client: any) => Promise<{
|
|
3
3
|
[column: string]: {
|
|
4
4
|
[value: string]: boolean;
|
|
5
5
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tableProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/tableProcessing.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"tableProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/tableProcessing.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAI3C,eAAO,MAAM,wBAAwB,YAC1B,MAAM,EAAE,SACV,MAAM,QACP,GAAG,UACD,GAAG;;;;SAwDZ,CAAC"}
|
|
@@ -4,9 +4,7 @@ exports.getUniqueValuesByColumns = void 0;
|
|
|
4
4
|
const dataFetcher_1 = require("./dataFetcher");
|
|
5
5
|
const queryConstructor_1 = require("./queryConstructor");
|
|
6
6
|
const getUniqueValuesByColumns = async (columns, query, rows, client) => {
|
|
7
|
-
const stringNames = columns.map(
|
|
8
|
-
// @ts-ignore
|
|
9
|
-
(column) => column.name || column.field);
|
|
7
|
+
const stringNames = columns.map((column) => column.field);
|
|
10
8
|
const uniqueValues = {};
|
|
11
9
|
if (!client.databaseType ||
|
|
12
10
|
client.databaseType.toLowerCase() === 'bigquery') {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { type AxisFormat } from '../Dashboard';
|
|
2
|
-
type Field = {
|
|
2
|
+
export type Field = {
|
|
3
3
|
_id: string;
|
|
4
4
|
label: string;
|
|
5
5
|
field: string;
|
|
@@ -11,6 +11,7 @@ type Props = {
|
|
|
11
11
|
fields: Field[];
|
|
12
12
|
};
|
|
13
13
|
export declare const DATE_FORMAT_TYPES: string[];
|
|
14
|
+
export declare const NUMBER_FORMAT_TYPES: string[];
|
|
14
15
|
/**
|
|
15
16
|
* Pretty-prints the given values to their nice-looking string form.
|
|
16
17
|
*/
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"valueFormatter.d.ts","sourceRoot":"","sources":["../../../src/utils/valueFormatter.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,cAAc,CAAC;AAE/C,
|
|
1
|
+
{"version":3,"file":"valueFormatter.d.ts","sourceRoot":"","sources":["../../../src/utils/valueFormatter.ts"],"names":[],"mappings":"AASA,OAAO,EAAE,KAAK,UAAU,EAAE,MAAM,cAAc,CAAC;AAE/C,MAAM,MAAM,KAAK,GAAG;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,UAAU,CAAC;CACpB,CAAC;AAEF,KAAK,KAAK,GAAG;IACX,KAAK,EAAE,GAAG,CAAC;IACX,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAAC;IACjC,MAAM,EAAE,KAAK,EAAE,CAAC;CACjB,CAAC;AAEF,eAAO,MAAM,iBAAiB,UAQ7B,CAAC;AAEF,eAAO,MAAM,mBAAmB,UAM/B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,cAAc,6BAA8B,KAAK,KAAG,MAwChE,CAAC;AAEF,eAAO,MAAM,WAAW;WAIf,GAAG;YACF,MAAM;MACZ,MAwCH,CAAC;AAoMF,eAAO,MAAM,aAAa;;;;WAGhB,MAAM,KACb,MA6CF,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.compareValues = exports.quillFormat = exports.valueFormatter = exports.DATE_FORMAT_TYPES = void 0;
|
|
3
|
+
exports.compareValues = exports.quillFormat = exports.valueFormatter = exports.NUMBER_FORMAT_TYPES = exports.DATE_FORMAT_TYPES = void 0;
|
|
4
4
|
const date_fns_1 = require("date-fns");
|
|
5
5
|
const date_fns_tz_1 = require("date-fns-tz");
|
|
6
6
|
exports.DATE_FORMAT_TYPES = [
|
|
@@ -12,6 +12,13 @@ exports.DATE_FORMAT_TYPES = [
|
|
|
12
12
|
'MMM_dd_hh:mm_ap_pm',
|
|
13
13
|
'wo, yyyy',
|
|
14
14
|
];
|
|
15
|
+
exports.NUMBER_FORMAT_TYPES = [
|
|
16
|
+
'whole_number',
|
|
17
|
+
'one_decimal_place',
|
|
18
|
+
'two_decimal_places',
|
|
19
|
+
'dollar_amount',
|
|
20
|
+
'dollar_cents',
|
|
21
|
+
];
|
|
15
22
|
/**
|
|
16
23
|
* Pretty-prints the given values to their nice-looking string form.
|
|
17
24
|
*/
|
|
@@ -54,6 +61,10 @@ const valueFormatter = ({ value, field, fields }) => {
|
|
|
54
61
|
};
|
|
55
62
|
exports.valueFormatter = valueFormatter;
|
|
56
63
|
const quillFormat = ({ value, format, }) => {
|
|
64
|
+
// Handle special case, if value is null and format is numeric display '-'
|
|
65
|
+
if (value === null && exports.NUMBER_FORMAT_TYPES.includes(format)) {
|
|
66
|
+
return '-';
|
|
67
|
+
}
|
|
57
68
|
const HANDLERS = {
|
|
58
69
|
percent: formatPercent,
|
|
59
70
|
dollar_amount: formatDollarAmount,
|
package/dist/esm/Chart.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Chart.d.ts","sourceRoot":"","sources":["../../src/Chart.tsx"],"names":[],"mappings":";AAWA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAgB7C,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAsGjD,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,WAQhE;AAED,MAAM,MAAM,YAAY,GAAG;IACzB,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;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,aAAa,GAAG,GAAG,CAAC;IAE7B;;;;;;;;OAQG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;;;;OAKG;IACH,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAC;IAEtC;;OAEG;IACH,yBAAyB,CAAC,EAAE,OAAO,CAAC;IAEpC;;OAEG;IACH,wBAAwB,CAAC,EAAE,OAAO,CAAC;IAEnC;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAE9B;;;OAGG;IACH,mBAAmB,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAEzC;;OAEG;IACH,sBAAsB,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAE5C;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACH,iBAAiB,CAAC,EAAE,CAClB,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,UAAU,KACd,YAAY,CAAC;IAElB;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CACtC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,QAAA,MAAM,KAAK,UAAW,UAAU,4CA2C/B,CAAC;
|
|
1
|
+
{"version":3,"file":"Chart.d.ts","sourceRoot":"","sources":["../../src/Chart.tsx"],"names":[],"mappings":";AAWA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAgB7C,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAsGjD,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,WAQhE;AAED,MAAM,MAAM,YAAY,GAAG;IACzB,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;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB;;;;;;;OAOG;IACH,MAAM,CAAC,EAAE,aAAa,GAAG,GAAG,CAAC;IAE7B;;;;;;;;OAQG;IACH,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB;;;;;OAKG;IACH,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAElB;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;OAEG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;OAEG;IACH,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAE5B;;OAEG;IACH,2BAA2B,CAAC,EAAE,OAAO,CAAC;IAEtC;;OAEG;IACH,yBAAyB,CAAC,EAAE,OAAO,CAAC;IAEpC;;OAEG;IACH,wBAAwB,CAAC,EAAE,OAAO,CAAC;IAEnC;;OAEG;IACH,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAE9B;;;OAGG;IACH,mBAAmB,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAEzC;;OAEG;IACH,sBAAsB,CAAC,EAAE,OAAO,GAAG,QAAQ,CAAC;IAE5C;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACH,iBAAiB,CAAC,EAAE,CAClB,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,UAAU,KACd,YAAY,CAAC;IAElB;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;CACtC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,QAAA,MAAM,KAAK,UAAW,UAAU,4CA2C/B,CAAC;AA2lBF,eAAe,KAAK,CAAC"}
|
package/dist/esm/Chart.js
CHANGED
|
@@ -213,15 +213,15 @@ const ChartDisplay = ({ config, colors, className, containerStyle, hideXAxis, hi
|
|
|
213
213
|
const data = config;
|
|
214
214
|
return pivot && data?.rows
|
|
215
215
|
? generatePivotTable(pivot, JSON.parse(JSON.stringify(data.rows)), // deep copy
|
|
216
|
-
dateFilter
|
|
217
|
-
?
|
|
218
|
-
:
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
dateFilter
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
:
|
|
216
|
+
dateFilter && dateFilter.startDate && dateFilter.endDate
|
|
217
|
+
? { start: dateFilter.startDate, end: dateFilter.endDate }
|
|
218
|
+
: undefined, Boolean(dateFilter?.comparisonRange?.startDate), -1, dateFilter?.comparisonRange?.startDate &&
|
|
219
|
+
dateFilter?.comparisonRange.endDate
|
|
220
|
+
? {
|
|
221
|
+
start: dateFilter.comparisonRange.startDate,
|
|
222
|
+
end: dateFilter.comparisonRange.endDate,
|
|
223
|
+
}
|
|
224
|
+
: undefined)
|
|
225
225
|
: null;
|
|
226
226
|
}, [config?.pivot]);
|
|
227
227
|
const pivotTableYAxis = useMemo(() => {
|
|
@@ -239,9 +239,10 @@ const ChartDisplay = ({ config, colors, className, containerStyle, hideXAxis, hi
|
|
|
239
239
|
}
|
|
240
240
|
else if (!pivotTable &&
|
|
241
241
|
config &&
|
|
242
|
+
config?.chartType !== 'metric' &&
|
|
242
243
|
config.rows &&
|
|
243
244
|
config.rows.length > MAX_ROWS_FOR_GENERIC_TABLE) {
|
|
244
|
-
return (_jsx(ChartError, { className: className, containerStyle: containerStyle, label: "Charts can only display
|
|
245
|
+
return (_jsx(ChartError, { className: className, containerStyle: containerStyle, label: "Charts can only display 300 rows. Please add a pivot or modify the query." }));
|
|
245
246
|
}
|
|
246
247
|
else if (!config || loading) {
|
|
247
248
|
return (_jsx(ChartSkeleton, { className: className, containerStyle: containerStyle }));
|
|
@@ -268,8 +269,10 @@ const ChartDisplay = ({ config, colors, className, containerStyle, hideXAxis, hi
|
|
|
268
269
|
// Walk through data.columns and pick off the labels from yAxisFields
|
|
269
270
|
columns.forEach((col, index) => {
|
|
270
271
|
// ADD THE RIGHT FIELD TYPE FOR THE VALUE COLUMNS
|
|
271
|
-
if (valueFieldType
|
|
272
|
-
|
|
272
|
+
if ((valueFieldType ||
|
|
273
|
+
['min', 'max'].includes(config?.pivot.aggregationType)) &&
|
|
274
|
+
index !== 0) {
|
|
275
|
+
col.format = valueFieldType || 'two_decimal_places';
|
|
273
276
|
}
|
|
274
277
|
if (!data.yAxisFields)
|
|
275
278
|
return;
|
|
@@ -293,7 +296,7 @@ const ChartDisplay = ({ config, colors, className, containerStyle, hideXAxis, hi
|
|
|
293
296
|
return (_jsx(QuillTable, { rows: formattedRows ?? [], columns: columns ?? data.yAxisFields, rowsPerPage: config?.rowsPerPage || 10, containerStyle: {
|
|
294
297
|
width: containerStyle?.width || '100%',
|
|
295
298
|
height: containerStyle?.height || '400px',
|
|
296
|
-
}, className: className,
|
|
299
|
+
}, className: className, downloadCSV: () => {
|
|
297
300
|
downloadCSV({
|
|
298
301
|
rows: pivotTable?.rows ?? data.rows ?? [],
|
|
299
302
|
fields: columns ?? data.yAxisFields,
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import React, { ReactNode } from 'react';
|
|
2
|
+
import { ColumnInternal } from './models/Columns';
|
|
2
3
|
import { DashboardItem } from './Dashboard';
|
|
3
4
|
export declare const numberFormatOptions: string[];
|
|
4
5
|
export declare const dateFormatOptions: string[];
|
|
@@ -145,24 +146,7 @@ export interface ChartBuilderProps {
|
|
|
145
146
|
/**
|
|
146
147
|
* Columns of this query response.
|
|
147
148
|
*/
|
|
148
|
-
columns:
|
|
149
|
-
label: string;
|
|
150
|
-
field: string;
|
|
151
|
-
name: string;
|
|
152
|
-
displayName: string;
|
|
153
|
-
fieldType: string;
|
|
154
|
-
format: string;
|
|
155
|
-
}[];
|
|
156
|
-
/** The fields on this query. */
|
|
157
|
-
fields?: {
|
|
158
|
-
name: string;
|
|
159
|
-
tableID: number;
|
|
160
|
-
columnID: number;
|
|
161
|
-
dataTypeID: number;
|
|
162
|
-
dataTypeSize: number;
|
|
163
|
-
dataTypeModifier: number;
|
|
164
|
-
format: string;
|
|
165
|
-
}[];
|
|
149
|
+
columns: ColumnInternal[];
|
|
166
150
|
/** The SQL query for this dashboard item. */
|
|
167
151
|
query?: string;
|
|
168
152
|
/** Whether the ChartBuilder is in horizontal view mode. */
|
|
@@ -199,7 +183,10 @@ export interface ChartBuilderProps {
|
|
|
199
183
|
}[];
|
|
200
184
|
};
|
|
201
185
|
/** The date range applied to this ChartBuilder. */
|
|
202
|
-
dateRange?:
|
|
186
|
+
dateRange?: {
|
|
187
|
+
start: Date;
|
|
188
|
+
end: Date;
|
|
189
|
+
} | undefined;
|
|
203
190
|
/** The dashboardItem for this ChartBuilder. */
|
|
204
191
|
dashboardItem?: DashboardItem | any;
|
|
205
192
|
/** A list of generated pivots that were recommended as useful for this query. */
|
|
@@ -295,7 +282,7 @@ export declare function ChartBuilderWithModal(props: ChartBuilderProps): import(
|
|
|
295
282
|
* ### Chart Builder API
|
|
296
283
|
* @see https://docs.quillsql.com/components/chart-builder
|
|
297
284
|
*/
|
|
298
|
-
export default function ChartBuilder({ TextInputComponent, SelectComponent, ButtonComponent, SecondaryButtonComponent, HeaderComponent, SubHeaderComponent, LabelComponent, DeleteButtonComponent, TextComponent, PopoverComponent, CardComponent, TableComponent, ModalComponent, ErrorMessageComponent, ChartBuilderInputRowContainer, ChartBuilderInputColumnContainer, PivotRowContainer, PivotColumnContainer, FormContainer, isOpen, isHorizontalView, pivot, setIsOpen, rows, columns, query, queryNoDateColumn, dateRange: dr, showTableFormatOptions, showDateFieldOptions, showAccessControlOptions, showDashboardDropdown, onAddToDashboardComplete, onDelete,
|
|
285
|
+
export default function ChartBuilder({ TextInputComponent, SelectComponent, ButtonComponent, SecondaryButtonComponent, HeaderComponent, SubHeaderComponent, LabelComponent, DeleteButtonComponent, TextComponent, PopoverComponent, CardComponent, TableComponent, ModalComponent, ErrorMessageComponent, ChartBuilderInputRowContainer, ChartBuilderInputColumnContainer, PivotRowContainer, PivotColumnContainer, FormContainer, isOpen, isHorizontalView, pivot, setIsOpen, rows, columns, query, queryNoDateColumn, dateRange: dr, showTableFormatOptions, showDateFieldOptions, showAccessControlOptions, showDashboardDropdown, onAddToDashboardComplete, onDelete, dashboardItem, recommendedPivots: rp, createdPivots: cp, destinationDashboard, dateColumn, buttonLabel, organizationName, pivotData, hideDeleteButton, hideSubmitButton, hideDateRangeFilter, initialUniqueValues, pivotRecommendationsEnabled, }: ChartBuilderProps): import("react/jsx-runtime").JSX.Element | null;
|
|
299
286
|
export declare function DashboardFilterModal({ isOpen, setIsOpen, issues, ModalComponent, ButtonComponent, }: {
|
|
300
287
|
isOpen: boolean;
|
|
301
288
|
setIsOpen: (e: boolean) => void;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChartBuilder.d.ts","sourceRoot":"","sources":["../../src/ChartBuilder.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAOZ,SAAS,EACV,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"ChartBuilder.d.ts","sourceRoot":"","sources":["../../src/ChartBuilder.tsx"],"names":[],"mappings":"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"}
|