@elderbyte/ngx-starter 16.3.4 → 16.4.1

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.
Files changed (48) hide show
  1. package/esm2022/lib/common/data/data-context/data-context-active-page.mjs +5 -5
  2. package/esm2022/lib/common/data/data-context/data-context-auto-starter.mjs +2 -2
  3. package/esm2022/lib/common/data/data-context/data-context-base.mjs +58 -28
  4. package/esm2022/lib/common/data/data-context/data-context-continuable-base.mjs +7 -7
  5. package/esm2022/lib/common/data/data-context/data-context-continuable-paged.mjs +10 -10
  6. package/esm2022/lib/common/data/data-context/data-context-continuable-token.mjs +8 -8
  7. package/esm2022/lib/common/data/data-context/data-context-simple.mjs +6 -5
  8. package/esm2022/lib/common/data/data-context/data-context-source-event-binding.mjs +2 -2
  9. package/esm2022/lib/common/data/data-context/data-context.mjs +1 -1
  10. package/esm2022/lib/common/data/filters/filter-context.mjs +12 -26
  11. package/esm2022/lib/common/data/required-filter-evaluator.mjs +2 -3
  12. package/esm2022/lib/common/data/sort-context.mjs +2 -2
  13. package/esm2022/lib/common/utils/filter-util.mjs +19 -1
  14. package/esm2022/lib/components/data-view/table/elder-table/elder-table.component.mjs +2 -2
  15. package/esm2022/lib/components/forms/search/domain/context/search-context.mjs +57 -0
  16. package/esm2022/lib/components/forms/search/domain/context/search-context.service.mjs +42 -0
  17. package/esm2022/lib/components/forms/search/domain/input/search-input-state.mjs +81 -0
  18. package/esm2022/lib/components/forms/search/domain/input/search-input.mjs +2 -0
  19. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.directive.mjs +74 -0
  20. package/esm2022/lib/components/forms/search/domain/url/elder-search-url.service.mjs +162 -0
  21. package/esm2022/lib/components/forms/search/domain/url/search-query-params-parser.mjs +81 -0
  22. package/esm2022/lib/components/forms/search/elder-search-context.directive.mjs +88 -50
  23. package/esm2022/lib/components/forms/search/elder-search-input.directive.mjs +6 -5
  24. package/esm2022/lib/components/forms/search/elder-search.module.mjs +30 -9
  25. package/fesm2022/elderbyte-ngx-starter.mjs +663 -432
  26. package/fesm2022/elderbyte-ngx-starter.mjs.map +1 -1
  27. package/lib/common/data/data-context/data-context-base.d.ts +10 -3
  28. package/lib/common/data/data-context/data-context.d.ts +6 -1
  29. package/lib/common/data/filters/filter-context.d.ts +1 -6
  30. package/lib/common/utils/filter-util.d.ts +1 -0
  31. package/lib/components/forms/search/domain/context/search-context.d.ts +38 -0
  32. package/lib/components/forms/search/domain/context/search-context.service.d.ts +25 -0
  33. package/lib/components/forms/search/{elder-search-context-url-binding.directive.d.ts → domain/url/elder-search-url.directive.d.ts} +12 -13
  34. package/lib/components/forms/search/domain/url/elder-search-url.service.d.ts +60 -0
  35. package/lib/components/forms/search/domain/url/search-query-params-parser.d.ts +36 -0
  36. package/lib/components/forms/search/elder-search-context.directive.d.ts +29 -16
  37. package/lib/components/forms/search/elder-search-input.directive.d.ts +2 -2
  38. package/lib/components/forms/search/elder-search.module.d.ts +5 -3
  39. package/package.json +1 -1
  40. package/esm2022/lib/components/forms/search/elder-search-context-url-binding.directive.mjs +0 -71
  41. package/esm2022/lib/components/forms/search/model/search-input-state.mjs +0 -81
  42. package/esm2022/lib/components/forms/search/model/search-input.mjs +0 -2
  43. package/esm2022/lib/components/forms/search/search-box/elder-search-context-filters.mjs +0 -10
  44. package/esm2022/lib/components/forms/search/search-box/elder-search-url-binding.service.mjs +0 -184
  45. package/lib/components/forms/search/search-box/elder-search-context-filters.d.ts +0 -7
  46. package/lib/components/forms/search/search-box/elder-search-url-binding.service.d.ts +0 -74
  47. /package/lib/components/forms/search/{model → domain/input}/search-input-state.d.ts +0 -0
  48. /package/lib/components/forms/search/{model → domain/input}/search-input.d.ts +0 -0
