@kovalenko/base-filter
TypeScript icon, indicating that this package has built-in type declarations

1.2.3 • Public • Published

BaseFilter

Install

npm i @kovalenko/base-filter

Setup

add import to polyfills.ts

import 'reflect-metadata';

Usage

Class BaseFilter

Protected static properties

key?

string

If set then query params will pe parsed from the key in query string. E.g.:
class MyFilter extends BaseFilter {
  protected static readonly key = 't';
}
defaultPage = 1 Default pagination page number
limitOptions?

number[]

Options for items per page, e.g. [10, 20, 30]

Constructor

limit

number

items per page
queryParams?

Observable

query Observable, e.g. Angular ActivatedRoute.queryParams. Optional, sets `query$` property. If omitted, the filter will be updated via internal observable `update$`

Public properties

updated$

Observable

readonly. Triggers when filter is being updated.
query$

Observable

readonly. Observes query params or internal changes.
page

number

Current pagination page. Updates from query string
limit

number

items per page
offset

number

getter for current pagination offset: `page * limit`

Public methods

clear
Clears all filter properties and changes the page to first
Parameters
No
Returns
void
changePage
Changes filter page
Parameters
pageIndex?
number
Index
Returns
void
updated
Triggers filter update
Parameters
No
Returns
void
toJSON
Returns a record of filter properties decorated with `@FilterProperty`
Parameters
No
Returns
Record<string, any>
toQueryParams
Returns a record of filter properties decorated with `@FilterProperty` for angular router, excluding limit
Parameters
No
Returns
Record<string, any>

Protected methods

transformParams
default query params transformation
Parameters
No
Returns
void
deleteProperties
default filter properties deletion
Parameters
No
Returns
void

Decorators

@FilterProperty(serialize?: SerializeFn)
PropertyDecorator
If set then query params will pe parsed from the key in query string. E.g.:
class MyFilter extends BaseFilter {
  protected static readonly key = 't';
}
@TransformBoolean()
PropertyDecorator
Transforms query param into boolean

https://path/to?param=true becomes {param: true}

@TransformArray()
PropertyDecorator
Transforms query param into boolean

https://path/to?param=test becomes {param: ['test']}

@TransformMoment()
PropertyDecorator
Transforms date param into moment.js object.

https://path/to?date=2020-10-10 becomes {param: Moment}

Class QsHttpParams

Class extending @angular/common/http/HttpParams to pass filter into angular http client.

this.http.get('api/v1/test', {params: new QsHttpParams(filter.toJSON())});

Example

Filter

import {BaseFilter} from '@kovalenko/base-filter';

export class TestFilter extends BaseFilter {
  @FilterProperty()
  title?: string;

  @FilterProperty()
  @TransformBoolean()
  hasParticipants?: boolean;

  @Type(() => Number)
  @TransformArray()
  @FilterProperty()
  campaign?: number[];

  @TransformMoment()
  @TransformArray()
  @FilterProperty((v: moment.Moment[]) => v?.map(ts => ts.format('YYYY-MM')))
  submittedAtFrom?: moment.Moment[];
}

Service

import type {TestFilter} from './test-filter';
import {QsHttpParams} from '@kovalenko/base-filter';

@Injectable()
export class PersonService {

  constructor(
    private http: HttpClient,
  ) { }

  list(flt: TestFilter): Observable<any> {
    return this.http.get('api/v1/test', {
      params: new QsHttpParams(flt.toJSON()),
    });
  }
}

Component

import {ActivatedRoute} from '@angular/router';
import {PersonService} from './person.service';
import {TestFilter} from './test-filter';

@Component({
  selector: 'some-component',
  template: 'hi',
})
export class ApplicationListComponent implements OnInit, OnDestroy {
  loading = false;

  filter = new TestFilter(100, this.route.queryParams);

  constructor(
    private route: ActivatedRoute,
    private personService: PersonService,
  ) { }

  ngOnInit(): void {
    this.filter.updated$.pipe(
      skip(1),
    ).subscribe(f => {
      this.router.navigate([], {
        queryParams: f.toQueryParams(),
        relativeTo: this.route,
        queryParamsHandling: 'merge',
      });
    });

    this.filter.query$.pipe(
      tap(() => this.loading = true),
      switchMap(f => this.personService.list(f)),
    ).subscribe();
  }
}

License

MIT

Readme

Keywords

Package Sidebar

Install

npm i @kovalenko/base-filter

Weekly Downloads

23

Version

1.2.3

License

MIT

Unpacked Size

90.6 kB

Total Files

24

Last publish

Collaborators

  • kovalenko