Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(query-builder): support for nested queries and other improvements #14647

Open
wants to merge 216 commits into
base: master
Choose a base branch
from

Conversation

igdmdimitrov
Copy link
Contributor

@igdmdimitrov igdmdimitrov commented Aug 19, 2024

Closes #14642
Closes #14979

Additional information (check all that apply):

  • Bug fix
  • New functionality
  • Documentation
  • Demos
  • CI/CD

Checklist:

  • All relevant tags have been applied to this PR
  • This PR includes unit tests covering all the new code (test guidelines)
  • This PR includes API docs for newly added methods/properties (api docs guidelines)
  • This PR includes feature/README.MD updates for the feature docs
  • This PR includes general feature table updates in the root README.MD
  • This PR includes CHANGELOG.MD updates for newly added functionality
  • This PR contains breaking changes
  • This PR includes ng update migrations for the breaking changes (migrations guidelines)
  • This PR includes behavioral changes and the feature specification has been updated with them

igdmdimitrov and others added 19 commits July 24, 2024 19:44
@igdmdimitrov igdmdimitrov added the 🛠️ status: in-development Issues and PRs with active development on them label Aug 19, 2024
@gedinakova
Copy link
Contributor

1. Run QB dev demo
2. Click on the group line in the inner query

Result: The dialog to change the group operator is not shown. Only the group line style changes to selected.
Note: The dialog is shown when the query is in edit mode.

This may be by design but I still think we should probably discuss this UX.

@gedinakova
Copy link
Contributor

    1. Run QB Dev Demo
2. Hover over the first condition of the inner query
3. Click the "+" button to add a new condition
4. Click the "+condition", "and group" or "or group" button 

The row to add a condition is shown but the following error is logged in the console (3 times):
TypeError: Cannot read properties of null (reading 'name')
at IgxQueryBuilderTreeComponent2_ng_template_9_div_0_Template (template.html:99:21)
at executeTemplate (core.mjs:11621:9)
at refreshView (core.mjs:13239:13)
at detectChangesInView (core.mjs:13455:9)
at detectChangesInViewIfAttached (core.mjs:13415:5)
at detectChangesInEmbeddedViews (core.mjs:13374:13)
at refreshView (core.mjs:13267:9)
at detectChangesInView (core.mjs:13455:9)
at detectChangesInViewIfAttached (core.mjs:13415:5)
at detectChangesInEmbeddedViews (core.mjs:13374:13)

@gedinakova
Copy link
Contributor

    1. Run the dev demo
2. Reset all filters & start a new group
3. Select entity & add the first condition
4. The add a new group, e.g an and group
5. Add the first condition to it (note how all the buttons to add new filters are inside the group)
6. Submit the condition - only the condition remains in the group, the buttons seem to be shifted to the outer group
7. Attempt to add another group

Result: All inputs and buttons in the new group are disabled.
Expected result: The buttons should stay part of the current group and it should be possible to add another condition to it (not having all inputs disabled on step 7)

@gedinakova
Copy link
Contributor

    1. Run the dev demo
2. Click the edit button on the first filter (In)
3. Select the two inner conditions and click the "Create OR group" button in the pop up - the group is created in the UI
4. Click the submit button

Result: All inner conditions disappear from the UI. The tree doesn't seem to change.
The following error is logged in the console:
TypeError: Cannot read properties of undefined (reading 'find')
at IgxQueryBuilderTreeComponent2.createExpressionGroupItem (query-builder-tree.component.ts:1164:47)
at IgxQueryBuilderTreeComponent2.createExpressionGroupItem (query-builder-tree.component.ts:1149:50)
at IgxQueryBuilderTreeComponent2.init (query-builder-tree.component.ts:1369:31)
at set expressionTree (query-builder-tree.component.ts:175:14)
at applyValueToInputField (core.mjs:4045:29)
at writeToDirectiveInput (core.mjs:11443:13)
at setInputsForProperty (core.mjs:12749:9)
at elementPropertyInternal (core.mjs:12050:9)
at ɵɵproperty (core.mjs:22491:9)
at IgxQueryBuilderTreeComponent2_ng_template_9_ng_container_2_Template (template.html:369:17)

@gedinakova
Copy link
Contributor

1. Run the dev demo
2. Click to edit the second condition
3. In the filter dropdown change from "Equals" to "In"
4. Click the commit icon button

The button is not disabled on switching to In/Not In conditions (as the value the input is). The following error is logged in the console on clicking it:
TypeError: Cannot read properties of undefined (reading 'operator')
at IgxQueryBuilderTreeComponent2.commitOperandEdit (query-builder-tree.component.ts:618:123)
at IgxQueryBuilderTreeComponent2_ng_template_9_div_1_Template_button_click_18_listener (template.html:351:21)
at executeListenerWithErrorHandling (core.mjs:26660:16)

@gedinakova
Copy link
Contributor

@igdmdimitrov After deleting all inner conditions and submitting the parent, the two buttons for adding a group remain.

  1. In the dev demo, expand the inner query via "Details" button (without entering edit mode on the parent)
  2. Put the first inner condition in edit mode & discard
  3. Delete all inner conditons
  4. Commit the parent

The buttons stay:
screen-capture (2).webm

@gedinakova
Copy link
Contributor

@igdmdimitrov @ivanvpetrov

  1. In the dev demo, change the entity (do not change the return fields)
  2. Click one of the add group buttons
  3. Discard the empty condition

Result: In addition to removing the empty condition, the return fields are also cleared.

Expected result: Return fields not to be changed.

igdmdimitrov and others added 17 commits November 1, 2024 17:56
)

* feat(query-builder): select only one return field in inner query
* chore(query-builder): update resource string translations
* chore(*): replace *ngIf with @if/@else

---------

Co-authored-by: INFRAGISTICS\IPetrov <[email protected]>
Co-authored-by: teodosiah <[email protected]>
@teodosiah
Copy link
Contributor

  1. start editing an expression
  2. click the edit icon of another expression

Result:

  • if the edited expression is valid i.e. can be committed, it exits edit mode properly, but the next expression does not enter edit mode
  • if the edited expression is not valid, it exits edit mode and discards the invalid changes, and the next one enters edit mode as expected
    QB-edit-issue

Expected:
To exit edit mode, apply or discard the changes based on the validity of the expression and the next expression should enter edit mode properly

* feat(query-builder): Added rehydration for filtering expressions and trees
* feat(query-builder): Added tests for sub-tree rehydration
* chore(*): Improved rehydration checks for grids

---------
Co-authored-by: Galina Edinakova <[email protected]>
Co-authored-by: igdmdimitrov <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Query Builder: Update theme to match latest design Query Builder component update