@pepperi-addons/ngx-lib 0.3.15-beta.20 → 0.3.15-beta.21

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 (41) hide show
  1. package/bundles/pepperi-addons-ngx-lib-query-builder.umd.js +22 -11
  2. package/bundles/pepperi-addons-ngx-lib-query-builder.umd.js.map +1 -1
  3. package/bundles/pepperi-addons-ngx-lib-smart-filters.umd.js +76 -40
  4. package/bundles/pepperi-addons-ngx-lib-smart-filters.umd.js.map +1 -1
  5. package/bundles/pepperi-addons-ngx-lib.umd.js +46 -0
  6. package/bundles/pepperi-addons-ngx-lib.umd.js.map +1 -1
  7. package/core/common/pipes/date-ago.pipe.d.ts +8 -0
  8. package/core/common/pipes/public-api.d.ts +1 -0
  9. package/esm2015/core/common/pipes/date-ago.pipe.js +45 -0
  10. package/esm2015/core/common/pipes/public-api.js +2 -1
  11. package/esm2015/ngx-lib.module.js +3 -1
  12. package/esm2015/query-builder/common/model/legacy.js +1 -1
  13. package/esm2015/query-builder/common/model/operator.js +19 -8
  14. package/esm2015/query-builder/common/model/type-map.js +3 -3
  15. package/esm2015/query-builder/query-builder-item/query-builder-item.component.js +2 -2
  16. package/esm2015/smart-filters/common/model/operator.js +21 -32
  17. package/esm2015/smart-filters/common/model/type.js +1 -1
  18. package/esm2015/smart-filters/date-filter/date-filter.component.js +12 -4
  19. package/esm2015/smart-filters/multi-select-filter/multi-select-filter.component.js +44 -6
  20. package/esm2015/smart-filters/smart-filters.component.js +2 -2
  21. package/esm2015/smart-filters/text-filter/text-filter.component.js +2 -2
  22. package/fesm2015/pepperi-addons-ngx-lib-query-builder.js +21 -10
  23. package/fesm2015/pepperi-addons-ngx-lib-query-builder.js.map +1 -1
  24. package/fesm2015/pepperi-addons-ngx-lib-smart-filters.js +75 -40
  25. package/fesm2015/pepperi-addons-ngx-lib-smart-filters.js.map +1 -1
  26. package/fesm2015/pepperi-addons-ngx-lib.js +45 -1
  27. package/fesm2015/pepperi-addons-ngx-lib.js.map +1 -1
  28. package/package.json +1 -1
  29. package/pepperi-addons-ngx-lib.metadata.json +1 -1
  30. package/query-builder/common/model/legacy.d.ts +1 -1
  31. package/query-builder/common/model/type-map.d.ts +2 -2
  32. package/query-builder/pepperi-addons-ngx-lib-query-builder.metadata.json +1 -1
  33. package/smart-filters/boolean-filter/boolean-filter.component.d.ts +0 -1
  34. package/smart-filters/common/model/operator.d.ts +2 -1
  35. package/smart-filters/common/model/type.d.ts +1 -1
  36. package/smart-filters/date-filter/date-filter.component.d.ts +3 -1
  37. package/smart-filters/multi-select-filter/multi-select-filter.component.d.ts +14 -0
  38. package/smart-filters/number-filter/number-filter.component.d.ts +2 -1
  39. package/smart-filters/pepperi-addons-ngx-lib-smart-filters.metadata.json +1 -1
  40. package/smart-filters/text-filter/text-filter.component.d.ts +0 -1
  41. package/src/assets/i18n/en.ngx-lib.json +16 -1
