@quillsql/react 2.13.30 → 2.13.32

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 (81) hide show
  1. package/dist/cjs/ChartBuilder.d.ts +1 -3
  2. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  3. package/dist/cjs/ChartBuilder.js +126 -74
  4. package/dist/cjs/ChartEditor.d.ts +1 -5
  5. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  6. package/dist/cjs/ChartEditor.js +2 -2
  7. package/dist/cjs/Context.d.ts.map +1 -1
  8. package/dist/cjs/Context.js +10 -0
  9. package/dist/cjs/Dashboard.d.ts.map +1 -1
  10. package/dist/cjs/Dashboard.js +49 -24
  11. package/dist/cjs/QuillProvider.d.ts +24 -6
  12. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  13. package/dist/cjs/QuillProvider.js +14 -3
  14. package/dist/cjs/ReportBuilder.d.ts +1 -5
  15. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  16. package/dist/cjs/ReportBuilder.js +2 -2
  17. package/dist/cjs/SQLEditor.d.ts +1 -5
  18. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  19. package/dist/cjs/SQLEditor.js +2 -2
  20. package/dist/cjs/components/Chart/InternalChart.d.ts.map +1 -1
  21. package/dist/cjs/components/Chart/InternalChart.js +2 -2
  22. package/dist/cjs/components/QuillMultiSelectSectionList.d.ts +39 -0
  23. package/dist/cjs/components/QuillMultiSelectSectionList.d.ts.map +1 -0
  24. package/dist/cjs/components/QuillMultiSelectSectionList.js +343 -0
  25. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts +3 -1
  26. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  27. package/dist/cjs/components/QuillMultiSelectWithCombo.js +4 -3
  28. package/dist/cjs/hooks/useExport.d.ts +2 -2
  29. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  30. package/dist/cjs/hooks/useExport.js +19 -24
  31. package/dist/cjs/models/Client.d.ts +6 -10
  32. package/dist/cjs/models/Client.d.ts.map +1 -1
  33. package/dist/cjs/models/Report.d.ts +1 -1
  34. package/dist/cjs/models/Report.d.ts.map +1 -1
  35. package/dist/cjs/utils/client.d.ts +2 -2
  36. package/dist/cjs/utils/client.d.ts.map +1 -1
  37. package/dist/cjs/utils/client.js +4 -12
  38. package/dist/cjs/utils/tenants.d.ts +0 -2
  39. package/dist/cjs/utils/tenants.d.ts.map +1 -1
  40. package/dist/cjs/utils/tenants.js +0 -11
  41. package/dist/esm/ChartBuilder.d.ts +1 -3
  42. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  43. package/dist/esm/ChartBuilder.js +127 -75
  44. package/dist/esm/ChartEditor.d.ts +1 -5
  45. package/dist/esm/ChartEditor.d.ts.map +1 -1
  46. package/dist/esm/ChartEditor.js +2 -2
  47. package/dist/esm/Context.d.ts.map +1 -1
  48. package/dist/esm/Context.js +10 -0
  49. package/dist/esm/Dashboard.d.ts.map +1 -1
  50. package/dist/esm/Dashboard.js +49 -24
  51. package/dist/esm/QuillProvider.d.ts +24 -6
  52. package/dist/esm/QuillProvider.d.ts.map +1 -1
  53. package/dist/esm/QuillProvider.js +14 -3
  54. package/dist/esm/ReportBuilder.d.ts +1 -5
  55. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  56. package/dist/esm/ReportBuilder.js +2 -2
  57. package/dist/esm/SQLEditor.d.ts +1 -5
  58. package/dist/esm/SQLEditor.d.ts.map +1 -1
  59. package/dist/esm/SQLEditor.js +2 -2
  60. package/dist/esm/components/Chart/InternalChart.d.ts.map +1 -1
  61. package/dist/esm/components/Chart/InternalChart.js +2 -2
  62. package/dist/esm/components/QuillMultiSelectSectionList.d.ts +39 -0
  63. package/dist/esm/components/QuillMultiSelectSectionList.d.ts.map +1 -0
  64. package/dist/esm/components/QuillMultiSelectSectionList.js +317 -0
  65. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts +3 -1
  66. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  67. package/dist/esm/components/QuillMultiSelectWithCombo.js +4 -3
  68. package/dist/esm/hooks/useExport.d.ts +2 -2
  69. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  70. package/dist/esm/hooks/useExport.js +19 -24
  71. package/dist/esm/models/Client.d.ts +6 -10
  72. package/dist/esm/models/Client.d.ts.map +1 -1
  73. package/dist/esm/models/Report.d.ts +1 -1
  74. package/dist/esm/models/Report.d.ts.map +1 -1
  75. package/dist/esm/utils/client.d.ts +2 -2
  76. package/dist/esm/utils/client.d.ts.map +1 -1
  77. package/dist/esm/utils/client.js +4 -12
  78. package/dist/esm/utils/tenants.d.ts +0 -2
  79. package/dist/esm/utils/tenants.d.ts.map +1 -1
  80. package/dist/esm/utils/tenants.js +1 -9
  81. package/package.json +1 -1
