@quillsql/react 2.10.39 → 2.11.0

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 (123) hide show
  1. package/dist/cjs/Chart.d.ts +4 -0
  2. package/dist/cjs/Chart.d.ts.map +1 -1
  3. package/dist/cjs/Chart.js +5 -5
  4. package/dist/cjs/ChartBuilder.js +2 -2
  5. package/dist/cjs/Context.d.ts +1 -1
  6. package/dist/cjs/Context.d.ts.map +1 -1
  7. package/dist/cjs/Context.js +3 -1
  8. package/dist/cjs/Dashboard.d.ts +3 -1
  9. package/dist/cjs/Dashboard.d.ts.map +1 -1
  10. package/dist/cjs/Dashboard.js +4 -4
  11. package/dist/cjs/QuillProvider.d.ts +3 -1
  12. package/dist/cjs/QuillProvider.d.ts.map +1 -1
  13. package/dist/cjs/QuillProvider.js +2 -2
  14. package/dist/cjs/ReportBuilder.d.ts +40 -40
  15. package/dist/cjs/ReportBuilder.d.ts.map +1 -1
  16. package/dist/cjs/ReportBuilder.js +2026 -917
  17. package/dist/cjs/components/Chart/LineChart.d.ts +5 -1
  18. package/dist/cjs/components/Chart/LineChart.d.ts.map +1 -1
  19. package/dist/cjs/components/Chart/LineChart.js +18 -6
  20. package/dist/cjs/components/QuillTable.d.ts +1 -1
  21. package/dist/cjs/components/QuillTable.d.ts.map +1 -1
  22. package/dist/cjs/components/QuillTable.js +157 -157
  23. package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts +2 -0
  24. package/dist/cjs/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -0
  25. package/dist/cjs/components/ReportBuilder/AddColumnPopover.js +128 -0
  26. package/dist/cjs/components/ReportBuilder/ast.d.ts +512 -0
  27. package/dist/cjs/components/ReportBuilder/ast.d.ts.map +1 -0
  28. package/dist/cjs/components/ReportBuilder/ast.js +210 -0
  29. package/dist/cjs/components/ReportBuilder/bigDateMap.d.ts +7 -0
  30. package/dist/cjs/components/ReportBuilder/bigDateMap.d.ts.map +1 -0
  31. package/dist/cjs/components/ReportBuilder/bigDateMap.js +689 -0
  32. package/dist/cjs/components/ReportBuilder/constants.d.ts +89 -0
  33. package/dist/cjs/components/ReportBuilder/constants.d.ts.map +1 -0
  34. package/dist/cjs/components/ReportBuilder/constants.js +130 -0
  35. package/dist/cjs/components/ReportBuilder/convert.d.ts +41 -0
  36. package/dist/cjs/components/ReportBuilder/convert.d.ts.map +1 -0
  37. package/dist/cjs/components/ReportBuilder/convert.js +730 -0
  38. package/dist/cjs/components/ReportBuilder/operators.d.ts +445 -0
  39. package/dist/cjs/components/ReportBuilder/operators.d.ts.map +1 -0
  40. package/dist/cjs/components/ReportBuilder/operators.js +552 -0
  41. package/dist/cjs/components/ReportBuilder/pivot.d.ts +10 -0
  42. package/dist/cjs/components/ReportBuilder/pivot.d.ts.map +1 -0
  43. package/dist/cjs/components/ReportBuilder/pivot.js +2 -0
  44. package/dist/cjs/components/ReportBuilder/postgres.d.ts +150 -0
  45. package/dist/cjs/components/ReportBuilder/postgres.d.ts.map +1 -0
  46. package/dist/cjs/components/ReportBuilder/postgres.js +365 -0
  47. package/dist/cjs/components/ReportBuilder/schema.d.ts +23 -0
  48. package/dist/cjs/components/ReportBuilder/schema.d.ts.map +1 -0
  49. package/dist/cjs/components/ReportBuilder/schema.js +2 -0
  50. package/dist/cjs/components/ReportBuilder/ui.d.ts +34 -0
  51. package/dist/cjs/components/ReportBuilder/ui.d.ts.map +1 -0
  52. package/dist/cjs/components/ReportBuilder/ui.js +389 -0
  53. package/dist/cjs/components/ReportBuilder/util.d.ts +76 -0
  54. package/dist/cjs/components/ReportBuilder/util.d.ts.map +1 -0
  55. package/dist/cjs/components/ReportBuilder/util.js +648 -0
  56. package/dist/cjs/components/UiComponents.d.ts +15 -2
  57. package/dist/cjs/components/UiComponents.d.ts.map +1 -1
  58. package/dist/cjs/components/UiComponents.js +50 -3
  59. package/dist/cjs/utils/crypto.d.ts +1 -1
  60. package/dist/cjs/utils/crypto.d.ts.map +1 -1
  61. package/dist/cjs/utils/crypto.js +9 -5
  62. package/dist/esm/Chart.d.ts +4 -0
  63. package/dist/esm/Chart.d.ts.map +1 -1
  64. package/dist/esm/Chart.js +5 -5
  65. package/dist/esm/ChartBuilder.js +1 -1
  66. package/dist/esm/Context.d.ts +1 -1
  67. package/dist/esm/Context.d.ts.map +1 -1
  68. package/dist/esm/Context.js +3 -1
  69. package/dist/esm/Dashboard.d.ts +3 -1
  70. package/dist/esm/Dashboard.d.ts.map +1 -1
  71. package/dist/esm/Dashboard.js +4 -4
  72. package/dist/esm/QuillProvider.d.ts +3 -1
  73. package/dist/esm/QuillProvider.d.ts.map +1 -1
  74. package/dist/esm/QuillProvider.js +2 -2
  75. package/dist/esm/ReportBuilder.d.ts +40 -40
  76. package/dist/esm/ReportBuilder.d.ts.map +1 -1
  77. package/dist/esm/ReportBuilder.js +2028 -917
  78. package/dist/esm/components/Chart/LineChart.d.ts +5 -1
  79. package/dist/esm/components/Chart/LineChart.d.ts.map +1 -1
  80. package/dist/esm/components/Chart/LineChart.js +18 -6
  81. package/dist/esm/components/QuillTable.d.ts +1 -1
  82. package/dist/esm/components/QuillTable.d.ts.map +1 -1
  83. package/dist/esm/components/QuillTable.js +157 -157
  84. package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts +2 -0
  85. package/dist/esm/components/ReportBuilder/AddColumnPopover.d.ts.map +1 -0
  86. package/dist/esm/components/ReportBuilder/AddColumnPopover.js +125 -0
  87. package/dist/esm/components/ReportBuilder/ast.d.ts +512 -0
  88. package/dist/esm/components/ReportBuilder/ast.d.ts.map +1 -0
  89. package/dist/esm/components/ReportBuilder/ast.js +186 -0
  90. package/dist/esm/components/ReportBuilder/bigDateMap.d.ts +7 -0
  91. package/dist/esm/components/ReportBuilder/bigDateMap.d.ts.map +1 -0
  92. package/dist/esm/components/ReportBuilder/bigDateMap.js +686 -0
  93. package/dist/esm/components/ReportBuilder/constants.d.ts +89 -0
  94. package/dist/esm/components/ReportBuilder/constants.d.ts.map +1 -0
  95. package/dist/esm/components/ReportBuilder/constants.js +127 -0
  96. package/dist/esm/components/ReportBuilder/convert.d.ts +41 -0
  97. package/dist/esm/components/ReportBuilder/convert.d.ts.map +1 -0
  98. package/dist/esm/components/ReportBuilder/convert.js +719 -0
  99. package/dist/esm/components/ReportBuilder/operators.d.ts +445 -0
  100. package/dist/esm/components/ReportBuilder/operators.d.ts.map +1 -0
  101. package/dist/esm/components/ReportBuilder/operators.js +548 -0
  102. package/dist/esm/components/ReportBuilder/pivot.d.ts +10 -0
  103. package/dist/esm/components/ReportBuilder/pivot.d.ts.map +1 -0
  104. package/dist/esm/components/ReportBuilder/pivot.js +1 -0
  105. package/dist/esm/components/ReportBuilder/postgres.d.ts +150 -0
  106. package/dist/esm/components/ReportBuilder/postgres.d.ts.map +1 -0
  107. package/dist/esm/components/ReportBuilder/postgres.js +355 -0
  108. package/dist/esm/components/ReportBuilder/schema.d.ts +23 -0
  109. package/dist/esm/components/ReportBuilder/schema.d.ts.map +1 -0
  110. package/dist/esm/components/ReportBuilder/schema.js +1 -0
  111. package/dist/esm/components/ReportBuilder/ui.d.ts +34 -0
  112. package/dist/esm/components/ReportBuilder/ui.d.ts.map +1 -0
  113. package/dist/esm/components/ReportBuilder/ui.js +366 -0
  114. package/dist/esm/components/ReportBuilder/util.d.ts +76 -0
  115. package/dist/esm/components/ReportBuilder/util.d.ts.map +1 -0
  116. package/dist/esm/components/ReportBuilder/util.js +616 -0
  117. package/dist/esm/components/UiComponents.d.ts +15 -2
  118. package/dist/esm/components/UiComponents.d.ts.map +1 -1
  119. package/dist/esm/components/UiComponents.js +47 -2
  120. package/dist/esm/utils/crypto.d.ts +1 -1
  121. package/dist/esm/utils/crypto.d.ts.map +1 -1
  122. package/dist/esm/utils/crypto.js +9 -5
  123. package/package.json +1 -1
