valtech-components 2.0.607 → 2.0.608

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.
@@ -94,7 +94,7 @@ export class DocsBreadcrumbComponent {
94
94
  }
95
95
  </ol>
96
96
  </nav>
97
- `, isInline: true, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:.25rem .5rem;border:none;background:transparent;font-size:.8125rem;color:var(--ion-color-medium, #666);text-decoration:none;border-radius:4px;cursor:pointer;transition:all .15s ease;&:hover{background:#0000000d;color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{padding:.25rem;ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.8125rem;font-weight:500;color:var(--ion-text-color, #1a1a1a);padding:.25rem .5rem}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{background:#ffffff0d;color:#f4f5f8}&__current{color:#f4f5f8}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
97
+ `, isInline: true, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease;&:hover{color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{color:#f4f5f8}&__current{color:#f4f5f8}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
98
98
  }
99
99
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsBreadcrumbComponent, decorators: [{
100
100
  type: Component,
@@ -157,10 +157,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
157
157
  }
158
158
  </ol>
159
159
  </nav>
160
- `, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:.25rem .5rem;border:none;background:transparent;font-size:.8125rem;color:var(--ion-color-medium, #666);text-decoration:none;border-radius:4px;cursor:pointer;transition:all .15s ease;&:hover{background:#0000000d;color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{padding:.25rem;ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.8125rem;font-weight:500;color:var(--ion-text-color, #1a1a1a);padding:.25rem .5rem}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{background:#ffffff0d;color:#f4f5f8}&__current{color:#f4f5f8}}}\n"] }]
160
+ `, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease;&:hover{color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{color:#f4f5f8}&__current{color:#f4f5f8}}}\n"] }]
161
161
  }], ctorParameters: () => [{ type: i1.Router }], propDecorators: { props: [{
162
162
  type: Input
163
163
  }], navigate: [{
164
164
  type: Output
165
165
  }] } });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-breadcrumb.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-breadcrumb/docs-breadcrumb.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,CAAC;AAEvE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;;;AAGpE,QAAQ,CAAC,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC,CAAC;AAEjD;;;;;;;;;;;;;;;;;GAiBG;AAwJH,MAAM,OAAO,uBAAuB;IAKlC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAJzB,UAAK,GAA2B,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QAE7C,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;IAEb,CAAC;IAEtC,UAAU,CAAC,KAAe;QACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;+GAVU,uBAAuB;mGAAvB,uBAAuB,8IAnJxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT,glCA5DS,YAAY,+BAAE,OAAO;;4FAoJpB,uBAAuB;kBAvJnC,SAAS;+BACE,qBAAqB,cACnB,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT;2EAyFQ,KAAK;sBAAb,KAAK;gBAEI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport { homeOutline, chevronForwardOutline } from 'ionicons/icons';\nimport { DocsBreadcrumbMetadata, DocsBreadcrumbItem } from './types';\n\naddIcons({ homeOutline, chevronForwardOutline });\n\n/**\n * val-docs-breadcrumb\n *\n * A breadcrumb navigation component for documentation.\n *\n * @example\n * ```html\n * <val-docs-breadcrumb\n *   [props]=\"{\n *     showHome: true,\n *     items: [\n *       { label: 'Components', route: ['/docs', 'components'] },\n *       { label: 'Button' }\n *     ]\n *   }\"\n * ></val-docs-breadcrumb>\n * ```\n */\n@Component({\n  selector: 'val-docs-breadcrumb',\n  standalone: true,\n  imports: [CommonModule, IonIcon],\n  template: `\n    <nav\n      class=\"docs-breadcrumb\"\n      [class]=\"props.cssClass\"\n      aria-label=\"Breadcrumb\"\n    >\n      <ol class=\"docs-breadcrumb__list\">\n        @if (props.showHome) {\n          <li class=\"docs-breadcrumb__item\">\n            <button\n              type=\"button\"\n              class=\"docs-breadcrumb__link docs-breadcrumb__link--home\"\n              (click)=\"onNavigate(props.homeRoute || ['/'])\"\n              aria-label=\"Home\"\n            >\n              <ion-icon name=\"home-outline\"></ion-icon>\n            </button>\n            <span class=\"docs-breadcrumb__separator\" aria-hidden=\"true\">\n              @if (props.separator) {\n                {{ props.separator }}\n              } @else {\n                <ion-icon name=\"chevron-forward-outline\"></ion-icon>\n              }\n            </span>\n          </li>\n        }\n\n        @for (item of props.items; track item.label; let last = $last) {\n          <li class=\"docs-breadcrumb__item\">\n            @if (item.route && !last) {\n              <button\n                type=\"button\"\n                class=\"docs-breadcrumb__link\"\n                (click)=\"onNavigate(item.route)\"\n              >\n                {{ item.label }}\n              </button>\n            } @else {\n              <span\n                class=\"docs-breadcrumb__current\"\n                aria-current=\"page\"\n              >\n                {{ item.label }}\n              </span>\n            }\n\n            @if (!last) {\n              <span class=\"docs-breadcrumb__separator\" aria-hidden=\"true\">\n                @if (props.separator) {\n                  {{ props.separator }}\n                } @else {\n                  <ion-icon name=\"chevron-forward-outline\"></ion-icon>\n                }\n              </span>\n            }\n          </li>\n        }\n      </ol>\n    </nav>\n  `,\n  styles: [`\n    .docs-breadcrumb {\n      font-family: var(--ion-font-family, system-ui, sans-serif);\n\n      &__list {\n        display: flex;\n        flex-wrap: wrap;\n        align-items: center;\n        gap: 0.25rem;\n        list-style: none;\n        margin: 0;\n        padding: 0;\n      }\n\n      &__item {\n        display: flex;\n        align-items: center;\n        gap: 0.25rem;\n      }\n\n      &__link {\n        display: flex;\n        align-items: center;\n        padding: 0.25rem 0.5rem;\n        border: none;\n        background: transparent;\n        font-size: 0.8125rem;\n        color: var(--ion-color-medium, #666);\n        text-decoration: none;\n        border-radius: 4px;\n        cursor: pointer;\n        transition: all 0.15s ease;\n\n        &:hover {\n          background: rgba(0, 0, 0, 0.05);\n          color: var(--ion-text-color, #1a1a1a);\n        }\n\n        &:focus-visible {\n          outline: 2px solid #1a1a1a;\n          outline-offset: 2px;\n        }\n\n        &--home {\n          padding: 0.25rem;\n\n          ion-icon {\n            font-size: 1rem;\n          }\n        }\n      }\n\n      &__separator {\n        display: flex;\n        align-items: center;\n        color: var(--ion-color-medium, #666);\n        font-size: 0.75rem;\n\n        ion-icon {\n          font-size: 0.75rem;\n        }\n      }\n\n      &__current {\n        font-size: 0.8125rem;\n        font-weight: 500;\n        color: var(--ion-text-color, #1a1a1a);\n        padding: 0.25rem 0.5rem;\n      }\n    }\n\n    // Dark mode\n    :host-context(.dark),\n    :host-context([color-scheme='dark']) {\n      .docs-breadcrumb {\n        &__link:hover {\n          background: rgba(255, 255, 255, 0.05);\n          color: #f4f5f8;\n        }\n\n        &__current {\n          color: #f4f5f8;\n        }\n      }\n    }\n  `],\n})\nexport class DocsBreadcrumbComponent {\n  @Input() props: DocsBreadcrumbMetadata = { items: [] };\n\n  @Output() navigate = new EventEmitter<string[]>();\n\n  constructor(private router: Router) {}\n\n  onNavigate(route: string[]): void {\n    this.navigate.emit(route);\n    this.router.navigate(route);\n  }\n}\n"]}
