@theseam/ui-common 0.4.13 → 0.4.15
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/buttons/public-api.d.ts +1 -0
- package/buttons/testing/anchor-badge-button.harness.d.ts +16 -0
- package/buttons/testing/anchor-button.harness.d.ts +16 -0
- package/buttons/testing/badge-button.harness.d.ts +15 -0
- package/buttons/testing/base-badge-button.harness.d.ts +15 -0
- package/buttons/testing/base-button.harness.d.ts +19 -0
- package/buttons/testing/button.harness.d.ts +15 -0
- package/buttons/testing/index.d.ts +5 -0
- package/buttons/testing/toggle-button.harness.d.ts +21 -0
- package/checkbox/checkbox.component.d.ts +1 -1
- package/checkbox/checkbox.module.d.ts +2 -3
- package/datatable/datatable.module.d.ts +1 -1
- package/esm2020/buttons/button/button.component.mjs +2 -1
- package/esm2020/buttons/public-api.mjs +2 -1
- package/esm2020/buttons/testing/anchor-badge-button.harness.mjs +18 -0
- package/esm2020/buttons/testing/anchor-button.harness.mjs +18 -0
- package/esm2020/buttons/testing/badge-button.harness.mjs +14 -0
- package/esm2020/buttons/testing/base-badge-button.harness.mjs +29 -0
- package/esm2020/buttons/testing/base-button.harness.mjs +41 -0
- package/esm2020/buttons/testing/button.harness.mjs +16 -0
- package/esm2020/buttons/testing/index.mjs +6 -0
- package/esm2020/buttons/testing/toggle-button.harness.mjs +25 -0
- package/esm2020/checkbox/checkbox.component.mjs +8 -3
- package/esm2020/checkbox/checkbox.module.mjs +5 -12
- package/esm2020/datatable/datatable.module.mjs +5 -5
- package/esm2020/form-field/form-field.component.mjs +4 -4
- package/esm2020/framework/schema-form/index.mjs +2 -1
- package/esm2020/framework/schema-form/schema-form-framework.component.mjs +6 -3
- package/esm2020/framework/schema-form/schema-form-framework.mjs +62 -7
- package/esm2020/framework/schema-form/schema-form-widget.mjs +2 -0
- package/esm2020/framework/schema-form/schema-form.module.mjs +1 -8
- package/esm2020/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.mjs +21 -11
- package/esm2020/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.mjs +20 -0
- package/esm2020/framework/schema-form-controls/schema-form-input/schema-form-input.component.mjs +17 -8
- package/esm2020/framework/schema-form-controls/schema-form-number/schema-form-number.component.mjs +14 -5
- package/esm2020/framework/schema-form-controls/schema-form-select/schema-form-select.component.mjs +19 -9
- package/esm2020/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.mjs +21 -13
- package/esm2020/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.mjs +30 -18
- package/esm2020/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.mjs +48 -0
- package/esm2020/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.mjs +57 -0
- package/esm2020/google-maps/google-maps/google-maps.component.mjs +9 -2
- package/esm2020/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.mjs +2 -1
- package/esm2020/menu/public-api.mjs +5 -1
- package/esm2020/menu/testing/menu-footer.harness.mjs +28 -0
- package/esm2020/menu/testing/menu-header.harness.mjs +23 -0
- package/esm2020/menu/testing/menu-item.harness.mjs +59 -0
- package/esm2020/menu/testing/menu.harness.mjs +163 -0
- package/esm2020/menu/testing/utils.mjs +13 -0
- package/esm2020/story-helpers/args-to-tpl.mjs +83 -0
- package/esm2020/story-helpers/public-api.mjs +2 -2
- package/esm2020/tel-input/public-api.mjs +2 -1
- package/esm2020/tel-input/tel-input/tel-input.component.mjs +22 -10
- package/esm2020/tel-input/tel-input.directive.mjs +12 -13
- package/esm2020/tel-input/tel-input.module.mjs +10 -9
- package/esm2020/tel-input/testing/tel-input.harness.mjs +49 -0
- package/esm2020/testing/harnesses/ng-select-dropdown.harness.mjs +39 -0
- package/esm2020/testing/harnesses/ng-select-option.harness.mjs +26 -0
- package/esm2020/testing/harnesses/ng-select.harness.mjs +104 -0
- package/esm2020/testing/public-api.mjs +4 -1
- package/esm2020/tiled-select/components/tiled-select/tiled-select.component.mjs +1 -1
- package/fesm2015/theseam-ui-common-buttons.mjs +181 -3
- package/fesm2015/theseam-ui-common-buttons.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-checkbox.mjs +12 -14
- package/fesm2015/theseam-ui-common-checkbox.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-datatable.mjs +4 -4
- package/fesm2015/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-form-field.mjs +3 -3
- package/fesm2015/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-framework.mjs +248 -164
- package/fesm2015/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-google-maps.mjs +10 -1
- package/fesm2015/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-menu.mjs +329 -3
- package/fesm2015/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs +86 -1
- package/fesm2015/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tel-input.mjs +105 -29
- package/fesm2015/theseam-ui-common-tel-input.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-testing.mjs +197 -1
- package/fesm2015/theseam-ui-common-testing.mjs.map +1 -1
- package/fesm2015/theseam-ui-common-tiled-select.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-buttons.mjs +154 -2
- package/fesm2020/theseam-ui-common-buttons.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-checkbox.mjs +12 -14
- package/fesm2020/theseam-ui-common-checkbox.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-datatable.mjs +4 -4
- package/fesm2020/theseam-ui-common-datatable.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-form-field.mjs +3 -3
- package/fesm2020/theseam-ui-common-form-field.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-framework.mjs +236 -162
- package/fesm2020/theseam-ui-common-framework.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-google-maps.mjs +9 -1
- package/fesm2020/theseam-ui-common-google-maps.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-menu.mjs +275 -2
- package/fesm2020/theseam-ui-common-menu.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs +84 -1
- package/fesm2020/theseam-ui-common-story-helpers.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tel-input.mjs +89 -29
- package/fesm2020/theseam-ui-common-tel-input.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-testing.mjs +165 -1
- package/fesm2020/theseam-ui-common-testing.mjs.map +1 -1
- package/fesm2020/theseam-ui-common-tiled-select.mjs.map +1 -1
- package/framework/schema-form/index.d.ts +1 -0
- package/framework/schema-form/schema-form-framework.d.ts +12 -1
- package/framework/schema-form/schema-form-widget.d.ts +61 -0
- package/framework/schema-form/schema-form.module.d.ts +1 -2
- package/framework/schema-form-controls/schema-form-checkbox/schema-form-checkbox.component.d.ts +12 -11
- package/framework/schema-form-controls/schema-form-divider/schema-form-divider.component.d.ts +12 -0
- package/framework/schema-form-controls/schema-form-input/schema-form-input.component.d.ts +10 -9
- package/framework/schema-form-controls/schema-form-number/schema-form-number.component.d.ts +8 -7
- package/framework/schema-form-controls/schema-form-select/schema-form-select.component.d.ts +10 -9
- package/framework/schema-form-controls/schema-form-submit/schema-form-submit.component.d.ts +10 -9
- package/framework/schema-form-controls/schema-form-submit-split/schema-form-submit-split.component.d.ts +10 -9
- package/framework/schema-form-controls/schema-form-tel/schema-form-tel.component.d.ts +23 -0
- package/framework/schema-form-controls/schema-form-tiled-select/schema-form-tiled-select.component.d.ts +32 -0
- package/google-maps/google-maps/google-maps.component.d.ts +2 -1
- package/google-maps/google-maps-api-loader/lazy-google-maps-api-loader.d.ts +1 -0
- package/menu/menu-footer-action/menu-footer-action.component.d.ts +1 -1
- package/menu/public-api.d.ts +4 -0
- package/menu/testing/menu-footer.harness.d.ts +22 -0
- package/menu/testing/menu-header.harness.d.ts +18 -0
- package/menu/testing/menu-item.harness.d.ts +37 -0
- package/menu/testing/menu.harness.d.ts +74 -0
- package/menu/testing/utils.d.ts +5 -0
- package/package.json +1 -1
- package/story-helpers/args-to-tpl.d.ts +25 -0
- package/story-helpers/public-api.d.ts +1 -0
- package/tel-input/public-api.d.ts +1 -0
- package/tel-input/tel-input/tel-input.component.d.ts +2 -2
- package/tel-input/tel-input.directive.d.ts +1 -1
- package/tel-input/tel-input.module.d.ts +7 -7
- package/tel-input/testing/tel-input.harness.d.ts +19 -0
- package/testing/harnesses/ng-select-dropdown.harness.d.ts +23 -0
- package/testing/harnesses/ng-select-option.harness.d.ts +18 -0
- package/testing/harnesses/ng-select.harness.d.ts +50 -0
- package/testing/public-api.d.ts +3 -0
- package/tiled-select/components/tiled-select/tiled-select.component.d.ts +10 -10
- package/esm2020/framework/schema-form-controls/schema-form-controls.module.mjs +0 -79
- package/framework/schema-form-controls/schema-form-controls.module.d.ts +0 -20
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
|
|
2
|
+
import { TheSeamNgSelectOptionHarness } from './ng-select-option.harness';
|
|
3
|
+
export class TheSeamNgSelectDropdownHarness extends ComponentHarness {
|
|
4
|
+
// private readonly _ngSelect = this.locatorFor(TheSeamNgSelectDropdownHarness)
|
|
5
|
+
// private readonly _requiredIndicator = this.locatorFor(TheSeamFormFieldRequiredIndicatorHarness)
|
|
6
|
+
// private readonly _valueLabel = this.locatorForOptional('.ng-value-label')
|
|
7
|
+
// private readonly _options = this.locatorForOptional(TheSeamNgSelectOptionHarness)
|
|
8
|
+
/** Creates a `HarnessPredicate` used to locate a particular `MyMenuHarness`. */
|
|
9
|
+
static with(options) {
|
|
10
|
+
return new HarnessPredicate(TheSeamNgSelectDropdownHarness, options)
|
|
11
|
+
.addOption('field id', options.id, (harness, id) => HarnessPredicate.stringMatches(harness.getId(), id));
|
|
12
|
+
}
|
|
13
|
+
async getId() {
|
|
14
|
+
return (await this.host()).getAttribute('id');
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* Gets a list of `TheSeamNgSelectOptionHarness` representing the items in the menu.
|
|
18
|
+
* @param filters Optionally filters which menu items are included.
|
|
19
|
+
*/
|
|
20
|
+
async getOptions(filters) {
|
|
21
|
+
return this.locatorForAll(TheSeamNgSelectOptionHarness.with({
|
|
22
|
+
...(filters || {}),
|
|
23
|
+
}))();
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Clicks an option in the dropdown.
|
|
27
|
+
* @param optionFilter A filter used to represent which option in the dropdown should be clicked. The
|
|
28
|
+
* first matching dropdown option will be clicked.
|
|
29
|
+
*/
|
|
30
|
+
async clickOption(optionFilter) {
|
|
31
|
+
const options = await this.getOptions(optionFilter);
|
|
32
|
+
if (!options.length) {
|
|
33
|
+
throw Error(`Could not find option matching ${JSON.stringify(optionFilter)}`);
|
|
34
|
+
}
|
|
35
|
+
return options[0].click();
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
TheSeamNgSelectDropdownHarness.hostSelector = 'ng-dropdown-panel';
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctc2VsZWN0LWRyb3Bkb3duLmhhcm5lc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1jb21tb24vdGVzdGluZy9oYXJuZXNzZXMvbmctc2VsZWN0LWRyb3Bkb3duLmhhcm5lc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFzQixnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBRzdGLE9BQU8sRUFBRSw0QkFBNEIsRUFBdUMsTUFBTSw0QkFBNEIsQ0FBQTtBQU85RyxNQUFNLE9BQU8sOEJBQStCLFNBQVEsZ0JBQWdCO0lBR2xFLCtFQUErRTtJQUMvRSxrR0FBa0c7SUFDbEcsNEVBQTRFO0lBQzVFLG9GQUFvRjtJQUVwRixnRkFBZ0Y7SUFDaEYsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUE4QztRQUN4RCxPQUFPLElBQUksZ0JBQWdCLENBQUMsOEJBQThCLEVBQUUsT0FBTyxDQUFDO2FBQy9ELFNBQVMsQ0FBQyxVQUFVLEVBQUUsT0FBTyxDQUFDLEVBQUUsRUFDN0IsQ0FBQyxPQUFPLEVBQUUsRUFBRSxFQUFFLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUE7SUFDL0UsQ0FBQztJQUVNLEtBQUssQ0FBQyxLQUFLO1FBQ2hCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUMvQyxDQUFDO0lBRUQ7OztPQUdHO0lBQ0gsS0FBSyxDQUFDLFVBQVUsQ0FDZCxPQUErRDtRQUUvRCxPQUFPLElBQUksQ0FBQyxhQUFhLENBQ3ZCLDRCQUE0QixDQUFDLElBQUksQ0FBQztZQUNoQyxHQUFHLENBQUMsT0FBTyxJQUFJLEVBQUUsQ0FBQztTQUMyQixDQUFDLENBQ2pELEVBQUUsQ0FBQTtJQUNMLENBQUM7SUFFRDs7OztPQUlHO0lBQ0gsS0FBSyxDQUFDLFdBQVcsQ0FDZixZQUFtRTtRQUVuRSxNQUFNLE9BQU8sR0FBRyxNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxDQUFDLENBQUE7UUFDbkQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUU7WUFDbkIsTUFBTSxLQUFLLENBQUMsa0NBQWtDLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBWSxDQUFDLEVBQUUsQ0FBQyxDQUFBO1NBQzlFO1FBRUQsT0FBTyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDM0IsQ0FBQzs7QUE5Q00sMkNBQVksR0FBRyxtQkFBbUIsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jb2VyY2lvbidcbmltcG9ydCB7IEJhc2VIYXJuZXNzRmlsdGVycywgQ29tcG9uZW50SGFybmVzcywgSGFybmVzc1ByZWRpY2F0ZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay90ZXN0aW5nJ1xuXG5pbXBvcnQgeyBUaGVTZWFtRm9ybUZpZWxkUmVxdWlyZWRJbmRpY2F0b3JIYXJuZXNzIH0gZnJvbSAnQHRoZXNlYW0vdWktY29tbW9uL2Zvcm0tZmllbGQnXG5pbXBvcnQgeyBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzLCBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzRmlsdGVycyB9IGZyb20gJy4vbmctc2VsZWN0LW9wdGlvbi5oYXJuZXNzJ1xuXG5leHBvcnQgaW50ZXJmYWNlIFRoZVNlYW1OZ1NlbGVjdERyb3Bkb3duSGFybmVzc0ZpbHRlcnMgZXh0ZW5kcyBCYXNlSGFybmVzc0ZpbHRlcnMge1xuICAvKiogRmlsdGVycyBiYXNlZCBvbiB0aGUgbmFtZSBvZiB0aGUgZmllbGQuICovXG4gIGlkPzogc3RyaW5nIHwgUmVnRXhwXG59XG5cbmV4cG9ydCBjbGFzcyBUaGVTZWFtTmdTZWxlY3REcm9wZG93bkhhcm5lc3MgZXh0ZW5kcyBDb21wb25lbnRIYXJuZXNzIHtcbiAgc3RhdGljIGhvc3RTZWxlY3RvciA9ICduZy1kcm9wZG93bi1wYW5lbCdcblxuICAvLyBwcml2YXRlIHJlYWRvbmx5IF9uZ1NlbGVjdCA9IHRoaXMubG9jYXRvckZvcihUaGVTZWFtTmdTZWxlY3REcm9wZG93bkhhcm5lc3MpXG4gIC8vIHByaXZhdGUgcmVhZG9ubHkgX3JlcXVpcmVkSW5kaWNhdG9yID0gdGhpcy5sb2NhdG9yRm9yKFRoZVNlYW1Gb3JtRmllbGRSZXF1aXJlZEluZGljYXRvckhhcm5lc3MpXG4gIC8vIHByaXZhdGUgcmVhZG9ubHkgX3ZhbHVlTGFiZWwgPSB0aGlzLmxvY2F0b3JGb3JPcHRpb25hbCgnLm5nLXZhbHVlLWxhYmVsJylcbiAgLy8gcHJpdmF0ZSByZWFkb25seSBfb3B0aW9ucyA9IHRoaXMubG9jYXRvckZvck9wdGlvbmFsKFRoZVNlYW1OZ1NlbGVjdE9wdGlvbkhhcm5lc3MpXG5cbiAgLyoqIENyZWF0ZXMgYSBgSGFybmVzc1ByZWRpY2F0ZWAgdXNlZCB0byBsb2NhdGUgYSBwYXJ0aWN1bGFyIGBNeU1lbnVIYXJuZXNzYC4gKi9cbiAgc3RhdGljIHdpdGgob3B0aW9uczogVGhlU2VhbU5nU2VsZWN0RHJvcGRvd25IYXJuZXNzRmlsdGVycyk6IEhhcm5lc3NQcmVkaWNhdGU8VGhlU2VhbU5nU2VsZWN0RHJvcGRvd25IYXJuZXNzPiB7XG4gICAgcmV0dXJuIG5ldyBIYXJuZXNzUHJlZGljYXRlKFRoZVNlYW1OZ1NlbGVjdERyb3Bkb3duSGFybmVzcywgb3B0aW9ucylcbiAgICAgICAgLmFkZE9wdGlvbignZmllbGQgaWQnLCBvcHRpb25zLmlkLFxuICAgICAgICAgICAgKGhhcm5lc3MsIGlkKSA9PiBIYXJuZXNzUHJlZGljYXRlLnN0cmluZ01hdGNoZXMoaGFybmVzcy5nZXRJZCgpLCBpZCkpXG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0SWQoKTogUHJvbWlzZTxzdHJpbmcgfCBudWxsPiB7XG4gICAgcmV0dXJuIChhd2FpdCB0aGlzLmhvc3QoKSkuZ2V0QXR0cmlidXRlKCdpZCcpXG4gIH1cblxuICAvKipcbiAgICogR2V0cyBhIGxpc3Qgb2YgYFRoZVNlYW1OZ1NlbGVjdE9wdGlvbkhhcm5lc3NgIHJlcHJlc2VudGluZyB0aGUgaXRlbXMgaW4gdGhlIG1lbnUuXG4gICAqIEBwYXJhbSBmaWx0ZXJzIE9wdGlvbmFsbHkgZmlsdGVycyB3aGljaCBtZW51IGl0ZW1zIGFyZSBpbmNsdWRlZC5cbiAgICovXG4gIGFzeW5jIGdldE9wdGlvbnMoXG4gICAgZmlsdGVycz86IE9taXQ8VGhlU2VhbU5nU2VsZWN0T3B0aW9uSGFybmVzc0ZpbHRlcnMsICdhbmNlc3Rvcic+LFxuICApOiBQcm9taXNlPFRoZVNlYW1OZ1NlbGVjdE9wdGlvbkhhcm5lc3NbXT4ge1xuICAgIHJldHVybiB0aGlzLmxvY2F0b3JGb3JBbGwoXG4gICAgICBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzLndpdGgoe1xuICAgICAgICAuLi4oZmlsdGVycyB8fCB7fSksXG4gICAgICB9IHNhdGlzZmllcyBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzRmlsdGVycyksXG4gICAgKSgpXG4gIH1cblxuICAvKipcbiAgICogQ2xpY2tzIGFuIG9wdGlvbiBpbiB0aGUgZHJvcGRvd24uXG4gICAqIEBwYXJhbSBvcHRpb25GaWx0ZXIgQSBmaWx0ZXIgdXNlZCB0byByZXByZXNlbnQgd2hpY2ggb3B0aW9uIGluIHRoZSBkcm9wZG93biBzaG91bGQgYmUgY2xpY2tlZC4gVGhlXG4gICAqICAgICBmaXJzdCBtYXRjaGluZyBkcm9wZG93biBvcHRpb24gd2lsbCBiZSBjbGlja2VkLlxuICAgKi9cbiAgYXN5bmMgY2xpY2tPcHRpb24oXG4gICAgb3B0aW9uRmlsdGVyOiBPbWl0PFRoZVNlYW1OZ1NlbGVjdE9wdGlvbkhhcm5lc3NGaWx0ZXJzLCAnYW5jZXN0b3InPlxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBvcHRpb25zID0gYXdhaXQgdGhpcy5nZXRPcHRpb25zKG9wdGlvbkZpbHRlcilcbiAgICBpZiAoIW9wdGlvbnMubGVuZ3RoKSB7XG4gICAgICB0aHJvdyBFcnJvcihgQ291bGQgbm90IGZpbmQgb3B0aW9uIG1hdGNoaW5nICR7SlNPTi5zdHJpbmdpZnkob3B0aW9uRmlsdGVyKX1gKVxuICAgIH1cblxuICAgIHJldHVybiBvcHRpb25zWzBdLmNsaWNrKClcbiAgfVxuXG59XG4iXX0=
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
|
|
3
|
+
export class TheSeamNgSelectOptionHarness extends ComponentHarness {
|
|
4
|
+
/** Creates a `HarnessPredicate` used to locate a particular `MyMenuHarness`. */
|
|
5
|
+
static with(options) {
|
|
6
|
+
return new HarnessPredicate(TheSeamNgSelectOptionHarness, options)
|
|
7
|
+
.addOption('option value', options.value, (harness, value) => HarnessPredicate.stringMatches(harness.getValue(), value));
|
|
8
|
+
}
|
|
9
|
+
/**
|
|
10
|
+
* NOTE: Only works with string values, curently.
|
|
11
|
+
* @returns value of the select option
|
|
12
|
+
*/
|
|
13
|
+
async getValue() {
|
|
14
|
+
return (await this.host()).text();
|
|
15
|
+
}
|
|
16
|
+
/** Whether the ng-select is disabled. */
|
|
17
|
+
async isDisabled() {
|
|
18
|
+
const disabled = (await this.host()).getAttribute('disabled');
|
|
19
|
+
return coerceBooleanProperty(await disabled);
|
|
20
|
+
}
|
|
21
|
+
async click() {
|
|
22
|
+
return (await this.host()).click();
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
TheSeamNgSelectOptionHarness.hostSelector = '.ng-option';
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmctc2VsZWN0LW9wdGlvbi5oYXJuZXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWktY29tbW9uL3Rlc3RpbmcvaGFybmVzc2VzL25nLXNlbGVjdC1vcHRpb24uaGFybmVzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQTtBQUM3RCxPQUFPLEVBQXNCLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUE7QUFPN0YsTUFBTSxPQUFPLDRCQUE2QixTQUFRLGdCQUFnQjtJQUdoRSxnRkFBZ0Y7SUFDaEYsTUFBTSxDQUFDLElBQUksQ0FBQyxPQUE0QztRQUN0RCxPQUFPLElBQUksZ0JBQWdCLENBQUMsNEJBQTRCLEVBQUUsT0FBTyxDQUFDO2FBQzdELFNBQVMsQ0FBQyxjQUFjLEVBQUUsT0FBTyxDQUFDLEtBQUssRUFDcEMsQ0FBQyxPQUFPLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUE7SUFDeEYsQ0FBQztJQUVEOzs7T0FHRztJQUNJLEtBQUssQ0FBQyxRQUFRO1FBQ25CLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFBO0lBQ25DLENBQUM7SUFFRCx5Q0FBeUM7SUFDekMsS0FBSyxDQUFDLFVBQVU7UUFDZCxNQUFNLFFBQVEsR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsWUFBWSxDQUFDLFVBQVUsQ0FBQyxDQUFBO1FBQzdELE9BQU8scUJBQXFCLENBQUMsTUFBTSxRQUFRLENBQUMsQ0FBQTtJQUM5QyxDQUFDO0lBRU0sS0FBSyxDQUFDLEtBQUs7UUFDaEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsS0FBSyxFQUFFLENBQUE7SUFDcEMsQ0FBQzs7QUF6Qk0seUNBQVksR0FBRyxZQUFZLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjb2VyY2VCb29sZWFuUHJvcGVydHkgfSBmcm9tICdAYW5ndWxhci9jZGsvY29lcmNpb24nXG5pbXBvcnQgeyBCYXNlSGFybmVzc0ZpbHRlcnMsIENvbXBvbmVudEhhcm5lc3MsIEhhcm5lc3NQcmVkaWNhdGUgfSBmcm9tICdAYW5ndWxhci9jZGsvdGVzdGluZydcblxuZXhwb3J0IGludGVyZmFjZSBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzRmlsdGVycyBleHRlbmRzIEJhc2VIYXJuZXNzRmlsdGVycyB7XG4gIC8qKiBGaWx0ZXJzIGJhc2VkIG9uIHRoZSB2YWx1ZSBvZiB0aGUgZmllbGQuICovXG4gIHZhbHVlPzogc3RyaW5nIHwgUmVnRXhwXG59XG5cbmV4cG9ydCBjbGFzcyBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzIGV4dGVuZHMgQ29tcG9uZW50SGFybmVzcyB7XG4gIHN0YXRpYyBob3N0U2VsZWN0b3IgPSAnLm5nLW9wdGlvbidcblxuICAvKiogQ3JlYXRlcyBhIGBIYXJuZXNzUHJlZGljYXRlYCB1c2VkIHRvIGxvY2F0ZSBhIHBhcnRpY3VsYXIgYE15TWVudUhhcm5lc3NgLiAqL1xuICBzdGF0aWMgd2l0aChvcHRpb25zOiBUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzRmlsdGVycyk6IEhhcm5lc3NQcmVkaWNhdGU8VGhlU2VhbU5nU2VsZWN0T3B0aW9uSGFybmVzcz4ge1xuICAgIHJldHVybiBuZXcgSGFybmVzc1ByZWRpY2F0ZShUaGVTZWFtTmdTZWxlY3RPcHRpb25IYXJuZXNzLCBvcHRpb25zKVxuICAgICAgICAuYWRkT3B0aW9uKCdvcHRpb24gdmFsdWUnLCBvcHRpb25zLnZhbHVlLFxuICAgICAgICAgICAgKGhhcm5lc3MsIHZhbHVlKSA9PiBIYXJuZXNzUHJlZGljYXRlLnN0cmluZ01hdGNoZXMoaGFybmVzcy5nZXRWYWx1ZSgpLCB2YWx1ZSkpXG4gIH1cblxuICAvKipcbiAgICogTk9URTogT25seSB3b3JrcyB3aXRoIHN0cmluZyB2YWx1ZXMsIGN1cmVudGx5LlxuICAgKiBAcmV0dXJucyB2YWx1ZSBvZiB0aGUgc2VsZWN0IG9wdGlvblxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldFZhbHVlKCk6IFByb21pc2U8YW55PiB7XG4gICAgcmV0dXJuIChhd2FpdCB0aGlzLmhvc3QoKSkudGV4dCgpXG4gIH1cblxuICAvKiogV2hldGhlciB0aGUgbmctc2VsZWN0IGlzIGRpc2FibGVkLiAqL1xuICBhc3luYyBpc0Rpc2FibGVkKCk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICAgIGNvbnN0IGRpc2FibGVkID0gKGF3YWl0IHRoaXMuaG9zdCgpKS5nZXRBdHRyaWJ1dGUoJ2Rpc2FibGVkJylcbiAgICByZXR1cm4gY29lcmNlQm9vbGVhblByb3BlcnR5KGF3YWl0IGRpc2FibGVkKVxuICB9XG5cbiAgcHVibGljIGFzeW5jIGNsaWNrKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5ob3N0KCkpLmNsaWNrKClcbiAgfVxufVxuIl19
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { ComponentHarness, HarnessPredicate } from '@angular/cdk/testing';
|
|
3
|
+
import { TheSeamNgSelectDropdownHarness } from './ng-select-dropdown.harness';
|
|
4
|
+
export class TheSeamNgSelectHarness extends ComponentHarness {
|
|
5
|
+
constructor() {
|
|
6
|
+
super(...arguments);
|
|
7
|
+
this._documentRootLocator = this.documentRootLocatorFactory();
|
|
8
|
+
this._value = this.locatorForOptional('.ng-value');
|
|
9
|
+
this._valueLabel = this.locatorForOptional('.ng-value-label');
|
|
10
|
+
}
|
|
11
|
+
/** Creates a `HarnessPredicate` used to locate a particular `MyMenuHarness`. */
|
|
12
|
+
static with(options) {
|
|
13
|
+
return new HarnessPredicate(TheSeamNgSelectHarness, options);
|
|
14
|
+
// .addOption('field name', options.name,
|
|
15
|
+
// (harness, name) => HarnessPredicate.stringMatches(harness.getName(), name))
|
|
16
|
+
}
|
|
17
|
+
async getId() {
|
|
18
|
+
return (await this.getInputElement()).getAttribute('id');
|
|
19
|
+
}
|
|
20
|
+
async getAriaControls() {
|
|
21
|
+
return (await this.getInputElement()).getAttribute('aria-controls');
|
|
22
|
+
}
|
|
23
|
+
async getName() {
|
|
24
|
+
return (await this.getInputElement()).getAttribute('name');
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* NOTE: Only works with string values, curently.
|
|
28
|
+
* @returns value of the select
|
|
29
|
+
*/
|
|
30
|
+
async getValue() {
|
|
31
|
+
const valueLabel = await this._valueLabel();
|
|
32
|
+
if (valueLabel === null) {
|
|
33
|
+
const value = await this._value();
|
|
34
|
+
if (value === null) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
return value.text();
|
|
38
|
+
}
|
|
39
|
+
return valueLabel.text();
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Gets a list of `TheSeamNgSelectOptionHarness` representing the options in the dropdown.
|
|
43
|
+
*
|
|
44
|
+
* NOTE: Must open the dropdown first. eg. `await ngSelectHarness.click()`
|
|
45
|
+
*
|
|
46
|
+
* @param filters Optionally filters which menu items are included.
|
|
47
|
+
*/
|
|
48
|
+
async getOptions(filters) {
|
|
49
|
+
const dropdown = await this._getDropdown();
|
|
50
|
+
if (dropdown === null) {
|
|
51
|
+
return [];
|
|
52
|
+
}
|
|
53
|
+
return dropdown.getOptions(filters);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Clicks an option in the dropdown.
|
|
57
|
+
* @param optionFilter A filter used to represent which option in the dropdown should be clicked. The
|
|
58
|
+
* first matching dropdown option will be clicked.
|
|
59
|
+
*/
|
|
60
|
+
async clickOption(optionFilter) {
|
|
61
|
+
await this.click();
|
|
62
|
+
const dropdown = await this._getDropdown();
|
|
63
|
+
if (dropdown === null) {
|
|
64
|
+
throw Error(`Could not find dropdown.`);
|
|
65
|
+
}
|
|
66
|
+
return dropdown.clickOption(optionFilter);
|
|
67
|
+
}
|
|
68
|
+
/** Whether the ng-select is disabled. */
|
|
69
|
+
async isDisabled() {
|
|
70
|
+
const disabled = (await this.host()).getAttribute('disabled');
|
|
71
|
+
return coerceBooleanProperty(await disabled);
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Returns the required state of the ng-select.
|
|
75
|
+
*
|
|
76
|
+
* @returns true if the ng-select is required, false if not
|
|
77
|
+
*/
|
|
78
|
+
async isRequired() {
|
|
79
|
+
const required = await (await this.host()).getAttribute('required');
|
|
80
|
+
return required === undefined ? true : coerceBooleanProperty(required);
|
|
81
|
+
}
|
|
82
|
+
async click() {
|
|
83
|
+
return (await this.getInputElement()).click();
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Returns the input element of the checkbox.
|
|
87
|
+
*
|
|
88
|
+
* @returns the input element of the checkbox
|
|
89
|
+
*/
|
|
90
|
+
async getInputElement() {
|
|
91
|
+
return this.locatorFor('input')();
|
|
92
|
+
}
|
|
93
|
+
async _getDropdown() {
|
|
94
|
+
const ariaControls = await this.getAriaControls();
|
|
95
|
+
if (ariaControls) {
|
|
96
|
+
return this._documentRootLocator.locatorForOptional(TheSeamNgSelectDropdownHarness.with({
|
|
97
|
+
id: ariaControls,
|
|
98
|
+
}))();
|
|
99
|
+
}
|
|
100
|
+
return null;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
TheSeamNgSelectHarness.hostSelector = 'ng-select';
|
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ng-select.harness.js","sourceRoot":"","sources":["../../../../../projects/ui-common/testing/harnesses/ng-select.harness.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion'\nimport { BaseHarnessFilters, ComponentHarness, HarnessPredicate } from '@angular/cdk/testing'\n\nimport { TheSeamFormFieldRequiredIndicatorHarness } from '@theseam/ui-common/form-field'\nimport { TheSeamNgSelectOptionHarness, TheSeamNgSelectOptionHarnessFilters } from './ng-select-option.harness'\nimport { TheSeamNgSelectDropdownHarness, TheSeamNgSelectDropdownHarnessFilters } from './ng-select-dropdown.harness'\n\nexport interface TheSeamNgSelectHarnessFilters extends BaseHarnessFilters {\n  /** Filters based on the name of the field. */\n  // name?: string | RegExp\n}\n\nexport class TheSeamNgSelectHarness extends ComponentHarness {\n  private _documentRootLocator = this.documentRootLocatorFactory()\n\n  static hostSelector = 'ng-select'\n\n  private readonly _value = this.locatorForOptional('.ng-value')\n  private readonly _valueLabel = this.locatorForOptional('.ng-value-label')\n\n  /** Creates a `HarnessPredicate` used to locate a particular `MyMenuHarness`. */\n  static with(options: TheSeamNgSelectHarnessFilters): HarnessPredicate<TheSeamNgSelectHarness> {\n    return new HarnessPredicate(TheSeamNgSelectHarness, options)\n        // .addOption('field name', options.name,\n        //     (harness, name) => HarnessPredicate.stringMatches(harness.getName(), name))\n  }\n\n  public async getId(): Promise<string | null> {\n    return (await this.getInputElement()).getAttribute('id')\n  }\n\n  public async getAriaControls(): Promise<string | null> {\n    return (await this.getInputElement()).getAttribute('aria-controls')\n  }\n\n  public async getName(): Promise<string | null> {\n    return (await this.getInputElement()).getAttribute('name')\n  }\n\n  /**\n   * NOTE: Only works with string values, curently.\n   * @returns value of the select\n   */\n  public async getValue(): Promise<any> {\n    const valueLabel = await this._valueLabel()\n    if (valueLabel === null) {\n      const value = await this._value()\n      if (value === null) {\n        return null\n      }\n\n      return value.text()\n    }\n\n    return valueLabel.text()\n  }\n\n  /**\n   * Gets a list of `TheSeamNgSelectOptionHarness` representing the options in the dropdown.\n   *\n   * NOTE: Must open the dropdown first. eg. `await ngSelectHarness.click()`\n   *\n   * @param filters Optionally filters which menu items are included.\n   */\n  async getOptions(\n    filters?: Omit<TheSeamNgSelectOptionHarnessFilters, 'ancestor'>,\n  ): Promise<TheSeamNgSelectOptionHarness[]> {\n    const dropdown = await this._getDropdown()\n    if (dropdown === null) {\n      return []\n    }\n\n    return dropdown.getOptions(filters)\n  }\n\n  /**\n   * Clicks an option in the dropdown.\n   * @param optionFilter A filter used to represent which option in the dropdown should be clicked. The\n   *     first matching dropdown option will be clicked.\n   */\n  async clickOption(\n    optionFilter: Omit<TheSeamNgSelectOptionHarnessFilters, 'ancestor'>\n  ): Promise<void> {\n    await this.click()\n    const dropdown = await this._getDropdown()\n    if (dropdown === null) {\n      throw Error(`Could not find dropdown.`)\n    }\n\n    return dropdown.clickOption(optionFilter)\n  }\n\n  /** Whether the ng-select is disabled. */\n  async isDisabled(): Promise<boolean> {\n    const disabled = (await this.host()).getAttribute('disabled')\n    return coerceBooleanProperty(await disabled)\n  }\n\n  /**\n   * Returns the required state of the ng-select.\n   *\n   * @returns true if the ng-select is required, false if not\n   */\n  public async isRequired(): Promise<boolean> {\n    const required = await (await this.host()).getAttribute('required')\n    return required === undefined ? true : coerceBooleanProperty(required)\n  }\n\n  public async click(): Promise<void> {\n    return (await this.getInputElement()).click()\n  }\n\n  /**\n   * Returns the input element of the checkbox.\n   *\n   * @returns the input element of the checkbox\n   */\n  public async getInputElement() {\n    return this.locatorFor('input')()\n  }\n\n  private async _getDropdown(): Promise<TheSeamNgSelectDropdownHarness | null> {\n    const ariaControls = await this.getAriaControls()\n    if (ariaControls) {\n      return this._documentRootLocator.locatorForOptional(\n        TheSeamNgSelectDropdownHarness.with({\n          id: ariaControls,\n        } satisfies TheSeamNgSelectDropdownHarnessFilters),\n      )()\n    }\n    return null\n  }\n}\n"]}
|
|
@@ -1,7 +1,10 @@
|
|
|
1
|
+
export * from './harnesses/ng-select-dropdown.harness';
|
|
2
|
+
export * from './harnesses/ng-select-option.harness';
|
|
3
|
+
export * from './harnesses/ng-select.harness';
|
|
1
4
|
export * from './fake-toastr';
|
|
2
5
|
export * from './render-story';
|
|
3
6
|
export * from './tick-helper';
|
|
4
7
|
export * from './current-tick-time';
|
|
5
8
|
export * from './story-expect';
|
|
6
9
|
export * from './get-harness';
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWNvbW1vbi90ZXN0aW5nL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3Q0FBd0MsQ0FBQTtBQUN0RCxjQUFjLHNDQUFzQyxDQUFBO0FBQ3BELGNBQWMsK0JBQStCLENBQUE7QUFFN0MsY0FBYyxlQUFlLENBQUE7QUFDN0IsY0FBYyxnQkFBZ0IsQ0FBQTtBQUM5QixjQUFjLGVBQWUsQ0FBQTtBQUM3QixjQUFjLHFCQUFxQixDQUFBO0FBRW5DLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxlQUFlLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2hhcm5lc3Nlcy9uZy1zZWxlY3QtZHJvcGRvd24uaGFybmVzcydcbmV4cG9ydCAqIGZyb20gJy4vaGFybmVzc2VzL25nLXNlbGVjdC1vcHRpb24uaGFybmVzcydcbmV4cG9ydCAqIGZyb20gJy4vaGFybmVzc2VzL25nLXNlbGVjdC5oYXJuZXNzJ1xuXG5leHBvcnQgKiBmcm9tICcuL2Zha2UtdG9hc3RyJ1xuZXhwb3J0ICogZnJvbSAnLi9yZW5kZXItc3RvcnknXG5leHBvcnQgKiBmcm9tICcuL3RpY2staGVscGVyJ1xuZXhwb3J0ICogZnJvbSAnLi9jdXJyZW50LXRpY2stdGltZSdcblxuZXhwb3J0ICogZnJvbSAnLi9zdG9yeS1leHBlY3QnXG5leHBvcnQgKiBmcm9tICcuL2dldC1oYXJuZXNzJ1xuIl19
|
|
@@ -211,4 +211,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
211
211
|
type: ContentChildren,
|
|
212
212
|
args: [TiledSelectTileOverlayDirective]
|
|
213
213
|
}] } });
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.ts","../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAClH,OAAO,EAAgB,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAEjE,OAAO,EAAqB,SAAS,EAAE,eAAe,EAAc,YAAY,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAwB,MAAM,eAAe,CAAA;AACxJ,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAExE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,+BAA+B,EAAE,MAAM,wDAAwD,CAAA;;;;;AAIxG,MAAM,CAAC,MAAM,mBAAmB,GAAG,SAAS,CAAC;IAC3C,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,mBAAmB,EAAE,CAAC;IACrD,OAAO,CAAC,GAAG,EAAE;QACX,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;KACnE,CAAC;CACH,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAQ;IAC9C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;IAC1D,KAAK,EAAE,IAAI;CACZ,CAAA;AAkBD,MAAM,OAAO,2BAA2B;IAUtC,IACI,KAAK,KAAK,OAAO,IAAI,CAAC,MAAM,CAAA,CAAC,CAAC;IAClC,IAAI,KAAK,CAAC,KAAyB;QACjC,MAAM,MAAM,GAAG,CAAE,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAE,CAAA;QACnC,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE;YACtB,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,EAAE;gBACzB,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,EAAE;oBACxB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;iBACpE;gBACD,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAA;aACjB;SACF;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAA;QACxB,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE;YACjC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAA;SACrD;aAAM;YACL,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE;gBACtB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE;oBACtC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAA;oBACpD,MAAK;iBACN;aACF;SACF;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAwBD,YACmB,SAAmB,EACnB,IAAuB,EACvB,SAAoB,EACpB,WAAuB;QAHvB,cAAS,GAAT,SAAS,CAAU;QACnB,SAAI,GAAJ,IAAI,CAAmB;QACvB,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QAvDjC,WAAM,GAAsB,MAAM,CAAA;QA4BnC,WAAM,GAAuB,EAAE,CAAA;QAKd,aAAQ,GAAG,KAAK,CAAA;QAChB,aAAQ,GAAG,KAAK,CAAA;QAChB,wBAAmB,GAAG,IAAI,CAAA;QAC1B,iBAAY,GAAG,KAAK,CAAA;QACpB,qBAAgB,GAAG,IAAI,CAAA;QACvB,uBAAkB,GAAY,IAAI,CAAC,SAAS,CAAC,GAAG,CAAA;QAEzE,4DAA4D;QACzC,WAAM,GAAG,IAAI,YAAY,EAAiC,CAAA;QAE7E,wBAAmB,GAAG,KAAK,CAAA;IAavB,CAAC;IAEL,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,GAAG,CAAA;IACjB,CAAC;IAED,IAAI,KAAK,CAAC,KAAoC;QAC5C,IAAI,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAE,GAAG,CAAC,KAAiB,IAAI,EAAE,CAAC,CAAE,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAA;QAE3E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAA;QAE7E,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;SACzB;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YAAE,IAAI,CAAC,SAAS,EAAE,CAAA;SAAE;IAC1C,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;IACrB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;IAC5B,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,IAAsB;QACtD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;IAC/B,CAAC;IAEM,UAAU,CAAC,IAAsB;QACtC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;gBAC7B,OAAO,IAAI,CAAA;aACZ;SACF;aAAM;YACL,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC1B,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;wBACpB,OAAO,IAAI,CAAA;qBACZ;iBACF;aACF;SACF;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAEM,kBAAkB,CAAC,IAAsB;QAC9C,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACtD,OAAM;SACP;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;SACxB;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;SACtB;IACH,CAAC;IAEM,UAAU,CAAC,IAAsB;QACtC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;gBAC1B,MAAM,KAAK,GAAa,IAAI,CAAC,KAAiB,IAAI,EAAE,CAAA;gBACpD,IAAI,CAAC,KAAK,GAAG,CAAE,GAAG,WAAW,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,KAAK,CAAE,CAAA;aACnD;SACF;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;SACxB;IACH,CAAC;IAEM,YAAY,CAAC,IAAsB;QACxC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,MAAM,KAAK,GAAa,IAAI,CAAC,KAAiB,IAAI,EAAE,CAAA;YACpD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAA;SACjD;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;SACvB;IACH,CAAC;IAEM,gBAAgB;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA;IACnD,CAAC;IAED,aAAa,CAAC,IAAsB;QAClC,+CAA+C;QAC/C,OAAO,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,CAAA;IACzE,CAAC;;wHAjKU,2BAA2B;4GAA3B,2BAA2B,wZAZ3B,CAAE,2BAA2B,CAAE,sDAqEzB,+BAA+B,6BClGlD,kjCA4BA,uvCDKc;QACV,OAAO,CAAC,OAAO,EAAE;YACf,UAAU,CAAC,QAAQ,EAAE;gBACnB,KAAK,CAAC,QAAQ,EAAE,YAAY,CAAC,mBAAmB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aACvE,CAAC;SACH,CAAC;KACH;AA4CwB;IAAf,YAAY,EAAE;6DAAiB;AAChB;IAAf,YAAY,EAAE;6DAAiB;AAChB;IAAf,YAAY,EAAE;wEAA2B;AAC1B;IAAf,YAAY,EAAE;iEAAqB;AACpB;IAAf,YAAY,EAAE;qEAAwB;AACvB;IAAf,YAAY,EAAE;uEAAiD;2FA/C9D,2BAA2B;kBAhBvC,SAAS;+BACE,mBAAmB,aAGlB,CAAE,2BAA2B,CAAE,QACpC;wBACJ,oBAAoB,EAAE,gBAAgB;qBACvC,cACW;wBACV,OAAO,CAAC,OAAO,EAAE;4BACf,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,QAAQ,EAAE,YAAY,CAAC,mBAAmB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;6BACvE,CAAC;yBACH,CAAC;qBACH;gLAWQ,MAAM;sBAAd,KAAK;gBAEF,KAAK;sBADR,KAAK;gBA8BU,GAAG;sBAAlB,KAAK;uBAAC,OAAO;gBAEW,QAAQ;sBAAhC,KAAK;gBACmB,QAAQ;sBAAhC,KAAK;gBACmB,mBAAmB;sBAA3C,KAAK;gBACmB,YAAY;sBAApC,KAAK;gBACmB,gBAAgB;sBAAxC,KAAK;gBACmB,kBAAkB;sBAA1C,KAAK;gBAGa,MAAM;sBAAxB,MAAM;gBAQA,WAAW;sBADjB,eAAe;uBAAC,+BAA+B","sourcesContent":["import { animate, animation, query, stagger, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput, coerceArray } from '@angular/cdk/coercion'\nimport { Platform } from '@angular/cdk/platform'\nimport { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, Output, QueryList, Renderer2 } from '@angular/core'\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { TiledSelectTileOverlayDirective } from './../../directives/tiled-select-tile-overlay.directive'\n\nimport { ITiledSelectItem, TiledSelectLayout } from '../../tiled-select.models'\n\nexport const slideEnterAnimation = animation([\n  style({ opacity: 0, transform: 'translateX(-15px)' }),\n  stagger(100, [\n    animate('0.5s', style({ opacity: 1, transform: 'translateX(0)' }))\n  ])\n])\n\nexport const TILED_SELECT_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => TheSeamTiledSelectComponent),\n  multi: true,\n}\n\n@Component({\n  selector: 'seam-tiled-select',\n  templateUrl: './tiled-select.component.html',\n  styleUrls: ['./tiled-select.component.scss'],\n  providers: [ TILED_SELECT_VALUE_ACCESSOR ],\n  host: {\n    '[attr.data-testid]': '\"tiled-select\"'\n  },\n  animations: [\n    trigger('tiles', [\n      transition('* => *', [\n        query(':enter', useAnimation(slideEnterAnimation), { optional: true })\n      ])\n    ])\n  ],\n})\nexport class TheSeamTiledSelectComponent implements ControlValueAccessor {\n  static ngAcceptInputType_val: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_multiple: BooleanInput\n  static ngAcceptInputType_selectionToggleable: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n  static ngAcceptInputType_animationsDisabled: BooleanInput\n\n  @Input() layout: TiledSelectLayout = 'grid'\n  @Input()\n  get tiles() { return this._tiles }\n  set tiles(value: ITiledSelectItem[]) {\n    const _value = [ ...(value || []) ]\n    for (const v of _value) {\n      if (v.value === undefined) {\n        if (v.name === undefined) {\n          throw new Error('If value is undefined then name must be defined.')\n        }\n        v.value = v.name\n      }\n    }\n\n    const prev = this._tiles\n    if (prev.length !== _value.length) {\n      this.tilesAnimationState = !this.tilesAnimationState\n    } else {\n      for (const t of _value) {\n        if (!prev.find(p => p.name === t.name)) {\n          this.tilesAnimationState = !this.tilesAnimationState\n          break\n        }\n      }\n    }\n\n    this._tiles = _value\n  }\n  private _tiles: ITiledSelectItem[] = []\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('value') val: string | string[] | undefined\n\n  @Input() @InputBoolean() disabled = false\n  @Input() @InputBoolean() multiple = false\n  @Input() @InputBoolean() selectionToggleable = true\n  @Input() @InputBoolean() tileBackdrop = false\n  @Input() @InputBoolean() showSelectedIcon = true\n  @Input() @InputBoolean() animationsDisabled: boolean = this._platform.IOS\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() readonly change = new EventEmitter<string | string[] | undefined>()\n\n  tilesAnimationState = false\n\n  onChange: any\n  onTouched: any\n\n  @ContentChildren(TiledSelectTileOverlayDirective)\n  public overlayTpls?: QueryList<TiledSelectTileOverlayDirective>\n\n  constructor(\n    private readonly _platform: Platform,\n    private readonly _cdr: ChangeDetectorRef,\n    private readonly _renderer: Renderer2,\n    private readonly _elementRef: ElementRef\n  ) { }\n\n  get value(): string | string[] | undefined {\n    return this.val\n  }\n\n  set value(value: string | string[] | undefined) {\n    this.val = (this.multiple) ? [ ...(value as string[] || []) ] : value || ''\n\n    this._renderer.setProperty(this._elementRef.nativeElement, 'value', this.val)\n\n    if (this.onChange) {\n      this.onChange(this.val)\n      this.change.emit(this.val)\n      this._cdr.markForCheck()\n    }\n    if (this.onTouched) { this.onTouched() }\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n  }\n\n  onTileSelected(event: MouseEvent, tile: ITiledSelectItem) {\n    this.toggleTileSelected(tile)\n  }\n\n  public isSelected(tile: ITiledSelectItem) {\n    if (!this.multiple) {\n      if (this.value === tile.value) {\n        return true\n      }\n    } else {\n      if (this.value) {\n        for (const v of this.value) {\n          if (v === tile.value) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  public toggleTileSelected(tile: ITiledSelectItem): void {\n    if (!this.selectionToggleable && this.isSelected(tile)) {\n      return\n    }\n\n    if (this.isSelected(tile)) {\n      this.unselectTile(tile)\n    } else {\n      this.selectTile(tile)\n    }\n  }\n\n  public selectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      if (!this.isSelected(tile)) {\n        const value: string[] = this.value as string[] || []\n        this.value = [ ...coerceArray(value), tile.value ]\n      }\n    } else {\n      this.value = tile.value\n    }\n  }\n\n  public unselectTile(tile: ITiledSelectItem): void {\n    if (this.multiple) {\n      const value: string[] = this.value as string[] || []\n      this.value = value.filter(v => v !== tile.value)\n    } else {\n      this.value = undefined\n    }\n  }\n\n  public getSelectedTiles(): ITiledSelectItem[] {\n    return this.tiles.filter(t => this.isSelected(t))\n  }\n\n  getOverlayTpl(tile: ITiledSelectItem): TiledSelectTileOverlayDirective | undefined {\n    // console.log('overlayTpls', this.overlayTpls)\n    return (this.overlayTpls || []).find(t => t.record?.name === tile.name)\n  }\n\n}\n\n/** @deprecated Use `TheSeamTiledSelectComponent`. */\nexport type TiledSelectComponent = TheSeamTiledSelectComponent\n","<div class=\"tiled-select--container\"\n  [class.grid]=\"layout === 'grid'\"\n  [class.list]=\"layout === 'list'\"\n  [@tiles]=\"tilesAnimationState\"\n  [@.disabled]=\"animationsDisabled\">\n  <ng-container *ngFor=\"let tile of tiles; let index = index\">\n    <div class=\"tile-wrapper\" [ngClass]=\"tile.customClass || ''\">\n      <seam-tiled-select-tile\n        class=\"tiled-select-tile\"\n        [ngClass]=\"tile.customClass || ''\"\n        [name]=\"tile.name\"\n        [label]=\"tile.label\"\n        [icon]=\"tile.icon\"\n        [disabled]=\"disabled || tile.disabled\"\n        [attr.hidden]=\"tile.hidden\"\n        [layout]=\"layout\"\n        [selected]=\"isSelected(tile)\"\n        [selectable]=\"true\"\n        [tileBackdrop]=\"tileBackdrop\"\n        [showSelectedIcon]=\"showSelectedIcon\"\n        [overlayTpl]=\"getOverlayTpl(tile)\"\n        (activated)=\"onTileSelected($event, tile)\"\n        [attr.data-tile-index]=\"index\"\n        [attr.data-testid]=\"tile.name\">\n      </seam-tiled-select-tile>\n    </div>\n  </ng-container>\n</div>\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiled-select.component.js","sourceRoot":"","sources":["../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.ts","../../../../../../projects/ui-common/tiled-select/components/tiled-select/tiled-select.component.html"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAA;AAClH,OAAO,EAAgB,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAEjE,OAAO,EAAqB,SAAS,EAAE,eAAe,EAAc,YAAY,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAwB,MAAM,eAAe,CAAA;AACxJ,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAExE,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAEtD,OAAO,EAAE,+BAA+B,EAAE,MAAM,wDAAwD,CAAA;;;;;AAIxG,MAAM,CAAC,MAAM,mBAAmB,GAAG,SAAS,CAAC;IAC3C,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,mBAAmB,EAAE,CAAC;IACrD,OAAO,CAAC,GAAG,EAAE;QACX,OAAO,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,SAAS,EAAE,eAAe,EAAE,CAAC,CAAC;KACnE,CAAC;CACH,CAAC,CAAA;AAEF,MAAM,CAAC,MAAM,2BAA2B,GAAQ;IAC9C,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,2BAA2B,CAAC;IAC1D,KAAK,EAAE,IAAI;CACZ,CAAA;AAkBD,MAAM,OAAO,2BAA2B;IAUtC,IACI,KAAK,KAAK,OAAO,IAAI,CAAC,MAAM,CAAA,CAAC,CAAC;IAClC,IAAI,KAAK,CAAC,KAAwB;QAChC,MAAM,MAAM,GAAG,CAAE,GAAG,CAAC,KAAK,IAAI,EAAE,CAAC,CAAE,CAAA;QACnC,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE;YACtB,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,EAAE;gBACzB,IAAI,CAAC,CAAC,IAAI,KAAK,SAAS,EAAE;oBACxB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAA;iBACpE;gBACD,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAA;aACjB;SACF;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAA;QACxB,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE;YACjC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAA;SACrD;aAAM;YACL,KAAK,MAAM,CAAC,IAAI,MAAM,EAAE;gBACtB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE;oBACtC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAA;oBACpD,MAAK;iBACN;aACF;SACF;QAED,IAAI,CAAC,MAAM,GAAG,MAAM,CAAA;IACtB,CAAC;IAwBD,YACmB,SAAmB,EACnB,IAAuB,EACvB,SAAoB,EACpB,WAAuB;QAHvB,cAAS,GAAT,SAAS,CAAU;QACnB,SAAI,GAAJ,IAAI,CAAmB;QACvB,cAAS,GAAT,SAAS,CAAW;QACpB,gBAAW,GAAX,WAAW,CAAY;QAvDjC,WAAM,GAAsB,MAAM,CAAA;QA4BnC,WAAM,GAAsB,EAAE,CAAA;QAKb,aAAQ,GAAG,KAAK,CAAA;QAChB,aAAQ,GAAG,KAAK,CAAA;QAChB,wBAAmB,GAAG,IAAI,CAAA;QAC1B,iBAAY,GAAG,KAAK,CAAA;QACpB,qBAAgB,GAAG,IAAI,CAAA;QACvB,uBAAkB,GAAY,IAAI,CAAC,SAAS,CAAC,GAAG,CAAA;QAEzE,4DAA4D;QACzC,WAAM,GAAG,IAAI,YAAY,EAAiC,CAAA;QAE7E,wBAAmB,GAAG,KAAK,CAAA;IAavB,CAAC;IAEL,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,GAAG,CAAA;IACjB,CAAC;IAED,IAAI,KAAK,CAAC,KAAoC;QAC5C,IAAI,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAE,GAAG,CAAC,KAAiB,IAAI,EAAE,CAAC,CAAE,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAA;QAE3E,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,OAAO,EAAE,IAAI,CAAC,GAAG,CAAC,CAAA;QAE7E,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YACvB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;YAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAA;SACzB;QACD,IAAI,IAAI,CAAC,SAAS,EAAE;YAAE,IAAI,CAAC,SAAS,EAAE,CAAA;SAAE;IAC1C,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;IACpB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAA;IACpB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAA;IACrB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;IAC5B,CAAC;IAED,cAAc,CAAC,KAAiB,EAAE,IAAqB;QACrD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAA;IAC/B,CAAC;IAEM,UAAU,CAAC,IAAqB;QACrC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,EAAE;gBAC7B,OAAO,IAAI,CAAA;aACZ;SACF;aAAM;YACL,IAAI,IAAI,CAAC,KAAK,EAAE;gBACd,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC1B,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;wBACpB,OAAO,IAAI,CAAA;qBACZ;iBACF;aACF;SACF;QAED,OAAO,KAAK,CAAA;IACd,CAAC;IAEM,kBAAkB,CAAC,IAAqB;QAC7C,IAAI,CAAC,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACtD,OAAM;SACP;QAED,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YACzB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAA;SACxB;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;SACtB;IACH,CAAC;IAEM,UAAU,CAAC,IAAqB;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;gBAC1B,MAAM,KAAK,GAAa,IAAI,CAAC,KAAiB,IAAI,EAAE,CAAA;gBACpD,IAAI,CAAC,KAAK,GAAG,CAAE,GAAG,WAAW,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,KAAK,CAAE,CAAA;aACnD;SACF;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAA;SACxB;IACH,CAAC;IAEM,YAAY,CAAC,IAAqB;QACvC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,MAAM,KAAK,GAAa,IAAI,CAAC,KAAiB,IAAI,EAAE,CAAA;YACpD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,KAAK,CAAC,CAAA;SACjD;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,SAAS,CAAA;SACvB;IACH,CAAC;IAEM,gBAAgB;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAA;IACnD,CAAC;IAED,aAAa,CAAC,IAAqB;QACjC,+CAA+C;QAC/C,OAAO,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,KAAK,IAAI,CAAC,IAAI,CAAC,CAAA;IACzE,CAAC;;wHAjKU,2BAA2B;4GAA3B,2BAA2B,wZAZ3B,CAAE,2BAA2B,CAAE,sDAqEzB,+BAA+B,6BClGlD,kjCA4BA,uvCDKc;QACV,OAAO,CAAC,OAAO,EAAE;YACf,UAAU,CAAC,QAAQ,EAAE;gBACnB,KAAK,CAAC,QAAQ,EAAE,YAAY,CAAC,mBAAmB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;aACvE,CAAC;SACH,CAAC;KACH;AA4CwB;IAAf,YAAY,EAAE;6DAAiB;AAChB;IAAf,YAAY,EAAE;6DAAiB;AAChB;IAAf,YAAY,EAAE;wEAA2B;AAC1B;IAAf,YAAY,EAAE;iEAAqB;AACpB;IAAf,YAAY,EAAE;qEAAwB;AACvB;IAAf,YAAY,EAAE;uEAAiD;2FA/C9D,2BAA2B;kBAhBvC,SAAS;+BACE,mBAAmB,aAGlB,CAAE,2BAA2B,CAAE,QACpC;wBACJ,oBAAoB,EAAE,gBAAgB;qBACvC,cACW;wBACV,OAAO,CAAC,OAAO,EAAE;4BACf,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,QAAQ,EAAE,YAAY,CAAC,mBAAmB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;6BACvE,CAAC;yBACH,CAAC;qBACH;gLAWQ,MAAM;sBAAd,KAAK;gBAEF,KAAK;sBADR,KAAK;gBA8BU,GAAG;sBAAlB,KAAK;uBAAC,OAAO;gBAEW,QAAQ;sBAAhC,KAAK;gBACmB,QAAQ;sBAAhC,KAAK;gBACmB,mBAAmB;sBAA3C,KAAK;gBACmB,YAAY;sBAApC,KAAK;gBACmB,gBAAgB;sBAAxC,KAAK;gBACmB,kBAAkB;sBAA1C,KAAK;gBAGa,MAAM;sBAAxB,MAAM;gBAQA,WAAW;sBADjB,eAAe;uBAAC,+BAA+B","sourcesContent":["import { animate, animation, query, stagger, style, transition, trigger, useAnimation } from '@angular/animations'\nimport { BooleanInput, coerceArray } from '@angular/cdk/coercion'\nimport { Platform } from '@angular/cdk/platform'\nimport { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, forwardRef, Input, Output, QueryList, Renderer2 } from '@angular/core'\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms'\n\nimport { InputBoolean } from '@theseam/ui-common/core'\n\nimport { TiledSelectTileOverlayDirective } from './../../directives/tiled-select-tile-overlay.directive'\n\nimport { TiledSelectItem, TiledSelectLayout } from '../../tiled-select.models'\n\nexport const slideEnterAnimation = animation([\n  style({ opacity: 0, transform: 'translateX(-15px)' }),\n  stagger(100, [\n    animate('0.5s', style({ opacity: 1, transform: 'translateX(0)' }))\n  ])\n])\n\nexport const TILED_SELECT_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => TheSeamTiledSelectComponent),\n  multi: true,\n}\n\n@Component({\n  selector: 'seam-tiled-select',\n  templateUrl: './tiled-select.component.html',\n  styleUrls: ['./tiled-select.component.scss'],\n  providers: [ TILED_SELECT_VALUE_ACCESSOR ],\n  host: {\n    '[attr.data-testid]': '\"tiled-select\"'\n  },\n  animations: [\n    trigger('tiles', [\n      transition('* => *', [\n        query(':enter', useAnimation(slideEnterAnimation), { optional: true })\n      ])\n    ])\n  ],\n})\nexport class TheSeamTiledSelectComponent implements ControlValueAccessor {\n  static ngAcceptInputType_val: BooleanInput\n  static ngAcceptInputType_disabled: BooleanInput\n  static ngAcceptInputType_multiple: BooleanInput\n  static ngAcceptInputType_selectionToggleable: BooleanInput\n  static ngAcceptInputType_tileBackdrop: BooleanInput\n  static ngAcceptInputType_showSelectedIcon: BooleanInput\n  static ngAcceptInputType_animationsDisabled: BooleanInput\n\n  @Input() layout: TiledSelectLayout = 'grid'\n  @Input()\n  get tiles() { return this._tiles }\n  set tiles(value: TiledSelectItem[]) {\n    const _value = [ ...(value || []) ]\n    for (const v of _value) {\n      if (v.value === undefined) {\n        if (v.name === undefined) {\n          throw new Error('If value is undefined then name must be defined.')\n        }\n        v.value = v.name\n      }\n    }\n\n    const prev = this._tiles\n    if (prev.length !== _value.length) {\n      this.tilesAnimationState = !this.tilesAnimationState\n    } else {\n      for (const t of _value) {\n        if (!prev.find(p => p.name === t.name)) {\n          this.tilesAnimationState = !this.tilesAnimationState\n          break\n        }\n      }\n    }\n\n    this._tiles = _value\n  }\n  private _tiles: TiledSelectItem[] = []\n\n  // eslint-disable-next-line @angular-eslint/no-input-rename\n  @Input('value') val: string | string[] | undefined\n\n  @Input() @InputBoolean() disabled = false\n  @Input() @InputBoolean() multiple = false\n  @Input() @InputBoolean() selectionToggleable = true\n  @Input() @InputBoolean() tileBackdrop = false\n  @Input() @InputBoolean() showSelectedIcon = true\n  @Input() @InputBoolean() animationsDisabled: boolean = this._platform.IOS\n\n  // eslint-disable-next-line @angular-eslint/no-output-native\n  @Output() readonly change = new EventEmitter<string | string[] | undefined>()\n\n  tilesAnimationState = false\n\n  onChange: any\n  onTouched: any\n\n  @ContentChildren(TiledSelectTileOverlayDirective)\n  public overlayTpls?: QueryList<TiledSelectTileOverlayDirective>\n\n  constructor(\n    private readonly _platform: Platform,\n    private readonly _cdr: ChangeDetectorRef,\n    private readonly _renderer: Renderer2,\n    private readonly _elementRef: ElementRef\n  ) { }\n\n  get value(): string | string[] | undefined {\n    return this.val\n  }\n\n  set value(value: string | string[] | undefined) {\n    this.val = (this.multiple) ? [ ...(value as string[] || []) ] : value || ''\n\n    this._renderer.setProperty(this._elementRef.nativeElement, 'value', this.val)\n\n    if (this.onChange) {\n      this.onChange(this.val)\n      this.change.emit(this.val)\n      this._cdr.markForCheck()\n    }\n    if (this.onTouched) { this.onTouched() }\n  }\n\n  writeValue(value: any): void {\n    this.value = value\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled\n  }\n\n  onTileSelected(event: MouseEvent, tile: TiledSelectItem) {\n    this.toggleTileSelected(tile)\n  }\n\n  public isSelected(tile: TiledSelectItem) {\n    if (!this.multiple) {\n      if (this.value === tile.value) {\n        return true\n      }\n    } else {\n      if (this.value) {\n        for (const v of this.value) {\n          if (v === tile.value) {\n            return true\n          }\n        }\n      }\n    }\n\n    return false\n  }\n\n  public toggleTileSelected(tile: TiledSelectItem): void {\n    if (!this.selectionToggleable && this.isSelected(tile)) {\n      return\n    }\n\n    if (this.isSelected(tile)) {\n      this.unselectTile(tile)\n    } else {\n      this.selectTile(tile)\n    }\n  }\n\n  public selectTile(tile: TiledSelectItem): void {\n    if (this.multiple) {\n      if (!this.isSelected(tile)) {\n        const value: string[] = this.value as string[] || []\n        this.value = [ ...coerceArray(value), tile.value ]\n      }\n    } else {\n      this.value = tile.value\n    }\n  }\n\n  public unselectTile(tile: TiledSelectItem): void {\n    if (this.multiple) {\n      const value: string[] = this.value as string[] || []\n      this.value = value.filter(v => v !== tile.value)\n    } else {\n      this.value = undefined\n    }\n  }\n\n  public getSelectedTiles(): TiledSelectItem[] {\n    return this.tiles.filter(t => this.isSelected(t))\n  }\n\n  getOverlayTpl(tile: TiledSelectItem): TiledSelectTileOverlayDirective | undefined {\n    // console.log('overlayTpls', this.overlayTpls)\n    return (this.overlayTpls || []).find(t => t.record?.name === tile.name)\n  }\n\n}\n\n/** @deprecated Use `TheSeamTiledSelectComponent`. */\nexport type TiledSelectComponent = TheSeamTiledSelectComponent\n","<div class=\"tiled-select--container\"\n  [class.grid]=\"layout === 'grid'\"\n  [class.list]=\"layout === 'list'\"\n  [@tiles]=\"tilesAnimationState\"\n  [@.disabled]=\"animationsDisabled\">\n  <ng-container *ngFor=\"let tile of tiles; let index = index\">\n    <div class=\"tile-wrapper\" [ngClass]=\"tile.customClass || ''\">\n      <seam-tiled-select-tile\n        class=\"tiled-select-tile\"\n        [ngClass]=\"tile.customClass || ''\"\n        [name]=\"tile.name\"\n        [label]=\"tile.label\"\n        [icon]=\"tile.icon\"\n        [disabled]=\"disabled || tile.disabled\"\n        [attr.hidden]=\"tile.hidden\"\n        [layout]=\"layout\"\n        [selected]=\"isSelected(tile)\"\n        [selectable]=\"true\"\n        [tileBackdrop]=\"tileBackdrop\"\n        [showSelectedIcon]=\"showSelectedIcon\"\n        [overlayTpl]=\"getOverlayTpl(tile)\"\n        (activated)=\"onTileSelected($event, tile)\"\n        [attr.data-tile-index]=\"index\"\n        [attr.data-testid]=\"tile.name\">\n      </seam-tiled-select-tile>\n    </div>\n  </ng-container>\n</div>\n"]}
|
|
@@ -1,14 +1,191 @@
|
|
|
1
|
+
import { __awaiter, __decorate } from 'tslib';
|
|
2
|
+
import { ThemeNames, OutlineThemeNames } from '@theseam/ui-common/models';
|
|
3
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
4
|
+
import { HarnessPredicate, ContentContainerComponentHarness } from '@angular/cdk/testing';
|
|
1
5
|
import * as i0 from '@angular/core';
|
|
2
6
|
import { Component, ChangeDetectionStrategy, Input, HostBinding, forwardRef, EventEmitter, Output, NgModule } from '@angular/core';
|
|
3
7
|
import { mixinSize, mixinTheme, mixinDisabled, InputBoolean, InputNumber } from '@theseam/ui-common/core';
|
|
4
8
|
import * as i1 from '@angular/cdk/a11y';
|
|
5
|
-
import { __decorate } from 'tslib';
|
|
6
9
|
import * as i2 from '@theseam/ui-common/progress';
|
|
7
10
|
import { TheSeamProgressModule } from '@theseam/ui-common/progress';
|
|
8
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
9
11
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
10
12
|
import { CommonModule } from '@angular/common';
|
|
11
13
|
|
|
14
|
+
const THEME_NAMES$1 = [...ThemeNames, ...OutlineThemeNames];
|
|
15
|
+
const THEME_CLASSES$1 = THEME_NAMES$1.map(t => `btn-${t}`);
|
|
16
|
+
function getButtonThemeClass(classListString) {
|
|
17
|
+
return ((classListString === null || classListString === void 0 ? void 0 : classListString.split(' ')) || []).find(c => THEME_CLASSES$1.includes(c));
|
|
18
|
+
}
|
|
19
|
+
function createBaseButtonComponentHarnessPredicate(componentHarness, options = {}) {
|
|
20
|
+
return new HarnessPredicate(componentHarness, options)
|
|
21
|
+
.addOption('text', options.text, (harness, text) => HarnessPredicate.stringMatches(harness.getText(), text))
|
|
22
|
+
.addOption('type', options.type, (harness, type) => HarnessPredicate.stringMatches(harness.getType(), type));
|
|
23
|
+
}
|
|
24
|
+
class TheSeamBaseButtonComponentHarness extends ContentContainerComponentHarness {
|
|
25
|
+
/** Whether the button is disabled. */
|
|
26
|
+
isDisabled() {
|
|
27
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
28
|
+
const disabled = (yield this.host()).getAttribute('disabled');
|
|
29
|
+
return coerceBooleanProperty(yield disabled);
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
hasDisabledAria() {
|
|
33
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
34
|
+
const ariaValue = yield (yield this.host()).getAttribute('aria-disabled');
|
|
35
|
+
return ariaValue === 'true';
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
getType() {
|
|
39
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
40
|
+
return (yield this.host()).getAttribute('type');
|
|
41
|
+
});
|
|
42
|
+
}
|
|
43
|
+
/** Gets the text of the button item. */
|
|
44
|
+
getText() {
|
|
45
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
+
return (yield this.host()).text();
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
/** Gets the theme of the button item. */
|
|
50
|
+
getTheme() {
|
|
51
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
52
|
+
return (yield this.host()).getAttribute('class').then(c => { var _a; return ((_a = getButtonThemeClass(c)) === null || _a === void 0 ? void 0 : _a.replace('btn-', '')) || null; });
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
click() {
|
|
56
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
57
|
+
return (yield this.host()).click();
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
const THEME_NAMES = [...ThemeNames, ...OutlineThemeNames];
|
|
63
|
+
const THEME_CLASSES = THEME_NAMES.map(t => `badge-${t}`);
|
|
64
|
+
function getbadgeThemeClass(classListString) {
|
|
65
|
+
return ((classListString === null || classListString === void 0 ? void 0 : classListString.split(' ')) || []).find(c => THEME_CLASSES.includes(c));
|
|
66
|
+
}
|
|
67
|
+
function createBaseBadgeButtonComponentHarnessPredicate(componentHarness, options = {}) {
|
|
68
|
+
return createBaseButtonComponentHarnessPredicate(componentHarness, options);
|
|
69
|
+
}
|
|
70
|
+
class TheSeamBaseBadgeButtonComponentHarness extends TheSeamBaseButtonComponentHarness {
|
|
71
|
+
constructor() {
|
|
72
|
+
super(...arguments);
|
|
73
|
+
this._badgeElement = this.locatorFor('.badge');
|
|
74
|
+
}
|
|
75
|
+
/** Gets the text of the button item. */
|
|
76
|
+
getText() {
|
|
77
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
+
return (yield this.host()).text({ exclude: '.badge' });
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
/** Gets the text of the badge. */
|
|
82
|
+
getBadgeText() {
|
|
83
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
84
|
+
return (yield this._badgeElement()).text();
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
/** Gets the theme of the badge. */
|
|
88
|
+
getBadgeTheme() {
|
|
89
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
90
|
+
return (yield this._badgeElement()).getAttribute('class').then(c => { var _a; return ((_a = getbadgeThemeClass(c)) === null || _a === void 0 ? void 0 : _a.replace('badge-', '')) || null; });
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
class TheSeamAnchorBadgeButtonComponentHarness extends TheSeamBaseBadgeButtonComponentHarness {
|
|
96
|
+
/**
|
|
97
|
+
* Gets a `HarnessPredicate` that can be used to search for a button item with specific attributes.
|
|
98
|
+
* @param options Options for filtering which button item instances are considered a match.
|
|
99
|
+
* @return a `HarnessPredicate` configured with the given options.
|
|
100
|
+
*/
|
|
101
|
+
static with(options = {}) {
|
|
102
|
+
return createBaseBadgeButtonComponentHarnessPredicate(this, options);
|
|
103
|
+
}
|
|
104
|
+
getTabIndex() {
|
|
105
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
106
|
+
const tabIndex = yield (yield this.host()).getAttribute('tabindex');
|
|
107
|
+
return Number(tabIndex);
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
/** The selector for the host element of a `TheSeamAnchorBadgeButtonComponent` instance. */
|
|
112
|
+
TheSeamAnchorBadgeButtonComponentHarness.hostSelector = 'a[seamBadgeButton]';
|
|
113
|
+
|
|
114
|
+
class TheSeamAnchorButtonComponentHarness extends TheSeamBaseButtonComponentHarness {
|
|
115
|
+
/**
|
|
116
|
+
* Gets a `HarnessPredicate` that can be used to search for a button item with specific attributes.
|
|
117
|
+
* @param options Options for filtering which button item instances are considered a match.
|
|
118
|
+
* @return a `HarnessPredicate` configured with the given options.
|
|
119
|
+
*/
|
|
120
|
+
static with(options = {}) {
|
|
121
|
+
return createBaseButtonComponentHarnessPredicate(this, options);
|
|
122
|
+
}
|
|
123
|
+
getTabIndex() {
|
|
124
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
125
|
+
const tabIndex = yield (yield this.host()).getAttribute('tabindex');
|
|
126
|
+
return Number(tabIndex);
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
/** The selector for the host element of a `TheSeamAnchorButtonComponent` instance. */
|
|
131
|
+
TheSeamAnchorButtonComponentHarness.hostSelector = 'a[seamButton]';
|
|
132
|
+
|
|
133
|
+
class TheSeamBadgeButtonComponentHarness extends TheSeamBaseBadgeButtonComponentHarness {
|
|
134
|
+
/**
|
|
135
|
+
* Gets a `HarnessPredicate` that can be used to search for a button item with specific attributes.
|
|
136
|
+
* @param options Options for filtering which button item instances are considered a match.
|
|
137
|
+
* @return a `HarnessPredicate` configured with the given options.
|
|
138
|
+
*/
|
|
139
|
+
static with(options = {}) {
|
|
140
|
+
return createBaseBadgeButtonComponentHarnessPredicate(this, options);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/** The selector for the host element of a `TheSeamBadgeButtonComponent` instance. */
|
|
144
|
+
TheSeamBadgeButtonComponentHarness.hostSelector = 'button[seamBadgeButton]';
|
|
145
|
+
|
|
146
|
+
// import { TheSeamMenuHarness } from './button.harness'
|
|
147
|
+
// import { animatingWait } from './utils'
|
|
148
|
+
class TheSeamButtonComponentHarness extends TheSeamBaseButtonComponentHarness {
|
|
149
|
+
/**
|
|
150
|
+
* Gets a `HarnessPredicate` that can be used to search for a button item with specific attributes.
|
|
151
|
+
* @param options Options for filtering which button item instances are considered a match.
|
|
152
|
+
* @return a `HarnessPredicate` configured with the given options.
|
|
153
|
+
*/
|
|
154
|
+
static with(options = {}) {
|
|
155
|
+
return createBaseButtonComponentHarnessPredicate(this, options);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
/** The selector for the host element of a `TheSeamButtonComponent` instance. */
|
|
159
|
+
TheSeamButtonComponentHarness.hostSelector = 'button[seamButton]';
|
|
160
|
+
|
|
161
|
+
class TheSeamToggleButtonComponentHarness extends TheSeamBaseButtonComponentHarness {
|
|
162
|
+
/**
|
|
163
|
+
* Gets a `HarnessPredicate` that can be used to search for a button item with specific attributes.
|
|
164
|
+
* @param options Options for filtering which button item instances are considered a match.
|
|
165
|
+
* @return a `HarnessPredicate` configured with the given options.
|
|
166
|
+
*/
|
|
167
|
+
static with(options = {}) {
|
|
168
|
+
return createBaseButtonComponentHarnessPredicate(this, options);
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Clicks the button.
|
|
172
|
+
*/
|
|
173
|
+
click() {
|
|
174
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
175
|
+
return (yield this.host()).click();
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
/** Gets the theme of the button item. */
|
|
179
|
+
isActive() {
|
|
180
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
181
|
+
return (yield this.host()).getAttribute('class')
|
|
182
|
+
.then(c => ((c === null || c === void 0 ? void 0 : c.split(' ').indexOf('active')) !== -1) || false);
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
/** The selector for the host element of a `TheSeamToggleButtonComponent` instance. */
|
|
187
|
+
TheSeamToggleButtonComponentHarness.hostSelector = 'button[seamToggleButton]';
|
|
188
|
+
|
|
12
189
|
class TheSeamButtonBase {
|
|
13
190
|
constructor(_elementRef, _focusMonitor, _renderer) {
|
|
14
191
|
this._elementRef = _elementRef;
|
|
@@ -80,6 +257,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
80
257
|
type: Component,
|
|
81
258
|
args: [{ selector: 'a[seamButton]', exportAs: 'seamButton,seamButtonBaseAnchor', inputs: ['disabled', 'theme', 'size'], host: {
|
|
82
259
|
'class': 'btn',
|
|
260
|
+
// '[class.disabled]': 'disabled || null',
|
|
83
261
|
'[attr.tabindex]': 'disabled ? -1 : (tabIndex || 0)',
|
|
84
262
|
'[attr.disabled]': 'disabled || null',
|
|
85
263
|
'[attr.aria-disabled]': 'disabled.toString()',
|
|
@@ -310,5 +488,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.7", ngImpor
|
|
|
310
488
|
* Generated bundle index. Do not edit.
|
|
311
489
|
*/
|
|
312
490
|
|
|
313
|
-
export { TOGGLE_BUTTON_VALUE_ACCESSOR, TheSeamAnchorBadgeButtonComponent, TheSeamAnchorButtonComponent, TheSeamBadgeButtonComponent, TheSeamButtonComponent, TheSeamButtonsModule, TheSeamProgressCircleButtonComponent, TheSeamToggleButtonComponent };
|
|
491
|
+
export { TOGGLE_BUTTON_VALUE_ACCESSOR, TheSeamAnchorBadgeButtonComponent, TheSeamAnchorBadgeButtonComponentHarness, TheSeamAnchorButtonComponent, TheSeamAnchorButtonComponentHarness, TheSeamBadgeButtonComponent, TheSeamBadgeButtonComponentHarness, TheSeamButtonComponent, TheSeamButtonComponentHarness, TheSeamButtonsModule, TheSeamProgressCircleButtonComponent, TheSeamToggleButtonComponent, TheSeamToggleButtonComponentHarness };
|
|
314
492
|
//# sourceMappingURL=theseam-ui-common-buttons.mjs.map
|