@skyux/layout 7.0.0-beta.1 → 7.0.0-beta.10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (82) hide show
  1. package/documentation.json +1543 -826
  2. package/esm2020/index.mjs +2 -2
  3. package/esm2020/lib/modules/action-button/action-button-container.component.mjs +2 -2
  4. package/esm2020/lib/modules/back-to-top/back-to-top.directive.mjs +2 -2
  5. package/esm2020/lib/modules/card/card.component.mjs +38 -11
  6. package/esm2020/lib/modules/definition-list/definition-list-label.component.mjs +1 -1
  7. package/esm2020/lib/modules/definition-list/definition-list-value.component.mjs +3 -3
  8. package/esm2020/lib/modules/definition-list/definition-list.component.mjs +1 -1
  9. package/esm2020/lib/modules/definition-list/definition-list.service.mjs +1 -1
  10. package/esm2020/lib/modules/description-list/description-list-adapter-service.mjs +26 -22
  11. package/esm2020/lib/modules/description-list/description-list-content.component.mjs +2 -2
  12. package/esm2020/lib/modules/description-list/description-list-description.component.mjs +16 -11
  13. package/esm2020/lib/modules/description-list/description-list-term.component.mjs +1 -1
  14. package/esm2020/lib/modules/description-list/description-list.component.mjs +25 -16
  15. package/esm2020/lib/modules/fluid-grid/column.component.mjs +19 -1
  16. package/esm2020/lib/modules/fluid-grid/fluid-grid.component.mjs +15 -35
  17. package/esm2020/lib/modules/fluid-grid/row.component.mjs +1 -1
  18. package/esm2020/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.mjs +1 -1
  19. package/esm2020/lib/modules/format/format.component.mjs +34 -26
  20. package/esm2020/lib/modules/inline-delete/inline-delete-adapter.service.mjs +91 -83
  21. package/esm2020/lib/modules/inline-delete/inline-delete.component.mjs +15 -9
  22. package/esm2020/lib/modules/page/page-layout-type.mjs +2 -0
  23. package/esm2020/lib/modules/page/page-theme-adapter.service.mjs +23 -11
  24. package/esm2020/lib/modules/page/page.component.mjs +28 -9
  25. package/esm2020/lib/modules/page/page.module.mjs +5 -3
  26. package/esm2020/lib/modules/page-summary/page-summary-adapter.service.mjs +1 -1
  27. package/esm2020/lib/modules/page-summary/page-summary.component.mjs +40 -16
  28. package/esm2020/lib/modules/text-expand/text-expand-adapter.service.mjs +8 -10
  29. package/esm2020/lib/modules/text-expand/text-expand-modal-context-token.mjs +6 -0
  30. package/esm2020/lib/modules/text-expand/text-expand-modal-context.mjs +2 -6
  31. package/esm2020/lib/modules/text-expand/text-expand-modal.component.mjs +12 -10
  32. package/esm2020/lib/modules/text-expand/text-expand.component.mjs +188 -127
  33. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.mjs +10 -12
  34. package/esm2020/lib/modules/text-expand-repeater/text-expand-repeater.component.mjs +139 -95
  35. package/esm2020/lib/modules/toolbar/toolbar.component.mjs +2 -2
  36. package/esm2020/testing/action-button-fixture.mjs +12 -6
  37. package/esm2020/testing/card-fixture.mjs +19 -16
  38. package/esm2020/testing/page-summary-fixture.mjs +9 -5
  39. package/fesm2015/skyux-layout-testing.mjs +35 -24
  40. package/fesm2015/skyux-layout-testing.mjs.map +1 -1
  41. package/fesm2015/skyux-layout.mjs +707 -516
  42. package/fesm2015/skyux-layout.mjs.map +1 -1
  43. package/fesm2020/skyux-layout-testing.mjs +35 -24
  44. package/fesm2020/skyux-layout-testing.mjs.map +1 -1
  45. package/fesm2020/skyux-layout.mjs +699 -516
  46. package/fesm2020/skyux-layout.mjs.map +1 -1
  47. package/index.d.ts +1 -1
  48. package/lib/modules/back-to-top/back-to-top.directive.d.ts +1 -1
  49. package/lib/modules/card/card.component.d.ts +7 -6
  50. package/lib/modules/definition-list/definition-list-label.component.d.ts +1 -1
  51. package/lib/modules/definition-list/definition-list-value.component.d.ts +1 -1
  52. package/lib/modules/definition-list/definition-list.component.d.ts +2 -2
  53. package/lib/modules/definition-list/definition-list.service.d.ts +2 -2
  54. package/lib/modules/description-list/description-list-adapter-service.d.ts +1 -2
  55. package/lib/modules/description-list/description-list-content.component.d.ts +2 -2
  56. package/lib/modules/description-list/description-list-description.component.d.ts +5 -7
  57. package/lib/modules/description-list/description-list-term.component.d.ts +1 -1
  58. package/lib/modules/description-list/description-list.component.d.ts +6 -7
  59. package/lib/modules/fluid-grid/column.component.d.ts +7 -5
  60. package/lib/modules/fluid-grid/fluid-grid.component.d.ts +3 -9
  61. package/lib/modules/fluid-grid/row.component.d.ts +1 -1
  62. package/lib/modules/fluid-grid/types/fluid-grid-gutter-size-type.d.ts +1 -1
  63. package/lib/modules/format/format.component.d.ts +5 -7
  64. package/lib/modules/inline-delete/inline-delete-adapter.service.d.ts +1 -11
  65. package/lib/modules/inline-delete/inline-delete.component.d.ts +3 -5
  66. package/lib/modules/page/page-layout-type.d.ts +1 -0
  67. package/lib/modules/page/page-theme-adapter.service.d.ts +2 -1
  68. package/lib/modules/page/page.component.d.ts +11 -3
  69. package/lib/modules/page/page.module.d.ts +2 -1
  70. package/lib/modules/page-summary/page-summary.component.d.ts +8 -9
  71. package/lib/modules/text-expand/text-expand-adapter.service.d.ts +3 -4
  72. package/lib/modules/text-expand/text-expand-modal-context-token.d.ts +6 -0
  73. package/lib/modules/text-expand/text-expand-modal-context.d.ts +1 -1
  74. package/lib/modules/text-expand/text-expand.component.d.ts +18 -25
  75. package/lib/modules/text-expand-repeater/text-expand-repeater-adapter.service.d.ts +4 -5
  76. package/lib/modules/text-expand-repeater/text-expand-repeater.component.d.ts +13 -21
  77. package/package.json +9 -9
  78. package/testing/action-button-fixture.d.ts +4 -4
  79. package/testing/card-fixture.d.ts +3 -5
  80. package/testing/page-summary-fixture.d.ts +4 -4
  81. package/esm2020/lib/modules/fluid-grid/fluid-grid-gutter-size.mjs +0 -20
  82. 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._text = value;
