@quillsql/react 2.13.47 → 2.13.49

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 (298) hide show
  1. package/dist/cjs/Chart.d.ts +2 -2
  2. package/dist/cjs/Chart.d.ts.map +1 -1
  3. package/dist/cjs/Chart.js +56 -49
  4. package/dist/cjs/ChartBuilder.d.ts +3 -2
  5. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  6. package/dist/cjs/ChartBuilder.js +172 -138
  7. package/dist/cjs/ChartEditor.d.ts +2 -2
  8. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  9. package/dist/cjs/ChartEditor.js +5 -2
  10. package/dist/cjs/Context.d.ts +121 -41
  11. package/dist/cjs/Context.d.ts.map +1 -1
  12. package/dist/cjs/Context.js +449 -261
  13. package/dist/cjs/Dashboard.d.ts.map +1 -1
  14. package/dist/cjs/Dashboard.js +26 -25
  15. package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +0 -3
  16. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
  17. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  18. package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +472 -96
  19. package/dist/cjs/QuillProvider.d.ts +3 -1
  20. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  21. package/dist/cjs/QuillProvider.js +2 -2
  22. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  23. package/dist/cjs/ReportBuilder.js +25 -14
  24. package/dist/cjs/SQLEditor.d.ts +1 -1
  25. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  26. package/dist/cjs/SQLEditor.js +51 -16
  27. package/dist/cjs/Table.d.ts.map +1 -1
  28. package/dist/cjs/Table.js +85 -14
  29. package/dist/cjs/assets/ExclamationFilledIcon.d.ts.map +1 -1
  30. package/dist/cjs/components/Chart/BarChart.d.ts.map +1 -1
  31. package/dist/cjs/components/Chart/BarChart.js +2 -1
  32. package/dist/cjs/components/Chart/CustomReferenceLine.d.ts +1 -1
  33. package/dist/cjs/components/Chart/CustomReferenceLine.d.ts.map +1 -1
  34. package/dist/cjs/components/Chart/CustomReferenceLine.js +7 -6
  35. package/dist/cjs/components/Chart/GaugeChart.d.ts +1 -1
  36. package/dist/cjs/components/Chart/GaugeChart.d.ts.map +1 -1
  37. package/dist/cjs/components/Chart/GaugeChart.js +63 -36
  38. package/dist/cjs/components/Chart/InternalChart.d.ts.map +1 -1
  39. package/dist/cjs/components/Chart/InternalChart.js +30 -33
  40. package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
  41. package/dist/cjs/components/Chart/LineChart.js +3 -1
  42. package/dist/cjs/components/Chart/MapChart.d.ts +3 -3
  43. package/dist/cjs/components/Chart/MapChart.d.ts.map +1 -1
  44. package/dist/cjs/components/Chart/MapChart.js +62 -34
  45. package/dist/cjs/components/Chart/PieChart.d.ts +3 -1
  46. package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
  47. package/dist/cjs/components/Chart/PieChart.js +80 -39
  48. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  49. package/dist/cjs/components/Dashboard/DashboardFilter.js +4 -20
  50. package/dist/cjs/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  51. package/dist/cjs/components/Dashboard/DashboardTemplate.js +2 -1
  52. package/dist/cjs/components/Dashboard/DataLoader.d.ts +4 -4
  53. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  54. package/dist/cjs/components/Dashboard/DataLoader.js +101 -65
  55. package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
  56. package/dist/cjs/components/Dashboard/MetricComponent.js +2 -2
  57. package/dist/cjs/components/Dashboard/util.d.ts +1 -1
  58. package/dist/cjs/components/Dashboard/util.d.ts.map +1 -1
  59. package/dist/cjs/components/Dashboard/util.js +7 -6
  60. package/dist/cjs/components/QuillMultiSelectSectionList.d.ts.map +1 -1
  61. package/dist/cjs/components/QuillMultiSelectSectionList.js +32 -22
  62. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  63. package/dist/cjs/components/QuillMultiSelectWithCombo.js +186 -159
  64. package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
  65. package/dist/cjs/components/QuillSelect.js +83 -75
  66. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  67. package/dist/cjs/components/QuillSelectWithCombo.js +18 -11
  68. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  69. package/dist/cjs/components/QuillTable.js +59 -61
  70. package/dist/cjs/components/ReportBuilder/FilterStack.d.ts +2 -1
  71. package/dist/cjs/components/ReportBuilder/FilterStack.d.ts.map +1 -1
  72. package/dist/cjs/components/ReportBuilder/FilterStack.js +3 -4
  73. package/dist/cjs/components/ReportBuilder/ui.d.ts +2 -2
  74. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  75. package/dist/cjs/components/ReportBuilder/ui.js +4 -7
  76. package/dist/cjs/components/UiComponents.d.ts +1 -1
  77. package/dist/cjs/hooks/useAskQuill.d.ts.map +1 -1
  78. package/dist/cjs/hooks/useAskQuill.js +5 -1
  79. package/dist/cjs/hooks/useDashboard.d.ts +2 -2
  80. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  81. package/dist/cjs/hooks/useDashboard.js +160 -69
  82. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  83. package/dist/cjs/hooks/useExport.js +29 -15
  84. package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -1
  85. package/dist/cjs/hooks/useQuill.d.ts +1 -0
  86. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  87. package/dist/cjs/hooks/useQuill.js +22 -12
  88. package/dist/cjs/hooks/useReport.d.ts +2 -2
  89. package/dist/cjs/hooks/useReport.d.ts.map +1 -1
  90. package/dist/cjs/hooks/useReport.js +3 -4
  91. package/dist/cjs/hooks/useVirtualTables.d.ts.map +1 -1
  92. package/dist/cjs/hooks/useVirtualTables.js +16 -22
  93. package/dist/cjs/index.d.ts +2 -2
  94. package/dist/cjs/index.d.ts.map +1 -1
  95. package/dist/cjs/index.js +2 -1
  96. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +2 -1
  97. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  98. package/dist/cjs/internals/ReportBuilder/PivotModal.js +19 -7
  99. package/dist/cjs/models/Client.d.ts +0 -1
  100. package/dist/cjs/models/Client.d.ts.map +1 -1
  101. package/dist/cjs/models/Data.d.ts +20 -0
  102. package/dist/cjs/models/Data.d.ts.map +1 -0
  103. package/dist/cjs/models/Data.js +2 -0
  104. package/dist/cjs/models/Filter.d.ts +42 -4
  105. package/dist/cjs/models/Filter.d.ts.map +1 -1
  106. package/dist/cjs/models/Pivot.d.ts.map +1 -1
  107. package/dist/cjs/utils/astProcessing.d.ts +3 -2
  108. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  109. package/dist/cjs/utils/astProcessing.js +28 -37
  110. package/dist/cjs/utils/client.d.ts +3 -2
  111. package/dist/cjs/utils/client.d.ts.map +1 -1
  112. package/dist/cjs/utils/client.js +38 -39
  113. package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
  114. package/dist/cjs/utils/columnProcessing.js +14 -3
  115. package/dist/cjs/utils/constants.d.ts +1 -0
  116. package/dist/cjs/utils/constants.d.ts.map +1 -1
  117. package/dist/cjs/utils/constants.js +2 -1
  118. package/dist/cjs/utils/dashboard.d.ts +3 -2
  119. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  120. package/dist/cjs/utils/dashboard.js +30 -12
  121. package/dist/cjs/utils/dataFetcher.d.ts +8 -5
  122. package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
  123. package/dist/cjs/utils/dataFetcher.js +189 -65
  124. package/dist/cjs/utils/filterProcessing.d.ts +2 -1
  125. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  126. package/dist/cjs/utils/filterProcessing.js +24 -38
  127. package/dist/cjs/utils/getDomain.d.ts.map +1 -1
  128. package/dist/cjs/utils/paginationProcessing.d.ts +1 -0
  129. package/dist/cjs/utils/paginationProcessing.d.ts.map +1 -1
  130. package/dist/cjs/utils/paginationProcessing.js +6 -1
  131. package/dist/cjs/utils/pivotConstructor.d.ts +2 -1
  132. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  133. package/dist/cjs/utils/pivotConstructor.js +15 -9
  134. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  135. package/dist/cjs/utils/pivotProcessing.js +3 -5
  136. package/dist/cjs/utils/queryConstructor.js +1 -1
  137. package/dist/cjs/utils/report.d.ts +10 -7
  138. package/dist/cjs/utils/report.d.ts.map +1 -1
  139. package/dist/cjs/utils/report.js +52 -60
  140. package/dist/cjs/utils/schema.d.ts +4 -3
  141. package/dist/cjs/utils/schema.d.ts.map +1 -1
  142. package/dist/cjs/utils/schema.js +30 -44
  143. package/dist/cjs/utils/tableProcessing.d.ts +16 -10
  144. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  145. package/dist/cjs/utils/tableProcessing.js +92 -90
  146. package/dist/cjs/utils/textProcessing.d.ts.map +1 -1
  147. package/dist/cjs/utils/textProcessing.js +2 -1
  148. package/dist/cjs/utils/ui.d.ts.map +1 -1
  149. package/dist/esm/Chart.d.ts +2 -2
  150. package/dist/esm/Chart.d.ts.map +1 -1
  151. package/dist/esm/Chart.js +60 -53
  152. package/dist/esm/ChartBuilder.d.ts +3 -2
  153. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  154. package/dist/esm/ChartBuilder.js +173 -139
  155. package/dist/esm/ChartEditor.d.ts +2 -2
  156. package/dist/esm/ChartEditor.d.ts.map +1 -1
  157. package/dist/esm/ChartEditor.js +6 -3
  158. package/dist/esm/Context.d.ts +121 -41
  159. package/dist/esm/Context.d.ts.map +1 -1
  160. package/dist/esm/Context.js +450 -262
  161. package/dist/esm/Dashboard.d.ts.map +1 -1
  162. package/dist/esm/Dashboard.js +28 -27
  163. package/dist/esm/DateRangePicker/QuillDateRangePicker.js +0 -3
  164. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +24 -10
  165. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  166. package/dist/esm/DateRangePicker/dateRangePickerUtils.js +471 -95
  167. package/dist/esm/QuillProvider.d.ts +3 -1
  168. package/dist/esm/QuillProvider.d.ts.map +1 -1
  169. package/dist/esm/QuillProvider.js +2 -2
  170. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  171. package/dist/esm/ReportBuilder.js +28 -17
  172. package/dist/esm/SQLEditor.d.ts +1 -1
  173. package/dist/esm/SQLEditor.d.ts.map +1 -1
  174. package/dist/esm/SQLEditor.js +54 -19
  175. package/dist/esm/Table.d.ts.map +1 -1
  176. package/dist/esm/Table.js +88 -17
  177. package/dist/esm/assets/ExclamationFilledIcon.d.ts.map +1 -1
  178. package/dist/esm/components/Chart/BarChart.d.ts.map +1 -1
  179. package/dist/esm/components/Chart/BarChart.js +2 -1
  180. package/dist/esm/components/Chart/CustomReferenceLine.d.ts +1 -1
  181. package/dist/esm/components/Chart/CustomReferenceLine.d.ts.map +1 -1
  182. package/dist/esm/components/Chart/CustomReferenceLine.js +8 -7
  183. package/dist/esm/components/Chart/GaugeChart.d.ts +1 -1
  184. package/dist/esm/components/Chart/GaugeChart.d.ts.map +1 -1
  185. package/dist/esm/components/Chart/GaugeChart.js +65 -38
  186. package/dist/esm/components/Chart/InternalChart.d.ts.map +1 -1
  187. package/dist/esm/components/Chart/InternalChart.js +32 -35
  188. package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
  189. package/dist/esm/components/Chart/LineChart.js +3 -1
  190. package/dist/esm/components/Chart/MapChart.d.ts +3 -3
  191. package/dist/esm/components/Chart/MapChart.d.ts.map +1 -1
  192. package/dist/esm/components/Chart/MapChart.js +67 -39
  193. package/dist/esm/components/Chart/PieChart.d.ts +3 -1
  194. package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
  195. package/dist/esm/components/Chart/PieChart.js +80 -39
  196. package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  197. package/dist/esm/components/Dashboard/DashboardFilter.js +5 -21
  198. package/dist/esm/components/Dashboard/DashboardSection.js +2 -2
  199. package/dist/esm/components/Dashboard/DashboardTemplate.d.ts.map +1 -1
  200. package/dist/esm/components/Dashboard/DashboardTemplate.js +3 -2
  201. package/dist/esm/components/Dashboard/DataLoader.d.ts +4 -4
  202. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  203. package/dist/esm/components/Dashboard/DataLoader.js +102 -66
  204. package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
  205. package/dist/esm/components/Dashboard/MetricComponent.js +2 -2
  206. package/dist/esm/components/Dashboard/util.d.ts +1 -1
  207. package/dist/esm/components/Dashboard/util.d.ts.map +1 -1
  208. package/dist/esm/components/Dashboard/util.js +8 -7
  209. package/dist/esm/components/QuillMultiSelectSectionList.d.ts.map +1 -1
  210. package/dist/esm/components/QuillMultiSelectSectionList.js +32 -22
  211. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  212. package/dist/esm/components/QuillMultiSelectWithCombo.js +187 -160
  213. package/dist/esm/components/QuillSelect.d.ts.map +1 -1
  214. package/dist/esm/components/QuillSelect.js +85 -77
  215. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  216. package/dist/esm/components/QuillSelectWithCombo.js +18 -11
  217. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  218. package/dist/esm/components/QuillTable.js +59 -61
  219. package/dist/esm/components/ReportBuilder/FilterStack.d.ts +2 -1
  220. package/dist/esm/components/ReportBuilder/FilterStack.d.ts.map +1 -1
  221. package/dist/esm/components/ReportBuilder/FilterStack.js +3 -4
  222. package/dist/esm/components/ReportBuilder/ui.d.ts +2 -2
  223. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  224. package/dist/esm/components/ReportBuilder/ui.js +4 -7
  225. package/dist/esm/components/UiComponents.d.ts +1 -1
  226. package/dist/esm/hooks/useAskQuill.d.ts.map +1 -1
  227. package/dist/esm/hooks/useAskQuill.js +6 -2
  228. package/dist/esm/hooks/useDashboard.d.ts +2 -2
  229. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  230. package/dist/esm/hooks/useDashboard.js +162 -71
  231. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  232. package/dist/esm/hooks/useExport.js +31 -17
  233. package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -1
  234. package/dist/esm/hooks/useQuill.d.ts +1 -0
  235. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  236. package/dist/esm/hooks/useQuill.js +23 -13
  237. package/dist/esm/hooks/useReport.d.ts +2 -2
  238. package/dist/esm/hooks/useReport.d.ts.map +1 -1
  239. package/dist/esm/hooks/useReport.js +4 -5
  240. package/dist/esm/hooks/useVirtualTables.d.ts.map +1 -1
  241. package/dist/esm/hooks/useVirtualTables.js +17 -23
  242. package/dist/esm/index.d.ts +2 -2
  243. package/dist/esm/index.d.ts.map +1 -1
  244. package/dist/esm/index.js +1 -1
  245. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +2 -1
  246. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  247. package/dist/esm/internals/ReportBuilder/PivotModal.js +20 -8
  248. package/dist/esm/models/Client.d.ts +0 -1
  249. package/dist/esm/models/Client.d.ts.map +1 -1
  250. package/dist/esm/models/Data.d.ts +20 -0
  251. package/dist/esm/models/Data.d.ts.map +1 -0
  252. package/dist/esm/models/Data.js +1 -0
  253. package/dist/esm/models/Filter.d.ts +42 -4
  254. package/dist/esm/models/Filter.d.ts.map +1 -1
  255. package/dist/esm/models/Pivot.d.ts.map +1 -1
  256. package/dist/esm/utils/astProcessing.d.ts +3 -2
  257. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  258. package/dist/esm/utils/astProcessing.js +28 -37
  259. package/dist/esm/utils/client.d.ts +3 -2
  260. package/dist/esm/utils/client.d.ts.map +1 -1
  261. package/dist/esm/utils/client.js +38 -39
  262. package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
  263. package/dist/esm/utils/columnProcessing.js +14 -3
  264. package/dist/esm/utils/constants.d.ts +1 -0
  265. package/dist/esm/utils/constants.d.ts.map +1 -1
  266. package/dist/esm/utils/constants.js +1 -0
  267. package/dist/esm/utils/dashboard.d.ts +3 -2
  268. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  269. package/dist/esm/utils/dashboard.js +31 -13
  270. package/dist/esm/utils/dataFetcher.d.ts +8 -5
  271. package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
  272. package/dist/esm/utils/dataFetcher.js +187 -65
  273. package/dist/esm/utils/filterProcessing.d.ts +2 -1
  274. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  275. package/dist/esm/utils/filterProcessing.js +25 -39
  276. package/dist/esm/utils/getDomain.d.ts.map +1 -1
  277. package/dist/esm/utils/paginationProcessing.d.ts +1 -0
  278. package/dist/esm/utils/paginationProcessing.d.ts.map +1 -1
  279. package/dist/esm/utils/paginationProcessing.js +5 -0
  280. package/dist/esm/utils/pivotConstructor.d.ts +2 -1
  281. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  282. package/dist/esm/utils/pivotConstructor.js +16 -10
  283. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  284. package/dist/esm/utils/pivotProcessing.js +5 -7
  285. package/dist/esm/utils/queryConstructor.js +1 -1
  286. package/dist/esm/utils/report.d.ts +10 -7
  287. package/dist/esm/utils/report.d.ts.map +1 -1
  288. package/dist/esm/utils/report.js +53 -61
  289. package/dist/esm/utils/schema.d.ts +4 -3
  290. package/dist/esm/utils/schema.d.ts.map +1 -1
  291. package/dist/esm/utils/schema.js +30 -44
  292. package/dist/esm/utils/tableProcessing.d.ts +16 -10
  293. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  294. package/dist/esm/utils/tableProcessing.js +94 -92
  295. package/dist/esm/utils/textProcessing.d.ts.map +1 -1
  296. package/dist/esm/utils/textProcessing.js +2 -1
  297. package/dist/esm/utils/ui.d.ts.map +1 -1
  298. package/package.json +2 -1