@@ -39,7 +39,8 @@ export class PepDateFilterComponent extends BaseFilterComponent {
39
39
  const filterValue = {
40
40
  first: this.firstControl.value,
41
41
  };
42
- if (this.operator === PepSmartFilterOperators.DateRange) {
42
+ if (this.operator === PepSmartFilterOperators.DateRange ||
43
+ PepSmartFilterVariableOperators.DateRangeVariable) {
43
44
  filterValue['second'] = this.secondControl.value;
44
45
  }
45
46
  return filterValue;
@@ -62,7 +63,8 @@ export class PepDateFilterComponent extends BaseFilterComponent {
62
63
  // Override
63
64
  setFieldsStateAndValidators() {
64
65
  this.firstControl.enable();
65
- if (this.operator === PepSmartFilterOperators.DateRange) {
66
+ if (this.operator === PepSmartFilterOperators.DateRange ||
67
+ PepSmartFilterVariableOperators.DateRangeVariable) {
66
68
  this.firstControl.setValidators(Validators.required);
67
69
  this.secondControl.enable();
68
70
  this.secondControl.setValidators(Validators.required);
@@ -140,6 +142,12 @@ export class PepDateFilterComponent extends BaseFilterComponent {
140
142
  this.applyFilter();
141
143
  }
142
144
  }
145
+ onSecondVariableChanged(value) {
146
+ this.secondControl.setValue(value);
147
+ if (this.emitOnChange) {
148
+ this.applyFilter();
149
+ }
150
+ }
143
151
  onDateValueChanged() {
144
152
  if (this.emitOnChange) {
145
153
  this.applyFilter();
@@ -149,8 +157,8 @@ export class PepDateFilterComponent extends BaseFilterComponent {
149
157
  PepDateFilterComponent.decorators = [
150
158
  { type: Component, args: [{
151
159
  selector: 'pep-date-filter',
152
- template: "<div [formGroup]=\"form\" [fxLayout]=\"inline ? 'row' : 'column'\" [fxLayoutGap]=\"inline ? '.5rem' : '0rem'\">\n <ng-container>\n <pep-select [key]=\"'timeOperator'\" [value]=\"operator.id\" [label]=\"'SMART_FILTERS.CHOOSE_TIME' | translate\"\n [renderTitle]=\"renderTitle\" [emptyOption]=\"false\" [options]=\"chooseTimeOptions\"\n [fxFlex]=\"inline ? operatorWidth : null\" (valueChange)=\"onOperatorChanged($event)\">\n </pep-select>\n </ng-container>\n <div *ngIf=\"operator === PepSmartFilterOperators.InTheLast ||\n operator === PepSmartFilterAdditionalOperators.InTheLastCalendar || \n operator === PepSmartFilterOperators.NotInTheLast ||\n operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar || \n operator === PepSmartFilterOperators.DueIn ||\n operator === PepSmartFilterOperators.NotDueIn\" fxLayout=\"row\" fxLayout.xs=\"column\"\n [fxLayoutGap]=\"inline ? '.5rem' : '1rem'\" [fxFlex]=\"inline ? fieldsWidth : null\">\n <!-- Amount -->\n <pep-textbox [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.AMOUNT' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\" [type]=\"'int'\"\n [formattedValue]=\"firstControl?.value || ''\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onDateValueChanged()\">\n </pep-textbox>\n <!-- Time unit -->\n <pep-select [form]=\"form\" [key]=\"'timeUnit'\" [value]=\"operatorUnit?.id\"\n [label]=\"'SMART_FILTERS.TIME_UNIT' | translate\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [emptyOption]=\"false\" [options]=\"chooseTimeUnitOptions\" (valueChange)=\"onTimeUnitChanged($event)\">\n </pep-select>\n </div>\n <div pepRtlDirection *ngIf=\"operator === PepSmartFilterOperators.DateRange\" fxLayout=\"row\" fxLayout.xs=\"column\"\n [fxLayoutGap]=\"inline ? '.5rem' : '1rem'\" [fxFlex]=\"inline ? fieldsWidth : null\">\n <!-- Start date -->\n <pep-date [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.START_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [type]=\"field.type === 'date' ? 'date' : 'datetime'\" [value]=\"firstControl?.value || ''\"\n [maxDateValue]=\"secondControl?.value\" (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n <!-- End date -->\n <pep-date [form]=\"form\" [key]=\"secondControlKey\" [label]=\"'SMART_FILTERS.END_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [type]=\"field.type === 'date' ? 'date' : 'datetime'\" [value]=\"secondControl?.value || ''\"\n [minDateValue]=\"firstControl?.value\" (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n </div>\n <ng-container *ngIf=\"operator === PepSmartFilterOperators.On\">\n <!-- Choose a date -->\n <pep-date [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.CHOOSE_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" [type]=\"field.type === 'date' ? 'date' : 'datetime'\"\n [fxFlex]=\"inline ? fieldsWidth : null\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n </ng-container>\n <ng-container *ngIf=\"operator === PepSmartFilterVariableOperators.DateRangeVariable ||\n operator === PepSmartFilterVariableOperators.InTheLastVariable\">\n <pep-select [fxFlex]=\"inline ? fieldsWidth : null\" [key]=\"firstControlKey\" [value]=\"firstControl?.value || ''\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"variableFieldOptions\" (valueChange)=\"onVariableChanged($event)\"></pep-select>\n </ng-container>\n</div>",
160
+ template: "<div [formGroup]=\"form\" [fxLayout]=\"inline ? 'row' : 'column'\" [fxLayoutGap]=\"inline ? '.5rem' : '0rem'\">\n <ng-container>\n <pep-select [key]=\"'timeOperator'\" [value]=\"operator.id\" [label]=\"'SMART_FILTERS.CHOOSE_TIME' | translate\"\n [renderTitle]=\"renderTitle\" [emptyOption]=\"false\" [options]=\"chooseTimeOptions\"\n [fxFlex]=\"inline ? operatorWidth : null\" (valueChange)=\"onOperatorChanged($event)\">\n </pep-select>\n </ng-container>\n <div *ngIf=\"operator === PepSmartFilterOperators.InTheLast ||\n operator === PepSmartFilterAdditionalOperators.InTheLastCalendar || \n operator === PepSmartFilterOperators.NotInTheLast ||\n operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar || \n operator === PepSmartFilterOperators.DueIn ||\n operator === PepSmartFilterOperators.NotDueIn\" fxLayout=\"row\" fxLayout.xs=\"column\"\n [fxLayoutGap]=\"inline ? '.5rem' : '1rem'\" [fxFlex]=\"inline ? fieldsWidth : null\">\n <!-- Amount -->\n <pep-textbox [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.AMOUNT' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\" [type]=\"'int'\"\n [formattedValue]=\"firstControl?.value || ''\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onDateValueChanged()\">\n </pep-textbox>\n <!-- Time unit -->\n <pep-select [form]=\"form\" [key]=\"'timeUnit'\" [value]=\"operatorUnit?.id\"\n [label]=\"'SMART_FILTERS.TIME_UNIT' | translate\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [emptyOption]=\"false\" [options]=\"chooseTimeUnitOptions\" (valueChange)=\"onTimeUnitChanged($event)\">\n </pep-select>\n </div>\n <div pepRtlDirection *ngIf=\"operator === PepSmartFilterOperators.DateRange\" fxLayout=\"row\" fxLayout.xs=\"column\"\n [fxLayoutGap]=\"inline ? '.5rem' : '1rem'\" [fxFlex]=\"inline ? fieldsWidth : null\">\n <!-- Start date -->\n <pep-date [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.START_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [type]=\"field.type === 'date' ? 'date' : 'datetime'\" [value]=\"firstControl?.value || ''\"\n [maxDateValue]=\"secondControl?.value\" (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n <!-- End date -->\n <pep-date [form]=\"form\" [key]=\"secondControlKey\" [label]=\"'SMART_FILTERS.END_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" fxFlex=\"50%\"\n [type]=\"field.type === 'date' ? 'date' : 'datetime'\" [value]=\"secondControl?.value || ''\"\n [minDateValue]=\"firstControl?.value\" (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n </div>\n <ng-container *ngIf=\"operator === PepSmartFilterOperators.On\">\n <!-- Choose a date -->\n <pep-date [form]=\"form\" [key]=\"firstControlKey\" [label]=\"'SMART_FILTERS.CHOOSE_DATE' | translate\"\n [renderError]=\"false\" [renderTitle]=\"renderTitle\" [type]=\"field.type === 'date' ? 'date' : 'datetime'\"\n [fxFlex]=\"inline ? fieldsWidth : null\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onDateValueChanged()\">\n </pep-date>\n </ng-container>\n <div pepRtlDirection *ngIf=\"operator === PepSmartFilterVariableOperators.DateRangeVariable\" fxLayout=\"row\"\n fxLayout.xs=\"column\" fxLayoutGap=\".5rem\" fxFlex=\"fieldsWidth\">\n <pep-select fxFlex=\"50%\" [key]=\"firstControlKey\" [value]=\"firstControl?.value || ''\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"variableFieldOptions\" (valueChange)=\"onVariableChanged($event)\"></pep-select>\n <pep-select fxFlex=\"50%\" [key]=\"secondControlKey\" [value]=\"secondControl?.value || ''\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"variableFieldOptions\" (valueChange)=\"onSecondVariableChanged($event)\"></pep-select>\n </div>\n</div>\n",
153
161
  styles: [""]
154
162
  },] }
155
163
  ];
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-lib/smart-filters/date-filter/date-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { BaseFilterComponent } from '../common/model/base-filter-component';\nimport {\n    IPepSmartFilterOperator,\n    IPepSmartFilterOperatorUnit,\n    PepSmartFilterOperators,\n    PepSmartFilterAdditionalOperators,\n    PepSmartFilterVariableOperators,\n    PepSmartFilterOperatorUnits,\n} from '../common/model/operator';\nimport { IPepSmartFilterDataValue } from '../common/model/filter';\nimport { Validators } from '@angular/forms';\nimport { IPepOption } from '@pepperi-addons/ngx-lib';\n\n@Component({\n    selector: 'pep-date-filter',\n    templateUrl: './date-filter.component.html',\n    styleUrls: ['./date-filter.component.scss'],\n})\nexport class PepDateFilterComponent extends BaseFilterComponent implements OnInit {\n    PepSmartFilterOperators = PepSmartFilterOperators;\n    PepSmartFilterAdditionalOperators = PepSmartFilterAdditionalOperators;\n    PepSmartFilterVariableOperators = PepSmartFilterVariableOperators;\n    chooseTimeOptions: Array<IPepOption> = [];\n    chooseTimeUnitOptions: Array<IPepOption> = [];\n    operatorWidth: string;\n    fieldsWidth: string;\n\n    ngOnInit() {\n        if (this.inline) {\n            this.setControlsWidth();\n        }\n    }\n\n    // Override\n    getDefaultOperator(): IPepSmartFilterOperator {\n        return PepSmartFilterOperators.InTheLast;\n    }\n\n    // Override\n    getDefaultOperatorUnit(): IPepSmartFilterOperatorUnit {\n        if (this.operator === PepSmartFilterOperators.InTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.InTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.NotInTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.DueIn ||\n            this.operator === PepSmartFilterOperators.NotDueIn) {\n            return PepSmartFilterOperatorUnits.Months;\n        } else {\n            return undefined;\n        }\n    }\n\n    // Override\n    getFilterValue(): IPepSmartFilterDataValue {\n        const filterValue = {\n            first: this.firstControl.value,\n        };\n\n        if (this.operator === PepSmartFilterOperators.DateRange) {\n            filterValue['second'] = this.secondControl.value;\n        }\n\n        return filterValue;\n    }\n\n    // Override\n    loadOperatorsOptions() {\n        this.chooseTimeOptions = this.operators.map((operator) => {\n            return {\n                key: operator.id,\n                value: this.translate.instant(\n                    `${this.OPERATORS_TRANSLATION_PREFIX}.${operator.name}`\n                ),\n            };\n        });\n\n        this.chooseTimeUnitOptions = this.operatorUnits.map((operatorUnit) => {\n            return {\n                key: operatorUnit.id,\n                value: this.translate.instant(\n                    `${this.OPERATOR_UNITS_TRANSLATION_PREFIX}.${operatorUnit.name}`\n                ),\n            };\n        });\n    }\n\n    // Override\n    setFieldsStateAndValidators(): void {\n        this.firstControl.enable();\n\n        if (this.operator === PepSmartFilterOperators.DateRange) {\n            this.firstControl.setValidators(Validators.required);\n            this.secondControl.enable();\n            this.secondControl.setValidators(Validators.required);\n        } else if (\n            this.operator === PepSmartFilterOperators.InTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.InTheLastCalendar || \n            this.operator === PepSmartFilterOperators.NotInTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.DueIn ||\n            this.operator === PepSmartFilterOperators.NotDueIn\n        ) {\n            this.firstControl.setValidators([\n                Validators.required,\n                this.validator.numberValidator(),\n            ]);\n            this.secondControl.disable();\n        } else {\n            // Disable 'first' field.\n            if (\n                this.operator === PepSmartFilterOperators.Today ||\n                this.operator === PepSmartFilterOperators.ThisWeek ||\n                this.operator === PepSmartFilterOperators.ThisMonth ||\n                this.operator === PepSmartFilterOperators.IsEmpty ||\n                this.operator === PepSmartFilterOperators.IsNotEmpty\n            ) {\n                this.firstControl.disable();\n            }\n\n            // Default disable 'second' field.\n            super.setFieldsStateAndValidators();\n        }\n    }\n\n    setControlsWidth() {\n        if (\n            this.operator === PepSmartFilterOperators.Today ||\n            this.operator === PepSmartFilterOperators.ThisWeek ||\n            this.operator === PepSmartFilterOperators.ThisMonth ||\n            this.operator === PepSmartFilterOperators.IsEmpty ||\n            this.operator === PepSmartFilterOperators.IsNotEmpty\n        ) {\n            this.operatorWidth = 'auto';\n            this.fieldsWidth = '0%';\n        } else if (this.operator === PepSmartFilterOperators.On) {\n            this.operatorWidth = '38%';\n            this.fieldsWidth = '62%';\n        } else {\n            this.operatorWidth = '30%';\n            this.fieldsWidth = '70%';\n        }\n    }\n\n    onOperatorChanged(value: string) {\n        const operator = Object.values(this.operators).find(\n            (operator) => operator.id === value\n        );\n\n        this.operator = operator;\n        this.operatorUnit = this.getDefaultOperatorUnit();\n        if (this.inline) {\n            this.setControlsWidth();\n        }\n        if (this._parentForm) {\n            this.updateParentForm();\n        }\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onTimeUnitChanged(value: string) {\n        const operatorUnit = Object.values(PepSmartFilterOperatorUnits).find(\n            (operatorUnit) => operatorUnit.id === value\n        );\n        this.operatorUnit = operatorUnit;\n        if (this._parentForm) {\n            this.updateParentForm();\n        }\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onVariableChanged(value: any) {\n        this.firstControl.setValue(value);\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onDateValueChanged() {\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n}\n"]}
164
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-lib/smart-filters/date-filter/date-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { BaseFilterComponent } from '../common/model/base-filter-component';\nimport {\n    IPepSmartFilterOperator,\n    IPepSmartFilterOperatorUnit,\n    PepSmartFilterOperators,\n    PepSmartFilterAdditionalOperators,\n    PepSmartFilterVariableOperators,\n    PepSmartFilterOperatorUnits,\n} from '../common/model/operator';\nimport { IPepSmartFilterDataValue } from '../common/model/filter';\nimport { Validators } from '@angular/forms';\nimport { IPepOption } from '@pepperi-addons/ngx-lib';\n\n@Component({\n    selector: 'pep-date-filter',\n    templateUrl: './date-filter.component.html',\n    styleUrls: ['./date-filter.component.scss'],\n})\nexport class PepDateFilterComponent extends BaseFilterComponent implements OnInit {\n    PepSmartFilterOperators = PepSmartFilterOperators;\n    PepSmartFilterAdditionalOperators = PepSmartFilterAdditionalOperators;\n    PepSmartFilterVariableOperators = PepSmartFilterVariableOperators;\n    chooseTimeOptions: Array<IPepOption> = [];\n    chooseTimeUnitOptions: Array<IPepOption> = [];\n    operatorWidth: string;\n    fieldsWidth: string;\n\n    ngOnInit() {\n        if (this.inline) {\n            this.setControlsWidth();\n        }\n    }\n\n    // Override\n    getDefaultOperator(): IPepSmartFilterOperator {\n        return PepSmartFilterOperators.InTheLast;\n    }\n\n    // Override\n    getDefaultOperatorUnit(): IPepSmartFilterOperatorUnit {\n        if (this.operator === PepSmartFilterOperators.InTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.InTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.NotInTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.DueIn ||\n            this.operator === PepSmartFilterOperators.NotDueIn) {\n            return PepSmartFilterOperatorUnits.Months;\n        } else {\n            return undefined;\n        }\n    }\n\n    // Override\n    getFilterValue(): IPepSmartFilterDataValue {\n        const filterValue = {\n            first: this.firstControl.value,\n        };\n\n        if (this.operator === PepSmartFilterOperators.DateRange ||\n            PepSmartFilterVariableOperators.DateRangeVariable) {\n            filterValue['second'] = this.secondControl.value;\n        }\n\n        return filterValue;\n    }\n\n    // Override\n    loadOperatorsOptions() {\n        this.chooseTimeOptions = this.operators.map((operator) => {\n            return {\n                key: operator.id,\n                value: this.translate.instant(\n                    `${this.OPERATORS_TRANSLATION_PREFIX}.${operator.name}`\n                ),\n            };\n        });\n\n        this.chooseTimeUnitOptions = this.operatorUnits.map((operatorUnit) => {\n            return {\n                key: operatorUnit.id,\n                value: this.translate.instant(\n                    `${this.OPERATOR_UNITS_TRANSLATION_PREFIX}.${operatorUnit.name}`\n                ),\n            };\n        });\n    }\n\n    // Override\n    setFieldsStateAndValidators(): void {\n        this.firstControl.enable();\n\n        if (\n            this.operator === PepSmartFilterOperators.DateRange ||\n            PepSmartFilterVariableOperators.DateRangeVariable\n        ) {\n            this.firstControl.setValidators(Validators.required);\n            this.secondControl.enable();\n            this.secondControl.setValidators(Validators.required);\n        } else if (\n            this.operator === PepSmartFilterOperators.InTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.InTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.NotInTheLast ||\n            this.operator === PepSmartFilterAdditionalOperators.NotInTheLastCalendar ||\n            this.operator === PepSmartFilterOperators.DueIn ||\n            this.operator === PepSmartFilterOperators.NotDueIn\n        ) {\n            this.firstControl.setValidators([\n                Validators.required,\n                this.validator.numberValidator(),\n            ]);\n            this.secondControl.disable();\n        } else {\n            // Disable 'first' field.\n            if (\n                this.operator === PepSmartFilterOperators.Today ||\n                this.operator === PepSmartFilterOperators.ThisWeek ||\n                this.operator === PepSmartFilterOperators.ThisMonth ||\n                this.operator === PepSmartFilterOperators.IsEmpty ||\n                this.operator === PepSmartFilterOperators.IsNotEmpty\n            ) {\n                this.firstControl.disable();\n            }\n\n            // Default disable 'second' field.\n            super.setFieldsStateAndValidators();\n        }\n    }\n\n    setControlsWidth() {\n        if (\n            this.operator === PepSmartFilterOperators.Today ||\n            this.operator === PepSmartFilterOperators.ThisWeek ||\n            this.operator === PepSmartFilterOperators.ThisMonth ||\n            this.operator === PepSmartFilterOperators.IsEmpty ||\n            this.operator === PepSmartFilterOperators.IsNotEmpty\n        ) {\n            this.operatorWidth = 'auto';\n            this.fieldsWidth = '0%';\n        } else if (this.operator === PepSmartFilterOperators.On) {\n            this.operatorWidth = '38%';\n            this.fieldsWidth = '62%';\n        } else {\n            this.operatorWidth = '30%';\n            this.fieldsWidth = '70%';\n        }\n    }\n\n    onOperatorChanged(value: string) {\n        const operator = Object.values(this.operators).find(\n            (operator) => operator.id === value\n        );\n\n        this.operator = operator;\n        this.operatorUnit = this.getDefaultOperatorUnit();\n        if (this.inline) {\n            this.setControlsWidth();\n        }\n        if (this._parentForm) {\n            this.updateParentForm();\n        }\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onTimeUnitChanged(value: string) {\n        const operatorUnit = Object.values(PepSmartFilterOperatorUnits).find(\n            (operatorUnit) => operatorUnit.id === value\n        );\n        this.operatorUnit = operatorUnit;\n        if (this._parentForm) {\n            this.updateParentForm();\n        }\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onVariableChanged(value: any) {\n        this.firstControl.setValue(value);\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onSecondVariableChanged(value: any) {\n        this.secondControl.setValue(value);\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onDateValueChanged() {\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import { ViewChild, } from '@angular/core';
2
2
  import { Component } from '@angular/core';
3
3
  import { BaseFilterComponent } from '../common/model/base-filter-component';
4
- import { PepSmartFilterOperators, } from '../common/model/operator';
4
+ import { PepSmartFilterOperators, PepSmartFilterVariableOperators } from '../common/model/operator';
5
5
  import { distinctUntilChanged, map, startWith } from 'rxjs/operators';
6
6
  import { FormControl } from '@angular/forms';
7
7
  import { VirtualScrollerComponent } from 'ngx-virtual-scroller';
@@ -13,7 +13,9 @@ class PepMultiSelectFilterOption {
13
13
  export class PepMultiSelectFilterComponent extends BaseFilterComponent {
14
14
  constructor() {
15
15
  super(...arguments);
16
+ this.PepSmartFilterVariableOperators = PepSmartFilterVariableOperators;
16
17
  this.options = [];
18
+ this.chooseTypeOptions = [];
17
19
  this.searchControl = new FormControl();
18
20
  //inline props
19
21
  this.selected = '';
@@ -25,6 +27,7 @@ export class PepMultiSelectFilterComponent extends BaseFilterComponent {
25
27
  super.ngOnInit;
26
28
  if (this.inline) {
27
29
  this.inlineControlInit();
30
+ this.setControlsWidth();
28
31
  }
29
32
  else {
30
33
  this.noneInlineControlInit();
@@ -35,11 +38,11 @@ export class PepMultiSelectFilterComponent extends BaseFilterComponent {
35
38
  this.calcOptionsHeight(this.options.length);
36
39
  }
37
40
  inlineControlInit() {
38
- var _a, _b, _c, _d;
41
+ var _a, _b, _c;
39
42
  //load options from field
40
43
  this.inlineOptions = ((_b = (_a = this.field) === null || _a === void 0 ? void 0 : _a.options) === null || _b === void 0 ? void 0 : _b.length) > 0 ? this.field.options : [];
41
- // Init the selected values from first value.
42
- if (((_d = (_c = this.firstControl) === null || _c === void 0 ? void 0 : _c.value) === null || _d === void 0 ? void 0 : _d.length) > 0) {
44
+ // init the selected values from first value.
45
+ if (((_c = this.firstControl) === null || _c === void 0 ? void 0 : _c.value) && Array.isArray(this.firstControl.value)) {
43
46
  this.selected = this.firstControl.value.join(';');
44
47
  }
45
48
  }
@@ -118,6 +121,35 @@ export class PepMultiSelectFilterComponent extends BaseFilterComponent {
118
121
  }
119
122
  }
120
123
  // Override
124
+ loadOperatorsOptions() {
125
+ this.chooseTypeOptions = this.operators.map((operator) => {
126
+ return {
127
+ key: operator.id,
128
+ value: this.translate.instant(`${this.OPERATORS_TRANSLATION_PREFIX}.${operator.name}`),
129
+ };
130
+ });
131
+ }
132
+ setControlsWidth() {
133
+ var _a;
134
+ if ((_a = this.variableFieldOptions) === null || _a === void 0 ? void 0 : _a.length) {
135
+ this.operatorWidth = '38%';
136
+ this.valueWidth = '62%';
137
+ }
138
+ else {
139
+ this.valueWidth = '100%';
140
+ }
141
+ }
142
+ onOperatorChanged(value) {
143
+ const operator = Object.values(this.operators).find((operator) => operator.id === value);
144
+ this.operator = operator;
145
+ if (this._parentForm) {
146
+ this.updateParentForm();
147
+ }
148
+ if (this.emitOnChange) {
149
+ this.applyFilter();
150
+ }
151
+ }
152
+ // Override
121
153
  initFilter() {
122
154
  this.options.forEach((opt) => (opt.selected = false));
123
155
  this.searchControl.setValue('');
@@ -138,11 +170,17 @@ export class PepMultiSelectFilterComponent extends BaseFilterComponent {
138
170
  this.applyFilter();
139
171
  }
140
172
  }
173
+ onValueChanged(value) {
174
+ this.firstControl.setValue(value);
175
+ if (this.emitOnChange) {
176
+ this.applyFilter();
177
+ }
178
+ }
141
179
  }
142
180
  PepMultiSelectFilterComponent.decorators = [
143
181
  { type: Component, args: [{
144
182
  selector: 'pep-multi-select-filter',
145
- template: "<ng-container *ngIf=\"inline\">\n <pep-select [key]=\"'multi1'\" [label]=\"'Pepperi Multi Select'\" [type]=\"'multi'\" [value]=\"selected\"\n [xAlignment]=\"'left'\" [renderTitle]=\"renderTitle\" [options]='inlineOptions'\n (valueChange)=\"onMultiSelectChanged($event)\">\n </pep-select>\n</ng-container>\n<div *ngIf=\"!inline\" [formGroup]=\"form\">\n <pep-search *ngIf=\"options?.length > numberOptionsToShowSearch\" [searchControl]=\"searchControl\"\n [triggerOn]=\"'keydown'\" shrink=\"never\"></pep-search>\n <div pepRtlClass class=\"multi-select-options pep-border-top pep-border-bottom\"\n [ngClass]=\"{'with-no-search': options?.length <= numberOptionsToShowSearch}\">\n <div #optionsContainer class=\"flip-scroll\" pepRtlClass>\n <virtual-scroller #scroll [items]=\"filteredOptions$ | async\" [parentScroll]=\"optionsContainer\">\n <mat-checkbox *ngFor=\"let opt of scroll.viewPortItems\"\n class=\"pep-checkbox-container pep-input no-default-background md\" [title]=\"opt.value\"\n [checked]=\"opt.selected\" (change)=\"onOptionChange(opt, $event)\">\n <div class=\"title\">\n <span class=\"body-sm ellipsis\">{{ opt.value }}</span>\n <span *ngIf=\"opt.count\" class=\"color-dimmed body-xs ellipsis\">({{opt.count}})</span>\n </div>\n </mat-checkbox>\n <ng-container *ngIf=\"scroll.viewPortItems?.length === 0\">\n <span class=\"no-options body-sm ellipsis\" [title]=\"field.name\">\n {{ ( options.length > 0 ? \"SMART_FILTERS.NO_SEARCH_RESULTS\" : \"SMART_FILTERS.NO_OPTIONS\") |\n translate }}\n </span>\n </ng-container>\n </virtual-scroller>\n </div>\n </div>\n</div>",
183
+ template: "<ng-container *ngIf=\"inline\">\n <ng-container *ngIf=\"variableFieldOptions?.length\">\n <div fxLayout=\"row\" fxLayoutGap=\".5rem\">\n <pep-select [fxFlex]=\"operatorWidth\" [key]=\"'typeOperator'\" [value]=\"operator.id\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"chooseTypeOptions\" (valueChange)=\"onOperatorChanged($event)\">\n </pep-select>\n <ng-container *ngIf=\"operator === PepSmartFilterVariableOperators.EqualsToVariable || \n operator === PepSmartFilterVariableOperators.NotEqualsToVariable\">\n <pep-select [fxFlex]=\"valueWidth\" [key]=\"firstControlKey\" [value]=\"firstControl?.value || ''\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"variableFieldOptions\" (valueChange)=\"onValueChanged($event)\">\n </pep-select>\n </ng-container>\n <ng-container *ngIf=\"operator !== PepSmartFilterVariableOperators.EqualsToVariable && \n operator !== PepSmartFilterVariableOperators.NotEqualsToVariable\">\n <pep-select [fxFlex]=\"valueWidth\" [label]=\"'Pepperi Multi Select'\" [type]=\"'multi'\"\n [value]=\"selected\" [xAlignment]=\"'left'\" [renderTitle]=\"renderTitle\" [options]='inlineOptions'\n (valueChange)=\"onMultiSelectChanged($event)\">\n </pep-select>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"!variableFieldOptions || !variableFieldOptions.length\">\n <pep-select [label]=\"'Pepperi Multi Select'\" [type]=\"'multi'\" [value]=\"selected\"\n [xAlignment]=\"'left'\" [renderTitle]=\"renderTitle\" [options]='inlineOptions'\n (valueChange)=\"onMultiSelectChanged($event)\">\n </pep-select>\n </ng-container>\n</ng-container>\n<div *ngIf=\"!inline\" [formGroup]=\"form\">\n <pep-search *ngIf=\"options?.length > numberOptionsToShowSearch\" [searchControl]=\"searchControl\"\n [triggerOn]=\"'keydown'\" shrink=\"never\"></pep-search>\n <div pepRtlClass class=\"multi-select-options pep-border-top pep-border-bottom\"\n [ngClass]=\"{'with-no-search': options?.length <= numberOptionsToShowSearch}\">\n <div #optionsContainer class=\"flip-scroll\" pepRtlClass>\n <virtual-scroller #scroll [items]=\"filteredOptions$ | async\" [parentScroll]=\"optionsContainer\">\n <mat-checkbox *ngFor=\"let opt of scroll.viewPortItems\"\n class=\"pep-checkbox-container pep-input no-default-background md\" [title]=\"opt.value\"\n [checked]=\"opt.selected\" (change)=\"onOptionChange(opt, $event)\">\n <div class=\"title\">\n <span class=\"body-sm ellipsis\">{{ opt.value }}</span>\n <span *ngIf=\"opt.count\" class=\"color-dimmed body-xs ellipsis\">({{opt.count}})</span>\n </div>\n </mat-checkbox>\n <ng-container *ngIf=\"scroll.viewPortItems?.length === 0\">\n <span class=\"no-options body-sm ellipsis\" [title]=\"field.name\">\n {{ ( options.length > 0 ? \"SMART_FILTERS.NO_SEARCH_RESULTS\" : \"SMART_FILTERS.NO_OPTIONS\") |\n translate }}\n </span>\n </ng-container>\n </virtual-scroller>\n </div>\n </div>\n</div>",
146
184
  styles: [".multi-select-options{margin:.5rem calc(.25rem * -1) 0;margin:var(--pep-spacing-sm,.5rem) calc(var(--pep-spacing-xs, .25rem) * -1) 0}.multi-select-options.with-no-search{margin:calc(.5rem * -1) calc(.25rem * -1) 0;margin:calc(var(--pep-spacing-sm, .5rem) * -1) calc(var(--pep-spacing-xs, .25rem) * -1) 0}.multi-select-options .no-options{display:flex;padding:.5rem .75rem;padding:var(--pep-spacing-sm,.5rem) var(--pep-spacing-md,.75rem)}.multi-select-options .flip-scroll{padding:.5rem .25rem;padding:var(--pep-spacing-sm,.5rem) var(--pep-spacing-xs,.25rem);min-height:3.25rem;max-height:34.75rem;direction:rtl}.multi-select-options .flip-scroll.rtl,.multi-select-options .flip-scroll virtual-scroller{direction:ltr}.multi-select-options .flip-scroll.rtl virtual-scroller{direction:rtl}.multi-select-options .pep-checkbox-container{height:2.25rem;-webkit-padding-end:0;padding-inline-end:0}.multi-select-options .pep-checkbox-container ::ng-deep.mat-checkbox-layout{width:100%;height:100%;grid-template-columns:auto 1fr}.multi-select-options .pep-checkbox-container ::ng-deep.mat-checkbox-layout .mat-checkbox-label{align-self:center}.multi-select-options .pep-checkbox-container .title{display:grid;grid-auto-flow:column;justify-content:space-between;align-items:center;margin:0 .25rem;margin:0 var(--pep-spacing-xs,.25rem)}"]
147
185
  },] }
148
186
  ];
@@ -150,4 +188,4 @@ PepMultiSelectFilterComponent.propDecorators = {
150
188
  optionsContainer: [{ type: ViewChild, args: ['optionsContainer',] }],
151
189
  virtualScroller: [{ type: ViewChild, args: [VirtualScrollerComponent,] }]
152
190
  };
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-lib/smart-filters/multi-select-filter/multi-select-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { Component, OnInit } from '@angular/core';\nimport { BaseFilterComponent } from '../common/model/base-filter-component';\nimport {\n    IPepSmartFilterOperator,\n    PepSmartFilterOperators,\n} from '../common/model/operator';\nimport { IPepOption } from '@pepperi-addons/ngx-lib';\nimport { IPepSmartFilterDataValue } from '../common/model/filter';\nimport { IPepSmartFilterFieldOption } from '../common/model/field';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, map, startWith } from 'rxjs/operators';\nimport { FormControl } from '@angular/forms';\nimport { MatCheckboxChange } from '@angular/material/checkbox';\nimport { VirtualScrollerComponent } from 'ngx-virtual-scroller';\n\nclass PepMultiSelectFilterOption implements IPepSmartFilterFieldOption {\n    value: string;\n    count?: number;\n    selected = false;\n}\n\n@Component({\n    selector: 'pep-multi-select-filter',\n    templateUrl: './multi-select-filter.component.html',\n    styleUrls: ['./multi-select-filter.component.scss'],\n})\nexport class PepMultiSelectFilterComponent\n    extends BaseFilterComponent\n    implements OnInit, AfterViewInit {\n    options: PepMultiSelectFilterOption[] = [];\n    filteredOptions$: Observable<any>;\n    searchControl = new FormControl();\n    //inline props\n    selected = '';\n    inlineOptions: IPepOption[] = [];\n\n    @ViewChild('optionsContainer')\n    optionsContainer: ElementRef;\n\n    private readonly MAX_OPTIONS_TO_SHOW = 6.35;\n    @ViewChild(VirtualScrollerComponent)\n    private virtualScroller: VirtualScrollerComponent;\n\n    numberOptionsToShowSearch = 10;\n\n    ngOnInit() {\n        super.ngOnInit;\n\n        if (this.inline) {\n            this.inlineControlInit();\n        } else {\n            this.noneInlineControlInit();\n        }\n    }\n\n\n    ngAfterViewInit(): void {\n        // Calc for the first time.\n        this.calcOptionsHeight(this.options.length);\n    }\n\n    private inlineControlInit() {\n        //load options from field        \n        this.inlineOptions = this.field?.options?.length > 0 ? this.field.options as IPepOption[] : [];\n\n        // Init the selected values from first value.        \n        if (this.firstControl?.value?.length > 0) {\n            this.selected = this.firstControl.value.join(';');\n        }\n    }\n\n    private noneInlineControlInit() {\n        if (this.field.options?.length > 0) {\n            this.options = this.field.options.map((opt) => {\n                return { value: opt.value, count: opt.count, selected: false };\n            });\n        } else {\n            this.searchControl.disable();\n        }\n\n        // Init the selected values from first value.\n        const firstControl = this.firstControl;\n        if (firstControl.value) {\n            this.initOptionsSelectedValues(firstControl.value);\n        }\n\n        // Add subscription for the first value change to set the selected options.\n        firstControl.valueChanges\n            .pipe(this.getDestroyer(), distinctUntilChanged())\n            .subscribe((selectedValues: string[]) => {\n                this.initOptionsSelectedValues(selectedValues);\n            });\n\n        // Filter the options by the search control.\n        this.filteredOptions$ = this.searchControl.valueChanges.pipe(\n            this.getDestroyer(),\n            startWith<any>(''),\n            map((option) =>\n                typeof option === 'string' ? option : option && option.value\n            ),\n            map((value) => (value ? this.filterOptions(value) : this.options))\n        );\n\n        // Each time the filter change.\n        this.filteredOptions$.subscribe(\n            (filterdOptions: PepMultiSelectFilterOption[]) => {\n                this.calcOptionsHeight(filterdOptions.length);\n                setTimeout(() => {\n                    // 8 is the padding top of the multi-select-options\n                    this.virtualScroller.scrollToPosition(-8);\n                }, 125);\n            }\n        );\n\n    }\n\n    initOptionsSelectedValues(selectedValues: string[]): void {\n        this.options.forEach((opt) => {\n            const isValueSelected =\n                selectedValues && selectedValues.includes(opt.value);\n            opt.selected = isValueSelected;\n        });\n    }\n\n    private calcOptionsHeight(optionsCount: number) {\n        if (this.optionsContainer) {\n            const optionsToShow =\n                optionsCount > this.MAX_OPTIONS_TO_SHOW\n                    ? this.MAX_OPTIONS_TO_SHOW\n                    : optionsCount;\n            // optionsToShow * 2.25 is 1 option height + 1 is the padding top & bottom of the container.\n            const optionsHeight = optionsToShow * 2.25 + 1 + 'rem';\n\n            this.renderer.setStyle(\n                this.optionsContainer.nativeElement,\n                'height',\n                optionsHeight\n            );\n        }\n    }\n\n    private filterOptions(value: string): any[] {\n        const filterValue = value.toLowerCase();\n        return this.options.filter(\n            (opt) =>\n                opt.value &&\n                opt.value.toLowerCase().includes(filterValue.toLowerCase())\n        );\n    }\n\n    // Override\n    getDefaultOperator(): IPepSmartFilterOperator {\n        return PepSmartFilterOperators.In;\n    }\n\n    // Override\n    getFilterValue(): IPepSmartFilterDataValue {\n        if (this.inline) {\n            return {\n                first: this.firstControl.value\n            };\n        } else {\n            const selectedValues = this.options\n                .filter((opt) => opt.selected)\n                .map((opt) => opt.value);\n            const filterValue = {\n                first: selectedValues,\n            };\n\n            return selectedValues.length > 0 ? filterValue : null;\n        }\n\n    }\n\n    // Override\n    initFilter() {\n        this.options.forEach((opt) => (opt.selected = false));\n        this.searchControl.setValue('');\n    }\n\n    onOptionChange(\n        option: PepMultiSelectFilterOption,\n        event: MatCheckboxChange\n    ) {\n        option.selected = event.checked;\n        this.firstControl.setValue(\n            this.options.filter((opt) => opt.selected).map((opt) => opt.value),\n            { emitEvent: false }\n        );\n    }\n\n    onMultiSelectChanged(value: string) {\n        if (value) {\n            const selected: string[] = value.split(';');\n            this.firstControl.setValue(selected);\n        } else {\n            this.firstControl.setValue(null);\n        }\n\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n}\n"]}
191
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-lib/smart-filters/multi-select-filter/multi-select-filter.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Output,\n    ViewChild,\n} from '@angular/core';\nimport { Component, OnInit } from '@angular/core';\nimport { BaseFilterComponent } from '../common/model/base-filter-component';\nimport {\n    IPepSmartFilterOperator,\n    PepSmartFilterOperators,\n    PepSmartFilterVariableOperators\n} from '../common/model/operator';\nimport { IPepOption } from '@pepperi-addons/ngx-lib';\nimport { IPepSmartFilterDataValue } from '../common/model/filter';\nimport { IPepSmartFilterFieldOption } from '../common/model/field';\nimport { Observable } from 'rxjs';\nimport { distinctUntilChanged, map, startWith } from 'rxjs/operators';\nimport { FormControl } from '@angular/forms';\nimport { MatCheckboxChange } from '@angular/material/checkbox';\nimport { VirtualScrollerComponent } from 'ngx-virtual-scroller';\n\nclass PepMultiSelectFilterOption implements IPepSmartFilterFieldOption {\n    value: string;\n    count?: number;\n    selected = false;\n}\n\n@Component({\n    selector: 'pep-multi-select-filter',\n    templateUrl: './multi-select-filter.component.html',\n    styleUrls: ['./multi-select-filter.component.scss'],\n})\nexport class PepMultiSelectFilterComponent\n    extends BaseFilterComponent\n    implements OnInit, AfterViewInit {\n    PepSmartFilterVariableOperators = PepSmartFilterVariableOperators;\n\n    options: PepMultiSelectFilterOption[] = [];\n    filteredOptions$: Observable<any>;\n    chooseTypeOptions: Array<IPepOption> = [];\n    searchControl = new FormControl();\n    //inline props\n    selected = '';\n    inlineOptions: IPepOption[] = [];\n    operatorWidth: string;\n    valueWidth: string;\n\n    @ViewChild('optionsContainer')\n    optionsContainer: ElementRef;\n\n    private readonly MAX_OPTIONS_TO_SHOW = 6.35;\n    @ViewChild(VirtualScrollerComponent)\n    private virtualScroller: VirtualScrollerComponent;\n\n    numberOptionsToShowSearch = 10;\n\n    ngOnInit() {\n        super.ngOnInit;\n\n        if (this.inline) {\n            this.inlineControlInit();\n            this.setControlsWidth();\n        } else {\n            this.noneInlineControlInit();\n        }\n    }\n\n\n    ngAfterViewInit(): void {\n        // Calc for the first time.\n        this.calcOptionsHeight(this.options.length);\n    }\n\n    private inlineControlInit() {\n        //load options from field        \n        this.inlineOptions = this.field?.options?.length > 0 ? this.field.options as IPepOption[] : [];\n\n        // init the selected values from first value.  \n        if (this.firstControl?.value && Array.isArray(this.firstControl.value)) {\n            this.selected = this.firstControl.value.join(';');\n        }\n    }\n\n    private noneInlineControlInit() {\n        if (this.field.options?.length > 0) {\n            this.options = this.field.options.map((opt) => {\n                return { value: opt.value, count: opt.count, selected: false };\n            });\n        } else {\n            this.searchControl.disable();\n        }\n\n        // Init the selected values from first value.\n        const firstControl = this.firstControl;\n        if (firstControl.value) {\n            this.initOptionsSelectedValues(firstControl.value);\n        }\n\n        // Add subscription for the first value change to set the selected options.\n        firstControl.valueChanges\n            .pipe(this.getDestroyer(), distinctUntilChanged())\n            .subscribe((selectedValues: string[]) => {\n                this.initOptionsSelectedValues(selectedValues);\n            });\n\n        // Filter the options by the search control.\n        this.filteredOptions$ = this.searchControl.valueChanges.pipe(\n            this.getDestroyer(),\n            startWith<any>(''),\n            map((option) =>\n                typeof option === 'string' ? option : option && option.value\n            ),\n            map((value) => (value ? this.filterOptions(value) : this.options))\n        );\n\n        // Each time the filter change.\n        this.filteredOptions$.subscribe(\n            (filterdOptions: PepMultiSelectFilterOption[]) => {\n                this.calcOptionsHeight(filterdOptions.length);\n                setTimeout(() => {\n                    // 8 is the padding top of the multi-select-options\n                    this.virtualScroller.scrollToPosition(-8);\n                }, 125);\n            }\n        );\n\n    }\n\n    initOptionsSelectedValues(selectedValues: string[]): void {\n        this.options.forEach((opt) => {\n            const isValueSelected =\n                selectedValues && selectedValues.includes(opt.value);\n            opt.selected = isValueSelected;\n        });\n    }\n\n    private calcOptionsHeight(optionsCount: number) {\n        if (this.optionsContainer) {\n            const optionsToShow =\n                optionsCount > this.MAX_OPTIONS_TO_SHOW\n                    ? this.MAX_OPTIONS_TO_SHOW\n                    : optionsCount;\n            // optionsToShow * 2.25 is 1 option height + 1 is the padding top & bottom of the container.\n            const optionsHeight = optionsToShow * 2.25 + 1 + 'rem';\n\n            this.renderer.setStyle(\n                this.optionsContainer.nativeElement,\n                'height',\n                optionsHeight\n            );\n        }\n    }\n\n    private filterOptions(value: string): any[] {\n        const filterValue = value.toLowerCase();\n        return this.options.filter(\n            (opt) =>\n                opt.value &&\n                opt.value.toLowerCase().includes(filterValue.toLowerCase())\n        );\n    }\n\n    // Override\n    getDefaultOperator(): IPepSmartFilterOperator {\n        return PepSmartFilterOperators.In;\n    }\n\n    // Override\n    getFilterValue(): IPepSmartFilterDataValue {\n        if (this.inline) {\n            return {\n                first: this.firstControl.value\n            };\n        } else {\n            const selectedValues = this.options\n                .filter((opt) => opt.selected)\n                .map((opt) => opt.value);\n            const filterValue = {\n                first: selectedValues,\n            };\n\n            return selectedValues.length > 0 ? filterValue : null;\n        }\n\n    }\n\n    // Override\n    loadOperatorsOptions() {\n        this.chooseTypeOptions = this.operators.map((operator) => {\n            return {\n                key: operator.id,\n                value: this.translate.instant(\n                    `${this.OPERATORS_TRANSLATION_PREFIX}.${operator.name}`\n                ),\n            };\n        });\n    }\n\n    setControlsWidth() {\n        if (this.variableFieldOptions?.length) {\n            this.operatorWidth = '38%';\n            this.valueWidth = '62%';\n\n        } else {\n            this.valueWidth = '100%';\n        }\n    }\n\n    onOperatorChanged(value: string) {\n        const operator = Object.values(this.operators).find(\n            (operator) => operator.id === value\n        );\n        this.operator = operator;\n        if (this._parentForm) {\n            this.updateParentForm();\n        }\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n\n    // Override\n    initFilter() {\n        this.options.forEach((opt) => (opt.selected = false));\n        this.searchControl.setValue('');\n    }\n\n    onOptionChange(\n        option: PepMultiSelectFilterOption,\n        event: MatCheckboxChange\n    ) {\n        option.selected = event.checked;\n        this.firstControl.setValue(\n            this.options.filter((opt) => opt.selected).map((opt) => opt.value),\n            { emitEvent: false }\n        );\n    }\n\n    onMultiSelectChanged(value: string) {\n        if (value) {\n            const selected: string[] = value.split(';');\n            this.firstControl.setValue(selected);\n        } else {\n            this.firstControl.setValue(null);\n        }\n\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n    onValueChanged(value) {\n        this.firstControl.setValue(value);\n\n        if (this.emitOnChange) {\n            this.applyFilter();\n        }\n    }\n\n}\n"]}
@@ -110,7 +110,7 @@ export class PepSmartFiltersComponent {
110
110
  PepSmartFiltersComponent.decorators = [
111
111
  { type: Component, args: [{
112
112
  selector: 'pep-smart-filters',
113
- template: "<div class=\"smart-filters-container\" dir=\"{{ layoutService.isRtl() ? 'rtl' : 'ltr' }}\">\n <div *ngIf=\"fields?.length > 0\" class=\"title\">\n <span class=\"body-md bold\">{{ title?.length > 0 ? title : (\"SMART_FILTERS.TITLE\" | translate)}}</span>\n <mat-chip *ngIf=\"filtersDataMap.size > 0\" [selectable]=\"false\" [removable]=\"true\" (click)=\"onFiltersClear()\"\n class=\"clear-filter pep-button chip xs weak\">\n <span class=\"body-xs ellipsis \">\n {{ \"ACTIONS.CLEAR\" | translate}}\n </span>\n </mat-chip>\n </div>\n\n <mat-accordion [displayMode]=\"'flat'\" [multi]=\"true\" class=\"pep-accordion2\">\n <mat-expansion-panel *ngFor=\"let field of fields; let i = index\" hideToggle=\"true\" [expanded]=\"field.isOpen\"\n (opened)=\"toggleField(i, true)\" (closed)=\"toggleField(i, false)\">\n <mat-expansion-panel-header [collapsedHeight]=\"expansionPanelHeaderHeight\"\n [expandedHeight]=\"expansionPanelHeaderHeight\">\n <mat-panel-title class=\"pep-spacing-element-negative\">\n <div class=\"smart-filter-title-container\">\n <mat-icon class=\"pep-spacing-element\">\n <pep-icon [name]=\"field.isOpen ? 'number_minus' : 'number_plus'\"></pep-icon>\n </mat-icon>\n <span class=\"body-sm ellipsis\" [title]=\"field.name\">\n {{ field.name }}\n </span>\n <mat-chip *ngIf=\"filtersDataMap.get(field.id)\" [selectable]=\"false\" [removable]=\"true\"\n (click)=\"onFilterClear(field)\" class=\"clear-filter pep-button chip xs weak\">\n <span *ngIf=\"field.componentType === 'multi-select'\" class=\"body-xs pep-spacing-element\">\n {{ filtersDataMap.get(field.id).value?.first?.length }}\n <!-- {{ field.componentType === 'multi-select' ?\n filtersDataMap.get(field.id).value?.first?.length : 1 }} -->\n </span>\n <mat-icon>\n <pep-icon name=\"system_close\"></pep-icon>\n </mat-icon>\n </mat-chip>\n </div>\n </mat-panel-title>\n </mat-expansion-panel-header>\n <div class=\"expansion-content smart-filter-content\">\n <ng-container [ngSwitch]=\"field.componentType\">\n <ng-container *ngSwitchCase=\"'boolean'\">\n <pep-boolean-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-boolean-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'date'\">\n <pep-date-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-date-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'multi-select'\">\n <pep-multi-select-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-multi-select-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'number'\">\n <pep-number-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-number-filter>\n </ng-container>\n <!-- <div *ngSwitchDefault>\n </div> -->\n </ng-container>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n</div>",
113
+ template: "<div class=\"smart-filters-container\" dir=\"{{ layoutService.isRtl() ? 'rtl' : 'ltr' }}\">\n <div *ngIf=\"fields?.length > 0\" class=\"title\">\n <span class=\"body-md bold\">{{ title?.length > 0 ? title : (\"SMART_FILTERS.TITLE\" | translate)}}</span>\n <mat-chip *ngIf=\"filtersDataMap.size > 0\" [selectable]=\"false\" [removable]=\"true\" (click)=\"onFiltersClear()\"\n class=\"clear-filter pep-button chip xs weak\">\n <span class=\"body-xs ellipsis \">\n {{ \"ACTIONS.CLEAR\" | translate}}\n </span>\n </mat-chip>\n </div>\n\n <mat-accordion [displayMode]=\"'flat'\" [multi]=\"true\" class=\"pep-accordion2\">\n <mat-expansion-panel *ngFor=\"let field of fields; let i = index\" hideToggle=\"true\" [expanded]=\"field.isOpen\"\n (opened)=\"toggleField(i, true)\" (closed)=\"toggleField(i, false)\">\n <mat-expansion-panel-header [collapsedHeight]=\"expansionPanelHeaderHeight\"\n [expandedHeight]=\"expansionPanelHeaderHeight\">\n <mat-panel-title class=\"pep-spacing-element-negative\">\n <div class=\"smart-filter-title-container\">\n <mat-icon class=\"pep-spacing-element\">\n <pep-icon [name]=\"field.isOpen ? 'number_minus' : 'number_plus'\"></pep-icon>\n </mat-icon>\n <span class=\"body-sm ellipsis\" [title]=\"field.name\">\n {{ field.name }}\n </span>\n <mat-chip *ngIf=\"filtersDataMap.get(field.id)\" [selectable]=\"false\" [removable]=\"true\"\n (click)=\"onFilterClear(field)\" class=\"clear-filter pep-button chip xs weak\">\n <span *ngIf=\"field.componentType === 'multi-select'\" class=\"body-xs pep-spacing-element\">\n {{ filtersDataMap.get(field.id).value?.first?.length }}\n <!-- {{ field.componentType === 'multi-select' ?\n filtersDataMap.get(field.id).value?.first?.length : 1 }} -->\n </span>\n <mat-icon>\n <pep-icon name=\"system_close\"></pep-icon>\n </mat-icon>\n </mat-chip>\n </div>\n </mat-panel-title>\n </mat-expansion-panel-header>\n <div class=\"expansion-content smart-filter-content\">\n <ng-container [ngSwitch]=\"field.componentType\">\n <ng-container *ngSwitchCase=\"'boolean'\">\n <pep-boolean-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-boolean-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'date'\">\n <pep-date-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-date-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'multi-select'\">\n <pep-multi-select-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-multi-select-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'number'\">\n <pep-number-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-number-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'text'\">\n <pep-text-filter [field]=\"field\" [filter]=\"filtersDataMap.get(field.id)\"\n (filterChange)=\"onFilterChange(field, $event)\" (filterClear)=\"onFilterClear(field)\">\n </pep-text-filter>\n </ng-container>\n <!-- <div *ngSwitchDefault>\n </div> -->\n </ng-container>\n </div>\n </mat-expansion-panel>\n </mat-accordion>\n</div>",
114
114
  changeDetection: ChangeDetectionStrategy.OnPush,
115
115
  styles: [".smart-filters-container .title{height:calc(.5rem + 2.5rem);height:calc(var(--pep-top-bar-spacing-bottom, .5rem) + var(--pep-top-bar-field-height, 2.5rem));display:flex;flex-flow:wrap;align-items:center;justify-content:space-between}.smart-filters-container .title .clear-filter{display:flex;flex-direction:row;align-items:center;justify-content:center;margin:0 .25rem;margin:0 var(--pep-spacing-xs,.25rem);padding:0 .75rem;padding:0 var(--pep-spacing-md,.75rem)}.smart-filters-container .title .clear-filter:after{background-color:transparent}.smart-filters-container .smart-filter-title-container{display:grid;grid-auto-flow:column;grid-template-columns:auto 1fr auto;width:100%}.smart-filters-container .smart-filter-title-container>*{align-self:center}.smart-filters-container .smart-filter-title-container .clear-filter{display:flex;flex-direction:row;align-items:center;justify-content:center;-webkit-margin-end:.5rem;margin-inline-end:.5rem;-webkit-margin-end:var(--pep-spacing-sm,.5rem);margin-inline-end:var(--pep-spacing-sm,.5rem)}.smart-filters-container .smart-filter-title-container .clear-filter:after{background-color:transparent}.smart-filters-container .smart-filter-title-container .mat-icon pep-icon{height:.75rem;width:.75rem}", ".smart-filters-container .clear-filter.weak{background:rgba(26,26,26,.12);background:hsla(var(--pep-color-weak-h,0),var(--pep-color-weak-s,0%),var(--pep-color-weak-l,10%),.12)}.smart-filters-container .clear-filter.weak:hover{background:rgba(26,26,26,.16);background:hsla(var(--pep-color-weak-h,0),var(--pep-color-weak-s,0%),var(--pep-color-weak-l,10%),.16)}.smart-filters-container .clear-filter.weak:focus{box-shadow:0 .125rem .25rem 0 rgba(26,26,26,.08);box-shadow:var(--pep-shadow-xs-offset,0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h,0),var(--pep-color-system-primary-s,0%),var(--pep-color-system-primary-l,10%),.08);position:relative;box-shadow:0 0 0 .25rem rgba(23,102,166,.5);box-shadow:0 0 0 var(--pep-spacing-xs,.25rem) hsla(var(--pep-color-text-link-h,207),var(--pep-color-text-link-s,76%),var(--pep-color-text-link-l,37%),.5)}.smart-filters-container .clear-filter.weak:focus:not(.keep-background-on-focus){background:#fff;background:hsl(var(--pep-color-system-primary-invert-h,255),var(--pep-color-system-primary-invert-s,100%),var(--pep-color-system-primary-invert-l,100%))}.smart-filters-container .clear-filter.weak:focus:after{z-index:0;content:\"\";transition:all .25s;display:block;position:absolute;top:0;bottom:0;left:0;right:0;border-radius:inherit;border:1px solid #1a1a1a;border:1px solid hsl(var(--pep-color-weak-h,0),var(--pep-color-weak-s,0%),var(--pep-color-weak-l,10%))}.smart-filters-container .clear-filter.weak:active{box-shadow:0 .125rem .25rem 0 rgba(26,26,26,.08);box-shadow:var(--pep-shadow-xs-offset,0 .125rem .25rem 0) hsla(var(--pep-color-system-primary-h,0),var(--pep-color-system-primary-s,0%),var(--pep-color-system-primary-l,10%),.08);position:relative}.smart-filters-container .clear-filter.weak:active:not(.keep-background-on-focus){background:#fff;background:hsl(var(--pep-color-system-primary-invert-h,255),var(--pep-color-system-primary-invert-s,100%),var(--pep-color-system-primary-invert-l,100%))}.smart-filters-container .clear-filter.weak:active:after{z-index:0;content:\"\";transition:all .25s;display:block;position:absolute;top:0;bottom:0;left:0;right:0;border-radius:inherit;border:1px solid #1a1a1a;border:1px solid hsl(var(--pep-color-weak-h,0),var(--pep-color-weak-s,0%),var(--pep-color-weak-l,10%))}.smart-filters-container .clear-filter.weak:disabled:not(.ignore-disabled){box-shadow:unset;border:unset;color:rgba(26,26,26,.35)!important;color:hsla(var(--pep-color-system-primary-h,0),var(--pep-color-system-primary-s,0%),var(--pep-color-system-primary-l,10%),.35)!important;background:rgba(26,26,26,.04)!important;background:hsla(var(--pep-color-weak-h,0),var(--pep-color-weak-s,0%),var(--pep-color-weak-l,10%),.04)!important}.smart-filters-container .clear-filter.weak:disabled:not(.ignore-disabled):after{border:unset}.smart-filters-container .clear-filter.weak:disabled:not(.ignore-disabled) .svg-icon{fill:rgba(26,26,26,.35);fill:hsla(var(--pep-color-system-primary-h,0),var(--pep-color-system-primary-s,0%),var(--pep-color-system-primary-l,10%),.35)}.smart-filters-container .clear-filter.weak:disabled:not(.ignore-disabled) .svg-icon.stroke{fill:unset;stroke:rgba(26,26,26,.35);stroke:hsla(var(--pep-color-system-primary-h,0),var(--pep-color-system-primary-s,0%),var(--pep-color-system-primary-l,10%),.35)}"]
116
116
  },] }
@@ -127,4 +127,4 @@ PepSmartFiltersComponent.propDecorators = {
127
127
  filtersChange: [{ type: Output }],
128
128
  fieldToggleChange: [{ type: Output }]
129
129
  };
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filters.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/smart-filters/smart-filters.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,KAAK,EACL,uBAAuB,EACvB,MAAM,EACN,YAAY,EACZ,UAAU,GACb,MAAM,eAAe,CAAC;AAKvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAS3D,MAAM,OAAO,wBAAwB;IA2DjC,YACY,WAAuB,EACxB,aAA+B;QAD9B,gBAAW,GAAX,WAAW,CAAY;QACxB,kBAAa,GAAb,aAAa,CAAkB;QA3DjC,UAAK,GAAG,EAAE,CAAC;QAEpB,mBAAc,GAAqC,IAAI,GAAG,EAGvD,CAAC;QAEI,aAAQ,GAA0B,EAAE,CAAC;QAkBrC,YAAO,GAAgC,EAAE,CAAC;QAS1C,uBAAkB,GAAG,KAAK,CAAC;QAWnC,YAAY;QACZ,+DAA+D;QAE/D,kBAAa,GAAwC,IAAI,YAAY,EAElE,CAAC;QAGJ,sBAAiB,GAAuC,IAAI,YAAY,EAAwB,CAAC;QAEjG,+BAA0B,GAAG,GAAG,CAAC;IAK7B,CAAC;IApDL,IACI,OAAO,CAAC,KAA4B;QACpC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IACD,IAAI,OAAO;QACP,IAAI,CAAC,QAAQ,GAAG,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;YAC3C,0DAA0D;aACzD,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YACT,IAAI,GAAG,EAAE;gBACL,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;aACvC;QACL,CAAC,CAAC,CAAC;QAEP,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAGD,IACI,MAAM,CAAC,KAAkC;QACzC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAGD,IACI,iBAAiB,CAAC,KAAc;QAChC,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,4BAA4B,EAAE,CAAC;SACvC;IACL,CAAC;IACD,IAAI,iBAAiB;QACjB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACnC,CAAC;IAmBO,4BAA4B;QAChC,2DAA2D;QAC3D,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAChE,IAAI,CACP,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC9D,IAAI,CACP,CAAC;QACF,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAC9D,IAAI,CACP,CAAC;IACN,CAAC;IAEO,YAAY,CAAC,KAA4B;QAC7C,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;QAC5B,IAAI,KAAK,EAAE;YACP,KAAK,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;gBACrB,+CAA+C;gBAC/C,IAAI,YAAY,GAAG,IAAI,CAAC;gBAExB,IAAI,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;oBACvC,YAAY,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAC3B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,MAAM,CAAC,OAAO,CACd,CAAC;iBAChC;gBAED,IAAI,YAAY,EAAE;oBACd,6CAA6C;oBAC7C,IACI,MAAM,CAAC,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAClC,YAAY,CAAC,aAAa,CAC7B,EACH;wBACE,IAAI,mBAAmB,GAAG,IAAI,CAAC;wBAC/B,IAAI,MAAM,CAAC,YAAY,EAAE;4BACrB,sDAAsD;4BACtD,IACI,CAAC,MAAM,CAAC,YAAY,CAAC,aAAa,CAAC,QAAQ,CACvC,YAAY,CAAC,aAAa,CAC7B,EACH;gCACE,mBAAmB,GAAG,KAAK,CAAC;6BAC/B;yBACJ;wBAED,kBAAkB;wBAClB,IAAI,mBAAmB,EAAE;4BACrB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;yBACnD;qBACJ;iBACJ;YACL,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC1C,CAAC;IAED,WAAW,CAAC,KAAa,EAAE,MAAe;QACtC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC;QACnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,YAAY;QACR,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,CAAC;IAChC,CAAC;IAED,WAAW,CAAC,OAAe;QACvB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACxC,CAAC;IAED,iEAAiE;IACjE,cAAc;QACV,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,4DAA4D;IAC5D,aAAa,CAAC,KAA2B;QACrC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,0DAA0D;IAC1D,cAAc,CACV,KAA2B,EAC3B,UAA+B;QAE/B,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC3B,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QAC9C,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;;;YAlKJ,SAAS,SAAC;gBACP,QAAQ,EAAE,mBAAmB;gBAC7B,kwIAA6C;gBAE7C,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAClD;;;YAdG,UAAU;YAML,gBAAgB;;;oBAWpB,KAAK;sBAQL,KAAK;qBAkBL,KAAK;gCASL,KAAK;4BAYL,MAAM;gCAKN,MAAM","sourcesContent":["import {\n    Component,\n    Input,\n    ChangeDetectionStrategy,\n    Output,\n    EventEmitter,\n    ElementRef,\n} from '@angular/core';\nimport {\n    IPepSmartFilterField,\n    PepSmartFilterBaseField,\n} from './common/model/field';\nimport { PepLayoutService } from '@pepperi-addons/ngx-lib';\nimport { IPepSmartFilterData } from './common/model/filter';\n\n@Component({\n    selector: 'pep-smart-filters',\n    templateUrl: './smart-filters.component.html',\n    styleUrls: ['./smart-filters.component.scss', './smart-filters.component.theme.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PepSmartFiltersComponent {\n\n    @Input() title = '';\n\n    filtersDataMap: Map<string, IPepSmartFilterData> = new Map<\n        string,\n        IPepSmartFilterData\n    >();\n\n    private _filters: IPepSmartFilterData[] = [];\n    @Input()\n    set filters(value: IPepSmartFilterData[]) {\n        this._filters = value;\n        this.setupFilters(value);\n    }\n    get filters(): IPepSmartFilterData[] {\n        this._filters = [...this.filtersDataMap.keys()]\n            // .filter((key) => this.filtersDataMap.get(key) !== null)\n            .map((key) => {\n                if (key) {\n                    return this.filtersDataMap.get(key);\n                }\n            });\n\n        return this._filters;\n    }\n\n    private _fields: Array<IPepSmartFilterField> = [];\n    @Input()\n    set fields(value: Array<IPepSmartFilterField>) {\n        this._fields = value;\n    }\n    get fields(): Array<IPepSmartFilterField> {\n        return this._fields;\n    }\n\n    private _useAsWebComponent = false;\n    @Input()\n    set useAsWebComponent(value: boolean) {\n        if (value) {\n            this.exportFunctionsOnHostElement();\n        }\n    }\n    get useAsWebComponent(): boolean {\n        return this._useAsWebComponent;\n    }\n\n    // @Output()\n    // filtersClear: EventEmitter<void> = new EventEmitter<void>();\n    @Output()\n    filtersChange: EventEmitter<IPepSmartFilterData[]> = new EventEmitter<\n        IPepSmartFilterData[]\n    >();\n\n    @Output()\n    fieldToggleChange: EventEmitter<IPepSmartFilterField> = new EventEmitter<IPepSmartFilterField>();\n\n    expansionPanelHeaderHeight = '*';\n\n    constructor(\n        private hostElement: ElementRef,\n        public layoutService: PepLayoutService\n    ) { }\n\n    private exportFunctionsOnHostElement() {\n        // This is for web component usage for use those functions.\n        this.hostElement.nativeElement.clearFilters = this.clearFilters.bind(\n            this\n        );\n        this.hostElement.nativeElement.clearFilter = this.clearFilter.bind(\n            this\n        );\n        this.hostElement.nativeElement.toggleField = this.toggleField.bind(\n            this\n        );\n    }\n\n    private setupFilters(value: IPepSmartFilterData[]) {\n        this.filtersDataMap.clear();\n        if (value) {\n            value.forEach((filter) => {\n                // Validate before add the filter into the map.\n                let currentField = null;\n\n                if (this.fields && this.fields.length > 0) {\n                    currentField = this.fields.find(\n                        (field) => field.id === filter.fieldId\n                    ) as PepSmartFilterBaseField;\n                }\n\n                if (currentField) {\n                    // Only if the operator is from the same type\n                    if (\n                        filter.operator.componentType.includes(\n                            currentField.componentType\n                        )\n                    ) {\n                        let isOperatorUnitValid = true;\n                        if (filter.operatorUnit) {\n                            // Only if the operator unit is not from the same type\n                            if (\n                                !filter.operatorUnit.componentType.includes(\n                                    currentField.componentType\n                                )\n                            ) {\n                                isOperatorUnitValid = false;\n                            }\n                        }\n\n                        // Add the filter.\n                        if (isOperatorUnitValid) {\n                            this.filtersDataMap.set(filter.fieldId, filter);\n                        }\n                    }\n                }\n            });\n        }\n    }\n\n    private raiseFiltersChange(): void {\n        this.filtersChange.emit(this.filters);\n    }\n\n    toggleField(index: number, isOpen: boolean): void {\n        this.fields[index].isOpen = isOpen;\n        this.fieldToggleChange.emit(this.fields[index]);\n    }\n\n    clearFilters() {\n        this.filtersDataMap.clear();\n    }\n\n    clearFilter(fieldId: string) {\n        this.filtersDataMap.delete(fieldId);\n    }\n\n    // Clear all the filters and raise event that filters has change.\n    onFiltersClear() {\n        this.clearFilters();\n        this.raiseFiltersChange();\n    }\n\n    // Clear the filter and raise event that filters has change.\n    onFilterClear(field: IPepSmartFilterField) {\n        this.clearFilter(field.id);\n        this.raiseFiltersChange();\n    }\n\n    // Set the filter and raise event that filters has change.\n    onFilterChange(\n        field: IPepSmartFilterField,\n        filterData: IPepSmartFilterData\n    ) {\n        this.clearFilter(field.id);\n        this.filtersDataMap.set(field.id, filterData);\n        this.raiseFiltersChange();\n    }\n}\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smart-filters.component.js","sourceRoot":"","sources":["../../../../projects/ngx-lib/smart-filters/smart-filters.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    Input,\n    ChangeDetectionStrategy,\n    Output,\n    EventEmitter,\n    ElementRef,\n} from '@angular/core';\nimport {\n    IPepSmartFilterField,\n    PepSmartFilterBaseField,\n} from './common/model/field';\nimport { PepLayoutService } from '@pepperi-addons/ngx-lib';\nimport { IPepSmartFilterData } from './common/model/filter';\n\n@Component({\n    selector: 'pep-smart-filters',\n    templateUrl: './smart-filters.component.html',\n    styleUrls: ['./smart-filters.component.scss', './smart-filters.component.theme.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PepSmartFiltersComponent {\n\n    @Input() title = '';\n\n    filtersDataMap: Map<string, IPepSmartFilterData> = new Map<\n        string,\n        IPepSmartFilterData\n    >();\n\n    private _filters: IPepSmartFilterData[] = [];\n    @Input()\n    set filters(value: IPepSmartFilterData[]) {\n        this._filters = value;\n        this.setupFilters(value);\n    }\n    get filters(): IPepSmartFilterData[] {\n        this._filters = [...this.filtersDataMap.keys()]\n            // .filter((key) => this.filtersDataMap.get(key) !== null)\n            .map((key) => {\n                if (key) {\n                    return this.filtersDataMap.get(key);\n                }\n            });\n\n        return this._filters;\n    }\n\n    private _fields: Array<IPepSmartFilterField> = [];\n    @Input()\n    set fields(value: Array<IPepSmartFilterField>) {\n        this._fields = value;\n    }\n    get fields(): Array<IPepSmartFilterField> {\n        return this._fields;\n    }\n\n    private _useAsWebComponent = false;\n    @Input()\n    set useAsWebComponent(value: boolean) {\n        if (value) {\n            this.exportFunctionsOnHostElement();\n        }\n    }\n    get useAsWebComponent(): boolean {\n        return this._useAsWebComponent;\n    }\n\n    // @Output()\n    // filtersClear: EventEmitter<void> = new EventEmitter<void>();\n    @Output()\n    filtersChange: EventEmitter<IPepSmartFilterData[]> = new EventEmitter<\n        IPepSmartFilterData[]\n    >();\n\n    @Output()\n    fieldToggleChange: EventEmitter<IPepSmartFilterField> = new EventEmitter<IPepSmartFilterField>();\n\n    expansionPanelHeaderHeight = '*';\n\n    constructor(\n        private hostElement: ElementRef,\n        public layoutService: PepLayoutService\n    ) { }\n\n    private exportFunctionsOnHostElement() {\n        // This is for web component usage for use those functions.\n        this.hostElement.nativeElement.clearFilters = this.clearFilters.bind(\n            this\n        );\n        this.hostElement.nativeElement.clearFilter = this.clearFilter.bind(\n            this\n        );\n        this.hostElement.nativeElement.toggleField = this.toggleField.bind(\n            this\n        );\n    }\n\n    private setupFilters(value: IPepSmartFilterData[]) {\n        this.filtersDataMap.clear();\n        if (value) {\n            value.forEach((filter) => {\n                // Validate before add the filter into the map.\n                let currentField = null;\n\n                if (this.fields && this.fields.length > 0) {\n                    currentField = this.fields.find(\n                        (field) => field.id === filter.fieldId\n                    ) as PepSmartFilterBaseField;\n                }\n\n                if (currentField) {\n                    // Only if the operator is from the same type\n                    if (\n                        filter.operator.componentType.includes(\n                            currentField.componentType\n                        )\n                    ) {\n                        let isOperatorUnitValid = true;\n                        if (filter.operatorUnit) {\n                            // Only if the operator unit is not from the same type\n                            if (\n                                !filter.operatorUnit.componentType.includes(\n                                    currentField.componentType\n                                )\n                            ) {\n                                isOperatorUnitValid = false;\n                            }\n                        }\n\n                        // Add the filter.\n                        if (isOperatorUnitValid) {\n                            this.filtersDataMap.set(filter.fieldId, filter);\n                        }\n                    }\n                }\n            });\n        }\n    }\n\n    private raiseFiltersChange(): void {\n        this.filtersChange.emit(this.filters);\n    }\n\n    toggleField(index: number, isOpen: boolean): void {\n        this.fields[index].isOpen = isOpen;\n        this.fieldToggleChange.emit(this.fields[index]);\n    }\n\n    clearFilters() {\n        this.filtersDataMap.clear();\n    }\n\n    clearFilter(fieldId: string) {\n        this.filtersDataMap.delete(fieldId);\n    }\n\n    // Clear all the filters and raise event that filters has change.\n    onFiltersClear() {\n        this.clearFilters();\n        this.raiseFiltersChange();\n    }\n\n    // Clear the filter and raise event that filters has change.\n    onFilterClear(field: IPepSmartFilterField) {\n        this.clearFilter(field.id);\n        this.raiseFiltersChange();\n    }\n\n    // Set the filter and raise event that filters has change.\n    onFilterChange(\n        field: IPepSmartFilterField,\n        filterData: IPepSmartFilterData\n    ) {\n        this.clearFilter(field.id);\n        this.filtersDataMap.set(field.id, filterData);\n        this.raiseFiltersChange();\n    }\n}\n"]}
@@ -79,8 +79,8 @@ export class PepTextFilterComponent extends BaseFilterComponent {
79
79
  PepTextFilterComponent.decorators = [
80
80
  { type: Component, args: [{
81
81
  selector: 'pep-text-filter',
82
- template: "<div [formGroup]=\"form\" [fxLayout]=\"inline ? 'row' : 'column'\" [fxLayoutGap]=\"inline ? '.5rem' : '0rem'\">\n <pep-select [fxFlex]=\"inline ? operatorWidth : null\" [key]=\"'typeOperator'\" [value]=\"operator.id\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"chooseTypeOptions\" (valueChange)=\"onOperatorChanged($event)\">\n </pep-select>\n <ng-container *ngIf=\"operator !== PepSmartFilterVariableOperators.EqualsToVariable\">\n <pep-textbox [fxFlex]=\"inline ? firstControlWidth : null\" [form]=\"form\" [key]=\"firstControlKey\"\n [label]=\"'SMART_FILTERS.AMOUNT' | translate\" [renderError]=\"false\" [renderTitle]=\"renderTitle\"\n [type]=\"field.type\" [formattedValue]=\"firstControl?.value || ''\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onValueChanged()\">\n </pep-textbox>\n </ng-container>\n <ng-container *ngIf=\"operator === PepSmartFilterVariableOperators.EqualsToVariable\">\n <pep-select [fxFlex]=\"inline ? firstControlWidth : null\" [key]=\"firstControlKey\"\n [value]=\"firstControl?.value || ''\" [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\"\n [emptyOption]=\"false\" [options]=\"variableFieldOptions\" (valueChange)=\"onVariableChanged($event)\">\n </pep-select>\n </ng-container>\n</div>",
82
+ template: "<div [formGroup]=\"form\" [fxLayout]=\"inline ? 'row' : 'column'\" [fxLayoutGap]=\"inline ? '.5rem' : '0rem'\">\n <pep-select [fxFlex]=\"inline ? operatorWidth : null\" [key]=\"'typeOperator'\" [value]=\"operator.id\"\n [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\" [emptyOption]=\"false\"\n [options]=\"chooseTypeOptions\" (valueChange)=\"onOperatorChanged($event)\">\n </pep-select>\n <ng-container *ngIf=\"operator !== PepSmartFilterVariableOperators.EqualsToVariable\">\n <pep-textbox [fxFlex]=\"inline ? firstControlWidth : null\" [form]=\"form\" [key]=\"firstControlKey\"\n [label]=\"'SMART_FILTERS.VALUE' | translate\" [renderError]=\"false\" [renderTitle]=\"renderTitle\"\n [type]=\"field.type\" [formattedValue]=\"firstControl?.value || ''\" [value]=\"firstControl?.value || ''\"\n (valueChange)=\"onValueChanged()\">\n </pep-textbox>\n </ng-container>\n <ng-container *ngIf=\"operator === PepSmartFilterVariableOperators.EqualsToVariable\">\n <pep-select [fxFlex]=\"inline ? firstControlWidth : null\" [key]=\"firstControlKey\"\n [value]=\"firstControl?.value || ''\" [label]=\"'SMART_FILTERS.TYPE' | translate\" [renderTitle]=\"renderTitle\"\n [emptyOption]=\"false\" [options]=\"variableFieldOptions\" (valueChange)=\"onVariableChanged($event)\">\n </pep-select>\n </ng-container>\n</div>",
83
83
  styles: [""]
84
84
  },] }
85
85
  ];
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWxpYi9zbWFydC1maWx0ZXJzL3RleHQtZmlsdGVyL3RleHQtZmlsdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDNUUsT0FBTyxFQUVILHVCQUF1QixFQUN2QiwrQkFBK0IsRUFDbEMsTUFBTSwwQkFBMEIsQ0FBQztBQVNsQyxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsbUJBQW1CO0lBTC9EOztRQU1JLG9DQUErQixHQUFHLCtCQUErQixDQUFDO1FBQ2xFLHNCQUFpQixHQUFzQixFQUFFLENBQUM7UUFDMUMsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFDdEIsc0JBQWlCLEdBQUcsS0FBSyxDQUFDO0lBK0U5QixDQUFDO0lBN0VHLFFBQVE7UUFDSixJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVk7YUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsRUFBRSxvQkFBb0IsRUFBRSxDQUFDO2FBQ2pELFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDWixJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQztRQUN2QyxDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxXQUFXO0lBQ1gsa0JBQWtCO1FBQ2QsT0FBTyx1QkFBdUIsQ0FBQyxNQUFNLENBQUM7SUFDMUMsQ0FBQztJQUVELFdBQVc7SUFDWCxjQUFjO1FBQ1YsTUFBTSxXQUFXLEdBQUc7WUFDaEIsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSztTQUNqQyxDQUFDO1FBRUYsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLHVCQUF1QixDQUFDLFdBQVcsRUFBRTtZQUN2RCxXQUFXLENBQUMsUUFBUSxDQUFDLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUM7U0FDcEQ7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUN2QixDQUFDO0lBRUQsV0FBVztJQUNYLG9CQUFvQjtRQUNoQixJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUNyRCxPQUFPO2dCQUNILEdBQUcsRUFBRSxRQUFRLENBQUMsRUFBRTtnQkFDaEIsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUN6QixHQUFHLElBQUksQ0FBQyw0QkFBNEIsSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQzFEO2FBQ0osQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7SUFDWCwyQkFBMkI7UUFDdkIsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLHVCQUF1QixDQUFDLFdBQVcsRUFBRTtZQUN2RCxNQUFNLGVBQWUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM5QyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO2dCQUMxQixlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO2FBQ3ZFO1lBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLENBQUM7U0FDcEQ7YUFBTTtZQUNILEtBQUssQ0FBQywyQkFBMkIsRUFBRSxDQUFDO1NBQ3ZDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQWE7UUFDM0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUMvQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUUsS0FBSyxLQUFLLENBQ3RDLENBQUM7UUFDRixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUN6QixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7U0FDM0I7UUFDRCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ3RCO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQVU7UUFDeEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7SUFFRCxjQUFjO1FBQ1YsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7OztZQXRGSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGlCQUFpQjtnQkFDM0IsaTdDQUEyQzs7YUFFOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uQ2hhbmdlcywgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBCYXNlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tbW9uL21vZGVsL2Jhc2UtZmlsdGVyLWNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIElQZXBTbWFydEZpbHRlck9wZXJhdG9yLFxuICAgIFBlcFNtYXJ0RmlsdGVyT3BlcmF0b3JzLFxuICAgIFBlcFNtYXJ0RmlsdGVyVmFyaWFibGVPcGVyYXRvcnNcbn0gZnJvbSAnLi4vY29tbW9uL21vZGVsL29wZXJhdG9yJztcbmltcG9ydCB7IElQZXBPcHRpb24gfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBJUGVwU21hcnRGaWx0ZXJEYXRhVmFsdWUgfSBmcm9tICcuLi9jb21tb24vbW9kZWwvZmlsdGVyJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdwZXAtdGV4dC1maWx0ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90ZXh0LWZpbHRlci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdGV4dC1maWx0ZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgUGVwVGV4dEZpbHRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VGaWx0ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIFBlcFNtYXJ0RmlsdGVyVmFyaWFibGVPcGVyYXRvcnMgPSBQZXBTbWFydEZpbHRlclZhcmlhYmxlT3BlcmF0b3JzO1xuICAgIGNob29zZVR5cGVPcHRpb25zOiBBcnJheTxJUGVwT3B0aW9uPiA9IFtdO1xuICAgIG9wZXJhdG9yV2lkdGggPSAnMzglJztcbiAgICBmaXJzdENvbnRyb2xXaWR0aCA9ICc2MiUnO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuZmlyc3RDb250cm9sLnZhbHVlQ2hhbmdlc1xuICAgICAgICAgICAgLnBpcGUodGhpcy5nZXREZXN0cm95ZXIoKSwgZGlzdGluY3RVbnRpbENoYW5nZWQoKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk7XG4gICAgICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBPdmVycmlkZVxuICAgIGdldERlZmF1bHRPcGVyYXRvcigpOiBJUGVwU21hcnRGaWx0ZXJPcGVyYXRvciB7XG4gICAgICAgIHJldHVybiBQZXBTbWFydEZpbHRlck9wZXJhdG9ycy5FcXVhbHM7XG4gICAgfVxuXG4gICAgLy8gT3ZlcnJpZGVcbiAgICBnZXRGaWx0ZXJWYWx1ZSgpOiBJUGVwU21hcnRGaWx0ZXJEYXRhVmFsdWUge1xuICAgICAgICBjb25zdCBmaWx0ZXJWYWx1ZSA9IHtcbiAgICAgICAgICAgIGZpcnN0OiB0aGlzLmZpcnN0Q29udHJvbC52YWx1ZSxcbiAgICAgICAgfTtcblxuICAgICAgICBpZiAodGhpcy5vcGVyYXRvciA9PT0gUGVwU21hcnRGaWx0ZXJPcGVyYXRvcnMuTnVtYmVyUmFuZ2UpIHtcbiAgICAgICAgICAgIGZpbHRlclZhbHVlWydzZWNvbmQnXSA9IHRoaXMuc2Vjb25kQ29udHJvbC52YWx1ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBmaWx0ZXJWYWx1ZTtcbiAgICB9XG5cbiAgICAvLyBPdmVycmlkZVxuICAgIGxvYWRPcGVyYXRvcnNPcHRpb25zKCkge1xuICAgICAgICB0aGlzLmNob29zZVR5cGVPcHRpb25zID0gdGhpcy5vcGVyYXRvcnMubWFwKChvcGVyYXRvcikgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICBrZXk6IG9wZXJhdG9yLmlkLFxuICAgICAgICAgICAgICAgIHZhbHVlOiB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KFxuICAgICAgICAgICAgICAgICAgICBgJHt0aGlzLk9QRVJBVE9SU19UUkFOU0xBVElPTl9QUkVGSVh9LiR7b3BlcmF0b3IubmFtZX1gXG4gICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIE92ZXJyaWRlXG4gICAgc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5vcGVyYXRvciA9PT0gUGVwU21hcnRGaWx0ZXJPcGVyYXRvcnMuTnVtYmVyUmFuZ2UpIHtcbiAgICAgICAgICAgIGNvbnN0IGZpcnN0VmFsaWRhdG9ycyA9IFtWYWxpZGF0b3JzLnJlcXVpcmVkXTtcbiAgICAgICAgICAgIGlmICh0aGlzLnNlY29uZENvbnRyb2wudmFsdWUpIHtcbiAgICAgICAgICAgICAgICBmaXJzdFZhbGlkYXRvcnMucHVzaCh0aGlzLnZhbGlkYXRvci5pc0xlc3NUaGFuKHRoaXMuc2Vjb25kQ29udHJvbCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5maXJzdENvbnRyb2wuc2V0VmFsaWRhdG9ycyhmaXJzdFZhbGlkYXRvcnMpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgc3VwZXIuc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBvbk9wZXJhdG9yQ2hhbmdlZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IG9wZXJhdG9yID0gT2JqZWN0LnZhbHVlcyh0aGlzLm9wZXJhdG9ycykuZmluZChcbiAgICAgICAgICAgIChvcGVyYXRvcikgPT4gb3BlcmF0b3IuaWQgPT09IHZhbHVlXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMub3BlcmF0b3IgPSBvcGVyYXRvcjtcbiAgICAgICAgaWYgKHRoaXMuX3BhcmVudEZvcm0pIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlUGFyZW50Rm9ybSgpO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25WYXJpYWJsZUNoYW5nZWQodmFsdWU6IGFueSkge1xuICAgICAgICB0aGlzLmZpcnN0Q29udHJvbC5zZXRWYWx1ZSh2YWx1ZSk7XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25WYWx1ZUNoYW5nZWQoKSB7XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG59Il19
86
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1maWx0ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWxpYi9zbWFydC1maWx0ZXJzL3RleHQtZmlsdGVyL3RleHQtZmlsdGVyLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUM3RCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDNUMsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDNUUsT0FBTyxFQUVILHVCQUF1QixFQUN2QiwrQkFBK0IsRUFDbEMsTUFBTSwwQkFBMEIsQ0FBQztBQVNsQyxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsbUJBQW1CO0lBTC9EOztRQU1JLG9DQUErQixHQUFHLCtCQUErQixDQUFDO1FBQ2xFLHNCQUFpQixHQUFzQixFQUFFLENBQUM7UUFDMUMsa0JBQWEsR0FBRyxLQUFLLENBQUM7UUFDdEIsc0JBQWlCLEdBQUcsS0FBSyxDQUFDO0lBK0U5QixDQUFDO0lBN0VHLFFBQVE7UUFDSixJQUFJLENBQUMsWUFBWSxDQUFDLFlBQVk7YUFDekIsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLEVBQUUsRUFBRSxvQkFBb0IsRUFBRSxDQUFDO2FBQ2pELFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDWixJQUFJLENBQUMsMkJBQTJCLEVBQUUsQ0FBQztRQUN2QyxDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFRCxXQUFXO0lBQ1gsa0JBQWtCO1FBQ2QsT0FBTyx1QkFBdUIsQ0FBQyxNQUFNLENBQUM7SUFDMUMsQ0FBQztJQUVELFdBQVc7SUFDWCxjQUFjO1FBQ1YsTUFBTSxXQUFXLEdBQUc7WUFDaEIsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLENBQUMsS0FBSztTQUNqQyxDQUFDO1FBRUYsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLHVCQUF1QixDQUFDLFdBQVcsRUFBRTtZQUN2RCxXQUFXLENBQUMsUUFBUSxDQUFDLEdBQUcsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUM7U0FDcEQ7UUFFRCxPQUFPLFdBQVcsQ0FBQztJQUN2QixDQUFDO0lBRUQsV0FBVztJQUNYLG9CQUFvQjtRQUNoQixJQUFJLENBQUMsaUJBQWlCLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRTtZQUNyRCxPQUFPO2dCQUNILEdBQUcsRUFBRSxRQUFRLENBQUMsRUFBRTtnQkFDaEIsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUN6QixHQUFHLElBQUksQ0FBQyw0QkFBNEIsSUFBSSxRQUFRLENBQUMsSUFBSSxFQUFFLENBQzFEO2FBQ0osQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7SUFDWCwyQkFBMkI7UUFDdkIsSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLHVCQUF1QixDQUFDLFdBQVcsRUFBRTtZQUN2RCxNQUFNLGVBQWUsR0FBRyxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM5QyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxFQUFFO2dCQUMxQixlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO2FBQ3ZFO1lBQ0QsSUFBSSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsZUFBZSxDQUFDLENBQUM7U0FDcEQ7YUFBTTtZQUNILEtBQUssQ0FBQywyQkFBMkIsRUFBRSxDQUFDO1NBQ3ZDO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQWE7UUFDM0IsTUFBTSxRQUFRLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsSUFBSSxDQUMvQyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLEVBQUUsS0FBSyxLQUFLLENBQ3RDLENBQUM7UUFDRixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztRQUN6QixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDbEIsSUFBSSxDQUFDLGdCQUFnQixFQUFFLENBQUM7U0FDM0I7UUFDRCxJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDbkIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1NBQ3RCO0lBQ0wsQ0FBQztJQUVELGlCQUFpQixDQUFDLEtBQVU7UUFDeEIsSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbEMsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7SUFFRCxjQUFjO1FBQ1YsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ25CLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztTQUN0QjtJQUNMLENBQUM7OztZQXRGSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGlCQUFpQjtnQkFDM0IsZzdDQUEyQzs7YUFFOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uQ2hhbmdlcywgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgZGlzdGluY3RVbnRpbENoYW5nZWQgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBCYXNlRmlsdGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tbW9uL21vZGVsL2Jhc2UtZmlsdGVyLWNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIElQZXBTbWFydEZpbHRlck9wZXJhdG9yLFxuICAgIFBlcFNtYXJ0RmlsdGVyT3BlcmF0b3JzLFxuICAgIFBlcFNtYXJ0RmlsdGVyVmFyaWFibGVPcGVyYXRvcnNcbn0gZnJvbSAnLi4vY29tbW9uL21vZGVsL29wZXJhdG9yJztcbmltcG9ydCB7IElQZXBPcHRpb24gfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBJUGVwU21hcnRGaWx0ZXJEYXRhVmFsdWUgfSBmcm9tICcuLi9jb21tb24vbW9kZWwvZmlsdGVyJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdwZXAtdGV4dC1maWx0ZXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi90ZXh0LWZpbHRlci5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vdGV4dC1maWx0ZXIuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgUGVwVGV4dEZpbHRlckNvbXBvbmVudCBleHRlbmRzIEJhc2VGaWx0ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIFBlcFNtYXJ0RmlsdGVyVmFyaWFibGVPcGVyYXRvcnMgPSBQZXBTbWFydEZpbHRlclZhcmlhYmxlT3BlcmF0b3JzO1xuICAgIGNob29zZVR5cGVPcHRpb25zOiBBcnJheTxJUGVwT3B0aW9uPiA9IFtdO1xuICAgIG9wZXJhdG9yV2lkdGggPSAnMzglJztcbiAgICBmaXJzdENvbnRyb2xXaWR0aCA9ICc2MiUnO1xuXG4gICAgbmdPbkluaXQoKSB7XG4gICAgICAgIHRoaXMuZmlyc3RDb250cm9sLnZhbHVlQ2hhbmdlc1xuICAgICAgICAgICAgLnBpcGUodGhpcy5nZXREZXN0cm95ZXIoKSwgZGlzdGluY3RVbnRpbENoYW5nZWQoKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMuc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk7XG4gICAgICAgICAgICB9KTtcbiAgICB9XG5cbiAgICAvLyBPdmVycmlkZVxuICAgIGdldERlZmF1bHRPcGVyYXRvcigpOiBJUGVwU21hcnRGaWx0ZXJPcGVyYXRvciB7XG4gICAgICAgIHJldHVybiBQZXBTbWFydEZpbHRlck9wZXJhdG9ycy5FcXVhbHM7XG4gICAgfVxuXG4gICAgLy8gT3ZlcnJpZGVcbiAgICBnZXRGaWx0ZXJWYWx1ZSgpOiBJUGVwU21hcnRGaWx0ZXJEYXRhVmFsdWUge1xuICAgICAgICBjb25zdCBmaWx0ZXJWYWx1ZSA9IHtcbiAgICAgICAgICAgIGZpcnN0OiB0aGlzLmZpcnN0Q29udHJvbC52YWx1ZSxcbiAgICAgICAgfTtcblxuICAgICAgICBpZiAodGhpcy5vcGVyYXRvciA9PT0gUGVwU21hcnRGaWx0ZXJPcGVyYXRvcnMuTnVtYmVyUmFuZ2UpIHtcbiAgICAgICAgICAgIGZpbHRlclZhbHVlWydzZWNvbmQnXSA9IHRoaXMuc2Vjb25kQ29udHJvbC52YWx1ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiBmaWx0ZXJWYWx1ZTtcbiAgICB9XG5cbiAgICAvLyBPdmVycmlkZVxuICAgIGxvYWRPcGVyYXRvcnNPcHRpb25zKCkge1xuICAgICAgICB0aGlzLmNob29zZVR5cGVPcHRpb25zID0gdGhpcy5vcGVyYXRvcnMubWFwKChvcGVyYXRvcikgPT4ge1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICBrZXk6IG9wZXJhdG9yLmlkLFxuICAgICAgICAgICAgICAgIHZhbHVlOiB0aGlzLnRyYW5zbGF0ZS5pbnN0YW50KFxuICAgICAgICAgICAgICAgICAgICBgJHt0aGlzLk9QRVJBVE9SU19UUkFOU0xBVElPTl9QUkVGSVh9LiR7b3BlcmF0b3IubmFtZX1gXG4gICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIC8vIE92ZXJyaWRlXG4gICAgc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk6IHZvaWQge1xuICAgICAgICBpZiAodGhpcy5vcGVyYXRvciA9PT0gUGVwU21hcnRGaWx0ZXJPcGVyYXRvcnMuTnVtYmVyUmFuZ2UpIHtcbiAgICAgICAgICAgIGNvbnN0IGZpcnN0VmFsaWRhdG9ycyA9IFtWYWxpZGF0b3JzLnJlcXVpcmVkXTtcbiAgICAgICAgICAgIGlmICh0aGlzLnNlY29uZENvbnRyb2wudmFsdWUpIHtcbiAgICAgICAgICAgICAgICBmaXJzdFZhbGlkYXRvcnMucHVzaCh0aGlzLnZhbGlkYXRvci5pc0xlc3NUaGFuKHRoaXMuc2Vjb25kQ29udHJvbCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgdGhpcy5maXJzdENvbnRyb2wuc2V0VmFsaWRhdG9ycyhmaXJzdFZhbGlkYXRvcnMpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgc3VwZXIuc2V0RmllbGRzU3RhdGVBbmRWYWxpZGF0b3JzKCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBvbk9wZXJhdG9yQ2hhbmdlZCh2YWx1ZTogc3RyaW5nKSB7XG4gICAgICAgIGNvbnN0IG9wZXJhdG9yID0gT2JqZWN0LnZhbHVlcyh0aGlzLm9wZXJhdG9ycykuZmluZChcbiAgICAgICAgICAgIChvcGVyYXRvcikgPT4gb3BlcmF0b3IuaWQgPT09IHZhbHVlXG4gICAgICAgICk7XG4gICAgICAgIHRoaXMub3BlcmF0b3IgPSBvcGVyYXRvcjtcbiAgICAgICAgaWYgKHRoaXMuX3BhcmVudEZvcm0pIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlUGFyZW50Rm9ybSgpO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25WYXJpYWJsZUNoYW5nZWQodmFsdWU6IGFueSkge1xuICAgICAgICB0aGlzLmZpcnN0Q29udHJvbC5zZXRWYWx1ZSh2YWx1ZSk7XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgb25WYWx1ZUNoYW5nZWQoKSB7XG4gICAgICAgIGlmICh0aGlzLmVtaXRPbkNoYW5nZSkge1xuICAgICAgICAgICAgdGhpcy5hcHBseUZpbHRlcigpO1xuICAgICAgICB9XG4gICAgfVxuXG59Il19
@@ -17,7 +17,7 @@ const Equals = {
17
17
  const EqualsVariable = {
18
18
  legacy: 'IsEqualVariable',
19
19
  smartFilter: PepSmartFilterVariableOperators.EqualsToVariable,
20
- type: ['boolean', 'int', 'text']
20
+ type: ['boolean', 'int', 'text', 'multi-select']
21
21
  };
22
22
  const NotEqual = {
23
23
  legacy: 'IsNotEqual',
@@ -27,7 +27,7 @@ const NotEqual = {
27
27
  const NotEqualsVariable = {
28
28
  legacy: 'IsNotEqualVariable',
29
29
  smartFilter: PepSmartFilterVariableOperators.NotEqualsToVariable,
30
- type: ['boolean', 'int', 'text']
30
+ type: ['boolean', 'multi-select']
31
31
  };
32
32
  const LessThan = {
33
33
  legacy: '<',
@@ -82,6 +82,16 @@ const Contains = {
82
82
  smartFilter: PepSmartFilterOperators.Contains,
83
83
  type: null
84
84
  };
85
+ const BeginsWith = {
86
+ legacy: 'BeginsWith',
87
+ smartFilter: PepSmartFilterOperators.BeginsWith,
88
+ type: null
89
+ };
90
+ const EndsWith = {
91
+ legacy: 'EndsWith',
92
+ smartFilter: PepSmartFilterOperators.EndsWith,
93
+ type: null
94
+ };
85
95
  /*
86
96
  const BeginsWith: IPepQueryBuilderOperator = {
87
97
  legacy: {
@@ -136,11 +146,12 @@ const InTheLastCalendar = {
136
146
  smartFilter: PepSmartFilterAdditionalOperators.InTheLastCalendar,
137
147
  type: null
138
148
  };
139
- const InTheLastVariable = {
149
+ /*
150
+ const InTheLastVariable: IPepQueryBuilderOperator = {
140
151
  legacy: 'InTheLastVariable',
141
152
  smartFilter: PepSmartFilterVariableOperators.InTheLastVariable,
142
153
  type: null
143
- };
154
+ } */
144
155
  const NotInTheLast = {
145
156
  legacy: 'NotInTheLast',
146
157
  smartFilter: PepSmartFilterOperators.NotInTheLast,
@@ -219,12 +230,12 @@ const PepQueryBuilderOperators = [
219
230
  // GreaterThanOrEquals,
220
231
  NumberRange,
221
232
  Contains,
222
- // BeginsWith,
223
- // EndsWith,
233
+ BeginsWith,
234
+ EndsWith,
224
235
  // After,
225
236
  // Before,
226
237
  InTheLast,
227
- InTheLastVariable,
238
+ // InTheLastVariable,
228
239
  InTheLastCalendar,
229
240
  NotInTheLast,
230
241
  NotInTheLastCalendar,
@@ -280,9 +291,9 @@ class PepQueryBuilderTypeMap {
280
291
  this.map.set('MultipleStringValues', 'multi-select');
281
292
  }
282
293
  /**
283
- * Converts legacy field type to smart builder type
294
+ * Converts legacy field type to smart filter type
284
295
  * @param type legacy type
285
- * @returns smart builder field type
296
+ * @returns smart filter field type
286
297
  */
287
298
  getSmartFilterType(key) {
288
299
  const item = this.map.get(key);
@@ -734,7 +745,7 @@ class PepQueryBuilderItemComponent {
734
745
  PepQueryBuilderItemComponent.decorators = [
735
746
  { type: Component, args: [{
736
747
  selector: 'pep-query-builder-item',
737
- template: "<div fxLayout=\"column\" fxLayoutGap=\".5rem\">\n <div fxLayout=\"row\" fxLayoutGap=\".5rem\">\n <pep-select fxFlex=\"25%\" [value]=\"_selectedField?.id\" xAlignment=\"left\" [options]=\"_options\"\n [renderTitle]=\"false\" (valueChange)=\"onFieldChanged($event)\"></pep-select>\n <ng-container *ngIf=\"_selectedField?.componentType\">\n <ng-container [ngSwitch]=\"_selectedField.componentType\">\n <ng-container *ngSwitchCase=\"'text'\">\n <pep-text-filter fxFlex=\"auto\" [showActionButtons]=\"false\" [variableField]=\"variableFields?.text\"\n [field]=\"_selectedField\" [filter]=\"_filter\" [parentForm]=\"f.smart\" [emitOnChange]=\"true\"\n [inline]=\"true\" [renderTitle]=\"false\" (filterChange)=\"onFilterChanged()\">\n </pep-text-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'boolean'\">\n <pep-boolean-filter fxFlex=\"auto\" [showActionButtons]=\"false\"\n [variableField]=\"variableFields?.boolean\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\"\n [options]=\"typeConvertorService.booleans\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-boolean-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'date'\">\n <pep-date-filter fxFlex=\"auto\" [showActionButtons]=\"false\" [showAdditionalOperators]=\"true\"\n [variableField]=\"variableFields?.date\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-date-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'multi-select'\">\n <pep-multi-select-filter fxFlex=\"auto\" [showActionButtons]=\"false\" [field]=\"_selectedField\"\n [filter]=\"_filter\" [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\"\n [renderTitle]=\"false\" (filterChange)=\"onFilterChanged()\">\n </pep-multi-select-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'number'\">\n <pep-number-filter fxFlex=\"auto\" [showActionButtons]=\"false\"\n [variableField]=\"variableFields?.number\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-number-filter>\n </ng-container>\n </ng-container>\n </ng-container>\n <pep-button styleType=\"weak\" styleStateType=\"system_bin\" sizeType=\"md\" classNames=\"\" [disabled]=\"false\"\n iconName=\"system_bin\" iconPosition=\"end\" [visible]=\"true\" (buttonClick)=\"onDeleteItemClicked()\">\n </pep-button>\n </div>\n</div>",
748
+ template: "<div fxLayout=\"column\" fxLayoutGap=\".5rem\">\n <div fxLayout=\"row\" fxLayoutGap=\".5rem\">\n <pep-select fxFlex=\"25%\" [value]=\"_selectedField?.id\" xAlignment=\"left\" [options]=\"_options\"\n [renderTitle]=\"false\" (valueChange)=\"onFieldChanged($event)\"></pep-select>\n <ng-container *ngIf=\"_selectedField?.componentType\">\n <ng-container [ngSwitch]=\"_selectedField.componentType\">\n <ng-container *ngSwitchCase=\"'text'\">\n <pep-text-filter fxFlex=\"auto\" [showActionButtons]=\"false\" [variableField]=\"variableFields?.text\"\n [field]=\"_selectedField\" [filter]=\"_filter\" [parentForm]=\"f.smart\" [emitOnChange]=\"true\"\n [inline]=\"true\" [renderTitle]=\"false\" (filterChange)=\"onFilterChanged()\">\n </pep-text-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'boolean'\">\n <pep-boolean-filter fxFlex=\"auto\" [showActionButtons]=\"false\"\n [variableField]=\"variableFields?.boolean\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\"\n [options]=\"typeConvertorService.booleans\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-boolean-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'date'\">\n <pep-date-filter fxFlex=\"auto\" [showActionButtons]=\"false\" [showAdditionalOperators]=\"true\"\n [variableField]=\"variableFields?.date\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-date-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'multi-select'\">\n <pep-multi-select-filter fxFlex=\"auto\" [showActionButtons]=\"false\"\n [variableField]=\"variableFields?.['multi-select']\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-multi-select-filter>\n </ng-container>\n <ng-container *ngSwitchCase=\"'number'\">\n <pep-number-filter fxFlex=\"auto\" [showActionButtons]=\"false\"\n [variableField]=\"variableFields?.number\" [field]=\"_selectedField\" [filter]=\"_filter\"\n [parentForm]=\"f.smart\" [emitOnChange]=\"true\" [inline]=\"true\" [renderTitle]=\"false\"\n (filterChange)=\"onFilterChanged()\">\n </pep-number-filter>\n </ng-container>\n </ng-container>\n </ng-container>\n <pep-button styleType=\"weak\" styleStateType=\"system_bin\" sizeType=\"md\" classNames=\"\" [disabled]=\"false\"\n iconName=\"system_bin\" iconPosition=\"end\" [visible]=\"true\" (buttonClick)=\"onDeleteItemClicked()\">\n </pep-button>\n </div>\n</div>",
738
749
  styles: ["::ng-deep .pep-field-no-spacing{min-height:0!important;margin-bottom:0!important}"]
739
750
  },] }
740
751
  ];