@bcgov/nr-ngx-component-lib 0.0.43 → 0.0.44

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.
@@ -33,6 +33,7 @@ export declare abstract class RowListBase<F, R, L = any> extends NrclBase implem
33
33
  private _filter?;
34
34
  get filter(): F;
35
35
  private _loadRowListRequest?;
36
+ constructor();
36
37
  ngAfterViewInit(): void;
37
38
  refreshRowList(): Promise<void>;
38
39
  abstract fetchRowListPage(): Observable<L>;
@@ -4,21 +4,6 @@ import { Aborted, ObservableAborter } from "../utils/row-list.util";
4
4
  import { NrclBase } from "./nrcl.base";
5
5
  import * as i0 from "@angular/core";
6
6
  export class RowListBase extends NrclBase {
7
- constructor() {
8
- super(...arguments);
9
- this.pageStateService = inject(PageStateService);
10
- this.changeDetectorRef = inject(ChangeDetectorRef);
11
- this.isLoadingChange = new EventEmitter();
12
- this._isLoading = false;
13
- this._rows = [];
14
- this._totalRowCount = 0;
15
- this._pageConfig = {
16
- pageSize: 0,
17
- pageNumber: 1,
18
- sortActive: '',
19
- sortDirection: 'asc'
20
- };
21
- }
22
7
  get isLoading() { return this._isLoading; }
23
8
  set isLoading(v) {
24
9
  if (v == this._isLoading)
@@ -33,10 +18,25 @@ export class RowListBase extends NrclBase {
33
18
  get sortActive() { return this._pageConfig.sortActive; }
34
19
  get sortDirection() { return this._pageConfig.sortDirection; }
35
20
  get filter() {
36
- return this._filter || {};
21
+ return this._filter;
37
22
  }
38
- ngAfterViewInit() {
23
+ constructor() {
24
+ super();
25
+ this.pageStateService = inject(PageStateService);
26
+ this.changeDetectorRef = inject(ChangeDetectorRef);
27
+ this.isLoadingChange = new EventEmitter();
28
+ this._isLoading = false;
29
+ this._rows = [];
30
+ this._totalRowCount = 0;
31
+ this._pageConfig = {
32
+ pageSize: 0,
33
+ pageNumber: 1,
34
+ sortActive: '',
35
+ sortDirection: 'asc'
36
+ };
39
37
  this.loadPageState();
38
+ }
39
+ ngAfterViewInit() {
40
40
  this.refreshRowList();
41
41
  }
42
42
  refreshRowList() {
@@ -122,12 +122,12 @@ export class RowListBase extends NrclBase {
122
122
  totalItems: this._totalRowCount
123
123
  };
124
124
  }
125
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
125
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
126
126
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: RowListBase, outputs: { isLoadingChange: "isLoadingChange" }, usesInheritance: true, ngImport: i0 }); }
127
127
  }
128
128
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, decorators: [{
129
129
  type: Directive
130
- }], propDecorators: { isLoadingChange: [{
130
+ }], ctorParameters: () => [], propDecorators: { isLoadingChange: [{
131
131
  type: Output
132
132
  }] } });