@@ -1,6 +1,6 @@
1
1
  import { convertPostgresColumn, isStringType } from './columnProcessing';
2
- import { MAX_PIVOT_UNIQUE_VALUES, QUILL_QUERY_ENDPOINT, QUILL_SERVER, } from './constants';
3
- import { getData } from './dataFetcher';
2
+ import { MAX_PIVOT_UNIQUE_VALUES } from './constants';
3
+ import { parseFetchResponse, quillFetch } from './dataFetcher';
4
4
  import { parseValueFromBigQueryDates } from './dataProcessing';
5
5
  import { parseQueryDateRangeByDatabaseType } from './dates';
6
6
  import { processFilterErrorList } from './errorProcessing';
@@ -18,14 +18,14 @@ export const hasColumnAlias = (columns, referencedColumns) => {
18
18
  }
19
19
  return false;
20
20
  };
21
- export const getUniqueValuesByQuery = async ({ columns, query, client, tenants, customFields, filters, dashboardName, }) => {
21
+ export const getUniqueValuesByQuery = async ({ columns, query, client, getToken, tenants, customFields, filters, dashboardName, }) => {
22
22
  const stringNames = columns.map((column) => column.field);
23
23
  const uniqueValues = {};
24
24
  if (stringNames.length === 0) {
25
25
  return {};
26
26
  }
27
27
  const distinctValueQuery = generateDistinctQuery(stringNames, query, client.databaseType || 'postgresql');
28
- const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client, tenants, customFields, filters, dashboardName);
28
+ const distinctStrings = await fetchDistinctStrings(distinctValueQuery, client, getToken, tenants, customFields, filters, dashboardName);
29
29
  if (!distinctStrings) {
30
30
  return {};
31
31
  }
@@ -34,13 +34,13 @@ export const getUniqueValuesByQuery = async ({ columns, query, client, tenants,
34
34
  }
35
35
  return uniqueValues;
36
36
  };
37
- export const getUniqueStringValuesByColumn = async ({ columns, tableName, client, tenants, customFields, withExceededColumns, query, dashboardName, }) => {
37
+ export const getUniqueStringValuesByColumn = async ({ columns, tableName, client, getToken, tenants, customFields, withExceededColumns, query, dashboardName, }) => {
38
38
  const convertedStringColumns = columns.filter((column) => {
39
39
  return isStringType(column.fieldType);
40
40
  });
41
41
  const stringNames = convertedStringColumns.map((column) => processColumnReference(column.field, client.databaseType, undefined, true));
42
42
  const { filteredColumns: smallStringColumns, exceededColumns } = stringNames.length > 0
43
- ? await getCountsByColumns(convertedStringColumns, query || `Select ${stringNames.join(', ')} from ${tableName}`, client, tenants, customFields ?? [], dashboardName)
43
+ ? await getCountsByColumns(convertedStringColumns, query || `Select ${stringNames.join(', ')} from ${tableName}`, client, getToken, tenants, customFields ?? [], dashboardName)
44
44
  : { filteredColumns: [], exceededColumns: undefined };
45
45
  const smallStringNames = smallStringColumns.map((column) => processColumnReference(column.field, client.databaseType, undefined, true));
46
46
  const newUniqueValues = query || smallStringColumns.length > 0
@@ -49,6 +49,7 @@ export const getUniqueStringValuesByColumn = async ({ columns, tableName, client
49
49
  columns: smallStringColumns,
50
50
  query: query || `Select ${smallStringNames.join(', ')} from ${tableName}`,
51
51
  client,
52
+ getToken,
52
53
  tenants,
53
54
  customFields: customFields ?? [],
54
55
  dashboardName,
@@ -66,7 +67,7 @@ export const getUniqueStringValuesByColumn = async ({ columns, tableName, client
66
67
  }
67
68
  return newUniqueValues;
68
69
  };
69
- export const getUniqueStringValuesByTable = async ({ tables, columns, client, tenants, dashboardName, customFields, withExceededColumns, queryTemplate, }) => {
70
+ export const getUniqueStringValuesByTable = async ({ tables, columns, client, getToken, tenants, dashboardName, customFields, withExceededColumns, queryTemplate, }) => {
70
71
  const uniqueValues = {};
71
72
  await Promise.all(tables.map(async (tableName) => {
72
73
  const tableColumns = columns.filter((column) => {
@@ -82,6 +83,7 @@ export const getUniqueStringValuesByTable = async ({ tables, columns, client, te
82
83
  columns: tableColumns,
83
84
  tableName,
84
85
  client,
86
+ getToken,
85
87
  tenants,
86
88
  dashboardName,
87
89
  customFields,
@@ -92,7 +94,7 @@ export const getUniqueStringValuesByTable = async ({ tables, columns, client, te
92
94
  }));
93
95
  return uniqueValues;
94
96
  };
95
- export const getRelevantInfoFromQuery = async ({ tables, columns, aliasedColumns, reportBuilderColumns, client, tenants, query, queryTemplate, customFields, dashboardName, }) => {
97
+ export const getRelevantInfoFromQuery = async ({ tables, columns, aliasedColumns, reportBuilderColumns, client, getToken, tenants, query, queryTemplate, customFields, dashboardName, }) => {
96
98
  let dateRanges = {};
97
99
  let uniqueStrings = null;
98
100
  const columnUniqueValues = {};
@@ -102,6 +104,7 @@ export const getRelevantInfoFromQuery = async ({ tables, columns, aliasedColumns
102
104
  tables,
103
105
  columns,
104
106
  client,
107
+ getToken,
105
108
  tenants,
106
109
  dashboardName,
107
110
  customFields,
@@ -116,7 +119,7 @@ export const getRelevantInfoFromQuery = async ({ tables, columns, aliasedColumns
116
119
  return column.fieldType === 'date';
117
120
  });
118
121
  if (dateColumns.length > 0) {
119
- dateRanges = await getQueryDateRangeByColumns(dateColumns, query, client, tenants, customFields, dashboardName);
122
+ dateRanges = await getQueryDateRangeByColumns(dateColumns, query, client, getToken, tenants, customFields, dashboardName);
120
123
  if (dateRanges === null) {
121
124
  throw new Error("Couldn't fetch date ranges");
122
125
  }
@@ -132,24 +135,26 @@ export const getRelevantInfoFromQuery = async ({ tables, columns, aliasedColumns
132
135
  error,
133
136
  };
134
137
  };
135
- export const getCountsByColumns = async (columns, query, client, tenants, customFields, dashboardName) => {
138
+ // TODO: Tenants should be required (not undefined in any circumstance)
139
+ export const getCountsByColumns = async (columns, query, client, getToken, tenants, customFields, dashboardName) => {
136
140
  const stringNames = columns.map((column) => column.field);
137
141
  const countQuery = generateCountQuery(stringNames, query, client.databaseType || 'postgresql');
138
142
  try {
139
- const hostedBody = {
143
+ const { data } = await quillFetch({
144
+ client,
145
+ task: 'query',
140
146
  metadata: {
141
147
  query: countQuery,
142
- task: 'query',
143
148
  clientId: client.publicKey,
144
- databaseType: client?.databaseType,
149
+ databaseType: client.databaseType,
145
150
  customFieldsByTable: customFields,
146
151
  useNewNodeSql: true,
147
152
  dashboardName: dashboardName && tenants ? dashboardName : undefined,
148
153
  tenants: dashboardName && tenants ? tenants : undefined,
149
154
  },
150
- };
151
- const cloudBody = { countQuery };
152
- const data = await getData(client, 'dashquery', 'same-origin', hostedBody, cloudBody);
155
+ urlParameters: `caller=getCounts&task=query`,
156
+ getToken,
157
+ });
153
158
  if (data.errorMessage) {
154
159
  return { filteredColumns: columns, exceededColumns: undefined };
155
160
  }
@@ -174,25 +179,25 @@ export const getCountsByColumns = async (columns, query, client, tenants, custom
174
179
  return { filteredColumns: columns, exceededColumns: undefined };
175
180
  }
176
181
  };
177
- const fetchDistinctStrings = async (query, client, tenants, customFields, filters, dashboardName) => {
182
+ const fetchDistinctStrings = async (query, client, getToken, tenants, customFields, filters, dashboardName) => {
178
183
  try {
179
- const hostedBody = {
184
+ const { data } = await quillFetch({
185
+ client,
186
+ task: 'query',
180
187
  metadata: {
181
188
  query,
182
- task: 'query',
183
189
  clientId: client.publicKey,
184
- databaseType: client?.databaseType,
190
+ databaseType: client.databaseType,
185
191
  customFieldsByTable: customFields,
186
192
  useNewNodeSql: true,
187
193
  filters,
188
- // @ts-ignore
189
194
  dateField: filters?.find((filter) => filter.filterType === 'date_range')?.dateField,
190
195
  dashboardName,
191
196
  tenants,
192
197
  },
193
- };
194
- const cloudBody = { query };
195
- const data = await getData(client, 'dashquery', 'same-origin', hostedBody, cloudBody);
198
+ urlParameters: `caller=fetchDistinct&task=query`,
199
+ getToken,
200
+ });
196
201
  if (data.errorMessage) {
197
202
  return null;
198
203
  }
@@ -230,30 +235,30 @@ const fetchDistinctStrings = async (query, client, tenants, customFields, filter
230
235
  return null;
231
236
  }
232
237
  };
233
- export const getQueryDateRangeByColumns = async (columns, query, client, tenants, customFields, dashboardName) => {
238
+ export const getQueryDateRangeByColumns = async (columns, query, client, getToken, tenants, customFields, dashboardName) => {
234
239
  const columnNames = columns.map(
235
240
  // @ts-ignore
236
241
  (column) => column.field || column.name);
237
242
  const distinctValueQuery = generateMinMaxDateRangeQueries(columnNames, query, client.databaseType || 'postgresql');
238
- const dateRanges = await fetchQueryDateRanges(distinctValueQuery, client, tenants, customFields, dashboardName);
243
+ const dateRanges = await fetchQueryDateRanges(distinctValueQuery, client, getToken, tenants, customFields, dashboardName);
239
244
  return dateRanges;
240
245
  };
241
- const fetchQueryDateRanges = async (query, client, tenants, customFields, dashboardName) => {
246
+ const fetchQueryDateRanges = async (query, client, getToken, tenants, customFields, dashboardName) => {
242
247
  try {
243
- const hostedBody = {
248
+ const { data } = await quillFetch({
249
+ client,
250
+ task: 'query',
244
251
  metadata: {
245
252
  query,
246
- task: 'query',
247
253
  clientId: client.publicKey,
248
- databaseType: client?.databaseType,
254
+ databaseType: client.databaseType,
249
255
  customFieldsByTable: customFields,
250
256
  useNewNodeSql: true,
251
257
  dashboardName: dashboardName && tenants ? dashboardName : undefined,
252
258
  tenants: dashboardName && tenants ? tenants : undefined,
253
259
  },
254
- };
255
- const cloudBody = { query };
256
- const data = await getData(client, 'dashquery', 'same-origin', hostedBody, cloudBody);
260
+ getToken,
261
+ });
257
262
  if (data.errorMessage) {
258
263
  return null;
259
264
  }
@@ -269,7 +274,8 @@ const fetchQueryDateRanges = async (query, client, tenants, customFields, dashbo
269
274
  return null;
270
275
  }
271
276
  };
272
- export const getPaginatedRows = async (client, tenants, query, reportId, processing, filters, customFields, dashboardName) => {
277
+ // Unused?
278
+ export const getPaginatedRows = async (client, getToken, tenants, query, reportId, processing, filters, customFields, dashboardName) => {
273
279
  if (query) {
274
280
  return await fetchResultsByQuery({
275
281
  query,
@@ -279,6 +285,7 @@ export const getPaginatedRows = async (client, tenants, query, reportId, process
279
285
  customFields,
280
286
  filters,
281
287
  dashboardName,
288
+ getToken,
282
289
  });
283
290
  }
284
291
  else if (reportId) {
@@ -289,12 +296,12 @@ export const getPaginatedRows = async (client, tenants, query, reportId, process
289
296
  processing,
290
297
  filters,
291
298
  customFields,
299
+ getToken,
292
300
  });
293
301
  }
294
302
  return { rows: [], columns: [] };
295
303
  };
296
- // TODO: Move these to call through the sdk
297
- export const fetchResultsByQuery = async ({ query, client, tenants, processing, customFields, filters, dateField, rowsOnly, rowCountOnly, filterMap, dashboardName, pivot, getPivotRowCount = true, comparisonQuery, }) => {
304
+ export const fetchResultsByQuery = async ({ query, client, tenants, processing, customFields, filters, dateField, rowsOnly, rowCountOnly, filterMap, dashboardName, pivot, getPivotRowCount = true, comparisonQuery, getToken, }) => {
298
305
  let rows = [];
299
306
  let columns = [];
300
307
  let error = undefined;
@@ -310,6 +317,7 @@ export const fetchResultsByQuery = async ({ query, client, tenants, processing,
310
317
  comparisonPivotQuery: comparisonQuery,
311
318
  additionalProcessing: processing,
312
319
  getPivotRowCount,
320
+ getToken,
313
321
  });
314
322
  rows = pivotData.rows;
315
323
  columns = pivotData.columns;
@@ -319,16 +327,34 @@ export const fetchResultsByQuery = async ({ query, client, tenants, processing,
319
327
  : [pivotData.pivotQuery];
320
328
  }
321
329
  else {
322
- const hostedBody = {
330
+ let parsedSuccessfully = true;
331
+ let parsingError = '';
332
+ if (!rowCountOnly) {
333
+ const { data: results } = await quillFetch({
334
+ client,
335
+ task: 'astify',
336
+ metadata: {
337
+ clientId: client.clientId,
338
+ useNewNodeSql: true,
339
+ query,
340
+ },
341
+ getToken,
342
+ });
343
+ if (!results || results.success == false) {
344
+ parsedSuccessfully = false;
345
+ parsingError = results.message;
346
+ }
347
+ }
348
+ const fetchResp = await quillFetch({
349
+ client,
350
+ task: 'query',
323
351
  metadata: {
324
352
  query,
325
- task: 'query',
326
353
  filterMap,
327
354
  clientId: client.publicKey,
328
355
  databaseType: client?.databaseType,
329
356
  customFieldsByTable: customFields,
330
357
  additionalProcessing: processing,
331
- useUpdatedDataGathering: processing ? true : false,
332
358
  useNewNodeSql: true,
333
359
  filters: filters?.map((filter) => ({
334
360
  ...filter,
@@ -340,30 +366,10 @@ export const fetchResultsByQuery = async ({ query, client, tenants, processing,
340
366
  dashboardName: dashboardName && tenants ? dashboardName : undefined,
341
367
  tenants: dashboardName && tenants ? tenants : undefined,
342
368
  },
343
- };
344
- const cloudBody = { query };
345
- let parsedSuccessfully = true;
346
- let parsingError = '';
347
- if (!rowCountOnly) {
348
- const localURL = `${QUILL_SERVER}/astify`;
349
- const response = await fetch(localURL, {
350
- method: 'POST',
351
- headers: {
352
- 'Content-Type': 'application/json',
353
- },
354
- body: JSON.stringify({
355
- query,
356
- publicKey: client.publicKey,
357
- useNewNodeSql: true,
358
- }),
359
- });
360
- const results = await response.json();
361
- if (results.success == false) {
362
- parsedSuccessfully = false;
363
- parsingError = results.message;
364
- }
365
- }
366
- const resp = await getData(client, 'dashquery', 'same-origin', hostedBody, cloudBody);
369
+ getToken,
370
+ });
371
+ const resp = await parseFetchResponse(client, 'query', fetchResp, getToken);
372
+ // console.log('newdata', newdata);
367
373
  if (resp && resp.errorMessage) {
368
374
  throw new Error(resp.errorMessage);
369
375
  }
@@ -371,19 +377,15 @@ export const fetchResultsByQuery = async ({ query, client, tenants, processing,
371
377
  rowCount = resp.rowCount;
372
378
  }
373
379
  if (!resp.error && !parsedSuccessfully) {
374
- fetch(`${QUILL_SERVER}${QUILL_QUERY_ENDPOINT}`, {
375
- method: 'POST',
376
- headers: {
377
- 'Content-Type': 'application/json',
380
+ await quillFetch({
381
+ client,
382
+ task: 'log-broken-query',
383
+ metadata: {
384
+ query,
385
+ clientId: client.clientId,
386
+ error: parsingError,
378
387
  },
379
- body: JSON.stringify({
380
- metadata: {
381
- task: 'log-broken-query',
382
- query,
383
- clientId: client.clientId,
384
- error: parsingError,
385
- },
386
- }),
388
+ getToken,
387
389
  });
388
390
  throw new Error('Quill parsing error' +
389
391
  parsingError.replace(`Error parsing query`, ''));
@@ -417,7 +419,7 @@ export const fetchResultsByQuery = async ({ query, client, tenants, processing,
417
419
  }
418
420
  return { rows, columns, rowCount, error, itemQuery, referencedTables };
419
421
  };
420
- export const fetchResultsByReport = async ({ reportId, client, tenants, processing, filters, customFields, rowsOnly, rowCountOnly, abortSignal, pivot, pivotQuery, comparisonPivotQuery, getPivotRowCount = true, }) => {
422
+ export const fetchResultsByReport = async ({ reportId, client, tenants, processing, filters, customFields, rowsOnly, rowCountOnly, abortSignal, pivot, pivotQuery, comparisonPivotQuery, getPivotRowCount = true, getToken, }) => {
421
423
  if (pivot && pivotQuery) {
422
424
  return fetchResultsByQuery({
423
425
  query: pivotQuery,
@@ -429,6 +431,7 @@ export const fetchResultsByReport = async ({ reportId, client, tenants, processi
429
431
  filters,
430
432
  pivot,
431
433
  getPivotRowCount,
434
+ getToken,
432
435
  });
433
436
  }
434
437
  const updatedProcessing = { ...processing };
@@ -447,16 +450,18 @@ export const fetchResultsByReport = async ({ reportId, client, tenants, processi
447
450
  if (newFilter.filterType === 'date_range') {
448
451
  delete newFilter['field'];
449
452
  delete newFilter['selectedValue'];
453
+ delete newFilter['presetOptions'];
450
454
  }
451
455
  delete newFilter['options'];
452
456
  return newFilter;
453
457
  })
454
458
  : [];
455
459
  try {
456
- const hostedBody = {
460
+ const fetchResp = await quillFetch({
461
+ client,
462
+ task: 'item',
457
463
  metadata: {
458
464
  dashboardItemId: reportId,
459
- task: 'item',
460
465
  filters: minimalFilters,
461
466
  clientId: client?.publicKey,
462
467
  databaseType: client?.databaseType,
@@ -468,13 +473,10 @@ export const fetchResultsByReport = async ({ reportId, client, tenants, processi
468
473
  rowCountOnly,
469
474
  tenants,
470
475
  },
471
- };
472
- const cloudBody = {
473
- id: reportId,
474
- filters: [],
475
- useNewNodeSql: true,
476
- };
477
- const resp = await getData(client, 'itempost', 'omit', hostedBody, cloudBody, undefined, undefined, abortSignal);
476
+ abortSignal,
477
+ getToken,
478
+ });
479
+ const resp = await parseFetchResponse(client, 'item', fetchResp, getToken);
478
480
  if (resp.errorMessage) {
479
481
  throw new Error(resp.errorMessage);
480
482
  }
@@ -503,7 +505,7 @@ export const fetchResultsByReport = async ({ reportId, client, tenants, processi
503
505
  }
504
506
  return { rows, columns, rowCount, error };
505
507
  };
506
- export const fetchTableByAST = async (ast, client, tenants, processing, customFields, rowsOnly, rowCountOnly, dashboardName) => {
508
+ export const fetchTableByAST = async (ast, client, getToken, tenants, processing, customFields, rowsOnly, rowCountOnly, dashboardName) => {
507
509
  let rows = [];
508
510
  let columns = [];
509
511
  let rowCount;
@@ -511,12 +513,12 @@ export const fetchTableByAST = async (ast, client, tenants, processing, customFi
511
513
  let itemQuery;
512
514
  let referencedTables;
513
515
  try {
514
- const hostedBody = {
516
+ const fetchResp = await quillFetch({
517
+ client,
518
+ task: 'patterns',
515
519
  metadata: {
516
520
  clientId: client.publicKey,
517
521
  ast,
518
- publicKey: client.publicKey,
519
- task: 'patterns',
520
522
  customFields,
521
523
  additionalProcessing: processing,
522
524
  useUpdatedDataGathering: true,
@@ -526,9 +528,9 @@ export const fetchTableByAST = async (ast, client, tenants, processing, customFi
526
528
  dashboardName: dashboardName && tenants ? dashboardName : undefined,
527
529
  tenants: dashboardName && tenants ? tenants : undefined,
528
530
  },
529
- };
530
- const cloudBody = {};
531
- const resp = await getData(client, 'dashquery', 'same-origin', hostedBody, cloudBody);
531
+ getToken,
532
+ });
533
+ const resp = await parseFetchResponse(client, 'patterns', fetchResp, getToken);
532
534
  if (resp.errorMessage || resp.name === 'error') {
533
535
  throw new Error(resp.errorMessage);
534
536
  }
@@ -1 +1 @@
1
- {"version":3,"file":"textProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/textProcessing.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAE/C;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAQhD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,EAAE,QAAQ,EAAE,MAAM,GAAG,SAAS,GAAG,MAAM,CAsE1F;AAED,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,MAAM,UAa/C;AAED,wBAAgB,4BAA4B,CAAC,GAAG,EAAE,MAAM,UAiBvD;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,UAK7C"}
1
+ {"version":3,"file":"textProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/textProcessing.ts"],"names":[],"mappings":"AAAA,wBAAgB,UAAU,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAE/C;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAQhD;AAED,wBAAgB,WAAW,CACzB,IAAI,EAAE,MAAM,GAAG,SAAS,EACxB,QAAQ,EAAE,MAAM,GAAG,SAAS,GAC3B,MAAM,CAwER;AAED,wBAAgB,oBAAoB,CAAC,GAAG,EAAE,MAAM,UAa/C;AAED,wBAAgB,4BAA4B,CAAC,GAAG,EAAE,MAAM,UAiBvD;AAED,wBAAgB,kBAAkB,CAAC,GAAG,EAAE,MAAM,UAK7C"}
@@ -40,7 +40,8 @@ export function matchCasing(text, template) {
40
40
  const toUpperCase = (str) => str.toUpperCase();
41
41
  // Function to convert to capitalized (first letter uppercase, rest lowercase)
42
42
  const toCapitalized = (str) => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase();
43
- const toScreamingSnakeCase = (str) => str.replace(/([A-Z])/g, '_$1') // Add underscore before capitals
43
+ const toScreamingSnakeCase = (str) => str
44
+ .replace(/([A-Z])/g, '_$1') // Add underscore before capitals
44
45
  .replace(/^_/, '') // Remove leading underscore if present
45
46
  .toUpperCase(); // Convert everything to uppercase
46
47
  // Match casing of the template and apply to the text
@@ -1 +1 @@
1
- {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../src/utils/ui.ts"],"names":[],"mappings":"AACC,eAAO,MAAM,mBAAmB,YAAa,WAAW,GAAG,IAAI,+CAU/D,CAAC"}
1
+ {"version":3,"file":"ui.d.ts","sourceRoot":"","sources":["../../../src/utils/ui.ts"],"names":[],"mappings":"AACA,eAAO,MAAM,mBAAmB,YAAa,WAAW,GAAG,IAAI,+CAY9D,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@quillsql/react",
3
- "version": "2.13.47",
3
+ "version": "2.13.49",
4
4
  "exports": {
5
5
  ".": {
6
6
  "import": "./dist/esm/index.js",
@@ -46,6 +46,7 @@
46
46
  "@babel/preset-env": "^7.25.8",
47
47
  "@babel/preset-react": "^7.25.7",
48
48
  "@babel/preset-typescript": "^7.25.7",
49
+ "@playwright/test": "^1.51.1",
49
50
  "@repo/eslint-config": "*",
50
51
  "@repo/typescript-config": "*",
51
52
  "@types/big.js": "^6.2.2",