@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.
Files changed (75) hide show
  1. package/dist/cjs/Chart.d.ts.map +1 -1
  2. package/dist/cjs/Chart.js +2 -0
  3. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  4. package/dist/cjs/ChartBuilder.js +21 -30
  5. package/dist/cjs/Context.d.ts +1 -0
  6. package/dist/cjs/Context.d.ts.map +1 -1
  7. package/dist/cjs/Context.js +58 -30
  8. package/dist/cjs/Dashboard.d.ts.map +1 -1
  9. package/dist/cjs/Dashboard.js +3 -3
  10. package/dist/cjs/QuillProvider.d.ts +3 -3
  11. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  12. package/dist/cjs/QuillProvider.js +1 -1
  13. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  14. package/dist/cjs/ReportBuilder.js +14 -60
  15. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  16. package/dist/cjs/SQLEditor.js +12 -26
  17. package/dist/cjs/Table.d.ts.map +1 -1
  18. package/dist/cjs/Table.js +2 -0
  19. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  20. package/dist/cjs/components/Dashboard/DataLoader.js +4 -0
  21. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts +11 -0
  22. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -0
  23. package/dist/cjs/components/QuillMultiSelectWithCombo.js +228 -0
  24. package/dist/cjs/components/QuillSelectWithCombo.d.ts +6 -0
  25. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -0
  26. package/dist/cjs/components/QuillSelectWithCombo.js +186 -0
  27. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  28. package/dist/cjs/hooks/useQuill.js +2 -0
  29. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  30. package/dist/cjs/internals/ReportBuilder/PivotModal.js +2 -1
  31. package/dist/cjs/utils/schema.d.ts +6 -0
  32. package/dist/cjs/utils/schema.d.ts.map +1 -0
  33. package/dist/cjs/utils/schema.js +118 -0
  34. package/dist/cjs/utils/tableProcessing.d.ts +1 -1
  35. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  36. package/dist/cjs/utils/tableProcessing.js +5 -3
  37. package/dist/cjs/utils/valueFormatter.js +1 -1
  38. package/dist/esm/Chart.d.ts.map +1 -1
  39. package/dist/esm/Chart.js +3 -1
  40. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  41. package/dist/esm/ChartBuilder.js +21 -30
  42. package/dist/esm/Context.d.ts +1 -0
  43. package/dist/esm/Context.d.ts.map +1 -1
  44. package/dist/esm/Context.js +57 -29
  45. package/dist/esm/Dashboard.d.ts.map +1 -1
  46. package/dist/esm/Dashboard.js +3 -3
  47. package/dist/esm/QuillProvider.d.ts +3 -3
  48. package/dist/esm/QuillProvider.d.ts.map +1 -1
  49. package/dist/esm/QuillProvider.js +1 -1
  50. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  51. package/dist/esm/ReportBuilder.js +15 -61
  52. package/dist/esm/SQLEditor.d.ts.map +1 -1
  53. package/dist/esm/SQLEditor.js +13 -27
  54. package/dist/esm/Table.d.ts.map +1 -1
  55. package/dist/esm/Table.js +3 -1
  56. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  57. package/dist/esm/components/Dashboard/DataLoader.js +5 -1
  58. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts +11 -0
  59. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -0
  60. package/dist/esm/components/QuillMultiSelectWithCombo.js +200 -0
  61. package/dist/esm/components/QuillSelectWithCombo.d.ts +6 -0
  62. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -0
  63. package/dist/esm/components/QuillSelectWithCombo.js +159 -0
  64. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  65. package/dist/esm/hooks/useQuill.js +3 -1
  66. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  67. package/dist/esm/internals/ReportBuilder/PivotModal.js +3 -2
  68. package/dist/esm/utils/schema.d.ts +6 -0
  69. package/dist/esm/utils/schema.d.ts.map +1 -0
  70. package/dist/esm/utils/schema.js +113 -0
  71. package/dist/esm/utils/tableProcessing.d.ts +1 -1
  72. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  73. package/dist/esm/utils/tableProcessing.js +5 -3
  74. package/dist/esm/utils/valueFormatter.js +1 -1
  75. package/package.json +1 -1
