valtech-components 2.0.602 → 2.0.604

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.
@@ -28,9 +28,9 @@ export class DocsNavLinksComponent {
28
28
  this.navigate = new EventEmitter();
29
29
  this.docsNav = inject(DocsNavigationService);
30
30
  this.i18n = inject(I18nService);
31
- // i18n labels with fallbacks
32
- this.previousLabel = computed(() => this.i18n.t('Nav.previous', 'Docs') || 'Previous');
33
- this.nextLabel = computed(() => this.i18n.t('Nav.next', 'Docs') || 'Next');
31
+ // i18n labels - uses _global namespace from valtech-components defaults
32
+ this.previousLabel = computed(() => this.i18n.t('previous') || 'Previous');
33
+ this.nextLabel = computed(() => this.i18n.t('next') || 'Next');
34
34
  }
35
35
  getHref(route) {
36
36
  // Handle routes that already start with '/'
@@ -137,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
137
137
  }], navigate: [{
138
138
  type: Output
139
139
  }] } });
140
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-nav-links.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-nav-links/docs-nav-links.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gDAAgD,CAAC;AACvF,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;;AAErD,QAAQ,CAAC,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,CAAC,CAAC;AAEpD;;;;;;;;;;;;;;GAcG;AAuKH,MAAM,OAAO,qBAAqB;IAtKlC;QAuKW,UAAK,GAAyB,EAAE,CAAC;QAEhC,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;QAE1C,YAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QACxC,SAAI,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEnC,6BAA6B;QAC7B,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,EAAE,MAAM,CAAC,IAAI,UAAU,CAAC,CAAC;QAClF,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,MAAM,CAAC,CAAC;KAavE;IAXC,OAAO,CAAC,KAAe;QACrB,4CAA4C;QAC5C,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7B,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC;IAClD,CAAC;IAED,UAAU,CAAC,KAAY,EAAE,KAAe;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;+GAtBU,qBAAqB;mGAArB,qBAAqB,6IAlKtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT,65DA3CS,YAAY,+BAAE,OAAO;;4FAmKpB,qBAAqB;kBAtKjC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;8BAyHQ,KAAK;sBAAb,KAAK;gBAEI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, Output, EventEmitter, inject, computed } from '@angular/core';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport { arrowBackOutline, arrowForwardOutline } from 'ionicons/icons';\nimport { DocsNavLinksMetadata } from './types';\nimport { DocsNavigationService } from '../../../services/docs/docs-navigation.service';\nimport { I18nService } from '../../../services/i18n';\n\naddIcons({ arrowBackOutline, arrowForwardOutline });\n\n/**\n * val-docs-nav-links\n *\n * Navigation links for previous/next page navigation in documentation.\n *\n * @example\n * ```html\n * <val-docs-nav-links\n *   [props]=\"{\n *     previous: { label: 'Previous', title: 'Getting Started', route: ['/docs', 'getting-started'] },\n *     next: { label: 'Next', title: 'Components', route: ['/docs', 'components'] }\n *   }\"\n * ></val-docs-nav-links>\n * ```\n */\n@Component({\n  selector: 'val-docs-nav-links',\n  standalone: true,\n  imports: [CommonModule, IonIcon],\n  template: `\n    <nav class=\"docs-nav-links\" [class]=\"props.cssClass\" aria-label=\"Page navigation\">\n      <!-- Previous -->\n      <div\n        class=\"docs-nav-links__item docs-nav-links__item--prev\"\n        [class.docs-nav-links__item--empty]=\"!props.previous\"\n      >\n        @if (props.previous) {\n          <a\n            class=\"docs-nav-links__link\"\n            [href]=\"getHref(props.previous.route)\"\n            (click)=\"onNavigate($event, props.previous.route)\"\n          >\n            <ion-icon name=\"arrow-back-outline\" class=\"docs-nav-links__icon\"></ion-icon>\n            <div class=\"docs-nav-links__text\">\n              <span class=\"docs-nav-links__label\">{{ props.previous.label || previousLabel() }}</span>\n              <span class=\"docs-nav-links__title\">{{ props.previous.title }}</span>\n            </div>\n          </a>\n        }\n      </div>\n\n      <!-- Next -->\n      <div\n        class=\"docs-nav-links__item docs-nav-links__item--next\"\n        [class.docs-nav-links__item--empty]=\"!props.next\"\n      >\n        @if (props.next) {\n          <a\n            class=\"docs-nav-links__link\"\n            [href]=\"getHref(props.next.route)\"\n            (click)=\"onNavigate($event, props.next.route)\"\n          >\n            <div class=\"docs-nav-links__text\">\n              <span class=\"docs-nav-links__label\">{{ props.next.label || nextLabel() }}</span>\n              <span class=\"docs-nav-links__title\">{{ props.next.title }}</span>\n            </div>\n            <ion-icon name=\"arrow-forward-outline\" class=\"docs-nav-links__icon\"></ion-icon>\n          </a>\n        }\n      </div>\n    </nav>\n  `,\n  styles: [`\n    .docs-nav-links {\n      display: flex;\n      gap: 1rem;\n      margin-top: 3rem;\n      padding-top: 2rem;\n      border-top: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    .docs-nav-links__item {\n      flex: 1;\n      min-width: 0;\n    }\n\n    .docs-nav-links__item--empty {\n      visibility: hidden;\n    }\n\n    .docs-nav-links__item--next {\n      text-align: right;\n    }\n\n    .docs-nav-links__item--next .docs-nav-links__link {\n      justify-content: flex-end;\n    }\n\n    .docs-nav-links__item--next .docs-nav-links__text {\n      align-items: flex-end;\n    }\n\n    .docs-nav-links__link {\n      display: flex;\n      align-items: center;\n      gap: 0.75rem;\n      padding: 1rem;\n      border-radius: 8px;\n      text-decoration: none;\n      color: inherit;\n      transition: all 0.2s ease;\n      border: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    .docs-nav-links__link:hover {\n      background: rgba(0, 0, 0, 0.03);\n      border-color: #1a1a1a;\n    }\n\n    .docs-nav-links__link:hover .docs-nav-links__title {\n      color: #1a1a1a;\n    }\n\n    .docs-nav-links__link:hover .docs-nav-links__icon {\n      color: #1a1a1a;\n    }\n\n    .docs-nav-links__icon {\n      font-size: 1.25rem;\n      color: var(--ion-color-medium, #666);\n      flex-shrink: 0;\n    }\n\n    .docs-nav-links__text {\n      display: flex;\n      flex-direction: column;\n      gap: 0.25rem;\n    }\n\n    .docs-nav-links__label {\n      font-size: 0.75rem;\n      font-weight: 500;\n      text-transform: uppercase;\n      letter-spacing: 0.5px;\n      color: var(--ion-color-medium, #666);\n    }\n\n    .docs-nav-links__title {\n      font-size: 1rem;\n      font-weight: 600;\n      color: var(--ion-text-color, #1a1a1a);\n      transition: color 0.2s ease;\n    }\n\n    /* Mobile responsive */\n    @media (max-width: 600px) {\n      .docs-nav-links {\n        flex-direction: column;\n      }\n\n      .docs-nav-links__item--next {\n        text-align: left;\n      }\n\n      .docs-nav-links__item--next .docs-nav-links__link {\n        justify-content: flex-start;\n        flex-direction: row-reverse;\n      }\n\n      .docs-nav-links__item--next .docs-nav-links__text {\n        align-items: flex-start;\n      }\n    }\n\n    /* Dark mode */\n    :host-context(.dark) .docs-nav-links__link,\n    :host-context([color-scheme='dark']) .docs-nav-links__link {\n      border-color: #3a3a3a;\n    }\n\n    :host-context(.dark) .docs-nav-links__link:hover,\n    :host-context([color-scheme='dark']) .docs-nav-links__link:hover {\n      background: rgba(255, 255, 255, 0.05);\n    }\n\n    :host-context(.dark) .docs-nav-links__title,\n    :host-context([color-scheme='dark']) .docs-nav-links__title {\n      color: #f4f5f8;\n    }\n  `],\n})\nexport class DocsNavLinksComponent {\n  @Input() props: DocsNavLinksMetadata = {};\n\n  @Output() navigate = new EventEmitter<string[]>();\n\n  private docsNav = inject(DocsNavigationService);\n  private i18n = inject(I18nService);\n\n  // i18n labels with fallbacks\n  previousLabel = computed(() => this.i18n.t('Nav.previous', 'Docs') || 'Previous');\n  nextLabel = computed(() => this.i18n.t('Nav.next', 'Docs') || 'Next');\n\n  getHref(route: string[]): string {\n    // Handle routes that already start with '/'\n    const path = route.join('/');\n    return path.startsWith('/') ? path : '/' + path;\n  }\n\n  onNavigate(event: Event, route: string[]): void {\n    event.preventDefault();\n    this.navigate.emit(route);\n    this.docsNav.navigateAndScroll(route);\n  }\n}\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-nav-links.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-nav-links/docs-nav-links.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gDAAgD,CAAC;AACvF,OAAO,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAC;;AAErD,QAAQ,CAAC,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,CAAC,CAAC;AAEpD;;;;;;;;;;;;;;GAcG;AAuKH,MAAM,OAAO,qBAAqB;IAtKlC;QAuKW,UAAK,GAAyB,EAAE,CAAC;QAEhC,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;QAE1C,YAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QACxC,SAAI,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAEnC,wEAAwE;QACxE,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,IAAI,UAAU,CAAC,CAAC;QACtE,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,CAAC;KAa3D;IAXC,OAAO,CAAC,KAAe;QACrB,4CAA4C;QAC5C,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC7B,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC;IAClD,CAAC;IAED,UAAU,CAAC,KAAY,EAAE,KAAe;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;IACxC,CAAC;+GAtBU,qBAAqB;mGAArB,qBAAqB,6IAlKtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT,65DA3CS,YAAY,+BAAE,OAAO;;4FAmKpB,qBAAqB;kBAtKjC,SAAS;+BACE,oBAAoB,cAClB,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CT;8BAyHQ,KAAK;sBAAb,KAAK;gBAEI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, Output, EventEmitter, inject, computed } from '@angular/core';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport { arrowBackOutline, arrowForwardOutline } from 'ionicons/icons';\nimport { DocsNavLinksMetadata } from './types';\nimport { DocsNavigationService } from '../../../services/docs/docs-navigation.service';\nimport { I18nService } from '../../../services/i18n';\n\naddIcons({ arrowBackOutline, arrowForwardOutline });\n\n/**\n * val-docs-nav-links\n *\n * Navigation links for previous/next page navigation in documentation.\n *\n * @example\n * ```html\n * <val-docs-nav-links\n *   [props]=\"{\n *     previous: { label: 'Previous', title: 'Getting Started', route: ['/docs', 'getting-started'] },\n *     next: { label: 'Next', title: 'Components', route: ['/docs', 'components'] }\n *   }\"\n * ></val-docs-nav-links>\n * ```\n */\n@Component({\n  selector: 'val-docs-nav-links',\n  standalone: true,\n  imports: [CommonModule, IonIcon],\n  template: `\n    <nav class=\"docs-nav-links\" [class]=\"props.cssClass\" aria-label=\"Page navigation\">\n      <!-- Previous -->\n      <div\n        class=\"docs-nav-links__item docs-nav-links__item--prev\"\n        [class.docs-nav-links__item--empty]=\"!props.previous\"\n      >\n        @if (props.previous) {\n          <a\n            class=\"docs-nav-links__link\"\n            [href]=\"getHref(props.previous.route)\"\n            (click)=\"onNavigate($event, props.previous.route)\"\n          >\n            <ion-icon name=\"arrow-back-outline\" class=\"docs-nav-links__icon\"></ion-icon>\n            <div class=\"docs-nav-links__text\">\n              <span class=\"docs-nav-links__label\">{{ props.previous.label || previousLabel() }}</span>\n              <span class=\"docs-nav-links__title\">{{ props.previous.title }}</span>\n            </div>\n          </a>\n        }\n      </div>\n\n      <!-- Next -->\n      <div\n        class=\"docs-nav-links__item docs-nav-links__item--next\"\n        [class.docs-nav-links__item--empty]=\"!props.next\"\n      >\n        @if (props.next) {\n          <a\n            class=\"docs-nav-links__link\"\n            [href]=\"getHref(props.next.route)\"\n            (click)=\"onNavigate($event, props.next.route)\"\n          >\n            <div class=\"docs-nav-links__text\">\n              <span class=\"docs-nav-links__label\">{{ props.next.label || nextLabel() }}</span>\n              <span class=\"docs-nav-links__title\">{{ props.next.title }}</span>\n            </div>\n            <ion-icon name=\"arrow-forward-outline\" class=\"docs-nav-links__icon\"></ion-icon>\n          </a>\n        }\n      </div>\n    </nav>\n  `,\n  styles: [`\n    .docs-nav-links {\n      display: flex;\n      gap: 1rem;\n      margin-top: 3rem;\n      padding-top: 2rem;\n      border-top: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    .docs-nav-links__item {\n      flex: 1;\n      min-width: 0;\n    }\n\n    .docs-nav-links__item--empty {\n      visibility: hidden;\n    }\n\n    .docs-nav-links__item--next {\n      text-align: right;\n    }\n\n    .docs-nav-links__item--next .docs-nav-links__link {\n      justify-content: flex-end;\n    }\n\n    .docs-nav-links__item--next .docs-nav-links__text {\n      align-items: flex-end;\n    }\n\n    .docs-nav-links__link {\n      display: flex;\n      align-items: center;\n      gap: 0.75rem;\n      padding: 1rem;\n      border-radius: 8px;\n      text-decoration: none;\n      color: inherit;\n      transition: all 0.2s ease;\n      border: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    .docs-nav-links__link:hover {\n      background: rgba(0, 0, 0, 0.03);\n      border-color: #1a1a1a;\n    }\n\n    .docs-nav-links__link:hover .docs-nav-links__title {\n      color: #1a1a1a;\n    }\n\n    .docs-nav-links__link:hover .docs-nav-links__icon {\n      color: #1a1a1a;\n    }\n\n    .docs-nav-links__icon {\n      font-size: 1.25rem;\n      color: var(--ion-color-medium, #666);\n      flex-shrink: 0;\n    }\n\n    .docs-nav-links__text {\n      display: flex;\n      flex-direction: column;\n      gap: 0.25rem;\n    }\n\n    .docs-nav-links__label {\n      font-size: 0.75rem;\n      font-weight: 500;\n      text-transform: uppercase;\n      letter-spacing: 0.5px;\n      color: var(--ion-color-medium, #666);\n    }\n\n    .docs-nav-links__title {\n      font-size: 1rem;\n      font-weight: 600;\n      color: var(--ion-text-color, #1a1a1a);\n      transition: color 0.2s ease;\n    }\n\n    /* Mobile responsive */\n    @media (max-width: 600px) {\n      .docs-nav-links {\n        flex-direction: column;\n      }\n\n      .docs-nav-links__item--next {\n        text-align: left;\n      }\n\n      .docs-nav-links__item--next .docs-nav-links__link {\n        justify-content: flex-start;\n        flex-direction: row-reverse;\n      }\n\n      .docs-nav-links__item--next .docs-nav-links__text {\n        align-items: flex-start;\n      }\n    }\n\n    /* Dark mode */\n    :host-context(.dark) .docs-nav-links__link,\n    :host-context([color-scheme='dark']) .docs-nav-links__link {\n      border-color: #3a3a3a;\n    }\n\n    :host-context(.dark) .docs-nav-links__link:hover,\n    :host-context([color-scheme='dark']) .docs-nav-links__link:hover {\n      background: rgba(255, 255, 255, 0.05);\n    }\n\n    :host-context(.dark) .docs-nav-links__title,\n    :host-context([color-scheme='dark']) .docs-nav-links__title {\n      color: #f4f5f8;\n    }\n  `],\n})\nexport class DocsNavLinksComponent {\n  @Input() props: DocsNavLinksMetadata = {};\n\n  @Output() navigate = new EventEmitter<string[]>();\n\n  private docsNav = inject(DocsNavigationService);\n  private i18n = inject(I18nService);\n\n  // i18n labels - uses _global namespace from valtech-components defaults\n  previousLabel = computed(() => this.i18n.t('previous') || 'Previous');\n  nextLabel = computed(() => this.i18n.t('next') || 'Next');\n\n  getHref(route: string[]): string {\n    // Handle routes that already start with '/'\n    const path = route.join('/');\n    return path.startsWith('/') ? path : '/' + path;\n  }\n\n  onNavigate(event: Event, route: string[]): void {\n    event.preventDefault();\n    this.navigate.emit(route);\n    this.docsNav.navigateAndScroll(route);\n  }\n}\n"]}
@@ -36704,9 +36704,9 @@ class DocsNavLinksComponent {
36704
36704
  this.navigate = new EventEmitter();
36705
36705
  this.docsNav = inject(DocsNavigationService);
36706
36706
  this.i18n = inject(I18nService);
36707
- // i18n labels with fallbacks
36708
- this.previousLabel = computed(() => this.i18n.t('Nav.previous', 'Docs') || 'Previous');
36709
- this.nextLabel = computed(() => this.i18n.t('Nav.next', 'Docs') || 'Next');
36707
+ // i18n labels - uses _global namespace from valtech-components defaults
36708
+ this.previousLabel = computed(() => this.i18n.t('previous') || 'Previous');
36709
+ this.nextLabel = computed(() => this.i18n.t('next') || 'Next');
36710
36710
  }
36711
36711
  getHref(route) {
36712
36712
  // Handle routes that already start with '/'