@quillsql/react 2.13.7 → 2.13.9

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 (368) hide show
  1. package/dist/cjs/Chart.d.ts +5 -5
  2. package/dist/cjs/Chart.d.ts.map +1 -1
  3. package/dist/cjs/Chart.js +19 -8
  4. package/dist/cjs/ChartBuilder.d.ts +1 -1
  5. package/dist/cjs/ChartBuilder.d.ts.map +1 -1
  6. package/dist/cjs/ChartBuilder.js +58 -93
  7. package/dist/cjs/ChartEditor.js +1 -1
  8. package/dist/cjs/Context.d.ts +9 -8
  9. package/dist/cjs/Context.d.ts.map +1 -1
  10. package/dist/cjs/Context.js +119 -34
  11. package/dist/cjs/Dashboard.d.ts +20 -8
  12. package/dist/cjs/Dashboard.d.ts.map +1 -1
  13. package/dist/cjs/Dashboard.js +68 -58
  14. package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts +2 -2
  15. package/dist/cjs/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  16. package/dist/cjs/DateRangePicker/QuillDateRangePicker.js +1 -2
  17. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts +20 -20
  18. package/dist/cjs/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  19. package/dist/cjs/DateRangePicker/dateRangePickerUtils.js +64 -52
  20. package/dist/cjs/ReportBuilder.d.ts +2 -1
  21. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  22. package/dist/cjs/ReportBuilder.js +339 -339
  23. package/dist/cjs/SQLEditor.d.ts +1 -1
  24. package/dist/cjs/SQLEditor.d.ts.map +1 -1
  25. package/dist/cjs/SQLEditor.js +30 -18
  26. package/dist/cjs/components/Banner/index.d.ts +0 -1
  27. package/dist/cjs/components/Banner/index.d.ts.map +1 -1
  28. package/dist/cjs/components/Banner/index.js +1 -1
  29. package/dist/cjs/components/Chart/BarChart.d.ts +0 -1
  30. package/dist/cjs/components/Chart/BarChart.d.ts.map +1 -1
  31. package/dist/cjs/components/Chart/BarChart.js +1 -1
  32. package/dist/cjs/components/Chart/BarList.js +1 -2
  33. package/dist/cjs/components/Chart/ChartError.js +2 -3
  34. package/dist/cjs/components/Chart/ChartSkeleton.js +1 -1
  35. package/dist/cjs/components/Chart/ChartTooltip.js +1 -1
  36. package/dist/cjs/components/Chart/ChartTooltipFrame.d.ts +0 -1
  37. package/dist/cjs/components/Chart/ChartTooltipFrame.d.ts.map +1 -1
  38. package/dist/cjs/components/Chart/ChartTooltipFrame.js +1 -1
  39. package/dist/cjs/components/Chart/ChartTooltipGroup.js +1 -1
  40. package/dist/cjs/components/Chart/ChartTooltipRow.js +1 -1
  41. package/dist/cjs/components/Chart/LineChart.d.ts +0 -1
  42. package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
  43. package/dist/cjs/components/Chart/LineChart.js +1 -1
  44. package/dist/cjs/components/Chart/PieChart.d.ts.map +1 -1
  45. package/dist/cjs/components/Chart/PieChart.js +18 -9
  46. package/dist/cjs/components/Dashboard/ChartComponent.d.ts +0 -1
  47. package/dist/cjs/components/Dashboard/ChartComponent.d.ts.map +1 -1
  48. package/dist/cjs/components/Dashboard/ChartComponent.js +1 -1
  49. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts +10 -2
  50. package/dist/cjs/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  51. package/dist/cjs/components/Dashboard/DashboardFilter.js +9 -23
  52. package/dist/cjs/components/Dashboard/DashboardSection.d.ts +0 -1
  53. package/dist/cjs/components/Dashboard/DashboardSection.d.ts.map +1 -1
  54. package/dist/cjs/components/Dashboard/DashboardSection.js +1 -1
  55. package/dist/cjs/components/Dashboard/DashboardSectionContainer.d.ts +0 -1
  56. package/dist/cjs/components/Dashboard/DashboardSectionContainer.d.ts.map +1 -1
  57. package/dist/cjs/components/Dashboard/DashboardSectionContainer.js +1 -1
  58. package/dist/cjs/components/Dashboard/DashboardTemplate.js +1 -1
  59. package/dist/cjs/components/Dashboard/DataLoader.d.ts +9 -7
  60. package/dist/cjs/components/Dashboard/DataLoader.d.ts.map +1 -1
  61. package/dist/cjs/components/Dashboard/DataLoader.js +104 -61
  62. package/dist/cjs/components/Dashboard/MetricComponent.d.ts +0 -1
  63. package/dist/cjs/components/Dashboard/MetricComponent.d.ts.map +1 -1
  64. package/dist/cjs/components/Dashboard/MetricComponent.js +3 -3
  65. package/dist/cjs/components/Dashboard/TableComponent.d.ts +0 -1
  66. package/dist/cjs/components/Dashboard/TableComponent.d.ts.map +1 -1
  67. package/dist/cjs/components/Dashboard/TableComponent.js +1 -1
  68. package/dist/cjs/components/Dashboard/TemplateChartComponent.d.ts +0 -1
  69. package/dist/cjs/components/Dashboard/TemplateChartComponent.d.ts.map +1 -1
  70. package/dist/cjs/components/Dashboard/TemplateChartComponent.js +1 -1
  71. package/dist/cjs/components/Dashboard/TemplateMetricComponent.d.ts +0 -1
  72. package/dist/cjs/components/Dashboard/TemplateMetricComponent.d.ts.map +1 -1
  73. package/dist/cjs/components/Dashboard/TemplateMetricComponent.js +1 -1
  74. package/dist/cjs/components/Dashboard/TemplateTableComponent.d.ts +0 -1
  75. package/dist/cjs/components/Dashboard/TemplateTableComponent.d.ts.map +1 -1
  76. package/dist/cjs/components/Dashboard/TemplateTableComponent.js +1 -1
  77. package/dist/cjs/components/Dashboard/util.js +2 -3
  78. package/dist/cjs/components/QuillCard.js +1 -2
  79. package/dist/cjs/components/QuillMultiSelect.d.ts.map +1 -1
  80. package/dist/cjs/components/QuillMultiSelect.js +21 -20
  81. package/dist/cjs/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  82. package/dist/cjs/components/QuillMultiSelectWithCombo.js +172 -70
  83. package/dist/cjs/components/QuillSelect.d.ts.map +1 -1
  84. package/dist/cjs/components/QuillSelect.js +9 -8
  85. package/dist/cjs/components/QuillSelectWithCombo.d.ts.map +1 -1
  86. package/dist/cjs/components/QuillSelectWithCombo.js +26 -12
  87. package/dist/cjs/components/QuillTable.d.ts +5 -1
  88. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  89. package/dist/cjs/components/QuillTable.js +5 -3
  90. package/dist/cjs/components/ReportBuilder/AddColumnModal.js +1 -1
  91. package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts +2 -3
  92. package/dist/cjs/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  93. package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts +5 -6
  94. package/dist/cjs/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  95. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts +3 -4
  96. package/dist/cjs/components/ReportBuilder/FilterModal.d.ts.map +1 -1
  97. package/dist/cjs/components/ReportBuilder/FilterModal.js +45 -39
  98. package/dist/cjs/components/ReportBuilder/FilterStack.js +1 -1
  99. package/dist/cjs/components/ReportBuilder/ast.d.ts.map +1 -1
  100. package/dist/cjs/components/ReportBuilder/ast.js +2 -2
  101. package/dist/cjs/components/ReportBuilder/convert.js +11 -12
  102. package/dist/cjs/components/ReportBuilder/postgres.js +4 -4
  103. package/dist/cjs/components/ReportBuilder/ui.d.ts +3 -3
  104. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -1
  105. package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -1
  106. package/dist/cjs/components/ReportBuilder/util.js +21 -23
  107. package/dist/cjs/components/UiComponents.d.ts +14 -12
  108. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  109. package/dist/cjs/components/UiComponents.js +41 -17
  110. package/dist/cjs/components/selectUtils.js +3 -3
  111. package/dist/cjs/contexts/BaseColorContext.d.ts +0 -1
  112. package/dist/cjs/contexts/BaseColorContext.d.ts.map +1 -1
  113. package/dist/cjs/contexts/RootStylesContext.d.ts +0 -1
  114. package/dist/cjs/contexts/RootStylesContext.d.ts.map +1 -1
  115. package/dist/cjs/contexts/SelectedValueContext.d.ts +0 -1
  116. package/dist/cjs/contexts/SelectedValueContext.d.ts.map +1 -1
  117. package/dist/cjs/hooks/useAskQuill.d.ts +2 -2
  118. package/dist/cjs/hooks/useAskQuill.d.ts.map +1 -1
  119. package/dist/cjs/hooks/useAskQuill.js +11 -11
  120. package/dist/cjs/hooks/useAstToFilterTree.d.ts.map +1 -1
  121. package/dist/cjs/hooks/useDashboard.d.ts +8 -7
  122. package/dist/cjs/hooks/useDashboard.d.ts.map +1 -1
  123. package/dist/cjs/hooks/useDashboard.js +47 -31
  124. package/dist/cjs/hooks/useExport.d.ts +3 -4
  125. package/dist/cjs/hooks/useExport.d.ts.map +1 -1
  126. package/dist/cjs/hooks/useExport.js +6 -2
  127. package/dist/cjs/hooks/useInternalState.d.ts +1 -2
  128. package/dist/cjs/hooks/useInternalState.d.ts.map +1 -1
  129. package/dist/cjs/hooks/useOnClickOutside.d.ts +3 -1
  130. package/dist/cjs/hooks/useOnClickOutside.d.ts.map +1 -1
  131. package/dist/cjs/hooks/useQuill.d.ts +0 -14
  132. package/dist/cjs/hooks/useQuill.d.ts.map +1 -1
  133. package/dist/cjs/hooks/useQuill.js +17 -55
  134. package/dist/cjs/hooks/useSelectOnKeyDown.d.ts.map +1 -1
  135. package/dist/cjs/index.d.ts +2 -1
  136. package/dist/cjs/index.d.ts.map +1 -1
  137. package/dist/cjs/index.js +7 -2
  138. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts +4 -1
  139. package/dist/cjs/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  140. package/dist/cjs/internals/ReportBuilder/PivotForm.js +32 -7
  141. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts +17 -13
  142. package/dist/cjs/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  143. package/dist/cjs/internals/ReportBuilder/PivotModal.js +368 -162
  144. package/dist/cjs/lib/utils.d.ts +0 -1
  145. package/dist/cjs/lib/utils.d.ts.map +1 -1
  146. package/dist/cjs/lib/utils.js +2 -2
  147. package/dist/cjs/models/Filter.d.ts +49 -30
  148. package/dist/cjs/models/Filter.d.ts.map +1 -1
  149. package/dist/cjs/models/Filter.js +125 -52
  150. package/dist/cjs/models/Pivot.d.ts +3 -1
  151. package/dist/cjs/models/Pivot.d.ts.map +1 -1
  152. package/dist/cjs/models/Report.d.ts +2 -2
  153. package/dist/cjs/models/Report.d.ts.map +1 -1
  154. package/dist/cjs/utils/astFilterProcessing.d.ts +4 -4
  155. package/dist/cjs/utils/astFilterProcessing.d.ts.map +1 -1
  156. package/dist/cjs/utils/astFilterProcessing.js +3839 -3427
  157. package/dist/cjs/utils/astProcessing.d.ts +12 -3
  158. package/dist/cjs/utils/astProcessing.d.ts.map +1 -1
  159. package/dist/cjs/utils/astProcessing.js +76 -11
  160. package/dist/cjs/utils/client.js +2 -2
  161. package/dist/cjs/utils/color.js +5 -6
  162. package/dist/cjs/utils/columnProcessing.d.ts.map +1 -1
  163. package/dist/cjs/utils/columnProcessing.js +7 -7
  164. package/dist/cjs/utils/crypto.js +1 -2
  165. package/dist/cjs/utils/dashboard.d.ts.map +1 -1
  166. package/dist/cjs/utils/dashboard.js +34 -30
  167. package/dist/cjs/utils/dataFetcher.js +3 -4
  168. package/dist/cjs/utils/dataProcessing.js +2 -2
  169. package/dist/cjs/utils/dates.d.ts +4 -1
  170. package/dist/cjs/utils/dates.d.ts.map +1 -1
  171. package/dist/cjs/utils/dates.js +12 -10
  172. package/dist/cjs/utils/errorProcessing.js +1 -2
  173. package/dist/cjs/utils/filterProcessing.d.ts +3 -3
  174. package/dist/cjs/utils/filterProcessing.d.ts.map +1 -1
  175. package/dist/cjs/utils/filterProcessing.js +30 -27
  176. package/dist/cjs/utils/getDomain.js +1 -1
  177. package/dist/cjs/utils/logging.js +1 -2
  178. package/dist/cjs/utils/merge.d.ts +1 -1
  179. package/dist/cjs/utils/merge.d.ts.map +1 -1
  180. package/dist/cjs/utils/merge.js +15 -11
  181. package/dist/cjs/utils/monacoConfig.js +3 -3
  182. package/dist/cjs/utils/paginationProcessing.js +3 -3
  183. package/dist/cjs/utils/pivotConstructor.d.ts +4 -4
  184. package/dist/cjs/utils/pivotConstructor.d.ts.map +1 -1
  185. package/dist/cjs/utils/pivotConstructor.js +104 -127
  186. package/dist/cjs/utils/pivotProcessing.d.ts.map +1 -1
  187. package/dist/cjs/utils/pivotProcessing.js +14 -16
  188. package/dist/cjs/utils/queryConstructor.d.ts +2 -2
  189. package/dist/cjs/utils/queryConstructor.d.ts.map +1 -1
  190. package/dist/cjs/utils/queryConstructor.js +344 -78
  191. package/dist/cjs/utils/report.d.ts.map +1 -1
  192. package/dist/cjs/utils/report.js +22 -12
  193. package/dist/cjs/utils/schema.d.ts.map +1 -1
  194. package/dist/cjs/utils/styles.js +1 -2
  195. package/dist/cjs/utils/tableProcessing.d.ts +12 -12
  196. package/dist/cjs/utils/tableProcessing.d.ts.map +1 -1
  197. package/dist/cjs/utils/tableProcessing.js +69 -26
  198. package/dist/cjs/utils/textProcessing.js +5 -6
  199. package/dist/cjs/utils/validation.d.ts.map +1 -1
  200. package/dist/cjs/utils/validation.js +3 -1
  201. package/dist/cjs/utils/valueFormatter.d.ts +1 -0
  202. package/dist/cjs/utils/valueFormatter.d.ts.map +1 -1
  203. package/dist/cjs/utils/valueFormatter.js +2 -0
  204. package/dist/cjs/utils/width.d.ts.map +1 -1
  205. package/dist/esm/Chart.d.ts +5 -5
  206. package/dist/esm/Chart.d.ts.map +1 -1
  207. package/dist/esm/Chart.js +15 -4
  208. package/dist/esm/ChartBuilder.d.ts +1 -1
  209. package/dist/esm/ChartBuilder.d.ts.map +1 -1
  210. package/dist/esm/ChartBuilder.js +52 -87
  211. package/dist/esm/Context.d.ts +9 -8
  212. package/dist/esm/Context.d.ts.map +1 -1
  213. package/dist/esm/Context.js +119 -34
  214. package/dist/esm/Dashboard.d.ts +20 -8
  215. package/dist/esm/Dashboard.d.ts.map +1 -1
  216. package/dist/esm/Dashboard.js +68 -58
  217. package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts +2 -2
  218. package/dist/esm/DateRangePicker/QuillDateRangePicker.d.ts.map +1 -1
  219. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts +20 -20
  220. package/dist/esm/DateRangePicker/dateRangePickerUtils.d.ts.map +1 -1
  221. package/dist/esm/DateRangePicker/dateRangePickerUtils.js +64 -52
  222. package/dist/esm/ReportBuilder.d.ts +2 -1
  223. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  224. package/dist/esm/ReportBuilder.js +343 -343
  225. package/dist/esm/SQLEditor.d.ts +1 -1
  226. package/dist/esm/SQLEditor.d.ts.map +1 -1
  227. package/dist/esm/SQLEditor.js +29 -17
  228. package/dist/esm/components/Banner/index.d.ts +0 -1
  229. package/dist/esm/components/Banner/index.d.ts.map +1 -1
  230. package/dist/esm/components/Chart/BarChart.d.ts +0 -1
  231. package/dist/esm/components/Chart/BarChart.d.ts.map +1 -1
  232. package/dist/esm/components/Chart/ChartTooltipFrame.d.ts +0 -1
  233. package/dist/esm/components/Chart/ChartTooltipFrame.d.ts.map +1 -1
  234. package/dist/esm/components/Chart/LineChart.d.ts +0 -1
  235. package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
  236. package/dist/esm/components/Chart/PieChart.d.ts.map +1 -1
  237. package/dist/esm/components/Chart/PieChart.js +18 -9
  238. package/dist/esm/components/Dashboard/ChartComponent.d.ts +0 -1
  239. package/dist/esm/components/Dashboard/ChartComponent.d.ts.map +1 -1
  240. package/dist/esm/components/Dashboard/DashboardFilter.d.ts +10 -2
  241. package/dist/esm/components/Dashboard/DashboardFilter.d.ts.map +1 -1
  242. package/dist/esm/components/Dashboard/DashboardFilter.js +8 -21
  243. package/dist/esm/components/Dashboard/DashboardSection.d.ts +0 -1
  244. package/dist/esm/components/Dashboard/DashboardSection.d.ts.map +1 -1
  245. package/dist/esm/components/Dashboard/DashboardSectionContainer.d.ts +0 -1
  246. package/dist/esm/components/Dashboard/DashboardSectionContainer.d.ts.map +1 -1
  247. package/dist/esm/components/Dashboard/DataLoader.d.ts +9 -7
  248. package/dist/esm/components/Dashboard/DataLoader.d.ts.map +1 -1
  249. package/dist/esm/components/Dashboard/DataLoader.js +102 -62
  250. package/dist/esm/components/Dashboard/MetricComponent.d.ts +0 -1
  251. package/dist/esm/components/Dashboard/MetricComponent.d.ts.map +1 -1
  252. package/dist/esm/components/Dashboard/MetricComponent.js +2 -2
  253. package/dist/esm/components/Dashboard/TableComponent.d.ts +0 -1
  254. package/dist/esm/components/Dashboard/TableComponent.d.ts.map +1 -1
  255. package/dist/esm/components/Dashboard/TemplateChartComponent.d.ts +0 -1
  256. package/dist/esm/components/Dashboard/TemplateChartComponent.d.ts.map +1 -1
  257. package/dist/esm/components/Dashboard/TemplateMetricComponent.d.ts +0 -1
  258. package/dist/esm/components/Dashboard/TemplateMetricComponent.d.ts.map +1 -1
  259. package/dist/esm/components/Dashboard/TemplateTableComponent.d.ts +0 -1
  260. package/dist/esm/components/Dashboard/TemplateTableComponent.d.ts.map +1 -1
  261. package/dist/esm/components/QuillMultiSelect.d.ts.map +1 -1
  262. package/dist/esm/components/QuillMultiSelect.js +19 -18
  263. package/dist/esm/components/QuillMultiSelectWithCombo.d.ts.map +1 -1
  264. package/dist/esm/components/QuillMultiSelectWithCombo.js +171 -69
  265. package/dist/esm/components/QuillSelect.d.ts.map +1 -1
  266. package/dist/esm/components/QuillSelect.js +8 -6
  267. package/dist/esm/components/QuillSelectWithCombo.d.ts.map +1 -1
  268. package/dist/esm/components/QuillSelectWithCombo.js +25 -10
  269. package/dist/esm/components/QuillTable.d.ts +5 -1
  270. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  271. package/dist/esm/components/QuillTable.js +4 -2
  272. package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts +2 -3
  273. package/dist/esm/components/ReportBuilder/AddLimitPopover.d.ts.map +1 -1
  274. package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts +5 -6
  275. package/dist/esm/components/ReportBuilder/AddSortPopover.d.ts.map +1 -1
  276. package/dist/esm/components/ReportBuilder/FilterModal.d.ts +3 -4
  277. package/dist/esm/components/ReportBuilder/FilterModal.d.ts.map +1 -1
  278. package/dist/esm/components/ReportBuilder/FilterModal.js +46 -40
  279. package/dist/esm/components/ReportBuilder/ast.d.ts.map +1 -1
  280. package/dist/esm/components/ReportBuilder/ui.d.ts +3 -3
  281. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -1
  282. package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -1
  283. package/dist/esm/components/ReportBuilder/util.js +0 -2
  284. package/dist/esm/components/UiComponents.d.ts +14 -12
  285. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  286. package/dist/esm/components/UiComponents.js +37 -14
  287. package/dist/esm/contexts/BaseColorContext.d.ts +0 -1
  288. package/dist/esm/contexts/BaseColorContext.d.ts.map +1 -1
  289. package/dist/esm/contexts/RootStylesContext.d.ts +0 -1
  290. package/dist/esm/contexts/RootStylesContext.d.ts.map +1 -1
  291. package/dist/esm/contexts/SelectedValueContext.d.ts +0 -1
  292. package/dist/esm/contexts/SelectedValueContext.d.ts.map +1 -1
  293. package/dist/esm/hooks/useAskQuill.d.ts +2 -2
  294. package/dist/esm/hooks/useAskQuill.d.ts.map +1 -1
  295. package/dist/esm/hooks/useAskQuill.js +12 -12
  296. package/dist/esm/hooks/useAstToFilterTree.d.ts.map +1 -1
  297. package/dist/esm/hooks/useDashboard.d.ts +8 -7
  298. package/dist/esm/hooks/useDashboard.d.ts.map +1 -1
  299. package/dist/esm/hooks/useDashboard.js +48 -32
  300. package/dist/esm/hooks/useExport.d.ts +3 -4
  301. package/dist/esm/hooks/useExport.d.ts.map +1 -1
  302. package/dist/esm/hooks/useExport.js +6 -2
  303. package/dist/esm/hooks/useInternalState.d.ts +1 -2
  304. package/dist/esm/hooks/useInternalState.d.ts.map +1 -1
  305. package/dist/esm/hooks/useOnClickOutside.d.ts +3 -1
  306. package/dist/esm/hooks/useOnClickOutside.d.ts.map +1 -1
  307. package/dist/esm/hooks/useQuill.d.ts +0 -14
  308. package/dist/esm/hooks/useQuill.d.ts.map +1 -1
  309. package/dist/esm/hooks/useQuill.js +16 -53
  310. package/dist/esm/hooks/useSelectOnKeyDown.d.ts.map +1 -1
  311. package/dist/esm/index.d.ts +2 -1
  312. package/dist/esm/index.d.ts.map +1 -1
  313. package/dist/esm/index.js +2 -1
  314. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts +4 -1
  315. package/dist/esm/internals/ReportBuilder/PivotForm.d.ts.map +1 -1
  316. package/dist/esm/internals/ReportBuilder/PivotForm.js +32 -7
  317. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts +17 -13
  318. package/dist/esm/internals/ReportBuilder/PivotModal.d.ts.map +1 -1
  319. package/dist/esm/internals/ReportBuilder/PivotModal.js +364 -158
  320. package/dist/esm/lib/utils.d.ts +0 -1
  321. package/dist/esm/lib/utils.d.ts.map +1 -1
  322. package/dist/esm/models/Filter.d.ts +49 -30
  323. package/dist/esm/models/Filter.d.ts.map +1 -1
  324. package/dist/esm/models/Filter.js +123 -50
  325. package/dist/esm/models/Pivot.d.ts +3 -1
  326. package/dist/esm/models/Pivot.d.ts.map +1 -1
  327. package/dist/esm/models/Report.d.ts +2 -2
  328. package/dist/esm/models/Report.d.ts.map +1 -1
  329. package/dist/esm/utils/astFilterProcessing.d.ts +4 -4
  330. package/dist/esm/utils/astFilterProcessing.d.ts.map +1 -1
  331. package/dist/esm/utils/astFilterProcessing.js +3835 -3423
  332. package/dist/esm/utils/astProcessing.d.ts +12 -3
  333. package/dist/esm/utils/astProcessing.d.ts.map +1 -1
  334. package/dist/esm/utils/astProcessing.js +64 -0
  335. package/dist/esm/utils/columnProcessing.d.ts.map +1 -1
  336. package/dist/esm/utils/columnProcessing.js +1 -1
  337. package/dist/esm/utils/dashboard.d.ts.map +1 -1
  338. package/dist/esm/utils/dashboard.js +31 -26
  339. package/dist/esm/utils/dates.d.ts +4 -1
  340. package/dist/esm/utils/dates.d.ts.map +1 -1
  341. package/dist/esm/utils/dates.js +6 -3
  342. package/dist/esm/utils/filterProcessing.d.ts +3 -3
  343. package/dist/esm/utils/filterProcessing.d.ts.map +1 -1
  344. package/dist/esm/utils/filterProcessing.js +22 -19
  345. package/dist/esm/utils/merge.d.ts +1 -1
  346. package/dist/esm/utils/merge.d.ts.map +1 -1
  347. package/dist/esm/utils/merge.js +14 -9
  348. package/dist/esm/utils/pivotConstructor.d.ts +4 -4
  349. package/dist/esm/utils/pivotConstructor.d.ts.map +1 -1
  350. package/dist/esm/utils/pivotConstructor.js +103 -125
  351. package/dist/esm/utils/pivotProcessing.d.ts.map +1 -1
  352. package/dist/esm/utils/pivotProcessing.js +9 -11
  353. package/dist/esm/utils/queryConstructor.d.ts +2 -2
  354. package/dist/esm/utils/queryConstructor.d.ts.map +1 -1
  355. package/dist/esm/utils/queryConstructor.js +338 -71
  356. package/dist/esm/utils/report.d.ts.map +1 -1
  357. package/dist/esm/utils/report.js +18 -8
  358. package/dist/esm/utils/schema.d.ts.map +1 -1
  359. package/dist/esm/utils/tableProcessing.d.ts +12 -12
  360. package/dist/esm/utils/tableProcessing.d.ts.map +1 -1
  361. package/dist/esm/utils/tableProcessing.js +69 -26
  362. package/dist/esm/utils/validation.d.ts.map +1 -1
  363. package/dist/esm/utils/validation.js +3 -1
  364. package/dist/esm/utils/valueFormatter.d.ts +1 -0
  365. package/dist/esm/utils/valueFormatter.d.ts.map +1 -1
  366. package/dist/esm/utils/valueFormatter.js +2 -1
  367. package/dist/esm/utils/width.d.ts.map +1 -1
  368. package/package.json +4 -4
