@skyux/layout 8.7.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.
- package/esm2022/lib/modules/action-button/action-button-adapter-service.mjs +44 -0
- package/esm2022/lib/modules/action-button/action-button-container.component.mjs +138 -0
- package/{esm2020 → esm2022}/lib/modules/action-button/action-button-details.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/action-button/action-button-header.component.mjs +4 -4
- package/esm2022/lib/modules/action-button/action-button-icon.component.mjs +40 -0
- package/esm2022/lib/modules/action-button/action-button.component.mjs +50 -0
- package/{esm2020 → esm2022}/lib/modules/action-button/action-button.module.mjs +23 -23
- package/{esm2020 → esm2022}/lib/modules/back-to-top/back-to-top-adapter.service.mjs +19 -22
- package/esm2022/lib/modules/back-to-top/back-to-top.component.mjs +25 -0
- package/esm2022/lib/modules/back-to-top/back-to-top.directive.mjs +119 -0
- package/{esm2020 → esm2022}/lib/modules/back-to-top/back-to-top.module.mjs +13 -13
- package/{esm2020 → esm2022}/lib/modules/box/box-content.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/box/box-controls.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/box/box-header.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/box/box.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/box/box.module.mjs +11 -11
- package/{esm2020 → esm2022}/lib/modules/card/card-actions.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/card/card-content.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/card/card-title.component.mjs +4 -4
- package/esm2022/lib/modules/card/card.component.mjs +107 -0
- package/{esm2020 → esm2022}/lib/modules/card/card.module.mjs +21 -21
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list-content.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list-heading.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list-label.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list-value.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list.module.mjs +13 -13
- package/{esm2020 → esm2022}/lib/modules/definition-list/definition-list.service.mjs +4 -4
- package/esm2022/lib/modules/description-list/description-list-adapter-service.mjs +44 -0
- package/{esm2020 → esm2022}/lib/modules/description-list/description-list-content.component.mjs +4 -4
- package/esm2022/lib/modules/description-list/description-list-description.component.mjs +52 -0
- package/{esm2020 → esm2022}/lib/modules/description-list/description-list-term.component.mjs +4 -4
- package/esm2022/lib/modules/description-list/description-list.component.mjs +95 -0
- package/{esm2020 → esm2022}/lib/modules/description-list/description-list.module.mjs +19 -19
- package/esm2022/lib/modules/description-list/description-list.service.mjs +24 -0
- package/esm2022/lib/modules/fluid-grid/column.component.mjs +66 -0
- package/esm2022/lib/modules/fluid-grid/fluid-grid.component.mjs +40 -0
- package/{esm2020 → esm2022}/lib/modules/fluid-grid/fluid-grid.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/fluid-grid/row.component.mjs +4 -4
- package/esm2022/lib/modules/format/format.component.mjs +64 -0
- package/{esm2020 → esm2022}/lib/modules/format/format.module.mjs +5 -5
- package/esm2022/lib/modules/inline-delete/inline-delete-adapter.service.mjs +123 -0
- package/esm2022/lib/modules/inline-delete/inline-delete.component.mjs +164 -0
- package/{esm2020 → esm2022}/lib/modules/inline-delete/inline-delete.module.mjs +11 -11
- package/esm2022/lib/modules/page/page-theme-adapter.service.mjs +40 -0
- package/esm2022/lib/modules/page/page.component.mjs +49 -0
- package/{esm2020 → esm2022}/lib/modules/page/page.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-adapter.service.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-alert.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-content.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-image.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-key-info.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-status.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-subtitle.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary-title.component.mjs +4 -4
- package/esm2022/lib/modules/page-summary/page-summary.component.mjs +73 -0
- package/{esm2020 → esm2022}/lib/modules/page-summary/page-summary.module.mjs +19 -19
- package/esm2022/lib/modules/shared/sky-layout-resources.module.mjs +60 -0
- package/esm2022/lib/modules/text-expand/text-expand-adapter.service.mjs +26 -0
- package/{esm2020 → esm2022}/lib/modules/text-expand/text-expand-modal.component.mjs +4 -4
- package/esm2022/lib/modules/text-expand/text-expand.component.mjs +315 -0
- package/{esm2020 → esm2022}/lib/modules/text-expand/text-expand.module.mjs +11 -11
- package/esm2022/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +32 -0
- package/esm2022/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +216 -0
- package/{esm2020 → esm2022}/lib/modules/text-expand-repeater/text-expand-repeater.module.mjs +5 -5
- package/{esm2020 → esm2022}/lib/modules/toolbar/toolbar-item.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/toolbar/toolbar-section.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/toolbar/toolbar-view-actions.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/toolbar/toolbar.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/modules/toolbar/toolbar.module.mjs +11 -11
- package/esm2022/testing/action-button-fixture.mjs +48 -0
- package/esm2022/testing/box/box-harness.mjs +34 -0
- package/esm2022/testing/card-fixture.mjs +65 -0
- package/esm2022/testing/page-summary-fixture.mjs +31 -0
- package/fesm2022/skyux-layout-testing.mjs +181 -0
- package/{fesm2015 → fesm2022}/skyux-layout-testing.mjs.map +1 -1
- package/fesm2022/skyux-layout.mjs +2957 -0
- package/{fesm2020 → fesm2022}/skyux-layout.mjs.map +1 -1
- package/lib/modules/action-button/action-button-container.component.d.ts +1 -1
- package/lib/modules/action-button/action-button-icon.component.d.ts +1 -1
- package/lib/modules/action-button/action-button.component.d.ts +1 -1
- package/lib/modules/back-to-top/back-to-top.directive.d.ts +1 -1
- package/lib/modules/box/box.component.d.ts +1 -1
- package/lib/modules/card/card.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list.component.d.ts +1 -1
- package/lib/modules/description-list/description-list.component.d.ts +1 -1
- package/lib/modules/fluid-grid/column.component.d.ts +1 -1
- package/lib/modules/fluid-grid/fluid-grid.component.d.ts +1 -1
- package/lib/modules/fluid-grid/row.component.d.ts +1 -1
- package/lib/modules/format/format.component.d.ts +1 -1
- package/lib/modules/inline-delete/inline-delete.component.d.ts +1 -1
- package/lib/modules/page/page.component.d.ts +1 -1
- package/lib/modules/text-expand/text-expand.component.d.ts +1 -1
- package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +1 -1
- package/package.json +23 -31
- package/esm2020/lib/modules/action-button/action-button-adapter-service.mjs +0 -47
- package/esm2020/lib/modules/action-button/action-button-container.component.mjs +0 -139
- package/esm2020/lib/modules/action-button/action-button-icon.component.mjs +0 -43
- package/esm2020/lib/modules/action-button/action-button.component.mjs +0 -53
- package/esm2020/lib/modules/back-to-top/back-to-top.component.mjs +0 -30
- package/esm2020/lib/modules/back-to-top/back-to-top.directive.mjs +0 -118
- package/esm2020/lib/modules/card/card.component.mjs +0 -109
- package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +0 -47
- package/esm2020/lib/modules/description-list/description-list-description.component.mjs +0 -55
- package/esm2020/lib/modules/description-list/description-list.component.mjs +0 -98
- package/esm2020/lib/modules/description-list/description-list.service.mjs +0 -29
- package/esm2020/lib/modules/fluid-grid/column.component.mjs +0 -71
- package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +0 -42
- package/esm2020/lib/modules/format/format.component.mjs +0 -67
- package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +0 -122
- package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +0 -167
- package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +0 -43
- package/esm2020/lib/modules/page/page.component.mjs +0 -52
- package/esm2020/lib/modules/page-summary/page-summary.component.mjs +0 -75
- package/esm2020/lib/modules/shared/sky-layout-resources.module.mjs +0 -60
- package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +0 -29
- package/esm2020/lib/modules/text-expand/text-expand.component.mjs +0 -306
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +0 -35
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +0 -214
- package/esm2020/testing/action-button-fixture.mjs +0 -51
- package/esm2020/testing/box/box-harness.mjs +0 -40
- package/esm2020/testing/card-fixture.mjs +0 -67
- package/esm2020/testing/page-summary-fixture.mjs +0 -34
- package/fesm2015/skyux-layout-testing.mjs +0 -198
- package/fesm2015/skyux-layout.mjs +0 -2996
- package/fesm2015/skyux-layout.mjs.map +0 -1
- package/fesm2020/skyux-layout-testing.mjs +0 -192
- package/fesm2020/skyux-layout-testing.mjs.map +0 -1
- package/fesm2020/skyux-layout.mjs +0 -2982
- /package/{esm2020 → esm2022}/index.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/action-button/action-button-permalink.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/action-button/types/action-button-container-align-items-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/action-button/types/action-button-container-align-items.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/back-to-top/models/back-to-top-message-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/back-to-top/models/back-to-top-message.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/back-to-top/models/back-to-top-options.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/description-list/types/description-list-mode-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/description-list/types/description-list-mode.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/format/format-item.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/inline-delete/inline-delete-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/page/page-layout-type.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/text-expand/text-expand-modal-context-token.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/text-expand/text-expand-modal-context.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/modules/text-expand-repeater/types/text-expand-repeater-list-style-type.mjs +0 -0
- /package/{esm2020 → esm2022}/skyux-layout.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/box/box-harness.filters.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/public-api.mjs +0 -0
- /package/{esm2020 → esm2022}/testing/skyux-layout-testing.mjs +0 -0
|
@@ -3,11 +3,11 @@ import { NgModule } from '@angular/core';
|
|
|
3
3
|
import { SkyFormatComponent } from './format.component';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class SkyFormatModule {
|
|
6
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyFormatModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
7
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyFormatModule, declarations: [SkyFormatComponent], imports: [CommonModule], exports: [SkyFormatComponent] }); }
|
|
8
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyFormatModule, imports: [CommonModule] }); }
|
|
6
9
|
}
|
|
7
|
-
|
|
8
|
-
SkyFormatModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyFormatModule, declarations: [SkyFormatComponent], imports: [CommonModule], exports: [SkyFormatComponent] });
|
|
9
|
-
SkyFormatModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyFormatModule, imports: [CommonModule] });
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyFormatModule, decorators: [{
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyFormatModule, decorators: [{
|
|
11
11
|
type: NgModule,
|
|
12
12
|
args: [{
|
|
13
13
|
declarations: [SkyFormatComponent],
|
|
@@ -15,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
15
15
|
exports: [SkyFormatComponent],
|
|
16
16
|
}]
|
|
17
17
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL2Zvcm1hdC9mb3JtYXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQU94RCxNQUFNLE9BQU8sZUFBZTs4R0FBZixlQUFlOytHQUFmLGVBQWUsaUJBSlgsa0JBQWtCLGFBQ3ZCLFlBQVksYUFDWixrQkFBa0I7K0dBRWpCLGVBQWUsWUFIaEIsWUFBWTs7MkZBR1gsZUFBZTtrQkFMM0IsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztvQkFDbEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDOUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5Rm9ybWF0Q29tcG9uZW50IH0gZnJvbSAnLi9mb3JtYXQuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5Rm9ybWF0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtTa3lGb3JtYXRDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBTa3lGb3JtYXRNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@skyux/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyInlineDeleteAdapterService {
|
|
8
|
+
#element;
|
|
9
|
+
#focusableElements;
|
|
10
|
+
#parentEl;
|
|
11
|
+
#parentElClearListenerFn;
|
|
12
|
+
#renderer;
|
|
13
|
+
#coreAdapterService;
|
|
14
|
+
constructor(coreAdapterService, rendererFactory) {
|
|
15
|
+
this.#coreAdapterService = coreAdapterService;
|
|
16
|
+
this.#renderer = rendererFactory.createRenderer(undefined, null);
|
|
17
|
+
}
|
|
18
|
+
clearListeners() {
|
|
19
|
+
/* istanbul ignore else */
|
|
20
|
+
if (this.#parentElClearListenerFn) {
|
|
21
|
+
this.#parentElClearListenerFn();
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
setEl(element) {
|
|
25
|
+
this.#element = element;
|
|
26
|
+
this.#parentEl = element.parentElement;
|
|
27
|
+
/* istanbul ignore else */
|
|
28
|
+
if (this.#parentEl) {
|
|
29
|
+
this.#parentElClearListenerFn = this.#renderer.listen(this.#parentEl, 'focusin', (event) => {
|
|
30
|
+
if (this.#element) {
|
|
31
|
+
const target = event.target;
|
|
32
|
+
if (!this.#element.contains(target) && this.#parentEl !== target) {
|
|
33
|
+
event.preventDefault();
|
|
34
|
+
event.stopPropagation();
|
|
35
|
+
event.stopImmediatePropagation();
|
|
36
|
+
target.blur();
|
|
37
|
+
this.#focusNextElement(target, this.#isShift(event));
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
#focusNextElement(targetElement, shiftKey) {
|
|
44
|
+
const focusable = this.#getFocusableElements();
|
|
45
|
+
// If shift tab, go in the other direction
|
|
46
|
+
const modifier = shiftKey ? -1 : 1;
|
|
47
|
+
// Find the next navigable element that isn't waiting
|
|
48
|
+
const startingIndex = focusable.indexOf(targetElement);
|
|
49
|
+
let curIndex = startingIndex + modifier;
|
|
50
|
+
while (focusable[curIndex] &&
|
|
51
|
+
this.#isElementHiddenOrCovered(focusable[curIndex])) {
|
|
52
|
+
curIndex += modifier;
|
|
53
|
+
}
|
|
54
|
+
if (focusable[curIndex] &&
|
|
55
|
+
!this.#isElementHiddenOrCovered(focusable[curIndex])) {
|
|
56
|
+
focusable[curIndex].focus();
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
// Try wrapping the navigation
|
|
60
|
+
/* istanbul ignore next */
|
|
61
|
+
curIndex = modifier > 0 ? 0 : focusable.length - 1;
|
|
62
|
+
/* istanbul ignore next */
|
|
63
|
+
while (curIndex !== startingIndex &&
|
|
64
|
+
focusable[curIndex] &&
|
|
65
|
+
this.#isElementHiddenOrCovered(focusable[curIndex])) {
|
|
66
|
+
curIndex += modifier;
|
|
67
|
+
}
|
|
68
|
+
/* istanbul ignore else */
|
|
69
|
+
/* sanity check */
|
|
70
|
+
if (focusable[curIndex] &&
|
|
71
|
+
!this.#isElementHiddenOrCovered(focusable[curIndex])) {
|
|
72
|
+
focusable[curIndex].focus();
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// No valid target, wipe focus
|
|
76
|
+
// This should never happen in practice due to the multiple inline delete buttons
|
|
77
|
+
if (document.activeElement && document.activeElement.blur) {
|
|
78
|
+
document.activeElement.blur();
|
|
79
|
+
}
|
|
80
|
+
document.body.focus();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// clear focusableElements list so that if things change between tabbing we know about it
|
|
84
|
+
this.#focusableElements = undefined;
|
|
85
|
+
}
|
|
86
|
+
#getFocusableElements() {
|
|
87
|
+
// Keep this cached so we can reduce queries
|
|
88
|
+
if (this.#focusableElements) {
|
|
89
|
+
return this.#focusableElements;
|
|
90
|
+
}
|
|
91
|
+
this.#focusableElements = this.#coreAdapterService.getFocusableChildren(document.body);
|
|
92
|
+
return this.#focusableElements;
|
|
93
|
+
}
|
|
94
|
+
#isElementHiddenOrCovered(element) {
|
|
95
|
+
// Check if the element is hidden by css, not within the inline delete, or a wait is covering it
|
|
96
|
+
return (this.#isElementHidden(element) ||
|
|
97
|
+
(!!this.#parentEl &&
|
|
98
|
+
this.#parentEl.contains(element) &&
|
|
99
|
+
(!this.#element?.contains(element) ||
|
|
100
|
+
this.#parentEl.querySelector('.sky-wait-mask') !== null)));
|
|
101
|
+
}
|
|
102
|
+
#isElementHidden(element) {
|
|
103
|
+
const style = window.getComputedStyle(element);
|
|
104
|
+
return style.display === 'none' || style.visibility === 'hidden';
|
|
105
|
+
}
|
|
106
|
+
#isShift(event) {
|
|
107
|
+
// Determine if shift+tab was used based on element order
|
|
108
|
+
const elements = this.#getFocusableElements().filter((elem) => !this.#isElementHidden(elem));
|
|
109
|
+
const previousInd = elements.indexOf(event.relatedTarget);
|
|
110
|
+
const currentInd = elements.indexOf(event.target);
|
|
111
|
+
/* istanbul ignore next */
|
|
112
|
+
return (previousInd === currentInd + 1 ||
|
|
113
|
+
(previousInd === 0 && currentInd === elements.length - 1) ||
|
|
114
|
+
previousInd > currentInd ||
|
|
115
|
+
!event.relatedTarget);
|
|
116
|
+
}
|
|
117
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteAdapterService, deps: [{ token: i1.SkyCoreAdapterService }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
118
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteAdapterService }); }
|
|
119
|
+
}
|
|
120
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteAdapterService, decorators: [{
|
|
121
|
+
type: Injectable
|
|
122
|
+
}], ctorParameters: function () { return [{ type: i1.SkyCoreAdapterService }, { type: i0.RendererFactory2 }]; } });
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-delete-adapter.service.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/inline-delete/inline-delete-adapter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Renderer2, RendererFactory2 } from '@angular/core';\nimport { SkyCoreAdapterService } from '@skyux/core';\n\n/**\n * @internal\n */\n@Injectable()\nexport class SkyInlineDeleteAdapterService {\n  #element: HTMLElement | undefined;\n  #focusableElements: HTMLElement[] | undefined;\n  #parentEl: HTMLElement | null | undefined;\n  #parentElClearListenerFn: (() => void) | undefined;\n  #renderer: Renderer2;\n\n  #coreAdapterService: SkyCoreAdapterService;\n\n  constructor(\n    coreAdapterService: SkyCoreAdapterService,\n    rendererFactory: RendererFactory2\n  ) {\n    this.#coreAdapterService = coreAdapterService;\n    this.#renderer = rendererFactory.createRenderer(undefined, null);\n  }\n\n  public clearListeners(): void {\n    /* istanbul ignore else */\n    if (this.#parentElClearListenerFn) {\n      this.#parentElClearListenerFn();\n    }\n  }\n\n  public setEl(element: HTMLElement): void {\n    this.#element = element;\n    this.#parentEl = element.parentElement;\n\n    /* istanbul ignore else */\n    if (this.#parentEl) {\n      this.#parentElClearListenerFn = this.#renderer.listen(\n        this.#parentEl,\n        'focusin',\n        (event: FocusEvent) => {\n          if (this.#element) {\n            const target: any = event.target;\n            if (!this.#element.contains(target) && this.#parentEl !== target) {\n              event.preventDefault();\n              event.stopPropagation();\n              event.stopImmediatePropagation();\n\n              target.blur();\n              this.#focusNextElement(target, this.#isShift(event));\n            }\n          }\n        }\n      );\n    }\n  }\n\n  #focusNextElement(targetElement: HTMLElement, shiftKey: boolean): void {\n    const focusable = this.#getFocusableElements();\n\n    // If shift tab, go in the other direction\n    const modifier = shiftKey ? -1 : 1;\n\n    // Find the next navigable element that isn't waiting\n    const startingIndex = focusable.indexOf(targetElement);\n    let curIndex = startingIndex + modifier;\n    while (\n      focusable[curIndex] &&\n      this.#isElementHiddenOrCovered(focusable[curIndex])\n    ) {\n      curIndex += modifier;\n    }\n\n    if (\n      focusable[curIndex] &&\n      !this.#isElementHiddenOrCovered(focusable[curIndex])\n    ) {\n      focusable[curIndex].focus();\n    } else {\n      // Try wrapping the navigation\n      /* istanbul ignore next */\n      curIndex = modifier > 0 ? 0 : focusable.length - 1;\n\n      /* istanbul ignore next */\n      while (\n        curIndex !== startingIndex &&\n        focusable[curIndex] &&\n        this.#isElementHiddenOrCovered(focusable[curIndex])\n      ) {\n        curIndex += modifier;\n      }\n\n      /* istanbul ignore else */\n      /* sanity check */\n      if (\n        focusable[curIndex] &&\n        !this.#isElementHiddenOrCovered(focusable[curIndex])\n      ) {\n        focusable[curIndex].focus();\n      } else {\n        // No valid target, wipe focus\n        // This should never happen in practice due to the multiple inline delete buttons\n        if (document.activeElement && (document.activeElement as any).blur) {\n          (document.activeElement as any).blur();\n        }\n        document.body.focus();\n      }\n    }\n\n    // clear focusableElements list so that if things change between tabbing we know about it\n    this.#focusableElements = undefined;\n  }\n\n  #getFocusableElements(): HTMLElement[] {\n    // Keep this cached so we can reduce queries\n    if (this.#focusableElements) {\n      return this.#focusableElements;\n    }\n\n    this.#focusableElements = this.#coreAdapterService.getFocusableChildren(\n      document.body\n    );\n\n    return this.#focusableElements;\n  }\n\n  #isElementHiddenOrCovered(element: any): boolean {\n    // Check if the element is hidden by css, not within the inline delete, or a wait is covering it\n    return (\n      this.#isElementHidden(element) ||\n      (!!this.#parentEl &&\n        this.#parentEl.contains(element) &&\n        (!this.#element?.contains(element) ||\n          this.#parentEl.querySelector('.sky-wait-mask') !== null))\n    );\n  }\n\n  #isElementHidden(element: any): boolean {\n    const style = window.getComputedStyle(element);\n    return style.display === 'none' || style.visibility === 'hidden';\n  }\n\n  #isShift(event: Event): boolean {\n    // Determine if shift+tab was used based on element order\n    const elements = this.#getFocusableElements().filter(\n      (elem) => !this.#isElementHidden(elem)\n    );\n\n    const previousInd = elements.indexOf((event as any).relatedTarget);\n    const currentInd = elements.indexOf(event.target as HTMLElement);\n\n    /* istanbul ignore next */\n    return (\n      previousInd === currentInd + 1 ||\n      (previousInd === 0 && currentInd === elements.length - 1) ||\n      previousInd > currentInd ||\n      !(event as any).relatedTarget\n    );\n  }\n}\n"]}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { animate, group, query, style, transition, trigger, } from '@angular/animations';
|
|
2
|
+
import { Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
|
+
import { SkyCoreAdapterService } from '@skyux/core';
|
|
4
|
+
import { SkyInlineDeleteAdapterService } from './inline-delete-adapter.service';
|
|
5
|
+
import { SkyInlineDeleteType } from './inline-delete-type';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "./inline-delete-adapter.service";
|
|
8
|
+
import * as i2 from "@skyux/indicators";
|
|
9
|
+
import * as i3 from "@skyux/i18n";
|
|
10
|
+
/**
|
|
11
|
+
* Auto-incrementing integer used to generate unique ids for inline delete components.
|
|
12
|
+
*/
|
|
13
|
+
let nextId = 0;
|
|
14
|
+
export class SkyInlineDeleteComponent {
|
|
15
|
+
#adapterService;
|
|
16
|
+
#changeDetector;
|
|
17
|
+
#elRef;
|
|
18
|
+
constructor(adapterService, changeDetector, elRef) {
|
|
19
|
+
/**
|
|
20
|
+
* Whether the deletion is pending.
|
|
21
|
+
* @default false
|
|
22
|
+
*/
|
|
23
|
+
this.pending = false;
|
|
24
|
+
/**
|
|
25
|
+
* Fires when users click the cancel button.
|
|
26
|
+
*/
|
|
27
|
+
this.cancelTriggered = new EventEmitter();
|
|
28
|
+
/**
|
|
29
|
+
* Fires when users click the delete button.
|
|
30
|
+
*/
|
|
31
|
+
this.deleteTriggered = new EventEmitter();
|
|
32
|
+
this.animationState = 'shown';
|
|
33
|
+
this.assistiveTextId = `sky-inline-delete-assistive-text-${++nextId}`;
|
|
34
|
+
this.type = SkyInlineDeleteType.Standard;
|
|
35
|
+
this.#adapterService = adapterService;
|
|
36
|
+
this.#changeDetector = changeDetector;
|
|
37
|
+
this.#elRef = elRef;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Initialization lifecycle hook
|
|
41
|
+
* @internal
|
|
42
|
+
*/
|
|
43
|
+
ngOnInit() {
|
|
44
|
+
this.animationState = 'shown';
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Destruction lifecycle hook
|
|
48
|
+
* @internal
|
|
49
|
+
*/
|
|
50
|
+
ngOnDestroy() {
|
|
51
|
+
this.#adapterService.clearListeners();
|
|
52
|
+
this.cancelTriggered.complete();
|
|
53
|
+
this.deleteTriggered.complete();
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* @internal
|
|
57
|
+
*/
|
|
58
|
+
onCancelClick() {
|
|
59
|
+
this.animationState = 'hidden';
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* @internal
|
|
63
|
+
*/
|
|
64
|
+
onDeleteClick() {
|
|
65
|
+
this.deleteTriggered.emit();
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Sets the inline delete to one of its predefined types.
|
|
69
|
+
* @param type The inline delete type
|
|
70
|
+
* @internal
|
|
71
|
+
*/
|
|
72
|
+
setType(type) {
|
|
73
|
+
this.type = type;
|
|
74
|
+
this.#changeDetector.detectChanges();
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Handles actions that should be taken after the inline delete animates
|
|
78
|
+
* @param event The animation event
|
|
79
|
+
* @internal
|
|
80
|
+
*/
|
|
81
|
+
onAnimationDone(event) {
|
|
82
|
+
if (event.toState === 'hidden') {
|
|
83
|
+
this.cancelTriggered.emit();
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.deleteButton?.nativeElement.focus();
|
|
87
|
+
/* istanbul ignore else */
|
|
88
|
+
if (this.#elRef) {
|
|
89
|
+
this.#adapterService.setEl(this.#elRef.nativeElement);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteComponent, deps: [{ token: i1.SkyInlineDeleteAdapterService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
94
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyInlineDeleteComponent, selector: "sky-inline-delete", inputs: { pending: "pending" }, outputs: { cancelTriggered: "cancelTriggered", deleteTriggered: "deleteTriggered" }, providers: [SkyCoreAdapterService, SkyInlineDeleteAdapterService], viewQueries: [{ propertyName: "deleteButton", first: true, predicate: ["delete"], descendants: true, read: ElementRef }], ngImport: i0, template: "<div\n class=\"sky-inline-delete sky-inline-delete-{{ type }}\"\n role=\"alertdialog\"\n [@inlineDeleteAnimation]=\"animationState\"\n (@inlineDeleteAnimation.done)=\"onAnimationDone($event)\"\n [attr.aria-describedby]=\"assistiveTextId\"\n [attr.aria-label]=\"'skyux_inline_delete_confirm_deletion' | skyLibResources\"\n>\n <span class=\"sky-inline-delete-assistive-text\" [id]=\"assistiveTextId\">\n {{ 'skyux_inline_delete_assistive_text' | skyLibResources }}\n </span>\n <sky-wait class=\"sky-inline-delete-wait\" [isWaiting]=\"pending\"></sky-wait>\n <div class=\"sky-inline-delete-content\">\n <div class=\"sky-inline-delete-content-animation-container\">\n <button\n class=\"sky-btn sky-btn-danger sky-inline-delete-button\"\n type=\"button\"\n (click)=\"onDeleteClick()\"\n #delete\n >\n {{ 'skyux_inline_delete_delete' | skyLibResources }}\n </button>\n <button\n class=\"sky-btn sky-btn-default\"\n type=\"button\"\n (click)=\"onCancelClick()\"\n >\n {{ 'skyux_inline_delete_cancel' | skyLibResources }}\n </button>\n </div>\n </div>\n</div>\n", styles: [".sky-inline-delete{position:absolute!important;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999;border:2px solid #ef4044}.sky-inline-delete-assistive-text{width:0;height:0;padding:0;opacity:0;position:absolute;margin:-1px;border:0;overflow:hidden;clip:rect(0,0,0,0);outline:none;white-space:nowrap}.sky-inline-delete-button{margin-right:10px}.sky-inline-delete-card .sky-inline-delete-content{position:absolute;bottom:10px;text-align:center;width:100%}.sky-inline-delete-standard .sky-inline-delete-content{position:absolute;top:50%;transform:translateY(-50%);left:20px}.sky-inline-delete-wait{height:100%}\n"], dependencies: [{ kind: "component", type: i2.λ14, selector: "sky-wait", inputs: ["ariaLabel", "isWaiting", "isFullPage", "isNonBlocking", "screenReaderCompletedText"] }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], animations: [
|
|
95
|
+
trigger('inlineDeleteAnimation', [
|
|
96
|
+
transition('* => shown', [
|
|
97
|
+
style({
|
|
98
|
+
opacity: 0,
|
|
99
|
+
}),
|
|
100
|
+
query('.sky-inline-delete-content-animation-container', style({ transform: 'scale(0.0)' })),
|
|
101
|
+
group([
|
|
102
|
+
animate('300ms ease-in-out', style({ opacity: 1 })),
|
|
103
|
+
query('.sky-inline-delete-content-animation-container', animate('300ms ease-in-out', style({
|
|
104
|
+
transform: 'scale(1)',
|
|
105
|
+
}))),
|
|
106
|
+
]),
|
|
107
|
+
]),
|
|
108
|
+
transition(`shown <=> *`, [
|
|
109
|
+
query('.sky-inline-delete-content-animation-container', style({ transform: 'scale(1)' })),
|
|
110
|
+
group([
|
|
111
|
+
animate('300ms ease-in-out', style({
|
|
112
|
+
opacity: 0,
|
|
113
|
+
})),
|
|
114
|
+
query('.sky-inline-delete-content-animation-container', animate('300ms ease-in-out', style({
|
|
115
|
+
transform: 'scale(0.0)',
|
|
116
|
+
}))),
|
|
117
|
+
]),
|
|
118
|
+
]),
|
|
119
|
+
]),
|
|
120
|
+
] }); }
|
|
121
|
+
}
|
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteComponent, decorators: [{
|
|
123
|
+
type: Component,
|
|
124
|
+
args: [{ selector: 'sky-inline-delete', animations: [
|
|
125
|
+
trigger('inlineDeleteAnimation', [
|
|
126
|
+
transition('* => shown', [
|
|
127
|
+
style({
|
|
128
|
+
opacity: 0,
|
|
129
|
+
}),
|
|
130
|
+
query('.sky-inline-delete-content-animation-container', style({ transform: 'scale(0.0)' })),
|
|
131
|
+
group([
|
|
132
|
+
animate('300ms ease-in-out', style({ opacity: 1 })),
|
|
133
|
+
query('.sky-inline-delete-content-animation-container', animate('300ms ease-in-out', style({
|
|
134
|
+
transform: 'scale(1)',
|
|
135
|
+
}))),
|
|
136
|
+
]),
|
|
137
|
+
]),
|
|
138
|
+
transition(`shown <=> *`, [
|
|
139
|
+
query('.sky-inline-delete-content-animation-container', style({ transform: 'scale(1)' })),
|
|
140
|
+
group([
|
|
141
|
+
animate('300ms ease-in-out', style({
|
|
142
|
+
opacity: 0,
|
|
143
|
+
})),
|
|
144
|
+
query('.sky-inline-delete-content-animation-container', animate('300ms ease-in-out', style({
|
|
145
|
+
transform: 'scale(0.0)',
|
|
146
|
+
}))),
|
|
147
|
+
]),
|
|
148
|
+
]),
|
|
149
|
+
]),
|
|
150
|
+
], providers: [SkyCoreAdapterService, SkyInlineDeleteAdapterService], template: "<div\n class=\"sky-inline-delete sky-inline-delete-{{ type }}\"\n role=\"alertdialog\"\n [@inlineDeleteAnimation]=\"animationState\"\n (@inlineDeleteAnimation.done)=\"onAnimationDone($event)\"\n [attr.aria-describedby]=\"assistiveTextId\"\n [attr.aria-label]=\"'skyux_inline_delete_confirm_deletion' | skyLibResources\"\n>\n <span class=\"sky-inline-delete-assistive-text\" [id]=\"assistiveTextId\">\n {{ 'skyux_inline_delete_assistive_text' | skyLibResources }}\n </span>\n <sky-wait class=\"sky-inline-delete-wait\" [isWaiting]=\"pending\"></sky-wait>\n <div class=\"sky-inline-delete-content\">\n <div class=\"sky-inline-delete-content-animation-container\">\n <button\n class=\"sky-btn sky-btn-danger sky-inline-delete-button\"\n type=\"button\"\n (click)=\"onDeleteClick()\"\n #delete\n >\n {{ 'skyux_inline_delete_delete' | skyLibResources }}\n </button>\n <button\n class=\"sky-btn sky-btn-default\"\n type=\"button\"\n (click)=\"onCancelClick()\"\n >\n {{ 'skyux_inline_delete_cancel' | skyLibResources }}\n </button>\n </div>\n </div>\n</div>\n", styles: [".sky-inline-delete{position:absolute!important;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:999;border:2px solid #ef4044}.sky-inline-delete-assistive-text{width:0;height:0;padding:0;opacity:0;position:absolute;margin:-1px;border:0;overflow:hidden;clip:rect(0,0,0,0);outline:none;white-space:nowrap}.sky-inline-delete-button{margin-right:10px}.sky-inline-delete-card .sky-inline-delete-content{position:absolute;bottom:10px;text-align:center;width:100%}.sky-inline-delete-standard .sky-inline-delete-content{position:absolute;top:50%;transform:translateY(-50%);left:20px}.sky-inline-delete-wait{height:100%}\n"] }]
|
|
151
|
+
}], ctorParameters: function () { return [{ type: i1.SkyInlineDeleteAdapterService }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }]; }, propDecorators: { pending: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], cancelTriggered: [{
|
|
154
|
+
type: Output
|
|
155
|
+
}], deleteTriggered: [{
|
|
156
|
+
type: Output
|
|
157
|
+
}], deleteButton: [{
|
|
158
|
+
type: ViewChild,
|
|
159
|
+
args: ['delete', {
|
|
160
|
+
read: ElementRef,
|
|
161
|
+
static: false,
|
|
162
|
+
}]
|
|
163
|
+
}] } });
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-delete.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/src/lib/modules/inline-delete/inline-delete.component.ts","../../../../../../../../libs/components/layout/src/lib/modules/inline-delete/inline-delete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AnimationEvent,\n  animate,\n  group,\n  query,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport { SkyCoreAdapterService } from '@skyux/core';\n\nimport { SkyInlineDeleteAdapterService } from './inline-delete-adapter.service';\nimport { SkyInlineDeleteType } from './inline-delete-type';\n\n/**\n * Auto-incrementing integer used to generate unique ids for inline delete components.\n */\nlet nextId = 0;\n\n@Component({\n  selector: 'sky-inline-delete',\n  styleUrls: ['./inline-delete.component.scss'],\n  templateUrl: './inline-delete.component.html',\n  animations: [\n    trigger('inlineDeleteAnimation', [\n      transition('* => shown', [\n        style({\n          opacity: 0,\n        }),\n        query(\n          '.sky-inline-delete-content-animation-container',\n          style({ transform: 'scale(0.0)' })\n        ),\n        group([\n          animate('300ms ease-in-out', style({ opacity: 1 })),\n          query(\n            '.sky-inline-delete-content-animation-container',\n            animate(\n              '300ms ease-in-out',\n              style({\n                transform: 'scale(1)',\n              })\n            )\n          ),\n        ]),\n      ]),\n      transition(`shown <=> *`, [\n        query(\n          '.sky-inline-delete-content-animation-container',\n          style({ transform: 'scale(1)' })\n        ),\n        group([\n          animate(\n            '300ms ease-in-out',\n            style({\n              opacity: 0,\n            })\n          ),\n          query(\n            '.sky-inline-delete-content-animation-container',\n            animate(\n              '300ms ease-in-out',\n              style({\n                transform: 'scale(0.0)',\n              })\n            )\n          ),\n        ]),\n      ]),\n    ]),\n  ],\n  providers: [SkyCoreAdapterService, SkyInlineDeleteAdapterService],\n})\nexport class SkyInlineDeleteComponent implements OnDestroy, OnInit {\n  /**\n   * Whether the deletion is pending.\n   * @default false\n   */\n  @Input()\n  public pending: boolean | undefined = false;\n\n  /**\n   * Fires when users click the cancel button.\n   */\n  @Output()\n  public cancelTriggered = new EventEmitter<void>();\n\n  /**\n   * Fires when users click the delete button.\n   */\n  @Output()\n  public deleteTriggered = new EventEmitter<void>();\n\n  public animationState = 'shown';\n\n  public assistiveTextId = `sky-inline-delete-assistive-text-${++nextId}`;\n\n  public type: SkyInlineDeleteType = SkyInlineDeleteType.Standard;\n\n  @ViewChild('delete', {\n    read: ElementRef,\n    static: false,\n  })\n  public deleteButton: ElementRef | undefined;\n\n  #adapterService: SkyInlineDeleteAdapterService;\n  #changeDetector: ChangeDetectorRef;\n  #elRef: ElementRef;\n\n  constructor(\n    adapterService: SkyInlineDeleteAdapterService,\n    changeDetector: ChangeDetectorRef,\n    elRef: ElementRef\n  ) {\n    this.#adapterService = adapterService;\n    this.#changeDetector = changeDetector;\n    this.#elRef = elRef;\n  }\n\n  /**\n   * Initialization lifecycle hook\n   * @internal\n   */\n  public ngOnInit(): void {\n    this.animationState = 'shown';\n  }\n\n  /**\n   * Destruction lifecycle hook\n   * @internal\n   */\n  public ngOnDestroy(): void {\n    this.#adapterService.clearListeners();\n    this.cancelTriggered.complete();\n    this.deleteTriggered.complete();\n  }\n\n  /**\n   * @internal\n   */\n  public onCancelClick(): void {\n    this.animationState = 'hidden';\n  }\n\n  /**\n   * @internal\n   */\n  public onDeleteClick(): void {\n    this.deleteTriggered.emit();\n  }\n\n  /**\n   * Sets the inline delete to one of its predefined types.\n   * @param type The inline delete type\n   * @internal\n   */\n  public setType(type: SkyInlineDeleteType): void {\n    this.type = type;\n    this.#changeDetector.detectChanges();\n  }\n\n  /**\n   * Handles actions that should be taken after the inline delete animates\n   * @param event The animation event\n   * @internal\n   */\n  public onAnimationDone(event: AnimationEvent): void {\n    if (event.toState === 'hidden') {\n      this.cancelTriggered.emit();\n    } else {\n      this.deleteButton?.nativeElement.focus();\n      /* istanbul ignore else */\n      if (this.#elRef) {\n        this.#adapterService.setEl(this.#elRef.nativeElement);\n      }\n    }\n  }\n}\n","<div\n  class=\"sky-inline-delete sky-inline-delete-{{ type }}\"\n  role=\"alertdialog\"\n  [@inlineDeleteAnimation]=\"animationState\"\n  (@inlineDeleteAnimation.done)=\"onAnimationDone($event)\"\n  [attr.aria-describedby]=\"assistiveTextId\"\n  [attr.aria-label]=\"'skyux_inline_delete_confirm_deletion' | skyLibResources\"\n>\n  <span class=\"sky-inline-delete-assistive-text\" [id]=\"assistiveTextId\">\n    {{ 'skyux_inline_delete_assistive_text' | skyLibResources }}\n  </span>\n  <sky-wait class=\"sky-inline-delete-wait\" [isWaiting]=\"pending\"></sky-wait>\n  <div class=\"sky-inline-delete-content\">\n    <div class=\"sky-inline-delete-content-animation-container\">\n      <button\n        class=\"sky-btn sky-btn-danger sky-inline-delete-button\"\n        type=\"button\"\n        (click)=\"onDeleteClick()\"\n        #delete\n      >\n        {{ 'skyux_inline_delete_delete' | skyLibResources }}\n      </button>\n      <button\n        class=\"sky-btn sky-btn-default\"\n        type=\"button\"\n        (click)=\"onCancelClick()\"\n      >\n        {{ 'skyux_inline_delete_cancel' | skyLibResources }}\n      </button>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -6,17 +6,17 @@ import { SkyLayoutResourcesModule } from '../shared/sky-layout-resources.module'
|
|
|
6
6
|
import { SkyInlineDeleteComponent } from './inline-delete.component';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class SkyInlineDeleteModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteModule, declarations: [SkyInlineDeleteComponent], imports: [CommonModule,
|
|
11
|
+
SkyI18nModule,
|
|
12
|
+
SkyLayoutResourcesModule,
|
|
13
|
+
SkyWaitModule], exports: [SkyInlineDeleteComponent] }); }
|
|
14
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteModule, imports: [CommonModule,
|
|
15
|
+
SkyI18nModule,
|
|
16
|
+
SkyLayoutResourcesModule,
|
|
17
|
+
SkyWaitModule] }); }
|
|
9
18
|
}
|
|
10
|
-
|
|
11
|
-
SkyInlineDeleteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyInlineDeleteModule, declarations: [SkyInlineDeleteComponent], imports: [CommonModule,
|
|
12
|
-
SkyI18nModule,
|
|
13
|
-
SkyLayoutResourcesModule,
|
|
14
|
-
SkyWaitModule], exports: [SkyInlineDeleteComponent] });
|
|
15
|
-
SkyInlineDeleteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyInlineDeleteModule, imports: [CommonModule,
|
|
16
|
-
SkyI18nModule,
|
|
17
|
-
SkyLayoutResourcesModule,
|
|
18
|
-
SkyWaitModule] });
|
|
19
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyInlineDeleteModule, decorators: [{
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyInlineDeleteModule, decorators: [{
|
|
20
20
|
type: NgModule,
|
|
21
21
|
args: [{
|
|
22
22
|
declarations: [SkyInlineDeleteComponent],
|
|
@@ -29,4 +29,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
29
29
|
exports: [SkyInlineDeleteComponent],
|
|
30
30
|
}]
|
|
31
31
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
32
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLWRlbGV0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9pbmxpbmUtZGVsZXRlL2lubGluZS1kZWxldGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDNUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWxELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRWpGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQVlyRSxNQUFNLE9BQU8scUJBQXFCOzhHQUFyQixxQkFBcUI7K0dBQXJCLHFCQUFxQixpQkFUakIsd0JBQXdCLGFBRXJDLFlBQVk7WUFDWixhQUFhO1lBQ2Isd0JBQXdCO1lBQ3hCLGFBQWEsYUFFTCx3QkFBd0I7K0dBRXZCLHFCQUFxQixZQVA5QixZQUFZO1lBQ1osYUFBYTtZQUNiLHdCQUF3QjtZQUN4QixhQUFhOzsyRkFJSixxQkFBcUI7a0JBVmpDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsd0JBQXdCLENBQUM7b0JBQ3hDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGFBQWE7d0JBQ2Isd0JBQXdCO3dCQUN4QixhQUFhO3FCQUNkO29CQUNELE9BQU8sRUFBRSxDQUFDLHdCQUF3QixDQUFDO2lCQUNwQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2t5STE4bk1vZHVsZSB9IGZyb20gJ0Bza3l1eC9pMThuJztcbmltcG9ydCB7IFNreVdhaXRNb2R1bGUgfSBmcm9tICdAc2t5dXgvaW5kaWNhdG9ycyc7XG5cbmltcG9ydCB7IFNreUxheW91dFJlc291cmNlc01vZHVsZSB9IGZyb20gJy4uL3NoYXJlZC9za3ktbGF5b3V0LXJlc291cmNlcy5tb2R1bGUnO1xuXG5pbXBvcnQgeyBTa3lJbmxpbmVEZWxldGVDb21wb25lbnQgfSBmcm9tICcuL2lubGluZS1kZWxldGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbU2t5SW5saW5lRGVsZXRlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBTa3lJMThuTW9kdWxlLFxuICAgIFNreUxheW91dFJlc291cmNlc01vZHVsZSxcbiAgICBTa3lXYWl0TW9kdWxlLFxuICBdLFxuICBleHBvcnRzOiBbU2t5SW5saW5lRGVsZXRlQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5SW5saW5lRGVsZXRlTW9kdWxlIHt9XG4iXX0=
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { Inject, Injectable } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyPageThemeAdapterService {
|
|
8
|
+
#styleEl;
|
|
9
|
+
#document;
|
|
10
|
+
constructor(document) {
|
|
11
|
+
this.#document = document;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* We can't use ViewEncapsulation.None for this behavior because Angular does
|
|
15
|
+
* not remove `style` tags from the HEAD element after route changes.
|
|
16
|
+
* @see https://github.com/angular/angular/issues/16670
|
|
17
|
+
*/
|
|
18
|
+
addTheme() {
|
|
19
|
+
if (!this.#styleEl) {
|
|
20
|
+
this.#styleEl = this.#document.createElement('style');
|
|
21
|
+
this.#styleEl.appendChild(this.#document.createTextNode('body:not(.sky-theme-modern) { background-color: #fff; }'));
|
|
22
|
+
this.#document.head.appendChild(this.#styleEl);
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
removeTheme() {
|
|
26
|
+
if (this.#styleEl) {
|
|
27
|
+
this.#styleEl.remove();
|
|
28
|
+
this.#styleEl = undefined;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageThemeAdapterService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
32
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageThemeAdapterService }); }
|
|
33
|
+
}
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageThemeAdapterService, decorators: [{
|
|
35
|
+
type: Injectable
|
|
36
|
+
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
37
|
+
type: Inject,
|
|
38
|
+
args: [DOCUMENT]
|
|
39
|
+
}] }]; } });
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10aGVtZS1hZGFwdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UtdGhlbWUtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFbkQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLFFBQVEsQ0FBK0I7SUFFdkMsU0FBUyxDQUFXO0lBRXBCLFlBQThCLFFBQWtCO1FBQzlDLElBQUksQ0FBQyxTQUFTLEdBQUcsUUFBUSxDQUFDO0lBQzVCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksUUFBUTtRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDdEQsSUFBSSxDQUFDLFFBQVEsQ0FBQyxXQUFXLENBQ3ZCLElBQUksQ0FBQyxTQUFTLENBQUMsY0FBYyxDQUMzQix5REFBeUQsQ0FDMUQsQ0FDRixDQUFDO1lBRUYsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztTQUNoRDtJQUNILENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxRQUFRLEdBQUcsU0FBUyxDQUFDO1NBQzNCO0lBQ0gsQ0FBQzs4R0FoQ1UsMEJBQTBCLGtCQUtqQixRQUFRO2tIQUxqQiwwQkFBMEI7OzJGQUExQiwwQkFBMEI7a0JBRHRDLFVBQVU7OzBCQU1JLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5UGFnZVRoZW1lQWRhcHRlclNlcnZpY2Uge1xuICAjc3R5bGVFbDogSFRNTFN0eWxlRWxlbWVudCB8IHVuZGVmaW5lZDtcblxuICAjZG9jdW1lbnQ6IERvY3VtZW50O1xuXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoRE9DVU1FTlQpIGRvY3VtZW50OiBEb2N1bWVudCkge1xuICAgIHRoaXMuI2RvY3VtZW50ID0gZG9jdW1lbnQ7XG4gIH1cblxuICAvKipcbiAgICogV2UgY2FuJ3QgdXNlIFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUgZm9yIHRoaXMgYmVoYXZpb3IgYmVjYXVzZSBBbmd1bGFyIGRvZXNcbiAgICogbm90IHJlbW92ZSBgc3R5bGVgIHRhZ3MgZnJvbSB0aGUgSEVBRCBlbGVtZW50IGFmdGVyIHJvdXRlIGNoYW5nZXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2FuZ3VsYXIvYW5ndWxhci9pc3N1ZXMvMTY2NzBcbiAgICovXG4gIHB1YmxpYyBhZGRUaGVtZSgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuI3N0eWxlRWwpIHtcbiAgICAgIHRoaXMuI3N0eWxlRWwgPSB0aGlzLiNkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgdGhpcy4jc3R5bGVFbC5hcHBlbmRDaGlsZChcbiAgICAgICAgdGhpcy4jZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoXG4gICAgICAgICAgJ2JvZHk6bm90KC5za3ktdGhlbWUtbW9kZXJuKSB7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IH0nXG4gICAgICAgIClcbiAgICAgICk7XG5cbiAgICAgIHRoaXMuI2RvY3VtZW50LmhlYWQuYXBwZW5kQ2hpbGQodGhpcy4jc3R5bGVFbCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHJlbW92ZVRoZW1lKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLiNzdHlsZUVsKSB7XG4gICAgICB0aGlzLiNzdHlsZUVsLnJlbW92ZSgpO1xuICAgICAgdGhpcy4jc3R5bGVFbCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Component, Input, inject } from '@angular/core';
|
|
2
|
+
import { SkyLogService } from '@skyux/core';
|
|
3
|
+
import { SkyPageThemeAdapterService } from './page-theme-adapter.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "./page-theme-adapter.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
/**
|
|
8
|
+
* Displays page contents using the specified layout.
|
|
9
|
+
* @deprecated Use the `sky-page` component in `@skyux/pages` instead.
|
|
10
|
+
*/
|
|
11
|
+
export class SkyPageComponent {
|
|
12
|
+
/**
|
|
13
|
+
* The page layout. Use `auto` to allow the page contents
|
|
14
|
+
* to expand beyond the bottom of the browser window. Use `fit`
|
|
15
|
+
* to constrain the page contents to the available viewport.
|
|
16
|
+
*/
|
|
17
|
+
set layout(value) {
|
|
18
|
+
this.#_layout = value || 'auto';
|
|
19
|
+
}
|
|
20
|
+
get layout() {
|
|
21
|
+
return this.#_layout;
|
|
22
|
+
}
|
|
23
|
+
#themeAdapter;
|
|
24
|
+
#_layout = 'auto';
|
|
25
|
+
#logger = inject(SkyLogService);
|
|
26
|
+
constructor(themeAdapter) {
|
|
27
|
+
this.#logger.deprecated('SkyPageComponent', {
|
|
28
|
+
deprecationMajorVersion: 8,
|
|
29
|
+
moreInfoUrl: 'https://developer.blackbaud.com/skyux/components/page',
|
|
30
|
+
replacementRecommendation: 'Use the `sky-page` component in `@skyux/pages` instead.',
|
|
31
|
+
});
|
|
32
|
+
this.#themeAdapter = themeAdapter;
|
|
33
|
+
}
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
this.#themeAdapter.addTheme();
|
|
36
|
+
}
|
|
37
|
+
ngOnDestroy() {
|
|
38
|
+
this.#themeAdapter.removeTheme();
|
|
39
|
+
}
|
|
40
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageComponent, deps: [{ token: i1.SkyPageThemeAdapterService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
41
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyPageComponent, selector: "sky-page", inputs: { layout: "layout" }, providers: [SkyPageThemeAdapterService], ngImport: i0, template: "<div [ngClass]=\"'sky-layout-host-' + layout\">\n <ng-content></ng-content>\n</div>\n", styles: [".sky-layout-host-fit{position:absolute;left:var(--sky-viewport-left);top:var(--sky-viewport-top);right:var(--sky-viewport-right);bottom:var(--sky-viewport-bottom)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
42
|
+
}
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageComponent, decorators: [{
|
|
44
|
+
type: Component,
|
|
45
|
+
args: [{ selector: 'sky-page', providers: [SkyPageThemeAdapterService], template: "<div [ngClass]=\"'sky-layout-host-' + layout\">\n <ng-content></ng-content>\n</div>\n", styles: [".sky-layout-host-fit{position:absolute;left:var(--sky-viewport-left);top:var(--sky-viewport-top);right:var(--sky-viewport-right);bottom:var(--sky-viewport-bottom)}\n"] }]
|
|
46
|
+
}], ctorParameters: function () { return [{ type: i1.SkyPageThemeAdapterService }]; }, propDecorators: { layout: [{
|
|
47
|
+
type: Input
|
|
48
|
+
}] } });
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvcGFnZS9wYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFxQixNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUc1QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7OztBQUUxRTs7O0dBR0c7QUFPSCxNQUFNLE9BQU8sZ0JBQWdCO0lBQzNCOzs7O09BSUc7SUFDSCxJQUNXLE1BQU0sQ0FBQyxLQUFvQztRQUNwRCxJQUFJLENBQUMsUUFBUSxHQUFHLEtBQUssSUFBSSxNQUFNLENBQUM7SUFDbEMsQ0FBQztJQUVELElBQVcsTUFBTTtRQUNmLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUN2QixDQUFDO0lBRUQsYUFBYSxDQUE2QjtJQUUxQyxRQUFRLEdBQXNCLE1BQU0sQ0FBQztJQUVyQyxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBRWhDLFlBQVksWUFBd0M7UUFDbEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsa0JBQWtCLEVBQUU7WUFDMUMsdUJBQXVCLEVBQUUsQ0FBQztZQUMxQixXQUFXLEVBQUUsdURBQXVEO1lBQ3BFLHlCQUF5QixFQUN2Qix5REFBeUQ7U0FDNUQsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLGFBQWEsR0FBRyxZQUFZLENBQUM7SUFDcEMsQ0FBQztJQUVNLFFBQVE7UUFDYixJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFTSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxhQUFhLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDbkMsQ0FBQzs4R0F0Q1UsZ0JBQWdCO2tHQUFoQixnQkFBZ0IsaUVBRmhCLENBQUMsMEJBQTBCLENBQUMsMEJDZHpDLHdGQUdBOzsyRkRhYSxnQkFBZ0I7a0JBTjVCLFNBQVM7K0JBQ0UsVUFBVSxhQUdULENBQUMsMEJBQTBCLENBQUM7aUhBUzVCLE1BQU07c0JBRGhCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBTa3lMb2dTZXJ2aWNlIH0gZnJvbSAnQHNreXV4L2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lQYWdlTGF5b3V0VHlwZSB9IGZyb20gJy4vcGFnZS1sYXlvdXQtdHlwZSc7XG5pbXBvcnQgeyBTa3lQYWdlVGhlbWVBZGFwdGVyU2VydmljZSB9IGZyb20gJy4vcGFnZS10aGVtZS1hZGFwdGVyLnNlcnZpY2UnO1xuXG4vKipcbiAqIERpc3BsYXlzIHBhZ2UgY29udGVudHMgdXNpbmcgdGhlIHNwZWNpZmllZCBsYXlvdXQuXG4gKiBAZGVwcmVjYXRlZCBVc2UgdGhlIGBza3ktcGFnZWAgY29tcG9uZW50IGluIGBAc2t5dXgvcGFnZXNgIGluc3RlYWQuXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1wYWdlJyxcbiAgdGVtcGxhdGVVcmw6ICcuL3BhZ2UuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wYWdlLmNvbXBvbmVudC5zY3NzJ10sXG4gIHByb3ZpZGVyczogW1NreVBhZ2VUaGVtZUFkYXB0ZXJTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGFnZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgLyoqXG4gICAqIFRoZSBwYWdlIGxheW91dC4gVXNlIGBhdXRvYCB0byBhbGxvdyB0aGUgcGFnZSBjb250ZW50c1xuICAgKiB0byBleHBhbmQgYmV5b25kIHRoZSBib3R0b20gb2YgdGhlIGJyb3dzZXIgd2luZG93LiBVc2UgYGZpdGBcbiAgICogdG8gY29uc3RyYWluIHRoZSBwYWdlIGNvbnRlbnRzIHRvIHRoZSBhdmFpbGFibGUgdmlld3BvcnQuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IGxheW91dCh2YWx1ZTogU2t5UGFnZUxheW91dFR5cGUgfCB1bmRlZmluZWQpIHtcbiAgICB0aGlzLiNfbGF5b3V0ID0gdmFsdWUgfHwgJ2F1dG8nO1xuICB9XG5cbiAgcHVibGljIGdldCBsYXlvdXQoKTogU2t5UGFnZUxheW91dFR5cGUge1xuICAgIHJldHVybiB0aGlzLiNfbGF5b3V0O1xuICB9XG5cbiAgI3RoZW1lQWRhcHRlcjogU2t5UGFnZVRoZW1lQWRhcHRlclNlcnZpY2U7XG5cbiAgI19sYXlvdXQ6IFNreVBhZ2VMYXlvdXRUeXBlID0gJ2F1dG8nO1xuXG4gICNsb2dnZXIgPSBpbmplY3QoU2t5TG9nU2VydmljZSk7XG5cbiAgY29uc3RydWN0b3IodGhlbWVBZGFwdGVyOiBTa3lQYWdlVGhlbWVBZGFwdGVyU2VydmljZSkge1xuICAgIHRoaXMuI2xvZ2dlci5kZXByZWNhdGVkKCdTa3lQYWdlQ29tcG9uZW50Jywge1xuICAgICAgZGVwcmVjYXRpb25NYWpvclZlcnNpb246IDgsXG4gICAgICBtb3JlSW5mb1VybDogJ2h0dHBzOi8vZGV2ZWxvcGVyLmJsYWNrYmF1ZC5jb20vc2t5dXgvY29tcG9uZW50cy9wYWdlJyxcbiAgICAgIHJlcGxhY2VtZW50UmVjb21tZW5kYXRpb246XG4gICAgICAgICdVc2UgdGhlIGBza3ktcGFnZWAgY29tcG9uZW50IGluIGBAc2t5dXgvcGFnZXNgIGluc3RlYWQuJyxcbiAgICB9KTtcblxuICAgIHRoaXMuI3RoZW1lQWRhcHRlciA9IHRoZW1lQWRhcHRlcjtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLiN0aGVtZUFkYXB0ZXIuYWRkVGhlbWUoKTtcbiAgfVxuXG4gIHB1YmxpYyBuZ09uRGVzdHJveSgpOiB2b2lkIHtcbiAgICB0aGlzLiN0aGVtZUFkYXB0ZXIucmVtb3ZlVGhlbWUoKTtcbiAgfVxufVxuIiwiPGRpdiBbbmdDbGFzc109XCInc2t5LWxheW91dC1ob3N0LScgKyBsYXlvdXRcIj5cbiAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuPC9kaXY+XG4iXX0=
|
|
@@ -6,11 +6,11 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
* @deprecated Use the SkyPageModule in `@skyux/pages` instead.
|
|
7
7
|
*/
|
|
8
8
|
export class SkyPageModule {
|
|
9
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
10
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.1.7", ngImport: i0, type: SkyPageModule, declarations: [SkyPageComponent], imports: [CommonModule], exports: [SkyPageComponent] }); }
|
|
11
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageModule, imports: [CommonModule] }); }
|
|
9
12
|
}
|
|
10
|
-
|
|
11
|
-
SkyPageModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.9", ngImport: i0, type: SkyPageModule, declarations: [SkyPageComponent], imports: [CommonModule], exports: [SkyPageComponent] });
|
|
12
|
-
SkyPageModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageModule, imports: [CommonModule] });
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageModule, decorators: [{
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageModule, decorators: [{
|
|
14
14
|
type: NgModule,
|
|
15
15
|
args: [{
|
|
16
16
|
declarations: [SkyPageComponent],
|
|
@@ -18,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
18
18
|
exports: [SkyPageComponent],
|
|
19
19
|
}]
|
|
20
20
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXpDLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDOztBQUVwRDs7R0FFRztBQU1ILE1BQU0sT0FBTyxhQUFhOzhHQUFiLGFBQWE7K0dBQWIsYUFBYSxpQkFKVCxnQkFBZ0IsYUFDckIsWUFBWSxhQUNaLGdCQUFnQjsrR0FFZixhQUFhLFlBSGQsWUFBWTs7MkZBR1gsYUFBYTtrQkFMekIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztpQkFDNUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgU2t5UGFnZUNvbXBvbmVudCB9IGZyb20gJy4vcGFnZS5jb21wb25lbnQnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB0aGUgU2t5UGFnZU1vZHVsZSBpbiBgQHNreXV4L3BhZ2VzYCBpbnN0ZWFkLlxuICovXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtTa3lQYWdlQ29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIGV4cG9ydHM6IFtTa3lQYWdlQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgU2t5UGFnZU1vZHVsZSB7fVxuIl19
|
|
@@ -14,10 +14,10 @@ export class SkyPageSummaryAdapterService {
|
|
|
14
14
|
el.querySelector('.sky-page-summary-key-info-sm').appendChild(keyInfoContainerEl);
|
|
15
15
|
}
|
|
16
16
|
}
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryAdapterService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
18
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryAdapterService }); }
|
|
17
19
|
}
|
|
18
|
-
|
|
19
|
-
SkyPageSummaryAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageSummaryAdapterService });
|
|
20
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageSummaryAdapterService, decorators: [{
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryAdapterService, decorators: [{
|
|
21
21
|
type: Injectable
|
|
22
22
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1zdW1tYXJ5LWFkYXB0ZXIuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL3BhZ2Utc3VtbWFyeS9wYWdlLXN1bW1hcnktYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBYyxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRXZEOztHQUVHO0FBRUgsTUFBTSxPQUFPLDRCQUE0QjtJQUNoQyxxQkFBcUIsQ0FBQyxLQUFpQixFQUFFLElBQWE7UUFDM0QsTUFBTSxFQUFFLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUMvQixNQUFNLGtCQUFrQixHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQ3pDLHNDQUFzQyxDQUN2QyxDQUFDO1FBRUYsSUFBSSxJQUFJLEVBQUU7WUFDUixFQUFFLENBQUMsYUFBYSxDQUFDLCtCQUErQixDQUFDLENBQUMsV0FBVyxDQUMzRCxrQkFBa0IsQ0FDbkIsQ0FBQztTQUNIO2FBQU07WUFDTCxFQUFFLENBQUMsYUFBYSxDQUFDLCtCQUErQixDQUFDLENBQUMsV0FBVyxDQUMzRCxrQkFBa0IsQ0FDbkIsQ0FBQztTQUNIO0lBQ0gsQ0FBQzs4R0FoQlUsNEJBQTRCO2tIQUE1Qiw0QkFBNEI7OzJGQUE1Qiw0QkFBNEI7a0JBRHhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFbGVtZW50UmVmLCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKlxuICogQGludGVybmFsXG4gKi9cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBTa3lQYWdlU3VtbWFyeUFkYXB0ZXJTZXJ2aWNlIHtcbiAgcHVibGljIHVwZGF0ZUtleUluZm9Mb2NhdGlvbihlbFJlZjogRWxlbWVudFJlZiwgaXNYUzogYm9vbGVhbik6IHZvaWQge1xuICAgIGNvbnN0IGVsID0gZWxSZWYubmF0aXZlRWxlbWVudDtcbiAgICBjb25zdCBrZXlJbmZvQ29udGFpbmVyRWwgPSBlbC5xdWVyeVNlbGVjdG9yKFxuICAgICAgJy5za3ktcGFnZS1zdW1tYXJ5LWtleS1pbmZvLWNvbnRhaW5lcidcbiAgICApO1xuXG4gICAgaWYgKGlzWFMpIHtcbiAgICAgIGVsLnF1ZXJ5U2VsZWN0b3IoJy5za3ktcGFnZS1zdW1tYXJ5LWtleS1pbmZvLXhzJykuYXBwZW5kQ2hpbGQoXG4gICAgICAgIGtleUluZm9Db250YWluZXJFbFxuICAgICAgKTtcbiAgICB9IGVsc2Uge1xuICAgICAgZWwucXVlcnlTZWxlY3RvcignLnNreS1wYWdlLXN1bW1hcnkta2V5LWluZm8tc20nKS5hcHBlbmRDaGlsZChcbiAgICAgICAga2V5SW5mb0NvbnRhaW5lckVsXG4gICAgICApO1xuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -8,11 +8,11 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
/* istanbul ignore next */
|
|
9
9
|
/* Code coverage having problems with no statements in classes */
|
|
10
10
|
export class SkyPageSummaryAlertComponent {
|
|
11
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryAlertComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyPageSummaryAlertComponent, selector: "sky-page-summary-alert", ngImport: i0, template: "<ng-content></ng-content>\n", styles: ["::ng-deep .sky-alert{margin-top:0;margin-bottom:20px;line-height:initial}\n"] }); }
|
|
11
13
|
}
|
|
12
|
-
|
|
13
|
-
SkyPageSummaryAlertComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyPageSummaryAlertComponent, selector: "sky-page-summary-alert", ngImport: i0, template: "<ng-content></ng-content>\n", styles: ["::ng-deep .sky-alert{margin-top:0;margin-bottom:20px;line-height:initial}\n"] });
|
|
14
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageSummaryAlertComponent, decorators: [{
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryAlertComponent, decorators: [{
|
|
15
15
|
type: Component,
|
|
16
16
|
args: [{ selector: 'sky-page-summary-alert', template: "<ng-content></ng-content>\n", styles: ["::ng-deep .sky-alert{margin-top:0;margin-bottom:20px;line-height:initial}\n"] }]
|
|
17
17
|
}] });
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1zdW1tYXJ5LWFsZXJ0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL3BhZ2Utc3VtbWFyeS9wYWdlLXN1bW1hcnktYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvcGFnZS1zdW1tYXJ5L3BhZ2Utc3VtbWFyeS1hbGVydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUxQzs7OztHQUlHO0FBTUgsMEJBQTBCO0FBQzFCLGlFQUFpRTtBQUNqRSxNQUFNLE9BQU8sNEJBQTRCOzhHQUE1Qiw0QkFBNEI7a0dBQTVCLDRCQUE0Qiw4RENkekMsNkJBQ0E7OzJGRGFhLDRCQUE0QjtrQkFQeEMsU0FBUzsrQkFDRSx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuLyoqXG4gKiBEaXNwbGF5cyBtZXNzYWdlcyB0aGF0IHJlcXVpcmUgaW1tZWRpYXRlIGF0dGVudGlvbiBhcyBbYWxlcnRzXShodHRwczovL2RldmVsb3Blci5ibGFja2JhdWQuY29tL3NreXV4L2NvbXBvbmVudHMvYWxlcnQpIHdpdGhpblxuICogdGhlIHBhZ2Ugc3VtbWFyeS5cbiAqIEBkZXByZWNhdGVkXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NreS1wYWdlLXN1bW1hcnktYWxlcnQnLFxuICB0ZW1wbGF0ZVVybDogJy4vcGFnZS1zdW1tYXJ5LWFsZXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vcGFnZS1zdW1tYXJ5LWFsZXJ0LmNvbXBvbmVudC5zY3NzJ10sXG59KVxuLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbi8qIENvZGUgY292ZXJhZ2UgaGF2aW5nIHByb2JsZW1zIHdpdGggbm8gc3RhdGVtZW50cyBpbiBjbGFzc2VzICovXG5leHBvcnQgY2xhc3MgU2t5UGFnZVN1bW1hcnlBbGVydENvbXBvbmVudCB7fVxuIiwiPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuIl19
|
|
@@ -7,11 +7,11 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
/* istanbul ignore next */
|
|
8
8
|
/* Code coverage having problems with no statements in classes */
|
|
9
9
|
export class SkyPageSummaryContentComponent {
|
|
10
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryContentComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", type: SkyPageSummaryContentComponent, selector: "sky-page-summary-content", ngImport: i0, template: "<div class=\"sky-page-summary-content\">\n <ng-content></ng-content>\n</div>\n", styles: [".sky-page-summary-content{margin-top:20px}\n"] }); }
|
|
10
12
|
}
|
|
11
|
-
|
|
12
|
-
SkyPageSummaryContentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", type: SkyPageSummaryContentComponent, selector: "sky-page-summary-content", ngImport: i0, template: "<div class=\"sky-page-summary-content\">\n <ng-content></ng-content>\n</div>\n", styles: [".sky-page-summary-content{margin-top:20px}\n"] });
|
|
13
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: SkyPageSummaryContentComponent, decorators: [{
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: SkyPageSummaryContentComponent, decorators: [{
|
|
14
14
|
type: Component,
|
|
15
15
|
args: [{ selector: 'sky-page-summary-content', template: "<div class=\"sky-page-summary-content\">\n <ng-content></ng-content>\n</div>\n", styles: [".sky-page-summary-content{margin-top:20px}\n"] }]
|
|
16
16
|
}] });
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1zdW1tYXJ5LWNvbnRlbnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvcGFnZS1zdW1tYXJ5L3BhZ2Utc3VtbWFyeS1jb250ZW50LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL3BhZ2Utc3VtbWFyeS9wYWdlLXN1bW1hcnktY29udGVudC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUUxQzs7O0dBR0c7QUFNSCwwQkFBMEI7QUFDMUIsaUVBQWlFO0FBQ2pFLE1BQU0sT0FBTyw4QkFBOEI7OEdBQTlCLDhCQUE4QjtrR0FBOUIsOEJBQThCLGdFQ2IzQyxpRkFHQTs7MkZEVWEsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIERpc3BsYXlzIGNvbnRlbnQgaW4gdGhlIGFyYml0cmFyeSBzZWN0aW9uIG9mIHRoZSBwYWdlIHN1bW1hcnkuXG4gKiBAZGVwcmVjYXRlZFxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdza3ktcGFnZS1zdW1tYXJ5LWNvbnRlbnQnLFxuICB0ZW1wbGF0ZVVybDogJy4vcGFnZS1zdW1tYXJ5LWNvbnRlbnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wYWdlLXN1bW1hcnktY29udGVudC5jb21wb25lbnQuc2NzcyddLFxufSlcbi8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4vKiBDb2RlIGNvdmVyYWdlIGhhdmluZyBwcm9ibGVtcyB3aXRoIG5vIHN0YXRlbWVudHMgaW4gY2xhc3NlcyAqL1xuZXhwb3J0IGNsYXNzIFNreVBhZ2VTdW1tYXJ5Q29udGVudENvbXBvbmVudCB7fVxuIiwiPGRpdiBjbGFzcz1cInNreS1wYWdlLXN1bW1hcnktY29udGVudFwiPlxuICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG48L2Rpdj5cbiJdfQ==
|