@skyux/layout 11.22.0 → 11.23.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/documentation.json +950 -849
- package/esm2022/lib/modules/box/box.component.mjs +2 -2
- package/esm2022/testing/legacy/action-button-fixture.mjs +48 -0
- package/esm2022/testing/legacy/card-fixture.mjs +65 -0
- package/esm2022/testing/legacy/page-summary-fixture.mjs +31 -0
- package/esm2022/testing/modules/box/box-harness.filters.mjs +2 -0
- package/esm2022/testing/modules/box/box-harness.mjs +109 -0
- package/esm2022/testing/modules/fluid-grid/column-harness-filters.mjs +2 -0
- package/esm2022/testing/modules/fluid-grid/column-harness.mjs +61 -0
- package/esm2022/testing/modules/fluid-grid/fluid-grid-harness-filters.mjs +2 -0
- package/esm2022/testing/modules/fluid-grid/fluid-grid-harness.mjs +50 -0
- package/esm2022/testing/modules/fluid-grid/row-harness-filters.mjs +2 -0
- package/esm2022/testing/modules/fluid-grid/row-harness.mjs +35 -0
- package/esm2022/testing/public-api.mjs +8 -8
- package/fesm2022/skyux-layout-testing.mjs +9 -9
- package/fesm2022/skyux-layout-testing.mjs.map +1 -1
- package/fesm2022/skyux-layout.mjs +2 -2
- package/package.json +11 -11
- package/testing/public-api.d.ts +11 -11
- package/esm2022/testing/action-button-fixture.mjs +0 -48
- package/esm2022/testing/box/box-harness.filters.mjs +0 -2
- package/esm2022/testing/box/box-harness.mjs +0 -109
- package/esm2022/testing/card-fixture.mjs +0 -65
- package/esm2022/testing/fluid-grid/column-harness-filters.mjs +0 -2
- package/esm2022/testing/fluid-grid/column-harness.mjs +0 -61
- package/esm2022/testing/fluid-grid/fluid-grid-harness-filters.mjs +0 -2
- package/esm2022/testing/fluid-grid/fluid-grid-harness.mjs +0 -50
- package/esm2022/testing/fluid-grid/row-harness-filters.mjs +0 -2
- package/esm2022/testing/fluid-grid/row-harness.mjs +0 -35
- package/esm2022/testing/page-summary-fixture.mjs +0 -31
- /package/testing/{action-button-fixture.d.ts → legacy/action-button-fixture.d.ts} +0 -0
- /package/testing/{card-fixture.d.ts → legacy/card-fixture.d.ts} +0 -0
- /package/testing/{page-summary-fixture.d.ts → legacy/page-summary-fixture.d.ts} +0 -0
- /package/testing/{box → modules/box}/box-harness.d.ts +0 -0
- /package/testing/{box → modules/box}/box-harness.filters.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/column-harness-filters.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/column-harness.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/fluid-grid-harness-filters.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/fluid-grid-harness.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/row-harness-filters.d.ts +0 -0
- /package/testing/{fluid-grid → modules/fluid-grid}/row-harness.d.ts +0 -0
|
@@ -69,7 +69,7 @@ export class SkyBoxComponent {
|
|
|
69
69
|
return idService.generateId();
|
|
70
70
|
},
|
|
71
71
|
},
|
|
72
|
-
], queries: [{ propertyName: "boxHeaderRef", first: true, predicate: SkyBoxHeaderComponent, descendants: true, read: ElementRef }, { propertyName: "boxControls", first: true, predicate: SkyBoxControlsComponent, descendants: true }], ngImport: i0, template: "<section\n class=\"sky-box\"\n [attr.aria-label]=\"headingText || ariaLabel\"\n [attr.aria-labelledby]=\"headingText ? headerId : ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [skyThemeClass]=\"{\n 'sky-shadow sky-border-dark': 'default',\n 'sky-elevation-1-bordered': 'modern'\n }\"\n>\n <div class=\"sky-box-header-content\">\n @if (headingText) {\n <div class=\"sky-box-header-right\">\n @switch (headingLevel) {\n @case (3) {\n <!-- display: inline -->\n <h3\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h3\n >\n }\n @case (4) {\n <!-- display: inline -->\n <h4\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h4\n >\n }\n @case (5) {\n <!-- display: inline -->\n <h5\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h5\n >\n }\n @default {\n <!-- display: inline -->\n <h2\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h2\n >\n }\n }\n @if ((helpPopoverContent || helpKey) && !headingHidden) {\n <span class=\"sky-control-help-container\">\n <sky-help-inline\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverTitle]=\"helpPopoverTitle\"\n [popoverContent]=\"helpPopoverContent\"\n />\n </span>\n }\n </div>\n } @else {\n <ng-content select=\"sky-box-header\" />\n }\n <ng-content select=\"sky-box-controls\" />\n </div>\n <ng-content />\n</section>\n", styles: ["sky-box:not(.sky-theme-modern *){--sky-override-box-
|
|
72
|
+
], queries: [{ propertyName: "boxHeaderRef", first: true, predicate: SkyBoxHeaderComponent, descendants: true, read: ElementRef }, { propertyName: "boxControls", first: true, predicate: SkyBoxControlsComponent, descendants: true }], ngImport: i0, template: "<section\n class=\"sky-box\"\n [attr.aria-label]=\"headingText || ariaLabel\"\n [attr.aria-labelledby]=\"headingText ? headerId : ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [skyThemeClass]=\"{\n 'sky-shadow sky-border-dark': 'default',\n 'sky-elevation-1-bordered': 'modern'\n }\"\n>\n <div class=\"sky-box-header-content\">\n @if (headingText) {\n <div class=\"sky-box-header-right\">\n @switch (headingLevel) {\n @case (3) {\n <!-- display: inline -->\n <h3\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h3\n >\n }\n @case (4) {\n <!-- display: inline -->\n <h4\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h4\n >\n }\n @case (5) {\n <!-- display: inline -->\n <h5\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h5\n >\n }\n @default {\n <!-- display: inline -->\n <h2\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h2\n >\n }\n }\n @if ((helpPopoverContent || helpKey) && !headingHidden) {\n <span class=\"sky-control-help-container\">\n <sky-help-inline\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverTitle]=\"helpPopoverTitle\"\n [popoverContent]=\"helpPopoverContent\"\n />\n </span>\n }\n </div>\n } @else {\n <ng-content select=\"sky-box-header\" />\n }\n <ng-content select=\"sky-box-controls\" />\n </div>\n <ng-content />\n</section>\n", styles: ["sky-box:not(.sky-theme-modern *){--sky-override-box-content-padding: var(--sky-padding-even-xl);--sky-override-box-header-container-padding: var(--sky-padding-even-xl) var(--sky-padding-even-xl) 0 var(--sky-padding-even-xl);--sky-override-box-header-padding-right: var(--sky-margin-inline-xl)}.sky-theme-modern:not(.sky-theme-brand-blackbaud) sky-box{--sky-override-box-header-padding-right: var(--sky-margin-inline-xl)}sky-box{display:block}.sky-box{background-color:#fff;border-radius:var(--sky-box-border-radius);overflow:var(--sky-box-overflow)}.sky-box .sky-box-header-content{display:flex;flex-direction:row;flex-wrap:wrap;align-items:baseline;padding:var(--sky-override-box-header-container-padding, var(--sky-space-inset-bottomless-top-xl) var(--sky-space-inset-bottomless-right-xl) var(--sky-space-inset-bottomless-bottom-xl) var(--sky-space-inset-bottomless-left-xl))}.sky-box .sky-box-header-content:empty{display:none}.sky-box .sky-box-header-content sky-box-controls{margin-left:auto}.sky-box .sky-box-header-content sky-box-controls .sky-box-controls{position:relative;top:-2px}.sky-box .sky-box-header-content .sky-box-header-right{flex:1 0;padding-right:var(--sky-override-box-header-padding-right, var(--sky-space-gap-text_action-l))}.sky-box .sky-box-header-content h2,.sky-box .sky-box-header-content h3,.sky-box .sky-box-header-content h4,.sky-box .sky-box-header-content h5{display:inline;margin-block:0}.sky-box sky-box-content .sky-box-content{padding:var(--sky-override-box-content-padding, var(--sky-space-inset-balanced-xl))}\n"], dependencies: [{ kind: "component", type: i1.λ1, selector: "sky-help-inline", inputs: ["ariaControls", "ariaExpanded", "ariaLabel", "helpKey", "labelledBy", "labelText", "popoverContent", "popoverTitle"], outputs: ["actionClick"] }, { kind: "directive", type: i2.λ2, selector: "[skyThemeClass]", inputs: ["class", "skyThemeClass"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
73
73
|
}
|
|
74
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: SkyBoxComponent, decorators: [{
|
|
75
75
|
type: Component,
|
|
@@ -81,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImpor
|
|
|
81
81
|
return idService.generateId();
|
|
82
82
|
},
|
|
83
83
|
},
|
|
84
|
-
], template: "<section\n class=\"sky-box\"\n [attr.aria-label]=\"headingText || ariaLabel\"\n [attr.aria-labelledby]=\"headingText ? headerId : ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [skyThemeClass]=\"{\n 'sky-shadow sky-border-dark': 'default',\n 'sky-elevation-1-bordered': 'modern'\n }\"\n>\n <div class=\"sky-box-header-content\">\n @if (headingText) {\n <div class=\"sky-box-header-right\">\n @switch (headingLevel) {\n @case (3) {\n <!-- display: inline -->\n <h3\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h3\n >\n }\n @case (4) {\n <!-- display: inline -->\n <h4\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h4\n >\n }\n @case (5) {\n <!-- display: inline -->\n <h5\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h5\n >\n }\n @default {\n <!-- display: inline -->\n <h2\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h2\n >\n }\n }\n @if ((helpPopoverContent || helpKey) && !headingHidden) {\n <span class=\"sky-control-help-container\">\n <sky-help-inline\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverTitle]=\"helpPopoverTitle\"\n [popoverContent]=\"helpPopoverContent\"\n />\n </span>\n }\n </div>\n } @else {\n <ng-content select=\"sky-box-header\" />\n }\n <ng-content select=\"sky-box-controls\" />\n </div>\n <ng-content />\n</section>\n", styles: ["sky-box:not(.sky-theme-modern *){--sky-override-box-
|
|
84
|
+
], template: "<section\n class=\"sky-box\"\n [attr.aria-label]=\"headingText || ariaLabel\"\n [attr.aria-labelledby]=\"headingText ? headerId : ariaLabelledBy\"\n [attr.role]=\"ariaRole\"\n [skyThemeClass]=\"{\n 'sky-shadow sky-border-dark': 'default',\n 'sky-elevation-1-bordered': 'modern'\n }\"\n>\n <div class=\"sky-box-header-content\">\n @if (headingText) {\n <div class=\"sky-box-header-right\">\n @switch (headingLevel) {\n @case (3) {\n <!-- display: inline -->\n <h3\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h3\n >\n }\n @case (4) {\n <!-- display: inline -->\n <h4\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h4\n >\n }\n @case (5) {\n <!-- display: inline -->\n <h5\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h5\n >\n }\n @default {\n <!-- display: inline -->\n <h2\n [id]=\"headerId\"\n [class]=\"headingClass\"\n [class.sky-screen-reader-only]=\"headingHidden\"\n >{{ headingText }}</h2\n >\n }\n }\n @if ((helpPopoverContent || helpKey) && !headingHidden) {\n <span class=\"sky-control-help-container\">\n <sky-help-inline\n [helpKey]=\"helpKey\"\n [labelText]=\"headingText\"\n [popoverTitle]=\"helpPopoverTitle\"\n [popoverContent]=\"helpPopoverContent\"\n />\n </span>\n }\n </div>\n } @else {\n <ng-content select=\"sky-box-header\" />\n }\n <ng-content select=\"sky-box-controls\" />\n </div>\n <ng-content />\n</section>\n", styles: ["sky-box:not(.sky-theme-modern *){--sky-override-box-content-padding: var(--sky-padding-even-xl);--sky-override-box-header-container-padding: var(--sky-padding-even-xl) var(--sky-padding-even-xl) 0 var(--sky-padding-even-xl);--sky-override-box-header-padding-right: var(--sky-margin-inline-xl)}.sky-theme-modern:not(.sky-theme-brand-blackbaud) sky-box{--sky-override-box-header-padding-right: var(--sky-margin-inline-xl)}sky-box{display:block}.sky-box{background-color:#fff;border-radius:var(--sky-box-border-radius);overflow:var(--sky-box-overflow)}.sky-box .sky-box-header-content{display:flex;flex-direction:row;flex-wrap:wrap;align-items:baseline;padding:var(--sky-override-box-header-container-padding, var(--sky-space-inset-bottomless-top-xl) var(--sky-space-inset-bottomless-right-xl) var(--sky-space-inset-bottomless-bottom-xl) var(--sky-space-inset-bottomless-left-xl))}.sky-box .sky-box-header-content:empty{display:none}.sky-box .sky-box-header-content sky-box-controls{margin-left:auto}.sky-box .sky-box-header-content sky-box-controls .sky-box-controls{position:relative;top:-2px}.sky-box .sky-box-header-content .sky-box-header-right{flex:1 0;padding-right:var(--sky-override-box-header-padding-right, var(--sky-space-gap-text_action-l))}.sky-box .sky-box-header-content h2,.sky-box .sky-box-header-content h3,.sky-box .sky-box-header-content h4,.sky-box .sky-box-header-content h5{display:inline;margin-block:0}.sky-box sky-box-content .sky-box-content{padding:var(--sky-override-box-content-padding, var(--sky-space-inset-balanced-xl))}\n"] }]
|
|
85
85
|
}], propDecorators: { headingText: [{
|
|
86
86
|
type: Input
|
|
87
87
|
}], headingHidden: [{
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { By } from '@angular/platform-browser';
|
|
2
|
+
import { SkyAppTestUtility } from '@skyux-sdk/testing';
|
|
3
|
+
/**
|
|
4
|
+
* Allows interaction with a SKY UX action button component.
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyActionButtonFixture {
|
|
8
|
+
/**
|
|
9
|
+
* The action button's current header text.
|
|
10
|
+
*/
|
|
11
|
+
get headerText() {
|
|
12
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('.sky-action-button-header')));
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* The action button's current details text.
|
|
16
|
+
*/
|
|
17
|
+
get detailsText() {
|
|
18
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-action-button-details')));
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* The action button's current icon type.
|
|
22
|
+
*/
|
|
23
|
+
get iconType() {
|
|
24
|
+
const classList = this.#debugEl.query(By.css('.fa.sky-icon')).nativeElement
|
|
25
|
+
.classList;
|
|
26
|
+
for (let i = 0, n = classList.length; i < n; i++) {
|
|
27
|
+
const cls = classList.item(i);
|
|
28
|
+
if (cls.indexOf('fa-') === 0) {
|
|
29
|
+
return cls.substr(3);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
/* istanbul ignore next */
|
|
33
|
+
return undefined;
|
|
34
|
+
}
|
|
35
|
+
#debugEl;
|
|
36
|
+
constructor(fixture, skyTestId) {
|
|
37
|
+
this.#debugEl = SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-action-button');
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Clicks the action button.
|
|
41
|
+
*/
|
|
42
|
+
actionClick() {
|
|
43
|
+
this.#debugEl
|
|
44
|
+
.query(By.css('.sky-action-button'))
|
|
45
|
+
.triggerEventHandler('click', {});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLWJ1dHRvbi1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9sZWdhY3kvYWN0aW9uLWJ1dHRvbi1maXh0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV2RDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sc0JBQXNCO0lBQ2pDOztPQUVHO0lBQ0gsSUFBVyxVQUFVO1FBQ25CLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUM5QixJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxDQUFDLDJCQUEyQixDQUFDLENBQUMsQ0FDekQsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNILElBQVcsV0FBVztRQUNwQixPQUFPLGlCQUFpQixDQUFDLE9BQU8sQ0FDOUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDLENBQ3pELENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFFBQVE7UUFDakIsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLGFBQWE7YUFDeEUsU0FBUyxDQUFDO1FBRWIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDO1lBQ2pELE1BQU0sR0FBRyxHQUFHLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFFOUIsSUFBSSxHQUFHLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUM3QixPQUFPLEdBQUcsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDdkIsQ0FBQztRQUNILENBQUM7UUFDRCwwQkFBMEI7UUFDMUIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELFFBQVEsQ0FBZTtJQUV2QixZQUFZLE9BQThCLEVBQUUsU0FBaUI7UUFDM0QsSUFBSSxDQUFDLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQyx1QkFBdUIsQ0FDdkQsT0FBTyxFQUNQLFNBQVMsRUFDVCxtQkFBbUIsQ0FDcEIsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLFdBQVc7UUFDaEIsSUFBSSxDQUFDLFFBQVE7YUFDVixLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO2FBQ25DLG1CQUFtQixDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN0QyxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZWJ1Z0VsZW1lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudEZpeHR1cmUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3Rlc3RpbmcnO1xuaW1wb3J0IHsgQnkgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7IFNreUFwcFRlc3RVdGlsaXR5IH0gZnJvbSAnQHNreXV4LXNkay90ZXN0aW5nJztcblxuLyoqXG4gKiBBbGxvd3MgaW50ZXJhY3Rpb24gd2l0aCBhIFNLWSBVWCBhY3Rpb24gYnV0dG9uIGNvbXBvbmVudC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2t5QWN0aW9uQnV0dG9uRml4dHVyZSB7XG4gIC8qKlxuICAgKiBUaGUgYWN0aW9uIGJ1dHRvbidzIGN1cnJlbnQgaGVhZGVyIHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGhlYWRlclRleHQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuI2RlYnVnRWwucXVlcnkoQnkuY3NzKCcuc2t5LWFjdGlvbi1idXR0b24taGVhZGVyJykpLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGFjdGlvbiBidXR0b24ncyBjdXJyZW50IGRldGFpbHMgdGV4dC5cbiAgICovXG4gIHB1YmxpYyBnZXQgZGV0YWlsc1RleHQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuI2RlYnVnRWwucXVlcnkoQnkuY3NzKCdza3ktYWN0aW9uLWJ1dHRvbi1kZXRhaWxzJykpLFxuICAgICk7XG4gIH1cblxuICAvKipcbiAgICogVGhlIGFjdGlvbiBidXR0b24ncyBjdXJyZW50IGljb24gdHlwZS5cbiAgICovXG4gIHB1YmxpYyBnZXQgaWNvblR5cGUoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICBjb25zdCBjbGFzc0xpc3QgPSB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnLmZhLnNreS1pY29uJykpLm5hdGl2ZUVsZW1lbnRcbiAgICAgIC5jbGFzc0xpc3Q7XG5cbiAgICBmb3IgKGxldCBpID0gMCwgbiA9IGNsYXNzTGlzdC5sZW5ndGg7IGkgPCBuOyBpKyspIHtcbiAgICAgIGNvbnN0IGNscyA9IGNsYXNzTGlzdC5pdGVtKGkpO1xuXG4gICAgICBpZiAoY2xzLmluZGV4T2YoJ2ZhLScpID09PSAwKSB7XG4gICAgICAgIHJldHVybiBjbHMuc3Vic3RyKDMpO1xuICAgICAgfVxuICAgIH1cbiAgICAvKiBpc3RhbmJ1bCBpZ25vcmUgbmV4dCAqL1xuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICAjZGVidWdFbDogRGVidWdFbGVtZW50O1xuXG4gIGNvbnN0cnVjdG9yKGZpeHR1cmU6IENvbXBvbmVudEZpeHR1cmU8YW55Piwgc2t5VGVzdElkOiBzdHJpbmcpIHtcbiAgICB0aGlzLiNkZWJ1Z0VsID0gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0RGVidWdFbGVtZW50QnlUZXN0SWQoXG4gICAgICBmaXh0dXJlLFxuICAgICAgc2t5VGVzdElkLFxuICAgICAgJ3NreS1hY3Rpb24tYnV0dG9uJyxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIENsaWNrcyB0aGUgYWN0aW9uIGJ1dHRvbi5cbiAgICovXG4gIHB1YmxpYyBhY3Rpb25DbGljaygpOiB2b2lkIHtcbiAgICB0aGlzLiNkZWJ1Z0VsXG4gICAgICAucXVlcnkoQnkuY3NzKCcuc2t5LWFjdGlvbi1idXR0b24nKSlcbiAgICAgIC50cmlnZ2VyRXZlbnRIYW5kbGVyKCdjbGljaycsIHt9KTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import { By } from '@angular/platform-browser';
|
|
2
|
+
import { SkyAppTestUtility } from '@skyux-sdk/testing';
|
|
3
|
+
/**
|
|
4
|
+
* Allows interaction with a SKY UX avatar component.
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyCardFixture {
|
|
8
|
+
/**
|
|
9
|
+
* The card's current title.
|
|
10
|
+
*/
|
|
11
|
+
get titleText() {
|
|
12
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-card-title')));
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* The card's current content text.
|
|
16
|
+
*/
|
|
17
|
+
get contentText() {
|
|
18
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-card-content')));
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* A flag indicating whether the user can select the card.
|
|
22
|
+
*/
|
|
23
|
+
get selectable() {
|
|
24
|
+
return !!this.#debugEl.query(By.css('.sky-card-check'));
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* A flag indicating whether the card is currently selected. If the card
|
|
28
|
+
* is not selectable, an error is thrown.
|
|
29
|
+
*/
|
|
30
|
+
get selected() {
|
|
31
|
+
if (this.selectable) {
|
|
32
|
+
return this.#getCheckInputEl().nativeElement.checked;
|
|
33
|
+
}
|
|
34
|
+
throw new Error('The card is not selectable.');
|
|
35
|
+
}
|
|
36
|
+
#debugEl;
|
|
37
|
+
constructor(fixture, skyTestId) {
|
|
38
|
+
this.#debugEl = SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-card');
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Selects the card.
|
|
42
|
+
*/
|
|
43
|
+
select() {
|
|
44
|
+
if (!this.selected) {
|
|
45
|
+
this.#clickCheckLabelEl();
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Deselects the card.
|
|
50
|
+
*/
|
|
51
|
+
deselect() {
|
|
52
|
+
if (this.selected) {
|
|
53
|
+
this.#clickCheckLabelEl();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
#clickCheckLabelEl() {
|
|
57
|
+
this.#debugEl
|
|
58
|
+
.query(By.css('.sky-card-check label.sky-checkbox-wrapper'))
|
|
59
|
+
.nativeElement.click();
|
|
60
|
+
}
|
|
61
|
+
#getCheckInputEl() {
|
|
62
|
+
return this.#debugEl.query(By.css('.sky-card-check .sky-checkbox-wrapper input'));
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC1maXh0dXJlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9sZWdhY3kvY2FyZC1maXh0dXJlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUV2RDs7O0dBR0c7QUFDSCxNQUFNLE9BQU8sY0FBYztJQUN6Qjs7T0FFRztJQUNILElBQVcsU0FBUztRQUNsQixPQUFPLGlCQUFpQixDQUFDLE9BQU8sQ0FDOUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDLENBQzlDLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFdBQVc7UUFDcEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsa0JBQWtCLENBQUMsQ0FBQyxDQUNoRCxDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxVQUFVO1FBQ25CLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFRDs7O09BR0c7SUFDSCxJQUFXLFFBQVE7UUFDakIsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDcEIsT0FBTyxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDO1FBQ3ZELENBQUM7UUFFRCxNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7SUFDakQsQ0FBQztJQUVELFFBQVEsQ0FBZTtJQUV2QixZQUFZLE9BQThCLEVBQUUsU0FBaUI7UUFDM0QsSUFBSSxDQUFDLFFBQVEsR0FBRyxpQkFBaUIsQ0FBQyx1QkFBdUIsQ0FDdkQsT0FBTyxFQUNQLFNBQVMsRUFDVCxVQUFVLENBQ1gsQ0FBQztJQUNKLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ25CLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQzVCLENBQUM7SUFDSCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxRQUFRO1FBQ2IsSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDbEIsSUFBSSxDQUFDLGtCQUFrQixFQUFFLENBQUM7UUFDNUIsQ0FBQztJQUNILENBQUM7SUFFRCxrQkFBa0I7UUFDaEIsSUFBSSxDQUFDLFFBQVE7YUFDVixLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyw0Q0FBNEMsQ0FBQyxDQUFDO2FBQzNELGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRUQsZ0JBQWdCO1FBQ2QsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FDeEIsRUFBRSxDQUFDLEdBQUcsQ0FBQyw2Q0FBNkMsQ0FBQyxDQUN0RCxDQUFDO0lBQ0osQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGVidWdFbGVtZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21wb25lbnRGaXh0dXJlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZS90ZXN0aW5nJztcbmltcG9ydCB7IEJ5IH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XG5pbXBvcnQgeyBTa3lBcHBUZXN0VXRpbGl0eSB9IGZyb20gJ0Bza3l1eC1zZGsvdGVzdGluZyc7XG5cbi8qKlxuICogQWxsb3dzIGludGVyYWN0aW9uIHdpdGggYSBTS1kgVVggYXZhdGFyIGNvbXBvbmVudC5cbiAqIEBpbnRlcm5hbFxuICovXG5leHBvcnQgY2xhc3MgU2t5Q2FyZEZpeHR1cmUge1xuICAvKipcbiAgICogVGhlIGNhcmQncyBjdXJyZW50IHRpdGxlLlxuICAgKi9cbiAgcHVibGljIGdldCB0aXRsZVRleHQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuI2RlYnVnRWwucXVlcnkoQnkuY3NzKCdza3ktY2FyZC10aXRsZScpKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBjYXJkJ3MgY3VycmVudCBjb250ZW50IHRleHQuXG4gICAqL1xuICBwdWJsaWMgZ2V0IGNvbnRlbnRUZXh0KCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnc2t5LWNhcmQtY29udGVudCcpKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIEEgZmxhZyBpbmRpY2F0aW5nIHdoZXRoZXIgdGhlIHVzZXIgY2FuIHNlbGVjdCB0aGUgY2FyZC5cbiAgICovXG4gIHB1YmxpYyBnZXQgc2VsZWN0YWJsZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KEJ5LmNzcygnLnNreS1jYXJkLWNoZWNrJykpO1xuICB9XG5cbiAgLyoqXG4gICAqIEEgZmxhZyBpbmRpY2F0aW5nIHdoZXRoZXIgdGhlIGNhcmQgaXMgY3VycmVudGx5IHNlbGVjdGVkLiAgSWYgdGhlIGNhcmRcbiAgICogaXMgbm90IHNlbGVjdGFibGUsIGFuIGVycm9yIGlzIHRocm93bi5cbiAgICovXG4gIHB1YmxpYyBnZXQgc2VsZWN0ZWQoKTogYm9vbGVhbiB7XG4gICAgaWYgKHRoaXMuc2VsZWN0YWJsZSkge1xuICAgICAgcmV0dXJuIHRoaXMuI2dldENoZWNrSW5wdXRFbCgpLm5hdGl2ZUVsZW1lbnQuY2hlY2tlZDtcbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IoJ1RoZSBjYXJkIGlzIG5vdCBzZWxlY3RhYmxlLicpO1xuICB9XG5cbiAgI2RlYnVnRWw6IERlYnVnRWxlbWVudDtcblxuICBjb25zdHJ1Y3RvcihmaXh0dXJlOiBDb21wb25lbnRGaXh0dXJlPGFueT4sIHNreVRlc3RJZDogc3RyaW5nKSB7XG4gICAgdGhpcy4jZGVidWdFbCA9IFNreUFwcFRlc3RVdGlsaXR5LmdldERlYnVnRWxlbWVudEJ5VGVzdElkKFxuICAgICAgZml4dHVyZSxcbiAgICAgIHNreVRlc3RJZCxcbiAgICAgICdza3ktY2FyZCcsXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZWxlY3RzIHRoZSBjYXJkLlxuICAgKi9cbiAgcHVibGljIHNlbGVjdCgpOiB2b2lkIHtcbiAgICBpZiAoIXRoaXMuc2VsZWN0ZWQpIHtcbiAgICAgIHRoaXMuI2NsaWNrQ2hlY2tMYWJlbEVsKCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIERlc2VsZWN0cyB0aGUgY2FyZC5cbiAgICovXG4gIHB1YmxpYyBkZXNlbGVjdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5zZWxlY3RlZCkge1xuICAgICAgdGhpcy4jY2xpY2tDaGVja0xhYmVsRWwoKTtcbiAgICB9XG4gIH1cblxuICAjY2xpY2tDaGVja0xhYmVsRWwoKTogdm9pZCB7XG4gICAgdGhpcy4jZGVidWdFbFxuICAgICAgLnF1ZXJ5KEJ5LmNzcygnLnNreS1jYXJkLWNoZWNrIGxhYmVsLnNreS1jaGVja2JveC13cmFwcGVyJykpXG4gICAgICAubmF0aXZlRWxlbWVudC5jbGljaygpO1xuICB9XG5cbiAgI2dldENoZWNrSW5wdXRFbCgpOiBEZWJ1Z0VsZW1lbnQge1xuICAgIHJldHVybiB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KFxuICAgICAgQnkuY3NzKCcuc2t5LWNhcmQtY2hlY2sgLnNreS1jaGVja2JveC13cmFwcGVyIGlucHV0JyksXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { By } from '@angular/platform-browser';
|
|
2
|
+
import { SkyAppTestUtility } from '@skyux-sdk/testing';
|
|
3
|
+
/**
|
|
4
|
+
* Allows interaction with a SKY UX page summary component.
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
export class SkyPageSummaryFixture {
|
|
8
|
+
/**
|
|
9
|
+
* The page summary's current title text.
|
|
10
|
+
*/
|
|
11
|
+
get titleText() {
|
|
12
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-page-summary-title .sky-page-summary-title')));
|
|
13
|
+
}
|
|
14
|
+
/**
|
|
15
|
+
* The page summary's current subtitle text.
|
|
16
|
+
*/
|
|
17
|
+
get subtitleText() {
|
|
18
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-page-summary-subtitle .sky-page-summary-subtitle')));
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* The page summary's current content text.
|
|
22
|
+
*/
|
|
23
|
+
get contentText() {
|
|
24
|
+
return SkyAppTestUtility.getText(this.#debugEl.query(By.css('sky-page-summary-content .sky-page-summary-content')));
|
|
25
|
+
}
|
|
26
|
+
#debugEl;
|
|
27
|
+
constructor(fixture, skyTestId) {
|
|
28
|
+
this.#debugEl = SkyAppTestUtility.getDebugElementByTestId(fixture, skyTestId, 'sky-page-summary');
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS1zdW1tYXJ5LWZpeHR1cmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3Rlc3Rpbmcvc3JjL2xlZ2FjeS9wYWdlLXN1bW1hcnktZml4dHVyZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFdkQ7OztHQUdHO0FBQ0gsTUFBTSxPQUFPLHFCQUFxQjtJQUNoQzs7T0FFRztJQUNILElBQVcsU0FBUztRQUNsQixPQUFPLGlCQUFpQixDQUFDLE9BQU8sQ0FDOUIsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQ2pCLEVBQUUsQ0FBQyxHQUFHLENBQUMsZ0RBQWdELENBQUMsQ0FDekQsQ0FDRixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsSUFBVyxZQUFZO1FBQ3JCLE9BQU8saUJBQWlCLENBQUMsT0FBTyxDQUM5QixJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FDakIsRUFBRSxDQUFDLEdBQUcsQ0FBQyxzREFBc0QsQ0FBQyxDQUMvRCxDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFXLFdBQVc7UUFDcEIsT0FBTyxpQkFBaUIsQ0FBQyxPQUFPLENBQzlCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUNqQixFQUFFLENBQUMsR0FBRyxDQUFDLG9EQUFvRCxDQUFDLENBQzdELENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRCxRQUFRLENBQWU7SUFFdkIsWUFBWSxPQUE4QixFQUFFLFNBQWlCO1FBQzNELElBQUksQ0FBQyxRQUFRLEdBQUcsaUJBQWlCLENBQUMsdUJBQXVCLENBQ3ZELE9BQU8sRUFDUCxTQUFTLEVBQ1Qsa0JBQWtCLENBQ25CLENBQUM7SUFDSixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZWJ1Z0VsZW1lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbXBvbmVudEZpeHR1cmUgfSBmcm9tICdAYW5ndWxhci9jb3JlL3Rlc3RpbmcnO1xuaW1wb3J0IHsgQnkgfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7IFNreUFwcFRlc3RVdGlsaXR5IH0gZnJvbSAnQHNreXV4LXNkay90ZXN0aW5nJztcblxuLyoqXG4gKiBBbGxvd3MgaW50ZXJhY3Rpb24gd2l0aCBhIFNLWSBVWCBwYWdlIHN1bW1hcnkgY29tcG9uZW50LlxuICogQGludGVybmFsXG4gKi9cbmV4cG9ydCBjbGFzcyBTa3lQYWdlU3VtbWFyeUZpeHR1cmUge1xuICAvKipcbiAgICogVGhlIHBhZ2Ugc3VtbWFyeSdzIGN1cnJlbnQgdGl0bGUgdGV4dC5cbiAgICovXG4gIHB1YmxpYyBnZXQgdGl0bGVUZXh0KCk6IHN0cmluZyB8IHVuZGVmaW5lZCB7XG4gICAgcmV0dXJuIFNreUFwcFRlc3RVdGlsaXR5LmdldFRleHQoXG4gICAgICB0aGlzLiNkZWJ1Z0VsLnF1ZXJ5KFxuICAgICAgICBCeS5jc3MoJ3NreS1wYWdlLXN1bW1hcnktdGl0bGUgLnNreS1wYWdlLXN1bW1hcnktdGl0bGUnKSxcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBUaGUgcGFnZSBzdW1tYXJ5J3MgY3VycmVudCBzdWJ0aXRsZSB0ZXh0LlxuICAgKi9cbiAgcHVibGljIGdldCBzdWJ0aXRsZVRleHQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuI2RlYnVnRWwucXVlcnkoXG4gICAgICAgIEJ5LmNzcygnc2t5LXBhZ2Utc3VtbWFyeS1zdWJ0aXRsZSAuc2t5LXBhZ2Utc3VtbWFyeS1zdWJ0aXRsZScpLFxuICAgICAgKSxcbiAgICApO1xuICB9XG5cbiAgLyoqXG4gICAqIFRoZSBwYWdlIHN1bW1hcnkncyBjdXJyZW50IGNvbnRlbnQgdGV4dC5cbiAgICovXG4gIHB1YmxpYyBnZXQgY29udGVudFRleHQoKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICByZXR1cm4gU2t5QXBwVGVzdFV0aWxpdHkuZ2V0VGV4dChcbiAgICAgIHRoaXMuI2RlYnVnRWwucXVlcnkoXG4gICAgICAgIEJ5LmNzcygnc2t5LXBhZ2Utc3VtbWFyeS1jb250ZW50IC5za3ktcGFnZS1zdW1tYXJ5LWNvbnRlbnQnKSxcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gICNkZWJ1Z0VsOiBEZWJ1Z0VsZW1lbnQ7XG5cbiAgY29uc3RydWN0b3IoZml4dHVyZTogQ29tcG9uZW50Rml4dHVyZTxhbnk+LCBza3lUZXN0SWQ6IHN0cmluZykge1xuICAgIHRoaXMuI2RlYnVnRWwgPSBTa3lBcHBUZXN0VXRpbGl0eS5nZXREZWJ1Z0VsZW1lbnRCeVRlc3RJZChcbiAgICAgIGZpeHR1cmUsXG4gICAgICBza3lUZXN0SWQsXG4gICAgICAnc2t5LXBhZ2Utc3VtbWFyeScsXG4gICAgKTtcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm94LWhhcm5lc3MuZmlsdGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvdGVzdGluZy9zcmMvbW9kdWxlcy9ib3gvYm94LWhhcm5lc3MuZmlsdGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2t5SGFybmVzc0ZpbHRlcnMgfSBmcm9tICdAc2t5dXgvY29yZS90ZXN0aW5nJztcblxuLyoqXG4gKiBBIHNldCBvZiBjcml0ZXJpYSB0aGF0IGNhbiBiZSB1c2VkIHRvIGZpbHRlciBhIGxpc3Qgb2YgYFNreUJveEhhcm5lc3NgIGluc3RhbmNlcy5cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1pbnRlcmZhY2UsIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1vYmplY3QtdHlwZVxuZXhwb3J0IGludGVyZmFjZSBTa3lCb3hIYXJuZXNzRmlsdGVycyBleHRlbmRzIFNreUhhcm5lc3NGaWx0ZXJzIHt9XG4iXX0=
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
2
|
+
import { SkyHelpInlineHarness } from '@skyux/help-inline/testing';
|
|
3
|
+
export class SkyBoxHarness extends SkyComponentHarness {
|
|
4
|
+
/**
|
|
5
|
+
* @internal
|
|
6
|
+
*/
|
|
7
|
+
static { this.hostSelector = 'sky-box'; }
|
|
8
|
+
#getBox = this.locatorFor('.sky-box');
|
|
9
|
+
#getHeading = this.locatorFor('.sky-box-header-content');
|
|
10
|
+
#getH2 = this.locatorForOptional('.sky-box-header-content h2');
|
|
11
|
+
#getH3 = this.locatorForOptional('.sky-box-header-content h3');
|
|
12
|
+
#getH4 = this.locatorForOptional('.sky-box-header-content h4');
|
|
13
|
+
#getH5 = this.locatorForOptional('.sky-box-header-content h5');
|
|
14
|
+
/**
|
|
15
|
+
* Gets a `HarnessPredicate` that can be used to search for a
|
|
16
|
+
* `SkyBoxHarness` that meets certain criteria
|
|
17
|
+
*/
|
|
18
|
+
static with(filters) {
|
|
19
|
+
return SkyBoxHarness.getDataSkyIdPredicate(filters);
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Clicks the help inline button.
|
|
23
|
+
*/
|
|
24
|
+
async clickHelpInline() {
|
|
25
|
+
return await (await this.#getHelpInline()).click();
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Gets the help popover content.
|
|
29
|
+
*/
|
|
30
|
+
async getHelpPopoverContent() {
|
|
31
|
+
return await (await this.#getHelpInline()).getPopoverContent();
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Gets the help popover title.
|
|
35
|
+
*/
|
|
36
|
+
async getHelpPopoverTitle() {
|
|
37
|
+
return await (await this.#getHelpInline()).getPopoverTitle();
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Gets the box's heading text. If `headingHidden` is true,
|
|
41
|
+
* the text will still be returned.
|
|
42
|
+
*/
|
|
43
|
+
async getHeadingText() {
|
|
44
|
+
return await (await this.#getHeading()).text();
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Whether the heading is hidden.
|
|
48
|
+
*/
|
|
49
|
+
async getHeadingHidden() {
|
|
50
|
+
const heading = (await this.#getH2()) ||
|
|
51
|
+
(await this.#getH3()) ||
|
|
52
|
+
(await this.#getH4()) ||
|
|
53
|
+
(await this.#getH5());
|
|
54
|
+
return (await heading?.hasClass('sky-screen-reader-only')) ?? false;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* The semantic heading level used for the checkbox group. Returns undefined if heading level is not set.
|
|
58
|
+
*/
|
|
59
|
+
async getHeadingLevel() {
|
|
60
|
+
return (await this.#getH2())
|
|
61
|
+
? 2
|
|
62
|
+
: (await this.#getH3())
|
|
63
|
+
? 3
|
|
64
|
+
: (await this.#getH4())
|
|
65
|
+
? 4
|
|
66
|
+
: 5;
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* The heading style used for the checkbox group.
|
|
70
|
+
*/
|
|
71
|
+
async getHeadingStyle() {
|
|
72
|
+
const heading = (await this.#getH2()) ||
|
|
73
|
+
(await this.#getH3()) ||
|
|
74
|
+
(await this.#getH4()) ||
|
|
75
|
+
(await this.#getH5());
|
|
76
|
+
const isHeadingStyle2 = await heading?.hasClass('sky-font-heading-2');
|
|
77
|
+
const isHeadingStyle3 = await heading?.hasClass('sky-font-heading-3');
|
|
78
|
+
const isHeadingStyle4 = await heading?.hasClass('sky-font-heading-4');
|
|
79
|
+
return isHeadingStyle2 ? 2 : isHeadingStyle3 ? 3 : isHeadingStyle4 ? 4 : 5;
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Gets the aria-label property of the box
|
|
83
|
+
*/
|
|
84
|
+
async getAriaLabel() {
|
|
85
|
+
return await (await this.#getBox()).getAttribute('aria-label');
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Gets the aria-labelledby property of the box
|
|
89
|
+
*/
|
|
90
|
+
async getAriaLabelledby() {
|
|
91
|
+
return await (await this.#getBox()).getAttribute('aria-labelledby');
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* Gets the aria-role property of the box
|
|
95
|
+
*/
|
|
96
|
+
async getAriaRole() {
|
|
97
|
+
return await (await this.#getBox()).getAttribute('role');
|
|
98
|
+
}
|
|
99
|
+
async #getHelpInline() {
|
|
100
|
+
const harness = await this.locatorForOptional(SkyHelpInlineHarness.with({
|
|
101
|
+
ancestor: '.sky-box-header-content',
|
|
102
|
+
}))();
|
|
103
|
+
if (harness) {
|
|
104
|
+
return harness;
|
|
105
|
+
}
|
|
106
|
+
throw Error('No help inline found.');
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"box-harness.js","sourceRoot":"","sources":["../../../../../../../../libs/components/layout/testing/src/modules/box/box-harness.ts"],"names":[],"mappings":"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","sourcesContent":["import { HarnessPredicate } from '@angular/cdk/testing';\nimport { TemplateRef } from '@angular/core';\nimport { SkyComponentHarness } from '@skyux/core/testing';\nimport { SkyHelpInlineHarness } from '@skyux/help-inline/testing';\nimport { SkyBoxHeadingLevel, SkyBoxHeadingStyle } from '@skyux/layout';\n\nimport { SkyBoxHarnessFilters } from './box-harness.filters';\n\nexport class SkyBoxHarness extends SkyComponentHarness {\n  /**\n   * @internal\n   */\n  public static hostSelector = 'sky-box';\n\n  #getBox = this.locatorFor('.sky-box');\n  #getHeading = this.locatorFor('.sky-box-header-content');\n  #getH2 = this.locatorForOptional('.sky-box-header-content h2');\n  #getH3 = this.locatorForOptional('.sky-box-header-content h3');\n  #getH4 = this.locatorForOptional('.sky-box-header-content h4');\n  #getH5 = this.locatorForOptional('.sky-box-header-content h5');\n\n  /**\n   * Gets a `HarnessPredicate` that can be used to search for a\n   * `SkyBoxHarness` that meets certain criteria\n   */\n  public static with(\n    filters: SkyBoxHarnessFilters,\n  ): HarnessPredicate<SkyBoxHarness> {\n    return SkyBoxHarness.getDataSkyIdPredicate(filters);\n  }\n\n  /**\n   * Clicks the help inline button.\n   */\n  public async clickHelpInline(): Promise<void> {\n    return await (await this.#getHelpInline()).click();\n  }\n\n  /**\n   * Gets the help popover content.\n   */\n  public async getHelpPopoverContent(): Promise<\n    TemplateRef<unknown> | string | undefined\n  > {\n    return await (await this.#getHelpInline()).getPopoverContent();\n  }\n\n  /**\n   * Gets the help popover title.\n   */\n  public async getHelpPopoverTitle(): Promise<string | undefined> {\n    return await (await this.#getHelpInline()).getPopoverTitle();\n  }\n\n  /**\n   * Gets the box's heading text. If `headingHidden` is true,\n   * the text will still be returned.\n   */\n  public async getHeadingText(): Promise<string | undefined> {\n    return await (await this.#getHeading()).text();\n  }\n\n  /**\n   * Whether the heading is hidden.\n   */\n  public async getHeadingHidden(): Promise<boolean> {\n    const heading =\n      (await this.#getH2()) ||\n      (await this.#getH3()) ||\n      (await this.#getH4()) ||\n      (await this.#getH5());\n    return (await heading?.hasClass('sky-screen-reader-only')) ?? false;\n  }\n\n  /**\n   * The semantic heading level used for the checkbox group. Returns undefined if heading level is not set.\n   */\n  public async getHeadingLevel(): Promise<SkyBoxHeadingLevel | undefined> {\n    return (await this.#getH2())\n      ? 2\n      : (await this.#getH3())\n        ? 3\n        : (await this.#getH4())\n          ? 4\n          : 5;\n  }\n\n  /**\n   * The heading style used for the checkbox group.\n   */\n  public async getHeadingStyle(): Promise<SkyBoxHeadingStyle> {\n    const heading =\n      (await this.#getH2()) ||\n      (await this.#getH3()) ||\n      (await this.#getH4()) ||\n      (await this.#getH5());\n\n    const isHeadingStyle2 = await heading?.hasClass('sky-font-heading-2');\n    const isHeadingStyle3 = await heading?.hasClass('sky-font-heading-3');\n    const isHeadingStyle4 = await heading?.hasClass('sky-font-heading-4');\n\n    return isHeadingStyle2 ? 2 : isHeadingStyle3 ? 3 : isHeadingStyle4 ? 4 : 5;\n  }\n\n  /**\n   * Gets the aria-label property of the box\n   */\n  public async getAriaLabel(): Promise<string | null> {\n    return await (await this.#getBox()).getAttribute('aria-label');\n  }\n\n  /**\n   * Gets the aria-labelledby property of the box\n   */\n  public async getAriaLabelledby(): Promise<string | null> {\n    return await (await this.#getBox()).getAttribute('aria-labelledby');\n  }\n\n  /**\n   * Gets the aria-role property of the box\n   */\n  public async getAriaRole(): Promise<string | null> {\n    return await (await this.#getBox()).getAttribute('role');\n  }\n\n  async #getHelpInline(): Promise<SkyHelpInlineHarness> {\n    const harness = await this.locatorForOptional(\n      SkyHelpInlineHarness.with({\n        ancestor: '.sky-box-header-content',\n      }),\n    )();\n\n    if (harness) {\n      return harness;\n    }\n\n    throw Error('No help inline found.');\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLWhhcm5lc3MtZmlsdGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvdGVzdGluZy9zcmMvbW9kdWxlcy9mbHVpZC1ncmlkL2NvbHVtbi1oYXJuZXNzLWZpbHRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNreUhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnQHNreXV4L2NvcmUvdGVzdGluZyc7XG5cbi8qKlxuICogQSBzZXQgb2YgY3JpdGVyaWEgdGhhdCBjYW4gYmUgdXNlZCB0byBmaWx0ZXIgYSBsaXN0IG9mIGBTa3lDb2x1bW5IYXJuZXNzYCBpbnN0YW5jZXMuXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlLCBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktb2JqZWN0LXR5cGVcbmV4cG9ydCBpbnRlcmZhY2UgU2t5Q29sdW1uSGFybmVzc0ZpbHRlcnMgZXh0ZW5kcyBTa3lIYXJuZXNzRmlsdGVycyB7fVxuIl19
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
2
|
+
const sizes = ['xs', 'sm', 'md', 'lg'];
|
|
3
|
+
/**
|
|
4
|
+
* Harness for interacting with a fluid grid column component in tests.
|
|
5
|
+
*/
|
|
6
|
+
export class SkyColumnHarness extends SkyComponentHarness {
|
|
7
|
+
/**
|
|
8
|
+
* @internal
|
|
9
|
+
*/
|
|
10
|
+
static { this.hostSelector = 'sky-column'; }
|
|
11
|
+
/**
|
|
12
|
+
* Gets a `HarnessPredicate` that can be used to search for a
|
|
13
|
+
* `SkyColumnHarness` that meets certain criteria
|
|
14
|
+
*/
|
|
15
|
+
static with(filters) {
|
|
16
|
+
return SkyColumnHarness.getDataSkyIdPredicate(filters);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Gets the size of the column in an XSmall responsive context.
|
|
20
|
+
*/
|
|
21
|
+
async getXSmallSize() {
|
|
22
|
+
return await this.#getColumnSize(0);
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Gets the size of the column in a Small responsive context.
|
|
26
|
+
*/
|
|
27
|
+
async getSmallSize() {
|
|
28
|
+
return await this.#getColumnSize(1);
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Gets the size of the column in a Medium responsive context.
|
|
32
|
+
*/
|
|
33
|
+
async getMediumSize() {
|
|
34
|
+
return await this.#getColumnSize(2);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Gets the size of the column in a Large responsive context.
|
|
38
|
+
*/
|
|
39
|
+
async getLargeSize() {
|
|
40
|
+
return await this.#getColumnSize(3);
|
|
41
|
+
}
|
|
42
|
+
async #getColumnSize(index) {
|
|
43
|
+
const size = sizes[index];
|
|
44
|
+
const result = await this.#getColumnClass(size);
|
|
45
|
+
/* istanbul ignore if */
|
|
46
|
+
if (!result && !index) {
|
|
47
|
+
throw Error('No column sizes found.');
|
|
48
|
+
}
|
|
49
|
+
return result || (await this.#getColumnSize(index - 1));
|
|
50
|
+
}
|
|
51
|
+
async #getColumnClass(size) {
|
|
52
|
+
const host = await this.host();
|
|
53
|
+
for (let i = 12; i; i--) {
|
|
54
|
+
if (await host.hasClass(`sky-column-${size}-${i}`)) {
|
|
55
|
+
return i;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
return 0;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sdW1uLWhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3Rlc3Rpbmcvc3JjL21vZHVsZXMvZmx1aWQtZ3JpZC9jb2x1bW4taGFybmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUkxRCxNQUFNLEtBQUssR0FBRyxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0FBRXZDOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGdCQUFpQixTQUFRLG1CQUFtQjtJQUN2RDs7T0FFRzthQUNXLGlCQUFZLEdBQUcsWUFBWSxDQUFDO0lBRTFDOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxJQUFJLENBQ2hCLE9BQWdDO1FBRWhDLE9BQU8sZ0JBQWdCLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLGFBQWE7UUFDeEIsT0FBTyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFlBQVk7UUFDdkIsT0FBTyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLGFBQWE7UUFDeEIsT0FBTyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFlBQVk7UUFDdkIsT0FBTyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELEtBQUssQ0FBQyxjQUFjLENBQUMsS0FBYTtRQUNoQyxNQUFNLElBQUksR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUM7UUFFMUIsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBRWhELHdCQUF3QjtRQUN4QixJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDdEIsTUFBTSxLQUFLLENBQUMsd0JBQXdCLENBQUMsQ0FBQztRQUN4QyxDQUFDO1FBRUQsT0FBTyxNQUFNLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVELEtBQUssQ0FBQyxlQUFlLENBQUMsSUFBWTtRQUNoQyxNQUFNLElBQUksR0FBRyxNQUFNLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUUvQixLQUFLLElBQUksQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUN4QixJQUFJLE1BQU0sSUFBSSxDQUFDLFFBQVEsQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUM7Z0JBQ25ELE9BQU8sQ0FBQyxDQUFDO1lBQ1gsQ0FBQztRQUNILENBQUM7UUFFRCxPQUFPLENBQUMsQ0FBQztJQUNYLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIYXJuZXNzUHJlZGljYXRlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL3Rlc3RpbmcnO1xuaW1wb3J0IHsgU2t5Q29tcG9uZW50SGFybmVzcyB9IGZyb20gJ0Bza3l1eC9jb3JlL3Rlc3RpbmcnO1xuXG5pbXBvcnQgeyBTa3lDb2x1bW5IYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vY29sdW1uLWhhcm5lc3MtZmlsdGVycyc7XG5cbmNvbnN0IHNpemVzID0gWyd4cycsICdzbScsICdtZCcsICdsZyddO1xuXG4vKipcbiAqIEhhcm5lc3MgZm9yIGludGVyYWN0aW5nIHdpdGggYSBmbHVpZCBncmlkIGNvbHVtbiBjb21wb25lbnQgaW4gdGVzdHMuXG4gKi9cbmV4cG9ydCBjbGFzcyBTa3lDb2x1bW5IYXJuZXNzIGV4dGVuZHMgU2t5Q29tcG9uZW50SGFybmVzcyB7XG4gIC8qKlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgaG9zdFNlbGVjdG9yID0gJ3NreS1jb2x1bW4nO1xuXG4gIC8qKlxuICAgKiBHZXRzIGEgYEhhcm5lc3NQcmVkaWNhdGVgIHRoYXQgY2FuIGJlIHVzZWQgdG8gc2VhcmNoIGZvciBhXG4gICAqIGBTa3lDb2x1bW5IYXJuZXNzYCB0aGF0IG1lZXRzIGNlcnRhaW4gY3JpdGVyaWFcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgd2l0aChcbiAgICBmaWx0ZXJzOiBTa3lDb2x1bW5IYXJuZXNzRmlsdGVycyxcbiAgKTogSGFybmVzc1ByZWRpY2F0ZTxTa3lDb2x1bW5IYXJuZXNzPiB7XG4gICAgcmV0dXJuIFNreUNvbHVtbkhhcm5lc3MuZ2V0RGF0YVNreUlkUHJlZGljYXRlKGZpbHRlcnMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldHMgdGhlIHNpemUgb2YgdGhlIGNvbHVtbiBpbiBhbiBYU21hbGwgcmVzcG9uc2l2ZSBjb250ZXh0LlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldFhTbWFsbFNpemUoKTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy4jZ2V0Q29sdW1uU2l6ZSgwKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSBzaXplIG9mIHRoZSBjb2x1bW4gaW4gYSBTbWFsbCByZXNwb25zaXZlIGNvbnRleHQuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U21hbGxTaXplKCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuI2dldENvbHVtblNpemUoMSk7XG4gIH1cblxuICAvKipcbiAgICogR2V0cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uIGluIGEgTWVkaXVtIHJlc3BvbnNpdmUgY29udGV4dC5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBnZXRNZWRpdW1TaXplKCk6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuI2dldENvbHVtblNpemUoMik7XG4gIH1cblxuICAvKipcbiAgICogR2V0cyB0aGUgc2l6ZSBvZiB0aGUgY29sdW1uIGluIGEgTGFyZ2UgcmVzcG9uc2l2ZSBjb250ZXh0LlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldExhcmdlU2l6ZSgpOiBQcm9taXNlPG51bWJlcj4ge1xuICAgIHJldHVybiBhd2FpdCB0aGlzLiNnZXRDb2x1bW5TaXplKDMpO1xuICB9XG5cbiAgYXN5bmMgI2dldENvbHVtblNpemUoaW5kZXg6IG51bWJlcik6IFByb21pc2U8bnVtYmVyPiB7XG4gICAgY29uc3Qgc2l6ZSA9IHNpemVzW2luZGV4XTtcblxuICAgIGNvbnN0IHJlc3VsdCA9IGF3YWl0IHRoaXMuI2dldENvbHVtbkNsYXNzKHNpemUpO1xuXG4gICAgLyogaXN0YW5idWwgaWdub3JlIGlmICovXG4gICAgaWYgKCFyZXN1bHQgJiYgIWluZGV4KSB7XG4gICAgICB0aHJvdyBFcnJvcignTm8gY29sdW1uIHNpemVzIGZvdW5kLicpO1xuICAgIH1cblxuICAgIHJldHVybiByZXN1bHQgfHwgKGF3YWl0IHRoaXMuI2dldENvbHVtblNpemUoaW5kZXggLSAxKSk7XG4gIH1cblxuICBhc3luYyAjZ2V0Q29sdW1uQ2xhc3Moc2l6ZTogc3RyaW5nKTogUHJvbWlzZTxudW1iZXI+IHtcbiAgICBjb25zdCBob3N0ID0gYXdhaXQgdGhpcy5ob3N0KCk7XG5cbiAgICBmb3IgKGxldCBpID0gMTI7IGk7IGktLSkge1xuICAgICAgaWYgKGF3YWl0IGhvc3QuaGFzQ2xhc3MoYHNreS1jb2x1bW4tJHtzaXplfS0ke2l9YCkpIHtcbiAgICAgICAgcmV0dXJuIGk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIDA7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmx1aWQtZ3JpZC1oYXJuZXNzLWZpbHRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3Rlc3Rpbmcvc3JjL21vZHVsZXMvZmx1aWQtZ3JpZC9mbHVpZC1ncmlkLWhhcm5lc3MtZmlsdGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2t5SGFybmVzc0ZpbHRlcnMgfSBmcm9tICdAc2t5dXgvY29yZS90ZXN0aW5nJztcblxuLyoqXG4gKiBBIHNldCBvZiBjcml0ZXJpYSB0aGF0IGNhbiBiZSB1c2VkIHRvIGZpbHRlciBhIGxpc3Qgb2YgYFNreUZsdWlkR3JpZEhhcm5lc3NgIGluc3RhbmNlcy5cbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1pbnRlcmZhY2UsIEB0eXBlc2NyaXB0LWVzbGludC9uby1lbXB0eS1vYmplY3QtdHlwZVxuZXhwb3J0IGludGVyZmFjZSBTa3lGbHVpZEdyaWRIYXJuZXNzRmlsdGVycyBleHRlbmRzIFNreUhhcm5lc3NGaWx0ZXJzIHt9XG4iXX0=
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
2
|
+
import { SkyRowHarness } from './row-harness';
|
|
3
|
+
/**
|
|
4
|
+
* Harness for interacting with a fluid grid component in tests.
|
|
5
|
+
*/
|
|
6
|
+
export class SkyFluidGridHarness extends SkyComponentHarness {
|
|
7
|
+
/**
|
|
8
|
+
* @internal
|
|
9
|
+
*/
|
|
10
|
+
static { this.hostSelector = 'sky-fluid-grid'; }
|
|
11
|
+
#getGrid = this.locatorFor('.sky-fluid-grid');
|
|
12
|
+
#getRows = this.locatorForAll(SkyRowHarness);
|
|
13
|
+
/**
|
|
14
|
+
* Gets a `HarnessPredicate` that can be used to search for a
|
|
15
|
+
* `SkyFluidGridHarness` that meets certain criteria
|
|
16
|
+
*/
|
|
17
|
+
static with(filters) {
|
|
18
|
+
return SkyFluidGridHarness.getDataSkyIdPredicate(filters);
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Gets the gutter size for the grid.
|
|
22
|
+
*/
|
|
23
|
+
async getGutterSize() {
|
|
24
|
+
const grid = await this.#getGrid();
|
|
25
|
+
const small = await grid.hasClass('sky-fluid-grid-gutter-size-small');
|
|
26
|
+
const medium = await grid.hasClass('sky-fluid-grid-gutter-size-medium');
|
|
27
|
+
if (small) {
|
|
28
|
+
return 'small';
|
|
29
|
+
}
|
|
30
|
+
else if (medium) {
|
|
31
|
+
return 'medium';
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
34
|
+
return 'large';
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Gets all of the rows in the grid.
|
|
39
|
+
*/
|
|
40
|
+
async getRows() {
|
|
41
|
+
return await this.#getRows();
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Whether the fluid grid has margin enabled.
|
|
45
|
+
*/
|
|
46
|
+
async hasMargin() {
|
|
47
|
+
return !(await (await this.#getGrid()).hasClass('sky-fluid-grid-no-margin'));
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmx1aWQtZ3JpZC1oYXJuZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL2xheW91dC90ZXN0aW5nL3NyYy9tb2R1bGVzL2ZsdWlkLWdyaWQvZmx1aWQtZ3JpZC1oYXJuZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRzFELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFOUM7O0dBRUc7QUFDSCxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsbUJBQW1CO0lBQzFEOztPQUVHO2FBQ1csaUJBQVksR0FBRyxnQkFBZ0IsQ0FBQztJQUU5QyxRQUFRLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0lBQzlDLFFBQVEsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGFBQWEsQ0FBQyxDQUFDO0lBRTdDOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxJQUFJLENBQ2hCLE9BQW1DO1FBRW5DLE9BQU8sbUJBQW1CLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDNUQsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLGFBQWE7UUFDeEIsTUFBTSxJQUFJLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFbkMsTUFBTSxLQUFLLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLGtDQUFrQyxDQUFDLENBQUM7UUFDdEUsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsUUFBUSxDQUFDLG1DQUFtQyxDQUFDLENBQUM7UUFFeEUsSUFBSSxLQUFLLEVBQUUsQ0FBQztZQUNWLE9BQU8sT0FBTyxDQUFDO1FBQ2pCLENBQUM7YUFBTSxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ2xCLE9BQU8sUUFBUSxDQUFDO1FBQ2xCLENBQUM7YUFBTSxDQUFDO1lBQ04sT0FBTyxPQUFPLENBQUM7UUFDakIsQ0FBQztJQUNILENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxPQUFPO1FBQ2xCLE9BQU8sTUFBTSxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxDQUFDLENBQUMsTUFBTSxDQUNiLE1BQU0sSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUN0QixDQUFDLFFBQVEsQ0FBQywwQkFBMEIsQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhcm5lc3NQcmVkaWNhdGUgfSBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZyc7XG5pbXBvcnQgeyBTa3lDb21wb25lbnRIYXJuZXNzIH0gZnJvbSAnQHNreXV4L2NvcmUvdGVzdGluZyc7XG5cbmltcG9ydCB7IFNreUZsdWlkR3JpZEhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9mbHVpZC1ncmlkLWhhcm5lc3MtZmlsdGVycyc7XG5pbXBvcnQgeyBTa3lSb3dIYXJuZXNzIH0gZnJvbSAnLi9yb3ctaGFybmVzcyc7XG5cbi8qKlxuICogSGFybmVzcyBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBhIGZsdWlkIGdyaWQgY29tcG9uZW50IGluIHRlc3RzLlxuICovXG5leHBvcnQgY2xhc3MgU2t5Rmx1aWRHcmlkSGFybmVzcyBleHRlbmRzIFNreUNvbXBvbmVudEhhcm5lc3Mge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGhvc3RTZWxlY3RvciA9ICdza3ktZmx1aWQtZ3JpZCc7XG5cbiAgI2dldEdyaWQgPSB0aGlzLmxvY2F0b3JGb3IoJy5za3ktZmx1aWQtZ3JpZCcpO1xuICAjZ2V0Um93cyA9IHRoaXMubG9jYXRvckZvckFsbChTa3lSb3dIYXJuZXNzKTtcblxuICAvKipcbiAgICogR2V0cyBhIGBIYXJuZXNzUHJlZGljYXRlYCB0aGF0IGNhbiBiZSB1c2VkIHRvIHNlYXJjaCBmb3IgYVxuICAgKiBgU2t5Rmx1aWRHcmlkSGFybmVzc2AgdGhhdCBtZWV0cyBjZXJ0YWluIGNyaXRlcmlhXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHdpdGgoXG4gICAgZmlsdGVyczogU2t5Rmx1aWRHcmlkSGFybmVzc0ZpbHRlcnMsXG4gICk6IEhhcm5lc3NQcmVkaWNhdGU8U2t5Rmx1aWRHcmlkSGFybmVzcz4ge1xuICAgIHJldHVybiBTa3lGbHVpZEdyaWRIYXJuZXNzLmdldERhdGFTa3lJZFByZWRpY2F0ZShmaWx0ZXJzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIHRoZSBndXR0ZXIgc2l6ZSBmb3IgdGhlIGdyaWQuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0R3V0dGVyU2l6ZSgpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGNvbnN0IGdyaWQgPSBhd2FpdCB0aGlzLiNnZXRHcmlkKCk7XG5cbiAgICBjb25zdCBzbWFsbCA9IGF3YWl0IGdyaWQuaGFzQ2xhc3MoJ3NreS1mbHVpZC1ncmlkLWd1dHRlci1zaXplLXNtYWxsJyk7XG4gICAgY29uc3QgbWVkaXVtID0gYXdhaXQgZ3JpZC5oYXNDbGFzcygnc2t5LWZsdWlkLWdyaWQtZ3V0dGVyLXNpemUtbWVkaXVtJyk7XG5cbiAgICBpZiAoc21hbGwpIHtcbiAgICAgIHJldHVybiAnc21hbGwnO1xuICAgIH0gZWxzZSBpZiAobWVkaXVtKSB7XG4gICAgICByZXR1cm4gJ21lZGl1bSc7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiAnbGFyZ2UnO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIGFsbCBvZiB0aGUgcm93cyBpbiB0aGUgZ3JpZC5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBnZXRSb3dzKCk6IFByb21pc2U8U2t5Um93SGFybmVzc1tdPiB7XG4gICAgcmV0dXJuIGF3YWl0IHRoaXMuI2dldFJvd3MoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRoZSBmbHVpZCBncmlkIGhhcyBtYXJnaW4gZW5hYmxlZC5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBoYXNNYXJnaW4oKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgcmV0dXJuICEoYXdhaXQgKFxuICAgICAgYXdhaXQgdGhpcy4jZ2V0R3JpZCgpXG4gICAgKS5oYXNDbGFzcygnc2t5LWZsdWlkLWdyaWQtbm8tbWFyZ2luJykpO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93LWhhcm5lc3MtZmlsdGVycy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvdGVzdGluZy9zcmMvbW9kdWxlcy9mbHVpZC1ncmlkL3Jvdy1oYXJuZXNzLWZpbHRlcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNreUhhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnQHNreXV4L2NvcmUvdGVzdGluZyc7XG5cbi8qKlxuICogQSBzZXQgb2YgY3JpdGVyaWEgdGhhdCBjYW4gYmUgdXNlZCB0byBmaWx0ZXIgYSBsaXN0IG9mIGBTa3lSb3dIYXJuZXNzYCBpbnN0YW5jZXMuXG4gKi9cbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktaW50ZXJmYWNlLCBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktb2JqZWN0LXR5cGVcbmV4cG9ydCBpbnRlcmZhY2UgU2t5Um93SGFybmVzc0ZpbHRlcnMgZXh0ZW5kcyBTa3lIYXJuZXNzRmlsdGVycyB7fVxuIl19
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { SkyComponentHarness } from '@skyux/core/testing';
|
|
2
|
+
import { SkyColumnHarness } from './column-harness';
|
|
3
|
+
/**
|
|
4
|
+
* Harness for interacting with a fluid grid column component in tests.
|
|
5
|
+
*/
|
|
6
|
+
export class SkyRowHarness extends SkyComponentHarness {
|
|
7
|
+
/**
|
|
8
|
+
* @internal
|
|
9
|
+
*/
|
|
10
|
+
static { this.hostSelector = 'sky-row'; }
|
|
11
|
+
#getRow = this.locatorFor('.sky-row');
|
|
12
|
+
#getColumns = this.locatorForAll(SkyColumnHarness);
|
|
13
|
+
/**
|
|
14
|
+
* Gets a `HarnessPredicate` that can be used to search for a
|
|
15
|
+
* `SkyRowHarness` that meets certain criteria
|
|
16
|
+
*/
|
|
17
|
+
static with(filters) {
|
|
18
|
+
return SkyRowHarness.getDataSkyIdPredicate(filters);
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Gets all of the columns in the row.
|
|
22
|
+
*/
|
|
23
|
+
async getColumns() {
|
|
24
|
+
return await this.#getColumns();
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* Gets the ordering of the columns in the row.
|
|
28
|
+
* @returns `normal` | `reverse`
|
|
29
|
+
*/
|
|
30
|
+
async getColumnOrder() {
|
|
31
|
+
const row = await this.#getRow();
|
|
32
|
+
return (await row.hasClass('sky-row-reverse')) ? 'reverse' : 'normal';
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm93LWhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbXBvbmVudHMvbGF5b3V0L3Rlc3Rpbmcvc3JjL21vZHVsZXMvZmx1aWQtZ3JpZC9yb3ctaGFybmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUUxRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUdwRDs7R0FFRztBQUNILE1BQU0sT0FBTyxhQUFjLFNBQVEsbUJBQW1CO0lBQ3BEOztPQUVHO2FBQ1csaUJBQVksR0FBRyxTQUFTLENBQUM7SUFFdkMsT0FBTyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDdEMsV0FBVyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUVuRDs7O09BR0c7SUFDSSxNQUFNLENBQUMsSUFBSSxDQUNoQixPQUE2QjtRQUU3QixPQUFPLGFBQWEsQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN0RCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxLQUFLLENBQUMsVUFBVTtRQUNyQixPQUFPLE1BQU0sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFRDs7O09BR0c7SUFDSSxLQUFLLENBQUMsY0FBYztRQUN6QixNQUFNLEdBQUcsR0FBRyxNQUFNLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQztRQUVqQyxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUM7SUFDeEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhhcm5lc3NQcmVkaWNhdGUgfSBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZyc7XG5pbXBvcnQgeyBTa3lDb21wb25lbnRIYXJuZXNzIH0gZnJvbSAnQHNreXV4L2NvcmUvdGVzdGluZyc7XG5cbmltcG9ydCB7IFNreUNvbHVtbkhhcm5lc3MgfSBmcm9tICcuL2NvbHVtbi1oYXJuZXNzJztcbmltcG9ydCB7IFNreVJvd0hhcm5lc3NGaWx0ZXJzIH0gZnJvbSAnLi9yb3ctaGFybmVzcy1maWx0ZXJzJztcblxuLyoqXG4gKiBIYXJuZXNzIGZvciBpbnRlcmFjdGluZyB3aXRoIGEgZmx1aWQgZ3JpZCBjb2x1bW4gY29tcG9uZW50IGluIHRlc3RzLlxuICovXG5leHBvcnQgY2xhc3MgU2t5Um93SGFybmVzcyBleHRlbmRzIFNreUNvbXBvbmVudEhhcm5lc3Mge1xuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIGhvc3RTZWxlY3RvciA9ICdza3ktcm93JztcblxuICAjZ2V0Um93ID0gdGhpcy5sb2NhdG9yRm9yKCcuc2t5LXJvdycpO1xuICAjZ2V0Q29sdW1ucyA9IHRoaXMubG9jYXRvckZvckFsbChTa3lDb2x1bW5IYXJuZXNzKTtcblxuICAvKipcbiAgICogR2V0cyBhIGBIYXJuZXNzUHJlZGljYXRlYCB0aGF0IGNhbiBiZSB1c2VkIHRvIHNlYXJjaCBmb3IgYVxuICAgKiBgU2t5Um93SGFybmVzc2AgdGhhdCBtZWV0cyBjZXJ0YWluIGNyaXRlcmlhXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHdpdGgoXG4gICAgZmlsdGVyczogU2t5Um93SGFybmVzc0ZpbHRlcnMsXG4gICk6IEhhcm5lc3NQcmVkaWNhdGU8U2t5Um93SGFybmVzcz4ge1xuICAgIHJldHVybiBTa3lSb3dIYXJuZXNzLmdldERhdGFTa3lJZFByZWRpY2F0ZShmaWx0ZXJzKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIGFsbCBvZiB0aGUgY29sdW1ucyBpbiB0aGUgcm93LlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldENvbHVtbnMoKTogUHJvbWlzZTxTa3lDb2x1bW5IYXJuZXNzW10+IHtcbiAgICByZXR1cm4gYXdhaXQgdGhpcy4jZ2V0Q29sdW1ucygpO1xuICB9XG5cbiAgLyoqXG4gICAqIEdldHMgdGhlIG9yZGVyaW5nIG9mIHRoZSBjb2x1bW5zIGluIHRoZSByb3cuXG4gICAqIEByZXR1cm5zIGBub3JtYWxgIHwgYHJldmVyc2VgXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0Q29sdW1uT3JkZXIoKTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICBjb25zdCByb3cgPSBhd2FpdCB0aGlzLiNnZXRSb3coKTtcblxuICAgIHJldHVybiAoYXdhaXQgcm93Lmhhc0NsYXNzKCdza3ktcm93LXJldmVyc2UnKSkgPyAncmV2ZXJzZScgOiAnbm9ybWFsJztcbiAgfVxufVxuIl19
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
export { SkyActionButtonFixture } from './action-button-fixture';
|
|
2
|
-
export { SkyCardFixture } from './card-fixture';
|
|
3
|
-
export { SkyPageSummaryFixture } from './page-summary-fixture';
|
|
4
|
-
export { SkyBoxHarness } from './box/box-harness';
|
|
5
|
-
export { SkyColumnHarness } from './fluid-grid/column-harness';
|
|
6
|
-
export { SkyFluidGridHarness } from './fluid-grid/fluid-grid-harness';
|
|
7
|
-
export { SkyRowHarness } from './fluid-grid/row-harness';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
export { SkyActionButtonFixture } from './legacy/action-button-fixture';
|
|
2
|
+
export { SkyCardFixture } from './legacy/card-fixture';
|
|
3
|
+
export { SkyPageSummaryFixture } from './legacy/page-summary-fixture';
|
|
4
|
+
export { SkyBoxHarness } from './modules/box/box-harness';
|
|
5
|
+
export { SkyColumnHarness } from './modules/fluid-grid/column-harness';
|
|
6
|
+
export { SkyFluidGridHarness } from './modules/fluid-grid/fluid-grid-harness';
|
|
7
|
+
export { SkyRowHarness } from './modules/fluid-grid/row-harness';
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9sYXlvdXQvdGVzdGluZy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN4RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDdkQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFFdEUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRzFELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBRXZFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBRTlFLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7IFNreUFjdGlvbkJ1dHRvbkZpeHR1cmUgfSBmcm9tICcuL2xlZ2FjeS9hY3Rpb24tYnV0dG9uLWZpeHR1cmUnO1xuZXhwb3J0IHsgU2t5Q2FyZEZpeHR1cmUgfSBmcm9tICcuL2xlZ2FjeS9jYXJkLWZpeHR1cmUnO1xuZXhwb3J0IHsgU2t5UGFnZVN1bW1hcnlGaXh0dXJlIH0gZnJvbSAnLi9sZWdhY3kvcGFnZS1zdW1tYXJ5LWZpeHR1cmUnO1xuXG5leHBvcnQgeyBTa3lCb3hIYXJuZXNzIH0gZnJvbSAnLi9tb2R1bGVzL2JveC9ib3gtaGFybmVzcyc7XG5leHBvcnQgeyBTa3lCb3hIYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vbW9kdWxlcy9ib3gvYm94LWhhcm5lc3MuZmlsdGVycyc7XG5cbmV4cG9ydCB7IFNreUNvbHVtbkhhcm5lc3MgfSBmcm9tICcuL21vZHVsZXMvZmx1aWQtZ3JpZC9jb2x1bW4taGFybmVzcyc7XG5leHBvcnQgeyBTa3lDb2x1bW5IYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vbW9kdWxlcy9mbHVpZC1ncmlkL2NvbHVtbi1oYXJuZXNzLWZpbHRlcnMnO1xuZXhwb3J0IHsgU2t5Rmx1aWRHcmlkSGFybmVzcyB9IGZyb20gJy4vbW9kdWxlcy9mbHVpZC1ncmlkL2ZsdWlkLWdyaWQtaGFybmVzcyc7XG5leHBvcnQgeyBTa3lGbHVpZEdyaWRIYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vbW9kdWxlcy9mbHVpZC1ncmlkL2ZsdWlkLWdyaWQtaGFybmVzcy1maWx0ZXJzJztcbmV4cG9ydCB7IFNreVJvd0hhcm5lc3MgfSBmcm9tICcuL21vZHVsZXMvZmx1aWQtZ3JpZC9yb3ctaGFybmVzcyc7XG5leHBvcnQgeyBTa3lSb3dIYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vbW9kdWxlcy9mbHVpZC1ncmlkL3Jvdy1oYXJuZXNzLWZpbHRlcnMnO1xuIl19
|
|
@@ -163,7 +163,7 @@ class SkyBoxHarness extends SkyComponentHarness {
|
|
|
163
163
|
* Clicks the help inline button.
|
|
164
164
|
*/
|
|
165
165
|
async clickHelpInline() {
|
|
166
|
-
return (await this.#getHelpInline()).click();
|
|
166
|
+
return await (await this.#getHelpInline()).click();
|
|
167
167
|
}
|
|
168
168
|
/**
|
|
169
169
|
* Gets the help popover content.
|
|
@@ -182,7 +182,7 @@ class SkyBoxHarness extends SkyComponentHarness {
|
|
|
182
182
|
* the text will still be returned.
|
|
183
183
|
*/
|
|
184
184
|
async getHeadingText() {
|
|
185
|
-
return (await this.#getHeading()).text();
|
|
185
|
+
return await (await this.#getHeading()).text();
|
|
186
186
|
}
|
|
187
187
|
/**
|
|
188
188
|
* Whether the heading is hidden.
|
|
@@ -223,19 +223,19 @@ class SkyBoxHarness extends SkyComponentHarness {
|
|
|
223
223
|
* Gets the aria-label property of the box
|
|
224
224
|
*/
|
|
225
225
|
async getAriaLabel() {
|
|
226
|
-
return (await this.#getBox()).getAttribute('aria-label');
|
|
226
|
+
return await (await this.#getBox()).getAttribute('aria-label');
|
|
227
227
|
}
|
|
228
228
|
/**
|
|
229
229
|
* Gets the aria-labelledby property of the box
|
|
230
230
|
*/
|
|
231
231
|
async getAriaLabelledby() {
|
|
232
|
-
return (await this.#getBox()).getAttribute('aria-labelledby');
|
|
232
|
+
return await (await this.#getBox()).getAttribute('aria-labelledby');
|
|
233
233
|
}
|
|
234
234
|
/**
|
|
235
235
|
* Gets the aria-role property of the box
|
|
236
236
|
*/
|
|
237
237
|
async getAriaRole() {
|
|
238
|
-
return (await this.#getBox()).getAttribute('role');
|
|
238
|
+
return await (await this.#getBox()).getAttribute('role');
|
|
239
239
|
}
|
|
240
240
|
async #getHelpInline() {
|
|
241
241
|
const harness = await this.locatorForOptional(SkyHelpInlineHarness.with({
|
|
@@ -268,25 +268,25 @@ class SkyColumnHarness extends SkyComponentHarness {
|
|
|
268
268
|
* Gets the size of the column in an XSmall responsive context.
|
|
269
269
|
*/
|
|
270
270
|
async getXSmallSize() {
|
|
271
|
-
return this.#getColumnSize(0);
|
|
271
|
+
return await this.#getColumnSize(0);
|
|
272
272
|
}
|
|
273
273
|
/**
|
|
274
274
|
* Gets the size of the column in a Small responsive context.
|
|
275
275
|
*/
|
|
276
276
|
async getSmallSize() {
|
|
277
|
-
return this.#getColumnSize(1);
|
|
277
|
+
return await this.#getColumnSize(1);
|
|
278
278
|
}
|
|
279
279
|
/**
|
|
280
280
|
* Gets the size of the column in a Medium responsive context.
|
|
281
281
|
*/
|
|
282
282
|
async getMediumSize() {
|
|
283
|
-
return this.#getColumnSize(2);
|
|
283
|
+
return await this.#getColumnSize(2);
|
|
284
284
|
}
|
|
285
285
|
/**
|
|
286
286
|
* Gets the size of the column in a Large responsive context.
|
|
287
287
|
*/
|
|
288
288
|
async getLargeSize() {
|
|
289
|
-
return this.#getColumnSize(3);
|
|
289
|
+
return await this.#getColumnSize(3);
|
|
290
290
|
}
|
|
291
291
|
async #getColumnSize(index) {
|
|
292
292
|
const size = sizes[index];
|