@skyux/data-manager 9.16.2 → 9.17.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/documentation.json +1058 -836
- package/esm2022/lib/modules/data-manager/data-manager.component.mjs +33 -4
- package/esm2022/lib/modules/data-manager/data-manager.service.mjs +23 -1
- package/esm2022/lib/modules/data-manager/models/data-manager-summary-change.mjs +2 -0
- package/esm2022/lib/modules/data-manager/models/data-manager-summary.mjs +2 -0
- package/esm2022/lib/modules/shared/sky-data-manager-resources.module.mjs +10 -1
- package/fesm2022/skyux-data-manager.mjs +61 -2
- package/fesm2022/skyux-data-manager.mjs.map +1 -1
- package/lib/modules/data-manager/data-manager.service.d.ts +17 -0
- package/lib/modules/data-manager/models/data-manager-summary-change.d.ts +9 -0
- package/lib/modules/data-manager/models/data-manager-summary.d.ts +13 -0
- package/package.json +9 -9
@@ -1,9 +1,10 @@
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
2
2
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, inject, } from '@angular/core';
|
3
|
-
import { SkyViewkeeperModule } from '@skyux/core';
|
3
|
+
import { SkyLiveAnnouncerService, SkyViewkeeperModule } from '@skyux/core';
|
4
|
+
import { SkyLibResourcesService } from '@skyux/i18n';
|
4
5
|
import { SkyBackToTopMessageType, SkyBackToTopModule, } from '@skyux/layout';
|
5
6
|
import { Subject } from 'rxjs';
|
6
|
-
import { takeUntil } from 'rxjs/operators';
|
7
|
+
import { take, takeUntil } from 'rxjs/operators';
|
7
8
|
import { SkyDataManagerService } from './data-manager.service';
|
8
9
|
import * as i0 from "@angular/core";
|
9
10
|
import * as i1 from "@angular/common";
|
@@ -26,6 +27,8 @@ export class SkyDataManagerComponent {
|
|
26
27
|
this.#_currentViewkeeperClasses = VIEWKEEPER_CLASSES_DEFAULT;
|
27
28
|
this.#changeDetection = inject(ChangeDetectorRef);
|
28
29
|
this.#dataManagerService = inject(SkyDataManagerService);
|
30
|
+
this.#liveAnnouncer = inject(SkyLiveAnnouncerService);
|
31
|
+
this.#resourceSvc = inject(SkyLibResourcesService);
|
29
32
|
}
|
30
33
|
get currentViewkeeperClasses() {
|
31
34
|
return this.#_currentViewkeeperClasses;
|
@@ -48,15 +51,33 @@ export class SkyDataManagerComponent {
|
|
48
51
|
#allViewkeeperClasses;
|
49
52
|
#ngUnsubscribe;
|
50
53
|
#sourceId;
|
54
|
+
#dataState;
|
51
55
|
#_isInitialized;
|
52
56
|
#_currentViewkeeperClasses;
|
53
57
|
#changeDetection;
|
54
58
|
#dataManagerService;
|
59
|
+
#liveAnnouncer;
|
60
|
+
#resourceSvc;
|
55
61
|
ngOnInit() {
|
56
62
|
this.#dataManagerService
|
57
63
|
.getDataStateUpdates(this.#sourceId)
|
58
64
|
.pipe(takeUntil(this.#ngUnsubscribe))
|
59
|
-
.subscribe(() =>
|
65
|
+
.subscribe((state) => {
|
66
|
+
this.isInitialized = true;
|
67
|
+
this.#dataState = state;
|
68
|
+
});
|
69
|
+
this.#dataManagerService
|
70
|
+
.getDataSummaryUpdates(this.#sourceId)
|
71
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
72
|
+
.subscribe((summary) => {
|
73
|
+
const itemsSelected = this.#dataState?.selectedIds?.length || 0;
|
74
|
+
const resourceString = `skyux_data_manager_status_update_${this.#dataState?.onlyShowSelected
|
75
|
+
? 'only_selected'
|
76
|
+
: itemsSelected
|
77
|
+
? 'with_selections'
|
78
|
+
: 'without_selections'}`;
|
79
|
+
this.#announceState(resourceString, summary.itemsMatching, summary.totalItems, itemsSelected);
|
80
|
+
});
|
60
81
|
this.#dataManagerService.viewkeeperClasses
|
61
82
|
.pipe(takeUntil(this.#ngUnsubscribe))
|
62
83
|
.subscribe((classes) => {
|
@@ -81,6 +102,14 @@ export class SkyDataManagerComponent {
|
|
81
102
|
this.#ngUnsubscribe.next();
|
82
103
|
this.#ngUnsubscribe.complete();
|
83
104
|
}
|
105
|
+
#announceState(resourceString, itemsMatching, totalItems, itemsSelected) {
|
106
|
+
this.#resourceSvc
|
107
|
+
.getString(resourceString, itemsMatching, totalItems, itemsSelected)
|
108
|
+
.pipe(take(1))
|
109
|
+
.subscribe((internationalizedString) => {
|
110
|
+
this.#liveAnnouncer.announce(internationalizedString);
|
111
|
+
});
|
112
|
+
}
|
84
113
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyDataManagerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
85
114
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyDataManagerComponent, isStandalone: true, selector: "sky-data-manager", ngImport: i0, template: "<div\n *ngIf=\"isInitialized\"\n class=\"sky-data-manager\"\n [skyBackToTop]=\"backToTopOptions\"\n [skyBackToTopMessageStream]=\"backToTopController\"\n [skyViewkeeper]=\"currentViewkeeperClasses\"\n #dataManager\n>\n <ng-content />\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: SkyBackToTopModule }, { kind: "directive", type: i2.λ7, selector: "[skyBackToTop]", inputs: ["skyBackToTop", "skyBackToTopMessageStream"] }, { kind: "ngmodule", type: SkyViewkeeperModule }, { kind: "directive", type: i3.λ3, selector: "[skyViewkeeper]", inputs: ["skyViewkeeper"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
86
115
|
}
|
@@ -88,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
|
|
88
117
|
type: Component,
|
89
118
|
args: [{ standalone: true, selector: 'sky-data-manager', changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule, SkyBackToTopModule, SkyViewkeeperModule], template: "<div\n *ngIf=\"isInitialized\"\n class=\"sky-data-manager\"\n [skyBackToTop]=\"backToTopOptions\"\n [skyBackToTopMessageStream]=\"backToTopController\"\n [skyViewkeeper]=\"currentViewkeeperClasses\"\n #dataManager\n>\n <ng-content />\n</div>\n" }]
|
90
119
|
}] });
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-manager.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.component.ts","../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  OnDestroy,\n  OnInit,\n  inject,\n} from '@angular/core';\nimport { SkyViewkeeperModule } from '@skyux/core';\nimport {\n  SkyBackToTopMessage,\n  SkyBackToTopMessageType,\n  SkyBackToTopModule,\n} from '@skyux/layout';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDataManagerService } from './data-manager.service';\n\nconst VIEWKEEPER_CLASSES_DEFAULT = ['.sky-data-manager-toolbar'];\n\n/**\n * The top-level data manager component. Provide `SkyDataManagerService` at this level.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-data-manager',\n  templateUrl: './data-manager.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule, SkyBackToTopModule, SkyViewkeeperModule],\n})\nexport class SkyDataManagerComponent implements OnDestroy, OnInit {\n  public get currentViewkeeperClasses(): string[] {\n    return this.#_currentViewkeeperClasses;\n  }\n\n  public set currentViewkeeperClasses(value: string[] | undefined) {\n    this.#_currentViewkeeperClasses = [\n      ...VIEWKEEPER_CLASSES_DEFAULT,\n      ...(value || []),\n    ];\n    this.#changeDetection.markForCheck();\n  }\n\n  public get isInitialized(): boolean {\n    return this.#_isInitialized;\n  }\n\n  public set isInitialized(value: boolean) {\n    this.#_isInitialized = value;\n    this.#changeDetection.markForCheck();\n  }\n\n  public backToTopController = new Subject<SkyBackToTopMessage>();\n\n  public backToTopOptions = {\n    buttonHidden: true,\n  };\n\n  #activeViewId: string | undefined;\n  #allViewkeeperClasses: Record<string, string[]> = {};\n  #ngUnsubscribe = new Subject<void>();\n  #sourceId = 'dataManagerComponent';\n\n  #_isInitialized = false;\n  #_currentViewkeeperClasses = VIEWKEEPER_CLASSES_DEFAULT;\n\n  readonly #changeDetection = inject(ChangeDetectorRef);\n  readonly #dataManagerService = inject(SkyDataManagerService);\n\n  public ngOnInit(): void {\n    this.#dataManagerService\n      .getDataStateUpdates(this.#sourceId)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => (this.isInitialized = true));\n\n    this.#dataManagerService.viewkeeperClasses\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((classes) => {\n        this.#allViewkeeperClasses = classes;\n        this.currentViewkeeperClasses = this.#activeViewId\n          ? classes[this.#activeViewId]\n          : undefined;\n      });\n\n    this.#dataManagerService\n      .getActiveViewIdUpdates()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((activeViewId) => {\n        this.#activeViewId = activeViewId;\n        this.backToTopController.next({\n          type: SkyBackToTopMessageType.BackToTop,\n        });\n        this.currentViewkeeperClasses =\n          this.#allViewkeeperClasses[this.#activeViewId];\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n}\n","<div\n  *ngIf=\"isInitialized\"\n  class=\"sky-data-manager\"\n  [skyBackToTop]=\"backToTopOptions\"\n  [skyBackToTopMessageStream]=\"backToTopController\"\n  [skyViewkeeper]=\"currentViewkeeperClasses\"\n  #dataManager\n>\n  <ng-content />\n</div>\n"]}
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-manager.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.component.ts","../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  OnDestroy,\n  OnInit,\n  inject,\n} from '@angular/core';\nimport { SkyLiveAnnouncerService, SkyViewkeeperModule } from '@skyux/core';\nimport { SkyLibResourcesService } from '@skyux/i18n';\nimport {\n  SkyBackToTopMessage,\n  SkyBackToTopMessageType,\n  SkyBackToTopModule,\n} from '@skyux/layout';\n\nimport { Subject } from 'rxjs';\nimport { take, takeUntil } from 'rxjs/operators';\n\nimport { SkyDataManagerService } from './data-manager.service';\nimport { SkyDataManagerState } from './models/data-manager-state';\nimport { SkyDataManagerSummary } from './models/data-manager-summary';\n\nconst VIEWKEEPER_CLASSES_DEFAULT = ['.sky-data-manager-toolbar'];\n\n/**\n * The top-level data manager component. Provide `SkyDataManagerService` at this level.\n */\n@Component({\n  standalone: true,\n  selector: 'sky-data-manager',\n  templateUrl: './data-manager.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule, SkyBackToTopModule, SkyViewkeeperModule],\n})\nexport class SkyDataManagerComponent implements OnDestroy, OnInit {\n  public get currentViewkeeperClasses(): string[] {\n    return this.#_currentViewkeeperClasses;\n  }\n\n  public set currentViewkeeperClasses(value: string[] | undefined) {\n    this.#_currentViewkeeperClasses = [\n      ...VIEWKEEPER_CLASSES_DEFAULT,\n      ...(value || []),\n    ];\n    this.#changeDetection.markForCheck();\n  }\n\n  public get isInitialized(): boolean {\n    return this.#_isInitialized;\n  }\n\n  public set isInitialized(value: boolean) {\n    this.#_isInitialized = value;\n    this.#changeDetection.markForCheck();\n  }\n\n  public backToTopController = new Subject<SkyBackToTopMessage>();\n\n  public backToTopOptions = {\n    buttonHidden: true,\n  };\n\n  #activeViewId: string | undefined;\n  #allViewkeeperClasses: Record<string, string[]> = {};\n  #ngUnsubscribe = new Subject<void>();\n  #sourceId = 'dataManagerComponent';\n  #dataState: SkyDataManagerState | undefined;\n\n  #_isInitialized = false;\n  #_currentViewkeeperClasses = VIEWKEEPER_CLASSES_DEFAULT;\n\n  readonly #changeDetection = inject(ChangeDetectorRef);\n  readonly #dataManagerService = inject(SkyDataManagerService);\n  readonly #liveAnnouncer = inject(SkyLiveAnnouncerService);\n  readonly #resourceSvc = inject(SkyLibResourcesService);\n\n  public ngOnInit(): void {\n    this.#dataManagerService\n      .getDataStateUpdates(this.#sourceId)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((state) => {\n        this.isInitialized = true;\n        this.#dataState = state;\n      });\n\n    this.#dataManagerService\n      .getDataSummaryUpdates(this.#sourceId)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((summary: SkyDataManagerSummary) => {\n        const itemsSelected = this.#dataState?.selectedIds?.length || 0;\n        const resourceString = `skyux_data_manager_status_update_${\n          this.#dataState?.onlyShowSelected\n            ? 'only_selected'\n            : itemsSelected\n            ? 'with_selections'\n            : 'without_selections'\n        }`;\n\n        this.#announceState(\n          resourceString,\n          summary.itemsMatching,\n          summary.totalItems,\n          itemsSelected,\n        );\n      });\n\n    this.#dataManagerService.viewkeeperClasses\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((classes) => {\n        this.#allViewkeeperClasses = classes;\n        this.currentViewkeeperClasses = this.#activeViewId\n          ? classes[this.#activeViewId]\n          : undefined;\n      });\n\n    this.#dataManagerService\n      .getActiveViewIdUpdates()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((activeViewId) => {\n        this.#activeViewId = activeViewId;\n        this.backToTopController.next({\n          type: SkyBackToTopMessageType.BackToTop,\n        });\n        this.currentViewkeeperClasses =\n          this.#allViewkeeperClasses[this.#activeViewId];\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  #announceState(\n    resourceString: string,\n    itemsMatching: number,\n    totalItems: number,\n    itemsSelected: number,\n  ): void {\n    this.#resourceSvc\n      .getString(resourceString, itemsMatching, totalItems, itemsSelected)\n      .pipe(take(1))\n      .subscribe((internationalizedString) => {\n        this.#liveAnnouncer.announce(internationalizedString);\n      });\n  }\n}\n","<div\n  *ngIf=\"isInitialized\"\n  class=\"sky-data-manager\"\n  [skyBackToTop]=\"backToTopOptions\"\n  [skyBackToTopMessageStream]=\"backToTopController\"\n  [skyViewkeeper]=\"currentViewkeeperClasses\"\n  #dataManager\n>\n  <ng-content />\n</div>\n"]}
|
@@ -19,6 +19,7 @@ export class SkyDataManagerService {
|
|
19
19
|
#dataManagerConfig;
|
20
20
|
#views;
|
21
21
|
#dataStateChange;
|
22
|
+
#dataSummary;
|
22
23
|
#isInitialized;
|
23
24
|
#ngUnsubscribe;
|
24
25
|
#initSource;
|
@@ -29,6 +30,7 @@ export class SkyDataManagerService {
|
|
29
30
|
this.#dataManagerConfig = new BehaviorSubject({});
|
30
31
|
this.#views = new BehaviorSubject([]);
|
31
32
|
this.#dataStateChange = new ReplaySubject(1);
|
33
|
+
this.#dataSummary = new Subject();
|
32
34
|
this.#ngUnsubscribe = new Subject();
|
33
35
|
this.#initSource = 'dataManagerServiceInit';
|
34
36
|
this.#uiConfigService = uiConfigService;
|
@@ -185,6 +187,26 @@ export class SkyDataManagerService {
|
|
185
187
|
const newStateChange = new SkyDataManagerStateChange(newState, sourceId);
|
186
188
|
this.#dataStateChange.next(newStateChange);
|
187
189
|
}
|
190
|
+
/**
|
191
|
+
* Returns an observable of data summary changes that views and other data manager entities can subscribe to.
|
192
|
+
* It excludes updates originating from the provided source. This allows subscribers to only respond to
|
193
|
+
* changes they did not create and helps prevent infinite loops of updates and responses.
|
194
|
+
* @param sourceId The ID of the entity subscribing to data summary updates. This can be any value you choose
|
195
|
+
* but should be unique within the data manager instance and should also be used when that entity updates the summary.
|
196
|
+
*/
|
197
|
+
getDataSummaryUpdates(sourceId) {
|
198
|
+
return this.#dataSummary.pipe(filter((summaryChange) => sourceId !== summaryChange.source), map((summaryChange) => summaryChange.dataSummary));
|
199
|
+
}
|
200
|
+
/**
|
201
|
+
* Updates the data summary and emits a new value to entities subscribed to data summary changes.
|
202
|
+
* @param summary The new `SkyDataManagerSummary` value.
|
203
|
+
* @param sourceId The ID of the entity updating the summary. This can be any value you choose,
|
204
|
+
* but should be unique within the data manager instance and should also be used when that entity
|
205
|
+
* subscribes to summary changes from `getDataSummaryUpdates`.
|
206
|
+
*/
|
207
|
+
updateDataSummary(summary, sourceId) {
|
208
|
+
this.#dataSummary.next({ dataSummary: summary, source: sourceId });
|
209
|
+
}
|
188
210
|
/**
|
189
211
|
* Returns the current `SkyDataManagerConfig`.
|
190
212
|
*/
|
@@ -282,4 +304,4 @@ export class SkyDataManagerService {
|
|
282
304
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyDataManagerService, decorators: [{
|
283
305
|
type: Injectable
|
284
306
|
}], ctorParameters: function () { return [{ type: i1.SkyUIConfigService }]; } });
|
285
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-manager.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { SkyUIConfigService } from '@skyux/core';\n\nimport { BehaviorSubject, Observable, ReplaySubject, Subject } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  filter,\n  map,\n  take,\n  takeUntil,\n} from 'rxjs/operators';\n\nimport { SkyDataManagerConfig } from './models/data-manager-config';\nimport { SkyDataManagerInitArgs } from './models/data-manager-init-args';\nimport { SkyDataManagerState } from './models/data-manager-state';\nimport { SkyDataManagerStateChange } from './models/data-manager-state-change';\nimport { SkyDataManagerStateOptions } from './models/data-manager-state-options';\nimport { SkyDataManagerStateUpdateFilterArgs } from './models/data-manager-state-update-filter-args';\nimport { SkyDataViewConfig } from './models/data-view-config';\nimport { SkyDataViewState } from './models/data-view-state';\n\n/**\n * The data manager service provides ways for data views, toolbar items, and more to stay up to date\n * with the active view ID, data manager config, registered views and their configs, and data state.\n * There are methods to get current values, update values, and get subscriptions to the changing values.<br/> <br/>\n * Provide this service at the component level for each instance of a data manager. Do not\n * provide it at the module level or in `app-extras`. This allows multiple data\n * managers to be used and self-contained.\n */\n@Injectable()\nexport class SkyDataManagerService implements OnDestroy {\n  public viewkeeperClasses = new BehaviorSubject<Record<string, string[]>>({});\n\n  readonly #activeViewId = new ReplaySubject<string>(1);\n  readonly #dataManagerConfig = new BehaviorSubject<SkyDataManagerConfig>({});\n  readonly #views = new BehaviorSubject<SkyDataViewConfig[]>([]);\n  readonly #dataStateChange = new ReplaySubject<SkyDataManagerStateChange>(1);\n\n  #isInitialized: boolean | undefined;\n  #ngUnsubscribe = new Subject<void>();\n  #initSource = 'dataManagerServiceInit';\n  #uiConfigService: SkyUIConfigService;\n\n  constructor(uiConfigService: SkyUIConfigService) {\n    this.#uiConfigService = uiConfigService;\n  }\n\n  public ngOnDestroy(): void {\n    this.#activeViewId.complete();\n    this.#dataManagerConfig.complete();\n    this.#views.complete();\n    this.#dataStateChange.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * Initializes the data manager with the given settings and sets `isInitialized` to `true`.\n   * This must be called for the data manager to render.\n   * @param args The initial active view ID, data manager config, and state to use for the data manager.\n   * If a settings key is provided, it checks for a saved data state in the SKY UI config service before using the default data state\n   * and saves any state changes to the service.\n   */\n  public initDataManager(args: SkyDataManagerInitArgs): void {\n    if (this.#isInitialized) {\n      console.warn('This data manager instance has already been initialized.');\n      return;\n    }\n\n    this.#isInitialized = true;\n\n    const defaultDataState = args.defaultDataState;\n    const settingsKey = args.settingsKey;\n\n    this.updateActiveViewId(args.activeViewId);\n    this.updateDataManagerConfig(args.dataManagerConfig);\n\n    if (settingsKey) {\n      this.#uiConfigService\n        .getConfig(settingsKey, defaultDataState.getStateOptions())\n        .pipe(take(1))\n        .subscribe((config: SkyDataManagerStateOptions) => {\n          this.updateDataState(\n            new SkyDataManagerState(config),\n            this.#initSource,\n          );\n        });\n    } else {\n      this.updateDataState(defaultDataState, this.#initSource);\n    }\n\n    if (settingsKey) {\n      this.getDataStateUpdates(this.#initSource)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((state: SkyDataManagerState) => {\n          this.#uiConfigService\n            .setConfig(settingsKey, state.getStateOptions())\n            .pipe(takeUntil(this.#ngUnsubscribe))\n            .subscribe(\n              // eslint-disable-next-line @typescript-eslint/no-empty-function\n              () => {},\n              (err) => {\n                console.warn('Could not save data manager settings.');\n                console.warn(err);\n              },\n            );\n        });\n    }\n  }\n\n  /**\n   * Initializes a view within the data manager. This must be called for each view for the views to appear within the data manager.\n   * @param viewConfig The SkyDataViewConfig settings for the view being registered.\n   */\n  public initDataView(viewConfig: SkyDataViewConfig): void {\n    const currentViews = this.#views.value;\n\n    if (this.getViewById(viewConfig.id)) {\n      console.warn(\n        `A data manager view with the id ${viewConfig.id} has already been initialized.`,\n      );\n      return;\n    }\n\n    currentViews.push(viewConfig);\n    this.#views.next(currentViews);\n\n    // When the initial activeViewId is set there are no views registered. We have to re-emit\n    // the activeId so the newly registered view is notified that it is active.\n    this.#activeViewId.pipe(take(1)).subscribe((id) => {\n      this.#activeViewId.next(id);\n    });\n\n    this.#dataStateChange\n      .pipe(take(1))\n      .subscribe((change) => {\n        const dataState = change.dataState;\n        const currentViewState = dataState.getViewStateById(viewConfig.id);\n\n        if (!currentViewState) {\n          const newViewState = new SkyDataViewState({ viewId: viewConfig.id });\n\n          // Ensure that the view state's available columns match with the view config. Also,\n          // add columns to the `displayedColumnIds` as long as they are not `initialHide`\n          if (viewConfig.columnOptions) {\n            const columnIds = viewConfig.columnOptions.map((columnOptions) => {\n              return columnOptions.id;\n            });\n            const displayedColumnIds = viewConfig.columnOptions\n              .filter((columnOption) => {\n                return !columnOption.initialHide;\n              })\n              .map((columnOption) => {\n                return columnOption.id;\n              });\n\n            newViewState.columnIds = columnIds;\n            newViewState.displayedColumnIds = displayedColumnIds;\n          }\n          const newDataState = dataState.addOrUpdateView(\n            viewConfig.id,\n            newViewState,\n          );\n\n          this.updateDataState(newDataState, this.#initSource);\n        } else {\n          const currentAvailableColumnIds =\n            viewConfig.columnOptions?.map((columnOptions) => {\n              return columnOptions.id;\n            }) || [];\n\n          // Ensure that the view state's available columns match with the view config. Also,\n          // add new columns to the `displayedColumnIds` as long as they are not `initialHide`.\n          // We only add columns to `displayedColumnsIds` if we had previously tracked\n          // `columnIds` to avoid breaking changes.\n          if (currentViewState.columnIds.length > 0) {\n            let newColumnIds = currentAvailableColumnIds?.filter(\n              (id) => currentViewState.columnIds.indexOf(id) < 0,\n            );\n            newColumnIds = newColumnIds?.filter((columnId) => {\n              return viewConfig.columnOptions?.find(\n                (columnOption) =>\n                  columnOption.id === columnId && !columnOption.initialHide,\n              );\n            });\n\n            // Add the column IDs that now exist to the data manager state both as available\n            // and as shown.\n            currentViewState.displayedColumnIds =\n              currentViewState.displayedColumnIds.concat(newColumnIds);\n          }\n          // Add the column IDs that now exist to the data manager state both as available\n          // and as shown.\n          currentViewState.columnIds = currentAvailableColumnIds;\n\n          const newDataState = dataState.addOrUpdateView(\n            viewConfig.id,\n            currentViewState,\n          );\n\n          this.updateDataState(newDataState, this.#initSource);\n        }\n      })\n      .unsubscribe();\n  }\n\n  /**\n   * Returns an observable of data state changes that views and other data manager entities can subscribe to.\n   * It excludes updates originating from the provided source. This allows subscribers to only respond to\n   * changes they did not create and helps prevent infinite loops of updates and responses.\n   * @param sourceId The ID of the entity subscribing to data state updates. This can be any value you choose\n   * but should be unique within the data manager instance and should also be used when that entity updates the state.\n   */\n  public getDataStateUpdates(\n    sourceId: string,\n    updateFilter?: SkyDataManagerStateUpdateFilterArgs,\n  ): Observable<SkyDataManagerState> {\n    // filter out events from the provided source and emit just the dataState\n    if (updateFilter) {\n      return this.#dataStateChange.pipe(\n        filter((stateChange) => sourceId !== stateChange.source),\n        map((stateChange) => stateChange.dataState),\n        updateFilter.comparator\n          ? distinctUntilChanged(updateFilter.comparator)\n          : distinctUntilChanged(\n              this.#getDefaultStateComparator(\n                updateFilter.properties as (keyof SkyDataManagerStateOptions)[],\n              ),\n            ),\n      );\n    } else {\n      return this.#dataStateChange.pipe(\n        filter((stateChange) => sourceId !== stateChange.source),\n        map((stateChange) => stateChange.dataState),\n      );\n    }\n  }\n\n  /**\n   * Updates the data state and emits a new value to entities subscribed to data state changes.\n   * @param state The new `SkyDataManagerState` value.\n   * @param sourceId The ID of the entity updating the state. This can be any value you choose,\n   * but should be unique within the data manager instance and should also be used when that entity\n   * subscribes to state changes from `getDataStateUpdates`.\n   */\n  public updateDataState(state: SkyDataManagerState, sourceId: string): void {\n    const newState = new SkyDataManagerState(state.getStateOptions());\n    const newStateChange = new SkyDataManagerStateChange(newState, sourceId);\n\n    this.#dataStateChange.next(newStateChange);\n  }\n\n  /**\n   * Returns the current `SkyDataManagerConfig`.\n   */\n  public getCurrentDataManagerConfig(): SkyDataManagerConfig {\n    return this.#dataManagerConfig.value;\n  }\n\n  /**\n   * Returns an observable of data manager config changes that views and other data manager entities can subscribe to.\n   */\n  public getDataManagerConfigUpdates(): Observable<SkyDataManagerConfig> {\n    return this.#dataManagerConfig;\n  }\n\n  /**\n   * Updates the data manager config and emits a new value to entities subscribed to data config changes.\n   * @param value The new `SkyDataManagerConfig` value.\n   */\n  public updateDataManagerConfig(value: SkyDataManagerConfig): void {\n    this.#dataManagerConfig.next(value);\n  }\n\n  /**\n   * Returns an observable of data view config changes that views and other data manager entities can subscribe to.\n   */\n  public getDataViewsUpdates(): Observable<SkyDataViewConfig[]> {\n    return this.#views;\n  }\n\n  /**\n   * Returns an observable of the active view ID that views and other data manager entities can subscribe to.\n   */\n  public getActiveViewIdUpdates(): Observable<string> {\n    return this.#activeViewId;\n  }\n\n  /**\n   * Updates the active view ID. The data manager changes the displayed view.\n   * @param id The new active view ID.\n   */\n  public updateActiveViewId(id: string): void {\n    this.#activeViewId.next(id);\n  }\n\n  /**\n   * Returns the `SkyDataViewConfig` for the given view ID.\n   * @param viewId The ID of the view config to get.\n   */\n  public getViewById(viewId: string): SkyDataViewConfig | undefined {\n    const currentViews: SkyDataViewConfig[] = this.#views.value;\n    const viewConfig: SkyDataViewConfig | undefined = currentViews.find(\n      (view) => view.id === viewId,\n    );\n\n    return viewConfig;\n  }\n\n  /**\n   * Updates the given view config. The registered view with the same ID is updated to the\n   * provided config, so include all properties regardless of whether they changed. If the\n   * view was not initialized already, no update happens.\n   * @param view The new `SkyDataViewConfig` containing all properties.\n   */\n  public updateViewConfig(view: SkyDataViewConfig): void {\n    const currentViews: SkyDataViewConfig[] = this.#views.value;\n    const existingViewIndex = currentViews.findIndex(\n      (currentView) => currentView.id === view.id,\n    );\n\n    if (existingViewIndex === -1) {\n      console.error('A view with the id {id} does not exist.', view.id);\n    } else {\n      currentViews[existingViewIndex] = view;\n      this.#views.next(currentViews);\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public setViewkeeperClasses(viewId: string, classes: string[]): void {\n    const viewkeeperClasses = this.viewkeeperClasses.value;\n    viewkeeperClasses[viewId] = classes;\n\n    this.viewkeeperClasses.next(viewkeeperClasses);\n  }\n\n  #filterDataStateProperties(\n    state: SkyDataManagerState,\n    properties: (keyof SkyDataManagerStateOptions)[] | undefined,\n  ): Record<string, unknown> {\n    const stateProperties = state.getStateOptions();\n    const filteredStateProperties: Record<string, unknown> = {};\n\n    if (properties) {\n      for (const property of properties) {\n        if (property in stateProperties) {\n          filteredStateProperties[property] = stateProperties[property];\n        }\n      }\n    }\n\n    return filteredStateProperties;\n  }\n\n  #getDefaultStateComparator(\n    properties: (keyof SkyDataManagerStateOptions)[] | undefined,\n  ): (state1: SkyDataManagerState, state2: SkyDataManagerState) => boolean {\n    return (\n      state1: SkyDataManagerState,\n      state2: SkyDataManagerState,\n    ): boolean => {\n      const filteredState1 = this.#filterDataStateProperties(\n        state1,\n        properties,\n      );\n      const filteredState2 = this.#filterDataStateProperties(\n        state2,\n        properties,\n      );\n      return JSON.stringify(filteredState1) === JSON.stringify(filteredState2);\n    };\n  }\n}\n"]}
|
307
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-manager.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, OnDestroy } from '@angular/core';\nimport { SkyUIConfigService } from '@skyux/core';\n\nimport { BehaviorSubject, Observable, ReplaySubject, Subject } from 'rxjs';\nimport {\n  distinctUntilChanged,\n  filter,\n  map,\n  take,\n  takeUntil,\n} from 'rxjs/operators';\n\nimport { SkyDataManagerConfig } from './models/data-manager-config';\nimport { SkyDataManagerInitArgs } from './models/data-manager-init-args';\nimport { SkyDataManagerState } from './models/data-manager-state';\nimport { SkyDataManagerStateChange } from './models/data-manager-state-change';\nimport { SkyDataManagerStateOptions } from './models/data-manager-state-options';\nimport { SkyDataManagerStateUpdateFilterArgs } from './models/data-manager-state-update-filter-args';\nimport { SkyDataManagerSummary } from './models/data-manager-summary';\nimport { SkyDataManagerSummaryChange } from './models/data-manager-summary-change';\nimport { SkyDataViewConfig } from './models/data-view-config';\nimport { SkyDataViewState } from './models/data-view-state';\n\n/**\n * The data manager service provides ways for data views, toolbar items, and more to stay up to date\n * with the active view ID, data manager config, registered views and their configs, and data state.\n * There are methods to get current values, update values, and get subscriptions to the changing values.<br/> <br/>\n * Provide this service at the component level for each instance of a data manager. Do not\n * provide it at the module level or in `app-extras`. This allows multiple data\n * managers to be used and self-contained.\n */\n@Injectable()\nexport class SkyDataManagerService implements OnDestroy {\n  public viewkeeperClasses = new BehaviorSubject<Record<string, string[]>>({});\n\n  readonly #activeViewId = new ReplaySubject<string>(1);\n  readonly #dataManagerConfig = new BehaviorSubject<SkyDataManagerConfig>({});\n  readonly #views = new BehaviorSubject<SkyDataViewConfig[]>([]);\n  readonly #dataStateChange = new ReplaySubject<SkyDataManagerStateChange>(1);\n  readonly #dataSummary = new Subject<SkyDataManagerSummaryChange>();\n\n  #isInitialized: boolean | undefined;\n  #ngUnsubscribe = new Subject<void>();\n  #initSource = 'dataManagerServiceInit';\n  #uiConfigService: SkyUIConfigService;\n\n  constructor(uiConfigService: SkyUIConfigService) {\n    this.#uiConfigService = uiConfigService;\n  }\n\n  public ngOnDestroy(): void {\n    this.#activeViewId.complete();\n    this.#dataManagerConfig.complete();\n    this.#views.complete();\n    this.#dataStateChange.complete();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * Initializes the data manager with the given settings and sets `isInitialized` to `true`.\n   * This must be called for the data manager to render.\n   * @param args The initial active view ID, data manager config, and state to use for the data manager.\n   * If a settings key is provided, it checks for a saved data state in the SKY UI config service before using the default data state\n   * and saves any state changes to the service.\n   */\n  public initDataManager(args: SkyDataManagerInitArgs): void {\n    if (this.#isInitialized) {\n      console.warn('This data manager instance has already been initialized.');\n      return;\n    }\n\n    this.#isInitialized = true;\n\n    const defaultDataState = args.defaultDataState;\n    const settingsKey = args.settingsKey;\n\n    this.updateActiveViewId(args.activeViewId);\n    this.updateDataManagerConfig(args.dataManagerConfig);\n\n    if (settingsKey) {\n      this.#uiConfigService\n        .getConfig(settingsKey, defaultDataState.getStateOptions())\n        .pipe(take(1))\n        .subscribe((config: SkyDataManagerStateOptions) => {\n          this.updateDataState(\n            new SkyDataManagerState(config),\n            this.#initSource,\n          );\n        });\n    } else {\n      this.updateDataState(defaultDataState, this.#initSource);\n    }\n\n    if (settingsKey) {\n      this.getDataStateUpdates(this.#initSource)\n        .pipe(takeUntil(this.#ngUnsubscribe))\n        .subscribe((state: SkyDataManagerState) => {\n          this.#uiConfigService\n            .setConfig(settingsKey, state.getStateOptions())\n            .pipe(takeUntil(this.#ngUnsubscribe))\n            .subscribe(\n              // eslint-disable-next-line @typescript-eslint/no-empty-function\n              () => {},\n              (err) => {\n                console.warn('Could not save data manager settings.');\n                console.warn(err);\n              },\n            );\n        });\n    }\n  }\n\n  /**\n   * Initializes a view within the data manager. This must be called for each view for the views to appear within the data manager.\n   * @param viewConfig The SkyDataViewConfig settings for the view being registered.\n   */\n  public initDataView(viewConfig: SkyDataViewConfig): void {\n    const currentViews = this.#views.value;\n\n    if (this.getViewById(viewConfig.id)) {\n      console.warn(\n        `A data manager view with the id ${viewConfig.id} has already been initialized.`,\n      );\n      return;\n    }\n\n    currentViews.push(viewConfig);\n    this.#views.next(currentViews);\n\n    // When the initial activeViewId is set there are no views registered. We have to re-emit\n    // the activeId so the newly registered view is notified that it is active.\n    this.#activeViewId.pipe(take(1)).subscribe((id) => {\n      this.#activeViewId.next(id);\n    });\n\n    this.#dataStateChange\n      .pipe(take(1))\n      .subscribe((change) => {\n        const dataState = change.dataState;\n        const currentViewState = dataState.getViewStateById(viewConfig.id);\n\n        if (!currentViewState) {\n          const newViewState = new SkyDataViewState({ viewId: viewConfig.id });\n\n          // Ensure that the view state's available columns match with the view config. Also,\n          // add columns to the `displayedColumnIds` as long as they are not `initialHide`\n          if (viewConfig.columnOptions) {\n            const columnIds = viewConfig.columnOptions.map((columnOptions) => {\n              return columnOptions.id;\n            });\n            const displayedColumnIds = viewConfig.columnOptions\n              .filter((columnOption) => {\n                return !columnOption.initialHide;\n              })\n              .map((columnOption) => {\n                return columnOption.id;\n              });\n\n            newViewState.columnIds = columnIds;\n            newViewState.displayedColumnIds = displayedColumnIds;\n          }\n          const newDataState = dataState.addOrUpdateView(\n            viewConfig.id,\n            newViewState,\n          );\n\n          this.updateDataState(newDataState, this.#initSource);\n        } else {\n          const currentAvailableColumnIds =\n            viewConfig.columnOptions?.map((columnOptions) => {\n              return columnOptions.id;\n            }) || [];\n\n          // Ensure that the view state's available columns match with the view config. Also,\n          // add new columns to the `displayedColumnIds` as long as they are not `initialHide`.\n          // We only add columns to `displayedColumnsIds` if we had previously tracked\n          // `columnIds` to avoid breaking changes.\n          if (currentViewState.columnIds.length > 0) {\n            let newColumnIds = currentAvailableColumnIds?.filter(\n              (id) => currentViewState.columnIds.indexOf(id) < 0,\n            );\n            newColumnIds = newColumnIds?.filter((columnId) => {\n              return viewConfig.columnOptions?.find(\n                (columnOption) =>\n                  columnOption.id === columnId && !columnOption.initialHide,\n              );\n            });\n\n            // Add the column IDs that now exist to the data manager state both as available\n            // and as shown.\n            currentViewState.displayedColumnIds =\n              currentViewState.displayedColumnIds.concat(newColumnIds);\n          }\n          // Add the column IDs that now exist to the data manager state both as available\n          // and as shown.\n          currentViewState.columnIds = currentAvailableColumnIds;\n\n          const newDataState = dataState.addOrUpdateView(\n            viewConfig.id,\n            currentViewState,\n          );\n\n          this.updateDataState(newDataState, this.#initSource);\n        }\n      })\n      .unsubscribe();\n  }\n\n  /**\n   * Returns an observable of data state changes that views and other data manager entities can subscribe to.\n   * It excludes updates originating from the provided source. This allows subscribers to only respond to\n   * changes they did not create and helps prevent infinite loops of updates and responses.\n   * @param sourceId The ID of the entity subscribing to data state updates. This can be any value you choose\n   * but should be unique within the data manager instance and should also be used when that entity updates the state.\n   */\n  public getDataStateUpdates(\n    sourceId: string,\n    updateFilter?: SkyDataManagerStateUpdateFilterArgs,\n  ): Observable<SkyDataManagerState> {\n    // filter out events from the provided source and emit just the dataState\n    if (updateFilter) {\n      return this.#dataStateChange.pipe(\n        filter((stateChange) => sourceId !== stateChange.source),\n        map((stateChange) => stateChange.dataState),\n        updateFilter.comparator\n          ? distinctUntilChanged(updateFilter.comparator)\n          : distinctUntilChanged(\n              this.#getDefaultStateComparator(\n                updateFilter.properties as (keyof SkyDataManagerStateOptions)[],\n              ),\n            ),\n      );\n    } else {\n      return this.#dataStateChange.pipe(\n        filter((stateChange) => sourceId !== stateChange.source),\n        map((stateChange) => stateChange.dataState),\n      );\n    }\n  }\n\n  /**\n   * Updates the data state and emits a new value to entities subscribed to data state changes.\n   * @param state The new `SkyDataManagerState` value.\n   * @param sourceId The ID of the entity updating the state. This can be any value you choose,\n   * but should be unique within the data manager instance and should also be used when that entity\n   * subscribes to state changes from `getDataStateUpdates`.\n   */\n  public updateDataState(state: SkyDataManagerState, sourceId: string): void {\n    const newState = new SkyDataManagerState(state.getStateOptions());\n    const newStateChange = new SkyDataManagerStateChange(newState, sourceId);\n\n    this.#dataStateChange.next(newStateChange);\n  }\n\n  /**\n   * Returns an observable of data summary changes that views and other data manager entities can subscribe to.\n   * It excludes updates originating from the provided source. This allows subscribers to only respond to\n   * changes they did not create and helps prevent infinite loops of updates and responses.\n   * @param sourceId The ID of the entity subscribing to data summary updates. This can be any value you choose\n   * but should be unique within the data manager instance and should also be used when that entity updates the summary.\n   */\n  public getDataSummaryUpdates(\n    sourceId: string,\n  ): Observable<SkyDataManagerSummary> {\n    return this.#dataSummary.pipe(\n      filter((summaryChange) => sourceId !== summaryChange.source),\n      map((summaryChange) => summaryChange.dataSummary),\n    );\n  }\n\n  /**\n   * Updates the data summary and emits a new value to entities subscribed to data summary changes.\n   * @param summary The new `SkyDataManagerSummary` value.\n   * @param sourceId The ID of the entity updating the summary. This can be any value you choose,\n   * but should be unique within the data manager instance and should also be used when that entity\n   * subscribes to summary changes from `getDataSummaryUpdates`.\n   */\n  public updateDataSummary(\n    summary: SkyDataManagerSummary,\n    sourceId: string,\n  ): void {\n    this.#dataSummary.next({ dataSummary: summary, source: sourceId });\n  }\n\n  /**\n   * Returns the current `SkyDataManagerConfig`.\n   */\n  public getCurrentDataManagerConfig(): SkyDataManagerConfig {\n    return this.#dataManagerConfig.value;\n  }\n\n  /**\n   * Returns an observable of data manager config changes that views and other data manager entities can subscribe to.\n   */\n  public getDataManagerConfigUpdates(): Observable<SkyDataManagerConfig> {\n    return this.#dataManagerConfig;\n  }\n\n  /**\n   * Updates the data manager config and emits a new value to entities subscribed to data config changes.\n   * @param value The new `SkyDataManagerConfig` value.\n   */\n  public updateDataManagerConfig(value: SkyDataManagerConfig): void {\n    this.#dataManagerConfig.next(value);\n  }\n\n  /**\n   * Returns an observable of data view config changes that views and other data manager entities can subscribe to.\n   */\n  public getDataViewsUpdates(): Observable<SkyDataViewConfig[]> {\n    return this.#views;\n  }\n\n  /**\n   * Returns an observable of the active view ID that views and other data manager entities can subscribe to.\n   */\n  public getActiveViewIdUpdates(): Observable<string> {\n    return this.#activeViewId;\n  }\n\n  /**\n   * Updates the active view ID. The data manager changes the displayed view.\n   * @param id The new active view ID.\n   */\n  public updateActiveViewId(id: string): void {\n    this.#activeViewId.next(id);\n  }\n\n  /**\n   * Returns the `SkyDataViewConfig` for the given view ID.\n   * @param viewId The ID of the view config to get.\n   */\n  public getViewById(viewId: string): SkyDataViewConfig | undefined {\n    const currentViews: SkyDataViewConfig[] = this.#views.value;\n    const viewConfig: SkyDataViewConfig | undefined = currentViews.find(\n      (view) => view.id === viewId,\n    );\n\n    return viewConfig;\n  }\n\n  /**\n   * Updates the given view config. The registered view with the same ID is updated to the\n   * provided config, so include all properties regardless of whether they changed. If the\n   * view was not initialized already, no update happens.\n   * @param view The new `SkyDataViewConfig` containing all properties.\n   */\n  public updateViewConfig(view: SkyDataViewConfig): void {\n    const currentViews: SkyDataViewConfig[] = this.#views.value;\n    const existingViewIndex = currentViews.findIndex(\n      (currentView) => currentView.id === view.id,\n    );\n\n    if (existingViewIndex === -1) {\n      console.error('A view with the id {id} does not exist.', view.id);\n    } else {\n      currentViews[existingViewIndex] = view;\n      this.#views.next(currentViews);\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public setViewkeeperClasses(viewId: string, classes: string[]): void {\n    const viewkeeperClasses = this.viewkeeperClasses.value;\n    viewkeeperClasses[viewId] = classes;\n\n    this.viewkeeperClasses.next(viewkeeperClasses);\n  }\n\n  #filterDataStateProperties(\n    state: SkyDataManagerState,\n    properties: (keyof SkyDataManagerStateOptions)[] | undefined,\n  ): Record<string, unknown> {\n    const stateProperties = state.getStateOptions();\n    const filteredStateProperties: Record<string, unknown> = {};\n\n    if (properties) {\n      for (const property of properties) {\n        if (property in stateProperties) {\n          filteredStateProperties[property] = stateProperties[property];\n        }\n      }\n    }\n\n    return filteredStateProperties;\n  }\n\n  #getDefaultStateComparator(\n    properties: (keyof SkyDataManagerStateOptions)[] | undefined,\n  ): (state1: SkyDataManagerState, state2: SkyDataManagerState) => boolean {\n    return (\n      state1: SkyDataManagerState,\n      state2: SkyDataManagerState,\n    ): boolean => {\n      const filteredState1 = this.#filterDataStateProperties(\n        state1,\n        properties,\n      );\n      const filteredState2 = this.#filterDataStateProperties(\n        state2,\n        properties,\n      );\n      return JSON.stringify(filteredState1) === JSON.stringify(filteredState2);\n    };\n  }\n}\n"]}
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1tYW5hZ2VyLXN1bW1hcnktY2hhbmdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGEtbWFuYWdlci9zcmMvbGliL21vZHVsZXMvZGF0YS1tYW5hZ2VyL21vZGVscy9kYXRhLW1hbmFnZXItc3VtbWFyeS1jaGFuZ2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNreURhdGFNYW5hZ2VyU3VtbWFyeSB9IGZyb20gJy4vZGF0YS1tYW5hZ2VyLXN1bW1hcnknO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICogQSBzdW1tYXJ5IG9mIHRoZSBkYXRhIGRpc3BsYXllZCB3aXRoaW4gdGhlIGRhdGEgbWFuYWdlciBhbmQgdGhlIHNvdXJjZSBvZiB0aGUgY2hhbmdlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFNreURhdGFNYW5hZ2VyU3VtbWFyeUNoYW5nZSB7XG4gIGRhdGFTdW1tYXJ5OiBTa3lEYXRhTWFuYWdlclN1bW1hcnk7XG4gIHNvdXJjZTogc3RyaW5nO1xufVxuIl19
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1tYW5hZ2VyLXN1bW1hcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvZGF0YS1tYW5hZ2VyL3NyYy9saWIvbW9kdWxlcy9kYXRhLW1hbmFnZXIvbW9kZWxzL2RhdGEtbWFuYWdlci1zdW1tYXJ5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvbnRhaW5zIHN1bW1hcnkgZGV0YWlscyBvZiB0aGUgZGF0YSBkaXNwbGF5ZWQgd2l0aGluIHRoZSBkYXRhIG1hbmFnZXIuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU2t5RGF0YU1hbmFnZXJTdW1tYXJ5IHtcbiAgLyoqXG4gICAqIFRoZSB0b3RhbCBudW1iZXIgb2YgaXRlbXMgaW4gdGhlIGRhdGEgc2V0LlxuICAgKi9cbiAgdG90YWxJdGVtczogbnVtYmVyO1xuICAvKipcbiAgICogVGhlIHRvdGFsIG51bWJlciBvZiBpdGVtcyB0aGF0IG1hdGNoIHRoZSBzZWFyY2ggYW5kIGZpbHRlciBjcml0ZXJpYS5cbiAgICovXG4gIGl0ZW1zTWF0Y2hpbmc6IG51bWJlcjtcbn1cbiJdfQ==
|
@@ -36,6 +36,15 @@ const RESOURCES = {
|
|
36
36
|
skyux_data_manager_select_column_status_indicator_title: {
|
37
37
|
message: 'Select at least one column.',
|
38
38
|
},
|
39
|
+
skyux_data_manager_status_update_with_selections: {
|
40
|
+
message: '{0} of {1} items meet criteria and {2} selected.',
|
41
|
+
},
|
42
|
+
skyux_data_manager_status_update_without_selections: {
|
43
|
+
message: '{0} of {1} items meet criteria.',
|
44
|
+
},
|
45
|
+
skyux_data_manager_status_update_only_selected: {
|
46
|
+
message: '{0} of {1} items meet criteria and {2} selected. Only selected items are displayed.',
|
47
|
+
},
|
39
48
|
},
|
40
49
|
};
|
41
50
|
SkyLibResourcesService.addResources(RESOURCES);
|
@@ -71,4 +80,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.9", ngImpor
|
|
71
80
|
],
|
72
81
|
}]
|
73
82
|
}] });
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2t5LWRhdGEtbWFuYWdlci1yZXNvdXJjZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGEtbWFuYWdlci9zcmMvbGliL21vZHVsZXMvc2hhcmVkL3NreS1kYXRhLW1hbmFnZXItcmVzb3VyY2VzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSwwQkFBMEI7QUFFMUI7Ozs7O0dBS0c7QUFDSCxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFDTCwyQkFBMkIsRUFFM0IsYUFBYSxFQUdiLHNCQUFzQixFQUN0QixxQkFBcUIsR0FDdEIsTUFBTSxhQUFhLENBQUM7O0FBRXJCLE1BQU0sU0FBUyxHQUEwQztJQUN2RCxPQUFPLEVBQUU7UUFDUCxzQ0FBc0MsRUFBRTtZQUN0QyxPQUFPLEVBQUUsb0NBQW9DO1NBQzlDO1FBQ0QsNkNBQTZDLEVBQUUsRUFBRSxPQUFPLEVBQUUsZUFBZSxFQUFFO1FBQzNFLHNDQUFzQyxFQUFFLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRTtRQUM3RCwrQ0FBK0MsRUFBRTtZQUMvQyxPQUFPLEVBQUUsZ0JBQWdCO1NBQzFCO1FBQ0QsMENBQTBDLEVBQUUsRUFBRSxPQUFPLEVBQUUsWUFBWSxFQUFFO1FBQ3JFLDhDQUE4QyxFQUFFO1lBQzlDLE9BQU8sRUFBRSx3QkFBd0I7U0FDbEM7UUFDRCx5Q0FBeUMsRUFBRSxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUU7UUFDbkUsa0RBQWtELEVBQUU7WUFDbEQsT0FBTyxFQUFFLHdCQUF3QjtTQUNsQztRQUNELDZDQUE2QyxFQUFFO1lBQzdDLE9BQU8sRUFBRSwwQkFBMEI7U0FDcEM7UUFDRCw0Q0FBNEMsRUFBRTtZQUM1QyxPQUFPLEVBQUUsd0JBQXdCO1NBQ2xDO1FBQ0QsdUNBQXVDLEVBQUUsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFO1FBQy9ELHVEQUF1RCxFQUFFO1lBQ3ZELE9BQU8sRUFBRSw2QkFBNkI7U0FDdkM7UUFDRCxnREFBZ0QsRUFBRTtZQUNoRCxPQUFPLEVBQUUsa0RBQWtEO1NBQzVEO1FBQ0QsbURBQW1ELEVBQUU7WUFDbkQsT0FBTyxFQUFFLGlDQUFpQztTQUMzQztRQUNELDhDQUE4QyxFQUFFO1lBQzlDLE9BQU8sRUFDTCxxRkFBcUY7U0FDeEY7S0FDRjtDQUNGLENBQUM7QUFFRixzQkFBc0IsQ0FBQyxZQUFZLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFL0MsTUFBTSxPQUFPLCtCQUErQjtJQUduQyxTQUFTLENBQ2QsVUFBNEIsRUFDNUIsSUFBWTtRQUVaLE9BQU8scUJBQXFCLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDbkUsQ0FBQztDQUNGO0FBRUQ7O0dBRUc7QUFXSCxNQUFNLE9BQU8sNkJBQTZCOzhHQUE3Qiw2QkFBNkI7K0dBQTdCLDZCQUE2QixZQVQ5QixhQUFhOytHQVNaLDZCQUE2QixhQVI3QjtZQUNUO2dCQUNFLE9BQU8sRUFBRSwyQkFBMkI7Z0JBQ3BDLFFBQVEsRUFBRSwrQkFBK0I7Z0JBQ3pDLEtBQUssRUFBRSxJQUFJO2FBQ1o7U0FDRixZQVBTLGFBQWE7OzJGQVNaLDZCQUE2QjtrQkFWekMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxhQUFhLENBQUM7b0JBQ3hCLFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsMkJBQTJCOzRCQUNwQyxRQUFRLEVBQUUsK0JBQStCOzRCQUN6QyxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFDRjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbIi8qIGlzdGFuYnVsIGlnbm9yZSBmaWxlICovXG5cbi8qKlxuICogTk9USUNFOiBETyBOT1QgTU9ESUZZIFRISVMgRklMRSFcbiAqIFRoZSBjb250ZW50cyBvZiB0aGlzIGZpbGUgd2VyZSBhdXRvbWF0aWNhbGx5IGdlbmVyYXRlZCBieVxuICogdGhlICduZyBnZW5lcmF0ZSBAc2t5dXgvaTE4bjpsaWItcmVzb3VyY2VzLW1vZHVsZSBsaWIvbW9kdWxlcy9zaGFyZWQvc2t5LWRhdGEtbWFuYWdlcicgc2NoZW1hdGljLlxuICogVG8gdXBkYXRlIHRoaXMgZmlsZSwgc2ltcGx5IHJlcnVuIHRoZSBjb21tYW5kLlxuICovXG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICBTa3lBcHBMb2NhbGVJbmZvLFxuICBTa3lJMThuTW9kdWxlLFxuICBTa3lMaWJSZXNvdXJjZXMsXG4gIFNreUxpYlJlc291cmNlc1Byb3ZpZGVyLFxuICBTa3lMaWJSZXNvdXJjZXNTZXJ2aWNlLFxuICBnZXRMaWJTdHJpbmdGb3JMb2NhbGUsXG59IGZyb20gJ0Bza3l1eC9pMThuJztcblxuY29uc3QgUkVTT1VSQ0VTOiB7IFtsb2NhbGU6IHN0cmluZ106IFNreUxpYlJlc291cmNlcyB9ID0ge1xuICAnRU4tVVMnOiB7XG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX2NvbHVtbl9waWNrZXJfdGl0bGU6IHtcbiAgICAgIG1lc3NhZ2U6ICdDaG9vc2UgY29sdW1ucyB0byBzaG93IGluIHRoZSBsaXN0JyxcbiAgICB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9hcHBseV9jaGFuZ2VzX2J1dHRvbl90aXRsZTogeyBtZXNzYWdlOiAnQXBwbHkgY2hhbmdlcycgfSxcbiAgICBza3l1eF9kYXRhX21hbmFnZXJfY2FuY2VsX2J1dHRvbl90aXRsZTogeyBtZXNzYWdlOiAnQ2FuY2VsJyB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9zZWxlY3RfYWxsX2J1dHRvbl9hcmlhX2xhYmVsOiB7XG4gICAgICBtZXNzYWdlOiAnU2VsZWN0IGFsbCB7MH0nLFxuICAgIH0sXG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX3NlbGVjdF9hbGxfYnV0dG9uX3RpdGxlOiB7IG1lc3NhZ2U6ICdTZWxlY3QgYWxsJyB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9jbGVhcl9hbGxfYnV0dG9uX2FyaWFfbGFiZWw6IHtcbiAgICAgIG1lc3NhZ2U6ICdDbGVhciBhbGwgc2VsZWN0ZWQgezB9JyxcbiAgICB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9jbGVhcl9hbGxfYnV0dG9uX3RpdGxlOiB7IG1lc3NhZ2U6ICdDbGVhciBhbGwnIH0sXG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX3Nob3dfc2VsZWN0ZWRfb3B0aW9uX2FyaWFfbGFiZWw6IHtcbiAgICAgIG1lc3NhZ2U6ICdTaG93IG9ubHkgc2VsZWN0ZWQgezB9JyxcbiAgICB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9zaG93X3NlbGVjdGVkX29wdGlvbl90aXRsZToge1xuICAgICAgbWVzc2FnZTogJ1Nob3cgb25seSBzZWxlY3RlZCBpdGVtcycsXG4gICAgfSxcbiAgICBza3l1eF9kYXRhX21hbmFnZXJfY29sdW1uc19idXR0b25fYXJpYV9sYWJlbDoge1xuICAgICAgbWVzc2FnZTogJ0Nob29zZSBjb2x1bW5zIGZvciB7MH0nLFxuICAgIH0sXG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX2NvbHVtbnNfYnV0dG9uX3RpdGxlOiB7IG1lc3NhZ2U6ICdDb2x1bW5zJyB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9zZWxlY3RfY29sdW1uX3N0YXR1c19pbmRpY2F0b3JfdGl0bGU6IHtcbiAgICAgIG1lc3NhZ2U6ICdTZWxlY3QgYXQgbGVhc3Qgb25lIGNvbHVtbi4nLFxuICAgIH0sXG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX3N0YXR1c191cGRhdGVfd2l0aF9zZWxlY3Rpb25zOiB7XG4gICAgICBtZXNzYWdlOiAnezB9IG9mIHsxfSBpdGVtcyBtZWV0IGNyaXRlcmlhIGFuZCB7Mn0gc2VsZWN0ZWQuJyxcbiAgICB9LFxuICAgIHNreXV4X2RhdGFfbWFuYWdlcl9zdGF0dXNfdXBkYXRlX3dpdGhvdXRfc2VsZWN0aW9uczoge1xuICAgICAgbWVzc2FnZTogJ3swfSBvZiB7MX0gaXRlbXMgbWVldCBjcml0ZXJpYS4nLFxuICAgIH0sXG4gICAgc2t5dXhfZGF0YV9tYW5hZ2VyX3N0YXR1c191cGRhdGVfb25seV9zZWxlY3RlZDoge1xuICAgICAgbWVzc2FnZTpcbiAgICAgICAgJ3swfSBvZiB7MX0gaXRlbXMgbWVldCBjcml0ZXJpYSBhbmQgezJ9IHNlbGVjdGVkLiBPbmx5IHNlbGVjdGVkIGl0ZW1zIGFyZSBkaXNwbGF5ZWQuJyxcbiAgICB9LFxuICB9LFxufTtcblxuU2t5TGliUmVzb3VyY2VzU2VydmljZS5hZGRSZXNvdXJjZXMoUkVTT1VSQ0VTKTtcblxuZXhwb3J0IGNsYXNzIFNreURhdGFNYW5hZ2VyUmVzb3VyY2VzUHJvdmlkZXJcbiAgaW1wbGVtZW50cyBTa3lMaWJSZXNvdXJjZXNQcm92aWRlclxue1xuICBwdWJsaWMgZ2V0U3RyaW5nKFxuICAgIGxvY2FsZUluZm86IFNreUFwcExvY2FsZUluZm8sXG4gICAgbmFtZTogc3RyaW5nLFxuICApOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiBnZXRMaWJTdHJpbmdGb3JMb2NhbGUoUkVTT1VSQ0VTLCBsb2NhbGVJbmZvLmxvY2FsZSwgbmFtZSk7XG4gIH1cbn1cblxuLyoqXG4gKiBJbXBvcnQgaW50byBhbnkgY29tcG9uZW50IGxpYnJhcnkgbW9kdWxlIHRoYXQgbmVlZHMgdG8gdXNlIHJlc291cmNlIHN0cmluZ3MuXG4gKi9cbkBOZ01vZHVsZSh7XG4gIGV4cG9ydHM6IFtTa3lJMThuTW9kdWxlXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogU0tZX0xJQl9SRVNPVVJDRVNfUFJPVklERVJTLFxuICAgICAgdXNlQ2xhc3M6IFNreURhdGFNYW5hZ2VyUmVzb3VyY2VzUHJvdmlkZXIsXG4gICAgICBtdWx0aTogdHJ1ZSxcbiAgICB9LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lEYXRhTWFuYWdlclJlc291cmNlc01vZHVsZSB7fVxuIl19
|
@@ -15,7 +15,7 @@ import { SkyLibResourcesService, getLibStringForLocale, SkyI18nModule, SKY_LIB_R
|
|
15
15
|
import * as i2 from '@angular/forms';
|
16
16
|
import { FormsModule } from '@angular/forms';
|
17
17
|
import * as i1 from '@skyux/core';
|
18
|
-
import { SkyLogService, SkyViewkeeperModule } from '@skyux/core';
|
18
|
+
import { SkyLogService, SkyLiveAnnouncerService, SkyViewkeeperModule } from '@skyux/core';
|
19
19
|
import * as i3 from '@skyux/forms';
|
20
20
|
import { SkyCheckboxModule, SkyRadioModule } from '@skyux/forms';
|
21
21
|
import * as i8 from '@skyux/layout';
|
@@ -65,6 +65,15 @@ const RESOURCES = {
|
|
65
65
|
skyux_data_manager_select_column_status_indicator_title: {
|
66
66
|
message: 'Select at least one column.',
|
67
67
|
},
|
68
|
+
skyux_data_manager_status_update_with_selections: {
|
69
|
+
message: '{0} of {1} items meet criteria and {2} selected.',
|
70
|
+
},
|
71
|
+
skyux_data_manager_status_update_without_selections: {
|
72
|
+
message: '{0} of {1} items meet criteria.',
|
73
|
+
},
|
74
|
+
skyux_data_manager_status_update_only_selected: {
|
75
|
+
message: '{0} of {1} items meet criteria and {2} selected. Only selected items are displayed.',
|
76
|
+
},
|
68
77
|
},
|
69
78
|
};
|
70
79
|
SkyLibResourcesService.addResources(RESOURCES);
|
@@ -263,6 +272,7 @@ class SkyDataManagerService {
|
|
263
272
|
#dataManagerConfig;
|
264
273
|
#views;
|
265
274
|
#dataStateChange;
|
275
|
+
#dataSummary;
|
266
276
|
#isInitialized;
|
267
277
|
#ngUnsubscribe;
|
268
278
|
#initSource;
|
@@ -273,6 +283,7 @@ class SkyDataManagerService {
|
|
273
283
|
this.#dataManagerConfig = new BehaviorSubject({});
|
274
284
|
this.#views = new BehaviorSubject([]);
|
275
285
|
this.#dataStateChange = new ReplaySubject(1);
|
286
|
+
this.#dataSummary = new Subject();
|
276
287
|
this.#ngUnsubscribe = new Subject();
|
277
288
|
this.#initSource = 'dataManagerServiceInit';
|
278
289
|
this.#uiConfigService = uiConfigService;
|
@@ -429,6 +440,26 @@ class SkyDataManagerService {
|
|
429
440
|
const newStateChange = new SkyDataManagerStateChange(newState, sourceId);
|
430
441
|
this.#dataStateChange.next(newStateChange);
|
431
442
|
}
|
443
|
+
/**
|
444
|
+
* Returns an observable of data summary changes that views and other data manager entities can subscribe to.
|
445
|
+
* It excludes updates originating from the provided source. This allows subscribers to only respond to
|
446
|
+
* changes they did not create and helps prevent infinite loops of updates and responses.
|
447
|
+
* @param sourceId The ID of the entity subscribing to data summary updates. This can be any value you choose
|
448
|
+
* but should be unique within the data manager instance and should also be used when that entity updates the summary.
|
449
|
+
*/
|
450
|
+
getDataSummaryUpdates(sourceId) {
|
451
|
+
return this.#dataSummary.pipe(filter((summaryChange) => sourceId !== summaryChange.source), map((summaryChange) => summaryChange.dataSummary));
|
452
|
+
}
|
453
|
+
/**
|
454
|
+
* Updates the data summary and emits a new value to entities subscribed to data summary changes.
|
455
|
+
* @param summary The new `SkyDataManagerSummary` value.
|
456
|
+
* @param sourceId The ID of the entity updating the summary. This can be any value you choose,
|
457
|
+
* but should be unique within the data manager instance and should also be used when that entity
|
458
|
+
* subscribes to summary changes from `getDataSummaryUpdates`.
|
459
|
+
*/
|
460
|
+
updateDataSummary(summary, sourceId) {
|
461
|
+
this.#dataSummary.next({ dataSummary: summary, source: sourceId });
|
462
|
+
}
|
432
463
|
/**
|
433
464
|
* Returns the current `SkyDataManagerConfig`.
|
434
465
|
*/
|
@@ -744,6 +775,8 @@ class SkyDataManagerComponent {
|
|
744
775
|
this.#_currentViewkeeperClasses = VIEWKEEPER_CLASSES_DEFAULT;
|
745
776
|
this.#changeDetection = inject(ChangeDetectorRef);
|
746
777
|
this.#dataManagerService = inject(SkyDataManagerService);
|
778
|
+
this.#liveAnnouncer = inject(SkyLiveAnnouncerService);
|
779
|
+
this.#resourceSvc = inject(SkyLibResourcesService);
|
747
780
|
}
|
748
781
|
get currentViewkeeperClasses() {
|
749
782
|
return this.#_currentViewkeeperClasses;
|
@@ -766,15 +799,33 @@ class SkyDataManagerComponent {
|
|
766
799
|
#allViewkeeperClasses;
|
767
800
|
#ngUnsubscribe;
|
768
801
|
#sourceId;
|
802
|
+
#dataState;
|
769
803
|
#_isInitialized;
|
770
804
|
#_currentViewkeeperClasses;
|
771
805
|
#changeDetection;
|
772
806
|
#dataManagerService;
|
807
|
+
#liveAnnouncer;
|
808
|
+
#resourceSvc;
|
773
809
|
ngOnInit() {
|
774
810
|
this.#dataManagerService
|
775
811
|
.getDataStateUpdates(this.#sourceId)
|
776
812
|
.pipe(takeUntil(this.#ngUnsubscribe))
|
777
|
-
.subscribe(() =>
|
813
|
+
.subscribe((state) => {
|
814
|
+
this.isInitialized = true;
|
815
|
+
this.#dataState = state;
|
816
|
+
});
|
817
|
+
this.#dataManagerService
|
818
|
+
.getDataSummaryUpdates(this.#sourceId)
|
819
|
+
.pipe(takeUntil(this.#ngUnsubscribe))
|
820
|
+
.subscribe((summary) => {
|
821
|
+
const itemsSelected = this.#dataState?.selectedIds?.length || 0;
|
822
|
+
const resourceString = `skyux_data_manager_status_update_${this.#dataState?.onlyShowSelected
|
823
|
+
? 'only_selected'
|
824
|
+
: itemsSelected
|
825
|
+
? 'with_selections'
|
826
|
+
: 'without_selections'}`;
|
827
|
+
this.#announceState(resourceString, summary.itemsMatching, summary.totalItems, itemsSelected);
|
828
|
+
});
|
778
829
|
this.#dataManagerService.viewkeeperClasses
|
779
830
|
.pipe(takeUntil(this.#ngUnsubscribe))
|
780
831
|
.subscribe((classes) => {
|
@@ -799,6 +850,14 @@ class SkyDataManagerComponent {
|
|
799
850
|
this.#ngUnsubscribe.next();
|
800
851
|
this.#ngUnsubscribe.complete();
|
801
852
|
}
|
853
|
+
#announceState(resourceString, itemsMatching, totalItems, itemsSelected) {
|
854
|
+
this.#resourceSvc
|
855
|
+
.getString(resourceString, itemsMatching, totalItems, itemsSelected)
|
856
|
+
.pipe(take(1))
|
857
|
+
.subscribe((internationalizedString) => {
|
858
|
+
this.#liveAnnouncer.announce(internationalizedString);
|
859
|
+
});
|
860
|
+
}
|
802
861
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.9", ngImport: i0, type: SkyDataManagerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
803
862
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.9", type: SkyDataManagerComponent, isStandalone: true, selector: "sky-data-manager", ngImport: i0, template: "<div\n *ngIf=\"isInitialized\"\n class=\"sky-data-manager\"\n [skyBackToTop]=\"backToTopOptions\"\n [skyBackToTopMessageStream]=\"backToTopController\"\n [skyViewkeeper]=\"currentViewkeeperClasses\"\n #dataManager\n>\n <ng-content />\n</div>\n", dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: SkyBackToTopModule }, { kind: "directive", type: i8.λ7, selector: "[skyBackToTop]", inputs: ["skyBackToTop", "skyBackToTopMessageStream"] }, { kind: "ngmodule", type: SkyViewkeeperModule }, { kind: "directive", type: i1.λ3, selector: "[skyViewkeeper]", inputs: ["skyViewkeeper"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
804
863
|
}
|