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.
@@ -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
- <ion-accordion
100
- *ngFor="let section of props.sections; let i = index"
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
- slot="header"
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)="section.route ? onLinkClick(section.route, $event) : null"
110
- [button]="!!section.route"
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
- <div
116
- slot="content"
117
- [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
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-list lines="none">
121
- <ion-item
122
- *ngFor="let link of section.links"
123
- [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
124
- (click)="onLinkClick(link.route, $event)"
125
- button
126
- >
127
- <ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
128
- </ion-item>
129
- </ion-list>
130
- </div>
131
- </ion-accordion>
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
- <ion-accordion
142
- *ngFor="let section of props.sections; let i = index"
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
- slot="header"
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)="section.route ? onLinkClick(section.route, $event) : null"
152
- [button]="!!section.route"
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
- <div
158
- slot="content"
159
- [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
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-list lines="none">
163
- <ion-item
164
- *ngFor="let link of section.links"
165
- [ngStyle]="{ background: props.backgroundColor || 'var(--ion-background-color)' }"
166
- (click)="onLinkClick(link.route, $event)"
167
- button
168
- >
169
- <ion-label class="accordion-item-label">{{ getLinkText(link) }}</ion-label>
170
- </ion-item>
171
- </ion-list>
172
- </div>
173
- </ion-accordion>
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"]}