@@ -0,0 +1,317 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useOnClickOutside } from '../hooks';
3
+ import { LoadingSpinner } from './UiComponents';
4
+ import React, { useContext,
5
+ // useEffect,
6
+ useMemo, useRef, useState, } from 'react';
7
+ import { ThemeContext } from '../Context';
8
+ /**
9
+ * A robust select component that implements the new minimal Select interface.
10
+ */
11
+ export function QuillMultiSelectSectionList({ options, width, onChange, label, sectionHeaderMap, value, isLoading, disabled, emptyLabel, allSelectedLabel, style, owner, }) {
12
+ const [theme] = useContext(ThemeContext);
13
+ // const [selectedOptions, setSelectedOptions] = useState<{[tenantField: string] : string[]}>({});
14
+ const [showModal, setShowModal] = useState(false);
15
+ const modalRef = useRef(null);
16
+ const buttonRef = useRef(null);
17
+ const debounceTimeoutId = useRef(null);
18
+ const [searchQuery, setSearchQuery] = React.useState('');
19
+ // const [exceedsLimit, setExceedsLimit] = useState(false);
20
+ useOnClickOutside(modalRef, (event) => {
21
+ if (!buttonRef.current?.contains(event.target))
22
+ setShowModal(false);
23
+ }, showModal);
24
+ const debounce = (updatedChangeEvent) => {
25
+ if (debounceTimeoutId.current) {
26
+ clearTimeout(debounceTimeoutId.current);
27
+ }
28
+ debounceTimeoutId.current = setTimeout(() => {
29
+ onChange(updatedChangeEvent);
30
+ }, 200);
31
+ };
32
+ const optionsLength = React.useMemo(() => {
33
+ return Object.values(options).reduce((a, b) => a + b.length, 0);
34
+ }, [options]);
35
+ const filteredItems = React.useMemo(() => {
36
+ if (searchQuery === '') {
37
+ return options;
38
+ }
39
+ const uuidRegex = /^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-5][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}$/;
40
+ // Get the first element of the first non-empty array
41
+ const sample = Object.values(options).find((arr) => arr.length > 0)?.[0];
42
+ if (!sample) {
43
+ return {};
44
+ }
45
+ const isUuid = sample.value?.match(uuidRegex);
46
+ const isNumber = !isNaN(parseInt(sample.value));
47
+ const filteredOptions = Object.keys(options).reduce((acc, key) => {
48
+ acc[key] = options[key]?.filter((option) => {
49
+ if (!option) {
50
+ return false;
51
+ }
52
+ return option.label
53
+ .toLowerCase()
54
+ .replace(/\s+/g, '')
55
+ .includes(searchQuery.toLowerCase().replace(/\s+/g, ''))
56
+ || (isNumber || isUuid ? option.value
57
+ .toLowerCase()
58
+ .replace(/\s+/g, '')
59
+ .includes(searchQuery.toLowerCase().replace(/\s+/g, '')) : false);
60
+ }) ?? [];
61
+ return acc;
62
+ }, {});
63
+ const sliceSize = Math.ceil(20 / Object.keys(filteredOptions).length);
64
+ Object.keys(filteredOptions).forEach((key) => {
65
+ if (filteredOptions[key]) {
66
+ filteredOptions[key] = filteredOptions[key].slice(0, sliceSize);
67
+ }
68
+ });
69
+ return Object.fromEntries(Object.entries(filteredOptions).filter(([, value]) => !!value?.length).sort(([key]) => key === owner ? -1 : 1));
70
+ }, [options, searchQuery]);
71
+ const filteredLength = React.useMemo(() => {
72
+ return Object.values(filteredItems).reduce((a, b) => a + b.length, 0);
73
+ }, [filteredItems]);
74
+ const selectedOptionsLabel = useMemo(() => {
75
+ const valuesLength = Object.values(value).reduce((a, b) => a + b.length, 0);
76
+ if (!valuesLength) {
77
+ return 'Select';
78
+ }
79
+ const selectedOptionsLabels = Object.keys(value).map((key) => {
80
+ const matchingOptions = options[key]?.filter((elem) => value[key]?.includes(elem.value)) ?? [];
81
+ if (matchingOptions.length === 0) {
82
+ return null;
83
+ }
84
+ if (matchingOptions.length !== value[key]?.length) {
85
+ return value[key]?.join(', ') ?? null;
86
+ }
87
+ return matchingOptions
88
+ .map((elem) => elem.label)
89
+ .join(', ');
90
+ });
91
+ if (selectedOptionsLabels.length === optionsLength && allSelectedLabel) {
92
+ return allSelectedLabel;
93
+ }
94
+ return selectedOptionsLabels.filter((label) => label !== null).join(', ');
95
+ }, [options, value]);
96
+ return (_jsxs("div", { style: {
97
+ position: 'relative',
98
+ borderRadius: '6px',
99
+ width: width,
100
+ minWidth: width,
101
+ ...style
102
+ }, children: [label && (_jsx("div", { style: {
103
+ fontSize: 14,
104
+ color: theme?.secondaryTextColor,
105
+ fontFamily: theme?.fontFamily,
106
+ paddingBottom: 5,
107
+ fontWeight: 600,
108
+ }, children: label })), _jsxs("button", { style: {
109
+ fontFamily: theme?.fontFamily,
110
+ color: theme?.primaryTextColor,
111
+ width: '100%',
112
+ display: 'flex',
113
+ alignItems: 'center',
114
+ justifyContent: 'space-between',
115
+ fontWeight: 'inherit',
116
+ lineHeight: 'inherit',
117
+ padding: '8px 12px',
118
+ fontSize: 14,
119
+ margin: 0,
120
+ boxSizing: 'border-box',
121
+ borderWidth: 1,
122
+ borderStyle: 'solid',
123
+ borderColor: theme?.borderColor,
124
+ borderRadius: 6,
125
+ paddingTop: 9,
126
+ paddingBottom: 9,
127
+ height: 40,
128
+ minHeight: 40,
129
+ maxHeight: 40,
130
+ }, className: 'quill-select-button', onClick: () => setShowModal((showModal) => !showModal), disabled: disabled, ref: buttonRef, children: [_jsx("style", { children: ` .quill-select-button { background: ${theme?.backgroundColor}; }
131
+ .quill-select-button:hover { background: ${theme?.hoverBackgroundColor}; }
132
+ .quill-select-button:disabled {
133
+ cursor: not-allowed;
134
+ background: ${theme?.hoverBackgroundColor};
135
+ }
136
+ ` }), _jsx("span", { style: {
137
+ textOverflow: 'ellipsis',
138
+ whiteSpace: 'nowrap',
139
+ overflow: 'hidden',
140
+ width: '100%',
141
+ textAlign: 'left',
142
+ zIndex: 1,
143
+ }, children: selectedOptionsLabel }), _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", { style: {
144
+ position: 'absolute',
145
+ width: '100%',
146
+ display: 'flex',
147
+ flexDirection: 'column',
148
+ boxSizing: 'border-box',
149
+ borderWidth: 1,
150
+ borderStyle: 'solid',
151
+ borderColor: theme?.borderColor,
152
+ borderRadius: 6,
153
+ background: 'white',
154
+ marginTop: 12,
155
+ zIndex: 100,
156
+ padding: 6,
157
+ fontFamily: theme?.fontFamily,
158
+ maxHeight: '50vh',
159
+ overflow: 'scroll',
160
+ fontSize: 14,
161
+ }, ref: modalRef, children: [options && optionsLength > 20 && (_jsxs(_Fragment, { children: [_jsx(ListboxTextInput, { value: searchQuery, placeholder: "Search", onChange: (value) => {
162
+ setSearchQuery(value);
163
+ } }), _jsx("div", { style: {
164
+ height: 9,
165
+ width: 230,
166
+ borderTop: '1px solid #e7e7e7',
167
+ } })] })), !isLoading &&
168
+ (!filteredItems || filteredLength === 0) && (_jsxs("div", { style: {
169
+ display: 'flex',
170
+ alignItems: 'center',
171
+ padding: 8,
172
+ margin: 0,
173
+ boxSizing: 'border-box',
174
+ borderWidth: 0,
175
+ fontSize: 14,
176
+ borderStyle: 'solid',
177
+ borderColor: theme?.borderColor,
178
+ borderRadius: 4,
179
+ fontFamily: theme?.fontFamily,
180
+ textOverflow: 'ellipsis',
181
+ whiteSpace: 'nowrap',
182
+ height: 34,
183
+ minHeight: 34,
184
+ gap: 6,
185
+ overflow: 'hidden',
186
+ }, children: [_jsx("style", { children: `
187
+ .quill-option {
188
+ background: white;
189
+ }
190
+ .quill-option:hover {
191
+ background: #F4F4F5;
192
+ }
193
+ ` }), _jsx("span", { style: {
194
+ textOverflow: 'ellipsis',
195
+ whiteSpace: 'nowrap',
196
+ overflow: 'hidden',
197
+ cursor: 'default',
198
+ }, children: emptyLabel ?? 'No options available' })] })), !isLoading ? Object.keys(filteredItems).map((key) => (_jsxs(_Fragment, { children: [_jsxs("button", { style: {
199
+ display: 'flex',
200
+ alignItems: 'center',
201
+ padding: 8,
202
+ margin: 0,
203
+ boxSizing: 'border-box',
204
+ borderWidth: 0,
205
+ fontSize: 14,
206
+ borderStyle: 'solid',
207
+ borderColor: theme?.borderColor,
208
+ borderRadius: 4,
209
+ fontFamily: theme?.fontFamily,
210
+ textOverflow: 'ellipsis',
211
+ whiteSpace: 'nowrap',
212
+ height: 34,
213
+ minHeight: 34,
214
+ gap: 6,
215
+ overflow: 'hidden',
216
+ }, className: "quill-option", onClick: () => {
217
+ const updatedValue = filteredItems[key]?.length === value[key]?.length
218
+ ? [] : filteredItems[key]?.map((option) => option.value) ?? [];
219
+ const updatedChangeEvent = {
220
+ target: {
221
+ value: {
222
+ ...value,
223
+ [key]: updatedValue,
224
+ },
225
+ },
226
+ };
227
+ // setSelectedOptions(updatedValue);
228
+ debounce(updatedChangeEvent);
229
+ }, children: [_jsx("style", { children: `
230
+ .quill-option {
231
+ background: white;
232
+ }
233
+ .quill-option:hover {
234
+ background: #F4F4F5;
235
+ }
236
+ ` }), _jsx("input", { type: "checkbox", checked: filteredItems[key]?.length === value[key]?.length, style: { width: '14px', height: '14px', margin: 'auto 0' }, readOnly: true }), _jsx("span", { style: {
237
+ textOverflow: 'ellipsis',
238
+ whiteSpace: 'nowrap',
239
+ overflow: 'hidden',
240
+ fontWeight: 600,
241
+ }, children: sectionHeaderMap?.[key] ?? key })] }, "section-header-" + key), _jsx("div", { style: {
242
+ height: 1,
243
+ borderTop: '1px solid #e7e7e7',
244
+ marginTop: 2,
245
+ marginBottom: 2,
246
+ } }), filteredItems[key]?.map((option) => (_jsxs("button", { style: {
247
+ display: 'flex',
248
+ alignItems: 'center',
249
+ padding: 8,
250
+ paddingLeft: 16,
251
+ margin: 0,
252
+ boxSizing: 'border-box',
253
+ borderWidth: 0,
254
+ fontSize: 14,
255
+ borderStyle: 'solid',
256
+ borderColor: theme?.borderColor,
257
+ borderRadius: 4,
258
+ fontFamily: theme?.fontFamily,
259
+ textOverflow: 'ellipsis',
260
+ whiteSpace: 'nowrap',
261
+ height: 34,
262
+ minHeight: 34,
263
+ gap: 6,
264
+ overflow: 'hidden',
265
+ }, className: "quill-option", onClick: () => {
266
+ const updatedValue = value[key]?.includes(option.value)
267
+ ? value[key]?.filter((val) => val !== option.value)
268
+ : [...(value[key] ?? []), option.value];
269
+ const updatedChangeEvent = {
270
+ target: {
271
+ value: {
272
+ ...value,
273
+ [key]: updatedValue,
274
+ },
275
+ },
276
+ };
277
+ // setSelectedOptions(updatedValue);
278
+ debounce(updatedChangeEvent);
279
+ }, children: [_jsx("style", { children: `
280
+ .quill-option {
281
+ background: white;
282
+ }
283
+ .quill-option:hover {
284
+ background: #F4F4F5;
285
+ }
286
+ ` }), _jsx("input", { type: "checkbox", checked: value[key]?.includes(option.value), style: { width: '14px', height: '14px', margin: 'auto 0' }, readOnly: true }), _jsx("span", { style: {
287
+ textOverflow: 'ellipsis',
288
+ whiteSpace: 'nowrap',
289
+ overflow: 'hidden',
290
+ }, children: option.label })] }, "value-" + key + "-" + option.value)))] }))) : (_jsx("div", { children: _jsx(LoadingSpinner, {}) }))] }))] }));
291
+ }
292
+ export const ListboxTextInput = ({ value, onChange, placeholder, }) => {
293
+ return (_jsxs("div", { style: {
294
+ position: 'relative',
295
+ display: 'flex',
296
+ flexDirection: 'row',
297
+ alignItems: 'center',
298
+ marginTop: 2,
299
+ }, children: [_jsx("style", { children: `
300
+ .quill-text-input {
301
+ background-color: white;
302
+ height: 40px;
303
+ width: 145px;
304
+ z-index: 2;
305
+ color: #384151;
306
+ border-radius: 4px;
307
+ text-align: left;
308
+ padding-top: 0px;
309
+ padding-bottom: 0px;
310
+ box-sizing: content-box;
311
+ margin-left: 6px;
312
+ border: 0 solid #e5e7eb;
313
+ }
314
+ .quill-text-input:focus {
315
+ outline: none;
316
+ }` }), _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 })] }));
317
+ };
@@ -1,9 +1,11 @@
1
1
  import { MultiSelectComponentProps } from './UiComponents';