12
- this.updateItemsForDisplay();
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._text;
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._args = value;
23
- this.updateItemsForDisplay();
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._args;
34
+ return __classPrivateFieldGet(this, _SkyFormatComponent__args, "f");
27
35
  }
28
- updateItemsForDisplay() {
29
- this.itemsForDisplay = [];
30
- if (this.text && this.args) {
31
- const textParts = this.text.split(tokenRegex);
32
- for (const textPart of textParts) {
33
- // Disregard empty strings.
34
- if (textPart) {
35
- const item = {};
36
- if (tokenRegex.test(textPart)) {
37
- const valueIndex = +textPart.substring(1, textPart.length - 1);
38
- item.templateRef = this.args[valueIndex];
39
- }
40
- else {
41
- item.text = textPart;
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 <!--\n The following ng-container must be on one line so no extra whitespace is introduced.\n -->\n <ng-container *ngIf=\"item.text; else item.templateRef\">{{\n item.text\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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
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 <!--\n The following ng-container must be on one line so no extra whitespace is introduced.\n -->\n <ng-container *ngIf=\"item.text; else item.templateRef\">{{\n item.text\n }}</ng-container>\n</ng-container>\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWF0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvc3JjL2xpYi9tb2R1bGVzL2Zvcm1hdC9mb3JtYXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC9zcmMvbGliL21vZHVsZXMvZm9ybWF0L2Zvcm1hdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxLQUFLLEdBRU4sTUFBTSxlQUFlLENBQUM7OztBQUl2QixNQUFNLFVBQVUsR0FBRyxXQUFXLENBQUM7QUFPL0IsTUFBTSxPQUFPLGtCQUFrQjtJQUc3Qjs7O09BR0c7SUFDSCxJQUNXLElBQUksQ0FBQyxLQUFhO1FBQzNCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFXLElBQUk7UUFDYixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVEOzs7T0FHRztJQUNILElBQ1csSUFBSSxDQUFDLEtBQXlCO1FBQ3ZDLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBQ25CLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQy9CLENBQUM7SUFFRCxJQUFXLElBQUk7UUFDYixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQU1PLHFCQUFxQjtRQUMzQixJQUFJLENBQUMsZUFBZSxHQUFHLEVBQUUsQ0FBQztRQUUxQixJQUFJLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLElBQUksRUFBRTtZQUMxQixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsQ0FBQztZQUU5QyxLQUFLLE1BQU0sUUFBUSxJQUFJLFNBQVMsRUFBRTtnQkFDaEMsMkJBQTJCO2dCQUMzQixJQUFJLFFBQVEsRUFBRTtvQkFDWixNQUFNLElBQUksR0FBa0IsRUFBRSxDQUFDO29CQUUvQixJQUFJLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLEVBQUU7d0JBQzdCLE1BQU0sVUFBVSxHQUFHLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsUUFBUSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsQ0FBQzt3QkFFL0QsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO3FCQUMxQzt5QkFBTTt3QkFDTCxJQUFJLENBQUMsSUFBSSxHQUFHLFFBQVEsQ0FBQztxQkFDdEI7b0JBRUQsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7aUJBQ2pDO2FBQ0Y7U0FDRjtJQUNILENBQUM7OytHQTFEVSxrQkFBa0I7bUdBQWxCLGtCQUFrQiwwRkNoQi9CLHNSQVFBOzJGRFFhLGtCQUFrQjtrQkFMOUIsU0FBUzsrQkFDRSxZQUFZLG1CQUVMLHVCQUF1QixDQUFDLE1BQU07OEJBVXBDLElBQUk7c0JBRGQsS0FBSztnQkFlSyxJQUFJO3NCQURkLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgVGVtcGxhdGVSZWYsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBTa3lGb3JtYXRJdGVtIH0gZnJvbSAnLi9mb3JtYXQtaXRlbSc7XG5cbmNvbnN0IHRva2VuUmVnZXggPSAvKFxce1xcZCtcXH0pLztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnc2t5LWZvcm1hdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9mb3JtYXQuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgU2t5Rm9ybWF0Q29tcG9uZW50IHtcbiAgcHVibGljIGl0ZW1zRm9yRGlzcGxheTogU2t5Rm9ybWF0SXRlbVtdO1xuXG4gIC8qKlxuICAgKiBUaGUgdG9rZW5pemVkIHN0cmluZyB0aGF0IHJlcHJlc2VudHMgdGhlIHRlbXBsYXRlLiBUb2tlbnMgdXNlIHRoZSBge259YCBub3RhdGlvblxuICAgKiB3aGVyZSBgbmAgaXMgdGhlIG9yZGluYWwgb2YgdGhlIGl0ZW0gdG8gcmVwbGFjZSB0aGUgdG9rZW4uXG4gICAqL1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2V0IHRleHQodmFsdWU6IHN0cmluZykge1xuICAgIHRoaXMuX3RleHQgPSB2YWx1ZTtcbiAgICB0aGlzLnVwZGF0ZUl0ZW1zRm9yRGlzcGxheSgpO1xuICB9XG5cbiAgcHVibGljIGdldCB0ZXh0KCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuX3RleHQ7XG4gIH1cblxuICAvKipcbiAgICogQW4gYXJyYXkgb2YgYFRlbXBsYXRlUmVmYCBvYmplY3RzIHRvIGJlIHBsYWNlZCBpbiB0aGUgdGVtcGxhdGUsIHdoZXJlIHRoZSBgbnRoYFxuICAgKiBpdGVtIGlzIHBsYWNlZCBhdCB0aGUgYHtufWAgbG9jYXRpb24gaW4gdGhlIHRlbXBsYXRlLlxuICAgKi9cbiAgQElucHV0KClcbiAgcHVibGljIHNldCBhcmdzKHZhbHVlOiBUZW1wbGF0ZVJlZjxhbnk+W10pIHtcbiAgICB0aGlzLl9hcmdzID0gdmFsdWU7XG4gICAgdGhpcy51cGRhdGVJdGVtc0ZvckRpc3BsYXkoKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgYXJncygpOiBUZW1wbGF0ZVJlZjxhbnk+W10ge1xuICAgIHJldHVybiB0aGlzLl9hcmdzO1xuICB9XG5cbiAgcHJpdmF0ZSBfdGV4dDogc3RyaW5nO1xuXG4gIHByaXZhdGUgX2FyZ3M6IFRlbXBsYXRlUmVmPGFueT5bXTtcblxuICBwcml2YXRlIHVwZGF0ZUl0ZW1zRm9yRGlzcGxheSgpOiB2b2lkIHtcbiAgICB0aGlzLml0ZW1zRm9yRGlzcGxheSA9IFtdO1xuXG4gICAgaWYgKHRoaXMudGV4dCAmJiB0aGlzLmFyZ3MpIHtcbiAgICAgIGNvbnN0IHRleHRQYXJ0cyA9IHRoaXMudGV4dC5zcGxpdCh0b2tlblJlZ2V4KTtcblxuICAgICAgZm9yIChjb25zdCB0ZXh0UGFydCBvZiB0ZXh0UGFydHMpIHtcbiAgICAgICAgLy8gRGlzcmVnYXJkIGVtcHR5IHN0cmluZ3MuXG4gICAgICAgIGlmICh0ZXh0UGFydCkge1xuICAgICAgICAgIGNvbnN0IGl0ZW06IFNreUZvcm1hdEl0ZW0gPSB7fTtcblxuICAgICAgICAgIGlmICh0b2tlblJlZ2V4LnRlc3QodGV4dFBhcnQpKSB7XG4gICAgICAgICAgICBjb25zdCB2YWx1ZUluZGV4ID0gK3RleHRQYXJ0LnN1YnN0cmluZygxLCB0ZXh0UGFydC5sZW5ndGggLSAxKTtcblxuICAgICAgICAgICAgaXRlbS50ZW1wbGF0ZVJlZiA9IHRoaXMuYXJnc1t2YWx1ZUluZGV4XTtcbiAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgaXRlbS50ZXh0ID0gdGV4dFBhcnQ7XG4gICAgICAgICAgfVxuXG4gICAgICAgICAgdGhpcy5pdGVtc0ZvckRpc3BsYXkucHVzaChpdGVtKTtcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIiwiPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiBpdGVtc0ZvckRpc3BsYXlcIj5cbiAgPCEtLVxuICAgIFRoZSBmb2xsb3dpbmcgbmctY29udGFpbmVyIG11c3QgYmUgb24gb25lIGxpbmUgc28gbm8gZXh0cmEgd2hpdGVzcGFjZSBpcyBpbnRyb2R1Y2VkLlxuICAtLT5cbiAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIml0ZW0udGV4dDsgZWxzZSBpdGVtLnRlbXBsYXRlUmVmXCI+e3tcbiAgICBpdGVtLnRleHRcbiAgfX08L25nLWNvbnRhaW5lcj5cbjwvbmctY29udGFpbmVyPlxuIl19
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.coreAdapterService = coreAdapterService;
11
- this.renderer = rendererFactory.createRenderer(undefined, undefined);
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.parentElUnlistenFn) {
16
- this.parentElUnlistenFn();
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.element = element;
21
- this.parentEl = element.parentElement;
29
+ __classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_element, element, "f");
30
+ __classPrivateFieldSet(this, _SkyInlineDeleteAdapterService_parentEl, element.parentElement, "f");
22
31
  /* istanbul ignore else */
23
- if (this.parentEl) {
24
- this.parentElUnlistenFn = this.renderer.listen(this.parentEl, 'focusin', (event) => {
25
- const target = event.target;
26
- if (!this.element.contains(target) && this.parentEl !== target) {
27
- event.preventDefault();
28
- event.stopPropagation();
29
- event.stopImmediatePropagation();
30
- target.blur();
31
- this.focusNextElement(target, this.isShift(event), this.parentEl);
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
- focusNextElement(targetElement, shiftKey, busyEl) {
37
- const focussable = this.getFocussableElements();
38
- // If shift tab, go in the other direction
39
- const modifier = shiftKey ? -1 : 1;
40
- // Find the next navigable element that isn't waiting
41
- const startingIndex = focussable.indexOf(targetElement);
42
- let curIndex = startingIndex + modifier;
43
- while (focussable[curIndex] &&
44
- this.isElementHiddenOrCovered(focussable[curIndex])) {
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
- if (focussable[curIndex] &&
48
- !this.isElementHiddenOrCovered(focussable[curIndex])) {
49
- focussable[curIndex].focus();
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
- // Try wrapping the navigation
53
- /* istanbul ignore next */
54
- curIndex = modifier > 0 ? 0 : focussable.length - 1;
55
- /* istanbul ignore next */
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
- /* istanbul ignore else */
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
- isElementHidden(element) {
95
- const style = window.getComputedStyle(element);
96
- return style.display === 'none' || style.visibility === 'hidden';
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
- isShift(event) {
99
- // Determine if shift+tab was used based on element order
100
- const elements = this.getFocussableElements().filter((elem) => !this.isElementHidden(elem));
101
- const previousInd = elements.indexOf(event.relatedTarget);
102
- const currentInd = elements.indexOf(event.target);
103
- /* istanbul ignore next */
104
- return (previousInd === currentInd + 1 ||
105
- (previousInd === 0 && currentInd === elements.length - 1) ||
106
- previousInd > currentInd ||
107
- !event.relatedTarget);
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.adapterService.clearListeners();
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.changeDetector.detectChanges();
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.nativeElement.focus();
88
+ this.deleteButton?.nativeElement.focus();
84
89
  /* istanbul ignore else */
85
- if (this.elRef) {
86
- this.adapterService.setEl(this.elRef.nativeElement);
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
- import { Injectable } from '@angular/core';
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.styleEl) {
14
- this.styleEl = document.createElement('style');
15
- this.styleEl.appendChild(document.createTextNode('body { background-color: #fff; }'));
16
- document.head.appendChild(this.styleEl);
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.styleEl) {
21
- document.head.removeChild(this.styleEl);
22
- this.styleEl = undefined;
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
- SkyPageThemeAdapterService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyPageThemeAdapterService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10aGVtZS1hZGFwdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UtdGhlbWUtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRTNDOztHQUVHO0FBRUgsTUFBTSxPQUFPLDBCQUEwQjtJQUdyQzs7OztPQUlHO0lBQ0ksUUFBUTtRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2pCLElBQUksQ0FBQyxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUMvQyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FDdEIsUUFBUSxDQUFDLGNBQWMsQ0FBQyxrQ0FBa0MsQ0FBQyxDQUM1RCxDQUFDO1lBRUYsUUFBUSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ3pDO0lBQ0gsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSxJQUFJLENBQUMsT0FBTyxFQUFFO1lBQ2hCLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUN4QyxJQUFJLENBQUMsT0FBTyxHQUFHLFNBQVMsQ0FBQztTQUMxQjtJQUNILENBQUM7O3VIQXhCVSwwQkFBMEI7MkhBQTFCLDBCQUEwQjsyRkFBMUIsMEJBQTBCO2tCQUR0QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5UGFnZVRoZW1lQWRhcHRlclNlcnZpY2Uge1xuICBwcml2YXRlIHN0eWxlRWw6IEhUTUxTdHlsZUVsZW1lbnQ7XG5cbiAgLyoqXG4gICAqIFdlIGNhbid0IHVzZSBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lIGZvciB0aGlzIGJlaGF2aW9yIGJlY2F1c2UgQW5ndWxhciBkb2VzXG4gICAqIG5vdCByZW1vdmUgYHN0eWxlYCB0YWdzIGZyb20gdGhlIEhFQUQgZWxlbWVudCBhZnRlciByb3V0ZSBjaGFuZ2VzLlxuICAgKiBAc2VlIGh0dHBzOi8vZ2l0aHViLmNvbS9hbmd1bGFyL2FuZ3VsYXIvaXNzdWVzLzE2NjcwXG4gICAqL1xuICBwdWJsaWMgYWRkVGhlbWUoKTogdm9pZCB7XG4gICAgaWYgKCF0aGlzLnN0eWxlRWwpIHtcbiAgICAgIHRoaXMuc3R5bGVFbCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3N0eWxlJyk7XG4gICAgICB0aGlzLnN0eWxlRWwuYXBwZW5kQ2hpbGQoXG4gICAgICAgIGRvY3VtZW50LmNyZWF0ZVRleHROb2RlKCdib2R5IHsgYmFja2dyb3VuZC1jb2xvcjogI2ZmZjsgfScpXG4gICAgICApO1xuXG4gICAgICBkb2N1bWVudC5oZWFkLmFwcGVuZENoaWxkKHRoaXMuc3R5bGVFbCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHJlbW92ZVRoZW1lKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLnN0eWxlRWwpIHtcbiAgICAgIGRvY3VtZW50LmhlYWQucmVtb3ZlQ2hpbGQodGhpcy5zdHlsZUVsKTtcbiAgICAgIHRoaXMuc3R5bGVFbCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
39
+ }], ctorParameters: function () { return [{ type: Document, decorators: [{
40
+ type: Inject,
41
+ args: [DOCUMENT]
42
+ }] }]; } });
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10aGVtZS1hZGFwdGVyLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3NyYy9saWIvbW9kdWxlcy9wYWdlL3BhZ2UtdGhlbWUtYWRhcHRlci5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7O0FBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNDLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVuRDs7R0FFRztBQUVILE1BQU0sT0FBTywwQkFBMEI7SUFLckMsWUFBOEIsUUFBa0I7UUFKaEQsc0RBQXVDO1FBRXZDLHVEQUFvQjtRQUdsQix1QkFBQSxJQUFJLHdDQUFhLFFBQVEsTUFBQSxDQUFDO0lBQzVCLENBQUM7SUFFRDs7OztPQUlHO0lBQ0ksUUFBUTtRQUNiLElBQUksQ0FBQyx1QkFBQSxJQUFJLDJDQUFTLEVBQUU7WUFDbEIsdUJBQUEsSUFBSSx1Q0FBWSx1QkFBQSxJQUFJLDRDQUFVLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxNQUFBLENBQUM7WUFDdEQsdUJBQUEsSUFBSSwyQ0FBUyxDQUFDLFdBQVcsQ0FDdkIsdUJBQUEsSUFBSSw0Q0FBVSxDQUFDLGNBQWMsQ0FDM0IseURBQXlELENBQzFELENBQ0YsQ0FBQztZQUVGLHVCQUFBLElBQUksNENBQVUsQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLHVCQUFBLElBQUksMkNBQVMsQ0FBQyxDQUFDO1NBQ2hEO0lBQ0gsQ0FBQztJQUVNLFdBQVc7UUFDaEIsSUFBSSx1QkFBQSxJQUFJLDJDQUFTLEVBQUU7WUFDakIsdUJBQUEsSUFBSSwyQ0FBUyxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3ZCLHVCQUFBLElBQUksdUNBQVksU0FBUyxNQUFBLENBQUM7U0FDM0I7SUFDSCxDQUFDOzs7dUhBaENVLDBCQUEwQixrQkFLakIsUUFBUTsySEFMakIsMEJBQTBCOzJGQUExQiwwQkFBMEI7a0JBRHRDLFVBQVU7MERBTStCLFFBQVE7MEJBQW5DLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIEBpbnRlcm5hbFxuICovXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgU2t5UGFnZVRoZW1lQWRhcHRlclNlcnZpY2Uge1xuICAjc3R5bGVFbDogSFRNTFN0eWxlRWxlbWVudCB8IHVuZGVmaW5lZDtcblxuICAjZG9jdW1lbnQ6IERvY3VtZW50O1xuXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoRE9DVU1FTlQpIGRvY3VtZW50OiBEb2N1bWVudCkge1xuICAgIHRoaXMuI2RvY3VtZW50ID0gZG9jdW1lbnQ7XG4gIH1cblxuICAvKipcbiAgICogV2UgY2FuJ3QgdXNlIFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUgZm9yIHRoaXMgYmVoYXZpb3IgYmVjYXVzZSBBbmd1bGFyIGRvZXNcbiAgICogbm90IHJlbW92ZSBgc3R5bGVgIHRhZ3MgZnJvbSB0aGUgSEVBRCBlbGVtZW50IGFmdGVyIHJvdXRlIGNoYW5nZXMuXG4gICAqIEBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2FuZ3VsYXIvYW5ndWxhci9pc3N1ZXMvMTY2NzBcbiAgICovXG4gIHB1YmxpYyBhZGRUaGVtZSgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuI3N0eWxlRWwpIHtcbiAgICAgIHRoaXMuI3N0eWxlRWwgPSB0aGlzLiNkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdzdHlsZScpO1xuICAgICAgdGhpcy4jc3R5bGVFbC5hcHBlbmRDaGlsZChcbiAgICAgICAgdGhpcy4jZG9jdW1lbnQuY3JlYXRlVGV4dE5vZGUoXG4gICAgICAgICAgJ2JvZHk6bm90KC5za3ktdGhlbWUtbW9kZXJuKSB7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IH0nXG4gICAgICAgIClcbiAgICAgICk7XG5cbiAgICAgIHRoaXMuI2RvY3VtZW50LmhlYWQuYXBwZW5kQ2hpbGQodGhpcy4jc3R5bGVFbCk7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIHJlbW92ZVRoZW1lKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLiNzdHlsZUVsKSB7XG4gICAgICB0aGlzLiNzdHlsZUVsLnJlbW92ZSgpO1xuICAgICAgdGhpcy4jc3R5bGVFbCA9IHVuZGVmaW5lZDtcbiAgICB9XG4gIH1cbn1cbiJdfQ==