@@ -15,7 +15,7 @@ import { QuillDateRangePicker } from './DateRangePicker/QuillDateRangePicker';
15
15
  import DataLoader, { ChartDataLoader, } from './components/Dashboard/DataLoader';
16
16
  import { QuillEmptyDashboardComponent, QuillFilterContainerComponent, QuillLoadingDashboardComponent, QuillModalComponent, MemoizedButton, MemoizedSecondaryButton, QuillTextInput, MemoizedPopover, QuillErrorMessageComponent, } from './components/UiComponents';
17
17
  import { DashboardFilter } from './components/Dashboard/DashboardFilter';
18
- import { BoolOperator, FieldTypes, NullOperator, NumberOperator, StringOperator, } from './models/Filter';
18
+ import { BoolOperator, convertCustomFilter, FieldType, NullOperator, NumberOperator, StringOperator, } from './models/Filter';
19
19
  import { QuillMultiSelectComponentWithCombo } from './components/QuillMultiSelectWithCombo';
20
20
  import { QuillSelectComponentWithCombo } from './components/QuillSelectWithCombo';
21
21
  import { getUniqueStringValues } from './utils/tableProcessing';
@@ -53,7 +53,7 @@ const sortByOrdering = (a, b) => {
53
53
  return a.order - b.order;
54
54
  };
