@skyux/data-manager 8.6.0 → 9.0.0-alpha.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.
Files changed (45) hide show
  1. package/documentation.json +2 -2
  2. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-column-picker/data-manager-column-picker-impl.service.mjs +4 -4
  3. package/esm2022/lib/modules/data-manager/data-manager-column-picker/data-manager-column-picker.component.mjs +161 -0
  4. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-column-picker/data-manager-column-picker.service.mjs +4 -4
  5. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar-left-item.component.mjs +4 -4
  6. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar-primary-item.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar-right-item.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar-section.component.mjs +4 -4
  9. package/esm2022/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar.component.mjs +198 -0
  10. package/esm2022/lib/modules/data-manager/data-manager.component.mjs +89 -0
  11. package/esm2022/lib/modules/data-manager/data-manager.module.mjs +123 -0
  12. package/esm2022/lib/modules/data-manager/data-manager.service.mjs +285 -0
  13. package/esm2022/lib/modules/data-manager/data-view.component.mjs +49 -0
  14. package/esm2022/lib/modules/shared/sky-data-manager-resources.module.mjs +60 -0
  15. package/fesm2022/skyux-data-manager.mjs +1138 -0
  16. package/{fesm2020 → fesm2022}/skyux-data-manager.mjs.map +1 -1
  17. package/lib/modules/data-manager/data-view.component.d.ts +1 -1
  18. package/package.json +16 -22
  19. package/esm2020/lib/modules/data-manager/data-manager-column-picker/data-manager-column-picker.component.mjs +0 -162
  20. package/esm2020/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar.component.mjs +0 -201
  21. package/esm2020/lib/modules/data-manager/data-manager.component.mjs +0 -87
  22. package/esm2020/lib/modules/data-manager/data-manager.module.mjs +0 -123
  23. package/esm2020/lib/modules/data-manager/data-manager.service.mjs +0 -281
  24. package/esm2020/lib/modules/data-manager/data-view.component.mjs +0 -52
  25. package/esm2020/lib/modules/shared/sky-data-manager-resources.module.mjs +0 -60
  26. package/fesm2015/skyux-data-manager.mjs +0 -1142
  27. package/fesm2015/skyux-data-manager.mjs.map +0 -1
  28. package/fesm2020/skyux-data-manager.mjs +0 -1135
  29. /package/{esm2020 → esm2022}/index.mjs +0 -0
  30. /package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-column-picker/data-manager-column-picker-context.mjs +0 -0
  31. /package/{esm2020 → esm2022}/lib/modules/data-manager/data-manager-filter-context.mjs +0 -0
  32. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-column-picker-option.mjs +0 -0
  33. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-column-picker-sort-strategy.mjs +0 -0
  34. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-config.mjs +0 -0
  35. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-filter-data.mjs +0 -0
  36. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-init-args.mjs +0 -0
  37. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-sort-option.mjs +0 -0
  38. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-state-change.mjs +0 -0
  39. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-state-options.mjs +0 -0
  40. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-state-update-filter-args.mjs +0 -0
  41. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-manager-state.mjs +0 -0
  42. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-view-config.mjs +0 -0
  43. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-view-state-options.mjs +0 -0
  44. /package/{esm2020 → esm2022}/lib/modules/data-manager/models/data-view-state.mjs +0 -0
  45. /package/{esm2020 → esm2022}/skyux-data-manager.mjs +0 -0
