@eui/mobile-core 17.2.2-snapshot-1718806226751 → 17.2.2-snapshot-1718990833040
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/esm2022/lib/components/euim-about/euim-help-support/euim-help-support.component.mjs +9 -13
- package/esm2022/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.mjs +5 -4
- package/esm2022/lib/components/euim-message/euim-message.component.mjs +10 -12
- package/esm2022/lib/components/layout/euim-language-selector/euim-language-list.component.mjs +4 -6
- package/esm2022/lib/components/layout/euim-language-selector/euim-language-selector.component.mjs +2 -2
- package/fesm2022/eui-mobile-core.mjs +25 -32
- package/fesm2022/eui-mobile-core.mjs.map +1 -1
- package/lib/components/euim-about/euim-help-support/euim-help-support.component.d.ts.map +1 -1
- package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts +1 -0
- package/lib/components/euim-chip-selector/euim-chip-selector-item/euim-chip-selector-item.directive.d.ts.map +1 -1
- package/lib/components/euim-message/euim-message.component.d.ts.map +1 -1
- package/lib/components/layout/euim-language-selector/euim-language-list.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -44,26 +44,22 @@ export class EuimHelpSupportComponent {
|
|
|
44
44
|
return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';
|
|
45
45
|
}
|
|
46
46
|
getLink(item, linkType, linkTitle) {
|
|
47
|
-
if (linkTitle && linkType === 'mail') {
|
|
48
|
-
return 'mailto:' + linkTitle;
|
|
49
|
-
}
|
|
50
|
-
if (linkTitle && linkType === 'call') {
|
|
51
|
-
return 'tel:' + linkTitle;
|
|
52
|
-
}
|
|
53
47
|
if (linkTitle) {
|
|
48
|
+
if (linkType === 'mail')
|
|
49
|
+
return 'mailto:' + linkTitle;
|
|
50
|
+
if (linkType === 'call')
|
|
51
|
+
return 'tel:' + linkTitle;
|
|
54
52
|
return linkTitle;
|
|
55
53
|
}
|
|
56
54
|
if (item) {
|
|
57
|
-
if (item.phone)
|
|
55
|
+
if (item.phone)
|
|
58
56
|
return 'tel:' + item.phone;
|
|
59
|
-
|
|
60
|
-
if (item.mail) {
|
|
57
|
+
if (item.mail)
|
|
61
58
|
return 'mailto:' + item.mail;
|
|
62
|
-
|
|
63
|
-
if (item.link) {
|
|
59
|
+
if (item.link)
|
|
64
60
|
return item.link;
|
|
65
|
-
}
|
|
66
61
|
}
|
|
62
|
+
return null;
|
|
67
63
|
}
|
|
68
64
|
setTargetAttribute(item, linkType) {
|
|
69
65
|
if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {
|
|
@@ -89,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
89
85
|
type: HostBinding,
|
|
90
86
|
args: ['class']
|
|
91
87
|
}] } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-help-support.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.ts","../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AASjF,MAAM,OAAO,wBAAwB;IAiBjC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAhBlC;;WAEG;QACM,iBAAY,GAAiB,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;QACvD;;WAEG;QACM,qBAAgB,GAAqB,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;QAChE;;WAEG;QACM,eAAU,GAAe,EAAE,CAAA;QAC3B,wBAAmB,GAAwB,EAAE,CAAC;QAEjC,cAAS,GAAG,mBAAmB,CAAC;IAEjB,CAAC;IAEtC,WAAW,CAAC,IAAU,EAAE,QAAgB,EAAE,SAAiB;QACvD,IAAI,IAAI,EAAE,UAAU,EAAE;YAClB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;aAC/D,CAAC,CAAC;SACN;aAAM;YACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;SACjG;IACL,CAAC;IAED,WAAW,CAAC,IAAU;QAClB,OAAO,IAAI,EAAE,OAAO,KAAK,YAAY,CAAC;IAC1C,CAAC;IAED,YAAY,CAAC,IAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,gFAAgF,CAAC,CAAC,CAAC,iCAAiC,CAAC;IACzJ,CAAC;IAED,OAAO,CAAC,IAAW,EAAE,QAAiB,EAAE,SAAkB;QAEtD,IAAI,SAAS,IAAI,QAAQ,KAAK,MAAM,EAAE;YAClC,OAAO,SAAS,GAAG,SAAS,CAAC;SAChC;QAED,IAAI,SAAS,IAAI,QAAQ,KAAK,MAAM,EAAE;YAClC,OAAO,MAAM,GAAG,SAAS,CAAC;SAC7B;QAED,IAAI,SAAS,EAAE;YACX,OAAO,SAAS,CAAC;SACpB;QAED,IAAI,IAAI,EAAE;YACN,IAAI,IAAI,CAAC,KAAK,EAAE;gBACZ,OAAO,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC;aAC9B;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,OAAO,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;aAChC;YAED,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,OAAO,IAAI,CAAC,IAAI,CAAC;aACpB;SACJ;IACL,CAAC;IAED,kBAAkB,CAAC,IAAW,EAAE,QAAiB;QAE7C,IAAI,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,MAAM,EAAE;YAC3E,OAAO,OAAO,CAAC;SAChB;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;iIAzEQ,wBAAwB;qHAAxB,wBAAwB,oQCTrC,y6KAkIA;;2FDzHa,wBAAwB;kBANpC,SAAS;+BACI,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI;2EAM5B,YAAY;sBAApB,KAAK;gBAIG,gBAAgB;sBAAxB,KAAK;gBAIG,UAAU;sBAAlB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEgB,SAAS;sBAA9B,WAAW;uBAAC,OAAO","sourcesContent":["import { Component, Input, HostBinding, ViewEncapsulation } from '@angular/core';\nimport { Router } from '@angular/router';\n\n@Component({\n    selector: 'euim-help-support',\n    templateUrl: './euim-help-support.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimHelpSupportComponent {\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() helpContacts: HelpContacts = { contacts: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() supportMaterials: SupportMaterials = { materials: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18\n     */\n    @Input() alertInfos: AlertInfos = {}\n    @Input() helpAndSupportItems:HelpAndSupportItem[] = [];\n\n    @HostBinding('class') className = 'euim-help-support';\n\n    constructor(private router: Router) {}\n\n    onItemClick(item: Item, linkType: string, linkTitle: string): void {\n        if (item?.routerLink) {\n            this.router.navigate([item.routerLink], {\n                fragment: item.fragment && !item.link ? item.fragment : null,\n            });\n        } else {\n            window.open(this.getLink(item, linkType, linkTitle), this.setTargetAttribute(item, linkType));\n        }\n    }\n\n    isLinkSharp(item: Item): boolean {\n        return item?.endIcon === 'link-sharp';\n    }\n\n    getLinkClass(item: Item): string {\n        return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';\n    }\n\n    getLink(item?: Item, linkType?: string, linkTitle?: string): string {\n\n        if (linkTitle && linkType === 'mail') {\n            return 'mailto:' + linkTitle;\n        }\n\n        if (linkTitle && linkType === 'call') {\n            return 'tel:' + linkTitle;\n        }\n\n        if (linkTitle) {\n            return linkTitle;\n        }\n\n        if (item) {\n            if (item.phone) {\n                return 'tel:' + item.phone;\n            }\n\n            if (item.mail) {\n                return 'mailto:' + item.mail;\n            }\n\n            if (item.link) {\n                return item.link;\n            }\n        }\n    }\n\n    setTargetAttribute(item?: Item, linkType?: string): string {\n\n        if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {\n          return '_self';\n        }\n\n        return '_blank';\n    }\n}\n\ninterface AlertInfos {\n    icon?: string;\n    title?: string;\n    btnLink?: string;\n    btnTitle?: string;\n}\n\ninterface Contact {\n    linkTitle: string;\n    linkType?: string;\n    link?: string;\n    subtitle?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface HelpContacts {\n    sectionTitle?: string;\n    contacts: Contact[];\n}\n\ninterface Material {\n    title: string;\n    subtitle?: string;\n    link?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface SupportMaterials {\n    sectionTitle?: string;\n    materials: Material[];\n}\ninterface Item {\n  title: string;\n  link?: string;\n  phone?: string;\n  mail?: string;\n  routerLink?: string;\n  fragment?: string;\n  subtitle?: string;\n  startIcon?: string;\n  endIcon?: string;\n  hasBottomLine?: boolean;\n}\n\ninterface HelpAndSupportItem {\n  sectionTitle?: string;\n  items: Item[];\n}\n","<ion-header>\n  <ion-toolbar color=\"primary\">\n    <euim-toolbar>\n      <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n    </euim-toolbar>\n  </ion-toolbar>\n    @if (alertInfos.title) {\n        <euim-alert-message color=\"primary\">\n            <ion-icon name=\"person-circle\" slotStart></ion-icon>\n            {{ alertInfos.title }}\n\n            @if (alertInfos.btnLink) {\n                <ion-button [href]=\"alertInfos.btnLink\" slotEnd size=\"small\" fill=\"outline\">\n                    <strong>{{ alertInfos.btnTitle }}</strong>\n                </ion-button>\n            }\n        </euim-alert-message>\n    }\n    <ng-content select=\"[headerSection]\"></ng-content>\n</ion-header>\n\n@if (helpAndSupportItems.length > 0 || helpContacts.contacts.length > 0 || supportMaterials.materials.length > 0) {\n  <ion-list>\n      @for (helpSupportItem of helpAndSupportItems; track $index;) {\n          @if (helpSupportItem.sectionTitle) {\n              <ion-item-divider>\n                <ion-label>{{ helpSupportItem.sectionTitle }}</ion-label>\n              </ion-item-divider>\n          }\n\n        @for (item of helpSupportItem.items; track item;) {\n\n            <ion-item [lines]=\"item.hasBottomLine ? 'insert' : 'none'\" (click)=\"onItemClick(item, undefined, undefined)\">\n                @if (item.startIcon) {\n                    <euim-avatar-icon fill=\"solid\" slot=\"start\">\n                        <ion-icon [name]=\"item.startIcon\"></ion-icon>\n                    </euim-avatar-icon>\n                }\n                @if (item.title || item.subtitle) {\n                    <ion-label>\n                        @if (item.title) {\n                            <a [ngClass]=\"getLinkClass(item)\">\n                                @if (!isLinkSharp(item)) {\n                                <div class=\"euim-help-support__title\">{{ item.title }}</div>\n                                }\n                                @if (isLinkSharp(item)) {\n                                <div euimLabel euimLabelTitle>{{ item.title }}</div>\n                                }\n                            </a>\n                        }\n                        @if (item.subtitle) {\n                            <div euimLabel euimLabelSubTitle>\n                                {{ item.subtitle }}\n                            </div>\n                        }\n                    </ion-label>\n                }\n                @if (item.endIcon) {\n                    <ion-buttons>\n                        <ion-button fill=\"clear\">\n                            <ion-icon [name]=\"item.endIcon\" slot=\"icon-only\"></ion-icon>\n                        </ion-button>\n                    </ion-buttons>\n                }\n            </ion-item>\n        }\n      }\n      @if (helpContacts.contacts.length > 0) {\n          @if (helpContacts.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ helpContacts.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (contact of helpContacts.contacts; track contact; let isLast = $last) {\n              <ion-item [lines]=\"isLast ? 'none' : ''\" (click)=\"onItemClick(undefined, contact.linkType, contact.linkTitle)\">\n                  @if (contact.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"contact.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  @if (contact.linkTitle || contact.subtitle) {\n                  <ion-label>\n                      @if (contact.linkTitle) {\n                      <a class=\"euim-help-support__contact-link\">\n                          <div class=\"euim-help-support__title\">{{contact.linkTitle}}</div>\n                      </a>\n                      }\n                      @if (contact.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{contact.subtitle}}</div>\n                      }\n                  </ion-label>\n                  }\n              </ion-item>\n          }\n      }\n\n      @if (supportMaterials.materials.length > 0) {\n          @if (supportMaterials.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ supportMaterials.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (material of supportMaterials.materials; track material) {\n              <ion-item lines=\"none\" (click)=\"onItemClick(material, undefined, undefined)\">\n                  @if (material.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"material.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  <ion-label>\n                      @if (material.title) {\n                      <div euimLabel euimLabelTitle>{{material.title}}</div>\n                      }\n                      @if (material.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{material.subtitle}}</div>\n                      }\n                  </ion-label>\n                  <ion-buttons>\n                      <ion-button fill=\"clear\" >\n                          <ion-icon name=\"link-sharp\" slot=\"icon-only\"></ion-icon>\n                      </ion-button>\n                  </ion-buttons>\n              </ion-item>\n          }\n      }\n  </ion-list>\n}\n<ng-content></ng-content>\n\n\n"]}
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"euim-help-support.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.ts","../../../../../../src/lib/components/euim-about/euim-help-support/euim-help-support.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;;AASjF,MAAM,OAAO,wBAAwB;IAiBjC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAhBlC;;WAEG;QACM,iBAAY,GAAiB,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;QACvD;;WAEG;QACM,qBAAgB,GAAqB,EAAE,SAAS,EAAE,EAAE,EAAE,CAAC;QAChE;;WAEG;QACM,eAAU,GAAe,EAAE,CAAA;QAC3B,wBAAmB,GAAwB,EAAE,CAAC;QAEjC,cAAS,GAAG,mBAAmB,CAAC;IAEjB,CAAC;IAEtC,WAAW,CAAC,IAAU,EAAE,QAAgB,EAAE,SAAiB;QACvD,IAAI,IAAI,EAAE,UAAU,EAAE;YAClB,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE;gBACpC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI;aAC/D,CAAC,CAAC;SACN;aAAM;YACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,QAAQ,EAAE,SAAS,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC,CAAC;SACjG;IACL,CAAC;IAED,WAAW,CAAC,IAAU;QAClB,OAAO,IAAI,EAAE,OAAO,KAAK,YAAY,CAAC;IAC1C,CAAC;IAED,YAAY,CAAC,IAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,gFAAgF,CAAC,CAAC,CAAC,iCAAiC,CAAC;IACzJ,CAAC;IAED,OAAO,CAAC,IAAW,EAAE,QAAiB,EAAE,SAAkB;QACtD,IAAI,SAAS,EAAE;YACX,IAAI,QAAQ,KAAK,MAAM;gBAAE,OAAO,SAAS,GAAG,SAAS,CAAC;YACtD,IAAI,QAAQ,KAAK,MAAM;gBAAE,OAAO,MAAM,GAAG,SAAS,CAAC;YACnD,OAAO,SAAS,CAAC;SACpB;QAED,IAAI,IAAI,EAAE;YACN,IAAI,IAAI,CAAC,KAAK;gBAAE,OAAO,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC;YAC3C,IAAI,IAAI,CAAC,IAAI;gBAAE,OAAO,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;YAC5C,IAAI,IAAI,CAAC,IAAI;gBAAE,OAAO,IAAI,CAAC,IAAI,CAAC;SACnC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,kBAAkB,CAAC,IAAW,EAAE,QAAiB;QAE7C,IAAI,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,IAAI,IAAI,QAAQ,KAAK,MAAM,IAAI,QAAQ,KAAK,MAAM,EAAE;YAC3E,OAAO,OAAO,CAAC;SAChB;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;iIA3DQ,wBAAwB;qHAAxB,wBAAwB,oQCTrC,y6KAkIA;;2FDzHa,wBAAwB;kBANpC,SAAS;+BACI,mBAAmB,iBAGd,iBAAiB,CAAC,IAAI;2EAM5B,YAAY;sBAApB,KAAK;gBAIG,gBAAgB;sBAAxB,KAAK;gBAIG,UAAU;sBAAlB,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEgB,SAAS;sBAA9B,WAAW;uBAAC,OAAO","sourcesContent":["import { Component, Input, HostBinding, ViewEncapsulation } from '@angular/core';\nimport { Router } from '@angular/router';\n\n@Component({\n    selector: 'euim-help-support',\n    templateUrl: './euim-help-support.component.html',\n    styleUrls: ['./styles/_index.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EuimHelpSupportComponent {\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() helpContacts: HelpContacts = { contacts: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18. Please use {@link helpAndSupportItems} instead\n     */\n    @Input() supportMaterials: SupportMaterials = { materials: [] };\n    /**\n     * @deprecated will be removed in eUI Mobile v18\n     */\n    @Input() alertInfos: AlertInfos = {}\n    @Input() helpAndSupportItems:HelpAndSupportItem[] = [];\n\n    @HostBinding('class') className = 'euim-help-support';\n\n    constructor(private router: Router) {}\n\n    onItemClick(item: Item, linkType: string, linkTitle: string): void {\n        if (item?.routerLink) {\n            this.router.navigate([item.routerLink], {\n                fragment: item.fragment && !item.link ? item.fragment : null,\n            });\n        } else {\n            window.open(this.getLink(item, linkType, linkTitle), this.setTargetAttribute(item, linkType));\n        }\n    }\n\n    isLinkSharp(item: Item): boolean {\n        return item?.endIcon === 'link-sharp';\n    }\n\n    getLinkClass(item: Item): string {\n        return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';\n    }\n\n    getLink(item?: Item, linkType?: string, linkTitle?: string): string {\n        if (linkTitle) {\n            if (linkType === 'mail') return 'mailto:' + linkTitle;\n            if (linkType === 'call') return 'tel:' + linkTitle;\n            return linkTitle;\n        }\n\n        if (item) {\n            if (item.phone) return 'tel:' + item.phone;\n            if (item.mail) return 'mailto:' + item.mail;\n            if (item.link) return item.link;\n        }\n        return null;\n    }\n\n    setTargetAttribute(item?: Item, linkType?: string): string {\n\n        if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {\n          return '_self';\n        }\n\n        return '_blank';\n    }\n}\n\ninterface AlertInfos {\n    icon?: string;\n    title?: string;\n    btnLink?: string;\n    btnTitle?: string;\n}\n\ninterface Contact {\n    linkTitle: string;\n    linkType?: string;\n    link?: string;\n    subtitle?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface HelpContacts {\n    sectionTitle?: string;\n    contacts: Contact[];\n}\n\ninterface Material {\n    title: string;\n    subtitle?: string;\n    link?: string;\n    icon?: string;\n    routerLink?: string;\n    fragment?: string;\n}\n\ninterface SupportMaterials {\n    sectionTitle?: string;\n    materials: Material[];\n}\ninterface Item {\n  title: string;\n  link?: string;\n  phone?: string;\n  mail?: string;\n  routerLink?: string;\n  fragment?: string;\n  subtitle?: string;\n  startIcon?: string;\n  endIcon?: string;\n  hasBottomLine?: boolean;\n}\n\ninterface HelpAndSupportItem {\n  sectionTitle?: string;\n  items: Item[];\n}\n","<ion-header>\n  <ion-toolbar color=\"primary\">\n    <euim-toolbar>\n      <euim-toolbar-title>{{'euim.about.help.support' | translate }}</euim-toolbar-title>\n    </euim-toolbar>\n  </ion-toolbar>\n    @if (alertInfos.title) {\n        <euim-alert-message color=\"primary\">\n            <ion-icon name=\"person-circle\" slotStart></ion-icon>\n            {{ alertInfos.title }}\n\n            @if (alertInfos.btnLink) {\n                <ion-button [href]=\"alertInfos.btnLink\" slotEnd size=\"small\" fill=\"outline\">\n                    <strong>{{ alertInfos.btnTitle }}</strong>\n                </ion-button>\n            }\n        </euim-alert-message>\n    }\n    <ng-content select=\"[headerSection]\"></ng-content>\n</ion-header>\n\n@if (helpAndSupportItems.length > 0 || helpContacts.contacts.length > 0 || supportMaterials.materials.length > 0) {\n  <ion-list>\n      @for (helpSupportItem of helpAndSupportItems; track $index;) {\n          @if (helpSupportItem.sectionTitle) {\n              <ion-item-divider>\n                <ion-label>{{ helpSupportItem.sectionTitle }}</ion-label>\n              </ion-item-divider>\n          }\n\n        @for (item of helpSupportItem.items; track item;) {\n\n            <ion-item [lines]=\"item.hasBottomLine ? 'insert' : 'none'\" (click)=\"onItemClick(item, undefined, undefined)\">\n                @if (item.startIcon) {\n                    <euim-avatar-icon fill=\"solid\" slot=\"start\">\n                        <ion-icon [name]=\"item.startIcon\"></ion-icon>\n                    </euim-avatar-icon>\n                }\n                @if (item.title || item.subtitle) {\n                    <ion-label>\n                        @if (item.title) {\n                            <a [ngClass]=\"getLinkClass(item)\">\n                                @if (!isLinkSharp(item)) {\n                                <div class=\"euim-help-support__title\">{{ item.title }}</div>\n                                }\n                                @if (isLinkSharp(item)) {\n                                <div euimLabel euimLabelTitle>{{ item.title }}</div>\n                                }\n                            </a>\n                        }\n                        @if (item.subtitle) {\n                            <div euimLabel euimLabelSubTitle>\n                                {{ item.subtitle }}\n                            </div>\n                        }\n                    </ion-label>\n                }\n                @if (item.endIcon) {\n                    <ion-buttons>\n                        <ion-button fill=\"clear\">\n                            <ion-icon [name]=\"item.endIcon\" slot=\"icon-only\"></ion-icon>\n                        </ion-button>\n                    </ion-buttons>\n                }\n            </ion-item>\n        }\n      }\n      @if (helpContacts.contacts.length > 0) {\n          @if (helpContacts.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ helpContacts.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (contact of helpContacts.contacts; track contact; let isLast = $last) {\n              <ion-item [lines]=\"isLast ? 'none' : ''\" (click)=\"onItemClick(undefined, contact.linkType, contact.linkTitle)\">\n                  @if (contact.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"contact.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  @if (contact.linkTitle || contact.subtitle) {\n                  <ion-label>\n                      @if (contact.linkTitle) {\n                      <a class=\"euim-help-support__contact-link\">\n                          <div class=\"euim-help-support__title\">{{contact.linkTitle}}</div>\n                      </a>\n                      }\n                      @if (contact.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{contact.subtitle}}</div>\n                      }\n                  </ion-label>\n                  }\n              </ion-item>\n          }\n      }\n\n      @if (supportMaterials.materials.length > 0) {\n          @if (supportMaterials.sectionTitle) {\n          <ion-item-divider>\n              <ion-label>{{ supportMaterials.sectionTitle }}</ion-label>\n          </ion-item-divider>\n          }\n          @for (material of supportMaterials.materials; track material) {\n              <ion-item lines=\"none\" (click)=\"onItemClick(material, undefined, undefined)\">\n                  @if (material.icon) {\n                  <euim-avatar-icon  fill=\"solid\" slot=\"start\">\n                      <ion-icon [name]=\"material.icon\"></ion-icon>\n                  </euim-avatar-icon>\n                  }\n                  <ion-label>\n                      @if (material.title) {\n                      <div euimLabel euimLabelTitle>{{material.title}}</div>\n                      }\n                      @if (material.subtitle) {\n                      <div euimLabel euimLabelSubTitle>{{material.subtitle}}</div>\n                      }\n                  </ion-label>\n                  <ion-buttons>\n                      <ion-button fill=\"clear\" >\n                          <ion-icon name=\"link-sharp\" slot=\"icon-only\"></ion-icon>\n                      </ion-button>\n                  </ion-buttons>\n              </ion-item>\n          }\n      }\n  </ion-list>\n}\n<ng-content></ng-content>\n\n\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Directive, HostBinding, Input, booleanAttribute } from '@angular/core';
|
|
1
|
+
import { Directive, HostBinding, Input, booleanAttribute, numberAttribute } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export class EuimChipSelectorItemDirective {
|
|
4
4
|
constructor(renderer, el) {
|
|
@@ -9,7 +9,7 @@ export class EuimChipSelectorItemDirective {
|
|
|
9
9
|
this.className = 'euim-chip-selector__item';
|
|
10
10
|
}
|
|
11
11
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimChipSelectorItemDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
12
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.7", type: EuimChipSelectorItemDirective, selector: "[euimChipSelectorItem]", inputs: { id: "id", euimChipSelectorAll: ["euimChipSelectorAll", "euimChipSelectorAll", booleanAttribute] }, host: { properties: { "class": "this.className" } }, ngImport: i0 }); }
|
|
12
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.7", type: EuimChipSelectorItemDirective, selector: "[euimChipSelectorItem]", inputs: { id: ["id", "id", numberAttribute], euimChipSelectorAll: ["euimChipSelectorAll", "euimChipSelectorAll", booleanAttribute] }, host: { properties: { "class": "this.className" } }, ngImport: i0 }); }
|
|
13
13
|
}
|
|
14
14
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimChipSelectorItemDirective, decorators: [{
|
|
15
15
|
type: Directive,
|
|
@@ -17,7 +17,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
17
17
|
selector: '[euimChipSelectorItem]',
|
|
18
18
|
}]
|
|
19
19
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { id: [{
|
|
20
|
-
type: Input
|
|
20
|
+
type: Input,
|
|
21
|
+
args: [{ transform: numberAttribute }]
|
|
21
22
|
}], euimChipSelectorAll: [{
|
|
22
23
|
type: Input,
|
|
23
24
|
args: [{ transform: booleanAttribute }]
|
|
@@ -25,4 +26,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
25
26
|
type: HostBinding,
|
|
26
27
|
args: ['class']
|
|
27
28
|
}] } });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1jaGlwLXNlbGVjdG9yLWl0ZW0uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jb21wb25lbnRzL2V1aW0tY2hpcC1zZWxlY3Rvci9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS9ldWltLWNoaXAtc2VsZWN0b3ItaXRlbS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUF5QixnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBS3hILE1BQU0sT0FBTyw2QkFBNkI7SUFTdEMsWUFBbUIsUUFBbUIsRUFBUyxFQUFjO1FBQTFDLGFBQVEsR0FBUixRQUFRLENBQVc7UUFBUyxPQUFFLEdBQUYsRUFBRSxDQUFZO1FBUjdELG9CQUFlLEdBQUcsS0FBSyxDQUFDO1FBSXhCLHdCQUFtQixHQUFHLEtBQUssQ0FBQztRQUVOLGNBQVMsR0FBRywwQkFBMEIsQ0FBQztJQUVHLENBQUM7aUlBVHhELDZCQUE2QjtxSEFBN0IsNkJBQTZCLGlFQUdsQixlQUFlLHVFQUNmLGdCQUFnQjs7MkZBSjNCLDZCQUE2QjtrQkFIekMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsd0JBQXdCO2lCQUNyQzt1R0FJMEMsRUFBRTtzQkFBeEMsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUU7Z0JBRXJDLG1CQUFtQjtzQkFEbEIsS0FBSzt1QkFBQyxFQUFFLFNBQVMsRUFBRSxnQkFBZ0IsRUFBRTtnQkFHaEIsU0FBUztzQkFBOUIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0QmluZGluZywgSW5wdXQsIEVsZW1lbnRSZWYsIFJlbmRlcmVyMiwgYm9vbGVhbkF0dHJpYnV0ZSwgbnVtYmVyQXR0cmlidXRlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW2V1aW1DaGlwU2VsZWN0b3JJdGVtXScsXG59KVxuZXhwb3J0IGNsYXNzIEV1aW1DaGlwU2VsZWN0b3JJdGVtRGlyZWN0aXZlIHtcbiAgICBjbGlja0V2ZW50QWRkZWQgPSBmYWxzZTtcblxuICAgIEBJbnB1dCh7IHRyYW5zZm9ybTogbnVtYmVyQXR0cmlidXRlIH0pIGlkOiBudW1iZXI7XG4gICAgQElucHV0KHsgdHJhbnNmb3JtOiBib29sZWFuQXR0cmlidXRlIH0pXG4gICAgZXVpbUNoaXBTZWxlY3RvckFsbCA9IGZhbHNlO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpIGNsYXNzTmFtZSA9ICdldWltLWNoaXAtc2VsZWN0b3JfX2l0ZW0nO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIHJlbmRlcmVyOiBSZW5kZXJlcjIsIHB1YmxpYyBlbDogRWxlbWVudFJlZikge31cblxufVxuIl19
|
|
@@ -5,17 +5,15 @@ import * as i1 from "../base-states.directive";
|
|
|
5
5
|
import * as i2 from "@ionic/angular";
|
|
6
6
|
export class EuimMessageComponent {
|
|
7
7
|
get icon() {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
if (this.baseStatesDirective.color === 'info' || (this.baseStatesDirective.color !== 'warning' && this.baseStatesDirective.color !== 'danger' && this.baseStatesDirective.color !== 'success' && this.baseStatesDirective.color !== 'info')) {
|
|
18
|
-
return 'information-circle';
|
|
8
|
+
switch (this.baseStatesDirective.color) {
|
|
9
|
+
case 'warning':
|
|
10
|
+
return 'alert-circle';
|
|
11
|
+
case 'danger':
|
|
12
|
+
return 'close-circle';
|
|
13
|
+
case 'success':
|
|
14
|
+
return 'checkmark-circle';
|
|
15
|
+
default:
|
|
16
|
+
return 'information-circle';
|
|
19
17
|
}
|
|
20
18
|
}
|
|
21
19
|
get cssClasses() {
|
|
@@ -50,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
50
48
|
type: HostBinding,
|
|
51
49
|
args: ['class']
|
|
52
50
|
}] } });
|
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXVpbS1tZXNzYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9ldWltLW1lc3NhZ2UvZXVpbS1tZXNzYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9ldWltLW1lc3NhZ2UvZXVpbS1tZXNzYWdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsV0FBVyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25HLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBbUIvRCxNQUFNLE9BQU8sb0JBQW9CO0lBRTdCLElBQUksSUFBSTtRQUNKLFFBQVEsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssRUFBRTtZQUNwQyxLQUFLLFNBQVM7Z0JBQ1YsT0FBTyxjQUFjLENBQUM7WUFDMUIsS0FBSyxRQUFRO2dCQUNULE9BQU8sY0FBYyxDQUFDO1lBQzFCLEtBQUssU0FBUztnQkFDVixPQUFPLGtCQUFrQixDQUFDO1lBQzlCO2dCQUNJLE9BQU8sb0JBQW9CLENBQUM7U0FDbkM7SUFDTCxDQUFDO0lBRUQsSUFDVyxVQUFVO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxZQUFtQixtQkFBd0M7UUFBeEMsd0JBQW1CLEdBQW5CLG1CQUFtQixDQUFxQjtJQUFHLENBQUM7SUFFL0QsYUFBYTtRQUNULE9BQU87WUFDSCxJQUFJLENBQUMsbUJBQW1CLENBQUMsYUFBYSxDQUFDLGNBQWMsQ0FBQztZQUN0RCxJQUFJLENBQUMsbUJBQW1CLENBQUMsS0FBSyxLQUFLLFNBQVM7Z0JBQzVDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxLQUFLLEtBQUssUUFBUTtnQkFDM0MsSUFBSSxDQUFDLG1CQUFtQixDQUFDLEtBQUssS0FBSyxTQUFTO2dCQUM1QyxJQUFJLENBQUMsbUJBQW1CLENBQUMsS0FBSyxLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsQ0FBQyxDQUFDLEVBQUU7U0FDeEUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDaEIsQ0FBQztpSUE5QlEsb0JBQW9CO3FIQUFwQixvQkFBb0IsK0xDcEJqQyx3UUFPQTs7MkZEYWEsb0JBQW9CO2tCQWZoQyxTQUFTOytCQUNJLGNBQWMsbUJBR1AsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxrQkFDckI7d0JBQ1o7NEJBQ0ksU0FBUyxFQUFFLG1CQUFtQjs0QkFDOUIsTUFBTSxFQUFFO2dDQUNKLE9BQU87NkJBQ1Y7eUJBQ0o7cUJBQ0o7d0ZBa0JVLFVBQVU7c0JBRHBCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQmFzZVN0YXRlc0RpcmVjdGl2ZSB9IGZyb20gJy4uL2Jhc2Utc3RhdGVzLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB0eXBlIFZhcmlhbnRUeXBlcyA9ICdpbmZvJyB8ICdzdWNjZXNzJyB8ICd3YXJuaW5nJyB8ICdkYW5nZXInIHwgJ2FjY2VudCcgfCAncHJpbWFyeScgfCAnc2Vjb25kYXJ5JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdldWltLW1lc3NhZ2UnLFxuICAgIHN0eWxlVXJsczogWycuL3N0eWxlcy9faW5kZXguc2NzcyddLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9ldWltLW1lc3NhZ2UuY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgZGlyZWN0aXZlOiBCYXNlU3RhdGVzRGlyZWN0aXZlLFxuICAgICAgICAgICAgaW5wdXRzOiBbXG4gICAgICAgICAgICAgICAgJ2NvbG9yJyxcbiAgICAgICAgICAgIF0sXG4gICAgICAgIH0sXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgRXVpbU1lc3NhZ2VDb21wb25lbnQge1xuXG4gICAgZ2V0IGljb24oKTogc3RyaW5nIHtcbiAgICAgICAgc3dpdGNoICh0aGlzLmJhc2VTdGF0ZXNEaXJlY3RpdmUuY29sb3IpIHtcbiAgICAgICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxuICAgICAgICAgICAgICAgIHJldHVybiAnYWxlcnQtY2lyY2xlJztcbiAgICAgICAgICAgIGNhc2UgJ2Rhbmdlcic6XG4gICAgICAgICAgICAgICAgcmV0dXJuICdjbG9zZS1jaXJjbGUnO1xuICAgICAgICAgICAgY2FzZSAnc3VjY2Vzcyc6XG4gICAgICAgICAgICAgICAgcmV0dXJuICdjaGVja21hcmstY2lyY2xlJztcbiAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgcmV0dXJuICdpbmZvcm1hdGlvbi1jaXJjbGUnO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gICAgcHVibGljIGdldCBjc3NDbGFzc2VzKCk6IHN0cmluZyB7XG4gICAgICAgIHJldHVybiB0aGlzLmdldENzc0NsYXNzZXMoKTtcbiAgICB9XG5cbiAgICBjb25zdHJ1Y3RvcihwdWJsaWMgYmFzZVN0YXRlc0RpcmVjdGl2ZTogQmFzZVN0YXRlc0RpcmVjdGl2ZSkge31cblxuICAgIGdldENzc0NsYXNzZXMoKTogc3RyaW5nIHtcbiAgICAgICAgcmV0dXJuIFtcbiAgICAgICAgICAgIHRoaXMuYmFzZVN0YXRlc0RpcmVjdGl2ZS5nZXRDc3NDbGFzc2VzKCdldWltLW1lc3NhZ2UnKSxcbiAgICAgICAgICAgIHRoaXMuYmFzZVN0YXRlc0RpcmVjdGl2ZS5jb2xvciAhPT0gJ3dhcm5pbmcnICYmXG4gICAgICAgICAgICB0aGlzLmJhc2VTdGF0ZXNEaXJlY3RpdmUuY29sb3IgIT09ICdkYW5nZXInICYmXG4gICAgICAgICAgICB0aGlzLmJhc2VTdGF0ZXNEaXJlY3RpdmUuY29sb3IgIT09ICdzdWNjZXNzJyAmJlxuICAgICAgICAgICAgdGhpcy5iYXNlU3RhdGVzRGlyZWN0aXZlLmNvbG9yICE9PSAnaW5mbycgPyAnZXVpbS1tZXNzYWdlLS1pbmZvJyA6ICcnLFxuICAgICAgICBdLmpvaW4oJyAnKTtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiZXVpbS1tZXNzYWdlX193cmFwcGVyaWNvblwiPlxuICAgIDxpb24taWNvbiBbbmFtZV09XCJpY29uXCIgY2xhc3M9XCJldWltLW1lc3NhZ2VfX2ljb25cIj48L2lvbi1pY29uPlxuPC9kaXY+XG48ZGl2IGNsYXNzPVwiZXVpbS1tZXNzYWdlX193cmFwcGVyXCI+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwiZXVpbS1tZXNzYWdlLXRpdGxlXCI+PC9uZy1jb250ZW50PlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuIl19
|
package/esm2022/lib/components/layout/euim-language-selector/euim-language-list.component.mjs
CHANGED
|
@@ -72,7 +72,7 @@ export class EuimLanguageListComponent {
|
|
|
72
72
|
return language.label;
|
|
73
73
|
}
|
|
74
74
|
}
|
|
75
|
-
return;
|
|
75
|
+
return null;
|
|
76
76
|
}
|
|
77
77
|
onClose() {
|
|
78
78
|
return this.modalCtrl.dismiss(null, 'cancel');
|
|
@@ -80,10 +80,8 @@ export class EuimLanguageListComponent {
|
|
|
80
80
|
handleChange(event) {
|
|
81
81
|
const query = event.target.value.toLowerCase();
|
|
82
82
|
this.results = this.languagesSortedByEUAndNonEU.filter(d => {
|
|
83
|
-
|
|
84
|
-
d.label.toLowerCase().indexOf(query) > -1
|
|
85
|
-
return d;
|
|
86
|
-
}
|
|
83
|
+
return d.code.toLowerCase().indexOf(query) > -1 ||
|
|
84
|
+
d.label.toLowerCase().indexOf(query) > -1;
|
|
87
85
|
});
|
|
88
86
|
}
|
|
89
87
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimLanguageListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TranslateService }, { token: i2.EuiAppShellService }, { token: i3.EuimAppService }, { token: i4.ModalController }, { token: i4.Platform }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -93,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
93
91
|
type: Component,
|
|
94
92
|
args: [{ selector: 'euim-language-list', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ion-header>\n <ion-toolbar color=\"primary\">\n <ion-buttons slot=\"start\">\n <ion-button (click)=\"onClose()\">\n <ion-icon name=\"close-sharp\" 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 <ion-toolbar color=\"primary\" class=\"euim-language-selector__search\">\n <ion-searchbar (ionChange)=\"handleChange($event)\"></ion-searchbar>\n </ion-toolbar>\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\n || firstElementFromNonEUList?.code === item.code) {\n <ion-item-divider>\n {{ (firstElementFromEUList?.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 ? 'none' : 'inset'\">\n <euim-avatar-icon fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n <ion-icon name=\"language-sharp\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n </euim-avatar-icon>\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-sharp\" 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" }]
|
|
95
93
|
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.TranslateService }, { type: i2.EuiAppShellService }, { type: i3.EuimAppService }, { type: i4.ModalController }, { type: i4.Platform }] });
|
|
96
|
-
//# 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 { ChangeDetectorRef, Component, OnDestroy, OnInit, ChangeDetectionStrategy } from '@angular/core';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage } from '@eui/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { distinctUntilKeyChanged, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { EuimAppService } from '../../../services';\nimport { ModalController, Platform } from '@ionic/angular';\n\n@Component({\n    selector: 'euim-language-list',\n    templateUrl: 'euim-language-list.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EuimLanguageListComponent implements OnInit, OnDestroy {\n\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n    name: string;\n    languagesSortedByEUAndNonEU: EuiLanguage[];\n    firstElementFromNonEUList: EuiLanguage;\n    firstElementFromEUList: EuiLanguage;\n    lastElementFromEUList: EuiLanguage;\n    euLanguageList: EuiLanguage[];\n    nonEULanguageList: EuiLanguage[];\n    results: EuiLanguage[];\n\n    isKeyboardShown : boolean;\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        private translateService: TranslateService,\n        public appShellService: EuiAppShellService,\n        public appService: EuimAppService,\n        private modalCtrl: ModalController,\n        private platform: Platform,\n    ) {\n        this.platform.keyboardDidShow.subscribe((): void => {\n            this.isKeyboardShown = true;\n        });\n\n        this.platform.keyboardDidHide.subscribe((): void => {\n            this.isKeyboardShown = false;\n        });\n\n    }\n\n    ngOnInit(): void {\n\n        this.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('languages'),\n        ).subscribe((state) => {\n\n            this.languages = (state.languages) ?\n                EuiEuLanguages.getOrderedLanguages(state.languages) :\n                EuiEuLanguages.getLanguages();\n\n            this.euLanguageList =\n                EuiEuLanguages.getOrderedLanguages(\n                    EuiEuLanguages.filterEULanguages(this.languages));\n\n            this.firstElementFromEUList = this.euLanguageList[0];\n            this.lastElementFromEUList = this.euLanguageList[this.euLanguageList?.length - 1];\n\n            this.nonEULanguageList =\n                [...EuiEuLanguages.getOrderedLanguages(\n                    EuiEuLanguages.filterNonEULanguages(this.languages))];\n\n            this.firstElementFromNonEUList = this.nonEULanguageList[0];\n\n            this.languagesSortedByEUAndNonEU = [...this.euLanguageList, ...this.nonEULanguageList];\n\n            this.results = [...this.languagesSortedByEUAndNonEU];\n\n            this.cd.detectChanges();\n\n        });\n\n        this.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('activeLanguage'),\n        ).subscribe((state) => {\n            this.selectedLanguage = {\n                code: state.activeLanguage,\n                label: this.getLanguageLabel(state.activeLanguage),\n            };\n            this.cd.detectChanges();\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onLanguageSelected(language: EuiLanguage): void {\n        this.translateService.use(language.code);\n        // this.appService.isLanguageListVisible = false;\n\n        this.appShellService.setState({\n            ...this.appShellService.state,\n            activeLanguage: language.code,\n        });\n\n        this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    onLanguageListClose(): void {\n        this.appService.isLanguageListVisible = false;\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;\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\n            if (d.code.toLowerCase().indexOf(query) > -1 ||\n                d.label.toLowerCase().indexOf(query) > -1 ) {\n\n               return d;\n           }\n        });\n    }\n\n}\n","<ion-header>\n  <ion-toolbar color=\"primary\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onClose()\">\n        <ion-icon name=\"close-sharp\" 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  <ion-toolbar color=\"primary\" class=\"euim-language-selector__search\">\n    <ion-searchbar (ionChange)=\"handleChange($event)\"></ion-searchbar>\n  </ion-toolbar>\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\n          || firstElementFromNonEUList?.code === item.code) {\n          <ion-item-divider>\n            {{ (firstElementFromEUList?.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 ? 'none' : 'inset'\">\n          <euim-avatar-icon  fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n            <ion-icon name=\"language-sharp\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n          </euim-avatar-icon>\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-sharp\" 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"]}
|
|
94
|
+
//# 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 { ChangeDetectorRef, Component, OnDestroy, OnInit, ChangeDetectionStrategy } from '@angular/core';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage } from '@eui/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { distinctUntilKeyChanged, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { EuimAppService } from '../../../services';\nimport { ModalController, Platform } from '@ionic/angular';\n\n@Component({\n    selector: 'euim-language-list',\n    templateUrl: 'euim-language-list.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class EuimLanguageListComponent implements OnInit, OnDestroy {\n\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n    name: string;\n    languagesSortedByEUAndNonEU: EuiLanguage[];\n    firstElementFromNonEUList: EuiLanguage;\n    firstElementFromEUList: EuiLanguage;\n    lastElementFromEUList: EuiLanguage;\n    euLanguageList: EuiLanguage[];\n    nonEULanguageList: EuiLanguage[];\n    results: EuiLanguage[];\n\n    isKeyboardShown : boolean;\n\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        private translateService: TranslateService,\n        public appShellService: EuiAppShellService,\n        public appService: EuimAppService,\n        private modalCtrl: ModalController,\n        private platform: Platform,\n    ) {\n        this.platform.keyboardDidShow.subscribe((): void => {\n            this.isKeyboardShown = true;\n        });\n\n        this.platform.keyboardDidHide.subscribe((): void => {\n            this.isKeyboardShown = false;\n        });\n\n    }\n\n    ngOnInit(): void {\n\n        this.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('languages'),\n        ).subscribe((state) => {\n\n            this.languages = (state.languages) ?\n                EuiEuLanguages.getOrderedLanguages(state.languages) :\n                EuiEuLanguages.getLanguages();\n\n            this.euLanguageList =\n                EuiEuLanguages.getOrderedLanguages(\n                    EuiEuLanguages.filterEULanguages(this.languages));\n\n            this.firstElementFromEUList = this.euLanguageList[0];\n            this.lastElementFromEUList = this.euLanguageList[this.euLanguageList?.length - 1];\n\n            this.nonEULanguageList =\n                [...EuiEuLanguages.getOrderedLanguages(\n                    EuiEuLanguages.filterNonEULanguages(this.languages))];\n\n            this.firstElementFromNonEUList = this.nonEULanguageList[0];\n\n            this.languagesSortedByEUAndNonEU = [...this.euLanguageList, ...this.nonEULanguageList];\n\n            this.results = [...this.languagesSortedByEUAndNonEU];\n\n            this.cd.detectChanges();\n\n        });\n\n        this.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('activeLanguage'),\n        ).subscribe((state) => {\n            this.selectedLanguage = {\n                code: state.activeLanguage,\n                label: this.getLanguageLabel(state.activeLanguage),\n            };\n            this.cd.detectChanges();\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    onLanguageSelected(language: EuiLanguage): void {\n        this.translateService.use(language.code);\n        // this.appService.isLanguageListVisible = false;\n\n        this.appShellService.setState({\n            ...this.appShellService.state,\n            activeLanguage: language.code,\n        });\n\n        this.modalCtrl.dismiss(null, 'cancel');\n    }\n\n    onLanguageListClose(): void {\n        this.appService.isLanguageListVisible = false;\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    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=\"primary\">\n    <ion-buttons slot=\"start\">\n      <ion-button (click)=\"onClose()\">\n        <ion-icon name=\"close-sharp\" 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  <ion-toolbar color=\"primary\" class=\"euim-language-selector__search\">\n    <ion-searchbar (ionChange)=\"handleChange($event)\"></ion-searchbar>\n  </ion-toolbar>\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\n          || firstElementFromNonEUList?.code === item.code) {\n          <ion-item-divider>\n            {{ (firstElementFromEUList?.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 ? 'none' : 'inset'\">\n          <euim-avatar-icon  fill=\"solid\" slot=\"start\" variant=\"rounded\" class=\"euim-language-selector__avatar\">\n            <ion-icon name=\"language-sharp\" class=\"euim-language-selector__internal-icon\"></ion-icon>\n          </euim-avatar-icon>\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-sharp\" 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
|
@@ -55,7 +55,7 @@ export class EuimLanguageSelectorComponent {
|
|
|
55
55
|
return language.label;
|
|
56
56
|
}
|
|
57
57
|
}
|
|
58
|
-
return;
|
|
58
|
+
return null;
|
|
59
59
|
}
|
|
60
60
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimLanguageSelectorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.TranslateService }, { token: i2.EuiAppShellService }, { token: i3.EuimAppService }, { token: i4.ModalController }, { token: i5.BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
61
|
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: EuimLanguageSelectorComponent, selector: "euim-language-selector", host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: i5.BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ion-button (click)=\"onShowLanguageList()\">\n <ion-icon class=\"euim-language-selector__icon {{_euimPrimary ? 'euim-language-selector__icon--primary' : ''}}\"\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 {{_euimPrimary ? 'euim-language-selector__text--primary' : ''}}\">\n {{ selectedLanguage?.code?.toUpperCase() }}\n </span>\n</ion-button>\n", styles: [".euim-language-selector__text{font:normal normal 400 .75rem/1rem var(--eui-base-font-family);font-weight:700;margin-bottom:var(--eui-base-spacing-2xs);position:absolute;color:var(--eui-base-color-primary-100)}.euim-language-selector__text--primary,.euim-language-selector__icon{color:#fff}.euim-language-selector__icon--primary{color:var(--eui-base-color-primary-100)}.euim-language-selector__avatar{background-color:var(--eui-base-color-grey-15)}.euim-language-selector__internal-icon{color:var(--eui-base-color-grey-100)}.euim-language-selector__search{display:contents}.euim-language-selector__empty-placeholder{display:block;height:auto;margin-top:calc(9 * var(--eui-base-spacing-m))}\n"], dependencies: [{ kind: "component", type: i4.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: i4.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
@@ -74,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
74
74
|
type: HostBinding,
|
|
75
75
|
args: ['class']
|
|
76
76
|
}] } });
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# 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, ChangeDetectionStrategy, Component, HostBinding, Input, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';\nimport { EuiAppShellService, EuiEuLanguages, EuiLanguage } from '@eui/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { distinctUntilKeyChanged, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { EuimAppService } from '../../../services';\nimport { ModalController } from '@ionic/angular';\nimport { EuimLanguageListComponent } from './euim-language-list.component';\nimport { BaseStatesDirective } from '../../base-states.directive';\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})\nexport class EuimLanguageSelectorComponent implements OnInit, OnDestroy {\n\n    _euimPrimary = this.baseStatesDirective.color === 'primary';\n    languages: EuiLanguage[];\n    selectedLanguage: EuiLanguage;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n\n    constructor(\n        private cd: ChangeDetectorRef,\n        private translateService: TranslateService,\n        public appShellService: EuiAppShellService,\n        public appService: EuimAppService,\n        private modalCtrl: ModalController,\n        public baseStatesDirective: BaseStatesDirective,\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.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('languages'),\n        ).subscribe((state) => {\n            this.languages = (state.languages) ?\n                EuiEuLanguages.getOrderedLanguages(state.languages) :\n                EuiEuLanguages.getLanguages();\n            this.cd.detectChanges();\n        });\n\n        this.appShellService.state$.pipe(\n            takeUntil(this.destroy$),\n            distinctUntilKeyChanged('activeLanguage'),\n        ).subscribe((state) => {\n            this.selectedLanguage = {\n                code: state.activeLanguage,\n                label: this.getLanguageLabel(state.activeLanguage),\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        });\n        await modal.present();\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()\">\n    <ion-icon class=\"euim-language-selector__icon {{_euimPrimary ? 'euim-language-selector__icon--primary' : ''}}\"\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 {{_euimPrimary ? 'euim-language-selector__text--primary' : ''}}\">\n        {{ selectedLanguage?.code?.toUpperCase() }}\n    </span>\n</ion-button>\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
export * from '@eui/base';
|
|
2
2
|
import * as i0 from '@angular/core';
|
|
3
|
-
import { Injectable, booleanAttribute, Directive, Input, Component, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, NgModule, EventEmitter, Output, ContentChildren, ViewChild, HostListener, ContentChild } from '@angular/core';
|
|
3
|
+
import { Injectable, booleanAttribute, Directive, Input, Component, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, NgModule, EventEmitter, Output, ContentChildren, ViewChild, HostListener, numberAttribute, ContentChild } from '@angular/core';
|
|
4
4
|
import { BehaviorSubject, Subject, throwError } from 'rxjs';
|
|
5
5
|
import * as i2$1 from '@angular/common';
|
|
6
6
|
import { CommonModule } from '@angular/common';
|
|
@@ -503,7 +503,7 @@ class EuimLanguageListComponent {
|
|
|
503
503
|
return language.label;
|
|
504
504
|
}
|
|
505
505
|
}
|
|
506
|
-
return;
|
|
506
|
+
return null;
|
|
507
507
|
}
|
|
508
508
|
onClose() {
|
|
509
509
|
return this.modalCtrl.dismiss(null, 'cancel');
|
|
@@ -511,10 +511,8 @@ class EuimLanguageListComponent {
|
|
|
511
511
|
handleChange(event) {
|
|
512
512
|
const query = event.target.value.toLowerCase();
|
|
513
513
|
this.results = this.languagesSortedByEUAndNonEU.filter(d => {
|
|
514
|
-
|
|
515
|
-
d.label.toLowerCase().indexOf(query) > -1
|
|
516
|
-
return d;
|
|
517
|
-
}
|
|
514
|
+
return d.code.toLowerCase().indexOf(query) > -1 ||
|
|
515
|
+
d.label.toLowerCase().indexOf(query) > -1;
|
|
518
516
|
});
|
|
519
517
|
}
|
|
520
518
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimLanguageListComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1$1.TranslateService }, { token: i2.EuiAppShellService }, { token: EuimAppService }, { token: i1.ModalController }, { token: i1.Platform }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
@@ -570,7 +568,7 @@ class EuimLanguageSelectorComponent {
|
|
|
570
568
|
return language.label;
|
|
571
569
|
}
|
|
572
570
|
}
|
|
573
|
-
return;
|
|
571
|
+
return null;
|
|
574
572
|
}
|
|
575
573
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimLanguageSelectorComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1$1.TranslateService }, { token: i2.EuiAppShellService }, { token: EuimAppService }, { token: i1.ModalController }, { token: BaseStatesDirective }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
576
574
|
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.7", type: EuimLanguageSelectorComponent, selector: "euim-language-selector", host: { properties: { "class": "this.cssClasses" } }, hostDirectives: [{ directive: BaseStatesDirective, inputs: ["color", "color"] }], ngImport: i0, template: "<ion-button (click)=\"onShowLanguageList()\">\n <ion-icon class=\"euim-language-selector__icon {{_euimPrimary ? 'euim-language-selector__icon--primary' : ''}}\"\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 {{_euimPrimary ? 'euim-language-selector__text--primary' : ''}}\">\n {{ selectedLanguage?.code?.toUpperCase() }}\n </span>\n</ion-button>\n", styles: [".euim-language-selector__text{font:normal normal 400 .75rem/1rem var(--eui-base-font-family);font-weight:700;margin-bottom:var(--eui-base-spacing-2xs);position:absolute;color:var(--eui-base-color-primary-100)}.euim-language-selector__text--primary,.euim-language-selector__icon{color:#fff}.euim-language-selector__icon--primary{color:var(--eui-base-color-primary-100)}.euim-language-selector__avatar{background-color:var(--eui-base-color-grey-15)}.euim-language-selector__internal-icon{color:var(--eui-base-color-grey-100)}.euim-language-selector__search{display:contents}.euim-language-selector__empty-placeholder{display:block;height:auto;margin-top:calc(9 * var(--eui-base-spacing-m))}\n"], dependencies: [{ kind: "component", type: i1.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: i1.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
@@ -1223,17 +1221,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
1223
1221
|
|
|
1224
1222
|
class EuimMessageComponent {
|
|
1225
1223
|
get icon() {
|
|
1226
|
-
|
|
1227
|
-
|
|
1228
|
-
|
|
1229
|
-
|
|
1230
|
-
|
|
1231
|
-
|
|
1232
|
-
|
|
1233
|
-
|
|
1234
|
-
|
|
1235
|
-
if (this.baseStatesDirective.color === 'info' || (this.baseStatesDirective.color !== 'warning' && this.baseStatesDirective.color !== 'danger' && this.baseStatesDirective.color !== 'success' && this.baseStatesDirective.color !== 'info')) {
|
|
1236
|
-
return 'information-circle';
|
|
1224
|
+
switch (this.baseStatesDirective.color) {
|
|
1225
|
+
case 'warning':
|
|
1226
|
+
return 'alert-circle';
|
|
1227
|
+
case 'danger':
|
|
1228
|
+
return 'close-circle';
|
|
1229
|
+
case 'success':
|
|
1230
|
+
return 'checkmark-circle';
|
|
1231
|
+
default:
|
|
1232
|
+
return 'information-circle';
|
|
1237
1233
|
}
|
|
1238
1234
|
}
|
|
1239
1235
|
get cssClasses() {
|
|
@@ -2215,7 +2211,7 @@ class EuimChipSelectorItemDirective {
|
|
|
2215
2211
|
this.className = 'euim-chip-selector__item';
|
|
2216
2212
|
}
|
|
2217
2213
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimChipSelectorItemDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
2218
|
-
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.7", type: EuimChipSelectorItemDirective, selector: "[euimChipSelectorItem]", inputs: { id: "id", euimChipSelectorAll: ["euimChipSelectorAll", "euimChipSelectorAll", booleanAttribute] }, host: { properties: { "class": "this.className" } }, ngImport: i0 }); }
|
|
2214
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "17.3.7", type: EuimChipSelectorItemDirective, selector: "[euimChipSelectorItem]", inputs: { id: ["id", "id", numberAttribute], euimChipSelectorAll: ["euimChipSelectorAll", "euimChipSelectorAll", booleanAttribute] }, host: { properties: { "class": "this.className" } }, ngImport: i0 }); }
|
|
2219
2215
|
}
|
|
2220
2216
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: EuimChipSelectorItemDirective, decorators: [{
|
|
2221
2217
|
type: Directive,
|
|
@@ -2223,7 +2219,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImpor
|
|
|
2223
2219
|
selector: '[euimChipSelectorItem]',
|
|
2224
2220
|
}]
|
|
2225
2221
|
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.ElementRef }], propDecorators: { id: [{
|
|
2226
|
-
type: Input
|
|
2222
|
+
type: Input,
|
|
2223
|
+
args: [{ transform: numberAttribute }]
|
|
2227
2224
|
}], euimChipSelectorAll: [{
|
|
2228
2225
|
type: Input,
|
|
2229
2226
|
args: [{ transform: booleanAttribute }]
|
|
@@ -3332,26 +3329,22 @@ class EuimHelpSupportComponent {
|
|
|
3332
3329
|
return this.isLinkSharp(item) ? 'euim-help-support__contact-link euim-help-support__contact-link--no-underlined' : 'euim-help-support__contact-link';
|
|
3333
3330
|
}
|
|
3334
3331
|
getLink(item, linkType, linkTitle) {
|
|
3335
|
-
if (linkTitle && linkType === 'mail') {
|
|
3336
|
-
return 'mailto:' + linkTitle;
|
|
3337
|
-
}
|
|
3338
|
-
if (linkTitle && linkType === 'call') {
|
|
3339
|
-
return 'tel:' + linkTitle;
|
|
3340
|
-
}
|
|
3341
3332
|
if (linkTitle) {
|
|
3333
|
+
if (linkType === 'mail')
|
|
3334
|
+
return 'mailto:' + linkTitle;
|
|
3335
|
+
if (linkType === 'call')
|
|
3336
|
+
return 'tel:' + linkTitle;
|
|
3342
3337
|
return linkTitle;
|
|
3343
3338
|
}
|
|
3344
3339
|
if (item) {
|
|
3345
|
-
if (item.phone)
|
|
3340
|
+
if (item.phone)
|
|
3346
3341
|
return 'tel:' + item.phone;
|
|
3347
|
-
|
|
3348
|
-
if (item.mail) {
|
|
3342
|
+
if (item.mail)
|
|
3349
3343
|
return 'mailto:' + item.mail;
|
|
3350
|
-
|
|
3351
|
-
if (item.link) {
|
|
3344
|
+
if (item.link)
|
|
3352
3345
|
return item.link;
|
|
3353
|
-
}
|
|
3354
3346
|
}
|
|
3347
|
+
return null;
|
|
3355
3348
|
}
|
|
3356
3349
|
setTargetAttribute(item, linkType) {
|
|
3357
3350
|
if (item?.phone || item?.mail || linkType === 'call' || linkType === 'mail') {
|