@finos/legend-query-builder 0.4.3 → 0.5.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 (242) hide show
  1. package/lib/components/QueryBuilder.d.ts.map +1 -1
  2. package/lib/components/QueryBuilder.js +11 -2
  3. package/lib/components/QueryBuilder.js.map +1 -1
  4. package/lib/components/QueryBuilderConstantExpressionPanel.d.ts +23 -0
  5. package/lib/components/QueryBuilderConstantExpressionPanel.d.ts.map +1 -0
  6. package/lib/components/QueryBuilderConstantExpressionPanel.js +104 -0
  7. package/lib/components/QueryBuilderConstantExpressionPanel.js.map +1 -0
  8. package/lib/components/QueryBuilderDiffPanel.d.ts.map +1 -1
  9. package/lib/components/QueryBuilderDiffPanel.js +1 -2
  10. package/lib/components/QueryBuilderDiffPanel.js.map +1 -1
  11. package/lib/components/QueryBuilderParametersPanel.d.ts +0 -9
  12. package/lib/components/QueryBuilderParametersPanel.d.ts.map +1 -1
  13. package/lib/components/QueryBuilderParametersPanel.js +10 -30
  14. package/lib/components/QueryBuilderParametersPanel.js.map +1 -1
  15. package/lib/components/QueryBuilderPropertyExpressionEditor.d.ts.map +1 -1
  16. package/lib/components/QueryBuilderPropertyExpressionEditor.js +60 -12
  17. package/lib/components/QueryBuilderPropertyExpressionEditor.js.map +1 -1
  18. package/lib/components/QueryBuilderSideBar.d.ts +2 -1
  19. package/lib/components/QueryBuilderSideBar.d.ts.map +1 -1
  20. package/lib/components/QueryBuilderSideBar.js +6 -14
  21. package/lib/components/QueryBuilderSideBar.js.map +1 -1
  22. package/lib/components/explorer/QueryBuilderMilestoningEditor.d.ts.map +1 -1
  23. package/lib/components/explorer/QueryBuilderMilestoningEditor.js +12 -18
  24. package/lib/components/explorer/QueryBuilderMilestoningEditor.js.map +1 -1
  25. package/lib/components/fetch-structure/{QueryBuilderOLAPGroupByPanel_.d.ts → QueryBuilderOLAPGroupByPanel.d.ts} +2 -2
  26. package/lib/components/fetch-structure/QueryBuilderOLAPGroupByPanel.d.ts.map +1 -0
  27. package/lib/components/fetch-structure/{QueryBuilderOLAPGroupByPanel_.js → QueryBuilderOLAPGroupByPanel.js} +2 -2
  28. package/lib/components/fetch-structure/QueryBuilderOLAPGroupByPanel.js.map +1 -0
  29. package/lib/components/fetch-structure/QueryBuilderPostFilterPanel.d.ts.map +1 -1
  30. package/lib/components/fetch-structure/QueryBuilderPostFilterPanel.js +9 -11
  31. package/lib/components/fetch-structure/QueryBuilderPostFilterPanel.js.map +1 -1
  32. package/lib/components/fetch-structure/QueryBuilderPostTDSPanel.js +1 -1
  33. package/lib/components/fetch-structure/QueryBuilderPostTDSPanel.js.map +1 -1
  34. package/lib/components/fetch-structure/QueryBuilderTDSPanel.d.ts.map +1 -1
  35. package/lib/components/fetch-structure/QueryBuilderTDSPanel.js +4 -4
  36. package/lib/components/fetch-structure/QueryBuilderTDSPanel.js.map +1 -1
  37. package/lib/components/filter/QueryBuilderFilterPanel.d.ts.map +1 -1
  38. package/lib/components/filter/QueryBuilderFilterPanel.js +8 -9
  39. package/lib/components/filter/QueryBuilderFilterPanel.js.map +1 -1
  40. package/lib/components/shared/BasicValueSpecificationEditor.d.ts +12 -1
  41. package/lib/components/shared/BasicValueSpecificationEditor.d.ts.map +1 -1
  42. package/lib/components/shared/BasicValueSpecificationEditor.js +11 -7
  43. package/lib/components/shared/BasicValueSpecificationEditor.js.map +1 -1
  44. package/lib/components/shared/LambdaEditor.d.ts.map +1 -1
  45. package/lib/components/shared/LambdaEditor.js +1 -15
  46. package/lib/components/shared/LambdaEditor.js.map +1 -1
  47. package/lib/components/shared/QueryBuilderVariableSelector.d.ts +36 -0
  48. package/lib/components/shared/QueryBuilderVariableSelector.d.ts.map +1 -0
  49. package/lib/components/shared/QueryBuilderVariableSelector.js +50 -0
  50. package/lib/components/shared/QueryBuilderVariableSelector.js.map +1 -0
  51. package/lib/components/watermark/QueryBuilderWatermark.d.ts.map +1 -1
  52. package/lib/components/watermark/QueryBuilderWatermark.js +9 -11
  53. package/lib/components/watermark/QueryBuilderWatermark.js.map +1 -1
  54. package/lib/graphManager/QueryBuilderHashUtils.d.ts +2 -0
  55. package/lib/graphManager/QueryBuilderHashUtils.d.ts.map +1 -1
  56. package/lib/graphManager/QueryBuilderHashUtils.js +2 -0
  57. package/lib/graphManager/QueryBuilderHashUtils.js.map +1 -1
  58. package/lib/index.css +17 -1
  59. package/lib/index.css.map +1 -1
  60. package/lib/package.json +8 -8
  61. package/lib/stores/QueryBuilderConfig.d.ts +1 -0
  62. package/lib/stores/QueryBuilderConfig.d.ts.map +1 -1
  63. package/lib/stores/QueryBuilderConfig.js +1 -0
  64. package/lib/stores/QueryBuilderConfig.js.map +1 -1
  65. package/lib/stores/QueryBuilderConstantsState.d.ts +43 -0
  66. package/lib/stores/QueryBuilderConstantsState.d.ts.map +1 -0
  67. package/lib/stores/QueryBuilderConstantsState.js +116 -0
  68. package/lib/stores/QueryBuilderConstantsState.js.map +1 -0
  69. package/lib/stores/QueryBuilderParametersState.d.ts +0 -4
  70. package/lib/stores/QueryBuilderParametersState.d.ts.map +1 -1
  71. package/lib/stores/QueryBuilderParametersState.js +0 -1
  72. package/lib/stores/QueryBuilderParametersState.js.map +1 -1
  73. package/lib/stores/QueryBuilderPropertyEditorState.d.ts +3 -10
  74. package/lib/stores/QueryBuilderPropertyEditorState.d.ts.map +1 -1
  75. package/lib/stores/QueryBuilderPropertyEditorState.js +6 -140
  76. package/lib/stores/QueryBuilderPropertyEditorState.js.map +1 -1
  77. package/lib/stores/QueryBuilderResultState.d.ts +1 -2
  78. package/lib/stores/QueryBuilderResultState.d.ts.map +1 -1
  79. package/lib/stores/QueryBuilderResultState.js +7 -12
  80. package/lib/stores/QueryBuilderResultState.js.map +1 -1
  81. package/lib/stores/QueryBuilderState.d.ts +9 -3
  82. package/lib/stores/QueryBuilderState.d.ts.map +1 -1
  83. package/lib/stores/QueryBuilderState.js +19 -4
  84. package/lib/stores/QueryBuilderState.js.map +1 -1
  85. package/lib/stores/QueryBuilderStateBuilder.d.ts +4 -3
  86. package/lib/stores/QueryBuilderStateBuilder.d.ts.map +1 -1
  87. package/lib/stores/QueryBuilderStateBuilder.js +50 -42
  88. package/lib/stores/QueryBuilderStateBuilder.js.map +1 -1
  89. package/lib/stores/QueryBuilderValueSpecificationBuilder.d.ts.map +1 -1
  90. package/lib/stores/QueryBuilderValueSpecificationBuilder.js +32 -29
  91. package/lib/stores/QueryBuilderValueSpecificationBuilder.js.map +1 -1
  92. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.d.ts.map +1 -1
  93. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.js +14 -78
  94. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.js.map +1 -1
  95. package/lib/stores/QueryBuilderValueSpecificationHelper.d.ts.map +1 -1
  96. package/lib/stores/QueryBuilderValueSpecificationHelper.js +4 -20
  97. package/lib/stores/QueryBuilderValueSpecificationHelper.js.map +1 -1
  98. package/lib/stores/fetch-structure/graph-fetch/QueryBuilderGraphFetchTreeStateBuilder.d.ts +3 -3
  99. package/lib/stores/fetch-structure/graph-fetch/QueryBuilderGraphFetchTreeStateBuilder.d.ts.map +1 -1
  100. package/lib/stores/fetch-structure/graph-fetch/QueryBuilderGraphFetchTreeStateBuilder.js +4 -4
  101. package/lib/stores/fetch-structure/graph-fetch/QueryBuilderGraphFetchTreeStateBuilder.js.map +1 -1
  102. package/lib/stores/fetch-structure/tds/QueryBuilderTDSState.d.ts +1 -1
  103. package/lib/stores/fetch-structure/tds/QueryBuilderTDSState.d.ts.map +1 -1
  104. package/lib/stores/fetch-structure/tds/QueryBuilderTDSState.js +2 -2
  105. package/lib/stores/fetch-structure/tds/QueryBuilderTDSState.js.map +1 -1
  106. package/lib/stores/fetch-structure/tds/aggregation/QueryBuilderAggregationStateBuilder.d.ts +3 -3
  107. package/lib/stores/fetch-structure/tds/aggregation/QueryBuilderAggregationStateBuilder.d.ts.map +1 -1
  108. package/lib/stores/fetch-structure/tds/aggregation/QueryBuilderAggregationStateBuilder.js +6 -6
  109. package/lib/stores/fetch-structure/tds/aggregation/QueryBuilderAggregationStateBuilder.js.map +1 -1
  110. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByOperatorLoader_.d.ts → QueryBuilderOLAPGroupByOperatorLoader.d.ts} +1 -1
  111. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByOperatorLoader.d.ts.map +1 -0
  112. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByOperatorLoader_.js → QueryBuilderOLAPGroupByOperatorLoader.js} +1 -1
  113. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByOperatorLoader.js.map +1 -0
  114. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByState_.d.ts → QueryBuilderOLAPGroupByState.d.ts} +1 -1
  115. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByState.d.ts.map +1 -0
  116. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByState_.js → QueryBuilderOLAPGroupByState.js} +1 -1
  117. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByState.js.map +1 -0
  118. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByStateBuilder_.d.ts → QueryBuilderOLAPGroupByStateBuilder.d.ts} +3 -3
  119. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder.d.ts.map +1 -0
  120. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByStateBuilder_.js → QueryBuilderOLAPGroupByStateBuilder.js} +4 -4
  121. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder.js.map +1 -0
  122. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByValueSpecificationBuilder_.d.ts → QueryBuilderOLAPGroupByValueSpecificationBuilder.d.ts} +2 -2
  123. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByValueSpecificationBuilder.d.ts.map +1 -0
  124. package/lib/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByValueSpecificationBuilder_.js → QueryBuilderOLAPGroupByValueSpecificationBuilder.js} +2 -2
  125. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByValueSpecificationBuilder.js.map +1 -0
  126. package/lib/stores/fetch-structure/tds/post-filter/operators/QueryBuilderPostFilterOperatorHelper.js +1 -1
  127. package/lib/stores/fetch-structure/tds/post-filter/operators/QueryBuilderPostFilterOperatorHelper.js.map +1 -1
  128. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.d.ts +5 -5
  129. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.d.ts.map +1 -1
  130. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.js +10 -10
  131. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.js.map +1 -1
  132. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionValueSpecificationBuilder.js +1 -1
  133. package/lib/stores/fetch-structure/tds/projection/QueryBuilderProjectionValueSpecificationBuilder.js.map +1 -1
  134. package/lib/stores/filter/QueryBuilderFilterValueSpecificationBuilder.d.ts +2 -2
  135. package/lib/stores/filter/QueryBuilderFilterValueSpecificationBuilder.d.ts.map +1 -1
  136. package/lib/stores/filter/QueryBuilderFilterValueSpecificationBuilder.js +6 -4
  137. package/lib/stores/filter/QueryBuilderFilterValueSpecificationBuilder.js.map +1 -1
  138. package/lib/stores/milestoning/QueryBuilderBitemporalMilestoningImplementation.d.ts +27 -0
  139. package/lib/stores/milestoning/QueryBuilderBitemporalMilestoningImplementation.d.ts.map +1 -0
  140. package/lib/stores/milestoning/QueryBuilderBitemporalMilestoningImplementation.js +93 -0
  141. package/lib/stores/milestoning/QueryBuilderBitemporalMilestoningImplementation.js.map +1 -0
  142. package/lib/stores/milestoning/QueryBuilderBusinessTemporalMilestoningImplementation.d.ts +26 -0
  143. package/lib/stores/milestoning/QueryBuilderBusinessTemporalMilestoningImplementation.d.ts.map +1 -0
  144. package/lib/stores/milestoning/QueryBuilderBusinessTemporalMilestoningImplementation.js +60 -0
  145. package/lib/stores/milestoning/QueryBuilderBusinessTemporalMilestoningImplementation.js.map +1 -0
  146. package/lib/stores/milestoning/QueryBuilderMilestoningHelper.d.ts +70 -0
  147. package/lib/stores/milestoning/QueryBuilderMilestoningHelper.d.ts.map +1 -0
  148. package/lib/stores/milestoning/QueryBuilderMilestoningHelper.js +199 -0
  149. package/lib/stores/milestoning/QueryBuilderMilestoningHelper.js.map +1 -0
  150. package/lib/stores/milestoning/QueryBuilderMilestoningImplementation.d.ts +49 -0
  151. package/lib/stores/milestoning/QueryBuilderMilestoningImplementation.d.ts.map +1 -0
  152. package/lib/stores/milestoning/QueryBuilderMilestoningImplementation.js +24 -0
  153. package/lib/stores/milestoning/QueryBuilderMilestoningImplementation.js.map +1 -0
  154. package/lib/stores/{QueryBuilderMilestoningState.d.ts → milestoning/QueryBuilderMilestoningState.d.ts} +6 -2
  155. package/lib/stores/milestoning/QueryBuilderMilestoningState.d.ts.map +1 -0
  156. package/lib/stores/{QueryBuilderMilestoningState.js → milestoning/QueryBuilderMilestoningState.js} +20 -20
  157. package/lib/stores/milestoning/QueryBuilderMilestoningState.js.map +1 -0
  158. package/lib/stores/milestoning/QueryBuilderProcessingTemporalMilestoningImplementation.d.ts +26 -0
  159. package/lib/stores/milestoning/QueryBuilderProcessingTemporalMilestoningImplementation.d.ts.map +1 -0
  160. package/lib/stores/milestoning/QueryBuilderProcessingTemporalMilestoningImplementation.js +55 -0
  161. package/lib/stores/milestoning/QueryBuilderProcessingTemporalMilestoningImplementation.js.map +1 -0
  162. package/lib/stores/shared/LambdaParameterState.d.ts +14 -2
  163. package/lib/stores/shared/LambdaParameterState.d.ts.map +1 -1
  164. package/lib/stores/shared/LambdaParameterState.js +79 -6
  165. package/lib/stores/shared/LambdaParameterState.js.map +1 -1
  166. package/lib/stores/shared/ValueSpecificationEditorHelper.d.ts +3 -1
  167. package/lib/stores/shared/ValueSpecificationEditorHelper.d.ts.map +1 -1
  168. package/lib/stores/shared/ValueSpecificationEditorHelper.js +58 -2
  169. package/lib/stores/shared/ValueSpecificationEditorHelper.js.map +1 -1
  170. package/lib/stores/watermark/QueryBuilderWatermarkStateBuilder.d.ts +2 -2
  171. package/lib/stores/watermark/QueryBuilderWatermarkStateBuilder.d.ts.map +1 -1
  172. package/lib/stores/watermark/QueryBuilderWatermarkStateBuilder.js +2 -2
  173. package/lib/stores/watermark/QueryBuilderWatermarkStateBuilder.js.map +1 -1
  174. package/lib/stores/watermark/QueryBuilderWatermarkValueSpecificationBuilder.d.ts +2 -2
  175. package/lib/stores/watermark/QueryBuilderWatermarkValueSpecificationBuilder.d.ts.map +1 -1
  176. package/lib/stores/watermark/QueryBuilderWatermarkValueSpecificationBuilder.js +7 -4
  177. package/lib/stores/watermark/QueryBuilderWatermarkValueSpecificationBuilder.js.map +1 -1
  178. package/lib/stores/workflows/ServiceQueryBuilderState.js +1 -1
  179. package/lib/stores/workflows/ServiceQueryBuilderState.js.map +1 -1
  180. package/package.json +15 -15
  181. package/src/components/QueryBuilder.tsx +38 -0
  182. package/src/components/QueryBuilderConstantExpressionPanel.tsx +284 -0
  183. package/src/components/QueryBuilderDiffPanel.tsx +0 -2
  184. package/src/components/QueryBuilderParametersPanel.tsx +24 -110
  185. package/src/components/QueryBuilderPropertyExpressionEditor.tsx +119 -36
  186. package/src/components/QueryBuilderSideBar.tsx +5 -22
  187. package/src/components/explorer/QueryBuilderMilestoningEditor.tsx +29 -39
  188. package/src/components/fetch-structure/{QueryBuilderOLAPGroupByPanel_.tsx → QueryBuilderOLAPGroupByPanel.tsx} +1 -1
  189. package/src/components/fetch-structure/QueryBuilderPostFilterPanel.tsx +18 -19
  190. package/src/components/fetch-structure/QueryBuilderPostTDSPanel.tsx +1 -1
  191. package/src/components/fetch-structure/QueryBuilderTDSPanel.tsx +9 -9
  192. package/src/components/filter/QueryBuilderFilterPanel.tsx +16 -17
  193. package/src/components/shared/BasicValueSpecificationEditor.tsx +47 -22
  194. package/src/components/shared/LambdaEditor.tsx +0 -15
  195. package/src/components/shared/QueryBuilderVariableSelector.tsx +186 -0
  196. package/src/components/watermark/QueryBuilderWatermark.tsx +19 -31
  197. package/src/graphManager/QueryBuilderHashUtils.ts +2 -0
  198. package/src/stores/QueryBuilderConfig.ts +1 -0
  199. package/src/stores/QueryBuilderConstantsState.ts +173 -0
  200. package/src/stores/QueryBuilderParametersState.ts +0 -6
  201. package/src/stores/QueryBuilderPropertyEditorState.ts +6 -235
  202. package/src/stores/QueryBuilderResultState.ts +19 -17
  203. package/src/stores/QueryBuilderState.ts +25 -4
  204. package/src/stores/QueryBuilderStateBuilder.ts +111 -52
  205. package/src/stores/QueryBuilderValueSpecificationBuilder.ts +48 -58
  206. package/src/stores/QueryBuilderValueSpecificationBuilderHelper.ts +16 -105
  207. package/src/stores/QueryBuilderValueSpecificationHelper.ts +10 -29
  208. package/src/stores/fetch-structure/graph-fetch/QueryBuilderGraphFetchTreeStateBuilder.ts +5 -0
  209. package/src/stores/fetch-structure/tds/QueryBuilderTDSState.ts +2 -2
  210. package/src/stores/fetch-structure/tds/aggregation/QueryBuilderAggregationStateBuilder.ts +7 -0
  211. package/src/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByOperatorLoader_.ts → QueryBuilderOLAPGroupByOperatorLoader.ts} +0 -0
  212. package/src/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByState_.ts → QueryBuilderOLAPGroupByState.ts} +0 -0
  213. package/src/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByStateBuilder_.ts → QueryBuilderOLAPGroupByStateBuilder.ts} +3 -1
  214. package/src/stores/fetch-structure/tds/olapGroupBy/{QueryBuilderOLAPGroupByValueSpecificationBuilder_.ts → QueryBuilderOLAPGroupByValueSpecificationBuilder.ts} +1 -1
  215. package/src/stores/fetch-structure/tds/post-filter/operators/QueryBuilderPostFilterOperatorHelper.ts +1 -1
  216. package/src/stores/fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.ts +11 -0
  217. package/src/stores/fetch-structure/tds/projection/QueryBuilderProjectionValueSpecificationBuilder.ts +1 -1
  218. package/src/stores/filter/QueryBuilderFilterValueSpecificationBuilder.ts +10 -5
  219. package/src/stores/milestoning/QueryBuilderBitemporalMilestoningImplementation.ts +165 -0
  220. package/src/stores/milestoning/QueryBuilderBusinessTemporalMilestoningImplementation.ts +96 -0
  221. package/src/stores/milestoning/QueryBuilderMilestoningHelper.ts +311 -0
  222. package/src/stores/milestoning/QueryBuilderMilestoningImplementation.ts +77 -0
  223. package/src/stores/{QueryBuilderMilestoningState.ts → milestoning/QueryBuilderMilestoningState.ts} +55 -39
  224. package/src/stores/milestoning/QueryBuilderProcessingTemporalMilestoningImplementation.ts +88 -0
  225. package/src/stores/shared/LambdaParameterState.ts +151 -10
  226. package/src/stores/shared/ValueSpecificationEditorHelper.ts +84 -2
  227. package/src/stores/watermark/QueryBuilderWatermarkStateBuilder.ts +3 -0
  228. package/src/stores/watermark/QueryBuilderWatermarkValueSpecificationBuilder.ts +11 -5
  229. package/src/stores/workflows/ServiceQueryBuilderState.ts +1 -1
  230. package/tsconfig.json +14 -6
  231. package/lib/components/fetch-structure/QueryBuilderOLAPGroupByPanel_.d.ts.map +0 -1
  232. package/lib/components/fetch-structure/QueryBuilderOLAPGroupByPanel_.js.map +0 -1
  233. package/lib/stores/QueryBuilderMilestoningState.d.ts.map +0 -1
  234. package/lib/stores/QueryBuilderMilestoningState.js.map +0 -1
  235. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByOperatorLoader_.d.ts.map +0 -1
  236. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByOperatorLoader_.js.map +0 -1
  237. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder_.d.ts.map +0 -1
  238. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder_.js.map +0 -1
  239. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByState_.d.ts.map +0 -1
  240. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByState_.js.map +0 -1
  241. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByValueSpecificationBuilder_.d.ts.map +0 -1
  242. package/lib/stores/fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByValueSpecificationBuilder_.js.map +0 -1