@@ -0,0 +1,689 @@
1
+ "use strict";
2
+ // A giant map of partial objects keys to functions that take the root node
3
+ // and return a strinified version of the node. Used to populate the filters.
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.DATE_DESCRIPTION_MAP = void 0;
6
+ /**
7
+ * Trims off the _at suffix of columnNames so "created_at" becomes "created"
8
+ */
9
+ function cleanDateFieldName(fieldName) {
10
+ if (!fieldName)
11
+ return undefined;
12
+ return fieldName.replace('_at', '');
13
+ }
14
+ /**
15
+ * A big map of partial objects and a callback to convert each to a string.
16
+ */
17
+ exports.DATE_DESCRIPTION_MAP = {
18
+ [JSON.stringify({
19
+ type: 'binary_expr',
20
+ left: {
21
+ type: 'function',
22
+ name: 'date_trunc',
23
+ args: {
24
+ type: 'expr_list',
25
+ value: [
26
+ { type: 'single_quote_string' },
27
+ { type: 'double_quote_string' },
28
+ ],
29
+ },
30
+ },
31
+ right: {
32
+ type: 'function',
33
+ name: 'date_trunc',
34
+ args: {
35
+ type: 'expr_list',
36
+ value: [
37
+ { type: 'single_quote_string' },
38
+ {
39
+ type: 'binary_expr',
40
+ left: {
41
+ type: 'function',
42
+ },
43
+ right: {
44
+ type: 'interval',
45
+ expr: {
46
+ type: 'single_quote_string',
47
+ },
48
+ },
49
+ },
50
+ ],
51
+ },
52
+ },
53
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].value)} in the last ${node.right.args.value[1].right.expr.value}`,
54
+ [JSON.stringify({
55
+ type: 'binary_expr',
56
+ left: {
57
+ type: 'function',
58
+ name: 'date_trunc',
59
+ args: {
60
+ type: 'expr_list',
61
+ value: [{ type: 'single_quote_string' }, { type: 'column_ref' }],
62
+ },
63
+ },
64
+ right: {
65
+ type: 'function',
66
+ name: 'date_trunc',
67
+ args: {
68
+ type: 'expr_list',
69
+ value: [
70
+ { type: 'single_quote_string' },
71
+ {
72
+ type: 'binary_expr',
73
+ left: {
74
+ type: 'function',
75
+ },
76
+ right: {
77
+ type: 'interval',
78
+ expr: {
79
+ type: 'single_quote_string',
80
+ },
81
+ },
82
+ },
83
+ ],
84
+ },
85
+ },
86
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].column)} in the last ${node.right.args.value[1].right.expr.value}`,
87
+ [JSON.stringify({
88
+ type: 'binary_expr',
89
+ left: { type: 'column_ref' },
90
+ right: {
91
+ type: 'function',
92
+ name: 'date_trunc',
93
+ args: {
94
+ type: 'expr_list',
95
+ value: [
96
+ { type: 'single_quote_string' },
97
+ {
98
+ type: 'binary_expr',
99
+ left: {
100
+ type: 'function',
101
+ },
102
+ right: {
103
+ type: 'interval',
104
+ expr: {
105
+ type: 'single_quote_string',
106
+ },
107
+ },
108
+ },
109
+ ],
110
+ },
111
+ },
112
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.args.value[1].right.expr.value}`,
113
+ [JSON.stringify({
114
+ type: 'binary_expr',
115
+ left: { type: 'double_quote_string' },
116
+ right: {
117
+ type: 'function',
118
+ name: 'date_trunc',
119
+ args: {
120
+ type: 'expr_list',
121
+ value: [
122
+ { type: 'single_quote_string' },
123
+ {
124
+ type: 'binary_expr',
125
+ left: {
126
+ type: 'function',
127
+ },
128
+ right: {
129
+ type: 'interval',
130
+ expr: {
131
+ type: 'single_quote_string',
132
+ },
133
+ },
134
+ },
135
+ ],
136
+ },
137
+ },
138
+ })]: (node) => `${cleanDateFieldName(node.left.value)} in the last ${node.right.args.value[1].right.expr.value}`,
139
+ [JSON.stringify({
140
+ type: 'binary_expr',
141
+ left: { type: 'column_ref' },
142
+ right: {
143
+ type: 'binary_expr',
144
+ operator: '-',
145
+ left: { type: 'function', name: 'CURRENT_DATE' },
146
+ right: { type: 'interval' },
147
+ },
148
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
149
+ [JSON.stringify({
150
+ type: 'binary_expr',
151
+ left: {
152
+ type: 'function',
153
+ name: 'date_trunc',
154
+ args: {
155
+ type: 'expr_list',
156
+ value: [
157
+ {
158
+ type: 'single_quote_string',
159
+ },
160
+ {
161
+ type: 'column_ref',
162
+ },
163
+ ],
164
+ },
165
+ },
166
+ right: {
167
+ type: 'function',
168
+ name: 'date_trunc',
169
+ args: {
170
+ type: 'expr_list',
171
+ value: [
172
+ {
173
+ type: 'single_quote_string',
174
+ },
175
+ {
176
+ type: 'binary_expr',
177
+ operator: '-',
178
+ left: {
179
+ type: 'function',
180
+ },
181
+ right: {
182
+ type: 'interval',
183
+ expr: {
184
+ type: 'single_quote_string',
185
+ },
186
+ },
187
+ },
188
+ ],
189
+ },
190
+ },
191
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[0].column)} in the last ${node.right.args.value[1].right.expr.value.toLowerCase()}`,
192
+ [JSON.stringify({
193
+ type: 'binary_expr',
194
+ left: {
195
+ type: 'function',
196
+ name: 'date_trunc',
197
+ args: {
198
+ type: 'expr_list',
199
+ value: [
200
+ {
201
+ type: 'single_quote_string',
202
+ },
203
+ {
204
+ type: 'double_quote_string',
205
+ },
206
+ ],
207
+ },
208
+ },
209
+ right: {
210
+ type: 'binary_expr',
211
+ operator: '-',
212
+ left: {
213
+ type: 'function',
214
+ },
215
+ right: {
216
+ type: 'interval',
217
+ expr: {
218
+ type: 'single_quote_string',
219
+ },
220
+ },
221
+ },
222
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].value)} in the last ${node.right.right.expr.value.toLowerCase()}`,
223
+ [JSON.stringify({
224
+ type: 'binary_expr',
225
+ left: {
226
+ type: 'function',
227
+ name: 'date_trunc',
228
+ args: {
229
+ type: 'expr_list',
230
+ value: [
231
+ {
232
+ type: 'single_quote_string',
233
+ },
234
+ {
235
+ type: 'column_ref',
236
+ },
237
+ ],
238
+ },
239
+ },
240
+ right: {
241
+ type: 'binary_expr',
242
+ operator: '-',
243
+ left: {
244
+ type: 'function',
245
+ },
246
+ right: {
247
+ type: 'interval',
248
+ expr: {
249
+ type: 'single_quote_string',
250
+ },
251
+ },
252
+ },
253
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
254
+ [JSON.stringify({
255
+ type: 'binary_expr',
256
+ left: {
257
+ type: 'column_ref',
258
+ },
259
+ right: {
260
+ type: 'binary_expr',
261
+ operator: '-',
262
+ left: {
263
+ type: 'function',
264
+ name: 'date_trunc',
265
+ args: {
266
+ type: 'expr_list',
267
+ value: [
268
+ {
269
+ type: 'single_quote_string',
270
+ value: 'month',
271
+ },
272
+ {
273
+ type: 'function',
274
+ name: 'CURRENT_DATE',
275
+ },
276
+ ],
277
+ },
278
+ },
279
+ right: {
280
+ type: 'interval',
281
+ },
282
+ },
283
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
284
+ [JSON.stringify({
285
+ type: 'binary_expr',
286
+ left: {
287
+ type: 'column_ref',
288
+ },
289
+ right: {
290
+ type: 'binary_expr',
291
+ operator: '-',
292
+ left: {
293
+ type: 'function',
294
+ name: 'DATE_TRUNC',
295
+ args: {
296
+ type: 'expr_list',
297
+ value: [
298
+ {
299
+ type: 'single_quote_string',
300
+ },
301
+ {
302
+ type: 'function',
303
+ },
304
+ ],
305
+ },
306
+ },
307
+ right: {
308
+ type: 'interval',
309
+ expr: {
310
+ type: 'single_quote_string',
311
+ },
312
+ },
313
+ },
314
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
315
+ [JSON.stringify({
316
+ type: 'binary_expr',
317
+ left: {
318
+ type: 'column_ref',
319
+ },
320
+ right: {
321
+ type: 'binary_expr',
322
+ operator: '-',
323
+ left: {
324
+ type: 'function',
325
+ name: 'CURRENT_DATE',
326
+ },
327
+ right: {
328
+ type: 'interval',
329
+ expr: {
330
+ type: 'single_quote_string',
331
+ },
332
+ },
333
+ },
334
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
335
+ [JSON.stringify({
336
+ type: 'binary_expr',
337
+ left: {
338
+ type: 'column_ref',
339
+ },
340
+ right: {
341
+ type: 'binary_expr',
342
+ operator: '-',
343
+ left: {
344
+ type: 'function',
345
+ name: 'DATE_TRUNC',
346
+ args: {
347
+ type: 'expr_list',
348
+ value: [
349
+ {
350
+ type: 'single_quote_string',
351
+ },
352
+ {
353
+ type: 'function',
354
+ name: 'CURRENT_DATE',
355
+ },
356
+ ],
357
+ },
358
+ },
359
+ right: {
360
+ type: 'interval',
361
+ expr: {
362
+ type: 'single_quote_string',
363
+ },
364
+ },
365
+ },
366
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
367
+ [JSON.stringify({
368
+ type: 'binary_expr',
369
+ left: {
370
+ type: 'function',
371
+ name: 'date_trunc',
372
+ args: {
373
+ type: 'expr_list',
374
+ value: [
375
+ {
376
+ type: 'single_quote_string',
377
+ },
378
+ {
379
+ type: 'column_ref',
380
+ },
381
+ ],
382
+ },
383
+ },
384
+ right: {
385
+ type: 'binary_expr',
386
+ operator: '-',
387
+ left: {
388
+ type: 'function',
389
+ name: 'date_trunc',
390
+ args: {
391
+ type: 'expr_list',
392
+ value: [
393
+ {
394
+ type: 'single_quote_string',
395
+ },
396
+ {
397
+ type: 'function',
398
+ name: 'CURRENT_DATE',
399
+ },
400
+ ],
401
+ },
402
+ },
403
+ right: {
404
+ type: 'interval',
405
+ expr: {
406
+ type: 'single_quote_string',
407
+ },
408
+ },
409
+ },
410
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
411
+ [JSON.stringify({
412
+ type: 'binary_expr',
413
+ operator: '>=',
414
+ left: {
415
+ type: 'column_ref',
416
+ },
417
+ right: {
418
+ type: 'function',
419
+ name: 'date_trunc',
420
+ args: {
421
+ type: 'expr_list',
422
+ value: [
423
+ {
424
+ type: 'single_quote_string',
425
+ },
426
+ {
427
+ type: 'binary_expr',
428
+ operator: '-',
429
+ left: {
430
+ type: 'function',
431
+ name: 'CURRENT_DATE',
432
+ },
433
+ right: {
434
+ type: 'interval',
435
+ expr: {
436
+ type: 'single_quote_string',
437
+ },
438
+ },
439
+ },
440
+ ],
441
+ },
442
+ },
443
+ })]: (node) => `${cleanDateFieldName(node?.left?.column ?? 'unknown')} in the last ${node?.right?.args?.value[0]?.value ?? 'period'}`,
444
+ [JSON.stringify({
445
+ type: 'binary_expr',
446
+ operator: '<',
447
+ left: {
448
+ type: 'column_ref',
449
+ },
450
+ right: {
451
+ type: 'function',
452
+ name: 'date_trunc',
453
+ args: {
454
+ type: 'expr_list',
455
+ value: [
456
+ {
457
+ type: 'single_quote_string',
458
+ value: 'month',
459
+ },
460
+ {
461
+ type: 'binary_expr',
462
+ operator: '+',
463
+ left: {
464
+ type: 'function',
465
+ name: 'CURRENT_DATE',
466
+ },
467
+ right: {
468
+ type: 'interval',
469
+ expr: {
470
+ type: 'single_quote_string',
471
+ },
472
+ },
473
+ },
474
+ ],
475
+ },
476
+ },
477
+ })]: (node) => `${cleanDateFieldName(node.left.args.value[1].column)} before the start of the ${node.right.args.value[0].value}, ${node.right.args.value[1].right.expr.value.toLowerCase()} from today`,
478
+ [JSON.stringify({
479
+ type: 'binary_expr',
480
+ operator: '>',
481
+ left: {
482
+ type: 'column_ref',
483
+ },
484
+ right: {
485
+ type: 'binary_expr',
486
+ operator: '-',
487
+ left: {
488
+ type: 'function',
489
+ name: 'CURRENT_DATE',
490
+ },
491
+ right: {
492
+ type: 'interval',
493
+ expr: {
494
+ type: 'single_quote_string',
495
+ },
496
+ unit: 'day',
497
+ },
498
+ },
499
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()} ${node.right.right.unit.toLowerCase()}${Number(node.right.right.expr.value) > 1 ? 's' : ''}`,
500
+ [JSON.stringify({
501
+ type: 'binary_expr',
502
+ operator: '>=',
503
+ left: {
504
+ type: 'column_ref',
505
+ },
506
+ right: {
507
+ type: 'binary_expr',
508
+ operator: '-',
509
+ left: {
510
+ type: 'function',
511
+ name: 'now',
512
+ },
513
+ right: {
514
+ type: 'interval',
515
+ expr: {
516
+ type: 'single_quote_string',
517
+ },
518
+ },
519
+ },
520
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
521
+ [JSON.stringify({
522
+ type: 'binary_expr',
523
+ operator: '>',
524
+ left: {
525
+ type: 'column_ref',
526
+ },
527
+ right: {
528
+ type: 'binary_expr',
529
+ operator: '-',
530
+ left: {
531
+ type: 'function',
532
+ name: 'now',
533
+ },
534
+ right: {
535
+ type: 'interval',
536
+ expr: {
537
+ type: 'single_quote_string',
538
+ },
539
+ },
540
+ },
541
+ })]: (node) => `${cleanDateFieldName(node.left.column)} in the last ${node.right.right.expr.value.toLowerCase()}`,
542
+ [JSON.stringify({
543
+ type: 'binary_expr',
544
+ operator: '>=',
545
+ left: { type: 'double_quote_string' },
546
+ right: {
547
+ type: 'binary_expr',
548
+ operator: '-',
549
+ left: {
550
+ type: 'function',
551
+ name: 'date_trunc',
552
+ args: {
553
+ type: 'expr_list',
554
+ value: [
555
+ { type: 'single_quote_string' },
556
+ { type: 'function', name: 'CURRENT_DATE' },
557
+ ],
558
+ },
559
+ },
560
+ right: {
561
+ type: 'interval',
562
+ expr: { type: 'single_quote_string' },
563
+ },
564
+ },
565
+ })]: (node) => `${cleanDateFieldName(node?.left?.column ?? 'unknown')} ${node?.right?.right?.expr?.value?.toLowerCase() ?? 'time ago'} from start of this ${node?.right?.left?.args?.value[0]?.value?.toLowerCase() ?? 'period'}`,
566
+ [JSON.stringify({
567
+ type: 'binary_expr',
568
+ operator: '>=',
569
+ left: {
570
+ type: 'column_ref',
571
+ },
572
+ right: {
573
+ type: 'function',
574
+ name: 'date_trunc',
575
+ args: {
576
+ type: 'expr_list',
577
+ value: [
578
+ {
579
+ type: 'single_quote_string',
580
+ },
581
+ {
582
+ type: 'function',
583
+ name: 'CURRENT_DATE',
584
+ },
585
+ ],
586
+ },
587
+ },
588
+ })]: (node) => `${cleanDateFieldName(node?.left?.column ?? 'unknown')} this ${node?.right?.args?.value[0]?.value?.toLowerCase() ?? 'period'}`,
589
+ [JSON.stringify({
590
+ type: 'binary_expr',
591
+ operator: '=',
592
+ left: {
593
+ type: 'function',
594
+ name: 'date_trunc',
595
+ args: {
596
+ type: 'expr_list',
597
+ value: [
598
+ {
599
+ type: 'single_quote_string',
600
+ value: 'day',
601
+ },
602
+ {
603
+ type: 'column_ref',
604
+ },
605
+ ],
606
+ },
607
+ },
608
+ right: {
609
+ type: 'function',
610
+ name: 'date_trunc',
611
+ args: {
612
+ type: 'expr_list',
613
+ value: [
614
+ {
615
+ type: 'single_quote_string',
616
+ },
617
+ {
618
+ type: 'function',
619
+ name: 'CURRENT_DATE',
620
+ },
621
+ ],
622
+ },
623
+ },
624
+ })]: (node) => `${cleanDateFieldName(node?.left?.args?.value[1]?.column ?? 'unknown')} today`,
625
+ [JSON.stringify({
626
+ type: 'binary_expr',
627
+ operator: '=',
628
+ left: {
629
+ type: 'function',
630
+ name: 'date_trunc',
631
+ args: {
632
+ type: 'expr_list',
633
+ value: [
634
+ {
635
+ type: 'single_quote_string',
636
+ },
637
+ {
638
+ type: 'column_ref',
639
+ },
640
+ ],
641
+ },
642
+ },
643
+ right: {
644
+ type: 'function',
645
+ name: 'date_trunc',
646
+ args: {
647
+ type: 'expr_list',
648
+ value: [
649
+ {
650
+ type: 'single_quote_string',
651
+ },
652
+ {
653
+ type: 'function',
654
+ name: 'CURRENT_DATE',
655
+ },
656
+ ],
657
+ },
658
+ },
659
+ })]: (node) => `${cleanDateFieldName(node?.left?.args?.value[1]?.column ?? 'unknown')} this ${node?.right?.args?.value[0]?.value?.toLowerCase() ?? 'period'}`,
660
+ [JSON.stringify({
661
+ type: 'binary_expr',
662
+ left: {
663
+ type: 'binary_expr',
664
+ operator: '-',
665
+ left: {
666
+ type: 'function',
667
+ name: 'date_trunc',
668
+ args: {
669
+ type: 'expr_list',
670
+ value: [{ type: 'single_quote_string' }, { type: 'function' }],
671
+ },
672
+ },
673
+ right: {
674
+ type: 'function',
675
+ name: 'date_trunc',
676
+ args: {
677
+ type: 'expr_list',
678
+ value: [
679
+ { type: 'single_quote_string' },
680
+ { type: 'double_quote_string' },
681
+ ],
682
+ },
683
+ },
684
+ },
685
+ right: {
686
+ name: 'number',
687
+ },
688
+ })]: (node) => `${cleanDateFieldName(node.left.right.args.value[1].value)} in the last ${node.right.value} ${node.left.right.args.value[0].value}${node.right.value === 1 ? '' : 's'}`,
689
+ };