@recursyve/nice-data-filter-kit 12.1.27 → 13.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_index.scss +1 -7
- package/{esm2015/lib/api/dto/saved-reports.dto.js → esm2020/lib/api/dto/saved-reports.dto.mjs} +0 -0
- package/esm2020/lib/api/filter.api.mjs +51 -0
- package/{esm2015/lib/api/models/saved-reports.model.js → esm2020/lib/api/models/saved-reports.model.mjs} +0 -0
- package/{esm2015/lib/api/public-api.js → esm2020/lib/api/public-api.mjs} +0 -0
- package/esm2020/lib/api/saved-report.api.mjs +48 -0
- package/esm2020/lib/components/base-list/base-list.component.mjs +288 -0
- package/{esm2015/lib/components/base-list/base-list.constant.js → esm2020/lib/components/base-list/base-list.constant.mjs} +0 -0
- package/esm2020/lib/components/base-list/base-list.module.mjs +171 -0
- package/{esm2015/lib/components/base-list/directives/base-list-buttons.directive.js → esm2020/lib/components/base-list/directives/base-list-buttons.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-cards.directive.js → esm2020/lib/components/base-list/directives/base-list-cards.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-custom-content.directive.js → esm2020/lib/components/base-list/directives/base-list-custom-content.directive.mjs} +3 -3
- package/esm2020/lib/components/base-list/directives/base-list-directives.module.mjs +45 -0
- package/esm2020/lib/components/base-list/directives/base-list-filters.directive.mjs +14 -0
- package/{esm2015/lib/components/base-list/directives/base-list-table.directive.js → esm2020/lib/components/base-list/directives/base-list-table.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/directives/base-list-title.directive.js → esm2020/lib/components/base-list/directives/base-list-title.directive.mjs} +3 -3
- package/{esm2015/lib/components/base-list/models/columns.model.js → esm2020/lib/components/base-list/models/columns.model.mjs} +0 -0
- package/{esm2015/lib/components/base-list/models/export.model.js → esm2020/lib/components/base-list/models/export.model.mjs} +0 -0
- package/esm2020/lib/components/base-list/models/layout.model.mjs +149 -0
- package/esm2020/lib/components/base-list/providers/base-filter.service.mjs +34 -0
- package/{esm2015/lib/components/base-list/providers/base-list-saved-report.service.js → esm2020/lib/components/base-list/providers/base-list-saved-report.service.mjs} +3 -3
- package/esm2020/lib/components/base-list/public-api.mjs +17 -0
- package/esm2020/lib/components/base-list/store/base-list.query.mjs +35 -0
- package/esm2020/lib/components/base-list/store/base-list.service.mjs +341 -0
- package/esm2020/lib/components/base-list/store/base-list.store.mjs +81 -0
- package/{esm2015/lib/components/multi-state-list/models/list-states.model.js → esm2020/lib/components/multi-state-list/models/list-states.model.mjs} +0 -0
- package/esm2020/lib/components/multi-state-list/multi-state-list.component.mjs +71 -0
- package/{esm2015/lib/components/multi-state-list/multi-state-list.constant.js → esm2020/lib/components/multi-state-list/multi-state-list.constant.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/multi-state-list.module.js → esm2020/lib/components/multi-state-list/multi-state-list.module.mjs} +6 -14
- package/{esm2015/lib/components/multi-state-list/providers/multi-state-filter.service.js → esm2020/lib/components/multi-state-list/providers/multi-state-filter.service.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/public-api.js → esm2020/lib/components/multi-state-list/public-api.mjs} +0 -0
- package/{esm2015/lib/components/multi-state-list/store/multi-state-list.query.js → esm2020/lib/components/multi-state-list/store/multi-state-list.query.mjs} +3 -3
- package/{esm2015/lib/components/multi-state-list/store/multi-state-list.service.js → esm2020/lib/components/multi-state-list/store/multi-state-list.service.mjs} +5 -6
- package/esm2020/lib/components/multi-state-list/store/multi-state-list.store.mjs +24 -0
- package/{esm2015/lib/components/public-api.js → esm2020/lib/components/public-api.mjs} +0 -0
- package/esm2020/lib/components/query-builder/filter-selection/filter-selection.component.mjs +41 -0
- package/{esm2015/lib/components/query-builder/pipes/filter-group-icon.pipe.js → esm2020/lib/components/query-builder/pipes/filter-group-icon.pipe.mjs} +3 -3
- package/{esm2015/lib/components/query-builder/providers/filter-group.service.js → esm2020/lib/components/query-builder/providers/filter-group.service.mjs} +0 -0
- package/{esm2015/lib/components/query-builder/public-api.js → esm2020/lib/components/query-builder/public-api.mjs} +0 -0
- package/{esm2015/lib/components/query-builder/query-builder-trigger.directive.js → esm2020/lib/components/query-builder/query-builder-trigger.directive.mjs} +3 -3
- package/esm2020/lib/components/query-builder/query-builder.component.mjs +93 -0
- package/{esm2015/lib/components/query-builder/query-builder.form.js → esm2020/lib/components/query-builder/query-builder.form.mjs} +0 -0
- package/esm2020/lib/components/query-builder/query-builder.module.mjs +116 -0
- package/esm2020/lib/components/query-builder/rule/components/date/date-filter.component.mjs +29 -0
- package/{esm2015/lib/components/query-builder/rule/components/filter.component.js → esm2020/lib/components/query-builder/rule/components/filter.component.mjs} +3 -3
- package/esm2020/lib/components/query-builder/rule/components/number/number-filter.component.mjs +28 -0
- package/esm2020/lib/components/query-builder/rule/components/radio/radio-filter.component.mjs +30 -0
- package/esm2020/lib/components/query-builder/rule/components/select/select-filter.component.mjs +83 -0
- package/esm2020/lib/components/query-builder/rule/components/text/text-filter.component.mjs +31 -0
- package/esm2020/lib/components/query-builder/rule/rule.component.mjs +78 -0
- package/{esm2015/lib/components/query-builder/utils/qb-filter.utils.js → esm2020/lib/components/query-builder/utils/qb-filter.utils.mjs} +23 -9
- package/{esm2015/lib/models/filter.model.js → esm2020/lib/models/filter.model.mjs} +0 -0
- package/{esm2015/lib/models/public-api.js → esm2020/lib/models/public-api.mjs} +0 -0
- package/{esm2015/lib/models/query.model.js → esm2020/lib/models/query.model.mjs} +0 -0
- package/{esm2015/lib/utils/date.adapter.js → esm2020/lib/utils/date.adapter.mjs} +3 -3
- package/esm2020/lib/utils/filter.utils.mjs +40 -0
- package/{esm2015/lib/utils/public-api.js → esm2020/lib/utils/public-api.mjs} +0 -0
- package/{esm2015/lib/utils/query-params.utils.js → esm2020/lib/utils/query-params.utils.mjs} +0 -0
- package/{esm2015/lib/utils/string.utils.js → esm2020/lib/utils/string.utils.mjs} +0 -0
- package/{esm2015/public-api.js → esm2020/public-api.mjs} +0 -0
- package/{esm2015/recursyve-nice-data-filter-kit.js → esm2020/recursyve-nice-data-filter-kit.mjs} +0 -0
- package/fesm2015/recursyve-nice-data-filter-kit.mjs +2448 -0
- package/fesm2015/recursyve-nice-data-filter-kit.mjs.map +1 -0
- package/fesm2020/recursyve-nice-data-filter-kit.mjs +2446 -0
- package/fesm2020/recursyve-nice-data-filter-kit.mjs.map +1 -0
- package/lib/components/base-list/base-list.component.d.ts +3 -1
- package/lib/components/base-list/base-list.module.d.ts +15 -16
- package/lib/components/base-list/directives/base-list-directives.module.d.ts +2 -1
- package/lib/components/base-list/directives/base-list-filters.directive.d.ts +8 -0
- package/lib/components/base-list/models/layout.model.d.ts +1 -5
- package/lib/components/base-list/public-api.d.ts +1 -0
- package/lib/components/base-list/store/base-list.service.d.ts +2 -0
- package/lib/components/multi-state-list/multi-state-list.module.d.ts +15 -16
- package/lib/components/query-builder/query-builder.module.d.ts +10 -11
- package/package.json +30 -16
- package/src/lib/components/base-list/base-list.theme.scss +5 -5
- package/src/lib/components/query-builder/rule/rule.theme.scss +1 -1
- package/src/lib/nice-data-filter.theme.scss +7 -0
- package/bundles/recursyve-nice-data-filter-kit.umd.js +0 -3140
- package/bundles/recursyve-nice-data-filter-kit.umd.js.map +0 -1
- package/esm2015/lib/api/filter.api.js +0 -52
- package/esm2015/lib/api/saved-report.api.js +0 -49
- package/esm2015/lib/components/base-list/base-list.component.js +0 -292
- package/esm2015/lib/components/base-list/base-list.module.js +0 -180
- package/esm2015/lib/components/base-list/directives/base-list-directives.module.js +0 -40
- package/esm2015/lib/components/base-list/models/layout.model.js +0 -155
- package/esm2015/lib/components/base-list/providers/base-filter.service.js +0 -40
- package/esm2015/lib/components/base-list/public-api.js +0 -16
- package/esm2015/lib/components/base-list/store/base-list.query.js +0 -35
- package/esm2015/lib/components/base-list/store/base-list.service.js +0 -321
- package/esm2015/lib/components/base-list/store/base-list.store.js +0 -78
- package/esm2015/lib/components/multi-state-list/multi-state-list.component.js +0 -75
- package/esm2015/lib/components/multi-state-list/store/multi-state-list.store.js +0 -22
- package/esm2015/lib/components/query-builder/filter-selection/filter-selection.component.js +0 -48
- package/esm2015/lib/components/query-builder/query-builder.component.js +0 -100
- package/esm2015/lib/components/query-builder/query-builder.module.js +0 -120
- package/esm2015/lib/components/query-builder/rule/components/date/date-filter.component.js +0 -35
- package/esm2015/lib/components/query-builder/rule/components/number/number-filter.component.js +0 -34
- package/esm2015/lib/components/query-builder/rule/components/radio/radio-filter.component.js +0 -36
- package/esm2015/lib/components/query-builder/rule/components/select/select-filter.component.js +0 -94
- package/esm2015/lib/components/query-builder/rule/components/text/text-filter.component.js +0 -37
- package/esm2015/lib/components/query-builder/rule/rule.component.js +0 -86
- package/esm2015/lib/utils/filter.utils.js +0 -41
- package/fesm2015/recursyve-nice-data-filter-kit.js +0 -2481
- package/fesm2015/recursyve-nice-data-filter-kit.js.map +0 -1
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewEncapsulation } from "@angular/core";
|
|
2
|
+
import { FormGroupName } from "@angular/forms";
|
|
3
|
+
import { QBFilterUtils } from "../utils/qb-filter.utils";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@angular/material/button";
|
|
7
|
+
import * as i3 from "@angular/material/icon";
|
|
8
|
+
import * as i4 from "@angular/material/form-field";
|
|
9
|
+
import * as i5 from "@angular/material/select";
|
|
10
|
+
import * as i6 from "@angular/material/core";
|
|
11
|
+
import * as i7 from "./components/text/text-filter.component";
|
|
12
|
+
import * as i8 from "./components/number/number-filter.component";
|
|
13
|
+
import * as i9 from "./components/radio/radio-filter.component";
|
|
14
|
+
import * as i10 from "./components/select/select-filter.component";
|
|
15
|
+
import * as i11 from "./components/date/date-filter.component";
|
|
16
|
+
import * as i12 from "../query-builder-trigger.directive";
|
|
17
|
+
import * as i13 from "@angular/common";
|
|
18
|
+
import * as i14 from "@ngx-translate/core";
|
|
19
|
+
export class RuleComponent {
|
|
20
|
+
constructor(formGroupName) {
|
|
21
|
+
this.formGroupName = formGroupName;
|
|
22
|
+
this.remove = new EventEmitter();
|
|
23
|
+
}
|
|
24
|
+
get filterConfig() {
|
|
25
|
+
const rule = this.rules.at(0).value;
|
|
26
|
+
return this.filterConfigs?.find(f => f.id === rule.id);
|
|
27
|
+
}
|
|
28
|
+
get isSingleInput() {
|
|
29
|
+
return !this.isDoubleInput && !this.isNoInput;
|
|
30
|
+
}
|
|
31
|
+
get isDoubleInput() {
|
|
32
|
+
return QBFilterUtils.isDoubleInput(this.filterOperator);
|
|
33
|
+
}
|
|
34
|
+
get isNoInput() {
|
|
35
|
+
return QBFilterUtils.isNoInput(this.filterOperator);
|
|
36
|
+
}
|
|
37
|
+
ngOnInit() {
|
|
38
|
+
this.formGroup = this.formGroupName.control;
|
|
39
|
+
this.rules = this.formGroup.get("rules");
|
|
40
|
+
this.filterOperator = this.rules.at(0).value.operation;
|
|
41
|
+
}
|
|
42
|
+
onUpdateFilterConfig(config) {
|
|
43
|
+
const rule = QBFilterUtils.createRule(config);
|
|
44
|
+
this.rules.patchValue([rule]);
|
|
45
|
+
this.filterOperator = rule.operation;
|
|
46
|
+
}
|
|
47
|
+
onClickOr() {
|
|
48
|
+
this.rules.push(QBFilterUtils.createRule(this.filterConfig, this.filterOperator));
|
|
49
|
+
}
|
|
50
|
+
onUpdateFilterOperator(operator) {
|
|
51
|
+
this.filterOperator = operator;
|
|
52
|
+
for (const rule of this.rules.controls) {
|
|
53
|
+
rule.get("operation")?.patchValue(this.filterOperator);
|
|
54
|
+
if (this.isDoubleInput) {
|
|
55
|
+
rule.get("value")?.patchValue([rule.value.value, rule.value.value]);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
onClickDelete(index) {
|
|
60
|
+
if (this.rules.length > 1) {
|
|
61
|
+
this.rules.removeAt(index);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
this.remove.emit();
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
RuleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: RuleComponent, deps: [{ token: i1.FormGroupName }], target: i0.ɵɵFactoryTarget.Component });
|
|
69
|
+
RuleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.0.3", type: RuleComponent, selector: "nice-rule", inputs: { filterConfigs: "filterConfigs" }, outputs: { remove: "remove" }, ngImport: i0, template: "<div class=\"flex flex-row justify-start items-center gap-2.5\">\n <button\n class=\"select-filter\"\n mat-raised-button\n color=\"accent\"\n niceQueryBuilderTrigger\n [queryBuilderFilters]=\"filterConfigs\"\n (queryBuilderFilterSelected)=\"onUpdateFilterConfig($event)\"\n >\n <div class=\"flex flex-row justify-between items-center\">\n <div class=\"config-name\">{{ filterConfig?.name }}</div>\n <mat-icon class=\"config-name-icon\">arrow_drop_down</mat-icon>\n </div>\n </button>\n <div class=\"flex flex-col md:flex-row flex-auto justify-start items-center gap-2.5\">\n <mat-form-field class=\"w-90-p md:auto\" ngClass.lt-md=\"w-90-p\" fxFlex=\"0 0 188px\">\n <mat-select\n class=\"rule-operator\"\n [ngModel]=\"filterOperator\"\n (ngModelChange)=\"onUpdateFilterOperator($event)\"\n >\n <mat-option *ngFor=\"let operator of filterConfig?.operators\" [value]=\"operator.id\">\n {{ operator?.name }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n <div class=\"flex flex-col md:flex-row flex-wrap\" [formGroup]=\"formGroup\">\n <ng-container formArrayName=\"rules\">\n <div\n class=\"rule-container flex flex-col md:flex-row flex-full justify-start items-center gap-2.5\"\n [class.is-double-input]=\"!!isDoubleInput\"\n [formGroupName]=\"i\"\n *ngFor=\"let rule of rules.controls; let i = index\"\n >\n <ng-container *ngIf=\"isSingleInput\">\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter *ngSwitchCase=\"'text'\" class=\"flex flex-auto\" formControlName=\"value\" [filterConfig]=\"filterConfig\"></nice-text-filter>\n <nice-number-filter *ngSwitchCase=\"'number'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n ></nice-select-filter>\n <nice-date-filter *ngSwitchCase=\"'date'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-date-filter>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isDoubleInput\">\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter\n *ngSwitchCase=\"'text'\"\n [valueIndex]=\"0\"\n [filterConfig]=\"filterConfig\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-text-filter>\n <nice-number-filter\n *ngSwitchCase=\"'number'\"\n [valueIndex]=\"0\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"secondValue\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"0\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"0\"\n ></nice-select-filter>\n <nice-date-filter\n *ngSwitchCase=\"'date'\"\n [valueIndex]=\"0\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-date-filter>\n </ng-container>\n <h3 class=\"aligned-text\">\n {{ \"components.query_builder.rule.conditions.and\" | translate }}\n </h3>\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter\n *ngSwitchCase=\"'text'\"\n [valueIndex]=\"1\"\n [filterConfig]=\"filterConfig\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-text-filter>\n <nice-number-filter\n *ngSwitchCase=\"'number'\"\n [valueIndex]=\"1\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"1\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"1\"\n ></nice-select-filter>\n <nice-date-filter\n *ngSwitchCase=\"'date'\"\n [valueIndex]=\"1\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-date-filter>\n </ng-container>\n </ng-container>\n <div class=\"flex flex-row gap-2\">\n <button mat-mini-fab class=\"or-button aligned-button\" (click)=\"onClickOr()\">\n {{ \"components.query_builder.rule.conditions.or\" | translate }}\n </button>\n <button class=\"aligned-button\" mat-icon-button color=\"warn\" (click)=\"onClickDelete(i)\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["nice-rule{background:transparent}nice-rule .select-filter{@apply flex flex-full;height:36px;max-width:150px}nice-rule .config-name{@apply flex flex-full flex-grow-0 truncate;max-width:90px}nice-rule .config-name-icon{@apply flex flex-full;max-width:24px}nice-rule .rule-operator{@apply flex flex-full;max-width:100%}@screen md{nice-rule .rule-operator {max-width: 150px;}}nice-rule .aligned-button,nice-rule .select-filter{margin-bottom:1.25em}nice-rule .aligned-text{margin-bottom:2em}nice-rule .filter-select{margin-top:-14px}nice-rule .mat-form-field-infix{border:none}@media screen and (max-width: 959px){nice-rule .mat-form-field-infix{max-width:150px}}nice-rule .rule-container{padding-left:12px;padding-right:12px;max-width:100%}@screen md{nice-rule .rule-container:not(.is-double-input) {max-width: 50%;}}@media screen and (max-width: 959px){nice-rule .rule-container{padding:0}}\n"], components: [{ type: i2.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i4.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i5.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { type: i6.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { type: i7.TextFilterComponent, selector: "nice-text-filter", inputs: ["filterConfig"] }, { type: i8.NumberFilterComponent, selector: "nice-number-filter" }, { type: i9.RadioFilterComponent, selector: "nice-radio-filter", inputs: ["filterConfig"] }, { type: i10.SelectFilterComponent, selector: "nice-select-filter", inputs: ["filterConfig"] }, { type: i11.DateFilterComponent, selector: "nice-date-filter" }], directives: [{ type: i12.QueryBuilderTriggerDirective, selector: "[niceQueryBuilderTrigger]", inputs: ["queryBuilderFilters", "queryBuilderFiltersLoading"], outputs: ["queryBuilderFilterSelected"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i13.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.FormArrayName, selector: "[formArrayName]", inputs: ["formArrayName"] }, { type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { type: i13.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i13.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i13.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }], pipes: { "translate": i14.TranslatePipe }, encapsulation: i0.ViewEncapsulation.None });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: RuleComponent, decorators: [{
|
|
71
|
+
type: Component,
|
|
72
|
+
args: [{ selector: "nice-rule", encapsulation: ViewEncapsulation.None, template: "<div class=\"flex flex-row justify-start items-center gap-2.5\">\n <button\n class=\"select-filter\"\n mat-raised-button\n color=\"accent\"\n niceQueryBuilderTrigger\n [queryBuilderFilters]=\"filterConfigs\"\n (queryBuilderFilterSelected)=\"onUpdateFilterConfig($event)\"\n >\n <div class=\"flex flex-row justify-between items-center\">\n <div class=\"config-name\">{{ filterConfig?.name }}</div>\n <mat-icon class=\"config-name-icon\">arrow_drop_down</mat-icon>\n </div>\n </button>\n <div class=\"flex flex-col md:flex-row flex-auto justify-start items-center gap-2.5\">\n <mat-form-field class=\"w-90-p md:auto\" ngClass.lt-md=\"w-90-p\" fxFlex=\"0 0 188px\">\n <mat-select\n class=\"rule-operator\"\n [ngModel]=\"filterOperator\"\n (ngModelChange)=\"onUpdateFilterOperator($event)\"\n >\n <mat-option *ngFor=\"let operator of filterConfig?.operators\" [value]=\"operator.id\">\n {{ operator?.name }}\n </mat-option>\n </mat-select>\n </mat-form-field>\n <div class=\"flex flex-col md:flex-row flex-wrap\" [formGroup]=\"formGroup\">\n <ng-container formArrayName=\"rules\">\n <div\n class=\"rule-container flex flex-col md:flex-row flex-full justify-start items-center gap-2.5\"\n [class.is-double-input]=\"!!isDoubleInput\"\n [formGroupName]=\"i\"\n *ngFor=\"let rule of rules.controls; let i = index\"\n >\n <ng-container *ngIf=\"isSingleInput\">\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter *ngSwitchCase=\"'text'\" class=\"flex flex-auto\" formControlName=\"value\" [filterConfig]=\"filterConfig\"></nice-text-filter>\n <nice-number-filter *ngSwitchCase=\"'number'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n ></nice-select-filter>\n <nice-date-filter *ngSwitchCase=\"'date'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-date-filter>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isDoubleInput\">\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter\n *ngSwitchCase=\"'text'\"\n [valueIndex]=\"0\"\n [filterConfig]=\"filterConfig\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-text-filter>\n <nice-number-filter\n *ngSwitchCase=\"'number'\"\n [valueIndex]=\"0\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"secondValue\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"0\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"0\"\n ></nice-select-filter>\n <nice-date-filter\n *ngSwitchCase=\"'date'\"\n [valueIndex]=\"0\"\n class=\"flex flex-auto\"\n formControlName=\"secondValue\"\n ></nice-date-filter>\n </ng-container>\n <h3 class=\"aligned-text\">\n {{ \"components.query_builder.rule.conditions.and\" | translate }}\n </h3>\n <ng-container [ngSwitch]=\"filterConfig?.type\">\n <nice-text-filter\n *ngSwitchCase=\"'text'\"\n [valueIndex]=\"1\"\n [filterConfig]=\"filterConfig\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-text-filter>\n <nice-number-filter\n *ngSwitchCase=\"'number'\"\n [valueIndex]=\"1\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-number-filter>\n <nice-radio-filter\n *ngSwitchCase=\"'radio'\"\n class=\"flex flex-auto mb-16\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"1\"\n ></nice-radio-filter>\n <nice-select-filter\n *ngSwitchCase=\"'select'\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n [filterConfig]=\"filterConfig\"\n [valueIndex]=\"1\"\n ></nice-select-filter>\n <nice-date-filter\n *ngSwitchCase=\"'date'\"\n [valueIndex]=\"1\"\n class=\"flex flex-auto\"\n formControlName=\"value\"\n ></nice-date-filter>\n </ng-container>\n </ng-container>\n <div class=\"flex flex-row gap-2\">\n <button mat-mini-fab class=\"or-button aligned-button\" (click)=\"onClickOr()\">\n {{ \"components.query_builder.rule.conditions.or\" | translate }}\n </button>\n <button class=\"aligned-button\" mat-icon-button color=\"warn\" (click)=\"onClickDelete(i)\">\n <mat-icon>delete</mat-icon>\n </button>\n </div>\n\n </div>\n </ng-container>\n </div>\n </div>\n</div>\n", styles: ["nice-rule{background:transparent}nice-rule .select-filter{@apply flex flex-full;height:36px;max-width:150px}nice-rule .config-name{@apply flex flex-full flex-grow-0 truncate;max-width:90px}nice-rule .config-name-icon{@apply flex flex-full;max-width:24px}nice-rule .rule-operator{@apply flex flex-full;max-width:100%}@screen md{nice-rule .rule-operator {max-width: 150px;}}nice-rule .aligned-button,nice-rule .select-filter{margin-bottom:1.25em}nice-rule .aligned-text{margin-bottom:2em}nice-rule .filter-select{margin-top:-14px}nice-rule .mat-form-field-infix{border:none}@media screen and (max-width: 959px){nice-rule .mat-form-field-infix{max-width:150px}}nice-rule .rule-container{padding-left:12px;padding-right:12px;max-width:100%}@screen md{nice-rule .rule-container:not(.is-double-input) {max-width: 50%;}}@media screen and (max-width: 959px){nice-rule .rule-container{padding:0}}\n"] }]
|
|
73
|
+
}], ctorParameters: function () { return [{ type: i1.FormGroupName }]; }, propDecorators: { filterConfigs: [{
|
|
74
|
+
type: Input
|
|
75
|
+
}], remove: [{
|
|
76
|
+
type: Output
|
|
77
|
+
}] } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rule.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-data-filter-kit/src/lib/components/query-builder/rule/rule.component.ts","../../../../../../../projects/nice-data-filter-kit/src/lib/components/query-builder/rule/rule.template.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation } from \"@angular/core\";\nimport { FormGroupName } from \"@angular/forms\";\nimport { GeneratedFormArray, GeneratedFormGroup } from \"@recursyve/ngx-form-generator\";\nimport { FilterConfigurationModel } from \"../../../models/filter.model\";\nimport { FilterOperators, QueryRuleModel } from \"../../../models/query.model\";\nimport { QueryForm, QueryRuleForm } from \"../query-builder.form\";\nimport { QBFilterUtils } from \"../utils/qb-filter.utils\";\n\n@Component({\n    selector: \"nice-rule\",\n    templateUrl: \"rule.template.html\",\n    styleUrls: [\"./rule.style.scss\"],\n    encapsulation: ViewEncapsulation.None\n})\nexport class RuleComponent implements OnInit {\n    @Input()\n    public filterConfigs: FilterConfigurationModel[] | null;\n\n    @Output()\n    public remove = new EventEmitter();\n\n    public formGroup: GeneratedFormGroup<QueryForm>;\n    public rules: GeneratedFormArray<QueryRuleForm>;\n    public filterOperator: FilterOperators;\n\n    public get filterConfig(): FilterConfigurationModel {\n        const rule = this.rules.at(0).value as QueryRuleModel;\n        return this.filterConfigs?.find(f => f.id === rule.id) as FilterConfigurationModel;\n    }\n\n    public get isSingleInput(): boolean {\n        return !this.isDoubleInput && !this.isNoInput;\n    }\n\n    public get isDoubleInput(): boolean {\n        return QBFilterUtils.isDoubleInput(this.filterOperator);\n    }\n\n    public get isNoInput(): boolean {\n        return QBFilterUtils.isNoInput(this.filterOperator);\n    }\n\n    constructor(private formGroupName: FormGroupName) {}\n\n    public ngOnInit(): void {\n        this.formGroup = this.formGroupName.control as GeneratedFormGroup<QueryForm>;\n        this.rules = this.formGroup.get(\"rules\") as GeneratedFormArray<QueryRuleForm>;\n        this.filterOperator = this.rules.at(0).value.operation;\n    }\n\n    public onUpdateFilterConfig(config: FilterConfigurationModel): void {\n        const rule = QBFilterUtils.createRule(config);\n        this.rules.patchValue([rule as QueryRuleForm]);\n        this.filterOperator = rule.operation;\n    }\n\n    public onClickOr(): void {\n        this.rules.push(QBFilterUtils.createRule(this.filterConfig, this.filterOperator));\n    }\n\n    public onUpdateFilterOperator(operator: string): void {\n        this.filterOperator = operator as FilterOperators;\n        for (const rule of this.rules.controls) {\n            rule.get(\"operation\")?.patchValue(this.filterOperator);\n\n            if (this.isDoubleInput) {\n                rule.get(\"value\")?.patchValue([rule.value.value, rule.value.value]);\n            }\n        }\n    }\n\n    public onClickDelete(index: number): void {\n        if (this.rules.length > 1) {\n            this.rules.removeAt(index);\n        } else {\n            this.remove.emit();\n        }\n    }\n}\n","<div class=\"flex flex-row justify-start items-center gap-2.5\">\n    <button\n        class=\"select-filter\"\n        mat-raised-button\n        color=\"accent\"\n        niceQueryBuilderTrigger\n        [queryBuilderFilters]=\"filterConfigs\"\n        (queryBuilderFilterSelected)=\"onUpdateFilterConfig($event)\"\n    >\n        <div class=\"flex flex-row justify-between items-center\">\n            <div class=\"config-name\">{{ filterConfig?.name }}</div>\n            <mat-icon class=\"config-name-icon\">arrow_drop_down</mat-icon>\n        </div>\n    </button>\n    <div class=\"flex flex-col md:flex-row flex-auto justify-start items-center gap-2.5\">\n        <mat-form-field class=\"w-90-p md:auto\" ngClass.lt-md=\"w-90-p\" fxFlex=\"0 0 188px\">\n            <mat-select\n                class=\"rule-operator\"\n                [ngModel]=\"filterOperator\"\n                (ngModelChange)=\"onUpdateFilterOperator($event)\"\n            >\n                <mat-option *ngFor=\"let operator of filterConfig?.operators\" [value]=\"operator.id\">\n                    {{ operator?.name }}\n                </mat-option>\n            </mat-select>\n        </mat-form-field>\n        <div class=\"flex flex-col md:flex-row flex-wrap\" [formGroup]=\"formGroup\">\n            <ng-container formArrayName=\"rules\">\n                <div\n                    class=\"rule-container flex flex-col md:flex-row flex-full justify-start items-center gap-2.5\"\n                    [class.is-double-input]=\"!!isDoubleInput\"\n                    [formGroupName]=\"i\"\n                    *ngFor=\"let rule of rules.controls; let i = index\"\n                >\n                    <ng-container *ngIf=\"isSingleInput\">\n                        <ng-container [ngSwitch]=\"filterConfig?.type\">\n                            <nice-text-filter *ngSwitchCase=\"'text'\" class=\"flex flex-auto\" formControlName=\"value\" [filterConfig]=\"filterConfig\"></nice-text-filter>\n                            <nice-number-filter *ngSwitchCase=\"'number'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-number-filter>\n                            <nice-radio-filter\n                                *ngSwitchCase=\"'radio'\"\n                                class=\"flex flex-auto mb-16\"\n                                formControlName=\"value\"\n                                [filterConfig]=\"filterConfig\"\n                            ></nice-radio-filter>\n                            <nice-select-filter\n                                *ngSwitchCase=\"'select'\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"value\"\n                                [filterConfig]=\"filterConfig\"\n                            ></nice-select-filter>\n                            <nice-date-filter *ngSwitchCase=\"'date'\" class=\"flex flex-auto\" formControlName=\"value\"></nice-date-filter>\n                        </ng-container>\n                    </ng-container>\n                    <ng-container *ngIf=\"isDoubleInput\">\n                        <ng-container [ngSwitch]=\"filterConfig?.type\">\n                            <nice-text-filter\n                                *ngSwitchCase=\"'text'\"\n                                [valueIndex]=\"0\"\n                                [filterConfig]=\"filterConfig\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"secondValue\"\n                            ></nice-text-filter>\n                            <nice-number-filter\n                                *ngSwitchCase=\"'number'\"\n                                [valueIndex]=\"0\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"secondValue\"\n                            ></nice-number-filter>\n                            <nice-radio-filter\n                                *ngSwitchCase=\"'radio'\"\n                                class=\"flex flex-auto mb-16\"\n                                formControlName=\"secondValue\"\n                                [filterConfig]=\"filterConfig\"\n                                [valueIndex]=\"0\"\n                            ></nice-radio-filter>\n                            <nice-select-filter\n                                *ngSwitchCase=\"'select'\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"secondValue\"\n                                [filterConfig]=\"filterConfig\"\n                                [valueIndex]=\"0\"\n                            ></nice-select-filter>\n                            <nice-date-filter\n                                *ngSwitchCase=\"'date'\"\n                                [valueIndex]=\"0\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"secondValue\"\n                            ></nice-date-filter>\n                        </ng-container>\n                        <h3 class=\"aligned-text\">\n                            {{ \"components.query_builder.rule.conditions.and\" | translate }}\n                        </h3>\n                        <ng-container [ngSwitch]=\"filterConfig?.type\">\n                            <nice-text-filter\n                                *ngSwitchCase=\"'text'\"\n                                [valueIndex]=\"1\"\n                                [filterConfig]=\"filterConfig\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"value\"\n                            ></nice-text-filter>\n                            <nice-number-filter\n                                *ngSwitchCase=\"'number'\"\n                                [valueIndex]=\"1\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"value\"\n                            ></nice-number-filter>\n                            <nice-radio-filter\n                                *ngSwitchCase=\"'radio'\"\n                                class=\"flex flex-auto mb-16\"\n                                formControlName=\"value\"\n                                [filterConfig]=\"filterConfig\"\n                                [valueIndex]=\"1\"\n                            ></nice-radio-filter>\n                            <nice-select-filter\n                                *ngSwitchCase=\"'select'\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"value\"\n                                [filterConfig]=\"filterConfig\"\n                                [valueIndex]=\"1\"\n                            ></nice-select-filter>\n                            <nice-date-filter\n                                *ngSwitchCase=\"'date'\"\n                                [valueIndex]=\"1\"\n                                class=\"flex flex-auto\"\n                                formControlName=\"value\"\n                            ></nice-date-filter>\n                        </ng-container>\n                    </ng-container>\n                    <div class=\"flex flex-row gap-2\">\n                        <button mat-mini-fab class=\"or-button aligned-button\" (click)=\"onClickOr()\">\n                            {{ \"components.query_builder.rule.conditions.or\" | translate }}\n                        </button>\n                        <button class=\"aligned-button\" mat-icon-button color=\"warn\" (click)=\"onClickDelete(i)\">\n                            <mat-icon>delete</mat-icon>\n                        </button>\n                    </div>\n\n                </div>\n            </ng-container>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -20,24 +20,38 @@ export class QBFilterUtils {
|
|
|
20
20
|
return QBFilterUtils.noInputOperators.includes(filterOperator);
|
|
21
21
|
}
|
|
22
22
|
static createRule(config, operator) {
|
|
23
|
-
var _a, _b, _c;
|
|
24
23
|
const base = {
|
|
25
24
|
id: config.id,
|
|
26
25
|
operation: operator || config.operators[0].id
|
|
27
26
|
};
|
|
28
27
|
switch (config.type) {
|
|
29
28
|
case FilterType.Text:
|
|
30
|
-
return
|
|
29
|
+
return {
|
|
30
|
+
...base,
|
|
31
|
+
value: QBFilterUtils.isDoubleInput(operator) ? ["", ""] : ""
|
|
32
|
+
};
|
|
31
33
|
case FilterType.Select:
|
|
32
|
-
return
|
|
34
|
+
return {
|
|
35
|
+
...base,
|
|
36
|
+
value: QBFilterUtils.isDoubleInput(operator) ? [null, null] : null
|
|
37
|
+
};
|
|
33
38
|
case FilterType.Date:
|
|
34
|
-
return
|
|
39
|
+
return {
|
|
40
|
+
...base,
|
|
41
|
+
value: QBFilterUtils.isDoubleInput(operator) ? [new Date(), new Date()] : new Date()
|
|
42
|
+
};
|
|
35
43
|
case FilterType.Radio:
|
|
36
|
-
return
|
|
37
|
-
|
|
38
|
-
|
|
44
|
+
return {
|
|
45
|
+
...base,
|
|
46
|
+
value: QBFilterUtils.isDoubleInput(operator)
|
|
47
|
+
? [config.options?.[0].key, config.options?.[0].key]
|
|
48
|
+
: config.options?.[0].key
|
|
49
|
+
};
|
|
39
50
|
case FilterType.Number:
|
|
40
|
-
return
|
|
51
|
+
return {
|
|
52
|
+
...base,
|
|
53
|
+
value: QBFilterUtils.isDoubleInput(operator) ? [0, 0] : 0
|
|
54
|
+
};
|
|
41
55
|
}
|
|
42
56
|
}
|
|
43
57
|
static createQueryModel(config) {
|
|
@@ -72,4 +86,4 @@ QBFilterUtils.doubleInputOperators = [
|
|
|
72
86
|
FilterOperatorTypes.Between,
|
|
73
87
|
FilterOperatorTypes.NotBetween
|
|
74
88
|
];
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"qb-filter.utils.js","sourceRoot":"","sources":["../../../../../../../projects/nice-data-filter-kit/src/lib/components/query-builder/utils/qb-filter.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAA4B,UAAU,EAAE,MAAM,8BAA8B,CAAC;AACpF,OAAO,EAAmB,mBAAmB,EAA8B,MAAM,6BAA6B,CAAC;AAE/G,MAAM,OAAO,aAAa;IA6Bf,MAAM,CAAC,aAAa,CAAC,cAAgC;QACxD,IAAI,CAAC,cAAc,EAAE;YACjB,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,aAAa,CAAC,oBAAoB,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACvE,CAAC;IAEM,MAAM,CAAC,aAAa,CAAC,cAAgC;QACxD,IAAI,CAAC,cAAc,EAAE;YACjB,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,aAAa,CAAC,oBAAoB,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACvE,CAAC;IAEM,MAAM,CAAC,SAAS,CAAC,cAAgC;QACpD,IAAI,CAAC,cAAc,EAAE;YACjB,OAAO,KAAK,CAAC;SAChB;QACD,OAAO,aAAa,CAAC,gBAAgB,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACnE,CAAC;IAEM,MAAM,CAAC,UAAU,CAAC,MAAgC,EAAE,QAA0B;QACjF,MAAM,IAAI,GAAG;YACT,EAAE,EAAE,MAAM,CAAC,EAAE;YACb,SAAS,EAAE,QAAQ,IAAK,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAsB;SACrE,CAAC;QACF,QAAQ,MAAM,CAAC,IAAI,EAAE;YACjB,KAAK,UAAU,CAAC,IAAI;gBAChB,OAAO;oBACH,GAAG,IAAI;oBACP,KAAK,EAAE,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE;iBAC/D,CAAC;YACN,KAAK,UAAU,CAAC,MAAM;gBAClB,OAAO;oBACH,GAAG,IAAI;oBACP,KAAK,EAAE,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI;iBACrE,CAAC;YACN,KAAK,UAAU,CAAC,IAAI;gBAChB,OAAO;oBACH,GAAG,IAAI;oBACP,KAAK,EAAE,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE;iBACvF,CAAC;YACN,KAAK,UAAU,CAAC,KAAK;gBACjB,OAAO;oBACH,GAAG,IAAI;oBACP,KAAK,EAAE,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC;wBACxC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;wBACpD,CAAC,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG;iBAChC,CAAC;YACN,KAAK,UAAU,CAAC,MAAM;gBAClB,OAAO;oBACH,GAAG,IAAI;oBACP,KAAK,EAAE,aAAa,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC5D,CAAC;SACT;IACL,CAAC;IAEM,MAAM,CAAC,gBAAgB,CAAC,MAAgC;QAC3D,OAAO;YACH,SAAS,EAAE,IAAI;YACf,KAAK,EAAE,CAAC,aAAa,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;SAC5C,CAAC;IACN,CAAC;;AA1Fa,8BAAgB,GAAsB;IAChD,mBAAmB,CAAC,OAAO;IAC3B,mBAAmB,CAAC,UAAU;IAC9B,mBAAmB,CAAC,MAAM;IAC1B,mBAAmB,CAAC,SAAS;IAC7B,mBAAmB,CAAC,IAAI;CAC3B,CAAC;AAEY,kCAAoB,GAAsB;IACpD,mBAAmB,CAAC,KAAK;IACzB,mBAAmB,CAAC,QAAQ;IAC5B,mBAAmB,CAAC,IAAI;IACxB,mBAAmB,CAAC,WAAW;IAC/B,mBAAmB,CAAC,OAAO;IAC3B,mBAAmB,CAAC,cAAc;IAClC,mBAAmB,CAAC,UAAU;IAC9B,mBAAmB,CAAC,aAAa;IACjC,mBAAmB,CAAC,QAAQ;IAC5B,mBAAmB,CAAC,WAAW;IAC/B,mBAAmB,CAAC,QAAQ;IAC5B,mBAAmB,CAAC,WAAW;CAClC,CAAC;AAEY,kCAAoB,GAAsB;IACpD,mBAAmB,CAAC,OAAO;IAC3B,mBAAmB,CAAC,UAAU;CACjC,CAAC","sourcesContent":["import { FilterConfigurationModel, FilterType } from \"../../../models/filter.model\";\nimport { FilterOperators, FilterOperatorTypes, QueryModel, QueryRuleModel } from \"../../../models/query.model\";\n\nexport class QBFilterUtils {\n    public static noInputOperators: FilterOperators[] = [\n        FilterOperatorTypes.IsEmpty,\n        FilterOperatorTypes.IsNotEmpty,\n        FilterOperatorTypes.IsNull,\n        FilterOperatorTypes.IsNotNull,\n        FilterOperatorTypes.None\n    ];\n\n    public static singleInputOperators: FilterOperators[] = [\n        FilterOperatorTypes.Equal,\n        FilterOperatorTypes.NotEqual,\n        FilterOperatorTypes.Less,\n        FilterOperatorTypes.LessOrEqual,\n        FilterOperatorTypes.Greater,\n        FilterOperatorTypes.GreaterOrEqual,\n        FilterOperatorTypes.BeginsWith,\n        FilterOperatorTypes.NotBeginsWith,\n        FilterOperatorTypes.EndsWith,\n        FilterOperatorTypes.NotEndsWith,\n        FilterOperatorTypes.Contains,\n        FilterOperatorTypes.NotContains\n    ];\n\n    public static doubleInputOperators: FilterOperators[] = [\n        FilterOperatorTypes.Between,\n        FilterOperatorTypes.NotBetween\n    ];\n\n    public static isSingleInput(filterOperator?: FilterOperators): boolean {\n        if (!filterOperator) {\n            return false;\n        }\n        return QBFilterUtils.singleInputOperators.includes(filterOperator);\n    }\n\n    public static isDoubleInput(filterOperator?: FilterOperators): boolean {\n        if (!filterOperator) {\n            return false;\n        }\n        return QBFilterUtils.doubleInputOperators.includes(filterOperator);\n    }\n\n    public static isNoInput(filterOperator?: FilterOperators): boolean {\n        if (!filterOperator) {\n            return false;\n        }\n        return QBFilterUtils.noInputOperators.includes(filterOperator);\n    }\n\n    public static createRule(config: FilterConfigurationModel, operator?: FilterOperators): QueryRuleModel {\n        const base = {\n            id: config.id,\n            operation: operator || (config.operators[0].id as FilterOperators)\n        };\n        switch (config.type) {\n            case FilterType.Text:\n                return {\n                    ...base,\n                    value: QBFilterUtils.isDoubleInput(operator) ? [\"\", \"\"] : \"\"\n                };\n            case FilterType.Select:\n                return {\n                    ...base,\n                    value: QBFilterUtils.isDoubleInput(operator) ? [null, null] : null\n                };\n            case FilterType.Date:\n                return {\n                    ...base,\n                    value: QBFilterUtils.isDoubleInput(operator) ? [new Date(), new Date()] : new Date()\n                };\n            case FilterType.Radio:\n                return {\n                    ...base,\n                    value: QBFilterUtils.isDoubleInput(operator)\n                        ? [config.options?.[0].key, config.options?.[0].key]\n                        : config.options?.[0].key\n                };\n            case FilterType.Number:\n                return {\n                    ...base,\n                    value: QBFilterUtils.isDoubleInput(operator) ? [0, 0] : 0\n                };\n        }\n    }\n\n    public static createQueryModel(config: FilterConfigurationModel): QueryModel {\n        return {\n            condition: \"or\",\n            rules: [QBFilterUtils.createRule(config)]\n        };\n    }\n}\n"]}
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
@@ -28,9 +28,9 @@ export class NiceCustomDateAdapter extends NativeDateAdapter {
|
|
|
28
28
|
return date.getUTCFullYear();
|
|
29
29
|
}
|
|
30
30
|
}
|
|
31
|
-
NiceCustomDateAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
32
|
-
NiceCustomDateAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "
|
|
33
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
31
|
+
NiceCustomDateAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceCustomDateAdapter, deps: [{ token: i1.TranslateService }, { token: MAT_DATE_LOCALE }, { token: i2.Platform }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
32
|
+
NiceCustomDateAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceCustomDateAdapter });
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.3", ngImport: i0, type: NiceCustomDateAdapter, decorators: [{
|
|
34
34
|
type: Injectable
|
|
35
35
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: undefined, decorators: [{
|
|
36
36
|
type: Inject,
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { ObjectUtils } from "@recursyve/nice-ui-kit.v2";
|
|
2
|
+
export class FilterUtils {
|
|
3
|
+
static parametersToRequest(filterParameters) {
|
|
4
|
+
return {
|
|
5
|
+
page: {
|
|
6
|
+
number: Math.ceil((filterParameters.start ?? 0) / (filterParameters.length ?? 1)),
|
|
7
|
+
size: filterParameters.length ?? 0
|
|
8
|
+
},
|
|
9
|
+
search: {
|
|
10
|
+
value: filterParameters.search ?? ""
|
|
11
|
+
},
|
|
12
|
+
query: {
|
|
13
|
+
condition: "and",
|
|
14
|
+
rules: filterParameters.rules ?? []
|
|
15
|
+
},
|
|
16
|
+
order: filterParameters.order ?? undefined,
|
|
17
|
+
data: filterParameters.data
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
static filterChangeNeedsRefresh(currentFilters, newFilters) {
|
|
21
|
+
const newFilterKeys = Object.keys(newFilters).sort();
|
|
22
|
+
if (newFilterKeys.length === 0) {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
return newFilterKeys.some((key) => {
|
|
26
|
+
const currentValue = currentFilters[key];
|
|
27
|
+
const newValue = currentFilters[key];
|
|
28
|
+
if (Array.isArray(currentValue)) {
|
|
29
|
+
return !ObjectUtils.areObjectsEqual(currentValue, newValue);
|
|
30
|
+
}
|
|
31
|
+
else if (typeof currentValue === "object" && currentValue !== null) {
|
|
32
|
+
return !ObjectUtils.areObjectsEqual(currentValue, newValue);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
return currentValue !== newValue;
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLnV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmljZS1kYXRhLWZpbHRlci1raXQvc3JjL2xpYi91dGlscy9maWx0ZXIudXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBR3hELE1BQU0sT0FBTyxXQUFXO0lBQ2IsTUFBTSxDQUFDLG1CQUFtQixDQUFDLGdCQUF1QztRQUNyRSxPQUFPO1lBQ0gsSUFBSSxFQUFFO2dCQUNGLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxJQUFJLENBQUMsQ0FBQyxDQUFDO2dCQUNqRixJQUFJLEVBQUUsZ0JBQWdCLENBQUMsTUFBTSxJQUFJLENBQUM7YUFDckM7WUFDRCxNQUFNLEVBQUU7Z0JBQ0osS0FBSyxFQUFFLGdCQUFnQixDQUFDLE1BQU0sSUFBSSxFQUFFO2FBQ3ZDO1lBQ0QsS0FBSyxFQUFFO2dCQUNILFNBQVMsRUFBRSxLQUFLO2dCQUNoQixLQUFLLEVBQUUsZ0JBQWdCLENBQUMsS0FBSyxJQUFJLEVBQUU7YUFDdEM7WUFDRCxLQUFLLEVBQUUsZ0JBQWdCLENBQUMsS0FBSyxJQUFJLFNBQVM7WUFDMUMsSUFBSSxFQUFFLGdCQUFnQixDQUFDLElBQUk7U0FDOUIsQ0FBQztJQUNOLENBQUM7SUFFTSxNQUFNLENBQUMsd0JBQXdCLENBQUMsY0FBcUMsRUFBRSxVQUFpQztRQUMzRyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ3JELElBQUksYUFBYSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDNUIsT0FBTyxJQUFJLENBQUM7U0FDZjtRQUNELE9BQU8sYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRSxFQUFFO1lBQzlCLE1BQU0sWUFBWSxHQUFJLGNBQXNCLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDbEQsTUFBTSxRQUFRLEdBQUksY0FBc0IsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUM5QyxJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLEVBQUU7Z0JBQzdCLE9BQU8sQ0FBQyxXQUFXLENBQUMsZUFBZSxDQUFDLFlBQVksRUFBRSxRQUFRLENBQUMsQ0FBQzthQUMvRDtpQkFBTSxJQUFJLE9BQU8sWUFBWSxLQUFLLFFBQVEsSUFBSSxZQUFZLEtBQUssSUFBSSxFQUFFO2dCQUNsRSxPQUFPLENBQUMsV0FBVyxDQUFDLGVBQWUsQ0FBQyxZQUFZLEVBQUUsUUFBUSxDQUFDLENBQUM7YUFDL0Q7aUJBQU07Z0JBQ0gsT0FBTyxZQUFZLEtBQUssUUFBUSxDQUFDO2FBQ3BDO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPYmplY3RVdGlscyB9IGZyb20gXCJAcmVjdXJzeXZlL25pY2UtdWkta2l0LnYyXCI7XG5pbXBvcnQgeyBGaWx0ZXJQYXJhbWV0ZXJzTW9kZWwsIEZpbHRlclF1ZXJ5TW9kZWwgfSBmcm9tIFwiLi4vbW9kZWxzL2ZpbHRlci5tb2RlbFwiO1xuXG5leHBvcnQgY2xhc3MgRmlsdGVyVXRpbHMge1xuICAgIHB1YmxpYyBzdGF0aWMgcGFyYW1ldGVyc1RvUmVxdWVzdChmaWx0ZXJQYXJhbWV0ZXJzOiBGaWx0ZXJQYXJhbWV0ZXJzTW9kZWwpOiBGaWx0ZXJRdWVyeU1vZGVsIHtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHBhZ2U6IHtcbiAgICAgICAgICAgICAgICBudW1iZXI6IE1hdGguY2VpbCgoZmlsdGVyUGFyYW1ldGVycy5zdGFydCA/PyAwKSAvIChmaWx0ZXJQYXJhbWV0ZXJzLmxlbmd0aCA/PyAxKSksXG4gICAgICAgICAgICAgICAgc2l6ZTogZmlsdGVyUGFyYW1ldGVycy5sZW5ndGggPz8gMFxuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHNlYXJjaDoge1xuICAgICAgICAgICAgICAgIHZhbHVlOiBmaWx0ZXJQYXJhbWV0ZXJzLnNlYXJjaCA/PyBcIlwiXG4gICAgICAgICAgICB9LFxuICAgICAgICAgICAgcXVlcnk6IHtcbiAgICAgICAgICAgICAgICBjb25kaXRpb246IFwiYW5kXCIsXG4gICAgICAgICAgICAgICAgcnVsZXM6IGZpbHRlclBhcmFtZXRlcnMucnVsZXMgPz8gW11cbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBvcmRlcjogZmlsdGVyUGFyYW1ldGVycy5vcmRlciA/PyB1bmRlZmluZWQsXG4gICAgICAgICAgICBkYXRhOiBmaWx0ZXJQYXJhbWV0ZXJzLmRhdGFcbiAgICAgICAgfTtcbiAgICB9XG5cbiAgICBwdWJsaWMgc3RhdGljIGZpbHRlckNoYW5nZU5lZWRzUmVmcmVzaChjdXJyZW50RmlsdGVyczogRmlsdGVyUGFyYW1ldGVyc01vZGVsLCBuZXdGaWx0ZXJzOiBGaWx0ZXJQYXJhbWV0ZXJzTW9kZWwpOiBib29sZWFuIHtcbiAgICAgICAgY29uc3QgbmV3RmlsdGVyS2V5cyA9IE9iamVjdC5rZXlzKG5ld0ZpbHRlcnMpLnNvcnQoKTtcbiAgICAgICAgaWYgKG5ld0ZpbHRlcktleXMubGVuZ3RoID09PSAwKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbmV3RmlsdGVyS2V5cy5zb21lKChrZXkpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGN1cnJlbnRWYWx1ZSA9IChjdXJyZW50RmlsdGVycyBhcyBhbnkpW2tleV07XG4gICAgICAgICAgICBjb25zdCBuZXdWYWx1ZSA9IChjdXJyZW50RmlsdGVycyBhcyBhbnkpW2tleV07XG4gICAgICAgICAgICBpZiAoQXJyYXkuaXNBcnJheShjdXJyZW50VmFsdWUpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuICFPYmplY3RVdGlscy5hcmVPYmplY3RzRXF1YWwoY3VycmVudFZhbHVlLCBuZXdWYWx1ZSk7XG4gICAgICAgICAgICB9IGVsc2UgaWYgKHR5cGVvZiBjdXJyZW50VmFsdWUgPT09IFwib2JqZWN0XCIgJiYgY3VycmVudFZhbHVlICE9PSBudWxsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuICFPYmplY3RVdGlscy5hcmVPYmplY3RzRXF1YWwoY3VycmVudFZhbHVlLCBuZXdWYWx1ZSk7XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHJldHVybiBjdXJyZW50VmFsdWUgIT09IG5ld1ZhbHVlO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
|
File without changes
|
package/{esm2015/lib/utils/query-params.utils.js → esm2020/lib/utils/query-params.utils.mjs}
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
package/{esm2015/recursyve-nice-data-filter-kit.js → esm2020/recursyve-nice-data-filter-kit.mjs}
RENAMED
|
File without changes
|