@elderbyte/ngx-starter 16.3.3 → 16.4.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/esm2022/lib/common/data/data-context/data-context-active-page.mjs +5 -5
- package/esm2022/lib/common/data/data-context/data-context-auto-starter.mjs +2 -2
- package/esm2022/lib/common/data/data-context/data-context-base.mjs +58 -28
- package/esm2022/lib/common/data/data-context/data-context-continuable-base.mjs +7 -7
- package/esm2022/lib/common/data/data-context/data-context-continuable-paged.mjs +10 -10
- package/esm2022/lib/common/data/data-context/data-context-continuable-token.mjs +8 -8
- package/esm2022/lib/common/data/data-context/data-context-simple.mjs +6 -5
- package/esm2022/lib/common/data/data-context/data-context-source-event-binding.mjs +2 -2
- package/esm2022/lib/common/data/data-context/data-context.mjs +1 -1
- package/esm2022/lib/common/data/filters/filter-context.mjs +12 -26
- package/esm2022/lib/common/data/sort-context.mjs +2 -2
- package/esm2022/lib/common/utils/filter-util.mjs +55 -1
- package/esm2022/lib/components/data-view/table/elder-table/elder-table.component.mjs +2 -2
- package/esm2022/lib/components/forms/search/domain/context/search-context.mjs +52 -0
- package/esm2022/lib/components/forms/search/domain/context/search-context.service.mjs +42 -0
- package/esm2022/lib/components/forms/search/domain/input/search-input-state.mjs +81 -0
- package/esm2022/lib/components/forms/search/domain/input/search-input.mjs +2 -0
- package/esm2022/lib/components/forms/search/domain/url/elder-search-url.directive.mjs +74 -0
- package/esm2022/lib/components/forms/search/domain/url/elder-search-url.service.mjs +162 -0
- package/esm2022/lib/components/forms/search/domain/url/search-query-params-parser.mjs +81 -0
- package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +92 -47
- package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +6 -5
- package/esm2022/lib/components/forms/search/elder-search.module.mjs +30 -9
- package/fesm2022/elderbyte-ngx-starter.mjs +664 -395
- package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/common/data/data-context/data-context-base.d.ts +10 -3
- package/lib/common/data/data-context/data-context.d.ts +6 -1
- package/lib/common/data/filters/filter-context.d.ts +1 -6
- package/lib/common/utils/filter-util.d.ts +3 -0
- package/lib/components/forms/search/domain/context/search-context.d.ts +37 -0
- package/lib/components/forms/search/domain/context/search-context.service.d.ts +25 -0
- package/lib/components/forms/search/{elder-search-context-url-binding.directive.d.ts → domain/url/elder-search-url.directive.d.ts} +13 -14
- package/lib/components/forms/search/domain/url/elder-search-url.service.d.ts +60 -0
- package/lib/components/forms/search/domain/url/search-query-params-parser.d.ts +36 -0
- package/lib/components/forms/search/elder-search-context.directive.d.ts +34 -14
- package/lib/components/forms/search/elder-search-input.directive.d.ts +2 -2
- package/lib/components/forms/search/elder-search.module.d.ts +5 -3
- package/package.json +1 -1
- package/esm2022/lib/components/forms/search/elder-search-context-url-binding.directive.mjs +0 -72
- package/esm2022/lib/components/forms/search/model/search-input-state.mjs +0 -81
- package/esm2022/lib/components/forms/search/model/search-input.mjs +0 -2
- package/esm2022/lib/components/forms/search/search-box/elder-search-context-filters.mjs +0 -10
- package/esm2022/lib/components/forms/search/search-box/elder-search-url-binding.service.mjs +0 -184
- package/lib/components/forms/search/search-box/elder-search-context-filters.d.ts +0 -7
- package/lib/components/forms/search/search-box/elder-search-url-binding.service.d.ts +0 -74
- /package/lib/components/forms/search/{model → domain/input}/search-input-state.d.ts +0 -0
- /package/lib/components/forms/search/{model → domain/input}/search-input.d.ts +0 -0
|
@@ -23,7 +23,7 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
23
23
|
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
24
24
|
this._pageCache = new Map();
|
|
25
25
|
this._latestPage = 0;
|
|
26
|
-
this._hasMoreData = combineLatest([this.total, this.data]).pipe(map(([total, data]) => this.checkHasMoreData(total, data)), takeUntil(this.
|
|
26
|
+
this._hasMoreData = combineLatest([this.total, this.data]).pipe(map(([total, data]) => this.checkHasMoreData(total, data)), takeUntil(this.destroy$));
|
|
27
27
|
}
|
|
28
28
|
/***************************************************************************
|
|
29
29
|
* *
|
|
@@ -45,7 +45,7 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
45
45
|
*/
|
|
46
46
|
loadMore() {
|
|
47
47
|
if (this.hasMoreDataSnapshot) {
|
|
48
|
-
this.logger.info('Loading more...' + this._latestPage);
|
|
48
|
+
this.logger.info(this.id + ': Loading more...' + this._latestPage);
|
|
49
49
|
if (this.loadingSnapshot) {
|
|
50
50
|
return EMPTY;
|
|
51
51
|
}
|
|
@@ -53,7 +53,7 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
53
53
|
return this.fetchPage(nextPage, this.chunkSize);
|
|
54
54
|
}
|
|
55
55
|
else {
|
|
56
|
-
this.logger.debug('Cannot load more data, since no more data available.');
|
|
56
|
+
this.logger.debug(this.id + ': Cannot load more data, since no more data available.');
|
|
57
57
|
return EMPTY;
|
|
58
58
|
}
|
|
59
59
|
}
|
|
@@ -75,7 +75,7 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
75
75
|
return false;
|
|
76
76
|
}
|
|
77
77
|
onChunkSizeChanged(newSize) {
|
|
78
|
-
this.reload();
|
|
78
|
+
this.reload('ChunkSizeChanged');
|
|
79
79
|
}
|
|
80
80
|
reloadInternal() {
|
|
81
81
|
// Since continuable data-contexts are appending data,
|
|
@@ -93,16 +93,16 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
93
93
|
const pageRequest = new Pageable(pageIndex, pageSize, this.sort.sortsSnapshot);
|
|
94
94
|
if (this._pageCache.has(pageIndex)) {
|
|
95
95
|
// Page already loaded - skipping request!
|
|
96
|
-
this.logger.trace('Skipping fetching page since its already in page observable cache.');
|
|
96
|
+
this.logger.trace(this.id + ': Skipping fetching page since its already in page observable cache.');
|
|
97
97
|
subject.next();
|
|
98
98
|
}
|
|
99
99
|
else {
|
|
100
100
|
this.onLoading();
|
|
101
|
-
this.logger.debug(
|
|
101
|
+
this.logger.debug(this.id + `: Loading page ${pageIndex} using pageable:`, pageRequest);
|
|
102
102
|
const pageObs = this.dataSource.findAllPaged(pageRequest, this.filter.filtersSnapshot);
|
|
103
103
|
this._pageCache.set(pageIndex, pageObs);
|
|
104
104
|
pageObs.subscribe((page) => {
|
|
105
|
-
this.logger.debug('Got page data:', page);
|
|
105
|
+
this.logger.debug(this.id + ': Got page data:', page);
|
|
106
106
|
this.populatePageData(page, clear);
|
|
107
107
|
if (this._latestPage < page.number) {
|
|
108
108
|
this._latestPage = page.number; // TODO This might cause that pages are skipped
|
|
@@ -113,7 +113,7 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
113
113
|
this.onError(err);
|
|
114
114
|
this.clearData();
|
|
115
115
|
this.setTotal(0);
|
|
116
|
-
this.logger.error('Failed to query data', err);
|
|
116
|
+
this.logger.error(this.id + ': Failed to query data', err);
|
|
117
117
|
subject.error(err);
|
|
118
118
|
});
|
|
119
119
|
}
|
|
@@ -135,8 +135,8 @@ export class DataContextContinuablePaged extends DataContextContinuableBase {
|
|
|
135
135
|
}
|
|
136
136
|
catch (err) {
|
|
137
137
|
this.onError(err);
|
|
138
|
-
this.logger.error('Failed to populate data with page', page, err);
|
|
138
|
+
this.logger.error(this.id + ': Failed to populate data with page', page, err);
|
|
139
139
|
}
|
|
140
140
|
}
|
|
141
141
|
}
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-continuable-paged.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-continuable-paged.ts"],"names":[],"mappings":"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","sourcesContent":["import {combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {Page, Pageable} from '../page';\nimport {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {DataContextContinuableBase} from './data-context-continuable-base';\nimport {first, map, takeUntil} from 'rxjs/operators';\nimport {Sort} from '../sort';\nimport {IPagedDataSource} from '../datasource/data-source';\n\n/**\n * Extends a simple flat list data-context with infinite-scroll pagination support.\n *\n */\nexport class DataContextContinuablePaged<T> extends DataContextContinuableBase<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _pageCache: Map<number, Observable<Page<T>>> = new Map();\n  private _latestPage = 0;\n\n  private readonly _hasMoreData: Observable<boolean>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructors                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataSource: IPagedDataSource<T>,\n    pageSize: number,\n    indexFn: ((item: T) => any),\n    localApply: ((data: T[]) => T[]),\n    localSort: ((data: T[], sorts: Sort[]) => T[])\n  ) {\n    super(dataSource, pageSize, indexFn, localApply, localSort);\n\n    this._hasMoreData = combineLatest([this.total, this.data]).pipe(\n      map(([total, data]) => this.checkHasMoreData(total, data)),\n      takeUntil(this.unsubscribe$)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IPagedDataSource<T> {\n    return <IPagedDataSource<T>>super.dataSource;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Load the next chunk of data.\n   * Useful for infinite scroll like data flows.\n   *\n   */\n  public loadMore(): Observable<any> {\n    if (this.hasMoreDataSnapshot) {\n      this.logger.info('Loading more...' + this._latestPage);\n\n      if (this.loadingSnapshot) {\n        return EMPTY;\n      }\n      const nextPage = this._latestPage + 1;\n      return this.fetchPage(nextPage, this.chunkSize);\n    } else {\n      this.logger.debug('Cannot load more data, since no more data available.');\n      return EMPTY;\n    }\n  }\n\n  public get hasMoreData(): Observable<boolean> {\n    return this._hasMoreData;\n  }\n\n  public get hasMoreDataSnapshot(): boolean {\n    return this.checkHasMoreData(this.totalSnapshot, this.dataSnapshot);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private checkHasMoreData(total: number | undefined, data: T[]): boolean {\n    if (total) {\n      return total > data.length;\n    }\n    return false;\n  }\n\n  protected onChunkSizeChanged(newSize: number): void {\n    this.reload();\n  }\n\n  protected reloadInternal(): Observable<any> {\n    // Since continuable data-contexts are appending data,\n    // we need to clear it for a reload.\n    this.clearAll(true);\n    return this.fetchPage(0, this.chunkSize, true);\n  }\n\n  protected clearAll(silent = false): void {\n    super.clearAll(silent);\n    this._pageCache = new Map();\n    this._latestPage = 0;\n  }\n\n  private fetchPage(pageIndex: number, pageSize: number, clear = false): Observable<any> {\n\n    const subject = new Subject<void>();\n\n    const pageRequest = new Pageable(pageIndex, pageSize, this.sort.sortsSnapshot);\n\n    if (this._pageCache.has(pageIndex)) {\n      // Page already loaded - skipping request!\n      this.logger.trace('Skipping fetching page since its already in page observable cache.');\n      subject.next();\n    } else {\n\n      this.onLoading();\n\n      this.logger.debug(`Loading page ${pageIndex} using pageable:`, pageRequest);\n\n      const pageObs = this.dataSource.findAllPaged(pageRequest, this.filter.filtersSnapshot);\n\n      this._pageCache.set(pageIndex, pageObs);\n\n      pageObs.subscribe((page: Page<T>) => {\n\n\n        this.logger.debug('Got page data:', page);\n\n        this.populatePageData(page, clear);\n\n        if (this._latestPage < page.number) {\n          this._latestPage = page.number; // TODO This might cause that pages are skipped\n        }\n\n        subject.next();\n        this.onIdle();\n      }, err => {\n        this.onError(err);\n        this.clearData();\n        this.setTotal(0);\n        this.logger.error('Failed to query data', err);\n        subject.error(err);\n      });\n    }\n\n    return subject.pipe(first());\n  }\n\n  /**\n   * Load the data from the given page into the current data context\n   */\n  private populatePageData(page: Page<T>, clear: boolean): void {\n    try {\n      this.setTotal(page.totalElements);\n      const start = page.number * page.size;\n      if (clear) {\n        this.setData(page.content);\n      } else {\n        this.insertData(page.content, start);\n      }\n    } catch (err) {\n      this.onError(err);\n      this.logger.error('Failed to populate data with page', page, err);\n    }\n  }\n}\n"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-continuable-paged.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-continuable-paged.ts"],"names":[],"mappings":"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","sourcesContent":["import {combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {Page, Pageable} from '../page';\nimport {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {DataContextContinuableBase} from './data-context-continuable-base';\nimport {first, map, takeUntil} from 'rxjs/operators';\nimport {Sort} from '../sort';\nimport {IPagedDataSource} from '../datasource/data-source';\n\n/**\n * Extends a simple flat list data-context with infinite-scroll pagination support.\n *\n */\nexport class DataContextContinuablePaged<T> extends DataContextContinuableBase<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private _pageCache: Map<number, Observable<Page<T>>> = new Map();\n  private _latestPage = 0;\n\n  private readonly _hasMoreData: Observable<boolean>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructors                                                            *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataSource: IPagedDataSource<T>,\n    pageSize: number,\n    indexFn: ((item: T) => any),\n    localApply: ((data: T[]) => T[]),\n    localSort: ((data: T[], sorts: Sort[]) => T[])\n  ) {\n    super(dataSource, pageSize, indexFn, localApply, localSort);\n\n    this._hasMoreData = combineLatest([this.total, this.data]).pipe(\n      map(([total, data]) => this.checkHasMoreData(total, data)),\n      takeUntil(this.destroy$)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IPagedDataSource<T> {\n    return <IPagedDataSource<T>>super.dataSource;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Load the next chunk of data.\n   * Useful for infinite scroll like data flows.\n   *\n   */\n  public loadMore(): Observable<any> {\n    if (this.hasMoreDataSnapshot) {\n      this.logger.info(this.id +': Loading more...' + this._latestPage);\n\n      if (this.loadingSnapshot) {\n        return EMPTY;\n      }\n      const nextPage = this._latestPage + 1;\n      return this.fetchPage(nextPage, this.chunkSize);\n    } else {\n      this.logger.debug(this.id +': Cannot load more data, since no more data available.');\n      return EMPTY;\n    }\n  }\n\n  public get hasMoreData(): Observable<boolean> {\n    return this._hasMoreData;\n  }\n\n  public get hasMoreDataSnapshot(): boolean {\n    return this.checkHasMoreData(this.totalSnapshot, this.dataSnapshot);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private checkHasMoreData(total: number | undefined, data: T[]): boolean {\n    if (total) {\n      return total > data.length;\n    }\n    return false;\n  }\n\n  protected onChunkSizeChanged(newSize: number): void {\n    this.reload('ChunkSizeChanged');\n  }\n\n  protected reloadInternal(): Observable<any> {\n    // Since continuable data-contexts are appending data,\n    // we need to clear it for a reload.\n    this.clearAll(true);\n    return this.fetchPage(0, this.chunkSize, true);\n  }\n\n  protected clearAll(silent = false): void {\n    super.clearAll(silent);\n    this._pageCache = new Map();\n    this._latestPage = 0;\n  }\n\n  private fetchPage(pageIndex: number, pageSize: number, clear = false): Observable<any> {\n\n    const subject = new Subject<void>();\n\n    const pageRequest = new Pageable(pageIndex, pageSize, this.sort.sortsSnapshot);\n\n    if (this._pageCache.has(pageIndex)) {\n      // Page already loaded - skipping request!\n      this.logger.trace(this.id +': Skipping fetching page since its already in page observable cache.');\n      subject.next();\n    } else {\n\n      this.onLoading();\n\n      this.logger.debug(this.id +`: Loading page ${pageIndex} using pageable:`, pageRequest);\n\n      const pageObs = this.dataSource.findAllPaged(pageRequest, this.filter.filtersSnapshot);\n\n      this._pageCache.set(pageIndex, pageObs);\n\n      pageObs.subscribe((page: Page<T>) => {\n\n\n        this.logger.debug(this.id +': Got page data:', page);\n\n        this.populatePageData(page, clear);\n\n        if (this._latestPage < page.number) {\n          this._latestPage = page.number; // TODO This might cause that pages are skipped\n        }\n\n        subject.next();\n        this.onIdle();\n      }, err => {\n        this.onError(err);\n        this.clearData();\n        this.setTotal(0);\n        this.logger.error(this.id +': Failed to query data', err);\n        subject.error(err);\n      });\n    }\n\n    return subject.pipe(first());\n  }\n\n  /**\n   * Load the data from the given page into the current data context\n   */\n  private populatePageData(page: Page<T>, clear: boolean): void {\n    try {\n      this.setTotal(page.totalElements);\n      const start = page.number * page.size;\n      if (clear) {\n        this.setData(page.content);\n      } else {\n        this.insertData(page.content, start);\n      }\n    } catch (err) {\n      this.onError(err);\n      this.logger.error(this.id +': Failed to populate data with page', page, err);\n    }\n  }\n}\n"]}
|
|
@@ -42,7 +42,7 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
42
42
|
}
|
|
43
43
|
loadMore() {
|
|
44
44
|
if (this.loadingSnapshot) {
|
|
45
|
-
this.logger.debug('Skipping load-more since already loading a chunk!');
|
|
45
|
+
this.logger.debug(this.id + ': Skipping load-more since already loading a chunk!');
|
|
46
46
|
return EMPTY;
|
|
47
47
|
}
|
|
48
48
|
const token = this._expectedChunkToken;
|
|
@@ -50,7 +50,7 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
50
50
|
return this.fetchNextChunk(token);
|
|
51
51
|
}
|
|
52
52
|
else {
|
|
53
|
-
this.logger.debug('Cannot load more data, since no more data available.');
|
|
53
|
+
this.logger.debug(this.id + ': Cannot load more data, since no more data available.');
|
|
54
54
|
return EMPTY;
|
|
55
55
|
}
|
|
56
56
|
}
|
|
@@ -75,7 +75,7 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
75
75
|
const subject = new Subject();
|
|
76
76
|
nextToken = nextToken ? nextToken : undefined;
|
|
77
77
|
if (this._chunkCache.has(nextToken)) {
|
|
78
|
-
this.logger.debug('Skipping fetching chunk for token "' + nextToken + '" since its already in observable cache.');
|
|
78
|
+
this.logger.debug(this.id + ': Skipping fetching chunk for token "' + nextToken + '" since its already in observable cache.');
|
|
79
79
|
subject.complete();
|
|
80
80
|
}
|
|
81
81
|
else {
|
|
@@ -84,7 +84,7 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
84
84
|
this.dataSource.findAllContinuable(new TokenChunkRequest(nextToken, this.filter.filtersSnapshot, this.sort.sortsSnapshot))
|
|
85
85
|
.pipe(first())
|
|
86
86
|
.subscribe(chunk => {
|
|
87
|
-
this.logger.debug('Got next chunk data:', chunk);
|
|
87
|
+
this.logger.debug(this.id + ': Got next chunk data:', chunk);
|
|
88
88
|
this._hasMoreData.next(chunk.hasMore);
|
|
89
89
|
this.chunkSize = chunk.chunkSize;
|
|
90
90
|
this.populateChunkData(chunk);
|
|
@@ -92,7 +92,7 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
92
92
|
this.onIdle();
|
|
93
93
|
}, err => {
|
|
94
94
|
this.onError(err);
|
|
95
|
-
this.logger.error('Failed to query data', err);
|
|
95
|
+
this.logger.error(this.id + ': Failed to query data', err);
|
|
96
96
|
this.clearData();
|
|
97
97
|
this.setTotal(0);
|
|
98
98
|
subject.error(err);
|
|
@@ -117,12 +117,12 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
117
117
|
}
|
|
118
118
|
catch (err) {
|
|
119
119
|
this.onError(err);
|
|
120
|
-
this.logger.error('Failed to populate data with chunk', chunk, err);
|
|
120
|
+
this.logger.error(this.id + ': Failed to populate data with chunk', chunk, err);
|
|
121
121
|
}
|
|
122
122
|
this._expectedChunkToken = chunk.nextContinuationToken;
|
|
123
123
|
}
|
|
124
124
|
else {
|
|
125
|
-
this.logger.warn('Discarding continuable chunk (items: ' + chunk.content.length + ', token: ' + chunk.continuationToken + ' )' +
|
|
125
|
+
this.logger.warn(this.id + ': Discarding continuable chunk (items: ' + chunk.content.length + ', token: ' + chunk.continuationToken + ' )' +
|
|
126
126
|
' as it does not match the expected contiunation-token: ' + this._expectedChunkToken);
|
|
127
127
|
}
|
|
128
128
|
}
|
|
@@ -133,4 +133,4 @@ export class DataContextContinuableToken extends DataContextContinuableBase {
|
|
|
133
133
|
return token1 === token2;
|
|
134
134
|
}
|
|
135
135
|
}
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-continuable-token.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-continuable-token.ts"],"names":[],"mappings":"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","sourcesContent":["import {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {ContinuableListing} from '../continuable-listing';\nimport {DataContextContinuableBase} from './data-context-continuable-base';\nimport {BehaviorSubject, EMPTY, Observable, Subject} from 'rxjs';\nimport {first, take} from 'rxjs/operators';\nimport {TokenChunkRequest} from '../token-chunk-request';\nimport {Sort} from '../sort';\nimport {IContinuableDataSource} from '../datasource/data-source';\n\nexport class DataContextContinuableToken<T> extends DataContextContinuableBase<T> {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _hasMoreData = new BehaviorSubject<boolean>(false);\n  private readonly _chunkCache: Set<string|undefined> = new Set();\n\n  private _expectedChunkToken?: string;\n\n  // protected nextContinuationToken?: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataSource: IContinuableDataSource<T>,\n    chunkSize: number,\n    indexFn: ((item: T) => any),\n    localApply: ((data: T[]) => T[]),\n    localSort: ((data: T[], sorts: Sort[]) => T[])\n  ) {\n    super(dataSource, chunkSize, indexFn, localApply, localSort);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IContinuableDataSource<T> {\n    return <IContinuableDataSource<T>>super.dataSource;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get hasMoreDataSnapshot(): boolean {\n    return this._hasMoreData.getValue();\n  }\n\n  public get hasMoreData(): Observable<boolean> {\n    return this._hasMoreData.asObservable();\n  }\n\n  public loadMore(): Observable<any> {\n\n    if (this.loadingSnapshot) {\n      this.logger.debug('Skipping load-more since already loading a chunk!');\n      return EMPTY;\n    }\n\n    const token = this._expectedChunkToken;\n\n    if (token && token.length > 0) {\n      return this.fetchNextChunk(token);\n    } else {\n      this.logger.debug('Cannot load more data, since no more data available.');\n      return EMPTY;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protect API                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected clearAll(silent = false): void {\n    super.clearAll(silent);\n    this._chunkCache.clear();\n    this._hasMoreData.next(true);\n    this._expectedChunkToken = undefined;\n  }\n\n  protected reloadInternal(): Observable<any> {\n\n    // Since continuable data-contexts are appending data,\n    // we need to clear it for a reload.\n    this.clearAll(true);\n\n    return this.fetchNextChunk(undefined);\n  }\n\n  private fetchNextChunk(nextToken?: string): Observable<ContinuableListing<T>> {\n\n    const subject = new Subject<ContinuableListing<T>>();\n\n    nextToken = nextToken ? nextToken : undefined;\n\n    if (this._chunkCache.has(nextToken)) {\n      this.logger.debug('Skipping fetching chunk for token \"' + nextToken + '\" since its already in observable cache.');\n      subject.complete();\n    } else {\n\n      this.onLoading();\n\n      this._chunkCache.add(nextToken);\n\n      this.dataSource.findAllContinuable(new TokenChunkRequest(nextToken, this.filter.filtersSnapshot, this.sort.sortsSnapshot))\n        .pipe(first())\n        .subscribe(\n          chunk => {\n            this.logger.debug('Got next chunk data:', chunk);\n            this._hasMoreData.next(chunk.hasMore);\n            this.chunkSize = chunk.chunkSize;\n            this.populateChunkData(chunk);\n            subject.next(chunk);\n            this.onIdle();\n          }, err => {\n            this.onError(err);\n            this.logger.error('Failed to query data', err);\n            this.clearData();\n            this.setTotal(0);\n            subject.error(err);\n          }\n        );\n    }\n    return subject.pipe(take(1));\n  }\n\n  /**\n   * Load the data from the given page into the current data context\n   */\n  private populateChunkData(chunk: ContinuableListing<T>): void {\n    if (this.areTokenEqual(chunk.continuationToken, this._expectedChunkToken)) {\n      try {\n        this.setTotal(chunk.total);\n\n        if (chunk.continuationToken) {\n          // We had previous chunks so append to current data.\n          this.appendData(chunk.content);\n        } else {\n          this.setData(chunk.content);\n        }\n\n      } catch (err) {\n        this.onError(err);\n        this.logger.error('Failed to populate data with chunk', chunk, err);\n      }\n      this._expectedChunkToken = chunk.nextContinuationToken;\n    } else {\n      this.logger.warn('Discarding continuable chunk (items: ' + chunk.content.length + ', token: ' + chunk.continuationToken + ' )' +\n        ' as it does not match the expected contiunation-token: ' + this._expectedChunkToken);\n    }\n  }\n\n  private areTokenEqual(token1?: string, token2?: string): boolean {\n    if (!token1 && !token2) { return true; }\n    return token1 === token2;\n  }\n\n\n}\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-continuable-token.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-continuable-token.ts"],"names":[],"mappings":"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","sourcesContent":["import {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {ContinuableListing} from '../continuable-listing';\nimport {DataContextContinuableBase} from './data-context-continuable-base';\nimport {BehaviorSubject, EMPTY, Observable, Subject} from 'rxjs';\nimport {first, take} from 'rxjs/operators';\nimport {TokenChunkRequest} from '../token-chunk-request';\nimport {Sort} from '../sort';\nimport {IContinuableDataSource} from '../datasource/data-source';\n\nexport class DataContextContinuableToken<T> extends DataContextContinuableBase<T> {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _hasMoreData = new BehaviorSubject<boolean>(false);\n  private readonly _chunkCache: Set<string|undefined> = new Set();\n\n  private _expectedChunkToken?: string;\n\n  // protected nextContinuationToken?: string;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataSource: IContinuableDataSource<T>,\n    chunkSize: number,\n    indexFn: ((item: T) => any),\n    localApply: ((data: T[]) => T[]),\n    localSort: ((data: T[], sorts: Sort[]) => T[])\n  ) {\n    super(dataSource, chunkSize, indexFn, localApply, localSort);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IContinuableDataSource<T> {\n    return <IContinuableDataSource<T>>super.dataSource;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get hasMoreDataSnapshot(): boolean {\n    return this._hasMoreData.getValue();\n  }\n\n  public get hasMoreData(): Observable<boolean> {\n    return this._hasMoreData.asObservable();\n  }\n\n  public loadMore(): Observable<any> {\n\n    if (this.loadingSnapshot) {\n      this.logger.debug(this.id + ': Skipping load-more since already loading a chunk!');\n      return EMPTY;\n    }\n\n    const token = this._expectedChunkToken;\n\n    if (token && token.length > 0) {\n      return this.fetchNextChunk(token);\n    } else {\n      this.logger.debug(this.id + ': Cannot load more data, since no more data available.');\n      return EMPTY;\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protect API                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected clearAll(silent = false): void {\n    super.clearAll(silent);\n    this._chunkCache.clear();\n    this._hasMoreData.next(true);\n    this._expectedChunkToken = undefined;\n  }\n\n  protected reloadInternal(): Observable<any> {\n\n    // Since continuable data-contexts are appending data,\n    // we need to clear it for a reload.\n    this.clearAll(true);\n\n    return this.fetchNextChunk(undefined);\n  }\n\n  private fetchNextChunk(nextToken?: string): Observable<ContinuableListing<T>> {\n\n    const subject = new Subject<ContinuableListing<T>>();\n\n    nextToken = nextToken ? nextToken : undefined;\n\n    if (this._chunkCache.has(nextToken)) {\n      this.logger.debug(this.id + ': Skipping fetching chunk for token \"' + nextToken + '\" since its already in observable cache.');\n      subject.complete();\n    } else {\n\n      this.onLoading();\n\n      this._chunkCache.add(nextToken);\n\n      this.dataSource.findAllContinuable(new TokenChunkRequest(nextToken, this.filter.filtersSnapshot, this.sort.sortsSnapshot))\n        .pipe(first())\n        .subscribe(\n          chunk => {\n            this.logger.debug(this.id + ': Got next chunk data:', chunk);\n            this._hasMoreData.next(chunk.hasMore);\n            this.chunkSize = chunk.chunkSize;\n            this.populateChunkData(chunk);\n            subject.next(chunk);\n            this.onIdle();\n          }, err => {\n            this.onError(err);\n            this.logger.error(this.id +': Failed to query data', err);\n            this.clearData();\n            this.setTotal(0);\n            subject.error(err);\n          }\n        );\n    }\n    return subject.pipe(take(1));\n  }\n\n  /**\n   * Load the data from the given page into the current data context\n   */\n  private populateChunkData(chunk: ContinuableListing<T>): void {\n    if (this.areTokenEqual(chunk.continuationToken, this._expectedChunkToken)) {\n      try {\n        this.setTotal(chunk.total);\n\n        if (chunk.continuationToken) {\n          // We had previous chunks so append to current data.\n          this.appendData(chunk.content);\n        } else {\n          this.setData(chunk.content);\n        }\n\n      } catch (err) {\n        this.onError(err);\n        this.logger.error(this.id +': Failed to populate data with chunk', chunk, err);\n      }\n      this._expectedChunkToken = chunk.nextContinuationToken;\n    } else {\n      this.logger.warn(this.id +': Discarding continuable chunk (items: ' + chunk.content.length + ', token: ' + chunk.continuationToken + ' )' +\n        ' as it does not match the expected contiunation-token: ' + this._expectedChunkToken);\n    }\n  }\n\n  private areTokenEqual(token1?: string, token2?: string): boolean {\n    if (!token1 && !token2) { return true; }\n    return token1 === token2;\n  }\n\n\n}\n"]}
|
|
@@ -40,20 +40,21 @@ export class DataContextSimple extends DataContextBase {
|
|
|
40
40
|
this.onIdle();
|
|
41
41
|
this.setTotal(list.length);
|
|
42
42
|
this.setData(list);
|
|
43
|
-
this.log.debug('
|
|
43
|
+
this.log.debug(this.id + ': Got list data: ' + list.length);
|
|
44
44
|
subject.next();
|
|
45
45
|
}, err => {
|
|
46
46
|
this.onError(err);
|
|
47
47
|
this.clearAll();
|
|
48
|
-
this.log.error('
|
|
48
|
+
this.log.error(this.id + ': Failed to query data', err);
|
|
49
49
|
subject.error(err);
|
|
50
50
|
});
|
|
51
51
|
}
|
|
52
52
|
else {
|
|
53
|
-
this.
|
|
54
|
-
|
|
53
|
+
const errorMsg = this.id + ': Skipping data context load - no list fetcher present!';
|
|
54
|
+
this.log.warn(errorMsg);
|
|
55
|
+
subject.error(new Error(errorMsg));
|
|
55
56
|
}
|
|
56
57
|
return subject.pipe(first());
|
|
57
58
|
}
|
|
58
59
|
}
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb250ZXh0LXNpbXBsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2VsZGVyYnl0ZS9uZ3gtc3RhcnRlci9zcmMvbGliL2NvbW1vbi9kYXRhL2RhdGEtY29udGV4dC9kYXRhLWNvbnRleHQtc2ltcGxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBUyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMzRCxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFFcEQsT0FBTyxFQUFhLE9BQU8sRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUN6QyxPQUFPLEVBQUMsS0FBSyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFHckMsTUFBTSxPQUFPLGlCQUFxQixTQUFRLGVBQWtCO0lBVTFEOzs7O2dGQUk0RTtJQUU1RSxZQUNFLFVBQThCLEVBQzlCLE9BQTJCLEVBQzNCLFVBQWdDLEVBQ2hDLFNBQThDO1FBRTlDLEtBQUssQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLENBQUMsQ0FBQztRQXBCcEQ7Ozs7b0ZBSTRFO1FBRTNELFFBQUcsR0FBVyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7SUFlOUUsQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUU1RSxJQUFXLFVBQVU7UUFDbkIsT0FBMkIsS0FBSyxDQUFDLFVBQVUsQ0FBQztJQUM5QyxDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRWxFLGNBQWM7UUFFdEIsTUFBTSxPQUFPLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUVwQyxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFFbkIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBRWpCLElBQUksQ0FBQyxVQUFVLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsZUFBZSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO2lCQUNsRixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7aUJBQ2IsU0FBUyxDQUNSLElBQUksQ0FBQyxFQUFFO2dCQUNMLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztnQkFDZCxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztnQkFDM0IsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztnQkFDbkIsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRyxtQkFBbUIsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBRTVELE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUNqQixDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztnQkFDbEIsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO2dCQUNoQixJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFFLHdCQUF3QixFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUN2RCxPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ3JCLENBQUMsQ0FBQyxDQUFDO1NBQ1I7YUFBTTtZQUNMLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxFQUFFLEdBQUcseURBQXlELENBQUM7WUFDckYsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDeEIsT0FBTyxDQUFDLEtBQUssQ0FBQyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1NBQ3BDO1FBRUQsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDL0IsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtMb2dnZXIsIExvZ2dlckZhY3Rvcnl9IGZyb20gJ0BlbGRlcmJ5dGUvdHMtbG9nZ2VyJztcbmltcG9ydCB7RGF0YUNvbnRleHRCYXNlfSBmcm9tICcuL2RhdGEtY29udGV4dC1iYXNlJztcbmltcG9ydCB7U29ydH0gZnJvbSAnLi4vc29ydCc7XG5pbXBvcnQge09ic2VydmFibGUsIFN1YmplY3R9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtmaXJzdH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHtJTGlzdERhdGFTb3VyY2V9IGZyb20gJy4uL2RhdGFzb3VyY2UvZGF0YS1zb3VyY2UnO1xuXG5leHBvcnQgY2xhc3MgRGF0YUNvbnRleHRTaW1wbGU8VD4gZXh0ZW5kcyBEYXRhQ29udGV4dEJhc2U8VD4ge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgcmVhZG9ubHkgbG9nOiBMb2dnZXIgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvciAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIGRhdGFTb3VyY2U6IElMaXN0RGF0YVNvdXJjZTxUPixcbiAgICBpbmRleEZuOiAoKGl0ZW06IFQpID0+IGFueSksXG4gICAgbG9jYWxBcHBseTogKChkYXRhOiBUW10pID0+IFRbXSksXG4gICAgbG9jYWxTb3J0OiAoKGRhdGE6IFRbXSwgc29ydHM6IFNvcnRbXSkgPT4gVFtdKVxuICApIHtcbiAgICBzdXBlcihkYXRhU291cmNlLCBpbmRleEZuLCBsb2NhbEFwcGx5LCBsb2NhbFNvcnQpO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFByb3BlcnRpZXMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIGdldCBkYXRhU291cmNlKCk6IElMaXN0RGF0YVNvdXJjZTxUPiB7XG4gICAgcmV0dXJuIDxJTGlzdERhdGFTb3VyY2U8VD4+c3VwZXIuZGF0YVNvdXJjZTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByb3RlY3RlZCByZWxvYWRJbnRlcm5hbCgpOiBPYnNlcnZhYmxlPGFueT4ge1xuXG4gICAgY29uc3Qgc3ViamVjdCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgICBpZiAodGhpcy5kYXRhU291cmNlKSB7XG5cbiAgICAgIHRoaXMub25Mb2FkaW5nKCk7XG5cbiAgICAgIHRoaXMuZGF0YVNvdXJjZS5maW5kQWxsRmlsdGVyZWQodGhpcy5maWx0ZXIuZmlsdGVyc1NuYXBzaG90LCB0aGlzLnNvcnQuc29ydHNTbmFwc2hvdClcbiAgICAgICAgLnBpcGUoZmlyc3QoKSlcbiAgICAgICAgLnN1YnNjcmliZShcbiAgICAgICAgICBsaXN0ID0+IHtcbiAgICAgICAgICAgIHRoaXMub25JZGxlKCk7XG4gICAgICAgICAgICB0aGlzLnNldFRvdGFsKGxpc3QubGVuZ3RoKTtcbiAgICAgICAgICAgIHRoaXMuc2V0RGF0YShsaXN0KTtcbiAgICAgICAgICAgIHRoaXMubG9nLmRlYnVnKHRoaXMuaWQgKyAnOiBHb3QgbGlzdCBkYXRhOiAnICsgbGlzdC5sZW5ndGgpO1xuXG4gICAgICAgICAgICBzdWJqZWN0Lm5leHQoKTtcbiAgICAgICAgICB9LCBlcnIgPT4ge1xuICAgICAgICAgICAgdGhpcy5vbkVycm9yKGVycik7XG4gICAgICAgICAgICB0aGlzLmNsZWFyQWxsKCk7XG4gICAgICAgICAgICB0aGlzLmxvZy5lcnJvcih0aGlzLmlkICsnOiBGYWlsZWQgdG8gcXVlcnkgZGF0YScsIGVycik7XG4gICAgICAgICAgICBzdWJqZWN0LmVycm9yKGVycik7XG4gICAgICAgICAgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIGNvbnN0IGVycm9yTXNnID0gdGhpcy5pZCArICc6IFNraXBwaW5nIGRhdGEgY29udGV4dCBsb2FkIC0gbm8gbGlzdCBmZXRjaGVyIHByZXNlbnQhJztcbiAgICAgIHRoaXMubG9nLndhcm4oZXJyb3JNc2cpO1xuICAgICAgc3ViamVjdC5lcnJvcihuZXcgRXJyb3IoZXJyb3JNc2cpKTtcbiAgICB9XG5cbiAgICByZXR1cm4gc3ViamVjdC5waXBlKGZpcnN0KCkpO1xuICB9XG59XG4iXX0=
|
|
@@ -31,7 +31,7 @@ export class DataContextSourceEventBinding extends DataContextLifeCycleBinding {
|
|
|
31
31
|
**************************************************************************/
|
|
32
32
|
handleDataChangeEvent(event) {
|
|
33
33
|
if (this.reloadOnChanges && this.isReloadDesirable(event)) {
|
|
34
|
-
this._dataContext.reload();
|
|
34
|
+
this._dataContext.reload('DataSourceChangeEvent');
|
|
35
35
|
return;
|
|
36
36
|
}
|
|
37
37
|
// We might also be able to perform deletions locally, and avoid reload data
|
|
@@ -43,4 +43,4 @@ export class DataContextSourceEventBinding extends DataContextLifeCycleBinding {
|
|
|
43
43
|
return event.unknownChanges || event.created || event.deletedIds;
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb250ZXh0LXNvdXJjZS1ldmVudC1iaW5kaW5nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL2RhdGEvZGF0YS1jb250ZXh0L2RhdGEtY29udGV4dC1zb3VyY2UtZXZlbnQtYmluZGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUc5RSxNQUFNLE9BQU8sNkJBQXVDLFNBQVEsMkJBQTJCO0lBRXJGOzs7O2dGQUk0RTtJQUU1RTs7OztnRkFJNEU7SUFFNUUsWUFDRSxXQUE0QixFQUNYLE9BQXVCLEVBQ3ZCLGVBQXdCO1FBRXpDLEtBQUssQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUhGLFlBQU8sR0FBUCxPQUFPLENBQWdCO1FBQ3ZCLG9CQUFlLEdBQWYsZUFBZSxDQUFTO1FBR3pDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztJQUNuQixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRWxFLFNBQVM7UUFDakIsSUFBSSxDQUFDLGFBQWEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQ3JELEtBQUssQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUMzQyxDQUFDO0lBQ0osQ0FBQztJQUVEOzs7O2dGQUk0RTtJQUVwRSxxQkFBcUIsQ0FBQyxLQUErQjtRQUUzRCxJQUFJLElBQUksQ0FBQyxlQUFlLElBQUksSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3pELElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUM7WUFDbEQsT0FBTztTQUNSO1FBRUQsNEVBQTRFO1FBRTVFLElBQUksS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUNsQixJQUFJLENBQUMsWUFBWSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7U0FDMUM7SUFDSCxDQUFDO0lBRU8saUJBQWlCLENBQUMsS0FBK0I7UUFDdkQsT0FBTyxLQUFLLENBQUMsY0FBYyxJQUFJLEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLFVBQVUsQ0FBQztJQUNuRSxDQUFDO0NBRUYiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0lEYXRhQ29udGV4dH0gZnJvbSAnLi9kYXRhLWNvbnRleHQnO1xuaW1wb3J0IHtJRGF0YVNvdXJjZX0gZnJvbSAnLi4vZGF0YXNvdXJjZS9kYXRhLXNvdXJjZSc7XG5pbXBvcnQge0RhdGFDb250ZXh0TGlmZUN5Y2xlQmluZGluZ30gZnJvbSAnLi9kYXRhLWNvbnRleHQtbGlmZS1jeWNsZS1iaW5kaW5nJztcbmltcG9ydCB7RGF0YVNvdXJjZUNoYW5nZUV2ZW50fSBmcm9tICcuLi9kYXRhc291cmNlL2RhdGEtc291cmNlLWNoYW5nZS1ldmVudCc7XG5cbmV4cG9ydCBjbGFzcyBEYXRhQ29udGV4dFNvdXJjZUV2ZW50QmluZGluZzxUID0gYW55PiBleHRlbmRzIERhdGFDb250ZXh0TGlmZUN5Y2xlQmluZGluZyB7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEZpZWxkcyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIENvbnN0cnVjdG9yICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgY29uc3RydWN0b3IoXG4gICAgZGF0YUNvbnRleHQ6IElEYXRhQ29udGV4dDxUPixcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRhdGFBcGk6IElEYXRhU291cmNlPFQ+LFxuICAgIHByaXZhdGUgcmVhZG9ubHkgcmVsb2FkT25DaGFuZ2VzOiBib29sZWFuXG4gICkge1xuICAgIHN1cGVyKGRhdGFDb250ZXh0KTtcbiAgICB0aGlzLnN1YnNjcmliZSgpO1xuICB9XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIEludGVybmFsIEltcGwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHJvdGVjdGVkIHN1YnNjcmliZSgpOiB2b2lkIHtcbiAgICB0aGlzLl9zdWJzY3JpcHRpb24gPSB0aGlzLmRhdGFBcGkuZGF0YUNoYW5nZWQuc3Vic2NyaWJlKFxuICAgICAgZXZlbnQgPT4gdGhpcy5oYW5kbGVEYXRhQ2hhbmdlRXZlbnQoZXZlbnQpXG4gICAgKTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByaXZhdGUgaGFuZGxlRGF0YUNoYW5nZUV2ZW50KGV2ZW50OiBEYXRhU291cmNlQ2hhbmdlRXZlbnQ8VD4pOiB2b2lkIHtcblxuICAgIGlmICh0aGlzLnJlbG9hZE9uQ2hhbmdlcyAmJiB0aGlzLmlzUmVsb2FkRGVzaXJhYmxlKGV2ZW50KSkge1xuICAgICAgdGhpcy5fZGF0YUNvbnRleHQucmVsb2FkKCdEYXRhU291cmNlQ2hhbmdlRXZlbnQnKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAvLyBXZSBtaWdodCBhbHNvIGJlIGFibGUgdG8gcGVyZm9ybSBkZWxldGlvbnMgbG9jYWxseSwgYW5kIGF2b2lkIHJlbG9hZCBkYXRhXG5cbiAgICBpZiAoZXZlbnQubW9kaWZpZWQpIHtcbiAgICAgIHRoaXMuX2RhdGFDb250ZXh0LnVwZGF0ZShldmVudC5tb2RpZmllZCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBpc1JlbG9hZERlc2lyYWJsZShldmVudDogRGF0YVNvdXJjZUNoYW5nZUV2ZW50PFQ+KSB7XG4gICAgcmV0dXJuIGV2ZW50LnVua25vd25DaGFuZ2VzIHx8IGV2ZW50LmNyZWF0ZWQgfHwgZXZlbnQuZGVsZXRlZElkcztcbiAgfVxuXG59XG4iXX0=
|
|
@@ -27,4 +27,4 @@ export function isContinuableDataContext(object) {
|
|
|
27
27
|
export function isActivePagedDataContext(object) {
|
|
28
28
|
return object.setActivePage !== undefined;
|
|
29
29
|
}
|
|
30
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,mBAAmB;IAC9B,YACkB,IAAS,EACT,OAAgB,EAChB,SAAkB,EAClB,KAAyB,EACzB,MAAyB;QAJzB,SAAI,GAAJ,IAAI,CAAK;QACT,YAAO,GAAP,OAAO,CAAS;QAChB,cAAS,GAAT,SAAS,CAAS;QAClB,UAAK,GAAL,KAAK,CAAoB;QACzB,WAAM,GAAN,MAAM,CAAmB;IACvC,CAAC;CACN;AAiLD;;;;4EAI4E;AAE5E,MAAM,UAAU,aAAa,CAAC,MAAW;IAEvC,IAAI,CAAC,MAAM,EAAE;QAAE,OAAO,KAAK,CAAC;KAAE;IAE9B,OAAQ,MAA4B,CAAC,IAAI,KAAK,SAAS;WACjD,MAA4B,CAAC,KAAK,KAAK,SAAS;WAChD,MAA4B,CAAC,MAAM,KAAK,SAAS;WACjD,MAA4B,CAAC,OAAO,KAAK,SAAS,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAyB;IAChE,OAAQ,MAAuC,CAAC,QAAQ,KAAK,SAAS,CAAC;AACzE,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAyB;IAChE,OAAQ,MAAsC,CAAC,aAAa,KAAK,SAAS,CAAC;AAC7E,CAAC","sourcesContent":["import {DataContextStatus} from './data-context-status';\nimport {Observable} from 'rxjs';\nimport {Sort} from '../sort';\nimport {Filter} from '../filters/filter';\nimport {FilterContext} from '../filters/filter-context';\nimport {PageRequest} from '../page';\nimport {SortContext} from '../sort-context';\nimport {IDataSource} from '../datasource/data-source';\n\n\nexport class DataContextSnapshot<T> {\n  constructor(\n    public readonly data: T[],\n    public readonly isEmpty: boolean,\n    public readonly isLoading: boolean,\n    public readonly total: number | undefined,\n    public readonly status: DataContextStatus\n  ) { }\n}\n\n/**\n * Manages a set of data (rows) which are to be displayed in a UI Component.\n *\n */\nexport interface IDataContext<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Gets the underlying DataSource of this DataContext.\n   */\n  readonly dataSource: IDataSource<T>;\n\n  /**\n   * Gets a snapshot of the current state in this data-context\n   */\n  readonly snapshot: DataContextSnapshot<T>;\n\n  /**\n   * Observable which emits the current data over time.\n   */\n  readonly data: Observable<T[]>;\n\n  /**\n   * Indicates if the context currently holds no data\n   */\n  readonly isEmpty: boolean;\n\n  /**\n   * Indicates if the context has been started.\n   */\n  readonly isStarted: boolean;\n\n  /**\n   * Indicates if the context has been started.\n   */\n  readonly isStarted$: Observable<boolean>;\n\n  /**\n   * Indicates if the context has been closed.\n   * Depending on the implementation, restarting might not be possible.\n   */\n  readonly isClosed: boolean;\n\n  /**\n   * Indicates if data is loading over time\n   */\n  readonly loading: Observable<boolean>;\n\n  /**\n   * The total count of all elements over time\n   * (I.e. the expected count when the data context is completed)\n   */\n  readonly total: Observable<number | undefined>;\n\n  /**\n   * Observable which emits when the status changes (i.e. error)\n   */\n  readonly status: Observable<DataContextStatus>;\n\n  /**\n   * Gets the sort context. Changes in this context are reflected by the data-context.\n   */\n  readonly sort: SortContext;\n\n  /**\n   * Gets the filter context. Changes in this context are reflected by the data-context.\n   */\n  readonly filter: FilterContext;\n\n  /***************************************************************************\n   *                                                                         *\n   * API                                                                     *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Starts populating data context by loading first\n   * batch of data.\n   */\n  start(sorts?: Sort[], filters?: Filter[]): Observable<any>;\n\n  /**\n   * Requests a reload of the current data / chunk.\n   * Attempts to keep the current position.\n   */\n  reload(): void;\n\n  /**\n   * Refresh the data view from the local data model. (Does not request new data from the server)\n   * Useful if the data model has changes that need to be reflected in the UI.\n   */\n  refresh(): void;\n\n  /**\n   * Closes the data-context and cleans up resources\n   */\n  close(): void;\n\n  /**\n   * Returns the item by a custom index key.\n   * Requires that custom index functionality is enabled.\n   *\n   * For id based lookup, refer to findById().\n   *\n   * @param key\n   */\n  findByIndex(key: any): T | undefined;\n\n  /**\n   * Lookup an entity by its id. This method is guaranteed to be backed by a fast index.\n   * @param id The Entity Id.\n   */\n  findById(id: any): T | undefined;\n\n  /**\n   * Update the given entities in this data-context\n   */\n  update(entities: T[]): void;\n\n}\n\n/**\n * Represents a data-context which backs a infinite like data stream\n * where more data will be loaded and added to the backing rows.\n */\nexport interface IDataContextContinuable<T> extends IDataContext<T> {\n\n  /**\n   * Returns true if this data-context can load more data\n   */\n  readonly hasMoreDataSnapshot: boolean;\n\n  /**\n   * Returns true if this data-context can load more data over time\n   */\n  readonly hasMoreData: Observable<boolean>;\n\n  /**\n   * Loads more data if any available.\n   * E.g. next page.\n   *\n   */\n  loadMore(): Observable<any>;\n\n  /**\n   * Loads all available data. In case of\n   * paged context loads page by page until finished.\n   */\n  loadAll(sorts?: Sort[], filters?: Filter[]): void;\n\n}\n\nexport interface IDataContextActivePage<T> extends IDataContext<T> {\n\n  /**\n   * Gets the active page over time\n   */\n  readonly page: Observable<PageRequest>;\n\n  /**\n   * Gets the current active page\n   */\n  readonly pageSnapshot: PageRequest;\n\n  /**\n   * Sets the active page\n   */\n  setActivePage(page: PageRequest): void;\n}\n\n/***************************************************************************\n *                                                                         *\n * Type Predicates                                                         *\n *                                                                         *\n **************************************************************************/\n\nexport function isDataContext(object: any): object is IDataContext<any> {\n\n  if (!object) { return false; }\n\n  return (object as IDataContext<any>).data !== undefined\n    && (object as IDataContext<any>).start !== undefined\n    && (object as IDataContext<any>).reload !== undefined\n    && (object as IDataContext<any>).refresh !== undefined;\n}\n\nexport function isContinuableDataContext(object: IDataContext<any>): object is IDataContextContinuable<any> {\n  return (object as IDataContextContinuable<any>).loadMore !== undefined;\n}\n\nexport function isActivePagedDataContext(object: IDataContext<any>): object is IDataContextActivePage<any> {\n  return (object as IDataContextActivePage<any>).setActivePage !== undefined;\n}\n"]}
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context.ts"],"names":[],"mappings":"AAUA,MAAM,OAAO,mBAAmB;IAC9B,YACkB,IAAS,EACT,OAAgB,EAChB,SAAkB,EAClB,KAAyB,EACzB,MAAyB;QAJzB,SAAI,GAAJ,IAAI,CAAK;QACT,YAAO,GAAP,OAAO,CAAS;QAChB,cAAS,GAAT,SAAS,CAAS;QAClB,UAAK,GAAL,KAAK,CAAoB;QACzB,WAAM,GAAN,MAAM,CAAmB;IACvC,CAAC;CACN;AAuLD;;;;4EAI4E;AAE5E,MAAM,UAAU,aAAa,CAAC,MAAW;IAEvC,IAAI,CAAC,MAAM,EAAE;QAAE,OAAO,KAAK,CAAC;KAAE;IAE9B,OAAQ,MAA4B,CAAC,IAAI,KAAK,SAAS;WACjD,MAA4B,CAAC,KAAK,KAAK,SAAS;WAChD,MAA4B,CAAC,MAAM,KAAK,SAAS;WACjD,MAA4B,CAAC,OAAO,KAAK,SAAS,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAyB;IAChE,OAAQ,MAAuC,CAAC,QAAQ,KAAK,SAAS,CAAC;AACzE,CAAC;AAED,MAAM,UAAU,wBAAwB,CAAC,MAAyB;IAChE,OAAQ,MAAsC,CAAC,aAAa,KAAK,SAAS,CAAC;AAC7E,CAAC","sourcesContent":["import {DataContextStatus} from './data-context-status';\nimport {Observable} from 'rxjs';\nimport {Sort} from '../sort';\nimport {Filter} from '../filters/filter';\nimport {FilterContext} from '../filters/filter-context';\nimport {PageRequest} from '../page';\nimport {SortContext} from '../sort-context';\nimport {IDataSource} from '../datasource/data-source';\n\n\nexport class DataContextSnapshot<T> {\n  constructor(\n    public readonly data: T[],\n    public readonly isEmpty: boolean,\n    public readonly isLoading: boolean,\n    public readonly total: number | undefined,\n    public readonly status: DataContextStatus\n  ) { }\n}\n\n/**\n * Manages a set of data (rows) which are to be displayed in a UI Component.\n *\n */\nexport interface IDataContext<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * An auto generated id of this DataContext instance.\n   * Mostly for debugging purposes.\n   */\n  readonly id: string;\n\n  /**\n   * Gets the underlying DataSource of this DataContext.\n   */\n  readonly dataSource: IDataSource<T>;\n\n  /**\n   * Gets a snapshot of the current state in this data-context\n   */\n  readonly snapshot: DataContextSnapshot<T>;\n\n  /**\n   * Observable which emits the current data over time.\n   */\n  readonly data: Observable<T[]>;\n\n  /**\n   * Indicates if the context currently holds no data\n   */\n  readonly isEmpty: boolean;\n\n  /**\n   * Indicates if the context has been started.\n   */\n  readonly isStarted: boolean;\n\n  /**\n   * Indicates if the context has been started.\n   */\n  readonly isStarted$: Observable<boolean>;\n\n  /**\n   * Indicates if the context has been closed.\n   * Depending on the implementation, restarting might not be possible.\n   */\n  readonly isClosed: boolean;\n\n  /**\n   * Indicates if data is loading over time\n   */\n  readonly loading: Observable<boolean>;\n\n  /**\n   * The total count of all elements over time\n   * (I.e. the expected count when the data context is completed)\n   */\n  readonly total: Observable<number | undefined>;\n\n  /**\n   * Observable which emits when the status changes (i.e. error)\n   */\n  readonly status: Observable<DataContextStatus>;\n\n  /**\n   * Gets the sort context. Changes in this context are reflected by the data-context.\n   */\n  readonly sort: SortContext;\n\n  /**\n   * Gets the filter context. Changes in this context are reflected by the data-context.\n   */\n  readonly filter: FilterContext;\n\n  /***************************************************************************\n   *                                                                         *\n   * API                                                                     *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Starts populating data context by loading first\n   * batch of data.\n   */\n  start(sorts?: Sort[], filters?: Filter[]): Observable<any>;\n\n  /**\n   * Requests a reload of the current data / chunk.\n   * Attempts to keep the current position.\n   */\n  reload(reason?: string): Observable<any>;\n\n  /**\n   * Refresh the data view from the local data model. (Does not request new data from the server)\n   * Useful if the data model has changes that need to be reflected in the UI.\n   */\n  refresh(): void;\n\n  /**\n   * Closes the data-context and cleans up resources\n   */\n  close(): void;\n\n  /**\n   * Returns the item by a custom index key.\n   * Requires that custom index functionality is enabled.\n   *\n   * For id based lookup, refer to findById().\n   *\n   * @param key\n   */\n  findByIndex(key: any): T | undefined;\n\n  /**\n   * Lookup an entity by its id. This method is guaranteed to be backed by a fast index.\n   * @param id The Entity Id.\n   */\n  findById(id: any): T | undefined;\n\n  /**\n   * Update the given entities in this data-context\n   */\n  update(entities: T[]): void;\n\n}\n\n/**\n * Represents a data-context which backs a infinite like data stream\n * where more data will be loaded and added to the backing rows.\n */\nexport interface IDataContextContinuable<T> extends IDataContext<T> {\n\n  /**\n   * Returns true if this data-context can load more data\n   */\n  readonly hasMoreDataSnapshot: boolean;\n\n  /**\n   * Returns true if this data-context can load more data over time\n   */\n  readonly hasMoreData: Observable<boolean>;\n\n  /**\n   * Loads more data if any available.\n   * E.g. next page.\n   *\n   */\n  loadMore(): Observable<any>;\n\n  /**\n   * Loads all available data. In case of\n   * paged context loads page by page until finished.\n   */\n  loadAll(sorts?: Sort[], filters?: Filter[]): void;\n\n}\n\nexport interface IDataContextActivePage<T> extends IDataContext<T> {\n\n  /**\n   * Gets the active page over time\n   */\n  readonly page: Observable<PageRequest>;\n\n  /**\n   * Gets the current active page\n   */\n  readonly pageSnapshot: PageRequest;\n\n  /**\n   * Sets the active page\n   */\n  setActivePage(page: PageRequest): void;\n}\n\n/***************************************************************************\n *                                                                         *\n * Type Predicates                                                         *\n *                                                                         *\n **************************************************************************/\n\nexport function isDataContext(object: any): object is IDataContext<any> {\n\n  if (!object) { return false; }\n\n  return (object as IDataContext<any>).data !== undefined\n    && (object as IDataContext<any>).start !== undefined\n    && (object as IDataContext<any>).reload !== undefined\n    && (object as IDataContext<any>).refresh !== undefined;\n}\n\nexport function isContinuableDataContext(object: IDataContext<any>): object is IDataContextContinuable<any> {\n  return (object as IDataContextContinuable<any>).loadMore !== undefined;\n}\n\nexport function isActivePagedDataContext(object: IDataContext<any>): object is IDataContextActivePage<any> {\n  return (object as IDataContextActivePage<any>).setActivePage !== undefined;\n}\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Filter } from './filter';
|
|
2
2
|
import { BehaviorSubject, lastValueFrom } from "rxjs";
|
|
3
3
|
import { distinctUntilChanged } from 'rxjs/operators';
|
|
4
|
+
import { FilterUtil } from '../../utils/filter-util';
|
|
4
5
|
export class FilterContext {
|
|
5
6
|
constructor() {
|
|
6
7
|
/***************************************************************************
|
|
@@ -9,6 +10,11 @@ export class FilterContext {
|
|
|
9
10
|
* *
|
|
10
11
|
**************************************************************************/
|
|
11
12
|
this._filters$ = new BehaviorSubject([]);
|
|
13
|
+
/***************************************************************************
|
|
14
|
+
* *
|
|
15
|
+
* Private methods *
|
|
16
|
+
* *
|
|
17
|
+
**************************************************************************/
|
|
12
18
|
}
|
|
13
19
|
static empty() {
|
|
14
20
|
return new FilterContext();
|
|
@@ -54,11 +60,14 @@ export class FilterContext {
|
|
|
54
60
|
* Read API *
|
|
55
61
|
* *
|
|
56
62
|
**************************************************************************/
|
|
63
|
+
get isEmpty() {
|
|
64
|
+
return this.filtersSnapshot.length == 0;
|
|
65
|
+
}
|
|
57
66
|
get filters() {
|
|
58
|
-
return this._filters$.asObservable().pipe(distinctUntilChanged((a, b) =>
|
|
67
|
+
return this._filters$.asObservable().pipe(distinctUntilChanged((a, b) => FilterUtil.equals(a, b)));
|
|
59
68
|
}
|
|
60
69
|
get filtersSnapshot() {
|
|
61
|
-
return this._filters$.getValue();
|
|
70
|
+
return [...this._filters$.getValue()];
|
|
62
71
|
}
|
|
63
72
|
findFilterValue(key) {
|
|
64
73
|
const f = this.findFilter(key);
|
|
@@ -123,28 +132,5 @@ export class FilterContext {
|
|
|
123
132
|
this.updateFilter(Filter.merge(existing, filter));
|
|
124
133
|
}
|
|
125
134
|
}
|
|
126
|
-
/***************************************************************************
|
|
127
|
-
* *
|
|
128
|
-
* Private methods *
|
|
129
|
-
* *
|
|
130
|
-
**************************************************************************/
|
|
131
|
-
equals(aFilters, bFilters) {
|
|
132
|
-
if (aFilters.length !== bFilters.length) {
|
|
133
|
-
return false;
|
|
134
|
-
}
|
|
135
|
-
if (aFilters.length === 0 && bFilters.length === 0) {
|
|
136
|
-
return true;
|
|
137
|
-
}
|
|
138
|
-
// The both filter arrays have the same length, so we must compare them by value
|
|
139
|
-
const bIndex = new Map();
|
|
140
|
-
bFilters.forEach(f => bIndex.set(f.key, f));
|
|
141
|
-
for (const fa of aFilters) {
|
|
142
|
-
const bFilter = bIndex.get(fa.key);
|
|
143
|
-
if (!Filter.equals(bFilter, fa)) {
|
|
144
|
-
return false;
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
return true;
|
|
148
|
-
}
|
|
149
135
|
}
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-context.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/filters/filter-context.ts"],"names":[],"mappings":"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","sourcesContent":["import {Filter} from './filter';\nimport { BehaviorSubject, lastValueFrom, Observable } from \"rxjs\";\nimport {distinctUntilChanged} from 'rxjs/operators';\nimport {F} from '@angular/cdk/keycodes';\n\nexport class FilterContext {\n\n  public static empty(): FilterContext {\n    return new FilterContext();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _filters$ = new BehaviorSubject<Filter[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Utilities                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Update the given filters with new ones, merging the two.\n   * The updated filters take precedence.\n   * @param filters\n   * @param updatedFilters\n   */\n  public static updateFilters(filters: Filter[], updatedFilters: Filter[]): Filter[] {\n    const filterMap = new Map<string, Filter>();\n\n    if (filters) {\n      filters.forEach(f => filterMap.set(f.key, f));\n    }\n\n    if (updatedFilters) {\n      updatedFilters.forEach(f => {\n        if (Filter.hasValue(f)) {\n          filterMap.set(f.key, f);\n        } else {\n          if (filterMap.has(f.key)) {\n            filterMap.delete(f.key);\n          }\n        }\n      });\n    }\n\n    return Array.from(filterMap.values());\n  }\n\n  public static async of(filters: Filter[]) {\n    const filterContext = new FilterContext();\n    filterContext.updateFilters(filters);\n    await lastValueFrom(filterContext.filters);\n    return filterContext;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Read API                                                                *\n   *                                                                         *\n   **************************************************************************/\n\n  public get filters(): Observable<Filter[]> {\n    return this._filters$.asObservable().pipe(\n      distinctUntilChanged((a, b) => this.equals(a, b))\n    );\n  }\n\n  public get filtersSnapshot(): Filter[] {\n    return this._filters$.getValue();\n  }\n\n  public findFilterValue(key: string): string | string[] | undefined {\n    const f = this.findFilter(key);\n    return f ? f.value : undefined;\n  }\n\n  public findFilter(key: string): Filter | undefined {\n    return this.filtersSnapshot\n      .filter(f => f.key === key)\n      .find(first => true);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public removeFilter(key: string): void {\n    const current = this.filtersSnapshot;\n    const newFilters = current.filter(f => f.key !== key);\n    if (current.length !== newFilters.length) {\n      this.replaceFilters(newFilters);\n    }\n  }\n\n  /**\n   * This method updatees / adds the given filter, leaving\n   * existing ones untouched.\n   * @param updatedFilter\n   */\n  public updateFilter(updatedFilter?: Filter): void {\n    if (updatedFilter) {\n      this.updateFilters([updatedFilter]);\n    }\n  }\n\n  /**\n   * This method updates / adds the given filters, leaving\n   * existing ones untouched.\n   * @param updatedFilters\n   */\n  public updateFilters(updatedFilters?: Filter[]): void {\n    if (updatedFilters && updatedFilters.length > 0) {\n      this.replaceFilters(\n        FilterContext.updateFilters(this.filtersSnapshot, updatedFilters)\n      );\n    }\n  }\n\n  /**\n   * Replace all existing filters with the given new ones.\n   * @param newFilters\n   */\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filters$.next(newFilters || []);\n  }\n\n  public clear(): void {\n    this.replaceFilters([]);\n  }\n\n  public mergeFilters(filters: Filter[]){\n    filters.forEach(filter => this.mergeFilter(filter));\n  }\n\n  public mergeFilter(filter: Filter): void {\n    const existing = this.findFilter(filter.key);\n    if(!existing){\n      this.updateFilter(filter);\n    } else {\n      this.updateFilter(Filter.merge(existing, filter))\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private equals(aFilters: Filter[], bFilters: Filter[]): boolean {\n\n    if (aFilters.length !== bFilters.length) { return false; }\n    if (aFilters.length === 0 && bFilters.length === 0) { return true; }\n\n    // The both filter arrays have the same length, so we must compare them by value\n\n    const bIndex = new Map<string, Filter>();\n    bFilters.forEach(f => bIndex.set(f.key, f));\n\n    for (const fa of aFilters) {\n      const bFilter = bIndex.get(fa.key);\n      if (!Filter.equals(bFilter, fa)) {\n        return false;\n      }\n    }\n    return true;\n  }\n}\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-context.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/filters/filter-context.ts"],"names":[],"mappings":"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","sourcesContent":["import {Filter} from './filter';\nimport { BehaviorSubject, lastValueFrom, Observable } from \"rxjs\";\nimport {distinctUntilChanged} from 'rxjs/operators';\nimport {F} from '@angular/cdk/keycodes';\nimport {FilterUtil} from '../../utils/filter-util';\n\nexport class FilterContext {\n\n  public static empty(): FilterContext {\n    return new FilterContext();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly _filters$ = new BehaviorSubject<Filter[]>([]);\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Utilities                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Update the given filters with new ones, merging the two.\n   * The updated filters take precedence.\n   * @param filters\n   * @param updatedFilters\n   */\n  public static updateFilters(filters: Filter[], updatedFilters: Filter[]): Filter[] {\n    const filterMap = new Map<string, Filter>();\n\n    if (filters) {\n      filters.forEach(f => filterMap.set(f.key, f));\n    }\n\n    if (updatedFilters) {\n      updatedFilters.forEach(f => {\n        if (Filter.hasValue(f)) {\n          filterMap.set(f.key, f);\n        } else {\n          if (filterMap.has(f.key)) {\n            filterMap.delete(f.key);\n          }\n        }\n      });\n    }\n\n    return Array.from(filterMap.values());\n  }\n\n  public static async of(filters: Filter[]) {\n    const filterContext = new FilterContext();\n    filterContext.updateFilters(filters);\n    await lastValueFrom(filterContext.filters);\n    return filterContext;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Read API                                                                *\n   *                                                                         *\n   **************************************************************************/\n\n  public get isEmpty(): boolean {\n    return this.filtersSnapshot.length == 0;\n  }\n\n  public get filters(): Observable<Filter[]> {\n    return this._filters$.asObservable().pipe(\n      distinctUntilChanged((a, b) => FilterUtil.equals(a, b))\n    );\n  }\n\n  public get filtersSnapshot(): Filter[] {\n    return [...this._filters$.getValue()];\n  }\n\n  public findFilterValue(key: string): string | string[] | undefined {\n    const f = this.findFilter(key);\n    return f ? f.value : undefined;\n  }\n\n  public findFilter(key: string): Filter | undefined {\n    return this.filtersSnapshot\n      .filter(f => f.key === key)\n      .find(first => true);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public removeFilter(key: string): void {\n    const current = this.filtersSnapshot;\n    const newFilters = current.filter(f => f.key !== key);\n    if (current.length !== newFilters.length) {\n      this.replaceFilters(newFilters);\n    }\n  }\n\n  /**\n   * This method updatees / adds the given filter, leaving\n   * existing ones untouched.\n   * @param updatedFilter\n   */\n  public updateFilter(updatedFilter?: Filter): void {\n    if (updatedFilter) {\n      this.updateFilters([updatedFilter]);\n    }\n  }\n\n  /**\n   * This method updates / adds the given filters, leaving\n   * existing ones untouched.\n   * @param updatedFilters\n   */\n  public updateFilters(updatedFilters?: Filter[]): void {\n    if (updatedFilters && updatedFilters.length > 0) {\n      this.replaceFilters(\n        FilterContext.updateFilters(this.filtersSnapshot, updatedFilters)\n      );\n    }\n  }\n\n  /**\n   * Replace all existing filters with the given new ones.\n   * @param newFilters\n   */\n  public replaceFilters(newFilters?: Filter[]) {\n    this._filters$.next(newFilters || []);\n  }\n\n  public clear(): void {\n    this.replaceFilters([]);\n  }\n\n  public mergeFilters(filters: Filter[]){\n    filters.forEach(filter => this.mergeFilter(filter));\n  }\n\n  public mergeFilter(filter: Filter): void {\n    const existing = this.findFilter(filter.key);\n    if(!existing){\n      this.updateFilter(filter);\n    } else {\n      this.updateFilter(Filter.merge(existing, filter))\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n}\n"]}
|
|
@@ -22,7 +22,7 @@ export class SortContext {
|
|
|
22
22
|
return this._sorts.asObservable();
|
|
23
23
|
}
|
|
24
24
|
get sortsSnapshot() {
|
|
25
|
-
return this._sorts.getValue();
|
|
25
|
+
return [...this._sorts.getValue()];
|
|
26
26
|
}
|
|
27
27
|
findSortDirection(prop) {
|
|
28
28
|
const f = this.findSort(prop);
|
|
@@ -72,4 +72,4 @@ export class SortContext {
|
|
|
72
72
|
this.replaceSorts([]);
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic29ydC1jb250ZXh0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL2RhdGEvc29ydC1jb250ZXh0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxlQUFlLEVBQWEsTUFBTSxNQUFNLENBQUM7QUFHakQsTUFBTSxPQUFPLFdBQVc7SUFBeEI7UUFFRTs7OztvRkFJNEU7UUFFM0QsV0FBTSxHQUFHLElBQUksZUFBZSxDQUFTLEVBQUUsQ0FBQyxDQUFDO1FBd0UxRDs7OztvRkFJNEU7SUFFOUUsQ0FBQztJQTVFQzs7OztnRkFJNEU7SUFFNUUsSUFBVyxLQUFLO1FBQ2QsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3BDLENBQUM7SUFFRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDO0lBQ3JDLENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxJQUFZO1FBQ25DLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDOUIsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQztJQUMvQixDQUFDO0lBRU0sUUFBUSxDQUFDLElBQVk7UUFDMUIsT0FBTyxJQUFJLENBQUMsYUFBYTthQUN0QixNQUFNLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxLQUFLLElBQUksQ0FBQzthQUM1QixJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRTVFOzs7O09BSUc7SUFDSSxVQUFVLENBQUMsV0FBa0I7UUFDbEMsSUFBSSxXQUFXLEVBQUU7WUFDZixJQUFJLENBQUMsV0FBVyxDQUFDLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQztTQUNqQztJQUNILENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksV0FBVyxDQUFDLFlBQXFCO1FBQ3RDLElBQUksWUFBWSxJQUFJLFlBQVksQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1lBQzNDLE1BQU0sT0FBTyxHQUFHLElBQUksR0FBRyxFQUFnQixDQUFDO1lBQ3hDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDeEQsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xELElBQUksQ0FBQyxZQUFZLENBQ2YsS0FBSyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FDbEMsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVEOzs7T0FHRztJQUNJLFlBQVksQ0FBQyxRQUFpQjtRQUNuQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxRQUFRLElBQUksRUFBRSxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUVNLEtBQUs7UUFDVixJQUFJLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3hCLENBQUM7Q0FRRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QmVoYXZpb3JTdWJqZWN0LCBPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7U29ydCwgU29ydERpcmVjdGlvbn0gZnJvbSAnLi9zb3J0JztcblxuZXhwb3J0IGNsYXNzIFNvcnRDb250ZXh0IHtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IF9zb3J0cyA9IG5ldyBCZWhhdmlvclN1YmplY3Q8U29ydFtdPihbXSk7XG5cbiAgLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqIFJlYWQgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovXG5cbiAgcHVibGljIGdldCBzb3J0cygpOiBPYnNlcnZhYmxlPFNvcnRbXT4ge1xuICAgIHJldHVybiB0aGlzLl9zb3J0cy5hc09ic2VydmFibGUoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgc29ydHNTbmFwc2hvdCgpOiBTb3J0W10ge1xuICAgIHJldHVybiBbLi4udGhpcy5fc29ydHMuZ2V0VmFsdWUoKV07XG4gIH1cblxuICBwdWJsaWMgZmluZFNvcnREaXJlY3Rpb24ocHJvcDogc3RyaW5nKTogU29ydERpcmVjdGlvbiB8IHVuZGVmaW5lZCB7XG4gICAgY29uc3QgZiA9IHRoaXMuZmluZFNvcnQocHJvcCk7XG4gICAgcmV0dXJuIGYgPyBmLmRpciA6IHVuZGVmaW5lZDtcbiAgfVxuXG4gIHB1YmxpYyBmaW5kU29ydChwcm9wOiBzdHJpbmcpOiBTb3J0IHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy5zb3J0c1NuYXBzaG90XG4gICAgICAuZmlsdGVyKGYgPT4gZi5wcm9wID09PSBwcm9wKVxuICAgICAgLmZpbmQoZmlyc3QgPT4gdHJ1ZSk7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHVibGljIEFQSSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICAvKipcbiAgICogVGhpcyBtZXRob2QgdXBkYXRlZXMgLyBhZGRzIHRoZSBnaXZlbiBzb3J0LCBsZWF2aW5nXG4gICAqIGV4aXN0aW5nIG9uZXMgdW50b3VjaGVkLlxuICAgKiBAcGFyYW0gdXBkYXRlZFNvcnRcbiAgICovXG4gIHB1YmxpYyB1cGRhdGVTb3J0KHVwZGF0ZWRTb3J0PzogU29ydCk6IHZvaWQge1xuICAgIGlmICh1cGRhdGVkU29ydCkge1xuICAgICAgdGhpcy51cGRhdGVTb3J0cyhbdXBkYXRlZFNvcnRdKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogVGhpcyBtZXRob2QgdXBkYXRlcyAvIGFkZHMgdGhlIGdpdmVuIGZpbHRlcnMsIGxlYXZpbmdcbiAgICogZXhpc3Rpbmcgb25lcyB1bnRvdWNoZWQuXG4gICAqIEBwYXJhbSB1cGRhdGVkU29ydHNcbiAgICovXG4gIHB1YmxpYyB1cGRhdGVTb3J0cyh1cGRhdGVkU29ydHM/OiBTb3J0W10pOiB2b2lkIHtcbiAgICBpZiAodXBkYXRlZFNvcnRzICYmIHVwZGF0ZWRTb3J0cy5sZW5ndGggPiAwKSB7XG4gICAgICBjb25zdCBzb3J0TWFwID0gbmV3IE1hcDxzdHJpbmcsIFNvcnQ+KCk7XG4gICAgICB0aGlzLnNvcnRzU25hcHNob3QuZm9yRWFjaChzID0+IHNvcnRNYXAuc2V0KHMucHJvcCwgcykpO1xuICAgICAgdXBkYXRlZFNvcnRzLmZvckVhY2gocyA9PiBzb3J0TWFwLnNldChzLnByb3AsIHMpKTtcbiAgICAgIHRoaXMucmVwbGFjZVNvcnRzKFxuICAgICAgICBBcnJheS5mcm9tKHVwZGF0ZWRTb3J0cy52YWx1ZXMoKSlcbiAgICAgICk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIFJlcGxhY2UgYWxsIGV4aXN0aW5nIGZpbHRlcnMgd2l0aCB0aGUgZ2l2ZW4gbmV3IG9uZXMuXG4gICAqIEBwYXJhbSBuZXdTb3J0c1xuICAgKi9cbiAgcHVibGljIHJlcGxhY2VTb3J0cyhuZXdTb3J0cz86IFNvcnRbXSkge1xuICAgIHRoaXMuX3NvcnRzLm5leHQobmV3U29ydHMgfHwgW10pO1xuICB9XG5cbiAgcHVibGljIGNsZWFyKCk6IHZvaWQge1xuICAgIHRoaXMucmVwbGFjZVNvcnRzKFtdKTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQcml2YXRlIG1ldGhvZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG59XG4iXX0=
|