@paperless/angular 0.1.0-alpha.247 → 0.1.0-alpha.249

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.
@@ -1,15 +1,18 @@
1
1
  import { __decorate } from "tslib";
2
2
  import { Component } from '@angular/core';
3
- import { FormControl } from '@angular/forms';
3
+ import { FormControl, FormGroup } from '@angular/forms';
4
4
  import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
5
5
  import { timer } from 'rxjs';
6
6
  import { debounce, filter, map, pairwise, startWith } from 'rxjs/operators';
7
+ import { createFormFilters } from '../utils';
7
8
  import { FormBaseComponent } from './form.component';
8
9
  import * as i0 from "@angular/core";
9
10
  let BaseTableComponent = class BaseTableComponent extends FormBaseComponent {
10
11
  constructor() {
11
12
  super();
12
13
  this.quickFilters = [];
14
+ this.filterForm = new FormGroup({});
15
+ this.defaultFilterFormValues = {};
13
16
  this.pageSizeDefault = 12;
14
17
  this._defaultTableValues = {
15
18
  pageSize: this.pageSizeDefault,
@@ -126,6 +129,29 @@ let BaseTableComponent = class BaseTableComponent extends FormBaseComponent {
126
129
  this._refresh();
127
130
  }
128
131
  }
132
+ applyFormFilters(values = null) {
133
+ values = values ?? this.filterForm.value;
134
+ const { filters, quickFilter } = createFormFilters(values, this.quickFilters, this.filterFormQuickFilterKey);
135
+ if (quickFilter) {
136
+ this.quickFilter = quickFilter;
137
+ }
138
+ this.filters = filters;
139
+ }
140
+ resetFormFilters(resetQuickFilter = false) {
141
+ const values = this.filterForm.value;
142
+ const defaultQuickFilter = this.quickFilters.find((f) => f.default);
143
+ for (const key of Object.keys(values)) {
144
+ if (key === this.filterFormQuickFilterKey) {
145
+ if (resetQuickFilter) {
146
+ values[key] = defaultQuickFilter.value;
147
+ }
148
+ continue;
149
+ }
150
+ values[key] = this.defaultFilterFormValues[key] ?? null;
151
+ }
152
+ this.filterForm.setValue(values);
153
+ this.applyFormFilters(values);
154
+ }
129
155
  _refresh() {
130
156
  console.warn('Not implemented');
131
157
  }
@@ -172,4 +198,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
172
198
  template: ``,
173
199
  }]
