valtech-components 2.0.717 → 2.0.719
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/molecules/links-accordion/links-accordion.component.mjs +67 -49
- package/esm2022/lib/services/auth/auth.service.mjs +34 -4
- package/esm2022/lib/services/i18n/default-content.mjs +7 -1
- package/esm2022/lib/version.mjs +2 -2
- package/fesm2022/valtech-components.mjs +295 -242
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/services/auth/auth.service.d.ts +24 -2
- package/lib/version.d.ts +1 -1
- package/package.json +1 -1
|
@@ -96,39 +96,48 @@ export class LinksAccordionComponent {
|
|
|
96
96
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: LinksAccordionComponent, isStandalone: true, selector: "val-links-accordion", inputs: { props: "props" }, outputs: { navigate: "navigate" }, viewQueries: [{ propertyName: "accordionGroup", first: true, predicate: ["accordionGroup"], descendants: true }], ngImport: i0, template: `
|
|
97
97
|
<div class="links-accordion">
|
|
98
98
|
<ion-accordion-group #accordionGroup>
|
|
99
|
-
<
|
|
100
|
-
|
|
101
|
-
[value]="getSectionValue(section, i)"
|
|
102
|
-
[toggleIcon]="section.links?.length ? 'chevron-down-outline' : ''"
|
|
103
|
-
[readonly]="!section.links?.length"
|
|
104
|
-
>
|
|
99
|
+
<ng-container *ngFor="let section of props.sections; let i = index">
|
|
100
|
+
<!-- Direct-link section: route + no children -->
|
|
105
101
|
<ion-item
|
|
106
|
-
|
|
102
|
+
*ngIf="section.route && !section.links?.length"
|
|
103
|
+
class="direct-link"
|
|
107
104
|
color="light"
|
|
108
105
|
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
109
|
-
(click)="
|
|
110
|
-
|
|
106
|
+
(click)="onLinkClick(section.route!, $event)"
|
|
107
|
+
button
|
|
111
108
|
lines="none"
|
|
112
109
|
>
|
|
113
110
|
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
114
111
|
</ion-item>
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
112
|
+
|
|
113
|
+
<!-- Accordion section: has children -->
|
|
114
|
+
<ion-accordion
|
|
118
115
|
*ngIf="section.links?.length"
|
|
116
|
+
[value]="getSectionValue(section, i)"
|
|
117
|
+
toggleIcon="chevron-down-outline"
|
|
119
118
|
>
|
|
120
|
-
<ion-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
>
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
119
|
+
<ion-item
|
|
120
|
+
slot="header"
|
|
121
|
+
color="light"
|
|
122
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
123
|
+
lines="none"
|
|
124
|
+
>
|
|
125
|
+
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
126
|
+
</ion-item>
|
|
127
|
+
<div slot="content" [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }">
|
|
128
|
+
<ion-list lines="none">
|
|
129
|
+
<ion-item
|
|
130
|
+
*ngFor="let link of section.links"
|
|
131
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
132
|
+
(click)="onLinkClick(link.route, $event)"
|
|
133
|
+
button
|
|
134
|
+
>
|
|
135
|
+
<ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
|
|
136
|
+
</ion-item>
|
|
137
|
+
</ion-list>
|
|
138
|
+
</div>
|
|
139
|
+
</ion-accordion>
|
|
140
|
+
</ng-container>
|
|
132
141
|
</ion-accordion-group>
|
|
133
142
|
</div>
|
|
134
143
|
`, isInline: true, styles: [".links-accordion .accordion-label{font-size:1.3rem}.links-accordion .accordion-item-label{font-size:1.1rem}.links-accordion ion-item{--background: var(--ion-color-light-tint)}.links-accordion ion-accordion{background:transparent}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: IonAccordionGroup, selector: "ion-accordion-group", inputs: ["animated", "disabled", "expand", "mode", "multiple", "readonly", "value"] }, { kind: "component", type: IonAccordion, selector: "ion-accordion", inputs: ["disabled", "mode", "readonly", "toggleIcon", "toggleIconSlot", "value"] }, { kind: "component", type: IonItem, selector: "ion-item", inputs: ["button", "color", "detail", "detailIcon", "disabled", "download", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "target", "type"] }, { kind: "component", type: IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "component", type: IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }] }); }
|
|
@@ -138,39 +147,48 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
138
147
|
args: [{ selector: 'val-links-accordion', standalone: true, imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList], template: `
|
|
139
148
|
<div class="links-accordion">
|
|
140
149
|
<ion-accordion-group #accordionGroup>
|
|
141
|
-
<
|
|
142
|
-
|
|
143
|
-
[value]="getSectionValue(section, i)"
|
|
144
|
-
[toggleIcon]="section.links?.length ? 'chevron-down-outline' : ''"
|
|
145
|
-
[readonly]="!section.links?.length"
|
|
146
|
-
>
|
|
150
|
+
<ng-container *ngFor="let section of props.sections; let i = index">
|
|
151
|
+
<!-- Direct-link section: route + no children -->
|
|
147
152
|
<ion-item
|
|
148
|
-
|
|
153
|
+
*ngIf="section.route && !section.links?.length"
|
|
154
|
+
class="direct-link"
|
|
149
155
|
color="light"
|
|
150
156
|
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
151
|
-
(click)="
|
|
152
|
-
|
|
157
|
+
(click)="onLinkClick(section.route!, $event)"
|
|
158
|
+
button
|
|
153
159
|
lines="none"
|
|
154
160
|
>
|
|
155
161
|
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
156
162
|
</ion-item>
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
163
|
+
|
|
164
|
+
<!-- Accordion section: has children -->
|
|
165
|
+
<ion-accordion
|
|
160
166
|
*ngIf="section.links?.length"
|
|
167
|
+
[value]="getSectionValue(section, i)"
|
|
168
|
+
toggleIcon="chevron-down-outline"
|
|
161
169
|
>
|
|
162
|
-
<ion-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
>
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
170
|
+
<ion-item
|
|
171
|
+
slot="header"
|
|
172
|
+
color="light"
|
|
173
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
174
|
+
lines="none"
|
|
175
|
+
>
|
|
176
|
+
<ion-label class="accordion-label">{{ getSectionTitle(section) }}</ion-label>
|
|
177
|
+
</ion-item>
|
|
178
|
+
<div slot="content" [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }">
|
|
179
|
+
<ion-list lines="none">
|
|
180
|
+
<ion-item
|
|
181
|
+
*ngFor="let link of section.links"
|
|
182
|
+
[ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
|
|
183
|
+
(click)="onLinkClick(link.route, $event)"
|
|
184
|
+
button
|
|
185
|
+
>
|
|
186
|
+
<ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
|
|
187
|
+
</ion-item>
|
|
188
|
+
</ion-list>
|
|
189
|
+
</div>
|
|
190
|
+
</ion-accordion>
|
|
191
|
+
</ng-container>
|
|
174
192
|
</ion-accordion-group>
|
|
175
193
|
</div>
|
|
176
194
|
`, styles: [".links-accordion .accordion-label{font-size:1.3rem}.links-accordion .accordion-item-label{font-size:1.1rem}.links-accordion ion-item{--background: var(--ion-color-light-tint)}.links-accordion ion-accordion{background:transparent}\n"] }]
|
|
@@ -182,4 +200,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
182
200
|
type: ViewChild,
|
|
183
201
|
args: ['accordionGroup']
|
|
184
202
|
}] } });
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"links-accordion.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/links-accordion/links-accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonAccordion, IonAccordionGroup, IonItem, IonLabel, IonList, MenuController } from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport { LinksAccordionLink, LinksAccordionMetadata, LinksAccordionSection } from './types';\n\n/**\n * val-links-accordion\n *\n * A hierarchical navigation component using Ionic accordions.\n * Supports sections with optional sub-links and automatic menu closing.\n *\n * @example\n * <val-links-accordion\n *   [props]=\"{\n *     sections: [\n *       { title: 'Home', route: ['/'] },\n *       { title: 'Products', links: [\n *         { text: 'Catalog', route: ['/products'] },\n *         { text: 'New Arrivals', route: ['/products', 'new'] }\n *       ]}\n *     ]\n *   }\"\n *   (navigate)=\"onNavigate($event)\"\n * ></val-links-accordion>\n *\n * @input props - Accordion configuration\n * @output navigate - Emits route when a link is clicked\n */\n@Component({\n  selector: 'val-links-accordion',\n  standalone: true,\n  imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList],\n  template: `\n    <div class=\"links-accordion\">\n      <ion-accordion-group #accordionGroup>\n        <ion-accordion\n          *ngFor=\"let section of props.sections; let i = index\"\n          [value]=\"getSectionValue(section, i)\"\n          [toggleIcon]=\"section.links?.length ? 'chevron-down-outline' : ''\"\n          [readonly]=\"!section.links?.length\"\n        >\n          <ion-item\n            slot=\"header\"\n            color=\"light\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            (click)=\"section.route ? onLinkClick(section.route, $event) : null\"\n            [button]=\"!!section.route\"\n            lines=\"none\"\n          >\n            <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n          </ion-item>\n          <div\n            slot=\"content\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            *ngIf=\"section.links?.length\"\n          >\n            <ion-list lines=\"none\">\n              <ion-item\n                *ngFor=\"let link of section.links\"\n                [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n                (click)=\"onLinkClick(link.route, $event)\"\n                button\n              >\n                <ion-label class=\"accordion-item-label\">{{ getLinkText(link) }}</ion-label>\n              </ion-item>\n            </ion-list>\n          </div>\n        </ion-accordion>\n      </ion-accordion-group>\n    </div>\n  `,\n  styleUrls: ['./links-accordion.component.scss'],\n})\nexport class LinksAccordionComponent {\n  private i18n = inject(I18nService);\n\n  /**\n   * Accordion configuration.\n   */\n  @Input() props: LinksAccordionMetadata = {\n    sections: [],\n    backgroundColor: 'var(--ion-background-color)',\n    closeMenuOnClick: true,\n    closeAccordionOnClick: true,\n  };\n\n  /**\n   * Emits the route when a link is clicked.\n   */\n  @Output() navigate = new EventEmitter<string[]>();\n\n  @ViewChild('accordionGroup') accordionGroup!: IonAccordionGroup;\n\n  constructor(\n    private router: Router,\n    private menuCtrl: MenuController\n  ) {}\n\n  /**\n   * Gets a unique value for the accordion section.\n   */\n  getSectionValue(section: LinksAccordionSection, index: number): string {\n    return section.titleKey || section.title || `section-${index}`;\n  }\n\n  /**\n   * Gets the section title, supporting i18n via titleKey.\n   */\n  getSectionTitle(section: LinksAccordionSection): string {\n    if (section.titleKey && this.props.i18nNamespace) {\n      return this.i18n.t(section.titleKey, this.props.i18nNamespace);\n    }\n    return section.title || '';\n  }\n\n  /**\n   * Gets the link text, supporting i18n via textKey.\n   */\n  getLinkText(link: LinksAccordionLink): string {\n    if (link.textKey && this.props.i18nNamespace) {\n      return this.i18n.t(link.textKey, this.props.i18nNamespace);\n    }\n    return link.text || '';\n  }\n\n  /**\n   * Handles link click - closes accordion/menu and navigates.\n   */\n  async onLinkClick(route: string[], event?: Event): Promise<void> {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    // Close accordion before navigating\n    if (this.props.closeAccordionOnClick !== false && this.accordionGroup) {\n      this.accordionGroup.value = undefined;\n    }\n\n    // Close menu if enabled\n    if (this.props.closeMenuOnClick !== false) {\n      await this.menuCtrl.close();\n    }\n\n    // Emit event\n    this.navigate.emit(route);\n\n    // Navigate\n    this.router.navigate(route);\n  }\n}\n"]}
|
|
203
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"links-accordion.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/links-accordion/links-accordion.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonAccordion, IonAccordionGroup, IonItem, IonLabel, IonList, MenuController } from '@ionic/angular/standalone';\nimport { I18nService } from '../../../services/i18n';\nimport { LinksAccordionLink, LinksAccordionMetadata, LinksAccordionSection } from './types';\n\n/**\n * val-links-accordion\n *\n * A hierarchical navigation component using Ionic accordions.\n * Supports sections with optional sub-links and automatic menu closing.\n *\n * @example\n * <val-links-accordion\n *   [props]=\"{\n *     sections: [\n *       { title: 'Home', route: ['/'] },\n *       { title: 'Products', links: [\n *         { text: 'Catalog', route: ['/products'] },\n *         { text: 'New Arrivals', route: ['/products', 'new'] }\n *       ]}\n *     ]\n *   }\"\n *   (navigate)=\"onNavigate($event)\"\n * ></val-links-accordion>\n *\n * @input props - Accordion configuration\n * @output navigate - Emits route when a link is clicked\n */\n@Component({\n  selector: 'val-links-accordion',\n  standalone: true,\n  imports: [CommonModule, IonAccordionGroup, IonAccordion, IonItem, IonLabel, IonList],\n  template: `\n    <div class=\"links-accordion\">\n      <ion-accordion-group #accordionGroup>\n        <ng-container *ngFor=\"let section of props.sections; let i = index\">\n          <!-- Direct-link section: route + no children -->\n          <ion-item\n            *ngIf=\"section.route && !section.links?.length\"\n            class=\"direct-link\"\n            color=\"light\"\n            [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n            (click)=\"onLinkClick(section.route!, $event)\"\n            button\n            lines=\"none\"\n          >\n            <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n          </ion-item>\n\n          <!-- Accordion section: has children -->\n          <ion-accordion\n            *ngIf=\"section.links?.length\"\n            [value]=\"getSectionValue(section, i)\"\n            toggleIcon=\"chevron-down-outline\"\n          >\n            <ion-item\n              slot=\"header\"\n              color=\"light\"\n              [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n              lines=\"none\"\n            >\n              <ion-label class=\"accordion-label\">{{ getSectionTitle(section) }}</ion-label>\n            </ion-item>\n            <div slot=\"content\" [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\">\n              <ion-list lines=\"none\">\n                <ion-item\n                  *ngFor=\"let link of section.links\"\n                  [ngStyle]=\"{ background: props.backgroundColor || 'var(--ion-background-color)' }\"\n                  (click)=\"onLinkClick(link.route, $event)\"\n                  button\n                >\n                  <ion-label class=\"accordion-item-label\">{{ getLinkText(link) }}</ion-label>\n                </ion-item>\n              </ion-list>\n            </div>\n          </ion-accordion>\n        </ng-container>\n      </ion-accordion-group>\n    </div>\n  `,\n  styleUrls: ['./links-accordion.component.scss'],\n})\nexport class LinksAccordionComponent {\n  private i18n = inject(I18nService);\n\n  /**\n   * Accordion configuration.\n   */\n  @Input() props: LinksAccordionMetadata = {\n    sections: [],\n    backgroundColor: 'var(--ion-background-color)',\n    closeMenuOnClick: true,\n    closeAccordionOnClick: true,\n  };\n\n  /**\n   * Emits the route when a link is clicked.\n   */\n  @Output() navigate = new EventEmitter<string[]>();\n\n  @ViewChild('accordionGroup') accordionGroup!: IonAccordionGroup;\n\n  constructor(\n    private router: Router,\n    private menuCtrl: MenuController\n  ) {}\n\n  /**\n   * Gets a unique value for the accordion section.\n   */\n  getSectionValue(section: LinksAccordionSection, index: number): string {\n    return section.titleKey || section.title || `section-${index}`;\n  }\n\n  /**\n   * Gets the section title, supporting i18n via titleKey.\n   */\n  getSectionTitle(section: LinksAccordionSection): string {\n    if (section.titleKey && this.props.i18nNamespace) {\n      return this.i18n.t(section.titleKey, this.props.i18nNamespace);\n    }\n    return section.title || '';\n  }\n\n  /**\n   * Gets the link text, supporting i18n via textKey.\n   */\n  getLinkText(link: LinksAccordionLink): string {\n    if (link.textKey && this.props.i18nNamespace) {\n      return this.i18n.t(link.textKey, this.props.i18nNamespace);\n    }\n    return link.text || '';\n  }\n\n  /**\n   * Handles link click - closes accordion/menu and navigates.\n   */\n  async onLinkClick(route: string[], event?: Event): Promise<void> {\n    if (event) {\n      event.stopPropagation();\n    }\n\n    // Close accordion before navigating\n    if (this.props.closeAccordionOnClick !== false && this.accordionGroup) {\n      this.accordionGroup.value = undefined;\n    }\n\n    // Close menu if enabled\n    if (this.props.closeMenuOnClick !== false) {\n      await this.menuCtrl.close();\n    }\n\n    // Emit event\n    this.navigate.emit(route);\n\n    // Navigate\n    this.router.navigate(route);\n  }\n}\n"]}
|