@skyux/core 11.31.0 → 12.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 (141) hide show
  1. package/documentation.json +520 -516
  2. package/fesm2022/skyux-core-testing.mjs +26 -26
  3. package/fesm2022/skyux-core-testing.mjs.map +1 -1
  4. package/fesm2022/skyux-core.mjs +180 -174
  5. package/fesm2022/skyux-core.mjs.map +1 -1
  6. package/package.json +8 -12
  7. package/esm2022/index.mjs +0 -67
  8. package/esm2022/lib/modules/adapter-service/adapter.module.mjs +0 -16
  9. package/esm2022/lib/modules/adapter-service/adapter.service.mjs +0 -205
  10. package/esm2022/lib/modules/adapter-service/focusable-children-options.mjs +0 -2
  11. package/esm2022/lib/modules/affix/affix-auto-fit-context.mjs +0 -12
  12. package/esm2022/lib/modules/affix/affix-config.mjs +0 -2
  13. package/esm2022/lib/modules/affix/affix-horizontal-alignment.mjs +0 -2
  14. package/esm2022/lib/modules/affix/affix-offset-change.mjs +0 -2
  15. package/esm2022/lib/modules/affix/affix-offset.mjs +0 -2
  16. package/esm2022/lib/modules/affix/affix-placement-change.mjs +0 -2
  17. package/esm2022/lib/modules/affix/affix-placement.mjs +0 -2
  18. package/esm2022/lib/modules/affix/affix-position.mjs +0 -2
  19. package/esm2022/lib/modules/affix/affix-rect.mjs +0 -2
  20. package/esm2022/lib/modules/affix/affix-utils.mjs +0 -18
  21. package/esm2022/lib/modules/affix/affix-vertical-alignment.mjs +0 -2
  22. package/esm2022/lib/modules/affix/affix.directive.mjs +0 -116
  23. package/esm2022/lib/modules/affix/affix.module.mjs +0 -18
  24. package/esm2022/lib/modules/affix/affix.service.mjs +0 -48
  25. package/esm2022/lib/modules/affix/affixer.mjs +0 -426
  26. package/esm2022/lib/modules/affix/dom-utils.mjs +0 -126
  27. package/esm2022/lib/modules/breakpoint-observer/breakpoint-observer.mjs +0 -2
  28. package/esm2022/lib/modules/breakpoint-observer/breakpoint-observer.token.mjs +0 -7
  29. package/esm2022/lib/modules/breakpoint-observer/breakpoint-utils.mjs +0 -38
  30. package/esm2022/lib/modules/breakpoint-observer/breakpoint.mjs +0 -6
  31. package/esm2022/lib/modules/breakpoint-observer/container-breakpoint-observer.mjs +0 -64
  32. package/esm2022/lib/modules/breakpoint-observer/media-breakpoint-observer.mjs +0 -58
  33. package/esm2022/lib/modules/breakpoint-observer/provide-breakpoint-observer.mjs +0 -24
  34. package/esm2022/lib/modules/breakpoint-observer/responsive-host.directive.mjs +0 -55
  35. package/esm2022/lib/modules/content-info-provider/content-info-descriptor.mjs +0 -2
  36. package/esm2022/lib/modules/content-info-provider/content-info-provider.mjs +0 -24
  37. package/esm2022/lib/modules/content-info-provider/content-info.mjs +0 -2
  38. package/esm2022/lib/modules/default-input-provider/default-input-provider.mjs +0 -26
  39. package/esm2022/lib/modules/dock/dock-dom-adapter.service.mjs +0 -81
  40. package/esm2022/lib/modules/dock/dock-insert-component-config.mjs +0 -2
  41. package/esm2022/lib/modules/dock/dock-item-config.mjs +0 -2
  42. package/esm2022/lib/modules/dock/dock-item-reference.mjs +0 -2
  43. package/esm2022/lib/modules/dock/dock-item.mjs +0 -31
  44. package/esm2022/lib/modules/dock/dock-location.mjs +0 -19
  45. package/esm2022/lib/modules/dock/dock-options.mjs +0 -2
  46. package/esm2022/lib/modules/dock/dock.component.mjs +0 -101
  47. package/esm2022/lib/modules/dock/dock.module.mjs +0 -15
  48. package/esm2022/lib/modules/dock/dock.service.mjs +0 -95
  49. package/esm2022/lib/modules/dock/sort-by-stack-order.mjs +0 -13
  50. package/esm2022/lib/modules/dynamic-component/dynamic-component-location.mjs +0 -27
  51. package/esm2022/lib/modules/dynamic-component/dynamic-component-options.mjs +0 -2
  52. package/esm2022/lib/modules/dynamic-component/dynamic-component.module.mjs +0 -17
  53. package/esm2022/lib/modules/dynamic-component/dynamic-component.service.mjs +0 -113
  54. package/esm2022/lib/modules/file-reader/file-reader.service.mjs +0 -32
  55. package/esm2022/lib/modules/format/app-format.mjs +0 -18
  56. package/esm2022/lib/modules/help/help-global-options-token.mjs +0 -6
  57. package/esm2022/lib/modules/help/help-global-options.mjs +0 -2
  58. package/esm2022/lib/modules/help/help-open-args.mjs +0 -2
  59. package/esm2022/lib/modules/help/help-update-args.mjs +0 -2
  60. package/esm2022/lib/modules/help/help.service.mjs +0 -20
  61. package/esm2022/lib/modules/id/id.directive.mjs +0 -31
  62. package/esm2022/lib/modules/id/id.module.mjs +0 -16
  63. package/esm2022/lib/modules/id/id.service.mjs +0 -24
  64. package/esm2022/lib/modules/layout-host/layout-host-for-child-args.mjs +0 -2
  65. package/esm2022/lib/modules/layout-host/layout-host.service.mjs +0 -22
  66. package/esm2022/lib/modules/live-announcer/live-announcer.service.mjs +0 -81
  67. package/esm2022/lib/modules/live-announcer/types/live-announcer-args.mjs +0 -2
  68. package/esm2022/lib/modules/live-announcer/types/live-announcer-politeness.mjs +0 -2
  69. package/esm2022/lib/modules/log/log.module.mjs +0 -16
  70. package/esm2022/lib/modules/log/log.service.mjs +0 -148
  71. package/esm2022/lib/modules/log/types/log-deprecation-args.mjs +0 -2
  72. package/esm2022/lib/modules/log/types/log-level-token.mjs +0 -6
  73. package/esm2022/lib/modules/log/types/log-level.mjs +0 -10
  74. package/esm2022/lib/modules/media-query/media-breakpoints.mjs +0 -24
  75. package/esm2022/lib/modules/media-query/media-query-listener.mjs +0 -2
  76. package/esm2022/lib/modules/media-query/media-query.module.mjs +0 -16
  77. package/esm2022/lib/modules/media-query/media-query.service.mjs +0 -82
  78. package/esm2022/lib/modules/mutation/mutation-observer-service.mjs +0 -19
  79. package/esm2022/lib/modules/numeric/numeric-symbol.mjs +0 -2
  80. package/esm2022/lib/modules/numeric/numeric.module.mjs +0 -19
  81. package/esm2022/lib/modules/numeric/numeric.options.mjs +0 -24
  82. package/esm2022/lib/modules/numeric/numeric.pipe.mjs +0 -84
  83. package/esm2022/lib/modules/numeric/numeric.service.mjs +0 -200
  84. package/esm2022/lib/modules/overlay/overlay-adapter.service.mjs +0 -74
  85. package/esm2022/lib/modules/overlay/overlay-config.mjs +0 -2
  86. package/esm2022/lib/modules/overlay/overlay-context.mjs +0 -10
  87. package/esm2022/lib/modules/overlay/overlay-instance.mjs +0 -62
  88. package/esm2022/lib/modules/overlay/overlay-position.mjs +0 -2
  89. package/esm2022/lib/modules/overlay/overlay.component.mjs +0 -203
  90. package/esm2022/lib/modules/overlay/overlay.module.mjs +0 -15
  91. package/esm2022/lib/modules/overlay/overlay.service.mjs +0 -134
  92. package/esm2022/lib/modules/percent-pipe/percent-pipe.module.mjs +0 -19
  93. package/esm2022/lib/modules/percent-pipe/percent.pipe.mjs +0 -56
  94. package/esm2022/lib/modules/resize-observer/resize-observer-media-query.service.mjs +0 -153
  95. package/esm2022/lib/modules/resize-observer/resize-observer.service.mjs +0 -115
  96. package/esm2022/lib/modules/screen-reader-label/screen-reader-label.directive.mjs +0 -66
  97. package/esm2022/lib/modules/scroll-shadow/scroll-shadow-event-args.mjs +0 -2
  98. package/esm2022/lib/modules/scroll-shadow/scroll-shadow.directive.mjs +0 -123
  99. package/esm2022/lib/modules/scrollable-host/scrollable-host.service.mjs +0 -223
  100. package/esm2022/lib/modules/shared/number-format/number-format-utility.mjs +0 -72
  101. package/esm2022/lib/modules/shared/sky-core-resources.module.mjs +0 -34
  102. package/esm2022/lib/modules/stacking-context/stacking-context-token.mjs +0 -6
  103. package/esm2022/lib/modules/stacking-context/stacking-context.mjs +0 -2
  104. package/esm2022/lib/modules/title/set-title-args.mjs +0 -2
  105. package/esm2022/lib/modules/title/title.service.mjs +0 -31
  106. package/esm2022/lib/modules/trim/trim.directive.mjs +0 -64
  107. package/esm2022/lib/modules/trim/trim.module.mjs +0 -16
  108. package/esm2022/lib/modules/ui-config/ui-config.service.mjs +0 -21
  109. package/esm2022/lib/modules/viewkeeper/viewkeeper-boundary-info.mjs +0 -2
  110. package/esm2022/lib/modules/viewkeeper/viewkeeper-fixed-styles.mjs +0 -2
  111. package/esm2022/lib/modules/viewkeeper/viewkeeper-host-options.mjs +0 -10
  112. package/esm2022/lib/modules/viewkeeper/viewkeeper-offset.mjs +0 -2
  113. package/esm2022/lib/modules/viewkeeper/viewkeeper-options.mjs +0 -2
  114. package/esm2022/lib/modules/viewkeeper/viewkeeper.directive.mjs +0 -131
  115. package/esm2022/lib/modules/viewkeeper/viewkeeper.mjs +0 -296
  116. package/esm2022/lib/modules/viewkeeper/viewkeeper.module.mjs +0 -16
  117. package/esm2022/lib/modules/viewkeeper/viewkeeper.service.mjs +0 -39
  118. package/esm2022/lib/modules/window/window-ref.mjs +0 -30
  119. package/esm2022/skyux-core.mjs +0 -5
  120. package/esm2022/testing/legacy/core-testing.module.mjs +0 -32
  121. package/esm2022/testing/legacy/mock-media-query.service.mjs +0 -47
  122. package/esm2022/testing/legacy/mock-ui-config.service.mjs +0 -62
  123. package/esm2022/testing/legacy/resize-observer-mock.mjs +0 -50
  124. package/esm2022/testing/modules/file-reader/file-reader-testing.service.mjs +0 -19
  125. package/esm2022/testing/modules/file-reader/provide-file-reader-testing.mjs +0 -22
  126. package/esm2022/testing/modules/help/help-testing-controller.mjs +0 -28
  127. package/esm2022/testing/modules/help/help-testing.module.mjs +0 -32
  128. package/esm2022/testing/modules/help/help-testing.service.mjs +0 -37
  129. package/esm2022/testing/modules/media-query/breakpoint-observer-testing.mjs +0 -26
  130. package/esm2022/testing/modules/media-query/media-query-testing-controller.mjs +0 -22
  131. package/esm2022/testing/modules/media-query/provide-media-query-testing.mjs +0 -26
  132. package/esm2022/testing/modules/overlay/overlay-harness-filters.mjs +0 -2
  133. package/esm2022/testing/modules/overlay/overlay-harness.mjs +0 -20
  134. package/esm2022/testing/public-api.mjs +0 -15
  135. package/esm2022/testing/shared/component-harness.mjs +0 -13
  136. package/esm2022/testing/shared/harness-filters.mjs +0 -2
  137. package/esm2022/testing/shared/harness-utility.mjs +0 -7
  138. package/esm2022/testing/shared/input-harness.mjs +0 -63
  139. package/esm2022/testing/shared/queryable-component-harness.mjs +0 -43
  140. package/esm2022/testing/skyux-core-testing.mjs +0 -5
  141. package/esm2022/version.mjs +0 -19
