@smartbit4all/ng-client 4.1.40 → 4.2.1

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 (29) hide show
  1. package/esm2022/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.mjs +3 -3
  2. package/esm2022/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.mjs +3 -3
  3. package/esm2022/lib/smart-form/services/smartform.service.mjs +11 -6
  4. package/esm2022/lib/smart-form/smartform.form-model.mjs +1 -1
  5. package/esm2022/lib/smart-form/smartform.model.mjs +1 -1
  6. package/esm2022/lib/smart-validation/named-validator.service.mjs +115 -0
  7. package/esm2022/lib/smart-validation/projects.mjs +4 -0
  8. package/esm2022/lib/smart-validation/smart-validation.module.mjs +24 -0
  9. package/esm2022/lib/smart-validation/smart-validation.types.mjs +4 -0
  10. package/esm2022/lib/view-context/api/model/componentConstraint.mjs +1 -1
  11. package/esm2022/lib/view-context/api/model/models.mjs +2 -1
  12. package/esm2022/lib/view-context/api/model/namedValidator.mjs +19 -0
  13. package/esm2022/projects.mjs +2 -1
  14. package/fesm2022/smartbit4all-ng-client.mjs +167 -10
  15. package/fesm2022/smartbit4all-ng-client.mjs.map +1 -1
  16. package/lib/smart-form/services/smartform.service.d.ts +4 -1
  17. package/lib/smart-form/smartform.form-model.d.ts +2 -2
  18. package/lib/smart-form/smartform.model.d.ts +11 -5
  19. package/lib/smart-validation/named-validator.service.d.ts +17 -0
  20. package/lib/smart-validation/projects.d.ts +3 -0
  21. package/lib/smart-validation/smart-validation.module.d.ts +8 -0
  22. package/lib/smart-validation/smart-validation.types.d.ts +12 -0
  23. package/lib/view-context/api/model/componentConstraint.d.ts +6 -0
  24. package/lib/view-context/api/model/models.d.ts +1 -0
  25. package/lib/view-context/api/model/namedValidator.d.ts +26 -0
  26. package/package.json +1 -1
  27. package/projects.d.ts +1 -0
  28. package/smartbit4all-ng-client-4.2.1.tgz +0 -0
  29. package/smartbit4all-ng-client-4.1.40.tgz +0 -0
@@ -58,11 +58,11 @@ export class SmartFilterExpressionItemComponent {
58
58
  }
59
59
  }