166
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-breadcrumb.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/molecules/docs-breadcrumb/docs-breadcrumb.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,CAAC;AAEvE,OAAO,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,WAAW,EAAE,qBAAqB,EAAE,MAAM,gBAAgB,CAAC;;;AAGpE,QAAQ,CAAC,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC,CAAC;AAEjD;;;;;;;;;;;;;;;;;GAiBG;AAkJH,MAAM,OAAO,uBAAuB;IAKlC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAJzB,UAAK,GAA2B,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC;QAE7C,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;IAEb,CAAC;IAEtC,UAAU,CAAC,KAAe;QACxB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;+GAVU,uBAAuB;mGAAvB,uBAAuB,8IA7IxB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT,q+BA5DS,YAAY,+BAAE,OAAO;;4FA8IpB,uBAAuB;kBAjJnC,SAAS;+BACE,qBAAqB,cACnB,IAAI,WACP,CAAC,YAAY,EAAE,OAAO,CAAC,YACtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2DT;2EAmFQ,KAAK;sBAAb,KAAK;gBAEI,QAAQ;sBAAjB,MAAM","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { Router } from '@angular/router';\nimport { IonIcon } from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport { homeOutline, chevronForwardOutline } from 'ionicons/icons';\nimport { DocsBreadcrumbMetadata, DocsBreadcrumbItem } from './types';\n\naddIcons({ homeOutline, chevronForwardOutline });\n\n/**\n * val-docs-breadcrumb\n *\n * A breadcrumb navigation component for documentation.\n *\n * @example\n * ```html\n * <val-docs-breadcrumb\n *   [props]=\"{\n *     showHome: true,\n *     items: [\n *       { label: 'Components', route: ['/docs', 'components'] },\n *       { label: 'Button' }\n *     ]\n *   }\"\n * ></val-docs-breadcrumb>\n * ```\n */\n@Component({\n  selector: 'val-docs-breadcrumb',\n  standalone: true,\n  imports: [CommonModule, IonIcon],\n  template: `\n    <nav\n      class=\"docs-breadcrumb\"\n      [class]=\"props.cssClass\"\n      aria-label=\"Breadcrumb\"\n    >\n      <ol class=\"docs-breadcrumb__list\">\n        @if (props.showHome) {\n          <li class=\"docs-breadcrumb__item\">\n            <button\n              type=\"button\"\n              class=\"docs-breadcrumb__link docs-breadcrumb__link--home\"\n              (click)=\"onNavigate(props.homeRoute || ['/'])\"\n              aria-label=\"Home\"\n            >\n              <ion-icon name=\"home-outline\"></ion-icon>\n            </button>\n            <span class=\"docs-breadcrumb__separator\" aria-hidden=\"true\">\n              @if (props.separator) {\n                {{ props.separator }}\n              } @else {\n                <ion-icon name=\"chevron-forward-outline\"></ion-icon>\n              }\n            </span>\n          </li>\n        }\n\n        @for (item of props.items; track item.label; let last = $last) {\n          <li class=\"docs-breadcrumb__item\">\n            @if (item.route && !last) {\n              <button\n                type=\"button\"\n                class=\"docs-breadcrumb__link\"\n                (click)=\"onNavigate(item.route)\"\n              >\n                {{ item.label }}\n              </button>\n            } @else {\n              <span\n                class=\"docs-breadcrumb__current\"\n                aria-current=\"page\"\n              >\n                {{ item.label }}\n              </span>\n            }\n\n            @if (!last) {\n              <span class=\"docs-breadcrumb__separator\" aria-hidden=\"true\">\n                @if (props.separator) {\n                  {{ props.separator }}\n                } @else {\n                  <ion-icon name=\"chevron-forward-outline\"></ion-icon>\n                }\n              </span>\n            }\n          </li>\n        }\n      </ol>\n    </nav>\n  `,\n  styles: [`\n    .docs-breadcrumb {\n      font-family: var(--ion-font-family, system-ui, sans-serif);\n\n      &__list {\n        display: flex;\n        flex-wrap: wrap;\n        align-items: center;\n        gap: 0.25rem;\n        list-style: none;\n        margin: 0;\n        padding: 0;\n      }\n\n      &__item {\n        display: flex;\n        align-items: center;\n        gap: 0.25rem;\n      }\n\n      &__link {\n        display: flex;\n        align-items: center;\n        padding: 0;\n        border: none;\n        background: transparent;\n        font-size: 0.875rem;\n        color: var(--ion-color-medium, #666);\n        text-decoration: none;\n        cursor: pointer;\n        transition: color 0.15s ease;\n\n        &:hover {\n          color: var(--ion-text-color, #1a1a1a);\n        }\n\n        &:focus-visible {\n          outline: 2px solid #1a1a1a;\n          outline-offset: 2px;\n        }\n\n        &--home {\n          ion-icon {\n            font-size: 1rem;\n          }\n        }\n      }\n\n      &__separator {\n        display: flex;\n        align-items: center;\n        color: var(--ion-color-medium, #666);\n        font-size: 0.75rem;\n\n        ion-icon {\n          font-size: 0.75rem;\n        }\n      }\n\n      &__current {\n        font-size: 0.875rem;\n        font-weight: 600;\n        color: var(--ion-text-color, #1a1a1a);\n      }\n    }\n\n    // Dark mode\n    :host-context(.dark),\n    :host-context([color-scheme='dark']) {\n      .docs-breadcrumb {\n        &__link:hover {\n          color: #f4f5f8;\n        }\n\n        &__current {\n          color: #f4f5f8;\n        }\n      }\n    }\n  `],\n})\nexport class DocsBreadcrumbComponent {\n  @Input() props: DocsBreadcrumbMetadata = { items: [] };\n\n  @Output() navigate = new EventEmitter<string[]>();\n\n  constructor(private router: Router) {}\n\n  onNavigate(route: string[]): void {\n    this.navigate.emit(route);\n    this.router.navigate(route);\n  }\n}\n"]}
@@ -83,7 +83,7 @@ export class DocsPageComponent {
83
83
  }