174
200
  }], ctorParameters: function () { return []; } });
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/paperless/src/lib/modules/table/base/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { QuickFilter } from '@paperless/core';\nimport { timer } from 'rxjs';\nimport { debounce, filter, map, pairwise, startWith } from 'rxjs/operators';\nimport { FormBaseComponent } from './form.component';\n\nexport type TableQuickFilter = QuickFilter & {\n    value: string;\n    metricName?: string;\n};\n\nexport interface TableOptions {\n    pageSize: number;\n    page: number;\n    quickFilter: TableQuickFilter | string | null;\n    query: string;\n    filters: any[];\n    selectedRows: any[];\n}\n\n@UntilDestroy({ checkProperties: true })\n@Component({\n    template: ``,\n})\nexport abstract class BaseTableComponent\n    extends FormBaseComponent\n    implements OnInit\n{\n    protected quickFilters: any[] = [];\n\n    public pageSizeDefault = 12;\n    public tableOptions?: FormControl<TableOptions>;\n\n    private _defaultTableValues: TableOptions = {\n        pageSize: this.pageSizeDefault,\n        page: 1,\n        quickFilter: null,\n        query: '',\n        filters: [],\n        selectedRows: [],\n    };\n    public defaultTableValues: Partial<TableOptions> = {};\n\n    get pageSize() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.pageSize;\n        }\n\n        return this.tableOptions.value.pageSize;\n    }\n\n    get page() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.page;\n        }\n\n        return this.tableOptions.value.page;\n    }\n\n    get quickFilter() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.quickFilter;\n        }\n\n        return this.tableOptions.value.quickFilter;\n    }\n    set quickFilter(quickFilter: TableQuickFilter | string | null) {\n        this.tableValues = {\n            quickFilter,\n        };\n    }\n\n    get query() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.query;\n        }\n\n        return this.tableOptions.value.query;\n    }\n    set query(query: string) {\n        this.tableValues = {\n            query,\n        };\n    }\n\n    get filters() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.filters;\n        }\n\n        return this.tableOptions.value.filters;\n    }\n    set filters(filters: any[]) {\n        this.tableValues = {\n            filters,\n        };\n    }\n\n    get selectedRows() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.selectedRows;\n        }\n\n        return this.tableOptions.value.selectedRows;\n    }\n    set selectedRows(selectedRows: any[]) {\n        this.tableValues = {\n            selectedRows,\n        };\n    }\n\n    // setter\n    get parsedDefaultTableValues() {\n        return {\n            ...this._defaultTableValues,\n            ...this.defaultTableValues,\n            pageSize: this.defaultTableValues?.pageSize || this.pageSizeDefault,\n        };\n    }\n\n    get tableValues() {\n        return this.tableOptions?.value ?? {};\n    }\n\n    set tableValues(values: Partial<TableOptions>) {\n        this._setTableValues({\n            ...this.tableValues,\n            ...values,\n        });\n    }\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n        this.tableOptions = new FormControl<TableOptions>({\n            pageSize: this.parsedDefaultTableValues.pageSize,\n            page: this.parsedDefaultTableValues.page,\n            quickFilter: this.parsedDefaultTableValues.quickFilter,\n            query: this.parsedDefaultTableValues.query,\n            filters: this.parsedDefaultTableValues.filters,\n            selectedRows: this.parsedDefaultTableValues.selectedRows,\n        }) as FormControl<TableOptions>;\n\n        this.tableOptions.valueChanges\n            .pipe(\n                untilDestroyed(this),\n                startWith(this.tableOptions.value),\n                pairwise(),\n                map(([previous, next]) => this._getChanges(previous, next)),\n                filter((changes: any) => !!changes),\n                debounce((changes) => {\n                    if (changes?.query && Object.keys(changes)?.length === 1) {\n                        return timer(300);\n                    }\n\n                    return timer(0);\n                }),\n                filter(\n                    (changes: any) =>\n                        !(\n                            changes?.selected &&\n                            Object.keys(changes)?.length === 1\n                        )\n                )\n            )\n            .subscribe((changes: TableOptions) => {\n                if (changes?.page) {\n                    this._refresh();\n                    return;\n                }\n\n                this._resetPageOrRefresh();\n            });\n\n        this._refresh();\n    }\n\n    resetTable(emitEvent = true, forceRefresh = null) {\n        this._setTableValues(this.parsedDefaultTableValues, emitEvent);\n\n        if (forceRefresh) {\n            this._refresh();\n        }\n    }\n\n    protected _refresh() {\n        console.warn('Not implemented');\n    }\n\n    private _resetPageOrRefresh() {\n        if (!this.tableOptions) {\n            return;\n        }\n\n        if (this.page !== 1) {\n            this.tableOptions.get('page')?.setValue(1);\n            return;\n        }\n\n        this._refresh();\n    }\n\n    private _setTableValues(data: Partial<TableOptions>, emitEvent = true) {\n        this.tableOptions?.setValue(\n            {\n                ...this.tableOptions.value,\n                ...data,\n            },\n            { emitEvent }\n        );\n    }\n\n    private _getChanges(previous: TableOptions, next: TableOptions) {\n        const changes: Partial<TableOptions> = {};\n\n        let key: keyof TableOptions;\n        for (key in next) {\n            if (key === 'selectedRows') {\n                continue;\n            }\n\n            if (JSON.stringify(previous[key]) !== JSON.stringify(next[key])) {\n                // @ts-ignore\n                changes[key] = next[key];\n            }\n        }\n\n        return Object.keys(changes).length ? changes : null;\n    }\n}\n"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../../projects/paperless/src/lib/modules/table/base/table.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAU,MAAM,eAAe,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAErE,OAAO,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;;IAoB/B,kBAAkB,SAAlB,kBAClB,SAAQ,iBAAiB;IA8GzB;QACI,KAAK,EAAE,CAAC;QA5GF,iBAAY,GAAU,EAAE,CAAC;QAE5B,eAAU,GAAmB,IAAI,SAAS,CAAM,EAAE,CAAC,CAAC;QAEpD,4BAAuB,GAAQ,EAAE,CAAC;QAElC,oBAAe,GAAG,EAAE,CAAC;QAGpB,wBAAmB,GAAiB;YACxC,QAAQ,EAAE,IAAI,CAAC,eAAe;YAC9B,IAAI,EAAE,CAAC;YACP,WAAW,EAAE,IAAI;YACjB,KAAK,EAAE,EAAE;YACT,OAAO,EAAE,EAAE;YACX,YAAY,EAAE,EAAE;SACnB,CAAC;QACK,uBAAkB,GAA0B,EAAE,CAAC;IA4FtD,CAAC;IA1FD,IAAI,QAAQ;QACR,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC;SAC5C;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,IAAI,IAAI;QACJ,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC;SACxC;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC;IACxC,CAAC;IAED,IAAI,WAAW;QACX,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,WAAW,CAAC;SAC/C;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,CAAC;IAC/C,CAAC;IACD,IAAI,WAAW,CAAC,WAA6C;QACzD,IAAI,CAAC,WAAW,GAAG;YACf,WAAW;SACd,CAAC;IACN,CAAC;IAED,IAAI,KAAK;QACL,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC;SACzC;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,KAAK,CAAC;IACzC,CAAC;IACD,IAAI,KAAK,CAAC,KAAa;QACnB,IAAI,CAAC,WAAW,GAAG;YACf,KAAK;SACR,CAAC;IACN,CAAC;IAED,IAAI,OAAO;QACP,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC;SAC3C;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,OAAO,CAAC;IAC3C,CAAC;IACD,IAAI,OAAO,CAAC,OAAc;QACtB,IAAI,CAAC,WAAW,GAAG;YACf,OAAO;SACV,CAAC;IACN,CAAC;IAED,IAAI,YAAY;QACZ,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,IAAI,CAAC,mBAAmB,CAAC,YAAY,CAAC;SAChD;QAED,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC;IAChD,CAAC;IACD,IAAI,YAAY,CAAC,YAAmB;QAChC,IAAI,CAAC,WAAW,GAAG;YACf,YAAY;SACf,CAAC;IACN,CAAC;IAED,SAAS;IACT,IAAI,wBAAwB;QACxB,OAAO;YACH,GAAG,IAAI,CAAC,mBAAmB;YAC3B,GAAG,IAAI,CAAC,kBAAkB;YAC1B,QAAQ,EAAE,IAAI,CAAC,kBAAkB,EAAE,QAAQ,IAAI,IAAI,CAAC,eAAe;SACtE,CAAC;IACN,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE,CAAC;IAC1C,CAAC;IAED,IAAI,WAAW,CAAC,MAA6B;QACzC,IAAI,CAAC,eAAe,CAAC;YACjB,GAAG,IAAI,CAAC,WAAW;YACnB,GAAG,MAAM;SACZ,CAAC,CAAC;IACP,CAAC;IAMD,QAAQ;QACJ,IAAI,CAAC,YAAY,GAAG,IAAI,WAAW,CAAe;YAC9C,QAAQ,EAAE,IAAI,CAAC,wBAAwB,CAAC,QAAQ;YAChD,IAAI,EAAE,IAAI,CAAC,wBAAwB,CAAC,IAAI;YACxC,WAAW,EAAE,IAAI,CAAC,wBAAwB,CAAC,WAAW;YACtD,KAAK,EAAE,IAAI,CAAC,wBAAwB,CAAC,KAAK;YAC1C,OAAO,EAAE,IAAI,CAAC,wBAAwB,CAAC,OAAO;YAC9C,YAAY,EAAE,IAAI,CAAC,wBAAwB,CAAC,YAAY;SAC3D,CAA8B,CAAC;QAEhC,IAAI,CAAC,YAAY,CAAC,YAAY;aACzB,IAAI,CACD,cAAc,CAAC,IAAI,CAAC,EACpB,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,EAClC,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,EAC3D,MAAM,CAAC,CAAC,OAAY,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,EACnC,QAAQ,CAAC,CAAC,OAAO,EAAE,EAAE;YACjB,IAAI,OAAO,EAAE,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,KAAK,CAAC,EAAE;gBACtD,OAAO,KAAK,CAAC,GAAG,CAAC,CAAC;aACrB;YAED,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC,CAAC,EACF,MAAM,CACF,CAAC,OAAY,EAAE,EAAE,CACb,CAAC,CACG,OAAO,EAAE,QAAQ;YACjB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,MAAM,KAAK,CAAC,CACrC,CACR,CACJ;aACA,SAAS,CAAC,CAAC,OAAqB,EAAE,EAAE;YACjC,IAAI,OAAO,EAAE,IAAI,EAAE;gBACf,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAChB,OAAO;aACV;YAED,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC/B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAED,UAAU,CAAC,SAAS,GAAG,IAAI,EAAE,YAAY,GAAG,IAAI;QAC5C,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,wBAAwB,EAAE,SAAS,CAAC,CAAC;QAE/D,IAAI,YAAY,EAAE;YACd,IAAI,CAAC,QAAQ,EAAE,CAAC;SACnB;IACL,CAAC;IAED,gBAAgB,CAAC,SAAc,IAAI;QAC/B,MAAM,GAAG,MAAM,IAAI,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QAEzC,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,iBAAiB,CAC9C,MAAM,EACN,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,wBAAwB,CAChC,CAAC;QAEF,IAAI,WAAW,EAAE;YACb,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;SAClC;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,mBAA4B,KAAK;QAC9C,MAAM,MAAM,GAAQ,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;QAC1C,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;QAEpE,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;YACnC,IAAI,GAAG,KAAK,IAAI,CAAC,wBAAwB,EAAE;gBACvC,IAAI,gBAAgB,EAAE;oBAClB,MAAM,CAAC,GAAG,CAAC,GAAG,kBAAkB,CAAC,KAAK,CAAC;iBAC1C;gBACD,SAAS;aACZ;YAED,MAAM,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC;SAC3D;QAED,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACjC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAES,QAAQ;QACd,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IACpC,CAAC;IAEO,mBAAmB;QACvB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,IAAI,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC;YAC3C,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,EAAE,CAAC;IACpB,CAAC;IAEO,eAAe,CAAC,IAA2B,EAAE,SAAS,GAAG,IAAI;QACjE,IAAI,CAAC,YAAY,EAAE,QAAQ,CACvB;YACI,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK;YAC1B,GAAG,IAAI;SACV,EACD,EAAE,SAAS,EAAE,CAChB,CAAC;IACN,CAAC;IAEO,WAAW,CAAC,QAAsB,EAAE,IAAkB;QAC1D,MAAM,OAAO,GAA0B,EAAE,CAAC;QAE1C,IAAI,GAAuB,CAAC;QAC5B,KAAK,GAAG,IAAI,IAAI,EAAE;YACd,IAAI,GAAG,KAAK,cAAc,EAAE;gBACxB,SAAS;aACZ;YAED,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE;gBAC7D,aAAa;gBACb,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;aAC5B;SACJ;QAED,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;IACxD,CAAC;CACJ,CAAA;gHAtPqB,kBAAkB;oGAAlB,kBAAkB,2EAF1B,EAAE;AAEM,kBAAkB;IAJvC,YAAY,CAAC,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC;GAIlB,kBAAkB,CAsPvC;SAtPqB,kBAAkB;4FAAlB,kBAAkB;kBAHvC,SAAS;mBAAC;oBACP,QAAQ,EAAE,EAAE;iBACf","sourcesContent":["import { Component, OnInit } from '@angular/core';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { QuickFilter } from '@paperless/core';\nimport { timer } from 'rxjs';\nimport { debounce, filter, map, pairwise, startWith } from 'rxjs/operators';\nimport { createFormFilters } from '../utils';\nimport { FormBaseComponent } from './form.component';\n\nexport type TableQuickFilter = QuickFilter & {\n    value: string;\n    metricName?: string;\n};\n\nexport interface TableOptions {\n    pageSize: number;\n    page: number;\n    quickFilter: TableQuickFilter | string | null;\n    query: string;\n    filters: any[];\n    selectedRows: any[];\n}\n\n@UntilDestroy({ checkProperties: true })\n@Component({\n    template: ``,\n})\nexport abstract class BaseTableComponent\n    extends FormBaseComponent\n    implements OnInit\n{\n    protected quickFilters: any[] = [];\n\n    public filterForm: FormGroup<any> = new FormGroup<any>({});\n    public filterFormQuickFilterKey?: string;\n    public defaultFilterFormValues: any = {};\n\n    public pageSizeDefault = 12;\n    public tableOptions?: FormControl<TableOptions>;\n\n    private _defaultTableValues: TableOptions = {\n        pageSize: this.pageSizeDefault,\n        page: 1,\n        quickFilter: null,\n        query: '',\n        filters: [],\n        selectedRows: [],\n    };\n    public defaultTableValues: Partial<TableOptions> = {};\n\n    get pageSize() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.pageSize;\n        }\n\n        return this.tableOptions.value.pageSize;\n    }\n\n    get page() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.page;\n        }\n\n        return this.tableOptions.value.page;\n    }\n\n    get quickFilter() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.quickFilter;\n        }\n\n        return this.tableOptions.value.quickFilter;\n    }\n    set quickFilter(quickFilter: TableQuickFilter | string | null) {\n        this.tableValues = {\n            quickFilter,\n        };\n    }\n\n    get query() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.query;\n        }\n\n        return this.tableOptions.value.query;\n    }\n    set query(query: string) {\n        this.tableValues = {\n            query,\n        };\n    }\n\n    get filters() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.filters;\n        }\n\n        return this.tableOptions.value.filters;\n    }\n    set filters(filters: any[]) {\n        this.tableValues = {\n            filters,\n        };\n    }\n\n    get selectedRows() {\n        if (!this.tableOptions) {\n            return this._defaultTableValues.selectedRows;\n        }\n\n        return this.tableOptions.value.selectedRows;\n    }\n    set selectedRows(selectedRows: any[]) {\n        this.tableValues = {\n            selectedRows,\n        };\n    }\n\n    // setter\n    get parsedDefaultTableValues() {\n        return {\n            ...this._defaultTableValues,\n            ...this.defaultTableValues,\n            pageSize: this.defaultTableValues?.pageSize || this.pageSizeDefault,\n        };\n    }\n\n    get tableValues() {\n        return this.tableOptions?.value ?? {};\n    }\n\n    set tableValues(values: Partial<TableOptions>) {\n        this._setTableValues({\n            ...this.tableValues,\n            ...values,\n        });\n    }\n\n    constructor() {\n        super();\n    }\n\n    ngOnInit() {\n        this.tableOptions = new FormControl<TableOptions>({\n            pageSize: this.parsedDefaultTableValues.pageSize,\n            page: this.parsedDefaultTableValues.page,\n            quickFilter: this.parsedDefaultTableValues.quickFilter,\n            query: this.parsedDefaultTableValues.query,\n            filters: this.parsedDefaultTableValues.filters,\n            selectedRows: this.parsedDefaultTableValues.selectedRows,\n        }) as FormControl<TableOptions>;\n\n        this.tableOptions.valueChanges\n            .pipe(\n                untilDestroyed(this),\n                startWith(this.tableOptions.value),\n                pairwise(),\n                map(([previous, next]) => this._getChanges(previous, next)),\n                filter((changes: any) => !!changes),\n                debounce((changes) => {\n                    if (changes?.query && Object.keys(changes)?.length === 1) {\n                        return timer(300);\n                    }\n\n                    return timer(0);\n                }),\n                filter(\n                    (changes: any) =>\n                        !(\n                            changes?.selected &&\n                            Object.keys(changes)?.length === 1\n                        )\n                )\n            )\n            .subscribe((changes: TableOptions) => {\n                if (changes?.page) {\n                    this._refresh();\n                    return;\n                }\n\n                this._resetPageOrRefresh();\n            });\n\n        this._refresh();\n    }\n\n    resetTable(emitEvent = true, forceRefresh = null) {\n        this._setTableValues(this.parsedDefaultTableValues, emitEvent);\n\n        if (forceRefresh) {\n            this._refresh();\n        }\n    }\n\n    applyFormFilters(values: any = null) {\n        values = values ?? this.filterForm.value;\n\n        const { filters, quickFilter } = createFormFilters(\n            values,\n            this.quickFilters,\n            this.filterFormQuickFilterKey\n        );\n\n        if (quickFilter) {\n            this.quickFilter = quickFilter;\n        }\n\n        this.filters = filters;\n    }\n\n    resetFormFilters(resetQuickFilter: boolean = false) {\n        const values: any = this.filterForm.value;\n        const defaultQuickFilter = this.quickFilters.find((f) => f.default);\n\n        for (const key of Object.keys(values)) {\n            if (key === this.filterFormQuickFilterKey) {\n                if (resetQuickFilter) {\n                    values[key] = defaultQuickFilter.value;\n                }\n                continue;\n            }\n\n            values[key] = this.defaultFilterFormValues[key] ?? null;\n        }\n\n        this.filterForm.setValue(values);\n        this.applyFormFilters(values);\n    }\n\n    protected _refresh() {\n        console.warn('Not implemented');\n    }\n\n    private _resetPageOrRefresh() {\n        if (!this.tableOptions) {\n            return;\n        }\n\n        if (this.page !== 1) {\n            this.tableOptions.get('page')?.setValue(1);\n            return;\n        }\n\n        this._refresh();\n    }\n\n    private _setTableValues(data: Partial<TableOptions>, emitEvent = true) {\n        this.tableOptions?.setValue(\n            {\n                ...this.tableOptions.value,\n                ...data,\n            },\n            { emitEvent }\n        );\n    }\n\n    private _getChanges(previous: TableOptions, next: TableOptions) {\n        const changes: Partial<TableOptions> = {};\n\n        let key: keyof TableOptions;\n        for (key in next) {\n            if (key === 'selectedRows') {\n                continue;\n            }\n\n            if (JSON.stringify(previous[key]) !== JSON.stringify(next[key])) {\n                // @ts-ignore\n                changes[key] = next[key];\n            }\n        }\n\n        return Object.keys(changes).length ? changes : null;\n    }\n}\n"]}
@@ -6,7 +6,7 @@ export const createFormFilters = (values, quickFilters, quickFilterKey) => {
6
6
  if (key !== quickFilterKey && !value?.length) {
7
7
  continue;
8
8
  }
9
- if (key === quickFilterKey) {
9
+ if (quickFilterKey && key === quickFilterKey) {
10
10
  quickFilter = quickFilters.find((f) => f.value === value);
11
11
  continue;
12
12
  }
@@ -20,4 +20,4 @@ export const createFormFilters = (values, quickFilters, quickFilterKey) => {
20
20
  quickFilter,
21
21
  };
22
22
  };
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYXBlcmxlc3Mvc3JjL2xpYi9tb2R1bGVzL3RhYmxlL3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQzdCLE1BQThCLEVBQzlCLFlBQWdDLEVBQ2hDLGNBQXNCLEVBQ3hCLEVBQUU7SUFDQSxNQUFNLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDbkIsSUFBSSxXQUFXLEdBQUcsSUFBSSxDQUFDO0lBRXZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUNuQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUIsSUFBSSxHQUFHLEtBQUssY0FBYyxJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRTtZQUMxQyxTQUFTO1NBQ1o7UUFFRCxJQUFJLEdBQUcsS0FBSyxjQUFjLEVBQUU7WUFDeEIsV0FBVyxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxLQUFLLEtBQUssS0FBSyxDQUFDLENBQUM7WUFFMUQsU0FBUztTQUNaO1FBRUQsT0FBTyxDQUFDLElBQUksQ0FBQztZQUNULEdBQUc7WUFDSCxLQUFLO1NBQ1IsQ0FBQyxDQUFDO0tBQ047SUFFRCxPQUFPO1FBQ0gsT0FBTztRQUNQLFdBQVc7S0FDZCxDQUFDO0FBQ04sQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGFibGVRdWlja0ZpbHRlciB9IGZyb20gJy4vYmFzZSc7XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVGb3JtRmlsdGVycyA9IChcbiAgICB2YWx1ZXM6IHsgW2tleTogc3RyaW5nXTogYW55IH0sXG4gICAgcXVpY2tGaWx0ZXJzOiBUYWJsZVF1aWNrRmlsdGVyW10sXG4gICAgcXVpY2tGaWx0ZXJLZXk6IHN0cmluZ1xuKSA9PiB7XG4gICAgY29uc3QgZmlsdGVycyA9IFtdO1xuICAgIGxldCBxdWlja0ZpbHRlciA9IG51bGw7XG5cbiAgICBmb3IgKGNvbnN0IGtleSBvZiBPYmplY3Qua2V5cyh2YWx1ZXMpKSB7XG4gICAgICAgIGNvbnN0IHZhbHVlID0gdmFsdWVzW2tleV07XG4gICAgICAgIGlmIChrZXkgIT09IHF1aWNrRmlsdGVyS2V5ICYmICF2YWx1ZT8ubGVuZ3RoKSB7XG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgfVxuXG4gICAgICAgIGlmIChrZXkgPT09IHF1aWNrRmlsdGVyS2V5KSB7XG4gICAgICAgICAgICBxdWlja0ZpbHRlciA9IHF1aWNrRmlsdGVycy5maW5kKChmKSA9PiBmLnZhbHVlID09PSB2YWx1ZSk7XG5cbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICB9XG5cbiAgICAgICAgZmlsdGVycy5wdXNoKHtcbiAgICAgICAgICAgIGtleSxcbiAgICAgICAgICAgIHZhbHVlLFxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICByZXR1cm4ge1xuICAgICAgICBmaWx0ZXJzLFxuICAgICAgICBxdWlja0ZpbHRlcixcbiAgICB9O1xufTtcbiJdfQ==
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYXBlcmxlc3Mvc3JjL2xpYi9tb2R1bGVzL3RhYmxlL3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQzdCLE1BQThCLEVBQzlCLFlBQWdDLEVBQ2hDLGNBQXVCLEVBQ3pCLEVBQUU7SUFDQSxNQUFNLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDbkIsSUFBSSxXQUFXLEdBQUcsSUFBSSxDQUFDO0lBRXZCLEtBQUssTUFBTSxHQUFHLElBQUksTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsRUFBRTtRQUNuQyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDMUIsSUFBSSxHQUFHLEtBQUssY0FBYyxJQUFJLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRTtZQUMxQyxTQUFTO1NBQ1o7UUFFRCxJQUFJLGNBQWMsSUFBSSxHQUFHLEtBQUssY0FBYyxFQUFFO1lBQzFDLFdBQVcsR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxLQUFLLEtBQUssQ0FBQyxDQUFDO1lBRTFELFNBQVM7U0FDWjtRQUVELE9BQU8sQ0FBQyxJQUFJLENBQUM7WUFDVCxHQUFHO1lBQ0gsS0FBSztTQUNSLENBQUMsQ0FBQztLQUNOO0lBRUQsT0FBTztRQUNILE9BQU87UUFDUCxXQUFXO0tBQ2QsQ0FBQztBQUNOLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFRhYmxlUXVpY2tGaWx0ZXIgfSBmcm9tICcuL2Jhc2UnO1xuXG5leHBvcnQgY29uc3QgY3JlYXRlRm9ybUZpbHRlcnMgPSAoXG4gICAgdmFsdWVzOiB7IFtrZXk6IHN0cmluZ106IGFueSB9LFxuICAgIHF1aWNrRmlsdGVyczogVGFibGVRdWlja0ZpbHRlcltdLFxuICAgIHF1aWNrRmlsdGVyS2V5Pzogc3RyaW5nXG4pID0+IHtcbiAgICBjb25zdCBmaWx0ZXJzID0gW107XG4gICAgbGV0IHF1aWNrRmlsdGVyID0gbnVsbDtcblxuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHZhbHVlcykpIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSB2YWx1ZXNba2V5XTtcbiAgICAgICAgaWYgKGtleSAhPT0gcXVpY2tGaWx0ZXJLZXkgJiYgIXZhbHVlPy5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnRpbnVlO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKHF1aWNrRmlsdGVyS2V5ICYmIGtleSA9PT0gcXVpY2tGaWx0ZXJLZXkpIHtcbiAgICAgICAgICAgIHF1aWNrRmlsdGVyID0gcXVpY2tGaWx0ZXJzLmZpbmQoKGYpID0+IGYudmFsdWUgPT09IHZhbHVlKTtcblxuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cblxuICAgICAgICBmaWx0ZXJzLnB1c2goe1xuICAgICAgICAgICAga2V5LFxuICAgICAgICAgICAgdmFsdWUsXG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHJldHVybiB7XG4gICAgICAgIGZpbHRlcnMsXG4gICAgICAgIHF1aWNrRmlsdGVyLFxuICAgIH07XG59O1xuIl19
@@ -326,10 +326,35 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
326
326
  }]
