@quillsql/react 2.12.2 → 2.12.4
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 +2 -0
- package/dist/cjs/ChartBuilder.d.ts.map +1 -1
- package/dist/cjs/ChartBuilder.js +21 -30
- package/dist/cjs/Context.d.ts +1 -0
- package/dist/cjs/Context.d.ts.map +1 -1
- package/dist/cjs/Context.js +58 -30
- package/dist/cjs/Dashboard.d.ts.map +1 -1
- package/dist/cjs/Dashboard.js +3 -3
- package/dist/cjs/QuillProvider.d.ts +3 -3
- package/dist/cjs/QuillProvider.d.ts.map +1 -1
- package/dist/cjs/QuillProvider.js +1 -1
- package/dist/cjs/ReportBuilder.d.ts.map +1 -1
- package/dist/cjs/ReportBuilder.js +14 -60
- package/dist/cjs/SQLEditor.d.ts.map +1 -1
- package/dist/cjs/SQLEditor.js +12 -26
- package/dist/cjs/Table.d.ts.map +1 -1
- package/dist/cjs/Table.js +2 -0
- package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/cjs/components/Dashboard/DataLoader.js +4 -0
- package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts +11 -0
- package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -0
- package/dist/cjs/components/QuillMultiSelectWithCombo.js +228 -0
- package/dist/cjs/components/QuillSelectWithCombo.d.ts +6 -0
- package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -0
- package/dist/cjs/components/QuillSelectWithCombo.js +186 -0
- package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
- package/dist/cjs/hooks/useQuill.js +2 -0
- package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/cjs/internals/ReportBuilder/PivotModal.js +2 -1
- package/dist/cjs/utils/schema.d.ts +6 -0
- package/dist/cjs/utils/schema.d.ts.map +1 -0
- package/dist/cjs/utils/schema.js +118 -0
- package/dist/cjs/utils/tableProcessing.d.ts +1 -1
- package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
- package/dist/cjs/utils/tableProcessing.js +5 -3
- package/dist/cjs/utils/valueFormatter.js +1 -1
- package/dist/esm/Chart.d.ts.map +1 -1
- package/dist/esm/Chart.js +3 -1
- package/dist/esm/ChartBuilder.d.ts.map +1 -1
- package/dist/esm/ChartBuilder.js +21 -30
- package/dist/esm/Context.d.ts +1 -0
- package/dist/esm/Context.d.ts.map +1 -1
- package/dist/esm/Context.js +57 -29
- package/dist/esm/Dashboard.d.ts.map +1 -1
- package/dist/esm/Dashboard.js +3 -3
- package/dist/esm/QuillProvider.d.ts +3 -3
- package/dist/esm/QuillProvider.d.ts.map +1 -1
- package/dist/esm/QuillProvider.js +1 -1
- package/dist/esm/ReportBuilder.d.ts.map +1 -1
- package/dist/esm/ReportBuilder.js +15 -61
- package/dist/esm/SQLEditor.d.ts.map +1 -1
- package/dist/esm/SQLEditor.js +13 -27
- package/dist/esm/Table.d.ts.map +1 -1
- package/dist/esm/Table.js +3 -1
- package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
- package/dist/esm/components/Dashboard/DataLoader.js +5 -1
- package/dist/esm/components/QuillMultiSelectWithCombo.d.ts +11 -0
- package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -0
- package/dist/esm/components/QuillMultiSelectWithCombo.js +200 -0
- package/dist/esm/components/QuillSelectWithCombo.d.ts +6 -0
- package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -0
- package/dist/esm/components/QuillSelectWithCombo.js +159 -0
- package/dist/esm/hooks/useQuill.d.ts.map +1 -1
- package/dist/esm/hooks/useQuill.js +3 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
- package/dist/esm/internals/ReportBuilder/PivotModal.js +3 -2
- package/dist/esm/utils/schema.d.ts +6 -0
- package/dist/esm/utils/schema.d.ts.map +1 -0
- package/dist/esm/utils/schema.js +113 -0
- package/dist/esm/utils/tableProcessing.d.ts +1 -1
- package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
- package/dist/esm/utils/tableProcessing.js +5 -3
- package/dist/esm/utils/valueFormatter.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
+
if (mod && mod.__esModule) return mod;
|
|
20
|
+
var result = {};
|
|
21
|
+
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
+
__setModuleDefault(result, mod);
|
|
23
|
+
return result;
|
|
24
|
+
};
|
|
25
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
26
|
+
exports.QuillSelectComponentWithCombo = void 0;
|
|
27
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
28
|
+
const hooks_1 = require("../hooks");
|
|
29
|
+
const react_1 = __importStar(require("react"));
|
|
30
|
+
const Context_1 = require("../Context");
|
|
31
|
+
const QuillMultiSelectWithCombo_1 = require("./QuillMultiSelectWithCombo");
|
|
32
|
+
/**
|
|
33
|
+
* A robust select component that implements the new minimal Select interface.
|
|
34
|
+
*/
|
|
35
|
+
function QuillSelectComponentWithCombo({ options, value, width, onChange, label, }) {
|
|
36
|
+
const [theme] = (0, react_1.useContext)(Context_1.ThemeContext);
|
|
37
|
+
const [showModal, setShowModal] = (0, react_1.useState)(false);
|
|
38
|
+
const modalRef = (0, react_1.useRef)(null);
|
|
39
|
+
const [searchQuery, setSearchQuery] = react_1.default.useState('');
|
|
40
|
+
const [filteredItems, setFilteredItems] = react_1.default.useState(options.slice(0, 20));
|
|
41
|
+
(0, hooks_1.useOnClickOutside)(modalRef, (e) => setShowModal(false));
|
|
42
|
+
const handleSearchChange = (value) => {
|
|
43
|
+
setSearchQuery(value);
|
|
44
|
+
const curFilteredItems = value === ''
|
|
45
|
+
? options.slice(0, 20)
|
|
46
|
+
: options
|
|
47
|
+
.filter((option) => {
|
|
48
|
+
if (!option) {
|
|
49
|
+
return false;
|
|
50
|
+
}
|
|
51
|
+
return option.value
|
|
52
|
+
.toLowerCase()
|
|
53
|
+
.replace(/\s+/g, '')
|
|
54
|
+
.includes(value.toLowerCase().replace(/\s+/g, ''));
|
|
55
|
+
})
|
|
56
|
+
.slice(0, 20);
|
|
57
|
+
setFilteredItems(curFilteredItems);
|
|
58
|
+
};
|
|
59
|
+
(0, hooks_1.useOnClickOutside)(modalRef, (e) => setShowModal(false));
|
|
60
|
+
return ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
61
|
+
position: 'relative',
|
|
62
|
+
// width: 200,
|
|
63
|
+
// minWidth: 200,
|
|
64
|
+
borderRadius: '6px',
|
|
65
|
+
width: width,
|
|
66
|
+
minWidth: width,
|
|
67
|
+
}, children: [label && ((0, jsx_runtime_1.jsx)("div", { style: {
|
|
68
|
+
fontSize: 14,
|
|
69
|
+
color: theme.secondaryTextColor,
|
|
70
|
+
fontFamily: theme.fontFamily,
|
|
71
|
+
paddingBottom: 5,
|
|
72
|
+
fontWeight: 600,
|
|
73
|
+
}, children: label })), (0, jsx_runtime_1.jsxs)("button", { style: {
|
|
74
|
+
fontFamily: theme.fontFamily,
|
|
75
|
+
color: theme.primaryTextColor,
|
|
76
|
+
width: '100%',
|
|
77
|
+
display: 'flex',
|
|
78
|
+
alignItems: 'center',
|
|
79
|
+
justifyContent: 'space-between',
|
|
80
|
+
lineHeight: 'inherit',
|
|
81
|
+
padding: '8px 12px',
|
|
82
|
+
fontSize: 14,
|
|
83
|
+
margin: 0,
|
|
84
|
+
boxSizing: 'border-box',
|
|
85
|
+
borderWidth: 1,
|
|
86
|
+
borderStyle: 'solid',
|
|
87
|
+
borderColor: theme.borderColor,
|
|
88
|
+
borderRadius: 6,
|
|
89
|
+
paddingTop: 9,
|
|
90
|
+
paddingBottom: 9,
|
|
91
|
+
height: 40,
|
|
92
|
+
minHeight: 40,
|
|
93
|
+
maxHeight: 40,
|
|
94
|
+
}, className: "quill-select-button", onClick: () => setShowModal((showModal) => !showModal), children: [(0, jsx_runtime_1.jsx)("style", { children: ` .quill-select-button { background: ${theme.backgroundColor}; } .quill-select-button:hover { background: ${theme.hoverBackgroundColor}; }` }), (0, jsx_runtime_1.jsx)("span", { style: {
|
|
95
|
+
textOverflow: 'ellipsis',
|
|
96
|
+
whiteSpace: 'nowrap',
|
|
97
|
+
overflow: 'hidden',
|
|
98
|
+
}, children: options.find((elem) => elem.value === value)?.label || 'Select' }), (0, jsx_runtime_1.jsx)("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 20 20", fill: "currentColor", "aria-hidden": "true", "data-slot": "icon", height: 20, width: 20, style: { minHeight: 20, minWidth: 20 }, children: (0, jsx_runtime_1.jsx)("path", { fillRule: "evenodd", d: "M5.22 8.22a.75.75 0 0 1 1.06 0L10 11.94l3.72-3.72a.75.75 0 1 1 1.06 1.06l-4.25 4.25a.75.75 0 0 1-1.06 0L5.22 9.28a.75.75 0 0 1 0-1.06Z", clipRule: "evenodd" }) })] }), showModal && ((0, jsx_runtime_1.jsxs)("div", { ref: modalRef, style: {
|
|
99
|
+
position: 'absolute',
|
|
100
|
+
width: '100%',
|
|
101
|
+
display: 'flex',
|
|
102
|
+
flexDirection: 'column',
|
|
103
|
+
boxSizing: 'border-box',
|
|
104
|
+
borderWidth: 1,
|
|
105
|
+
borderStyle: 'solid',
|
|
106
|
+
borderColor: theme.borderColor,
|
|
107
|
+
borderRadius: 6,
|
|
108
|
+
background: 'white',
|
|
109
|
+
marginTop: 12,
|
|
110
|
+
zIndex: 100,
|
|
111
|
+
paddingTop: 6,
|
|
112
|
+
paddingBottom: 6,
|
|
113
|
+
paddingLeft: 6,
|
|
114
|
+
paddingRight: 6,
|
|
115
|
+
fontFamily: theme.fontFamily,
|
|
116
|
+
maxHeight: '50vh',
|
|
117
|
+
overflow: 'scroll',
|
|
118
|
+
}, children: [options && options.length > 20 && ((0, jsx_runtime_1.jsx)(QuillMultiSelectWithCombo_1.ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
|
|
119
|
+
handleSearchChange(value);
|
|
120
|
+
} })), searchQuery === '' && ((0, jsx_runtime_1.jsxs)("button", { style: {
|
|
121
|
+
display: 'flex',
|
|
122
|
+
alignItems: 'center',
|
|
123
|
+
justifyContent: 'space-between',
|
|
124
|
+
padding: '8px 8px',
|
|
125
|
+
margin: 0,
|
|
126
|
+
boxSizing: 'border-box',
|
|
127
|
+
borderWidth: 0,
|
|
128
|
+
fontSize: 14,
|
|
129
|
+
borderStyle: 'solid',
|
|
130
|
+
borderColor: theme.borderColor,
|
|
131
|
+
borderRadius: 4,
|
|
132
|
+
fontFamily: theme.fontFamily,
|
|
133
|
+
textOverflow: 'ellipsis',
|
|
134
|
+
whiteSpace: 'nowrap',
|
|
135
|
+
overflow: 'hidden',
|
|
136
|
+
height: 34,
|
|
137
|
+
minHeight: 34,
|
|
138
|
+
}, className: "quill-option", onClick: () => {
|
|
139
|
+
// Manually create a synthetic ChangeEvent and pass it to callback
|
|
140
|
+
const changeEvent = { target: { value: '' } };
|
|
141
|
+
onChange(changeEvent);
|
|
142
|
+
setShowModal(false);
|
|
143
|
+
}, children: [(0, jsx_runtime_1.jsx)("style", { children: `
|
|
144
|
+
.quill-option {
|
|
145
|
+
background: white;
|
|
146
|
+
}
|
|
147
|
+
.quill-option:hover {
|
|
148
|
+
background: #F4F4F5;
|
|
149
|
+
}
|
|
150
|
+
` }), 'Select'] })), filteredItems.map((option) => ((0, jsx_runtime_1.jsxs)("button", { style: {
|
|
151
|
+
display: 'flex',
|
|
152
|
+
alignItems: 'center',
|
|
153
|
+
justifyContent: 'space-between',
|
|
154
|
+
padding: '8px 8px',
|
|
155
|
+
margin: 0,
|
|
156
|
+
boxSizing: 'border-box',
|
|
157
|
+
borderWidth: 0,
|
|
158
|
+
fontSize: 14,
|
|
159
|
+
borderStyle: 'solid',
|
|
160
|
+
borderColor: theme.borderColor,
|
|
161
|
+
borderRadius: 4,
|
|
162
|
+
fontFamily: theme.fontFamily,
|
|
163
|
+
textOverflow: 'ellipsis',
|
|
164
|
+
whiteSpace: 'nowrap',
|
|
165
|
+
height: 34,
|
|
166
|
+
minHeight: 34,
|
|
167
|
+
overflow: 'hidden',
|
|
168
|
+
}, className: "quill-option", onClick: () => {
|
|
169
|
+
// Manually create a synthetic ChangeEvent and pass it to callback
|
|
170
|
+
const changeEvent = { target: { value: option.value } };
|
|
171
|
+
onChange(changeEvent);
|
|
172
|
+
setShowModal(false);
|
|
173
|
+
}, children: [(0, jsx_runtime_1.jsx)("style", { children: `
|
|
174
|
+
.quill-option {
|
|
175
|
+
background: white;
|
|
176
|
+
}
|
|
177
|
+
.quill-option:hover {
|
|
178
|
+
background: #F4F4F5;
|
|
179
|
+
}
|
|
180
|
+
` }), (0, jsx_runtime_1.jsx)("span", { style: {
|
|
181
|
+
textOverflow: 'ellipsis',
|
|
182
|
+
whiteSpace: 'nowrap',
|
|
183
|
+
overflow: 'hidden',
|
|
184
|
+
}, children: option.label })] }, option.value)))] }))] }));
|
|
185
|
+
}
|
|
186
|
+
exports.QuillSelectComponentWithCombo = QuillSelectComponentWithCombo;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAWA,UAAU,MAAM;IACd,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,KAAK;IACpB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,gBAAgB,EAAE,MAAM,CAAC;IACzB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,UAAU;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,UAAU,WAAW;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,EAAE,MAAM,CAAC;IACd,gBAAgB,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,eAAO,MAAM,QAAQ,aACT,MAAM;UAEV,WAAW,GAAG,IAAI;aACf,OAAO;WACT,MAAM,GAAG,IAAI;CAoFrB,CAAC"}
|
|
@@ -9,6 +9,7 @@ const errorProcessing_1 = require("../utils/errorProcessing");
|
|
|
9
9
|
const useQuill = (reportId) => {
|
|
10
10
|
const { dashboard, dispatch } = (0, react_1.useContext)(Context_1.DashboardContext);
|
|
11
11
|
const { dashboardFilters } = (0, react_1.useContext)(Context_1.DashboardFiltersContext);
|
|
12
|
+
const [customFields] = (0, react_1.useContext)(Context_1.CustomFieldContext);
|
|
12
13
|
const [client] = (0, react_1.useContext)(Context_1.ClientContext);
|
|
13
14
|
const [data, setData] = (0, react_1.useState)(null);
|
|
14
15
|
const [loading, setLoading] = (0, react_1.useState)(true);
|
|
@@ -35,6 +36,7 @@ const useQuill = (reportId) => {
|
|
|
35
36
|
task: 'item',
|
|
36
37
|
filters: [...Object.values(dashboardFilters)],
|
|
37
38
|
databaseType: client?.databaseType,
|
|
39
|
+
customFields,
|
|
38
40
|
},
|
|
39
41
|
};
|
|
40
42
|
const cloudBody = {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"PivotModal.d.ts","sourceRoot":"","sources":["../../../../src/internals/ReportBuilder/PivotModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -34,6 +34,7 @@ const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField, setPivo
|
|
|
34
34
|
const [selectedPivotType, setSelectedPivotType] = (0, react_1.useState)('recommended');
|
|
35
35
|
const [errors, setErrors] = (0, react_1.useState)([]);
|
|
36
36
|
const [client] = (0, react_1.useContext)(Context_1.ClientContext);
|
|
37
|
+
const [customFields] = (0, react_1.useContext)(Context_1.CustomFieldContext);
|
|
37
38
|
const rowFieldRef = (0, react_1.useRef)(null);
|
|
38
39
|
const colFieldRef = (0, react_1.useRef)(null);
|
|
39
40
|
const [pivotCardWidth, setPivotCardWidth] = (0, react_1.useState)(420);
|
|
@@ -55,7 +56,7 @@ const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField, setPivo
|
|
|
55
56
|
setAllowedValueFields(possibleColumns.valueFields);
|
|
56
57
|
return possibleColumns;
|
|
57
58
|
}
|
|
58
|
-
const newUniqueValues = await (0, tableProcessing_1.getUniqueValuesByColumns)(stringColumns, query || '', data.rows || [], client);
|
|
59
|
+
const newUniqueValues = await (0, tableProcessing_1.getUniqueValuesByColumns)(stringColumns, query || '', data.rows || [], client, customFields);
|
|
59
60
|
if (!uniqueValues ||
|
|
60
61
|
(0, crypto_1.hashCode)(uniqueValues) !== (0, crypto_1.hashCode)(newUniqueValues)) {
|
|
61
62
|
const possibleColumns = (0, pivotProcessing_1.getPossiblePivotFieldOptions)(columns, newUniqueValues || {});
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const getCustomFieldInfo: (client: any, caller?: string) => Promise<any[]>;
|
|
2
|
+
export declare const getSchemaInfoWithCustomFields: (client: any, caller?: string) => Promise<{
|
|
3
|
+
schemaData: any;
|
|
4
|
+
customFieldsByTable: any[];
|
|
5
|
+
}>;
|
|
6
|
+
//# sourceMappingURL=schema.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../src/utils/schema.ts"],"names":[],"mappings":"AAuBA,eAAO,MAAM,kBAAkB,WAAkB,GAAG,oCA6DnD,CAAC;AAEF,eAAO,MAAM,6BAA6B,WAChC,GAAG;;;EA2CZ,CAAC"}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getSchemaInfoWithCustomFields = exports.getCustomFieldInfo = void 0;
|
|
4
|
+
const parseResponse = (results) => {
|
|
5
|
+
if (results.data?.data) {
|
|
6
|
+
if (results.data.data.queries &&
|
|
7
|
+
results.data.data.queries.queryResults.length > 0) {
|
|
8
|
+
return results.data.data.queries.queryResults;
|
|
9
|
+
}
|
|
10
|
+
else {
|
|
11
|
+
return results.data.data.tables;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
if (results.queries &&
|
|
16
|
+
results.queries.queryResults &&
|
|
17
|
+
results.queries.queryResults.length > 0) {
|
|
18
|
+
return results.queries.queryResults;
|
|
19
|
+
}
|
|
20
|
+
else {
|
|
21
|
+
return results.data.tables;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
const getCustomFieldInfo = async (client, caller = 'se') => {
|
|
26
|
+
let customFieldsByTableUnique = [];
|
|
27
|
+
try {
|
|
28
|
+
const { queryEndpoint, queryHeaders, publicKey, databaseType, customerId } = client;
|
|
29
|
+
let response = await fetch(`${queryEndpoint}?cfr-${caller}`, {
|
|
30
|
+
method: 'POST',
|
|
31
|
+
headers: {
|
|
32
|
+
...queryHeaders,
|
|
33
|
+
'Content-Type': 'application/json',
|
|
34
|
+
},
|
|
35
|
+
body: JSON.stringify({
|
|
36
|
+
metadata: {
|
|
37
|
+
clientId: publicKey,
|
|
38
|
+
publicKey,
|
|
39
|
+
task: 'custom-field-records',
|
|
40
|
+
databaseType: databaseType,
|
|
41
|
+
orgId: customerId,
|
|
42
|
+
},
|
|
43
|
+
}),
|
|
44
|
+
});
|
|
45
|
+
let result = await response.json();
|
|
46
|
+
const extractedData = parseResponse(result);
|
|
47
|
+
const customFieldsByTable = [];
|
|
48
|
+
extractedData.forEach((table) => {
|
|
49
|
+
if (!table.rows) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
table.rows.forEach((row) => {
|
|
53
|
+
customFieldsByTable.push({
|
|
54
|
+
ref_table: row.ref_table,
|
|
55
|
+
field: row.field,
|
|
56
|
+
ref_column: row.ref_column,
|
|
57
|
+
type: row.type,
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
});
|
|
61
|
+
// make sure the are no duplicate records in extractedData
|
|
62
|
+
const customFieldsByTableSet = new Set();
|
|
63
|
+
customFieldsByTableUnique = customFieldsByTable.filter((item) => {
|
|
64
|
+
if (customFieldsByTableSet.has(item.ref_table + item.field + item.ref_column + item.type)) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
customFieldsByTableSet.add(item.ref_table + item.field + item.ref_column + item.type);
|
|
68
|
+
return true;
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
catch (e) {
|
|
72
|
+
console.error('CUSTOM FIELDS DISABLED');
|
|
73
|
+
}
|
|
74
|
+
return customFieldsByTableUnique;
|
|
75
|
+
};
|
|
76
|
+
exports.getCustomFieldInfo = getCustomFieldInfo;
|
|
77
|
+
const getSchemaInfoWithCustomFields = async (client, caller = 'se') => {
|
|
78
|
+
const { queryEndpoint, queryHeaders, publicKey, databaseType, customerId } = client;
|
|
79
|
+
let customFieldsByTableUnique = [];
|
|
80
|
+
let getCustomFields = true;
|
|
81
|
+
if (!customerId || customerId !== '*') {
|
|
82
|
+
try {
|
|
83
|
+
customFieldsByTableUnique = await (0, exports.getCustomFieldInfo)(client, caller);
|
|
84
|
+
}
|
|
85
|
+
catch (e) {
|
|
86
|
+
getCustomFields = false;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
const response = await fetch(`${queryEndpoint}?schema-${caller}`, {
|
|
90
|
+
method: 'POST',
|
|
91
|
+
headers: {
|
|
92
|
+
...queryHeaders,
|
|
93
|
+
'Content-Type': 'application/json',
|
|
94
|
+
},
|
|
95
|
+
body: JSON.stringify({
|
|
96
|
+
metadata: {
|
|
97
|
+
clientId: publicKey,
|
|
98
|
+
publicKey: publicKey,
|
|
99
|
+
task: 'schema',
|
|
100
|
+
removeCustomerField: true,
|
|
101
|
+
getCustomFields: !client.customerId ||
|
|
102
|
+
client.customerId === '*' ||
|
|
103
|
+
(customFieldsByTableUnique.length === 0 && !getCustomFields)
|
|
104
|
+
? false
|
|
105
|
+
: true,
|
|
106
|
+
orgId: client.customerId || '*',
|
|
107
|
+
customFieldsByTable: customFieldsByTableUnique,
|
|
108
|
+
gatherSchemaData: true,
|
|
109
|
+
},
|
|
110
|
+
}),
|
|
111
|
+
});
|
|
112
|
+
const result = await response.json();
|
|
113
|
+
return {
|
|
114
|
+
schemaData: parseResponse(result),
|
|
115
|
+
customFieldsByTable: customFieldsByTableUnique,
|
|
116
|
+
};
|
|
117
|
+
};
|
|
118
|
+
exports.getSchemaInfoWithCustomFields = getSchemaInfoWithCustomFields;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Column } from '../models/Columns';
|
|
2
2
|
export declare const hasColumnAlias: (columns: Column[], referencedColumns: string[]) => boolean;
|
|
3
|
-
export declare const getUniqueValuesByColumns: (columns: Column[], query: string, rows: any, client: any) => Promise<{
|
|
3
|
+
export declare const getUniqueValuesByColumns: (columns: Column[], query: string, rows: any, client: any, customFields: any[]) => Promise<{
|
|
4
4
|
[column: string]: {
|
|
5
5
|
[value: string]: boolean;
|
|
6
6
|
};
|
|
@@ -1 +1 @@
|
|
|
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,cAAc,YAChB,MAAM,EAAE,qBACE,MAAM,EAAE,KAC1B,OAUF,CAAC;AAEF,eAAO,MAAM,wBAAwB,YAC1B,MAAM,EAAE,SACV,MAAM,QACP,GAAG,UACD,GAAG;;;;
|
|
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,cAAc,YAChB,MAAM,EAAE,qBACE,MAAM,EAAE,KAC1B,OAUF,CAAC;AAEF,eAAO,MAAM,wBAAwB,YAC1B,MAAM,EAAE,SACV,MAAM,QACP,GAAG,UACD,GAAG,gBACG,GAAG,EAAE;;;;SA6DpB,CAAC"}
|
|
@@ -15,7 +15,7 @@ const hasColumnAlias = (columns, referencedColumns) => {
|
|
|
15
15
|
return false;
|
|
16
16
|
};
|
|
17
17
|
exports.hasColumnAlias = hasColumnAlias;
|
|
18
|
-
const getUniqueValuesByColumns = async (columns, query, rows, client) => {
|
|
18
|
+
const getUniqueValuesByColumns = async (columns, query, rows, client, customFields) => {
|
|
19
19
|
const stringNames = columns.map((column) => column.field);
|
|
20
20
|
const uniqueValues = {};
|
|
21
21
|
if (!client.databaseType ||
|
|
@@ -28,6 +28,7 @@ const getUniqueValuesByColumns = async (columns, query, rows, client) => {
|
|
|
28
28
|
orgId: client.customerId || '*',
|
|
29
29
|
clientId: client.publicKey,
|
|
30
30
|
databaseType: client?.databaseType,
|
|
31
|
+
customFieldsByTable: customFields,
|
|
31
32
|
},
|
|
32
33
|
};
|
|
33
34
|
const cloudBody = { query };
|
|
@@ -50,7 +51,7 @@ const getUniqueValuesByColumns = async (columns, query, rows, client) => {
|
|
|
50
51
|
}
|
|
51
52
|
else {
|
|
52
53
|
const distinctValueQuery = (0, queryConstructor_1.generateDistinctQuery)(stringNames, query);
|
|
53
|
-
const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client);
|
|
54
|
+
const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client, customFields);
|
|
54
55
|
if (!distinctStrings) {
|
|
55
56
|
return {};
|
|
56
57
|
}
|
|
@@ -61,7 +62,7 @@ const getUniqueValuesByColumns = async (columns, query, rows, client) => {
|
|
|
61
62
|
return uniqueValues;
|
|
62
63
|
};
|
|
63
64
|
exports.getUniqueValuesByColumns = getUniqueValuesByColumns;
|
|
64
|
-
const fetchDistinctStrings = async (query, client) => {
|
|
65
|
+
const fetchDistinctStrings = async (query, client, customFields) => {
|
|
65
66
|
try {
|
|
66
67
|
const hostedBody = {
|
|
67
68
|
metadata: {
|
|
@@ -70,6 +71,7 @@ const fetchDistinctStrings = async (query, client) => {
|
|
|
70
71
|
orgId: client.customerId || '*',
|
|
71
72
|
clientId: client.publicKey,
|
|
72
73
|
databaseType: client?.databaseType,
|
|
74
|
+
customFieldsByTable: customFields,
|
|
73
75
|
},
|
|
74
76
|
};
|
|
75
77
|
const cloudBody = { query };
|
package/dist/esm/Chart.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Chart.d.ts","sourceRoot":"","sources":["../../src/Chart.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"Chart.d.ts","sourceRoot":"","sources":["../../src/Chart.tsx"],"names":[],"mappings":";AAYA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAgB7C,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AA0GzC,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,WAAW,GAAG,GAAG,CAAC;IAE3B;;;;;;;;OAQG;IACH,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB;;;;;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;;OAEG;IACH,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAEhC;;;;;;;;;;;;;;;;;;;;;;;;;OAyBG;IACH,iBAAiB,CAAC,EAAE,CAClB,MAAM,EAAE,WAAW,EACnB,KAAK,EAAE,UAAU,KACd,YAAY,CAAC;IAElB;;OAEG;IACH,gBAAgB,CAAC,EAAE,MAAM,GAAG,CAAC,OAAO,CAAC;IAErC;;;;OAIG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB;;OAEG;IACH,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IAErC,4EAA4E;IAC5E,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;CACpB;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,QAAA,MAAM,KAAK,UAAW,UAAU,4CA8C/B,CAAC;AA0nBF,eAAe,KAAK,CAAC"}
|
package/dist/esm/Chart.js
CHANGED
|
@@ -4,7 +4,7 @@ import { useState, useEffect, useContext, useMemo } from 'react';
|
|
|
4
4
|
import { differenceInHours } from 'date-fns';
|
|
5
5
|
import BarList from './components/Chart/BarList';
|
|
6
6
|
import PieChart from './components/Chart/PieChart';
|
|
7
|
-
import { ClientContext, DashboardContext, DashboardFiltersContext, } from './Context';
|
|
7
|
+
import { ClientContext, CustomFieldContext, DashboardContext, DashboardFiltersContext, } from './Context';
|
|
8
8
|
import QuillTable from './components/QuillTable';
|
|
9
9
|
import { getData } from './utils/dataFetcher';
|
|
10
10
|
import { generatePivotTable, generatePivotTableYAxis, } from './internals/ReportBuilder/PivotModal';
|
|
@@ -126,6 +126,7 @@ const ChartUpdater = ({ colors, reportId, className, containerStyle, isAnimation
|
|
|
126
126
|
const [isComparison, setIsComparison] = useState(false);
|
|
127
127
|
const [colorMap, setColorMap] = useState({});
|
|
128
128
|
const [client, _] = useContext(ClientContext);
|
|
129
|
+
const [customFields,] = useContext(CustomFieldContext);
|
|
129
130
|
const theme = useTheme();
|
|
130
131
|
useEffect(() => {
|
|
131
132
|
async function getChartOptions() {
|
|
@@ -161,6 +162,7 @@ const ChartUpdater = ({ colors, reportId, className, containerStyle, isAnimation
|
|
|
161
162
|
task: 'item',
|
|
162
163
|
databaseType: client.databaseType,
|
|
163
164
|
filters: minimalFilters,
|
|
165
|
+
customFields
|
|
164
166
|
},
|
|
165
167
|
};
|
|
166
168
|
const cloudBody = {
|
|
@@ -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;AAyCf,OAAO,EAAU,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAO1D,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;
|
|
1
|
+
{"version":3,"file":"ChartBuilder.d.ts","sourceRoot":"","sources":["../../src/ChartBuilder.tsx"],"names":[],"mappings":"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"}
|
package/dist/esm/ChartBuilder.js
CHANGED
|
@@ -14,6 +14,7 @@ import { QuillCard } from './components/QuillCard';
|
|
|
14
14
|
import { quillFormat } from './utils/valueFormatter';
|
|
15
15
|
import { convertColumnInfoToColumnInternal } from './utils/columnProcessing';
|
|
16
16
|
import { createTableNameToTableAliasMap, getColumnsByTableFromASTAndSchema, getSelectFromAST, } from './utils/astProcessing';
|
|
17
|
+
import { getSchemaInfoWithCustomFields } from './utils/schema';
|
|
17
18
|
const CHART_TYPES = ['column', 'line', 'table', 'metric', 'bar', 'pie'];
|
|
18
19
|
const POSTGRES_DATE_TYPES = [
|
|
19
20
|
'timestamp',
|
|
@@ -326,6 +327,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
326
327
|
// initial state is the fields array passed in, but can eventually be changed to be the pivot fields
|
|
327
328
|
const [dateFieldOptions, setDateFieldOptions] = useState([]);
|
|
328
329
|
const [allTables, setAllTables] = useState([]);
|
|
330
|
+
const [customFieldTableRef, setCustomFieldTableRef] = useState(false);
|
|
329
331
|
const [referencedColumns, setReferencedColumns] = useState({});
|
|
330
332
|
const [uniqueValues, setUniqueValues] = useState(undefined);
|
|
331
333
|
const [defaultDateField, setDefaultDateField] = useState({
|
|
@@ -437,31 +439,8 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
437
439
|
curFormData.dashboardName = dashboardName;
|
|
438
440
|
setDefaultDashboardName(destinationDashboard ??
|
|
439
441
|
(report ? report?.dashboardName : dashboardOptions[0]?.label));
|
|
440
|
-
const {
|
|
441
|
-
|
|
442
|
-
method: 'POST',
|
|
443
|
-
headers: {
|
|
444
|
-
...queryHeaders,
|
|
445
|
-
'Content-Type': 'application/json',
|
|
446
|
-
},
|
|
447
|
-
body: JSON.stringify({
|
|
448
|
-
metadata: {
|
|
449
|
-
clientId: publicKey,
|
|
450
|
-
publicKey: publicKey,
|
|
451
|
-
task: 'schema',
|
|
452
|
-
},
|
|
453
|
-
}),
|
|
454
|
-
});
|
|
455
|
-
const schemaInfo = await response.json();
|
|
456
|
-
let schemaData = schemaInfo.data?.data;
|
|
457
|
-
if (schemaInfo.data?.data) {
|
|
458
|
-
schemaData = schemaInfo.data.data.tables;
|
|
459
|
-
setSchema(schemaInfo.data.data.tables);
|
|
460
|
-
}
|
|
461
|
-
else {
|
|
462
|
-
schemaData = schemaInfo.data.tables;
|
|
463
|
-
setSchema(schemaInfo.data.tables);
|
|
464
|
-
}
|
|
442
|
+
const { schemaData } = await getSchemaInfoWithCustomFields(client, 'cb');
|
|
443
|
+
setSchema(schemaData);
|
|
465
444
|
if (!query) {
|
|
466
445
|
return;
|
|
467
446
|
}
|
|
@@ -473,7 +452,18 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
473
452
|
field: result.dateFields[0].columns[0].field,
|
|
474
453
|
});
|
|
475
454
|
}
|
|
476
|
-
|
|
455
|
+
// check if the referenced table is a table with custom field info.. If so block template settings
|
|
456
|
+
const tableNames = result.referencedTablesAndColumns.map((table) => table.name);
|
|
457
|
+
setAllTables(tableNames);
|
|
458
|
+
let customFieldUsage = false;
|
|
459
|
+
for (let table of tableNames) {
|
|
460
|
+
const tableInfo = schemaData.find((elem) => elem.name === table);
|
|
461
|
+
if (tableInfo?.customFieldInfo) {
|
|
462
|
+
customFieldUsage = true;
|
|
463
|
+
break;
|
|
464
|
+
}
|
|
465
|
+
}
|
|
466
|
+
setCustomFieldTableRef(customFieldUsage && client.customerId && client.customerId !== '*');
|
|
477
467
|
const referencedColumns = result.referencedTablesAndColumns.reduce((acc, table) => {
|
|
478
468
|
acc[table.name] = table.columns.map((col) => col.field);
|
|
479
469
|
return acc;
|
|
@@ -492,6 +482,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
492
482
|
dashboardName: report
|
|
493
483
|
? report?.dashboardName
|
|
494
484
|
: dashboardOptions[0]?.label,
|
|
485
|
+
template: !customFieldUsage,
|
|
495
486
|
});
|
|
496
487
|
}
|
|
497
488
|
getFormData();
|
|
@@ -1025,7 +1016,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
1025
1016
|
display: 'flex',
|
|
1026
1017
|
flexDirection: 'column',
|
|
1027
1018
|
gap: 12,
|
|
1028
|
-
}, children: [_jsx(HeaderComponent, { label: "Organization access" }), _jsx(SegmentedControl, { onChange: (e) => handleChange(e, 'template'), value: formData.template || !organizationName, theme: theme, organizationName: organizationName })] }))] }), _jsxs("div", { style: {
|
|
1019
|
+
}, children: [_jsx(HeaderComponent, { label: "Organization access" }), _jsx(SegmentedControl, { onChange: (e) => handleChange(e, 'template'), value: formData.template || !organizationName, theme: theme, organizationName: organizationName, customFieldTableRef: customFieldTableRef })] }))] }), _jsxs("div", { style: {
|
|
1029
1020
|
display: 'flex',
|
|
1030
1021
|
flexDirection: 'row',
|
|
1031
1022
|
justifyContent: 'flex-end',
|
|
@@ -1037,7 +1028,7 @@ export default function ChartBuilder({ TextInputComponent = QuillTextInput, Sele
|
|
|
1037
1028
|
? 'Save changes'
|
|
1038
1029
|
: 'Add to dashboard' }))] })] }))] }), _jsx(DashboardFilterModal, { isOpen: showFilterModal, setIsOpen: setShowFilterModal, issues: filterIssues, ButtonComponent: ButtonComponent })] }));
|
|
1039
1030
|
}
|
|
1040
|
-
function SegmentedControl({ onChange, value, theme, organizationName, }) {
|
|
1031
|
+
function SegmentedControl({ onChange, value, theme, organizationName, customFieldTableRef, }) {
|
|
1041
1032
|
return (_jsxs("div", { style: {
|
|
1042
1033
|
display: 'flex',
|
|
1043
1034
|
flexDirection: 'row',
|
|
@@ -1046,7 +1037,7 @@ function SegmentedControl({ onChange, value, theme, organizationName, }) {
|
|
|
1046
1037
|
maxWidth: organizationName ? 418 : 209,
|
|
1047
1038
|
padding: 4,
|
|
1048
1039
|
borderRadius: 6,
|
|
1049
|
-
}, children: [_jsxs("button", { className: "quill-tab", onClick: () => onChange(true), style: {
|
|
1040
|
+
}, children: [!customFieldTableRef && (_jsxs("button", { className: "quill-tab", onClick: () => onChange(true), style: {
|
|
1050
1041
|
border: value === true ? '1px solid #E7E7E7' : '1px solid transparent',
|
|
1051
1042
|
outline: 'none',
|
|
1052
1043
|
width: '100%',
|
|
@@ -1069,7 +1060,7 @@ function SegmentedControl({ onChange, value, theme, organizationName, }) {
|
|
|
1069
1060
|
.quill-tab:active {
|
|
1070
1061
|
background-color: "rgba(56, 65, 81, 0.15)";
|
|
1071
1062
|
}
|
|
1072
|
-
` }), 'All Organizations'] }), organizationName && (_jsxs("button", { className: "quill-tab2", onClick: () => onChange(false), style: {
|
|
1063
|
+
` }), 'All Organizations'] })), organizationName && (_jsxs("button", { className: "quill-tab2", onClick: () => onChange(false), style: {
|
|
1073
1064
|
border: value === false ? '1px solid #E7E7E7' : '1px solid transparent',
|
|
1074
1065
|
boxShadow: value === false
|
|
1075
1066
|
? '0px 1px 4px 0px rgba(56, 65, 81, 0.08)'
|
package/dist/esm/Context.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
export declare const DateFilterContext: React.Context<any>;
|
|
3
3
|
export declare const SchemaContext: React.Context<any>;
|
|
4
|
+
export declare const CustomFieldContext: React.Context<any>;
|
|
4
5
|
export declare const ColumnsContext: React.Context<any>;
|
|
5
6
|
export declare const RowsContext: React.Context<any>;
|
|
6
7
|
export declare const SelectedSidebarIndexContext: React.Context<any>;
|