55
55
  const customOperatorOptions = {
56
- [FieldTypes.Number]: [
56
+ [FieldType.Number]: [
57
57
  NumberOperator.EqualTo,
58
58
  NumberOperator.NotEqualTo,
59
59
  NumberOperator.GreaterThan,
@@ -63,7 +63,7 @@ const customOperatorOptions = {
63
63
  NullOperator.IsNotNull,
64
64
  NullOperator.IsNull,
65
65
  ],
66
- [FieldTypes.String]: [
66
+ [FieldType.String]: [
67
67
  StringOperator.IsExactly,
68
68
  StringOperator.IsNotExactly,
69
69
  StringOperator.Contains,
@@ -72,7 +72,7 @@ const customOperatorOptions = {
72
72
  NullOperator.IsNotNull,
73
73
  NullOperator.IsNull,
74
74
  ],
75
- [FieldTypes.Boolean]: [
75
+ [FieldType.Boolean]: [
76
76
  BoolOperator.EqualTo,
77
77
  BoolOperator.NotEqualTo,
78
78
  NullOperator.IsNotNull,
@@ -110,11 +110,22 @@ const customOperatorOptions = {
110
110
  * ### API Reference
111
111
  * @see https://docs.quillsql.com/components/dashboard
112
112
  */
113
- export default function Dashboard({ name, hidden = false, SelectComponent = QuillSelectComponentWithCombo, MultiSelectComponent = QuillMultiSelectComponentWithCombo, ModalComponent = QuillModalComponent, ButtonComponent = MemoizedButton, SecondaryButtonComponent = MemoizedSecondaryButton, FilterTagComponent = QuillFilterPopover, PopoverComponent = MemoizedPopover, TextInputComponent = QuillTextInput, EmptyDashboardComponent = QuillEmptyDashboardComponent, DateRangePickerComponent = QuillDateRangePicker, MetricComponent = QuillMetricComponent, ChartComponent = QuillChartComponent, TableComponent = QuillTableComponent, TemplateMetricComponent = QuillTemplateMetricComponent, TemplateChartComponent = QuillTemplateChartComponent, TemplateTableComponent = QuillTemplateTableComponent, DashboardSectionComponent = DashboardSection, DashboardSectionContainerComponent = DashboardSectionContainer, FilterContainerComponent = QuillFilterContainerComponent, DashboardLoadingComponent = QuillLoadingDashboardComponent, ErrorComponent = QuillChartErrorWithAction, onClickReport, hoverActions, onChangeLoading, hideFilters, hideXAxis = false, hideYAxis = false, hideCartesianGrid = false, comparisonLineStyle = 'solid', containerStyle, className, chartContainerStyle = defaultChartContainerStyles,
114
- // TODO: do something with these custom filters
115
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
116
- filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors = true, templateDashboardName, pagination = { rowsPerPage: 10, rowsPerRequest: 50 }, }) {
117
- const { isLoading, data, isDashboardFilterLoading, dashboardFilters: populatedDashboardFilters, reload, } = useDashboard(name);
113
+ export default function Dashboard({ name, hidden = false, SelectComponent = QuillSelectComponentWithCombo, MultiSelectComponent = QuillMultiSelectComponentWithCombo, ModalComponent = QuillModalComponent, ButtonComponent = MemoizedButton, SecondaryButtonComponent = MemoizedSecondaryButton, FilterTagComponent = QuillFilterPopover, PopoverComponent = MemoizedPopover, TextInputComponent = QuillTextInput, EmptyDashboardComponent = QuillEmptyDashboardComponent, DateRangePickerComponent = QuillDateRangePicker, MetricComponent = QuillMetricComponent, ChartComponent = QuillChartComponent, TableComponent = QuillTableComponent, TemplateMetricComponent = QuillTemplateMetricComponent, TemplateChartComponent = QuillTemplateChartComponent, TemplateTableComponent = QuillTemplateTableComponent, DashboardSectionComponent = DashboardSection, DashboardSectionContainerComponent = DashboardSectionContainer, FilterContainerComponent = QuillFilterContainerComponent, DashboardLoadingComponent = QuillLoadingDashboardComponent, ErrorComponent = QuillChartErrorWithAction, onClickReport, hoverActions, onChangeLoading, hideFilters, hideXAxis = false, hideYAxis = false, hideCartesianGrid = false, comparisonLineStyle = 'solid', containerStyle, className, chartContainerStyle = defaultChartContainerStyles, filters, onUserFiltersUpdated, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors = true, templateDashboardName, pagination = { rowsPerPage: 10, rowsPerRequest: 50 }, }) {
114
+ const [userFilters, setUserFilters] = useState({});
115
+ useEffect(() => {
116
+ onUserFiltersUpdated?.(Object.values(userFilters));
117
+ }, [userFilters]);
118
+ const { isLoading, data, isDashboardFilterLoading, dashboardFilters: populatedDashboardFilters, reload, } = useDashboard(name, (filters?.map((f) => convertCustomFilter(f)) ?? []).concat(Object.values(userFilters) ?? []));
119
+ const mounted = useRef(false);
120
+ useEffect(() => {
121
+ if (!mounted.current) {
122
+ mounted.current = true;
123
+ return;
124
+ }
125
+ reload(name, false, undefined, {
126
+ filters: populatedDashboardFilters ?? [],
127
+ });
128
+ }, [filters, userFilters]);
118
129
  const [client, isClientLoading] = useContext(ClientContext);
119
130
  const [theme] = useContext(ThemeContext);
120
131
  const [schemaData] = useContext(SchemaDataContext);
@@ -131,8 +142,10 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
131
142
  return {
132
143
  label: elem.label,
133
144
  value: elem.value,
134
- startDate: PRIMARY_RANGE[elem.value].start,
135
- endDate: PRIMARY_RANGE[elem.value].end,
145
+ startDate: PRIMARY_RANGE[elem.value]?.startDate ??
146
+ PRIMARY_RANGE['LAST_30_DAYS'].startDate,
147
+ endDate: PRIMARY_RANGE[elem.value]?.endDate ??
148
+ PRIMARY_RANGE['LAST_30_DAYS'].endDate,
136
149
  };
137
150
  }
138
151
  return {
@@ -144,10 +157,11 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
144
157
  }) ?? defaultOptionsV2)
145
158
  : defaultOptionsV2;
146
159
  }, [populatedDashboardFilters]);
147
- const [userFilters, setUserFilters] = useState({});
148
160
  // A filter value can either be a string, an array of strings for a multiselect, or a date range (that could have a comparison range)
149
161
  const [filterValues, setFilterValues] = useState({});
150
162
  const prevClientIdRef = useRef(undefined);
163
+ const addFilterPopoverButtonRef = useRef(null);
164
+ const viewFiltersPopoverButtonRef = useRef(null);
151
165
  useEffect(() => {
152
166
  setFilterValues({});
153
167
  const clientIdChanged = prevClientIdRef.current !== client?.organizationId;
@@ -191,12 +205,7 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
191
205
  .flatMap((section) => section.map((chart) => chart.referencedTables))
192
206
  .flat();
193
207
  if (tables && tables.length > 0) {
194
- let intersection = new Set(tables[0]);
195
- for (let i = 1; i < tables.length; ++i) {
196
- const currentSet = new Set(tables[i]);
197
- intersection = new Set(Array.from(intersection).filter((value) => currentSet.has(value)));
198
- }
199
- const tablesList = Array.from(intersection);
208
+ const tablesList = Array.from(new Set(tables));
200
209
  setReferencedTables(tablesList);
201
210
  // get all columns from the intersected tables
202
211
  const columns = tablesList
@@ -220,7 +229,7 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
220
229
  }
221
230
  }, [data?.sections, schemaData.schema]);
222
231
  const handleOnClickDashboardItem = (elem) => onClickReport && onClickReport({ ...elem, _id: elem.id });
223
- const updateFilter = (filter, value = null, comparison = null) => {
232
+ const updateFilter = (filter, value, comparison) => {
224
233
  if (!populatedDashboardFilters)
225
234
  return;
226
235
  let filterValue = {};
@@ -253,23 +262,25 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
253
262
  const key = comparison?.value ||
254
263
  (filter.comparisonRange?.value ?? 'NO_COMPARISON');
255
264
  let primaryRange = {
256
- start: value ? value.startDate : filter.startDate,
257
- end: value ? value.endDate : filter.endDate,
265
+ startDate: value ? value.startDate : filter.startDate,
266
+ endDate: value ? value.endDate : filter.endDate,
258
267
  };
259
268
  if (value && value.preset) {
260
269
  preset = value.preset;
261
270
  primaryRange = getRangeFromPresetOptions(value.preset, presetOptions);
262
271
  }
263
272
  filterValue = {
264
- startDate: primaryRange.start,
265
- endDate: primaryRange.end,
273
+ startDate: primaryRange.startDate,
274
+ endDate: primaryRange.endDate,
266
275
  preset: {
267
276
  label: presetOptions.find((o) => o.value === preset)?.label ?? preset,
268
277
  value: preset,
269
278
  },
270
279
  comparisonRange: {
271
- startDate: COMPARISON_RANGE[key](primaryRange)?.start,
272
- endDate: COMPARISON_RANGE[key](primaryRange)?.end,
280
+ startDate: COMPARISON_RANGE[key](primaryRange)
281
+ ?.startDate,
282
+ endDate: COMPARISON_RANGE[key](primaryRange)
283
+ ?.endDate,
273
284
  value: key,
274
285
  },
275
286
  };
@@ -282,14 +293,17 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
282
293
  const primaryRange = value && value.preset
283
294
  ? getRangeFromPresetOptions(value.preset, presetOptions)
284
295
  : {
285
- start: value?.startDate || filter.startDate,
286
- end: value?.endDate || filter.endDate,
296
+ startDate: value?.startDate || filter.startDate,
297
+ endDate: value?.endDate || filter.endDate,
287
298
  };
288
299
  const preset = value?.preset ? value.preset : '';
289
300
  filterValue = {
290
- startDate: primaryRange.start,
291
- endDate: primaryRange.end,
292
- preset: { label: preset, value: preset },
301
+ startDate: primaryRange.startDate,
302
+ endDate: primaryRange.endDate,
303
+ preset: {
304
+ label: presetOptions.find((o) => o.value === preset)?.label ?? preset,
305
+ value: preset,
306
+ },
293
307
  };
294
308
  setFilterValues((filterValues) => ({
295
309
  ...filterValues,
@@ -344,31 +358,25 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
344
358
  if (hidden || isLoading || isClientLoading || !data?.sections) {
345
359
  return (_jsx(DashboardLoadingComponent, { containerStyle: containerStyle, chartContainerStyle: chartContainerStyle }));
346
360
  }
347
- return (_jsxs("div", { className: className, ...styleToProps(containerStyle), children: [data &&
348
- data.customFiltersEnabled &&
349
- !hideAdminErrors &&
350
- !hideFilters &&
351
- data &&
352
- data.customFiltersEnabled &&
353
- filterSchema &&
354
- filterSchema.columns.length === 0 && (_jsx("div", { style: { marginBottom: 10 }, children: _jsx(QuillErrorMessageComponent, { errorMessage: "Warning: No custom filter options because there are no common views among the charts in the dashboard" }) })), _jsxs("div", { style: { display: 'flex', flexDirection: 'row', alignItems: 'center' }, children: [!hideFilters && (_jsxs(FilterContainerComponent, { children: [(populatedDashboardFilters ?? []).map((filter) => (_jsx(DashboardFilter, { filter: {
361
+ return (_jsxs("div", { className: className, ...styleToProps(containerStyle), children: [_jsxs("div", { style: { display: 'flex', flexDirection: 'row', alignItems: 'center' }, children: [!hideFilters && (_jsxs(FilterContainerComponent, { children: [(populatedDashboardFilters ?? []).map((filter) => (_jsx(DashboardFilter, { filter: {
355
362
  ...filter,
356
363
  ...(filter.filterType === 'date_range' && {
357
364
  options: presetOptions,
358
365
  }),
359
366
  ...filterValues[filter.label],
360
- }, onChangeFilter: updateFilter, theme: theme, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, DateRangePickerComponent: DateRangePickerComponent, isLoading: isDashboardFilterLoading(filter.label) }, filter.label + name))), _jsxs("div", { style: {
367
+ }, onChangeFilter: updateFilter, theme: theme, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, DateRangePickerComponent: DateRangePickerComponent, isLoading: isDashboardFilterLoading(filter.label) }, filter.label + name))), data?.customFiltersEnabled &&
368
+ Object.values(userFilters).length === 0 && (_jsxs("div", { style: {
361
369
  display: 'flex',
362
370
  flexDirection: 'column',
363
- }, children: [data && data.customFiltersEnabled && (_jsx(SecondaryButtonComponent, { onClick: () => {
371
+ }, ref: viewFiltersPopoverButtonRef, children: [_jsx(SecondaryButtonComponent, { onClick: () => {
364
372
  if (fieldValuesIsLoaded) {
365
- setAddFilterPopoverIsOpen(true);
373
+ setAddFilterPopoverIsOpen(!addFilterPopoverIsOpen);
366
374
  setFilterListIsOpen(false);
367
375
  }
368
- }, label: `Add Filter` })), _jsx(PopoverComponent, { isOpen: addFilterPopoverIsOpen, setIsOpen: setAddFilterPopoverIsOpen, popoverTitle: "Add Filter", popoverChildren: _jsx(FilterModal, { schema: filterSchema, fieldValuesMap: fieldValuesMap, onSubmitFilter: (filter) => {
376
+ }, label: `Add Filter` }), _jsx(PopoverComponent, { isOpen: addFilterPopoverIsOpen, setIsOpen: setAddFilterPopoverIsOpen, popoverTitle: "Add Filter", ignoredRefs: [viewFiltersPopoverButtonRef], popoverChildren: _jsx(FilterModal, { schema: filterSchema, fieldValuesMap: fieldValuesMap, onSubmitFilter: (filter) => {
369
377
  setAddFilterPopoverIsOpen(false);
370
378
  updateUserFilter(filter);
371
- }, onDeleteFilter: () => { }, ButtonComponent: ButtonComponent, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, TextInputComponent: TextInputComponent }), containerStyle: { position: 'relative', top: 10 } })] }), Object.values(userFilters).length > 0 && (_jsx(ModalComponent, { triggerLabel: `Filters${Object.values(userFilters).length > 0 ? ` (${Object.values(userFilters).length})` : ''}`, isOpen: filterListIsOpen, setIsOpen: setFilterListIsOpen, title: "Filters", children: _jsxs("div", { style: {
379
+ }, onDeleteFilter: () => { }, ButtonComponent: ButtonComponent, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, TextInputComponent: TextInputComponent }), containerStyle: { position: 'relative', top: 10 } })] })), Object.values(userFilters).length > 0 && (_jsx(ModalComponent, { triggerLabel: `Filters${Object.values(userFilters).length > 0 ? ` (${Object.values(userFilters).length})` : ''}`, isOpen: filterListIsOpen, setIsOpen: setFilterListIsOpen, title: "Filters", children: _jsxs("div", { style: {
372
380
  display: 'flex',
373
381
  flexDirection: 'column',
374
382
  alignItems: 'start',
@@ -379,14 +387,8 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
379
387
  operator: filter.operator,
380
388
  value: filter.value,
381
389
  }, filterLabel: filter ? filterSentence(filter) : '', index: index, fieldValuesMap: fieldValuesMap, customOperatorOptions: customOperatorOptions, FilterTagComponent: FilterTagComponent, FilterModal: FilterModal, ButtonComponent: ButtonComponent, SecondaryButtonComponent: SecondaryButtonComponent, SelectComponent: SelectComponent, TextInputComponent: TextInputComponent, MultiSelectComponent: MultiSelectComponent, handleFilterSave: (newFilter) => {
382
- // TODO: Implement user filters with new filter structure
383
- getUserFilter(newFilter, filter._id, filter);
384
- // console.log('updated filter', updatedFilter);
385
- // dashboardFiltersDispatch({
386
- // type: 'UPDATE_DASHBOARD_FILTER',
387
- // id: updatedFilter.id,
388
- // data: updatedFilter,
389
- // });
390
+ const userFilter = getUserFilter(newFilter, filter._id, filter);
391
+ updateUserFilter(userFilter);
390
392
  }, handleFilterDelete: () => {
391
393
  setUserFilters((userFilters) => {
392
394
  const updatedFilters = { ...userFilters };
@@ -396,15 +398,23 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
396
398
  }, containerStyle: { width: 300, marginBottom: 10 } }, `userFilter_${index}_${filter ? filterSentence(filter) : ''}`))), _jsxs("div", { style: {
397
399
  display: 'flex',
398
400
  flexDirection: 'column',
399
- }, children: [_jsx(SecondaryButtonComponent, { onClick: () => {
401
+ }, ref: addFilterPopoverButtonRef, children: [_jsx(SecondaryButtonComponent, { onClick: () => {
400
402
  if (fieldValuesIsLoaded) {
401
- setFilterListAddFilterPopoverIsOpen(true);
403
+ setFilterListAddFilterPopoverIsOpen(!filterListAddFilterPopoverIsOpen);
402
404
  }
403
- }, label: `Add Filter` }), _jsx(PopoverComponent, { isOpen: filterListAddFilterPopoverIsOpen, setIsOpen: setFilterListAddFilterPopoverIsOpen, popoverTitle: "Add Filter", popoverChildren: _jsx(FilterModal, { schema: filterSchema, fieldValuesMap: fieldValuesMap, onSubmitFilter: (filter) => {
405
+ }, label: `Add Filter` }), _jsx(PopoverComponent, { isOpen: filterListAddFilterPopoverIsOpen, setIsOpen: setFilterListAddFilterPopoverIsOpen, popoverTitle: "Add Filter", ignoredRefs: [addFilterPopoverButtonRef], popoverChildren: _jsx(FilterModal, { schema: filterSchema, fieldValuesMap: fieldValuesMap, onSubmitFilter: (filter) => {
404
406
  setFilterListAddFilterPopoverIsOpen(false);
405
407
  setFilterListIsOpen(false);
406
408
  updateUserFilter(filter);
407
- }, onDeleteFilter: () => { }, ButtonComponent: ButtonComponent, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, TextInputComponent: TextInputComponent }), containerStyle: { position: 'relative', top: 10 } })] })] }) }))] })), templateDashboardName && (_jsx(QuillDashboardTemplate, { name: templateDashboardName, originDashboard: name, client: client, appliedFilters: populatedDashboardFilters, ModalComponent: ModalComponent, TemplateChartComponent: TemplateChartComponent, TemplateMetricComponent: TemplateMetricComponent, TemplateTableComponent: TemplateTableComponent, ButtonComponent: SecondaryButtonComponent }))] }), Object.keys(data.sections)
409
+ }, onDeleteFilter: () => { }, ButtonComponent: ButtonComponent, SelectComponent: SelectComponent, MultiSelectComponent: MultiSelectComponent, TextInputComponent: TextInputComponent }), containerStyle: { position: 'relative', top: 10 } })] })] }) }))] })), templateDashboardName && (_jsx(QuillDashboardTemplate, { name: templateDashboardName, originDashboard: name, client: client, appliedFilters: populatedDashboardFilters, ModalComponent: ModalComponent, TemplateChartComponent: TemplateChartComponent, TemplateMetricComponent: TemplateMetricComponent, TemplateTableComponent: TemplateTableComponent, ButtonComponent: SecondaryButtonComponent }))] }), data &&
410
+ data.customFiltersEnabled &&
411
+ !hideAdminErrors &&
412
+ !hideFilters &&
413
+ filterSchema.columns.length === 0 && (_jsx(QuillErrorMessageComponent, { errorMessage: "No custom filter options because there are no common views among the charts in the dashboard", containerStyle: {
414
+ marginBottom: 16,
415
+ marginTop: -6,
416
+ maxWidth: 'fit-content',
417
+ } })), Object.keys(data.sections)
408
418
  .sort(function (a, b) {
409
419
  return a.length - b.length;
410
420
  })
@@ -418,7 +428,7 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
418
428
  textAlign: 'left',
419
429
  marginTop: 12,
420
430
  }, children: section })] })), metrics(data.sections, section, sortByOrdering).length > 0 && (_jsx(DashboardSectionComponent, { section: "metrics", children: metrics(data.sections, section, sortByOrdering).map((item) => {
421
- return (_jsx(DataLoader, { item: item, filters: populatedDashboardFilters, additionalProcessing: {
431
+ return (_jsx(DataLoader, { item: item, filters: populatedDashboardFilters ?? [], userFilters: (filters?.map((f) => convertCustomFilter(f)) ?? []).concat(Object.values(userFilters)), additionalProcessing: {
422
432
  page: DEFAULT_PAGINATION,
423
433
  last: additionalProcessing?.last,
424
434
  }, children: ({ isLoading, error, data, }) => (_jsx(MetricComponent, { error: error, isLoading: isLoading, report: data, onClick: !isLoading && onClickReport
@@ -430,7 +440,7 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
430
440
  }) })), charts(data.sections, section, sortByOrdering).length > 0 && (_jsx(DashboardSectionComponent, { section: "charts", children: charts(data.sections, section, sortByOrdering).map((item) => (_jsx(ChartDataLoader, { item: item, dateBucket: dateBucket, additionalProcessing: {
431
441
  page: pagination,
432
442
  last: additionalProcessing?.last,
433
- }, filters: populatedDashboardFilters, children: ({ isLoading, data, error, dateBucket, }) => (_jsx(ChartComponent, { report: data, error: error, onClick: () => {
443
+ }, filters: populatedDashboardFilters ?? [], userFilters: (filters?.map((f) => convertCustomFilter(f)) ?? []).concat(Object.values(userFilters)), children: ({ isLoading, data, error, dateBucket, }) => (_jsx(ChartComponent, { report: data, error: error, onClick: () => {
434
444
  if (!isLoading && onClickReport) {
435
445
  handleOnClickDashboardItem({
436
446
  ...item,
@@ -442,7 +452,7 @@ filters, onClickChartElement, dateBucket, additionalProcessing, hideAdminErrors
442
452
  height: 300,
443
453
  } })) : (_jsx(ChartDisplay, { reportId: data.id, config: data, loading: isLoading, containerStyle: chartContainerStyle, colors: theme.chartColors?.length
444
454
  ? theme.chartColors
445
- : undefined, scrollable: false, hideXAxis: hideXAxis, hideYAxis: hideYAxis, hideCartesianGrid: hideCartesianGrid, comparisonLineStyle: comparisonLineStyle, onClickChartElement: onClickChartElement })) }, 'chart' + item.name + '' + item.id)) }, `chart${item.id}`))) })), tables(data.sections, section, sortByOrdering).length > 0 && (_jsx(DashboardSectionComponent, { section: "tables", children: tables(data.sections, section, sortByOrdering).map((item) => (_jsx(DataLoader, { item: item, filters: populatedDashboardFilters, additionalProcessing: {
455
+ : undefined, scrollable: false, hideXAxis: hideXAxis, hideYAxis: hideYAxis, hideCartesianGrid: hideCartesianGrid, comparisonLineStyle: comparisonLineStyle, onClickChartElement: onClickChartElement })) }, 'chart' + item.name + '' + item.id)) }, `chart${item.id}`))) })), tables(data.sections, section, sortByOrdering).length > 0 && (_jsx(DashboardSectionComponent, { section: "tables", children: tables(data.sections, section, sortByOrdering).map((item) => (_jsx(DataLoader, { item: item, filters: populatedDashboardFilters ?? [], userFilters: (filters?.map((f) => convertCustomFilter(f)) ?? []).concat(Object.values(userFilters)), additionalProcessing: {
446
456
  page: pagination,
447
457
  last: additionalProcessing?.last,
448
458
  }, children: ({ isLoading, error, onPageChange, onSortChange, data, rowCount, rowCountIsLoading, }) => (_jsx(TableComponent, { report: data, isLoading: isLoading, error: error, onClick: !isLoading && onClickReport
@@ -4,8 +4,8 @@ export interface DateRangePickerComponentProps {
4
4
  label?: string;
5
5
  selectWidth?: number;
6
6
  dateRange: {
7
- startDate: Date;
8
- endDate: Date;
7
+ startDate?: Date;
8
+ endDate?: Date;
9
9
  };
10
10
  presetOptions: {
11
11
  label: string;
@@ -1 +1 @@
1
- {"version":3,"file":"QuillDateRangePicker.d.ts","sourceRoot":"","sources":["../../../src/DateRangePicker/QuillDateRangePicker.tsx"],"names":[],"mappings":"AAAA,OAAc,EACZ,WAAW,EAKZ,MAAM,OAAO,CAAC;AAmBf,MAAM,WAAW,6BAA6B;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE;QAAE,SAAS,EAAE,IAAI,CAAC;QAAC,OAAO,EAAE,IAAI,CAAA;KAAE,CAAC;IAC9C,aAAa,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAClD,iBAAiB,EAAE,CAAC,EAClB,SAAS,EACT,OAAO,GACR,EAAE;QACD,SAAS,EAAE,IAAI,CAAC;QAChB,OAAO,EAAE,IAAI,CAAC;KACf,KAAK,IAAI,CAAC;IACX,cAAc,EAAE,CAAC,KAAK,EAAE,WAAW,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAChE,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,MAAM,SAAS,GAAG;IACtB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,EACnC,SAAS,EACT,iBAAiB,EACjB,aAAa,EACb,cAAc,EACd,MAAM,EACN,KAAK,EACL,WAAW,EACX,UAAU,GACX,EAAE,6BAA6B,2CAoJ/B"}
1
+ {"version":3,"file":"QuillDateRangePicker.d.ts","sourceRoot":"","sources":["../../../src/DateRangePicker/QuillDateRangePicker.tsx"],"names":[],"mappings":"AAAA,OAAc,EACZ,WAAW,EAKZ,MAAM,OAAO,CAAC;AAmBf,MAAM,WAAW,6BAA6B;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,EAAE;QAAE,SAAS,CAAC,EAAE,IAAI,CAAC;QAAC,OAAO,CAAC,EAAE,IAAI,CAAA;KAAE,CAAC;IAChD,aAAa,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAClD,iBAAiB,EAAE,CAAC,EAClB,SAAS,EACT,OAAO,GACR,EAAE;QACD,SAAS,EAAE,IAAI,CAAC;QAChB,OAAO,EAAE,IAAI,CAAC;KACf,KAAK,IAAI,CAAC;IACX,cAAc,EAAE,CAAC,KAAK,EAAE,WAAW,CAAC,iBAAiB,CAAC,KAAK,IAAI,CAAC;IAChE,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,MAAM,SAAS,GAAG;IACtB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;IACb,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AAEF;;GAEG;AACH,wBAAgB,oBAAoB,CAAC,EACnC,SAAS,EACT,iBAAiB,EACjB,aAAa,EACb,cAAc,EACd,MAAM,EACN,KAAK,EACL,WAAW,EACX,UAAU,GACX,EAAE,6BAA6B,2CAoJ/B"}
@@ -9,8 +9,8 @@ export declare const parseEndDate: (endDate: Date | null | undefined, maxDate: D
9
9
  * A simple date range that spans from start to end.
10
10
  */
11
11
  type QuillDateRange = {
12
- start: Date;
13
- end: Date;
12
+ startDate: Date;
13
+ endDate: Date;
14
14
  };
15
15
  /**
16
16
  * A simple map between the primary range key and the QuillDateRange for that
@@ -18,8 +18,8 @@ type QuillDateRange = {
18
18
  */
19
19
  export declare const PRIMARY_RANGE: {
20
20
  [key: string]: QuillDateRange | {
21
- start: undefined;
22
- end: undefined;
21
+ startDate: undefined;
22
+ endDate: undefined;
23
23
  };
24
24
  };
25
25
  /**
@@ -38,21 +38,21 @@ export declare const COMPARISON_OPTIONS: {
38
38
  * comparison range) and returns a QuillDateRange based on that key and date.
39
39
  */
40
40
  export declare const COMPARISON_RANGE: {
41
- readonly PREV_PERIOD: ({ start, end }: QuillDateRange) => {
42
- start: Date;
43
- end: Date;
41
+ readonly PREV_PERIOD: ({ startDate, endDate }: QuillDateRange) => {
42
+ startDate: Date;
43
+ endDate: Date;
44
44
  };
45
- readonly PREV_7_DAYS: ({ start }: QuillDateRange) => {
46
- start: Date;
47
- end: Date;
45
+ readonly PREV_7_DAYS: ({ startDate }: QuillDateRange) => {
46
+ startDate: Date;
47
+ endDate: Date;
48
48
  };
49
- readonly PREV_30_DAYS: ({ start }: QuillDateRange) => {
50
- start: Date;
51
- end: Date;
49
+ readonly PREV_30_DAYS: ({ startDate }: QuillDateRange) => {
50
+ startDate: Date;
51
+ endDate: Date;
52
52
  };
53
- readonly PREV_90_DAYS: ({ start }: QuillDateRange) => {
54
- start: Date;
55
- end: Date;
53
+ readonly PREV_90_DAYS: ({ startDate }: QuillDateRange) => {
54
+ startDate: Date;
55
+ endDate: Date;
56
56
  };
57
57
  readonly NO_COMPARISON: () => null;
58
58
  };
@@ -67,11 +67,11 @@ export declare const getRangeFromPresetOptions: (preset: string, presetOptions:
67
67
  startDate: Date;
68
68
  endDate: Date;
69
69
  }[]) => {
70
- start: Date;
71
- end: Date;
70
+ startDate: Date;
71
+ endDate: Date;
72
72
  } | {
73
- start: null;
74
- end: null;
73
+ startDate: null;
74
+ endDate: null;
75
75
  };
76
76
  export declare const getDateStyles: (theme: any, date: Date, finalStartDate: Date | null, finalEndDate: Date | null, hoveredDate: Date | undefined, isDateDisabled: boolean) => any;
77
77
  export declare const displaySelected: (selectedStartDay: Date | null, selectedEndDay: Date | null) => string | undefined;
@@ -1 +1 @@
1
- {"version":3,"file":"dateRangePickerUtils.d.ts","sourceRoot":"","sources":["../../../src/DateRangePicker/dateRangePickerUtils.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAG/D,eAAO,MAAM,WAAW,WAAY,MAAM,aAKzC,CAAC;AAEF,eAAO,MAAM,UAAU,MAAO,MAAM,UAAU,MAAM,WAEnD,CAAC;AAEF,eAAO,MAAM,2BAA2B,kBACvB,MAAM,GAAG,IAAI,GAAG,SAAS,oBACtB,qBAAqB,EAAE,gBAU1C,CAAC;AAEF,eAAO,MAAM,yBAAyB,kBACrB,MAAM,GAAG,IAAI,GAAG,SAAS,oBACtB,qBAAqB,EAAE,SAU1C,CAAC;AAEF,eAAO,MAAM,cAAc,cACd,IAAI,GAAG,IAAI,GAAG,SAAS,WACzB,IAAI,GAAG,IAAI,GAAG,SAAS,yBACT,MAAM,GAAG,IAAI,GAAG,SAAS,mBAC/B,qBAAqB,EAAE,gBAWzC,CAAC;AAEF,eAAO,MAAM,YAAY,YACd,IAAI,GAAG,IAAI,GAAG,SAAS,WACvB,IAAI,GAAG,IAAI,GAAG,SAAS,yBACT,MAAM,GAAG,IAAI,GAAG,SAAS,mBAC/B,qBAAqB,EAAE,gBASzC,CAAC;AAEF;;GAEG;AACH,KAAK,cAAc,GAAG;IACpB,KAAK,EAAE,IAAI,CAAC;IACZ,GAAG,EAAE,IAAI,CAAC;CACX,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,aAAa,EAAE;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,cAAc,GAAG;QAAE,KAAK,EAAE,SAAS,CAAC;QAAC,GAAG,EAAE,SAAS,CAAA;KAAE,CAAC;CAatE,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,aAAa,EAAE;IAAE,CAAC,GAAG,EAAE,MAAM,OAAO,aAAa,GAAG,MAAM,CAAA;CAStE,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,EAqBA,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,gBAAgB;2CACG,cAAc;;;;sCAInB,cAAc;;;;uCAIb,cAAc;;;;uCAId,cAAc;;;;;CAKhC,CAAC;AACX,MAAM,MAAM,kBAAkB,GAAG,MAAM,OAAO,gBAAgB,CAAC;AAE/D,eAAO,MAAM,gBAAgB,EAAE,GAAG,EAiDjC,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,qBAAqB,EAyCjD,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,qBAAqB,EA+BvD,CAAC;AAEF,eAAO,MAAM,kBAAkB,WAAY,MAAM,6BAOhD,CAAC;AAEF,eAAO,MAAM,yBAAyB,WAC5B,MAAM,iBACC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf,EAAE;;;;;;CAQJ,CAAC;AAEF,eAAO,MAAM,aAAa,UACjB,GAAG,QACJ,IAAI,kBACM,IAAI,GAAG,IAAI,gBACb,IAAI,GAAG,IAAI,eACZ,IAAI,GAAG,SAAS,kBACb,OAAO,QAgCxB,CAAC;AAkGF,eAAO,MAAM,eAAe,qBACR,IAAI,GAAG,IAAI,kBACb,IAAI,GAAG,IAAI,uBA0C5B,CAAC;AAmGF,eAAO,MAAM,mBAAmB,cACnB,IAAI,GAAG,IAAI,WACb,IAAI,GAAG,IAAI,WACX,MAAM,WAyChB,CAAC"}
1
+ {"version":3,"file":"dateRangePickerUtils.d.ts","sourceRoot":"","sources":["../../../src/DateRangePicker/dateRangePickerUtils.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAG/D,eAAO,MAAM,WAAW,WAAY,MAAM,aAKzC,CAAC;AAEF,eAAO,MAAM,UAAU,MAAO,MAAM,UAAU,MAAM,WAEnD,CAAC;AAEF,eAAO,MAAM,2BAA2B,kBACvB,MAAM,GAAG,IAAI,GAAG,SAAS,oBACtB,qBAAqB,EAAE,gBAU1C,CAAC;AAEF,eAAO,MAAM,yBAAyB,kBACrB,MAAM,GAAG,IAAI,GAAG,SAAS,oBACtB,qBAAqB,EAAE,SAU1C,CAAC;AAEF,eAAO,MAAM,cAAc,cACd,IAAI,GAAG,IAAI,GAAG,SAAS,WACzB,IAAI,GAAG,IAAI,GAAG,SAAS,yBACT,MAAM,GAAG,IAAI,GAAG,SAAS,mBAC/B,qBAAqB,EAAE,gBAWzC,CAAC;AAEF,eAAO,MAAM,YAAY,YACd,IAAI,GAAG,IAAI,GAAG,SAAS,WACvB,IAAI,GAAG,IAAI,GAAG,SAAS,yBACT,MAAM,GAAG,IAAI,GAAG,SAAS,mBAC/B,qBAAqB,EAAE,gBASzC,CAAC;AAEF;;GAEG;AACH,KAAK,cAAc,GAAG;IACpB,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,aAAa,EAAE;IAC1B,CAAC,GAAG,EAAE,MAAM,GAAG,cAAc,GAAG;QAAE,SAAS,EAAE,SAAS,CAAC;QAAC,OAAO,EAAE,SAAS,CAAA;KAAE,CAAC;CAyB9E,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,aAAa,EAAE;IAAE,CAAC,GAAG,EAAE,MAAM,OAAO,aAAa,GAAG,MAAM,CAAA;CAStE,CAAC;AAEF,eAAO,MAAM,kBAAkB,EAAE;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,CAAC;CACd,EAqBA,CAAC;AAEF;;;;GAIG;AACH,eAAO,MAAM,gBAAgB;mDACW,cAAc;;;;0CAIvB,cAAc;;;;2CAIb,cAAc;;;;2CAId,cAAc;;;;;CAKpC,CAAC;AACX,MAAM,MAAM,kBAAkB,GAAG,MAAM,OAAO,gBAAgB,CAAC;AAE/D,eAAO,MAAM,gBAAgB,EAAE,GAAG,EAiDjC,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,qBAAqB,EAyCjD,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,qBAAqB,EA+BvD,CAAC;AAEF,eAAO,MAAM,kBAAkB,WAAY,MAAM,6BAOhD,CAAC;AAEF,eAAO,MAAM,yBAAyB,WAC5B,MAAM,iBACC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,IAAI,CAAC;IAChB,OAAO,EAAE,IAAI,CAAC;CACf,EAAE;;;;;;CAQJ,CAAC;AAEF,eAAO,MAAM,aAAa,UACjB,GAAG,QACJ,IAAI,kBACM,IAAI,GAAG,IAAI,gBACb,IAAI,GAAG,IAAI,eACZ,IAAI,GAAG,SAAS,kBACb,OAAO,QAgCxB,CAAC;AAkGF,eAAO,MAAM,eAAe,qBACR,IAAI,GAAG,IAAI,kBACb,IAAI,GAAG,IAAI,uBA0C5B,CAAC;AAmGF,eAAO,MAAM,mBAAmB,cACnB,IAAI,GAAG,IAAI,WACb,IAAI,GAAG,IAAI,WACX,MAAM,WAyChB,CAAC"}
@@ -45,17 +45,29 @@ export const parseEndDate = (endDate, maxDate, selectedDropdownValue, dropdownOp
45
45
  * key ending on today.
46
46
  */
47
47
  export const PRIMARY_RANGE = {
48
- THIS_WEEK: { start: startOfWeek(startOfToday()), end: endOfToday() },
49
- THIS_MONTH: { start: startOfMonth(startOfToday()), end: endOfToday() },
50
- THIS_YEAR: { start: startOfYear(startOfToday()), end: endOfToday() },
51
- LAST_7_DAYS: { start: sub(startOfToday(), { days: 7 }), end: endOfToday() },
52
- LAST_30_DAYS: { start: sub(startOfToday(), { days: 30 }), end: endOfToday() },
53
- LAST_90_DAYS: { start: sub(startOfToday(), { days: 90 }), end: endOfToday() },
48
+ THIS_WEEK: { startDate: startOfWeek(startOfToday()), endDate: endOfToday() },
49
+ THIS_MONTH: {
50
+ startDate: startOfMonth(startOfToday()),
51
+ endDate: endOfToday(),
52
+ },
53
+ THIS_YEAR: { startDate: startOfYear(startOfToday()), endDate: endOfToday() },
54
+ LAST_7_DAYS: {
55
+ startDate: sub(startOfToday(), { days: 7 }),
56
+ endDate: endOfToday(),
57
+ },
58
+ LAST_30_DAYS: {
59
+ startDate: sub(startOfToday(), { days: 30 }),
60
+ endDate: endOfToday(),
61
+ },
62
+ LAST_90_DAYS: {
63
+ startDate: sub(startOfToday(), { days: 90 }),
64
+ endDate: endOfToday(),
65
+ },
54
66
  LAST_6_MONTHS: {
55
- start: sub(startOfToday(), { months: 6 }),
56
- end: endOfToday(),
67
+ startDate: sub(startOfToday(), { months: 6 }),
68
+ endDate: endOfToday(),
57
69
  },
58
- ALL_TIME: { start: undefined, end: undefined },
70
+ ALL_TIME: { startDate: undefined, endDate: undefined },
59
71
  };
60
72
  /**
61
73
  * Maps between the keys of primary range and the short code.
@@ -98,21 +110,21 @@ export const COMPARISON_OPTIONS = [
98
110
  * comparison range) and returns a QuillDateRange based on that key and date.
99
111
  */
100
112
  export const COMPARISON_RANGE = {
101
- PREV_PERIOD: ({ start, end }) => ({
102
- start: sub(start, { days: differenceInDays(end, start) }),
103
- end: start,
113
+ PREV_PERIOD: ({ startDate, endDate }) => ({
114
+ startDate: sub(startDate, { days: differenceInDays(endDate, startDate) }),
115
+ endDate: startDate,
104
116
  }),
105
- PREV_7_DAYS: ({ start }) => ({
106
- start: sub(start, { days: 7 }),
107
- end: start,
117
+ PREV_7_DAYS: ({ startDate }) => ({
118
+ startDate: sub(startDate, { days: 7 }),
119
+ endDate: startDate,
108
120
  }),
109
- PREV_30_DAYS: ({ start }) => ({
110
- start: sub(start, { days: 30 }),
111
- end: start,
121
+ PREV_30_DAYS: ({ startDate }) => ({
122
+ startDate: sub(startDate, { days: 30 }),
123
+ endDate: startDate,
112
124
  }),
113
- PREV_90_DAYS: ({ start }) => ({
114
- start: sub(start, { days: 90 }),
115
- end: start,
125
+ PREV_90_DAYS: ({ startDate }) => ({
126
+ startDate: sub(startDate, { days: 90 }),
127
+ endDate: startDate,
116
128
  }),
117
129
  NO_COMPARISON: () => null,
118
130
  };
@@ -120,123 +132,123 @@ export const defaultOptionsV2 = [
120
132
  {
121
133
  value: 'THIS_WEEK',
122
134
  label: 'This week',
123
- startDate: PRIMARY_RANGE['THIS_WEEK']?.start,
124
- endDate: PRIMARY_RANGE['THIS_WEEK']?.end,
135
+ startDate: PRIMARY_RANGE['THIS_WEEK']?.startDate,
136
+ endDate: PRIMARY_RANGE['THIS_WEEK']?.endDate,
125
137
  },
126
138
  {
127
139
  value: 'THIS_MONTH',
128
140
  label: 'This month',
129
- startDate: PRIMARY_RANGE['THIS_MONTH']?.start,
130
- endDate: PRIMARY_RANGE['THIS_MONTH']?.end,
141
+ startDate: PRIMARY_RANGE['THIS_MONTH']?.startDate,
142
+ endDate: PRIMARY_RANGE['THIS_MONTH']?.endDate,
131
143
  },
132
144
  {
133
145
  value: 'THIS_YEAR',
134
146
  label: 'This year',
135
- startDate: PRIMARY_RANGE['THIS_YEAR']?.start,
136
- endDate: PRIMARY_RANGE['THIS_YEAR']?.end,
147
+ startDate: PRIMARY_RANGE['THIS_YEAR']?.startDate,
148
+ endDate: PRIMARY_RANGE['THIS_YEAR']?.endDate,
137
149
  },
138
150
  {
139
151
  value: 'LAST_7_DAYS',
140
152
  label: 'Last 7 days',
141
- startDate: PRIMARY_RANGE['LAST_7_DAYS']?.start,
142
- endDate: PRIMARY_RANGE['LAST_7_DAYS']?.end,
153
+ startDate: PRIMARY_RANGE['LAST_7_DAYS']?.startDate,
154
+ endDate: PRIMARY_RANGE['LAST_7_DAYS']?.endDate,
143
155
  },
144
156
  {
145
157
  value: 'LAST_30_DAYS',
146
158
  label: 'Last 30 days',
147
- startDate: PRIMARY_RANGE['LAST_30_DAYS']?.start,
148
- endDate: PRIMARY_RANGE['LAST_30_DAYS']?.end,
159
+ startDate: PRIMARY_RANGE['LAST_30_DAYS']?.startDate,
160
+ endDate: PRIMARY_RANGE['LAST_30_DAYS']?.endDate,
149
161
  },
150
162
  {
151
163
  value: 'LAST_90_DAYS',
152
164
  label: 'Last 90 days',
153
- startDate: PRIMARY_RANGE['LAST_90_DAYS']?.start,
154
- endDate: PRIMARY_RANGE['LAST_90_DAYS']?.end,
165
+ startDate: PRIMARY_RANGE['LAST_90_DAYS']?.startDate,
166
+ endDate: PRIMARY_RANGE['LAST_90_DAYS']?.endDate,
155
167
  },
156
168
  {
157
169
  value: 'LAST_6_MONTHS',
158
170
  label: 'Last 6 months',
159
- startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.start,
160
- endDate: PRIMARY_RANGE['LAST_6_MONTHS']?.end,
171
+ startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.startDate,
172
+ endDate: PRIMARY_RANGE['LAST_6_MONTHS']?.endDate,
161
173
  },
162
174
  {
163
175
  value: 'ALL_TIME',
164
176
  label: 'All time',
165
- startDate: PRIMARY_RANGE['ALL_TIME']?.start,
166
- endDate: PRIMARY_RANGE['ALL_TIME']?.end,
177
+ startDate: PRIMARY_RANGE['ALL_TIME']?.startDate,
178
+ endDate: PRIMARY_RANGE['ALL_TIME']?.endDate,
167
179
  },
168
180
  ];
169
181
  export const defaultOptions = [
170
182
  {
171
183
  value: 'wk',
172
184
  text: 'This week',
173
- startDate: PRIMARY_RANGE['THIS_WEEK']?.start,
185
+ startDate: PRIMARY_RANGE['THIS_WEEK']?.startDate,
174
186
  },
175
187
  {
176
188
  value: 'm',
177
189
  text: 'This month',
178
- startDate: PRIMARY_RANGE['THIS_MONTH']?.start,
190
+ startDate: PRIMARY_RANGE['THIS_MONTH']?.startDate,
179
191
  },
180
192
  {
181
193
  value: 'y',
182
194
  text: 'This year',
183
- startDate: PRIMARY_RANGE['THIS_YEAR']?.start,
195
+ startDate: PRIMARY_RANGE['THIS_YEAR']?.startDate,
184
196
  },
185
197
  {
186
198
  value: 'w',
187
199
  text: 'Last 7 days',
188
- startDate: PRIMARY_RANGE['LAST_7_DAYS']?.start,
200
+ startDate: PRIMARY_RANGE['LAST_7_DAYS']?.startDate,
189
201
  },
190
202
  {
191
203
  value: 't',
192
204
  text: 'Last 30 days',
193
- startDate: PRIMARY_RANGE['LAST_30_DAYS']?.start,
205
+ startDate: PRIMARY_RANGE['LAST_30_DAYS']?.startDate,
194
206
  },
195
207
  {
196
208
  value: '90d',
197
209
  text: 'Last 90 days',
198
- startDate: PRIMARY_RANGE['LAST_90_DAYS']?.start,
210
+ startDate: PRIMARY_RANGE['LAST_90_DAYS']?.startDate,
199
211
  },
200
212
  {
201
213
  value: '6m',
202
214
  text: 'Last 6 months',
203
- startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.start,
215
+ startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.startDate,
204
216
  },
205
217
  {
206
218
  value: 'at',
207
219
  text: 'All time',
208
- startDate: PRIMARY_RANGE['ALL_TIME']?.start,
220
+ startDate: PRIMARY_RANGE['ALL_TIME']?.startDate,
209
221
  },
210
222
  ];
211
223
  export const reportBuilderOptions = [
212
224
  {
213
225
  value: 'w',
214
226
  text: 'Last 7 days',
215
- startDate: PRIMARY_RANGE['LAST_7_DAYS']?.start,
227
+ startDate: PRIMARY_RANGE['LAST_7_DAYS']?.startDate,
216
228
  dayInterval: 7,
217
229
  },
218
230
  {
219
231
  value: 't',
220
232
  text: 'Last 30 days',
221
- startDate: PRIMARY_RANGE['LAST_30_DAYS']?.start,
233
+ startDate: PRIMARY_RANGE['LAST_30_DAYS']?.startDate,
222
234
  dayInterval: 30,
223
235
  },
224
236
  {
225
237
  value: '90d',
226
238
  text: 'Last 90 days',
227
- startDate: PRIMARY_RANGE['LAST_90_DAYS']?.start,
239
+ startDate: PRIMARY_RANGE['LAST_90_DAYS']?.startDate,
228
240
  dayInterval: 90,
229
241
  },
230
242
  {
231
243
  value: '6m',
232
244
  text: 'Last 6 months',
233
- startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.start,
245
+ startDate: PRIMARY_RANGE['LAST_6_MONTHS']?.startDate,
234
246
  dayInterval: 180,
235
247
  },
236
248
  {
237
249
  value: 'at',
238
250
  text: 'All time',
239
- startDate: PRIMARY_RANGE['ALL_TIME']?.start,
251
+ startDate: PRIMARY_RANGE['ALL_TIME']?.startDate,
240
252
  dayInterval: 36500,
241
253
  },
242
254
  ];
@@ -251,10 +263,10 @@ export const getRangeFromPreset = (preset) => {
251
263
  export const getRangeFromPresetOptions = (preset, presetOptions) => {
252
264
  const foundPreset = presetOptions.find((elem) => elem.value === preset);
253
265
  if (foundPreset) {
254
- return { start: foundPreset?.startDate, end: foundPreset?.endDate };
266
+ return { startDate: foundPreset?.startDate, endDate: foundPreset?.endDate };
255
267
  }
256
268
  else {
257
- return { start: null, end: null };
269
+ return { startDate: null, endDate: null };
258
270
  }
259
271
  };
260
272
  export const getDateStyles = (theme, date, finalStartDate, finalEndDate, hoveredDate, isDateDisabled) => {