@eui/mobile-core 18.1.3 → 18.1.4-snapshot-1763725940736
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/docs/changelog.html +24 -0
- package/docs/components/EuimLanguageSelectorComponent.html +4 -2
- package/docs/directives/EuimToolbarTransparentDirective.html +24 -0
- package/docs/js/search/search_index.js +2 -2
- package/docs/properties.html +1 -1
- package/esm2022/lib/components/atoms/euim-label/euim-label.component.mjs +10 -8
- package/esm2022/lib/components/atoms/euim-label/euim-label.module.mjs +4 -4
- package/esm2022/lib/components/atoms/euim-notification-item/euim-notification-item.component.mjs +4 -3
- package/esm2022/lib/components/atoms/euim-notification-item/euim-notification-item.module.mjs +4 -4
- package/esm2022/lib/components/base-states.directive.mjs +26 -28
- package/esm2022/lib/components/directives/euim-align-center/euim-align-center.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-align-top/euim-align-top.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-divider/euim-divider.directive.mjs +4 -3
- package/esm2022/lib/components/directives/euim-divider/euim-divider.module.mjs +4 -4
- package/esm2022/lib/components/directives/euim-footer-transparent/euim-footer-transparent.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-list-header/euim-list-header.directive.mjs +4 -3
- package/esm2022/lib/components/directives/euim-list-header/euim-list-header.module.mjs +4 -4
- package/esm2022/lib/components/directives/euim-list-item/euim-list-item.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-min-width/euim-min-width.directive.mjs +5 -6
- package/esm2022/lib/components/directives/euim-sidebar-footer/euim-sidebar-footer.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-skeleton-text-avatar/euim-skeleton-text-avatar.directive.mjs +4 -6
- package/esm2022/lib/components/directives/euim-skeleton-text-avatar/euim-skeleton-text-avatar.module.mjs +4 -4
- package/esm2022/lib/components/directives/euim-toolbar-transparent/euim-toolbar-transparent.directive.mjs +11 -9
- package/esm2022/lib/components/euim-about/euim-about-content-loading/euim-about-content-loading.component.mjs +8 -5
- package/esm2022/lib/components/euim-about/euim-about.component.mjs +4 -6
- package/esm2022/lib/components/euim-about/euim-about.module.mjs +6 -6
- package/esm2022/lib/components/euim-about/euim-changelog/euim-changelog.component.mjs +5 -7
- package/esm2022/lib/components/euim-about/euim-help-support/euim-help-support.component.mjs +7 -5
- package/esm2022/lib/components/euim-about/euim-opensource-licences/euim-opensource-licences.component.mjs +6 -8
- package/esm2022/lib/components/euim-alert-message/euim-alert-message.module.mjs +4 -4
- package/esm2022/lib/components/euim-alert-message/euim-alert-messsage.component.mjs +10 -9
- package/esm2022/lib/components/euim-avatar/euim-avatar-badge/euim-avatar-badge.component.mjs +4 -6
- package/esm2022/lib/components/euim-avatar/euim-avatar-icon/euim-avatar-icon.component.mjs +4 -6
- package/esm2022/lib/components/euim-avatar/euim-avatar-icon-sub/euim-avatar-icon-sub.component.mjs +8 -10
- package/esm2022/lib/components/euim-avatar/euim-avatar-image/euim-avatar-image.component.mjs +5 -6
- package/esm2022/lib/components/euim-avatar/euim-avatar-text/euim-avatar-text.component.mjs +4 -6
- package/esm2022/lib/components/euim-avatar/euim-avatar.component.mjs +8 -10
- package/esm2022/lib/components/euim-avatar/euim-avatar.module.mjs +5 -5
- package/esm2022/lib/components/euim-badge/euim-badge.component.mjs +4 -3
- package/esm2022/lib/components/euim-badge/euim-badge.module.mjs +4 -4
- package/esm2022/lib/components/euim-card/euim-card-image/euim-card-image.directive.mjs +6 -6
- package/esm2022/lib/components/euim-card/euim-card.component.mjs +6 -3
- package/esm2022/lib/components/euim-card/euim-card.module.mjs +4 -4
- package/esm2022/lib/components/euim-card-list/euim-card-list.component.mjs +4 -6
- package/esm2022/lib/components/euim-card-list/euim-card-list.module.mjs +4 -4
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.mjs +10 -7
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector.component.mjs +27 -27
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector.module.mjs +4 -4
- package/esm2022/lib/components/euim-data-summary/euim-data-summary-col/euim-data-summary-col.component.mjs +4 -6
- package/esm2022/lib/components/euim-data-summary/euim-data-summary-col-label/euim-data-summary-col-label.directive.mjs +4 -3
- package/esm2022/lib/components/euim-data-summary/euim-data-summary-col-value/euim-data-summary-col-value.directive.mjs +5 -3
- package/esm2022/lib/components/euim-data-summary/euim-data-summary.component.mjs +7 -4
- package/esm2022/lib/components/euim-data-summary/euim-data-summary.module.mjs +5 -5
- package/esm2022/lib/components/euim-empty-list-placeholder/directives/euim-empty-list-placeholder-icon.directive.mjs +4 -6
- package/esm2022/lib/components/euim-empty-list-placeholder/directives/euim-empty-list-placeholder-subtitle.directive.mjs +4 -6
- package/esm2022/lib/components/euim-empty-list-placeholder/directives/euim-empty-list-placeholder-title.directive.mjs +4 -6
- package/esm2022/lib/components/euim-empty-list-placeholder/euim-empty-list-placeholder.component.mjs +14 -5
- package/esm2022/lib/components/euim-empty-list-placeholder/euim-empty-list-placeholder.module.mjs +5 -5
- package/esm2022/lib/components/euim-helper-text/euim-helper-text.component.mjs +5 -4
- package/esm2022/lib/components/euim-media-header/euim-media-header-custom-content/euim-media-header-content.directive.mjs +4 -6
- package/esm2022/lib/components/euim-media-header/euim-media-header-image/euim-media-header-image.directive.mjs +4 -6
- package/esm2022/lib/components/euim-media-header/euim-media-header-sub-title/euim-media-header-sub-title.directive.mjs +4 -6
- package/esm2022/lib/components/euim-media-header/euim-media-header-title/euim-media-header-title.directive.mjs +4 -6
- package/esm2022/lib/components/euim-media-header/euim-media-header.component.mjs +7 -6
- package/esm2022/lib/components/euim-media-header/euim-media-header.module.mjs +5 -5
- package/esm2022/lib/components/euim-message/euim-message-title/euim-message-title.component.mjs +4 -6
- package/esm2022/lib/components/euim-message/euim-message.component.mjs +4 -3
- package/esm2022/lib/components/euim-message/euim-message.module.mjs +4 -4
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-all/euim-multiselect-all.directive.mjs +6 -4
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-filter/euim-multiselect-filter.component.mjs +7 -4
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-info/euim-multiselect-info.component.mjs +8 -5
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-list/euim-multiselect-list.component.mjs +6 -4
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-select-field/euim-multiselect-select-field.directive.mjs +8 -4
- package/esm2022/lib/components/euim-multiselect/euim-multiselect-toolbar/euim-multiselect-toolbar.component.mjs +11 -8
- package/esm2022/lib/components/euim-multiselect/euim-multiselect.component.mjs +15 -7
- package/esm2022/lib/components/euim-multiselect/euim-multiselect.module.mjs +6 -6
- package/esm2022/lib/components/euim-pdf-viewer/euim-pdf-viewer.component.mjs +22 -10
- package/esm2022/lib/components/euim-pdf-viewer/euim-pdf-viewer.module.mjs +4 -4
- package/esm2022/lib/components/euim-read-only-form/euim-read-only-form-label/euim-read-only-form-label.directive.mjs +4 -6
- package/esm2022/lib/components/euim-read-only-form/euim-read-only-form-value/euim-read-only-form-value.directive.mjs +4 -6
- package/esm2022/lib/components/euim-read-only-form/euim-read-only-form.directive.mjs +4 -6
- package/esm2022/lib/components/euim-scroller-x/euim-scroller-x.component.mjs +4 -6
- package/esm2022/lib/components/euim-scroller-x/euim-scroller-x.module.mjs +4 -4
- package/esm2022/lib/components/euim-skeleton-list/euim-skeleton-list.component.mjs +7 -8
- package/esm2022/lib/components/euim-skeleton-list/euim-skeleton-list.module.mjs +4 -4
- package/esm2022/lib/components/euim-skeleton-list-item/euim-skeleton-list-item.component.mjs +14 -11
- package/esm2022/lib/components/euim-skeleton-list-item/euim-skeleton-list-item.module.mjs +4 -4
- package/esm2022/lib/components/euim-slider-info-screen/euim-slide-info-screen/euim-slide-info-screen.component.mjs +5 -7
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen-content/euim-slider-info-screen-content.directive.mjs +4 -6
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen-sub-title/euim-slider-info-screen-sub-title.directive.mjs +4 -6
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen-title/euim-slider-info-screen-title.directive.mjs +4 -6
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen.component.mjs +34 -27
- package/esm2022/lib/components/euim-slider-info-screen/euim-slider-info-screen.module.mjs +5 -5
- package/esm2022/lib/components/euim-spinner/euim-spinner-description/euim-spinner-description.component.mjs +4 -6
- package/esm2022/lib/components/euim-spinner/euim-spinner-message/euim-spinner-message.component.mjs +4 -6
- package/esm2022/lib/components/euim-spinner/euim-spinner.component.mjs +4 -6
- package/esm2022/lib/components/euim-spinner/euim-spinner.module.mjs +5 -5
- package/esm2022/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker-datetime/euim-toolbar-datepicker-datetime.directive.mjs +12 -8
- package/esm2022/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.component.mjs +33 -10
- package/esm2022/lib/components/euim-toolbar-datepicker/euim-toolbar-datepicker.module.mjs +4 -4
- package/esm2022/lib/components/euim-toolbar-qrcode/euim-toolbar-qrcode.component.mjs +6 -6
- package/esm2022/lib/components/euim-toolbar-qrcode/euim-toolbar-qrcode.module.mjs +4 -4
- package/esm2022/lib/components/layout/euim-app/euim-app.component.mjs +6 -4
- package/esm2022/lib/components/layout/euim-app/euim-app.module.mjs +4 -4
- package/esm2022/lib/components/layout/euim-header-details/euim-header-details-icon/euim-header-details-icon.directive.mjs +4 -6
- package/esm2022/lib/components/layout/euim-header-details/euim-header-details-meta/euim-header-details-meta.directive.mjs +4 -6
- package/esm2022/lib/components/layout/euim-header-details/euim-header-details-title/euim-header-details-title.directive.mjs +4 -6
- package/esm2022/lib/components/layout/euim-header-details/euim-header-details.component.mjs +5 -4
- package/esm2022/lib/components/layout/euim-header-details/euim-header-details.module.mjs +4 -4
- package/esm2022/lib/components/layout/euim-language-selector/euim-language-list.component.mjs +41 -4
- package/esm2022/lib/components/layout/euim-language-selector/euim-language-selector.component.mjs +29 -11
- package/esm2022/lib/components/layout/euim-language-selector/euim-language-selector.module.mjs +6 -6
- package/esm2022/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.mjs +18 -11
- package/esm2022/lib/components/layout/euim-sidebar/euim-sidebar.component.mjs +11 -7
- package/esm2022/lib/components/layout/euim-sidebar/euim-sidebar.module.mjs +6 -6
- package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar-action-items/euim-toolbar-action-items.component.mjs +4 -6
- package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar-title/euim-toolbar-title.component.mjs +4 -3
- package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar.component.mjs +12 -10
- package/esm2022/lib/components/layout/euim-toolbar/euim-toolbar.module.mjs +5 -5
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile-action/euim-user-profile-action.component.mjs +4 -6
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile-avatar/euim-user-profile-avatar.component.mjs +4 -6
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile-infos/euim-user-profile-infos.component.mjs +4 -3
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile-infos-item/euim-user-profile-infos-item.component.mjs +4 -6
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile.component.mjs +4 -3
- package/esm2022/lib/components/layout/euim-user-profile/euim-user-profile.module.mjs +5 -5
- package/esm2022/lib/euim-all.module.mjs +6 -6
- package/esm2022/lib/services/euim-app.service.mjs +4 -3
- package/fesm2022/eui-mobile-core.mjs +686 -615
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/directives/euim-toolbar-transparent/euim-toolbar-transparent.directive.d.ts +2 -1
- package/lib/components/directives/euim-toolbar-transparent/euim-toolbar-transparent.directive.d.ts.map +1 -1
- package/lib/components/layout/euim-language-selector/euim-language-selector.component.d.ts.map +1 -1
- package/package.json +2 -2
|
@@ -3,12 +3,13 @@ import { BaseStatesDirective } from '../../base-states.directive';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "../../base-states.directive";
|
|
5
5
|
export class EuimHeaderDetailsComponent {
|
|
6
|
+
baseStatesDirective;
|
|
7
|
+
hasBorderBottom = true;
|
|
6
8
|
get cssClasses() {
|
|
7
9
|
return this.getCssClasses();
|
|
8
10
|
}
|
|
9
11
|
constructor(baseStatesDirective) {
|
|
10
12
|
this.baseStatesDirective = baseStatesDirective;
|
|
11
|
-
this.hasBorderBottom = true;
|
|
12
13
|
}
|
|
13
14
|
getCssClasses() {
|
|
14
15
|
return [
|
|
@@ -16,8 +17,8 @@ export class EuimHeaderDetailsComponent {
|
|
|
16
17
|
!this.hasBorderBottom ? 'euim-header-details--no-border-bottom' : '',
|
|
17
18
|
].join(' ');
|
|
18
19
|
}
|
|
19
|
-
static
|
|
20
|
-
static
|
|
20
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsComponent, deps: [{ token: i1.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component });
|
|
21
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: EuimHeaderDetailsComponent, isStandalone: true, selector: "euim-header-details", inputs: { hasBorderBottom: ["hasBorderBottom", "hasBorderBottom", booleanAttribute] }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i1.BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ng-content></ng-content>\n", styles: [".euim-header-details{padding:var(--eui-s-m);display:block;text-align:center;background-color:var(--eui-c-neutral-bg-light);border-bottom:1px solid var(--eui-c-neutral-lightest)}.euim-header-details--no-border-bottom{border-bottom:none}.euim-header-details--branding{background-color:var(--eui-c-branding);border-bottom:none}.euim-header-details--branding .euim-header-details__title,.euim-header-details--branding .euim-header-details__meta{color:var(--eui-c-branding-contrast)}.euim-header-details--branding .euim-avatar{background-color:var(--eui-c-branding-contrast)}.euim-header-details--branding .euim-avatar .euim-avatar-icon ion-icon{color:var(--eui-c-branding)}.euim-header-details__title{font:var(--eui-f-m-compact);color:var(--eui-c-neutral)}.euim-header-details__meta{color:var(--eui-c-neutral-light);font:var(--eui-f-s)}.euim-header-details__icon{display:inline-block;margin-bottom:var(--eui-s-xs)}.euim-header-details__title+.euim-header-details__meta,.euim-header-details__meta+.euim-header-details__meta{margin-top:var(--eui-s-2xs)}.euim-header-details p,.euim-header-details span{margin:0}.euim-header-details span[euimHeaderDetailsTitle],.euim-header-details span[euimHeaderDetailsMeta]{display:block}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
21
22
|
}
|
|
22
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsComponent, decorators: [{
|
|
23
24
|
type: Component,
|
|
@@ -36,4 +37,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
36
37
|
type: HostBinding,
|
|
37
38
|
args: ['class']
|
|
38
39
|
}] } });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1oZWFkZXItZGV0YWlscy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2V1aW0taGVhZGVyLWRldGFpbHMvZXVpbS1oZWFkZXItZGV0YWlscy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2V1aW0taGVhZGVyLWRldGFpbHMvZXVpbS1oZWFkZXItZGV0YWlscy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsS0FBSyxFQUFFLGdCQUFnQixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUgsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7OztBQW1CbEUsTUFBTSxPQUFPLDBCQUEwQjtJQU9oQjtJQUxuQixlQUFlLEdBQWlCLElBQUksQ0FBQztJQUNyQyxJQUNXLFVBQVU7UUFDakIsT0FBTyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUNELFlBQW1CLG1CQUF3QztRQUF4Qyx3QkFBbUIsR0FBbkIsbUJBQW1CLENBQXFCO0lBQUcsQ0FBQztJQUMvRCxhQUFhO1FBQ1QsT0FBTztZQUNILElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxhQUFhLENBQUMscUJBQXFCLENBQUM7WUFDN0QsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQyx1Q0FBdUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtTQUN2RSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNoQixDQUFDOzJIQWJRLDBCQUEwQjsrR0FBMUIsMEJBQTBCLHlIQUNmLGdCQUFnQix3S0NyQnhDLDZCQUNBOzs0RkRtQmEsMEJBQTBCO2tCQWhCdEMsU0FBUzsrQkFDSSxxQkFBcUIsbUJBR2QsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxrQkFDckI7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLG1CQUFtQjs0QkFDOUIsTUFBTSxFQUFFO2dDQUNKLE9BQU87NkJBQ1Y7eUJBQ0o7cUJBQ0osY0FDVyxJQUFJO3dGQUloQixlQUFlO3NCQURkLEtBQUs7dUJBQUMsRUFBRSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBRzNCLFVBQVU7c0JBRHBCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBJbnB1dCwgYm9vbGVhbkF0dHJpYnV0ZSwgQ29tcG9uZW50LCBIb3N0QmluZGluZywgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEJhc2VTdGF0ZXNEaXJlY3RpdmUgfSBmcm9tICcuLi8uLi9iYXNlLXN0YXRlcy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQm9vbGVhbklucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldWltLWhlYWRlci1kZXRhaWxzJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zdHlsZXMvX2luZGV4LnNjc3MnXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZXVpbS1oZWFkZXItZGV0YWlscy5jb21wb25lbnQuaHRtbCcsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgICBob3N0RGlyZWN0aXZlczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBkaXJlY3RpdmU6IEJhc2VTdGF0ZXNEaXJlY3RpdmUsXG4gICAgICAgICAgICBpbnB1dHM6IFtcbiAgICAgICAgICAgICAgICAnY29sb3InLFxuICAgICAgICAgICAgXSxcbiAgICAgICAgfSxcbiAgICBdLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIEV1aW1IZWFkZXJEZXRhaWxzQ29tcG9uZW50IHtcbiAgICBASW5wdXQoeyB0cmFuc2Zvcm06IGJvb2xlYW5BdHRyaWJ1dGUgfSlcbiAgICBoYXNCb3JkZXJCb3R0b206IEJvb2xlYW5JbnB1dCA9IHRydWU7XG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gICAgcHVibGljIGdldCBjc3NDbGFzc2VzKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0aGlzLmdldENzc0NsYXNzZXMoKTtcbiAgICB9XG4gICAgY29uc3RydWN0b3IocHVibGljIGJhc2VTdGF0ZXNEaXJlY3RpdmU6IEJhc2VTdGF0ZXNEaXJlY3RpdmUpIHt9XG4gICAgZ2V0Q3NzQ2xhc3NlcygpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gW1xuICAgICAgICAgICAgdGhpcy5iYXNlU3RhdGVzRGlyZWN0aXZlLmdldENzc0NsYXNzZXMoJ2V1aW0taGVhZGVyLWRldGFpbHMnKSxcbiAgICAgICAgICAgICF0aGlzLmhhc0JvcmRlckJvdHRvbSA/ICdldWltLWhlYWRlci1kZXRhaWxzLS1uby1ib3JkZXItYm90dG9tJyA6ICcnLFxuICAgICAgICBdLmpvaW4oJyAnKTtcbiAgICB9XG59XG4iLCI8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4iXX0=
|
|
@@ -8,9 +8,9 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
* @deprecated Use {@link EUIM_HEADER_DETAILS} instead.
|
|
9
9
|
*/
|
|
10
10
|
export class EuimHeaderDetailsModule {
|
|
11
|
-
static
|
|
12
|
-
static
|
|
13
|
-
static
|
|
11
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
12
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsModule, imports: [EuimHeaderDetailsComponent, EuimHeaderDetailsTitleDirective, EuimHeaderDetailsMetaDirective, EuimHeaderDetailsIconDirective], exports: [EuimHeaderDetailsComponent, EuimHeaderDetailsTitleDirective, EuimHeaderDetailsMetaDirective, EuimHeaderDetailsIconDirective] });
|
|
13
|
+
/** @nocollapse */ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsModule });
|
|
14
14
|
}
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimHeaderDetailsModule, decorators: [{
|
|
16
16
|
type: NgModule,
|
|
@@ -19,4 +19,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
19
19
|
exports: [EuimHeaderDetailsComponent, EuimHeaderDetailsTitleDirective, EuimHeaderDetailsMetaDirective, EuimHeaderDetailsIconDirective],
|
|
20
20
|
}]
|
|
21
21
|
}] });
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1oZWFkZXItZGV0YWlscy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2V1aW0taGVhZGVyLWRldGFpbHMvZXVpbS1oZWFkZXItZGV0YWlscy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQztBQUMvRyxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSxpRUFBaUUsQ0FBQztBQUNsSCxPQUFPLEVBQUUsOEJBQThCLEVBQUUsTUFBTSwrREFBK0QsQ0FBQzs7QUFFL0c7O0dBRUc7QUFLSCxNQUFNLE9BQU8sdUJBQXVCOzJIQUF2Qix1QkFBdUI7NEhBQXZCLHVCQUF1QixZQUh0QiwwQkFBMEIsRUFBRSwrQkFBK0IsRUFBRSw4QkFBOEIsRUFBRSw4QkFBOEIsYUFDM0gsMEJBQTBCLEVBQUUsK0JBQStCLEVBQUUsOEJBQThCLEVBQUUsOEJBQThCOzRIQUU1SCx1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBSm5DLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFLENBQUMsMEJBQTBCLEVBQUUsK0JBQStCLEVBQUUsOEJBQThCLEVBQUUsOEJBQThCLENBQUM7b0JBQ3RJLE9BQU8sRUFBRSxDQUFDLDBCQUEwQixFQUFFLCtCQUErQixFQUFFLDhCQUE4QixFQUFFLDhCQUE4QixDQUFDO2lCQUN6SSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFdWltSGVhZGVyRGV0YWlsc0NvbXBvbmVudCB9IGZyb20gJy4vZXVpbS1oZWFkZXItZGV0YWlscy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRXVpbUhlYWRlckRldGFpbHNNZXRhRGlyZWN0aXZlIH0gZnJvbSAnLi9ldWltLWhlYWRlci1kZXRhaWxzLW1ldGEvZXVpbS1oZWFkZXItZGV0YWlscy1tZXRhLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBFdWltSGVhZGVyRGV0YWlsc1RpdGxlRGlyZWN0aXZlIH0gZnJvbSAnLi9ldWltLWhlYWRlci1kZXRhaWxzLXRpdGxlL2V1aW0taGVhZGVyLWRldGFpbHMtdGl0bGUuZGlyZWN0aXZlJztcbmltcG9ydCB7IEV1aW1IZWFkZXJEZXRhaWxzSWNvbkRpcmVjdGl2ZSB9IGZyb20gJy4vZXVpbS1oZWFkZXItZGV0YWlscy1pY29uL2V1aW0taGVhZGVyLWRldGFpbHMtaWNvbi5kaXJlY3RpdmUnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgRVVJTV9IRUFERVJfREVUQUlMU30gaW5zdGVhZC5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbRXVpbUhlYWRlckRldGFpbHNDb21wb25lbnQsIEV1aW1IZWFkZXJEZXRhaWxzVGl0bGVEaXJlY3RpdmUsIEV1aW1IZWFkZXJEZXRhaWxzTWV0YURpcmVjdGl2ZSwgRXVpbUhlYWRlckRldGFpbHNJY29uRGlyZWN0aXZlXSxcbiAgICBleHBvcnRzOiBbRXVpbUhlYWRlckRldGFpbHNDb21wb25lbnQsIEV1aW1IZWFkZXJEZXRhaWxzVGl0bGVEaXJlY3RpdmUsIEV1aW1IZWFkZXJEZXRhaWxzTWV0YURpcmVjdGl2ZSwgRXVpbUhlYWRlckRldGFpbHNJY29uRGlyZWN0aXZlXSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbUhlYWRlckRldGFpbHNNb2R1bGUge31cbiJdfQ==
|
package/esm2022/lib/components/layout/euim-language-selector/euim-language-list.component.mjs
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { Component, ChangeDetectionStrategy } from '@angular/core';
|
|
2
|
-
import { EuiEuLanguages } from '@eui/core';
|
|
2
|
+
import { EuiAppShellService, EuiEuLanguages, I18nService } from '@eui/core';
|
|
3
3
|
import { EuimLabelModule } from '../../atoms/euim-label';
|
|
4
|
+
import { EuimAppService } from '../../../services';
|
|
5
|
+
import { ModalController } from '@ionic/angular';
|
|
4
6
|
import { IonicModule } from '@ionic/angular';
|
|
5
7
|
import { EuimAvatarModule } from '../../euim-avatar';
|
|
6
8
|
import { EuimEmptyListPlaceholderModule } from '../../euim-empty-list-placeholder';
|
|
@@ -15,6 +17,41 @@ import * as i6 from "../../atoms/euim-label/euim-label.component";
|
|
|
15
17
|
import * as i7 from "../../euim-empty-list-placeholder/euim-empty-list-placeholder.component";
|
|
16
18
|
import * as i8 from "@ngx-translate/core";
|
|
17
19
|
export class EuimLanguageListComponent {
|
|
20
|
+
appShellService;
|
|
21
|
+
appService;
|
|
22
|
+
modalCtrl;
|
|
23
|
+
i18nService;
|
|
24
|
+
/**
|
|
25
|
+
* @deprecated will be removed in eUI Mobile v19.
|
|
26
|
+
*/
|
|
27
|
+
name;
|
|
28
|
+
/**
|
|
29
|
+
* @deprecated will be removed in eUI Mobile v19. Use nonEULanguageList[0] instead.
|
|
30
|
+
*/
|
|
31
|
+
firstElementFromNonEUList;
|
|
32
|
+
/**
|
|
33
|
+
* @deprecated will be removed in eUI Mobile v19. Use euLanguageList[0] instead.
|
|
34
|
+
*/
|
|
35
|
+
firstElementFromEUList;
|
|
36
|
+
/**
|
|
37
|
+
* @deprecated will be removed in eUI Mobile v19. Use isLastElementOfArray() function instead.
|
|
38
|
+
*/
|
|
39
|
+
lastElementFromEUList;
|
|
40
|
+
languages;
|
|
41
|
+
selectedLanguage;
|
|
42
|
+
euLanguageList;
|
|
43
|
+
nonEULanguageList;
|
|
44
|
+
/**
|
|
45
|
+
* @deprecated
|
|
46
|
+
* will become private in eUI Mobile v19.
|
|
47
|
+
*/
|
|
48
|
+
languagesSortedByEUAndNonEU;
|
|
49
|
+
results;
|
|
50
|
+
/**
|
|
51
|
+
* @deprecated will be removed in eUI Mobile v19.
|
|
52
|
+
*/
|
|
53
|
+
isKeyboardShown;
|
|
54
|
+
hasSearchbar;
|
|
18
55
|
constructor(
|
|
19
56
|
/**
|
|
20
57
|
* @deprecated will be removed in eUI Mobile v19.
|
|
@@ -60,11 +97,11 @@ export class EuimLanguageListComponent {
|
|
|
60
97
|
d.label.toLowerCase().indexOf(query) > -1;
|
|
61
98
|
});
|
|
62
99
|
}
|
|
63
|
-
static
|
|
64
|
-
static
|
|
100
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageListComponent, deps: [{ token: i1.EuiAppShellService }, { token: i2.EuimAppService }, { token: i3.ModalController }, { token: i1.I18nService }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: EuimLanguageListComponent, isStandalone: true, selector: "euim-language-list", ngImport: i0, template: "<ion-header>\n <ion-toolbar color=\"branding\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onClose()\">\n <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-title> {{'euim.language-list.SELECT-LANGUAGE' | translate }}</ion-title>\n </ion-toolbar>\n @if (hasSearchbar) {\n <ion-toolbar color=\"branding\" class=\"euim-language-selector__search\">\n <ion-searchbar (ionInput)=\"handleChange($event)\"></ion-searchbar>\n </ion-toolbar>\n }\n</ion-header>\n<ion-content>\n @if (results.length > 0) {\n <ion-list>\n @for (item of results; track item) {\n @if (firstElementFromEUList?.code === item.code || firstElementFromNonEUList?.code === item.code || euLanguageList[0]?.code === item.code\n || nonEULanguageList[0]?.code === item.code) {\n <ion-item-divider>\n {{ (firstElementFromEUList?.code === item.code || euLanguageList[0]?.code === item.code)\n ? ('euim.language-list.EU-LANGUAGES' | translate)\n : 'euim.language-list.NON-EU-LANGUAGES' | translate }}\n </ion-item-divider>\n }\n <ion-item button (click)=\"onLanguageSelected(item)\" [lines]=\"lastElementFromEUList === item || isLastElementOfArray(euLanguageList, item) || isLastElementOfArray(nonEULanguageList, item) ? 'none' : 'inset'\">\n <euim-avatar fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n <euim-avatar-icon>\n <ion-icon name=\"language\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n </euim-avatar-icon>\n </euim-avatar>\n <ion-label>\n <div euimLabel euimLabelTitle>{{item.label}}</div>\n <div euimLabel euimLabelMeta class=\"eui-u-text-uppercase\">\n {{item.code}}\n </div>\n </ion-label>\n @if (selectedLanguage?.code===item.code) {\n <ion-buttons>\n <ion-button fill=\"clear\" >\n <ion-icon name=\"checkmark\" slot=\"icon-only\" color=\"primary\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n </ion-item>\n }\n </ion-list>\n }\n @if (results.length < 1) {\n <euim-empty-list-placeholder euimMarginTopLarge\n class=\"euim-language-selector__empty-placeholder\">\n </euim-empty-list-placeholder>\n }\n</ion-content>\n\n", dependencies: [{ kind: "ngmodule", type: EuimAvatarModule }, { kind: "component", type: i4.EuimAvatarComponent, selector: "euim-avatar", inputs: ["color", "size", "fill", "variant", "borderColor"] }, { kind: "component", type: i5.EuimAvatarIconComponent, selector: "euim-avatar-icon" }, { kind: "ngmodule", type: EuimLabelModule }, { kind: "component", type: i6.EuimLabelComponent, selector: "div[euimLabel], p[euimLabel], span[euimLabel], euim-label", inputs: ["euimLabelTruncateWithLines", "euimLabelTitle", "euimLabelSubTitle", "euimLabelMeta", "euimLabelTruncate", "euimLabelTextWrap"] }, { kind: "ngmodule", type: IonicModule }, { kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: i3.IonContent, selector: "ion-content", inputs: ["color", "fixedSlotPlacement", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: i3.IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i3.IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: i3.IonItemDivider, selector: "ion-item-divider", inputs: ["color", "mode", "sticky"] }, { kind: "component", type: i3.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: i3.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i3.IonSearchbar, selector: "ion-searchbar", inputs: ["animated", "autocapitalize", "autocomplete", "autocorrect", "cancelButtonIcon", "cancelButtonText", "clearIcon", "color", "debounce", "disabled", "enterkeyhint", "inputmode", "maxlength", "minlength", "mode", "name", "placeholder", "searchIcon", "showCancelButton", "showClearButton", "spellcheck", "type", "value"] }, { kind: "component", type: i3.IonTitle, selector: "ion-title", inputs: ["color", "size"] }, { kind: "component", type: i3.IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "directive", type: i3.TextValueAccessor, selector: "ion-input:not([type=number]),ion-input-otp[type=text],ion-textarea,ion-searchbar" }, { kind: "ngmodule", type: EuimEmptyListPlaceholderModule }, { kind: "component", type: i7.EuimEmptyListPlaceholderComponent, selector: "euim-empty-list-placeholder", inputs: ["message", "icon", "description", "button", "euimMarginTopLarge", "euimMarginTopSmall", "euimMarginBottomSmall"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i8.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
65
102
|
}
|
|
66
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageListComponent, decorators: [{
|
|
67
104
|
type: Component,
|
|
68
105
|
args: [{ selector: 'euim-language-list', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [EuimAvatarModule, EuimLabelModule, IonicModule, EuimEmptyListPlaceholderModule, TranslateModule], template: "<ion-header>\n <ion-toolbar color=\"branding\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onClose()\">\n <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\n </ion-button>\n </ion-buttons>\n <ion-title> {{'euim.language-list.SELECT-LANGUAGE' | translate }}</ion-title>\n </ion-toolbar>\n @if (hasSearchbar) {\n <ion-toolbar color=\"branding\" class=\"euim-language-selector__search\">\n <ion-searchbar (ionInput)=\"handleChange($event)\"></ion-searchbar>\n </ion-toolbar>\n }\n</ion-header>\n<ion-content>\n @if (results.length > 0) {\n <ion-list>\n @for (item of results; track item) {\n @if (firstElementFromEUList?.code === item.code || firstElementFromNonEUList?.code === item.code || euLanguageList[0]?.code === item.code\n || nonEULanguageList[0]?.code === item.code) {\n <ion-item-divider>\n {{ (firstElementFromEUList?.code === item.code || euLanguageList[0]?.code === item.code)\n ? ('euim.language-list.EU-LANGUAGES' | translate)\n : 'euim.language-list.NON-EU-LANGUAGES' | translate }}\n </ion-item-divider>\n }\n <ion-item button (click)=\"onLanguageSelected(item)\" [lines]=\"lastElementFromEUList === item || isLastElementOfArray(euLanguageList, item) || isLastElementOfArray(nonEULanguageList, item) ? 'none' : 'inset'\">\n <euim-avatar fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n <euim-avatar-icon>\n <ion-icon name=\"language\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n </euim-avatar-icon>\n </euim-avatar>\n <ion-label>\n <div euimLabel euimLabelTitle>{{item.label}}</div>\n <div euimLabel euimLabelMeta class=\"eui-u-text-uppercase\">\n {{item.code}}\n </div>\n </ion-label>\n @if (selectedLanguage?.code===item.code) {\n <ion-buttons>\n <ion-button fill=\"clear\" >\n <ion-icon name=\"checkmark\" slot=\"icon-only\" color=\"primary\"></ion-icon>\n </ion-button>\n </ion-buttons>\n }\n </ion-item>\n }\n </ion-list>\n }\n @if (results.length < 1) {\n <euim-empty-list-placeholder euimMarginTopLarge\n class=\"euim-language-selector__empty-placeholder\">\n </euim-empty-list-placeholder>\n }\n</ion-content>\n\n" }]
|
|
69
106
|
}], ctorParameters: () => [{ type: i1.EuiAppShellService }, { type: i2.EuimAppService }, { type: i3.ModalController }, { type: i1.I18nService }] });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-language-list.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/layout/euim-language-selector/euim-language-list.component.ts","../../../../../../src/lib/components/layout/euim-language-selector/euim-language-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage, I18nService } from '@eui/core';\nimport { EuimLabelModule } from '../../atoms/euim-label';\nimport { EuimAppService } from '../../../services';\nimport { ModalController } from '@ionic/angular';\nimport { IonicModule } from '@ionic/angular';\nimport { EuimAvatarModule } from '../../euim-avatar';\nimport { EuimEmptyListPlaceholderModule } from '../../euim-empty-list-placeholder';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n    selector: 'euim-language-list',\n    templateUrl: 'euim-language-list.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [EuimAvatarModule, EuimLabelModule, IonicModule, EuimEmptyListPlaceholderModule, TranslateModule],\n})\nexport class EuimLanguageListComponent implements OnInit {\n\n    /**\n     * @deprecated will be removed in eUI Mobile v19.\n     */\n    name: string;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use nonEULanguageList[0] instead.\n     */\n    firstElementFromNonEUList: EuiLanguage;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use euLanguageList[0] instead.\n     */\n    firstElementFromEUList: EuiLanguage;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use isLastElementOfArray() function instead.\n     */\n    lastElementFromEUList: EuiLanguage;\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n    euLanguageList: EuiLanguage[];\n    nonEULanguageList: EuiLanguage[];\n    /**\n     * @deprecated\n     * will become private in eUI Mobile v19.\n     */\n    languagesSortedByEUAndNonEU: EuiLanguage[];\n    results: EuiLanguage[];\n\n    /**\n     * @deprecated will be removed in eUI Mobile v19.\n     */\n    isKeyboardShown : boolean;\n    hasSearchbar: boolean;\n\n    constructor(\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appShellService: EuiAppShellService,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appService: EuimAppService,\n        private modalCtrl: ModalController,\n        private i18nService: I18nService,\n    ) {}\n\n    ngOnInit(): void {\n        this.setLanguages();\n    }\n\n    onLanguageSelected(language: EuiLanguage): void {\n        this.i18nService.updateState({ activeLang: language.code });\n        this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    isLastElementOfArray<T>(array: T[], element: T): boolean {\n        if (array.length === 0) {\n            return false;\n        }\n        return array[array.length - 1] === element;\n    }\n\n    protected setLanguages(): void {\n        this.euLanguageList =\n            EuiEuLanguages.getOrderedLanguages(\n            EuiEuLanguages.filterEULanguages(this.languages));\n\n        this.nonEULanguageList =\n            [...EuiEuLanguages.getOrderedLanguages(\n                EuiEuLanguages.filterNonEULanguages(this.languages))];\n\n        this.languagesSortedByEUAndNonEU = [...this.euLanguageList, ...this.nonEULanguageList];\n        this.results = [...this.languagesSortedByEUAndNonEU];\n    }\n\n    protected onClose(): Promise<boolean> {\n        return this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    protected handleChange(event): void {\n        const query = event.target.value.toLowerCase();\n\n        this.results = this.languagesSortedByEUAndNonEU.filter(d => {\n            return d.code.toLowerCase().indexOf(query) > -1 ||\n                d.label.toLowerCase().indexOf(query) > -1;\n        });\n    }\n\n}\n","<ion-header>\n  <ion-toolbar color=\"branding\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onClose()\">\n        <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n    </ion-buttons>\n    <ion-title> {{'euim.language-list.SELECT-LANGUAGE' | translate }}</ion-title>\n  </ion-toolbar>\n    @if (hasSearchbar) {\n      <ion-toolbar color=\"branding\" class=\"euim-language-selector__search\">\n        <ion-searchbar (ionInput)=\"handleChange($event)\"></ion-searchbar>\n      </ion-toolbar>\n    }\n</ion-header>\n<ion-content>\n  @if (results.length > 0) {\n    <ion-list>\n      @for (item of results; track item) {\n        @if (firstElementFromEUList?.code === item.code || firstElementFromNonEUList?.code === item.code || euLanguageList[0]?.code === item.code\n          || nonEULanguageList[0]?.code === item.code) {\n          <ion-item-divider>\n            {{ (firstElementFromEUList?.code === item.code || euLanguageList[0]?.code === item.code)\n            ? ('euim.language-list.EU-LANGUAGES' | translate)\n            : 'euim.language-list.NON-EU-LANGUAGES' | translate }}\n          </ion-item-divider>\n        }\n        <ion-item button (click)=\"onLanguageSelected(item)\" [lines]=\"lastElementFromEUList === item || isLastElementOfArray(euLanguageList, item) || isLastElementOfArray(nonEULanguageList, item) ? 'none' : 'inset'\">\n            <euim-avatar fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n                <euim-avatar-icon>\n                    <ion-icon name=\"language\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n                </euim-avatar-icon>\n            </euim-avatar>\n          <ion-label>\n            <div euimLabel euimLabelTitle>{{item.label}}</div>\n            <div euimLabel euimLabelMeta class=\"eui-u-text-uppercase\">\n              {{item.code}}\n            </div>\n          </ion-label>\n          @if (selectedLanguage?.code===item.code) {\n            <ion-buttons>\n              <ion-button  fill=\"clear\" >\n                <ion-icon name=\"checkmark\" slot=\"icon-only\" color=\"primary\"></ion-icon>\n              </ion-button>\n            </ion-buttons>\n          }\n        </ion-item>\n      }\n    </ion-list>\n  }\n  @if (results.length < 1) {\n    <euim-empty-list-placeholder euimMarginTopLarge\n      class=\"euim-language-selector__empty-placeholder\">\n    </euim-empty-list-placeholder>\n  }\n</ion-content>\n\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-language-list.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/layout/euim-language-selector/euim-language-list.component.ts","../../../../../../src/lib/components/layout/euim-language-selector/euim-language-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ChangeDetectionStrategy } from '@angular/core';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage, I18nService } from '@eui/core';\nimport { EuimLabelModule } from '../../atoms/euim-label';\nimport { EuimAppService } from '../../../services';\nimport { ModalController } from '@ionic/angular';\nimport { IonicModule } from '@ionic/angular';\nimport { EuimAvatarModule } from '../../euim-avatar';\nimport { EuimEmptyListPlaceholderModule } from '../../euim-empty-list-placeholder';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n    selector: 'euim-language-list',\n    templateUrl: 'euim-language-list.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    imports: [EuimAvatarModule, EuimLabelModule, IonicModule, EuimEmptyListPlaceholderModule, TranslateModule],\n})\nexport class EuimLanguageListComponent implements OnInit {\n\n    /**\n     * @deprecated will be removed in eUI Mobile v19.\n     */\n    name: string;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use nonEULanguageList[0] instead.\n     */\n    firstElementFromNonEUList: EuiLanguage;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use euLanguageList[0] instead.\n     */\n    firstElementFromEUList: EuiLanguage;\n    /**\n     * @deprecated will be removed in eUI Mobile v19. Use isLastElementOfArray() function instead.\n     */\n    lastElementFromEUList: EuiLanguage;\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n    euLanguageList: EuiLanguage[];\n    nonEULanguageList: EuiLanguage[];\n    /**\n     * @deprecated\n     * will become private in eUI Mobile v19.\n     */\n    languagesSortedByEUAndNonEU: EuiLanguage[];\n    results: EuiLanguage[];\n\n    /**\n     * @deprecated will be removed in eUI Mobile v19.\n     */\n    isKeyboardShown : boolean;\n    hasSearchbar: boolean;\n\n    constructor(\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appShellService: EuiAppShellService,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appService: EuimAppService,\n        private modalCtrl: ModalController,\n        private i18nService: I18nService,\n    ) {}\n\n    ngOnInit(): void {\n        this.setLanguages();\n    }\n\n    onLanguageSelected(language: EuiLanguage): void {\n        this.i18nService.updateState({ activeLang: language.code });\n        this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    isLastElementOfArray<T>(array: T[], element: T): boolean {\n        if (array.length === 0) {\n            return false;\n        }\n        return array[array.length - 1] === element;\n    }\n\n    protected setLanguages(): void {\n        this.euLanguageList =\n            EuiEuLanguages.getOrderedLanguages(\n            EuiEuLanguages.filterEULanguages(this.languages));\n\n        this.nonEULanguageList =\n            [...EuiEuLanguages.getOrderedLanguages(\n                EuiEuLanguages.filterNonEULanguages(this.languages))];\n\n        this.languagesSortedByEUAndNonEU = [...this.euLanguageList, ...this.nonEULanguageList];\n        this.results = [...this.languagesSortedByEUAndNonEU];\n    }\n\n    protected onClose(): Promise<boolean> {\n        return this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    protected handleChange(event): void {\n        const query = event.target.value.toLowerCase();\n\n        this.results = this.languagesSortedByEUAndNonEU.filter(d => {\n            return d.code.toLowerCase().indexOf(query) > -1 ||\n                d.label.toLowerCase().indexOf(query) > -1;\n        });\n    }\n\n}\n","<ion-header>\n  <ion-toolbar color=\"branding\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onClose()\">\n        <ion-icon name=\"close\" slot=\"icon-only\"></ion-icon>\n      </ion-button>\n    </ion-buttons>\n    <ion-title> {{'euim.language-list.SELECT-LANGUAGE' | translate }}</ion-title>\n  </ion-toolbar>\n    @if (hasSearchbar) {\n      <ion-toolbar color=\"branding\" class=\"euim-language-selector__search\">\n        <ion-searchbar (ionInput)=\"handleChange($event)\"></ion-searchbar>\n      </ion-toolbar>\n    }\n</ion-header>\n<ion-content>\n  @if (results.length > 0) {\n    <ion-list>\n      @for (item of results; track item) {\n        @if (firstElementFromEUList?.code === item.code || firstElementFromNonEUList?.code === item.code || euLanguageList[0]?.code === item.code\n          || nonEULanguageList[0]?.code === item.code) {\n          <ion-item-divider>\n            {{ (firstElementFromEUList?.code === item.code || euLanguageList[0]?.code === item.code)\n            ? ('euim.language-list.EU-LANGUAGES' | translate)\n            : 'euim.language-list.NON-EU-LANGUAGES' | translate }}\n          </ion-item-divider>\n        }\n        <ion-item button (click)=\"onLanguageSelected(item)\" [lines]=\"lastElementFromEUList === item || isLastElementOfArray(euLanguageList, item) || isLastElementOfArray(nonEULanguageList, item) ? 'none' : 'inset'\">\n            <euim-avatar fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n                <euim-avatar-icon>\n                    <ion-icon name=\"language\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n                </euim-avatar-icon>\n            </euim-avatar>\n          <ion-label>\n            <div euimLabel euimLabelTitle>{{item.label}}</div>\n            <div euimLabel euimLabelMeta class=\"eui-u-text-uppercase\">\n              {{item.code}}\n            </div>\n          </ion-label>\n          @if (selectedLanguage?.code===item.code) {\n            <ion-buttons>\n              <ion-button  fill=\"clear\" >\n                <ion-icon name=\"checkmark\" slot=\"icon-only\" color=\"primary\"></ion-icon>\n              </ion-button>\n            </ion-buttons>\n          }\n        </ion-item>\n      }\n    </ion-list>\n  }\n  @if (results.length < 1) {\n    <euim-empty-list-placeholder euimMarginTopLarge\n      class=\"euim-language-selector__empty-placeholder\">\n    </euim-empty-list-placeholder>\n  }\n</ion-content>\n\n"]}
|
package/esm2022/lib/components/layout/euim-language-selector/euim-language-selector.component.mjs
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
import { Input, booleanAttribute, ChangeDetectionStrategy, Inject, Component, HostBinding, ViewEncapsulation } from '@angular/core';
|
|
1
|
+
import { ChangeDetectorRef, Input, booleanAttribute, ChangeDetectionStrategy, Inject, Component, HostBinding, ViewEncapsulation } from '@angular/core';
|
|
2
2
|
import { getI18nServiceConfig } from '@eui/base';
|
|
3
|
-
import { EuiEuLanguages, GLOBAL_CONFIG_TOKEN } from '@eui/core';
|
|
3
|
+
import { EuiAppShellService, EuiEuLanguages, I18nService, GLOBAL_CONFIG_TOKEN } from '@eui/core';
|
|
4
4
|
import { takeUntil } from 'rxjs/operators';
|
|
5
5
|
import { Subject, startWith } from 'rxjs';
|
|
6
|
+
import { EuimAppService } from '../../../services';
|
|
7
|
+
import { ModalController } from '@ionic/angular';
|
|
6
8
|
import { EuimLanguageListComponent } from './euim-language-list.component';
|
|
7
9
|
import { BaseStatesDirective } from '../../base-states.directive';
|
|
8
10
|
import { IonicModule } from '@ionic/angular';
|
|
@@ -13,6 +15,27 @@ import * as i2 from "../../../services";
|
|
|
13
15
|
import * as i3 from "@ionic/angular";
|
|
14
16
|
import * as i4 from "../../base-states.directive";
|
|
15
17
|
export class EuimLanguageSelectorComponent {
|
|
18
|
+
cd;
|
|
19
|
+
appShellService;
|
|
20
|
+
appService;
|
|
21
|
+
i18nService;
|
|
22
|
+
modalCtrl;
|
|
23
|
+
baseStatesDirective;
|
|
24
|
+
baseGlobalConfig;
|
|
25
|
+
hasSearchbar = true;
|
|
26
|
+
/**
|
|
27
|
+
* @deprecated will be removed in eUI Mobile v20. _euimBranding instead.
|
|
28
|
+
*/
|
|
29
|
+
_euimPrimary;
|
|
30
|
+
_euimBranding;
|
|
31
|
+
/**
|
|
32
|
+
* @deprecated
|
|
33
|
+
* will become private in eUI Mobile v19.
|
|
34
|
+
*/
|
|
35
|
+
languages;
|
|
36
|
+
config;
|
|
37
|
+
selectedLanguage;
|
|
38
|
+
destroy$ = new Subject();
|
|
16
39
|
constructor(cd,
|
|
17
40
|
/**
|
|
18
41
|
* @deprecated will be removed in eUI Mobile v19.
|
|
@@ -29,14 +52,9 @@ export class EuimLanguageSelectorComponent {
|
|
|
29
52
|
this.modalCtrl = modalCtrl;
|
|
30
53
|
this.baseStatesDirective = baseStatesDirective;
|
|
31
54
|
this.baseGlobalConfig = baseGlobalConfig;
|
|
32
|
-
this.
|
|
33
|
-
/**
|
|
34
|
-
* @deprecated will be removed in eUI Mobile v20. _euimBranding instead.
|
|
35
|
-
*/
|
|
55
|
+
this.config = getI18nServiceConfig(this.baseGlobalConfig.i18n.i18nService);
|
|
36
56
|
this._euimPrimary = this.baseStatesDirective.color === 'primary';
|
|
37
57
|
this._euimBranding = this.baseStatesDirective.color === 'branding';
|
|
38
|
-
this.destroy$ = new Subject();
|
|
39
|
-
this.config = getI18nServiceConfig(this.baseGlobalConfig.i18n.i18nService);
|
|
40
58
|
}
|
|
41
59
|
get cssClasses() {
|
|
42
60
|
return this.baseStatesDirective.getCssClasses('euim-language-selector');
|
|
@@ -81,8 +99,8 @@ export class EuimLanguageSelectorComponent {
|
|
|
81
99
|
}
|
|
82
100
|
return null;
|
|
83
101
|
}
|
|
84
|
-
static
|
|
85
|
-
static
|
|
102
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.EuiAppShellService }, { token: i2.EuimAppService }, { token: i1.I18nService }, { token: i3.ModalController }, { token: i4.BaseStatesDirective }, { token: GLOBAL_CONFIG_TOKEN }], target: i0.ɵɵFactoryTarget.Component });
|
|
103
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.13", type: EuimLanguageSelectorComponent, isStandalone: true, selector: "euim-language-selector", inputs: { hasSearchbar: ["hasSearchbar", "hasSearchbar", booleanAttribute] }, host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i4.BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ion-button (click)=\"onShowLanguageList()\" fill=\"clear\" shape=\"round\">\n <ion-icon class=\"euim-language-selector__icon {{_euimBranding || _euimPrimary ? 'euim-language-selector__icon--branding' : ''}}\"\n slot=\"icon-only\"\n src='data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\">\n <path\n d=\"M 21.00,0.00\n C 22.66,-0.00 24.00,1.34 24.00,3.00\n 24.00,3.00 24.00,17.00 24.00,17.00\n 24.00,18.66 22.66,20.00 21.00,20.00\n 21.00,20.00 3.00,20.00 3.00,20.00\n 1.34,20.00 0.00,18.66 0.00,17.00\n 0.00,17.00 0.00,3.00 0.00,3.00\n 0.00,1.34 1.34,0.00 3.00,0.00\n 3.00,0.00 21.00,0.00 21.00,0.00 Z\n M 9.66,12.34\n C 9.66,12.34 15.31,18.00 15.31,18.00\n 15.31,18.00 9.66,23.66 9.66,23.66\n 9.66,23.66 4.00,18.00 4.00,18.00\n 4.00,18.00 9.66,12.34 9.66,12.34 Z\" />\n </svg>'>\n </ion-icon>\n\n <span class=\"euim-language-selector__text {{_euimBranding || _euimPrimary ? 'euim-language-selector__text--branding' : ''}}\">\n {{ selectedLanguage?.code?.toUpperCase() }}\n </span>\n</ion-button>\n", styles: [".euim-language-selector span.euim-language-selector__text{font:var(--eui-f-xs-bold-compact);margin-bottom:var(--eui-s-2xs);position:absolute;color:var(--eui-c-branding)}.euim-language-selector span.euim-language-selector__text--branding,.euim-language-selector__icon{color:var(--eui-c-branding-contrast)}.euim-language-selector__icon--branding{color:var(--eui-c-branding)}.euim-language-selector__internal-icon{color:var(--eui-c-neutral)}.euim-language-selector__search{display:contents}.euim-language-selector__empty-placeholder{display:block;height:auto;margin-top:calc(9 * var(--eui-s-m))}\n"], dependencies: [{ kind: "ngmodule", type: IonicModule }, { kind: "component", type: i3.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i3.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "ngmodule", type: TranslateModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
86
104
|
}
|
|
87
105
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorComponent, decorators: [{
|
|
88
106
|
type: Component,
|
|
@@ -108,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
108
126
|
type: HostBinding,
|
|
109
127
|
args: ['class']
|
|
110
128
|
}] } });
|
|
111
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-language-selector.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/layout/euim-language-selector/euim-language-selector.component.ts","../../../../../../src/lib/components/layout/euim-language-selector/euim-language-selector.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Input, booleanAttribute, ChangeDetectionStrategy, Inject, Component, HostBinding, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { getI18nServiceConfig, I18nServiceConfig, GlobalConfig } from '@eui/base';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage, I18nService, GLOBAL_CONFIG_TOKEN } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject, startWith } from 'rxjs';\nimport { EuimAppService } from '../../../services';\nimport { ModalController } from '@ionic/angular';\nimport { EuimLanguageListComponent } from './euim-language-list.component';\nimport { BaseStatesDirective } from '../../base-states.directive';\nimport { IonicModule } from '@ionic/angular';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n    selector: 'euim-language-selector',\n    templateUrl: 'euim-language-selector.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'color',\n            ],\n        },\n    ],\n    standalone: true,\n    imports: [\n        IonicModule,\n        TranslateModule,\n        EuimLanguageListComponent,\n    ],\n})\nexport class EuimLanguageSelectorComponent implements OnInit, OnDestroy {\n    @Input({ transform: booleanAttribute }) hasSearchbar = true;\n    /**\n     * @deprecated will be removed in eUI Mobile v20. _euimBranding instead.\n     */\n    _euimPrimary = this.baseStatesDirective.color === 'primary';\n    _euimBranding = this.baseStatesDirective.color === 'branding';\n    /**\n     * @deprecated\n     * will become private in eUI Mobile v19.\n     */\n    languages: EuiLanguage[];\n    protected config: I18nServiceConfig;\n    selectedLanguage: EuiLanguage;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appShellService: EuiAppShellService,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appService: EuimAppService,\n        private i18nService: I18nService,\n        private modalCtrl: ModalController,\n        public baseStatesDirective: BaseStatesDirective,\n        @Inject(GLOBAL_CONFIG_TOKEN) protected baseGlobalConfig: GlobalConfig,\n    ) {\n        this.config = getI18nServiceConfig(this.baseGlobalConfig.i18n.i18nService);\n    }\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.baseStatesDirective.getCssClasses('euim-language-selector');\n    }\n\n    ngOnInit(): void {\n        this.getAllLanguages();\n        this.i18nService.getState()\n            .pipe(\n                startWith({ activeLang: this.config.defaultLanguage }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe((state):void => {\n                this.selectedLanguage = {\n                    code: state.activeLang,\n                    label: this.getLanguageLabel(state.activeLang),\n                };\n                this.cd.detectChanges();\n            });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    async onShowLanguageList():Promise<void> {\n        const modal = await this.modalCtrl.create({\n            component: EuimLanguageListComponent,\n            componentProps: {\n                selectedLanguage: this.selectedLanguage,\n                languages: this.languages,\n                hasSearchbar: this.hasSearchbar,\n            },\n        });\n\n        await modal.present();\n   }\n\n    protected getAllLanguages(): void {\n        this.languages = (this.config.languages.length > 1) ?\n            EuiEuLanguages.getOrderedLanguages(this.config.languages) :\n            EuiEuLanguages.getLanguages();\n    }\n\n    protected getLanguageLabel(languageCode: string): string {\n        for (const language of this.languages) {\n            if (language.code === languageCode) {\n                return language.label;\n            }\n        }\n        return null;\n    }\n}\n","<ion-button (click)=\"onShowLanguageList()\" fill=\"clear\" shape=\"round\">\n    <ion-icon class=\"euim-language-selector__icon {{_euimBranding || _euimPrimary ? 'euim-language-selector__icon--branding' : ''}}\"\n              slot=\"icon-only\"\n              src='data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\"\n              viewBox=\"0 0 24 24\">\n                <path\n                    d=\"M 21.00,0.00\n                               C 22.66,-0.00 24.00,1.34 24.00,3.00\n                                 24.00,3.00 24.00,17.00 24.00,17.00\n                                 24.00,18.66 22.66,20.00 21.00,20.00\n                                 21.00,20.00 3.00,20.00 3.00,20.00\n                                 1.34,20.00 0.00,18.66 0.00,17.00\n                                 0.00,17.00 0.00,3.00 0.00,3.00\n                                 0.00,1.34 1.34,0.00 3.00,0.00\n                                 3.00,0.00 21.00,0.00 21.00,0.00 Z\n                               M 9.66,12.34\n                               C 9.66,12.34 15.31,18.00 15.31,18.00\n                                 15.31,18.00 9.66,23.66 9.66,23.66\n                                 9.66,23.66 4.00,18.00 4.00,18.00\n                                 4.00,18.00 9.66,12.34 9.66,12.34 Z\" />\n                </svg>'>\n    </ion-icon>\n\n    <span class=\"euim-language-selector__text {{_euimBranding || _euimPrimary ? 'euim-language-selector__text--branding' : ''}}\">\n        {{ selectedLanguage?.code?.toUpperCase() }}\n    </span>\n</ion-button>\n"]}
|
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-language-selector.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/layout/euim-language-selector/euim-language-selector.component.ts","../../../../../../src/lib/components/layout/euim-language-selector/euim-language-selector.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,KAAK,EAAE,gBAAgB,EAAE,uBAAuB,EAAE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAqB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAC1K,OAAO,EAAE,oBAAoB,EAAmC,MAAM,WAAW,CAAC;AAClF,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAe,WAAW,EAAE,mBAAmB,EAAE,MAAM,WAAW,CAAC;AAC9G,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;;;;;;AAuBtD,MAAM,OAAO,6BAA6B;IAiB1B;IAID;IAIA;IACC;IACA;IACD;IACgC;IA5BH,YAAY,GAAG,IAAI,CAAC;IAC5D;;OAEG;IACH,YAAY,CAAU;IACtB,aAAa,CAAU;IACvB;;;OAGG;IACH,SAAS,CAAgB;IACf,MAAM,CAAoB;IACpC,gBAAgB,CAAc;IACtB,QAAQ,GAAqB,IAAI,OAAO,EAAW,CAAC;IAE5D,YACY,EAAqB;IAC7B;;OAEG;IACI,eAAmC;IAC1C;;OAEG;IACI,UAA0B,EACzB,WAAwB,EACxB,SAA0B,EAC3B,mBAAwC,EACR,gBAA8B;QAZ7D,OAAE,GAAF,EAAE,CAAmB;QAItB,oBAAe,GAAf,eAAe,CAAoB;QAInC,eAAU,GAAV,UAAU,CAAgB;QACzB,gBAAW,GAAX,WAAW,CAAa;QACxB,cAAS,GAAT,SAAS,CAAiB;QAC3B,wBAAmB,GAAnB,mBAAmB,CAAqB;QACR,qBAAgB,GAAhB,gBAAgB,CAAc;QAErE,IAAI,CAAC,MAAM,GAAG,oBAAoB,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3E,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,KAAK,SAAS,CAAC;QACjE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,mBAAmB,CAAC,KAAK,KAAK,UAAU,CAAC;IACvE,CAAC;IAED,IACW,UAAU;QACjB,OAAO,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,wBAAwB,CAAC,CAAC;IAC5E,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE;aACtB,IAAI,CACD,SAAS,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,eAAe,EAAE,CAAC,EACtD,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC3B;aACA,SAAS,CAAC,CAAC,KAAK,EAAO,EAAE;YACtB,IAAI,CAAC,gBAAgB,GAAG;gBACpB,IAAI,EAAE,KAAK,CAAC,UAAU;gBACtB,KAAK,EAAE,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,UAAU,CAAC;aACjD,CAAC;YACF,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,kBAAkB;QACpB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC;YACtC,SAAS,EAAE,yBAAyB;YACpC,cAAc,EAAE;gBACZ,gBAAgB,EAAE,IAAI,CAAC,gBAAgB;gBACvC,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,YAAY,EAAE,IAAI,CAAC,YAAY;aAClC;SACJ,CAAC,CAAC;QAEH,MAAM,KAAK,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAEU,eAAe;QACrB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;YACjD,cAAc,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC;YAC3D,cAAc,CAAC,YAAY,EAAE,CAAC;IACtC,CAAC;IAES,gBAAgB,CAAC,YAAoB;QAC3C,KAAK,MAAM,QAAQ,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACpC,IAAI,QAAQ,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;gBACjC,OAAO,QAAQ,CAAC,KAAK,CAAC;YAC1B,CAAC;QACL,CAAC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;2HAxFQ,6BAA6B,gNA6B1B,mBAAmB;+GA7BtB,6BAA6B,mHAClB,gBAAgB,wKClCxC,ohDA2BA,2oBDCQ,WAAW,mcACX,eAAe;;4FAIV,6BAA6B;kBArBzC,SAAS;+BACI,wBAAwB,iBAGnB,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,kBAC/B;wBACZ;4BACI,SAAS,EAAE,mBAAmB;4BAC9B,MAAM,EAAE;gCACJ,OAAO;6BACV;yBACJ;qBACJ,cACW,IAAI,WACP;wBACL,WAAW;wBACX,eAAe;wBACf,yBAAyB;qBAC5B;;0BA+BI,MAAM;2BAAC,mBAAmB;yCA5BS,YAAY;sBAAnD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAoC3B,UAAU;sBADpB,WAAW;uBAAC,OAAO","sourcesContent":["import { ChangeDetectorRef, Input, booleanAttribute, ChangeDetectionStrategy, Inject, Component, HostBinding, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { getI18nServiceConfig, I18nServiceConfig, GlobalConfig } from '@eui/base';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage, I18nService, GLOBAL_CONFIG_TOKEN } from '@eui/core';\nimport { takeUntil } from 'rxjs/operators';\nimport { Subject, startWith } from 'rxjs';\nimport { EuimAppService } from '../../../services';\nimport { ModalController } from '@ionic/angular';\nimport { EuimLanguageListComponent } from './euim-language-list.component';\nimport { BaseStatesDirective } from '../../base-states.directive';\nimport { IonicModule } from '@ionic/angular';\nimport { TranslateModule } from '@ngx-translate/core';\n\n@Component({\n    selector: 'euim-language-selector',\n    templateUrl: 'euim-language-selector.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    hostDirectives: [\n        {\n            directive: BaseStatesDirective,\n            inputs: [\n                'color',\n            ],\n        },\n    ],\n    standalone: true,\n    imports: [\n        IonicModule,\n        TranslateModule,\n        EuimLanguageListComponent,\n    ],\n})\nexport class EuimLanguageSelectorComponent implements OnInit, OnDestroy {\n    @Input({ transform: booleanAttribute }) hasSearchbar = true;\n    /**\n     * @deprecated will be removed in eUI Mobile v20. _euimBranding instead.\n     */\n    _euimPrimary: boolean;\n    _euimBranding: boolean;\n    /**\n     * @deprecated\n     * will become private in eUI Mobile v19.\n     */\n    languages: EuiLanguage[];\n    protected config: I18nServiceConfig;\n    selectedLanguage: EuiLanguage;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appShellService: EuiAppShellService,\n        /**\n         * @deprecated will be removed in eUI Mobile v19.\n         */\n        public appService: EuimAppService,\n        private i18nService: I18nService,\n        private modalCtrl: ModalController,\n        public baseStatesDirective: BaseStatesDirective,\n        @Inject(GLOBAL_CONFIG_TOKEN) protected baseGlobalConfig: GlobalConfig,\n    ) {\n        this.config = getI18nServiceConfig(this.baseGlobalConfig.i18n.i18nService);\n        this._euimPrimary = this.baseStatesDirective.color === 'primary';\n        this._euimBranding = this.baseStatesDirective.color === 'branding';\n    }\n\n    @HostBinding('class')\n    public get cssClasses(): string {\n        return this.baseStatesDirective.getCssClasses('euim-language-selector');\n    }\n\n    ngOnInit(): void {\n        this.getAllLanguages();\n        this.i18nService.getState()\n            .pipe(\n                startWith({ activeLang: this.config.defaultLanguage }),\n                takeUntil(this.destroy$),\n            )\n            .subscribe((state):void => {\n                this.selectedLanguage = {\n                    code: state.activeLang,\n                    label: this.getLanguageLabel(state.activeLang),\n                };\n                this.cd.detectChanges();\n            });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    async onShowLanguageList():Promise<void> {\n        const modal = await this.modalCtrl.create({\n            component: EuimLanguageListComponent,\n            componentProps: {\n                selectedLanguage: this.selectedLanguage,\n                languages: this.languages,\n                hasSearchbar: this.hasSearchbar,\n            },\n        });\n\n        await modal.present();\n   }\n\n    protected getAllLanguages(): void {\n        this.languages = (this.config.languages.length > 1) ?\n            EuiEuLanguages.getOrderedLanguages(this.config.languages) :\n            EuiEuLanguages.getLanguages();\n    }\n\n    protected getLanguageLabel(languageCode: string): string {\n        for (const language of this.languages) {\n            if (language.code === languageCode) {\n                return language.label;\n            }\n        }\n        return null;\n    }\n}\n","<ion-button (click)=\"onShowLanguageList()\" fill=\"clear\" shape=\"round\">\n    <ion-icon class=\"euim-language-selector__icon {{_euimBranding || _euimPrimary ? 'euim-language-selector__icon--branding' : ''}}\"\n              slot=\"icon-only\"\n              src='data:image/svg+xml;utf8,<svg xmlns=\"http://www.w3.org/2000/svg\"\n              viewBox=\"0 0 24 24\">\n                <path\n                    d=\"M 21.00,0.00\n                               C 22.66,-0.00 24.00,1.34 24.00,3.00\n                                 24.00,3.00 24.00,17.00 24.00,17.00\n                                 24.00,18.66 22.66,20.00 21.00,20.00\n                                 21.00,20.00 3.00,20.00 3.00,20.00\n                                 1.34,20.00 0.00,18.66 0.00,17.00\n                                 0.00,17.00 0.00,3.00 0.00,3.00\n                                 0.00,1.34 1.34,0.00 3.00,0.00\n                                 3.00,0.00 21.00,0.00 21.00,0.00 Z\n                               M 9.66,12.34\n                               C 9.66,12.34 15.31,18.00 15.31,18.00\n                                 15.31,18.00 9.66,23.66 9.66,23.66\n                                 9.66,23.66 4.00,18.00 4.00,18.00\n                                 4.00,18.00 9.66,12.34 9.66,12.34 Z\" />\n                </svg>'>\n    </ion-icon>\n\n    <span class=\"euim-language-selector__text {{_euimBranding || _euimPrimary ? 'euim-language-selector__text--branding' : ''}}\">\n        {{ selectedLanguage?.code?.toUpperCase() }}\n    </span>\n</ion-button>\n"]}
|
package/esm2022/lib/components/layout/euim-language-selector/euim-language-selector.module.mjs
CHANGED
|
@@ -6,11 +6,11 @@ import * as i0 from "@angular/core";
|
|
|
6
6
|
* @deprecated Use {@link EUIM_LANGUAGE_SELECTOR} instead.
|
|
7
7
|
*/
|
|
8
8
|
export class EuimLanguageSelectorModule {
|
|
9
|
-
static
|
|
10
|
-
static
|
|
11
|
-
EuimLanguageListComponent], exports: [EuimLanguageSelectorComponent, EuimLanguageListComponent] });
|
|
12
|
-
static
|
|
13
|
-
EuimLanguageListComponent] });
|
|
9
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
/** @nocollapse */ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorModule, imports: [EuimLanguageSelectorComponent,
|
|
11
|
+
EuimLanguageListComponent], exports: [EuimLanguageSelectorComponent, EuimLanguageListComponent] });
|
|
12
|
+
/** @nocollapse */ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorModule, imports: [EuimLanguageSelectorComponent,
|
|
13
|
+
EuimLanguageListComponent] });
|
|
14
14
|
}
|
|
15
15
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimLanguageSelectorModule, decorators: [{
|
|
16
16
|
type: NgModule,
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
22
22
|
exports: [EuimLanguageSelectorComponent, EuimLanguageListComponent],
|
|
23
23
|
}]
|
|
24
24
|
}] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1sYW5ndWFnZS1zZWxlY3Rvci5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvbGF5b3V0L2V1aW0tbGFuZ3VhZ2Utc2VsZWN0b3IvZXVpbS1sYW5ndWFnZS1zZWxlY3Rvci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxvQ0FBb0MsQ0FBQztBQUNuRixPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUFFM0U7O0dBRUc7QUFRSCxNQUFNLE9BQU8sMEJBQTBCOzJIQUExQiwwQkFBMEI7NEhBQTFCLDBCQUEwQixZQUwvQiw2QkFBNkI7WUFDN0IseUJBQXlCLGFBRW5CLDZCQUE2QixFQUFFLHlCQUF5Qjs0SEFFekQsMEJBQTBCLFlBTC9CLDZCQUE2QjtZQUM3Qix5QkFBeUI7OzRGQUlwQiwwQkFBMEI7a0JBUHRDLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLDZCQUE2Qjt3QkFDN0IseUJBQXlCO3FCQUM1QjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyw2QkFBNkIsRUFBRSx5QkFBeUIsQ0FBQztpQkFDdEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRXVpbUxhbmd1YWdlU2VsZWN0b3JDb21wb25lbnQgfSBmcm9tICcuL2V1aW0tbGFuZ3VhZ2Utc2VsZWN0b3IuY29tcG9uZW50JztcbmltcG9ydCB7IEV1aW1MYW5ndWFnZUxpc3RDb21wb25lbnQgfSBmcm9tICcuL2V1aW0tbGFuZ3VhZ2UtbGlzdC5jb21wb25lbnQnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgRVVJTV9MQU5HVUFHRV9TRUxFQ1RPUn0gaW5zdGVhZC5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIEV1aW1MYW5ndWFnZVNlbGVjdG9yQ29tcG9uZW50LFxuICAgICAgICBFdWltTGFuZ3VhZ2VMaXN0Q29tcG9uZW50LFxuICAgIF0sXG4gICAgZXhwb3J0czogW0V1aW1MYW5ndWFnZVNlbGVjdG9yQ29tcG9uZW50LCBFdWltTGFuZ3VhZ2VMaXN0Q29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbUxhbmd1YWdlU2VsZWN0b3JNb2R1bGUge31cbiJdfQ==
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ViewChild, Output, EventEmitter, Component, HostBinding, Input, booleanAttribute } from '@angular/core';
|
|
2
|
+
import { I18nService, EuiAppShellService } from '@eui/core';
|
|
3
|
+
import { NavController, MenuController } from '@ionic/angular';
|
|
2
4
|
// import { IonList, IonSearchbar, IonMenuToggle } from '@ionic/angular/standalone';
|
|
3
5
|
import { IonicModule, IonSearchbar } from '@ionic/angular';
|
|
4
6
|
import { CommonModule } from '@angular/common';
|
|
@@ -7,19 +9,24 @@ import * as i1 from "@eui/core";
|
|
|
7
9
|
import * as i2 from "@ionic/angular";
|
|
8
10
|
import * as i3 from "@angular/common";
|
|
9
11
|
export class EuimSidebarContentComponent {
|
|
12
|
+
i18nService;
|
|
13
|
+
asService;
|
|
14
|
+
menuCtrl;
|
|
15
|
+
navCtrl;
|
|
16
|
+
className = 'euim-sidebar-content';
|
|
17
|
+
sidebarItems = [];
|
|
18
|
+
ionMenuId = 'main';
|
|
19
|
+
hasSearchbar = false;
|
|
20
|
+
isSearchbarSticky = false;
|
|
21
|
+
sidebarItemsFilter = new EventEmitter();
|
|
22
|
+
searchbar;
|
|
23
|
+
filteredItems = [];
|
|
24
|
+
query = '';
|
|
10
25
|
constructor(i18nService, asService, menuCtrl, navCtrl) {
|
|
11
26
|
this.i18nService = i18nService;
|
|
12
27
|
this.asService = asService;
|
|
13
28
|
this.menuCtrl = menuCtrl;
|
|
14
29
|
this.navCtrl = navCtrl;
|
|
15
|
-
this.className = 'euim-sidebar-content';
|
|
16
|
-
this.sidebarItems = [];
|
|
17
|
-
this.ionMenuId = 'main';
|
|
18
|
-
this.hasSearchbar = false;
|
|
19
|
-
this.isSearchbarSticky = false;
|
|
20
|
-
this.sidebarItemsFilter = new EventEmitter();
|
|
21
|
-
this.filteredItems = [];
|
|
22
|
-
this.query = '';
|
|
23
30
|
i18nService.init().subscribe();
|
|
24
31
|
}
|
|
25
32
|
ngOnInit() {
|
|
@@ -61,8 +68,8 @@ export class EuimSidebarContentComponent {
|
|
|
61
68
|
return labelMatch || typeMatch;
|
|
62
69
|
});
|
|
63
70
|
}
|
|
64
|
-
static
|
|
65
|
-
static
|
|
71
|
+
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimSidebarContentComponent, deps: [{ token: i1.I18nService }, { token: i1.EuiAppShellService }, { token: i2.MenuController }, { token: i2.NavController }], target: i0.ɵɵFactoryTarget.Component });
|
|
72
|
+
/** @nocollapse */ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: EuimSidebarContentComponent, isStandalone: true, selector: "euim-sidebar-content", inputs: { sidebarItems: "sidebarItems", ionMenuId: "ionMenuId", hasSearchbar: ["hasSearchbar", "hasSearchbar", booleanAttribute], isSearchbarSticky: ["isSearchbarSticky", "isSearchbarSticky", booleanAttribute] }, outputs: { sidebarItemsFilter: "sidebarItemsFilter" }, host: { properties: { "className": "this.className" } }, viewQueries: [{ propertyName: "searchbar", first: true, predicate: IonSearchbar, descendants: true }], ngImport: i0, template: "<ion-list class=\"euim-sidebar-content__list\">\n @if (hasSearchbar) {\n <div class=\"euim-sidebar-content__searchbar\" [ngClass]=\"{ 'euim-sidebar-content__searchbar--sticky': isSearchbarSticky }\">\n <ion-searchbar (ionInput)=\"handleInput($event)\"></ion-searchbar>\n </div>\n }\n <ion-menu-toggle auto-hide=\"true\" (click)=\"closeMenu()\" menu=\"{{ionMenuId}}\">\n <ng-content></ng-content>\n </ion-menu-toggle>\n</ion-list>\n\n", dependencies: [{ kind: "ngmodule", type: IonicModule }, { kind: "component", type: i2.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i2.IonMenuToggle, selector: "ion-menu-toggle", inputs: ["autoHide", "menu"] }, { kind: "component", type: i2.IonSearchbar, selector: "ion-searchbar", inputs: ["animated", "autocapitalize", "autocomplete", "autocorrect", "cancelButtonIcon", "cancelButtonText", "clearIcon", "color", "debounce", "disabled", "enterkeyhint", "inputmode", "maxlength", "minlength", "mode", "name", "placeholder", "searchIcon", "showCancelButton", "showClearButton", "spellcheck", "type", "value"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-input-otp[type=text],ion-textarea,ion-searchbar" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
66
73
|
}
|
|
67
74
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: EuimSidebarContentComponent, decorators: [{
|
|
68
75
|
type: Component,
|
|
@@ -85,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
85
92
|
type: ViewChild,
|
|
86
93
|
args: [IonSearchbar, { static: false }]
|
|
87
94
|
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-sidebar-content.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.ts","../../../../../../../src/lib/components/layout/euim-sidebar/euim-sidebar-content/euim-sidebar-content.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ViewChild, Output, EventEmitter, Component, HostBinding, Input, OnInit, booleanAttribute } from '@angular/core';\nimport { I18nService, EuiAppShellService } from '@eui/core';\nimport { NavController, MenuController } from '@ionic/angular';\nimport { BooleanInput } from '@angular/cdk/coercion';\n// import { IonList, IonSearchbar, IonMenuToggle } from '@ionic/angular/standalone';\nimport { IonicModule, IonSearchbar } from '@ionic/angular';\nimport { CommonModule } from '@angular/common';\n\nexport type IconColor = 'primary' | 'default' | 'info' | 'success' | 'warning' | 'danger' | 'dark' | 'white' | 'accent' | 'secondary';\n@Component({\n    selector: 'euim-sidebar-content',\n    templateUrl: './euim-sidebar-content.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    standalone: true,\n    // imports: [IonMenuToggle, IonList, IonSearchbar, CommonModule],\n    imports: [IonicModule, CommonModule],\n})\nexport class EuimSidebarContentComponent implements OnInit {\n    @HostBinding() className = 'euim-sidebar-content';\n    @Input() sidebarItems: MenuItem[] = [];\n    @Input() ionMenuId = 'main';\n    @Input({ transform: booleanAttribute })\n    hasSearchbar: BooleanInput = false;\n    @Input({ transform: booleanAttribute })\n    isSearchbarSticky: BooleanInput = false;\n    @Output() sidebarItemsFilter = new EventEmitter<MenuItem[]>();\n    @ViewChild(IonSearchbar, { static: false }) searchbar: IonSearchbar;\n\n    protected filteredItems: MenuItem[] = [];\n    protected query ='';\n\n    constructor(private i18nService: I18nService,\n        public asService: EuiAppShellService,\n        private menuCtrl: MenuController,\n        private navCtrl: NavController) {\n            i18nService.init().subscribe();\n    }\n\n    ngOnInit(): void {\n        this.sortSidebarItems();\n\n        if (this.hasSearchbar) {\n            this.filteredItems = [...this.sidebarItems];\n            this.sidebarItemsFilter.emit(this.filteredItems);\n        }\n    }\n\n    handleInput(event: CustomEvent): void {\n        this.query = event.detail.value.toLowerCase();\n        this.filteredItems = this.filterMenuItems(this.sidebarItems, this.query);\n        this.sidebarItemsFilter.emit(this.filteredItems);\n\n        if (this.query === '') {\n            this.sidebarItemsFilter.emit(this.sidebarItems);\n        }\n    }\n\n    closeMenu(): void {\n        if (!this.hasSearchbar) return;\n\n        this.menuCtrl.close().then(() => {\n            this.sidebarItemsFilter.emit(this.sidebarItems);\n            this.query = '';\n            this.searchbar.value = '';\n        });\n    }\n\n    protected sortSidebarItems(): void {\n        this.sidebarItems.sort((a, b) => {\n            if (a.group === b.group) {\n                return a.label.localeCompare(b.label);\n            }\n            return a.group - b.group;\n        });\n    }\n    protected filterMenuItems(items, searchPhrase: string): MenuItem[] {\n        return items.filter(component => {\n            const labelMatch = component.label?.toLowerCase().includes(searchPhrase);\n            const typeMatch = component.type?.toLowerCase().includes(searchPhrase);\n\n            return labelMatch || typeMatch;\n        });\n    }\n}\n\ninterface MenuItem {\n    icon?: string;\n    iconColor?: IconColor;\n    label: string;\n    url?: string;\n    isSection?: boolean;\n    section?: string;\n    group?: number;\n    groupHeader?: string;\n}\n\n","<ion-list class=\"euim-sidebar-content__list\">\n    @if (hasSearchbar) {\n        <div class=\"euim-sidebar-content__searchbar\" [ngClass]=\"{ 'euim-sidebar-content__searchbar--sticky': isSearchbarSticky }\">\n            <ion-searchbar (ionInput)=\"handleInput($event)\"></ion-searchbar>\n        </div>\n    }\n    <ion-menu-toggle auto-hide=\"true\" (click)=\"closeMenu()\" menu=\"{{ionMenuId}}\">\n        <ng-content></ng-content>\n    </ion-menu-toggle>\n</ion-list>\n\n"]}
|