@@ -18,6 +18,8 @@ import {
18
18
  assertNonNullable,
19
19
  assertTrue,
20
20
  assertType,
21
+ guaranteeIsString,
22
+ guaranteeNonNullable,
21
23
  guaranteeType,
22
24
  UnsupportedOperationError,
23
25
  } from '@finos/legend-shared';
@@ -30,18 +32,18 @@ import {
30
32
  type InstanceValue,
31
33
  type INTERNAL__UnknownValueSpecification,
32
34
  type LambdaFunction,
33
- MILESTONING_STEREOTYPE,
34
35
  matchFunctionName,
35
36
  Class,
36
37
  type CollectionInstanceValue,
37
38
  type LambdaFunctionInstanceValue,
38
- type PrimitiveInstanceValue,
39
+ PrimitiveInstanceValue,
39
40
  SimpleFunctionExpression,
40
41
  type VariableExpression,
41
42
  type AbstractPropertyExpression,
42
43
  getMilestoneTemporalStereotype,
43
44
  type INTERNAL__PropagatedValue,
44
45
  type ValueSpecification,
46
+ SUPPORTED_FUNCTIONS,
45
47
  } from '@finos/legend-graph';
46
48
  import { processTDSPostFilterExpression } from './fetch-structure/tds/post-filter/QueryBuilderPostFilterStateBuilder.js';
