@finos/legend-application-query 5.0.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 (553) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +3 -0
  3. package/lib/LegendQueryAppEvent.d.ts +19 -0
  4. package/lib/LegendQueryAppEvent.d.ts.map +1 -0
  5. package/lib/LegendQueryAppEvent.js +21 -0
  6. package/lib/LegendQueryAppEvent.js.map +1 -0
  7. package/lib/QueryBuilder_Const.d.ts +77 -0
  8. package/lib/QueryBuilder_Const.d.ts.map +1 -0
  9. package/lib/QueryBuilder_Const.js +85 -0
  10. package/lib/QueryBuilder_Const.js.map +1 -0
  11. package/lib/application/LegendQuery.d.ts +27 -0
  12. package/lib/application/LegendQuery.d.ts.map +1 -0
  13. package/lib/application/LegendQuery.js +58 -0
  14. package/lib/application/LegendQuery.js.map +1 -0
  15. package/lib/application/LegendQueryApplicationConfig.d.ts +46 -0
  16. package/lib/application/LegendQueryApplicationConfig.d.ts.map +1 -0
  17. package/lib/application/LegendQueryApplicationConfig.js +35 -0
  18. package/lib/application/LegendQueryApplicationConfig.js.map +1 -0
  19. package/lib/application/LegendQueryPluginManager.d.ts +32 -0
  20. package/lib/application/LegendQueryPluginManager.d.ts.map +1 -0
  21. package/lib/application/LegendQueryPluginManager.js +46 -0
  22. package/lib/application/LegendQueryPluginManager.js.map +1 -0
  23. package/lib/components/LegendQueryApplication.d.ts +25 -0
  24. package/lib/components/LegendQueryApplication.d.ts.map +1 -0
  25. package/lib/components/LegendQueryApplication.js +39 -0
  26. package/lib/components/LegendQueryApplication.js.map +1 -0
  27. package/lib/components/LegendQueryBaseStoreProvider.d.ts +28 -0
  28. package/lib/components/LegendQueryBaseStoreProvider.d.ts.map +1 -0
  29. package/lib/components/LegendQueryBaseStoreProvider.js +32 -0
  30. package/lib/components/LegendQueryBaseStoreProvider.js.map +1 -0
  31. package/lib/components/QueryBuilder.d.ts +23 -0
  32. package/lib/components/QueryBuilder.d.ts.map +1 -0
  33. package/lib/components/QueryBuilder.js +91 -0
  34. package/lib/components/QueryBuilder.js.map +1 -0
  35. package/lib/components/QueryBuilderExplorerPanel.d.ts +34 -0
  36. package/lib/components/QueryBuilderExplorerPanel.d.ts.map +1 -0
  37. package/lib/components/QueryBuilderExplorerPanel.js +379 -0
  38. package/lib/components/QueryBuilderExplorerPanel.js.map +1 -0
  39. package/lib/components/QueryBuilderFetchStructurePanel.d.ts +23 -0
  40. package/lib/components/QueryBuilderFetchStructurePanel.d.ts.map +1 -0
  41. package/lib/components/QueryBuilderFetchStructurePanel.js +89 -0
  42. package/lib/components/QueryBuilderFetchStructurePanel.js.map +1 -0
  43. package/lib/components/QueryBuilderFilterPanel.d.ts +23 -0
  44. package/lib/components/QueryBuilderFilterPanel.d.ts.map +1 -0
  45. package/lib/components/QueryBuilderFilterPanel.js +301 -0
  46. package/lib/components/QueryBuilderFilterPanel.js.map +1 -0
  47. package/lib/components/QueryBuilderFunctionsExplorerPanel.d.ts +23 -0
  48. package/lib/components/QueryBuilderFunctionsExplorerPanel.d.ts.map +1 -0
  49. package/lib/components/QueryBuilderFunctionsExplorerPanel.js +177 -0
  50. package/lib/components/QueryBuilderFunctionsExplorerPanel.js.map +1 -0
  51. package/lib/components/QueryBuilderGraphFetchTreePanel.d.ts +33 -0
  52. package/lib/components/QueryBuilderGraphFetchTreePanel.d.ts.map +1 -0
  53. package/lib/components/QueryBuilderGraphFetchTreePanel.js +96 -0
  54. package/lib/components/QueryBuilderGraphFetchTreePanel.js.map +1 -0
  55. package/lib/components/QueryBuilderLambdaEditor.d.ts +42 -0
  56. package/lib/components/QueryBuilderLambdaEditor.d.ts.map +1 -0
  57. package/lib/components/QueryBuilderLambdaEditor.js +47 -0
  58. package/lib/components/QueryBuilderLambdaEditor.js.map +1 -0
  59. package/lib/components/QueryBuilderMilestoneEditor.d.ts +24 -0
  60. package/lib/components/QueryBuilderMilestoneEditor.d.ts.map +1 -0
  61. package/lib/components/QueryBuilderMilestoneEditor.js +120 -0
  62. package/lib/components/QueryBuilderMilestoneEditor.js.map +1 -0
  63. package/lib/components/QueryBuilderParameterPanel.d.ts +30 -0
  64. package/lib/components/QueryBuilderParameterPanel.d.ts.map +1 -0
  65. package/lib/components/QueryBuilderParameterPanel.js +148 -0
  66. package/lib/components/QueryBuilderParameterPanel.js.map +1 -0
  67. package/lib/components/QueryBuilderPostFilterPanel.d.ts +31 -0
  68. package/lib/components/QueryBuilderPostFilterPanel.d.ts.map +1 -0
  69. package/lib/components/QueryBuilderPostFilterPanel.js +373 -0
  70. package/lib/components/QueryBuilderPostFilterPanel.js.map +1 -0
  71. package/lib/components/QueryBuilderProjectionPanel.d.ts +23 -0
  72. package/lib/components/QueryBuilderProjectionPanel.d.ts.map +1 -0
  73. package/lib/components/QueryBuilderProjectionPanel.js +229 -0
  74. package/lib/components/QueryBuilderProjectionPanel.js.map +1 -0
  75. package/lib/components/QueryBuilderPropertyExpressionEditor.d.ts +30 -0
  76. package/lib/components/QueryBuilderPropertyExpressionEditor.d.ts.map +1 -0
  77. package/lib/components/QueryBuilderPropertyExpressionEditor.js +116 -0
  78. package/lib/components/QueryBuilderPropertyExpressionEditor.js.map +1 -0
  79. package/lib/components/QueryBuilderPropertyInfoTooltip.d.ts +26 -0
  80. package/lib/components/QueryBuilderPropertyInfoTooltip.d.ts.map +1 -0
  81. package/lib/components/QueryBuilderPropertyInfoTooltip.js +32 -0
  82. package/lib/components/QueryBuilderPropertyInfoTooltip.js.map +1 -0
  83. package/lib/components/QueryBuilderPropertySearchPanel.d.ts +24 -0
  84. package/lib/components/QueryBuilderPropertySearchPanel.d.ts.map +1 -0
  85. package/lib/components/QueryBuilderPropertySearchPanel.js +202 -0
  86. package/lib/components/QueryBuilderPropertySearchPanel.js.map +1 -0
  87. package/lib/components/QueryBuilderResultModifierPanel.d.ts +23 -0
  88. package/lib/components/QueryBuilderResultModifierPanel.d.ts.map +1 -0
  89. package/lib/components/QueryBuilderResultModifierPanel.js +88 -0
  90. package/lib/components/QueryBuilderResultModifierPanel.js.map +1 -0
  91. package/lib/components/QueryBuilderResultPanel.d.ts +23 -0
  92. package/lib/components/QueryBuilderResultPanel.d.ts.map +1 -0
  93. package/lib/components/QueryBuilderResultPanel.js +223 -0
  94. package/lib/components/QueryBuilderResultPanel.js.map +1 -0
  95. package/lib/components/QueryBuilderSetupPanel.d.ts +23 -0
  96. package/lib/components/QueryBuilderSetupPanel.d.ts.map +1 -0
  97. package/lib/components/QueryBuilderSetupPanel.js +148 -0
  98. package/lib/components/QueryBuilderSetupPanel.js.map +1 -0
  99. package/lib/components/QueryBuilderTextEditor.d.ts +23 -0
  100. package/lib/components/QueryBuilderTextEditor.d.ts.map +1 -0
  101. package/lib/components/QueryBuilderTextEditor.js +48 -0
  102. package/lib/components/QueryBuilderTextEditor.js.map +1 -0
  103. package/lib/components/QueryBuilderUnsupportedQueryEditor.d.ts +23 -0
  104. package/lib/components/QueryBuilderUnsupportedQueryEditor.d.ts.map +1 -0
  105. package/lib/components/QueryBuilderUnsupportedQueryEditor.js +35 -0
  106. package/lib/components/QueryBuilderUnsupportedQueryEditor.js.map +1 -0
  107. package/lib/components/QueryBuilder_TestID.d.ts +26 -0
  108. package/lib/components/QueryBuilder_TestID.d.ts.map +1 -0
  109. package/lib/components/QueryBuilder_TestID.js +27 -0
  110. package/lib/components/QueryBuilder_TestID.js.map +1 -0
  111. package/lib/components/QueryEditor.d.ts +29 -0
  112. package/lib/components/QueryEditor.d.ts.map +1 -0
  113. package/lib/components/QueryEditor.js +130 -0
  114. package/lib/components/QueryEditor.js.map +1 -0
  115. package/lib/components/QueryEditorComponentTestUtils.d.ts +35 -0
  116. package/lib/components/QueryEditorComponentTestUtils.d.ts.map +1 -0
  117. package/lib/components/QueryEditorComponentTestUtils.js +108 -0
  118. package/lib/components/QueryEditorComponentTestUtils.js.map +1 -0
  119. package/lib/components/QueryEditorStoreProvider.d.ts +37 -0
  120. package/lib/components/QueryEditorStoreProvider.d.ts.map +1 -0
  121. package/lib/components/QueryEditorStoreProvider.js +48 -0
  122. package/lib/components/QueryEditorStoreProvider.js.map +1 -0
  123. package/lib/components/QuerySetup.d.ts +18 -0
  124. package/lib/components/QuerySetup.d.ts.map +1 -0
  125. package/lib/components/QuerySetup.js +388 -0
  126. package/lib/components/QuerySetup.js.map +1 -0
  127. package/lib/components/QuerySetupStoreProvider.d.ts +23 -0
  128. package/lib/components/QuerySetupStoreProvider.d.ts.map +1 -0
  129. package/lib/components/QuerySetupStoreProvider.js +35 -0
  130. package/lib/components/QuerySetupStoreProvider.js.map +1 -0
  131. package/lib/components/shared/ElementIconUtils.d.ts +18 -0
  132. package/lib/components/shared/ElementIconUtils.d.ts.map +1 -0
  133. package/lib/components/shared/ElementIconUtils.js +37 -0
  134. package/lib/components/shared/ElementIconUtils.js.map +1 -0
  135. package/lib/graphManager/QueryBuilder_GraphManagerPlugin.d.ts +21 -0
  136. package/lib/graphManager/QueryBuilder_GraphManagerPlugin.d.ts.map +1 -0
  137. package/lib/graphManager/QueryBuilder_GraphManagerPlugin.js +27 -0
  138. package/lib/graphManager/QueryBuilder_GraphManagerPlugin.js.map +1 -0
  139. package/lib/graphManager/QueryBuilder_GraphManagerPreset.d.ts +24 -0
  140. package/lib/graphManager/QueryBuilder_GraphManagerPreset.d.ts.map +1 -0
  141. package/lib/graphManager/QueryBuilder_GraphManagerPreset.js +32 -0
  142. package/lib/graphManager/QueryBuilder_GraphManagerPreset.js.map +1 -0
  143. package/lib/graphManager/action/analytics/MappingRuntimeCompatibilityAnalysis.d.ts +21 -0
  144. package/lib/graphManager/action/analytics/MappingRuntimeCompatibilityAnalysis.d.ts.map +1 -0
  145. package/lib/graphManager/action/analytics/MappingRuntimeCompatibilityAnalysis.js +20 -0
  146. package/lib/graphManager/action/analytics/MappingRuntimeCompatibilityAnalysis.js.map +1 -0
  147. package/lib/graphManager/action/analytics/ServiceExecutionAnalysis.d.ts +21 -0
  148. package/lib/graphManager/action/analytics/ServiceExecutionAnalysis.d.ts.map +1 -0
  149. package/lib/graphManager/action/analytics/ServiceExecutionAnalysis.js +20 -0
  150. package/lib/graphManager/action/analytics/ServiceExecutionAnalysis.js.map +1 -0
  151. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtension.d.ts +25 -0
  152. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtension.d.ts.map +1 -0
  153. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtension.js +21 -0
  154. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtension.js.map +1 -0
  155. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtensionBuilder.d.ts +18 -0
  156. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtensionBuilder.d.ts.map +1 -0
  157. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtensionBuilder.js +20 -0
  158. package/lib/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtensionBuilder.js.map +1 -0
  159. package/lib/graphManager/protocol/pure/QueryBuilder_PureProtocolProcessorPlugin.d.ts +22 -0
  160. package/lib/graphManager/protocol/pure/QueryBuilder_PureProtocolProcessorPlugin.d.ts.map +1 -0
  161. package/lib/graphManager/protocol/pure/QueryBuilder_PureProtocolProcessorPlugin.js +68 -0
  162. package/lib/graphManager/protocol/pure/QueryBuilder_PureProtocolProcessorPlugin.js.map +1 -0
  163. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_FunctionExpressionBuilder.d.ts +22 -0
  164. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_FunctionExpressionBuilder.d.ts.map +1 -0
  165. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_FunctionExpressionBuilder.js +207 -0
  166. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_FunctionExpressionBuilder.js.map +1 -0
  167. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PropertyExpressionTypeInferenceBuilder.d.ts +18 -0
  168. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PropertyExpressionTypeInferenceBuilder.d.ts.map +1 -0
  169. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PropertyExpressionTypeInferenceBuilder.js +18 -0
  170. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PropertyExpressionTypeInferenceBuilder.js.map +1 -0
  171. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PureGraphManagerExtension.d.ts +29 -0
  172. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PureGraphManagerExtension.d.ts.map +1 -0
  173. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PureGraphManagerExtension.js +182 -0
  174. package/lib/graphManager/protocol/pure/v1/V1_QueryBuilder_PureGraphManagerExtension.js.map +1 -0
  175. package/lib/index.css +17 -0
  176. package/lib/index.css.map +1 -0
  177. package/lib/index.d.ts +36 -0
  178. package/lib/index.d.ts.map +1 -0
  179. package/lib/index.js +36 -0
  180. package/lib/index.js.map +1 -0
  181. package/lib/package.json +99 -0
  182. package/lib/stores/LegendQueryApplicationPlugin.d.ts +47 -0
  183. package/lib/stores/LegendQueryApplicationPlugin.d.ts.map +1 -0
  184. package/lib/stores/LegendQueryApplicationPlugin.js +27 -0
  185. package/lib/stores/LegendQueryApplicationPlugin.js.map +1 -0
  186. package/lib/stores/LegendQueryBaseStore.d.ts +28 -0
  187. package/lib/stores/LegendQueryBaseStore.d.ts.map +1 -0
  188. package/lib/stores/LegendQueryBaseStore.js +28 -0
  189. package/lib/stores/LegendQueryBaseStore.js.map +1 -0
  190. package/lib/stores/LegendQueryEventService.d.ts +27 -0
  191. package/lib/stores/LegendQueryEventService.d.ts.map +1 -0
  192. package/lib/stores/LegendQueryEventService.js +29 -0
  193. package/lib/stores/LegendQueryEventService.js.map +1 -0
  194. package/lib/stores/LegendQueryRouter.d.ts +55 -0
  195. package/lib/stores/LegendQueryRouter.d.ts.map +1 -0
  196. package/lib/stores/LegendQueryRouter.js +50 -0
  197. package/lib/stores/LegendQueryRouter.js.map +1 -0
  198. package/lib/stores/QueryBuilderAggregationState.d.ts +53 -0
  199. package/lib/stores/QueryBuilderAggregationState.d.ts.map +1 -0
  200. package/lib/stores/QueryBuilderAggregationState.js +122 -0
  201. package/lib/stores/QueryBuilderAggregationState.js.map +1 -0
  202. package/lib/stores/QueryBuilderExplorerState.d.ts +93 -0
  203. package/lib/stores/QueryBuilderExplorerState.d.ts.map +1 -0
  204. package/lib/stores/QueryBuilderExplorerState.js +310 -0
  205. package/lib/stores/QueryBuilderExplorerState.js.map +1 -0
  206. package/lib/stores/QueryBuilderFetchStructureState.d.ts +33 -0
  207. package/lib/stores/QueryBuilderFetchStructureState.d.ts.map +1 -0
  208. package/lib/stores/QueryBuilderFetchStructureState.js +50 -0
  209. package/lib/stores/QueryBuilderFetchStructureState.js.map +1 -0
  210. package/lib/stores/QueryBuilderFilterState.d.ts +127 -0
  211. package/lib/stores/QueryBuilderFilterState.d.ts.map +1 -0
  212. package/lib/stores/QueryBuilderFilterState.js +566 -0
  213. package/lib/stores/QueryBuilderFilterState.js.map +1 -0
  214. package/lib/stores/QueryBuilderGraphFetchTreeState.d.ts +35 -0
  215. package/lib/stores/QueryBuilderGraphFetchTreeState.d.ts.map +1 -0
  216. package/lib/stores/QueryBuilderGraphFetchTreeState.js +65 -0
  217. package/lib/stores/QueryBuilderGraphFetchTreeState.js.map +1 -0
  218. package/lib/stores/QueryBuilderGraphFetchTreeUtil.d.ts +41 -0
  219. package/lib/stores/QueryBuilderGraphFetchTreeUtil.d.ts.map +1 -0
  220. package/lib/stores/QueryBuilderGraphFetchTreeUtil.js +173 -0
  221. package/lib/stores/QueryBuilderGraphFetchTreeUtil.js.map +1 -0
  222. package/lib/stores/QueryBuilderLambdaBuilder.d.ts +30 -0
  223. package/lib/stores/QueryBuilderLambdaBuilder.d.ts.map +1 -0
  224. package/lib/stores/QueryBuilderLambdaBuilder.js +407 -0
  225. package/lib/stores/QueryBuilderLambdaBuilder.js.map +1 -0
  226. package/lib/stores/QueryBuilderLambdaProcessor.d.ts +56 -0
  227. package/lib/stores/QueryBuilderLambdaProcessor.d.ts.map +1 -0
  228. package/lib/stores/QueryBuilderLambdaProcessor.js +544 -0
  229. package/lib/stores/QueryBuilderLambdaProcessor.js.map +1 -0
  230. package/lib/stores/QueryBuilderOperatorsHelper.d.ts +28 -0
  231. package/lib/stores/QueryBuilderOperatorsHelper.d.ts.map +1 -0
  232. package/lib/stores/QueryBuilderOperatorsHelper.js +123 -0
  233. package/lib/stores/QueryBuilderOperatorsHelper.js.map +1 -0
  234. package/lib/stores/QueryBuilderPostFilterOperator.d.ts +29 -0
  235. package/lib/stores/QueryBuilderPostFilterOperator.d.ts.map +1 -0
  236. package/lib/stores/QueryBuilderPostFilterOperator.js +30 -0
  237. package/lib/stores/QueryBuilderPostFilterOperator.js.map +1 -0
  238. package/lib/stores/QueryBuilderPostFilterProcessor.d.ts +24 -0
  239. package/lib/stores/QueryBuilderPostFilterProcessor.d.ts.map +1 -0
  240. package/lib/stores/QueryBuilderPostFilterProcessor.js +111 -0
  241. package/lib/stores/QueryBuilderPostFilterProcessor.js.map +1 -0
  242. package/lib/stores/QueryBuilderPostFilterState.d.ts +132 -0
  243. package/lib/stores/QueryBuilderPostFilterState.d.ts.map +1 -0
  244. package/lib/stores/QueryBuilderPostFilterState.js +559 -0
  245. package/lib/stores/QueryBuilderPostFilterState.js.map +1 -0
  246. package/lib/stores/QueryBuilderPreviewDataHelper.d.ts +25 -0
  247. package/lib/stores/QueryBuilderPreviewDataHelper.d.ts.map +1 -0
  248. package/lib/stores/QueryBuilderPreviewDataHelper.js +161 -0
  249. package/lib/stores/QueryBuilderPreviewDataHelper.js.map +1 -0
  250. package/lib/stores/QueryBuilderProjectionState.d.ts +104 -0
  251. package/lib/stores/QueryBuilderProjectionState.d.ts.map +1 -0
  252. package/lib/stores/QueryBuilderProjectionState.js +432 -0
  253. package/lib/stores/QueryBuilderProjectionState.js.map +1 -0
  254. package/lib/stores/QueryBuilderPropertyEditorState.d.ts +62 -0
  255. package/lib/stores/QueryBuilderPropertyEditorState.d.ts.map +1 -0
  256. package/lib/stores/QueryBuilderPropertyEditorState.js +384 -0
  257. package/lib/stores/QueryBuilderPropertyEditorState.js.map +1 -0
  258. package/lib/stores/QueryBuilderPropertySearchPanelState.d.ts +46 -0
  259. package/lib/stores/QueryBuilderPropertySearchPanelState.d.ts.map +1 -0
  260. package/lib/stores/QueryBuilderPropertySearchPanelState.js +240 -0
  261. package/lib/stores/QueryBuilderPropertySearchPanelState.js.map +1 -0
  262. package/lib/stores/QueryBuilderResultState.d.ts +38 -0
  263. package/lib/stores/QueryBuilderResultState.d.ts.map +1 -0
  264. package/lib/stores/QueryBuilderResultState.js +164 -0
  265. package/lib/stores/QueryBuilderResultState.js.map +1 -0
  266. package/lib/stores/QueryBuilderSetupState.d.ts +46 -0
  267. package/lib/stores/QueryBuilderSetupState.d.ts.map +1 -0
  268. package/lib/stores/QueryBuilderSetupState.js +163 -0
  269. package/lib/stores/QueryBuilderSetupState.js.map +1 -0
  270. package/lib/stores/QueryBuilderState.d.ts +101 -0
  271. package/lib/stores/QueryBuilderState.d.ts.map +1 -0
  272. package/lib/stores/QueryBuilderState.js +371 -0
  273. package/lib/stores/QueryBuilderState.js.map +1 -0
  274. package/lib/stores/QueryBuilderUnsupportedState.d.ts +26 -0
  275. package/lib/stores/QueryBuilderUnsupportedState.d.ts.map +1 -0
  276. package/lib/stores/QueryBuilderUnsupportedState.js +36 -0
  277. package/lib/stores/QueryBuilderUnsupportedState.js.map +1 -0
  278. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.d.ts +19 -0
  279. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.d.ts.map +1 -0
  280. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.js +50 -0
  281. package/lib/stores/QueryBuilderValueSpecificationBuilderHelper.js.map +1 -0
  282. package/lib/stores/QueryEditorStore.d.ts +98 -0
  283. package/lib/stores/QueryEditorStore.d.ts.map +1 -0
  284. package/lib/stores/QueryEditorStore.js +370 -0
  285. package/lib/stores/QueryEditorStore.js.map +1 -0
  286. package/lib/stores/QueryEditorStoreTestUtils.d.ts +18 -0
  287. package/lib/stores/QueryEditorStoreTestUtils.d.ts.map +1 -0
  288. package/lib/stores/QueryEditorStoreTestUtils.js +42 -0
  289. package/lib/stores/QueryEditorStoreTestUtils.js.map +1 -0
  290. package/lib/stores/QueryFunctionsExplorerState.d.ts +63 -0
  291. package/lib/stores/QueryFunctionsExplorerState.d.ts.map +1 -0
  292. package/lib/stores/QueryFunctionsExplorerState.js +238 -0
  293. package/lib/stores/QueryFunctionsExplorerState.js.map +1 -0
  294. package/lib/stores/QueryParametersState.d.ts +30 -0
  295. package/lib/stores/QueryParametersState.d.ts.map +1 -0
  296. package/lib/stores/QueryParametersState.js +42 -0
  297. package/lib/stores/QueryParametersState.js.map +1 -0
  298. package/lib/stores/QueryResultSetModifierState.d.ts +52 -0
  299. package/lib/stores/QueryResultSetModifierState.d.ts.map +1 -0
  300. package/lib/stores/QueryResultSetModifierState.js +165 -0
  301. package/lib/stores/QueryResultSetModifierState.js.map +1 -0
  302. package/lib/stores/QuerySetupStore.d.ts +86 -0
  303. package/lib/stores/QuerySetupStore.d.ts.map +1 -0
  304. package/lib/stores/QuerySetupStore.js +297 -0
  305. package/lib/stores/QuerySetupStore.js.map +1 -0
  306. package/lib/stores/QueryTextEditorState.d.ts +49 -0
  307. package/lib/stores/QueryTextEditorState.d.ts.map +1 -0
  308. package/lib/stores/QueryTextEditorState.js +145 -0
  309. package/lib/stores/QueryTextEditorState.js.map +1 -0
  310. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperatorHelper.d.ts +21 -0
  311. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperatorHelper.d.ts.map +1 -0
  312. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperatorHelper.js +40 -0
  313. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperatorHelper.js.map +1 -0
  314. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Average.d.ts +26 -0
  315. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Average.d.ts.map +1 -0
  316. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Average.js +50 -0
  317. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Average.js.map +1 -0
  318. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Count.d.ts +26 -0
  319. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Count.d.ts.map +1 -0
  320. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Count.js +55 -0
  321. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Count.js.map +1 -0
  322. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Distinct.d.ts +25 -0
  323. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Distinct.d.ts.map +1 -0
  324. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Distinct.js +50 -0
  325. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Distinct.js.map +1 -0
  326. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_DistinctCount.d.ts +26 -0
  327. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_DistinctCount.d.ts.map +1 -0
  328. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_DistinctCount.js +77 -0
  329. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_DistinctCount.js.map +1 -0
  330. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_JoinString.d.ts +26 -0
  331. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_JoinString.d.ts.map +1 -0
  332. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_JoinString.js +66 -0
  333. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_JoinString.js.map +1 -0
  334. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Max.d.ts +25 -0
  335. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Max.d.ts.map +1 -0
  336. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Max.js +86 -0
  337. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Max.js.map +1 -0
  338. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Min.d.ts +25 -0
  339. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Min.d.ts.map +1 -0
  340. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Min.js +86 -0
  341. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Min.js.map +1 -0
  342. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Population.d.ts +26 -0
  343. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Population.d.ts.map +1 -0
  344. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Population.js +50 -0
  345. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Population.js.map +1 -0
  346. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Sample.d.ts +26 -0
  347. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Sample.d.ts.map +1 -0
  348. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Sample.js +50 -0
  349. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Sample.js.map +1 -0
  350. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Sum.d.ts +25 -0
  351. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Sum.d.ts.map +1 -0
  352. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Sum.js +45 -0
  353. package/lib/stores/aggregateOperators/QueryBuilderAggregateOperator_Sum.js.map +1 -0
  354. package/lib/stores/filterOperators/QueryBuilderFilterOperatorHelper.d.ts +20 -0
  355. package/lib/stores/filterOperators/QueryBuilderFilterOperatorHelper.d.ts.map +1 -0
  356. package/lib/stores/filterOperators/QueryBuilderFilterOperatorHelper.js +257 -0
  357. package/lib/stores/filterOperators/QueryBuilderFilterOperatorHelper.js.map +1 -0
  358. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Contain.d.ts +31 -0
  359. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Contain.d.ts.map +1 -0
  360. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Contain.js +72 -0
  361. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Contain.js.map +1 -0
  362. package/lib/stores/filterOperators/QueryBuilderFilterOperator_EndWith.d.ts +31 -0
  363. package/lib/stores/filterOperators/QueryBuilderFilterOperator_EndWith.d.ts.map +1 -0
  364. package/lib/stores/filterOperators/QueryBuilderFilterOperator_EndWith.js +72 -0
  365. package/lib/stores/filterOperators/QueryBuilderFilterOperator_EndWith.js.map +1 -0
  366. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Equal.d.ts +31 -0
  367. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Equal.d.ts.map +1 -0
  368. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Equal.js +139 -0
  369. package/lib/stores/filterOperators/QueryBuilderFilterOperator_Equal.js.map +1 -0
  370. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThan.d.ts +26 -0
  371. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThan.d.ts.map +1 -0
  372. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThan.js +107 -0
  373. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThan.js.map +1 -0
  374. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThanEqual.d.ts +26 -0
  375. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThanEqual.d.ts.map +1 -0
  376. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThanEqual.js +107 -0
  377. package/lib/stores/filterOperators/QueryBuilderFilterOperator_GreaterThanEqual.js.map +1 -0
  378. package/lib/stores/filterOperators/QueryBuilderFilterOperator_In.d.ts +31 -0
  379. package/lib/stores/filterOperators/QueryBuilderFilterOperator_In.d.ts.map +1 -0
  380. package/lib/stores/filterOperators/QueryBuilderFilterOperator_In.js +103 -0
  381. package/lib/stores/filterOperators/QueryBuilderFilterOperator_In.js.map +1 -0
  382. package/lib/stores/filterOperators/QueryBuilderFilterOperator_IsEmpty.d.ts +31 -0
  383. package/lib/stores/filterOperators/QueryBuilderFilterOperator_IsEmpty.d.ts.map +1 -0
  384. package/lib/stores/filterOperators/QueryBuilderFilterOperator_IsEmpty.js +65 -0
  385. package/lib/stores/filterOperators/QueryBuilderFilterOperator_IsEmpty.js.map +1 -0
  386. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThan.d.ts +26 -0
  387. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThan.d.ts.map +1 -0
  388. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThan.js +108 -0
  389. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThan.js.map +1 -0
  390. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThanEqual.d.ts +26 -0
  391. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThanEqual.d.ts.map +1 -0
  392. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThanEqual.js +107 -0
  393. package/lib/stores/filterOperators/QueryBuilderFilterOperator_LessThanEqual.js.map +1 -0
  394. package/lib/stores/filterOperators/QueryBuilderFilterOperator_StartWith.d.ts +31 -0
  395. package/lib/stores/filterOperators/QueryBuilderFilterOperator_StartWith.d.ts.map +1 -0
  396. package/lib/stores/filterOperators/QueryBuilderFilterOperator_StartWith.js +72 -0
  397. package/lib/stores/filterOperators/QueryBuilderFilterOperator_StartWith.js.map +1 -0
  398. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperatorHelper.d.ts +23 -0
  399. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperatorHelper.d.ts.map +1 -0
  400. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperatorHelper.js +74 -0
  401. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperatorHelper.js.map +1 -0
  402. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Contain.d.ts +32 -0
  403. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Contain.d.ts.map +1 -0
  404. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Contain.js +76 -0
  405. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Contain.js.map +1 -0
  406. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_EndWith.d.ts +32 -0
  407. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_EndWith.d.ts.map +1 -0
  408. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_EndWith.js +76 -0
  409. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_EndWith.js.map +1 -0
  410. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Equal.d.ts +32 -0
  411. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Equal.d.ts.map +1 -0
  412. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Equal.js +142 -0
  413. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_Equal.js.map +1 -0
  414. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThan.d.ts +27 -0
  415. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThan.d.ts.map +1 -0
  416. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThan.js +105 -0
  417. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThan.js.map +1 -0
  418. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThanEqual.d.ts +24 -0
  419. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThanEqual.d.ts.map +1 -0
  420. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThanEqual.js +43 -0
  421. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThanEqual.js.map +1 -0
  422. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_In.d.ts +32 -0
  423. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_In.d.ts.map +1 -0
  424. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_In.js +104 -0
  425. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_In.js.map +1 -0
  426. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_IsEmpty.d.ts +33 -0
  427. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_IsEmpty.d.ts.map +1 -0
  428. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_IsEmpty.js +67 -0
  429. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_IsEmpty.js.map +1 -0
  430. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThan.d.ts +27 -0
  431. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThan.d.ts.map +1 -0
  432. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThan.js +105 -0
  433. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThan.js.map +1 -0
  434. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThanEqual.d.ts +24 -0
  435. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThanEqual.d.ts.map +1 -0
  436. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThanEqual.js +43 -0
  437. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThanEqual.js.map +1 -0
  438. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_StartWith.d.ts +32 -0
  439. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_StartWith.d.ts.map +1 -0
  440. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_StartWith.js +76 -0
  441. package/lib/stores/postFilterOperators/QueryBuilderPostFilterOperator_StartWith.js.map +1 -0
  442. package/package.json +99 -0
  443. package/src/LegendQueryAppEvent.ts +20 -0
  444. package/src/QueryBuilder_Const.ts +88 -0
  445. package/src/application/LegendQuery.tsx +92 -0
  446. package/src/application/LegendQueryApplicationConfig.ts +77 -0
  447. package/src/application/LegendQueryPluginManager.ts +67 -0
  448. package/src/components/LegendQueryApplication.tsx +104 -0
  449. package/src/components/LegendQueryBaseStoreProvider.tsx +68 -0
  450. package/src/components/QueryBuilder.tsx +375 -0
  451. package/src/components/QueryBuilderExplorerPanel.tsx +998 -0
  452. package/src/components/QueryBuilderFetchStructurePanel.tsx +184 -0
  453. package/src/components/QueryBuilderFilterPanel.tsx +858 -0
  454. package/src/components/QueryBuilderFunctionsExplorerPanel.tsx +598 -0
  455. package/src/components/QueryBuilderGraphFetchTreePanel.tsx +270 -0
  456. package/src/components/QueryBuilderLambdaEditor.tsx +117 -0
  457. package/src/components/QueryBuilderMilestoneEditor.tsx +291 -0
  458. package/src/components/QueryBuilderParameterPanel.tsx +434 -0
  459. package/src/components/QueryBuilderPostFilterPanel.tsx +1061 -0
  460. package/src/components/QueryBuilderProjectionPanel.tsx +652 -0
  461. package/src/components/QueryBuilderPropertyExpressionEditor.tsx +370 -0
  462. package/src/components/QueryBuilderPropertyInfoTooltip.tsx +87 -0
  463. package/src/components/QueryBuilderPropertySearchPanel.tsx +617 -0
  464. package/src/components/QueryBuilderResultModifierPanel.tsx +252 -0
  465. package/src/components/QueryBuilderResultPanel.tsx +582 -0
  466. package/src/components/QueryBuilderSetupPanel.tsx +341 -0
  467. package/src/components/QueryBuilderTextEditor.tsx +127 -0
  468. package/src/components/QueryBuilderUnsupportedQueryEditor.tsx +110 -0
  469. package/src/components/QueryBuilder_TestID.ts +26 -0
  470. package/src/components/QueryEditor.tsx +345 -0
  471. package/src/components/QueryEditorComponentTestUtils.tsx +200 -0
  472. package/src/components/QueryEditorStoreProvider.tsx +128 -0
  473. package/src/components/QuerySetup.tsx +907 -0
  474. package/src/components/QuerySetupStoreProvider.tsx +65 -0
  475. package/src/components/shared/ElementIconUtils.tsx +47 -0
  476. package/src/graphManager/QueryBuilder_GraphManagerPlugin.ts +32 -0
  477. package/src/graphManager/QueryBuilder_GraphManagerPreset.ts +33 -0
  478. package/src/graphManager/action/analytics/MappingRuntimeCompatibilityAnalysis.ts +22 -0
  479. package/src/graphManager/action/analytics/ServiceExecutionAnalysis.ts +22 -0
  480. package/src/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtension.ts +47 -0
  481. package/src/graphManager/protocol/pure/QueryBuilder_PureGraphManagerExtensionBuilder.ts +27 -0
  482. package/src/graphManager/protocol/pure/QueryBuilder_PureProtocolProcessorPlugin.ts +170 -0
  483. package/src/graphManager/protocol/pure/v1/V1_QueryBuilder_FunctionExpressionBuilder.ts +573 -0
  484. package/src/graphManager/protocol/pure/v1/V1_QueryBuilder_PropertyExpressionTypeInferenceBuilder.ts +28 -0
  485. package/src/graphManager/protocol/pure/v1/V1_QueryBuilder_PureGraphManagerExtension.ts +296 -0
  486. package/src/index.ts +57 -0
  487. package/src/stores/LegendQueryApplicationPlugin.ts +61 -0
  488. package/src/stores/LegendQueryBaseStore.ts +47 -0
  489. package/src/stores/LegendQueryEventService.ts +38 -0
  490. package/src/stores/LegendQueryRouter.ts +114 -0
  491. package/src/stores/QueryBuilderAggregationState.ts +208 -0
  492. package/src/stores/QueryBuilderExplorerState.ts +590 -0
  493. package/src/stores/QueryBuilderFetchStructureState.ts +59 -0
  494. package/src/stores/QueryBuilderFilterState.ts +815 -0
  495. package/src/stores/QueryBuilderGraphFetchTreeState.ts +90 -0
  496. package/src/stores/QueryBuilderGraphFetchTreeUtil.ts +281 -0
  497. package/src/stores/QueryBuilderLambdaBuilder.ts +755 -0
  498. package/src/stores/QueryBuilderLambdaProcessor.ts +1239 -0
  499. package/src/stores/QueryBuilderOperatorsHelper.ts +191 -0
  500. package/src/stores/QueryBuilderPostFilterOperator.ts +66 -0
  501. package/src/stores/QueryBuilderPostFilterProcessor.ts +275 -0
  502. package/src/stores/QueryBuilderPostFilterState.ts +762 -0
  503. package/src/stores/QueryBuilderPreviewDataHelper.ts +300 -0
  504. package/src/stores/QueryBuilderProjectionState.ts +796 -0
  505. package/src/stores/QueryBuilderPropertyEditorState.ts +656 -0
  506. package/src/stores/QueryBuilderPropertySearchPanelState.ts +331 -0
  507. package/src/stores/QueryBuilderResultState.ts +263 -0
  508. package/src/stores/QueryBuilderSetupState.ts +236 -0
  509. package/src/stores/QueryBuilderState.ts +561 -0
  510. package/src/stores/QueryBuilderUnsupportedState.ts +42 -0
  511. package/src/stores/QueryBuilderValueSpecificationBuilderHelper.ts +76 -0
  512. package/src/stores/QueryEditorStore.ts +648 -0
  513. package/src/stores/QueryEditorStoreTestUtils.ts +46 -0
  514. package/src/stores/QueryFunctionsExplorerState.ts +386 -0
  515. package/src/stores/QueryParametersState.ts +54 -0
  516. package/src/stores/QueryResultSetModifierState.ts +307 -0
  517. package/src/stores/QuerySetupStore.ts +430 -0
  518. package/src/stores/QueryTextEditorState.ts +203 -0
  519. package/src/stores/aggregateOperators/QueryBuilderAggregateOperatorHelper.ts +111 -0
  520. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Average.ts +100 -0
  521. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Count.ts +108 -0
  522. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Distinct.ts +98 -0
  523. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_DistinctCount.ts +175 -0
  524. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_JoinString.ts +157 -0
  525. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Max.ts +176 -0
  526. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Min.ts +176 -0
  527. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Population.ts +100 -0
  528. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_StdDev_Sample.ts +100 -0
  529. package/src/stores/aggregateOperators/QueryBuilderAggregateOperator_Sum.ts +90 -0
  530. package/src/stores/filterOperators/QueryBuilderFilterOperatorHelper.ts +524 -0
  531. package/src/stores/filterOperators/QueryBuilderFilterOperator_Contain.ts +134 -0
  532. package/src/stores/filterOperators/QueryBuilderFilterOperator_EndWith.ts +134 -0
  533. package/src/stores/filterOperators/QueryBuilderFilterOperator_Equal.ts +233 -0
  534. package/src/stores/filterOperators/QueryBuilderFilterOperator_GreaterThan.ts +164 -0
  535. package/src/stores/filterOperators/QueryBuilderFilterOperator_GreaterThanEqual.ts +164 -0
  536. package/src/stores/filterOperators/QueryBuilderFilterOperator_In.ts +181 -0
  537. package/src/stores/filterOperators/QueryBuilderFilterOperator_IsEmpty.ts +125 -0
  538. package/src/stores/filterOperators/QueryBuilderFilterOperator_LessThan.ts +165 -0
  539. package/src/stores/filterOperators/QueryBuilderFilterOperator_LessThanEqual.ts +164 -0
  540. package/src/stores/filterOperators/QueryBuilderFilterOperator_StartWith.ts +134 -0
  541. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperatorHelper.ts +129 -0
  542. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_Contain.ts +140 -0
  543. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_EndWith.ts +135 -0
  544. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_Equal.ts +238 -0
  545. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThan.ts +161 -0
  546. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_GreaterThanEqual.ts +70 -0
  547. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_In.ts +183 -0
  548. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_IsEmpty.ts +113 -0
  549. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThan.ts +161 -0
  550. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_LessThanEqual.ts +70 -0
  551. package/src/stores/postFilterOperators/QueryBuilderPostFilterOperator_StartWith.ts +135 -0
  552. package/tsconfig.json +155 -0
  553. package/tsconfig.package.json +38 -0