@@ -0,0 +1,11 @@
1
+ import { MultiSelectComponentProps } from './UiComponents';
2
+ /**
3
+ * A robust select component that implements the new minimal Select interface.
4
+ */
5
+ export declare function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, }: MultiSelectComponentProps): import("react/jsx-runtime").JSX.Element;
6
+ export declare const ListboxTextInput: ({ value, onChange, placeholder, }: {
7
+ value: string;
8
+ onChange: (e: string) => void;
9
+ placeholder: string;
10
+ }) => import("react/jsx-runtime").JSX.Element;
11
+ //# sourceMappingURL=QuillMultiSelectWithCombo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuillMultiSelectWithCombo.d.ts","sourceRoot":"","sources":["../../../src/components/QuillMultiSelectWithCombo.tsx"],"names":[],"mappings":"AACA,OAAO,EACL,yBAAyB,EAE1B,MAAM,gBAAgB,CAAC;AAYxB;;GAEG;AACH,wBAAgB,kCAAkC,CAAC,EACjD,OAAO,EACP,KAAK,EACL,QAAQ,EACR,KAAK,EACL,KAAK,GACN,EAAE,yBAAyB,2CAoS3B;AAED,eAAO,MAAM,gBAAgB;WAKpB,MAAM;kBACC,MAAM,KAAK,IAAI;iBAChB,MAAM;6CAyDpB,CAAC"}
@@ -0,0 +1,200 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useOnClickOutside } from '../hooks';
3
+ import React, { useContext, useEffect, useRef, useState, } from 'react';
4
+ import { ThemeContext } from '../Context';
5
+ /**
6
+ * A robust select component that implements the new minimal Select interface.
7
+ */
8
+ export function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, }) {
9
+ const [theme] = useContext(ThemeContext);
10
+ const [selectedOptions, setSelectedOptions] = useState([]);
11
+ const [showModal, setShowModal] = useState(false);
12
+ const modalRef = useRef(null);
13
+ const debounceTimeoutId = useRef(null);
14
+ const [searchQuery, setSearchQuery] = React.useState('');
15
+ const [filteredItems, setFilteredItems] = React.useState(options.slice(0, 20));
16
+ useEffect(() => {
17
+ setFilteredItems(options.slice(0, 20));
18
+ }, [options]);
19
+ const handleSearchChange = (value) => {
20
+ setSearchQuery(value);
21
+ const curFilteredItems = value === ''
22
+ ? options.slice(0, 20)
23
+ : options
24
+ .filter((option) => {
25
+ if (!option) {
26
+ return false;
27
+ }
28
+ return option.value
29
+ .toLowerCase()
30
+ .replace(/\s+/g, '')
31
+ .includes(value.toLowerCase().replace(/\s+/g, ''));
32
+ })
33
+ .slice(0, 20);
34
+ setFilteredItems(curFilteredItems);
35
+ };
36
+ useOnClickOutside(modalRef, (e) => setShowModal(false));
37
+ useEffect(() => {
38
+ if (!value) {
39
+ setSelectedOptions([]);
40
+ }
41
+ else {
42
+ setSelectedOptions(value);
43
+ }
44
+ }, [value]);
45
+ const debounce = (updatedChangeEvent) => {
46
+ if (debounceTimeoutId.current) {
47
+ clearTimeout(debounceTimeoutId.current);
48
+ }
49
+ debounceTimeoutId.current = setTimeout(() => {
50
+ onChange(updatedChangeEvent);
51
+ }, 500);
52
+ };
53
+ // const filterOptions = (query: string) => {
54
+ // setSearchQuery(query);
55
+ // setFilteredOptions(
56
+ // options.filter((option) =>
57
+ // option.label.toLowerCase().includes(query.toLowerCase()),
58
+ // ),
59
+ // );
60
+ // };
61
+ return (_jsxs("div", { style: {
62
+ position: 'relative',
63
+ borderRadius: '6px',
64
+ width: width,
65
+ minWidth: width,
66
+ }, children: [label && (_jsx("div", { style: {
67
+ fontSize: 14,
68
+ color: theme.secondaryTextColor,
69
+ fontFamily: theme.fontFamily,
70
+ paddingBottom: 5,
71
+ fontWeight: 600,
72
+ }, children: label })), _jsxs("button", { style: {
73
+ fontFamily: theme.fontFamily,
74
+ color: theme.primaryTextColor,
75
+ width: '100%',
76
+ display: 'flex',
77
+ alignItems: 'center',
78
+ justifyContent: 'space-between',
79
+ fontWeight: 'inherit',
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: [_jsx("style", { children: ` .quill-select-button { background: ${theme.backgroundColor}; }
95
+ .quill-select-button:hover { background: ${theme.hoverBackgroundColor}; }
96
+ ` }), _jsx("span", { style: {
97
+ textOverflow: 'ellipsis',
98
+ whiteSpace: 'nowrap',
99
+ overflow: 'hidden',
100
+ width: '100%',
101
+ textAlign: 'left',
102
+ zIndex: 1,
103
+ }, children: value && value.length > 0 ? value.join(', ') : 'Select' }), _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: _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 && (_jsxs("div", { ref: modalRef, style: {
104
+ position: 'absolute',
105
+ width: '100%',
106
+ display: 'flex',
107
+ flexDirection: 'column',
108
+ boxSizing: 'border-box',
109
+ borderWidth: 1,
110
+ borderStyle: 'solid',
111
+ borderColor: theme.borderColor,
112
+ borderRadius: 6,
113
+ background: 'white',
114
+ marginTop: 12,
115
+ zIndex: 100,
116
+ padding: 6,
117
+ fontFamily: theme.fontFamily,
118
+ maxHeight: '50vh',
119
+ overflow: 'scroll',
120
+ }, children: [options && options.length > 20 && (_jsx(ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
121
+ handleSearchChange(value);
122
+ } })), options && options.length > 20 && (_jsx("div", { style: { height: 9, width: 230, borderTop: '1px solid #e7e7e7' } })), filteredItems.map((option) => (_jsxs("button", { style: {
123
+ display: 'flex',
124
+ alignItems: 'center',
125
+ padding: 8,
126
+ margin: 0,
127
+ boxSizing: 'border-box',
128
+ borderWidth: 0,
129
+ fontSize: 14,
130
+ borderStyle: 'solid',
131
+ borderColor: theme.borderColor,
132
+ borderRadius: 4,
133
+ fontFamily: theme.fontFamily,
134
+ textOverflow: 'ellipsis',
135
+ whiteSpace: 'nowrap',
136
+ height: 34,
137
+ minHeight: 34,
138
+ gap: 6,
139
+ overflow: 'hidden',
140
+ }, className: "quill-option", onClick: () => {
141
+ // Manually create a synthetic ChangeEvent and pass it to callback
142
+ const changeEvent = { target: { value: option.value } };
143
+ let updateSelctedOptions = [...selectedOptions];
144
+ if (selectedOptions.includes(changeEvent.target.value)) {
145
+ updateSelctedOptions = selectedOptions.filter((opt) => opt !== changeEvent.target.value);
146
+ setSelectedOptions(updateSelctedOptions);
147
+ }
148
+ else {
149
+ updateSelctedOptions = [
150
+ ...updateSelctedOptions,
151
+ changeEvent.target.value,
152
+ ];
153
+ setSelectedOptions(updateSelctedOptions);
154
+ }
155
+ const updatedChangeEvent = {
156
+ target: { value: JSON.stringify(updateSelctedOptions) },
157
+ };
158
+ if (updateSelctedOptions.length === 0) {
159
+ updatedChangeEvent.target.value = '';
160
+ }
161
+ debounce(updatedChangeEvent);
162
+ }, children: [_jsx("style", { children: `
163
+ .quill-option {
164
+ background: white;
165
+ }
166
+ .quill-option:hover {
167
+ background: #F4F4F5;
168
+ }
169
+ ` }), _jsx("input", { type: "checkbox", checked: selectedOptions.includes(option.value), style: { width: '14px', height: '14px', margin: 'auto 0' }, readOnly: true }), _jsx("span", { style: {
170
+ textOverflow: 'ellipsis',
171
+ whiteSpace: 'nowrap',
172
+ overflow: 'hidden',
173
+ }, children: option.label })] }, option.value)))] }))] }));
174
+ }
175
+ export const ListboxTextInput = ({ value, onChange, placeholder, }) => {
176
+ return (_jsxs("div", { style: {
177
+ position: 'relative',
178
+ display: 'flex',
179
+ flexDirection: 'row',
180
+ alignItems: 'center',
181
+ marginTop: 2,
182
+ }, children: [_jsx("style", { children: `
183
+ .quill-text-input {
184
+ background-color: white;
185
+ height: 40px;
186
+ width: 180px;
187
+ z-index: 2;
188
+ color: #384151;
189
+ border-radius: 4px;
190
+ text-align: left;
191
+ padding-right: 12px;
192
+ padding-top: 0px;
193
+ padding-bottom: 0px;
194
+ box-sizing: content-box;
195
+ margin-left: 6px;
196
+ }
197
+ .quill-text-input:focus {
198
+ outline: none;
199
+ }` }), _jsx("div", { style: { width: 6 } }), _jsx("svg", { xmlns: "http://www.w3.org/2000/svg", viewBox: "0 0 16 16", fill: "rgba(56, 65, 81, 0.7)", height: "16", width: "16", children: _jsx("path", { fillRule: "evenodd", d: "M9.965 11.026a5 5 0 1 1 1.06-1.06l2.755 2.754a.75.75 0 1 1-1.06 1.06l-2.755-2.754ZM10.5 7a3.5 3.5 0 1 1-7 0 3.5 3.5 0 0 1 7 0Z", clipRule: "evenodd" }) }), _jsx("input", { className: "quill-text-input", type: "text", value: value, onChange: (event) => onChange(event.target.value), placeholder: placeholder })] }));
200
+ };
@@ -0,0 +1,6 @@
1
+ import { SelectComponentProps } from './UiComponents';
2
+ /**
3
+ * A robust select component that implements the new minimal Select interface.
4
+ */
5
+ export declare function QuillSelectComponentWithCombo({ options, value, width, onChange, label, }: SelectComponentProps): import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=QuillSelectWithCombo.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"QuillSelectWithCombo.d.ts","sourceRoot":"","sources":["../../../src/components/QuillSelectWithCombo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AAMtD;;GAEG;AACH,wBAAgB,6BAA6B,CAAC,EAC5C,OAAO,EACP,KAAK,EACL,KAAK,EACL,QAAQ,EACR,KAAK,GACN,EAAE,oBAAoB,2CA+OtB"}
@@ -0,0 +1,159 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useOnClickOutside } from '../hooks';
3
+ import React, { useContext, useRef, useState } from 'react';
4
+ import { ThemeContext } from '../Context';
5
+ import { ListboxTextInput } from './QuillMultiSelectWithCombo';
6
+ /**
7
+ * A robust select component that implements the new minimal Select interface.
8
+ */
9
+ export function QuillSelectComponentWithCombo({ options, value, width, onChange, label, }) {
10
+ const [theme] = useContext(ThemeContext);
11
+ const [showModal, setShowModal] = useState(false);
12
+ const modalRef = useRef(null);
13
+ const [searchQuery, setSearchQuery] = React.useState('');
14
+ const [filteredItems, setFilteredItems] = React.useState(options.slice(0, 20));
15
+ useOnClickOutside(modalRef, (e) => setShowModal(false));
16
+ const handleSearchChange = (value) => {
17
+ setSearchQuery(value);
18
+ const curFilteredItems = value === ''
19
+ ? options.slice(0, 20)
20
+ : options
21
+ .filter((option) => {
22
+ if (!option) {
23
+ return false;
24
+ }
25
+ return option.value
26
+ .toLowerCase()
27
+ .replace(/\s+/g, '')
28
+ .includes(value.toLowerCase().replace(/\s+/g, ''));
29
+ })
30
+ .slice(0, 20);
31
+ setFilteredItems(curFilteredItems);
32
+ };
33
+ useOnClickOutside(modalRef, (e) => setShowModal(false));
34
+ return (_jsxs("div", { style: {
35
+ position: 'relative',
36
+ // width: 200,
37
+ // minWidth: 200,
38
+ borderRadius: '6px',
39
+ width: width,
40
+ minWidth: width,
41
+ }, children: [label && (_jsx("div", { style: {
42
+ fontSize: 14,
43
+ color: theme.secondaryTextColor,
44
+ fontFamily: theme.fontFamily,
45
+ paddingBottom: 5,
46
+ fontWeight: 600,
47
+ }, children: label })), _jsxs("button", { style: {
48
+ fontFamily: theme.fontFamily,
49
+ color: theme.primaryTextColor,
50
+ width: '100%',
51
+ display: 'flex',
52
+ alignItems: 'center',
53
+ justifyContent: 'space-between',
54
+ lineHeight: 'inherit',
55
+ padding: '8px 12px',
56
+ fontSize: 14,
57
+ margin: 0,
58
+ boxSizing: 'border-box',
59
+ borderWidth: 1,
60
+ borderStyle: 'solid',
61
+ borderColor: theme.borderColor,
62
+ borderRadius: 6,
63
+ paddingTop: 9,
64
+ paddingBottom: 9,
65
+ height: 40,
66
+ minHeight: 40,
67
+ maxHeight: 40,
68
+ }, className: "quill-select-button", onClick: () => setShowModal((showModal) => !showModal), children: [_jsx("style", { children: ` .quill-select-button { background: ${theme.backgroundColor}; } .quill-select-button:hover { background: ${theme.hoverBackgroundColor}; }` }), _jsx("span", { style: {
69
+ textOverflow: 'ellipsis',
70
+ whiteSpace: 'nowrap',
71
+ overflow: 'hidden',
72
+ }, children: options.find((elem) => elem.value === value)?.label || 'Select' }), _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: _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 && (_jsxs("div", { ref: modalRef, style: {
73
+ position: 'absolute',
74
+ width: '100%',
75
+ display: 'flex',
76
+ flexDirection: 'column',
77
+ boxSizing: 'border-box',
78
+ borderWidth: 1,
79
+ borderStyle: 'solid',
80
+ borderColor: theme.borderColor,
81
+ borderRadius: 6,
82
+ background: 'white',
83
+ marginTop: 12,
84
+ zIndex: 100,
85
+ paddingTop: 6,
86
+ paddingBottom: 6,
87
+ paddingLeft: 6,
88
+ paddingRight: 6,
89
+ fontFamily: theme.fontFamily,
90
+ maxHeight: '50vh',
91
+ overflow: 'scroll',
92
+ }, children: [options && options.length > 20 && (_jsx(ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
93
+ handleSearchChange(value);
94
+ } })), searchQuery === '' && (_jsxs("button", { style: {
95
+ display: 'flex',
96
+ alignItems: 'center',
97
+ justifyContent: 'space-between',
98
+ padding: '8px 8px',
99
+ margin: 0,
100
+ boxSizing: 'border-box',
101
+ borderWidth: 0,
102
+ fontSize: 14,
103
+ borderStyle: 'solid',
104
+ borderColor: theme.borderColor,
105
+ borderRadius: 4,
106
+ fontFamily: theme.fontFamily,
107
+ textOverflow: 'ellipsis',
108
+ whiteSpace: 'nowrap',
109
+ overflow: 'hidden',
110
+ height: 34,
111
+ minHeight: 34,
112
+ }, className: "quill-option", onClick: () => {
113
+ // Manually create a synthetic ChangeEvent and pass it to callback
114
+ const changeEvent = { target: { value: '' } };
115
+ onChange(changeEvent);
116
+ setShowModal(false);
117
+ }, children: [_jsx("style", { children: `
118
+ .quill-option {
119
+ background: white;
120
+ }
121
+ .quill-option:hover {
122
+ background: #F4F4F5;
123
+ }
124
+ ` }), 'Select'] })), filteredItems.map((option) => (_jsxs("button", { style: {
125
+ display: 'flex',
126
+ alignItems: 'center',
127
+ justifyContent: 'space-between',
128
+ padding: '8px 8px',
129
+ margin: 0,
130
+ boxSizing: 'border-box',
131
+ borderWidth: 0,
132
+ fontSize: 14,
133
+ borderStyle: 'solid',
134
+ borderColor: theme.borderColor,
135
+ borderRadius: 4,
136
+ fontFamily: theme.fontFamily,
137
+ textOverflow: 'ellipsis',
138
+ whiteSpace: 'nowrap',
139
+ height: 34,
140
+ minHeight: 34,
141
+ overflow: 'hidden',
142
+ }, className: "quill-option", onClick: () => {
143
+ // Manually create a synthetic ChangeEvent and pass it to callback
144
+ const changeEvent = { target: { value: option.value } };
145
+ onChange(changeEvent);
146
+ setShowModal(false);
147
+ }, children: [_jsx("style", { children: `
148
+ .quill-option {
149
+ background: white;
150
+ }
151
+ .quill-option:hover {
152
+ background: #F4F4F5;
153
+ }
154
+ ` }), _jsx("span", { style: {
155
+ textOverflow: 'ellipsis',
156
+ whiteSpace: 'nowrap',
157
+ overflow: 'hidden',
158
+ }, children: option.label })] }, option.value)))] }))] }));
159
+ }
@@ -1 +1 @@
1
- {"version":3,"file":"useQuill.d.ts","sourceRoot":"","sources":["../../../src/hooks/useQuill.ts"],"names":[],"mappings":"AAUA,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;CAkFrB,CAAC"}
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"}
@@ -1,11 +1,12 @@
1
1
  import { useContext, useEffect, useState } from 'react';
2
- import { ClientContext, DashboardContext, DashboardFiltersContext, } from '../Context';
2
+ import { ClientContext, CustomFieldContext, DashboardContext, DashboardFiltersContext, } from '../Context';
3
3
  import { getData } from '../utils/dataFetcher';
4
4
  import { mergeComparisonRange } from '../utils/merge';
5
5
  import { processFilterErrorList } from '../utils/errorProcessing';
6
6
  export const useQuill = (reportId) => {
7
7
  const { dashboard, dispatch } = useContext(DashboardContext);
8
8
  const { dashboardFilters } = useContext(DashboardFiltersContext);
9
+ const [customFields] = useContext(CustomFieldContext);
9
10
  const [client] = useContext(ClientContext);
10
11
  const [data, setData] = useState(null);
11
12
  const [loading, setLoading] = useState(true);
@@ -32,6 +33,7 @@ export const useQuill = (reportId) => {
32
33
  task: 'item',
33
34
  filters: [...Object.values(dashboardFilters)],
34
35
  databaseType: client?.databaseType,
36
+ customFields,
35
37
  },
36
38
  };
37
39
  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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"}
@@ -1,6 +1,6 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { useCallback, useContext, useMemo, useState, useEffect, useRef, } from 'react';
3
- import { ClientContext } from '../../Context';
3
+ import { ClientContext, CustomFieldContext } from '../../Context';
4
4
  import { getDataFromCloud } from '../../utils/dataFetcher';
5
5
  import { PivotList, PivotCard } from './PivotList';
6
6
  import { differenceInDays, eachDayOfInterval, eachMonthOfInterval, eachWeekOfInterval, eachYearOfInterval, endOfDay, isWithinInterval, subMilliseconds, } from 'date-fns';
@@ -31,6 +31,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
31
31
  const [selectedPivotType, setSelectedPivotType] = useState('recommended');
32
32
  const [errors, setErrors] = useState([]);
33
33
  const [client] = useContext(ClientContext);
34
+ const [customFields] = useContext(CustomFieldContext);
34
35
  const rowFieldRef = useRef(null);
35
36
  const colFieldRef = useRef(null);
36
37
  const [pivotCardWidth, setPivotCardWidth] = useState(420);
@@ -52,7 +53,7 @@ export const PivotModal = ({ pivotRowField, setPivotRowField, pivotColumnField,
52
53
  setAllowedValueFields(possibleColumns.valueFields);
53
54
  return possibleColumns;
54
55
  }
55
- const newUniqueValues = await getUniqueValuesByColumns(stringColumns, query || '', data.rows || [], client);
56
+ const newUniqueValues = await getUniqueValuesByColumns(stringColumns, query || '', data.rows || [], client, customFields);
56
57
  if (!uniqueValues ||
57
58
  hashCode(uniqueValues) !== hashCode(newUniqueValues)) {
58
59
  const possibleColumns = 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,113 @@
1
+ const parseResponse = (results) => {
2
+ if (results.data?.data) {
3
+ if (results.data.data.queries &&
4
+ results.data.data.queries.queryResults.length > 0) {
5
+ return results.data.data.queries.queryResults;
6
+ }
7
+ else {
8
+ return results.data.data.tables;
9
+ }
10
+ }
11
+ else {
12
+ if (results.queries &&
13
+ results.queries.queryResults &&
14
+ results.queries.queryResults.length > 0) {
15
+ return results.queries.queryResults;
16
+ }
17
+ else {
18
+ return results.data.tables;
19
+ }
20
+ }
21
+ };
22
+ export const getCustomFieldInfo = async (client, caller = 'se') => {
23
+ let customFieldsByTableUnique = [];
24
+ try {
25
+ const { queryEndpoint, queryHeaders, publicKey, databaseType, customerId } = client;
26
+ let response = await fetch(`${queryEndpoint}?cfr-${caller}`, {
27
+ method: 'POST',
28
+ headers: {
29
+ ...queryHeaders,
30
+ 'Content-Type': 'application/json',
31
+ },
32
+ body: JSON.stringify({
33
+ metadata: {
34
+ clientId: publicKey,
35
+ publicKey,
36
+ task: 'custom-field-records',
37
+ databaseType: databaseType,
38
+ orgId: customerId,
39
+ },
40
+ }),
41
+ });
42
+ let result = await response.json();
43
+ const extractedData = parseResponse(result);
44
+ const customFieldsByTable = [];
45
+ extractedData.forEach((table) => {
46
+ if (!table.rows) {
47
+ return;
48
+ }
49
+ table.rows.forEach((row) => {
50
+ customFieldsByTable.push({
51
+ ref_table: row.ref_table,
52
+ field: row.field,
53
+ ref_column: row.ref_column,
54
+ type: row.type,
55
+ });
56
+ });
57
+ });
58
+ // make sure the are no duplicate records in extractedData
59
+ const customFieldsByTableSet = new Set();
60
+ customFieldsByTableUnique = customFieldsByTable.filter((item) => {
61
+ if (customFieldsByTableSet.has(item.ref_table + item.field + item.ref_column + item.type)) {
62
+ return false;
63
+ }
64
+ customFieldsByTableSet.add(item.ref_table + item.field + item.ref_column + item.type);
65
+ return true;
66
+ });
67
+ }
68
+ catch (e) {
69
+ console.error('CUSTOM FIELDS DISABLED');
70
+ }
71
+ return customFieldsByTableUnique;
72
+ };
73
+ export const getSchemaInfoWithCustomFields = async (client, caller = 'se') => {
74
+ const { queryEndpoint, queryHeaders, publicKey, databaseType, customerId } = client;
75
+ let customFieldsByTableUnique = [];
76
+ let getCustomFields = true;
77
+ if (!customerId || customerId !== '*') {
78
+ try {
79
+ customFieldsByTableUnique = await getCustomFieldInfo(client, caller);
80
+ }
81
+ catch (e) {
82
+ getCustomFields = false;
83
+ }
84
+ }
85
+ const response = await fetch(`${queryEndpoint}?schema-${caller}`, {
86
+ method: 'POST',
87
+ headers: {
88
+ ...queryHeaders,
89
+ 'Content-Type': 'application/json',
90
+ },
91
+ body: JSON.stringify({
92
+ metadata: {
93
+ clientId: publicKey,
94
+ publicKey: publicKey,
95
+ task: 'schema',
96
+ removeCustomerField: true,
97
+ getCustomFields: !client.customerId ||
98
+ client.customerId === '*' ||
99
+ (customFieldsByTableUnique.length === 0 && !getCustomFields)
100
+ ? false
101
+ : true,
102
+ orgId: client.customerId || '*',
103
+ customFieldsByTable: customFieldsByTableUnique,
104
+ gatherSchemaData: true,
105
+ },
106
+ }),
107
+ });
108
+ const result = await response.json();
109
+ return {
110
+ schemaData: parseResponse(result),
111
+ customFieldsByTable: customFieldsByTableUnique,
112
+ };
113
+ };
@@ -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;;;;SA2DZ,CAAC"}
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"}
@@ -11,7 +11,7 @@ export const hasColumnAlias = (columns, referencedColumns) => {
11
11
  }
12
12
  return false;
13
13
  };
14
- export const getUniqueValuesByColumns = async (columns, query, rows, client) => {
14
+ export const getUniqueValuesByColumns = async (columns, query, rows, client, customFields) => {
15
15
  const stringNames = columns.map((column) => column.field);
16
16
  const uniqueValues = {};
17
17
  if (!client.databaseType ||
@@ -24,6 +24,7 @@ export const getUniqueValuesByColumns = async (columns, query, rows, client) =>
24
24
  orgId: client.customerId || '*',
25
25
  clientId: client.publicKey,
26
26
  databaseType: client?.databaseType,
27
+ customFieldsByTable: customFields,
27
28
  },
28
29
  };
29
30
  const cloudBody = { query };
@@ -46,7 +47,7 @@ export const getUniqueValuesByColumns = async (columns, query, rows, client) =>
46
47
  }
47
48
  else {
48
49
  const distinctValueQuery = generateDistinctQuery(stringNames, query);
49
- const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client);
50
+ const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client, customFields);
50
51
  if (!distinctStrings) {
51
52
  return {};
52
53
  }
@@ -56,7 +57,7 @@ export const getUniqueValuesByColumns = async (columns, query, rows, client) =>
56
57
  }
57
58
  return uniqueValues;
58
59
  };
59
- const fetchDistinctStrings = async (query, client) => {
60
+ const fetchDistinctStrings = async (query, client, customFields) => {
60
61
  try {
61
62
  const hostedBody = {
62
63
  metadata: {
@@ -65,6 +66,7 @@ const fetchDistinctStrings = async (query, client) => {
65
66
  orgId: client.customerId || '*',
66
67
  clientId: client.publicKey,
67
68
  databaseType: client?.databaseType,
69
+ customFieldsByTable: customFields,
68
70
  },
69
71
  };
70
72
  const cloudBody = { query };
@@ -100,7 +100,7 @@ export const quillFormat = ({ value, format, }) => {
100
100
  */
101
101
  const formatString = (value) => {
102
102
  if (value === null || value === undefined) {
103
- return 'null';
103
+ return '-';
104
104
  }
105
105
  if (typeof value === 'object') {
106
106
  return JSON.stringify(value);