47
49
  import { processFilterExpression } from './filter/QueryBuilderFilterStateBuilder.js';
@@ -64,8 +66,9 @@ import {
64
66
  } from './fetch-structure/tds/projection/QueryBuilderProjectionStateBuilder.js';
65
67
  import { QUERY_BUILDER_SUPPORTED_FUNCTIONS } from '../graphManager/QueryBuilderSupportedFunctions.js';
66
68
  import { LambdaParameterState } from './shared/LambdaParameterState.js';
67
- import { processTDS_OLAPGroupByExpression } from './fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder_.js';
69
+ import { processTDS_OLAPGroupByExpression } from './fetch-structure/tds/olapGroupBy/QueryBuilderOLAPGroupByStateBuilder.js';
68
70
  import { processWatermarkExpression } from './watermark/QueryBuilderWatermarkStateBuilder.js';
71
+ import { QueryBuilderConstantExpressionState } from './QueryBuilderConstantsState.js';
69
72
 
70
73
  const processGetAllExpression = (
71
74
  expression: SimpleFunctionExpression,
@@ -78,57 +81,62 @@ const processGetAllExpression = (
78
81
  `Can't process getAll() expression: getAll() return type is missing`,
79
82
  );
80
83
  queryBuilderState.setClass(_class);
81
- queryBuilderState.milestoningState.updateMilestoningConfiguration();
84
+ queryBuilderState.milestoningState.clearMilestoningDates();
82
85
  queryBuilderState.explorerState.refreshTreeData();
83
86
 
84
87
  // check parameters (milestoning) and build state
85
- let acceptedNoOfParameters = 1;
88
+ const acceptedNoOfParameters = 1;
86
89
  const stereotype = getMilestoneTemporalStereotype(
87
90
  _class,
88
91
  queryBuilderState.graphManagerState.graph,
89
92
  );
90
- switch (stereotype) {
91
- case MILESTONING_STEREOTYPE.BITEMPORAL:
92
- acceptedNoOfParameters = 3;
93
- assertTrue(
94
- expression.parametersValues.length === acceptedNoOfParameters,
95
- `Can't process getAll() expression: when used with a bitemporal milestoned class getAll() expects two parameters`,
96
- );
97
- queryBuilderState.milestoningState.setProcessingDate(
98
- expression.parametersValues[1],
99
- );
100
- queryBuilderState.milestoningState.setBusinessDate(
101
- expression.parametersValues[2],
102
- );
103
- break;
104
- case MILESTONING_STEREOTYPE.BUSINESS_TEMPORAL:
105
- acceptedNoOfParameters = 2;
106
- assertTrue(
107
- expression.parametersValues.length === acceptedNoOfParameters,
108
- `Can't process getAll() expression: when used with a milestoned class getAll() expects a parameter`,
109
- );
110
- queryBuilderState.milestoningState.setBusinessDate(
111
- expression.parametersValues[1],
112
- );
113
- break;
114
- case MILESTONING_STEREOTYPE.PROCESSING_TEMPORAL:
115
- acceptedNoOfParameters = 2;
116
- assertTrue(
117
- expression.parametersValues.length === acceptedNoOfParameters,
118
- `Can't process getAll() expression: when used with a milestoned class getAll() expects a parameter`,
119
- );
120
- queryBuilderState.milestoningState.setProcessingDate(
121
- expression.parametersValues[1],
122
- );
123
- break;
124
- default:
125
- assertTrue(
126
- expression.parametersValues.length === acceptedNoOfParameters,
127
- `Can't process getAll() expression: getAll() expects no arguments`,
128
- );
93
+ if (stereotype) {
94
+ queryBuilderState.milestoningState
95
+ .getMilestoningImplementation(stereotype)
96
+ .processGetAllParamaters(expression.parametersValues);
97
+ } else {
98
+ assertTrue(
99
+ expression.parametersValues.length === acceptedNoOfParameters,
100
+ `Can't process getAll() expression: getAll() expects no arguments`,
101
+ );
129
102
  }
130
103
  };
131
104
 
105
+ const processLetExpression = (
106
+ expression: SimpleFunctionExpression,
107
+ queryBuilderState: QueryBuilderState,
108
+ parentLambda: LambdaFunction,
109
+ ): void => {
110
+ const parameters = expression.parametersValues;
111
+ assertTrue(
112
+ expression.parametersValues.length === 2,
113
+ 'Let function expected to have two parameters (left and right side value)',
114
+ );
115
+ // process left side (var)
116
+ const letVariable = guaranteeIsString(
117
+ guaranteeType(
118
+ parameters[0],
119
+ PrimitiveInstanceValue,
120
+ 'Can`t process let function: left side should be a primitive instance value',
121
+ ).values[0],
122
+ 'Can`t process let function: left side should be a string primitive instance value',
123
+ );
124
+ const varExp = guaranteeNonNullable(
125
+ parentLambda.openVariables.get(letVariable),
126
+ `Unable to find variable ${letVariable} in lambda function`,
127
+ );
128
+ // process right side (value)
129
+ const rightSide = guaranteeNonNullable(parameters[1]);
130
+ // final
131
+ const constantExpression = new QueryBuilderConstantExpressionState(
132
+ queryBuilderState,
133
+ varExp,
134
+ rightSide,
135
+ );
136
+ queryBuilderState.constantState.setShowConstantPanel(true);
137
+ queryBuilderState.constantState.addConstant(constantExpression);
138
+ };
139
+
132
140
  /**
133
141
  * This is the value specification processor (a.k.a state builder) for query builder.
134
142
  *
@@ -209,21 +217,29 @@ export class QueryBuilderValueSpecificationProcessor
209
217
  * value specification.
210
218
  */
211
219
  readonly parentExpression?: SimpleFunctionExpression | undefined;
220
+ readonly parentLambda: LambdaFunction;
212
221
 
213
222
  private constructor(
214
223
  queryBuilderState: QueryBuilderState,
224
+ parentLambda: LambdaFunction,
215
225
  parentExpression: SimpleFunctionExpression | undefined,
216
226
  ) {
217
227
  this.queryBuilderState = queryBuilderState;
218
228
  this.parentExpression = parentExpression;
229
+ this.parentLambda = parentLambda;
219
230
  }
220
231
 
221
232
  static process(
222
233
  valueSpecification: ValueSpecification,
234
+ parentLambda: LambdaFunction,
223
235
  queryBuilderState: QueryBuilderState,
224
236
  ): void {
225
237
  valueSpecification.accept_ValueSpecificationVisitor(
226
- new QueryBuilderValueSpecificationProcessor(queryBuilderState, undefined),
238
+ new QueryBuilderValueSpecificationProcessor(
239
+ queryBuilderState,
240
+ parentLambda,
241
+ undefined,
242
+ ),
227
243
  );
228
244
  }
229
245
 
@@ -234,11 +250,13 @@ export class QueryBuilderValueSpecificationProcessor
234
250
  static processChild(
235
251
  valueSpecification: ValueSpecification,
236
252
  parentExpression: SimpleFunctionExpression,
253
+ parentLambda: LambdaFunction,
237
254
  queryBuilderState: QueryBuilderState,
238
255
  ): void {
239
256
  valueSpecification.accept_ValueSpecificationVisitor(
240
257
  new QueryBuilderValueSpecificationProcessor(
241
258
  queryBuilderState,
259
+ parentLambda,
242
260
  parentExpression,
243
261
  ),
244
262
  );
@@ -316,6 +334,7 @@ export class QueryBuilderValueSpecificationProcessor
316
334
  );
317
335
  QueryBuilderValueSpecificationProcessor.process(
318
336
  precedingExpression,
337
+ this.parentLambda,
319
338
  this.queryBuilderState,
320
339
  );
321
340
 
@@ -371,7 +390,11 @@ export class QueryBuilderValueSpecificationProcessor
371
390
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.WATERMARK,
372
391
  )