@@ -1,203 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EnvironmentInjector, HostBinding, ViewChild, ViewContainerRef, createEnvironmentInjector, inject, } from '@angular/core';
3
- import { NavigationStart, Router } from '@angular/router';
4
- import { BehaviorSubject, ReplaySubject, Subject, fromEvent, } from 'rxjs';
5
- import { takeUntil } from 'rxjs/operators';
6
- import { SkyCoreAdapterService } from '../adapter-service/adapter.service';
7
- import { SkyIdService } from '../id/id.service';
8
- import { SKY_STACKING_CONTEXT } from '../stacking-context/stacking-context-token';
9
- import { SkyOverlayAdapterService } from './overlay-adapter.service';
10
- import { SkyOverlayContext } from './overlay-context';
11
- import * as i0 from "@angular/core";
12
- import * as i1 from "@angular/common";
13
- const POSITION_DEFAULT = 'fixed';
14
- /**
15
- * Omnibar is 1000.
16
- * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139
17
- * ---
18
- * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it
19
- * will be difficult to reliably predict a z-index that will always appear above all other
20
- * layers. Starting the z-index for overlays at a number much greater than modals will accommodate
21
- * the most reasonable of scenarios.
22
- * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22
23
- * (NOTE: It should be noted that modals do not use the overlay service, which is something we
24
- * should do in the near future to make sure z-indexes are predictable across all component
25
- * libraries.)
26
- */
27
- let uniqueZIndex = 5000;
28
- /**
29
- * @internal
30
- */
31
- export class SkyOverlayComponent {
32
- get backdropClick() {
33
- return this.#backdropClickObs;
34
- }
35
- get closed() {
36
- return this.#closedObs;
37
- }
38
- #backdropClick;
39
- #backdropClickObs;
40
- #closed;
41
- #closedObs;
42
- #ngUnsubscribe;
43
- #routerSubscription;
44
- #siblingAriaHiddenCache;
45
- #adapter;
46
- #changeDetector;
47
- #context;
48
- #coreAdapter;
49
- #elementRef;
50
- #environmentInjector;
51
- #idSvc;
52
- #router;
53
- constructor() {
54
- this.wrapperClass = '';
55
- this.enablePointerEvents = false;
56
- this.showBackdrop = false;
57
- this.zIndex = `${++uniqueZIndex}`;
58
- this.clipPath$ = new ReplaySubject(1);
59
- this.position = POSITION_DEFAULT;
60
- this.#ngUnsubscribe = new Subject();
61
- this.#siblingAriaHiddenCache = new Map();
62
- this.#adapter = inject(SkyOverlayAdapterService);
63
- this.#changeDetector = inject(ChangeDetectorRef);
64
- this.#context = inject(SkyOverlayContext);
65
- this.#coreAdapter = inject(SkyCoreAdapterService);
66
- this.#elementRef = inject(ElementRef);
67
- this.#environmentInjector = inject(EnvironmentInjector);
68
- this.#idSvc = inject(SkyIdService);
69
- this.#router = inject(Router, { optional: true });
70
- this.id = this.#idSvc.generateId();
71
- this.#backdropClick = new Subject();
72
- this.#closed = new Subject();
73
- this.#backdropClickObs = this.#backdropClick.asObservable();
74
- this.#closedObs = this.#closed.asObservable();
75
- }
76
- ngOnInit() {
77
- this.#applyConfig(this.#context.config);
78
- setTimeout(() => {
79
- this.#addBackdropClickListener();
80
- });
81
- if (this.#context.config.closeOnNavigation) {
82
- this.#addRouteListener();
83
- }
84
- if (this.#context.config.hideOthersFromScreenReaders) {
85
- this.#siblingAriaHiddenCache = this.#adapter.addAriaHiddenToSiblings(this.#elementRef);
86
- }
87
- }
88
- ngOnDestroy() {
89
- this.#removeRouteListener();
90
- this.#ngUnsubscribe.next();
91
- this.#ngUnsubscribe.complete();
92
- this.#backdropClick.complete();
93
- this.#adapter.restoreAriaHiddenForSiblings(this.#siblingAriaHiddenCache);
94
- this.#closed.next();
95
- this.#closed.complete();
96
- }
97
- attachComponent(component, providers = []) {
98
- /*istanbul ignore if: untestable*/
99
- if (!this.targetRef) {
100
- throw new Error('[SkyOverlayComponent] Could not attach the component because the target element could not be found.');
101
- }
102
- this.targetRef.clear();
103
- const environmentInjector = createEnvironmentInjector([
104
- {
105
- provide: SKY_STACKING_CONTEXT,
106
- useValue: {
107
- zIndex: new BehaviorSubject(parseInt(this.zIndex, 10))
108
- .asObservable()
109
- .pipe(takeUntil(this.#ngUnsubscribe)),
110
- },
111
- },
112
- ...providers,
113
- ], this.#environmentInjector);
114
- const componentRef = this.targetRef.createComponent(component, {
115
- environmentInjector,
116
- });
117
- // Run an initial change detection cycle after the component has been created.
118
- componentRef.changeDetectorRef.detectChanges();
119
- return componentRef;
120
- }
121
- attachTemplate(templateRef, context) {
122
- /*istanbul ignore if: untestable*/
123
- if (!this.targetRef) {
124
- throw new Error('[SkyOverlayComponent] Could not attach the template because the target element could not be found.');
125
- }
126
- this.targetRef.clear();
127
- return this.targetRef.createEmbeddedView(templateRef, context, {
128
- injector: this.#environmentInjector,
129
- });
130
- }
131
- updateClipPath(clipPath) {
132
- this.clipPath$.next(clipPath);
133
- }
134
- #applyConfig(config) {
135
- this.wrapperClass = config.wrapperClass || '';
136
- this.showBackdrop = !!config.showBackdrop;
137
- this.enablePointerEvents = !!config.enablePointerEvents;
138
- this.position = config.position || POSITION_DEFAULT;
139
- this.#changeDetector.markForCheck();
140
- }
141
- #addBackdropClickListener() {
142
- fromEvent(window.document, 'click')
143
- .pipe(takeUntil(this.#ngUnsubscribe))
144
- .subscribe((event) => {
145
- if (event.target && this.overlayContentRef && this.overlayRef) {
146
- const isChild = this.overlayContentRef.nativeElement.contains(event.target);
147
- const isAbove = this.#coreAdapter.isTargetAboveElement(event.target, this.overlayRef.nativeElement);
148
- /* istanbul ignore else */
149
- if (!isChild && !isAbove) {
150
- this.#backdropClick.next();
151
- if (this.#context.config.enableClose) {
152
- this.#closed.next();
153
- }
154
- }
155
- }
156
- });
157
- }
158
- #addRouteListener() {
159
- /*istanbul ignore else*/
160
- if (this.#router) {
161
- this.#routerSubscription = this.#router.events.subscribe((event) => {
162
- /* istanbul ignore else */
163
- if (event instanceof NavigationStart) {
164
- this.#closed.next();
165
- }
166
- });
167
- }
168
- }
169
- #removeRouteListener() {
170
- if (this.#routerSubscription) {
171
- this.#routerSubscription.unsubscribe();
172
- this.#routerSubscription = undefined;
173
- }
174
- }
175
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
176
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: SkyOverlayComponent, isStandalone: true, selector: "sky-overlay", host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "overlayContentRef", first: true, predicate: ["overlayContentRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "overlayRef", first: true, predicate: ["overlayRef"], descendants: true, read: ElementRef, static: true }, { propertyName: "targetRef", first: true, predicate: ["target"], descendants: true, read: ViewContainerRef, static: true }], ngImport: i0, template: "<div\n #overlayRef\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n>\n <div #overlayContentRef class=\"sky-overlay-content\">\n <ng-template #target />\n </div>\n @if (showBackdrop) {\n <div class=\"sky-overlay-backdrop\"></div>\n }\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:#00000080;inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
177
- }
178
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayComponent, decorators: [{
179
- type: Component,
180
- args: [{ standalone: true, selector: 'sky-overlay', changeDetection: ChangeDetectionStrategy.OnPush, imports: [CommonModule], template: "<div\n #overlayRef\n [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n [style.z-index]=\"zIndex\"\n [style.clip-path]=\"clipPath$ | async\"\n [ngClass]=\"{\n 'enable-pointer-events-pass-through': enablePointerEvents,\n 'sky-overlay': true\n }\"\n>\n <div #overlayContentRef class=\"sky-overlay-content\">\n <ng-template #target />\n </div>\n @if (showBackdrop) {\n <div class=\"sky-overlay-backdrop\"></div>\n }\n</div>\n", styles: [".sky-overlay{inset:0;width:100%;height:100%;display:flex;pointer-events:auto}.sky-overlay-position-absolute{position:absolute}.sky-overlay-position-fixed{position:fixed}.sky-overlay-content{position:relative;z-index:1;display:inline-flex;align-self:start;pointer-events:auto}.sky-overlay-backdrop{background:#00000080;inset:0;width:100%;height:100%;position:absolute}.enable-pointer-events-pass-through,.enable-pointer-events-pass-through .sky-overlay-backdrop{pointer-events:none}.enable-pointer-events-pass-through .sky-overlay-content{pointer-events:auto}\n"] }]
181
- }], ctorParameters: () => [], propDecorators: { id: [{
182
- type: HostBinding,
183
- args: ['id']
184
- }], overlayContentRef: [{
185
- type: ViewChild,
186
- args: ['overlayContentRef', {
187
- read: ElementRef,
188
- static: true,
189
- }]
190
- }], overlayRef: [{
191
- type: ViewChild,
192
- args: ['overlayRef', {
193
- read: ElementRef,
194
- static: true,
195
- }]
196
- }], targetRef: [{
197
- type: ViewChild,
198
- args: ['target', {
199
- read: ViewContainerRef,
200
- static: true,
201
- }]
202
- }] } });
203
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.ts","../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  EnvironmentInjector,\n  HostBinding,\n  OnDestroy,\n  OnInit,\n  StaticProvider,\n  TemplateRef,\n  Type,\n  ViewChild,\n  ViewContainerRef,\n  createEnvironmentInjector,\n  inject,\n} from '@angular/core';\nimport { NavigationStart, Router } from '@angular/router';\n\nimport {\n  BehaviorSubject,\n  Observable,\n  ReplaySubject,\n  Subject,\n  Subscription,\n  fromEvent,\n} from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyCoreAdapterService } from '../adapter-service/adapter.service';\nimport { SkyIdService } from '../id/id.service';\nimport { SKY_STACKING_CONTEXT } from '../stacking-context/stacking-context-token';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayPosition } from './overlay-position';\n\nconst POSITION_DEFAULT: SkyOverlayPosition = 'fixed';\n\n/**\n * Omnibar is 1000.\n * See: https://github.com/blackbaud/auth-client/blob/master/src/omnibar/omnibar.ts#L139\n * ---\n * Modals start their z-indexes at 1040. However, each modal's z-index is a multiple of 10, so it\n * will be difficult to reliably predict a z-index that will always appear above all other\n * layers. Starting the z-index for overlays at a number much greater than modals will accommodate\n * the most reasonable of scenarios.\n * See: https://github.com/blackbaud/skyux-modals/blob/master/src/app/public/modules/modal/modal-host.service.ts#L22\n * (NOTE: It should be noted that modals do not use the overlay service, which is something we\n * should do in the near future to make sure z-indexes are predictable across all component\n * libraries.)\n */\nlet uniqueZIndex = 5000;\n\n/**\n * @internal\n */\n@Component({\n  standalone: true,\n  selector: 'sky-overlay',\n  templateUrl: './overlay.component.html',\n  styleUrls: ['./overlay.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CommonModule],\n})\nexport class SkyOverlayComponent implements OnInit, OnDestroy {\n  public wrapperClass = '';\n\n  public get backdropClick(): Observable<void> {\n    return this.#backdropClickObs;\n  }\n\n  public get closed(): Observable<void> {\n    return this.#closedObs;\n  }\n\n  public enablePointerEvents = false;\n\n  @HostBinding('id')\n  public id: string;\n\n  public showBackdrop = false;\n\n  public zIndex = `${++uniqueZIndex}`;\n\n  protected clipPath$ = new ReplaySubject<string | undefined>(1);\n\n  protected position = POSITION_DEFAULT;\n\n  @ViewChild('overlayContentRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayContentRef: ElementRef | undefined;\n\n  @ViewChild('overlayRef', {\n    read: ElementRef,\n    static: true,\n  })\n  public overlayRef: ElementRef | undefined;\n\n  @ViewChild('target', {\n    read: ViewContainerRef,\n    static: true,\n  })\n  public targetRef: ViewContainerRef | undefined;\n\n  #backdropClick: Subject<void>;\n\n  #backdropClickObs: Observable<void>;\n\n  #closed: Subject<void>;\n\n  #closedObs: Observable<void>;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #routerSubscription: Subscription | undefined;\n\n  #siblingAriaHiddenCache = new Map<Element, string | null>();\n\n  readonly #adapter = inject(SkyOverlayAdapterService);\n  readonly #changeDetector = inject(ChangeDetectorRef);\n  readonly #context = inject(SkyOverlayContext);\n  readonly #coreAdapter = inject(SkyCoreAdapterService);\n  readonly #elementRef = inject(ElementRef);\n  readonly #environmentInjector = inject(EnvironmentInjector);\n  readonly #idSvc = inject(SkyIdService);\n  readonly #router = inject(Router, { optional: true });\n\n  constructor() {\n    this.id = this.#idSvc.generateId();\n\n    this.#backdropClick = new Subject<void>();\n    this.#closed = new Subject<void>();\n\n    this.#backdropClickObs = this.#backdropClick.asObservable();\n    this.#closedObs = this.#closed.asObservable();\n  }\n\n  public ngOnInit(): void {\n    this.#applyConfig(this.#context.config);\n\n    setTimeout(() => {\n      this.#addBackdropClickListener();\n    });\n\n    if (this.#context.config.closeOnNavigation) {\n      this.#addRouteListener();\n    }\n\n    if (this.#context.config.hideOthersFromScreenReaders) {\n      this.#siblingAriaHiddenCache = this.#adapter.addAriaHiddenToSiblings(\n        this.#elementRef,\n      );\n    }\n  }\n\n  public ngOnDestroy(): void {\n    this.#removeRouteListener();\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n\n    this.#backdropClick.complete();\n\n    this.#adapter.restoreAriaHiddenForSiblings(this.#siblingAriaHiddenCache);\n\n    this.#closed.next();\n    this.#closed.complete();\n  }\n\n  public attachComponent<C>(\n    component: Type<C>,\n    providers: StaticProvider[] = [],\n  ): ComponentRef<C> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the component because the target element could not be found.',\n      );\n    }\n\n    this.targetRef.clear();\n\n    const environmentInjector = createEnvironmentInjector(\n      [\n        {\n          provide: SKY_STACKING_CONTEXT,\n          useValue: {\n            zIndex: new BehaviorSubject(parseInt(this.zIndex, 10))\n              .asObservable()\n              .pipe(takeUntil(this.#ngUnsubscribe)),\n          },\n        },\n        ...providers,\n      ],\n      this.#environmentInjector,\n    );\n\n    const componentRef = this.targetRef.createComponent<C>(component, {\n      environmentInjector,\n    });\n\n    // Run an initial change detection cycle after the component has been created.\n    componentRef.changeDetectorRef.detectChanges();\n\n    return componentRef;\n  }\n\n  public attachTemplate<T>(\n    templateRef: TemplateRef<T>,\n    context: T,\n  ): EmbeddedViewRef<T> {\n    /*istanbul ignore if: untestable*/\n    if (!this.targetRef) {\n      throw new Error(\n        '[SkyOverlayComponent] Could not attach the template because the target element could not be found.',\n      );\n    }\n\n    this.targetRef.clear();\n\n    return this.targetRef.createEmbeddedView(templateRef, context, {\n      injector: this.#environmentInjector,\n    });\n  }\n\n  public updateClipPath(clipPath: string | undefined): void {\n    this.clipPath$.next(clipPath);\n  }\n\n  #applyConfig(config: SkyOverlayConfig): void {\n    this.wrapperClass = config.wrapperClass || '';\n    this.showBackdrop = !!config.showBackdrop;\n    this.enablePointerEvents = !!config.enablePointerEvents;\n    this.position = config.position || POSITION_DEFAULT;\n    this.#changeDetector.markForCheck();\n  }\n\n  #addBackdropClickListener(): void {\n    fromEvent<MouseEvent>(window.document, 'click')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe((event) => {\n        if (event.target && this.overlayContentRef && this.overlayRef) {\n          const isChild = this.overlayContentRef.nativeElement.contains(\n            event.target,\n          );\n\n          const isAbove = this.#coreAdapter.isTargetAboveElement(\n            event.target,\n            this.overlayRef.nativeElement,\n          );\n\n          /* istanbul ignore else */\n          if (!isChild && !isAbove) {\n            this.#backdropClick.next();\n            if (this.#context.config.enableClose) {\n              this.#closed.next();\n            }\n          }\n        }\n      });\n  }\n\n  #addRouteListener(): void {\n    /*istanbul ignore else*/\n    if (this.#router) {\n      this.#routerSubscription = this.#router.events.subscribe((event) => {\n        /* istanbul ignore else */\n        if (event instanceof NavigationStart) {\n          this.#closed.next();\n        }\n      });\n    }\n  }\n\n  #removeRouteListener(): void {\n    if (this.#routerSubscription) {\n      this.#routerSubscription.unsubscribe();\n      this.#routerSubscription = undefined;\n    }\n  }\n}\n","<div\n  #overlayRef\n  [class]=\"'sky-overlay-position-' + position + ' ' + wrapperClass\"\n  [style.z-index]=\"zIndex\"\n  [style.clip-path]=\"clipPath$ | async\"\n  [ngClass]=\"{\n    'enable-pointer-events-pass-through': enablePointerEvents,\n    'sky-overlay': true\n  }\"\n>\n  <div #overlayContentRef class=\"sky-overlay-content\">\n    <ng-template #target />\n  </div>\n  @if (showBackdrop) {\n    <div class=\"sky-overlay-backdrop\"></div>\n  }\n</div>\n"]}
@@ -1,15 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- /**
4
- * @deprecated The `SkyOverlayModule` is no longer needed and can be removed from your application.
5
- */
6
- export class SkyOverlayModule {
7
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
8
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayModule }); }
9
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayModule }); }
10
- }
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayModule, decorators: [{
12
- type: NgModule,
13
- args: [{}]
14
- }] });
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvY29yZS9zcmMvbGliL21vZHVsZXMvb3ZlcmxheS9vdmVybGF5Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUV6Qzs7R0FFRztBQUVILE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCO2dIQUFoQixnQkFBZ0I7OzRGQUFoQixnQkFBZ0I7a0JBRDVCLFFBQVE7bUJBQUMsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQGRlcHJlY2F0ZWQgVGhlIGBTa3lPdmVybGF5TW9kdWxlYCBpcyBubyBsb25nZXIgbmVlZGVkIGFuZCBjYW4gYmUgcmVtb3ZlZCBmcm9tIHlvdXIgYXBwbGljYXRpb24uXG4gKi9cbkBOZ01vZHVsZSh7fSlcbmV4cG9ydCBjbGFzcyBTa3lPdmVybGF5TW9kdWxlIHt9XG4iXX0=
@@ -1,134 +0,0 @@
1
- var _a;
2
- import { ApplicationRef, EnvironmentInjector, Injectable, inject, } from '@angular/core';
3
- import { SkyOverlayAdapterService } from './overlay-adapter.service';
4
- import { SkyOverlayContext } from './overlay-context';
5
- import { SkyOverlayInstance } from './overlay-instance';
6
- import { SkyOverlayComponent } from './overlay.component';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../dynamic-component/dynamic-component.service";
9
- /**
10
- * This service is used to create new overlays.
11
- * @internal
12
- */
13
- export class SkyOverlayService {
14
- static { this.overlays = []; }
15
- #adapter = inject(SkyOverlayAdapterService);
16
- #applicationRef = inject(ApplicationRef);
17
- #dynamicComponentSvc;
18
- #environmentInjector = inject(EnvironmentInjector);
19
- constructor(dynamicComponentSvc) {
20
- this.#dynamicComponentSvc = dynamicComponentSvc;
21
- }
22
- /**
23
- * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.
24
- * @param config Configuration for the overlay.
25
- */
26
- create(config) {
27
- const settings = this.#prepareConfig(config);
28
- if (settings.enableScroll === false) {
29
- this.#adapter.restrictBodyScroll();
30
- }
31
- const componentRef = this.#createOverlay(settings);
32
- const instance = new SkyOverlayInstance(settings, componentRef);
33
- instance.closed.subscribe(() => {
34
- // Only execute the service's close method if the instance still exists.
35
- // This is needed to address a race condition if the deprecated instance.close method is used instead.
36
- if (_a.overlays.indexOf(instance) > -1) {
37
- this.close(instance);
38
- }
39
- });
40
- _a.overlays.push(instance);
41
- return instance;
42
- }
43
- /**
44
- * Closes (and destroys) an overlay instance.
45
- * @param instance The instance to close.
46
- */
47
- close(instance) {
48
- this.#destroyOverlay(instance);
49
- this.#applicationRef.detachView(instance.componentRef.hostView);
50
- instance.componentRef.destroy();
51
- // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during
52
- // unit tests. This can make querying difficult because the older DOM nodes still exist and
53
- // produce inconsistent results.
54
- // Angular Material's overlay appears to do the same thing:
55
- // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145
56
- // (Ignoring coverage since this branch will only be hit by consumer unit tests.)
57
- const componentElement = instance.componentRef.location.nativeElement;
58
- /* istanbul ignore if */
59
- if (componentElement.parentNode !== null) {
60
- componentElement.parentNode.removeChild(componentElement);
61
- }
62
- }
63
- /**
64
- * Closes all overlay instances.
65
- */
66
- closeAll() {
67
- // The `close` event handler for each instance alters the array's length asynchronously,
68
- // so the only "safe" index to call is zero.
69
- while (_a.overlays.length > 0) {
70
- this.close(_a.overlays[0]);
71
- }
72
- }
73
- #createOverlay(config) {
74
- return this.#dynamicComponentSvc.createComponent(SkyOverlayComponent, {
75
- environmentInjector: this.#environmentInjector,
76
- providers: [
77
- {
78
- provide: SkyOverlayContext,
79
- useValue: new SkyOverlayContext(config),
80
- },
81
- ],
82
- });
83
- }
84
- #prepareConfig(config = {}) {
85
- const defaults = {
86
- closeOnNavigation: true,
87
- enableClose: false,
88
- enablePointerEvents: false,
89
- enableScroll: true,
90
- showBackdrop: false,
91
- wrapperClass: '',
92
- };
93
- return { ...defaults, ...config };
94
- }
95
- #destroyOverlay(instance) {
96
- _a.overlays.splice(_a.overlays.indexOf(instance), 1);
97
- if (instance.config.enableScroll === false) {
98
- // Only release the body scroll if no other overlay wishes it to be disabled.
99
- const anotherOverlayDisablesScroll = _a.overlays.some((o) => !o.config.enableScroll);
100
- if (!anotherOverlayDisablesScroll) {
101
- this.#adapter.releaseBodyScroll();
102
- }
103
- }
104
- }
105
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayService, deps: [{ token: i1.SkyDynamicComponentService }], target: i0.ɵɵFactoryTarget.Injectable }); }
106
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayService, providedIn: 'root' }); }
107
- }
108
- _a = SkyOverlayService;
109
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayService, decorators: [{
110
- type: Injectable,
111
- args: [{
112
- providedIn: 'root',
113
- }]
114
- }], ctorParameters: () => [{ type: i1.SkyDynamicComponentService }] });
115
- /**
116
- * This service is used to create new overlays.
117
- * @internal
118
- * @deprecated Use `SkyOverlayService` to open a standalone component instead.
119
- */
120
- export class SkyOverlayLegacyService extends SkyOverlayService {
121
- /* istanbul ignore next */
122
- constructor(dynamicComponentSvc) {
123
- super(dynamicComponentSvc);
124
- }
125
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayLegacyService, deps: [{ token: i1.SkyDynamicComponentLegacyService }], target: i0.ɵɵFactoryTarget.Injectable }); }
126
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayLegacyService, providedIn: 'any' }); }
127
- }
128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyOverlayLegacyService, decorators: [{
129
- type: Injectable,
130
- args: [{
131
- providedIn: 'any',
132
- }]
133
- }], ctorParameters: () => [{ type: i1.SkyDynamicComponentLegacyService }] });
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/core/src/lib/modules/overlay/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ApplicationRef,\n  ComponentRef,\n  EnvironmentInjector,\n  Injectable,\n  inject,\n} from '@angular/core';\n\nimport {\n  SkyDynamicComponentLegacyService,\n  SkyDynamicComponentService,\n} from '../dynamic-component/dynamic-component.service';\n\nimport { SkyOverlayAdapterService } from './overlay-adapter.service';\nimport { SkyOverlayConfig } from './overlay-config';\nimport { SkyOverlayContext } from './overlay-context';\nimport { SkyOverlayInstance } from './overlay-instance';\nimport { SkyOverlayComponent } from './overlay.component';\n\n/**\n * This service is used to create new overlays.\n * @internal\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class SkyOverlayService {\n  private static overlays: SkyOverlayInstance[] = [];\n\n  readonly #adapter = inject(SkyOverlayAdapterService);\n  readonly #applicationRef = inject(ApplicationRef);\n  readonly #dynamicComponentSvc: SkyDynamicComponentService;\n  readonly #environmentInjector = inject(EnvironmentInjector);\n\n  constructor(dynamicComponentSvc: SkyDynamicComponentService) {\n    this.#dynamicComponentSvc = dynamicComponentSvc;\n  }\n\n  /**\n   * Creates an empty overlay. Use the returned `SkyOverlayInstance` to append content.\n   * @param config Configuration for the overlay.\n   */\n  public create(config?: SkyOverlayConfig): SkyOverlayInstance {\n    const settings = this.#prepareConfig(config);\n\n    if (settings.enableScroll === false) {\n      this.#adapter.restrictBodyScroll();\n    }\n\n    const componentRef = this.#createOverlay(settings);\n    const instance = new SkyOverlayInstance(settings, componentRef);\n\n    instance.closed.subscribe(() => {\n      // Only execute the service's close method if the instance still exists.\n      // This is needed to address a race condition if the deprecated instance.close method is used instead.\n      if (SkyOverlayService.overlays.indexOf(instance) > -1) {\n        this.close(instance);\n      }\n    });\n\n    SkyOverlayService.overlays.push(instance);\n\n    return instance;\n  }\n\n  /**\n   * Closes (and destroys) an overlay instance.\n   * @param instance The instance to close.\n   */\n  public close(instance: SkyOverlayInstance): void {\n    this.#destroyOverlay(instance);\n    this.#applicationRef.detachView(instance.componentRef.hostView);\n    instance.componentRef.destroy();\n\n    // In some cases, Angular keeps dynamically-generated component's nodes in the DOM during\n    // unit tests. This can make querying difficult because the older DOM nodes still exist and\n    // produce inconsistent results.\n    // Angular Material's overlay appears to do the same thing:\n    // https://github.com/angular/components/blob/master/src/cdk/portal/dom-portal-outlet.ts#L143-L145\n    // (Ignoring coverage since this branch will only be hit by consumer unit tests.)\n    const componentElement = instance.componentRef.location.nativeElement;\n    /* istanbul ignore if */\n    if (componentElement.parentNode !== null) {\n      componentElement.parentNode.removeChild(componentElement);\n    }\n  }\n\n  /**\n   * Closes all overlay instances.\n   */\n  public closeAll(): void {\n    // The `close` event handler for each instance alters the array's length asynchronously,\n    // so the only \"safe\" index to call is zero.\n    while (SkyOverlayService.overlays.length > 0) {\n      this.close(SkyOverlayService.overlays[0]);\n    }\n  }\n\n  #createOverlay(config: SkyOverlayConfig): ComponentRef<SkyOverlayComponent> {\n    return this.#dynamicComponentSvc.createComponent(SkyOverlayComponent, {\n      environmentInjector: this.#environmentInjector,\n      providers: [\n        {\n          provide: SkyOverlayContext,\n          useValue: new SkyOverlayContext(config),\n        },\n      ],\n    });\n  }\n\n  #prepareConfig(config: SkyOverlayConfig = {}): SkyOverlayConfig {\n    const defaults: SkyOverlayConfig = {\n      closeOnNavigation: true,\n      enableClose: false,\n      enablePointerEvents: false,\n      enableScroll: true,\n      showBackdrop: false,\n      wrapperClass: '',\n    };\n\n    return { ...defaults, ...config };\n  }\n\n  #destroyOverlay(instance: SkyOverlayInstance): void {\n    SkyOverlayService.overlays.splice(\n      SkyOverlayService.overlays.indexOf(instance),\n      1,\n    );\n\n    if (instance.config.enableScroll === false) {\n      // Only release the body scroll if no other overlay wishes it to be disabled.\n      const anotherOverlayDisablesScroll = SkyOverlayService.overlays.some(\n        (o) => !o.config.enableScroll,\n      );\n      if (!anotherOverlayDisablesScroll) {\n        this.#adapter.releaseBodyScroll();\n      }\n    }\n  }\n}\n\n/**\n * This service is used to create new overlays.\n * @internal\n * @deprecated Use `SkyOverlayService` to open a standalone component instead.\n */\n@Injectable({\n  providedIn: 'any',\n})\nexport class SkyOverlayLegacyService extends SkyOverlayService {\n  /* istanbul ignore next */\n  constructor(dynamicComponentSvc: SkyDynamicComponentLegacyService) {\n    super(dynamicComponentSvc);\n  }\n}\n"]}
@@ -1,19 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { SkyCoreResourcesModule } from '../shared/sky-core-resources.module';
3
- import { SkyPercentPipe } from './percent.pipe';
4
- import * as i0 from "@angular/core";
5
- export class SkyPercentPipeModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipeModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipeModule, declarations: [SkyPercentPipe], imports: [SkyCoreResourcesModule], exports: [SkyPercentPipe] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipeModule, providers: [SkyPercentPipe], imports: [SkyCoreResourcesModule] }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipeModule, decorators: [{
11
- type: NgModule,
12
- args: [{
13
- declarations: [SkyPercentPipe],
14
- providers: [SkyPercentPipe],
15
- imports: [SkyCoreResourcesModule],
16
- exports: [SkyPercentPipe],
17
- }]
18
- }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudC1waXBlLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9jb3JlL3NyYy9saWIvbW9kdWxlcy9wZXJjZW50LXBpcGUvcGVyY2VudC1waXBlLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRTdFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFRaEQsTUFBTSxPQUFPLG9CQUFvQjsrR0FBcEIsb0JBQW9CO2dIQUFwQixvQkFBb0IsaUJBTGhCLGNBQWMsYUFFbkIsc0JBQXNCLGFBQ3RCLGNBQWM7Z0hBRWIsb0JBQW9CLGFBSnBCLENBQUMsY0FBYyxDQUFDLFlBQ2pCLHNCQUFzQjs7NEZBR3JCLG9CQUFvQjtrQkFOaEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxjQUFjLENBQUM7b0JBQzlCLFNBQVMsRUFBRSxDQUFDLGNBQWMsQ0FBQztvQkFDM0IsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ2pDLE9BQU8sRUFBRSxDQUFDLGNBQWMsQ0FBQztpQkFDMUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lDb3JlUmVzb3VyY2VzTW9kdWxlIH0gZnJvbSAnLi4vc2hhcmVkL3NreS1jb3JlLXJlc291cmNlcy5tb2R1bGUnO1xuXG5pbXBvcnQgeyBTa3lQZXJjZW50UGlwZSB9IGZyb20gJy4vcGVyY2VudC5waXBlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5UGVyY2VudFBpcGVdLFxuICBwcm92aWRlcnM6IFtTa3lQZXJjZW50UGlwZV0sXG4gIGltcG9ydHM6IFtTa3lDb3JlUmVzb3VyY2VzTW9kdWxlXSxcbiAgZXhwb3J0czogW1NreVBlcmNlbnRQaXBlXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGVyY2VudFBpcGVNb2R1bGUge31cbiJdfQ==
@@ -1,56 +0,0 @@
1
- import { Pipe } from '@angular/core';
2
- import { SkyIntlNumberFormatStyle } from '@skyux/i18n';
3
- import { Subject } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import { SkyNumberFormatUtility } from '../shared/number-format/number-format-utility';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@skyux/i18n";
8
- export class SkyPercentPipe {
9
- get defaultLocale() {
10
- return this.#defaultLocale;
11
- }
12
- #defaultFormat = '1.0-2';
13
- #defaultLocale = 'en-US';
14
- #format;
15
- #formattedValue = '';
16
- #locale;
17
- #ngUnsubscribe = new Subject();
18
- #value;
19
- constructor(localeProvider) {
20
- localeProvider
21
- .getLocaleInfo()
22
- .pipe(takeUntil(this.#ngUnsubscribe))
23
- .subscribe((localeInfo) => {
24
- this.#defaultLocale = localeInfo.locale;
25
- this.#updateFormattedValue();
26
- });
27
- }
28
- ngOnDestroy() {
29
- this.#ngUnsubscribe.next();
30
- this.#ngUnsubscribe.complete();
31
- }
32
- transform(value, format, locale) {
33
- this.#value = value;
34
- this.#format = format;
35
- this.#locale = locale;
36
- this.#updateFormattedValue();
37
- return this.#formattedValue;
38
- }
39
- #updateFormattedValue() {
40
- const locale = this.#locale || this.#defaultLocale;
41
- const format = this.#format || this.#defaultFormat;
42
- this.#formattedValue = this.#value
43
- ? SkyNumberFormatUtility.formatNumber(locale, this.#value, SkyIntlNumberFormatStyle.Percent, format)
44
- : '';
45
- }
46
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipe, deps: [{ token: i1.SkyAppLocaleProvider }], target: i0.ɵɵFactoryTarget.Pipe }); }
47
- static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipe, name: "skyPercent", pure: false }); }
48
- }
49
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: SkyPercentPipe, decorators: [{
50
- type: Pipe,
51
- args: [{
52
- name: 'skyPercent',
53
- pure: false,
54
- }]
55
- }], ctorParameters: () => [{ type: i1.SkyAppLocaleProvider }] });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVyY2VudC5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2NvcmUvc3JjL2xpYi9tb2R1bGVzL3BlcmNlbnQtcGlwZS9wZXJjZW50LnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFhLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7QUFDL0QsT0FBTyxFQUF3Qix3QkFBd0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUU3RSxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUUzQyxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSwrQ0FBK0MsQ0FBQzs7O0FBTXZGLE1BQU0sT0FBTyxjQUFjO0lBQ3pCLElBQVcsYUFBYTtRQUN0QixPQUFPLElBQUksQ0FBQyxjQUFjLENBQUM7SUFDN0IsQ0FBQztJQUVELGNBQWMsR0FBRyxPQUFPLENBQUM7SUFFekIsY0FBYyxHQUFHLE9BQU8sQ0FBQztJQUV6QixPQUFPLENBQXFCO0lBRTVCLGVBQWUsR0FBRyxFQUFFLENBQUM7SUFFckIsT0FBTyxDQUFxQjtJQUU1QixjQUFjLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztJQUVyQyxNQUFNLENBQXFCO0lBRTNCLFlBQVksY0FBb0M7UUFDOUMsY0FBYzthQUNYLGFBQWEsRUFBRTthQUNmLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDO2FBQ3BDLFNBQVMsQ0FBQyxDQUFDLFVBQVUsRUFBRSxFQUFFO1lBQ3hCLElBQUksQ0FBQyxjQUFjLEdBQUcsVUFBVSxDQUFDLE1BQU0sQ0FBQztZQUN4QyxJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUMvQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDM0IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNqQyxDQUFDO0lBRU0sU0FBUyxDQUFDLEtBQWEsRUFBRSxNQUFlLEVBQUUsTUFBZTtRQUM5RCxJQUFJLENBQUMsTUFBTSxHQUFHLEtBQUssQ0FBQztRQUNwQixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUN0QixJQUFJLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQztRQUV0QixJQUFJLENBQUMscUJBQXFCLEVBQUUsQ0FBQztRQUU3QixPQUFPLElBQUksQ0FBQyxlQUFlLENBQUM7SUFDOUIsQ0FBQztJQUVELHFCQUFxQjtRQUNuQixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxJQUFJLElBQUksQ0FBQyxjQUFjLENBQUM7UUFDbkQsTUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDO1FBRW5ELElBQUksQ0FBQyxlQUFlLEdBQUcsSUFBSSxDQUFDLE1BQU07WUFDaEMsQ0FBQyxDQUFFLHNCQUFzQixDQUFDLFlBQVksQ0FDbEMsTUFBTSxFQUNOLElBQUksQ0FBQyxNQUFNLEVBQ1gsd0JBQXdCLENBQUMsT0FBTyxFQUNoQyxNQUFNLENBQ0k7WUFDZCxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ1QsQ0FBQzsrR0F4RFUsY0FBYzs2R0FBZCxjQUFjOzs0RkFBZCxjQUFjO2tCQUoxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxZQUFZO29CQUNsQixJQUFJLEVBQUUsS0FBSztpQkFDWiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE9uRGVzdHJveSwgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5QXBwTG9jYWxlUHJvdmlkZXIsIFNreUludGxOdW1iZXJGb3JtYXRTdHlsZSB9IGZyb20gJ0Bza3l1eC9pMThuJztcblxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgdGFrZVVudGlsIH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQgeyBTa3lOdW1iZXJGb3JtYXRVdGlsaXR5IH0gZnJvbSAnLi4vc2hhcmVkL251bWJlci1mb3JtYXQvbnVtYmVyLWZvcm1hdC11dGlsaXR5JztcblxuQFBpcGUoe1xuICBuYW1lOiAnc2t5UGVyY2VudCcsXG4gIHB1cmU6IGZhbHNlLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lQZXJjZW50UGlwZSBpbXBsZW1lbnRzIE9uRGVzdHJveSwgUGlwZVRyYW5zZm9ybSB7XG4gIHB1YmxpYyBnZXQgZGVmYXVsdExvY2FsZSgpOiBzdHJpbmcge1xuICAgIHJldHVybiB0aGlzLiNkZWZhdWx0TG9jYWxlO1xuICB9XG5cbiAgI2RlZmF1bHRGb3JtYXQgPSAnMS4wLTInO1xuXG4gICNkZWZhdWx0TG9jYWxlID0gJ2VuLVVTJztcblxuICAjZm9ybWF0OiBzdHJpbmcgfCB1bmRlZmluZWQ7XG5cbiAgI2Zvcm1hdHRlZFZhbHVlID0gJyc7XG5cbiAgI2xvY2FsZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gICNuZ1Vuc3Vic2NyaWJlID0gbmV3IFN1YmplY3Q8dm9pZD4oKTtcblxuICAjdmFsdWU6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3Rvcihsb2NhbGVQcm92aWRlcjogU2t5QXBwTG9jYWxlUHJvdmlkZXIpIHtcbiAgICBsb2NhbGVQcm92aWRlclxuICAgICAgLmdldExvY2FsZUluZm8oKVxuICAgICAgLnBpcGUodGFrZVVudGlsKHRoaXMuI25nVW5zdWJzY3JpYmUpKVxuICAgICAgLnN1YnNjcmliZSgobG9jYWxlSW5mbykgPT4ge1xuICAgICAgICB0aGlzLiNkZWZhdWx0TG9jYWxlID0gbG9jYWxlSW5mby5sb2NhbGU7XG4gICAgICAgIHRoaXMuI3VwZGF0ZUZvcm1hdHRlZFZhbHVlKCk7XG4gICAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLiNuZ1Vuc3Vic2NyaWJlLm5leHQoKTtcbiAgICB0aGlzLiNuZ1Vuc3Vic2NyaWJlLmNvbXBsZXRlKCk7XG4gIH1cblxuICBwdWJsaWMgdHJhbnNmb3JtKHZhbHVlOiBzdHJpbmcsIGZvcm1hdD86IHN0cmluZywgbG9jYWxlPzogc3RyaW5nKTogc3RyaW5nIHtcbiAgICB0aGlzLiN2YWx1ZSA9IHZhbHVlO1xuICAgIHRoaXMuI2Zvcm1hdCA9IGZvcm1hdDtcbiAgICB0aGlzLiNsb2NhbGUgPSBsb2NhbGU7XG5cbiAgICB0aGlzLiN1cGRhdGVGb3JtYXR0ZWRWYWx1ZSgpO1xuXG4gICAgcmV0dXJuIHRoaXMuI2Zvcm1hdHRlZFZhbHVlO1xuICB9XG5cbiAgI3VwZGF0ZUZvcm1hdHRlZFZhbHVlKCk6IHZvaWQge1xuICAgIGNvbnN0IGxvY2FsZSA9IHRoaXMuI2xvY2FsZSB8fCB0aGlzLiNkZWZhdWx0TG9jYWxlO1xuICAgIGNvbnN0IGZvcm1hdCA9IHRoaXMuI2Zvcm1hdCB8fCB0aGlzLiNkZWZhdWx0Rm9ybWF0O1xuXG4gICAgdGhpcy4jZm9ybWF0dGVkVmFsdWUgPSB0aGlzLiN2YWx1ZVxuICAgICAgPyAoU2t5TnVtYmVyRm9ybWF0VXRpbGl0eS5mb3JtYXROdW1iZXIoXG4gICAgICAgICAgbG9jYWxlLFxuICAgICAgICAgIHRoaXMuI3ZhbHVlLFxuICAgICAgICAgIFNreUludGxOdW1iZXJGb3JtYXRTdHlsZS5QZXJjZW50LFxuICAgICAgICAgIGZvcm1hdCxcbiAgICAgICAgKSBhcyBzdHJpbmcpXG4gICAgICA6ICcnO1xuICB9XG59XG4iXX0=