133
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row-list.base.js","sourceRoot":"","sources":["../../../../projects/nr-ngx-component-lib/src/directives/row-list.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Directive, EventEmitter, inject, Output } from \"@angular/core\";\nimport { Sort, SortDirection } from \"@angular/material/sort\";\nimport { Observable } from \"rxjs\";\nimport { PageStateService } from \"../services/page-state.service\";\nimport { Aborted, ObservableAborter } from \"../utils/row-list.util\";\nimport { NrclBase } from \"./nrcl.base\";\n\nexport type RowListPageConfig = {    \n    pageSize: number\n    pageNumber: number\n    sortActive: string \n    sortDirection: SortDirection\n}\n\nexport type RowListState<F> = { pageConfig: RowListPageConfig, filter: F }\n\n@Directive()\nexport abstract class RowListBase<F,R,L=any> extends NrclBase implements AfterViewInit {\n    pageStateService = inject( PageStateService )\n    changeDetectorRef = inject( ChangeDetectorRef )\n\n    @Output() isLoadingChange = new EventEmitter<boolean>()\n    \n    private _isLoading = false\n    get isLoading() { return this._isLoading }\n    set isLoading( v: boolean ) { \n        if ( v == this._isLoading ) return        \n        this._isLoading = v \n        this.isLoadingChange.emit( v )\n    }  \n\n    private _rows: R[] = []\n    get rows(): R[] { return this._rows }\n\n    private _totalRowCount: number = 0\n    get totalRowCount(): number { return this._totalRowCount }\n\n    private _pageConfig: RowListPageConfig = {\n        pageSize:       0,\n        pageNumber:     1,\n        sortActive:     '',\n        sortDirection:  'asc'\n    }\n    get pageSize(): number              { return this._pageConfig.pageSize }\n    get pageNumber(): number            { return this._pageConfig.pageNumber }\n    get sortActive(): string            { return this._pageConfig.sortActive }\n    get sortDirection(): SortDirection  { return this._pageConfig.sortDirection }\n\n    private _filter?: F\n    get filter(): F {\n        return this._filter || {} as F\n    }\n\n    private _loadRowListRequest?: ObservableAborter<L> \n\n    ngAfterViewInit(): void {\n        this.loadPageState()        \n        this.refreshRowList()\n    }\n\n    refreshRowList(): Promise<void> {\n        this.isLoading = true\n\n        if ( this._loadRowListRequest )\n            this._loadRowListRequest.abort()\n\n        this._loadRowListRequest = new ObservableAborter<L>( () => {        \n            return this.fetchRowListPage()\n        } )\n\n        return this._loadRowListRequest.promise\n            .then( res => {\n                this._totalRowCount = this.parseTotalRowCount( res )\n                this._rows = this.parseRows( res )\n            } )\n            .catch( ( e ) => {\n                if ( e instanceof Aborted ) return\n\n                this.loadRowListPageFailed( e )\n            } )\n            .finally( () => {\n                this.isLoading = false\n                this.changeDetectorRef.detectChanges()\n            } )\n    }\n\n    abstract fetchRowListPage(): Observable<L> \n    abstract parseRows( res: L ): R[] \n    \n    parseTotalRowCount( res: L ): number {\n        if ( 'totalRowCount' in (res as any) ) return (res as any)[ 'totalRowCount' ]\n\n        throw 'Missing res.totalRowCount, might need to override RowListBase.parseTotalRowCount'\n    }\n\n    loadRowListPageFailed( error: any ) {\n        console.warn( error )\n        this._rows = []\n        this._totalRowCount = 0\n    }\n\n    clone( obj: any ) {\n        return JSON.parse( JSON.stringify( obj ) ) \n    }\n\n    onFilterChange( ev: F ) {\n        this._filter = this.clone( ev )\n        this.onPageNumberChange( 1 )\n    }\n\n    onSortChange( ev: Sort ) {\n        this._pageConfig.sortActive = ev.active\n        this._pageConfig.sortDirection = ev.direction\n        this.onPageNumberChange( 1 )\n    }\n\n    onPageSizeChange( ev: number ) {\n        this._pageConfig.pageSize = ev \n        this.onPageNumberChange( 1 )\n    }\n\n    onPageNumberChange( ev: number ) {\n        this._pageConfig.pageNumber = ev\n\n        this.refreshRowList()\n            .then( () => {\n                this.savePageState()\n            } )\n    }\n\n    abstract get initialPageState(): RowListState<F>\n\n    loadPageState() {\n        let state = this.pageStateService.getPageState<RowListState<F>>( this.constructor, () => this.initialPageState )\n\n        this._filter = state.filter\n        this._pageConfig.pageSize = state.pageConfig.pageSize\n        this._pageConfig.pageNumber = state.pageConfig.pageNumber\n        this._pageConfig.sortActive = state.pageConfig.sortActive\n        this._pageConfig.sortDirection = state.pageConfig.sortDirection\n    }\n\n    savePageState() {\n        let state: RowListState<F> = this.clone( {            \n            filter: this._filter,\n            pageConfig: {\n                pageSize: this._pageConfig.pageSize,\n                pageNumber: this._pageConfig.pageNumber,\n                sortActive: this._pageConfig.sortActive,\n                sortDirection: this._pageConfig.sortDirection,\n            }\n        } ) \n        \n        this.pageStateService.setPageState<RowListState<F>>( this.constructor, state )\n    }\n\n    paginateState( id: string ) {\n        return {\n            id,\n            itemsPerPage: this._pageConfig.pageSize,\n            currentPage: this._pageConfig.pageNumber,\n            totalItems: this._totalRowCount\n        }\n    }\n}\n"]}
133
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row-list.base.js","sourceRoot":"","sources":["../../../../projects/nr-ngx-component-lib/src/directives/row-list.base.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Directive, EventEmitter, inject, Output } from \"@angular/core\";\nimport { Sort, SortDirection } from \"@angular/material/sort\";\nimport { Observable } from \"rxjs\";\nimport { PageStateService } from \"../services/page-state.service\";\nimport { Aborted, ObservableAborter } from \"../utils/row-list.util\";\nimport { NrclBase } from \"./nrcl.base\";\n\nexport type RowListPageConfig = {    \n    pageSize: number\n    pageNumber: number\n    sortActive: string \n    sortDirection: SortDirection\n}\n\nexport type RowListState<F> = { pageConfig: RowListPageConfig, filter: F }\n\n@Directive()\nexport abstract class RowListBase<F,R,L=any> extends NrclBase implements AfterViewInit {\n    pageStateService = inject( PageStateService )\n    changeDetectorRef = inject( ChangeDetectorRef )\n\n    @Output() isLoadingChange = new EventEmitter<boolean>()\n    \n    private _isLoading = false\n    get isLoading() { return this._isLoading }\n    set isLoading( v: boolean ) { \n        if ( v == this._isLoading ) return        \n        this._isLoading = v \n        this.isLoadingChange.emit( v )\n    }  \n\n    private _rows: R[] = []\n    get rows(): R[] { return this._rows }\n\n    private _totalRowCount: number = 0\n    get totalRowCount(): number { return this._totalRowCount }\n\n    private _pageConfig: RowListPageConfig = {\n        pageSize:       0,\n        pageNumber:     1,\n        sortActive:     '',\n        sortDirection:  'asc'\n    }\n    get pageSize(): number              { return this._pageConfig.pageSize }\n    get pageNumber(): number            { return this._pageConfig.pageNumber }\n    get sortActive(): string            { return this._pageConfig.sortActive }\n    get sortDirection(): SortDirection  { return this._pageConfig.sortDirection }\n\n    private _filter?: F\n    get filter(): F {\n        return this._filter as F\n    }\n\n    private _loadRowListRequest?: ObservableAborter<L> \n\n    constructor() {\n        super()\n        this.loadPageState()        \n    }\n\n    ngAfterViewInit(): void {\n        this.refreshRowList()\n    }\n\n    refreshRowList(): Promise<void> {\n        this.isLoading = true\n\n        if ( this._loadRowListRequest )\n            this._loadRowListRequest.abort()\n\n        this._loadRowListRequest = new ObservableAborter<L>( () => {        \n            return this.fetchRowListPage()\n        } )\n\n        return this._loadRowListRequest.promise\n            .then( res => {\n                this._totalRowCount = this.parseTotalRowCount( res )\n                this._rows = this.parseRows( res )\n            } )\n            .catch( ( e ) => {\n                if ( e instanceof Aborted ) return\n\n                this.loadRowListPageFailed( e )\n            } )\n            .finally( () => {\n                this.isLoading = false\n                this.changeDetectorRef.detectChanges()\n            } )\n    }\n\n    abstract fetchRowListPage(): Observable<L> \n    abstract parseRows( res: L ): R[] \n    \n    parseTotalRowCount( res: L ): number {\n        if ( 'totalRowCount' in (res as any) ) return (res as any)[ 'totalRowCount' ]\n\n        throw 'Missing res.totalRowCount, might need to override RowListBase.parseTotalRowCount'\n    }\n\n    loadRowListPageFailed( error: any ) {\n        console.warn( error )\n        this._rows = []\n        this._totalRowCount = 0\n    }\n\n    clone( obj: any ) {\n        return JSON.parse( JSON.stringify( obj ) ) \n    }\n\n    onFilterChange( ev: F ) {\n        this._filter = this.clone( ev )\n        this.onPageNumberChange( 1 )\n    }\n\n    onSortChange( ev: Sort ) {\n        this._pageConfig.sortActive = ev.active\n        this._pageConfig.sortDirection = ev.direction\n        this.onPageNumberChange( 1 )\n    }\n\n    onPageSizeChange( ev: number ) {\n        this._pageConfig.pageSize = ev \n        this.onPageNumberChange( 1 )\n    }\n\n    onPageNumberChange( ev: number ) {\n        this._pageConfig.pageNumber = ev\n\n        this.refreshRowList()\n            .then( () => {\n                this.savePageState()\n            } )\n    }\n\n    abstract get initialPageState(): RowListState<F>\n\n    loadPageState() {\n        let state = this.pageStateService.getPageState<RowListState<F>>( this.constructor, () => this.initialPageState )\n\n        this._filter = state.filter\n        this._pageConfig.pageSize = state.pageConfig.pageSize\n        this._pageConfig.pageNumber = state.pageConfig.pageNumber\n        this._pageConfig.sortActive = state.pageConfig.sortActive\n        this._pageConfig.sortDirection = state.pageConfig.sortDirection\n    }\n\n    savePageState() {\n        let state: RowListState<F> = this.clone( {            \n            filter: this._filter,\n            pageConfig: {\n                pageSize: this._pageConfig.pageSize,\n                pageNumber: this._pageConfig.pageNumber,\n                sortActive: this._pageConfig.sortActive,\n                sortDirection: this._pageConfig.sortDirection,\n            }\n        } ) \n        \n        this.pageStateService.setPageState<RowListState<F>>( this.constructor, state )\n    }\n\n    paginateState( id: string ) {\n        return {\n            id,\n            itemsPerPage: this._pageConfig.pageSize,\n            currentPage: this._pageConfig.pageNumber,\n            totalItems: this._totalRowCount\n        }\n    }\n}\n"]}
@@ -1300,21 +1300,6 @@ class ObservableAborter {
1300
1300
  }