@@ -0,0 +1,815 @@
1
+ /**
2
+ * Copyright (c) 2020-present, Goldman Sachs
3
+ *
4
+ * Licensed under the Apache License, Version 2.0 (the "License");
5
+ * you may not use this file except in compliance with the License.
6
+ * You may obtain a copy of the License at
7
+ *
8
+ * http://www.apache.org/licenses/LICENSE-2.0
9
+ *
10
+ * Unless required by applicable law or agreed to in writing, software
11
+ * distributed under the License is distributed on an "AS IS" BASIS,
12
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
+ * See the License for the specific language governing permissions and
14
+ * limitations under the License.
15
+ */
16
+
17
+ import {
18
+ action,
19
+ computed,
20
+ makeAutoObservable,
21
+ makeObservable,
22
+ observable,
23
+ } from 'mobx';
24
+ import type { TreeNodeData, TreeData } from '@finos/legend-art';
25
+ import {
26
+ assertTrue,
27
+ getNullableFirstElement,
28
+ guaranteeNonNullable,
29
+ guaranteeType,
30
+ IllegalStateError,
31
+ isNonNullable,
32
+ uuid,
33
+ addUniqueEntry,
34
+ deleteEntry,
35
+ assertErrorThrown,
36
+ filterByType,
37
+ } from '@finos/legend-shared';
38
+ import type { QueryBuilderExplorerTreeDragSource } from './QueryBuilderExplorerState.js';
39
+ import { QueryBuilderPropertyExpressionState } from './QueryBuilderPropertyEditorState.js';
40
+ import type { QueryBuilderState } from './QueryBuilderState.js';
41
+ import {
42
+ type AbstractPropertyExpression,
43
+ type ValueSpecification,
44
+ extractElementNameFromPath,
45
+ SimpleFunctionExpression,
46
+ TYPICAL_MULTIPLICITY_TYPE,
47
+ observe_ValueSpecification,
48
+ } from '@finos/legend-graph';
49
+ import {
50
+ DEFAULT_LAMBDA_VARIABLE_NAME,
51
+ QUERY_BUILDER_SUPPORTED_FUNCTIONS,
52
+ } from '../QueryBuilder_Const.js';
53
+ import { buildGenericLambdaFunctionInstanceValue } from './QueryBuilderValueSpecificationBuilderHelper.js';
54
+ import {
55
+ fromGroupOperation,
56
+ QUERY_BUILDER_GROUP_OPERATION,
57
+ } from './QueryBuilderOperatorsHelper.js';
58
+
59
+ export abstract class QueryBuilderFilterOperator {
60
+ readonly uuid = uuid();
61
+
62
+ abstract getLabel(filterConditionState: FilterConditionState): string;
63
+
64
+ abstract isCompatibleWithFilterConditionProperty(
65
+ filterConditionState: FilterConditionState,
66
+ ): boolean;
67
+
68
+ abstract isCompatibleWithFilterConditionValue(
69
+ filterConditionState: FilterConditionState,
70
+ ): boolean;
71
+
72
+ abstract getDefaultFilterConditionValue(
73
+ filterConditionState: FilterConditionState,
74
+ ): ValueSpecification | undefined;
75
+
76
+ abstract buildFilterConditionExpression(
77
+ filterConditionState: FilterConditionState,
78
+ ): ValueSpecification;
79
+
80
+ abstract buildFilterConditionState(
81
+ filterState: QueryBuilderFilterState,
82
+ expression: SimpleFunctionExpression,
83
+ ): FilterConditionState | undefined;
84
+ }
85
+
86
+ export enum QUERY_BUILDER_FILTER_DND_TYPE {
87
+ GROUP_CONDITION = 'GROUP_CONDITION',
88
+ CONDITION = 'CONDITION',
89
+ BLANK_CONDITION = 'BLANK_CONDITION',
90
+ }
91
+
92
+ export interface QueryBuilderFilterConditionDragSource {
93
+ node: QueryBuilderFilterTreeNodeData;
94
+ }
95
+
96
+ export type QueryBuilderFilterDropTarget =
97
+ | QueryBuilderExplorerTreeDragSource
98
+ | QueryBuilderFilterConditionDragSource;
99
+ export type QueryBuilderFilterConditionRearrangeDropTarget =
100
+ QueryBuilderFilterConditionDragSource;
101
+
102
+ export class FilterConditionState {
103
+ filterState: QueryBuilderFilterState;
104
+ propertyExpressionState: QueryBuilderPropertyExpressionState;
105
+ operator!: QueryBuilderFilterOperator;
106
+ value?: ValueSpecification | undefined;
107
+ existsLambdaParamNames: string[] = [];
108
+
109
+ constructor(
110
+ filterState: QueryBuilderFilterState,
111
+ propertyExpression: AbstractPropertyExpression,
112
+ ) {
113
+ makeAutoObservable(this, {
114
+ filterState: false,
115
+ operators: computed,
116
+ changeProperty: action,
117
+ changeOperator: action,
118
+ setOperator: action,
119
+ setValue: action,
120
+ addExistsLambdaParamNames: action,
121
+ });
122
+
123
+ this.filterState = filterState;
124
+ this.propertyExpressionState = new QueryBuilderPropertyExpressionState(
125
+ filterState.queryBuilderState,
126
+ propertyExpression,
127
+ );
128
+
129
+ // operator
130
+ assertTrue(
131
+ this.operators.length !== 0,
132
+ `Can't find an operator for property '${this.propertyExpressionState.path}': no operators registered`,
133
+ );
134
+ this.operator = this.operators[0] as QueryBuilderFilterOperator;
135
+ this.setValue(this.operator.getDefaultFilterConditionValue(this));
136
+ }
137
+
138
+ get operators(): QueryBuilderFilterOperator[] {
139
+ return this.filterState.operators.filter((op) =>
140
+ op.isCompatibleWithFilterConditionProperty(this),
141
+ );
142
+ }
143
+
144
+ changeProperty(propertyExpression: AbstractPropertyExpression): void {
145
+ try {
146
+ // first, check if the new property is supported
147
+ new FilterConditionState(this.filterState, propertyExpression);
148
+ } catch (error) {
149
+ assertErrorThrown(error);
150
+ this.filterState.queryBuilderState.applicationStore.notifyError(error);
151
+ return;
152
+ }
153
+
154
+ // observe the property expression
155
+ observe_ValueSpecification(
156
+ propertyExpression,
157
+ this.filterState.queryBuilderState.observableContext,
158
+ );
159
+
160
+ this.propertyExpressionState = new QueryBuilderPropertyExpressionState(
161
+ this.filterState.queryBuilderState,
162
+ propertyExpression,
163
+ );
164
+
165
+ const newCompatibleOperators = this.operators;
166
+ assertTrue(
167
+ newCompatibleOperators.length !== 0,
168
+ `Can't find an operator for property '${this.propertyExpressionState.path}': no operators registered`,
169
+ );
170
+ if (!newCompatibleOperators.includes(this.operator)) {
171
+ this.changeOperator(
172
+ newCompatibleOperators[0] as QueryBuilderFilterOperator,
173
+ );
174
+ } else if (!this.operator.isCompatibleWithFilterConditionValue(this)) {
175
+ this.setValue(this.operator.getDefaultFilterConditionValue(this));
176
+ }
177
+ }
178
+
179
+ changeOperator(val: QueryBuilderFilterOperator): void {
180
+ this.setOperator(val);
181
+ if (!this.operator.isCompatibleWithFilterConditionValue(this)) {
182
+ this.setValue(this.operator.getDefaultFilterConditionValue(this));
183
+ }
184
+ }
185
+
186
+ setOperator(val: QueryBuilderFilterOperator): void {
187
+ this.operator = val;
188
+ }
189
+
190
+ setValue(val: ValueSpecification | undefined): void {
191
+ this.value = val
192
+ ? observe_ValueSpecification(
193
+ val,
194
+ this.filterState.queryBuilderState.observableContext,
195
+ )
196
+ : undefined;
197
+ }
198
+
199
+ addExistsLambdaParamNames(val: string): void {
200
+ this.existsLambdaParamNames.push(val);
201
+ }
202
+ }
203
+
204
+ export abstract class QueryBuilderFilterTreeNodeData implements TreeNodeData {
205
+ readonly id = uuid();
206
+ readonly label = '';
207
+ // NOTE: we don't use the `isSelected` attribute is not used since we keep track of it from the tree data level
208
+ isOpen?: boolean | undefined;
209
+ parentId?: string | undefined;
210
+
211
+ constructor(parentId: string | undefined) {
212
+ this.parentId = parentId;
213
+
214
+ makeObservable(this, {
215
+ isOpen: observable,
216
+ parentId: observable,
217
+ setIsOpen: action,
218
+ setParentId: action,
219
+ });
220
+ }
221
+
222
+ abstract get dragLayerLabel(): string;
223
+ setIsOpen(val: boolean): void {
224
+ this.isOpen = val;
225
+ }
226
+ setParentId(val: string | undefined): void {
227
+ this.parentId = val;
228
+ }
229
+ }
230
+
231
+ export class QueryBuilderFilterTreeGroupNodeData extends QueryBuilderFilterTreeNodeData {
232
+ groupOperation: QUERY_BUILDER_GROUP_OPERATION;
233
+ childrenIds: string[] = [];
234
+
235
+ constructor(
236
+ parentId: string | undefined,
237
+ groupOperation: QUERY_BUILDER_GROUP_OPERATION,
238
+ ) {
239
+ super(parentId);
240
+
241
+ makeObservable(this, {
242
+ groupOperation: observable,
243
+ childrenIds: observable,
244
+ setGroupOperation: action,
245
+ addChildNode: action,
246
+ removeChildNode: action,
247
+ dragLayerLabel: computed,
248
+ });
249
+
250
+ this.groupOperation = groupOperation;
251
+ this.isOpen = true;
252
+ }
253
+
254
+ get dragLayerLabel(): string {
255
+ return `${this.groupOperation.toUpperCase()} group`;
256
+ }
257
+
258
+ setGroupOperation(val: QUERY_BUILDER_GROUP_OPERATION): void {
259
+ this.groupOperation = val;
260
+ }
261
+ addChildNode(node: QueryBuilderFilterTreeNodeData): void {
262
+ addUniqueEntry(this.childrenIds, node.id);
263
+ node.setParentId(this.id);
264
+ }
265
+ removeChildNode(node: QueryBuilderFilterTreeNodeData): void {
266
+ deleteEntry(this.childrenIds, node.id);
267
+ node.setParentId(undefined);
268
+ }
269
+ addChildNodeAt(node: QueryBuilderFilterTreeNodeData, idx: number): void {
270
+ if (!this.childrenIds.find((childId) => childId === node.id)) {
271
+ idx = Math.max(0, Math.min(idx, this.childrenIds.length - 1));
272
+ this.childrenIds.splice(idx, 0, node.id);
273
+ node.setParentId(this.id);
274
+ }
275
+ }
276
+ }
277
+
278
+ export class QueryBuilderFilterTreeConditionNodeData extends QueryBuilderFilterTreeNodeData {
279
+ condition: FilterConditionState;
280
+
281
+ constructor(parentId: string | undefined, condition: FilterConditionState) {
282
+ super(parentId);
283
+
284
+ makeObservable(this, {
285
+ condition: observable,
286
+ dragLayerLabel: computed,
287
+ });
288
+
289
+ this.condition = condition;
290
+ }
291
+
292
+ get dragLayerLabel(): string {
293
+ return this.condition.propertyExpressionState.title;
294
+ }
295
+ }
296
+
297
+ export class QueryBuilderFilterTreeBlankConditionNodeData extends QueryBuilderFilterTreeNodeData {
298
+ constructor(parentId: string | undefined) {
299
+ super(parentId);
300
+
301
+ makeObservable(this, {
302
+ dragLayerLabel: computed,
303
+ });
304
+ }
305
+
306
+ get dragLayerLabel(): string {
307
+ return '<blank>';
308
+ }
309
+ }
310
+
311
+ const buildFilterConditionExpression = (
312
+ filterState: QueryBuilderFilterState,
313
+ node: QueryBuilderFilterTreeNodeData,
314
+ ): ValueSpecification | undefined => {
315
+ if (node instanceof QueryBuilderFilterTreeConditionNodeData) {
316
+ return node.condition.operator.buildFilterConditionExpression(
317
+ node.condition,
318
+ );
319
+ } else if (node instanceof QueryBuilderFilterTreeGroupNodeData) {
320
+ const multiplicityOne =
321
+ filterState.queryBuilderState.graphManagerState.graph.getTypicalMultiplicity(
322
+ TYPICAL_MULTIPLICITY_TYPE.ONE,
323
+ );
324
+ const func = new SimpleFunctionExpression(
325
+ extractElementNameFromPath(fromGroupOperation(node.groupOperation)),
326
+ multiplicityOne,
327
+ );
328
+ const clauses = node.childrenIds
329
+ .map((e) => filterState.nodes.get(e))
330
+ .filter(isNonNullable)
331
+ .map((e) => buildFilterConditionExpression(filterState, e))
332
+ .filter(isNonNullable);
333
+ /**
334
+ * NOTE: Due to a limitation (or perhaps design decision) in the engine, group operations
335
+ * like and/or do not take more than 2 parameters, as such, if we have more than 2, we need
336
+ * to create a chain of this operation to accomondate.
337
+ *
338
+ * This means that in the read direction, we might need to flatten the chains down to group with
339
+ * multiple clauses. This means user's intended grouping will not be kept.
340
+ */
341
+ if (clauses.length > 2) {
342
+ const firstClause = clauses[0] as ValueSpecification;
343
+ let currentClause: ValueSpecification = clauses[
344
+ clauses.length - 1
345
+ ] as ValueSpecification;
346
+ for (let i = clauses.length - 2; i > 0; --i) {
347
+ const clause1 = clauses[i] as ValueSpecification;
348
+ const clause2 = currentClause;
349
+ const groupClause = new SimpleFunctionExpression(
350
+ extractElementNameFromPath(fromGroupOperation(node.groupOperation)),
351
+ multiplicityOne,
352
+ );
353
+ groupClause.parametersValues = [clause1, clause2];
354
+ currentClause = groupClause;
355
+ }
356
+ func.parametersValues = [firstClause, currentClause];
357
+ } else {
358
+ func.parametersValues = clauses;
359
+ }
360
+ return func.parametersValues.length ? func : undefined;
361
+ }
362
+ return undefined;
363
+ };
364
+
365
+ export const buildFilterExpression = (
366
+ filterState: QueryBuilderFilterState,
367
+ getAllFunc: SimpleFunctionExpression,
368
+ ): SimpleFunctionExpression | undefined => {
369
+ const filterConditionExpressions = filterState.rootIds
370
+ .map((e) => guaranteeNonNullable(filterState.nodes.get(e)))
371
+ .map((e) => buildFilterConditionExpression(filterState, e))
372
+ .filter(isNonNullable);
373
+
374
+ if (!filterConditionExpressions.length) {
375
+ return undefined;
376
+ }
377
+ const multiplicityOne =
378
+ filterState.queryBuilderState.graphManagerState.graph.getTypicalMultiplicity(
379
+ TYPICAL_MULTIPLICITY_TYPE.ONE,
380
+ );
381
+ // main filter expression
382
+ const filterExpression = new SimpleFunctionExpression(
383
+ extractElementNameFromPath(QUERY_BUILDER_SUPPORTED_FUNCTIONS.FILTER),
384
+ multiplicityOne,
385
+ );
386
+ // param [0]
387
+ filterExpression.parametersValues.push(getAllFunc);
388
+ // param [1]
389
+ filterExpression.parametersValues.push(
390
+ buildGenericLambdaFunctionInstanceValue(
391
+ filterState.lambdaParameterName,
392
+ filterConditionExpressions,
393
+ filterState.queryBuilderState.graphManagerState.graph,
394
+ ),
395
+ );
396
+ return filterExpression;
397
+ };
398
+
399
+ export class QueryBuilderFilterState
400
+ implements TreeData<QueryBuilderFilterTreeNodeData>
401
+ {
402
+ queryBuilderState: QueryBuilderState;
403
+ lambdaParameterName = DEFAULT_LAMBDA_VARIABLE_NAME;
404
+ rootIds: string[] = [];
405
+ nodes = new Map<string, QueryBuilderFilterTreeNodeData>();
406
+ selectedNode?: QueryBuilderFilterTreeNodeData | undefined;
407
+ isRearrangingConditions = false;
408
+ operators: QueryBuilderFilterOperator[] = [];
409
+ private _suppressClickawayEventListener = false;
410
+
411
+ constructor(
412
+ queryBuilderState: QueryBuilderState,
413
+ operators: QueryBuilderFilterOperator[],
414
+ ) {
415
+ makeAutoObservable(this, {
416
+ queryBuilderState: false,
417
+ isValidMove: false,
418
+ setLambdaParameterName: action,
419
+ setRearrangingConditions: action,
420
+ suppressClickawayEventListener: action,
421
+ handleClickaway: action,
422
+ setSelectedNode: action,
423
+ addNodeFromNode: action,
424
+ replaceBlankNodeWithNode: action,
425
+ addGroupConditionNodeFromNode: action,
426
+ newGroupWithConditionFromNode: action,
427
+ removeNodeAndPruneBranch: action,
428
+ pruneTree: action,
429
+ simplifyTree: action,
430
+ collapseTree: action,
431
+ expandTree: action,
432
+ });
433
+
434
+ this.queryBuilderState = queryBuilderState;
435
+ this.operators = operators;
436
+ }
437
+
438
+ get isEmpty(): boolean {
439
+ return !this.nodes.size && !this.rootIds.length;
440
+ }
441
+
442
+ setLambdaParameterName(val: string): void {
443
+ this.lambdaParameterName = val;
444
+ }
445
+
446
+ setRearrangingConditions(val: boolean): void {
447
+ this.isRearrangingConditions = val;
448
+ }
449
+ suppressClickawayEventListener(): void {
450
+ this._suppressClickawayEventListener = true;
451
+ }
452
+ handleClickaway(): void {
453
+ if (this._suppressClickawayEventListener) {
454
+ this._suppressClickawayEventListener = false;
455
+ return;
456
+ }
457
+ this.setSelectedNode(undefined);
458
+ }
459
+ setSelectedNode(val: QueryBuilderFilterTreeNodeData | undefined): void {
460
+ this.selectedNode = val;
461
+ }
462
+
463
+ getNode(id: string): QueryBuilderFilterTreeNodeData {
464
+ return guaranteeNonNullable(
465
+ this.nodes.get(id),
466
+ `Can't find query builder filter tree node with ID '${id}'`,
467
+ );
468
+ }
469
+ getRootNode(): QueryBuilderFilterTreeNodeData | undefined {
470
+ assertTrue(
471
+ this.rootIds.length < 2,
472
+ 'Query builder filter tree cannot have more than 1 root',
473
+ );
474
+ const rootId = getNullableFirstElement(this.rootIds);
475
+ return rootId ? this.getNode(rootId) : undefined;
476
+ }
477
+
478
+ private getParentNode(
479
+ node: QueryBuilderFilterTreeNodeData,
480
+ ): QueryBuilderFilterTreeGroupNodeData | undefined {
481
+ return node.parentId
482
+ ? guaranteeType(
483
+ this.nodes.get(node.parentId),
484
+ QueryBuilderFilterTreeGroupNodeData,
485
+ )
486
+ : undefined;
487
+ }
488
+
489
+ private addRootNode(node: QueryBuilderFilterTreeNodeData): void {
490
+ const rootNode = this.getRootNode();
491
+ this.nodes.set(node.id, node);
492
+ if (rootNode instanceof QueryBuilderFilterTreeGroupNodeData) {
493
+ rootNode.addChildNode(node);
494
+ } else if (
495
+ rootNode instanceof QueryBuilderFilterTreeConditionNodeData ||
496
+ rootNode instanceof QueryBuilderFilterTreeBlankConditionNodeData
497
+ ) {
498
+ // if the root node is condition node, form a group between the root node and the new node and nominate the group node as the new root
499
+ const groupNode = new QueryBuilderFilterTreeGroupNodeData(
500
+ undefined,
501
+ QUERY_BUILDER_GROUP_OPERATION.AND,
502
+ );
503
+ groupNode.addChildNode(rootNode);
504
+ groupNode.addChildNode(node);
505
+ this.rootIds = [groupNode.id];
506
+ this.nodes.set(groupNode.id, groupNode);
507
+ } else if (!rootNode) {
508
+ // if there is no root node, set this node as the root
509
+ this.rootIds = [node.id];
510
+ }
511
+ }
512
+
513
+ addNodeFromNode(
514
+ node: QueryBuilderFilterTreeNodeData,
515
+ fromNode: QueryBuilderFilterTreeNodeData | undefined,
516
+ ): void {
517
+ if (fromNode instanceof QueryBuilderFilterTreeGroupNodeData) {
518
+ this.nodes.set(node.id, node);
519
+ fromNode.addChildNode(node);
520
+ } else if (
521
+ fromNode instanceof QueryBuilderFilterTreeConditionNodeData ||
522
+ fromNode instanceof QueryBuilderFilterTreeBlankConditionNodeData
523
+ ) {
524
+ this.nodes.set(node.id, node);
525
+ const fromNodeParent = this.getParentNode(fromNode);
526
+ if (fromNodeParent) {
527
+ fromNodeParent.addChildNode(node);
528
+ } else {
529
+ this.addRootNode(node);
530
+ }
531
+ } else if (!this.selectedNode) {
532
+ // if no current node is selected, the node will be added to root
533
+ this.addRootNode(node);
534
+ }
535
+ }
536
+
537
+ replaceBlankNodeWithNode(
538
+ node: QueryBuilderFilterTreeNodeData,
539
+ blankNode: QueryBuilderFilterTreeBlankConditionNodeData,
540
+ ): void {
541
+ this.nodes.set(node.id, node);
542
+ const blankNodeParent = this.getParentNode(blankNode);
543
+ if (blankNodeParent) {
544
+ const blankNodeIdx = blankNodeParent.childrenIds.findIndex(
545
+ (childId) => childId === blankNode.id,
546
+ );
547
+ blankNodeParent.addChildNodeAt(node, blankNodeIdx);
548
+ blankNodeParent.removeChildNode(blankNode);
549
+ } else {
550
+ this.addRootNode(node);
551
+ }
552
+ this.removeNode(blankNode);
553
+ }
554
+
555
+ addGroupConditionNodeFromNode(
556
+ fromNode: QueryBuilderFilterTreeNodeData | undefined,
557
+ ): void {
558
+ const newGroupNode = new QueryBuilderFilterTreeGroupNodeData(
559
+ undefined,
560
+ QUERY_BUILDER_GROUP_OPERATION.AND,
561
+ );
562
+ const newBlankConditionNode1 =
563
+ new QueryBuilderFilterTreeBlankConditionNodeData(undefined);
564
+ const newBlankConditionNode2 =
565
+ new QueryBuilderFilterTreeBlankConditionNodeData(undefined);
566
+ this.nodes.set(newBlankConditionNode1.id, newBlankConditionNode1);
567
+ this.nodes.set(newBlankConditionNode2.id, newBlankConditionNode2);
568
+ newGroupNode.addChildNode(newBlankConditionNode1);
569
+ newGroupNode.addChildNode(newBlankConditionNode2);
570
+ this.addNodeFromNode(newGroupNode, fromNode);
571
+ }
572
+
573
+ newGroupWithConditionFromNode(
574
+ node: QueryBuilderFilterTreeNodeData | undefined,
575
+ fromNode: QueryBuilderFilterTreeNodeData | undefined,
576
+ ): void {
577
+ const newNode =
578
+ node ?? new QueryBuilderFilterTreeBlankConditionNodeData(undefined);
579
+ if (fromNode instanceof QueryBuilderFilterTreeConditionNodeData) {
580
+ const fromNodeParent = this.getParentNode(fromNode);
581
+ if (fromNodeParent) {
582
+ const fromNodeIdx = fromNodeParent.childrenIds.findIndex(
583
+ (childId) => childId === fromNode.id,
584
+ );
585
+ fromNodeParent.removeChildNode(fromNode);
586
+ const newGroupNode = new QueryBuilderFilterTreeGroupNodeData(
587
+ undefined,
588
+ QUERY_BUILDER_GROUP_OPERATION.AND,
589
+ );
590
+ this.nodes.set(newNode.id, newNode);
591
+ this.nodes.set(newGroupNode.id, newGroupNode);
592
+ newGroupNode.addChildNode(fromNode);
593
+ newGroupNode.addChildNode(newNode);
594
+ fromNodeParent.addChildNodeAt(newGroupNode, fromNodeIdx);
595
+ } else {
596
+ this.addRootNode(newNode);
597
+ }
598
+ }
599
+ }
600
+
601
+ private removeNode(node: QueryBuilderFilterTreeNodeData): void {
602
+ this.nodes.delete(node.id);
603
+ // remove relationship with children nodes
604
+ if (node instanceof QueryBuilderFilterTreeGroupNodeData) {
605
+ // NOTE: we are deleting child node, i.e. modifying `childrenIds` as we iterate
606
+ [...node.childrenIds].forEach((childId) =>
607
+ node.removeChildNode(this.getNode(childId)),
608
+ );
609
+ }
610
+ // remove relationship with parent node
611
+ const parentNode = this.getParentNode(node);
612
+ if (parentNode) {
613
+ parentNode.removeChildNode(node);
614
+ } else {
615
+ deleteEntry(this.rootIds, node.id);
616
+ }
617
+ }
618
+
619
+ private pruneChildlessGroupNodes(): void {
620
+ const getChildlessGroupNodes = (): QueryBuilderFilterTreeGroupNodeData[] =>
621
+ Array.from(this.nodes.values())
622
+ .filter(filterByType(QueryBuilderFilterTreeGroupNodeData))
623
+ .filter((node) => !node.childrenIds.length);
624
+ let nodesToProcess = getChildlessGroupNodes();
625
+ while (nodesToProcess.length) {
626
+ nodesToProcess.forEach((node) => this.removeNode(node));
627
+ nodesToProcess = getChildlessGroupNodes();
628
+ }
629
+ }
630
+
631
+ private pruneOrphanNodes(): void {
632
+ const getOrphanNodes = (): QueryBuilderFilterTreeNodeData[] =>
633
+ Array.from(this.nodes.values()).filter(
634
+ (node) => !node.parentId && !this.rootIds.includes(node.id),
635
+ ); // nodes without parent, except for root nodes
636
+ let nodesToProcess = getOrphanNodes();
637
+ while (nodesToProcess.length) {
638
+ nodesToProcess.forEach((node) => this.removeNode(node));
639
+ nodesToProcess = getOrphanNodes();
640
+ }
641
+ }
642
+
643
+ /**
644
+ * If group node has fewer than 2 children, flatten it
645
+ */
646
+ private squashGroupNode(node: QueryBuilderFilterTreeGroupNodeData): void {
647
+ if (node.childrenIds.length < 2) {
648
+ const parentNode = this.getParentNode(node);
649
+ // NOTE: we are deleting child node, i.e. modifying `childrenIds` as we iterate
650
+ [...node.childrenIds].forEach((childId) => {
651
+ const childNode = this.getNode(childId);
652
+ node.removeChildNode(childNode);
653
+ if (parentNode) {
654
+ parentNode.addChildNode(childNode);
655
+ } else {
656
+ addUniqueEntry(this.rootIds, childId);
657
+ }
658
+ });
659
+ // remove the group node
660
+ this.nodes.delete(node.id);
661
+ if (parentNode) {
662
+ parentNode.removeChildNode(node);
663
+ } else {
664
+ deleteEntry(this.rootIds, node.id);
665
+ }
666
+ }
667
+ }
668
+
669
+ removeNodeAndPruneBranch(node: QueryBuilderFilterTreeNodeData): void {
670
+ const parentNode = this.getParentNode(node);
671
+ this.removeNode(node);
672
+ // squash parent node after the current node is deleted
673
+ if (parentNode) {
674
+ parentNode.removeChildNode(node);
675
+ let currentParentNode: QueryBuilderFilterTreeGroupNodeData | undefined =
676
+ parentNode;
677
+ while (currentParentNode) {
678
+ if (currentParentNode.childrenIds.length >= 2) {
679
+ break;
680
+ }
681
+ this.squashGroupNode(currentParentNode);
682
+ currentParentNode = this.getParentNode(currentParentNode);
683
+ }
684
+ } else {
685
+ deleteEntry(this.rootIds, node.id);
686
+ }
687
+ this.pruneOrphanNodes();
688
+ // check if selected node is still around, if not, unset the selected node
689
+ if (this.selectedNode && !this.nodes.get(this.selectedNode.id)) {
690
+ this.setSelectedNode(undefined);
691
+ }
692
+ }
693
+
694
+ pruneTree(): void {
695
+ this.setSelectedNode(undefined);
696
+ // remove all blank nodes
697
+ Array.from(this.nodes.values())
698
+ .filter(
699
+ (node) => node instanceof QueryBuilderFilterTreeBlankConditionNodeData,
700
+ )
701
+ .forEach((node) => this.removeNode(node));
702
+ // prune
703
+ this.pruneOrphanNodes();
704
+ this.pruneChildlessGroupNodes();
705
+ // squash group nodes
706
+ // NOTE: since we have pruned all blank nodes and childless group nodes, at this point, if there are group nodes to be squashed
707
+ // it will be group node with exactly 1 non-blank condition
708
+ const getSquashableGroupNodes = (): QueryBuilderFilterTreeGroupNodeData[] =>
709
+ Array.from(this.nodes.values())
710
+ .filter(filterByType(QueryBuilderFilterTreeGroupNodeData))
711
+ .filter((node) => node.childrenIds.length < 2)
712
+ .filter((node) => {
713
+ if (!node.childrenIds.length) {
714
+ throw new IllegalStateError(
715
+ 'Query builder filter tree found unexpected childless group nodes',
716
+ );
717
+ }
718
+ const firstChildNodeId = node.childrenIds[0] as string;
719
+ const childNode = this.getNode(firstChildNodeId);
720
+ if (
721
+ childNode instanceof QueryBuilderFilterTreeBlankConditionNodeData
722
+ ) {
723
+ throw new IllegalStateError(
724
+ 'Query builder filter tree found unexpected blank nodes',
725
+ );
726
+ }
727
+ return (
728
+ this.getNode(firstChildNodeId) instanceof
729
+ QueryBuilderFilterTreeConditionNodeData
730
+ );
731
+ });
732
+ let nodesToProcess = getSquashableGroupNodes();
733
+ while (nodesToProcess.length) {
734
+ nodesToProcess.forEach((node) => this.squashGroupNode(node));
735
+ nodesToProcess = getSquashableGroupNodes();
736
+ }
737
+ // check if selected node is still around, if not, unset the selected node
738
+ if (this.selectedNode && !this.nodes.get(this.selectedNode.id)) {
739
+ this.setSelectedNode(undefined);
740
+ }
741
+ }
742
+
743
+ /**
744
+ * Cleanup unecessary group nodes (i.e. group node whose group operation is the same as its parent's)
745
+ */
746
+ simplifyTree(): void {
747
+ this.setSelectedNode(undefined);
748
+ const getUnnecessaryNodes = (): QueryBuilderFilterTreeGroupNodeData[] =>
749
+ Array.from(this.nodes.values())
750
+ .filter(filterByType(QueryBuilderFilterTreeGroupNodeData))
751
+ .filter((node) => {
752
+ if (!node.parentId || !this.nodes.has(node.parentId)) {
753
+ return false;
754
+ }
755
+ const parentGroupNode = guaranteeType(
756
+ this.nodes.get(node.parentId),
757
+ QueryBuilderFilterTreeGroupNodeData,
758
+ );
759
+ return parentGroupNode.groupOperation === node.groupOperation;
760
+ });
761
+ // Squash these unnecessary group nodes
762
+ let nodesToProcess = getUnnecessaryNodes();
763
+ while (nodesToProcess.length) {
764
+ nodesToProcess.forEach((node) => {
765
+ const parentNode = guaranteeType(
766
+ this.nodes.get(guaranteeNonNullable(node.parentId)),
767
+ QueryBuilderFilterTreeGroupNodeData,
768
+ );
769
+ // send all children of the current group node to their grandparent node
770
+ [...node.childrenIds].forEach((childId) => {
771
+ const childNode = this.getNode(childId);
772
+ parentNode.addChildNode(childNode);
773
+ });
774
+ // remove the current group node
775
+ parentNode.removeChildNode(node);
776
+ // remove the node
777
+ this.nodes.delete(node.id);
778
+ });
779
+ nodesToProcess = getUnnecessaryNodes();
780
+ }
781
+ }
782
+
783
+ isValidMove(
784
+ node: QueryBuilderFilterTreeNodeData,
785
+ toNode: QueryBuilderFilterTreeNodeData,
786
+ ): boolean {
787
+ const isMovingToItself = node === toNode;
788
+ // disallow moving a node to its descendants
789
+ let isMovingToChildNode = false;
790
+ let currentParentNode = this.getParentNode(toNode);
791
+ while (currentParentNode) {
792
+ if (currentParentNode === node) {
793
+ isMovingToChildNode = true;
794
+ break;
795
+ }
796
+ currentParentNode = this.getParentNode(currentParentNode);
797
+ }
798
+ return !isMovingToItself && !isMovingToChildNode;
799
+ }
800
+
801
+ moveNode(
802
+ node: QueryBuilderFilterTreeNodeData,
803
+ toNode: QueryBuilderFilterTreeNodeData,
804
+ ): void {
805
+ // do something;
806
+ }
807
+
808
+ collapseTree(): void {
809
+ Array.from(this.nodes.values()).forEach((node) => node.setIsOpen(false));
810
+ }
811
+
812
+ expandTree(): void {
813
+ Array.from(this.nodes.values()).forEach((node) => node.setIsOpen(true));
814
+ }
815
+ }