@quillsql/react 2.12.29 → 2.12.31

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 (530) hide show
  1. package/dist/cjs/Chart.d.ts +29 -46
  2. package/dist/cjs/Chart.d.ts.map +1 -1
  3. package/dist/cjs/Chart.js +187 -468
  4. package/dist/cjs/ChartBuilder.d.ts +30 -61
  5. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  6. package/dist/cjs/ChartBuilder.js +190 -131
  7. package/dist/cjs/ChartEditor.d.ts +14 -2
  8. package/dist/cjs/ChartEditor.d.ts.map +1 -1
  9. package/dist/cjs/ChartEditor.js +70 -125
  10. package/dist/cjs/Context.d.ts +4 -1
  11. package/dist/cjs/Context.d.ts.map +1 -1
  12. package/dist/cjs/Context.js +52 -6
  13. package/dist/cjs/Dashboard.d.ts +74 -118
  14. package/dist/cjs/Dashboard.d.ts.map +1 -1
  15. package/dist/cjs/Dashboard.js +273 -47
  16. package/dist/cjs/DateRangePicker/Calendar.d.ts.map +1 -1
  17. package/dist/cjs/DateRangePicker/Calendar.js +3 -6
  18. package/dist/cjs/DateRangePicker/DateRangePicker.d.ts.map +1 -1
  19. package/dist/cjs/DateRangePicker/DateRangePicker.js +2 -29
  20. package/dist/cjs/DateRangePicker/DateRangePickerButton.d.ts +1 -2
  21. package/dist/cjs/DateRangePicker/DateRangePickerButton.d.ts.map +1 -1
  22. package/dist/cjs/DateRangePicker/DateRangePickerButton.js +2 -4
  23. package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts +2 -1
  24. package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  25. package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +4 -4
  26. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +1 -1
  27. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  28. package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +1 -15
  29. package/dist/cjs/ReportBuilder.d.ts +18 -6
  30. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  31. package/dist/cjs/ReportBuilder.js +477 -489
  32. package/dist/cjs/SQLEditor.d.ts +4 -11
  33. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  34. package/dist/cjs/SQLEditor.js +76 -88
  35. package/dist/cjs/Table.d.ts +19 -3
  36. package/dist/cjs/Table.d.ts.map +1 -1
  37. package/dist/cjs/Table.js +130 -114
  38. package/dist/cjs/TableChart.d.ts.map +1 -1
  39. package/dist/cjs/TableChart.js +0 -1
  40. package/dist/cjs/assets/ArrowDownHeadIcon.d.ts.map +1 -1
  41. package/dist/cjs/assets/ArrowDownIcon.d.ts.map +1 -1
  42. package/dist/cjs/assets/ArrowDownRightIcon.d.ts.map +1 -1
  43. package/dist/cjs/assets/ArrowLeftHeadIcon.d.ts.map +1 -1
  44. package/dist/cjs/assets/ArrowRightHeadIcon.d.ts.map +1 -1
  45. package/dist/cjs/assets/ArrowRightIcon.d.ts.map +1 -1
  46. package/dist/cjs/assets/ArrowUpHeadIcon.d.ts.map +1 -1
  47. package/dist/cjs/assets/ArrowUpIcon.d.ts.map +1 -1
  48. package/dist/cjs/assets/ArrowUpRightIcon.d.ts.map +1 -1
  49. package/dist/cjs/assets/CalendarIcon.d.ts.map +1 -1
  50. package/dist/cjs/assets/DoubleArrowLeftHeadIcon.d.ts.map +1 -1
  51. package/dist/cjs/assets/DoubleArrowRightHeadIcon.d.ts.map +1 -1
  52. package/dist/cjs/assets/ExclamationFilledIcon.d.ts.map +1 -1
  53. package/dist/cjs/assets/LoadingSpinner.d.ts.map +1 -1
  54. package/dist/cjs/assets/SearchIcon.d.ts.map +1 -1
  55. package/dist/cjs/assets/XCircleIcon.d.ts.map +1 -1
  56. package/dist/cjs/components/Banner/index.d.ts +1 -1
  57. package/dist/cjs/components/Banner/index.d.ts.map +1 -1
  58. package/dist/cjs/components/Banner/index.js +1 -1
  59. package/dist/cjs/components/BigModal/BigModal.d.ts.map +1 -1
  60. package/dist/cjs/components/BigModal/BigModal.js +6 -12
  61. package/dist/cjs/components/Chart/BarChart.d.ts.map +1 -1
  62. package/dist/cjs/components/Chart/BarChart.js +12 -1
  63. package/dist/cjs/components/Chart/BarList.d.ts.map +1 -1
  64. package/dist/cjs/components/Chart/BarList.js +21 -14
  65. package/dist/cjs/components/Chart/ChartError.d.ts +8 -1
  66. package/dist/cjs/components/Chart/ChartError.d.ts.map +1 -1
  67. package/dist/cjs/components/Chart/ChartError.js +40 -5
  68. package/dist/cjs/components/Chart/ChartTooltip.d.ts.map +1 -1
  69. package/dist/cjs/components/Chart/ChartTooltip.js +8 -2
  70. package/dist/cjs/components/Chart/LineChart.d.ts +2 -1
  71. package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
  72. package/dist/cjs/components/Chart/LineChart.js +27 -3
  73. package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
  74. package/dist/cjs/components/Chart/PieChart.js +1 -3
  75. package/dist/cjs/components/Dashboard/ChartComponent.d.ts +1 -1
  76. package/dist/cjs/components/Dashboard/ChartComponent.d.ts.map +1 -1
  77. package/dist/cjs/components/Dashboard/ChartComponent.js +1 -1
  78. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +5 -1
  79. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  80. package/dist/cjs/components/Dashboard/DashboardFilter.js +10 -5
  81. package/dist/cjs/components/Dashboard/DataLoader.d.ts +8 -12
  82. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  83. package/dist/cjs/components/Dashboard/DataLoader.js +137 -194
  84. package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
  85. package/dist/cjs/components/Dashboard/MetricComponent.js +11 -45
  86. package/dist/cjs/components/Dashboard/TableComponent.d.ts +2 -5
  87. package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
  88. package/dist/cjs/components/Dashboard/TableComponent.js +3 -32
  89. package/dist/cjs/components/Dropdown/Dropdown.d.ts.map +1 -1
  90. package/dist/cjs/components/Dropdown/Dropdown.js +1 -3
  91. package/dist/cjs/components/Dropdown/DropdownItem.d.ts.map +1 -1
  92. package/dist/cjs/components/Dropdown/DropdownItem.js +3 -8
  93. package/dist/cjs/components/Dropdown/index.d.ts +2 -2
  94. package/dist/cjs/components/Modal/Modal.d.ts.map +1 -1
  95. package/dist/cjs/components/Modal/Modal.js +2 -3
  96. package/dist/cjs/components/Modal/index.d.ts +1 -1
  97. package/dist/cjs/components/QuillMultiSelect.d.ts.map +1 -1
  98. package/dist/cjs/components/QuillMultiSelect.js +18 -3
  99. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  100. package/dist/cjs/components/QuillMultiSelectWithCombo.js +18 -3
  101. package/dist/cjs/components/QuillSelect.js +1 -1
  102. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  103. package/dist/cjs/components/QuillSelectWithCombo.js +6 -3
  104. package/dist/cjs/components/QuillTable.d.ts +1 -4
  105. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  106. package/dist/cjs/components/QuillTable.js +5 -11
  107. package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts +3 -1
  108. package/dist/cjs/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
  109. package/dist/cjs/components/ReportBuilder/AddColumnModal.js +5 -8
  110. package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  111. package/dist/cjs/components/ReportBuilder/AddLimitPopover.js +1 -3
  112. package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  113. package/dist/cjs/components/ReportBuilder/AddSortPopover.js +12 -1
  114. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts +30 -0
  115. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts.map +1 -0
  116. package/dist/cjs/components/ReportBuilder/FilterModal.js +579 -0
  117. package/dist/cjs/components/ReportBuilder/ast.d.ts +2 -1
  118. package/dist/cjs/components/ReportBuilder/ast.d.ts.map +1 -1
  119. package/dist/cjs/components/ReportBuilder/ast.js +33 -6
  120. package/dist/cjs/components/ReportBuilder/constants.d.ts +18 -3
  121. package/dist/cjs/components/ReportBuilder/constants.d.ts.map +1 -1
  122. package/dist/cjs/components/ReportBuilder/constants.js +24 -3
  123. package/dist/cjs/components/ReportBuilder/convert.d.ts +18 -16
  124. package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -1
  125. package/dist/cjs/components/ReportBuilder/convert.js +378 -494
  126. package/dist/cjs/components/ReportBuilder/operators.d.ts +24 -4
  127. package/dist/cjs/components/ReportBuilder/operators.d.ts.map +1 -1
  128. package/dist/cjs/components/ReportBuilder/operators.js +32 -4
  129. package/dist/cjs/components/ReportBuilder/ui.d.ts +20 -0
  130. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  131. package/dist/cjs/components/ReportBuilder/ui.js +15 -5
  132. package/dist/cjs/components/ReportBuilder/util.d.ts +3 -11
  133. package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -1
  134. package/dist/cjs/components/ReportBuilder/util.js +15 -18
  135. package/dist/cjs/components/UiComponents.d.ts +36 -8
  136. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  137. package/dist/cjs/components/UiComponents.js +106 -12
  138. package/dist/cjs/components/selectUtils.d.ts +0 -1
  139. package/dist/cjs/components/selectUtils.d.ts.map +1 -1
  140. package/dist/cjs/components/selectUtils.js +1 -22
  141. package/dist/cjs/hooks/index.d.ts +4 -4
  142. package/dist/cjs/hooks/useAstToFilterTree.d.ts +11 -0
  143. package/dist/cjs/hooks/useAstToFilterTree.d.ts.map +1 -0
  144. package/dist/cjs/hooks/useAstToFilterTree.js +26 -0
  145. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  146. package/dist/cjs/hooks/useDashboard.js +5 -1
  147. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  148. package/dist/cjs/hooks/useExport.js +3 -1
  149. package/dist/cjs/hooks/useOnClickOutside.js +4 -4
  150. package/dist/cjs/hooks/useOnWindowResize.d.ts.map +1 -1
  151. package/dist/cjs/hooks/useOnWindowResize.js +2 -2
  152. package/dist/cjs/hooks/useQuill.d.ts +10 -27
  153. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  154. package/dist/cjs/hooks/useQuill.js +133 -85
  155. package/dist/cjs/hooks/useSelectOnKeyDown.d.ts.map +1 -1
  156. package/dist/cjs/hooks/useSelectOnKeyDown.js +4 -4
  157. package/dist/cjs/hooks/useTheme.js +1 -1
  158. package/dist/cjs/index.d.ts +3 -1
  159. package/dist/cjs/index.d.ts.map +1 -1
  160. package/dist/cjs/index.js +3 -1
  161. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  162. package/dist/cjs/internals/ReportBuilder/PivotForm.js +8 -1
  163. package/dist/cjs/internals/ReportBuilder/PivotList.d.ts +2 -2
  164. package/dist/cjs/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  165. package/dist/cjs/internals/ReportBuilder/PivotList.js +2 -2
  166. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +2 -1
  167. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  168. package/dist/cjs/internals/ReportBuilder/PivotModal.js +8 -21
  169. package/dist/cjs/lib/utils.js +2 -2
  170. package/dist/cjs/models/Columns.d.ts +2 -1
  171. package/dist/cjs/models/Columns.d.ts.map +1 -1
  172. package/dist/cjs/models/Filter.d.ts +115 -4
  173. package/dist/cjs/models/Filter.d.ts.map +1 -1
  174. package/dist/cjs/models/Filter.js +99 -0
  175. package/dist/cjs/models/Pagination.d.ts +10 -0
  176. package/dist/cjs/models/Pagination.d.ts.map +1 -0
  177. package/dist/cjs/models/Pagination.js +2 -0
  178. package/dist/cjs/models/Report.d.ts +103 -0
  179. package/dist/cjs/models/Report.d.ts.map +1 -0
  180. package/dist/cjs/models/Report.js +2 -0
  181. package/dist/cjs/utils/aggregate.js +1 -1
  182. package/dist/cjs/utils/astFilterProcessing.d.ts +36 -0
  183. package/dist/cjs/utils/astFilterProcessing.d.ts.map +1 -0
  184. package/dist/cjs/utils/astFilterProcessing.js +8091 -0
  185. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  186. package/dist/cjs/utils/astProcessing.js +4 -3
  187. package/dist/cjs/utils/axisFormatter.js +0 -71
  188. package/dist/cjs/utils/color.js +9 -87
  189. package/dist/cjs/utils/columnProcessing.d.ts +2 -0
  190. package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
  191. package/dist/cjs/utils/columnProcessing.js +54 -1
  192. package/dist/cjs/utils/csv.d.ts.map +1 -1
  193. package/dist/cjs/utils/dashboard.d.ts +1 -1
  194. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  195. package/dist/cjs/utils/dashboard.js +6 -59
  196. package/dist/cjs/utils/dataFetcher.d.ts.map +1 -1
  197. package/dist/cjs/utils/dataFetcher.js +63 -1
  198. package/dist/cjs/utils/dataProcessing.d.ts +10 -0
  199. package/dist/cjs/utils/dataProcessing.d.ts.map +1 -0
  200. package/dist/cjs/utils/dataProcessing.js +144 -0
  201. package/dist/cjs/utils/dates.d.ts +2 -1
  202. package/dist/cjs/utils/dates.d.ts.map +1 -1
  203. package/dist/cjs/utils/dates.js +23 -1
  204. package/dist/cjs/utils/error.d.ts +5 -0
  205. package/dist/cjs/utils/error.d.ts.map +1 -0
  206. package/dist/cjs/utils/error.js +12 -0
  207. package/dist/cjs/utils/filterConstants.d.ts +34 -0
  208. package/dist/cjs/utils/filterConstants.d.ts.map +1 -0
  209. package/dist/cjs/utils/filterConstants.js +36 -0
  210. package/dist/cjs/utils/filterProcessing.d.ts +7 -1
  211. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  212. package/dist/cjs/utils/filterProcessing.js +104 -17
  213. package/dist/cjs/utils/logging.d.ts.map +1 -1
  214. package/dist/cjs/utils/logging.js +1 -0
  215. package/dist/cjs/utils/merge.js +0 -21
  216. package/dist/cjs/utils/{monacoAutocomplete.d.ts → monacoConfig.d.ts} +3 -2
  217. package/dist/cjs/utils/monacoConfig.d.ts.map +1 -0
  218. package/dist/cjs/utils/monacoConfig.js +324 -0
  219. package/dist/cjs/utils/paginationProcessing.d.ts +5 -0
  220. package/dist/cjs/utils/paginationProcessing.d.ts.map +1 -0
  221. package/dist/cjs/utils/paginationProcessing.js +30 -0
  222. package/dist/cjs/utils/pivotConstructor.d.ts +2 -1
  223. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  224. package/dist/cjs/utils/pivotConstructor.js +16 -1
  225. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  226. package/dist/cjs/utils/pivotProcessing.js +12 -6
  227. package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
  228. package/dist/cjs/utils/queryConstructor.js +4 -3
  229. package/dist/cjs/utils/report.d.ts +10 -0
  230. package/dist/cjs/utils/report.d.ts.map +1 -0
  231. package/dist/cjs/utils/report.js +180 -0
  232. package/dist/cjs/utils/schema.d.ts.map +1 -1
  233. package/dist/cjs/utils/schema.js +35 -6
  234. package/dist/cjs/utils/styles.d.ts +1 -1
  235. package/dist/cjs/utils/styles.d.ts.map +1 -1
  236. package/dist/cjs/utils/tableProcessing.d.ts +22 -8
  237. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  238. package/dist/cjs/utils/tableProcessing.js +116 -35
  239. package/dist/cjs/utils/textProcessing.js +3 -3
  240. package/dist/cjs/utils/validation.d.ts +9 -0
  241. package/dist/cjs/utils/validation.d.ts.map +1 -0
  242. package/dist/cjs/utils/validation.js +24 -0
  243. package/dist/cjs/utils/valueFormatter.d.ts.map +1 -1
  244. package/dist/cjs/utils/valueFormatter.js +8 -4
  245. package/dist/esm/Chart.d.ts +29 -46
  246. package/dist/esm/Chart.d.ts.map +1 -1
  247. package/dist/esm/Chart.js +189 -471
  248. package/dist/esm/ChartBuilder.d.ts +30 -61
  249. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  250. package/dist/esm/ChartBuilder.js +191 -129
  251. package/dist/esm/ChartEditor.d.ts +14 -2
  252. package/dist/esm/ChartEditor.d.ts.map +1 -1
  253. package/dist/esm/ChartEditor.js +71 -126
  254. package/dist/esm/Context.d.ts +4 -1
  255. package/dist/esm/Context.d.ts.map +1 -1
  256. package/dist/esm/Context.js +51 -5
  257. package/dist/esm/Dashboard.d.ts +74 -118
  258. package/dist/esm/Dashboard.d.ts.map +1 -1
  259. package/dist/esm/Dashboard.js +275 -49
  260. package/dist/esm/DateRangePicker/Calendar.d.ts.map +1 -1
  261. package/dist/esm/DateRangePicker/Calendar.js +5 -8
  262. package/dist/esm/DateRangePicker/DateRangePicker.d.ts.map +1 -1
  263. package/dist/esm/DateRangePicker/DateRangePicker.js +2 -29
  264. package/dist/esm/DateRangePicker/DateRangePickerButton.d.ts +1 -2
  265. package/dist/esm/DateRangePicker/DateRangePickerButton.d.ts.map +1 -1
  266. package/dist/esm/DateRangePicker/DateRangePickerButton.js +2 -4
  267. package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts +2 -1
  268. package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  269. package/dist/esm/DateRangePicker/QuillDateRangePicker.js +4 -4
  270. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +1 -1
  271. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  272. package/dist/esm/DateRangePicker/dateRangePickerUtils.js +1 -15
  273. package/dist/esm/ReportBuilder.d.ts +18 -6
  274. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  275. package/dist/esm/ReportBuilder.js +484 -496
  276. package/dist/esm/SQLEditor.d.ts +4 -11
  277. package/dist/esm/SQLEditor.d.ts.map +1 -1
  278. package/dist/esm/SQLEditor.js +75 -87
  279. package/dist/esm/Table.d.ts +19 -3
  280. package/dist/esm/Table.d.ts.map +1 -1
  281. package/dist/esm/Table.js +132 -116
  282. package/dist/esm/TableChart.d.ts.map +1 -1
  283. package/dist/esm/TableChart.js +0 -1
  284. package/dist/esm/assets/ArrowDownHeadIcon.d.ts.map +1 -1
  285. package/dist/esm/assets/ArrowDownIcon.d.ts.map +1 -1
  286. package/dist/esm/assets/ArrowDownRightIcon.d.ts.map +1 -1
  287. package/dist/esm/assets/ArrowLeftHeadIcon.d.ts.map +1 -1
  288. package/dist/esm/assets/ArrowRightHeadIcon.d.ts.map +1 -1
  289. package/dist/esm/assets/ArrowRightIcon.d.ts.map +1 -1
  290. package/dist/esm/assets/ArrowUpHeadIcon.d.ts.map +1 -1
  291. package/dist/esm/assets/ArrowUpIcon.d.ts.map +1 -1
  292. package/dist/esm/assets/ArrowUpRightIcon.d.ts.map +1 -1
  293. package/dist/esm/assets/CalendarIcon.d.ts.map +1 -1
  294. package/dist/esm/assets/DoubleArrowLeftHeadIcon.d.ts.map +1 -1
  295. package/dist/esm/assets/DoubleArrowRightHeadIcon.d.ts.map +1 -1
  296. package/dist/esm/assets/ExclamationFilledIcon.d.ts.map +1 -1
  297. package/dist/esm/assets/LoadingSpinner.d.ts.map +1 -1
  298. package/dist/esm/assets/SearchIcon.d.ts.map +1 -1
  299. package/dist/esm/assets/XCircleIcon.d.ts.map +1 -1
  300. package/dist/esm/components/Banner/index.d.ts +1 -1
  301. package/dist/esm/components/Banner/index.d.ts.map +1 -1
  302. package/dist/esm/components/Banner/index.js +1 -1
  303. package/dist/esm/components/BigModal/BigModal.d.ts.map +1 -1
  304. package/dist/esm/components/BigModal/BigModal.js +7 -13
  305. package/dist/esm/components/Chart/BarChart.d.ts.map +1 -1
  306. package/dist/esm/components/Chart/BarChart.js +13 -2
  307. package/dist/esm/components/Chart/BarList.d.ts.map +1 -1
  308. package/dist/esm/components/Chart/BarList.js +21 -14
  309. package/dist/esm/components/Chart/ChartError.d.ts +8 -1
  310. package/dist/esm/components/Chart/ChartError.d.ts.map +1 -1
  311. package/dist/esm/components/Chart/ChartError.js +39 -6
  312. package/dist/esm/components/Chart/ChartTooltip.d.ts.map +1 -1
  313. package/dist/esm/components/Chart/ChartTooltip.js +8 -2
  314. package/dist/esm/components/Chart/LineChart.d.ts +2 -1
  315. package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
  316. package/dist/esm/components/Chart/LineChart.js +28 -4
  317. package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
  318. package/dist/esm/components/Chart/PieChart.js +1 -3
  319. package/dist/esm/components/Dashboard/ChartComponent.d.ts +1 -1
  320. package/dist/esm/components/Dashboard/ChartComponent.d.ts.map +1 -1
  321. package/dist/esm/components/Dashboard/ChartComponent.js +1 -1
  322. package/dist/esm/components/Dashboard/DashboardFilter.d.ts +5 -1
  323. package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  324. package/dist/esm/components/Dashboard/DashboardFilter.js +10 -5
  325. package/dist/esm/components/Dashboard/DataLoader.d.ts +8 -12
  326. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  327. package/dist/esm/components/Dashboard/DataLoader.js +137 -194
  328. package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
  329. package/dist/esm/components/Dashboard/MetricComponent.js +11 -45
  330. package/dist/esm/components/Dashboard/TableComponent.d.ts +2 -5
  331. package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
  332. package/dist/esm/components/Dashboard/TableComponent.js +3 -32
  333. package/dist/esm/components/Dropdown/Dropdown.d.ts.map +1 -1
  334. package/dist/esm/components/Dropdown/Dropdown.js +2 -4
  335. package/dist/esm/components/Dropdown/DropdownItem.d.ts.map +1 -1
  336. package/dist/esm/components/Dropdown/DropdownItem.js +4 -9
  337. package/dist/esm/components/Dropdown/index.d.ts +2 -2
  338. package/dist/esm/components/Dropdown/index.js +2 -2
  339. package/dist/esm/components/Modal/Modal.d.ts.map +1 -1
  340. package/dist/esm/components/Modal/Modal.js +2 -3
  341. package/dist/esm/components/Modal/index.d.ts +1 -1
  342. package/dist/esm/components/Modal/index.js +1 -1
  343. package/dist/esm/components/QuillMultiSelect.d.ts.map +1 -1
  344. package/dist/esm/components/QuillMultiSelect.js +18 -3
  345. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  346. package/dist/esm/components/QuillMultiSelectWithCombo.js +18 -3
  347. package/dist/esm/components/QuillSelect.js +1 -1
  348. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  349. package/dist/esm/components/QuillSelectWithCombo.js +7 -4
  350. package/dist/esm/components/QuillTable.d.ts +1 -4
  351. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  352. package/dist/esm/components/QuillTable.js +5 -11
  353. package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts +3 -1
  354. package/dist/esm/components/ReportBuilder/AddColumnModal.d.ts.map +1 -1
  355. package/dist/esm/components/ReportBuilder/AddColumnModal.js +8 -11
  356. package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  357. package/dist/esm/components/ReportBuilder/AddLimitPopover.js +2 -4
  358. package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  359. package/dist/esm/components/ReportBuilder/AddSortPopover.js +12 -1
  360. package/dist/esm/components/ReportBuilder/FilterModal.d.ts +30 -0
  361. package/dist/esm/components/ReportBuilder/FilterModal.d.ts.map +1 -0
  362. package/dist/esm/components/ReportBuilder/FilterModal.js +576 -0
  363. package/dist/esm/components/ReportBuilder/ast.d.ts +2 -1
  364. package/dist/esm/components/ReportBuilder/ast.d.ts.map +1 -1
  365. package/dist/esm/components/ReportBuilder/ast.js +31 -5
  366. package/dist/esm/components/ReportBuilder/constants.d.ts +18 -3
  367. package/dist/esm/components/ReportBuilder/constants.d.ts.map +1 -1
  368. package/dist/esm/components/ReportBuilder/constants.js +24 -3
  369. package/dist/esm/components/ReportBuilder/convert.d.ts +18 -16
  370. package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -1
  371. package/dist/esm/components/ReportBuilder/convert.js +375 -493
  372. package/dist/esm/components/ReportBuilder/convert.uspec.d.ts +2 -0
  373. package/dist/esm/components/ReportBuilder/convert.uspec.d.ts.map +1 -0
  374. package/dist/esm/components/ReportBuilder/convert.uspec.js +1419 -0
  375. package/dist/esm/components/ReportBuilder/operators.d.ts +24 -4
  376. package/dist/esm/components/ReportBuilder/operators.d.ts.map +1 -1
  377. package/dist/esm/components/ReportBuilder/operators.js +32 -4
  378. package/dist/esm/components/ReportBuilder/ui.d.ts +20 -0
  379. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  380. package/dist/esm/components/ReportBuilder/ui.js +13 -4
  381. package/dist/esm/components/ReportBuilder/util.d.ts +3 -11
  382. package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -1
  383. package/dist/esm/components/ReportBuilder/util.js +16 -19
  384. package/dist/esm/components/UiComponents.d.ts +36 -8
  385. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  386. package/dist/esm/components/UiComponents.js +104 -11
  387. package/dist/esm/components/selectUtils.d.ts +0 -1
  388. package/dist/esm/components/selectUtils.d.ts.map +1 -1
  389. package/dist/esm/components/selectUtils.js +0 -20
  390. package/dist/esm/hooks/index.d.ts +4 -4
  391. package/dist/esm/hooks/index.js +4 -4
  392. package/dist/esm/hooks/useAstToFilterTree.d.ts +11 -0
  393. package/dist/esm/hooks/useAstToFilterTree.d.ts.map +1 -0
  394. package/dist/esm/hooks/useAstToFilterTree.js +24 -0
  395. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  396. package/dist/esm/hooks/useDashboard.js +5 -1
  397. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  398. package/dist/esm/hooks/useExport.js +4 -2
  399. package/dist/esm/hooks/useOnClickOutside.js +5 -5
  400. package/dist/esm/hooks/useOnWindowResize.d.ts.map +1 -1
  401. package/dist/esm/hooks/useOnWindowResize.js +3 -3
  402. package/dist/esm/hooks/useQuill.d.ts +10 -27
  403. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  404. package/dist/esm/hooks/useQuill.js +133 -85
  405. package/dist/esm/hooks/useSelectOnKeyDown.d.ts.map +1 -1
  406. package/dist/esm/hooks/useSelectOnKeyDown.js +5 -5
  407. package/dist/esm/hooks/useTheme.js +1 -1
  408. package/dist/esm/index.d.ts +3 -1
  409. package/dist/esm/index.d.ts.map +1 -1
  410. package/dist/esm/index.js +1 -0
  411. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  412. package/dist/esm/internals/ReportBuilder/PivotForm.js +9 -2
  413. package/dist/esm/internals/ReportBuilder/PivotList.d.ts +2 -2
  414. package/dist/esm/internals/ReportBuilder/PivotList.d.ts.map +1 -1
  415. package/dist/esm/internals/ReportBuilder/PivotList.js +3 -3
  416. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +2 -1
  417. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  418. package/dist/esm/internals/ReportBuilder/PivotModal.js +11 -24
  419. package/dist/esm/lib/utils.js +2 -2
  420. package/dist/esm/models/Columns.d.ts +2 -1
  421. package/dist/esm/models/Columns.d.ts.map +1 -1
  422. package/dist/esm/models/Filter.d.ts +115 -4
  423. package/dist/esm/models/Filter.d.ts.map +1 -1
  424. package/dist/esm/models/Filter.js +98 -1
  425. package/dist/esm/models/Pagination.d.ts +10 -0
  426. package/dist/esm/models/Pagination.d.ts.map +1 -0
  427. package/dist/esm/models/Pagination.js +1 -0
  428. package/dist/esm/models/Report.d.ts +103 -0
  429. package/dist/esm/models/Report.d.ts.map +1 -0
  430. package/dist/esm/models/Report.js +1 -0
  431. package/dist/esm/test-utils/constants.d.ts +56 -0
  432. package/dist/esm/test-utils/constants.d.ts.map +1 -0
  433. package/dist/esm/test-utils/constants.js +271 -0
  434. package/dist/esm/test-utils/generators.d.ts +4 -0
  435. package/dist/esm/test-utils/generators.d.ts.map +1 -0
  436. package/dist/esm/test-utils/generators.js +37 -0
  437. package/dist/esm/utils/aggregate.js +1 -1
  438. package/dist/esm/utils/astFilterProcessing.d.ts +36 -0
  439. package/dist/esm/utils/astFilterProcessing.d.ts.map +1 -0
  440. package/dist/esm/utils/astFilterProcessing.js +8084 -0
  441. package/dist/esm/utils/astFilterProcessing.uspec.d.ts +2 -0
  442. package/dist/esm/utils/astFilterProcessing.uspec.d.ts.map +1 -0
  443. package/dist/esm/utils/astFilterProcessing.uspec.js +2877 -0
  444. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  445. package/dist/esm/utils/astProcessing.js +4 -3
  446. package/dist/esm/utils/axisFormatter.js +0 -71
  447. package/dist/esm/utils/color.js +9 -87
  448. package/dist/esm/utils/columnProcessing.d.ts +2 -0
  449. package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
  450. package/dist/esm/utils/columnProcessing.js +52 -0
  451. package/dist/esm/utils/columnProcessing.uspec.d.ts +2 -0
  452. package/dist/esm/utils/columnProcessing.uspec.d.ts.map +1 -0
  453. package/dist/esm/utils/columnProcessing.uspec.js +65 -0
  454. package/dist/esm/utils/csv.d.ts.map +1 -1
  455. package/dist/esm/utils/dashboard.d.ts +1 -1
  456. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  457. package/dist/esm/utils/dashboard.js +6 -59
  458. package/dist/esm/utils/dataFetcher.d.ts.map +1 -1
  459. package/dist/esm/utils/dataFetcher.js +63 -1
  460. package/dist/esm/utils/dataProcessing.d.ts +10 -0
  461. package/dist/esm/utils/dataProcessing.d.ts.map +1 -0
  462. package/dist/esm/utils/dataProcessing.js +138 -0
  463. package/dist/esm/utils/dataProcessing.uspec.d.ts +2 -0
  464. package/dist/esm/utils/dataProcessing.uspec.d.ts.map +1 -0
  465. package/dist/esm/utils/dataProcessing.uspec.js +205 -0
  466. package/dist/esm/utils/dates.d.ts +2 -1
  467. package/dist/esm/utils/dates.d.ts.map +1 -1
  468. package/dist/esm/utils/dates.js +21 -0
  469. package/dist/esm/utils/error.d.ts +5 -0
  470. package/dist/esm/utils/error.d.ts.map +1 -0
  471. package/dist/esm/utils/error.js +8 -0
  472. package/dist/esm/utils/filterConstants.d.ts +34 -0
  473. package/dist/esm/utils/filterConstants.d.ts.map +1 -0
  474. package/dist/esm/utils/filterConstants.js +33 -0
  475. package/dist/esm/utils/filterProcessing.d.ts +7 -1
  476. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  477. package/dist/esm/utils/filterProcessing.js +101 -16
  478. package/dist/esm/utils/filterProcessing.uspec.d.ts +2 -0
  479. package/dist/esm/utils/filterProcessing.uspec.d.ts.map +1 -0
  480. package/dist/esm/utils/filterProcessing.uspec.js +245 -0
  481. package/dist/esm/utils/logging.d.ts.map +1 -1
  482. package/dist/esm/utils/logging.js +1 -0
  483. package/dist/esm/utils/merge.js +0 -21
  484. package/dist/esm/utils/{monacoAutocomplete.d.ts → monacoConfig.d.ts} +3 -2
  485. package/dist/esm/utils/monacoConfig.d.ts.map +1 -0
  486. package/dist/esm/utils/monacoConfig.js +319 -0
  487. package/dist/esm/utils/paginationProcessing.d.ts +5 -0
  488. package/dist/esm/utils/paginationProcessing.d.ts.map +1 -0
  489. package/dist/esm/utils/paginationProcessing.js +25 -0
  490. package/dist/esm/utils/pivotConstructor.d.ts +2 -1
  491. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  492. package/dist/esm/utils/pivotConstructor.js +16 -1
  493. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  494. package/dist/esm/utils/pivotProcessing.js +12 -6
  495. package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
  496. package/dist/esm/utils/queryConstructor.js +4 -3
  497. package/dist/esm/utils/queryConstructor.uspec.js +21 -21
  498. package/dist/esm/utils/report.d.ts +10 -0
  499. package/dist/esm/utils/report.d.ts.map +1 -0
  500. package/dist/esm/utils/report.ispec.d.ts +2 -0
  501. package/dist/esm/utils/report.ispec.d.ts.map +1 -0
  502. package/dist/esm/utils/report.ispec.js +46 -0
  503. package/dist/esm/utils/report.js +174 -0
  504. package/dist/esm/utils/report.uspec.d.ts +2 -0
  505. package/dist/esm/utils/report.uspec.d.ts.map +1 -0
  506. package/dist/esm/utils/report.uspec.js +66 -0
  507. package/dist/esm/utils/schema.d.ts.map +1 -1
  508. package/dist/esm/utils/schema.js +35 -6
  509. package/dist/esm/utils/styles.d.ts +1 -1
  510. package/dist/esm/utils/styles.d.ts.map +1 -1
  511. package/dist/esm/utils/tableProcessing.d.ts +22 -8
  512. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  513. package/dist/esm/utils/tableProcessing.ispec.d.ts +2 -0
  514. package/dist/esm/utils/tableProcessing.ispec.d.ts.map +1 -0
  515. package/dist/esm/utils/tableProcessing.ispec.js +61 -0
  516. package/dist/esm/utils/tableProcessing.js +112 -33
  517. package/dist/esm/utils/textProcessing.js +3 -3
  518. package/dist/esm/utils/validation.d.ts +9 -0
  519. package/dist/esm/utils/validation.d.ts.map +1 -0
  520. package/dist/esm/utils/validation.js +20 -0
  521. package/dist/esm/utils/valueFormatter.d.ts.map +1 -1
  522. package/dist/esm/utils/valueFormatter.js +8 -4
  523. package/package.json +1 -1
  524. package/dist/cjs/utils/monacoAutocomplete.d.ts.map +0 -1
  525. package/dist/cjs/utils/monacoAutocomplete.js +0 -145
  526. package/dist/cjs/utils/queryConstructor.uspec.d.ts +0 -2
  527. package/dist/cjs/utils/queryConstructor.uspec.d.ts.map +0 -1
  528. package/dist/cjs/utils/queryConstructor.uspec.js +0 -225
  529. package/dist/esm/utils/monacoAutocomplete.d.ts.map +0 -1
  530. package/dist/esm/utils/monacoAutocomplete.js +0 -140