2
+ import { CSSProperties } from 'react';
2
3
  /**
3
4
  * A robust select component that implements the new minimal Select interface.
4
5
  */
5
- export declare function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, isLoading, disabled, emptyLabel, allSelectedLabel, }: MultiSelectComponentProps & {
6
+ export declare function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, isLoading, disabled, emptyLabel, allSelectedLabel, style, }: MultiSelectComponentProps & {
6
7
  allSelectedLabel?: string;
8
+ style?: CSSProperties;
7
9
  }): import("react/jsx-runtime").JSX.Element;
8
10
  export declare const ListboxTextInput: ({ value, onChange, placeholder, }: {
9
11
  value: string;
@@ -1 +1 @@
1
- {"version":3,"file":"QuillMultiSelectWithCombo.d.ts","sourceRoot":"","sources":["../../../src/components/QuillMultiSelectWithCombo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAkB,yBAAyB,EAAE,MAAM,gBAAgB,CAAC;AAW3E;;GAEG;AACH,wBAAgB,kCAAkC,CAAC,EACjD,OAAO,EACP,KAAK,EACL,QAAQ,EACR,KAAK,EACL,KAAK,EACL,SAAS,EACT,QAAQ,EACR,UAAU,EACV,gBAAgB,GACjB,EAAE,yBAAyB,GAAG;IAAE,gBAAgB,CAAC,EAAE,MAAM,CAAA;CAAE,2CA2f3D;AAED,eAAO,MAAM,gBAAgB,sCAI1B;IACD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,WAAW,EAAE,MAAM,CAAC;CACrB,4CAwDA,CAAC"}
1
+ {"version":3,"file":"QuillMultiSelectWithCombo.d.ts","sourceRoot":"","sources":["../../../src/components/QuillMultiSelectWithCombo.tsx"],"names":[],"mappings":"AACA,OAAO,EAAkB,yBAAyB,EAAE,MAAM,gBAAgB,CAAC;AAC3E,OAAc,EAEZ,aAAa,EAMd,MAAM,OAAO,CAAC;AAGf;;GAEG;AACH,wBAAgB,kCAAkC,CAAC,EACjD,OAAO,EACP,KAAK,EACL,QAAQ,EACR,KAAK,EACL,KAAK,EACL,SAAS,EACT,QAAQ,EACR,UAAU,EACV,gBAAgB,EAChB,KAAK,GACN,EAAE,yBAAyB,GAAG;IAAE,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,aAAa,CAAA;CAAE,2CA4flF;AAED,eAAO,MAAM,gBAAgB,sCAI1B;IACD,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI,CAAC;IAC9B,WAAW,EAAE,MAAM,CAAC;CACrB,4CAwDA,CAAC"}
@@ -6,7 +6,7 @@ import { ThemeContext } from '../Context';
6
6
  /**
7
7
  * A robust select component that implements the new minimal Select interface.
8
8
  */
9
- export function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, isLoading, disabled, emptyLabel, allSelectedLabel, }) {
9
+ export function QuillMultiSelectComponentWithCombo({ options, width, onChange, label, value, isLoading, disabled, emptyLabel, allSelectedLabel, style, }) {
10
10
  const [theme] = useContext(ThemeContext);
11
11
  const [selectedOptions, setSelectedOptions] = useState([]);
12
12
  const [showModal, setShowModal] = useState(false);
@@ -94,8 +94,8 @@ export function QuillMultiSelectComponentWithCombo({ options, width, onChange, l
94
94
  // But they don't have their proper labels, since we haven't stored/passed in the label
95
95
  const filteredItems = React.useMemo(() => {
96
96
  const uuidRegex = /^[0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-5][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}$/;
97
- const isUuid = potentialOptions[0]?.value?.match(uuidRegex);
98
- const isNumber = !isNaN(parseInt(potentialOptions[0]?.value ?? ''));
97
+ const isUuid = potentialOptions?.[0]?.value?.toString()?.match(uuidRegex);
98
+ const isNumber = !isNaN(parseInt(potentialOptions?.[0]?.value ?? ''));
99
99
  // Sort null to top
100
100
  if (searchQuery === '') {
101
101
  return potentialOptions
@@ -143,6 +143,7 @@ export function QuillMultiSelectComponentWithCombo({ options, width, onChange, l
143
143
  borderRadius: '6px',
144
144
  width: width,
145
145
  minWidth: width,
146
+ ...style
146
147
  }, children: [label && (_jsx("div", { style: {
147
148
  fontSize: 14,
148
149
  color: theme?.secondaryTextColor,
@@ -4,9 +4,9 @@ export declare const useExport: (reportId?: string, { CustomDocumentComponent, m
4
4
  maximumRowsPerPage?: number;
5
5
  sectionField?: string;
6
6
  }) => {
7
- downloadCSV: () => void;
8
- downloadPDF: () => void;
7
+ downloadPDF: () => Promise<void>;
9
8
  isPDFLoading: boolean;
9
+ downloadCSV: () => Promise<void>;
10
10
  isCSVLoading: boolean;
11
11
  };
12
12
  interface QuillPDFProps {
@@ -1 +1 @@
1
- {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAmE/C,eAAO,MAAM,SAAS,cACT,MAAM,mEAMd;IACD,uBAAuB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,GAAG,CAAC,OAAO,CAAC;IAChE,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;;;;;CAqPF,CAAC;AAEF,UAAU,aAAa;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
1
+ {"version":3,"file":"useExport.d.ts","sourceRoot":"","sources":["../../../src/hooks/useExport.tsx"],"names":[],"mappings":"AAWA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAmE/C,eAAO,MAAM,SAAS,cACT,MAAM,mEAMd;IACD,uBAAuB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,GAAG,CAAC,OAAO,CAAC;IAChE,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,KACA;IACD,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACjC,YAAY,EAAE,OAAO,CAAC;CAqPvB,CAAC;AAEF,UAAU,aAAa;IACrB,MAAM,EAAE,WAAW,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,CAAC;CAC5B"}
@@ -4,10 +4,8 @@ import { useContext, useMemo, useState } from 'react';
4
4
  import { getData } from '../utils/dataFetcher';
5
5
  import { ClientContext, DashboardContext, DashboardFiltersContext, ReportFiltersContext, TenantContext, } from '../Context';
6
6
  import { cleanDashboardItem } from '../utils/dashboard';
7
- import { defaultQuillTheme } from '../QuillProvider';
8
7
  import { createRoot } from 'react-dom/client';
9
8
  import { flushSync } from 'react-dom';
10
- import { ChartDisplay } from '../Chart';
11
9
  import { fetchReport } from '../utils/report';
12
10
  import jsPDF from 'jspdf';
13
11
  import { quillFormat } from '../utils/valueFormatter';
@@ -77,8 +75,8 @@ sectionField, } = {}) => {
77
75
  const [isPDFLoading, setIsPDFLoading] = useState(false);
78
76
  if (!reportId || !client) {
79
77
  return {
80
- downloadCSV: () => { },
81
- downloadPDF: () => { },
78
+ downloadCSV: async () => { },
79
+ downloadPDF: async () => { },
82
80
  isPDFLoading: false,
83
81
  isCSVLoading: false,
84
82
  };
@@ -247,25 +245,22 @@ function QuillCustomDocumentComponent({ report }) {
247
245
  textAlign: 'left',
248
246
  paddingLeft: 10,
249
247
  // color: theme?.primaryTextColor,
250
- }, children: report.name }) }), _jsxs("div", { style: { paddingLeft: 20, paddingRight: 20 }, children: [report.chartType !== 'table' && (_jsx(ChartDisplay, { overrideTheme: defaultQuillTheme, config: chartReport, containerStyle: {
251
- display: 'flex',
252
- height: 400,
253
- }, loading: false, isAnimationActive: false })), _jsx("div", { style: {
254
- border: '1px solid',
255
- borderRadius: '4px',
248
+ }, children: report.name }) }), _jsx("div", { style: { paddingLeft: 20, paddingRight: 20 }, children: _jsx("div", { style: {
249
+ border: '1px solid',
250
+ borderRadius: '4px',
251
+ borderStyle: 'none',
252
+ }, children: _jsxs("table", { style: {
253
+ fontFamily: 'sans-serif',
254
+ width: '100%',
255
+ borderCollapse: 'collapse',
256
256
  borderStyle: 'none',
257
- }, children: _jsxs("table", { style: {
258
- fontFamily: 'sans-serif',
259
- width: '100%',
260
- borderCollapse: 'collapse',
261
- borderStyle: 'none',
262
- }, children: [_jsx("thead", { style: {
263
- textAlign: 'left',
264
- textOverflow: 'ellipsis',
265
- whiteSpace: 'nowrap',
266
- overflow: 'hidden',
267
- }, children: _jsx("tr", { children: report.columns.map((col, colIndex) => (_jsx("th", { style: { padding: '2px', paddingLeft: '3px' }, children: col.label }, 'head' + colIndex))) }) }), _jsx("tbody", { children: report.rows.map((row, rowIndex) => (_jsx("tr", { children: report.columns.map((col, colIndex) => (_jsx("td", { style: { padding: '2px', paddingLeft: '3px' }, children: quillFormat({
268
- value: row[col.field],
269
- format: col.format,
270
- }) }, 'cell' + col.field + colIndex + rowIndex))) }, 'row' + rowIndex))) })] }) })] })] }));
257
+ }, children: [_jsx("thead", { style: {
258
+ textAlign: 'left',
259
+ textOverflow: 'ellipsis',
260
+ whiteSpace: 'nowrap',
261
+ overflow: 'hidden',
262
+ }, children: _jsx("tr", { children: report.columns.map((col, colIndex) => (_jsx("th", { style: { padding: '2px', paddingLeft: '3px' }, children: col.label }, 'head' + colIndex))) }) }), _jsx("tbody", { children: report.rows.map((row, rowIndex) => (_jsx("tr", { children: report.columns.map((col, colIndex) => (_jsx("td", { style: { padding: '2px', paddingLeft: '3px' }, children: quillFormat({
263
+ value: row[col.field],
264
+ format: col.format,
265
+ }) }, 'cell' + col.field + colIndex + rowIndex))) }, 'row' + rowIndex))) })] }) }) })] }));
271
266
  }
