From c1b7c882250f1972a0d3b8110fc656e4c1cb53bb Mon Sep 17 00:00:00 2001 From: waterplea Date: Tue, 8 Oct 2024 11:10:04 +0400 Subject: [PATCH] feat(addon-doc): allow adding extra tabs with DI --- .../addon-doc/components/page/page.component.ts | 10 +++++++--- .../addon-doc/components/page/page.providers.ts | 7 +++++++ .../addon-doc/components/page/page.template.html | 15 +++++++++++++++ 3 files changed, 29 insertions(+), 3 deletions(-) diff --git a/projects/addon-doc/components/page/page.component.ts b/projects/addon-doc/components/page/page.component.ts index 0a97c7a148fb2..8bb4a2b62946c 100644 --- a/projects/addon-doc/components/page/page.component.ts +++ b/projects/addon-doc/components/page/page.component.ts @@ -1,4 +1,4 @@ -import {NgForOf, NgIf, NgTemplateOutlet} from '@angular/common'; +import {KeyValuePipe, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common'; import type {QueryList} from '@angular/core'; import { ChangeDetectionStrategy, @@ -7,18 +7,19 @@ import { inject, Input, } from '@angular/core'; -import {RouterLink, RouterLinkActive} from '@angular/router'; +import {ActivatedRoute, RouterLink, RouterLinkActive} from '@angular/router'; import {TUI_DOC_DEFAULT_TABS, TUI_DOC_SUPPORT_LANGUAGE} from '@taiga-ui/addon-doc/tokens'; import {EMPTY_QUERY} from '@taiga-ui/cdk/constants'; import {TuiReplacePipe} from '@taiga-ui/cdk/pipes/replace'; import {TuiAutoColorPipe} from '@taiga-ui/core/pipes/auto-color'; import {TuiChip} from '@taiga-ui/kit/components/chip'; import {TuiTabs} from '@taiga-ui/kit/components/tabs'; +import {PolymorpheusOutlet} from '@taiga-ui/polymorpheus'; import {TuiDocSeeAlso} from '../internal/see-also'; import {TuiDocSourceCode} from '../internal/source-code/source-code.component'; import {TuiDocLanguageSwitcher} from '../language-switcher'; -import {PAGE_PROVIDERS, PAGE_SEE_ALSO} from './page.providers'; +import {PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_TABS} from './page.providers'; import {TuiDocPageTabConnector} from './page-tab.directive'; @Component({ @@ -37,6 +38,8 @@ import {TuiDocPageTabConnector} from './page-tab.directive'; TuiDocSourceCode, TuiReplacePipe, TuiTabs, + KeyValuePipe, + PolymorpheusOutlet, ], templateUrl: './page.template.html', styleUrls: ['./page.style.less'], @@ -44,6 +47,7 @@ import {TuiDocPageTabConnector} from './page-tab.directive'; providers: PAGE_PROVIDERS, }) export class TuiDocPage { + protected readonly tabs = inject(TUI_DOC_TABS)(inject(ActivatedRoute).snapshot); protected readonly supportLanguage = inject(TUI_DOC_SUPPORT_LANGUAGE); protected readonly defaultTabs = inject(TUI_DOC_DEFAULT_TABS); protected readonly from = / /g; diff --git a/projects/addon-doc/components/page/page.providers.ts b/projects/addon-doc/components/page/page.providers.ts index 7bfcdbecc72aa..771164a440727 100644 --- a/projects/addon-doc/components/page/page.providers.ts +++ b/projects/addon-doc/components/page/page.providers.ts @@ -1,7 +1,14 @@ import type {Provider} from '@angular/core'; import {ElementRef} from '@angular/core'; +import type {ActivatedRouteSnapshot} from '@angular/router'; import {TUI_DOC_SEE_ALSO} from '@taiga-ui/addon-doc/tokens'; +import type {TuiHandler} from '@taiga-ui/cdk'; import {tuiCreateToken} from '@taiga-ui/cdk/utils/miscellaneous'; +import type {PolymorpheusContent} from '@taiga-ui/polymorpheus'; + +export const TUI_DOC_TABS = tuiCreateToken< + TuiHandler> +>(() => ({})); /** * Array if related page titles diff --git a/projects/addon-doc/components/page/page.template.html b/projects/addon-doc/components/page/page.template.html index f95c94cd95066..d928ca51e7645 100644 --- a/projects/addon-doc/components/page/page.template.html +++ b/projects/addon-doc/components/page/page.template.html @@ -46,6 +46,16 @@

+ + + {{ tab.key }} + +
[ngTemplateOutlet]="tab.template" /> + + + {{ text }} + +