@@ -0,0 +1,245 @@
1
+ import { BoolOperator, DateOperator, FieldTypes, FilterNames, NullOperator, NumberOperator, StringOperator, } from '../models/Filter';
2
+ import { filterSentence } from './filterProcessing';
3
+ describe('filterSentence', () => {
4
+ it('should handle null filters', () => {
5
+ const isNullFilter = {
6
+ name: FilterNames.NullFilter,
7
+ operator: NullOperator.IsNull,
8
+ field: 'field',
9
+ type: FieldTypes.Null,
10
+ value: null,
11
+ };
12
+ const isNotNullFilter = {
13
+ name: FilterNames.NullFilter,
14
+ operator: NullOperator.IsNotNull,
15
+ field: 'field',
16
+ type: FieldTypes.Null,
17
+ value: null,
18
+ };
19
+ expect(filterSentence(isNullFilter)).toEqual('Field is null');
20
+ expect(filterSentence(isNotNullFilter)).toEqual('Field is not null');
21
+ });
22
+ it('should handle string filters', () => {
23
+ const stringExactlyFilter = {
24
+ name: FilterNames.StringFilter,
25
+ operator: StringOperator.IsExactly,
26
+ field: 'field',
27
+ type: FieldTypes.String,
28
+ value: 'this',
29
+ };
30
+ const stringNotExactlyFilter = {
31
+ name: FilterNames.StringFilter,
32
+ operator: StringOperator.IsNotExactly,
33
+ field: 'field',
34
+ type: FieldTypes.String,
35
+ value: 'this',
36
+ };
37
+ const stringContainsFilter = {
38
+ name: FilterNames.StringFilter,
39
+ operator: StringOperator.Contains,
40
+ field: 'field',
41
+ type: FieldTypes.String,
42
+ value: 'this',
43
+ };
44
+ expect(filterSentence(stringExactlyFilter)).toEqual('Field is exactly this');
45
+ expect(filterSentence(stringNotExactlyFilter)).toEqual('Field is not exactly this');
46
+ expect(filterSentence(stringContainsFilter)).toEqual('Field contains this');
47
+ });
48
+ it('should handle number filters', () => {
49
+ const numberEqualToFilter = {
50
+ name: FilterNames.NumericFilter,
51
+ operator: NumberOperator.EqualTo,
52
+ field: 'field',
53
+ type: FieldTypes.Numeric,
54
+ value: 0,
55
+ };
56
+ const numberNotEqualToFilter = {
57
+ name: FilterNames.NumericFilter,
58
+ operator: NumberOperator.NotEqualTo,
59
+ field: 'field',
60
+ type: FieldTypes.Numeric,
61
+ value: 0,
62
+ };
63
+ const numberGreaterThanFilter = {
64
+ name: FilterNames.NumericFilter,
65
+ operator: NumberOperator.GreaterThan,
66
+ field: 'field',
67
+ type: FieldTypes.Numeric,
68
+ value: 0,
69
+ };
70
+ const numberLessThanFilter = {
71
+ name: FilterNames.NumericFilter,
72
+ operator: NumberOperator.LessThan,
73
+ field: 'field',
74
+ type: FieldTypes.Numeric,
75
+ value: 0,
76
+ };
77
+ const numberGreaterThanOrEqualToFilter = {
78
+ name: FilterNames.NumericFilter,
79
+ operator: NumberOperator.GreaterThanOrEqualTo,
80
+ field: 'field',
81
+ type: FieldTypes.Numeric,
82
+ value: 0,
83
+ };
84
+ const numberLessThanOrEqualToFilter = {
85
+ name: FilterNames.NumericFilter,
86
+ operator: NumberOperator.LessThanOrEqualTo,
87
+ field: 'field',
88
+ type: FieldTypes.Numeric,
89
+ value: 0,
90
+ };
91
+ expect(filterSentence(numberEqualToFilter)).toEqual('Field equal to 0');
92
+ expect(filterSentence(numberNotEqualToFilter)).toEqual('Field not equal to 0');
93
+ expect(filterSentence(numberGreaterThanFilter)).toEqual('Field greater than 0');
94
+ expect(filterSentence(numberLessThanFilter)).toEqual('Field less than 0');
95
+ expect(filterSentence(numberGreaterThanOrEqualToFilter)).toEqual('Field greater than or equal to 0');
96
+ expect(filterSentence(numberLessThanOrEqualToFilter)).toEqual('Field less than or equal to 0');
97
+ });
98
+ it('should handle boolean filters', () => {
99
+ const booleanEqualToFilter = {
100
+ name: FilterNames.BooleanFilter,
101
+ operator: BoolOperator.EqualTo,
102
+ field: 'field',
103
+ type: FieldTypes.Boolean,
104
+ value: true,
105
+ };
106
+ const booleanNotEqualToFilter = {
107
+ name: FilterNames.BooleanFilter,
108
+ operator: BoolOperator.NotEqualTo,
109
+ field: 'field',
110
+ type: FieldTypes.Boolean,
111
+ value: true,
112
+ };
113
+ expect(filterSentence(booleanEqualToFilter)).toEqual('Field equal to true');
114
+ expect(filterSentence(booleanNotEqualToFilter)).toEqual('Field not equal to true');
115
+ });
116
+ it('should handle date filters', () => {
117
+ const dateInTheLastFilter = {
118
+ name: FilterNames.DateFilter,
119
+ operator: DateOperator.InTheLast,
120
+ field: 'field',
121
+ type: FieldTypes.Date,
122
+ value: { value: 10, unit: 'day' },
123
+ };
124
+ const dateInTheLastFilterSingular = {
125
+ name: FilterNames.DateFilter,
126
+ operator: DateOperator.InTheLast,
127
+ field: 'field',
128
+ type: FieldTypes.Date,
129
+ value: { value: 1, unit: 'day' },
130
+ };
131
+ const dateInTheCurrentFilter = {
132
+ name: FilterNames.DateFilter,
133
+ operator: DateOperator.InTheCurrent,
134
+ field: 'field',
135
+ type: FieldTypes.Date,
136
+ value: { value: 1, unit: 'day' },
137
+ };
138
+ const dateInThePreviousFilter = {
139
+ name: FilterNames.DateFilter,
140
+ operator: DateOperator.InThePrevious,
141
+ field: 'field',
142
+ type: FieldTypes.Date,
143
+ value: { value: 10, unit: 'day' },
144
+ };
145
+ const dateInThePreviousFilterSingular = {
146
+ name: FilterNames.DateFilter,
147
+ operator: DateOperator.InThePrevious,
148
+ field: 'field',
149
+ type: FieldTypes.Date,
150
+ value: { value: 1, unit: 'day' },
151
+ };
152
+ expect(filterSentence(dateInTheLastFilter)).toEqual('Field in the last 10 days');
153
+ expect(filterSentence(dateInTheLastFilterSingular)).toEqual('Field in the last 1 day');
154
+ expect(filterSentence(dateInTheCurrentFilter)).toEqual('Field in the current day');
155
+ expect(filterSentence(dateInThePreviousFilter)).toEqual('Field in the previous 10 days');
156
+ expect(filterSentence(dateInThePreviousFilterSingular)).toEqual('Field in the previous 1 day');
157
+ });
158
+ it('should handle date comparison filters', () => {
159
+ const dateEqualToFilter = {
160
+ name: FilterNames.DateComparisonFilter,
161
+ operator: DateOperator.EqualTo,
162
+ field: 'field',
163
+ type: FieldTypes.Date,
164
+ value: '2021-01-01',
165
+ };
166
+ const dateNotEqualToFilter = {
167
+ name: FilterNames.DateComparisonFilter,
168
+ operator: DateOperator.NotEqualTo,
169
+ field: 'field',
170
+ type: FieldTypes.Date,
171
+ value: '2021-01-01',
172
+ };
173
+ const dateGreaterThanFilter = {
174
+ name: FilterNames.DateComparisonFilter,
175
+ operator: DateOperator.GreaterThan,
176
+ field: 'field',
177
+ type: FieldTypes.Date,
178
+ value: '2021-01-01',
179
+ };
180
+ const dateLessThanFilter = {
181
+ name: FilterNames.DateComparisonFilter,
182
+ operator: DateOperator.LessThan,
183
+ field: 'field',
184
+ type: FieldTypes.Date,
185
+ value: '2021-01-01',
186
+ };
187
+ const dateGreaterThanOrEqualToFilter = {
188
+ name: FilterNames.DateComparisonFilter,
189
+ operator: DateOperator.GreaterThanOrEqualTo,
190
+ field: 'field',
191
+ type: FieldTypes.Date,
192
+ value: '2021-01-01',
193
+ };
194
+ const dateLessThanOrEqualToFilter = {
195
+ name: FilterNames.DateComparisonFilter,
196
+ operator: DateOperator.LessThanOrEqualTo,
197
+ field: 'field',
198
+ type: FieldTypes.Date,
199
+ value: '2021-01-01',
200
+ };
201
+ expect(filterSentence(dateEqualToFilter)).toEqual('Field equal to 2021-01-01');
202
+ expect(filterSentence(dateNotEqualToFilter)).toEqual('Field not equal to 2021-01-01');
203
+ expect(filterSentence(dateGreaterThanFilter)).toEqual('Field greater than 2021-01-01');
204
+ expect(filterSentence(dateLessThanFilter)).toEqual('Field less than 2021-01-01');
205
+ expect(filterSentence(dateGreaterThanOrEqualToFilter)).toEqual('Field greater than or equal to 2021-01-01');
206
+ expect(filterSentence(dateLessThanOrEqualToFilter)).toEqual('Field less than or equal to 2021-01-01');
207
+ });
208
+ it('should handle custom date filters', () => {
209
+ const dateCustomFilter = {
210
+ name: FilterNames.DateCustomFilter,
211
+ operator: DateOperator.Custom,
212
+ field: 'field',
213
+ type: FieldTypes.Date,
214
+ value: { startDate: '2021-01-01', endDate: '2021-12-31' },
215
+ };
216
+ expect(filterSentence(dateCustomFilter)).toEqual('Field custom from 2021-01-01');
217
+ });
218
+ it('should handle string in filters', () => {
219
+ const stringIsFilter = {
220
+ name: FilterNames.StringFilter,
221
+ operator: StringOperator.Is,
222
+ field: 'field',
223
+ type: FieldTypes.String,
224
+ value: ['this', 'that'],
225
+ };
226
+ const stringIsNotFilter = {
227
+ name: FilterNames.StringFilter,
228
+ operator: StringOperator.IsNot,
229
+ field: 'field',
230
+ type: FieldTypes.String,
231
+ value: ['this', 'that'],
232
+ };
233
+ expect(filterSentence(stringIsFilter)).toEqual('Field is one of this, that');
234
+ expect(filterSentence(stringIsNotFilter)).toEqual('Field is not one of this, that');
235
+ });
236
+ it('should throw an error for invalid filters', () => {
237
+ const invalidFilter = {
238
+ name: 'filter',
239
+ operator: '=',
240
+ field: 'field',
241
+ type: 'string',
242
+ };
243
+ expect(filterSentence(invalidFilter)).toEqual('Error: filter missing value');
244
+ });
245
+ });
@@ -1 +1 @@
1
- {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../src/utils/logging.ts"],"names":[],"mappings":"AAAA,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,cAAc,EAAE,GAAG,EAAE,QAKpE"}
1
+ {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../src/utils/logging.ts"],"names":[],"mappings":"AACA,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,cAAc,EAAE,GAAG,EAAE,QAKpE"}
@@ -1,3 +1,4 @@
1
+ /* eslint-disable no-undef */
1
2
  export function internalLog(message, ...optionalParams) {
2
3
  if (process.env.QUILL_ENV === 'development') {
3
4
  const completeMessage = `Quill: ${message}: ${optionalParams.join('\n')}`;
@@ -16,24 +16,3 @@ function mergeForwards(resp) {
16
16
  j++;
17
17
  }
18
18
  }
19
- // eslint-disable-next-line no-unused-vars
20
- function mergeBackwards(resp) {
21
- const compRows = resp.compareRows;
22
- let j = compRows.length - 1;
23
- for (let i = resp.rows.length - 1; i >= 0; i--) {
24
- if (j >= 0) {
25
- for (const [key, value] of Object.entries(compRows[j])) {
26
- resp.rows[i][`comparison_${key}`] = value;
27
- }
28
- }
29
- j--;
30
- }
31
- while (j >= 0) {
32
- const obj = {};
33
- for (const [key, value] of Object.entries(compRows[j])) {
34
- obj[`comparison_${key}`] = value;
35
- }
36
- resp.rows.push(obj);
37
- j--;
38
- }
39
- }
@@ -5,9 +5,10 @@ interface CompletionItem {
5
5
  kind: number;
6
6
  insertText: string;
7
7
  insertTextRules: number;
8
- range: any;
8
+ range: Range;
9
9
  detail?: string;
10
10
  }
11
+ export declare const QUILL_LANGUAGE: any;
11
12
  export declare function generateSuggestionsBySchema(schema: any[], monaco: Monaco, range: Range, databaseType: string): CompletionItem[];
12
13
  export declare function generateSuggestionsByDatasource(monaco: Monaco, range: Range, databaseType: string): {
13
14
  label: string;
@@ -17,4 +18,4 @@ export declare function generateSuggestionsByDatasource(monaco: Monaco, range: R
17
18
  range: Range;
18
19
  }[];
19
20
  export {};
20
- //# sourceMappingURL=monacoAutocomplete.d.ts.map
21
+ //# sourceMappingURL=monacoConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"monacoConfig.d.ts","sourceRoot":"","sources":["../../../src/utils/monacoConfig.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGtC,UAAU,cAAc;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,KAAK,EAAE,KAAK,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,eAAO,MAAM,cAAc,EAAE,GAmJ5B,CAAC;AAyJF,wBAAgB,2BAA2B,CACzC,MAAM,EAAE,GAAG,EAAE,EACb,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,MAAM,GACnB,cAAc,EAAE,CA2BlB;AAED,wBAAgB,+BAA+B,CAC7C,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,MAAM;;;;;;IAoBrB"}
@@ -0,0 +1,319 @@
1
+ import { processColumnReference } from './queryConstructor';
2
+ export const QUILL_LANGUAGE = {
3
+ monarchTokensProvider: {
4
+ defaultToken: '',
5
+ tokenPostfix: '.pgsql',
6
+ keywords: [
7
+ 'SELECT',
8
+ 'select',
9
+ 'FROM',
10
+ 'fromt',
11
+ 'WHERE',
12
+ 'where',
13
+ 'IF',
14
+ 'if',
15
+ 'THEN',
16
+ 'then',
17
+ 'ELSE',
18
+ 'ELSIF',
19
+ 'CASE',
20
+ 'case',
21
+ 'WHEN',
22
+ 'when',
23
+ 'NULL',
24
+ 'null',
25
+ 'TRUE',
26
+ 'true',
27
+ 'FALSE',
28
+ 'false',
29
+ 'AS',
30
+ 'as',
31
+ 'LEFT',
32
+ 'left',
33
+ 'INNER',
34
+ 'inner',
35
+ 'JOIN',
36
+ 'join',
37
+ ],
38
+ operators: [
39
+ '=',
40
+ '<',
41
+ '>',
42
+ '<=',
43
+ '>=',
44
+ '<>',
45
+ '!=',
46
+ '!',
47
+ '&&',
48
+ '||',
49
+ '++',
50
+ '--',
51
+ '+',
52
+ '-',
53
+ '*',
54
+ '/',
55
+ '%',
56
+ '<<',
57
+ '>>',
58
+ '&',
59
+ '|',
60
+ '^',
61
+ '~',
62
+ '::',
63
+ ],
64
+ symbols: '[=><!~?:&|+\\-*\\/\\^%]+',
65
+ tokenizer: {
66
+ root: [
67
+ [
68
+ /[a-zA-Z_$][\w$]*/,
69
+ {
70
+ cases: {
71
+ '@keywords': 'keyword',
72
+ '@default': 'identifier',
73
+ },
74
+ },
75
+ ],
76
+ { include: '@whitespace' },
77
+ ['[{}()\\[\\]]', '@brackets'],
78
+ ['[<>](?!@symbols)', '@brackets'],
79
+ [
80
+ '@symbols',
81
+ {
82
+ cases: {
83
+ '@operators': 'operator',
84
+ '@default': '',
85
+ },
86
+ },
87
+ ],
88
+ ['\\d*\\.\\d+([eE][\\-+]?\\d+)?', 'number.float'],
89
+ ['\\d+', 'number'],
90
+ ['[;,.]', 'delimiter'],
91
+ ["'([^'\\\\]|\\\\.)*$", 'string.invalid'],
92
+ ["'", 'string', '@string'],
93
+ ],
94
+ whitespace: [
95
+ ['[ \\t\\r\\n]+', ''],
96
+ ['--.*$', 'comment'],
97
+ ['\\/\\*', 'comment', '@comment'],
98
+ ],
99
+ comment: [
100
+ ['[^\\/*]+', 'comment'],
101
+ ['\\*\\/', 'comment', '@pop'],
102
+ ['[\\/*]', 'comment'],
103
+ ],
104
+ string: [
105
+ ["[^\\\\']+", 'string'],
106
+ ['\\\\.', 'string.escape'],
107
+ ["'", 'string', '@pop'],
108
+ ['"[^\\\\"]*"', 'string'],
109
+ ['"', 'string', '@dblString'],
110
+ ],
111
+ dblString: [
112
+ ['[^\\\\"]+', 'string'],
113
+ ['\\\\.', 'string.escape'],
114
+ ['"', 'string', '@pop'],
115
+ ],
116
+ },
117
+ },
118
+ languageConfiguration: {
119
+ comments: {
120
+ lineComment: '--',
121
+ blockComment: ['/*', '*/'],
122
+ },
123
+ brackets: [
124
+ ['{', '}'],
125
+ ['[', ']'],
126
+ ['(', ')'],
127
+ ],
128
+ autoClosingPairs: [
129
+ { open: '{', close: '}' },
130
+ { open: '[', close: ']' },
131
+ { open: '(', close: ')' },
132
+ { open: "'", close: "'" },
133
+ ],
134
+ surroundingPairs: [
135
+ { open: '{', close: '}' },
136
+ { open: '[', close: ']' },
137
+ { open: '(', close: ')' },
138
+ { open: '"', close: '"' },
139
+ { open: "'", close: "'" },
140
+ ],
141
+ },
142
+ };
143
+ const GENERIC_DATASOURCE_SUGGESTIONS = (monaco, range) => {
144
+ return [
145
+ {
146
+ label: 'SELECT',
147
+ kind: monaco.languages.CompletionItemKind.Keyword,
148
+ insertText: 'SELECT',
149
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
150
+ range,
151
+ },
152
+ {
153
+ label: 'FROM',
154
+ kind: monaco.languages.CompletionItemKind.Keyword,
155
+ insertText: 'FROM',
156
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
157
+ range,
158
+ },
159
+ {
160
+ label: 'JOIN',
161
+ kind: monaco.languages.CompletionItemKind.Keyword,
162
+ insertText: 'JOIN',
163
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
164
+ range,
165
+ },
166
+ {
167
+ label: 'LEFT JOIN',
168
+ kind: monaco.languages.CompletionItemKind.Keyword,
169
+ insertText: 'LEFT JOIN',
170
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
171
+ range,
172
+ },
173
+ {
174
+ label: 'INNER JOIN',
175
+ kind: monaco.languages.CompletionItemKind.Keyword,
176
+ insertText: 'INNER JOIN',
177
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
178
+ range,
179
+ },
180
+ {
181
+ label: 'MAX',
182
+ kind: monaco.languages.CompletionItemKind.Keyword,
183
+ insertText: 'MAX',
184
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
185
+ range,
186
+ },
187
+ {
188
+ label: 'MIN',
189
+ kind: monaco.languages.CompletionItemKind.Keyword,
190
+ insertText: 'MIN',
191
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
192
+ range,
193
+ },
194
+ {
195
+ label: 'ON',
196
+ kind: monaco.languages.CompletionItemKind.Keyword,
197
+ insertText: 'ON',
198
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
199
+ range,
200
+ },
201
+ {
202
+ label: 'WHERE',
203
+ kind: monaco.languages.CompletionItemKind.Keyword,
204
+ insertText: 'WHERE',
205
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
206
+ range,
207
+ },
208
+ {
209
+ label: 'LIMIT',
210
+ kind: monaco.languages.CompletionItemKind.Keyword,
211
+ insertText: 'LIMIT',
212
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
213
+ range,
214
+ },
215
+ {
216
+ label: 'GROUP BY',
217
+ kind: monaco.languages.CompletionItemKind.Keyword,
218
+ insertText: 'GROUP BY',
219
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
220
+ range,
221
+ },
222
+ {
223
+ label: 'ORDER BY',
224
+ kind: monaco.languages.CompletionItemKind.Keyword,
225
+ insertText: 'ORDER BY',
226
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
227
+ range,
228
+ },
229
+ ];
230
+ };
231
+ const POSTGRES_DATASOURCE_SUGGESTIONS = (monaco, range) => {
232
+ return [
233
+ {
234
+ label: 'EXTRACT',
235
+ kind: monaco.languages.CompletionItemKind.Keyword,
236
+ insertText: 'EXTRACT',
237
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
238
+ range,
239
+ },
240
+ {
241
+ label: 'TO_TIMESTAMP',
242
+ kind: monaco.languages.CompletionItemKind.Keyword,
243
+ insertText: 'TO_TIMESTAMP',
244
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
245
+ range,
246
+ },
247
+ {
248
+ label: 'CURRENT_DATE',
249
+ kind: monaco.languages.CompletionItemKind.Keyword,
250
+ insertText: 'CURRENT_DATE',
251
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
252
+ range,
253
+ },
254
+ {
255
+ label: 'CURRENT_TIMESTAMP',
256
+ kind: monaco.languages.CompletionItemKind.Keyword,
257
+ insertText: 'CURRENT_TIMESTAMP',
258
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
259
+ range,
260
+ },
261
+ ];
262
+ };
263
+ const BIGQUERY_DATASOURCE_SUGGESTIONS = (monaco, range) => {
264
+ return [
265
+ {
266
+ label: 'TO_TIMESTAMP',
267
+ kind: monaco.languages.CompletionItemKind.Keyword,
268
+ insertText: 'TO_TIMESTAMP',
269
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
270
+ range,
271
+ },
272
+ ];
273
+ };
274
+ export function generateSuggestionsBySchema(schema, monaco, range, databaseType) {
275
+ const suggestions = [];
276
+ schema.forEach((table) => {
277
+ const curSuggestion = {
278
+ label: table.name,
279
+ kind: monaco.languages.CompletionItemKind.Field,
280
+ insertText: `${processColumnReference(table.name, databaseType).replaceAll('`', '')}`,
281
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
282
+ range,
283
+ };
284
+ suggestions.push(curSuggestion);
285
+ table.columns.forEach((column) => {
286
+ const insertText = `${processColumnReference(column.name, databaseType).replaceAll('`', '')}`;
287
+ const curSuggestion = {
288
+ label: column.name,
289
+ kind: monaco.languages.CompletionItemKind.Field,
290
+ insertText,
291
+ detail: table.name,
292
+ insertTextRules: monaco.languages.CompletionItemInsertTextRule.InsertAsSnippet,
293
+ range,
294
+ };
295
+ suggestions.push(curSuggestion);
296
+ });
297
+ }, []);
298
+ return suggestions;
299
+ }
300
+ export function generateSuggestionsByDatasource(monaco, range, databaseType) {
301
+ if (!databaseType) {
302
+ return GENERIC_DATASOURCE_SUGGESTIONS(monaco, range);
303
+ }
304
+ switch (databaseType.toLowerCase()) {
305
+ case 'snowflake':
306
+ case 'postgresql':
307
+ return [
308
+ ...POSTGRES_DATASOURCE_SUGGESTIONS(monaco, range),
309
+ ...GENERIC_DATASOURCE_SUGGESTIONS(monaco, range),
310
+ ];
311
+ case 'bigquery':
312
+ return [
313
+ ...BIGQUERY_DATASOURCE_SUGGESTIONS(monaco, range),
314
+ ...GENERIC_DATASOURCE_SUGGESTIONS(monaco, range),
315
+ ];
316
+ default:
317
+ return GENERIC_DATASOURCE_SUGGESTIONS(monaco, range);
318
+ }
319
+ }
@@ -0,0 +1,5 @@
1
+ import { Pagination } from '../models/Pagination';
2
+ export declare const DEFAULT_PAGINATION: Pagination;
3
+ export declare function shouldFetchMore(pagination: Pagination, page: number, maxPage: number): boolean;
4
+ export declare function shouldSortInMemory(pagination: Pagination, rowCount?: number, isPivot?: boolean): boolean;
5
+ //# sourceMappingURL=paginationProcessing.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"paginationProcessing.d.ts","sourceRoot":"","sources":["../../../src/utils/paginationProcessing.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAElD,eAAO,MAAM,kBAAkB,EAAE,UAIhC,CAAC;AAEF,wBAAgB,eAAe,CAC7B,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE,MAAM,WAehB;AAED,wBAAgB,kBAAkB,CAChC,UAAU,EAAE,UAAU,EACtB,QAAQ,CAAC,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE,OAAO,WASlB"}
@@ -0,0 +1,25 @@
1
+ export const DEFAULT_PAGINATION = {
2
+ page: 0,
3
+ rowsPerPage: 20,
4
+ rowsPerRequest: 500,
5
+ };
6
+ export function shouldFetchMore(pagination, page, maxPage) {
7
+ if (!pagination) {
8
+ return false;
9
+ }
10
+ const indexAdjustedPage = page;
11
+ const pageInterval = Math.floor((indexAdjustedPage * pagination.rowsPerPage) / pagination.rowsPerRequest);
12
+ const indexAdjustedPreviousPage = maxPage;
13
+ const previousPageInterval = Math.floor((indexAdjustedPreviousPage * pagination.rowsPerPage) /
14
+ pagination.rowsPerRequest);
15
+ return pageInterval > previousPageInterval;
16
+ }
17
+ export function shouldSortInMemory(pagination, rowCount, isPivot) {
18
+ if (isPivot) {
19
+ return true;
20
+ }
21
+ if (!rowCount || rowCount < pagination.rowsPerRequest) {
22
+ return true;
23
+ }
24
+ return false;
25
+ }
@@ -1,5 +1,6 @@
1
1
  import { Pivot } from '../internals/ReportBuilder/PivotModal';
2
- export declare function generatePivotWithSQL(pivot: Pivot, report: any, client: any, dateBucket?: string, dateFilter?: any, distinctStrings?: any): Promise<{
2
+ import { QuillReportInternal } from '../models/Report';
3
+ export declare function generatePivotWithSQL(pivot: Pivot, report: QuillReportInternal, client: any, dateBucket?: string, dateFilter?: any, distinctStrings?: any): Promise<{
3
4
  rows: any;
4
5
  columns: any;
5
6
  } | undefined>;
@@ -1 +1 @@
1
- {"version":3,"file":"pivotConstructor.d.ts","sourceRoot":"","sources":["../../../src/utils/pivotConstructor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAiB,MAAM,uCAAuC,CAAC;AAO7E,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,GAAG,EACX,MAAM,EAAE,GAAG,EACX,UAAU,CAAC,EAAE,MAAM,EACnB,UAAU,CAAC,EAAE,GAAG,EAChB,eAAe,CAAC,EAAE,GAAG;;;eAsKtB"}
1
+ {"version":3,"file":"pivotConstructor.d.ts","sourceRoot":"","sources":["../../../src/utils/pivotConstructor.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAiB,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAOvD,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,mBAAmB,EAC3B,MAAM,EAAE,GAAG,EACX,UAAU,CAAC,EAAE,MAAM,EACnB,UAAU,CAAC,EAAE,GAAG,EAChB,eAAe,CAAC,EAAE,GAAG;;;eAyLtB"}