373
392
  ) {
374
- processWatermarkExpression(valueSpecification, this.queryBuilderState);
393
+ processWatermarkExpression(
394
+ valueSpecification,
395
+ this.queryBuilderState,
396
+ this.parentLambda,
397
+ );
375
398
  return;
376
399
  } else if (
377
400
  matchFunctionName(
@@ -379,7 +402,11 @@ export class QueryBuilderValueSpecificationProcessor
379
402
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_PROJECT,
380
403
  )
381
404
  ) {
382
- processTDSProjectExpression(valueSpecification, this.queryBuilderState);
405
+ processTDSProjectExpression(
406
+ valueSpecification,
407
+ this.queryBuilderState,
408
+ this.parentLambda,
409
+ );
383
410
  return;
384
411
  } else if (
385
412
  matchFunctionName(
@@ -387,7 +414,11 @@ export class QueryBuilderValueSpecificationProcessor
387
414
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_TAKE,
388
415
  )
389
416
  ) {
390
- processTDSTakeExpression(valueSpecification, this.queryBuilderState);
417
+ processTDSTakeExpression(
418
+ valueSpecification,
419
+ this.queryBuilderState,
420
+ this.parentLambda,
421
+ );
391
422
  return;
392
423
  } else if (
393
424
  matchFunctionName(
@@ -395,7 +426,11 @@ export class QueryBuilderValueSpecificationProcessor
395
426
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_DISTINCT,
396
427
  )
397
428
  ) {
398
- processTDSDistinctExpression(valueSpecification, this.queryBuilderState);
429
+ processTDSDistinctExpression(
430
+ valueSpecification,
431
+ this.queryBuilderState,
432
+ this.parentLambda,
433
+ );
399
434
  return;
400
435
  } else if (
401
436
  matchFunctionName(
@@ -403,7 +438,11 @@ export class QueryBuilderValueSpecificationProcessor
403
438
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_SORT,
404
439
  )
405
440
  ) {
406
- processTDSSortExpression(valueSpecification, this.queryBuilderState);
441
+ processTDSSortExpression(
442
+ valueSpecification,
443
+ this.queryBuilderState,
444
+ this.parentLambda,
445
+ );
407
446
  return;
408
447
  } else if (
409
448
  matchFunctionName(functionName, [
@@ -423,7 +462,11 @@ export class QueryBuilderValueSpecificationProcessor
423
462
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_GROUP_BY,
424
463
  )
425
464
  ) {
426
- processTDSGroupByExpression(valueSpecification, this.queryBuilderState);
465
+ processTDSGroupByExpression(
466
+ valueSpecification,
467
+ this.queryBuilderState,
468
+ this.parentLambda,
469
+ );
427
470
  return;
428
471
  } else if (
429
472
  matchFunctionName(functionName, QUERY_BUILDER_SUPPORTED_FUNCTIONS.TDS_AGG)
@@ -432,6 +475,7 @@ export class QueryBuilderValueSpecificationProcessor
432
475
  valueSpecification,
433
476
  this.parentExpression,
434
477
  this.queryBuilderState,
478
+ this.parentLambda,
435
479
  );
436
480
  return;
437
481
  } else if (
@@ -443,6 +487,7 @@ export class QueryBuilderValueSpecificationProcessor
443
487
  processTDS_OLAPGroupByExpression(
444
488
  valueSpecification,
445
489
  this.queryBuilderState,
490
+ this.parentLambda,
446
491
  );
447
492
  return;
448
493
  } else if (
@@ -454,6 +499,7 @@ export class QueryBuilderValueSpecificationProcessor
454
499
  processGraphFetchSerializeExpression(
455
500
  valueSpecification,
456
501
  this.queryBuilderState,
502
+ this.parentLambda,
457
503
  );
458
504
  return;
459
505
  } else if (
@@ -462,7 +508,18 @@ export class QueryBuilderValueSpecificationProcessor
462
508
  QUERY_BUILDER_SUPPORTED_FUNCTIONS.GRAPH_FETCH,
463
509
  ])