1301
1301
 
1302
1302
  class RowListBase extends NrclBase {
1303
- constructor() {
1304
- super(...arguments);
1305
- this.pageStateService = inject(PageStateService);
1306
- this.changeDetectorRef = inject(ChangeDetectorRef);
1307
- this.isLoadingChange = new EventEmitter();
1308
- this._isLoading = false;
1309
- this._rows = [];
1310
- this._totalRowCount = 0;
1311
- this._pageConfig = {
1312
- pageSize: 0,
1313
- pageNumber: 1,
1314
- sortActive: '',
1315
- sortDirection: 'asc'
1316
- };
1317
- }
1318
1303
  get isLoading() { return this._isLoading; }
1319
1304
  set isLoading(v) {
1320
1305
  if (v == this._isLoading)
@@ -1329,10 +1314,25 @@ class RowListBase extends NrclBase {
1329
1314
  get sortActive() { return this._pageConfig.sortActive; }
1330
1315
  get sortDirection() { return this._pageConfig.sortDirection; }
1331
1316
  get filter() {
1332
- return this._filter || {};
1317
+ return this._filter;
1333
1318
  }
1334
- ngAfterViewInit() {
1319
+ constructor() {
1320
+ super();
1321
+ this.pageStateService = inject(PageStateService);
1322
+ this.changeDetectorRef = inject(ChangeDetectorRef);
1323
+ this.isLoadingChange = new EventEmitter();
1324
+ this._isLoading = false;
1325
+ this._rows = [];
1326
+ this._totalRowCount = 0;
1327
+ this._pageConfig = {
1328
+ pageSize: 0,
1329
+ pageNumber: 1,
1330
+ sortActive: '',
1331
+ sortDirection: 'asc'
1332
+ };
1335
1333
  this.loadPageState();
1334
+ }
1335
+ ngAfterViewInit() {
1336
1336
  this.refreshRowList();
1337
1337
  }
1338
1338
  refreshRowList() {
@@ -1418,12 +1418,12 @@ class RowListBase extends NrclBase {
1418
1418
  totalItems: this._totalRowCount
1419
1419
  };
1420
1420
  }
1421
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
1421
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
1422
1422
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.14", type: RowListBase, outputs: { isLoadingChange: "isLoadingChange" }, usesInheritance: true, ngImport: i0 }); }
1423
1423
  }
1424
1424
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: RowListBase, decorators: [{
1425
1425
  type: Directive
1426
- }], propDecorators: { isLoadingChange: [{
1426
+ }], ctorParameters: () => [], propDecorators: { isLoadingChange: [{
1427
1427
  type: Output
1428
1428
  }] } });
1429
1429