@@ -0,0 +1,198 @@
1
+ import { ChangeDetectionStrategy, Component, } from '@angular/core';
2
+ import { Subject } from 'rxjs';
3
+ import { takeUntil } from 'rxjs/operators';
4
+ import { SkyDataManagerColumnPickerContext } from '../data-manager-column-picker/data-manager-column-picker-context';
5
+ import { SkyDataManagerFilterModalContext } from '../data-manager-filter-context';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../data-manager.service";
8
+ import * as i2 from "@skyux/modals";
9
+ import * as i3 from "../data-manager-column-picker/data-manager-column-picker.service";
10
+ import * as i4 from "@angular/common";
11
+ import * as i5 from "@angular/forms";
12
+ import * as i6 from "@skyux/forms";
13
+ import * as i7 from "@skyux/lists";
14
+ import * as i8 from "@skyux/indicators";
15
+ import * as i9 from "@skyux/lookup";
16
+ import * as i10 from "@skyux/layout";
17
+ import * as i11 from "@skyux/i18n";
18
+ /**
19
+ * Renders a `sky-toolbar` with the contents specified by the active view's `SkyDataViewConfig`
20
+ * and the `SkyDataManagerToolbarLeftItemsComponent`, `SkyDataManagerToolbarRightItemsComponent`,
21
+ * and `SkyDataManagerToolbarSectionComponent` wrappers.
22
+ */
23
+ export class SkyDataManagerToolbarComponent {
24
+ get activeView() {
25
+ return this.#_activeView;
26
+ }
27
+ set activeView(value) {
28
+ this.#_activeView = value;
29
+ this.#changeDetector.markForCheck();
30
+ }
31
+ get dataManagerConfig() {
32
+ return this.#_dataManagerConfig;
33
+ }
34
+ set dataManagerConfig(value) {
35
+ this.#_dataManagerConfig = value;
36
+ this.#changeDetector.markForCheck();
37
+ }
38
+ get dataState() {
39
+ return this.#_dataState;
40
+ }
41
+ set dataState(value) {
42
+ this.#_dataState = value;
43
+ if (value) {
44
+ this.#dataManagerService.updateDataState(value, this.#_source);
45
+ }
46
+ }
47
+ get views() {
48
+ return this.#_views;
49
+ }
50
+ set views(value) {
51
+ this.#_views = value;
52
+ this.#changeDetector.markForCheck();
53
+ }
54
+ #ngUnsubscribe = new Subject();
55
+ #changeDetector;
56
+ #dataManagerService;
57
+ #modalService;
58
+ #columnPickerService;
59
+ // the source to provide for data state changes
60
+ #_source = 'toolbar';
61
+ #_activeView;
62
+ #_dataManagerConfig;
63
+ #_dataState;
64
+ #_views = [];
65
+ constructor(changeDetector, dataManagerService, modalService, columnPickerService) {
66
+ this.#changeDetector = changeDetector;
67
+ this.#dataManagerService = dataManagerService;
68
+ this.#modalService = modalService;
69
+ this.#columnPickerService = columnPickerService;
70
+ }
71
+ ngOnInit() {
72
+ this.#dataManagerService
73
+ .getActiveViewIdUpdates()
74
+ .pipe(takeUntil(this.#ngUnsubscribe))
75
+ .subscribe((activeViewId) => {
76
+ /* istanbul ignore else */
77
+ if (activeViewId) {
78
+ this.activeView = this.#dataManagerService.getViewById(activeViewId);
79
+ this.#changeDetector.markForCheck();
80
+ }
81
+ });
82
+ this.#dataManagerService
83
+ .getDataViewsUpdates()
84
+ .pipe(takeUntil(this.#ngUnsubscribe))
85
+ .subscribe((views) => {
86
+ this.views = views;
87
+ if (this.activeView) {
88
+ this.activeView = this.#dataManagerService.getViewById(this.activeView.id);
89
+ }
90
+ this.#changeDetector.markForCheck();
91
+ });
92
+ this.#dataManagerService
93
+ .getDataStateUpdates(this.#_source)
94
+ .pipe(takeUntil(this.#ngUnsubscribe))
95
+ .subscribe((dataState) => {
96
+ this.#_dataState = dataState;
97
+ this.onlyShowSelected = dataState.onlyShowSelected;
98
+ this.#changeDetector.markForCheck();
99
+ });
100
+ this.#dataManagerService
101
+ .getDataManagerConfigUpdates()
102
+ .pipe(takeUntil(this.#ngUnsubscribe))
103
+ .subscribe((config) => {
104
+ this.dataManagerConfig = config;
105
+ });
106
+ }
107
+ ngOnDestroy() {
108
+ this.#ngUnsubscribe.next();
109
+ this.#ngUnsubscribe.complete();
110
+ }
111
+ sortSelected(sortOption) {
112
+ if (this.dataState) {
113
+ this.dataState.activeSortOption = sortOption;
114
+ this.#dataManagerService.updateDataState(this.dataState, this.#_source);
115
+ }
116
+ }
117
+ onViewChange(viewId) {
118
+ this.#dataManagerService.updateActiveViewId(viewId);
119
+ }
120
+ searchApplied(text) {
121
+ if (this.dataState) {
122
+ this.dataState.searchText = text;
123
+ this.#dataManagerService.updateDataState(this.dataState, this.#_source);
124
+ }
125
+ }
126
+ filterButtonClicked() {
127
+ const context = new SkyDataManagerFilterModalContext();
128
+ const filterModal = this.dataManagerConfig && this.dataManagerConfig.filterModalComponent;
129
+ context.filterData = this.dataState?.filterData;
130
+ const options = {
131
+ providers: [
132
+ { provide: SkyDataManagerFilterModalContext, useValue: context },
133
+ ],
134
+ size: 'large',
135
+ };
136
+ if (filterModal) {
137
+ const modalInstance = this.#modalService.open(filterModal, options);
138
+ modalInstance.closed.subscribe((result) => {
139
+ if (this.dataState && result.reason === 'save') {
140
+ this.dataState.filterData = result.data;
141
+ this.#dataManagerService.updateDataState(this.dataState, this.#_source);
142
+ }
143
+ });
144
+ }
145
+ }
146
+ openColumnPicker() {
147
+ if (this.dataState && this.activeView && this.activeView.columnOptions) {
148
+ const viewState = this.dataState.getViewStateById(this.activeView.id);
149
+ if (viewState) {
150
+ const context = new SkyDataManagerColumnPickerContext(this.activeView.columnOptions, viewState.displayedColumnIds);
151
+ if (this.activeView.columnPickerSortStrategy) {
152
+ context.columnPickerSortStrategy =
153
+ this.activeView.columnPickerSortStrategy;
154
+ }
155
+ const options = {
156
+ providers: [
157
+ { provide: SkyDataManagerColumnPickerContext, useValue: context },
158
+ ],
159
+ };
160
+ const modalInstance = this.#modalService.open(this.#columnPickerService.getComponentType(), options);
161
+ modalInstance.closed.subscribe((result) => {
162
+ if (result.reason === 'save') {
163
+ const displayedColumnIds = result.data.map((col) => col.id);
164
+ viewState.displayedColumnIds = displayedColumnIds;
165
+ if (this.dataState && this.activeView) {
166
+ this.dataState = this.dataState.addOrUpdateView(this.activeView.id, viewState);
167
+ }
168
+ }
169
+ });
170
+ }
171
+ }
172
+ }
173
+ selectAll() {
174
+ /* istanbul ignore else */
175
+ if (this.activeView?.onSelectAllClick) {
176
+ this.activeView.onSelectAllClick();
177
+ }
178
+ }
179
+ clearAll() {
180
+ /* istanbul ignore else */
181
+ if (this.activeView?.onClearAllClick) {
182
+ this.activeView.onClearAllClick();
183
+ }
184
+ }
185
+ onOnlyShowSelected(event) {
186
+ if (this.dataState) {
187
+ this.dataState.onlyShowSelected = !!event.checked;
188
+ this.#dataManagerService.updateDataState(this.dataState, this.#_source);
189
+ }
190
+ }
191
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerToolbarComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDataManagerService }, { token: i2.SkyModalService }, { token: i3.SkyDataManagerColumnPickerService }], target: i0.ɵɵFactoryTarget.Component }); }
192
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyDataManagerToolbarComponent, selector: "sky-data-manager-toolbar", ngImport: i0, template: "<div class=\"sky-data-manager-toolbar\">\n <sky-toolbar>\n <sky-toolbar-section>\n <ng-content select=\"sky-data-manager-toolbar-primary-item\"></ng-content>\n\n <sky-toolbar-item *ngIf=\"activeView?.filterButtonEnabled\">\n <sky-filter-button\n [showButtonText]=\"activeView?.showFilterButtonText\"\n (filterButtonClick)=\"filterButtonClicked()\"\n >\n </sky-filter-button>\n </sky-toolbar-item>\n\n <sky-toolbar-item *ngIf=\"activeView?.sortEnabled\">\n <sky-sort [showButtonText]=\"activeView?.showSortButtonText\">\n <sky-sort-item\n *ngFor=\"let item of dataManagerConfig?.sortOptions\"\n [active]=\"!!(dataState?.activeSortOption?.id === item.id)\"\n (itemSelect)=\"sortSelected(item)\"\n >\n {{ item.label }}\n </sky-sort-item>\n </sky-sort>\n </sky-toolbar-item>\n\n <sky-toolbar-item *ngIf=\"activeView?.columnPickerEnabled\">\n <button\n class=\"sky-btn sky-btn-default sky-col-picker-btn\"\n type=\"button\"\n [attr.aria-label]=\"\n 'skyux_data_manager_columns_button_title' | skyLibResources\n \"\n [attr.title]=\"\n 'skyux_data_manager_columns_button_title' | skyLibResources\n \"\n (click)=\"openColumnPicker()\"\n >\n <sky-icon icon=\"columns\"></sky-icon>\n <span class=\"sky-column-selector-action-btn-text\">\n {{ 'skyux_data_manager_columns_button_title' | skyLibResources }}\n </span>\n </button>\n </sky-toolbar-item>\n\n <ng-content select=\"sky-data-manager-toolbar-left-item\"></ng-content>\n\n <sky-toolbar-item *ngIf=\"activeView?.searchEnabled\">\n <sky-search\n [expandMode]=\"activeView?.searchExpandMode\"\n [placeholderText]=\"activeView?.searchPlaceholderText\"\n [searchText]=\"dataState?.searchText\"\n (searchApply)=\"searchApplied($event)\"\n >\n </sky-search>\n </sky-toolbar-item>\n\n <sky-toolbar-view-actions>\n <ng-content select=\"sky-data-manager-toolbar-right-item\"></ng-content>\n <sky-radio-group\n *ngIf=\"activeView && views && views.length > 1\"\n [ariaLabel]=\"'data view switcher'\"\n [(ngModel)]=\"activeView.id\"\n class=\"sky-switch-icon-group\"\n >\n <sky-radio\n *ngFor=\"let view of views\"\n [attr.aria-label]=\"view.name\"\n [icon]=\"view.icon\"\n [value]=\"view.id\"\n [label]=\"view.name\"\n (change)=\"onViewChange(view.id)\"\n >\n </sky-radio>\n </sky-radio-group>\n </sky-toolbar-view-actions>\n </sky-toolbar-section>\n <ng-content select=\"sky-data-manager-toolbar-section\"></ng-content>\n </sky-toolbar>\n\n <sky-toolbar\n *ngIf=\"activeView?.multiselectToolbarEnabled\"\n class=\"sky-data-manager-multiselect-toolbar\"\n >\n <sky-toolbar-section>\n <sky-toolbar-item>\n <button\n class=\"sky-btn sky-btn-link sky-data-manager-select-all-btn\"\n type=\"button\"\n (click)=\"selectAll()\"\n >\n {{ 'skyux_data_manager_select_all_button_title' | skyLibResources }}\n </button>\n </sky-toolbar-item>\n <sky-toolbar-item>\n <button\n class=\"sky-btn sky-btn-link sky-data-manager-clear-all-btn\"\n type=\"button\"\n (click)=\"clearAll()\"\n >\n {{ 'skyux_data_manager_clear_all_button_title' | skyLibResources }}\n </button>\n </sky-toolbar-item>\n <sky-toolbar-view-actions>\n <sky-checkbox\n [checked]=\"onlyShowSelected\"\n (change)=\"onOnlyShowSelected($event)\"\n >\n <sky-checkbox-label>\n {{\n 'skyux_data_manager_show_selected_option_title' | skyLibResources\n }}\n </sky-checkbox-label>\n </sky-checkbox>\n </sky-toolbar-view-actions>\n </sky-toolbar-section>\n </sky-toolbar>\n</div>\n", styles: [":host .sky-col-picker-btn .sky-column-selector-action-btn-text{display:none}:host-context(.sky-responsive-container-xs) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-sm) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-md) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-lg) .sky-col-picker-btn .sky-column-selector-action-btn-text{display:none}@media (min-width: 768px){:host .sky-col-picker-btn .sky-column-selector-action-btn-text{display:inline}}:host-context(.sky-responsive-container-sm) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-md) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-lg) .sky-col-picker-btn .sky-column-selector-action-btn-text{display:inline}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.λ3, selector: "sky-checkbox", inputs: ["label", "labelledBy", "id", "disabled", "tabindex", "name", "icon", "checkboxType", "checked", "indeterminate", "required"], outputs: ["change", "checkedChange", "disabledChange", "indeterminateChange"] }, { kind: "component", type: i6.λ4, selector: "sky-checkbox-label" }, { kind: "component", type: i7.λ1, selector: "sky-filter-button", inputs: ["filterButtonId", "ariaControls", "ariaExpanded", "active", "disabled", "showButtonText"], outputs: ["filterButtonClick"] }, { kind: "component", type: i8.λ4, selector: "sky-icon", inputs: ["icon", "iconType", "size", "fixedWidth", "variant"] }, { kind: "component", type: i6.λ13, selector: "sky-radio", inputs: ["checked", "disabled", "id", "label", "labelledBy", "name", "tabindex", "value", "icon", "radioType"], outputs: ["change", "checkedChange", "disabledChange"] }, { kind: "component", type: i6.λ11, selector: "sky-radio-group", inputs: ["ariaLabelledBy", "ariaLabel", "disabled", "name", "required", "value", "tabIndex"] }, { kind: "component", type: i9.SkySearchComponent, selector: "sky-search", inputs: ["searchText", "expandMode", "debounceTime", "disabled", "placeholderText"], outputs: ["searchApply", "searchChange", "searchClear"] }, { kind: "component", type: i7.λ14, selector: "sky-sort", inputs: ["showButtonText"] }, { kind: "component", type: i7.λ13, selector: "sky-sort-item", inputs: ["active"], outputs: ["itemSelect"] }, { kind: "component", type: i10.λ37, selector: "sky-toolbar" }, { kind: "component", type: i10.λ39, selector: "sky-toolbar-item" }, { kind: "component", type: i10.λ38, selector: "sky-toolbar-section" }, { kind: "component", type: i10.λ40, selector: "sky-toolbar-view-actions" }, { kind: "pipe", type: i11.SkyLibResourcesPipe, name: "skyLibResources" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
193
+ }
194
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerToolbarComponent, decorators: [{
195
+ type: Component,
196
+ args: [{ selector: 'sky-data-manager-toolbar', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"sky-data-manager-toolbar\">\n <sky-toolbar>\n <sky-toolbar-section>\n <ng-content select=\"sky-data-manager-toolbar-primary-item\"></ng-content>\n\n <sky-toolbar-item *ngIf=\"activeView?.filterButtonEnabled\">\n <sky-filter-button\n [showButtonText]=\"activeView?.showFilterButtonText\"\n (filterButtonClick)=\"filterButtonClicked()\"\n >\n </sky-filter-button>\n </sky-toolbar-item>\n\n <sky-toolbar-item *ngIf=\"activeView?.sortEnabled\">\n <sky-sort [showButtonText]=\"activeView?.showSortButtonText\">\n <sky-sort-item\n *ngFor=\"let item of dataManagerConfig?.sortOptions\"\n [active]=\"!!(dataState?.activeSortOption?.id === item.id)\"\n (itemSelect)=\"sortSelected(item)\"\n >\n {{ item.label }}\n </sky-sort-item>\n </sky-sort>\n </sky-toolbar-item>\n\n <sky-toolbar-item *ngIf=\"activeView?.columnPickerEnabled\">\n <button\n class=\"sky-btn sky-btn-default sky-col-picker-btn\"\n type=\"button\"\n [attr.aria-label]=\"\n 'skyux_data_manager_columns_button_title' | skyLibResources\n \"\n [attr.title]=\"\n 'skyux_data_manager_columns_button_title' | skyLibResources\n \"\n (click)=\"openColumnPicker()\"\n >\n <sky-icon icon=\"columns\"></sky-icon>\n <span class=\"sky-column-selector-action-btn-text\">\n {{ 'skyux_data_manager_columns_button_title' | skyLibResources }}\n </span>\n </button>\n </sky-toolbar-item>\n\n <ng-content select=\"sky-data-manager-toolbar-left-item\"></ng-content>\n\n <sky-toolbar-item *ngIf=\"activeView?.searchEnabled\">\n <sky-search\n [expandMode]=\"activeView?.searchExpandMode\"\n [placeholderText]=\"activeView?.searchPlaceholderText\"\n [searchText]=\"dataState?.searchText\"\n (searchApply)=\"searchApplied($event)\"\n >\n </sky-search>\n </sky-toolbar-item>\n\n <sky-toolbar-view-actions>\n <ng-content select=\"sky-data-manager-toolbar-right-item\"></ng-content>\n <sky-radio-group\n *ngIf=\"activeView && views && views.length > 1\"\n [ariaLabel]=\"'data view switcher'\"\n [(ngModel)]=\"activeView.id\"\n class=\"sky-switch-icon-group\"\n >\n <sky-radio\n *ngFor=\"let view of views\"\n [attr.aria-label]=\"view.name\"\n [icon]=\"view.icon\"\n [value]=\"view.id\"\n [label]=\"view.name\"\n (change)=\"onViewChange(view.id)\"\n >\n </sky-radio>\n </sky-radio-group>\n </sky-toolbar-view-actions>\n </sky-toolbar-section>\n <ng-content select=\"sky-data-manager-toolbar-section\"></ng-content>\n </sky-toolbar>\n\n <sky-toolbar\n *ngIf=\"activeView?.multiselectToolbarEnabled\"\n class=\"sky-data-manager-multiselect-toolbar\"\n >\n <sky-toolbar-section>\n <sky-toolbar-item>\n <button\n class=\"sky-btn sky-btn-link sky-data-manager-select-all-btn\"\n type=\"button\"\n (click)=\"selectAll()\"\n >\n {{ 'skyux_data_manager_select_all_button_title' | skyLibResources }}\n </button>\n </sky-toolbar-item>\n <sky-toolbar-item>\n <button\n class=\"sky-btn sky-btn-link sky-data-manager-clear-all-btn\"\n type=\"button\"\n (click)=\"clearAll()\"\n >\n {{ 'skyux_data_manager_clear_all_button_title' | skyLibResources }}\n </button>\n </sky-toolbar-item>\n <sky-toolbar-view-actions>\n <sky-checkbox\n [checked]=\"onlyShowSelected\"\n (change)=\"onOnlyShowSelected($event)\"\n >\n <sky-checkbox-label>\n {{\n 'skyux_data_manager_show_selected_option_title' | skyLibResources\n }}\n </sky-checkbox-label>\n </sky-checkbox>\n </sky-toolbar-view-actions>\n </sky-toolbar-section>\n </sky-toolbar>\n</div>\n", styles: [":host .sky-col-picker-btn .sky-column-selector-action-btn-text{display:none}:host-context(.sky-responsive-container-xs) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-sm) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-md) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-lg) .sky-col-picker-btn .sky-column-selector-action-btn-text{display:none}@media (min-width: 768px){:host .sky-col-picker-btn .sky-column-selector-action-btn-text{display:inline}}:host-context(.sky-responsive-container-sm) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-md) .sky-col-picker-btn .sky-column-selector-action-btn-text,:host-context(.sky-responsive-container-lg) .sky-col-picker-btn .sky-column-selector-action-btn-text{display:inline}\n"] }]
197
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyDataManagerService }, { type: i2.SkyModalService }, { type: i3.SkyDataManagerColumnPickerService }]; } });
198
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-manager-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar.component.ts","../../../../../../../../../libs/components/data-manager/src/lib/modules/data-manager/data-manager-toolbar/data-manager-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { SkyCheckboxChange } from '@skyux/forms';\nimport {\n  SkyModalCloseArgs,\n  SkyModalConfigurationInterface,\n  SkyModalService,\n} from '@skyux/modals';\n\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyDataManagerColumnPickerContext } from '../data-manager-column-picker/data-manager-column-picker-context';\nimport { SkyDataManagerColumnPickerService } from '../data-manager-column-picker/data-manager-column-picker.service';\nimport { SkyDataManagerFilterModalContext } from '../data-manager-filter-context';\nimport { SkyDataManagerService } from '../data-manager.service';\nimport { SkyDataManagerColumnPickerOption } from '../models/data-manager-column-picker-option';\nimport { SkyDataManagerConfig } from '../models/data-manager-config';\nimport { SkyDataManagerSortOption } from '../models/data-manager-sort-option';\nimport { SkyDataManagerState } from '../models/data-manager-state';\nimport { SkyDataViewConfig } from '../models/data-view-config';\n\n/**\n * Renders a `sky-toolbar` with the contents specified by the active view's `SkyDataViewConfig`\n * and the `SkyDataManagerToolbarLeftItemsComponent`, `SkyDataManagerToolbarRightItemsComponent`,\n * and `SkyDataManagerToolbarSectionComponent` wrappers.\n */\n@Component({\n  selector: 'sky-data-manager-toolbar',\n  templateUrl: './data-manager-toolbar.component.html',\n  styleUrls: ['./data-manager-toolbar.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class SkyDataManagerToolbarComponent implements OnDestroy, OnInit {\n  public get activeView(): SkyDataViewConfig | undefined {\n    return this.#_activeView;\n  }\n\n  public set activeView(value: SkyDataViewConfig | undefined) {\n    this.#_activeView = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public get dataManagerConfig(): SkyDataManagerConfig | undefined {\n    return this.#_dataManagerConfig;\n  }\n\n  public set dataManagerConfig(value: SkyDataManagerConfig | undefined) {\n    this.#_dataManagerConfig = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public get dataState(): SkyDataManagerState | undefined {\n    return this.#_dataState;\n  }\n\n  public set dataState(value: SkyDataManagerState | undefined) {\n    this.#_dataState = value;\n    if (value) {\n      this.#dataManagerService.updateDataState(value, this.#_source);\n    }\n  }\n\n  public get views(): SkyDataViewConfig[] {\n    return this.#_views;\n  }\n\n  public set views(value: SkyDataViewConfig[]) {\n    this.#_views = value;\n    this.#changeDetector.markForCheck();\n  }\n\n  public onlyShowSelected: boolean | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n  #changeDetector: ChangeDetectorRef;\n  #dataManagerService: SkyDataManagerService;\n  #modalService: SkyModalService;\n  #columnPickerService: SkyDataManagerColumnPickerService;\n\n  // the source to provide for data state changes\n  #_source = 'toolbar';\n  #_activeView: SkyDataViewConfig | undefined;\n  #_dataManagerConfig: SkyDataManagerConfig | undefined;\n  #_dataState: SkyDataManagerState | undefined;\n  #_views: SkyDataViewConfig[] = [];\n\n  constructor(\n    changeDetector: ChangeDetectorRef,\n    dataManagerService: SkyDataManagerService,\n    modalService: SkyModalService,\n    columnPickerService: SkyDataManagerColumnPickerService\n  ) {\n    this.#changeDetector = changeDetector;\n    this.#dataManagerService = dataManagerService;\n    this.#modalService = modalService;\n    this.#columnPickerService = columnPickerService;\n  }\n\n  public ngOnInit(): void {\n    this.#dataManagerService\n      .getActiveViewIdUpdates()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((activeViewId) => {\n        /* istanbul ignore else */\n        if (activeViewId) {\n          this.activeView = this.#dataManagerService.getViewById(activeViewId);\n          this.#changeDetector.markForCheck();\n        }\n      });\n\n    this.#dataManagerService\n      .getDataViewsUpdates()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((views) => {\n        this.views = views;\n        if (this.activeView) {\n          this.activeView = this.#dataManagerService.getViewById(\n            this.activeView.id\n          );\n        }\n        this.#changeDetector.markForCheck();\n      });\n\n    this.#dataManagerService\n      .getDataStateUpdates(this.#_source)\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((dataState) => {\n        this.#_dataState = dataState;\n        this.onlyShowSelected = dataState.onlyShowSelected;\n        this.#changeDetector.markForCheck();\n      });\n\n    this.#dataManagerService\n      .getDataManagerConfigUpdates()\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((config) => {\n        this.dataManagerConfig = config;\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  public sortSelected(sortOption: SkyDataManagerSortOption): void {\n    if (this.dataState) {\n      this.dataState.activeSortOption = sortOption;\n      this.#dataManagerService.updateDataState(this.dataState, this.#_source);\n    }\n  }\n\n  public onViewChange(viewId: string): void {\n    this.#dataManagerService.updateActiveViewId(viewId);\n  }\n\n  public searchApplied(text: string): void {\n    if (this.dataState) {\n      this.dataState.searchText = text;\n      this.#dataManagerService.updateDataState(this.dataState, this.#_source);\n    }\n  }\n\n  public filterButtonClicked(): void {\n    const context = new SkyDataManagerFilterModalContext();\n    const filterModal =\n      this.dataManagerConfig && this.dataManagerConfig.filterModalComponent;\n\n    context.filterData = this.dataState?.filterData;\n\n    const options: SkyModalConfigurationInterface = {\n      providers: [\n        { provide: SkyDataManagerFilterModalContext, useValue: context },\n      ],\n      size: 'large',\n    };\n\n    if (filterModal) {\n      const modalInstance = this.#modalService.open(filterModal, options);\n\n      modalInstance.closed.subscribe((result: SkyModalCloseArgs) => {\n        if (this.dataState && result.reason === 'save') {\n          this.dataState.filterData = result.data;\n          this.#dataManagerService.updateDataState(\n            this.dataState,\n            this.#_source\n          );\n        }\n      });\n    }\n  }\n\n  public openColumnPicker(): void {\n    if (this.dataState && this.activeView && this.activeView.columnOptions) {\n      const viewState = this.dataState.getViewStateById(this.activeView.id);\n      if (viewState) {\n        const context = new SkyDataManagerColumnPickerContext(\n          this.activeView.columnOptions,\n          viewState.displayedColumnIds\n        );\n\n        if (this.activeView.columnPickerSortStrategy) {\n          context.columnPickerSortStrategy =\n            this.activeView.columnPickerSortStrategy;\n        }\n\n        const options: SkyModalConfigurationInterface = {\n          providers: [\n            { provide: SkyDataManagerColumnPickerContext, useValue: context },\n          ],\n        };\n\n        const modalInstance = this.#modalService.open(\n          this.#columnPickerService.getComponentType(),\n          options\n        );\n\n        modalInstance.closed.subscribe((result: SkyModalCloseArgs) => {\n          if (result.reason === 'save') {\n            const displayedColumnIds = result.data.map(\n              (col: SkyDataManagerColumnPickerOption) => col.id\n            );\n\n            viewState.displayedColumnIds = displayedColumnIds;\n            if (this.dataState && this.activeView) {\n              this.dataState = this.dataState.addOrUpdateView(\n                this.activeView.id,\n                viewState\n              );\n            }\n          }\n        });\n      }\n    }\n  }\n\n  public selectAll(): void {\n    /* istanbul ignore else */\n    if (this.activeView?.onSelectAllClick) {\n      this.activeView.onSelectAllClick();\n    }\n  }\n\n  public clearAll(): void {\n    /* istanbul ignore else */\n    if (this.activeView?.onClearAllClick) {\n      this.activeView.onClearAllClick();\n    }\n  }\n\n  public onOnlyShowSelected(event: SkyCheckboxChange): void {\n    if (this.dataState) {\n      this.dataState.onlyShowSelected = !!event.checked;\n      this.#dataManagerService.updateDataState(this.dataState, this.#_source);\n    }\n  }\n}\n","<div class=\"sky-data-manager-toolbar\">\n  <sky-toolbar>\n    <sky-toolbar-section>\n      <ng-content select=\"sky-data-manager-toolbar-primary-item\"></ng-content>\n\n      <sky-toolbar-item *ngIf=\"activeView?.filterButtonEnabled\">\n        <sky-filter-button\n          [showButtonText]=\"activeView?.showFilterButtonText\"\n          (filterButtonClick)=\"filterButtonClicked()\"\n        >\n        </sky-filter-button>\n      </sky-toolbar-item>\n\n      <sky-toolbar-item *ngIf=\"activeView?.sortEnabled\">\n        <sky-sort [showButtonText]=\"activeView?.showSortButtonText\">\n          <sky-sort-item\n            *ngFor=\"let item of dataManagerConfig?.sortOptions\"\n            [active]=\"!!(dataState?.activeSortOption?.id === item.id)\"\n            (itemSelect)=\"sortSelected(item)\"\n          >\n            {{ item.label }}\n          </sky-sort-item>\n        </sky-sort>\n      </sky-toolbar-item>\n\n      <sky-toolbar-item *ngIf=\"activeView?.columnPickerEnabled\">\n        <button\n          class=\"sky-btn sky-btn-default sky-col-picker-btn\"\n          type=\"button\"\n          [attr.aria-label]=\"\n            'skyux_data_manager_columns_button_title' | skyLibResources\n          \"\n          [attr.title]=\"\n            'skyux_data_manager_columns_button_title' | skyLibResources\n          \"\n          (click)=\"openColumnPicker()\"\n        >\n          <sky-icon icon=\"columns\"></sky-icon>\n          <span class=\"sky-column-selector-action-btn-text\">\n            {{ 'skyux_data_manager_columns_button_title' | skyLibResources }}\n          </span>\n        </button>\n      </sky-toolbar-item>\n\n      <ng-content select=\"sky-data-manager-toolbar-left-item\"></ng-content>\n\n      <sky-toolbar-item *ngIf=\"activeView?.searchEnabled\">\n        <sky-search\n          [expandMode]=\"activeView?.searchExpandMode\"\n          [placeholderText]=\"activeView?.searchPlaceholderText\"\n          [searchText]=\"dataState?.searchText\"\n          (searchApply)=\"searchApplied($event)\"\n        >\n        </sky-search>\n      </sky-toolbar-item>\n\n      <sky-toolbar-view-actions>\n        <ng-content select=\"sky-data-manager-toolbar-right-item\"></ng-content>\n        <sky-radio-group\n          *ngIf=\"activeView && views && views.length > 1\"\n          [ariaLabel]=\"'data view switcher'\"\n          [(ngModel)]=\"activeView.id\"\n          class=\"sky-switch-icon-group\"\n        >\n          <sky-radio\n            *ngFor=\"let view of views\"\n            [attr.aria-label]=\"view.name\"\n            [icon]=\"view.icon\"\n            [value]=\"view.id\"\n            [label]=\"view.name\"\n            (change)=\"onViewChange(view.id)\"\n          >\n          </sky-radio>\n        </sky-radio-group>\n      </sky-toolbar-view-actions>\n    </sky-toolbar-section>\n    <ng-content select=\"sky-data-manager-toolbar-section\"></ng-content>\n  </sky-toolbar>\n\n  <sky-toolbar\n    *ngIf=\"activeView?.multiselectToolbarEnabled\"\n    class=\"sky-data-manager-multiselect-toolbar\"\n  >\n    <sky-toolbar-section>\n      <sky-toolbar-item>\n        <button\n          class=\"sky-btn sky-btn-link sky-data-manager-select-all-btn\"\n          type=\"button\"\n          (click)=\"selectAll()\"\n        >\n          {{ 'skyux_data_manager_select_all_button_title' | skyLibResources }}\n        </button>\n      </sky-toolbar-item>\n      <sky-toolbar-item>\n        <button\n          class=\"sky-btn sky-btn-link sky-data-manager-clear-all-btn\"\n          type=\"button\"\n          (click)=\"clearAll()\"\n        >\n          {{ 'skyux_data_manager_clear_all_button_title' | skyLibResources }}\n        </button>\n      </sky-toolbar-item>\n      <sky-toolbar-view-actions>\n        <sky-checkbox\n          [checked]=\"onlyShowSelected\"\n          (change)=\"onOnlyShowSelected($event)\"\n        >\n          <sky-checkbox-label>\n            {{\n              'skyux_data_manager_show_selected_option_title' | skyLibResources\n            }}\n          </sky-checkbox-label>\n        </sky-checkbox>\n      </sky-toolbar-view-actions>\n    </sky-toolbar-section>\n  </sky-toolbar>\n</div>\n"]}
@@ -0,0 +1,89 @@
1
+ import { ChangeDetectionStrategy, Component, } from '@angular/core';
2
+ import { SkyBackToTopMessageType } from '@skyux/layout';
3
+ import { Subject } from 'rxjs';
4
+ import { takeUntil } from 'rxjs/operators';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "./data-manager.service";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "@skyux/layout";
9
+ import * as i4 from "@skyux/core";
10
+ const VIEWKEEPER_CLASSES_DEFAULT = ['.sky-data-manager-toolbar'];
11
+ /**
12
+ * The top-level data manager component. Provide `SkyDataManagerService` at this level.
13
+ */
14
+ export class SkyDataManagerComponent {
15
+ get currentViewkeeperClasses() {
16
+ return this.#_currentViewkeeperClasses;
17
+ }
18
+ set currentViewkeeperClasses(value) {
19
+ this.#_currentViewkeeperClasses = [
20
+ ...VIEWKEEPER_CLASSES_DEFAULT,
21
+ ...(value || []),
22
+ ];
23
+ this.#changeDetection.markForCheck();
24
+ }
25
+ get isInitialized() {
26
+ return this.#_isInitialized;
27
+ }
28
+ set isInitialized(value) {
29
+ this.#_isInitialized = value;
30
+ this.#changeDetection.markForCheck();
31
+ }
32
+ #activeViewId;
33
+ #allViewkeeperClasses;
34
+ #ngUnsubscribe;
35
+ #sourceId;
36
+ #changeDetection;
37
+ #dataManagerService;
38
+ #_isInitialized;
39
+ #_currentViewkeeperClasses;
40
+ constructor(changeDetection, dataManagerService) {
41
+ this.backToTopController = new Subject();
42
+ this.backToTopOptions = {
43
+ buttonHidden: true,
44
+ };
45
+ this.#allViewkeeperClasses = {};
46
+ this.#ngUnsubscribe = new Subject();
47
+ this.#sourceId = 'dataManagerComponent';
48
+ this.#_isInitialized = false;
49
+ this.#_currentViewkeeperClasses = VIEWKEEPER_CLASSES_DEFAULT;
50
+ this.#changeDetection = changeDetection;
51
+ this.#dataManagerService = dataManagerService;
52
+ }
53
+ ngOnInit() {
54
+ this.#dataManagerService
55
+ .getDataStateUpdates(this.#sourceId)
56
+ .pipe(takeUntil(this.#ngUnsubscribe))
57
+ .subscribe(() => (this.isInitialized = true));
58
+ this.#dataManagerService.viewkeeperClasses
59
+ .pipe(takeUntil(this.#ngUnsubscribe))
60
+ .subscribe((classes) => {
61
+ this.#allViewkeeperClasses = classes;
62
+ this.currentViewkeeperClasses = this.#activeViewId
63
+ ? classes[this.#activeViewId]
64
+ : undefined;
65
+ });
66
+ this.#dataManagerService
67
+ .getActiveViewIdUpdates()
68
+ .pipe(takeUntil(this.#ngUnsubscribe))
69
+ .subscribe((activeViewId) => {
70
+ this.#activeViewId = activeViewId;
71
+ this.backToTopController.next({
72
+ type: SkyBackToTopMessageType.BackToTop,
73
+ });
74
+ this.currentViewkeeperClasses =
75
+ this.#allViewkeeperClasses[this.#activeViewId];
76
+ });
77
+ }
78
+ ngOnDestroy() {
79
+ this.#ngUnsubscribe.next();
80
+ this.#ngUnsubscribe.complete();
81
+ }
82
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.SkyDataManagerService }], target: i0.ɵɵFactoryTarget.Component }); }
83
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyDataManagerComponent, 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></ng-content>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.λ7, selector: "[skyBackToTop]", inputs: ["skyBackToTop", "skyBackToTopMessageStream"] }, { kind: "directive", type: i4.λ3, selector: "[skyViewkeeper]", inputs: ["skyViewkeeper"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
84
+ }
85
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerComponent, decorators: [{
86
+ type: Component,
87
+ args: [{ selector: 'sky-data-manager', changeDetection: ChangeDetectionStrategy.OnPush, 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></ng-content>\n</div>\n" }]
88
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.SkyDataManagerService }]; } });
89
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1tYW5hZ2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRhLW1hbmFnZXIvc3JjL2xpYi9tb2R1bGVzL2RhdGEtbWFuYWdlci9kYXRhLW1hbmFnZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2RhdGEtbWFuYWdlci9zcmMvbGliL21vZHVsZXMvZGF0YS1tYW5hZ2VyL2RhdGEtbWFuYWdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBRXZCLFNBQVMsR0FHVixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQXVCLHVCQUF1QixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTdFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDL0IsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7QUFJM0MsTUFBTSwwQkFBMEIsR0FBRyxDQUFDLDJCQUEyQixDQUFDLENBQUM7QUFFakU7O0dBRUc7QUFNSCxNQUFNLE9BQU8sdUJBQXVCO0lBQ2xDLElBQVcsd0JBQXdCO1FBQ2pDLE9BQU8sSUFBSSxDQUFDLDBCQUEwQixDQUFDO0lBQ3pDLENBQUM7SUFFRCxJQUFXLHdCQUF3QixDQUFDLEtBQTJCO1FBQzdELElBQUksQ0FBQywwQkFBMEIsR0FBRztZQUNoQyxHQUFHLDBCQUEwQjtZQUM3QixHQUFHLENBQUMsS0FBSyxJQUFJLEVBQUUsQ0FBQztTQUNqQixDQUFDO1FBQ0YsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxJQUFXLGFBQWE7UUFDdEIsT0FBTyxJQUFJLENBQUMsZUFBZSxDQUFDO0lBQzlCLENBQUM7SUFFRCxJQUFXLGFBQWEsQ0FBQyxLQUFjO1FBQ3JDLElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDO1FBQzdCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN2QyxDQUFDO0lBUUQsYUFBYSxDQUFxQjtJQUNsQyxxQkFBcUIsQ0FBZ0M7SUFDckQsY0FBYyxDQUF1QjtJQUNyQyxTQUFTLENBQTBCO0lBQ25DLGdCQUFnQixDQUFvQjtJQUNwQyxtQkFBbUIsQ0FBd0I7SUFFM0MsZUFBZSxDQUFTO0lBQ3hCLDBCQUEwQixDQUE4QjtJQUV4RCxZQUNFLGVBQWtDLEVBQ2xDLGtCQUF5QztRQWxCcEMsd0JBQW1CLEdBQUcsSUFBSSxPQUFPLEVBQXVCLENBQUM7UUFFekQscUJBQWdCLEdBQUc7WUFDeEIsWUFBWSxFQUFFLElBQUk7U0FDbkIsQ0FBQztRQUdGLDBCQUFxQixHQUE2QixFQUFFLENBQUM7UUFDckQsbUJBQWMsR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBQ3JDLGNBQVMsR0FBRyxzQkFBc0IsQ0FBQztRQUluQyxvQkFBZSxHQUFHLEtBQUssQ0FBQztRQUN4QiwrQkFBMEIsR0FBRywwQkFBMEIsQ0FBQztRQU10RCxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsZUFBZSxDQUFDO1FBQ3hDLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxrQkFBa0IsQ0FBQztJQUNoRCxDQUFDO0lBRU0sUUFBUTtRQUNiLElBQUksQ0FBQyxtQkFBbUI7YUFDckIsbUJBQW1CLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQzthQUNuQyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQzthQUNwQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUM7UUFFaEQsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGlCQUFpQjthQUN2QyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQzthQUNwQyxTQUFTLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRTtZQUNyQixJQUFJLENBQUMscUJBQXFCLEdBQUcsT0FBTyxDQUFDO1lBQ3JDLElBQUksQ0FBQyx3QkFBd0IsR0FBRyxJQUFJLENBQUMsYUFBYTtnQkFDaEQsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDO2dCQUM3QixDQUFDLENBQUMsU0FBUyxDQUFDO1FBQ2hCLENBQUMsQ0FBQyxDQUFDO1FBRUwsSUFBSSxDQUFDLG1CQUFtQjthQUNyQixzQkFBc0IsRUFBRTthQUN4QixJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQzthQUNwQyxTQUFTLENBQUMsQ0FBQyxZQUFZLEVBQUUsRUFBRTtZQUMxQixJQUFJLENBQUMsYUFBYSxHQUFHLFlBQVksQ0FBQztZQUNsQyxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDO2dCQUM1QixJQUFJLEVBQUUsdUJBQXVCLENBQUMsU0FBUzthQUN4QyxDQUFDLENBQUM7WUFDSCxJQUFJLENBQUMsd0JBQXdCO2dCQUMzQixJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ25ELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUMzQixJQUFJLENBQUMsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2pDLENBQUM7OEdBN0VVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLHdEQ3hCcEMsdVFBVUE7OzJGRGNhLHVCQUF1QjtrQkFMbkMsU0FBUzsrQkFDRSxrQkFBa0IsbUJBRVgsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICBDaGFuZ2VEZXRlY3RvclJlZixcbiAgQ29tcG9uZW50LFxuICBPbkRlc3Ryb3ksXG4gIE9uSW5pdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lCYWNrVG9Ub3BNZXNzYWdlLCBTa3lCYWNrVG9Ub3BNZXNzYWdlVHlwZSB9IGZyb20gJ0Bza3l1eC9sYXlvdXQnO1xuXG5pbXBvcnQgeyBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XG5pbXBvcnQgeyB0YWtlVW50aWwgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7IFNreURhdGFNYW5hZ2VyU2VydmljZSB9IGZyb20gJy4vZGF0YS1tYW5hZ2VyLnNlcnZpY2UnO1xuXG5jb25zdCBWSUVXS0VFUEVSX0NMQVNTRVNfREVGQVVMVCA9IFsnLnNreS1kYXRhLW1hbmFnZXItdG9vbGJhciddO1xuXG4vKipcbiAqIFRoZSB0b3AtbGV2ZWwgZGF0YSBtYW5hZ2VyIGNvbXBvbmVudC4gUHJvdmlkZSBgU2t5RGF0YU1hbmFnZXJTZXJ2aWNlYCBhdCB0aGlzIGxldmVsLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktZGF0YS1tYW5hZ2VyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGEtbWFuYWdlci5jb21wb25lbnQuaHRtbCcsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lEYXRhTWFuYWdlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uRGVzdHJveSwgT25Jbml0IHtcbiAgcHVibGljIGdldCBjdXJyZW50Vmlld2tlZXBlckNsYXNzZXMoKTogc3RyaW5nW10ge1xuICAgIHJldHVybiB0aGlzLiNfY3VycmVudFZpZXdrZWVwZXJDbGFzc2VzO1xuICB9XG5cbiAgcHVibGljIHNldCBjdXJyZW50Vmlld2tlZXBlckNsYXNzZXModmFsdWU6IHN0cmluZ1tdIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy4jX2N1cnJlbnRWaWV3a2VlcGVyQ2xhc3NlcyA9IFtcbiAgICAgIC4uLlZJRVdLRUVQRVJfQ0xBU1NFU19ERUZBVUxULFxuICAgICAgLi4uKHZhbHVlIHx8IFtdKSxcbiAgICBdO1xuICAgIHRoaXMuI2NoYW5nZURldGVjdGlvbi5tYXJrRm9yQ2hlY2soKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gdGhpcy4jX2lzSW5pdGlhbGl6ZWQ7XG4gIH1cblxuICBwdWJsaWMgc2V0IGlzSW5pdGlhbGl6ZWQodmFsdWU6IGJvb2xlYW4pIHtcbiAgICB0aGlzLiNfaXNJbml0aWFsaXplZCA9IHZhbHVlO1xuICAgIHRoaXMuI2NoYW5nZURldGVjdGlvbi5tYXJrRm9yQ2hlY2soKTtcbiAgfVxuXG4gIHB1YmxpYyBiYWNrVG9Ub3BDb250cm9sbGVyID0gbmV3IFN1YmplY3Q8U2t5QmFja1RvVG9wTWVzc2FnZT4oKTtcblxuICBwdWJsaWMgYmFja1RvVG9wT3B0aW9ucyA9IHtcbiAgICBidXR0b25IaWRkZW46IHRydWUsXG4gIH07XG5cbiAgI2FjdGl2ZVZpZXdJZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAjYWxsVmlld2tlZXBlckNsYXNzZXM6IFJlY29yZDxzdHJpbmcsIHN0cmluZ1tdPiA9IHt9O1xuICAjbmdVbnN1YnNjcmliZSA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG4gICNzb3VyY2VJZCA9ICdkYXRhTWFuYWdlckNvbXBvbmVudCc7XG4gICNjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdG9yUmVmO1xuICAjZGF0YU1hbmFnZXJTZXJ2aWNlOiBTa3lEYXRhTWFuYWdlclNlcnZpY2U7XG5cbiAgI19pc0luaXRpYWxpemVkID0gZmFsc2U7XG4gICNfY3VycmVudFZpZXdrZWVwZXJDbGFzc2VzID0gVklFV0tFRVBFUl9DTEFTU0VTX0RFRkFVTFQ7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3RvclJlZixcbiAgICBkYXRhTWFuYWdlclNlcnZpY2U6IFNreURhdGFNYW5hZ2VyU2VydmljZVxuICApIHtcbiAgICB0aGlzLiNjaGFuZ2VEZXRlY3Rpb24gPSBjaGFuZ2VEZXRlY3Rpb247XG4gICAgdGhpcy4jZGF0YU1hbmFnZXJTZXJ2aWNlID0gZGF0YU1hbmFnZXJTZXJ2aWNlO1xuICB9XG5cbiAgcHVibGljIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMuI2RhdGFNYW5hZ2VyU2VydmljZVxuICAgICAgLmdldERhdGFTdGF0ZVVwZGF0ZXModGhpcy4jc291cmNlSWQpXG4gICAgICAucGlwZSh0YWtlVW50aWwodGhpcy4jbmdVbnN1YnNjcmliZSkpXG4gICAgICAuc3Vic2NyaWJlKCgpID0+ICh0aGlzLmlzSW5pdGlhbGl6ZWQgPSB0cnVlKSk7XG5cbiAgICB0aGlzLiNkYXRhTWFuYWdlclNlcnZpY2Uudmlld2tlZXBlckNsYXNzZXNcbiAgICAgIC5waXBlKHRha2VVbnRpbCh0aGlzLiNuZ1Vuc3Vic2NyaWJlKSlcbiAgICAgIC5zdWJzY3JpYmUoKGNsYXNzZXMpID0+IHtcbiAgICAgICAgdGhpcy4jYWxsVmlld2tlZXBlckNsYXNzZXMgPSBjbGFzc2VzO1xuICAgICAgICB0aGlzLmN1cnJlbnRWaWV3a2VlcGVyQ2xhc3NlcyA9IHRoaXMuI2FjdGl2ZVZpZXdJZFxuICAgICAgICAgID8gY2xhc3Nlc1t0aGlzLiNhY3RpdmVWaWV3SWRdXG4gICAgICAgICAgOiB1bmRlZmluZWQ7XG4gICAgICB9KTtcblxuICAgIHRoaXMuI2RhdGFNYW5hZ2VyU2VydmljZVxuICAgICAgLmdldEFjdGl2ZVZpZXdJZFVwZGF0ZXMoKVxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuI25nVW5zdWJzY3JpYmUpKVxuICAgICAgLnN1YnNjcmliZSgoYWN0aXZlVmlld0lkKSA9PiB7XG4gICAgICAgIHRoaXMuI2FjdGl2ZVZpZXdJZCA9IGFjdGl2ZVZpZXdJZDtcbiAgICAgICAgdGhpcy5iYWNrVG9Ub3BDb250cm9sbGVyLm5leHQoe1xuICAgICAgICAgIHR5cGU6IFNreUJhY2tUb1RvcE1lc3NhZ2VUeXBlLkJhY2tUb1RvcCxcbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMuY3VycmVudFZpZXdrZWVwZXJDbGFzc2VzID1cbiAgICAgICAgICB0aGlzLiNhbGxWaWV3a2VlcGVyQ2xhc3Nlc1t0aGlzLiNhY3RpdmVWaWV3SWRdO1xuICAgICAgfSk7XG4gIH1cblxuICBwdWJsaWMgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgdGhpcy4jbmdVbnN1YnNjcmliZS5uZXh0KCk7XG4gICAgdGhpcy4jbmdVbnN1YnNjcmliZS5jb21wbGV0ZSgpO1xuICB9XG59XG4iLCI8ZGl2XG4gICpuZ0lmPVwiaXNJbml0aWFsaXplZFwiXG4gIGNsYXNzPVwic2t5LWRhdGEtbWFuYWdlclwiXG4gIFtza3lCYWNrVG9Ub3BdPVwiYmFja1RvVG9wT3B0aW9uc1wiXG4gIFtza3lCYWNrVG9Ub3BNZXNzYWdlU3RyZWFtXT1cImJhY2tUb1RvcENvbnRyb2xsZXJcIlxuICBbc2t5Vmlld2tlZXBlcl09XCJjdXJyZW50Vmlld2tlZXBlckNsYXNzZXNcIlxuICAjZGF0YU1hbmFnZXJcbj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
@@ -0,0 +1,123 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { FormsModule } from '@angular/forms';
4
+ import { SkyViewkeeperModule } from '@skyux/core';
5
+ import { SkyCheckboxModule, SkyRadioModule } from '@skyux/forms';
6
+ import { SkyIconModule, SkyStatusIndicatorModule } from '@skyux/indicators';
7
+ import { SkyBackToTopModule, SkyToolbarModule } from '@skyux/layout';
8
+ import { SkyFilterModule, SkyRepeaterModule, SkySortModule, } from '@skyux/lists';
9
+ import { SkySearchModule } from '@skyux/lookup';
10
+ import { SkyModalModule } from '@skyux/modals';
11
+ import { SkyDataManagerResourcesModule } from '../shared/sky-data-manager-resources.module';
12
+ import { SkyDataManagerColumnPickerImplService } from './data-manager-column-picker/data-manager-column-picker-impl.service';
13
+ import { SkyDataManagerColumnPickerComponent } from './data-manager-column-picker/data-manager-column-picker.component';
14
+ import { SkyDataManagerColumnPickerService } from './data-manager-column-picker/data-manager-column-picker.service';
15
+ import { SkyDataManagerToolbarLeftItemComponent } from './data-manager-toolbar/data-manager-toolbar-left-item.component';
16
+ import { SkyDataManagerToolbarPrimaryItemComponent } from './data-manager-toolbar/data-manager-toolbar-primary-item.component';
17
+ import { SkyDataManagerToolbarRightItemComponent } from './data-manager-toolbar/data-manager-toolbar-right-item.component';
18
+ import { SkyDataManagerToolbarSectionComponent } from './data-manager-toolbar/data-manager-toolbar-section.component';
19
+ import { SkyDataManagerToolbarComponent } from './data-manager-toolbar/data-manager-toolbar.component';
20
+ import { SkyDataManagerComponent } from './data-manager.component';
21
+ import { SkyDataViewComponent } from './data-view.component';
22
+ import * as i0 from "@angular/core";
23
+ export class SkyDataManagerModule {
24
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
25
+ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerModule, declarations: [SkyDataManagerColumnPickerComponent,
26
+ SkyDataManagerComponent,
27
+ SkyDataManagerToolbarLeftItemComponent,
28
+ SkyDataManagerToolbarPrimaryItemComponent,
29
+ SkyDataManagerToolbarRightItemComponent,
30
+ SkyDataManagerToolbarSectionComponent,
31
+ SkyDataManagerToolbarComponent,
32
+ SkyDataViewComponent], imports: [CommonModule,
33
+ FormsModule,
34
+ SkyBackToTopModule,
35
+ SkyCheckboxModule,
36
+ SkyDataManagerResourcesModule,
37
+ SkyFilterModule,
38
+ SkyIconModule,
39
+ SkyModalModule,
40
+ SkyRadioModule,
41
+ SkyRepeaterModule,
42
+ SkySearchModule,
43
+ SkyStatusIndicatorModule,
44
+ SkySortModule,
45
+ SkyToolbarModule,
46
+ SkyViewkeeperModule], exports: [SkyDataManagerColumnPickerComponent,
47
+ SkyDataManagerComponent,
48
+ SkyDataManagerToolbarLeftItemComponent,
49
+ SkyDataManagerToolbarPrimaryItemComponent,
50
+ SkyDataManagerToolbarRightItemComponent,
51
+ SkyDataManagerToolbarSectionComponent,
52
+ SkyDataManagerToolbarComponent,
53
+ SkyDataViewComponent] }); }
54
+ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerModule, providers: [
55
+ {
56
+ provide: SkyDataManagerColumnPickerService,
57
+ useClass: SkyDataManagerColumnPickerImplService,
58
+ },
59
+ ], imports: [CommonModule,
60
+ FormsModule,
61
+ SkyBackToTopModule,
62
+ SkyCheckboxModule,
63
+ SkyDataManagerResourcesModule,
64
+ SkyFilterModule,
65
+ SkyIconModule,
66
+ SkyModalModule,
67
+ SkyRadioModule,
68
+ SkyRepeaterModule,
69
+ SkySearchModule,
70
+ SkyStatusIndicatorModule,
71
+ SkySortModule,
72
+ SkyToolbarModule,
73
+ SkyViewkeeperModule] }); }
74
+ }
75
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyDataManagerModule, decorators: [{
76
+ type: NgModule,
77
+ args: [{
78
+ declarations: [
79
+ SkyDataManagerColumnPickerComponent,
80
+ SkyDataManagerComponent,
81
+ SkyDataManagerToolbarLeftItemComponent,
82
+ SkyDataManagerToolbarPrimaryItemComponent,
83
+ SkyDataManagerToolbarRightItemComponent,
84
+ SkyDataManagerToolbarSectionComponent,
85
+ SkyDataManagerToolbarComponent,
86
+ SkyDataViewComponent,
87
+ ],
88
+ imports: [
89
+ CommonModule,
90
+ FormsModule,
91
+ SkyBackToTopModule,
92
+ SkyCheckboxModule,
93
+ SkyDataManagerResourcesModule,
94
+ SkyFilterModule,
95
+ SkyIconModule,
96
+ SkyModalModule,
97
+ SkyRadioModule,
98
+ SkyRepeaterModule,
99
+ SkySearchModule,
100
+ SkyStatusIndicatorModule,
101
+ SkySortModule,
102
+ SkyToolbarModule,
103
+ SkyViewkeeperModule,
104
+ ],
105
+ exports: [
106
+ SkyDataManagerColumnPickerComponent,
107
+ SkyDataManagerComponent,
108
+ SkyDataManagerToolbarLeftItemComponent,
109
+ SkyDataManagerToolbarPrimaryItemComponent,
110
+ SkyDataManagerToolbarRightItemComponent,
111
+ SkyDataManagerToolbarSectionComponent,
112
+ SkyDataManagerToolbarComponent,
113
+ SkyDataViewComponent,
114
+ ],
115
+ providers: [
116
+ {
117
+ provide: SkyDataManagerColumnPickerService,
118
+ useClass: SkyDataManagerColumnPickerImplService,
119
+ },
120
+ ],
121
+ }]
122
+ }] });
123
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1tYW5hZ2VyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRhLW1hbmFnZXIvc3JjL2xpYi9tb2R1bGVzL2RhdGEtbWFuYWdlci9kYXRhLW1hbmFnZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDbEQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLGNBQWMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNqRSxPQUFPLEVBQUUsYUFBYSxFQUFFLHdCQUF3QixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDNUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFDTCxlQUFlLEVBQ2YsaUJBQWlCLEVBQ2pCLGFBQWEsR0FDZCxNQUFNLGNBQWMsQ0FBQztBQUN0QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2hELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFL0MsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFFNUYsT0FBTyxFQUFFLHFDQUFxQyxFQUFFLE1BQU0sc0VBQXNFLENBQUM7QUFDN0gsT0FBTyxFQUFFLG1DQUFtQyxFQUFFLE1BQU0sbUVBQW1FLENBQUM7QUFDeEgsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDcEgsT0FBTyxFQUFFLHNDQUFzQyxFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDekgsT0FBTyxFQUFFLHlDQUF5QyxFQUFFLE1BQU0sb0VBQW9FLENBQUM7QUFDL0gsT0FBTyxFQUFFLHVDQUF1QyxFQUFFLE1BQU0sa0VBQWtFLENBQUM7QUFDM0gsT0FBTyxFQUFFLHFDQUFxQyxFQUFFLE1BQU0sK0RBQStELENBQUM7QUFDdEgsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDdkcsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDbkUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7O0FBK0M3RCxNQUFNLE9BQU8sb0JBQW9COzhHQUFwQixvQkFBb0I7K0dBQXBCLG9CQUFvQixpQkEzQzdCLG1DQUFtQztZQUNuQyx1QkFBdUI7WUFDdkIsc0NBQXNDO1lBQ3RDLHlDQUF5QztZQUN6Qyx1Q0FBdUM7WUFDdkMscUNBQXFDO1lBQ3JDLDhCQUE4QjtZQUM5QixvQkFBb0IsYUFHcEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLDZCQUE2QjtZQUM3QixlQUFlO1lBQ2YsYUFBYTtZQUNiLGNBQWM7WUFDZCxjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZix3QkFBd0I7WUFDeEIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixtQkFBbUIsYUFHbkIsbUNBQW1DO1lBQ25DLHVCQUF1QjtZQUN2QixzQ0FBc0M7WUFDdEMseUNBQXlDO1lBQ3pDLHVDQUF1QztZQUN2QyxxQ0FBcUM7WUFDckMsOEJBQThCO1lBQzlCLG9CQUFvQjsrR0FTWCxvQkFBb0IsYUFQcEI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUNBQWlDO2dCQUMxQyxRQUFRLEVBQUUscUNBQXFDO2FBQ2hEO1NBQ0YsWUEvQkMsWUFBWTtZQUNaLFdBQVc7WUFDWCxrQkFBa0I7WUFDbEIsaUJBQWlCO1lBQ2pCLDZCQUE2QjtZQUM3QixlQUFlO1lBQ2YsYUFBYTtZQUNiLGNBQWM7WUFDZCxjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZix3QkFBd0I7WUFDeEIsYUFBYTtZQUNiLGdCQUFnQjtZQUNoQixtQkFBbUI7OzJGQW1CVixvQkFBb0I7a0JBN0NoQyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsc0NBQXNDO3dCQUN0Qyx5Q0FBeUM7d0JBQ3pDLHVDQUF1Qzt3QkFDdkMscUNBQXFDO3dCQUNyQyw4QkFBOEI7d0JBQzlCLG9CQUFvQjtxQkFDckI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxrQkFBa0I7d0JBQ2xCLGlCQUFpQjt3QkFDakIsNkJBQTZCO3dCQUM3QixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsY0FBYzt3QkFDZCxjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsZUFBZTt3QkFDZix3QkFBd0I7d0JBQ3hCLGFBQWE7d0JBQ2IsZ0JBQWdCO3dCQUNoQixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxtQ0FBbUM7d0JBQ25DLHVCQUF1Qjt3QkFDdkIsc0NBQXNDO3dCQUN0Qyx5Q0FBeUM7d0JBQ3pDLHVDQUF1Qzt3QkFDdkMscUNBQXFDO3dCQUNyQyw4QkFBOEI7d0JBQzlCLG9CQUFvQjtxQkFDckI7b0JBQ0QsU0FBUyxFQUFFO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQ0FBaUM7NEJBQzFDLFFBQVEsRUFBRSxxQ0FBcUM7eUJBQ2hEO3FCQUNGO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFNreVZpZXdrZWVwZXJNb2R1bGUgfSBmcm9tICdAc2t5dXgvY29yZSc7XG5pbXBvcnQgeyBTa3lDaGVja2JveE1vZHVsZSwgU2t5UmFkaW9Nb2R1bGUgfSBmcm9tICdAc2t5dXgvZm9ybXMnO1xuaW1wb3J0IHsgU2t5SWNvbk1vZHVsZSwgU2t5U3RhdHVzSW5kaWNhdG9yTW9kdWxlIH0gZnJvbSAnQHNreXV4L2luZGljYXRvcnMnO1xuaW1wb3J0IHsgU2t5QmFja1RvVG9wTW9kdWxlLCBTa3lUb29sYmFyTW9kdWxlIH0gZnJvbSAnQHNreXV4L2xheW91dCc7XG5pbXBvcnQge1xuICBTa3lGaWx0ZXJNb2R1bGUsXG4gIFNreVJlcGVhdGVyTW9kdWxlLFxuICBTa3lTb3J0TW9kdWxlLFxufSBmcm9tICdAc2t5dXgvbGlzdHMnO1xuaW1wb3J0IHsgU2t5U2VhcmNoTW9kdWxlIH0gZnJvbSAnQHNreXV4L2xvb2t1cCc7XG5pbXBvcnQgeyBTa3lNb2RhbE1vZHVsZSB9IGZyb20gJ0Bza3l1eC9tb2RhbHMnO1xuXG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlclJlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktZGF0YS1tYW5hZ2VyLXJlc291cmNlcy5tb2R1bGUnO1xuXG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlckNvbHVtblBpY2tlckltcGxTZXJ2aWNlIH0gZnJvbSAnLi9kYXRhLW1hbmFnZXItY29sdW1uLXBpY2tlci9kYXRhLW1hbmFnZXItY29sdW1uLXBpY2tlci1pbXBsLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2t5RGF0YU1hbmFnZXJDb2x1bW5QaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtbWFuYWdlci1jb2x1bW4tcGlja2VyL2RhdGEtbWFuYWdlci1jb2x1bW4tcGlja2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlckNvbHVtblBpY2tlclNlcnZpY2UgfSBmcm9tICcuL2RhdGEtbWFuYWdlci1jb2x1bW4tcGlja2VyL2RhdGEtbWFuYWdlci1jb2x1bW4tcGlja2VyLnNlcnZpY2UnO1xuaW1wb3J0IHsgU2t5RGF0YU1hbmFnZXJUb29sYmFyTGVmdEl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2RhdGEtbWFuYWdlci10b29sYmFyL2RhdGEtbWFuYWdlci10b29sYmFyLWxlZnQtaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5RGF0YU1hbmFnZXJUb29sYmFyUHJpbWFyeUl0ZW1Db21wb25lbnQgfSBmcm9tICcuL2RhdGEtbWFuYWdlci10b29sYmFyL2RhdGEtbWFuYWdlci10b29sYmFyLXByaW1hcnktaXRlbS5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2t5RGF0YU1hbmFnZXJUb29sYmFyUmlnaHRJdGVtQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLW1hbmFnZXItdG9vbGJhci9kYXRhLW1hbmFnZXItdG9vbGJhci1yaWdodC1pdGVtLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlclRvb2xiYXJTZWN0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLW1hbmFnZXItdG9vbGJhci9kYXRhLW1hbmFnZXItdG9vbGJhci1zZWN0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlclRvb2xiYXJDb21wb25lbnQgfSBmcm9tICcuL2RhdGEtbWFuYWdlci10b29sYmFyL2RhdGEtbWFuYWdlci10b29sYmFyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRhTWFuYWdlckNvbXBvbmVudCB9IGZyb20gJy4vZGF0YS1tYW5hZ2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTa3lEYXRhVmlld0NvbXBvbmVudCB9IGZyb20gJy4vZGF0YS12aWV3LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1xuICAgIFNreURhdGFNYW5hZ2VyQ29sdW1uUGlja2VyQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhckxlZnRJdGVtQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhclByaW1hcnlJdGVtQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhclJpZ2h0SXRlbUNvbXBvbmVudCxcbiAgICBTa3lEYXRhTWFuYWdlclRvb2xiYXJTZWN0aW9uQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhckNvbXBvbmVudCxcbiAgICBTa3lEYXRhVmlld0NvbXBvbmVudCxcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBTa3lCYWNrVG9Ub3BNb2R1bGUsXG4gICAgU2t5Q2hlY2tib3hNb2R1bGUsXG4gICAgU2t5RGF0YU1hbmFnZXJSZXNvdXJjZXNNb2R1bGUsXG4gICAgU2t5RmlsdGVyTW9kdWxlLFxuICAgIFNreUljb25Nb2R1bGUsXG4gICAgU2t5TW9kYWxNb2R1bGUsXG4gICAgU2t5UmFkaW9Nb2R1bGUsXG4gICAgU2t5UmVwZWF0ZXJNb2R1bGUsXG4gICAgU2t5U2VhcmNoTW9kdWxlLFxuICAgIFNreVN0YXR1c0luZGljYXRvck1vZHVsZSxcbiAgICBTa3lTb3J0TW9kdWxlLFxuICAgIFNreVRvb2xiYXJNb2R1bGUsXG4gICAgU2t5Vmlld2tlZXBlck1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIFNreURhdGFNYW5hZ2VyQ29sdW1uUGlja2VyQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhckxlZnRJdGVtQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhclByaW1hcnlJdGVtQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhclJpZ2h0SXRlbUNvbXBvbmVudCxcbiAgICBTa3lEYXRhTWFuYWdlclRvb2xiYXJTZWN0aW9uQ29tcG9uZW50LFxuICAgIFNreURhdGFNYW5hZ2VyVG9vbGJhckNvbXBvbmVudCxcbiAgICBTa3lEYXRhVmlld0NvbXBvbmVudCxcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogU2t5RGF0YU1hbmFnZXJDb2x1bW5QaWNrZXJTZXJ2aWNlLFxuICAgICAgdXNlQ2xhc3M6IFNreURhdGFNYW5hZ2VyQ29sdW1uUGlja2VySW1wbFNlcnZpY2UsXG4gICAgfSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5RGF0YU1hbmFnZXJNb2R1bGUge31cbiJdfQ==