84
84
  return {
85
85
  items: props.breadcrumb.items,
86
- showHome: props.breadcrumb.showHome ?? true,
86
+ showHome: props.breadcrumb.showHome ?? false,
87
87
  homeRoute: props.breadcrumb.homeRoute ?? ['/'],
88
88
  };
89
89
  });
@@ -217,4 +217,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
217
217
  }], propDecorators: { props: [{
218
218
  type: Input
219
219
  }] } });
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-page.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/templates/docs-page/docs-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, computed, signal, AfterViewInit, OnDestroy, ElementRef, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { DocsBreadcrumbComponent } from '../../molecules/docs-breadcrumb/docs-breadcrumb.component';\nimport { DocsBreadcrumbMetadata } from '../../molecules/docs-breadcrumb/types';\nimport { DocsNavLinksComponent } from '../../molecules/docs-nav-links/docs-nav-links.component';\nimport { DocsNavLinksMetadata } from '../../molecules/docs-nav-links/types';\nimport { DocsTocComponent } from '../../organisms/docs-toc/docs-toc.component';\nimport { DocsTocMetadata } from '../../organisms/docs-toc/types';\nimport { DocsPageMetadata } from './types';\n\n/**\n * val-docs-page\n *\n * A complete documentation page template that eliminates boilerplate.\n * Provides automatic TOC generation, navigation links, and consistent styling.\n *\n * @example Basic usage\n * ```html\n * <val-docs-page [props]=\"{\n *   title: 'Button',\n *   lead: 'A clickable element for user interactions.',\n *   previousPage: { title: 'Quick Start', route: ['/docs', 'quick-start'] },\n *   nextPage: { title: 'Card', route: ['/docs', 'components', 'card'] }\n * }\">\n *   <val-docs-section [props]=\"{ id: 'basic-usage', title: 'Basic Usage' }\">\n *     <p>Content here...</p>\n *   </val-docs-section>\n *\n *   <val-docs-section [props]=\"{ id: 'variants', title: 'Variants' }\">\n *     <p>More content...</p>\n *   </val-docs-section>\n * </val-docs-page>\n * ```\n *\n * @example With badge\n * ```html\n * <val-docs-page [props]=\"{\n *   title: 'New Component',\n *   badge: 'New',\n *   badgeColor: 'success'\n * }\">\n *   ...\n * </val-docs-page>\n * ```\n */\n@Component({\n  selector: 'val-docs-page',\n  standalone: true,\n  imports: [CommonModule, DocsBreadcrumbComponent, DocsNavLinksComponent, DocsTocComponent],\n  template: `\n    <div class=\"docs-page\" [class]=\"props.cssClass\">\n      <div class=\"docs-page__content\" #content>\n        @if (breadcrumbProps()) {\n          <val-docs-breadcrumb [props]=\"breadcrumbProps()!\"></val-docs-breadcrumb>\n        }\n        <header class=\"docs-page__header\">\n          <div class=\"docs-page__title-row\">\n            <h1 class=\"docs-page__title\">{{ props.title }}</h1>\n            @if (props.badge) {\n              <span\n                class=\"docs-page__badge\"\n                [class.docs-page__badge--success]=\"props.badgeColor === 'success'\"\n                [class.docs-page__badge--warning]=\"props.badgeColor === 'warning'\"\n                [class.docs-page__badge--danger]=\"props.badgeColor === 'danger'\"\n              >\n                {{ props.badge }}\n              </span>\n            }\n          </div>\n          @if (props.lead) {\n            <p class=\"docs-page__lead\">{{ props.lead }}</p>\n          }\n        </header>\n\n        <div class=\"docs-page__sections\">\n          <ng-content></ng-content>\n        </div>\n\n        @if (showNavLinks()) {\n          <val-docs-nav-links [props]=\"navLinksProps()\"></val-docs-nav-links>\n        }\n      </div>\n\n      @if (!props.toc?.hide) {\n        <aside class=\"docs-page__toc\">\n          <val-docs-toc [props]=\"tocProps()\"></val-docs-toc>\n        </aside>\n      }\n    </div>\n  `,\n  styles: [`\n    /* Main layout */\n    .docs-page {\n      display: grid;\n      grid-template-columns: 1fr;\n      gap: 2rem;\n      max-width: 1400px;\n      margin: 0 auto;\n      padding: 2rem 1.5rem;\n    }\n\n    @media (min-width: 1200px) {\n      .docs-page {\n        grid-template-columns: 1fr 220px;\n        padding: 2rem;\n      }\n    }\n\n    .docs-page__content {\n      min-width: 0;\n      max-width: 900px;\n    }\n\n    val-docs-breadcrumb {\n      display: block;\n      margin-bottom: 1rem;\n    }\n\n    .docs-page__header {\n      margin-bottom: 2rem;\n    }\n\n    .docs-page__title-row {\n      display: flex;\n      align-items: center;\n      gap: 0.75rem;\n      flex-wrap: wrap;\n    }\n\n    .docs-page__title {\n      margin: 0;\n      font-size: 2rem;\n      font-weight: 700;\n      color: var(--ion-text-color, #1a1a1a);\n      line-height: 1.2;\n    }\n\n    @media (min-width: 768px) {\n      .docs-page__title {\n        font-size: 2.5rem;\n      }\n    }\n\n    .docs-page__badge {\n      display: inline-flex;\n      align-items: center;\n      padding: 0.25rem 0.5rem;\n      font-size: 0.6875rem;\n      font-weight: 500;\n      text-transform: uppercase;\n      letter-spacing: 0.03em;\n      border-radius: 4px;\n      background: rgba(0, 0, 0, 0.04);\n      color: #888;\n    }\n\n    .docs-page__badge--success {\n      background: var(--ion-color-success-tint, #e8f5e9);\n      color: var(--ion-color-success-shade, #2e7d32);\n    }\n\n    .docs-page__badge--warning {\n      background: var(--ion-color-warning-tint, #fff3e0);\n      color: var(--ion-color-warning-shade, #e65100);\n    }\n\n    .docs-page__badge--danger {\n      background: var(--ion-color-danger-tint, #ffebee);\n      color: var(--ion-color-danger-shade, #c62828);\n    }\n\n    .docs-page__lead {\n      margin: 1rem 0 0;\n      font-size: 1.125rem;\n      line-height: 1.7;\n      color: var(--ion-color-medium, #666);\n    }\n\n    .docs-page__sections > *:last-child {\n      margin-bottom: 0;\n    }\n\n    /* TOC - Hidden on mobile, visible on desktop */\n    .docs-page__toc {\n      display: none;\n    }\n\n    @media (min-width: 1200px) {\n      .docs-page__toc {\n        display: block;\n        position: sticky;\n        top: 2rem;\n        height: fit-content;\n        max-height: calc(100vh - 4rem);\n        overflow-y: auto;\n      }\n    }\n\n    /* Content typography styles */\n    .docs-page__sections h2 {\n      font-size: 1.5rem;\n      font-weight: 600;\n      margin: 0 0 1rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n      scroll-margin-top: 2rem;\n    }\n\n    .docs-page__sections h3 {\n      font-size: 1.125rem;\n      font-weight: 600;\n      margin: 1.5rem 0 1rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections h4 {\n      font-size: 1rem;\n      font-weight: 600;\n      margin: 1.25rem 0 0.75rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections p {\n      line-height: 1.7;\n      color: var(--ion-text-color, #1a1a1a);\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections ul,\n    .docs-page__sections ol {\n      padding-left: 1.5rem;\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections li {\n      margin-bottom: 0.5rem;\n      line-height: 1.6;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections a {\n      color: var(--ion-color-primary, #3880ff);\n      text-decoration: none;\n    }\n\n    .docs-page__sections a:hover {\n      text-decoration: underline;\n    }\n\n    .docs-page__sections code:not([class*='language-']) {\n      background: rgba(0, 0, 0, 0.06);\n      padding: 0.125rem 0.375rem;\n      border-radius: 4px;\n      font-family: 'SF Mono', 'Fira Code', Consolas, monospace;\n      font-size: 0.875em;\n    }\n\n    .docs-page__sections pre:not([class*='language-']) {\n      background: rgba(0, 0, 0, 0.04);\n      padding: 1rem;\n      border-radius: 8px;\n      overflow-x: auto;\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections pre:not([class*='language-']) code {\n      background: none;\n      padding: 0;\n    }\n\n    .docs-page__sections table {\n      width: 100%;\n      border-collapse: collapse;\n      margin: 0 0 1rem 0;\n      font-size: 0.875rem;\n    }\n\n    .docs-page__sections th,\n    .docs-page__sections td {\n      padding: 0.75rem;\n      text-align: left;\n      border-bottom: 1px solid rgba(0, 0, 0, 0.1);\n    }\n\n    .docs-page__sections th {\n      font-weight: 600;\n      background: rgba(0, 0, 0, 0.02);\n    }\n\n    .docs-page__sections blockquote {\n      margin: 0 0 1rem 0;\n      padding: 1rem 1.5rem;\n      border-left: 4px solid var(--ion-color-primary, #3880ff);\n      background: rgba(0, 0, 0, 0.02);\n      border-radius: 0 8px 8px 0;\n    }\n\n    .docs-page__sections blockquote p:last-child {\n      margin-bottom: 0;\n    }\n\n    .docs-page__sections img {\n      max-width: 100%;\n      height: auto;\n      border-radius: 8px;\n    }\n\n    .docs-page__sections hr {\n      border: none;\n      border-top: 1px solid rgba(0, 0, 0, 0.1);\n      margin: 2rem 0;\n    }\n\n    .docs-page__sections strong {\n      font-weight: 600;\n    }\n\n    .docs-page__sections section {\n      margin-bottom: 2rem;\n    }\n\n    /* Dark mode */\n    :host-context(.dark) .docs-page__badge,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge {\n      background: rgba(255, 255, 255, 0.06);\n      color: #999;\n    }\n\n    :host-context(.dark) .docs-page__badge--success,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--success {\n      background: rgba(46, 125, 50, 0.2);\n      color: #81c784;\n    }\n\n    :host-context(.dark) .docs-page__badge--warning,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--warning {\n      background: rgba(230, 81, 0, 0.2);\n      color: #ffb74d;\n    }\n\n    :host-context(.dark) .docs-page__badge--danger,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--danger {\n      background: rgba(198, 40, 40, 0.2);\n      color: #e57373;\n    }\n\n    :host-context(.dark) .docs-page__sections code:not([class*='language-']),\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections code:not([class*='language-']) {\n      background: rgba(255, 255, 255, 0.1);\n    }\n\n    :host-context(.dark) .docs-page__sections pre:not([class*='language-']),\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections pre:not([class*='language-']) {\n      background: rgba(255, 255, 255, 0.06);\n    }\n\n    :host-context(.dark) .docs-page__sections th,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections th {\n      background: rgba(255, 255, 255, 0.04);\n    }\n\n    :host-context(.dark) .docs-page__sections th,\n    :host-context(.dark) .docs-page__sections td,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections th,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections td {\n      border-color: rgba(255, 255, 255, 0.1);\n    }\n\n    :host-context(.dark) .docs-page__sections blockquote,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections blockquote {\n      background: rgba(255, 255, 255, 0.04);\n    }\n\n    :host-context(.dark) .docs-page__sections hr,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections hr {\n      border-color: rgba(255, 255, 255, 0.1);\n    }\n  `],\n})\nexport class DocsPageComponent implements AfterViewInit, OnDestroy {\n  private elementRef = inject(ElementRef);\n\n  // Use signal internally so computed properties react to changes\n  private _props = signal<DocsPageMetadata>({ title: '' });\n\n  @Input()\n  set props(value: DocsPageMetadata) {\n    this._props.set(value);\n  }\n  get props(): DocsPageMetadata {\n    return this._props();\n  }\n\n  private tocItems = signal<{ id: string; label: string; level: number }[]>([]);\n  private observer: MutationObserver | null = null;\n\n  ngAfterViewInit(): void {\n    // Initial scan\n    this.scanForSections();\n\n    // Watch for dynamic content changes\n    this.observer = new MutationObserver(() => {\n      this.scanForSections();\n    });\n\n    const contentEl = this.elementRef.nativeElement.querySelector('.docs-page__sections');\n    if (contentEl) {\n      this.observer.observe(contentEl, { childList: true, subtree: true });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.observer?.disconnect();\n  }\n\n  private scanForSections(): void {\n    const contentEl = this.elementRef.nativeElement.querySelector('.docs-page__sections');\n    if (!contentEl) return;\n\n    const headings = contentEl.querySelectorAll('h2[id], h3[id], section[id] > h2, section[id] > h3');\n    const items: { id: string; label: string; level: number }[] = [];\n\n    headings.forEach((heading: Element) => {\n      // Get ID from heading or parent section\n      let id = heading.id;\n      if (!id && heading.parentElement?.tagName === 'SECTION') {\n        id = heading.parentElement.id;\n      }\n\n      if (id) {\n        const level = heading.tagName === 'H2' ? 2 : 3;\n        items.push({ id, label: heading.textContent?.trim() || '', level });\n      }\n    });\n\n    this.tocItems.set(items);\n  }\n\n  tocProps = computed<DocsTocMetadata>(() => {\n    const props = this._props();\n    return {\n      title: props.toc?.title ?? 'On this page',\n      items: this.tocItems(),\n    };\n  });\n\n  navLinksProps = computed<DocsNavLinksMetadata>(() => {\n    const props = this._props();\n    return {\n      previous: props.previousPage\n        ? {\n            // Don't pass label - let DocsNavLinksComponent use its internal i18n-reactive labels\n            title: props.previousPage.title,\n            route: props.previousPage.route,\n          }\n        : undefined,\n      next: props.nextPage\n        ? {\n            // Don't pass label - let DocsNavLinksComponent use its internal i18n-reactive labels\n            title: props.nextPage.title,\n            route: props.nextPage.route,\n          }\n        : undefined,\n    };\n  });\n\n  showNavLinks = computed(() => {\n    const props = this._props();\n    return !!props.previousPage || !!props.nextPage;\n  });\n\n  breadcrumbProps = computed<DocsBreadcrumbMetadata | null>(() => {\n    const props = this._props();\n    if (!props.breadcrumb?.items?.length) {\n      return null;\n    }\n    return {\n      items: props.breadcrumb.items,\n      showHome: props.breadcrumb.showHome ?? true,\n      homeRoute: props.breadcrumb.homeRoute ?? ['/'],\n    };\n  });\n}\n"]}
220
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-page.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/templates/docs-page/docs-page.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,EAA4B,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACjH,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,MAAM,2DAA2D,CAAC;AAEpG,OAAO,EAAE,qBAAqB,EAAE,MAAM,yDAAyD,CAAC;AAEhG,OAAO,EAAE,gBAAgB,EAAE,MAAM,6CAA6C,CAAC;;AAI/E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAkCG;AA8UH,MAAM,OAAO,iBAAiB;IA7U9B;QA8UU,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAExC,gEAAgE;QACxD,WAAM,GAAG,MAAM,CAAmB,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,CAAC;QAUjD,aAAQ,GAAG,MAAM,CAAiD,EAAE,CAAC,CAAC;QACtE,aAAQ,GAA4B,IAAI,CAAC;QA4CjD,aAAQ,GAAG,QAAQ,CAAkB,GAAG,EAAE;YACxC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,OAAO;gBACL,KAAK,EAAE,KAAK,CAAC,GAAG,EAAE,KAAK,IAAI,cAAc;gBACzC,KAAK,EAAE,IAAI,CAAC,QAAQ,EAAE;aACvB,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,kBAAa,GAAG,QAAQ,CAAuB,GAAG,EAAE;YAClD,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,OAAO;gBACL,QAAQ,EAAE,KAAK,CAAC,YAAY;oBAC1B,CAAC,CAAC;wBACE,qFAAqF;wBACrF,KAAK,EAAE,KAAK,CAAC,YAAY,CAAC,KAAK;wBAC/B,KAAK,EAAE,KAAK,CAAC,YAAY,CAAC,KAAK;qBAChC;oBACH,CAAC,CAAC,SAAS;gBACb,IAAI,EAAE,KAAK,CAAC,QAAQ;oBAClB,CAAC,CAAC;wBACE,qFAAqF;wBACrF,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK;wBAC3B,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK;qBAC5B;oBACH,CAAC,CAAC,SAAS;aACd,CAAC;QACJ,CAAC,CAAC,CAAC;QAEH,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,OAAO,CAAC,CAAC,KAAK,CAAC,YAAY,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC;QAClD,CAAC,CAAC,CAAC;QAEH,oBAAe,GAAG,QAAQ,CAAgC,GAAG,EAAE;YAC7D,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC5B,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;gBACrC,OAAO,IAAI,CAAC;YACd,CAAC;YACD,OAAO;gBACL,KAAK,EAAE,KAAK,CAAC,UAAU,CAAC,KAAK;gBAC7B,QAAQ,EAAE,KAAK,CAAC,UAAU,CAAC,QAAQ,IAAI,KAAK;gBAC5C,SAAS,EAAE,KAAK,CAAC,UAAU,CAAC,SAAS,IAAI,CAAC,GAAG,CAAC;aAC/C,CAAC;QACJ,CAAC,CAAC,CAAC;KACJ;IAjGC,IACI,KAAK,CAAC,KAAuB;QAC/B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;IACD,IAAI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;IACvB,CAAC;IAKD,eAAe;QACb,eAAe;QACf,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,oCAAoC;QACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACxC,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;QACtF,IAAI,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;QACvE,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,EAAE,UAAU,EAAE,CAAC;IAC9B,CAAC;IAEO,eAAe;QACrB,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;QACtF,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,MAAM,QAAQ,GAAG,SAAS,CAAC,gBAAgB,CAAC,oDAAoD,CAAC,CAAC;QAClG,MAAM,KAAK,GAAmD,EAAE,CAAC;QAEjE,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAgB,EAAE,EAAE;YACpC,wCAAwC;YACxC,IAAI,EAAE,GAAG,OAAO,CAAC,EAAE,CAAC;YACpB,IAAI,CAAC,EAAE,IAAI,OAAO,CAAC,aAAa,EAAE,OAAO,KAAK,SAAS,EAAE,CAAC;gBACxD,EAAE,GAAG,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;YAChC,CAAC;YAED,IAAI,EAAE,EAAE,CAAC;gBACP,MAAM,KAAK,GAAG,OAAO,CAAC,OAAO,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC/C,KAAK,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,OAAO,CAAC,WAAW,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YACtE,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;+GAzDU,iBAAiB;mGAAjB,iBAAiB,qGAzUlB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCT,88JAzCS,YAAY,+BAAE,uBAAuB,0GAAE,qBAAqB,yGAAE,gBAAgB;;4FA0U7E,iBAAiB;kBA7U7B,SAAS;+BACE,eAAe,cACb,IAAI,WACP,CAAC,YAAY,EAAE,uBAAuB,EAAE,qBAAqB,EAAE,gBAAgB,CAAC,YAC/E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwCT;8BAwSG,KAAK;sBADR,KAAK","sourcesContent":["import { Component, Input, computed, signal, AfterViewInit, OnDestroy, ElementRef, inject } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { DocsBreadcrumbComponent } from '../../molecules/docs-breadcrumb/docs-breadcrumb.component';\nimport { DocsBreadcrumbMetadata } from '../../molecules/docs-breadcrumb/types';\nimport { DocsNavLinksComponent } from '../../molecules/docs-nav-links/docs-nav-links.component';\nimport { DocsNavLinksMetadata } from '../../molecules/docs-nav-links/types';\nimport { DocsTocComponent } from '../../organisms/docs-toc/docs-toc.component';\nimport { DocsTocMetadata } from '../../organisms/docs-toc/types';\nimport { DocsPageMetadata } from './types';\n\n/**\n * val-docs-page\n *\n * A complete documentation page template that eliminates boilerplate.\n * Provides automatic TOC generation, navigation links, and consistent styling.\n *\n * @example Basic usage\n * ```html\n * <val-docs-page [props]=\"{\n *   title: 'Button',\n *   lead: 'A clickable element for user interactions.',\n *   previousPage: { title: 'Quick Start', route: ['/docs', 'quick-start'] },\n *   nextPage: { title: 'Card', route: ['/docs', 'components', 'card'] }\n * }\">\n *   <val-docs-section [props]=\"{ id: 'basic-usage', title: 'Basic Usage' }\">\n *     <p>Content here...</p>\n *   </val-docs-section>\n *\n *   <val-docs-section [props]=\"{ id: 'variants', title: 'Variants' }\">\n *     <p>More content...</p>\n *   </val-docs-section>\n * </val-docs-page>\n * ```\n *\n * @example With badge\n * ```html\n * <val-docs-page [props]=\"{\n *   title: 'New Component',\n *   badge: 'New',\n *   badgeColor: 'success'\n * }\">\n *   ...\n * </val-docs-page>\n * ```\n */\n@Component({\n  selector: 'val-docs-page',\n  standalone: true,\n  imports: [CommonModule, DocsBreadcrumbComponent, DocsNavLinksComponent, DocsTocComponent],\n  template: `\n    <div class=\"docs-page\" [class]=\"props.cssClass\">\n      <div class=\"docs-page__content\" #content>\n        @if (breadcrumbProps()) {\n          <val-docs-breadcrumb [props]=\"breadcrumbProps()!\"></val-docs-breadcrumb>\n        }\n        <header class=\"docs-page__header\">\n          <div class=\"docs-page__title-row\">\n            <h1 class=\"docs-page__title\">{{ props.title }}</h1>\n            @if (props.badge) {\n              <span\n                class=\"docs-page__badge\"\n                [class.docs-page__badge--success]=\"props.badgeColor === 'success'\"\n                [class.docs-page__badge--warning]=\"props.badgeColor === 'warning'\"\n                [class.docs-page__badge--danger]=\"props.badgeColor === 'danger'\"\n              >\n                {{ props.badge }}\n              </span>\n            }\n          </div>\n          @if (props.lead) {\n            <p class=\"docs-page__lead\">{{ props.lead }}</p>\n          }\n        </header>\n\n        <div class=\"docs-page__sections\">\n          <ng-content></ng-content>\n        </div>\n\n        @if (showNavLinks()) {\n          <val-docs-nav-links [props]=\"navLinksProps()\"></val-docs-nav-links>\n        }\n      </div>\n\n      @if (!props.toc?.hide) {\n        <aside class=\"docs-page__toc\">\n          <val-docs-toc [props]=\"tocProps()\"></val-docs-toc>\n        </aside>\n      }\n    </div>\n  `,\n  styles: [`\n    /* Main layout */\n    .docs-page {\n      display: grid;\n      grid-template-columns: 1fr;\n      gap: 2rem;\n      max-width: 1400px;\n      margin: 0 auto;\n      padding: 2rem 1.5rem;\n    }\n\n    @media (min-width: 1200px) {\n      .docs-page {\n        grid-template-columns: 1fr 220px;\n        padding: 2rem;\n      }\n    }\n\n    .docs-page__content {\n      min-width: 0;\n      max-width: 900px;\n    }\n\n    val-docs-breadcrumb {\n      display: block;\n      margin-bottom: 1rem;\n    }\n\n    .docs-page__header {\n      margin-bottom: 2rem;\n    }\n\n    .docs-page__title-row {\n      display: flex;\n      align-items: center;\n      gap: 0.75rem;\n      flex-wrap: wrap;\n    }\n\n    .docs-page__title {\n      margin: 0;\n      font-size: 2rem;\n      font-weight: 700;\n      color: var(--ion-text-color, #1a1a1a);\n      line-height: 1.2;\n    }\n\n    @media (min-width: 768px) {\n      .docs-page__title {\n        font-size: 2.5rem;\n      }\n    }\n\n    .docs-page__badge {\n      display: inline-flex;\n      align-items: center;\n      padding: 0.25rem 0.5rem;\n      font-size: 0.6875rem;\n      font-weight: 500;\n      text-transform: uppercase;\n      letter-spacing: 0.03em;\n      border-radius: 4px;\n      background: rgba(0, 0, 0, 0.04);\n      color: #888;\n    }\n\n    .docs-page__badge--success {\n      background: var(--ion-color-success-tint, #e8f5e9);\n      color: var(--ion-color-success-shade, #2e7d32);\n    }\n\n    .docs-page__badge--warning {\n      background: var(--ion-color-warning-tint, #fff3e0);\n      color: var(--ion-color-warning-shade, #e65100);\n    }\n\n    .docs-page__badge--danger {\n      background: var(--ion-color-danger-tint, #ffebee);\n      color: var(--ion-color-danger-shade, #c62828);\n    }\n\n    .docs-page__lead {\n      margin: 1rem 0 0;\n      font-size: 1.125rem;\n      line-height: 1.7;\n      color: var(--ion-color-medium, #666);\n    }\n\n    .docs-page__sections > *:last-child {\n      margin-bottom: 0;\n    }\n\n    /* TOC - Hidden on mobile, visible on desktop */\n    .docs-page__toc {\n      display: none;\n    }\n\n    @media (min-width: 1200px) {\n      .docs-page__toc {\n        display: block;\n        position: sticky;\n        top: 2rem;\n        height: fit-content;\n        max-height: calc(100vh - 4rem);\n        overflow-y: auto;\n      }\n    }\n\n    /* Content typography styles */\n    .docs-page__sections h2 {\n      font-size: 1.5rem;\n      font-weight: 600;\n      margin: 0 0 1rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n      scroll-margin-top: 2rem;\n    }\n\n    .docs-page__sections h3 {\n      font-size: 1.125rem;\n      font-weight: 600;\n      margin: 1.5rem 0 1rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections h4 {\n      font-size: 1rem;\n      font-weight: 600;\n      margin: 1.25rem 0 0.75rem 0;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections p {\n      line-height: 1.7;\n      color: var(--ion-text-color, #1a1a1a);\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections ul,\n    .docs-page__sections ol {\n      padding-left: 1.5rem;\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections li {\n      margin-bottom: 0.5rem;\n      line-height: 1.6;\n      color: var(--ion-text-color, #1a1a1a);\n    }\n\n    .docs-page__sections a {\n      color: var(--ion-color-primary, #3880ff);\n      text-decoration: none;\n    }\n\n    .docs-page__sections a:hover {\n      text-decoration: underline;\n    }\n\n    .docs-page__sections code:not([class*='language-']) {\n      background: rgba(0, 0, 0, 0.06);\n      padding: 0.125rem 0.375rem;\n      border-radius: 4px;\n      font-family: 'SF Mono', 'Fira Code', Consolas, monospace;\n      font-size: 0.875em;\n    }\n\n    .docs-page__sections pre:not([class*='language-']) {\n      background: rgba(0, 0, 0, 0.04);\n      padding: 1rem;\n      border-radius: 8px;\n      overflow-x: auto;\n      margin: 0 0 1rem 0;\n    }\n\n    .docs-page__sections pre:not([class*='language-']) code {\n      background: none;\n      padding: 0;\n    }\n\n    .docs-page__sections table {\n      width: 100%;\n      border-collapse: collapse;\n      margin: 0 0 1rem 0;\n      font-size: 0.875rem;\n    }\n\n    .docs-page__sections th,\n    .docs-page__sections td {\n      padding: 0.75rem;\n      text-align: left;\n      border-bottom: 1px solid rgba(0, 0, 0, 0.1);\n    }\n\n    .docs-page__sections th {\n      font-weight: 600;\n      background: rgba(0, 0, 0, 0.02);\n    }\n\n    .docs-page__sections blockquote {\n      margin: 0 0 1rem 0;\n      padding: 1rem 1.5rem;\n      border-left: 4px solid var(--ion-color-primary, #3880ff);\n      background: rgba(0, 0, 0, 0.02);\n      border-radius: 0 8px 8px 0;\n    }\n\n    .docs-page__sections blockquote p:last-child {\n      margin-bottom: 0;\n    }\n\n    .docs-page__sections img {\n      max-width: 100%;\n      height: auto;\n      border-radius: 8px;\n    }\n\n    .docs-page__sections hr {\n      border: none;\n      border-top: 1px solid rgba(0, 0, 0, 0.1);\n      margin: 2rem 0;\n    }\n\n    .docs-page__sections strong {\n      font-weight: 600;\n    }\n\n    .docs-page__sections section {\n      margin-bottom: 2rem;\n    }\n\n    /* Dark mode */\n    :host-context(.dark) .docs-page__badge,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge {\n      background: rgba(255, 255, 255, 0.06);\n      color: #999;\n    }\n\n    :host-context(.dark) .docs-page__badge--success,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--success {\n      background: rgba(46, 125, 50, 0.2);\n      color: #81c784;\n    }\n\n    :host-context(.dark) .docs-page__badge--warning,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--warning {\n      background: rgba(230, 81, 0, 0.2);\n      color: #ffb74d;\n    }\n\n    :host-context(.dark) .docs-page__badge--danger,\n    :host-context([color-scheme=\"dark\"]) .docs-page__badge--danger {\n      background: rgba(198, 40, 40, 0.2);\n      color: #e57373;\n    }\n\n    :host-context(.dark) .docs-page__sections code:not([class*='language-']),\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections code:not([class*='language-']) {\n      background: rgba(255, 255, 255, 0.1);\n    }\n\n    :host-context(.dark) .docs-page__sections pre:not([class*='language-']),\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections pre:not([class*='language-']) {\n      background: rgba(255, 255, 255, 0.06);\n    }\n\n    :host-context(.dark) .docs-page__sections th,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections th {\n      background: rgba(255, 255, 255, 0.04);\n    }\n\n    :host-context(.dark) .docs-page__sections th,\n    :host-context(.dark) .docs-page__sections td,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections th,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections td {\n      border-color: rgba(255, 255, 255, 0.1);\n    }\n\n    :host-context(.dark) .docs-page__sections blockquote,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections blockquote {\n      background: rgba(255, 255, 255, 0.04);\n    }\n\n    :host-context(.dark) .docs-page__sections hr,\n    :host-context([color-scheme=\"dark\"]) .docs-page__sections hr {\n      border-color: rgba(255, 255, 255, 0.1);\n    }\n  `],\n})\nexport class DocsPageComponent implements AfterViewInit, OnDestroy {\n  private elementRef = inject(ElementRef);\n\n  // Use signal internally so computed properties react to changes\n  private _props = signal<DocsPageMetadata>({ title: '' });\n\n  @Input()\n  set props(value: DocsPageMetadata) {\n    this._props.set(value);\n  }\n  get props(): DocsPageMetadata {\n    return this._props();\n  }\n\n  private tocItems = signal<{ id: string; label: string; level: number }[]>([]);\n  private observer: MutationObserver | null = null;\n\n  ngAfterViewInit(): void {\n    // Initial scan\n    this.scanForSections();\n\n    // Watch for dynamic content changes\n    this.observer = new MutationObserver(() => {\n      this.scanForSections();\n    });\n\n    const contentEl = this.elementRef.nativeElement.querySelector('.docs-page__sections');\n    if (contentEl) {\n      this.observer.observe(contentEl, { childList: true, subtree: true });\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.observer?.disconnect();\n  }\n\n  private scanForSections(): void {\n    const contentEl = this.elementRef.nativeElement.querySelector('.docs-page__sections');\n    if (!contentEl) return;\n\n    const headings = contentEl.querySelectorAll('h2[id], h3[id], section[id] > h2, section[id] > h3');\n    const items: { id: string; label: string; level: number }[] = [];\n\n    headings.forEach((heading: Element) => {\n      // Get ID from heading or parent section\n      let id = heading.id;\n      if (!id && heading.parentElement?.tagName === 'SECTION') {\n        id = heading.parentElement.id;\n      }\n\n      if (id) {\n        const level = heading.tagName === 'H2' ? 2 : 3;\n        items.push({ id, label: heading.textContent?.trim() || '', level });\n      }\n    });\n\n    this.tocItems.set(items);\n  }\n\n  tocProps = computed<DocsTocMetadata>(() => {\n    const props = this._props();\n    return {\n      title: props.toc?.title ?? 'On this page',\n      items: this.tocItems(),\n    };\n  });\n\n  navLinksProps = computed<DocsNavLinksMetadata>(() => {\n    const props = this._props();\n    return {\n      previous: props.previousPage\n        ? {\n            // Don't pass label - let DocsNavLinksComponent use its internal i18n-reactive labels\n            title: props.previousPage.title,\n            route: props.previousPage.route,\n          }\n        : undefined,\n      next: props.nextPage\n        ? {\n            // Don't pass label - let DocsNavLinksComponent use its internal i18n-reactive labels\n            title: props.nextPage.title,\n            route: props.nextPage.route,\n          }\n        : undefined,\n    };\n  });\n\n  showNavLinks = computed(() => {\n    const props = this._props();\n    return !!props.previousPage || !!props.nextPage;\n  });\n\n  breadcrumbProps = computed<DocsBreadcrumbMetadata | null>(() => {\n    const props = this._props();\n    if (!props.breadcrumb?.items?.length) {\n      return null;\n    }\n    return {\n      items: props.breadcrumb.items,\n      showHome: props.breadcrumb.showHome ?? false,\n      homeRoute: props.breadcrumb.homeRoute ?? ['/'],\n    };\n  });\n}\n"]}
@@ -37628,7 +37628,7 @@ class DocsBreadcrumbComponent {
37628
37628
  }
37629
37629
  </ol>
37630
37630
  </nav>
37631
- `, isInline: true, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:.25rem .5rem;border:none;background:transparent;font-size:.8125rem;color:var(--ion-color-medium, #666);text-decoration:none;border-radius:4px;cursor:pointer;transition:all .15s ease;&:hover{background:#0000000d;color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{padding:.25rem;ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.8125rem;font-weight:500;color:var(--ion-text-color, #1a1a1a);padding:.25rem .5rem}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{background:#ffffff0d;color:#f4f5f8}&__current{color:#f4f5f8}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
37631
+ `, isInline: true, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease;&:hover{color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{color:#f4f5f8}&__current{color:#f4f5f8}}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }] }); }
37632
37632
  }
37633
37633
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsBreadcrumbComponent, decorators: [{
37634
37634
  type: Component,
@@ -37691,7 +37691,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
37691
37691
  }
37692
37692
  </ol>
37693
37693
  </nav>
37694
- `, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:.25rem .5rem;border:none;background:transparent;font-size:.8125rem;color:var(--ion-color-medium, #666);text-decoration:none;border-radius:4px;cursor:pointer;transition:all .15s ease;&:hover{background:#0000000d;color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{padding:.25rem;ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.8125rem;font-weight:500;color:var(--ion-text-color, #1a1a1a);padding:.25rem .5rem}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{background:#ffffff0d;color:#f4f5f8}&__current{color:#f4f5f8}}}\n"] }]
37694
+ `, styles: [".docs-breadcrumb{font-family:var(--ion-font-family, system-ui, sans-serif);&__list{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem;list-style:none;margin:0;padding:0}&__item{display:flex;align-items:center;gap:.25rem}&__link{display:flex;align-items:center;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease;&:hover{color:var(--ion-text-color, #1a1a1a)}&:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}&--home{ion-icon{font-size:1rem}}}&__separator{display:flex;align-items:center;color:var(--ion-color-medium, #666);font-size:.75rem;ion-icon{font-size:.75rem}}&__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}}// Dark mode :host-context(.dark),:host-context([color-scheme=\"dark\"]){.docs-breadcrumb{&__link:hover{color:#f4f5f8}&__current{color:#f4f5f8}}}\n"] }]
37695
37695
  }], ctorParameters: () => [{ type: i1$1.Router }], propDecorators: { props: [{
37696
37696
  type: Input
37697
37697
  }], navigate: [{
@@ -37916,7 +37916,7 @@ class DocsPageComponent {
37916
37916
  }
37917
37917
  return {
37918
37918
  items: props.breadcrumb.items,
37919
- showHome: props.breadcrumb.showHome ?? true,
37919
+ showHome: props.breadcrumb.showHome ?? false,
37920
37920
  homeRoute: props.breadcrumb.homeRoute ?? ['/'],
37921
37921
  };
37922
37922
  });