60
60
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFilterExpressionItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
61
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartFilterExpressionItemComponent, selector: "app-expression-item", inputs: { item: "item", hasNext: "hasNext", service: "service" }, ngImport: i0, template: "<div class=\"expressionItemContainer\">\r\n <div\r\n class=\"expressionItemInnerContainer\"\r\n [ngClass]=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION'\r\n ? isSelected\r\n ? 'selectedExpressionContainer'\r\n : 'expressionContainer'\r\n : ''\r\n \"\r\n >\r\n <div\r\n *ngIf=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION';\r\n then expression;\r\n else simpleItem\r\n \"\r\n ></div>\r\n <ng-template #expression>\r\n <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n <app-expression-item\r\n [item]=\"subItem\"\r\n [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n ></app-expression-item>\r\n <div class=\"expressionItemBubble expression\">]</div>\r\n </ng-template>\r\n <ng-template #simpleItem>\r\n <div\r\n (click)=\"select($event, item)\"\r\n class=\"expressionItemBubble simpleItem\"\r\n [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n >\r\n {{ item.label }}:\r\n <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n </b>\r\n </div>\r\n <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n </div>\r\n <b>-</b>\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.AND\r\n ? 'mat-raised-button and-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n \u00C9S\r\n </button>\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.OR\r\n ? 'mat-raised-button or-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n VAGY\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".expressionItemContainer{display:flex;flex-direction:row;gap:.75rem}.expressionItemInnerContainer{display:flex;flex-direction:row;grid-area:.75rem;padding:.25rem;border-radius:.25rem}.expressionContainer{border:1px dashed var(--primary-lighter-gray-color);cursor:pointer}.selectedExpressionContainer{border:2px dashed var(--primary-darker-color)}.expressionItemBubble,.relationItemBubble{display:flex;flex-direction:row;border-radius:1.5rem}.expressionItemBubble{padding:.75rem}.expression{background-color:var(--inner-container);font-weight:600;margin:auto 0}.simpleItem{background-color:#c6ddff;cursor:pointer}.selectedSimpleItem{border:2px solid var(--primary-color)}.relationItemBubble{border:1px solid #cdcdcd;padding:.25rem}.relationItemBubble .mat-mdc-button{border-radius:1.5rem;height:100%;margin:auto 0}.expressionValues{display:flex;flex-direction:row;gap:.5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: SmartFilterExpressionItemComponent, selector: "app-expression-item", inputs: ["item", "hasNext", "service"] }, { kind: "pipe", type: i3.SmartDateTimePipe, name: "smartDateTime" }, { kind: "pipe", type: i3.SmartDatePipe, name: "smartDate" }] }); }
61
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartFilterExpressionItemComponent, selector: "app-expression-item", inputs: { item: "item", hasNext: "hasNext", service: "service" }, ngImport: i0, template: "<div class=\"expressionItemContainer\">\r\n <div\r\n class=\"expressionItemInnerContainer\"\r\n [ngClass]=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION'\r\n ? isSelected\r\n ? 'selectedExpressionContainer'\r\n : 'expressionContainer'\r\n : ''\r\n \"\r\n >\r\n <div\r\n *ngIf=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION';\r\n then expression;\r\n else simpleItem\r\n \"\r\n ></div>\r\n <ng-template #expression>\r\n <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n <app-expression-item\r\n [item]=\"subItem\"\r\n [service]=\"service\"\r\n [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n ></app-expression-item>\r\n <div class=\"expressionItemBubble expression\">]</div>\r\n </ng-template>\r\n <ng-template #simpleItem>\r\n <div\r\n (click)=\"select($event, item)\"\r\n class=\"expressionItemBubble simpleItem\"\r\n [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n >\r\n {{ item.label }}:\r\n <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n </b>\r\n </div>\r\n <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n </div>\r\n <b>-</b>\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.AND\r\n ? 'mat-raised-button and-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n \u00C9S\r\n </button>\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.OR\r\n ? 'mat-raised-button or-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n VAGY\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".expressionItemContainer{display:flex;flex-direction:row;gap:.75rem}.expressionItemInnerContainer{display:flex;flex-direction:row;grid-area:.75rem;padding:.25rem;border-radius:.25rem}.expressionContainer{border:1px dashed var(--primary-lighter-gray-color);cursor:pointer}.selectedExpressionContainer{border:2px dashed var(--primary-darker-color)}.expressionItemBubble,.relationItemBubble{display:flex;flex-direction:row;border-radius:1.5rem}.expressionItemBubble{padding:.75rem}.expression{background-color:var(--inner-container);font-weight:600;margin:auto 0}.simpleItem{background-color:#c6ddff;cursor:pointer}.selectedSimpleItem{border:2px solid var(--primary-color)}.relationItemBubble{border:1px solid #cdcdcd;padding:.25rem}.relationItemBubble .mat-mdc-button{border-radius:1.5rem;height:100%;margin:auto 0}.expressionValues{display:flex;flex-direction:row;gap:.5rem}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: SmartFilterExpressionItemComponent, selector: "app-expression-item", inputs: ["item", "hasNext", "service"] }, { kind: "pipe", type: i3.SmartDateTimePipe, name: "smartDateTime" }, { kind: "pipe", type: i3.SmartDatePipe, name: "smartDate" }] }); }
62
62
  }
63
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFilterExpressionItemComponent, decorators: [{
64
64
  type: Component,
65
- args: [{ selector: 'app-expression-item', template: "<div class=\"expressionItemContainer\">\r\n <div\r\n class=\"expressionItemInnerContainer\"\r\n [ngClass]=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION'\r\n ? isSelected\r\n ? 'selectedExpressionContainer'\r\n : 'expressionContainer'\r\n : ''\r\n \"\r\n >\r\n <div\r\n *ngIf=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION';\r\n then expression;\r\n else simpleItem\r\n \"\r\n ></div>\r\n <ng-template #expression>\r\n <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n <app-expression-item\r\n [item]=\"subItem\"\r\n [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n ></app-expression-item>\r\n <div class=\"expressionItemBubble expression\">]</div>\r\n </ng-template>\r\n <ng-template #simpleItem>\r\n <div\r\n (click)=\"select($event, item)\"\r\n class=\"expressionItemBubble simpleItem\"\r\n [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n >\r\n {{ item.label }}:\r\n <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n </b>\r\n </div>\r\n <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n </div>\r\n <b>-</b>\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.AND\r\n ? 'mat-raised-button and-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n \u00C9S\r\n </button>\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.OR\r\n ? 'mat-raised-button or-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n VAGY\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".expressionItemContainer{display:flex;flex-direction:row;gap:.75rem}.expressionItemInnerContainer{display:flex;flex-direction:row;grid-area:.75rem;padding:.25rem;border-radius:.25rem}.expressionContainer{border:1px dashed var(--primary-lighter-gray-color);cursor:pointer}.selectedExpressionContainer{border:2px dashed var(--primary-darker-color)}.expressionItemBubble,.relationItemBubble{display:flex;flex-direction:row;border-radius:1.5rem}.expressionItemBubble{padding:.75rem}.expression{background-color:var(--inner-container);font-weight:600;margin:auto 0}.simpleItem{background-color:#c6ddff;cursor:pointer}.selectedSimpleItem{border:2px solid var(--primary-color)}.relationItemBubble{border:1px solid #cdcdcd;padding:.25rem}.relationItemBubble .mat-mdc-button{border-radius:1.5rem;height:100%;margin:auto 0}.expressionValues{display:flex;flex-direction:row;gap:.5rem}\n"] }]
65
+ args: [{ selector: 'app-expression-item', template: "<div class=\"expressionItemContainer\">\r\n <div\r\n class=\"expressionItemInnerContainer\"\r\n [ngClass]=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION'\r\n ? isSelected\r\n ? 'selectedExpressionContainer'\r\n : 'expressionContainer'\r\n : ''\r\n \"\r\n >\r\n <div\r\n *ngIf=\"\r\n item.expressionData?.currentOperation === 'EXPRESSION';\r\n then expression;\r\n else simpleItem\r\n \"\r\n ></div>\r\n <ng-template #expression>\r\n <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n <app-expression-item\r\n [item]=\"subItem\"\r\n [service]=\"service\"\r\n [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n ></app-expression-item>\r\n <div class=\"expressionItemBubble expression\">]</div>\r\n </ng-template>\r\n <ng-template #simpleItem>\r\n <div\r\n (click)=\"select($event, item)\"\r\n class=\"expressionItemBubble simpleItem\"\r\n [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n >\r\n {{ item.label }}:\r\n <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n </b>\r\n </div>\r\n <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n </div>\r\n <b>-</b>\r\n <div *ngIf=\"item.widgetType === 'DATE'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n </div>\r\n <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </div>\r\n <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.AND\r\n ? 'mat-raised-button and-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n \u00C9S\r\n </button>\r\n <button\r\n mat-button\r\n (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n [ngClass]=\"\r\n item.expressionData?.boolOperator === boolOperatorType.OR\r\n ? 'mat-raised-button or-operator'\r\n : ''\r\n \"\r\n color=\"black\"\r\n >\r\n VAGY\r\n </button>\r\n </div>\r\n</div>\r\n", styles: [".expressionItemContainer{display:flex;flex-direction:row;gap:.75rem}.expressionItemInnerContainer{display:flex;flex-direction:row;grid-area:.75rem;padding:.25rem;border-radius:.25rem}.expressionContainer{border:1px dashed var(--primary-lighter-gray-color);cursor:pointer}.selectedExpressionContainer{border:2px dashed var(--primary-darker-color)}.expressionItemBubble,.relationItemBubble{display:flex;flex-direction:row;border-radius:1.5rem}.expressionItemBubble{padding:.75rem}.expression{background-color:var(--inner-container);font-weight:600;margin:auto 0}.simpleItem{background-color:#c6ddff;cursor:pointer}.selectedSimpleItem{border:2px solid var(--primary-color)}.relationItemBubble{border:1px solid #cdcdcd;padding:.25rem}.relationItemBubble .mat-mdc-button{border-radius:1.5rem;height:100%;margin:auto 0}.expressionValues{display:flex;flex-direction:row;gap:.5rem}\n"] }]
66
66
  }], ctorParameters: () => [], propDecorators: { item: [{
67
67
  type: Input
68
68
  }], hasNext: [{
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
70
70
  }], service: [{
71
71
  type: Input
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filter-expression-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAMzD,OAAO,EAAE,4BAA4B,EAAE,MAAM,iDAAiD,CAAC;;;;;AAS/F,MAAM,OAAO,kCAAkC;IAS7C;QAJA,eAAU,GAAY,KAAK,CAAC;QAE5B,qBAAgB,GAAG,4BAA4B,CAAC;IAEjC,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,UAAU;YACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpF,CAAC;IAED,aAAa,CAAC,KAAU,EAAE,aAA2C;QACnE,KAAK,EAAE,eAAe,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,cAAe,CAAC,YAAY,GAAG,aAAa,CAAC;YACvD,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;gBAC9B,IAAI,EAAE,0BAA0B;gBAChC,MAAM,EAAE;oBACN,KAAK,EAAE,IAAI,CAAC,IAAI;iBACjB;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAU,EAAE,IAA2B;QAC5C,KAAK,EAAE,eAAe,EAAE,CAAC;QAEzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;gBACrB,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;oBAC9B,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE;wBACN,KAAK,EAAE,IAAI,CAAC,IAAI;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;oBAC9B,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE;wBACN,KAAK,EAAE,IAAI,CAAC,IAAI;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,IAAI,KAAK,GAAsB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,KAAY,EAAE,EAAE;YAC5E,OAAO,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,KAAK,CAAC,YAAa,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;+GA7DU,kCAAkC;mGAAlC,kCAAkC,6HCf/C,wgIAqGA,i6CDtFa,kCAAkC;;4FAAlC,kCAAkC;kBAL9C,SAAS;+BACE,qBAAqB;wDAKtB,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport {\r\n  ISmartFilterEditorService,\r\n  SmartFilterEditorService,\r\n} from '../../../smart-filter-editor.service';\r\nimport { FilterExpressionField } from '../../../api/model/filterExpressionField';\r\nimport { FilterExpressionBoolOperator } from '../../../api/model/filterExpressionBoolOperator';\r\nimport { Value } from './../../../../view-context/value-api/model/value';\r\nimport { V } from '@angular/cdk/keycodes';\r\n\r\n@Component({\r\n  selector: 'app-expression-item',\r\n  templateUrl: './smart-filter-expression-item.component.html',\r\n  styleUrls: ['./smart-filter-expression-item.component.css'],\r\n})\r\nexport class SmartFilterExpressionItemComponent implements OnInit {\r\n  @Input() item!: FilterExpressionField;\r\n  @Input() hasNext!: boolean;\r\n  @Input() service!: ISmartFilterEditorService;\r\n\r\n  isSelected: boolean = false;\r\n\r\n  boolOperatorType = FilterExpressionBoolOperator;\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    this.isSelected =\r\n      JSON.stringify(this.service.model?.selectedField) === JSON.stringify(this.item);\r\n  }\r\n\r\n  setOperatorTo(event: any, operationType: FilterExpressionBoolOperator): void {\r\n    event?.stopPropagation();\r\n    if (!this.service.model?.readOnly) {\r\n      this.item.expressionData!.boolOperator = operationType;\r\n      this.service.peformWidgetAction({\r\n        code: 'UPDATE_FILTER_EXPRESSION',\r\n        params: {\r\n          model: this.item,\r\n        },\r\n      });\r\n    }\r\n  }\r\n\r\n  select(event: any, item: FilterExpressionField): void {\r\n    event?.stopPropagation();\r\n\r\n    if (!this.service.model?.readOnly) {\r\n      if (!this.isSelected) {\r\n        this.service.peformWidgetAction({\r\n          code: 'SELECT_FIELD',\r\n          params: {\r\n            model: this.item,\r\n          },\r\n        });\r\n      } else {\r\n        this.service.peformWidgetAction({\r\n          code: 'SELECT_FIELD',\r\n          params: {\r\n            model: this.item,\r\n          },\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getDisplayValue(code: string): string {\r\n    let value: Value | undefined = this.item.possibleValues.find((value: Value) => {\r\n      return value.code === code;\r\n    });\r\n\r\n    if (value) {\r\n      return value.displayValue!;\r\n    } else {\r\n      return code;\r\n    }\r\n  }\r\n}\r\n","<div class=\"expressionItemContainer\">\r\n  <div\r\n    class=\"expressionItemInnerContainer\"\r\n    [ngClass]=\"\r\n      item.expressionData?.currentOperation === 'EXPRESSION'\r\n        ? isSelected\r\n          ? 'selectedExpressionContainer'\r\n          : 'expressionContainer'\r\n        : ''\r\n    \"\r\n  >\r\n    <div\r\n      *ngIf=\"\r\n        item.expressionData?.currentOperation === 'EXPRESSION';\r\n        then expression;\r\n        else simpleItem\r\n      \"\r\n    ></div>\r\n    <ng-template #expression>\r\n      <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n      <app-expression-item\r\n        [item]=\"subItem\"\r\n        [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n        *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n      ></app-expression-item>\r\n      <div class=\"expressionItemBubble expression\">]</div>\r\n    </ng-template>\r\n    <ng-template #simpleItem>\r\n      <div\r\n        (click)=\"select($event, item)\"\r\n        class=\"expressionItemBubble simpleItem\"\r\n        [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n      >\r\n        {{ item.label }}:\r\n        <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n          </div>\r\n        </div>\r\n        <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n          <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n            {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n          </b>\r\n        </div>\r\n        <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n          </div>\r\n          <b>-</b>\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n  <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n    <button\r\n      mat-button\r\n      (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n      [ngClass]=\"\r\n        item.expressionData?.boolOperator === boolOperatorType.AND\r\n          ? 'mat-raised-button and-operator'\r\n          : ''\r\n      \"\r\n      color=\"black\"\r\n    >\r\n      ÉS\r\n    </button>\r\n    <button\r\n      mat-button\r\n      (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n      [ngClass]=\"\r\n        item.expressionData?.boolOperator === boolOperatorType.OR\r\n          ? 'mat-raised-button or-operator'\r\n          : ''\r\n      \"\r\n      color=\"black\"\r\n    >\r\n      VAGY\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filter-expression-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.ts","../../../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/components/smart-filter-expression-item/smart-filter-expression-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AAMzD,OAAO,EAAE,4BAA4B,EAAE,MAAM,iDAAiD,CAAC;;;;;AAS/F,MAAM,OAAO,kCAAkC;IAS7C;QAJA,eAAU,GAAY,KAAK,CAAC;QAE5B,qBAAgB,GAAG,4BAA4B,CAAC;IAEjC,CAAC;IAEhB,QAAQ;QACN,IAAI,CAAC,UAAU;YACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACpF,CAAC;IAED,aAAa,CAAC,KAAU,EAAE,aAA2C;QACnE,KAAK,EAAE,eAAe,EAAE,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,cAAe,CAAC,YAAY,GAAG,aAAa,CAAC;YACvD,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;gBAC9B,IAAI,EAAE,0BAA0B;gBAChC,MAAM,EAAE;oBACN,KAAK,EAAE,IAAI,CAAC,IAAI;iBACjB;aACF,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,MAAM,CAAC,KAAU,EAAE,IAA2B;QAC5C,KAAK,EAAE,eAAe,EAAE,CAAC;QAEzB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;YAClC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;gBACrB,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;oBAC9B,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE;wBACN,KAAK,EAAE,IAAI,CAAC,IAAI;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;oBAC9B,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE;wBACN,KAAK,EAAE,IAAI,CAAC,IAAI;qBACjB;iBACF,CAAC,CAAC;YACL,CAAC;QACH,CAAC;IACH,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,IAAI,KAAK,GAAsB,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,KAAY,EAAE,EAAE;YAC5E,OAAO,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEH,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,KAAK,CAAC,YAAa,CAAC;QAC7B,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC;QACd,CAAC;IACH,CAAC;+GA7DU,kCAAkC;mGAAlC,kCAAkC,6HCf/C,yiIAsGA,i6CDvFa,kCAAkC;;4FAAlC,kCAAkC;kBAL9C,SAAS;+BACE,qBAAqB;wDAKtB,IAAI;sBAAZ,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\r\nimport {\r\n  ISmartFilterEditorService,\r\n  SmartFilterEditorService,\r\n} from '../../../smart-filter-editor.service';\r\nimport { FilterExpressionField } from '../../../api/model/filterExpressionField';\r\nimport { FilterExpressionBoolOperator } from '../../../api/model/filterExpressionBoolOperator';\r\nimport { Value } from './../../../../view-context/value-api/model/value';\r\nimport { V } from '@angular/cdk/keycodes';\r\n\r\n@Component({\r\n  selector: 'app-expression-item',\r\n  templateUrl: './smart-filter-expression-item.component.html',\r\n  styleUrls: ['./smart-filter-expression-item.component.css'],\r\n})\r\nexport class SmartFilterExpressionItemComponent implements OnInit {\r\n  @Input() item!: FilterExpressionField;\r\n  @Input() hasNext!: boolean;\r\n  @Input() service!: ISmartFilterEditorService;\r\n\r\n  isSelected: boolean = false;\r\n\r\n  boolOperatorType = FilterExpressionBoolOperator;\r\n\r\n  constructor() {}\r\n\r\n  ngOnInit(): void {\r\n    this.isSelected =\r\n      JSON.stringify(this.service.model?.selectedField) === JSON.stringify(this.item);\r\n  }\r\n\r\n  setOperatorTo(event: any, operationType: FilterExpressionBoolOperator): void {\r\n    event?.stopPropagation();\r\n    if (!this.service.model?.readOnly) {\r\n      this.item.expressionData!.boolOperator = operationType;\r\n      this.service.peformWidgetAction({\r\n        code: 'UPDATE_FILTER_EXPRESSION',\r\n        params: {\r\n          model: this.item,\r\n        },\r\n      });\r\n    }\r\n  }\r\n\r\n  select(event: any, item: FilterExpressionField): void {\r\n    event?.stopPropagation();\r\n\r\n    if (!this.service.model?.readOnly) {\r\n      if (!this.isSelected) {\r\n        this.service.peformWidgetAction({\r\n          code: 'SELECT_FIELD',\r\n          params: {\r\n            model: this.item,\r\n          },\r\n        });\r\n      } else {\r\n        this.service.peformWidgetAction({\r\n          code: 'SELECT_FIELD',\r\n          params: {\r\n            model: this.item,\r\n          },\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  getDisplayValue(code: string): string {\r\n    let value: Value | undefined = this.item.possibleValues.find((value: Value) => {\r\n      return value.code === code;\r\n    });\r\n\r\n    if (value) {\r\n      return value.displayValue!;\r\n    } else {\r\n      return code;\r\n    }\r\n  }\r\n}\r\n","<div class=\"expressionItemContainer\">\r\n  <div\r\n    class=\"expressionItemInnerContainer\"\r\n    [ngClass]=\"\r\n      item.expressionData?.currentOperation === 'EXPRESSION'\r\n        ? isSelected\r\n          ? 'selectedExpressionContainer'\r\n          : 'expressionContainer'\r\n        : ''\r\n    \"\r\n  >\r\n    <div\r\n      *ngIf=\"\r\n        item.expressionData?.currentOperation === 'EXPRESSION';\r\n        then expression;\r\n        else simpleItem\r\n      \"\r\n    ></div>\r\n    <ng-template #expression>\r\n      <div class=\"expressionItemBubble expression\" (click)=\"select($event, item)\">[</div>\r\n      <app-expression-item\r\n        [item]=\"subItem\"\r\n        [service]=\"service\"\r\n        [hasNext]=\"i < (item.subFieldList?.filters)!.length - 1\"\r\n        *ngFor=\"let subItem of item.subFieldList?.filters; let i = index\"\r\n      ></app-expression-item>\r\n      <div class=\"expressionItemBubble expression\">]</div>\r\n    </ng-template>\r\n    <ng-template #simpleItem>\r\n      <div\r\n        (click)=\"select($event, item)\"\r\n        class=\"expressionItemBubble simpleItem\"\r\n        [ngClass]=\"isSelected ? 'selectedSimpleItem' : ''\"\r\n      >\r\n        {{ item.label }}:\r\n        <div *ngIf=\"item.expressionData?.currentOperation !== 'BETWEEN'\">\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ getDisplayValue(item.expressionData!.operand2!.valueAsString!) }}</b>\r\n          </div>\r\n        </div>\r\n        <div *ngIf=\"item.expressionData?.currentOperation === 'IN'\">\r\n          <b *ngFor=\"let value of item.expressionData?.operand2?.selectedValues; let last = last\">\r\n            {{ getDisplayValue(value) }} <b *ngIf=\"!last\">,</b>\r\n          </b>\r\n        </div>\r\n        <div class=\"expressionValues\" *ngIf=\"item.expressionData?.currentOperation === 'BETWEEN'\">\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand2!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ item.expressionData?.operand2?.valueAsString }}</b>\r\n          </div>\r\n          <b>-</b>\r\n          <div *ngIf=\"item.widgetType === 'DATE'\">\r\n            <b>{{ item.expressionData!.operand3!.valueAsString! | smartDate }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType === 'DATE_TIME'\">\r\n            <b>{{ item.expressionData!.operand3!.valueAsString! | smartDateTime }}</b>\r\n          </div>\r\n          <div *ngIf=\"item.widgetType !== 'DATE_TIME' && item.widgetType !== 'DATE'\">\r\n            <b>{{ item.expressionData?.operand3?.valueAsString }}</b>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </div>\r\n  <div *ngIf=\"hasNext\" class=\"relationItemBubble\">\r\n    <button\r\n      mat-button\r\n      (click)=\"setOperatorTo($event, boolOperatorType.AND)\"\r\n      [ngClass]=\"\r\n        item.expressionData?.boolOperator === boolOperatorType.AND\r\n          ? 'mat-raised-button and-operator'\r\n          : ''\r\n      \"\r\n      color=\"black\"\r\n    >\r\n      ÉS\r\n    </button>\r\n    <button\r\n      mat-button\r\n      (click)=\"setOperatorTo($event, boolOperatorType.OR)\"\r\n      [ngClass]=\"\r\n        item.expressionData?.boolOperator === boolOperatorType.OR\r\n          ? 'mat-raised-button or-operator'\r\n          : ''\r\n      \"\r\n      color=\"black\"\r\n    >\r\n      VAGY\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -254,11 +254,11 @@ export class SmartFilterEditorContentComponent {
254
254
  return widget;
255
255
  }
256
256
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFilterEditorContentComponent, deps: [{ token: i1.SmartformLayoutDefinitionService }, { token: i2.ComponentFactoryService }], target: i0.ɵɵFactoryTarget.Component }); }
257
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartFilterEditorContentComponent, selector: "smart-filter-expression-editor", inputs: { service: "service" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["form"], descendants: true, read: ViewContainerRef }, { propertyName: "simpleFilterVcRef", first: true, predicate: ["simpleFilterFromChild"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n <h3 class=\"smart-filter-editor-title\">{{ service.model?.model?.label }}</h3>\r\n\r\n <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n <ng-template #simpleFilter>\r\n <div class=\"smart-filter-editor-expressionsContainer\">\r\n <ng-template #simpleFilterFromChild></ng-template>\r\n <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n </div>\r\n </ng-template>\r\n <ng-template #complexFilter>\r\n <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n service?.model?.model?.workplaceList?.filters?.length;\r\n then withParameters;\r\n else withoutParameters\r\n \"\r\n ></div>\r\n <ng-template #withoutParameters>\r\n <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n <span class=\"mat-body\"> M\u00E9g nincs megadva param\u00E9ter </span>\r\n </div>\r\n </ng-template>\r\n <ng-template #withParameters>\r\n <div class=\"smart-filter-editor-withParametersContainer\">\r\n <div\r\n class=\"smart-filter-editor-expressionsContainer\"\r\n *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n >\r\n <app-expression-items\r\n [items]=\"(service.model?.model?.workplaceList)!.filters\"\r\n [service]=\"service\"\r\n ></app-expression-items>\r\n </div>\r\n <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n <ng-template #form></ng-template>\r\n <div *ngIf=\"smartForm\">\r\n <button (click)=\"remove()\" mat-raised-button color=\"primary\">T\u00F6rl\u00E9s</button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n</div>\r\n", styles: [".smart-filter-editor-container{display:flex;flex-direction:column;overflow:auto;position:relative}.targetGroupContentContainer h3{margin:0;font-weight:600}.smart-filter-editor-uiActionsBar{padding:1.5rem;border-radius:.25rem;background-color:var(--container-color);display:flex;flex-direction:row;gap:1rem}.smart-filter-editor-withoutParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.withoutParametersContainer .mat-body{font-weight:600;text-align:center}.smart-filter-editor-withParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.smart-filter-editor-expressionEditorContainer{display:flex;flex-direction:column;gap:.75rem}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.SmartFilterExpressionItemsComponent, selector: "app-expression-items", inputs: ["items", "service"] }] }); }
257
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SmartFilterEditorContentComponent, selector: "smart-filter-expression-editor", inputs: { service: "service" }, viewQueries: [{ propertyName: "vcRef", first: true, predicate: ["form"], descendants: true, read: ViewContainerRef }, { propertyName: "simpleFilterVcRef", first: true, predicate: ["simpleFilterFromChild"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: "<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n <h3 class=\"smart-filter-editor-title\">{{ service.model.model?.label }}</h3>\r\n\r\n <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n <ng-template #simpleFilter>\r\n <div class=\"smart-filter-editor-expressionsContainer\">\r\n <ng-template #simpleFilterFromChild></ng-template>\r\n <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n </div>\r\n </ng-template>\r\n <ng-template #complexFilter>\r\n <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n service?.model?.model?.workplaceList?.filters?.length;\r\n then withParameters;\r\n else withoutParameters\r\n \"\r\n ></div>\r\n <ng-template #withoutParameters>\r\n <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n <span class=\"mat-body\"> M\u00E9g nincs megadva param\u00E9ter </span>\r\n </div>\r\n </ng-template>\r\n <ng-template #withParameters>\r\n <div class=\"smart-filter-editor-withParametersContainer\">\r\n <div\r\n class=\"smart-filter-editor-expressionsContainer\"\r\n *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n >\r\n <app-expression-items\r\n [items]=\"(service.model.model?.workplaceList)!.filters\"\r\n [service]=\"service\"\r\n ></app-expression-items>\r\n </div>\r\n <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n <ng-template #form></ng-template>\r\n <div *ngIf=\"smartForm\">\r\n <button (click)=\"remove()\" mat-raised-button color=\"primary\">T\u00F6rl\u00E9s</button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n</div>\r\n", styles: [".smart-filter-editor-container{display:flex;flex-direction:column;overflow:auto;position:relative}.targetGroupContentContainer h3{margin:0;font-weight:600}.smart-filter-editor-uiActionsBar{padding:1.5rem;border-radius:.25rem;background-color:var(--container-color);display:flex;flex-direction:row;gap:1rem}.smart-filter-editor-withoutParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.withoutParametersContainer .mat-body{font-weight:600;text-align:center}.smart-filter-editor-withParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.smart-filter-editor-expressionEditorContainer{display:flex;flex-direction:column;gap:.75rem}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.UiActionToolbarComponent, selector: "smart-ui-action-toolbar", inputs: ["uiActionModels", "uiActionDescriptorService", "id"] }, { kind: "component", type: i5.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i6.SmartFilterExpressionItemsComponent, selector: "app-expression-items", inputs: ["items", "service"] }] }); }
258
258
  }
259
259
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SmartFilterEditorContentComponent, decorators: [{
260
260
  type: Component,
261
- args: [{ selector: 'smart-filter-expression-editor', template: "<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n <h3 class=\"smart-filter-editor-title\">{{ service.model?.model?.label }}</h3>\r\n\r\n <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n <ng-template #simpleFilter>\r\n <div class=\"smart-filter-editor-expressionsContainer\">\r\n <ng-template #simpleFilterFromChild></ng-template>\r\n <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n </div>\r\n </ng-template>\r\n <ng-template #complexFilter>\r\n <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n service?.model?.model?.workplaceList?.filters?.length;\r\n then withParameters;\r\n else withoutParameters\r\n \"\r\n ></div>\r\n <ng-template #withoutParameters>\r\n <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n <span class=\"mat-body\"> M\u00E9g nincs megadva param\u00E9ter </span>\r\n </div>\r\n </ng-template>\r\n <ng-template #withParameters>\r\n <div class=\"smart-filter-editor-withParametersContainer\">\r\n <div\r\n class=\"smart-filter-editor-expressionsContainer\"\r\n *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n >\r\n <app-expression-items\r\n [items]=\"(service.model?.model?.workplaceList)!.filters\"\r\n [service]=\"service\"\r\n ></app-expression-items>\r\n </div>\r\n <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n <ng-template #form></ng-template>\r\n <div *ngIf=\"smartForm\">\r\n <button (click)=\"remove()\" mat-raised-button color=\"primary\">T\u00F6rl\u00E9s</button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n</div>\r\n", styles: [".smart-filter-editor-container{display:flex;flex-direction:column;overflow:auto;position:relative}.targetGroupContentContainer h3{margin:0;font-weight:600}.smart-filter-editor-uiActionsBar{padding:1.5rem;border-radius:.25rem;background-color:var(--container-color);display:flex;flex-direction:row;gap:1rem}.smart-filter-editor-withoutParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.withoutParametersContainer .mat-body{font-weight:600;text-align:center}.smart-filter-editor-withParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.smart-filter-editor-expressionEditorContainer{display:flex;flex-direction:column;gap:.75rem}\n"] }]
261
+ args: [{ selector: 'smart-filter-expression-editor', template: "<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n <h3 class=\"smart-filter-editor-title\">{{ service.model.model?.label }}</h3>\r\n\r\n <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n <ng-template #simpleFilter>\r\n <div class=\"smart-filter-editor-expressionsContainer\">\r\n <ng-template #simpleFilterFromChild></ng-template>\r\n <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n </div>\r\n </ng-template>\r\n <ng-template #complexFilter>\r\n <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n </div>\r\n <div\r\n *ngIf=\"\r\n service?.model?.model?.workplaceList?.filters?.length;\r\n then withParameters;\r\n else withoutParameters\r\n \"\r\n ></div>\r\n <ng-template #withoutParameters>\r\n <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n <span class=\"mat-body\"> M\u00E9g nincs megadva param\u00E9ter </span>\r\n </div>\r\n </ng-template>\r\n <ng-template #withParameters>\r\n <div class=\"smart-filter-editor-withParametersContainer\">\r\n <div\r\n class=\"smart-filter-editor-expressionsContainer\"\r\n *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n >\r\n <app-expression-items\r\n [items]=\"(service.model.model?.workplaceList)!.filters\"\r\n [service]=\"service\"\r\n ></app-expression-items>\r\n </div>\r\n <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n <ng-template #form></ng-template>\r\n <div *ngIf=\"smartForm\">\r\n <button (click)=\"remove()\" mat-raised-button color=\"primary\">T\u00F6rl\u00E9s</button>\r\n </div>\r\n </div>\r\n </div>\r\n </ng-template>\r\n </ng-template>\r\n</div>\r\n", styles: [".smart-filter-editor-container{display:flex;flex-direction:column;overflow:auto;position:relative}.targetGroupContentContainer h3{margin:0;font-weight:600}.smart-filter-editor-uiActionsBar{padding:1.5rem;border-radius:.25rem;background-color:var(--container-color);display:flex;flex-direction:row;gap:1rem}.smart-filter-editor-withoutParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.withoutParametersContainer .mat-body{font-weight:600;text-align:center}.smart-filter-editor-withParametersContainer{display:flex;flex-direction:column;background-color:var(--container-color)}.smart-filter-editor-expressionEditorContainer{display:flex;flex-direction:column;gap:.75rem}\n"] }]
262
262
  }], ctorParameters: () => [{ type: i1.SmartformLayoutDefinitionService }, { type: i2.ComponentFactoryService }], propDecorators: { service: [{
263
263
  type: Input
264
264
  }], vcRef: [{
@@ -268,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
268
268
  type: ViewChild,
269
269
  args: ['simpleFilterFromChild', { read: ViewContainerRef }]
270
270
  }] } });
271
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filter-editor-content.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,KAAK,EAGL,SAAS,EAET,gBAAgB,GACjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;AAExD,OAAO,EAAE,+BAA+B,EAAE,MAAM,6BAA6B,CAAC;AAC9E,OAAO,EAAE,wBAAwB,EAAE,MAAM,qDAAqD,CAAC;AAC/F,OAAO,EAAE,mBAAmB,EAAE,MAAM,2BAA2B,CAAC;AAEhE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAK1E,OAAO,EAAE,sCAAsC,EAAE,MAAM,6CAA6C,CAAC;AAErG,OAAO,EAAE,iCAAiC,EAAE,MAAM,sCAAsC,CAAC;AAEzF,OAAO,EAAE,kBAAkB,EAAE,MAAM,iDAAiD,CAAC;;;;;;;;AAOrF,MAAM,OAAO,iCAAiC;IAiB5C,YACU,aAA+C,EAC/C,SAAkC;QADlC,kBAAa,GAAb,aAAa,CAAkC;QAC/C,cAAS,GAAT,SAAS,CAAyB;QAlBpC,cAAS,GAAkB,IAAI,OAAO,EAAE,CAAC;QAGjD,mBAAc,GAAoB,EAAE,CAAC;QACrC,6BAAwB,GAAoB,EAAE,CAAC;QAU/C,SAAI,GAAG,sCAAsC,CAAC;IAK3C,CAAC;IAEI,iCAAiC;QACvC,IAAI,CAAC,eAAgB,CAAC,QAAQ,CAAC,aAAc,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC3F,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,eAAgB,CAAC,QAAQ,CAAC,wBAAwB,EAAE,IAAI,CAC3D,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACrB,IAAI,MAAM,CAAC,IAAI,KAAK,WAAW,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC;gBAC1E,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,iCAAiC;QACvC,IAAI,CAAC,WAAW,EAAE,QAAS,CAAC,aAAc,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACxF,IAAI,CAAC,IAAI,EAAE,CAAC;QACd,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,WAAY,CAAC,QAAS,CAAC,wBAAwB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAC7F,CAAC,MAAgC,EAAE,EAAE;YACnC,IAAI,MAAM,CAAC,GAAG,KAAK,iCAAiC,EAAE,CAAC;gBACrD,IAAI,CAAC,IAAI,EAAE,CAAC;YACd,CAAC;QACH,CAAC,CACF,CAAC;IACJ,CAAC;IAED,QAAQ,KAAU,CAAC;IACnB,eAAe;QACb,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC;QACxF,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IACD,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC5B,OAAO;QACT,CAAC;QAED,IAAI,OAAO,GAA2B,EAAE,CAAC;QAEzC,IAAI,GAAuB,CAAC;QAE5B,IAAI,KAAK,GAA2B,EAAE,CAAC;QAEvC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,aAAa,EAAE,OAAO,CAAC,OAAO,CACvD,CAAC,qBAA4C,EAAE,KAAa,EAAE,EAAE;YAC9D,KAAK,CAAC,KAAK,CAAC,GAAG,qBAAqB,CAAC;YAErC,IACE,qBAAqB,CAAC,UAAU,KAAK,+BAA+B,CAAC,iBAAiB,EACtF,CAAC;gBACD,GAAG,GAAG,KAAK,GAAG,0CAA0C,CAAC;gBACzD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,+BAA+B,CAAC,iBAAiB,EACjD,EAAE,EACF,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,eAAe,IAAI,EAAE,EACrE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBACF,OAAO;YACT,CAAC;YAED,IAAI,qBAAqB,CAAC,UAAU,KAAK,iBAAiB,EAAE,CAAC;gBAC3D,GAAG,GAAG,KAAK,GAAG,yCAAyC,CAAC;gBACxD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,qBAAqB,CAAC,UAAU,IAAI,+BAA+B,CAAC,UAAU,EAC9E,qBAAqB,CAAC,cAAyB,EAC/C,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,cAAc,IAAI,EAAE,EACpE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBACF,OAAO;YACT,CAAC;YAED,IAAI,qBAAqB,CAAC,cAAc,EAAE,gBAAgB,KAAK,SAAS,EAAE,CAAC;gBACzE,GAAG,GAAG,KAAK,GAAG,wCAAwC,CAAC;gBACvD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,qBAAqB,CAAC,UAAU,IAAI,+BAA+B,CAAC,UAAU,EAC9E,qBAAqB,CAAC,cAAyB,EAC/C,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,aAAa,IAAI,EAAE,EACnE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBAEF,GAAG,GAAG,KAAK,GAAG,wCAAwC,CAAC;gBACvD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,qBAAqB,CAAC,UAAU,IAAI,+BAA+B,CAAC,UAAU,EAC9E,qBAAqB,CAAC,cAAyB,EAC/C,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,aAAa,IAAI,EAAE,EACnE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBACF,OAAO;YACT,CAAC;YAED,IAAI,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,CAAC;gBACnD,GAAG,GAAG,KAAK,GAAG,wCAAwC,CAAC;gBAEvD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,qBAAqB,CAAC,UAAU,IAAI,+BAA+B,CAAC,UAAU,EAC9E,qBAAqB,CAAC,cAAyB,EAC/C,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,aAAa,IAAI,EAAE,EACnE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBACF,OAAO;YACT,CAAC;YACD,IAAI,qBAAqB,EAAE,cAAc,EAAE,QAAQ,EAAE,CAAC;gBACpD,GAAG,GAAG,KAAK,GAAG,wCAAwC,CAAC;gBAEvD,OAAO,CAAC,IAAI,CACV,IAAI,CAAC,mBAAmB,CACtB,GAAG,EACH,qBAAqB,CAAC,MAAO,EAC7B,qBAAqB,CAAC,UAAU,IAAI,+BAA+B,CAAC,UAAU,EAE9E,qBAAqB,CAAC,cAAyB,EAC/C,qBAAqB,CAAC,cAAc,EAAE,QAAQ,EAAE,aAAa,IAAI,EAAE,EACnE,qBAAqB,CAAC,SAAS,CAChC,CACF,CAAC;gBACF,OAAO;YACT,CAAC;QACH,CAAC,CACF,CAAC;QAEF,IAAI,SAAS,GAAG;YACd,SAAS,EAAE,wBAAwB,CAAC,GAAG;YACvC,cAAc,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE;YAC/B,qBAAqB,EAAE,IAAI;YAC3B,cAAc,EAAE,IAAI;YACpB,OAAO;SACR,CAAC;QAEF,IAAI,IAAI,CAAC,eAAe,EAAE,QAAQ,EAAE,CAAC;YACnC,iDAAiD;YACjD,IAAI,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,CAAC;YAE1C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC;gBACrF,kEAAkE;gBAClE,IAAI,CAAC,SAAS,CAAC,cAAc,GAAG,SAAS,CAAC,cAAc,CAAC;gBACzD,IAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,OAAO;YACT,CAAC;QACH,CAAC;QAED,IAAI,CAAC,iBAAiB,EAAE,KAAK,EAAE,CAAC;QAChC,IAAI,CAAC,eAAe,EAAE,OAAO,EAAE,CAAC;QAEhC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CACnD,IAAI,CAAC,iBAAkB,EACvB,kBAAkB,EAClB,IAAI,GAAG,CAAc,CAAC,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC,CAAC,CACjD,CAAC;QAEF,IAAI,CAAC,iCAAiC,EAAE,CAAC;IAC3C,CAAC;IAEO,cAAc,CAAC,GAA2B,EAAE,GAA2B;QAC7E,IAAI,GAAG,CAAC,MAAM,KAAK,GAAG,CAAC,MAAM,EAAE,CAAC;YAC9B,OAAO,KAAK,CAAC;QACf,CAAC;QACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACpC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACxC,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa,CAAC,EAAwB,EAAE,EAAwB;QACtE,OAAO,kBAAkB,CAAC,cAAc,CAAC,EAAE,EAAE,EAAE,EAAE;YAC/C,OAAO;YACP,KAAK;YACL,OAAO;YACP,MAAM;YACN,wDAAwD;YACxD,WAAW;YACX,WAAW;YACX,WAAW;SACZ,CAAC,CAAC;IACL,CAAC;IAEO,+BAA+B;QACrC,IAAI,YAAY,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC;QACzF,IAAI,MAAM,GAA4B,EAAE,CAAC;QAEzC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,OAAO,CAAC,CAAC,GAAW,EAAE,EAAE;YAChD,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QACjC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,KAAM,CAAC,KAAM,CAAC,aAAc,CAAC,OAAO,GAAG,MAAM,CAAC;IAC7D,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YAClD,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC3B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAE/B,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,CAAC;gBAC7C,IAAI,CAAC,aAAa,EAAE,CAAC;YACvB,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;YAC7B,CAAC;QACH,CAAC;IACH,CAAC;IAED,uBAAuB;QACrB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,eAAe,EAAE,CAAC;YACxC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,MAAgB,EAAE,EAAE;gBAChF,OAAO;oBACL,YAAY,EAAE,IAAI,CAAC,OAAO;oBAC1B,QAAQ,EAAE,MAAM;iBACjB,CAAC;YACJ,CAAC,CAAC,CAAC;QACL,CAAC;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,mBAAmB,EAAE,eAAe,EAAE,CAAC;YAC7D,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,mBAAmB,CAAC,eAAe,CAAC,GAAG,CACzF,CAAC,QAAkB,EAAE,EAAE;gBACrB,IAAI,cAAc,GAAa,EAAE,CAAC;gBAClC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAW,EAAE,EAAE;oBACvC,cAAsB,CAAC,GAAG,CAAC,GAAI,QAAgB,CAAC,GAAG,CAAC,CAAC;gBACxD,CAAC,CAAC,CAAC;gBACH,cAAc,CAAC,MAAM,GAAG;oBACtB,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa;iBACzC,CAAC;gBACF,OAAO;oBACL,YAAY,EAAE,IAAI,CAAC,OAAO;oBAC1B,QAAQ,EAAE,cAAc;iBACzB,CAAC;YACJ,CAAC,CACF,CAAC;QACJ,CAAC;IACH,CAAC;IAED,aAAa;QACX,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,CAAC;QAE5B,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;QAED,IAAI,gBAAgB,GAA2B,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC;YACvE,iBAAiB,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,mBAAmB,EAAE,SAAS,EAAE,OAAO;SAC/E,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,GAAG;YACf,SAAS,EAAE,wBAAwB,CAAC,GAAG;YACvC,cAAc,EAAE,IAAI;YACpB,qBAAqB,EAAE,IAAI;YAC3B,cAAc,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa,EAAE;YAC3D,OAAO,EAAE,gBAAgB;SAC1B,CAAC;QAEF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,eAAe,CAC/C,IAAI,CAAC,KAAM,EACX,kBAAkB,EAClB,IAAI,GAAG,CAAc,CAAC,CAAC,WAAW,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CACtD,CAAC;QAEF,IAAI,CAAC,iCAAiC,EAAE,CAAC;IAC3C,CAAC;IAED,IAAI;QACF,IAAI,CAAC,WAAW,EAAE,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;YAC9B,IAAI,EAAE,0BAA0B;YAChC,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa;aACzC;SACF,CAAC,CAAC;IACL,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC;YAC9B,IAAI,EAAE,0BAA0B;YAChC,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,aAAa;aACzC;SACF,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,UAAU;QACd,IAAI,CAAC,+BAA+B,EAAE,CAAC;QACvC,MAAM,IAAI,CAAC,OAAO,CAAC,sBAAsB,CAAC;YACxC,IAAI,EAAE,iCAAiC,CAAC,0BAA0B;YAClE,MAAM,EAAE;gBACN,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,KAAM;aAC3B;SACF,CAAC,CAAC;IACL,CAAC;IAEO,mBAAmB,CACzB,GAAW,EACX,KAAa,EACb,UAA2C,EAC3C,cAAuB,EACvB,KAAU,EACV,SAAkB;QAElB,IAAI,IAAI,GAAQ,UAAU,CAAC;QAE3B,IAAI,IAAI,KAAK,+BAA+B,CAAC,IAAI,EAAE,CAAC;YAClD,IAAI,GAAG,mBAAmB,CAAC,WAAW,CAAC;QACzC,CAAC;aAAM,IAAI,IAAI,KAAK,+BAA+B,CAAC,SAAS,EAAE,CAAC;YAC9D,IAAI,GAAG,mBAAmB,CAAC,gBAAgB,CAAC;QAC9C,CAAC;QAED,IAAI,MAAM,GAAyB;YACjC,KAAK,EAAE,SAAS;YAChB,GAAG;YACH,KAAK;YACL,IAAI;YACJ,KAAK;YACL,SAAS,EAAE,IAAI;YACf,SAAS,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,KAAY,EAAE,EAAE;gBAC7C,OAAO;oBACL,GAAG,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,IAAK;oBACpD,KAAK,EAAE,KAAK,CAAC,YAAY;oBACzB,IAAI,EAAE,mBAAmB,CAAC,IAAI;oBAC9B,KAAK,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI;iBACtD,CAAC;YACJ,CAAC,CAAC;YACF,SAAS;SACV,CAAC;QAEF,OAAO,MAAM,CAAC;IAChB,CAAC;+GAlXU,iCAAiC;mGAAjC,iCAAiC,gLAOjB,gBAAgB,qHAIC,gBAAgB,6BC7C9D,olEAiDA;;4FDfa,iCAAiC;kBAL7C,SAAS;+BACE,gCAAgC;2IAMjC,OAAO;sBAAf,KAAK;gBAKyC,KAAK;sBAAnD,SAAS;uBAAC,MAAM,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBAK7C,iBAAiB;sBADhB,SAAS;uBAAC,uBAAuB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ComponentRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  ViewChildren,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\n\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { ComponentFactoryService } from '../../component-factory-service/component-factory-service.service';\r\nimport { FilterExpressionFieldWidgetType } from '../../smart-filter/projects';\r\nimport { SmartFormWidgetDirection } from '../../smart-form/api/model/smartFormWidgetDirection';\r\nimport { SmartFormWidgetType } from '../../smart-form/projects';\r\nimport { SmartformLayoutDefinitionService } from '../../smart-form/services/smartform.layout-definition.service';\r\nimport { SmartformComponent } from '../../smart-form/smartform.component';\r\nimport { SmartFormWidget } from '../../smart-form/smartform.form-model';\r\nimport { SmartForm, SophisticatedValueChange, Value } from '../../smart-form/smartform.model';\r\nimport { UiAction } from '../../view-context/api/model/uiAction';\r\nimport { UiActionModel } from '../../view-context/smart-ui-action/ui-action.model';\r\nimport { FilterExpressionBuilderUiModelTypeEnum } from '../api/model/filterExpressionBuilderUiModel';\r\nimport { FilterExpressionField } from '../api/model/filterExpressionField';\r\nimport { FilterExpressionBuilderApiActions } from '../filterExpressionBuilderApiActions';\r\nimport { ISmartFilterEditorService } from '../smart-filter-editor.service';\r\nimport { SmartObjectUtility } from '../../view-context/utility/smart-object-utility';\r\n\r\n@Component({\r\n  selector: 'smart-filter-expression-editor',\r\n  templateUrl: './smart-filter-editor-content.component.html',\r\n  styleUrls: ['./smart-filter-editor-content.component.css'],\r\n})\r\nexport class SmartFilterEditorContentComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n  @Input() service!: ISmartFilterEditorService;\r\n\r\n  uiActionModels: UiActionModel[] = [];\r\n  expressionUiActionModels: UiActionModel[] = [];\r\n\r\n  @ViewChild('form', { read: ViewContainerRef }) vcRef?: ViewContainerRef;\r\n  formCompRef?: ComponentRef<SmartformComponent>;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChild('simpleFilterFromChild', { read: ViewContainerRef })\r\n  simpleFilterVcRef?: ViewContainerRef;\r\n  simpleFilterRef?: ComponentRef<SmartformComponent>;\r\n\r\n  type = FilterExpressionBuilderUiModelTypeEnum;\r\n\r\n  constructor(\r\n    private layoutService: SmartformLayoutDefinitionService,\r\n    private cfService: ComponentFactoryService\r\n  ) {}\r\n\r\n  private subsrcibeSimpleFormChildrenEvents(): void {\r\n    this.simpleFilterRef!.instance.onBlurSubject!.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n      this.saveFilter();\r\n    });\r\n    this.simpleFilterRef!.instance.sophisticatedValueChange?.pipe(\r\n      takeUntil(this._destroy$)\r\n    ).subscribe((change) => {\r\n      if (change.kind === 'selection' && !change.key.includes('selectedValues')) {\r\n        this.saveFilter();\r\n      }\r\n    });\r\n  }\r\n\r\n  private subscribeEditorFormChildrenEvents(): void {\r\n    this.formCompRef?.instance!.onBlurSubject!.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n      this.save();\r\n    });\r\n\r\n    this.formCompRef!.instance!.sophisticatedValueChange?.pipe(takeUntil(this._destroy$)).subscribe(\r\n      (change: SophisticatedValueChange) => {\r\n        if (change.key === 'expressionData.currentOperation') {\r\n          this.save();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n  ngAfterViewInit(): void {\r\n    this.service.modelChanged.pipe(takeUntil(this._destroy$)).subscribe(() => this.setUp());\r\n    this.service.load();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  setupSimpleFilter(): void {\r\n    if (!this.simpleFilterVcRef) {\r\n      return;\r\n    }\r\n\r\n    let widgets: SmartFormWidget<any>[] = [];\r\n\r\n    let key: string | undefined;\r\n\r\n    let model: { [key: string]: any } = {};\r\n\r\n    this.service.model?.model?.workplaceList?.filters.forEach(\r\n      (filterExpressionField: FilterExpressionField, index: number) => {\r\n        model[index] = filterExpressionField;\r\n\r\n        if (\r\n          filterExpressionField.widgetType === FilterExpressionFieldWidgetType.TEXT_FIELD_LOOKUP\r\n        ) {\r\n          key = index + '.expressionData.operand2.selectedObjects';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              FilterExpressionFieldWidgetType.TEXT_FIELD_LOOKUP,\r\n              [],\r\n              filterExpressionField.expressionData?.operand2?.selectedObjects ?? [],\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.widgetType === 'SELECT_MULTIPLE') {\r\n          key = index + '.expressionData.operand2.selectedValues';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.selectedValues ?? [],\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.expressionData?.currentOperation === 'BETWEEN') {\r\n          key = index + '.expressionData.operand2.valueAsString';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n\r\n          key = index + '.expressionData.operand3.valueAsString';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label3!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand3?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.expressionData?.operand2) {\r\n          key = index + '.expressionData.operand2.valueAsString';\r\n\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n        if (filterExpressionField?.expressionData?.operand3) {\r\n          key = index + '.expressionData.operand3.valueAsString';\r\n\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label3!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand3?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n      }\r\n    );\r\n\r\n    let smartForm = {\r\n      direction: SmartFormWidgetDirection.ROW,\r\n      componentModel: { data: model },\r\n      useOnValueChangeEvent: true,\r\n      useOnBlurEvent: true,\r\n      widgets,\r\n    };\r\n\r\n    if (this.simpleFilterRef?.instance) {\r\n      // we already have a SmartFormComponent, use that\r\n      let comp = this.simpleFilterRef?.instance;\r\n\r\n      if (comp.smartForm && this.compareWidgets(comp.smartForm.widgets, smartForm.widgets)) {\r\n        // there's no structural change, don't recreate SmartFormComponent\r\n        comp.smartForm.componentModel = smartForm.componentModel;\r\n        comp.constructForm();\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.simpleFilterVcRef?.clear();\r\n    this.simpleFilterRef?.destroy();\r\n\r\n    this.simpleFilterRef = this.cfService.createComponent(\r\n      this.simpleFilterVcRef!,\r\n      SmartformComponent,\r\n      new Map<string, any>([['smartForm', smartForm]])\r\n    );\r\n\r\n    this.subsrcibeSimpleFormChildrenEvents();\r\n  }\r\n\r\n  private compareWidgets(ws1: SmartFormWidget<any>[], ws2: SmartFormWidget<any>[]): boolean {\r\n    if (ws1.length !== ws2.length) {\r\n      return false;\r\n    }\r\n    for (let i = 0; i < ws1.length; i++) {\r\n      if (!this.compareWidget(ws1[i], ws2[i])) {\r\n        return false;\r\n      }\r\n    }\r\n    return true;\r\n  }\r\n\r\n  private compareWidget(w1: SmartFormWidget<any>, w2: SmartFormWidget<any>): boolean {\r\n    return SmartObjectUtility.compareByProps(w1, w2, [\r\n      'error',\r\n      'key',\r\n      'label',\r\n      'type',\r\n      // 'value', <- value will be set by componentModel.data!\r\n      'showLabel',\r\n      'valueList',\r\n      'toolbarId',\r\n    ]);\r\n  }\r\n\r\n  private extractFilterFieldFromFormModel(): void {\r\n    let simpleFilter = this.simpleFilterRef?.instance?.submitForm(false).componentModel.data;\r\n    let result: FilterExpressionField[] = [];\r\n\r\n    Object.keys(simpleFilter).forEach((key: string) => {\r\n      result.push(simpleFilter[key]);\r\n    });\r\n    this.service.model!.model!.workplaceList!.filters = result;\r\n  }\r\n\r\n  setUp(): void {\r\n    if (this.service.model?.type === this.type.SIMPLE) {\r\n      this.setupSimpleFilter();\r\n    } else {\r\n      this.constructUiActionModels();\r\n\r\n      if (this.service?.model?.selectedFieldEditor) {\r\n        this.constructForm();\r\n      } else {\r\n        this.smartForm = undefined;\r\n      }\r\n    }\r\n  }\r\n\r\n  constructUiActionModels(): void {\r\n    if (this.service.model?.possibleActions) {\r\n      this.uiActionModels = this.service.model.possibleActions.map((action: UiAction) => {\r\n        return {\r\n          serviceToUse: this.service,\r\n          uiAction: action,\r\n        };\r\n      });\r\n    }\r\n\r\n    if (this.service.model?.selectedFieldEditor?.possibleActions) {\r\n      this.expressionUiActionModels = this.service.model?.selectedFieldEditor.possibleActions.map(\r\n        (uiAction: UiAction) => {\r\n          let copiedUiAction: UiAction = {};\r\n          Object.keys(uiAction).map((key: string) => {\r\n            (copiedUiAction as any)[key] = (uiAction as any)[key];\r\n          });\r\n          copiedUiAction.params = {\r\n            field: this.service.model?.selectedField,\r\n          };\r\n          return {\r\n            serviceToUse: this.service,\r\n            uiAction: copiedUiAction,\r\n          };\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  constructForm(): void {\r\n    this.vcRef?.clear();\r\n    this.formCompRef?.destroy();\r\n\r\n    if (!this.vcRef) {\r\n      return;\r\n    }\r\n\r\n    let generatedWidgets: SmartFormWidget<any>[] = this.layoutService.render({\r\n      layoutDefinitions: this.service.model?.selectedFieldEditor?.layoutDef?.widgets,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: SmartFormWidgetDirection.ROW,\r\n      useOnBlurEvent: true,\r\n      useOnValueChangeEvent: true,\r\n      componentModel: { data: this.service.model?.selectedField },\r\n      widgets: generatedWidgets,\r\n    };\r\n\r\n    this.formCompRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      SmartformComponent,\r\n      new Map<string, any>([['smartForm', this.smartForm]])\r\n    );\r\n\r\n    this.subscribeEditorFormChildrenEvents();\r\n  }\r\n\r\n  save(): void {\r\n    this.formCompRef?.instance?.submitForm(false);\r\n    this.service.peformWidgetAction({\r\n      code: 'UPDATE_FILTER_EXPRESSION',\r\n      params: {\r\n        model: this.service.model?.selectedField,\r\n      },\r\n    });\r\n  }\r\n\r\n  remove(): void {\r\n    this.service.peformWidgetAction({\r\n      code: 'REMOVE_FILTER_EXPRESSION',\r\n      params: {\r\n        model: this.service.model?.selectedField,\r\n      },\r\n    });\r\n  }\r\n\r\n  async saveFilter(): Promise<void> {\r\n    this.extractFilterFieldFromFormModel();\r\n    await this.service.performUiActionRequest({\r\n      code: FilterExpressionBuilderApiActions.SAVE_EXPRESSION_FIELD_LIST,\r\n      params: {\r\n        model: this.service.model!,\r\n      },\r\n    });\r\n  }\r\n\r\n  private constructFormWidget(\r\n    key: string,\r\n    label: string,\r\n    widgetType: FilterExpressionFieldWidgetType,\r\n    possibleValues: Value[],\r\n    value: any,\r\n    toolbarId?: string\r\n  ): SmartFormWidget<any> {\r\n    let type: any = widgetType;\r\n\r\n    if (type === FilterExpressionFieldWidgetType.DATE) {\r\n      type = SmartFormWidgetType.DATE_PICKER;\r\n    } else if (type === FilterExpressionFieldWidgetType.DATE_TIME) {\r\n      type = SmartFormWidgetType.DATE_TIME_PICKER;\r\n    }\r\n\r\n    let widget: SmartFormWidget<any> = {\r\n      error: undefined,\r\n      key,\r\n      label,\r\n      type,\r\n      value,\r\n      showLabel: true,\r\n      valueList: possibleValues.map((value: Value) => {\r\n        return {\r\n          key: value.objectUri ? value.objectUri : value.code!,\r\n          label: value.displayValue,\r\n          type: SmartFormWidgetType.ITEM,\r\n          value: value.objectUri ? value.objectUri : value.code,\r\n        };\r\n      }),\r\n      toolbarId,\r\n    };\r\n\r\n    return widget;\r\n  }\r\n}\r\n","<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n  <h3 class=\"smart-filter-editor-title\">{{ service.model?.model?.label }}</h3>\r\n\r\n  <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n  <ng-template #simpleFilter>\r\n    <div class=\"smart-filter-editor-expressionsContainer\">\r\n      <ng-template #simpleFilterFromChild></ng-template>\r\n      <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n    </div>\r\n  </ng-template>\r\n  <ng-template #complexFilter>\r\n    <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n      <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n    </div>\r\n    <div\r\n      *ngIf=\"\r\n        service?.model?.model?.workplaceList?.filters?.length;\r\n        then withParameters;\r\n        else withoutParameters\r\n      \"\r\n    ></div>\r\n    <ng-template #withoutParameters>\r\n      <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n        <span class=\"mat-body\"> Még nincs megadva paraméter </span>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #withParameters>\r\n      <div class=\"smart-filter-editor-withParametersContainer\">\r\n        <div\r\n          class=\"smart-filter-editor-expressionsContainer\"\r\n          *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n        >\r\n          <app-expression-items\r\n            [items]=\"(service.model?.model?.workplaceList)!.filters\"\r\n            [service]=\"service\"\r\n          ></app-expression-items>\r\n        </div>\r\n        <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n          <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n          <ng-template #form></ng-template>\r\n          <div *ngIf=\"smartForm\">\r\n            <button (click)=\"remove()\" mat-raised-button color=\"primary\">Törlés</button>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </ng-template>\r\n</div>\r\n"]}
271
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filter-editor-content.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-filter-editor/smart-filter-editor-content/smart-filter-editor-content.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ComponentRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n  ViewChildren,\r\n  ViewContainerRef,\r\n} from '@angular/core';\r\n\r\nimport { Subject, Subscription, takeUntil } from 'rxjs';\r\nimport { ComponentFactoryService } from '../../component-factory-service/component-factory-service.service';\r\nimport { FilterExpressionFieldWidgetType } from '../../smart-filter/projects';\r\nimport { SmartFormWidgetDirection } from '../../smart-form/api/model/smartFormWidgetDirection';\r\nimport { SmartFormWidgetType } from '../../smart-form/projects';\r\nimport { SmartformLayoutDefinitionService } from '../../smart-form/services/smartform.layout-definition.service';\r\nimport { SmartformComponent } from '../../smart-form/smartform.component';\r\nimport { SmartFormWidget } from '../../smart-form/smartform.form-model';\r\nimport { SmartForm, SophisticatedValueChange, Value } from '../../smart-form/smartform.model';\r\nimport { UiAction } from '../../view-context/api/model/uiAction';\r\nimport { UiActionModel } from '../../view-context/smart-ui-action/ui-action.model';\r\nimport { FilterExpressionBuilderUiModelTypeEnum } from '../api/model/filterExpressionBuilderUiModel';\r\nimport { FilterExpressionField } from '../api/model/filterExpressionField';\r\nimport { FilterExpressionBuilderApiActions } from '../filterExpressionBuilderApiActions';\r\nimport { ISmartFilterEditorService } from '../smart-filter-editor.service';\r\nimport { SmartObjectUtility } from '../../view-context/utility/smart-object-utility';\r\n\r\n@Component({\r\n  selector: 'smart-filter-expression-editor',\r\n  templateUrl: './smart-filter-editor-content.component.html',\r\n  styleUrls: ['./smart-filter-editor-content.component.css'],\r\n})\r\nexport class SmartFilterEditorContentComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  private _destroy$: Subject<void> = new Subject();\r\n  @Input() service!: ISmartFilterEditorService;\r\n\r\n  uiActionModels: UiActionModel[] = [];\r\n  expressionUiActionModels: UiActionModel[] = [];\r\n\r\n  @ViewChild('form', { read: ViewContainerRef }) vcRef?: ViewContainerRef;\r\n  formCompRef?: ComponentRef<SmartformComponent>;\r\n  smartForm?: SmartForm;\r\n\r\n  @ViewChild('simpleFilterFromChild', { read: ViewContainerRef })\r\n  simpleFilterVcRef?: ViewContainerRef;\r\n  simpleFilterRef?: ComponentRef<SmartformComponent>;\r\n\r\n  type = FilterExpressionBuilderUiModelTypeEnum;\r\n\r\n  constructor(\r\n    private layoutService: SmartformLayoutDefinitionService,\r\n    private cfService: ComponentFactoryService\r\n  ) {}\r\n\r\n  private subsrcibeSimpleFormChildrenEvents(): void {\r\n    this.simpleFilterRef!.instance.onBlurSubject!.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n      this.saveFilter();\r\n    });\r\n    this.simpleFilterRef!.instance.sophisticatedValueChange?.pipe(\r\n      takeUntil(this._destroy$)\r\n    ).subscribe((change) => {\r\n      if (change.kind === 'selection' && !change.key.includes('selectedValues')) {\r\n        this.saveFilter();\r\n      }\r\n    });\r\n  }\r\n\r\n  private subscribeEditorFormChildrenEvents(): void {\r\n    this.formCompRef?.instance!.onBlurSubject!.pipe(takeUntil(this._destroy$)).subscribe(() => {\r\n      this.save();\r\n    });\r\n\r\n    this.formCompRef!.instance!.sophisticatedValueChange?.pipe(takeUntil(this._destroy$)).subscribe(\r\n      (change: SophisticatedValueChange) => {\r\n        if (change.key === 'expressionData.currentOperation') {\r\n          this.save();\r\n        }\r\n      }\r\n    );\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n  ngAfterViewInit(): void {\r\n    this.service.modelChanged.pipe(takeUntil(this._destroy$)).subscribe(() => this.setUp());\r\n    this.service.load();\r\n  }\r\n  ngOnDestroy(): void {\r\n    this._destroy$.next();\r\n    this._destroy$.complete();\r\n  }\r\n\r\n  setupSimpleFilter(): void {\r\n    if (!this.simpleFilterVcRef) {\r\n      return;\r\n    }\r\n\r\n    let widgets: SmartFormWidget<any>[] = [];\r\n\r\n    let key: string | undefined;\r\n\r\n    let model: { [key: string]: any } = {};\r\n\r\n    this.service.model?.model?.workplaceList?.filters.forEach(\r\n      (filterExpressionField: FilterExpressionField, index: number) => {\r\n        model[index] = filterExpressionField;\r\n\r\n        if (\r\n          filterExpressionField.widgetType === FilterExpressionFieldWidgetType.TEXT_FIELD_LOOKUP\r\n        ) {\r\n          key = index + '.expressionData.operand2.selectedObjects';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              FilterExpressionFieldWidgetType.TEXT_FIELD_LOOKUP,\r\n              [],\r\n              filterExpressionField.expressionData?.operand2?.selectedObjects ?? [],\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.widgetType === 'SELECT_MULTIPLE') {\r\n          key = index + '.expressionData.operand2.selectedValues';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.selectedValues ?? [],\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.expressionData?.currentOperation === 'BETWEEN') {\r\n          key = index + '.expressionData.operand2.valueAsString';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n\r\n          key = index + '.expressionData.operand3.valueAsString';\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label3!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand3?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n\r\n        if (filterExpressionField.expressionData?.operand2) {\r\n          key = index + '.expressionData.operand2.valueAsString';\r\n\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label2!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand2?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n        if (filterExpressionField?.expressionData?.operand3) {\r\n          key = index + '.expressionData.operand3.valueAsString';\r\n\r\n          widgets.push(\r\n            this.constructFormWidget(\r\n              key,\r\n              filterExpressionField.label3!,\r\n              filterExpressionField.widgetType ?? FilterExpressionFieldWidgetType.TEXT_FIELD,\r\n\r\n              filterExpressionField.possibleValues as Value[],\r\n              filterExpressionField.expressionData?.operand3?.valueAsString ?? '',\r\n              filterExpressionField.toolbarId\r\n            )\r\n          );\r\n          return;\r\n        }\r\n      }\r\n    );\r\n\r\n    let smartForm = {\r\n      direction: SmartFormWidgetDirection.ROW,\r\n      componentModel: { data: model },\r\n      useOnValueChangeEvent: true,\r\n      useOnBlurEvent: true,\r\n      widgets,\r\n    };\r\n\r\n    if (this.simpleFilterRef?.instance) {\r\n      // we already have a SmartFormComponent, use that\r\n      let comp = this.simpleFilterRef?.instance;\r\n\r\n      if (comp.smartForm && this.compareWidgets(comp.smartForm.widgets, smartForm.widgets)) {\r\n        // there's no structural change, don't recreate SmartFormComponent\r\n        comp.smartForm.componentModel = smartForm.componentModel;\r\n        comp.constructForm();\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.simpleFilterVcRef?.clear();\r\n    this.simpleFilterRef?.destroy();\r\n\r\n    this.simpleFilterRef = this.cfService.createComponent(\r\n      this.simpleFilterVcRef!,\r\n      SmartformComponent,\r\n      new Map<string, any>([['smartForm', smartForm]])\r\n    );\r\n\r\n    this.subsrcibeSimpleFormChildrenEvents();\r\n  }\r\n\r\n  private compareWidgets(ws1: SmartFormWidget<any>[], ws2: SmartFormWidget<any>[]): boolean {\r\n    if (ws1.length !== ws2.length) {\r\n      return false;\r\n    }\r\n    for (let i = 0; i < ws1.length; i++) {\r\n      if (!this.compareWidget(ws1[i], ws2[i])) {\r\n        return false;\r\n      }\r\n    }\r\n    return true;\r\n  }\r\n\r\n  private compareWidget(w1: SmartFormWidget<any>, w2: SmartFormWidget<any>): boolean {\r\n    return SmartObjectUtility.compareByProps(w1, w2, [\r\n      'error',\r\n      'key',\r\n      'label',\r\n      'type',\r\n      // 'value', <- value will be set by componentModel.data!\r\n      'showLabel',\r\n      'valueList',\r\n      'toolbarId',\r\n    ]);\r\n  }\r\n\r\n  private extractFilterFieldFromFormModel(): void {\r\n    let simpleFilter = this.simpleFilterRef?.instance?.submitForm(false).componentModel.data;\r\n    let result: FilterExpressionField[] = [];\r\n\r\n    Object.keys(simpleFilter).forEach((key: string) => {\r\n      result.push(simpleFilter[key]);\r\n    });\r\n    this.service.model!.model!.workplaceList!.filters = result;\r\n  }\r\n\r\n  setUp(): void {\r\n    if (this.service.model?.type === this.type.SIMPLE) {\r\n      this.setupSimpleFilter();\r\n    } else {\r\n      this.constructUiActionModels();\r\n\r\n      if (this.service?.model?.selectedFieldEditor) {\r\n        this.constructForm();\r\n      } else {\r\n        this.smartForm = undefined;\r\n      }\r\n    }\r\n  }\r\n\r\n  constructUiActionModels(): void {\r\n    if (this.service.model?.possibleActions) {\r\n      this.uiActionModels = this.service.model.possibleActions.map((action: UiAction) => {\r\n        return {\r\n          serviceToUse: this.service,\r\n          uiAction: action,\r\n        };\r\n      });\r\n    }\r\n\r\n    if (this.service.model?.selectedFieldEditor?.possibleActions) {\r\n      this.expressionUiActionModels = this.service.model?.selectedFieldEditor.possibleActions.map(\r\n        (uiAction: UiAction) => {\r\n          let copiedUiAction: UiAction = {};\r\n          Object.keys(uiAction).map((key: string) => {\r\n            (copiedUiAction as any)[key] = (uiAction as any)[key];\r\n          });\r\n          copiedUiAction.params = {\r\n            field: this.service.model?.selectedField,\r\n          };\r\n          return {\r\n            serviceToUse: this.service,\r\n            uiAction: copiedUiAction,\r\n          };\r\n        }\r\n      );\r\n    }\r\n  }\r\n\r\n  constructForm(): void {\r\n    this.vcRef?.clear();\r\n    this.formCompRef?.destroy();\r\n\r\n    if (!this.vcRef) {\r\n      return;\r\n    }\r\n\r\n    let generatedWidgets: SmartFormWidget<any>[] = this.layoutService.render({\r\n      layoutDefinitions: this.service.model?.selectedFieldEditor?.layoutDef?.widgets,\r\n    });\r\n\r\n    this.smartForm = {\r\n      direction: SmartFormWidgetDirection.ROW,\r\n      useOnBlurEvent: true,\r\n      useOnValueChangeEvent: true,\r\n      componentModel: { data: this.service.model?.selectedField },\r\n      widgets: generatedWidgets,\r\n    };\r\n\r\n    this.formCompRef = this.cfService.createComponent(\r\n      this.vcRef!,\r\n      SmartformComponent,\r\n      new Map<string, any>([['smartForm', this.smartForm]])\r\n    );\r\n\r\n    this.subscribeEditorFormChildrenEvents();\r\n  }\r\n\r\n  save(): void {\r\n    this.formCompRef?.instance?.submitForm(false);\r\n    this.service.peformWidgetAction({\r\n      code: 'UPDATE_FILTER_EXPRESSION',\r\n      params: {\r\n        model: this.service.model?.selectedField,\r\n      },\r\n    });\r\n  }\r\n\r\n  remove(): void {\r\n    this.service.peformWidgetAction({\r\n      code: 'REMOVE_FILTER_EXPRESSION',\r\n      params: {\r\n        model: this.service.model?.selectedField,\r\n      },\r\n    });\r\n  }\r\n\r\n  async saveFilter(): Promise<void> {\r\n    this.extractFilterFieldFromFormModel();\r\n    await this.service.performUiActionRequest({\r\n      code: FilterExpressionBuilderApiActions.SAVE_EXPRESSION_FIELD_LIST,\r\n      params: {\r\n        model: this.service.model!,\r\n      },\r\n    });\r\n  }\r\n\r\n  private constructFormWidget(\r\n    key: string,\r\n    label: string,\r\n    widgetType: FilterExpressionFieldWidgetType,\r\n    possibleValues: Value[],\r\n    value: any,\r\n    toolbarId?: string\r\n  ): SmartFormWidget<any> {\r\n    let type: any = widgetType;\r\n\r\n    if (type === FilterExpressionFieldWidgetType.DATE) {\r\n      type = SmartFormWidgetType.DATE_PICKER;\r\n    } else if (type === FilterExpressionFieldWidgetType.DATE_TIME) {\r\n      type = SmartFormWidgetType.DATE_TIME_PICKER;\r\n    }\r\n\r\n    let widget: SmartFormWidget<any> = {\r\n      error: undefined,\r\n      key,\r\n      label,\r\n      type,\r\n      value,\r\n      showLabel: true,\r\n      valueList: possibleValues.map((value: Value) => {\r\n        return {\r\n          key: value.objectUri ? value.objectUri : value.code!,\r\n          label: value.displayValue,\r\n          type: SmartFormWidgetType.ITEM,\r\n          value: value.objectUri ? value.objectUri : value.code,\r\n        };\r\n      }),\r\n      toolbarId,\r\n    };\r\n\r\n    return widget;\r\n  }\r\n}\r\n","<div class=\"smart-filter-editor-container\" *ngIf=\"service.model\">\r\n  <h3 class=\"smart-filter-editor-title\">{{ service.model.model?.label }}</h3>\r\n\r\n  <div *ngIf=\"service.model?.type === type.SIMPLE; then simpleFilter; else complexFilter\"></div>\r\n\r\n  <ng-template #simpleFilter>\r\n    <div class=\"smart-filter-editor-expressionsContainer\">\r\n      <ng-template #simpleFilterFromChild></ng-template>\r\n      <!-- #simpleFilterFromChild [smartForm]=\"simpleFilterForm\"></smartform> -->\r\n    </div>\r\n  </ng-template>\r\n  <ng-template #complexFilter>\r\n    <div class=\"smart-filter-editor-uiActionsBar\" *ngIf=\"!service.model?.readOnly\">\r\n      <smart-ui-action-toolbar [uiActionModels]=\"uiActionModels\"></smart-ui-action-toolbar>\r\n    </div>\r\n    <div\r\n      *ngIf=\"\r\n        service?.model?.model?.workplaceList?.filters?.length;\r\n        then withParameters;\r\n        else withoutParameters\r\n      \"\r\n    ></div>\r\n    <ng-template #withoutParameters>\r\n      <div class=\"smart-filter-editor-withoutParametersContainer\">\r\n        <span class=\"mat-body\"> Még nincs megadva paraméter </span>\r\n      </div>\r\n    </ng-template>\r\n    <ng-template #withParameters>\r\n      <div class=\"smart-filter-editor-withParametersContainer\">\r\n        <div\r\n          class=\"smart-filter-editor-expressionsContainer\"\r\n          *ngIf=\"service?.model?.model?.workplaceList?.filters?.length\"\r\n        >\r\n          <app-expression-items\r\n            [items]=\"(service.model.model?.workplaceList)!.filters\"\r\n            [service]=\"service\"\r\n          ></app-expression-items>\r\n        </div>\r\n        <div class=\"smart-filter-editor-expressionEditorContainer\">\r\n          <!-- <smartform #form [smartForm]=\"smartForm\"></smartform> -->\r\n          <ng-template #form></ng-template>\r\n          <div *ngIf=\"smartForm\">\r\n            <button (click)=\"remove()\" mat-raised-button color=\"primary\">Törlés</button>\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </ng-template>\r\n  </ng-template>\r\n</div>\r\n"]}