@@ -49,9 +49,9 @@ export class DataContextActivePage extends DataContextBase {
49
49
  * Sets the current page index / size and reload.
50
50
  */
51
51
  setActivePage(request) {
52
- this.actlogger.trace('Setting page to ', request);
52
+ // this.actlogger.trace('Setting page to ', request);
53
53
  if (!request) {
54
- throw new Error('Setting page PageRequest must not be null!');
54
+ throw new Error(this.id + ': Setting page PageRequest must not be null!');
55
55
  }
56
56
  let hasChange = false;
57
57
  const page = this.pageSnapshot;
@@ -63,7 +63,7 @@ export class DataContextActivePage extends DataContextBase {
63
63
  }
64
64
  if (hasChange) {
65
65
  this._page.next(request);
66
- this.reload();
66
+ this.reload('setActivePage');
67
67
  }
68
68
  }
69
69
  close() {
@@ -99,7 +99,7 @@ export class DataContextActivePage extends DataContextBase {
99
99
  this.onIdle();
100
100
  }, err => {
101
101
  this.clearData();
102
- this.actlogger.error('Failed to query data', err);
102
+ this.actlogger.error(this.id + ': Failed to query data', err);
103
103
  subject.error(err);
104
104
  this.onError(err);
105
105
  }, () => {
@@ -127,4 +127,4 @@ export class DataContextActivePage extends DataContextBase {
127
127
  super.onFiltersChanged(filters);
128
128
  }
129
129
  }
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-active-page.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-active-page.ts"],"names":[],"mappings":"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","sourcesContent":["import {DataContextBase} from './data-context-base';\nimport {Page, Pageable, PageRequest} from '../page';\nimport {Filter} from '../filters/filter';\nimport {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subject, Subscription} from 'rxjs';\nimport {first} from 'rxjs/operators';\nimport {IDataContextActivePage} from './data-context';\nimport {Sort} from '../sort';\nimport {IPagedDataSource} from '../datasource/data-source';\n\nexport class DataContextActivePage<T> extends DataContextBase<T> implements IDataContextActivePage<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly actlogger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _page: BehaviorSubject<PageRequest>;\n\n  /**\n   * Subscription to the event when the active page has changed.\n   * This will trigger a page reload.\n   */\n  private _activePageChangedSub: Subscription;\n\n  /**\n   * Subscription of an actual page load http request.\n   * If this is closed, it will cancel the http request.\n   */\n  private _activePageLoad: Subscription;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\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, indexFn, localApply, localSort);\n    this._page = new BehaviorSubject<PageRequest>(new PageRequest(0, pageSize));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IPagedDataSource<T> {\n    return <IPagedDataSource<T>>super.dataSource;\n  }\n\n  public get page(): Observable<PageRequest> {\n    return this._page.asObservable();\n  }\n\n  public get pageSnapshot(): PageRequest {\n    return this._page.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Set the current page index and reload.\n   * @param pageIndex\n   */\n  public setActiveIndex(pageIndex: number) {\n    this.setActivePage(new PageRequest(pageIndex, this.pageSnapshot.size));\n  }\n\n  /**\n   * Sets the current page index / size and reload.\n   */\n  public setActivePage(request: PageRequest) {\n\n    this.actlogger.trace('Setting page to ', request);\n\n    if (!request) { throw new Error('Setting page PageRequest must not be null!'); }\n\n    let hasChange = false;\n\n    const page = this.pageSnapshot;\n\n    if (page.index !== request.index) {\n      hasChange = true;\n    } else if (page.size !== request.size) {\n      hasChange = true;\n    }\n\n    if (hasChange) {\n      this._page.next(request);\n      this.reload();\n    }\n  }\n\n  public close(): void {\n    super.close();\n    if (this._activePageChangedSub) {\n      this._activePageChangedSub.unsubscribe();\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected clearAll(): void {\n    super.clearAll();\n    this.setActiveIndex(0);\n  }\n\n  protected reloadInternal(): Observable<any> {\n\n    if (this._activePageLoad) {\n      // Cancel previous pending request\n      this._activePageLoad.unsubscribe();\n    }\n\n    const subject = new Subject<any>();\n\n    this.onLoading();\n    const page = this.pageSnapshot;\n    const pageRequest = new Pageable(page.index, page.size, this.sort.sortsSnapshot);\n\n\n    this._activePageLoad = this.dataSource.findAllPaged(pageRequest, this.filter.filtersSnapshot)\n      .pipe(first())\n      .subscribe(\n        success => {\n          this.setTotal(success.totalElements);\n          this.setData(success.content);\n          subject.next(success);\n          this.onIdle();\n        }, err => {\n          this.clearData();\n          this.actlogger.error('Failed to query data', err);\n          subject.error(err);\n          this.onError(err);\n        }, () => {\n          this.onIdle();\n        });\n\n    return subject.pipe(first());\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event handlers                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the sorts property has changed.\n   */\n  protected onSortsChanged(sorts: Sort[]): void {\n    this.setActiveIndex(0);\n    super.onSortsChanged(sorts);\n  }\n\n  /**\n   * Occurs when the filtersSnapshot property has changed.\n   */\n  protected onFiltersChanged(filters: Filter[]): void {\n    this.setActiveIndex(0);\n    super.onFiltersChanged(filters);\n  }\n}\n\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-active-page.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-active-page.ts"],"names":[],"mappings":"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","sourcesContent":["import {DataContextBase} from './data-context-base';\nimport {Page, Pageable, PageRequest} from '../page';\nimport {Filter} from '../filters/filter';\nimport {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {BehaviorSubject, Observable, Subject, Subscription} from 'rxjs';\nimport {first} from 'rxjs/operators';\nimport {IDataContextActivePage} from './data-context';\nimport {Sort} from '../sort';\nimport {IPagedDataSource} from '../datasource/data-source';\n\nexport class DataContextActivePage<T> extends DataContextBase<T> implements IDataContextActivePage<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly actlogger: Logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _page: BehaviorSubject<PageRequest>;\n\n  /**\n   * Subscription to the event when the active page has changed.\n   * This will trigger a page reload.\n   */\n  private _activePageChangedSub: Subscription;\n\n  /**\n   * Subscription of an actual page load http request.\n   * If this is closed, it will cancel the http request.\n   */\n  private _activePageLoad: Subscription;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\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, indexFn, localApply, localSort);\n    this._page = new BehaviorSubject<PageRequest>(new PageRequest(0, pageSize));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IPagedDataSource<T> {\n    return <IPagedDataSource<T>>super.dataSource;\n  }\n\n  public get page(): Observable<PageRequest> {\n    return this._page.asObservable();\n  }\n\n  public get pageSnapshot(): PageRequest {\n    return this._page.getValue();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Set the current page index and reload.\n   * @param pageIndex\n   */\n  public setActiveIndex(pageIndex: number) {\n    this.setActivePage(new PageRequest(pageIndex, this.pageSnapshot.size));\n  }\n\n  /**\n   * Sets the current page index / size and reload.\n   */\n  public setActivePage(request: PageRequest) {\n\n    // this.actlogger.trace('Setting page to ', request);\n\n    if (!request) { throw new Error(this.id +': Setting page PageRequest must not be null!'); }\n\n    let hasChange = false;\n\n    const page = this.pageSnapshot;\n\n    if (page.index !== request.index) {\n      hasChange = true;\n    } else if (page.size !== request.size) {\n      hasChange = true;\n    }\n\n    if (hasChange) {\n      this._page.next(request);\n      this.reload('setActivePage');\n    }\n  }\n\n  public close(): void {\n    super.close();\n    if (this._activePageChangedSub) {\n      this._activePageChangedSub.unsubscribe();\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected clearAll(): void {\n    super.clearAll();\n    this.setActiveIndex(0);\n  }\n\n  protected reloadInternal(): Observable<any> {\n\n    if (this._activePageLoad) {\n      // Cancel previous pending request\n      this._activePageLoad.unsubscribe();\n    }\n\n    const subject = new Subject<any>();\n\n    this.onLoading();\n    const page = this.pageSnapshot;\n    const pageRequest = new Pageable(page.index, page.size, this.sort.sortsSnapshot);\n\n\n    this._activePageLoad = this.dataSource.findAllPaged(pageRequest, this.filter.filtersSnapshot)\n      .pipe(first())\n      .subscribe(\n        success => {\n          this.setTotal(success.totalElements);\n          this.setData(success.content);\n          subject.next(success);\n          this.onIdle();\n        }, err => {\n          this.clearData();\n          this.actlogger.error(this.id +': Failed to query data', err);\n          subject.error(err);\n          this.onError(err);\n        }, () => {\n          this.onIdle();\n        });\n\n    return subject.pipe(first());\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event handlers                                                          *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the sorts property has changed.\n   */\n  protected onSortsChanged(sorts: Sort[]): void {\n    this.setActiveIndex(0);\n    super.onSortsChanged(sorts);\n  }\n\n  /**\n   * Occurs when the filtersSnapshot property has changed.\n   */\n  protected onFiltersChanged(filters: Filter[]): void {\n    this.setActiveIndex(0);\n    super.onFiltersChanged(filters);\n  }\n}\n\n"]}
@@ -69,8 +69,8 @@ export class DataContextAutoStarter extends DataContextLifeCycleBinding {
69
69
  return new RequiredFilterEvaluator(this._dataContext.filter, this._autoStartSpec.requiredFilters).context$.pipe(map(event => event.isValid));
70
70
  }
71
71
  startDataContext() {
72
- this.logger.debug('Auto starting data context...');
72
+ this.logger.debug(this._dataContext.id + ': Auto starting ...');
73
73
  this._dataContext.start(this._autoStartSpec.initialSort);
74
74
  }
75
75
  }
76
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-auto-starter.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-auto-starter.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {IDataContext} from './data-context';\nimport {RequiredFilterEvaluator} from '../required-filter-evaluator';\nimport {DataContextLifeCycleBinding} from './data-context-life-cycle-binding';\nimport {Observable} from 'rxjs';\nimport {filter, map, takeUntil, tap} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {Sort} from '../sort';\n\nexport class AutoStartSpec {\n\n  public static asap(sort?: Sort[]): AutoStartSpec {\n    return new AutoStartSpec(null, sort);\n  }\n\n  public static requireFiltersAll(filters: string[], sort?: Sort[]): AutoStartSpec {\n    return AutoStartSpec.requireFilters([filters], sort);\n  }\n\n  public static requireFiltersAny(filters: string[], sort?: Sort[]): AutoStartSpec {\n    const separateFilterArrays = filters.map(singleFilter => [singleFilter]);\n    return AutoStartSpec.requireFilters(separateFilterArrays, sort);\n  }\n\n  public static requireFilters(filters: Array<string[]>, sort?: Sort[]): AutoStartSpec {\n    return new AutoStartSpec(filters, sort);\n  }\n\n  constructor(\n    public requiredFilters?: Array<string[]>,\n    public initialSort?: Sort[]\n  ) {\n  }\n}\n\nexport class DataContextAutoStarter extends DataContextLifeCycleBinding {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _autoStartConditionFulfilled$: Observable<boolean>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataContext: IDataContext<any>,\n    private readonly _autoStartSpec: AutoStartSpec\n  ) {\n    super(dataContext);\n\n    if (_autoStartSpec == null) {\n      throw new Error('autoStartSpec must not be null!');\n    }\n\n    if (_autoStartSpec.requiredFilters) {\n      this._autoStartConditionFulfilled$ = this.buildRequiredFilterConditionObservable();\n    } else {\n      // no condition defined, try to start immediately\n      this.startDataContext();\n    }\n\n    this.subscribe();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  protected subscribe(): void {\n    const hasRequiredFilters = !!this._autoStartConditionFulfilled$;\n    if (hasRequiredFilters) {\n      const startedTrue$ = this._dataContext.isStarted$.pipe(filter(t => t));\n      this._subscription = this._autoStartConditionFulfilled$.pipe(\n        takeUntil(startedTrue$),\n        tap(fulfilled => this.logger.debug(`Got fulfilled event: ${fulfilled}`)),\n        filter(fulfilled => !!fulfilled)\n      ).subscribe(() => this.startDataContext());\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildRequiredFilterConditionObservable(): Observable<boolean> {\n    return new RequiredFilterEvaluator(\n      this._dataContext.filter,\n      this._autoStartSpec.requiredFilters\n    ).context$.pipe(\n      map(event => event.isValid)\n    );\n  }\n\n  private startDataContext() {\n    this.logger.debug('Auto starting data context...');\n    this._dataContext.start(this._autoStartSpec.initialSort);\n  }\n\n}\n"]}
76
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-auto-starter.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-auto-starter.ts"],"names":[],"mappings":"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","sourcesContent":["\nimport {IDataContext} from './data-context';\nimport {RequiredFilterEvaluator} from '../required-filter-evaluator';\nimport {DataContextLifeCycleBinding} from './data-context-life-cycle-binding';\nimport {Observable} from 'rxjs';\nimport {filter, map, takeUntil, tap} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {Sort} from '../sort';\n\nexport class AutoStartSpec {\n\n  public static asap(sort?: Sort[]): AutoStartSpec {\n    return new AutoStartSpec(null, sort);\n  }\n\n  public static requireFiltersAll(filters: string[], sort?: Sort[]): AutoStartSpec {\n    return AutoStartSpec.requireFilters([filters], sort);\n  }\n\n  public static requireFiltersAny(filters: string[], sort?: Sort[]): AutoStartSpec {\n    const separateFilterArrays = filters.map(singleFilter => [singleFilter]);\n    return AutoStartSpec.requireFilters(separateFilterArrays, sort);\n  }\n\n  public static requireFilters(filters: Array<string[]>, sort?: Sort[]): AutoStartSpec {\n    return new AutoStartSpec(filters, sort);\n  }\n\n  constructor(\n    public requiredFilters?: Array<string[]>,\n    public initialSort?: Sort[]\n  ) {\n  }\n}\n\nexport class DataContextAutoStarter extends DataContextLifeCycleBinding {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly _autoStartConditionFulfilled$: Observable<boolean>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    dataContext: IDataContext<any>,\n    private readonly _autoStartSpec: AutoStartSpec\n  ) {\n    super(dataContext);\n\n    if (_autoStartSpec == null) {\n      throw new Error('autoStartSpec must not be null!');\n    }\n\n    if (_autoStartSpec.requiredFilters) {\n      this._autoStartConditionFulfilled$ = this.buildRequiredFilterConditionObservable();\n    } else {\n      // no condition defined, try to start immediately\n      this.startDataContext();\n    }\n\n    this.subscribe();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  protected subscribe(): void {\n    const hasRequiredFilters = !!this._autoStartConditionFulfilled$;\n    if (hasRequiredFilters) {\n      const startedTrue$ = this._dataContext.isStarted$.pipe(filter(t => t));\n      this._subscription = this._autoStartConditionFulfilled$.pipe(\n        takeUntil(startedTrue$),\n        tap(fulfilled => this.logger.debug(`Got fulfilled event: ${fulfilled}`)),\n        filter(fulfilled => !!fulfilled)\n      ).subscribe(() => this.startDataContext());\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildRequiredFilterConditionObservable(): Observable<boolean> {\n    return new RequiredFilterEvaluator(\n      this._dataContext.filter,\n      this._autoStartSpec.requiredFilters\n    ).context$.pipe(\n      map(event => event.isValid)\n    );\n  }\n\n  private startDataContext() {\n    this.logger.debug(this._dataContext.id + ': Auto starting ...');\n    this._dataContext.start(this._autoStartSpec.initialSort);\n  }\n\n}\n"]}
@@ -1,13 +1,34 @@
1
1
  import { LoggerFactory } from '@elderbyte/ts-logger';
2
2
  import { DataSource } from '@angular/cdk/collections';
3
3
  import { DataContextStatus } from './data-context-status';
4
- import { BehaviorSubject, EMPTY, Subject } from 'rxjs';
4
+ import { BehaviorSubject, of, Subject, switchMap } from 'rxjs';
5
5
  import { FilterContext } from '../filters/filter-context';
6
6
  import { DataContextSnapshot } from './data-context';
7
7
  import { catchError, debounceTime, filter, map, takeUntil } from 'rxjs/operators';
8
8
  import { SortContext } from '../sort-context';
9
9
  import { IndexedEntities } from './indexed-entities';
10
+ class ReloadRequest {
11
+ constructor(number, reason) {
12
+ this.number = number;
13
+ this.reason = reason;
14
+ }
15
+ }
16
+ class AfterReload {
17
+ constructor(request, result) {
18
+ this.request = request;
19
+ this.result = result;
20
+ }
21
+ fulfills(minRequest) {
22
+ return this.request.number >= minRequest.number;
23
+ }
24
+ }
10
25
  export class DataContextBase extends DataSource {
26
+ /***************************************************************************
27
+ * *
28
+ * Fields *
29
+ * *
30
+ **************************************************************************/
31
+ static { this.DC_ID_COUNTER = 0; }
11
32
  /***************************************************************************
12
33
  * *
13
34
  * Constructor *
@@ -18,11 +39,6 @@ export class DataContextBase extends DataSource {
18
39
  this._indexFn = _indexFn;
19
40
  this._localApply = _localApply;
20
41
  this._localSort = _localSort;
21
- /***************************************************************************
22
- * *
23
- * Fields *
24
- * *
25
- **************************************************************************/
26
42
  this.baselog = LoggerFactory.getLogger('DataContextBase');
27
43
  this._filter = new FilterContext();
28
44
  this._sort = new SortContext();
@@ -31,18 +47,20 @@ export class DataContextBase extends DataSource {
31
47
  this._started = new BehaviorSubject(false);
32
48
  this._closed = new BehaviorSubject(false);
33
49
  this._customIndex = new Map();
50
+ this._reloadCounter = 0;
34
51
  this._reloadQueue = new Subject();
35
- this.unsubscribe$ = new Subject();
52
+ this._reloaded = new Subject();
53
+ this.destroy$ = new Subject();
54
+ this.id = 'DataContext#' + (++DataContextBase.DC_ID_COUNTER);
36
55
  this._dataSource = dataSource;
37
56
  this._data = new IndexedEntities(e => dataSource.getId(e), _localSort, this._sort);
38
57
  this._loading = this._status.pipe(map(status => status.loading));
39
- this._filter.filters.pipe(filter(() => this.started), takeUntil(this.unsubscribe$)).subscribe(filters => this.onFiltersChanged(filters));
40
- this._sort.sorts.pipe(filter(() => this.started), takeUntil(this.unsubscribe$)).subscribe(sorts => this.onSortsChanged(sorts));
41
- this._reloadQueue.pipe(filter(() => this.started), debounceTime(50), takeUntil(this.unsubscribe$), catchError(err => {
42
- this.baselog.error('Reload queue detected error, bad!', err);
43
- return EMPTY;
44
- })).subscribe(() => this.reloadNow());
45
- // Maybe skipMap the real requests for auto abort pending (except for continuation / paged)
58
+ this._filter.filters.pipe(filter(() => this.started), takeUntil(this.destroy$)).subscribe(filters => this.onFiltersChanged(filters));
59
+ this._sort.sorts.pipe(filter(() => this.started), takeUntil(this.destroy$)).subscribe(sorts => this.onSortsChanged(sorts));
60
+ this._reloadQueue.pipe(takeUntil(this.destroy$), filter(request => this.started), debounceTime(50), switchMap(request => this.reloadNow(request).pipe(map(result => new AfterReload(request, result)), catchError(err => {
61
+ this.baselog.error(this.id + ': Reload queue detected error, bad!', err);
62
+ return of(new AfterReload(request, err));
63
+ })))).subscribe(afterReload => this._reloaded.next(afterReload));
46
64
  }
47
65
  /***************************************************************************
48
66
  * *
@@ -121,22 +139,28 @@ export class DataContextBase extends DataSource {
121
139
  **************************************************************************/
122
140
  start(sorts, filters) {
123
141
  if (this.isClosed) {
124
- throw new Error('Restarting a closed DataContext is not possible!'); // See unsubscribe$
142
+ throw new Error(this.id + ': Restarting a closed DataContext is not possible!'); // See unsubscribe$
125
143
  }
126
- this.baselog.debug('Starting fresh dataContext ...');
127
144
  this.started = false;
128
145
  this._sort.replaceSorts(sorts || this.sort.sortsSnapshot);
129
146
  this._filter.replaceFilters(filters || this.filter.filtersSnapshot);
147
+ this.baselog.debug(this.id + ': Start ...', {
148
+ dataSource: this.dataSource,
149
+ sort: this._sort.sortsSnapshot,
150
+ filter: this._filter.filtersSnapshot
151
+ });
130
152
  this.started = true;
131
- return this.reloadNow();
153
+ return this.reload('START');
132
154
  }
133
- reload() {
134
- this.baselog.debug('Requesting a reload of the DataContext from the DataSource.');
135
- this._reloadQueue.next();
155
+ reload(reason) {
156
+ const request = new ReloadRequest(++this._reloadCounter, reason);
157
+ this.baselog.debug(this.id + ': Enqueuing reload request #' + request.number + ' [' + reason + ']');
158
+ this._reloadQueue.next(request);
159
+ return this._reloaded.pipe(filter(reload => reload.fulfills(request)), map(reload => reload.result));
136
160
  }
137
161
  findByIndex(key) {
138
162
  if (!this._indexFn) {
139
- throw new Error('findByIndex requires you to pass a index function!');
163
+ throw new Error(this.id + ': findByIndex requires you to pass a index function!');
140
164
  }
141
165
  return this._customIndex.get(key);
142
166
  }
@@ -148,14 +172,14 @@ export class DataContextBase extends DataSource {
148
172
  */
149
173
  close() {
150
174
  this.started = false;
151
- this.unsubscribe$.next();
152
- this.unsubscribe$.complete();
175
+ this.destroy$.next();
176
+ this.destroy$.complete();
153
177
  this._closed.next(true);
154
178
  this._data.destroy();
155
179
  this._total.complete();
156
180
  this._status.complete();
157
181
  this.clearAll();
158
- this.baselog.debug('DataContext has been closed and resources cleaned up!');
182
+ this.baselog.debug(this.id + ': Has been closed and resources cleaned up!');
159
183
  }
160
184
  refresh() {
161
185
  this._data.notify();
@@ -168,7 +192,13 @@ export class DataContextBase extends DataSource {
168
192
  * Protected methods *
169
193
  * *
170
194
  **************************************************************************/
171
- reloadNow() {
195
+ reloadNow(request) {
196
+ this.baselog.debug(this.id + ": reloadNow triggered. Request #" + request.number + ' ' + request.reason, {
197
+ filter: this._filter.filtersSnapshot,
198
+ sort: this._sort.sortsSnapshot,
199
+ dataSource: this.dataSource,
200
+ request: request
201
+ });
172
202
  return this.reloadInternal(); // TODO This should actually return the real (http) request
173
203
  }
174
204
  /**
@@ -266,7 +296,7 @@ export class DataContextBase extends DataSource {
266
296
  */
267
297
  onSortsChanged(sorts) {
268
298
  if (!this._localSort) {
269
- this.reload();
299
+ this.reload('Sort Changed');
270
300
  }
271
301
  else {
272
302
  this.setData(this.dataSnapshot, true);
@@ -276,7 +306,7 @@ export class DataContextBase extends DataSource {
276
306
  * Occurs when the filter has changed.
277
307
  */
278
308
  onFiltersChanged(filters) {
279
- this.reload();
309
+ this.reload('Filters Changed');
280
310
  }
281
311
  onError(err) {
282
312
  this.onStatus(DataContextStatus.error(err));
@@ -299,4 +329,4 @@ export class DataContextBase extends DataSource {
299
329
  this._customIndex.clear();
300
330
  }
301
331
  }
302
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {Filter} from '../filters/filter';\nimport {Sort} from '../sort';\nimport {CollectionViewer, DataSource} from '@angular/cdk/collections';\nimport {DataContextStatus} from './data-context-status';\nimport {BehaviorSubject, EMPTY, Observable, Subject} from 'rxjs';\nimport {FilterContext} from '../filters/filter-context';\nimport {DataContextSnapshot, IDataContext} from './data-context';\nimport {catchError, debounceTime, filter, map, takeUntil} from 'rxjs/operators';\nimport {SortContext} from '../sort-context';\nimport {IDataSource} from '../datasource/data-source';\nimport {IndexedEntities} from './indexed-entities';\n\nexport abstract class DataContextBase<T, TId = any> extends DataSource<T> implements IDataContext<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly baselog: Logger = LoggerFactory.getLogger('DataContextBase');\n\n  private readonly _dataSource: IDataSource<T>;\n\n  private readonly _filter = new FilterContext();\n  private readonly _sort = new SortContext();\n\n  private readonly _loading: Observable<boolean>;\n\n  private readonly _data: IndexedEntities<T, TId>;\n  private readonly _total = new BehaviorSubject<number | undefined>(undefined);\n  private readonly _status = new BehaviorSubject<DataContextStatus>(DataContextStatus.idle());\n\n  private readonly _started = new BehaviorSubject<boolean>(false);\n  private readonly _closed = new BehaviorSubject<boolean>(false);\n\n  private readonly _customIndex = new Map<any, T>();\n\n  private readonly _reloadQueue = new Subject<void>();\n\n  protected readonly unsubscribe$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    dataSource: IDataSource<T>,\n    private _indexFn: ((item: T) => any),\n    private _localApply: ((data: T[]) => T[]),\n    private _localSort: ((data: T[], sorts: Sort[]) => T[]),\n  ) {\n    super();\n\n    this._dataSource = dataSource;\n    this._data = new IndexedEntities(e => dataSource.getId(e), _localSort, this._sort);\n\n    this._loading = this._status.pipe(\n      map(status => status.loading)\n    );\n\n    this._filter.filters.pipe(\n      filter(() => this.started),\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      filters => this.onFiltersChanged(filters)\n    );\n\n    this._sort.sorts.pipe(\n      filter(() => this.started),\n      takeUntil(this.unsubscribe$)\n    ).subscribe(\n      sorts => this.onSortsChanged(sorts)\n    );\n\n    this._reloadQueue.pipe(\n      filter(() => this.started),\n      debounceTime(50),\n      takeUntil(this.unsubscribe$),\n      catchError(err => {  // Dont die on errors\n        this.baselog.error('Reload queue detected error, bad!', err);\n        return EMPTY;\n      })\n    ).subscribe(() => this.reloadNow());\n    // Maybe skipMap the real requests for auto abort pending (except for continuation / paged)\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Material DC                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public connect(collectionViewer: CollectionViewer): Observable<T[]> {\n    return this.data;\n  }\n\n  public disconnect(collectionViewer: CollectionViewer): void {\n    // this.close(); Closing will destroy the DC\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IDataSource<T> {\n    return this._dataSource;\n  }\n\n  public get snapshot(): DataContextSnapshot<T> {\n    return new DataContextSnapshot(\n      this.dataSnapshot,\n      this.isEmpty,\n      this.loadingSnapshot,\n      this.totalSnapshot,\n      this.statusSnapshot\n    );\n  }\n\n\n  public get total(): Observable<number | undefined> {\n    return this._total.asObservable();\n  }\n\n  public get totalSnapshot(): number | undefined {\n    return this._total.getValue();\n  }\n\n  public get sort(): SortContext {\n    return this._sort;\n  }\n\n  public get filter(): FilterContext {\n    return this._filter;\n  }\n\n  public get loading(): Observable<boolean> {\n    return this._loading;\n  }\n\n  public get loadingSnapshot(): boolean {\n    return this.statusSnapshot?.loading;\n  }\n\n  public get data(): Observable<T[]> {\n    return this._data.entities$;\n  }\n\n  public get dataSnapshot(): T[] {\n    return this._data.entitiesSnapshot;\n  }\n\n  public get status(): Observable<DataContextStatus> {\n    return this._status;\n  }\n\n  public get statusSnapshot(): DataContextStatus {\n    return this._status.getValue();\n  }\n\n  public get isEmpty(): boolean {\n    return this.dataSnapshot.length === 0;\n  }\n\n  public get isStarted(): boolean {\n    return this.started;\n  }\n\n  public get isStarted$(): Observable<boolean> {\n    return this._started.asObservable();\n  }\n\n  public get isClosed(): boolean {\n    return this._closed.getValue();\n  }\n\n  protected get started(): boolean {\n    return this._started.getValue();\n  }\n\n  protected set started(started: boolean) {\n    this._started.next(started);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public start(sorts?: Sort[], filters?: Filter[]): Observable<any> {\n\n    if (this.isClosed) {\n      throw new Error('Restarting a closed DataContext is not possible!'); // See unsubscribe$\n    }\n\n    this.baselog.debug('Starting fresh dataContext ...');\n\n    this.started = false;\n\n    this._sort.replaceSorts(sorts || this.sort.sortsSnapshot);\n    this._filter.replaceFilters(filters || this.filter.filtersSnapshot);\n\n    this.started = true;\n\n    return this.reloadNow();\n  }\n\n  public reload(): void {\n    this.baselog.debug('Requesting a reload of the DataContext from the DataSource.')\n    this._reloadQueue.next();\n  }\n\n  public findByIndex(key: any): T | undefined {\n    if (!this._indexFn) {\n      throw new Error('findByIndex requires you to pass a index function!');\n    }\n    return this._customIndex.get(key);\n  }\n\n  public findById(id: any): T | undefined {\n    return this._data.getById(id);\n  }\n\n  /**\n   * Closes this DataContext and cleans up all used resources.\n   */\n  public close(): void {\n\n    this.started = false;\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this._closed.next(true);\n\n    this._data.destroy();\n    this._total.complete();\n    this._status.complete();\n\n    this.clearAll();\n    this.baselog.debug('DataContext has been closed and resources cleaned up!');\n  }\n\n  public refresh(): void {\n    this._data.notify();\n  }\n\n  public update(entities: T[]): void {\n    this._data.updateSome(entities);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protected methods                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  protected reloadNow(): Observable<any> {\n    return this.reloadInternal(); // TODO This should actually return the real (http) request\n  }\n\n  /**\n   * Append the given rows to the existing ones.\n   */\n  protected appendData(additionalData: T[]): void {\n    additionalData = this.localApply(additionalData);\n    this.indexAll(additionalData);\n    this._data.append(additionalData);\n  }\n\n  /**\n   * Insert the given rows at the given location.\n   */\n  protected insertData(additionalData: T[], offset: number): void {\n    additionalData = this.localApply(additionalData);\n    this.indexAll(additionalData);\n    this._data.insert(additionalData, offset);\n  }\n\n  /**\n   * Replaces the existing data with the new set.\n   * @param newData The new data set.\n   * @param alreadyIndexed The rows will be indexed unless they already have been.\n   */\n  protected setData(newData: T[], alreadyIndexed = false): void {\n    newData = this.localApply(newData);\n    if (!alreadyIndexed) {\n      this.clearIndex();\n      this.indexAll(newData);\n    }\n    this._data.replaceAll(newData);\n  }\n\n  protected clearData(): void {\n    this.setData([]);\n  }\n\n  private localApply(data: T[]): T[] {\n    if (this._localApply) {\n      return this._localApply(data);\n    } else {\n      return data;\n    }\n  }\n\n  protected setTotal(total: number | undefined): void {\n    this._total.next(total);\n  }\n\n  /**\n   * Clears the current data-context cached data.\n   * State such as current sorting and filtersSnapshot are kept.\n   */\n  protected clearAll(silent = false): void {\n    this.clearIndex();\n\n    if (!silent) {\n      this.setTotal(0);\n      this.clearData();\n    }\n\n    this.onIdle();\n  }\n\n  protected updateIndex(): void {\n    this.clearIndex();\n    this.indexAll(this.dataSnapshot);\n  }\n\n  /**\n   * Indexes the given item by key if there is an index function defined.\n   */\n  protected indexItem(item: T): void {\n    const key = this.getItemKey(item);\n    if (key) {\n      this._customIndex.set(key, item);\n    }\n  }\n\n  /**\n   * Indexes all the given items by key if there is an index function defined.\n   */\n  protected indexAll(items: T[]): void {\n    if (this._indexFn) {\n      items.forEach(item => this.indexItem(item));\n    }\n  }\n\n  protected getItemKey(item: T): any {\n    if (this._indexFn) {\n      return this._indexFn(item);\n    }\n    return null;\n  }\n\n  protected getItemId(item: T): TId {\n    return this.dataSource.getId(item);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event handler                                                           *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the sort has changed.\n   */\n  protected onSortsChanged(sorts: Sort[]): void {\n    if (!this._localSort) {\n      this.reload();\n    } else {\n      this.setData(this.dataSnapshot, true);\n    }\n  }\n\n  /**\n   * Occurs when the filter has changed.\n   */\n  protected onFiltersChanged(filters: Filter[]): void {\n    this.reload();\n  }\n\n  protected onError(err: any): void {\n    this.onStatus(DataContextStatus.error(err));\n  }\n\n  protected onIdle(): void {\n    this.onStatus(DataContextStatus.idle());\n  }\n\n  protected onLoading(): void {\n    this.onStatus(DataContextStatus.loading());\n  }\n\n  protected onStatus(status: DataContextStatus): void {\n    this._status.next(status);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Subclasses must implement this method and\n   * reload the currently held data.\n   * If possible, the current view state should be kept.\n   *\n   * @returns The reload job.\n   */\n  protected abstract reloadInternal(): Observable<any>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private clearIndex(): void {\n    this._customIndex.clear();\n  }\n}\n"]}
332
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-context-base.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/data/data-context/data-context-base.ts"],"names":[],"mappings":"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","sourcesContent":["import {Logger, LoggerFactory} from '@elderbyte/ts-logger';\nimport {Filter} from '../filters/filter';\nimport {Sort} from '../sort';\nimport {CollectionViewer, DataSource} from '@angular/cdk/collections';\nimport {DataContextStatus} from './data-context-status';\nimport {BehaviorSubject, EMPTY, Observable, of, Subject, switchMap} from 'rxjs';\nimport {FilterContext} from '../filters/filter-context';\nimport {DataContextSnapshot, IDataContext} from './data-context';\nimport {catchError, debounceTime, filter, map, takeUntil} from 'rxjs/operators';\nimport {SortContext} from '../sort-context';\nimport {IDataSource} from '../datasource/data-source';\nimport {IndexedEntities} from './indexed-entities';\n\nclass ReloadRequest {\n\n  constructor(\n    public readonly number: number,\n    public readonly reason?: string\n  ) {}\n}\n\nclass AfterReload {\n  constructor(\n    public readonly request: ReloadRequest,\n    public readonly result: any\n  ) {}\n\n  public fulfills(minRequest: ReloadRequest): boolean {\n    return this.request.number >= minRequest.number;\n  }\n}\n\nexport abstract class DataContextBase<T, TId = any> extends DataSource<T> implements IDataContext<T> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private static DC_ID_COUNTER = 0;\n\n\n  private readonly baselog: Logger = LoggerFactory.getLogger('DataContextBase');\n\n  /**\n   * ID of this DataContext\n   */\n  public readonly id: string;\n\n  private readonly _dataSource: IDataSource<T>;\n\n  private readonly _filter = new FilterContext();\n  private readonly _sort = new SortContext();\n\n  private readonly _loading: Observable<boolean>;\n\n  private readonly _data: IndexedEntities<T, TId>;\n  private readonly _total = new BehaviorSubject<number | undefined>(undefined);\n  private readonly _status = new BehaviorSubject<DataContextStatus>(DataContextStatus.idle());\n\n  private readonly _started = new BehaviorSubject<boolean>(false);\n  private readonly _closed = new BehaviorSubject<boolean>(false);\n\n  private readonly _customIndex = new Map<any, T>();\n\n  private _reloadCounter = 0;\n  private readonly _reloadQueue = new Subject<ReloadRequest>();\n  private readonly _reloaded = new Subject<AfterReload>();\n\n  protected readonly destroy$ = new Subject<void>();\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  protected constructor(\n    dataSource: IDataSource<T>,\n    private _indexFn: ((item: T) => any),\n    private _localApply: ((data: T[]) => T[]),\n    private _localSort: ((data: T[], sorts: Sort[]) => T[]),\n  ) {\n    super();\n    this.id = 'DataContext#' + (++DataContextBase.DC_ID_COUNTER);\n    this._dataSource = dataSource;\n    this._data = new IndexedEntities(e => dataSource.getId(e), _localSort, this._sort);\n\n    this._loading = this._status.pipe(\n      map(status => status.loading)\n    );\n\n    this._filter.filters.pipe(\n      filter(() => this.started),\n      takeUntil(this.destroy$)\n    ).subscribe(\n      filters => this.onFiltersChanged(filters)\n    );\n\n    this._sort.sorts.pipe(\n      filter(() => this.started),\n      takeUntil(this.destroy$)\n    ).subscribe(\n      sorts => this.onSortsChanged(sorts)\n    );\n\n    this._reloadQueue.pipe(\n      takeUntil(this.destroy$),\n      filter(request => this.started),\n      debounceTime(50),\n      switchMap(\n        request => this.reloadNow(request).pipe(\n          map(result => new AfterReload(request, result)),\n          catchError(err => {  // Dont die on errors\n            this.baselog.error(this.id + ': Reload queue detected error, bad!', err);\n            return of(new AfterReload(request, err));\n          }),\n        )\n      )\n    ).subscribe(afterReload => this._reloaded.next(afterReload));\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API Material DC                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  public connect(collectionViewer: CollectionViewer): Observable<T[]> {\n    return this.data;\n  }\n\n  public disconnect(collectionViewer: CollectionViewer): void {\n    // this.close(); Closing will destroy the DC\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public get dataSource(): IDataSource<T> {\n    return this._dataSource;\n  }\n\n  public get snapshot(): DataContextSnapshot<T> {\n    return new DataContextSnapshot(\n      this.dataSnapshot,\n      this.isEmpty,\n      this.loadingSnapshot,\n      this.totalSnapshot,\n      this.statusSnapshot\n    );\n  }\n\n\n  public get total(): Observable<number | undefined> {\n    return this._total.asObservable();\n  }\n\n  public get totalSnapshot(): number | undefined {\n    return this._total.getValue();\n  }\n\n  public get sort(): SortContext {\n    return this._sort;\n  }\n\n  public get filter(): FilterContext {\n    return this._filter;\n  }\n\n  public get loading(): Observable<boolean> {\n    return this._loading;\n  }\n\n  public get loadingSnapshot(): boolean {\n    return this.statusSnapshot?.loading;\n  }\n\n  public get data(): Observable<T[]> {\n    return this._data.entities$;\n  }\n\n  public get dataSnapshot(): T[] {\n    return this._data.entitiesSnapshot;\n  }\n\n  public get status(): Observable<DataContextStatus> {\n    return this._status;\n  }\n\n  public get statusSnapshot(): DataContextStatus {\n    return this._status.getValue();\n  }\n\n  public get isEmpty(): boolean {\n    return this.dataSnapshot.length === 0;\n  }\n\n  public get isStarted(): boolean {\n    return this.started;\n  }\n\n  public get isStarted$(): Observable<boolean> {\n    return this._started.asObservable();\n  }\n\n  public get isClosed(): boolean {\n    return this._closed.getValue();\n  }\n\n  protected get started(): boolean {\n    return this._started.getValue();\n  }\n\n  protected set started(started: boolean) {\n    this._started.next(started);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public start(sorts?: Sort[], filters?: Filter[]): Observable<any> {\n\n    if (this.isClosed) {\n      throw new Error(this.id + ': Restarting a closed DataContext is not possible!'); // See unsubscribe$\n    }\n\n    this.started = false;\n\n    this._sort.replaceSorts(sorts || this.sort.sortsSnapshot);\n    this._filter.replaceFilters(filters || this.filter.filtersSnapshot);\n\n    this.baselog.debug(this.id +': Start ...', {\n      dataSource: this.dataSource,\n      sort: this._sort.sortsSnapshot,\n      filter: this._filter.filtersSnapshot\n    });\n\n    this.started = true;\n\n    return this.reload('START');\n  }\n\n  public reload(reason?: string): Observable<any> {\n    const request = new ReloadRequest(++this._reloadCounter, reason);\n    this.baselog.debug(this.id +': Enqueuing reload request #'+request.number+' [' + reason + ']');\n    this._reloadQueue.next(request);\n    return this._reloaded.pipe(\n      filter(reload => reload.fulfills(request)),\n      map(reload => reload.result)\n    );\n  }\n\n  public findByIndex(key: any): T | undefined {\n    if (!this._indexFn) {\n      throw new Error(this.id +': findByIndex requires you to pass a index function!');\n    }\n    return this._customIndex.get(key);\n  }\n\n  public findById(id: any): T | undefined {\n    return this._data.getById(id);\n  }\n\n  /**\n   * Closes this DataContext and cleans up all used resources.\n   */\n  public close(): void {\n\n    this.started = false;\n    this.destroy$.next();\n    this.destroy$.complete();\n    this._closed.next(true);\n\n    this._data.destroy();\n    this._total.complete();\n    this._status.complete();\n\n    this.clearAll();\n    this.baselog.debug(this.id +': Has been closed and resources cleaned up!');\n  }\n\n  public refresh(): void {\n    this._data.notify();\n  }\n\n  public update(entities: T[]): void {\n    this._data.updateSome(entities);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Protected methods                                                       *\n   *                                                                         *\n   **************************************************************************/\n\n  private reloadNow(request: ReloadRequest): Observable<any> {\n    this.baselog.debug(this.id + \": reloadNow triggered. Request #\" + request.number + ' ' + request.reason , {\n      filter: this._filter.filtersSnapshot,\n      sort: this._sort.sortsSnapshot,\n      dataSource: this.dataSource,\n      request: request\n    });\n    return this.reloadInternal(); // TODO This should actually return the real (http) request\n  }\n\n  /**\n   * Append the given rows to the existing ones.\n   */\n  protected appendData(additionalData: T[]): void {\n    additionalData = this.localApply(additionalData);\n    this.indexAll(additionalData);\n    this._data.append(additionalData);\n  }\n\n  /**\n   * Insert the given rows at the given location.\n   */\n  protected insertData(additionalData: T[], offset: number): void {\n    additionalData = this.localApply(additionalData);\n    this.indexAll(additionalData);\n    this._data.insert(additionalData, offset);\n  }\n\n  /**\n   * Replaces the existing data with the new set.\n   * @param newData The new data set.\n   * @param alreadyIndexed The rows will be indexed unless they already have been.\n   */\n  protected setData(newData: T[], alreadyIndexed = false): void {\n    newData = this.localApply(newData);\n    if (!alreadyIndexed) {\n      this.clearIndex();\n      this.indexAll(newData);\n    }\n    this._data.replaceAll(newData);\n  }\n\n  protected clearData(): void {\n    this.setData([]);\n  }\n\n  private localApply(data: T[]): T[] {\n    if (this._localApply) {\n      return this._localApply(data);\n    } else {\n      return data;\n    }\n  }\n\n  protected setTotal(total: number | undefined): void {\n    this._total.next(total);\n  }\n\n  /**\n   * Clears the current data-context cached data.\n   * State such as current sorting and filtersSnapshot are kept.\n   */\n  protected clearAll(silent = false): void {\n    this.clearIndex();\n\n    if (!silent) {\n      this.setTotal(0);\n      this.clearData();\n    }\n\n    this.onIdle();\n  }\n\n  protected updateIndex(): void {\n    this.clearIndex();\n    this.indexAll(this.dataSnapshot);\n  }\n\n  /**\n   * Indexes the given item by key if there is an index function defined.\n   */\n  protected indexItem(item: T): void {\n    const key = this.getItemKey(item);\n    if (key) {\n      this._customIndex.set(key, item);\n    }\n  }\n\n  /**\n   * Indexes all the given items by key if there is an index function defined.\n   */\n  protected indexAll(items: T[]): void {\n    if (this._indexFn) {\n      items.forEach(item => this.indexItem(item));\n    }\n  }\n\n  protected getItemKey(item: T): any {\n    if (this._indexFn) {\n      return this._indexFn(item);\n    }\n    return null;\n  }\n\n  protected getItemId(item: T): TId {\n    return this.dataSource.getId(item);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Event handler                                                           *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the sort has changed.\n   */\n  protected onSortsChanged(sorts: Sort[]): void {\n    if (!this._localSort) {\n      this.reload('Sort Changed');\n    } else {\n      this.setData(this.dataSnapshot, true);\n    }\n  }\n\n  /**\n   * Occurs when the filter has changed.\n   */\n  protected onFiltersChanged(filters: Filter[]): void {\n    this.reload('Filters Changed');\n  }\n\n  protected onError(err: any): void {\n    this.onStatus(DataContextStatus.error(err));\n  }\n\n  protected onIdle(): void {\n    this.onStatus(DataContextStatus.idle());\n  }\n\n  protected onLoading(): void {\n    this.onStatus(DataContextStatus.loading());\n  }\n\n  protected onStatus(status: DataContextStatus): void {\n    this._status.next(status);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract methods                                                        *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Subclasses must implement this method and\n   * reload the currently held data.\n   * If possible, the current view state should be kept.\n   *\n   * @returns The reload job.\n   */\n  protected abstract reloadInternal(): Observable<any>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private clearIndex(): void {\n    this._customIndex.clear();\n  }\n}\n"]}
@@ -26,16 +26,16 @@ export class DataContextContinuableBase extends DataContextBase {
26
26
  * *
27
27
  **************************************************************************/
28
28
  loadAll(sorts, filters) {
29
- this.cblogger.debug('Starting to load all data ...');
29
+ this.cblogger.debug(this.id + ': Starting to load all data ...');
30
30
  // load first page
31
31
  this.start(sorts, filters)
32
32
  .subscribe(() => {
33
- this.cblogger.debug('First page has been loaded. Loading remaining data ...');
33
+ this.cblogger.debug(this.id + ': First page has been loaded. Loading remaining data ...');
34
34
  // load rest in a recursive manner
35
35
  this.loadAllRec();
36
36
  }, err => {
37
37
  this.onError(err);
38
- this.cblogger.error('Failed to load first page of load all procedure!', err);
38
+ this.cblogger.error(this.id + ': Failed to load first page of load all procedure!', err);
39
39
  });
40
40
  }
41
41
  get chunkSize() {
@@ -56,14 +56,14 @@ export class DataContextContinuableBase extends DataContextBase {
56
56
  loadAllRec() {
57
57
  this.loadMore()
58
58
  .subscribe(() => {
59
- this.cblogger.debug('Loading data chunk finished, loading next...');
59
+ this.cblogger.debug(this.id + ': Loading data chunk finished, loading next...');
60
60
  this.loadAllRec();
61
61
  }, err => {
62
62
  this.onError(err);
63
- this.cblogger.error('Loading all failed!', err);
63
+ this.cblogger.error(this.id + ': Loading all failed!', err);
64
64
  }, () => {
65
- this.cblogger.info('All data loaded completely.');
65
+ this.cblogger.info(this.id + ': All data loaded completely.');
66
66
  });
67
67
  }
68
68
  }
69
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb250ZXh0LWNvbnRpbnVhYmxlLWJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21tb24vZGF0YS9kYXRhLWNvbnRleHQvZGF0YS1jb250ZXh0LWNvbnRpbnVhYmxlLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBR3BELE9BQU8sRUFBUyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQU0zRDs7O0dBR0c7QUFDSCxNQUFNLE9BQWdCLDBCQUE4QixTQUFRLGVBQWtCO0lBWTVFOzs7O2dGQUk0RTtJQUU1RSxZQUNFLFVBQTBCLEVBQzFCLFNBQWlCLEVBQ2pCLE9BQTJCLEVBQzNCLFVBQWdDLEVBQ2hDLFNBQThDO1FBRTlDLEtBQUssQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLENBQUMsQ0FBQztRQXZCcEQ7Ozs7b0ZBSTRFO1FBRTNELGFBQVEsR0FBVyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFrQmpGLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQzlCLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsT0FBTyxDQUFDLEtBQWMsRUFBRSxPQUFrQjtRQUUvQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQywrQkFBK0IsQ0FBQyxDQUFDO1FBRXJELGtCQUFrQjtRQUNsQixJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssRUFBRSxPQUFPLENBQUM7YUFDdkIsU0FBUyxDQUFDLEdBQUcsRUFBRTtZQUNkLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLHdEQUF3RCxDQUFDLENBQUM7WUFDOUUsa0NBQWtDO1lBQ2xDLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNwQixDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUU7WUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLGtEQUFrRCxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQy9FLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLElBQVk7UUFDL0IsSUFBSSxJQUFJLENBQUMsVUFBVSxLQUFLLElBQUksRUFBRTtZQUM1QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUN2QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDL0I7SUFDSCxDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRWxFLGtCQUFrQixDQUFDLE9BQWUsSUFBVyxDQUFDO0lBRWhELFVBQVU7UUFDaEIsSUFBSSxDQUFDLFFBQVEsRUFBRTthQUNaLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyw4Q0FBOEMsQ0FBQyxDQUFDO1lBQ3BFLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztRQUNwQixDQUFDLEVBQUUsR0FBRyxDQUFDLEVBQUU7WUFDUCxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLHFCQUFxQixFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQ2xELENBQUMsRUFBRSxHQUFHLEVBQUU7WUFDTixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBQ3BELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztDQUtGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEYXRhQ29udGV4dEJhc2V9IGZyb20gJy4vZGF0YS1jb250ZXh0LWJhc2UnO1xuaW1wb3J0IHtTb3J0fSBmcm9tICcuLi9zb3J0JztcbmltcG9ydCB7RmlsdGVyfSBmcm9tICcuLi9maWx0ZXJzL2ZpbHRlcic7XG5pbXBvcnQge0xvZ2dlciwgTG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7SURhdGFDb250ZXh0Q29udGludWFibGV9IGZyb20gJy4vZGF0YS1jb250ZXh0JztcbmltcG9ydCB7SURhdGFTb3VyY2V9IGZyb20gJy4uL2RhdGFzb3VyY2UvZGF0YS1zb3VyY2UnO1xuXG5cbi8qKlxuICogRXh0ZW5kcyBhIHNpbXBsZSBmbGF0IGxpc3QgZGF0YS1jb250ZXh0IHdpdGggaW5maW5pdGUtc2Nyb2xsIHBhZ2luYXRpb24gc3VwcG9ydC5cbiAqXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEYXRhQ29udGV4dENvbnRpbnVhYmxlQmFzZTxUPiBleHRlbmRzIERhdGFDb250ZXh0QmFzZTxUPiBpbXBsZW1lbnRzIElEYXRhQ29udGV4dENvbnRpbnVhYmxlPFQ+IHtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGNibG9nZ2VyOiBMb2dnZXIgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIHByaXZhdGUgX2NodW5rU2l6ZTogbnVtYmVyO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvcnMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihcbiAgICBkYXRhU291cmNlOiBJRGF0YVNvdXJjZTxUPixcbiAgICBjaHVua1NpemU6IG51bWJlcixcbiAgICBpbmRleEZuOiAoKGl0ZW06IFQpID0+IGFueSksXG4gICAgbG9jYWxBcHBseTogKChkYXRhOiBUW10pID0+IFRbXSksXG4gICAgbG9jYWxTb3J0OiAoKGRhdGE6IFRbXSwgc29ydHM6IFNvcnRbXSkgPT4gVFtdKVxuICApIHtcbiAgICBzdXBlcihkYXRhU291cmNlLCBpbmRleEZuLCBsb2NhbEFwcGx5LCBsb2NhbFNvcnQpO1xuICAgIHRoaXMuX2NodW5rU2l6ZSA9IGNodW5rU2l6ZTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBsb2FkQWxsKHNvcnRzPzogU29ydFtdLCBmaWx0ZXJzPzogRmlsdGVyW10pOiB2b2lkIHtcblxuICAgIHRoaXMuY2Jsb2dnZXIuZGVidWcoJ1N0YXJ0aW5nIHRvIGxvYWQgYWxsIGRhdGEgLi4uJyk7XG5cbiAgICAvLyBsb2FkIGZpcnN0IHBhZ2VcbiAgICB0aGlzLnN0YXJ0KHNvcnRzLCBmaWx0ZXJzKVxuICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgIHRoaXMuY2Jsb2dnZXIuZGVidWcoJ0ZpcnN0IHBhZ2UgaGFzIGJlZW4gbG9hZGVkLiBMb2FkaW5nIHJlbWFpbmluZyBkYXRhIC4uLicpO1xuICAgICAgICAvLyBsb2FkIHJlc3QgaW4gYSByZWN1cnNpdmUgbWFubmVyXG4gICAgICAgIHRoaXMubG9hZEFsbFJlYygpO1xuICAgICAgfSwgZXJyID0+IHtcbiAgICAgICAgdGhpcy5vbkVycm9yKGVycik7XG4gICAgICAgIHRoaXMuY2Jsb2dnZXIuZXJyb3IoJ0ZhaWxlZCB0byBsb2FkIGZpcnN0IHBhZ2Ugb2YgbG9hZCBhbGwgcHJvY2VkdXJlIScsIGVycik7XG4gICAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgY2h1bmtTaXplKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuX2NodW5rU2l6ZTtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgY2h1bmtTaXplKHNpemU6IG51bWJlcikge1xuICAgIGlmICh0aGlzLl9jaHVua1NpemUgIT09IHNpemUpIHtcbiAgICAgIHRoaXMuX2NodW5rU2l6ZSA9IHNpemU7XG4gICAgICB0aGlzLm9uQ2h1bmtTaXplQ2hhbmdlZChzaXplKTtcbiAgICB9XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJpdmF0ZSBNZXRob2RzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcm90ZWN0ZWQgb25DaHVua1NpemVDaGFuZ2VkKG5ld1NpemU6IG51bWJlcik6IHZvaWQgeyAgfVxuXG4gIHByaXZhdGUgbG9hZEFsbFJlYygpOiB2b2lkIHtcbiAgICB0aGlzLmxvYWRNb3JlKClcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmNibG9nZ2VyLmRlYnVnKCdMb2FkaW5nIGRhdGEgY2h1bmsgZmluaXNoZWQsIGxvYWRpbmcgbmV4dC4uLicpO1xuICAgICAgICB0aGlzLmxvYWRBbGxSZWMoKTtcbiAgICAgIH0sIGVyciA9PiB7XG4gICAgICAgIHRoaXMub25FcnJvcihlcnIpO1xuICAgICAgICB0aGlzLmNibG9nZ2VyLmVycm9yKCdMb2FkaW5nIGFsbCBmYWlsZWQhJywgZXJyKTtcbiAgICAgIH0sICgpID0+IHtcbiAgICAgICAgdGhpcy5jYmxvZ2dlci5pbmZvKCdBbGwgZGF0YSBsb2FkZWQgY29tcGxldGVseS4nKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFic3RyYWN0IGxvYWRNb3JlKCk6IE9ic2VydmFibGU8YW55PjtcbiAgcHVibGljIGFic3RyYWN0IGdldCBoYXNNb3JlRGF0YVNuYXBzaG90KCk6IGJvb2xlYW47XG4gIHB1YmxpYyBhYnN0cmFjdCBnZXQgaGFzTW9yZURhdGEoKTogT2JzZXJ2YWJsZTxib29sZWFuPjtcbn1cbiJdfQ==
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1jb250ZXh0LWNvbnRpbnVhYmxlLWJhc2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21tb24vZGF0YS9kYXRhLWNvbnRleHQvZGF0YS1jb250ZXh0LWNvbnRpbnVhYmxlLWJhc2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBR3BELE9BQU8sRUFBUyxhQUFhLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQU0zRDs7O0dBR0c7QUFDSCxNQUFNLE9BQWdCLDBCQUE4QixTQUFRLGVBQWtCO0lBWTVFOzs7O2dGQUk0RTtJQUU1RSxZQUNFLFVBQTBCLEVBQzFCLFNBQWlCLEVBQ2pCLE9BQTJCLEVBQzNCLFVBQWdDLEVBQ2hDLFNBQThDO1FBRTlDLEtBQUssQ0FBQyxVQUFVLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRSxTQUFTLENBQUMsQ0FBQztRQXZCcEQ7Ozs7b0ZBSTRFO1FBRTNELGFBQVEsR0FBVyxhQUFhLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7UUFrQmpGLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQzlCLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsT0FBTyxDQUFDLEtBQWMsRUFBRSxPQUFrQjtRQUUvQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFFLGlDQUFpQyxDQUFDLENBQUM7UUFFaEUsa0JBQWtCO1FBQ2xCLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQzthQUN2QixTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRSwwREFBMEQsQ0FBQyxDQUFDO1lBQ3pGLGtDQUFrQztZQUNsQyxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDcEIsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxFQUFFO1lBQ1AsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNsQixJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFFLG9EQUFvRCxFQUFFLEdBQUcsQ0FBQyxDQUFDO1FBQzFGLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLElBQVk7UUFDL0IsSUFBSSxJQUFJLENBQUMsVUFBVSxLQUFLLElBQUksRUFBRTtZQUM1QixJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQztZQUN2QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDL0I7SUFDSCxDQUFDO0lBRUQ7Ozs7Z0ZBSTRFO0lBRWxFLGtCQUFrQixDQUFDLE9BQWUsSUFBVyxDQUFDO0lBRWhELFVBQVU7UUFDaEIsSUFBSSxDQUFDLFFBQVEsRUFBRTthQUNaLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsRUFBRSxHQUFFLGdEQUFnRCxDQUFDLENBQUM7WUFDL0UsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ3BCLENBQUMsRUFBRSxHQUFHLENBQUMsRUFBRTtZQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLENBQUM7WUFDbEIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRSx1QkFBdUIsRUFBRSxHQUFHLENBQUMsQ0FBQztRQUM3RCxDQUFDLEVBQUUsR0FBRyxFQUFFO1lBQ04sSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEVBQUUsR0FBRSwrQkFBK0IsQ0FBQyxDQUFDO1FBQy9ELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztDQUtGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEYXRhQ29udGV4dEJhc2V9IGZyb20gJy4vZGF0YS1jb250ZXh0LWJhc2UnO1xuaW1wb3J0IHtTb3J0fSBmcm9tICcuLi9zb3J0JztcbmltcG9ydCB7RmlsdGVyfSBmcm9tICcuLi9maWx0ZXJzL2ZpbHRlcic7XG5pbXBvcnQge0xvZ2dlciwgTG9nZ2VyRmFjdG9yeX0gZnJvbSAnQGVsZGVyYnl0ZS90cy1sb2dnZXInO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcbmltcG9ydCB7SURhdGFDb250ZXh0Q29udGludWFibGV9IGZyb20gJy4vZGF0YS1jb250ZXh0JztcbmltcG9ydCB7SURhdGFTb3VyY2V9IGZyb20gJy4uL2RhdGFzb3VyY2UvZGF0YS1zb3VyY2UnO1xuXG5cbi8qKlxuICogRXh0ZW5kcyBhIHNpbXBsZSBmbGF0IGxpc3QgZGF0YS1jb250ZXh0IHdpdGggaW5maW5pdGUtc2Nyb2xsIHBhZ2luYXRpb24gc3VwcG9ydC5cbiAqXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBEYXRhQ29udGV4dENvbnRpbnVhYmxlQmFzZTxUPiBleHRlbmRzIERhdGFDb250ZXh0QmFzZTxUPiBpbXBsZW1lbnRzIElEYXRhQ29udGV4dENvbnRpbnVhYmxlPFQ+IHtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogRmllbGRzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcml2YXRlIHJlYWRvbmx5IGNibG9nZ2VyOiBMb2dnZXIgPSBMb2dnZXJGYWN0b3J5LmdldExvZ2dlcih0aGlzLmNvbnN0cnVjdG9yLm5hbWUpO1xuXG4gIHByaXZhdGUgX2NodW5rU2l6ZTogbnVtYmVyO1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBDb25zdHJ1Y3RvcnMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHByb3RlY3RlZCBjb25zdHJ1Y3RvcihcbiAgICBkYXRhU291cmNlOiBJRGF0YVNvdXJjZTxUPixcbiAgICBjaHVua1NpemU6IG51bWJlcixcbiAgICBpbmRleEZuOiAoKGl0ZW06IFQpID0+IGFueSksXG4gICAgbG9jYWxBcHBseTogKChkYXRhOiBUW10pID0+IFRbXSksXG4gICAgbG9jYWxTb3J0OiAoKGRhdGE6IFRbXSwgc29ydHM6IFNvcnRbXSkgPT4gVFtdKVxuICApIHtcbiAgICBzdXBlcihkYXRhU291cmNlLCBpbmRleEZuLCBsb2NhbEFwcGx5LCBsb2NhbFNvcnQpO1xuICAgIHRoaXMuX2NodW5rU2l6ZSA9IGNodW5rU2l6ZTtcbiAgfVxuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBQdWJsaWMgQVBJICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIHB1YmxpYyBsb2FkQWxsKHNvcnRzPzogU29ydFtdLCBmaWx0ZXJzPzogRmlsdGVyW10pOiB2b2lkIHtcblxuICAgIHRoaXMuY2Jsb2dnZXIuZGVidWcodGhpcy5pZCArJzogU3RhcnRpbmcgdG8gbG9hZCBhbGwgZGF0YSAuLi4nKTtcblxuICAgIC8vIGxvYWQgZmlyc3QgcGFnZVxuICAgIHRoaXMuc3RhcnQoc29ydHMsIGZpbHRlcnMpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgdGhpcy5jYmxvZ2dlci5kZWJ1Zyh0aGlzLmlkICsnOiBGaXJzdCBwYWdlIGhhcyBiZWVuIGxvYWRlZC4gTG9hZGluZyByZW1haW5pbmcgZGF0YSAuLi4nKTtcbiAgICAgICAgLy8gbG9hZCByZXN0IGluIGEgcmVjdXJzaXZlIG1hbm5lclxuICAgICAgICB0aGlzLmxvYWRBbGxSZWMoKTtcbiAgICAgIH0sIGVyciA9PiB7XG4gICAgICAgIHRoaXMub25FcnJvcihlcnIpO1xuICAgICAgICB0aGlzLmNibG9nZ2VyLmVycm9yKHRoaXMuaWQgKyc6IEZhaWxlZCB0byBsb2FkIGZpcnN0IHBhZ2Ugb2YgbG9hZCBhbGwgcHJvY2VkdXJlIScsIGVycik7XG4gICAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgY2h1bmtTaXplKCk6IG51bWJlciB7XG4gICAgcmV0dXJuIHRoaXMuX2NodW5rU2l6ZTtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgY2h1bmtTaXplKHNpemU6IG51bWJlcikge1xuICAgIGlmICh0aGlzLl9jaHVua1NpemUgIT09IHNpemUpIHtcbiAgICAgIHRoaXMuX2NodW5rU2l6ZSA9IHNpemU7XG4gICAgICB0aGlzLm9uQ2h1bmtTaXplQ2hhbmdlZChzaXplKTtcbiAgICB9XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogUHJpdmF0ZSBNZXRob2RzICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcm90ZWN0ZWQgb25DaHVua1NpemVDaGFuZ2VkKG5ld1NpemU6IG51bWJlcik6IHZvaWQgeyAgfVxuXG4gIHByaXZhdGUgbG9hZEFsbFJlYygpOiB2b2lkIHtcbiAgICB0aGlzLmxvYWRNb3JlKClcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICB0aGlzLmNibG9nZ2VyLmRlYnVnKHRoaXMuaWQgKyc6IExvYWRpbmcgZGF0YSBjaHVuayBmaW5pc2hlZCwgbG9hZGluZyBuZXh0Li4uJyk7XG4gICAgICAgIHRoaXMubG9hZEFsbFJlYygpO1xuICAgICAgfSwgZXJyID0+IHtcbiAgICAgICAgdGhpcy5vbkVycm9yKGVycik7XG4gICAgICAgIHRoaXMuY2Jsb2dnZXIuZXJyb3IodGhpcy5pZCArJzogTG9hZGluZyBhbGwgZmFpbGVkIScsIGVycik7XG4gICAgICB9LCAoKSA9PiB7XG4gICAgICAgIHRoaXMuY2Jsb2dnZXIuaW5mbyh0aGlzLmlkICsnOiBBbGwgZGF0YSBsb2FkZWQgY29tcGxldGVseS4nKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgcHVibGljIGFic3RyYWN0IGxvYWRNb3JlKCk6IE9ic2VydmFibGU8YW55PjtcbiAgcHVibGljIGFic3RyYWN0IGdldCBoYXNNb3JlRGF0YVNuYXBzaG90KCk6IGJvb2xlYW47XG4gIHB1YmxpYyBhYnN0cmFjdCBnZXQgaGFzTW9yZURhdGEoKTogT2JzZXJ2YWJsZTxib29sZWFuPjtcbn1cbiJdfQ==