@@ -23,27 +23,23 @@ export type QuillProviderClient = {
23
23
  [key: string]: boolean;
24
24
  };
25
25
  domainName: string;
26
- allTenantTypes?: (QuillTenant | QuillDatabaseTenant)[];
26
+ allTenantTypes?: QuillTenant[];
27
27
  };
28
28
  export type QuillTenant = {
29
29
  name: string;
30
30
  tenantField: string;
31
- query: string;
32
- mappings: {
31
+ query?: string;
32
+ mappings?: {
33
33
  [key: string]: {
34
34
  query: string;
35
35
  };
36
36
  };
37
+ flags?: string[];
37
38
  tenantIds?: {
38
39
  id: string;
39
- flag?: string;
40
- label?: string;
40
+ flag: string;
41
+ label: string;
41
42
  }[];
42
43
  scope: 'row' | 'schema' | 'database';
43
44
  };
44
- export type QuillDatabaseTenant = {
45
- scope: 'database';
46
- flags: string[];
47
- tenantField: 'QUILL_SINGLE_TENANT';
48
- };
49
45
  //# sourceMappingURL=Client.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Client.d.ts","sourceRoot":"","sources":["../../../src/models/Client.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,MAAM,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAC;IAC1C,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,WAAW,CAAC;IAC3B,eAAe,EAAE,OAAO,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAC;IAC1C,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,CAAC,WAAW,GAAG,mBAAmB,CAAC,EAAE,CAAC;CACxD,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG;YAAE,KAAK,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IAC/C,SAAS,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC5D,KAAK,EAAE,KAAK,GAAG,QAAQ,GAAG,UAAU,CAAC;CACtC,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,KAAK,EAAE,UAAU,CAAC;IAClB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,WAAW,EAAE,qBAAqB,CAAC;CACpC,CAAC"}
1
+ {"version":3,"file":"Client.d.ts","sourceRoot":"","sources":["../../../src/models/Client.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,MAAM,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;IACZ,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAC;IAC1C,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,aAAa,EAAE,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,WAAW,CAAC;IAC3B,eAAe,EAAE,OAAO,CAAC;IACzB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,yBAAyB,CAAC,EAAE,OAAO,CAAC;IACpC,YAAY,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAA;KAAE,CAAC;IAC1C,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,WAAW,EAAE,CAAC;CAChC,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG;YAAE,KAAK,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IAChD,KAAK,CAAC,EAAE,MAAM,EAAE,CAAC;IACjB,SAAS,CAAC,EAAE;QAAE,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC1D,KAAK,EAAE,KAAK,GAAG,QAAQ,GAAG,UAAU,CAAC;CACtC,CAAC"}
@@ -116,7 +116,7 @@ export interface QuillReportInternal extends QuillReport {
116
116
  loadingRows?: boolean;
117
117
  /** Flags on this report */
118
118
  flags?: {
119
- [tenantField: string]: string[];
119
+ [tenantField: string]: string[] | 'QUILL_ALL_TENANTS';
120
120
  };
121
121
  }
122
122
  export declare const TEMP_REPORT_ID = "__quillTempReport";
@@ -1 +1 @@
1
- {"version":3,"file":"Report.d.ts","sourceRoot":"","sources":["../../../src/models/Report.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Report.d.ts","sourceRoot":"","sources":["../../../src/models/Report.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { Client, QuillDatabaseTenant, QuillTenant } from '../models/Client';
1
+ import { Client, QuillTenant } from '../models/Client';
2
2
  export declare const EMPTY_CLIENT: Client;
3
3
  export declare function fetchClient(publicKey: string, queryEndpoint: string, withCredentials?: boolean, queryHeaders?: HeadersInit): Promise<Client & {
4
- allTenantTypes?: (QuillTenant | QuillDatabaseTenant)[];
4
+ allTenantTypes?: QuillTenant[];
5
5
  }>;
6
6
  //# sourceMappingURL=client.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/utils/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAE5E,eAAO,MAAM,YAAY,EAAE,MAM1B,CAAC;AAEF,wBAAsB,WAAW,CAC/B,SAAS,EAAE,MAAM,EACjB,aAAa,EAAE,MAAM,EACrB,eAAe,UAAQ,EACvB,YAAY,CAAC,EAAE,WAAW,GACzB,OAAO,CACR,MAAM,GAAG;IAAE,cAAc,CAAC,EAAE,CAAC,WAAW,GAAG,mBAAmB,CAAC,EAAE,CAAA;CAAE,CACpE,CAgFA"}
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/utils/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAEvD,eAAO,MAAM,YAAY,EAAE,MAM1B,CAAC;AAEF,wBAAsB,WAAW,CAC/B,SAAS,EAAE,MAAM,EACjB,aAAa,EAAE,MAAM,EACrB,eAAe,UAAQ,EACvB,YAAY,CAAC,EAAE,WAAW,GACzB,OAAO,CACR,MAAM,GAAG;IAAE,cAAc,CAAC,EAAE,WAAW,EAAE,CAAA;CAAE,CAC5C,CAwEA"}
@@ -64,17 +64,9 @@ export async function fetchClient(publicKey, queryEndpoint, withCredentials = fa
64
64
  }
65
65
  return {
66
66
  ...result,
67
- allTenantTypes: result.multiTenancyDisabled
68
- ? [
69
- {
70
- scope: 'database',
71
- flags: [],
72
- tenantField: 'QUILL_SINGLE_TENANT',
73
- },
74
- ]
75
- : result.allTenantTypes?.map((tenant) => ({
76
- ...tenant,
77
- tenantIds: clientTenantIds?.find((clientTenant) => clientTenant.id === tenant.id)?.tenantIds || [],
78
- })),
67
+ allTenantTypes: result.allTenantTypes?.map((tenant) => ({
68
+ ...tenant,
69
+ tenantIds: clientTenantIds?.find((clientTenant) => clientTenant.id === tenant.id)?.tenantIds || [],
70
+ })),
79
71
  };
80
72
  }
@@ -1,4 +1,3 @@
1
- import { QuillDatabaseTenant, QuillProviderClient } from '../models/Client';
2
1
  export type TenantValue = {
3
2
  label: string;
4
3
  value: string | number;
@@ -7,5 +6,4 @@ export type Tenant = {
7
6
  name: string;
8
7
  tenantField: string;
9
8
  };
10
- export declare const asSingleDatabaseTenant: (client: QuillProviderClient | undefined) => QuillDatabaseTenant | undefined;
11
9
  //# sourceMappingURL=tenants.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"tenants.d.ts","sourceRoot":"","sources":["../../../src/utils/tenants.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAE5E,MAAM,MAAM,WAAW,GAAG;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,eAAO,MAAM,sBAAsB,WACzB,mBAAmB,GAAG,SAAS,KACtC,mBAAmB,GAAG,SASxB,CAAC"}
1
+ {"version":3,"file":"tenants.d.ts","sourceRoot":"","sources":["../../../src/utils/tenants.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC;CACxB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG;IACnB,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC"}
@@ -1,9 +1 @@
1
- export const asSingleDatabaseTenant = (client) => {
2
- if (client?.allTenantTypes?.length &&
3
- client.allTenantTypes?.[0]?.scope === 'database') {
4
- return client.allTenantTypes?.[0];
5
- }
6
- else {
7
- return undefined;
8
- }
9
- };
1
+ export {};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@quillsql/react",
3
- "version": "2.13.30",
3
+ "version": "2.13.32",
4
4
  "exports": {
5
5
  ".": {
6
6
  "import": "./dist/esm/index.js",