valtech-components 2.0.609 → 2.0.611
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/molecules/docs-breadcrumb/docs-breadcrumb.component.mjs +3 -3
- package/esm2022/lib/components/templates/docs-shell/docs-shell.component.mjs +334 -0
- package/esm2022/lib/components/templates/docs-shell/types.mjs +2 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/valtech-components.mjs +328 -5
- package/fesm2022/valtech-components.mjs.map +1 -1
- package/lib/components/atoms/rights-footer/rights-footer.component.d.ts +1 -1
- package/lib/components/organisms/article/article.component.d.ts +1 -1
- package/lib/components/organisms/toolbar/toolbar.component.d.ts +1 -1
- package/lib/components/templates/docs-shell/docs-shell.component.d.ts +33 -0
- package/lib/components/templates/docs-shell/types.d.ts +127 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -81,7 +81,7 @@ export class DocsBreadcrumbComponent {
|
|
|
81
81
|
}
|
|
82
82
|
</ol>
|
|
83
83
|
</nav>
|
|
84
|
-
`, isInline: true, styles: ["
|
|
84
|
+
`, isInline: true, styles: [":host{display:block;font-family:var(--ion-font-family, system-ui, sans-serif)}:host .docs-breadcrumb__list{display:flex!important;flex-direction:row!important;flex-wrap:wrap;align-items:center;gap:.5rem;list-style:none!important;list-style-type:none!important;margin:0!important;padding:0!important}:host .docs-breadcrumb__item{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;margin:0!important;padding:0!important}:host .docs-breadcrumb__link{display:inline;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease}:host .docs-breadcrumb__link:hover{color:var(--ion-text-color, #1a1a1a)}:host .docs-breadcrumb__link:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}:host .docs-breadcrumb__separator{color:var(--ion-color-medium, #666);font-size:.875rem}:host .docs-breadcrumb__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}:host-context(.dark) .docs-breadcrumb__link:hover,:host-context([color-scheme=\"dark\"]) .docs-breadcrumb__link:hover{color:#f4f5f8}:host-context(.dark) .docs-breadcrumb__current,:host-context([color-scheme=\"dark\"]) .docs-breadcrumb__current{color:#f4f5f8}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
85
85
|
}
|
|
86
86
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsBreadcrumbComponent, decorators: [{
|
|
87
87
|
type: Component,
|
|
@@ -135,10 +135,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
135
135
|
}
|
|
136
136
|
</ol>
|
|
137
137
|
</nav>
|
|
138
|
-
`, styles: ["
|
|
138
|
+
`, styles: [":host{display:block;font-family:var(--ion-font-family, system-ui, sans-serif)}:host .docs-breadcrumb__list{display:flex!important;flex-direction:row!important;flex-wrap:wrap;align-items:center;gap:.5rem;list-style:none!important;list-style-type:none!important;margin:0!important;padding:0!important}:host .docs-breadcrumb__item{display:flex!important;flex-direction:row!important;align-items:center;gap:.5rem;margin:0!important;padding:0!important}:host .docs-breadcrumb__link{display:inline;padding:0;border:none;background:transparent;font-size:.875rem;color:var(--ion-color-medium, #666);text-decoration:none;cursor:pointer;transition:color .15s ease}:host .docs-breadcrumb__link:hover{color:var(--ion-text-color, #1a1a1a)}:host .docs-breadcrumb__link:focus-visible{outline:2px solid #1a1a1a;outline-offset:2px}:host .docs-breadcrumb__separator{color:var(--ion-color-medium, #666);font-size:.875rem}:host .docs-breadcrumb__current{font-size:.875rem;font-weight:600;color:var(--ion-text-color, #1a1a1a)}:host-context(.dark) .docs-breadcrumb__link:hover,:host-context([color-scheme=\"dark\"]) .docs-breadcrumb__link:hover{color:#f4f5f8}:host-context(.dark) .docs-breadcrumb__current,:host-context([color-scheme=\"dark\"]) .docs-breadcrumb__current{color:#f4f5f8}\n"] }]
|
|
139
139
|
}], ctorParameters: () => [{ type: i1.Router }], propDecorators: { props: [{
|
|
140
140
|
type: Input
|
|
141
141
|
}], navigate: [{
|
|
142
142
|
type: Output
|
|
143
143
|
}] } });
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG9jcy1icmVhZGNydW1iLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY29tcG9uZW50cy9tb2xlY3VsZXMvZG9jcy1icmVhZGNydW1iL2RvY3MtYnJlYWRjcnVtYi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQUl2RTs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUErSEgsTUFBTSxPQUFPLHVCQUF1QjtJQUtsQyxZQUFvQixNQUFjO1FBQWQsV0FBTSxHQUFOLE1BQU0sQ0FBUTtRQUp6QixVQUFLLEdBQTJCLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDO1FBRTdDLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBWSxDQUFDO0lBRWIsQ0FBQztJQUV0QyxVQUFVLENBQUMsS0FBZTtRQUN4QixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUMxQixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QixDQUFDOytHQVZVLHVCQUF1QjttR0FBdkIsdUJBQXVCLDhJQTFIeEI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBa0RULDB6Q0FuRFMsWUFBWTs7NEZBMkhYLHVCQUF1QjtrQkE5SG5DLFNBQVM7K0JBQ0UscUJBQXFCLGNBQ25CLElBQUksV0FDUCxDQUFDLFlBQVksQ0FBQyxZQUNiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQWtEVDsyRUF5RVEsS0FBSztzQkFBYixLQUFLO2dCQUVJLFFBQVE7c0JBQWpCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT3V0cHV0LCBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBEb2NzQnJlYWRjcnVtYk1ldGFkYXRhLCBEb2NzQnJlYWRjcnVtYkl0ZW0gfSBmcm9tICcuL3R5cGVzJztcblxuLyoqXG4gKiB2YWwtZG9jcy1icmVhZGNydW1iXG4gKlxuICogQSBicmVhZGNydW1iIG5hdmlnYXRpb24gY29tcG9uZW50IGZvciBkb2N1bWVudGF0aW9uLlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBodG1sXG4gKiA8dmFsLWRvY3MtYnJlYWRjcnVtYlxuICogICBbcHJvcHNdPVwie1xuICogICAgIHNob3dIb21lOiB0cnVlLFxuICogICAgIGl0ZW1zOiBbXG4gKiAgICAgICB7IGxhYmVsOiAnQ29tcG9uZW50cycsIHJvdXRlOiBbJy9kb2NzJywgJ2NvbXBvbmVudHMnXSB9LFxuICogICAgICAgeyBsYWJlbDogJ0J1dHRvbicgfVxuICogICAgIF1cbiAqICAgfVwiXG4gKiA+PC92YWwtZG9jcy1icmVhZGNydW1iPlxuICogYGBgXG4gKi9cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3ZhbC1kb2NzLWJyZWFkY3J1bWInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgdGVtcGxhdGU6IGBcbiAgICA8bmF2XG4gICAgICBjbGFzcz1cImRvY3MtYnJlYWRjcnVtYlwiXG4gICAgICBbY2xhc3NdPVwicHJvcHMuY3NzQ2xhc3NcIlxuICAgICAgYXJpYS1sYWJlbD1cIkJyZWFkY3J1bWJcIlxuICAgID5cbiAgICAgIDxvbCBjbGFzcz1cImRvY3MtYnJlYWRjcnVtYl9fbGlzdFwiPlxuICAgICAgICBAaWYgKHByb3BzLnNob3dIb21lKSB7XG4gICAgICAgICAgPGxpIGNsYXNzPVwiZG9jcy1icmVhZGNydW1iX19pdGVtXCI+XG4gICAgICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICBjbGFzcz1cImRvY3MtYnJlYWRjcnVtYl9fbGlua1wiXG4gICAgICAgICAgICAgIChjbGljayk9XCJvbk5hdmlnYXRlKHByb3BzLmhvbWVSb3V0ZSB8fCBbJy8nXSlcIlxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7eyBwcm9wcy5ob21lTGFiZWwgfHwgJ0hvbWUnIH19XG4gICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiZG9jcy1icmVhZGNydW1iX19zZXBhcmF0b3JcIiBhcmlhLWhpZGRlbj1cInRydWVcIj5cbiAgICAgICAgICAgICAge3sgcHJvcHMuc2VwYXJhdG9yIHx8ICc+JyB9fVxuICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDwvbGk+XG4gICAgICAgIH1cblxuICAgICAgICBAZm9yIChpdGVtIG9mIHByb3BzLml0ZW1zOyB0cmFjayBpdGVtLmxhYmVsOyBsZXQgbGFzdCA9ICRsYXN0KSB7XG4gICAgICAgICAgPGxpIGNsYXNzPVwiZG9jcy1icmVhZGNydW1iX19pdGVtXCI+XG4gICAgICAgICAgICBAaWYgKGl0ZW0ucm91dGUgJiYgIWxhc3QpIHtcbiAgICAgICAgICAgICAgPGJ1dHRvblxuICAgICAgICAgICAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgICAgICAgICAgIGNsYXNzPVwiZG9jcy1icmVhZGNydW1iX19saW5rXCJcbiAgICAgICAgICAgICAgICAoY2xpY2spPVwib25OYXZpZ2F0ZShpdGVtLnJvdXRlKVwiXG4gICAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7eyBpdGVtLmxhYmVsIH19XG4gICAgICAgICAgICAgIDwvYnV0dG9uPlxuICAgICAgICAgICAgfSBAZWxzZSB7XG4gICAgICAgICAgICAgIDxzcGFuXG4gICAgICAgICAgICAgICAgY2xhc3M9XCJkb2NzLWJyZWFkY3J1bWJfX2N1cnJlbnRcIlxuICAgICAgICAgICAgICAgIGFyaWEtY3VycmVudD1cInBhZ2VcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3sgaXRlbS5sYWJlbCB9fVxuICAgICAgICAgICAgICA8L3NwYW4+XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIEBpZiAoIWxhc3QpIHtcbiAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJkb2NzLWJyZWFkY3J1bWJfX3NlcGFyYXRvclwiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPlxuICAgICAgICAgICAgICAgIHt7IHByb3BzLnNlcGFyYXRvciB8fCAnPicgfX1cbiAgICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgICAgfVxuICAgICAgICAgIDwvbGk+XG4gICAgICAgIH1cbiAgICAgIDwvb2w+XG4gICAgPC9uYXY+XG4gIGAsXG4gIHN0eWxlczogW2BcbiAgICA6aG9zdCB7XG4gICAgICBkaXNwbGF5OiBibG9jaztcbiAgICAgIGZvbnQtZmFtaWx5OiB2YXIoLS1pb24tZm9udC1mYW1pbHksIHN5c3RlbS11aSwgc2Fucy1zZXJpZik7XG4gICAgfVxuXG4gICAgOmhvc3QgLmRvY3MtYnJlYWRjcnVtYl9fbGlzdCB7XG4gICAgICBkaXNwbGF5OiBmbGV4ICFpbXBvcnRhbnQ7XG4gICAgICBmbGV4LWRpcmVjdGlvbjogcm93ICFpbXBvcnRhbnQ7XG4gICAgICBmbGV4LXdyYXA6IHdyYXA7XG4gICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgZ2FwOiAwLjVyZW07XG4gICAgICBsaXN0LXN0eWxlOiBub25lICFpbXBvcnRhbnQ7XG4gICAgICBsaXN0LXN0eWxlLXR5cGU6IG5vbmUgIWltcG9ydGFudDtcbiAgICAgIG1hcmdpbjogMCAhaW1wb3J0YW50O1xuICAgICAgcGFkZGluZzogMCAhaW1wb3J0YW50O1xuICAgIH1cblxuICAgIDpob3N0IC5kb2NzLWJyZWFkY3J1bWJfX2l0ZW0ge1xuICAgICAgZGlzcGxheTogZmxleCAhaW1wb3J0YW50O1xuICAgICAgZmxleC1kaXJlY3Rpb246IHJvdyAhaW1wb3J0YW50O1xuICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIGdhcDogMC41cmVtO1xuICAgICAgbWFyZ2luOiAwICFpbXBvcnRhbnQ7XG4gICAgICBwYWRkaW5nOiAwICFpbXBvcnRhbnQ7XG4gICAgfVxuXG4gICAgOmhvc3QgLmRvY3MtYnJlYWRjcnVtYl9fbGluayB7XG4gICAgICBkaXNwbGF5OiBpbmxpbmU7XG4gICAgICBwYWRkaW5nOiAwO1xuICAgICAgYm9yZGVyOiBub25lO1xuICAgICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgICBmb250LXNpemU6IDAuODc1cmVtO1xuICAgICAgY29sb3I6IHZhcigtLWlvbi1jb2xvci1tZWRpdW0sICM2NjYpO1xuICAgICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgdHJhbnNpdGlvbjogY29sb3IgMC4xNXMgZWFzZTtcbiAgICB9XG5cbiAgICA6aG9zdCAuZG9jcy1icmVhZGNydW1iX19saW5rOmhvdmVyIHtcbiAgICAgIGNvbG9yOiB2YXIoLS1pb24tdGV4dC1jb2xvciwgIzFhMWExYSk7XG4gICAgfVxuXG4gICAgOmhvc3QgLmRvY3MtYnJlYWRjcnVtYl9fbGluazpmb2N1cy12aXNpYmxlIHtcbiAgICAgIG91dGxpbmU6IDJweCBzb2xpZCAjMWExYTFhO1xuICAgICAgb3V0bGluZS1vZmZzZXQ6IDJweDtcbiAgICB9XG5cbiAgICA6aG9zdCAuZG9jcy1icmVhZGNydW1iX19zZXBhcmF0b3Ige1xuICAgICAgY29sb3I6IHZhcigtLWlvbi1jb2xvci1tZWRpdW0sICM2NjYpO1xuICAgICAgZm9udC1zaXplOiAwLjg3NXJlbTtcbiAgICB9XG5cbiAgICA6aG9zdCAuZG9jcy1icmVhZGNydW1iX19jdXJyZW50IHtcbiAgICAgIGZvbnQtc2l6ZTogMC44NzVyZW07XG4gICAgICBmb250LXdlaWdodDogNjAwO1xuICAgICAgY29sb3I6IHZhcigtLWlvbi10ZXh0LWNvbG9yLCAjMWExYTFhKTtcbiAgICB9XG5cbiAgICAvKiBEYXJrIG1vZGUgKi9cbiAgICA6aG9zdC1jb250ZXh0KC5kYXJrKSAuZG9jcy1icmVhZGNydW1iX19saW5rOmhvdmVyLFxuICAgIDpob3N0LWNvbnRleHQoW2NvbG9yLXNjaGVtZT0nZGFyayddKSAuZG9jcy1icmVhZGNydW1iX19saW5rOmhvdmVyIHtcbiAgICAgIGNvbG9yOiAjZjRmNWY4O1xuICAgIH1cblxuICAgIDpob3N0LWNvbnRleHQoLmRhcmspIC5kb2NzLWJyZWFkY3J1bWJfX2N1cnJlbnQsXG4gICAgOmhvc3QtY29udGV4dChbY29sb3Itc2NoZW1lPSdkYXJrJ10pIC5kb2NzLWJyZWFkY3J1bWJfX2N1cnJlbnQge1xuICAgICAgY29sb3I6ICNmNGY1Zjg7XG4gICAgfVxuICBgXSxcbn0pXG5leHBvcnQgY2xhc3MgRG9jc0JyZWFkY3J1bWJDb21wb25lbnQge1xuICBASW5wdXQoKSBwcm9wczogRG9jc0JyZWFkY3J1bWJNZXRhZGF0YSA9IHsgaXRlbXM6IFtdIH07XG5cbiAgQE91dHB1dCgpIG5hdmlnYXRlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmdbXT4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlcjogUm91dGVyKSB7fVxuXG4gIG9uTmF2aWdhdGUocm91dGU6IHN0cmluZ1tdKTogdm9pZCB7XG4gICAgdGhpcy5uYXZpZ2F0ZS5lbWl0KHJvdXRlKTtcbiAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShyb3V0ZSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,334 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, inject, signal, computed } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { RouterModule } from '@angular/router';
|
|
4
|
+
import { IonSplitPane, IonMenu, IonHeader, IonToolbar, IonContent, IonIcon, IonMenuButton, IonButtons, MenuController, } from '@ionic/angular/standalone';
|
|
5
|
+
import { addIcons } from 'ionicons';
|
|
6
|
+
import { chevronDownOutline, chevronForwardOutline, closeOutline, } from 'ionicons/icons';
|
|
7
|
+
import { DocsSearchComponent } from '../../molecules/docs-search/docs-search.component';
|
|
8
|
+
import { CompanyFooterComponent } from '../../organisms/company-footer/company-footer.component';
|
|
9
|
+
import { DocsNavigationService } from '../../../services/docs/docs-navigation.service';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/router";
|
|
12
|
+
addIcons({
|
|
13
|
+
chevronDownOutline,
|
|
14
|
+
chevronForwardOutline,
|
|
15
|
+
closeOutline,
|
|
16
|
+
});
|
|
17
|
+
/**
|
|
18
|
+
* val-docs-shell
|
|
19
|
+
*
|
|
20
|
+
* A complete documentation shell with sidebar navigation, search, and content area.
|
|
21
|
+
* Use this component as the root layout for documentation pages.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```html
|
|
25
|
+
* <val-docs-shell [props]="shellConfig">
|
|
26
|
+
* <router-outlet></router-outlet>
|
|
27
|
+
* </val-docs-shell>
|
|
28
|
+
* ```
|
|
29
|
+
*/
|
|
30
|
+
export class DocsShellComponent {
|
|
31
|
+
constructor() {
|
|
32
|
+
this.menuCtrl = inject(MenuController);
|
|
33
|
+
this.docsNav = inject(DocsNavigationService);
|
|
34
|
+
this.props = {
|
|
35
|
+
logo: { alt: 'Logo' },
|
|
36
|
+
sections: [],
|
|
37
|
+
};
|
|
38
|
+
this.navigate = new EventEmitter();
|
|
39
|
+
// Internal state for expanded sections
|
|
40
|
+
this._sectionsState = signal([]);
|
|
41
|
+
this.sectionsState = computed(() => {
|
|
42
|
+
// Initialize from props if empty
|
|
43
|
+
if (this._sectionsState().length === 0 && this.props.sections.length > 0) {
|
|
44
|
+
return this.props.sections.map(s => ({
|
|
45
|
+
...s,
|
|
46
|
+
expanded: s.expanded ?? true,
|
|
47
|
+
}));
|
|
48
|
+
}
|
|
49
|
+
return this._sectionsState().length > 0 ? this._sectionsState() : this.props.sections;
|
|
50
|
+
});
|
|
51
|
+
this.searchProps = computed(() => ({
|
|
52
|
+
placeholder: this.props.search?.placeholder || 'Search...',
|
|
53
|
+
showShortcut: this.props.search?.showShortcut ?? true,
|
|
54
|
+
sections: this.buildSearchSections(),
|
|
55
|
+
}));
|
|
56
|
+
}
|
|
57
|
+
ngOnChanges() {
|
|
58
|
+
// Update sections state when props change
|
|
59
|
+
if (this.props.sections.length > 0) {
|
|
60
|
+
this._sectionsState.set(this.props.sections.map(s => ({
|
|
61
|
+
...s,
|
|
62
|
+
expanded: s.expanded ?? true,
|
|
63
|
+
})));
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
toggleSection(section) {
|
|
67
|
+
this._sectionsState.update(sections => sections.map(s => s.key === section.key ? { ...s, expanded: !s.expanded } : s));
|
|
68
|
+
}
|
|
69
|
+
async closeMenu() {
|
|
70
|
+
await this.menuCtrl.close('docs-menu');
|
|
71
|
+
this.docsNav.scrollToTop();
|
|
72
|
+
}
|
|
73
|
+
onNavigate(route) {
|
|
74
|
+
this.navigate.emit(route);
|
|
75
|
+
this.docsNav.navigateAndScroll(route);
|
|
76
|
+
this.menuCtrl.close('docs-menu');
|
|
77
|
+
}
|
|
78
|
+
buildSearchSections() {
|
|
79
|
+
return this.props.sections.map(section => ({
|
|
80
|
+
title: section.title,
|
|
81
|
+
items: section.children.map(child => ({
|
|
82
|
+
label: child.label,
|
|
83
|
+
route: child.route,
|
|
84
|
+
description: `${section.title} > ${child.label}`,
|
|
85
|
+
})),
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsShellComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
89
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: DocsShellComponent, isStandalone: true, selector: "val-docs-shell", inputs: { props: "props" }, outputs: { navigate: "navigate" }, usesOnChanges: true, ngImport: i0, template: `
|
|
90
|
+
<ion-split-pane contentId="docs-content" when="lg">
|
|
91
|
+
<ion-menu contentId="docs-content" type="overlay" menuId="docs-menu">
|
|
92
|
+
<ion-header class="ion-no-border">
|
|
93
|
+
<ion-toolbar>
|
|
94
|
+
<div class="sidebar-header">
|
|
95
|
+
<a [routerLink]="props.logo.route || ['/']" class="logo-link" [attr.aria-label]="props.logo.alt">
|
|
96
|
+
@if (props.logo.cssVariable) {
|
|
97
|
+
<span
|
|
98
|
+
class="sidebar-logo sidebar-logo--css-var"
|
|
99
|
+
role="img"
|
|
100
|
+
[attr.aria-label]="props.logo.alt"
|
|
101
|
+
[style.--logo-var]="'var(' + props.logo.cssVariable + ')'"
|
|
102
|
+
[style.width]="props.logo.width || '10rem'"
|
|
103
|
+
[style.height]="props.logo.height || '3rem'"
|
|
104
|
+
></span>
|
|
105
|
+
} @else if (props.logo.src) {
|
|
106
|
+
<img
|
|
107
|
+
[src]="props.logo.src"
|
|
108
|
+
[alt]="props.logo.alt"
|
|
109
|
+
class="sidebar-logo sidebar-logo--img"
|
|
110
|
+
[style.width]="props.logo.width || '10rem'"
|
|
111
|
+
[style.height]="props.logo.height || '3rem'"
|
|
112
|
+
/>
|
|
113
|
+
}
|
|
114
|
+
</a>
|
|
115
|
+
<button
|
|
116
|
+
type="button"
|
|
117
|
+
class="sidebar-close"
|
|
118
|
+
(click)="closeMenu()"
|
|
119
|
+
aria-label="Close menu"
|
|
120
|
+
>
|
|
121
|
+
<ion-icon name="close-outline"></ion-icon>
|
|
122
|
+
</button>
|
|
123
|
+
</div>
|
|
124
|
+
</ion-toolbar>
|
|
125
|
+
</ion-header>
|
|
126
|
+
|
|
127
|
+
<ion-content>
|
|
128
|
+
<!-- Search -->
|
|
129
|
+
@if (props.search) {
|
|
130
|
+
<div class="search-wrapper">
|
|
131
|
+
<val-docs-search
|
|
132
|
+
[props]="searchProps()"
|
|
133
|
+
(navigate)="onNavigate($event)"
|
|
134
|
+
></val-docs-search>
|
|
135
|
+
</div>
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
<nav class="sidebar-nav">
|
|
139
|
+
@for (section of sectionsState(); track section.key) {
|
|
140
|
+
<div class="nav-section">
|
|
141
|
+
<button
|
|
142
|
+
type="button"
|
|
143
|
+
class="nav-section__header"
|
|
144
|
+
(click)="toggleSection(section)"
|
|
145
|
+
>
|
|
146
|
+
@if (section.icon) {
|
|
147
|
+
<ion-icon [name]="section.icon"></ion-icon>
|
|
148
|
+
}
|
|
149
|
+
<span>{{ section.title }}</span>
|
|
150
|
+
<ion-icon
|
|
151
|
+
[name]="section.expanded ? 'chevron-down-outline' : 'chevron-forward-outline'"
|
|
152
|
+
class="nav-chevron"
|
|
153
|
+
></ion-icon>
|
|
154
|
+
</button>
|
|
155
|
+
|
|
156
|
+
@if (section.expanded) {
|
|
157
|
+
<ul class="nav-links">
|
|
158
|
+
@for (link of section.children; track link.label) {
|
|
159
|
+
<li>
|
|
160
|
+
<a
|
|
161
|
+
[routerLink]="link.route"
|
|
162
|
+
routerLinkActive="active"
|
|
163
|
+
(click)="closeMenu()"
|
|
164
|
+
>
|
|
165
|
+
{{ link.label }}
|
|
166
|
+
@if (link.badge) {
|
|
167
|
+
<span
|
|
168
|
+
class="nav-badge"
|
|
169
|
+
[class.nav-badge--success]="link.badgeColor === 'success'"
|
|
170
|
+
>{{ link.badge }}</span>
|
|
171
|
+
}
|
|
172
|
+
</a>
|
|
173
|
+
</li>
|
|
174
|
+
}
|
|
175
|
+
</ul>
|
|
176
|
+
}
|
|
177
|
+
</div>
|
|
178
|
+
}
|
|
179
|
+
</nav>
|
|
180
|
+
</ion-content>
|
|
181
|
+
</ion-menu>
|
|
182
|
+
|
|
183
|
+
<div class="ion-page" id="docs-content">
|
|
184
|
+
<ion-header class="ion-no-border mobile-header">
|
|
185
|
+
<ion-toolbar>
|
|
186
|
+
<ion-buttons slot="start">
|
|
187
|
+
<ion-menu-button menu="docs-menu" color="dark"></ion-menu-button>
|
|
188
|
+
</ion-buttons>
|
|
189
|
+
</ion-toolbar>
|
|
190
|
+
</ion-header>
|
|
191
|
+
|
|
192
|
+
<main class="docs-main-scroll">
|
|
193
|
+
<ng-content></ng-content>
|
|
194
|
+
@if (props.footer) {
|
|
195
|
+
<val-company-footer [props]="props.footer"></val-company-footer>
|
|
196
|
+
}
|
|
197
|
+
</main>
|
|
198
|
+
</div>
|
|
199
|
+
</ion-split-pane>
|
|
200
|
+
`, isInline: true, styles: [":host{display:block;height:100%}ion-split-pane{height:100%;--side-width: var(--docs-sidebar-width, 260px);--side-min-width: var(--docs-sidebar-width, 260px);--side-max-width: var(--docs-sidebar-width, 260px)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}.logo-link{display:flex;align-items:center;gap:.75rem;text-decoration:none;transition:opacity .2s ease}.logo-link:hover{opacity:.8}.sidebar-logo--css-var{display:block;background-image:var(--logo-var);background-size:contain;background-repeat:no-repeat;background-position:left center}.sidebar-logo--img{display:block;object-fit:contain}.sidebar-close{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--ion-text-color, #333);transition:background .2s ease}.sidebar-close:hover{background:#0000000d}.sidebar-close ion-icon{font-size:1.5rem}@media (min-width: 992px){.sidebar-close{display:none}}.search-wrapper{padding:.75rem 1rem;border-bottom:1px solid var(--ion-border-color, #e0e0e0)}.sidebar-nav{padding:.5rem 0}.nav-section__header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#666;cursor:pointer}.nav-section__header:hover{color:var(--ion-text-color)}.nav-section__header span{flex:1;text-align:left}.nav-chevron{font-size:.875rem}.nav-links{list-style:none;margin:0;padding:0}.nav-links a{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem .5rem 2.5rem;font-size:.875rem;color:#555;text-decoration:none;border-left:2px solid transparent}.nav-links a:hover{color:var(--ion-text-color);background:#00000008}.nav-links a.active{color:var(--ion-text-color);font-weight:500;background:#0000000d;border-left-color:var(--ion-color-primary)}.nav-badge{font-size:.625rem;font-weight:500;text-transform:uppercase;padding:.125rem .375rem;border-radius:4px;background:#0000000a;color:#888}.nav-badge--success{background:#e8f5e9;color:#2e7d32}.docs-main-scroll{flex:1;overflow-y:auto;background:var(--ion-background-color)}ion-menu{--width: 100%;--max-width: 100%;--background: var(--ion-background-color);border-right:1px solid var(--ion-border-color, #e0e0e0)}@media (min-width: 992px){ion-menu{--width: var(--docs-sidebar-width, 260px);--max-width: var(--docs-sidebar-width, 260px)}.mobile-header{display:none}}#docs-content{display:flex;flex-direction:column}:host-context(.dark) .nav-badge,:host-context([color-scheme=\"dark\"]) .nav-badge{background:#ffffff0f;color:#999}:host-context(.dark) .nav-badge--success,:host-context([color-scheme=\"dark\"]) .nav-badge--success{background:#2e7d3233;color:#81c784}:host-context(.dark) .sidebar-close:hover,:host-context([color-scheme=\"dark\"]) .sidebar-close:hover{background:#ffffff1a}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i1.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i1.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: IonSplitPane, selector: "ion-split-pane", inputs: ["contentId", "disabled", "when"] }, { kind: "component", type: IonMenu, selector: "ion-menu", inputs: ["contentId", "disabled", "maxEdgeStart", "menuId", "side", "swipeGesture", "type"] }, { kind: "component", type: IonHeader, selector: "ion-header", inputs: ["collapse", "mode", "translucent"] }, { kind: "component", type: IonToolbar, selector: "ion-toolbar", inputs: ["color", "mode"] }, { kind: "component", type: IonContent, selector: "ion-content", inputs: ["color", "fixedSlotPlacement", "forceOverscroll", "fullscreen", "scrollEvents", "scrollX", "scrollY"] }, { kind: "component", type: IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: IonMenuButton, selector: "ion-menu-button", inputs: ["autoHide", "color", "disabled", "menu", "mode", "type"] }, { kind: "component", type: IonButtons, selector: "ion-buttons", inputs: ["collapse"] }, { kind: "component", type: DocsSearchComponent, selector: "val-docs-search", inputs: ["props"], outputs: ["navigate", "search"] }, { kind: "component", type: CompanyFooterComponent, selector: "val-company-footer", inputs: ["props"] }] }); }
|
|
201
|
+
}
|
|
202
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DocsShellComponent, decorators: [{
|
|
203
|
+
type: Component,
|
|
204
|
+
args: [{ selector: 'val-docs-shell', standalone: true, imports: [
|
|
205
|
+
CommonModule,
|
|
206
|
+
RouterModule,
|
|
207
|
+
IonSplitPane,
|
|
208
|
+
IonMenu,
|
|
209
|
+
IonHeader,
|
|
210
|
+
IonToolbar,
|
|
211
|
+
IonContent,
|
|
212
|
+
IonIcon,
|
|
213
|
+
IonMenuButton,
|
|
214
|
+
IonButtons,
|
|
215
|
+
DocsSearchComponent,
|
|
216
|
+
CompanyFooterComponent,
|
|
217
|
+
], template: `
|
|
218
|
+
<ion-split-pane contentId="docs-content" when="lg">
|
|
219
|
+
<ion-menu contentId="docs-content" type="overlay" menuId="docs-menu">
|
|
220
|
+
<ion-header class="ion-no-border">
|
|
221
|
+
<ion-toolbar>
|
|
222
|
+
<div class="sidebar-header">
|
|
223
|
+
<a [routerLink]="props.logo.route || ['/']" class="logo-link" [attr.aria-label]="props.logo.alt">
|
|
224
|
+
@if (props.logo.cssVariable) {
|
|
225
|
+
<span
|
|
226
|
+
class="sidebar-logo sidebar-logo--css-var"
|
|
227
|
+
role="img"
|
|
228
|
+
[attr.aria-label]="props.logo.alt"
|
|
229
|
+
[style.--logo-var]="'var(' + props.logo.cssVariable + ')'"
|
|
230
|
+
[style.width]="props.logo.width || '10rem'"
|
|
231
|
+
[style.height]="props.logo.height || '3rem'"
|
|
232
|
+
></span>
|
|
233
|
+
} @else if (props.logo.src) {
|
|
234
|
+
<img
|
|
235
|
+
[src]="props.logo.src"
|
|
236
|
+
[alt]="props.logo.alt"
|
|
237
|
+
class="sidebar-logo sidebar-logo--img"
|
|
238
|
+
[style.width]="props.logo.width || '10rem'"
|
|
239
|
+
[style.height]="props.logo.height || '3rem'"
|
|
240
|
+
/>
|
|
241
|
+
}
|
|
242
|
+
</a>
|
|
243
|
+
<button
|
|
244
|
+
type="button"
|
|
245
|
+
class="sidebar-close"
|
|
246
|
+
(click)="closeMenu()"
|
|
247
|
+
aria-label="Close menu"
|
|
248
|
+
>
|
|
249
|
+
<ion-icon name="close-outline"></ion-icon>
|
|
250
|
+
</button>
|
|
251
|
+
</div>
|
|
252
|
+
</ion-toolbar>
|
|
253
|
+
</ion-header>
|
|
254
|
+
|
|
255
|
+
<ion-content>
|
|
256
|
+
<!-- Search -->
|
|
257
|
+
@if (props.search) {
|
|
258
|
+
<div class="search-wrapper">
|
|
259
|
+
<val-docs-search
|
|
260
|
+
[props]="searchProps()"
|
|
261
|
+
(navigate)="onNavigate($event)"
|
|
262
|
+
></val-docs-search>
|
|
263
|
+
</div>
|
|
264
|
+
}
|
|
265
|
+
|
|
266
|
+
<nav class="sidebar-nav">
|
|
267
|
+
@for (section of sectionsState(); track section.key) {
|
|
268
|
+
<div class="nav-section">
|
|
269
|
+
<button
|
|
270
|
+
type="button"
|
|
271
|
+
class="nav-section__header"
|
|
272
|
+
(click)="toggleSection(section)"
|
|
273
|
+
>
|
|
274
|
+
@if (section.icon) {
|
|
275
|
+
<ion-icon [name]="section.icon"></ion-icon>
|
|
276
|
+
}
|
|
277
|
+
<span>{{ section.title }}</span>
|
|
278
|
+
<ion-icon
|
|
279
|
+
[name]="section.expanded ? 'chevron-down-outline' : 'chevron-forward-outline'"
|
|
280
|
+
class="nav-chevron"
|
|
281
|
+
></ion-icon>
|
|
282
|
+
</button>
|
|
283
|
+
|
|
284
|
+
@if (section.expanded) {
|
|
285
|
+
<ul class="nav-links">
|
|
286
|
+
@for (link of section.children; track link.label) {
|
|
287
|
+
<li>
|
|
288
|
+
<a
|
|
289
|
+
[routerLink]="link.route"
|
|
290
|
+
routerLinkActive="active"
|
|
291
|
+
(click)="closeMenu()"
|
|
292
|
+
>
|
|
293
|
+
{{ link.label }}
|
|
294
|
+
@if (link.badge) {
|
|
295
|
+
<span
|
|
296
|
+
class="nav-badge"
|
|
297
|
+
[class.nav-badge--success]="link.badgeColor === 'success'"
|
|
298
|
+
>{{ link.badge }}</span>
|
|
299
|
+
}
|
|
300
|
+
</a>
|
|
301
|
+
</li>
|
|
302
|
+
}
|
|
303
|
+
</ul>
|
|
304
|
+
}
|
|
305
|
+
</div>
|
|
306
|
+
}
|
|
307
|
+
</nav>
|
|
308
|
+
</ion-content>
|
|
309
|
+
</ion-menu>
|
|
310
|
+
|
|
311
|
+
<div class="ion-page" id="docs-content">
|
|
312
|
+
<ion-header class="ion-no-border mobile-header">
|
|
313
|
+
<ion-toolbar>
|
|
314
|
+
<ion-buttons slot="start">
|
|
315
|
+
<ion-menu-button menu="docs-menu" color="dark"></ion-menu-button>
|
|
316
|
+
</ion-buttons>
|
|
317
|
+
</ion-toolbar>
|
|
318
|
+
</ion-header>
|
|
319
|
+
|
|
320
|
+
<main class="docs-main-scroll">
|
|
321
|
+
<ng-content></ng-content>
|
|
322
|
+
@if (props.footer) {
|
|
323
|
+
<val-company-footer [props]="props.footer"></val-company-footer>
|
|
324
|
+
}
|
|
325
|
+
</main>
|
|
326
|
+
</div>
|
|
327
|
+
</ion-split-pane>
|
|
328
|
+
`, styles: [":host{display:block;height:100%}ion-split-pane{height:100%;--side-width: var(--docs-sidebar-width, 260px);--side-min-width: var(--docs-sidebar-width, 260px);--side-max-width: var(--docs-sidebar-width, 260px)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem}.logo-link{display:flex;align-items:center;gap:.75rem;text-decoration:none;transition:opacity .2s ease}.logo-link:hover{opacity:.8}.sidebar-logo--css-var{display:block;background-image:var(--logo-var);background-size:contain;background-repeat:no-repeat;background-position:left center}.sidebar-logo--img{display:block;object-fit:contain}.sidebar-close{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border:none;background:transparent;border-radius:50%;cursor:pointer;color:var(--ion-text-color, #333);transition:background .2s ease}.sidebar-close:hover{background:#0000000d}.sidebar-close ion-icon{font-size:1.5rem}@media (min-width: 992px){.sidebar-close{display:none}}.search-wrapper{padding:.75rem 1rem;border-bottom:1px solid var(--ion-border-color, #e0e0e0)}.sidebar-nav{padding:.5rem 0}.nav-section__header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.75rem 1rem;border:none;background:transparent;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#666;cursor:pointer}.nav-section__header:hover{color:var(--ion-text-color)}.nav-section__header span{flex:1;text-align:left}.nav-chevron{font-size:.875rem}.nav-links{list-style:none;margin:0;padding:0}.nav-links a{display:flex;align-items:center;justify-content:space-between;padding:.5rem 1rem .5rem 2.5rem;font-size:.875rem;color:#555;text-decoration:none;border-left:2px solid transparent}.nav-links a:hover{color:var(--ion-text-color);background:#00000008}.nav-links a.active{color:var(--ion-text-color);font-weight:500;background:#0000000d;border-left-color:var(--ion-color-primary)}.nav-badge{font-size:.625rem;font-weight:500;text-transform:uppercase;padding:.125rem .375rem;border-radius:4px;background:#0000000a;color:#888}.nav-badge--success{background:#e8f5e9;color:#2e7d32}.docs-main-scroll{flex:1;overflow-y:auto;background:var(--ion-background-color)}ion-menu{--width: 100%;--max-width: 100%;--background: var(--ion-background-color);border-right:1px solid var(--ion-border-color, #e0e0e0)}@media (min-width: 992px){ion-menu{--width: var(--docs-sidebar-width, 260px);--max-width: var(--docs-sidebar-width, 260px)}.mobile-header{display:none}}#docs-content{display:flex;flex-direction:column}:host-context(.dark) .nav-badge,:host-context([color-scheme=\"dark\"]) .nav-badge{background:#ffffff0f;color:#999}:host-context(.dark) .nav-badge--success,:host-context([color-scheme=\"dark\"]) .nav-badge--success{background:#2e7d3233;color:#81c784}:host-context(.dark) .sidebar-close:hover,:host-context([color-scheme=\"dark\"]) .sidebar-close:hover{background:#ffffff1a}\n"] }]
|
|
329
|
+
}], propDecorators: { props: [{
|
|
330
|
+
type: Input
|
|
331
|
+
}], navigate: [{
|
|
332
|
+
type: Output
|
|
333
|
+
}] } });
|
|
334
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"docs-shell.component.js","sourceRoot":"","sources":["../../../../../../../src/lib/components/templates/docs-shell/docs-shell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, inject, signal, computed } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { RouterModule } from '@angular/router';\nimport {\n  IonSplitPane,\n  IonMenu,\n  IonHeader,\n  IonToolbar,\n  IonContent,\n  IonIcon,\n  IonMenuButton,\n  IonButtons,\n  MenuController,\n} from '@ionic/angular/standalone';\nimport { addIcons } from 'ionicons';\nimport {\n  chevronDownOutline,\n  chevronForwardOutline,\n  closeOutline,\n} from 'ionicons/icons';\nimport { DocsSearchComponent } from '../../molecules/docs-search/docs-search.component';\nimport { DocsSearchMetadata, DocsSearchSection } from '../../molecules/docs-search/types';\nimport { CompanyFooterComponent } from '../../organisms/company-footer/company-footer.component';\nimport { DocsNavigationService } from '../../../services/docs/docs-navigation.service';\nimport { DocsShellMetadata, DocsShellSection } from './types';\n\naddIcons({\n  chevronDownOutline,\n  chevronForwardOutline,\n  closeOutline,\n});\n\n/**\n * val-docs-shell\n *\n * A complete documentation shell with sidebar navigation, search, and content area.\n * Use this component as the root layout for documentation pages.\n *\n * @example\n * ```html\n * <val-docs-shell [props]=\"shellConfig\">\n *   <router-outlet></router-outlet>\n * </val-docs-shell>\n * ```\n */\n@Component({\n  selector: 'val-docs-shell',\n  standalone: true,\n  imports: [\n    CommonModule,\n    RouterModule,\n    IonSplitPane,\n    IonMenu,\n    IonHeader,\n    IonToolbar,\n    IonContent,\n    IonIcon,\n    IonMenuButton,\n    IonButtons,\n    DocsSearchComponent,\n    CompanyFooterComponent,\n  ],\n  template: `\n    <ion-split-pane contentId=\"docs-content\" when=\"lg\">\n      <ion-menu contentId=\"docs-content\" type=\"overlay\" menuId=\"docs-menu\">\n        <ion-header class=\"ion-no-border\">\n          <ion-toolbar>\n            <div class=\"sidebar-header\">\n              <a [routerLink]=\"props.logo.route || ['/']\" class=\"logo-link\" [attr.aria-label]=\"props.logo.alt\">\n                @if (props.logo.cssVariable) {\n                  <span\n                    class=\"sidebar-logo sidebar-logo--css-var\"\n                    role=\"img\"\n                    [attr.aria-label]=\"props.logo.alt\"\n                    [style.--logo-var]=\"'var(' + props.logo.cssVariable + ')'\"\n                    [style.width]=\"props.logo.width || '10rem'\"\n                    [style.height]=\"props.logo.height || '3rem'\"\n                  ></span>\n                } @else if (props.logo.src) {\n                  <img\n                    [src]=\"props.logo.src\"\n                    [alt]=\"props.logo.alt\"\n                    class=\"sidebar-logo sidebar-logo--img\"\n                    [style.width]=\"props.logo.width || '10rem'\"\n                    [style.height]=\"props.logo.height || '3rem'\"\n                  />\n                }\n              </a>\n              <button\n                type=\"button\"\n                class=\"sidebar-close\"\n                (click)=\"closeMenu()\"\n                aria-label=\"Close menu\"\n              >\n                <ion-icon name=\"close-outline\"></ion-icon>\n              </button>\n            </div>\n          </ion-toolbar>\n        </ion-header>\n\n        <ion-content>\n          <!-- Search -->\n          @if (props.search) {\n            <div class=\"search-wrapper\">\n              <val-docs-search\n                [props]=\"searchProps()\"\n                (navigate)=\"onNavigate($event)\"\n              ></val-docs-search>\n            </div>\n          }\n\n          <nav class=\"sidebar-nav\">\n            @for (section of sectionsState(); track section.key) {\n              <div class=\"nav-section\">\n                <button\n                  type=\"button\"\n                  class=\"nav-section__header\"\n                  (click)=\"toggleSection(section)\"\n                >\n                  @if (section.icon) {\n                    <ion-icon [name]=\"section.icon\"></ion-icon>\n                  }\n                  <span>{{ section.title }}</span>\n                  <ion-icon\n                    [name]=\"section.expanded ? 'chevron-down-outline' : 'chevron-forward-outline'\"\n                    class=\"nav-chevron\"\n                  ></ion-icon>\n                </button>\n\n                @if (section.expanded) {\n                  <ul class=\"nav-links\">\n                    @for (link of section.children; track link.label) {\n                      <li>\n                        <a\n                          [routerLink]=\"link.route\"\n                          routerLinkActive=\"active\"\n                          (click)=\"closeMenu()\"\n                        >\n                          {{ link.label }}\n                          @if (link.badge) {\n                            <span\n                              class=\"nav-badge\"\n                              [class.nav-badge--success]=\"link.badgeColor === 'success'\"\n                            >{{ link.badge }}</span>\n                          }\n                        </a>\n                      </li>\n                    }\n                  </ul>\n                }\n              </div>\n            }\n          </nav>\n        </ion-content>\n      </ion-menu>\n\n      <div class=\"ion-page\" id=\"docs-content\">\n        <ion-header class=\"ion-no-border mobile-header\">\n          <ion-toolbar>\n            <ion-buttons slot=\"start\">\n              <ion-menu-button menu=\"docs-menu\" color=\"dark\"></ion-menu-button>\n            </ion-buttons>\n          </ion-toolbar>\n        </ion-header>\n\n        <main class=\"docs-main-scroll\">\n          <ng-content></ng-content>\n          @if (props.footer) {\n            <val-company-footer [props]=\"props.footer\"></val-company-footer>\n          }\n        </main>\n      </div>\n    </ion-split-pane>\n  `,\n  styles: [`\n    :host {\n      display: block;\n      height: 100%;\n    }\n\n    ion-split-pane {\n      height: 100%;\n      --side-width: var(--docs-sidebar-width, 260px);\n      --side-min-width: var(--docs-sidebar-width, 260px);\n      --side-max-width: var(--docs-sidebar-width, 260px);\n    }\n\n    .sidebar-header {\n      display: flex;\n      align-items: center;\n      justify-content: space-between;\n      padding: 0.75rem 1rem;\n    }\n\n    .logo-link {\n      display: flex;\n      align-items: center;\n      gap: 0.75rem;\n      text-decoration: none;\n      transition: opacity 0.2s ease;\n    }\n\n    .logo-link:hover {\n      opacity: 0.8;\n    }\n\n    .sidebar-logo--css-var {\n      display: block;\n      background-image: var(--logo-var);\n      background-size: contain;\n      background-repeat: no-repeat;\n      background-position: left center;\n    }\n\n    .sidebar-logo--img {\n      display: block;\n      object-fit: contain;\n    }\n\n    .sidebar-close {\n      display: flex;\n      align-items: center;\n      justify-content: center;\n      width: 2.5rem;\n      height: 2.5rem;\n      border: none;\n      background: transparent;\n      border-radius: 50%;\n      cursor: pointer;\n      color: var(--ion-text-color, #333);\n      transition: background 0.2s ease;\n    }\n\n    .sidebar-close:hover {\n      background: rgba(0, 0, 0, 0.05);\n    }\n\n    .sidebar-close ion-icon {\n      font-size: 1.5rem;\n    }\n\n    @media (min-width: 992px) {\n      .sidebar-close {\n        display: none;\n      }\n    }\n\n    .search-wrapper {\n      padding: 0.75rem 1rem;\n      border-bottom: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    .sidebar-nav {\n      padding: 0.5rem 0;\n    }\n\n    .nav-section__header {\n      display: flex;\n      align-items: center;\n      gap: 0.5rem;\n      width: 100%;\n      padding: 0.75rem 1rem;\n      border: none;\n      background: transparent;\n      font-size: 0.75rem;\n      font-weight: 600;\n      text-transform: uppercase;\n      letter-spacing: 0.5px;\n      color: #666;\n      cursor: pointer;\n    }\n\n    .nav-section__header:hover {\n      color: var(--ion-text-color);\n    }\n\n    .nav-section__header span {\n      flex: 1;\n      text-align: left;\n    }\n\n    .nav-chevron {\n      font-size: 0.875rem;\n    }\n\n    .nav-links {\n      list-style: none;\n      margin: 0;\n      padding: 0;\n    }\n\n    .nav-links a {\n      display: flex;\n      align-items: center;\n      justify-content: space-between;\n      padding: 0.5rem 1rem 0.5rem 2.5rem;\n      font-size: 0.875rem;\n      color: #555;\n      text-decoration: none;\n      border-left: 2px solid transparent;\n    }\n\n    .nav-links a:hover {\n      color: var(--ion-text-color);\n      background: rgba(0, 0, 0, 0.03);\n    }\n\n    .nav-links a.active {\n      color: var(--ion-text-color);\n      font-weight: 500;\n      background: rgba(0, 0, 0, 0.05);\n      border-left-color: var(--ion-color-primary);\n    }\n\n    .nav-badge {\n      font-size: 0.625rem;\n      font-weight: 500;\n      text-transform: uppercase;\n      padding: 0.125rem 0.375rem;\n      border-radius: 4px;\n      background: rgba(0, 0, 0, 0.04);\n      color: #888;\n    }\n\n    .nav-badge--success {\n      background: #e8f5e9;\n      color: #2e7d32;\n    }\n\n    .docs-main-scroll {\n      flex: 1;\n      overflow-y: auto;\n      background: var(--ion-background-color);\n    }\n\n    ion-menu {\n      --width: 100%;\n      --max-width: 100%;\n      --background: var(--ion-background-color);\n      border-right: 1px solid var(--ion-border-color, #e0e0e0);\n    }\n\n    @media (min-width: 992px) {\n      ion-menu {\n        --width: var(--docs-sidebar-width, 260px);\n        --max-width: var(--docs-sidebar-width, 260px);\n      }\n\n      .mobile-header {\n        display: none;\n      }\n    }\n\n    #docs-content {\n      display: flex;\n      flex-direction: column;\n    }\n\n    /* Dark mode */\n    :host-context(.dark) .nav-badge,\n    :host-context([color-scheme=\"dark\"]) .nav-badge {\n      background: rgba(255, 255, 255, 0.06);\n      color: #999;\n    }\n\n    :host-context(.dark) .nav-badge--success,\n    :host-context([color-scheme=\"dark\"]) .nav-badge--success {\n      background: rgba(46, 125, 50, 0.2);\n      color: #81c784;\n    }\n\n    :host-context(.dark) .sidebar-close:hover,\n    :host-context([color-scheme=\"dark\"]) .sidebar-close:hover {\n      background: rgba(255, 255, 255, 0.1);\n    }\n  `],\n})\nexport class DocsShellComponent {\n  private menuCtrl = inject(MenuController);\n  private docsNav = inject(DocsNavigationService);\n\n  @Input() props: DocsShellMetadata = {\n    logo: { alt: 'Logo' },\n    sections: [],\n  };\n\n  @Output() navigate = new EventEmitter<string[]>();\n\n  // Internal state for expanded sections\n  private _sectionsState = signal<DocsShellSection[]>([]);\n\n  sectionsState = computed(() => {\n    // Initialize from props if empty\n    if (this._sectionsState().length === 0 && this.props.sections.length > 0) {\n      return this.props.sections.map(s => ({\n        ...s,\n        expanded: s.expanded ?? true,\n      }));\n    }\n    return this._sectionsState().length > 0 ? this._sectionsState() : this.props.sections;\n  });\n\n  searchProps = computed<DocsSearchMetadata>(() => ({\n    placeholder: this.props.search?.placeholder || 'Search...',\n    showShortcut: this.props.search?.showShortcut ?? true,\n    sections: this.buildSearchSections(),\n  }));\n\n  ngOnChanges(): void {\n    // Update sections state when props change\n    if (this.props.sections.length > 0) {\n      this._sectionsState.set(\n        this.props.sections.map(s => ({\n          ...s,\n          expanded: s.expanded ?? true,\n        }))\n      );\n    }\n  }\n\n  toggleSection(section: DocsShellSection): void {\n    this._sectionsState.update(sections =>\n      sections.map(s =>\n        s.key === section.key ? { ...s, expanded: !s.expanded } : s\n      )\n    );\n  }\n\n  async closeMenu(): Promise<void> {\n    await this.menuCtrl.close('docs-menu');\n    this.docsNav.scrollToTop();\n  }\n\n  onNavigate(route: string[]): void {\n    this.navigate.emit(route);\n    this.docsNav.navigateAndScroll(route);\n    this.menuCtrl.close('docs-menu');\n  }\n\n  private buildSearchSections(): DocsSearchSection[] {\n    return this.props.sections.map(section => ({\n      title: section.title,\n      items: section.children.map(child => ({\n        label: child.label,\n        route: child.route,\n        description: `${section.title} > ${child.label}`,\n      })),\n    }));\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvdGVtcGxhdGVzL2RvY3Mtc2hlbGwvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBhbnlGb290ZXJNZXRhZGF0YSB9IGZyb20gJy4uLy4uL29yZ2FuaXNtcy9jb21wYW55LWZvb3Rlci90eXBlcyc7XG5pbXBvcnQgeyBMYW5ndWFnZVNlbGVjdG9yTWV0YWRhdGEgfSBmcm9tICcuLi8uLi9tb2xlY3VsZXMvbGFuZ3VhZ2Utc2VsZWN0b3IvdHlwZXMnO1xuXG4vKipcbiAqIENvbmZpZ3VyYXRpb24gZm9yIHRoZSBkb2NzLXNoZWxsIGNvbXBvbmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEb2NzU2hlbGxNZXRhZGF0YSB7XG4gIC8qKlxuICAgKiBMb2dvIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBzaWRlYmFyIGhlYWRlci5cbiAgICovXG4gIGxvZ286IERvY3NTaGVsbExvZ287XG5cbiAgLyoqXG4gICAqIE5hdmlnYXRpb24gc2VjdGlvbnMgZm9yIHRoZSBzaWRlYmFyLlxuICAgKi9cbiAgc2VjdGlvbnM6IERvY3NTaGVsbFNlY3Rpb25bXTtcblxuICAvKipcbiAgICogU2VhcmNoIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBzZWFyY2g/OiB7XG4gICAgLyoqIFBsYWNlaG9sZGVyIHRleHQgZm9yIHRoZSBzZWFyY2ggaW5wdXQgKi9cbiAgICBwbGFjZWhvbGRlcj86IHN0cmluZztcbiAgICAvKiogU2hvdyBrZXlib2FyZCBzaG9ydGN1dCBoaW50ICovXG4gICAgc2hvd1Nob3J0Y3V0PzogYm9vbGVhbjtcbiAgfTtcblxuICAvKipcbiAgICogRm9vdGVyIGNvbmZpZ3VyYXRpb24uXG4gICAqL1xuICBmb290ZXI/OiBDb21wYW55Rm9vdGVyTWV0YWRhdGE7XG5cbiAgLyoqXG4gICAqIFNpZGViYXIgd2lkdGggaW4gZGVza3RvcCBtb2RlLlxuICAgKiBAZGVmYXVsdCAnMjYwcHgnXG4gICAqL1xuICBzaWRlYmFyV2lkdGg/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIExhbmd1YWdlIHNlbGVjdG9yIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBmb290ZXIuXG4gICAqL1xuICBsYW5ndWFnZVNlbGVjdG9yPzogTGFuZ3VhZ2VTZWxlY3Rvck1ldGFkYXRhO1xuXG4gIC8qKlxuICAgKiBDdXN0b20gQ1NTIGNsYXNzIGZvciB0aGUgc2hlbGwuXG4gICAqL1xuICBjc3NDbGFzcz86IHN0cmluZztcbn1cblxuLyoqXG4gKiBMb2dvIGNvbmZpZ3VyYXRpb24gZm9yIHRoZSBkb2NzIHNoZWxsLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERvY3NTaGVsbExvZ28ge1xuICAvKipcbiAgICogVXNlIENTUyB2YXJpYWJsZSBmb3IgdGhlIGxvZ28gKHJlY29tbWVuZGVkIGZvciBkYXJrIG1vZGUgc3VwcG9ydCkuXG4gICAqIFdoZW4gc2V0LCB1c2VzIGJhY2tncm91bmQtaW1hZ2Ugd2l0aCB0aGlzIENTUyB2YXJpYWJsZS5cbiAgICogQGV4YW1wbGUgJy0tbWFpbi1sb2dvJ1xuICAgKi9cbiAgY3NzVmFyaWFibGU/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIExvZ28gaW1hZ2Ugc291cmNlIChhbHRlcm5hdGl2ZSB0byBjc3NWYXJpYWJsZSkuXG4gICAqL1xuICBzcmM/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERhcmsgbW9kZSBsb2dvIHNvdXJjZSAodXNlZCB3aXRoIHNyYykuXG4gICAqL1xuICBzcmNEYXJrPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBBbHQgdGV4dCBmb3IgYWNjZXNzaWJpbGl0eS5cbiAgICovXG4gIGFsdDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBSb3V0ZSB0byBuYXZpZ2F0ZSB3aGVuIGNsaWNraW5nIHRoZSBsb2dvLlxuICAgKiBAZGVmYXVsdCBbJy8nXVxuICAgKi9cbiAgcm91dGU/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogTG9nbyB3aWR0aC5cbiAgICogQGRlZmF1bHQgJzEwcmVtJ1xuICAgKi9cbiAgd2lkdGg/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIExvZ28gaGVpZ2h0LlxuICAgKiBAZGVmYXVsdCAnM3JlbSdcbiAgICovXG4gIGhlaWdodD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIG5hdmlnYXRpb24gc2VjdGlvbiBpbiB0aGUgc2lkZWJhci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBEb2NzU2hlbGxTZWN0aW9uIHtcbiAgLyoqXG4gICAqIFVuaXF1ZSBrZXkgZm9yIHRoZSBzZWN0aW9uLlxuICAgKi9cbiAga2V5OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIERpc3BsYXkgdGl0bGUgZm9yIHRoZSBzZWN0aW9uIGhlYWRlci5cbiAgICovXG4gIHRpdGxlOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEljb24gbmFtZSAoaW9uaWNvbnMpLlxuICAgKi9cbiAgaWNvbj86IHN0cmluZztcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgc2VjdGlvbiBpcyBleHBhbmRlZCBieSBkZWZhdWx0LlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICBleHBhbmRlZD86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIENoaWxkIG5hdmlnYXRpb24gbGlua3MuXG4gICAqL1xuICBjaGlsZHJlbjogRG9jc1NoZWxsTGlua1tdO1xufVxuXG4vKipcbiAqIEEgbmF2aWdhdGlvbiBsaW5rIGluIHRoZSBzaWRlYmFyLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERvY3NTaGVsbExpbmsge1xuICAvKipcbiAgICogRGlzcGxheSBsYWJlbCBmb3IgdGhlIGxpbmsuXG4gICAqL1xuICBsYWJlbDogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBSb3V0ZSBhcnJheSBmb3IgbmF2aWdhdGlvbi5cbiAgICovXG4gIHJvdXRlOiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogT3B0aW9uYWwgYmFkZ2UgdGV4dCAoZS5nLiwgXCJOZXdcIiwgXCJVcGRhdGVkXCIpLlxuICAgKi9cbiAgYmFkZ2U/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEJhZGdlIGNvbG9yIHZhcmlhbnQuXG4gICAqIEBkZWZhdWx0ICdkZWZhdWx0J1xuICAgKi9cbiAgYmFkZ2VDb2xvcj86ICdkZWZhdWx0JyB8ICdzdWNjZXNzJztcbn1cbiJdfQ==
|