464
510
  ) {
465
- processGraphFetchExpression(valueSpecification, this.queryBuilderState);
511
+ processGraphFetchExpression(
512
+ valueSpecification,
513
+ this.queryBuilderState,
514
+ this.parentLambda,
515
+ );
516
+ return;
517
+ } else if (matchFunctionName(functionName, [SUPPORTED_FUNCTIONS.LET])) {
518
+ processLetExpression(
519
+ valueSpecification,
520
+ this.queryBuilderState,
521
+ this.parentLambda,
522
+ );
466
523
  return;
467
524
  }
468
525
  throw new UnsupportedOperationError(
@@ -531,6 +588,7 @@ export class QueryBuilderValueSpecificationProcessor
531
588
  expression.accept_ValueSpecificationVisitor(
532
589
  new QueryBuilderValueSpecificationProcessor(
533
590
  this.queryBuilderState,
591
+ this.parentLambda,
534
592
  this.parentExpression,
535
593
  ),
536
594
  ),
@@ -574,6 +632,7 @@ export const processQueryLambdaFunction = (
574
632
  lambdaFunction.expressionSequence.map((expression) =>
575
633
  QueryBuilderValueSpecificationProcessor.process(
576
634
  expression,
635
+ lambdaFunction,
577
636
  queryBuilderState,
578
637
  ),
579
638
  );
@@ -28,7 +28,9 @@ import {
28
28
  GenericTypeExplicitReference,
29
29
  LambdaFunction,
30
30
  SimpleFunctionExpression,
31
- MILESTONING_STEREOTYPE,
31
+ PrimitiveInstanceValue,
32
+ PrimitiveType,
33
+ SUPPORTED_FUNCTIONS,
32
34
  } from '@finos/legend-graph';
33
35
  import type { QueryBuilderState } from './QueryBuilderState.js';
34
36
  import { buildFilterExpression } from './filter/QueryBuilderFilterValueSpecificationBuilder.js';
@@ -36,6 +38,8 @@ import type { LambdaFunctionBuilderOption } from './QueryBuilderValueSpecificati
36
38
  import type { QueryBuilderFetchStructureState } from './fetch-structure/QueryBuilderFetchStructureState.js';
37
39
  import { QUERY_BUILDER_SUPPORTED_FUNCTIONS } from '../graphManager/QueryBuilderSupportedFunctions.js';
38
40
  import { buildWatermarkExpression } from './watermark/QueryBuilderWatermarkValueSpecificationBuilder.js';
41
+ import { buildExecutionQueryFromLambdaFunction } from './shared/LambdaParameterState.js';
42
+ import type { QueryBuilderConstantExpressionState } from './QueryBuilderConstantsState.js';
39
43
 
40
44
  const buildGetAllFunction = (
41
45
  _class: Class,
@@ -53,6 +57,22 @@ const buildGetAllFunction = (
53
57
  return _func;
54
58
  };
55
59
 
60
+ const buildLetExpression = (
61
+ constantExpressionState: QueryBuilderConstantExpressionState,
62
+ ): SimpleFunctionExpression => {
63
+ const varName = constantExpressionState.variable.name;
64
+ const value = constantExpressionState.value;
65
+ const leftSide = new PrimitiveInstanceValue(
66
+ GenericTypeExplicitReference.create(new GenericType(PrimitiveType.STRING)),
67
+ );
68
+ leftSide.values = [varName];
69
+ const letFunc = new SimpleFunctionExpression(
70
+ extractElementNameFromPath(SUPPORTED_FUNCTIONS.LET),
71
+ );
72
+ letFunc.parametersValues = [leftSide, value];
73
+ return letFunc;
74
+ };
75
+
56
76
  const buildFetchStructure = (
57
77
  fetchStructureState: QueryBuilderFetchStructureState,
58
78
  lambdaFunction: LambdaFunction,
@@ -90,62 +110,17 @@ export const buildLambdaFunction = (
90
110
  queryBuilderState.graphManagerState.graph,
91
111
  );
92
112
  if (milestoningStereotype) {
93
- switch (milestoningStereotype) {
94
- case MILESTONING_STEREOTYPE.BUSINESS_TEMPORAL: {
95
- getAllFunction.parametersValues.push(
96
- guaranteeNonNullable(
97
- queryBuilderState.milestoningState.businessDate,
98
- `Milestoning class should have a parameter of type 'Date'`,
99
- ),
100
- );
101
- break;
102
- }
103
- case MILESTONING_STEREOTYPE.PROCESSING_TEMPORAL: {
104
- getAllFunction.parametersValues.push(
105
- guaranteeNonNullable(
106
- queryBuilderState.milestoningState.processingDate,
107
- `Milestoning class should have a parameter of type 'Date'`,
108
- ),
109
- );
110
- break;
111
- }
112
- case MILESTONING_STEREOTYPE.BITEMPORAL: {
113
- getAllFunction.parametersValues.push(
114
- guaranteeNonNullable(
115
- queryBuilderState.milestoningState.processingDate,
116
- `Milestoning class should have a parameter of type 'Date'`,
117
- ),
118
- );
119
- getAllFunction.parametersValues.push(
120
- guaranteeNonNullable(
121
- queryBuilderState.milestoningState.businessDate,
122
- `Milestoning class should have a parameter of type 'Date'`,
123
- ),
124
- );
125
- break;
126
- }
127
- default:
128
- }
113
+ queryBuilderState.milestoningState
114
+ .getMilestoningImplementation(milestoningStereotype)
115
+ .buildGetAllParameters(getAllFunction);
129
116
  }
130
117
  lambdaFunction.expressionSequence[0] = getAllFunction;
131
118
 
132
119
  // build watermark
133
- const watermarkFunction = buildWatermarkExpression(
134
- queryBuilderState.watermarkState,
135
- getAllFunction,
136
- );
137
- if (watermarkFunction) {
138
- lambdaFunction.expressionSequence[0] = watermarkFunction;
139
- }
120
+ buildWatermarkExpression(queryBuilderState.watermarkState, lambdaFunction);
140
121
 
141
122
  // build filter
142
- const filterFunction = buildFilterExpression(
143
- queryBuilderState.filterState,
144
- watermarkFunction ?? getAllFunction,
145
- );
146
- if (filterFunction) {
147
- lambdaFunction.expressionSequence[0] = filterFunction;
148
- }
123
+ buildFilterExpression(queryBuilderState.filterState, lambdaFunction);
149
124
 
150
125
  // build fetch-structure
151
126
  buildFetchStructure(
@@ -154,14 +129,29 @@ export const buildLambdaFunction = (
154
129
  options,
155
130
  );
156
131
 
132
+ // build variable expressions
133
+ if (queryBuilderState.constantState.constants.length) {
134
+ const letExpressions =
135
+ queryBuilderState.constantState.constants.map(buildLetExpression);
136
+ lambdaFunction.expressionSequence = [
137
+ ...letExpressions,
138
+ ...lambdaFunction.expressionSequence,
139
+ ];
140
+ }
157
141
  // build parameters
158
- if (
159
- !queryBuilderState.isParameterSupportDisabled &&
160
- queryBuilderState.parametersState.parameterStates.length
161
- ) {
162
- lambdaFunction.functionType.parameters =
163
- queryBuilderState.parametersState.parameterStates.map((e) => e.parameter);
142
+ if (queryBuilderState.parametersState.parameterStates.length) {
143
+ if (options?.isBuildingExecutionQuery) {
144
+ buildExecutionQueryFromLambdaFunction(
145
+ lambdaFunction,
146
+ queryBuilderState.parametersState.parameterStates,
147
+ queryBuilderState.graphManagerState,
148
+ );
149
+ } else {
150
+ lambdaFunction.functionType.parameters =
151
+ queryBuilderState.parametersState.parameterStates.map(
152
+ (e) => e.parameter,
153
+ );
154
+ }
164
155
  }
165
-
166
156
  return lambdaFunction;
167
157
  };
@@ -16,12 +16,9 @@
16
16
 
17
17
  import {
18
18
  AbstractPropertyExpression,
19
- Class,
20
19
  DerivedProperty,
21
- getMilestoneTemporalStereotype,
22
20
  INTERNAL__PropagatedValue,
23
21
  matchFunctionName,
24
- MILESTONING_STEREOTYPE,
25
22
  SimpleFunctionExpression,
26
23
  VariableExpression,
27
24
  type ValueSpecification,
@@ -32,103 +29,21 @@ import {
32
29
  guaranteeType,
33
30
  } from '@finos/legend-shared';
34
31
  import { QUERY_BUILDER_SUPPORTED_FUNCTIONS } from '../graphManager/QueryBuilderSupportedFunctions.js';
35
- import { getDerivedPropertyMilestoningSteoreotype } from './QueryBuilderPropertyEditorState.js';
36
32
  import type { QueryBuilderState } from './QueryBuilderState.js';
33
+ import { variableExpression_setName } from './shared/ValueSpecificationModifierHelper.js';
37
34
 
38
35
  /**
39
- * Checks if the provided property expression match the criteria for default
40
- * date propagation so we know whether we need to fill in values for the parameter
41
- * or just propgate values from the parent's expression
42
- *
43
- * NOTE: this takes date propgation into account. See the table below for all
44
- * the combination:
45
- *
46
- * | [source] | | | | |
47
- * ----------------------------------------------------------------------
48
- * [target] | | NONE | PR_TMP | BI_TMP | BU_TMP |
49
- * ----------------------------------------------------------------------
50
- * | NONE | N.A. | PRD | PRD,BUD | BUD |
51
- * ----------------------------------------------------------------------
52
- * | PR_TMP | N.A. | X | PRD,BUD | BUD |
53
- * ----------------------------------------------------------------------
54
- * | BI_TMP | N.A. | X | X | X |
55
- * ----------------------------------------------------------------------
56
- * | BU_TMP | N.A. | PRD | PRD,BUD | X |
57
- * ----------------------------------------------------------------------
58
- *
59
- * Annotations:
60
- *
61
- * [source]: source temporal type
62
- * [target]: target temporal type
63
- *
64
- * PR_TMP : processing temporal
65
- * BI_TMP : bitemporal
66
- * BU_TMP : business temporal
67
- *
68
- * X : no default date propagated
69
- * PRD : default processing date is propagated
70
- * BUD : default business date is propgated
36
+ * Gets the value of ValueSpecification given INTERNAL__PropagatedValue is pointing to.
71
37
  */
72
- const isDefaultDatePropagationSupported = (
73
- currentPropertyExpression: AbstractPropertyExpression,
74
- queryBuilderState: QueryBuilderState,
75
- prevPropertyExpression?: AbstractPropertyExpression | undefined,
76
- ): boolean => {
77
- const property = currentPropertyExpression.func.value;
78
- const graph = queryBuilderState.graphManagerState.graph;
79
- // Default date propagation is not supported for current expression when the previous property expression is a derived property.
80
- if (
81
- prevPropertyExpression &&
82
- prevPropertyExpression.func.value instanceof DerivedProperty &&
83
- prevPropertyExpression.func.value._OWNER.derivedProperties.includes(
84
- prevPropertyExpression.func.value,
85
- )
86
- ) {
87
- return false;
88
- }
89
- // Default date propagation is not supported for current expression when the milestonedParameterValues of
90
- // the previous property expression doesn't match with the global milestonedParameterValues
91
- if (
92
- prevPropertyExpression &&
93
- prevPropertyExpression.func.value.genericType.value.rawType instanceof Class
94
- ) {
95
- const milestoningStereotype = getMilestoneTemporalStereotype(
96
- prevPropertyExpression.func.value.genericType.value.rawType,
97
- graph,
98
- );
99
- if (
100
- milestoningStereotype &&
101
- !prevPropertyExpression.parametersValues
102
- .slice(1)
103
- .every(
104
- (parameterValue) =>
105
- parameterValue instanceof INTERNAL__PropagatedValue,
106
- )
107
- ) {
108
- return false;
109
- }
110
- }
111
- if (property.genericType.value.rawType instanceof Class) {
112
- // the stereotype of source class of current property expression.
113
- const sourceStereotype =
114
- property instanceof DerivedProperty
115
- ? getDerivedPropertyMilestoningSteoreotype(property, graph)
116
- : undefined;
117
- // Default date propagation is always supported if the source is `bitemporal`
118
- if (sourceStereotype === MILESTONING_STEREOTYPE.BITEMPORAL) {
119
- return true;
120
- }
121
- // the stereotype (if exists) of the generic type of current property expression.
122
- const targetStereotype = getMilestoneTemporalStereotype(
123
- property.genericType.value.rawType,
124
- graph,
38
+ const getValueOfInternalPropagatedValue = (
39
+ valueSpec: INTERNAL__PropagatedValue,
40
+ ): ValueSpecification => {
41
+ if (valueSpec.getValue() instanceof INTERNAL__PropagatedValue) {
42
+ return getValueOfInternalPropagatedValue(
43
+ guaranteeType(valueSpec.getValue(), INTERNAL__PropagatedValue),
125
44
  );
126
- // Default date propagation is supported when stereotype of both source and target matches
127
- if (sourceStereotype && targetStereotype) {
128
- return sourceStereotype === targetStereotype;
129
- }
130
45
  }
131
- return false;
46
+ return valueSpec.getValue();
132
47
  };
133
48
 
134
49
  export const buildPropertyExpressionChain = (
@@ -173,13 +88,7 @@ export const buildPropertyExpressionChain = (
173
88
  // Replace with argumentless derived property expression only when default date propagation is supported
174
89
  if (
175
90
  !TEMPORARY__disableDatePropagation &&
176
- isDefaultDatePropagationSupported(
177
- currentPropertyExpression,
178
- queryBuilderState,
179
- nextExpression instanceof AbstractPropertyExpression
180
- ? nextExpression
181
- : undefined,
182
- )
91
+ parameterValue.isPropagatedValue
183
92
  ) {
184
93
  // NOTE: For `bitemporal` property check if the property expression has parameters which are not instance of
185
94
  // `INTERNAL_PropagatedValue` then pass the parameters as user explicitly changed values of either of the parameters.
@@ -190,11 +99,13 @@ export const buildPropertyExpressionChain = (
190
99
  currentPropertyExpression.parametersValues.length === 3 &&
191
100
  !(
192
101
  currentPropertyExpression.parametersValues[2] instanceof
193
- INTERNAL__PropagatedValue
102
+ INTERNAL__PropagatedValue &&
103
+ currentPropertyExpression.parametersValues[2]
104
+ .isPropagatedValue === true
194
105
  ))
195
106
  ) {
196
107
  currentPropertyExpression.parametersValues[index + 1] =
197
- parameterValue.getValue();
108
+ getValueOfInternalPropagatedValue(parameterValue);
198
109
  } else {
199
110
  currentPropertyExpression.parametersValues = [
200
111
  guaranteeNonNullable(
@@ -205,7 +116,7 @@ export const buildPropertyExpressionChain = (
205
116
  }
206
117
  } else {
207
118
  currentPropertyExpression.parametersValues[index + 1] =
208
- parameterValue.getValue();
119
+ getValueOfInternalPropagatedValue(parameterValue);
209
120
  }
210
121
  }
211
122
  });
@@ -228,7 +139,7 @@ export const buildPropertyExpressionChain = (
228
139
 
229
140
  // Update the root lambda name based on the parent's lambda parameter name.
230
141
  if (currentExpression instanceof VariableExpression) {
231
- currentExpression.name = lambdaParameterName;
142
+ variableExpression_setName(currentExpression, lambdaParameterName);
232
143
  }
233
144
  return newPropertyExpression;
234
145
  };