327
327
  }] });
328
328
 
329
+ const createFormFilters = (values, quickFilters, quickFilterKey) => {
330
+ const filters = [];
331
+ let quickFilter = null;
332
+ for (const key of Object.keys(values)) {
333
+ const value = values[key];
334
+ if (key !== quickFilterKey && !(value === null || value === void 0 ? void 0 : value.length)) {
335
+ continue;
336
+ }
337
+ if (quickFilterKey && key === quickFilterKey) {
338
+ quickFilter = quickFilters.find((f) => f.value === value);
339
+ continue;
340
+ }
341
+ filters.push({
342
+ key,
343
+ value,
344
+ });
345
+ }
346
+ return {
347
+ filters,
348
+ quickFilter,
349
+ };
350
+ };
351
+
329
352
  let BaseTableComponent = class BaseTableComponent extends FormBaseComponent {
330
353
  constructor() {
331
354
  super();
332
355
  this.quickFilters = [];
356
+ this.filterForm = new FormGroup({});
357
+ this.defaultFilterFormValues = {};
333
358
  this.pageSizeDefault = 12;
334
359
  this._defaultTableValues = {
335
360
  pageSize: this.pageSizeDefault,
@@ -445,6 +470,30 @@ let BaseTableComponent = class BaseTableComponent extends FormBaseComponent {
445
470
  this._refresh();
446
471
  }
447
472
  }
473
+ applyFormFilters(values = null) {
474
+ values = values !== null && values !== void 0 ? values : this.filterForm.value;
475
+ const { filters, quickFilter } = createFormFilters(values, this.quickFilters, this.filterFormQuickFilterKey);
476
+ if (quickFilter) {
477
+ this.quickFilter = quickFilter;
478
+ }
479
+ this.filters = filters;
480
+ }
481
+ resetFormFilters(resetQuickFilter = false) {
482
+ var _a;
483
+ const values = this.filterForm.value;
484
+ const defaultQuickFilter = this.quickFilters.find((f) => f.default);
485
+ for (const key of Object.keys(values)) {
486
+ if (key === this.filterFormQuickFilterKey) {
487
+ if (resetQuickFilter) {
488
+ values[key] = defaultQuickFilter.value;
489
+ }
490
+ continue;
491
+ }
492
+ values[key] = (_a = this.defaultFilterFormValues[key]) !== null && _a !== void 0 ? _a : null;
493
+ }
494
+ this.filterForm.setValue(values);
495
+ this.applyFormFilters(values);
496
+ }
448
497
  _refresh() {
449
498
  console.warn('Not implemented');
450
499
  }
@@ -2895,29 +2944,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.10", ngImpo
2895
2944
  }]
2896
2945
  }] });
2897
2946
 
2898
- const createFormFilters = (values, quickFilters, quickFilterKey) => {
2899
- const filters = [];
2900
- let quickFilter = null;
2901
- for (const key of Object.keys(values)) {
2902
- const value = values[key];
2903
- if (key !== quickFilterKey && !(value === null || value === void 0 ? void 0 : value.length)) {
2904
- continue;
2905
- }
2906
- if (key === quickFilterKey) {
2907
- quickFilter = quickFilters.find((f) => f.value === value);
2908
- continue;
2909
- }
2910
- filters.push({
2911
- key,
2912
- value,
2913
- });
2914
- }
2915
- return {
2916
- filters,
2917
- quickFilter,
2918
- };
2919
- };
2920
-
2921
2947
  const SLIDE_IN_BOTTOM_OUT_TOP = trigger('pSlideInBottomOutTop', [
2922
2948
  transition(':enter', [
2923
2949
  style({ transform: 'translateY(50%)', opacity: 0 }),