@skyux/layout 7.0.0-beta.1 → 7.0.0-beta.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +1549 -817
- package/esm2020/index.mjs +2 -2
- package/esm2020/lib/modules/action-button/action-button-container.component.mjs +2 -2
- package/esm2020/lib/modules/back-to-top/back-to-top.directive.mjs +2 -2
- package/esm2020/lib/modules/card/card.component.mjs +38 -11
- package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
- package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
- package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
- package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
- package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
- package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
- package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
- package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
- package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
- package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
- package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
- package/esm2020/lib/modules/format/format.component.mjs +34 -26
- package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
- package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
- package/esm2020/lib/modules/page/page-layout-type.mjs +2 -0
- package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +23 -11
- package/esm2020/lib/modules/page/page.component.mjs +28 -9
- package/esm2020/lib/modules/page/page.module.mjs +5 -3
- package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
- package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
- package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
- package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
- package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
- package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
- package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
- package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
- package/esm2020/lib/modules/toolbar/toolbar.component.mjs +2 -2
- package/esm2020/testing/action-button-fixture.mjs +12 -6
- package/esm2020/testing/card-fixture.mjs +19 -16
- package/esm2020/testing/page-summary-fixture.mjs +9 -5
- package/fesm2015/skyux-layout-testing.mjs +35 -24
- package/fesm2015/skyux-layout-testing.mjs.map +1 -1
- package/fesm2015/skyux-layout.mjs +707 -516
- package/fesm2015/skyux-layout.mjs.map +1 -1
- package/fesm2020/skyux-layout-testing.mjs +35 -24
- package/fesm2020/skyux-layout-testing.mjs.map +1 -1
- package/fesm2020/skyux-layout.mjs +699 -516
- package/fesm2020/skyux-layout.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/lib/modules/back-to-top/back-to-top.directive.d.ts +1 -1
- package/lib/modules/card/card.component.d.ts +7 -6
- package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
- package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
- package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
- package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
- package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
- package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
- package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
- package/lib/modules/description-list/description-list.component.d.ts +6 -7
- package/lib/modules/fluid-grid/column.component.d.ts +7 -5
- package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
- package/lib/modules/fluid-grid/row.component.d.ts +1 -1
- package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
- package/lib/modules/format/format.component.d.ts +5 -7
- package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
- package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
- package/lib/modules/page/page-layout-type.d.ts +1 -0
- package/lib/modules/page/page-theme-adapter.service.d.ts +2 -1
- package/lib/modules/page/page.component.d.ts +11 -3
- package/lib/modules/page/page.module.d.ts +2 -1
- package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
- package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
- package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
- package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
- package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
- package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
- package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
- package/package.json +9 -9
- package/testing/action-button-fixture.d.ts +4 -4
- package/testing/card-fixture.d.ts +3 -5
- package/testing/page-summary-fixture.d.ts +4 -4
- package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
- package/lib/modules/fluid-grid/fluid-grid-gutter-size.d.ts +0 -18
|
@@ -1,59 +1,67 @@
|
|
|
1
|
+
var _SkyFormatComponent_instances, _SkyFormatComponent__text, _SkyFormatComponent__args, _SkyFormatComponent_updateItemsForDisplay;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
5
|
import * as i1 from "@angular/common";
|
|
4
6
|
const tokenRegex = /(\{\d+\})/;
|
|
5
7
|
export class SkyFormatComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
_SkyFormatComponent_instances.add(this);
|
|
10
|
+
this.itemsForDisplay = [];
|
|
11
|
+
_SkyFormatComponent__text.set(this, void 0);
|
|
12
|
+
_SkyFormatComponent__args.set(this, void 0);
|
|
13
|
+
}
|
|
6
14
|
/**
|
|
7
15
|
* The tokenized string that represents the template. Tokens use the `{n}` notation
|
|
8
16
|
* where `n` is the ordinal of the item to replace the token.
|
|
9
17
|
*/
|
|
10
18
|
set text(value) {
|
|
11
|
-
this
|
|
12
|
-
this.
|
|
19
|
+
__classPrivateFieldSet(this, _SkyFormatComponent__text, value, "f");
|
|
20
|
+
__classPrivateFieldGet(this, _SkyFormatComponent_instances, "m", _SkyFormatComponent_updateItemsForDisplay).call(this);
|
|
13
21
|
}
|
|
14
22
|
get text() {
|
|
15
|
-
return this
|
|
23
|
+
return __classPrivateFieldGet(this, _SkyFormatComponent__text, "f");
|
|
16
24
|
}
|
|
17
25
|
/**
|
|
18
26
|
* An array of `TemplateRef` objects to be placed in the template, where the `nth`
|
|
19
27
|
* item is placed at the `{n}` location in the template.
|
|
20
28
|
*/
|
|
21
29
|
set args(value) {
|
|
22
|
-
this
|
|
23
|
-
this.
|
|
30
|
+
__classPrivateFieldSet(this, _SkyFormatComponent__args, value, "f");
|
|
31
|
+
__classPrivateFieldGet(this, _SkyFormatComponent_instances, "m", _SkyFormatComponent_updateItemsForDisplay).call(this);
|
|
24
32
|
}
|
|
25
33
|
get args() {
|
|
26
|
-
return this
|
|
34
|
+
return __classPrivateFieldGet(this, _SkyFormatComponent__args, "f");
|
|
27
35
|
}
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
this.itemsForDisplay.push(item);
|
|
36
|
+
}
|
|
37
|
+
_SkyFormatComponent__text = new WeakMap(), _SkyFormatComponent__args = new WeakMap(), _SkyFormatComponent_instances = new WeakSet(), _SkyFormatComponent_updateItemsForDisplay = function _SkyFormatComponent_updateItemsForDisplay() {
|
|
38
|
+
this.itemsForDisplay = [];
|
|
39
|
+
if (this.text && this.args) {
|
|
40
|
+
const textParts = this.text.split(tokenRegex);
|
|
41
|
+
for (const textPart of textParts) {
|
|
42
|
+
// Disregard empty strings.
|
|
43
|
+
if (textPart) {
|
|
44
|
+
const item = {};
|
|
45
|
+
if (tokenRegex.test(textPart)) {
|
|
46
|
+
const valueIndex = +textPart.substring(1, textPart.length - 1);
|
|
47
|
+
item.templateRef = this.args[valueIndex];
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
item.text = textPart;
|
|
44
51
|
}
|
|
52
|
+
this.itemsForDisplay.push(item);
|
|
45
53
|
}
|
|
46
54
|
}
|
|
47
55
|
}
|
|
48
|
-
}
|
|
56
|
+
};
|
|
49
57
|
SkyFormatComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFormatComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
50
|
-
SkyFormatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyFormatComponent, selector: "sky-format", inputs: { text: "text", args: "args" }, ngImport: i0, template: "<ng-container *ngFor=\"let item of itemsForDisplay\">\n
|
|
58
|
+
SkyFormatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: SkyFormatComponent, selector: "sky-format", inputs: { text: "text", args: "args" }, ngImport: i0, template: "<ng-container *ngFor=\"let item of itemsForDisplay\">\n <ng-container *ngIf=\"item.text\">{{ item.text }}</ng-container>\n <ng-container *ngIf=\"!item.text && item.templateRef\">\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\n </ng-container>\n</ng-container>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
51
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyFormatComponent, decorators: [{
|
|
52
60
|
type: Component,
|
|
53
|
-
args: [{ selector: 'sky-format', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngFor=\"let item of itemsForDisplay\">\n
|
|
61
|
+
args: [{ selector: 'sky-format', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngFor=\"let item of itemsForDisplay\">\n <ng-container *ngIf=\"item.text\">{{ item.text }}</ng-container>\n <ng-container *ngIf=\"!item.text && item.templateRef\">\n <ng-container *ngTemplateOutlet=\"item.templateRef\"></ng-container>\n </ng-container>\n</ng-container>\n" }]
|
|
54
62
|
}], propDecorators: { text: [{
|
|
55
63
|
type: Input
|
|
56
64
|
}], args: [{
|
|
57
65
|
type: Input
|
|
58
66
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL2Zvcm1hdC9mb3JtYXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvZm9ybWF0L2Zvcm1hdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQzs7O0FBSXZCLE1BQU0sVUFBVSxHQUFHLFdBQVcsQ0FBQztBQU8vQixNQUFNLE9BQU8sa0JBQWtCO0lBTC9COztRQU1TLG9CQUFlLEdBQW9CLEVBQUUsQ0FBQztRQThCN0MsNENBQTJCO1FBRTNCLDRDQUF1QztLQTBCeEM7SUF4REM7OztPQUdHO0lBQ0gsSUFDVyxJQUFJLENBQUMsS0FBeUI7UUFDdkMsdUJBQUEsSUFBSSw2QkFBVSxLQUFLLE1BQUEsQ0FBQztRQUNwQix1QkFBQSxJQUFJLGdGQUF1QixNQUEzQixJQUFJLENBQXlCLENBQUM7SUFDaEMsQ0FBQztJQUVELElBQVcsSUFBSTtRQUNiLE9BQU8sdUJBQUEsSUFBSSxpQ0FBTyxDQUFDO0lBQ3JCLENBQUM7SUFFRDs7O09BR0c7SUFDSCxJQUNXLElBQUksQ0FBQyxLQUFxQztRQUNuRCx1QkFBQSxJQUFJLDZCQUFVLEtBQUssTUFBQSxDQUFDO1FBQ3BCLHVCQUFBLElBQUksZ0ZBQXVCLE1BQTNCLElBQUksQ0FBeUIsQ0FBQztJQUNoQyxDQUFDO0lBRUQsSUFBVyxJQUFJO1FBQ2IsT0FBTyx1QkFBQSxJQUFJLGlDQUFPLENBQUM7SUFDckIsQ0FBQzs7O0lBT0MsSUFBSSxDQUFDLGVBQWUsR0FBRyxFQUFFLENBQUM7SUFFMUIsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7UUFDMUIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7UUFFOUMsS0FBSyxNQUFNLFFBQVEsSUFBSSxTQUFTLEVBQUU7WUFDaEMsMkJBQTJCO1lBQzNCLElBQUksUUFBUSxFQUFFO2dCQUNaLE1BQU0sSUFBSSxHQUFrQixFQUFFLENBQUM7Z0JBRS9CLElBQUksVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRTtvQkFDN0IsTUFBTSxVQUFVLEdBQUcsQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxRQUFRLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO29CQUUvRCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7aUJBQzFDO3FCQUFNO29CQUNMLElBQUksQ0FBQyxJQUFJLEdBQUcsUUFBUSxDQUFDO2lCQUN0QjtnQkFFRCxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQzthQUNqQztTQUNGO0tBQ0Y7QUFDSCxDQUFDOytHQTFEVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiwwRkNoQi9CLHNTQU1BOzJGRFVhLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZLG1CQUVMLHVCQUF1QixDQUFDLE1BQU07OEJBVXBDLElBQUk7c0JBRGQsS0FBSztnQkFlSyxJQUFJO3NCQURkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgVGVtcGxhdGVSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lGb3JtYXRJdGVtIH0gZnJvbSAnLi9mb3JtYXQtaXRlbSc7XG5cbmNvbnN0IHRva2VuUmVnZXggPSAvKFxce1xcZCtcXH0pLztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2t5LWZvcm1hdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtYXQuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Rm9ybWF0Q29tcG9uZW50IHtcbiAgcHVibGljIGl0ZW1zRm9yRGlzcGxheTogU2t5Rm9ybWF0SXRlbVtdID0gW107XG5cbiAgLyoqXG4gICAqIFRoZSB0b2tlbml6ZWQgc3RyaW5nIHRoYXQgcmVwcmVzZW50cyB0aGUgdGVtcGxhdGUuIFRva2VucyB1c2UgdGhlIGB7bn1gIG5vdGF0aW9uXG4gICAqIHdoZXJlIGBuYCBpcyB0aGUgb3JkaW5hbCBvZiB0aGUgaXRlbSB0byByZXBsYWNlIHRoZSB0b2tlbi5cbiAgICovXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzZXQgdGV4dCh2YWx1ZTogc3RyaW5nIHwgdW5kZWZpbmVkKSB7XG4gICAgdGhpcy4jX3RleHQgPSB2YWx1ZTtcbiAgICB0aGlzLiN1cGRhdGVJdGVtc0ZvckRpc3BsYXkoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgdGV4dCgpOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgIHJldHVybiB0aGlzLiNfdGV4dDtcbiAgfVxuXG4gIC8qKlxuICAgKiBBbiBhcnJheSBvZiBgVGVtcGxhdGVSZWZgIG9iamVjdHMgdG8gYmUgcGxhY2VkIGluIHRoZSB0ZW1wbGF0ZSwgd2hlcmUgdGhlIGBudGhgXG4gICAqIGl0ZW0gaXMgcGxhY2VkIGF0IHRoZSBge259YCBsb2NhdGlvbiBpbiB0aGUgdGVtcGxhdGUuXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IGFyZ3ModmFsdWU6IFRlbXBsYXRlUmVmPGFueT5bXSB8IHVuZGVmaW5lZCkge1xuICAgIHRoaXMuI19hcmdzID0gdmFsdWU7XG4gICAgdGhpcy4jdXBkYXRlSXRlbXNGb3JEaXNwbGF5KCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0IGFyZ3MoKTogVGVtcGxhdGVSZWY8YW55PltdIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gdGhpcy4jX2FyZ3M7XG4gIH1cblxuICAjX3RleHQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAjX2FyZ3M6IFRlbXBsYXRlUmVmPGFueT5bXSB8IHVuZGVmaW5lZDtcblxuICAjdXBkYXRlSXRlbXNGb3JEaXNwbGF5KCk6IHZvaWQge1xuICAgIHRoaXMuaXRlbXNGb3JEaXNwbGF5ID0gW107XG5cbiAgICBpZiAodGhpcy50ZXh0ICYmIHRoaXMuYXJncykge1xuICAgICAgY29uc3QgdGV4dFBhcnRzID0gdGhpcy50ZXh0LnNwbGl0KHRva2VuUmVnZXgpO1xuXG4gICAgICBmb3IgKGNvbnN0IHRleHRQYXJ0IG9mIHRleHRQYXJ0cykge1xuICAgICAgICAvLyBEaXNyZWdhcmQgZW1wdHkgc3RyaW5ncy5cbiAgICAgICAgaWYgKHRleHRQYXJ0KSB7XG4gICAgICAgICAgY29uc3QgaXRlbTogU2t5Rm9ybWF0SXRlbSA9IHt9O1xuXG4gICAgICAgICAgaWYgKHRva2VuUmVnZXgudGVzdCh0ZXh0UGFydCkpIHtcbiAgICAgICAgICAgIGNvbnN0IHZhbHVlSW5kZXggPSArdGV4dFBhcnQuc3Vic3RyaW5nKDEsIHRleHRQYXJ0Lmxlbmd0aCAtIDEpO1xuXG4gICAgICAgICAgICBpdGVtLnRlbXBsYXRlUmVmID0gdGhpcy5hcmdzW3ZhbHVlSW5kZXhdO1xuICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBpdGVtLnRleHQgPSB0ZXh0UGFydDtcbiAgICAgICAgICB9XG5cbiAgICAgICAgICB0aGlzLml0ZW1zRm9yRGlzcGxheS5wdXNoKGl0ZW0pO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIGl0ZW1zRm9yRGlzcGxheVwiPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiaXRlbS50ZXh0XCI+e3sgaXRlbS50ZXh0IH19PC9uZy1jb250YWluZXI+XG4gIDxuZy1jb250YWluZXIgKm5nSWY9XCIhaXRlbS50ZXh0ICYmIGl0ZW0udGVtcGxhdGVSZWZcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ1RlbXBsYXRlT3V0bGV0PVwiaXRlbS50ZW1wbGF0ZVJlZlwiPjwvbmctY29udGFpbmVyPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyInlineDeleteAdapterService_instances, _SkyInlineDeleteAdapterService_element, _SkyInlineDeleteAdapterService_focusableElements, _SkyInlineDeleteAdapterService_parentEl, _SkyInlineDeleteAdapterService_parentElUnlistenFn, _SkyInlineDeleteAdapterService_renderer, _SkyInlineDeleteAdapterService_coreAdapterService, _SkyInlineDeleteAdapterService_focusNextElement, _SkyInlineDeleteAdapterService_getFocusableElements, _SkyInlineDeleteAdapterService_isElementHiddenOrCovered, _SkyInlineDeleteAdapterService_isElementHidden, _SkyInlineDeleteAdapterService_isShift;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { Injectable, RendererFactory2 } from '@angular/core';
|
|
2
4
|
import { SkyCoreAdapterService } from '@skyux/core';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
@@ -7,109 +9,115 @@ import * as i1 from "@skyux/core";
|
|
|
7
9
|
*/
|
|
8
10
|
export class SkyInlineDeleteAdapterService {
|
|
9
11
|
constructor(coreAdapterService, rendererFactory) {
|
|
10
|
-
this
|
|
11
|
-
|
|
12
|
+
_SkyInlineDeleteAdapterService_instances.add(this);
|
|
13
|
+
_SkyInlineDeleteAdapterService_element.set(this, void 0);
|
|
14
|
+
_SkyInlineDeleteAdapterService_focusableElements.set(this, void 0);
|
|
15
|
+
_SkyInlineDeleteAdapterService_parentEl.set(this, void 0);
|
|
16
|
+
_SkyInlineDeleteAdapterService_parentElUnlistenFn.set(this, void 0);
|
|
17
|
+
_SkyInlineDeleteAdapterService_renderer.set(this, void 0);
|
|
18
|
+
_SkyInlineDeleteAdapterService_coreAdapterService.set(this, void 0);
|
|
19
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_coreAdapterService, coreAdapterService, "f");
|
|
20
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_renderer, rendererFactory.createRenderer(undefined, null), "f");
|
|
12
21
|
}
|
|
13
22
|
clearListeners() {
|
|
14
23
|
/* istanbul ignore else */
|
|
15
|
-
if (this
|
|
16
|
-
this.
|
|
24
|
+
if (__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentElUnlistenFn, "f")) {
|
|
25
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentElUnlistenFn, "f").call(this);
|
|
17
26
|
}
|
|
18
27
|
}
|
|
19
28
|
setEl(element) {
|
|
20
|
-
this
|
|
21
|
-
this
|
|
29
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_element, element, "f");
|
|
30
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_parentEl, element.parentElement, "f");
|
|
22
31
|
/* istanbul ignore else */
|
|
23
|
-
if (this
|
|
24
|
-
this
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
+
if (__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f")) {
|
|
33
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_parentElUnlistenFn, __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_renderer, "f").listen(__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f"), 'focusin', (event) => {
|
|
34
|
+
if (__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_element, "f")) {
|
|
35
|
+
const target = event.target;
|
|
36
|
+
if (!__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_element, "f").contains(target) && __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f") !== target) {
|
|
37
|
+
event.preventDefault();
|
|
38
|
+
event.stopPropagation();
|
|
39
|
+
event.stopImmediatePropagation();
|
|
40
|
+
target.blur();
|
|
41
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_focusNextElement).call(this, target, __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isShift).call(this, event));
|
|
42
|
+
}
|
|
32
43
|
}
|
|
33
|
-
});
|
|
44
|
+
}), "f");
|
|
34
45
|
}
|
|
35
46
|
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
47
|
+
}
|
|
48
|
+
_SkyInlineDeleteAdapterService_element = new WeakMap(), _SkyInlineDeleteAdapterService_focusableElements = new WeakMap(), _SkyInlineDeleteAdapterService_parentEl = new WeakMap(), _SkyInlineDeleteAdapterService_parentElUnlistenFn = new WeakMap(), _SkyInlineDeleteAdapterService_renderer = new WeakMap(), _SkyInlineDeleteAdapterService_coreAdapterService = new WeakMap(), _SkyInlineDeleteAdapterService_instances = new WeakSet(), _SkyInlineDeleteAdapterService_focusNextElement = function _SkyInlineDeleteAdapterService_focusNextElement(targetElement, shiftKey) {
|
|
49
|
+
const focusable = __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_getFocusableElements).call(this);
|
|
50
|
+
// If shift tab, go in the other direction
|
|
51
|
+
const modifier = shiftKey ? -1 : 1;
|
|
52
|
+
// Find the next navigable element that isn't waiting
|
|
53
|
+
const startingIndex = focusable.indexOf(targetElement);
|
|
54
|
+
let curIndex = startingIndex + modifier;
|
|
55
|
+
while (focusable[curIndex] &&
|
|
56
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHiddenOrCovered).call(this, focusable[curIndex])) {
|
|
57
|
+
curIndex += modifier;
|
|
58
|
+
}
|
|
59
|
+
if (focusable[curIndex] &&
|
|
60
|
+
!__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHiddenOrCovered).call(this, focusable[curIndex])) {
|
|
61
|
+
focusable[curIndex].focus();
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
// Try wrapping the navigation
|
|
65
|
+
/* istanbul ignore next */
|
|
66
|
+
curIndex = modifier > 0 ? 0 : focusable.length - 1;
|
|
67
|
+
/* istanbul ignore next */
|
|
68
|
+
while (curIndex !== startingIndex &&
|
|
69
|
+
focusable[curIndex] &&
|
|
70
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHiddenOrCovered).call(this, focusable[curIndex])) {
|
|
45
71
|
curIndex += modifier;
|
|
46
72
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
73
|
+
/* istanbul ignore else */
|
|
74
|
+
/* sanity check */
|
|
75
|
+
if (focusable[curIndex] &&
|
|
76
|
+
!__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHiddenOrCovered).call(this, focusable[curIndex])) {
|
|
77
|
+
focusable[curIndex].focus();
|
|
50
78
|
}
|
|
51
79
|
else {
|
|
52
|
-
//
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
while (curIndex !== startingIndex &&
|
|
57
|
-
focussable[curIndex] &&
|
|
58
|
-
this.isElementHiddenOrCovered(focussable[curIndex])) {
|
|
59
|
-
curIndex += modifier;
|
|
80
|
+
// No valid target, wipe focus
|
|
81
|
+
// This should never happen in practice due to the multiple inline delete buttons
|
|
82
|
+
if (document.activeElement && document.activeElement.blur) {
|
|
83
|
+
document.activeElement.blur();
|
|
60
84
|
}
|
|
61
|
-
|
|
62
|
-
/* sanity check */
|
|
63
|
-
if (focussable[curIndex] &&
|
|
64
|
-
!this.isElementHiddenOrCovered(focussable[curIndex])) {
|
|
65
|
-
focussable[curIndex].focus();
|
|
66
|
-
}
|
|
67
|
-
else {
|
|
68
|
-
// No valid target, wipe focus
|
|
69
|
-
// This should never happen in practice due to the multiple inline delete buttons
|
|
70
|
-
if (document.activeElement && document.activeElement.blur) {
|
|
71
|
-
document.activeElement.blur();
|
|
72
|
-
}
|
|
73
|
-
document.body.focus();
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
// clear focussableElements list so that if things change between tabbing we know about it
|
|
77
|
-
this.focussableElements = undefined;
|
|
78
|
-
}
|
|
79
|
-
getFocussableElements() {
|
|
80
|
-
// Keep this cached so we can reduce querys
|
|
81
|
-
if (this.focussableElements) {
|
|
82
|
-
return this.focussableElements;
|
|
85
|
+
document.body.focus();
|
|
83
86
|
}
|
|
84
|
-
this.focussableElements = this.coreAdapterService.getFocusableChildren(document.body);
|
|
85
|
-
return this.focussableElements;
|
|
86
|
-
}
|
|
87
|
-
isElementHiddenOrCovered(element) {
|
|
88
|
-
// Check if the element is hidden by css, not within the inline delete, or a wait is covering it
|
|
89
|
-
return (this.isElementHidden(element) ||
|
|
90
|
-
(this.parentEl.contains(element) &&
|
|
91
|
-
(!this.element.contains(element) ||
|
|
92
|
-
this.parentEl.querySelector('.sky-wait-mask') !== null)));
|
|
93
87
|
}
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
88
|
+
// clear focusableElements list so that if things change between tabbing we know about it
|
|
89
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_focusableElements, undefined, "f");
|
|
90
|
+
}, _SkyInlineDeleteAdapterService_getFocusableElements = function _SkyInlineDeleteAdapterService_getFocusableElements() {
|
|
91
|
+
// Keep this cached so we can reduce querys
|
|
92
|
+
if (__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_focusableElements, "f")) {
|
|
93
|
+
return __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_focusableElements, "f");
|
|
97
94
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
(
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
95
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_focusableElements, __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_coreAdapterService, "f").getFocusableChildren(document.body), "f");
|
|
96
|
+
return __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_focusableElements, "f");
|
|
97
|
+
}, _SkyInlineDeleteAdapterService_isElementHiddenOrCovered = function _SkyInlineDeleteAdapterService_isElementHiddenOrCovered(element) {
|
|
98
|
+
// Check if the element is hidden by css, not within the inline delete, or a wait is covering it
|
|
99
|
+
return (__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHidden).call(this, element) ||
|
|
100
|
+
(!!__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f") &&
|
|
101
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f").contains(element) &&
|
|
102
|
+
(!__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_element, "f")?.contains(element) ||
|
|
103
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_parentEl, "f").querySelector('.sky-wait-mask') !== null)));
|
|
104
|
+
}, _SkyInlineDeleteAdapterService_isElementHidden = function _SkyInlineDeleteAdapterService_isElementHidden(element) {
|
|
105
|
+
const style = window.getComputedStyle(element);
|
|
106
|
+
return style.display === 'none' || style.visibility === 'hidden';
|
|
107
|
+
}, _SkyInlineDeleteAdapterService_isShift = function _SkyInlineDeleteAdapterService_isShift(event) {
|
|
108
|
+
// Determine if shift+tab was used based on element order
|
|
109
|
+
const elements = __classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_getFocusableElements).call(this).filter((elem) => !__classPrivateFieldGet(this, _SkyInlineDeleteAdapterService_instances, "m", _SkyInlineDeleteAdapterService_isElementHidden).call(this, elem));
|
|
110
|
+
const previousInd = elements.indexOf(event.relatedTarget);
|
|
111
|
+
const currentInd = elements.indexOf(event.target);
|
|
112
|
+
/* istanbul ignore next */
|
|
113
|
+
return (previousInd === currentInd + 1 ||
|
|
114
|
+
(previousInd === 0 && currentInd === elements.length - 1) ||
|
|
115
|
+
previousInd > currentInd ||
|
|
116
|
+
!event.relatedTarget);
|
|
117
|
+
};
|
|
110
118
|
SkyInlineDeleteAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInlineDeleteAdapterService, deps: [{ token: i1.SkyCoreAdapterService }, { token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
111
119
|
SkyInlineDeleteAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInlineDeleteAdapterService });
|
|
112
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInlineDeleteAdapterService, decorators: [{
|
|
113
121
|
type: Injectable
|
|
114
122
|
}], ctorParameters: function () { return [{ type: i1.SkyCoreAdapterService }, { type: i0.RendererFactory2 }]; } });
|
|
115
|
-
//# 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  private element: HTMLElement;\n  private focussableElements: HTMLElement[];\n  private parentEl: HTMLElement;\n  private parentElUnlistenFn: () => void;\n  private renderer: Renderer2;\n\n  constructor(\n    private coreAdapterService: SkyCoreAdapterService,\n    rendererFactory: RendererFactory2\n  ) {\n    this.renderer = rendererFactory.createRenderer(undefined, undefined);\n  }\n\n  public clearListeners(): void {\n    /* istanbul ignore else */\n    if (this.parentElUnlistenFn) {\n      this.parentElUnlistenFn();\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.parentElUnlistenFn = this.renderer.listen(\n        this.parentEl,\n        'focusin',\n        (event: FocusEvent) => {\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), this.parentEl);\n          }\n        }\n      );\n    }\n  }\n\n  private focusNextElement(\n    targetElement: HTMLElement,\n    shiftKey: boolean,\n    busyEl: Element\n  ): void {\n    const focussable = this.getFocussableElements();\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 = focussable.indexOf(targetElement);\n    let curIndex = startingIndex + modifier;\n    while (\n      focussable[curIndex] &&\n      this.isElementHiddenOrCovered(focussable[curIndex])\n    ) {\n      curIndex += modifier;\n    }\n\n    if (\n      focussable[curIndex] &&\n      !this.isElementHiddenOrCovered(focussable[curIndex])\n    ) {\n      focussable[curIndex].focus();\n    } else {\n      // Try wrapping the navigation\n      /* istanbul ignore next */\n      curIndex = modifier > 0 ? 0 : focussable.length - 1;\n\n      /* istanbul ignore next */\n      while (\n        curIndex !== startingIndex &&\n        focussable[curIndex] &&\n        this.isElementHiddenOrCovered(focussable[curIndex])\n      ) {\n        curIndex += modifier;\n      }\n\n      /* istanbul ignore else */\n      /* sanity check */\n      if (\n        focussable[curIndex] &&\n        !this.isElementHiddenOrCovered(focussable[curIndex])\n      ) {\n        focussable[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 focussableElements list so that if things change between tabbing we know about it\n    this.focussableElements = undefined;\n  }\n\n  private getFocussableElements(): HTMLElement[] {\n    // Keep this cached so we can reduce querys\n    if (this.focussableElements) {\n      return this.focussableElements;\n    }\n\n    this.focussableElements = this.coreAdapterService.getFocusableChildren(\n      document.body\n    );\n\n    return this.focussableElements;\n  }\n\n  private 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.contains(element) &&\n        (!this.element.contains(element) ||\n          this.parentEl.querySelector('.sky-wait-mask') !== null))\n    );\n  }\n\n  private isElementHidden(element: any): boolean {\n    const style = window.getComputedStyle(element);\n    return style.display === 'none' || style.visibility === 'hidden';\n  }\n\n  private isShift(event: Event): boolean {\n    // Determine if shift+tab was used based on element order\n    const elements = this.getFocussableElements().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"]}
|
|
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  #parentElUnlistenFn: (() => 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.#parentElUnlistenFn) {\n      this.#parentElUnlistenFn();\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.#parentElUnlistenFn = 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 querys\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"]}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyInlineDeleteComponent_adapterService, _SkyInlineDeleteComponent_changeDetector, _SkyInlineDeleteComponent_elRef;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { animate, group, query, style, transition, trigger, } from '@angular/animations';
|
|
2
4
|
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
3
5
|
import { SkyCoreAdapterService } from '@skyux/core';
|
|
@@ -13,9 +15,6 @@ import * as i3 from "@skyux/i18n";
|
|
|
13
15
|
let nextId = 0;
|
|
14
16
|
export class SkyInlineDeleteComponent {
|
|
15
17
|
constructor(adapterService, changeDetector, elRef) {
|
|
16
|
-
this.adapterService = adapterService;
|
|
17
|
-
this.changeDetector = changeDetector;
|
|
18
|
-
this.elRef = elRef;
|
|
19
18
|
/**
|
|
20
19
|
* Indicates whether the deletion is pending.
|
|
21
20
|
* @default false
|
|
@@ -32,6 +31,12 @@ export class SkyInlineDeleteComponent {
|
|
|
32
31
|
this.animationState = 'shown';
|
|
33
32
|
this.assistiveTextId = `sky-inline-delete-assistive-text-${++nextId}`;
|
|
34
33
|
this.type = SkyInlineDeleteType.Standard;
|
|
34
|
+
_SkyInlineDeleteComponent_adapterService.set(this, void 0);
|
|
35
|
+
_SkyInlineDeleteComponent_changeDetector.set(this, void 0);
|
|
36
|
+
_SkyInlineDeleteComponent_elRef.set(this, void 0);
|
|
37
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteComponent_adapterService, adapterService, "f");
|
|
38
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteComponent_changeDetector, changeDetector, "f");
|
|
39
|
+
__classPrivateFieldSet(this, _SkyInlineDeleteComponent_elRef, elRef, "f");
|
|
35
40
|
}
|
|
36
41
|
/**
|
|
37
42
|
* Initialization lifecycle hook
|
|
@@ -45,7 +50,7 @@ export class SkyInlineDeleteComponent {
|
|
|
45
50
|
* @internal
|
|
46
51
|
*/
|
|
47
52
|
ngOnDestroy() {
|
|
48
|
-
this.
|
|
53
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteComponent_adapterService, "f").clearListeners();
|
|
49
54
|
this.cancelTriggered.complete();
|
|
50
55
|
this.deleteTriggered.complete();
|
|
51
56
|
}
|
|
@@ -68,7 +73,7 @@ export class SkyInlineDeleteComponent {
|
|
|
68
73
|
*/
|
|
69
74
|
setType(type) {
|
|
70
75
|
this.type = type;
|
|
71
|
-
this.
|
|
76
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteComponent_changeDetector, "f").detectChanges();
|
|
72
77
|
}
|
|
73
78
|
/**
|
|
74
79
|
* Handles actions that should be taken after the inline delete animates
|
|
@@ -80,14 +85,15 @@ export class SkyInlineDeleteComponent {
|
|
|
80
85
|
this.cancelTriggered.emit();
|
|
81
86
|
}
|
|
82
87
|
else {
|
|
83
|
-
this.deleteButton
|
|
88
|
+
this.deleteButton?.nativeElement.focus();
|
|
84
89
|
/* istanbul ignore else */
|
|
85
|
-
if (this
|
|
86
|
-
this.
|
|
90
|
+
if (__classPrivateFieldGet(this, _SkyInlineDeleteComponent_elRef, "f")) {
|
|
91
|
+
__classPrivateFieldGet(this, _SkyInlineDeleteComponent_adapterService, "f").setEl(__classPrivateFieldGet(this, _SkyInlineDeleteComponent_elRef, "f").nativeElement);
|
|
87
92
|
}
|
|
88
93
|
}
|
|
89
94
|
}
|
|
90
95
|
}
|
|
96
|
+
_SkyInlineDeleteComponent_adapterService = new WeakMap(), _SkyInlineDeleteComponent_changeDetector = new WeakMap(), _SkyInlineDeleteComponent_elRef = new WeakMap();
|
|
91
97
|
SkyInlineDeleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyInlineDeleteComponent, deps: [{ token: i1.SkyInlineDeleteAdapterService }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
92
98
|
SkyInlineDeleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", 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"] }, { kind: "pipe", type: i3.SkyLibResourcesPipe, name: "skyLibResources" }], animations: [
|
|
93
99
|
trigger('inlineDeleteAnimation', [
|
|
@@ -158,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
158
164
|
static: false,
|
|
159
165
|
}]
|
|
160
166
|
}] } });
|
|
161
|
-
//# 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   * Indicates whether the deletion is pending.\n   * @default false\n   */\n  @Input()\n  public pending = 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  private deleteButton: ElementRef;\n\n  constructor(\n    private adapterService: SkyInlineDeleteAdapterService,\n    private changeDetector: ChangeDetectorRef,\n    private elRef: ElementRef\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"]}
|
|
167
|
+
//# 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   * Indicates 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"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1sYXlvdXQtdHlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL3BhZ2UvcGFnZS1sYXlvdXQtdHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgU2t5UGFnZUxheW91dFR5cGUgPSAnYXV0bycgfCAnZml0JztcbiJdfQ==
|
|
@@ -1,31 +1,43 @@
|
|
|
1
|
-
|
|
1
|
+
var _SkyPageThemeAdapterService_styleEl, _SkyPageThemeAdapterService_document;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { DOCUMENT } from '@angular/common';
|
|
4
|
+
import { Inject, Injectable } from '@angular/core';
|
|
2
5
|
import * as i0 from "@angular/core";
|
|
3
6
|
/**
|
|
4
7
|
* @internal
|
|
5
8
|
*/
|
|
6
9
|
export class SkyPageThemeAdapterService {
|
|
10
|
+
constructor(document) {
|
|
11
|
+
_SkyPageThemeAdapterService_styleEl.set(this, void 0);
|
|
12
|
+
_SkyPageThemeAdapterService_document.set(this, void 0);
|
|
13
|
+
__classPrivateFieldSet(this, _SkyPageThemeAdapterService_document, document, "f");
|
|
14
|
+
}
|
|
7
15
|
/**
|
|
8
16
|
* We can't use ViewEncapsulation.None for this behavior because Angular does
|
|
9
17
|
* not remove `style` tags from the HEAD element after route changes.
|
|
10
18
|
* @see https://github.com/angular/angular/issues/16670
|
|
11
19
|
*/
|
|
12
20
|
addTheme() {
|
|
13
|
-
if (!this
|
|
14
|
-
this
|
|
15
|
-
this.
|
|
16
|
-
|
|
21
|
+
if (!__classPrivateFieldGet(this, _SkyPageThemeAdapterService_styleEl, "f")) {
|
|
22
|
+
__classPrivateFieldSet(this, _SkyPageThemeAdapterService_styleEl, __classPrivateFieldGet(this, _SkyPageThemeAdapterService_document, "f").createElement('style'), "f");
|
|
23
|
+
__classPrivateFieldGet(this, _SkyPageThemeAdapterService_styleEl, "f").appendChild(__classPrivateFieldGet(this, _SkyPageThemeAdapterService_document, "f").createTextNode('body:not(.sky-theme-modern) { background-color: #fff; }'));
|
|
24
|
+
__classPrivateFieldGet(this, _SkyPageThemeAdapterService_document, "f").head.appendChild(__classPrivateFieldGet(this, _SkyPageThemeAdapterService_styleEl, "f"));
|
|
17
25
|
}
|
|
18
26
|
}
|
|
19
27
|
removeTheme() {
|
|
20
|
-
if (this
|
|
21
|
-
|
|
22
|
-
this
|
|
28
|
+
if (__classPrivateFieldGet(this, _SkyPageThemeAdapterService_styleEl, "f")) {
|
|
29
|
+
__classPrivateFieldGet(this, _SkyPageThemeAdapterService_styleEl, "f").remove();
|
|
30
|
+
__classPrivateFieldSet(this, _SkyPageThemeAdapterService_styleEl, undefined, "f");
|
|
23
31
|
}
|
|
24
32
|
}
|
|
25
33
|
}
|
|
26
|
-
|
|
34
|
+
_SkyPageThemeAdapterService_styleEl = new WeakMap(), _SkyPageThemeAdapterService_document = new WeakMap();
|
|
35
|
+
SkyPageThemeAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyPageThemeAdapterService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
27
36
|
SkyPageThemeAdapterService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyPageThemeAdapterService });
|
|
28
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyPageThemeAdapterService, decorators: [{
|
|
29
38
|
type: Injectable
|
|
30
|
-
}]
|
|
31
|
-
|
|
39
|
+
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
40
|
+
type: Inject,
|
|
41
|
+
args: [DOCUMENT]
|
|
42
|
+
}] }]; } });
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10aGVtZS1hZGFwdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UtdGhlbWUtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVuRDs7R0FFRztBQUVILE1BQU0sT0FBTywwQkFBMEI7SUFLckMsWUFBOEIsUUFBa0I7UUFKaEQsc0RBQXVDO1FBRXZDLHVEQUFvQjtRQUdsQix1QkFBQSxJQUFJLHdDQUFhLFFBQVEsTUFBQSxDQUFDO0lBQzVCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksUUFBUTtRQUNiLElBQUksQ0FBQyx1QkFBQSxJQUFJLDJDQUFTLEVBQUU7WUFDbEIsdUJBQUEsSUFBSSx1Q0FBWSx1QkFBQSxJQUFJLDRDQUFVLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxNQUFBLENBQUM7WUFDdEQsdUJBQUEsSUFBSSwyQ0FBUyxDQUFDLFdBQVcsQ0FDdkIsdUJBQUEsSUFBSSw0Q0FBVSxDQUFDLGNBQWMsQ0FDM0IseURBQXlELENBQzFELENBQ0YsQ0FBQztZQUVGLHVCQUFBLElBQUksNENBQVUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHVCQUFBLElBQUksMkNBQVMsQ0FBQyxDQUFDO1NBQ2hEO0lBQ0gsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSx1QkFBQSxJQUFJLDJDQUFTLEVBQUU7WUFDakIsdUJBQUEsSUFBSSwyQ0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3ZCLHVCQUFBLElBQUksdUNBQVksU0FBUyxNQUFBLENBQUM7U0FDM0I7SUFDSCxDQUFDOzs7dUhBaENVLDBCQUEwQixrQkFLakIsUUFBUTsySEFMakIsMEJBQTBCOzJGQUExQiwwQkFBMEI7a0JBRHRDLFVBQVU7MERBTStCLFFBQVE7MEJBQW5DLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5UGFnZVRoZW1lQWRhcHRlclNlcnZpY2Uge1xuICAjc3R5bGVFbDogSFRNTFN0eWxlRWxlbWVudCB8IHVuZGVmaW5lZDtcblxuICAjZG9jdW1lbnQ6IERvY3VtZW50O1xuXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoRE9DVU1FTlQpIGRvY3VtZW50OiBEb2N1bWVudCkge1xuICAgIHRoaXMuI2RvY3VtZW50ID0gZG9jdW1lbnQ7XG4gIH1cblxuICAvKipcbiAgICogV2UgY2FuJ3QgdXNlIFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUgZm9yIHRoaXMgYmVoYXZpb3IgYmVjYXVzZSBBbmd1bGFyIGRvZXNcbiAgICogbm90IHJlbW92ZSBgc3R5bGVgIHRhZ3MgZnJvbSB0aGUgSEVBRCBlbGVtZW50IGFmdGVyIHJvdXRlIGNoYW5nZXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2FuZ3VsYXIvYW5ndWxhci9pc3N1ZXMvMTY2NzBcbiAgICovXG4gIHB1YmxpYyBhZGRUaGVtZSgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuI3N0eWxlRWwpIHtcbiAgICAgIHRoaXMuI3N0eWxlRWwgPSB0aGlzLiNkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgdGhpcy4jc3R5bGVFbC5hcHBlbmRDaGlsZChcbiAgICAgICAgdGhpcy4jZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoXG4gICAgICAgICAgJ2JvZHk6bm90KC5za3ktdGhlbWUtbW9kZXJuKSB7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IH0nXG4gICAgICAgIClcbiAgICAgICk7XG5cbiAgICAgIHRoaXMuI2RvY3VtZW50LmhlYWQuYXBwZW5kQ2hpbGQodGhpcy4jc3R5bGVFbCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHJlbW92ZVRoZW1lKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLiNzdHlsZUVsKSB7XG4gICAgICB0aGlzLiNzdHlsZUVsLnJlbW92ZSgpO1xuICAgICAgdGhpcy4jc3R5bGVFbCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
|