@taiga-ui/addon-doc 4.58.0 → 4.60.0

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.
@@ -1,7 +1,9 @@
1
1
  import { type QueryList } from '@angular/core';
2
+ import { type TuiDocPageOptions } from './page.providers';
2
3
  import { TuiDocPageTabConnector } from './page-tab.directive';
3
4
  import * as i0 from "@angular/core";
4
- export declare class TuiDocPage {
5
+ export declare class TuiDocPage implements TuiDocPageOptions {
6
+ protected readonly options: TuiDocPageOptions;
5
7
  protected readonly tabs: Record<string, import("@taiga-ui/polymorpheus").PolymorpheusContent>;
6
8
  protected readonly supportLanguage: Set<string>;
7
9
  protected readonly defaultTabs: readonly string[];
@@ -12,7 +14,7 @@ export declare class TuiDocPage {
12
14
  type: string;
13
15
  tags: string[];
14
16
  path: string;
15
- deprecated: boolean | '';
17
+ deprecated: boolean | "";
16
18
  readonly tabConnectors: QueryList<TuiDocPageTabConnector>;
17
19
  activeItemIndex: number;
18
20
  readonly seeAlso: readonly string[];
@@ -2,6 +2,15 @@ import { InjectionToken, type Provider } from '@angular/core';
2
2
  import { type ActivatedRouteSnapshot } from '@angular/router';
3
3
  import { type TuiHandler } from '@taiga-ui/cdk/types';
4
4
  import { type PolymorpheusContent } from '@taiga-ui/polymorpheus';
5
+ export interface TuiDocPageOptions {
6
+ header: string;
7
+ package: string;
8
+ type: string;
9
+ tags: string[];
10
+ path: string;
11
+ deprecated: boolean | '';
12
+ }
13
+ export declare const TUI_DOC_PAGE_OPTIONS: InjectionToken<TuiDocPageOptions>, tuiDocPageOptionsProvider: (item: Partial<TuiDocPageOptions> | import("@angular/core").ProviderToken<Partial<TuiDocPageOptions>> | (() => Partial<TuiDocPageOptions>)) => import("@angular/core").FactoryProvider;
5
14
  export declare const TUI_DOC_TABS: InjectionToken<TuiHandler<ActivatedRouteSnapshot, Record<string, PolymorpheusContent>>>;
6
15
  /**
7
16
  * Array if related page titles
@@ -11,24 +11,25 @@ import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
11
11
  import { TuiDocSeeAlso } from '../internal/see-also';
12
12
  import { TuiDocSourceCode } from '../internal/source-code/source-code.component';
13
13
  import { TuiDocLanguageSwitcher } from '../language-switcher';
14
- import { PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_TABS } from './page.providers';
14
+ import { PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_PAGE_OPTIONS, TUI_DOC_TABS, } from './page.providers';
15
15
  import { TuiDocPageTabConnector } from './page-tab.directive';
16
16
  import * as i0 from "@angular/core";
17
17
  import * as i1 from "@taiga-ui/cdk/directives/item";
18
18
  import * as i2 from "@taiga-ui/kit/components/tabs";
19
19
  class TuiDocPage {
20
20
  constructor() {
21
+ this.options = inject(TUI_DOC_PAGE_OPTIONS);
21
22
  this.tabs = inject(TUI_DOC_TABS)(inject(ActivatedRoute).snapshot);
22
23
  this.supportLanguage = inject(TUI_DOC_SUPPORT_LANGUAGE);
23
24
  this.defaultTabs = inject(TUI_DOC_DEFAULT_TABS);
24
25
  this.from = / /g;
25
26
  this.to = '_';
26
- this.header = '';
27
- this.package = '';
28
- this.type = '';
29
- this.tags = [];
30
- this.path = '';
31
- this.deprecated = false;
27
+ this.header = this.options.header;
28
+ this.package = this.options.package;
29
+ this.type = this.options.type;
30
+ this.tags = this.options.tags;
31
+ this.path = this.options.path;
32
+ this.deprecated = this.options.deprecated;
32
33
  this.tabConnectors = EMPTY_QUERY;
33
34
  this.activeItemIndex = 0;
34
35
  this.seeAlso = inject(PAGE_SEE_ALSO);
@@ -74,4 +75,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
74
75
  type: ContentChildren,
75
76
  args: [TuiDocPageTabConnector]
76
77
  }] } });
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/page/page.component.ts","../../../../../projects/addon-doc/components/page/page.template.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAC9E,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,MAAM,EACN,KAAK,GAER,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,cAAc,EAAE,UAAU,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAC7E,OAAO,EAAC,oBAAoB,EAAE,wBAAwB,EAAC,MAAM,4BAA4B,CAAC;AAC1F,OAAO,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAC,gBAAgB,EAAC,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAC,OAAO,EAAC,MAAM,+BAA+B,CAAC;AACtD,OAAO,EAAC,OAAO,EAAC,MAAM,+BAA+B,CAAC;AACtD,OAAO,EAAC,kBAAkB,EAAC,MAAM,wBAAwB,CAAC;AAE1D,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,gBAAgB,EAAC,MAAM,+CAA+C,CAAC;AAC/E,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAC,cAAc,EAAE,aAAa,EAAE,YAAY,EAAC,MAAM,kBAAkB,CAAC;AAC7E,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;;;;AAE5D,MAwBa,UAAU;IAxBvB;QAyBuB,SAAI,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,CAAC;QAC7D,oBAAe,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QACnD,gBAAW,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAC3C,SAAI,GAAG,IAAI,CAAC;QACZ,OAAE,GAAG,GAAG,CAAC;QAGrB,WAAM,GAAG,EAAE,CAAC;QAGZ,YAAO,GAAG,EAAE,CAAC;QAGb,SAAI,GAAG,EAAE,CAAC;QAGV,SAAI,GAAa,EAAE,CAAC;QAGpB,SAAI,GAAG,EAAE,CAAC;QAGV,eAAU,GAAiB,KAAK,CAAC;QAGxB,kBAAa,GAAsC,WAAW,CAAC;QAExE,oBAAe,GAAG,CAAC,CAAC;QACX,YAAO,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;KAKnD;IAHG,IAAW,WAAW;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,eAAe,KAAK,CAAC,CAAC;IAC/D,CAAC;+GAjCQ,UAAU;mGAAV,UAAU,iLAFR,cAAc,wDA2BR,sBAAsB,6BCzE3C,k/FAiGA,s/CDrEQ,YAAY,iDACZ,OAAO,mHACP,IAAI,6FACJ,gBAAgB,oJAChB,kBAAkB,8HAClB,UAAU,4NACV,gBAAgB,yMAChB,gBAAgB,qDAChB,OAAO,iFACP,sBAAsB,sEACtB,aAAa,kFACb,gBAAgB,0GAChB,cAAc;;SAQT,UAAU;4FAAV,UAAU;kBAxBtB,SAAS;iCACM,IAAI,YACN,cAAc,WACf;wBACL,YAAY;wBACZ,OAAO;wBACP,IAAI;wBACJ,gBAAgB;wBAChB,kBAAkB;wBAClB,UAAU;wBACV,gBAAgB;wBAChB,gBAAgB;wBAChB,OAAO;wBACP,sBAAsB;wBACtB,aAAa;wBACb,gBAAgB;wBAChB,cAAc;wBACd,OAAO;qBACV,mBAGgB,uBAAuB,CAAC,MAAM,aACpC,cAAc;8BAUlB,MAAM;sBADZ,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIU,aAAa;sBAD5B,eAAe;uBAAC,sBAAsB","sourcesContent":["import {KeyValuePipe, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    inject,\n    Input,\n    type QueryList,\n} from '@angular/core';\nimport {ActivatedRoute, RouterLink, RouterLinkActive} from '@angular/router';\nimport {TUI_DOC_DEFAULT_TABS, TUI_DOC_SUPPORT_LANGUAGE} from '@taiga-ui/addon-doc/tokens';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiReplacePipe} from '@taiga-ui/cdk/pipes/replace';\nimport {TuiAutoColorPipe} from '@taiga-ui/core/pipes/auto-color';\nimport {TuiChip} from '@taiga-ui/kit/components/chip';\nimport {TuiTabs} from '@taiga-ui/kit/components/tabs';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TuiDocSeeAlso} from '../internal/see-also';\nimport {TuiDocSourceCode} from '../internal/source-code/source-code.component';\nimport {TuiDocLanguageSwitcher} from '../language-switcher';\nimport {PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_TABS} from './page.providers';\nimport {TuiDocPageTabConnector} from './page-tab.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-doc-page',\n    imports: [\n        KeyValuePipe,\n        NgForOf,\n        NgIf,\n        NgTemplateOutlet,\n        PolymorpheusOutlet,\n        RouterLink,\n        RouterLinkActive,\n        TuiAutoColorPipe,\n        TuiChip,\n        TuiDocLanguageSwitcher,\n        TuiDocSeeAlso,\n        TuiDocSourceCode,\n        TuiReplacePipe,\n        TuiTabs,\n    ],\n    templateUrl: './page.template.html',\n    styleUrls: ['./page.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: PAGE_PROVIDERS,\n})\nexport class TuiDocPage {\n    protected readonly tabs = inject(TUI_DOC_TABS)(inject(ActivatedRoute).snapshot);\n    protected readonly supportLanguage = inject(TUI_DOC_SUPPORT_LANGUAGE);\n    protected readonly defaultTabs = inject(TUI_DOC_DEFAULT_TABS);\n    protected readonly from = / /g;\n    protected readonly to = '_';\n\n    @Input()\n    public header = '';\n\n    @Input()\n    public package = '';\n\n    @Input()\n    public type = '';\n\n    @Input()\n    public tags: string[] = [];\n\n    @Input()\n    public path = '';\n\n    @Input()\n    public deprecated: boolean | '' = false;\n\n    @ContentChildren(TuiDocPageTabConnector)\n    public readonly tabConnectors: QueryList<TuiDocPageTabConnector> = EMPTY_QUERY;\n\n    public activeItemIndex = 0;\n    public readonly seeAlso = inject(PAGE_SEE_ALSO);\n\n    public get showSeeAlso(): boolean {\n        return !!this.seeAlso.length && this.activeItemIndex === 0;\n    }\n}\n","<header class=\"t-header\">\n    <h1\n        *ngIf=\"header\"\n        class=\"t-title\"\n    >\n        {{ header }}\n        <tui-chip\n            *ngIf=\"!!deprecated || deprecated === ''\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_deprecated\"\n        >\n            deprecated\n        </tui-chip>\n        <tui-chip\n            *ngIf=\"package\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_package\"\n            [style.background]=\"package | tuiAutoColor\"\n        >\n            {{ package }}\n        </tui-chip>\n        <tui-chip\n            *ngFor=\"let tag of tags\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_package\"\n            [style.background]=\"tag | tuiAutoColor\"\n        >\n            {{ tag }}\n        </tui-chip>\n    </h1>\n    <tui-tabs-with-more\n        *ngIf=\"tabConnectors.length\"\n        class=\"t-tabs\"\n        [(activeItemIndex)]=\"activeItemIndex\"\n    >\n        <ng-container *ngFor=\"let tab of tabConnectors; first as first; index as index\">\n            <ng-container *ngIf=\"tab.pageTab || defaultTabs[index] as tabName\">\n                <a\n                    *tuiItem\n                    routerLinkActive\n                    tuiTab\n                    [routerLink]=\"first ? './' : (tabName | tuiReplace: from : to)\"\n                    [routerLinkActiveOptions]=\"{exact: first}\"\n                >\n                    {{ tabName }}\n                </a>\n            </ng-container>\n        </ng-container>\n        <ng-container *ngFor=\"let tab of tabs | keyvalue\">\n            <a\n                *tuiItem\n                routerLinkActive\n                tuiTab\n                [routerLink]=\"tab.key\"\n            >\n                {{ tab.key }}\n            </a>\n        </ng-container>\n    </tui-tabs-with-more>\n\n    <div\n        *ngIf=\"package || path || type\"\n        class=\"t-right-side\"\n    >\n        <tui-doc-source-code\n            class=\"t-source-code\"\n            [header]=\"header\"\n            [package]=\"package\"\n            [path]=\"path\"\n            [type]=\"type\"\n        />\n\n        <tui-doc-language-switcher *ngIf=\"supportLanguage.has(header)\" />\n    </div>\n</header>\n<div class=\"t-content\">\n    <ng-content />\n    <tui-doc-see-also\n        *ngIf=\"showSeeAlso\"\n        class=\"t-see-also\"\n        [seeAlso]=\"seeAlso\"\n    />\n    <ng-container *ngFor=\"let tab of tabConnectors; index as index\">\n        <ng-container\n            *ngIf=\"index === activeItemIndex\"\n            [ngTemplateOutlet]=\"tab.template\"\n        />\n    </ng-container>\n    <ng-container *ngFor=\"let tab of tabs | keyvalue; index as index\">\n        <ng-container *ngIf=\"index + tabConnectors.length === activeItemIndex\">\n            <ng-container *polymorpheusOutlet=\"tab.value as text\">{{ text }}</ng-container>\n        </ng-container>\n    </ng-container>\n</div>\n"]}
78
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/page/page.component.ts","../../../../../projects/addon-doc/components/page/page.template.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,YAAY,EAAE,OAAO,EAAE,IAAI,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAC9E,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,MAAM,EACN,KAAK,GAER,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,cAAc,EAAE,UAAU,EAAE,gBAAgB,EAAC,MAAM,iBAAiB,CAAC;AAC7E,OAAO,EAAC,oBAAoB,EAAE,wBAAwB,EAAC,MAAM,4BAA4B,CAAC;AAC1F,OAAO,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAC,gBAAgB,EAAC,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAC,OAAO,EAAC,MAAM,+BAA+B,CAAC;AACtD,OAAO,EAAC,OAAO,EAAC,MAAM,+BAA+B,CAAC;AACtD,OAAO,EAAC,kBAAkB,EAAC,MAAM,wBAAwB,CAAC;AAE1D,OAAO,EAAC,aAAa,EAAC,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAC,gBAAgB,EAAC,MAAM,+CAA+C,CAAC;AAC/E,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EACH,cAAc,EACd,aAAa,EACb,oBAAoB,EACpB,YAAY,GAEf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;;;;AAE5D,MAwBa,UAAU;IAxBvB;QAyBuB,YAAO,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QACvC,SAAI,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,QAAQ,CAAC,CAAC;QAC7D,oBAAe,GAAG,MAAM,CAAC,wBAAwB,CAAC,CAAC;QACnD,gBAAW,GAAG,MAAM,CAAC,oBAAoB,CAAC,CAAC;QAC3C,SAAI,GAAG,IAAI,CAAC;QACZ,OAAE,GAAG,GAAG,CAAC;QAGrB,WAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QAG7B,YAAO,GAAG,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;QAG/B,SAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAGzB,SAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAGzB,SAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAGzB,eAAU,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC;QAG5B,kBAAa,GAAsC,WAAW,CAAC;QAExE,oBAAe,GAAG,CAAC,CAAC;QACX,YAAO,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;KAKnD;IAHG,IAAW,WAAW;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,IAAI,CAAC,eAAe,KAAK,CAAC,CAAC;IAC/D,CAAC;+GAlCQ,UAAU;mGAAV,UAAU,iLAFR,cAAc,wDA4BR,sBAAsB,6BChF3C,k/FAiGA,s/CD/DQ,YAAY,iDACZ,OAAO,mHACP,IAAI,6FACJ,gBAAgB,oJAChB,kBAAkB,8HAClB,UAAU,4NACV,gBAAgB,yMAChB,gBAAgB,qDAChB,OAAO,iFACP,sBAAsB,sEACtB,aAAa,kFACb,gBAAgB,0GAChB,cAAc;;SAQT,UAAU;4FAAV,UAAU;kBAxBtB,SAAS;iCACM,IAAI,YACN,cAAc,WACf;wBACL,YAAY;wBACZ,OAAO;wBACP,IAAI;wBACJ,gBAAgB;wBAChB,kBAAkB;wBAClB,UAAU;wBACV,gBAAgB;wBAChB,gBAAgB;wBAChB,OAAO;wBACP,sBAAsB;wBACtB,aAAa;wBACb,gBAAgB;wBAChB,cAAc;wBACd,OAAO;qBACV,mBAGgB,uBAAuB,CAAC,MAAM,aACpC,cAAc;8BAWlB,MAAM;sBADZ,KAAK;gBAIC,OAAO;sBADb,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIU,aAAa;sBAD5B,eAAe;uBAAC,sBAAsB","sourcesContent":["import {KeyValuePipe, NgForOf, NgIf, NgTemplateOutlet} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    inject,\n    Input,\n    type QueryList,\n} from '@angular/core';\nimport {ActivatedRoute, RouterLink, RouterLinkActive} from '@angular/router';\nimport {TUI_DOC_DEFAULT_TABS, TUI_DOC_SUPPORT_LANGUAGE} from '@taiga-ui/addon-doc/tokens';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiReplacePipe} from '@taiga-ui/cdk/pipes/replace';\nimport {TuiAutoColorPipe} from '@taiga-ui/core/pipes/auto-color';\nimport {TuiChip} from '@taiga-ui/kit/components/chip';\nimport {TuiTabs} from '@taiga-ui/kit/components/tabs';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nimport {TuiDocSeeAlso} from '../internal/see-also';\nimport {TuiDocSourceCode} from '../internal/source-code/source-code.component';\nimport {TuiDocLanguageSwitcher} from '../language-switcher';\nimport {\n    PAGE_PROVIDERS,\n    PAGE_SEE_ALSO,\n    TUI_DOC_PAGE_OPTIONS,\n    TUI_DOC_TABS,\n    type TuiDocPageOptions,\n} from './page.providers';\nimport {TuiDocPageTabConnector} from './page-tab.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-doc-page',\n    imports: [\n        KeyValuePipe,\n        NgForOf,\n        NgIf,\n        NgTemplateOutlet,\n        PolymorpheusOutlet,\n        RouterLink,\n        RouterLinkActive,\n        TuiAutoColorPipe,\n        TuiChip,\n        TuiDocLanguageSwitcher,\n        TuiDocSeeAlso,\n        TuiDocSourceCode,\n        TuiReplacePipe,\n        TuiTabs,\n    ],\n    templateUrl: './page.template.html',\n    styleUrls: ['./page.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: PAGE_PROVIDERS,\n})\nexport class TuiDocPage implements TuiDocPageOptions {\n    protected readonly options = inject(TUI_DOC_PAGE_OPTIONS);\n    protected readonly tabs = inject(TUI_DOC_TABS)(inject(ActivatedRoute).snapshot);\n    protected readonly supportLanguage = inject(TUI_DOC_SUPPORT_LANGUAGE);\n    protected readonly defaultTabs = inject(TUI_DOC_DEFAULT_TABS);\n    protected readonly from = / /g;\n    protected readonly to = '_';\n\n    @Input()\n    public header = this.options.header;\n\n    @Input()\n    public package = this.options.package;\n\n    @Input()\n    public type = this.options.type;\n\n    @Input()\n    public tags = this.options.tags;\n\n    @Input()\n    public path = this.options.path;\n\n    @Input()\n    public deprecated = this.options.deprecated;\n\n    @ContentChildren(TuiDocPageTabConnector)\n    public readonly tabConnectors: QueryList<TuiDocPageTabConnector> = EMPTY_QUERY;\n\n    public activeItemIndex = 0;\n    public readonly seeAlso = inject(PAGE_SEE_ALSO);\n\n    public get showSeeAlso(): boolean {\n        return !!this.seeAlso.length && this.activeItemIndex === 0;\n    }\n}\n","<header class=\"t-header\">\n    <h1\n        *ngIf=\"header\"\n        class=\"t-title\"\n    >\n        {{ header }}\n        <tui-chip\n            *ngIf=\"!!deprecated || deprecated === ''\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_deprecated\"\n        >\n            deprecated\n        </tui-chip>\n        <tui-chip\n            *ngIf=\"package\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_package\"\n            [style.background]=\"package | tuiAutoColor\"\n        >\n            {{ package }}\n        </tui-chip>\n        <tui-chip\n            *ngFor=\"let tag of tags\"\n            appearance=\"custom\"\n            size=\"xs\"\n            class=\"t-tag t-tag_package\"\n            [style.background]=\"tag | tuiAutoColor\"\n        >\n            {{ tag }}\n        </tui-chip>\n    </h1>\n    <tui-tabs-with-more\n        *ngIf=\"tabConnectors.length\"\n        class=\"t-tabs\"\n        [(activeItemIndex)]=\"activeItemIndex\"\n    >\n        <ng-container *ngFor=\"let tab of tabConnectors; first as first; index as index\">\n            <ng-container *ngIf=\"tab.pageTab || defaultTabs[index] as tabName\">\n                <a\n                    *tuiItem\n                    routerLinkActive\n                    tuiTab\n                    [routerLink]=\"first ? './' : (tabName | tuiReplace: from : to)\"\n                    [routerLinkActiveOptions]=\"{exact: first}\"\n                >\n                    {{ tabName }}\n                </a>\n            </ng-container>\n        </ng-container>\n        <ng-container *ngFor=\"let tab of tabs | keyvalue\">\n            <a\n                *tuiItem\n                routerLinkActive\n                tuiTab\n                [routerLink]=\"tab.key\"\n            >\n                {{ tab.key }}\n            </a>\n        </ng-container>\n    </tui-tabs-with-more>\n\n    <div\n        *ngIf=\"package || path || type\"\n        class=\"t-right-side\"\n    >\n        <tui-doc-source-code\n            class=\"t-source-code\"\n            [header]=\"header\"\n            [package]=\"package\"\n            [path]=\"path\"\n            [type]=\"type\"\n        />\n\n        <tui-doc-language-switcher *ngIf=\"supportLanguage.has(header)\" />\n    </div>\n</header>\n<div class=\"t-content\">\n    <ng-content />\n    <tui-doc-see-also\n        *ngIf=\"showSeeAlso\"\n        class=\"t-see-also\"\n        [seeAlso]=\"seeAlso\"\n    />\n    <ng-container *ngFor=\"let tab of tabConnectors; index as index\">\n        <ng-container\n            *ngIf=\"index === activeItemIndex\"\n            [ngTemplateOutlet]=\"tab.template\"\n        />\n    </ng-container>\n    <ng-container *ngFor=\"let tab of tabs | keyvalue; index as index\">\n        <ng-container *ngIf=\"index + tabConnectors.length === activeItemIndex\">\n            <ng-container *polymorpheusOutlet=\"tab.value as text\">{{ text }}</ng-container>\n        </ng-container>\n    </ng-container>\n</div>\n"]}
@@ -1,5 +1,14 @@
1
1
  import { ElementRef, InjectionToken } from '@angular/core';
2
2
  import { TUI_DOC_SEE_ALSO } from '@taiga-ui/addon-doc/tokens';
3
+ import { tuiCreateOptions } from '@taiga-ui/cdk/utils/di';
4
+ export const [TUI_DOC_PAGE_OPTIONS, tuiDocPageOptionsProvider] = tuiCreateOptions({
5
+ header: '',
6
+ package: '',
7
+ type: '',
8
+ tags: [],
9
+ path: '',
10
+ deprecated: false,
11
+ });
3
12
  export const TUI_DOC_TABS = new InjectionToken(ngDevMode ? 'TUI_DOC_TABS' : '', {
4
13
  factory: () => () => ({}),
5
14
  });
@@ -22,4 +31,4 @@ export const PAGE_PROVIDERS = [
22
31
  },
23
32
  },
24
33
  ];
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9wYWdlL3BhZ2UucHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUUsY0FBYyxFQUFnQixNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUk1RCxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQUcsSUFBSSxjQUFjLENBRTVDLFNBQVMsQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7SUFDL0IsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDO0NBQzVCLENBQUMsQ0FBQztBQUVIOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLElBQUksY0FBYyxDQUMzQyxTQUFTLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUNuQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFlO0lBQ3RDO1FBQ0ksT0FBTyxFQUFFLGFBQWE7UUFDdEIsSUFBSSxFQUFFLENBQUMsVUFBVSxFQUFFLGdCQUFnQixDQUFDO1FBQ3BDLFVBQVUsRUFBRSxDQUNSLEVBQUMsYUFBYSxFQUFhLEVBQzNCLGFBQStDLEVBQzlCLEVBQUU7WUFDbkIsTUFBTSxhQUFhLEdBQUcsYUFBYSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUMzRCxNQUFNLE1BQU0sR0FDUixhQUFhLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO1lBRXpFLE1BQU0sVUFBVSxHQUFHLElBQUksR0FBRyxDQUN0QixNQUFNO2lCQUNELElBQUksRUFBRTtpQkFDTixLQUFLLENBQUMsR0FBRyxDQUFDO2lCQUNWLE1BQU0sQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsU0FBUyxJQUFJLFNBQVMsS0FBSyxhQUFhLENBQUMsQ0FDdkUsQ0FBQztZQUVGLE9BQU8sS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUNsQyxDQUFDO0tBQ0o7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtFbGVtZW50UmVmLCBJbmplY3Rpb25Ub2tlbiwgdHlwZSBQcm92aWRlcn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R5cGUgQWN0aXZhdGVkUm91dGVTbmFwc2hvdH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7VFVJX0RPQ19TRUVfQUxTT30gZnJvbSAnQHRhaWdhLXVpL2FkZG9uLWRvYy90b2tlbnMnO1xuaW1wb3J0IHt0eXBlIFR1aUhhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvdHlwZXMnO1xuaW1wb3J0IHt0eXBlIFBvbHltb3JwaGV1c0NvbnRlbnR9IGZyb20gJ0B0YWlnYS11aS9wb2x5bW9ycGhldXMnO1xuXG5leHBvcnQgY29uc3QgVFVJX0RPQ19UQUJTID0gbmV3IEluamVjdGlvblRva2VuPFxuICAgIFR1aUhhbmRsZXI8QWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUmVjb3JkPHN0cmluZywgUG9seW1vcnBoZXVzQ29udGVudD4+XG4+KG5nRGV2TW9kZSA/ICdUVUlfRE9DX1RBQlMnIDogJycsIHtcbiAgICBmYWN0b3J5OiAoKSA9PiAoKSA9PiAoe30pLFxufSk7XG5cbi8qKlxuICogQXJyYXkgaWYgcmVsYXRlZCBwYWdlIHRpdGxlc1xuICovXG5leHBvcnQgY29uc3QgUEFHRV9TRUVfQUxTTyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxyZWFkb25seSBzdHJpbmdbXT4oXG4gICAgbmdEZXZNb2RlID8gJ1BBR0VfU0VFX0FMU08nIDogJycsXG4pO1xuXG5leHBvcnQgY29uc3QgUEFHRV9QUk9WSURFUlM6IFByb3ZpZGVyW10gPSBbXG4gICAge1xuICAgICAgICBwcm92aWRlOiBQQUdFX1NFRV9BTFNPLFxuICAgICAgICBkZXBzOiBbRWxlbWVudFJlZiwgVFVJX0RPQ19TRUVfQUxTT10sXG4gICAgICAgIHVzZUZhY3Rvcnk6IChcbiAgICAgICAgICAgIHtuYXRpdmVFbGVtZW50fTogRWxlbWVudFJlZixcbiAgICAgICAgICAgIHNlZUFsc29Hcm91cHM6IFJlYWRvbmx5QXJyYXk8cmVhZG9ubHkgc3RyaW5nW10+LFxuICAgICAgICApOiByZWFkb25seSBzdHJpbmdbXSA9PiB7XG4gICAgICAgICAgICBjb25zdCBjdXJyZW50SGVhZGVyID0gbmF0aXZlRWxlbWVudC5nZXRBdHRyaWJ1dGUoJ2hlYWRlcicpO1xuICAgICAgICAgICAgY29uc3QgZ3JvdXBzID1cbiAgICAgICAgICAgICAgICBzZWVBbHNvR3JvdXBzLmZpbHRlcigoZ3JvdXApID0+IGdyb3VwLmluY2x1ZGVzKGN1cnJlbnRIZWFkZXIpKSB8fCBbXTtcblxuICAgICAgICAgICAgY29uc3Qgc2VlQWxzb1NldCA9IG5ldyBTZXQoXG4gICAgICAgICAgICAgICAgZ3JvdXBzXG4gICAgICAgICAgICAgICAgICAgIC5qb2luKClcbiAgICAgICAgICAgICAgICAgICAgLnNwbGl0KCcsJylcbiAgICAgICAgICAgICAgICAgICAgLmZpbHRlcigoY29tcG9uZW50KSA9PiBjb21wb25lbnQgJiYgY29tcG9uZW50ICE9PSBjdXJyZW50SGVhZGVyKSxcbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgIHJldHVybiBBcnJheS5mcm9tKHNlZUFsc29TZXQpO1xuICAgICAgICB9LFxuICAgIH0sXG5dO1xuIl19
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9wYWdlL3BhZ2UucHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUUsY0FBYyxFQUFnQixNQUFNLGVBQWUsQ0FBQztBQUV4RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUU1RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQVl4RCxNQUFNLENBQUMsTUFBTSxDQUFDLG9CQUFvQixFQUFFLHlCQUF5QixDQUFDLEdBQzFELGdCQUFnQixDQUFvQjtJQUNoQyxNQUFNLEVBQUUsRUFBRTtJQUNWLE9BQU8sRUFBRSxFQUFFO0lBQ1gsSUFBSSxFQUFFLEVBQUU7SUFDUixJQUFJLEVBQUUsRUFBRTtJQUNSLElBQUksRUFBRSxFQUFFO0lBQ1IsVUFBVSxFQUFFLEtBQUs7Q0FDcEIsQ0FBQyxDQUFDO0FBRVAsTUFBTSxDQUFDLE1BQU0sWUFBWSxHQUFHLElBQUksY0FBYyxDQUU1QyxTQUFTLENBQUMsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFO0lBQy9CLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQztDQUM1QixDQUFDLENBQUM7QUFFSDs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxJQUFJLGNBQWMsQ0FDM0MsU0FBUyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FDbkMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBZTtJQUN0QztRQUNJLE9BQU8sRUFBRSxhQUFhO1FBQ3RCLElBQUksRUFBRSxDQUFDLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQztRQUNwQyxVQUFVLEVBQUUsQ0FDUixFQUFDLGFBQWEsRUFBYSxFQUMzQixhQUErQyxFQUM5QixFQUFFO1lBQ25CLE1BQU0sYUFBYSxHQUFHLGFBQWEsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDM0QsTUFBTSxNQUFNLEdBQ1IsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQztZQUV6RSxNQUFNLFVBQVUsR0FBRyxJQUFJLEdBQUcsQ0FDdEIsTUFBTTtpQkFDRCxJQUFJLEVBQUU7aUJBQ04sS0FBSyxDQUFDLEdBQUcsQ0FBQztpQkFDVixNQUFNLENBQUMsQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLFNBQVMsSUFBSSxTQUFTLEtBQUssYUFBYSxDQUFDLENBQ3ZFLENBQUM7WUFFRixPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbEMsQ0FBQztLQUNKO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RWxlbWVudFJlZiwgSW5qZWN0aW9uVG9rZW4sIHR5cGUgUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHt0eXBlIEFjdGl2YXRlZFJvdXRlU25hcHNob3R9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge1RVSV9ET0NfU0VFX0FMU099IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvdG9rZW5zJztcbmltcG9ydCB7dHlwZSBUdWlIYW5kbGVyfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3R5cGVzJztcbmltcG9ydCB7dHVpQ3JlYXRlT3B0aW9uc30gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9kaSc7XG5pbXBvcnQge3R5cGUgUG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpRG9jUGFnZU9wdGlvbnMge1xuICAgIGhlYWRlcjogc3RyaW5nO1xuICAgIHBhY2thZ2U6IHN0cmluZztcbiAgICB0eXBlOiBzdHJpbmc7XG4gICAgdGFnczogc3RyaW5nW107XG4gICAgcGF0aDogc3RyaW5nO1xuICAgIGRlcHJlY2F0ZWQ6IGJvb2xlYW4gfCAnJztcbn1cblxuZXhwb3J0IGNvbnN0IFtUVUlfRE9DX1BBR0VfT1BUSU9OUywgdHVpRG9jUGFnZU9wdGlvbnNQcm92aWRlcl0gPVxuICAgIHR1aUNyZWF0ZU9wdGlvbnM8VHVpRG9jUGFnZU9wdGlvbnM+KHtcbiAgICAgICAgaGVhZGVyOiAnJyxcbiAgICAgICAgcGFja2FnZTogJycsXG4gICAgICAgIHR5cGU6ICcnLFxuICAgICAgICB0YWdzOiBbXSxcbiAgICAgICAgcGF0aDogJycsXG4gICAgICAgIGRlcHJlY2F0ZWQ6IGZhbHNlLFxuICAgIH0pO1xuXG5leHBvcnQgY29uc3QgVFVJX0RPQ19UQUJTID0gbmV3IEluamVjdGlvblRva2VuPFxuICAgIFR1aUhhbmRsZXI8QWN0aXZhdGVkUm91dGVTbmFwc2hvdCwgUmVjb3JkPHN0cmluZywgUG9seW1vcnBoZXVzQ29udGVudD4+XG4+KG5nRGV2TW9kZSA/ICdUVUlfRE9DX1RBQlMnIDogJycsIHtcbiAgICBmYWN0b3J5OiAoKSA9PiAoKSA9PiAoe30pLFxufSk7XG5cbi8qKlxuICogQXJyYXkgaWYgcmVsYXRlZCBwYWdlIHRpdGxlc1xuICovXG5leHBvcnQgY29uc3QgUEFHRV9TRUVfQUxTTyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxyZWFkb25seSBzdHJpbmdbXT4oXG4gICAgbmdEZXZNb2RlID8gJ1BBR0VfU0VFX0FMU08nIDogJycsXG4pO1xuXG5leHBvcnQgY29uc3QgUEFHRV9QUk9WSURFUlM6IFByb3ZpZGVyW10gPSBbXG4gICAge1xuICAgICAgICBwcm92aWRlOiBQQUdFX1NFRV9BTFNPLFxuICAgICAgICBkZXBzOiBbRWxlbWVudFJlZiwgVFVJX0RPQ19TRUVfQUxTT10sXG4gICAgICAgIHVzZUZhY3Rvcnk6IChcbiAgICAgICAgICAgIHtuYXRpdmVFbGVtZW50fTogRWxlbWVudFJlZixcbiAgICAgICAgICAgIHNlZUFsc29Hcm91cHM6IFJlYWRvbmx5QXJyYXk8cmVhZG9ubHkgc3RyaW5nW10+LFxuICAgICAgICApOiByZWFkb25seSBzdHJpbmdbXSA9PiB7XG4gICAgICAgICAgICBjb25zdCBjdXJyZW50SGVhZGVyID0gbmF0aXZlRWxlbWVudC5nZXRBdHRyaWJ1dGUoJ2hlYWRlcicpO1xuICAgICAgICAgICAgY29uc3QgZ3JvdXBzID1cbiAgICAgICAgICAgICAgICBzZWVBbHNvR3JvdXBzLmZpbHRlcigoZ3JvdXApID0+IGdyb3VwLmluY2x1ZGVzKGN1cnJlbnRIZWFkZXIpKSB8fCBbXTtcblxuICAgICAgICAgICAgY29uc3Qgc2VlQWxzb1NldCA9IG5ldyBTZXQoXG4gICAgICAgICAgICAgICAgZ3JvdXBzXG4gICAgICAgICAgICAgICAgICAgIC5qb2luKClcbiAgICAgICAgICAgICAgICAgICAgLnNwbGl0KCcsJylcbiAgICAgICAgICAgICAgICAgICAgLmZpbHRlcigoY29tcG9uZW50KSA9PiBjb21wb25lbnQgJiYgY29tcG9uZW50ICE9PSBjdXJyZW50SGVhZGVyKSxcbiAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgIHJldHVybiBBcnJheS5mcm9tKHNlZUFsc29TZXQpO1xuICAgICAgICB9LFxuICAgIH0sXG5dO1xuIl19
@@ -1,12 +1,13 @@
1
- export function tuiProvideRoutePageTab({ path, title, loadComponent, loadChildren, } = {}) {
1
+ export function tuiProvideRoutePageTab({ path, title, loadComponent, loadChildren, providers, } = {}) {
2
2
  return {
3
3
  path: path?.replace(/^\//, ''),
4
4
  loadComponent,
5
5
  loadChildren,
6
+ providers,
6
7
  data: { title },
7
8
  ...(!loadChildren && path !== ''
8
9
  ? { children: [{ path: ':tab', loadComponent }] }
9
10
  : {}),
10
11
  };
11
12
  }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1yb3V0ZS1wYWdlLXRhYi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy91dGlscy9wcm92aWRlLXJvdXRlLXBhZ2UtdGFiLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWNBLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxFQUNuQyxJQUFJLEVBQ0osS0FBSyxFQUNMLGFBQWEsRUFDYixZQUFZLE1BQ0gsRUFBRTtJQUNYLE9BQU87UUFDSCxJQUFJLEVBQUUsSUFBSSxFQUFFLE9BQU8sQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDO1FBQzlCLGFBQWE7UUFDYixZQUFZO1FBQ1osSUFBSSxFQUFFLEVBQUMsS0FBSyxFQUFDO1FBQ2IsR0FBRyxDQUFDLENBQUMsWUFBWSxJQUFJLElBQUksS0FBSyxFQUFFO1lBQzVCLENBQUMsQ0FBQyxFQUFDLFFBQVEsRUFBRSxDQUFDLEVBQUMsSUFBSSxFQUFFLE1BQU0sRUFBRSxhQUFhLEVBQUMsQ0FBQyxFQUFDO1lBQzdDLENBQUMsQ0FBQyxFQUFFLENBQUM7S0FDWixDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dHlwZSBUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHlwZSBEZWZhdWx0RXhwb3J0LCB0eXBlIExvYWRDaGlsZHJlbiwgdHlwZSBSb3V0ZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7dHlwZSBPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuaW50ZXJmYWNlIE9wdGlvbnMge1xuICAgIHBhdGg/OiBzdHJpbmc7XG4gICAgdGl0bGU/OiBzdHJpbmc7XG4gICAgbG9hZENvbXBvbmVudD86ICgpID0+XG4gICAgICAgIHwgT2JzZXJ2YWJsZTxEZWZhdWx0RXhwb3J0PFR5cGU8dW5rbm93bj4+IHwgVHlwZTx1bmtub3duPj5cbiAgICAgICAgfCBQcm9taXNlPERlZmF1bHRFeHBvcnQ8VHlwZTx1bmtub3duPj4gfCBUeXBlPHVua25vd24+PlxuICAgICAgICB8IFR5cGU8dW5rbm93bj47XG4gICAgbG9hZENoaWxkcmVuPzogTG9hZENoaWxkcmVuO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gdHVpUHJvdmlkZVJvdXRlUGFnZVRhYih7XG4gICAgcGF0aCxcbiAgICB0aXRsZSxcbiAgICBsb2FkQ29tcG9uZW50LFxuICAgIGxvYWRDaGlsZHJlbixcbn06IE9wdGlvbnMgPSB7fSk6IFJvdXRlIHtcbiAgICByZXR1cm4ge1xuICAgICAgICBwYXRoOiBwYXRoPy5yZXBsYWNlKC9eXFwvLywgJycpLCAvLyBFcnJvcjogTkcwNDAxNDogSW52YWxpZCBjb25maWd1cmF0aW9uIG9mIHJvdXRlOiBwYXRoIGNhbm5vdCBzdGFydCB3aXRoIGEgc2xhc2hcbiAgICAgICAgbG9hZENvbXBvbmVudCxcbiAgICAgICAgbG9hZENoaWxkcmVuLFxuICAgICAgICBkYXRhOiB7dGl0bGV9LFxuICAgICAgICAuLi4oIWxvYWRDaGlsZHJlbiAmJiBwYXRoICE9PSAnJ1xuICAgICAgICAgICAgPyB7Y2hpbGRyZW46IFt7cGF0aDogJzp0YWInLCBsb2FkQ29tcG9uZW50fV19XG4gICAgICAgICAgICA6IHt9KSxcbiAgICB9O1xufVxuIl19
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvdmlkZS1yb3V0ZS1wYWdlLXRhYi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy91dGlscy9wcm92aWRlLXJvdXRlLXBhZ2UtdGFiLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxFQUNuQyxJQUFJLEVBQ0osS0FBSyxFQUNMLGFBQWEsRUFDYixZQUFZLEVBQ1osU0FBUyxNQUNBLEVBQUU7SUFDWCxPQUFPO1FBQ0gsSUFBSSxFQUFFLElBQUksRUFBRSxPQUFPLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUM5QixhQUFhO1FBQ2IsWUFBWTtRQUNaLFNBQVM7UUFDVCxJQUFJLEVBQUUsRUFBQyxLQUFLLEVBQUM7UUFDYixHQUFHLENBQUMsQ0FBQyxZQUFZLElBQUksSUFBSSxLQUFLLEVBQUU7WUFDNUIsQ0FBQyxDQUFDLEVBQUMsUUFBUSxFQUFFLENBQUMsRUFBQyxJQUFJLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBQyxDQUFDLEVBQUM7WUFDN0MsQ0FBQyxDQUFDLEVBQUUsQ0FBQztLQUNaLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHt0eXBlIEVudmlyb25tZW50UHJvdmlkZXJzLCB0eXBlIFByb3ZpZGVyLCB0eXBlIFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHt0eXBlIERlZmF1bHRFeHBvcnQsIHR5cGUgTG9hZENoaWxkcmVuLCB0eXBlIFJvdXRlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHt0eXBlIE9ic2VydmFibGV9IGZyb20gJ3J4anMnO1xuXG5pbnRlcmZhY2UgT3B0aW9ucyB7XG4gICAgcGF0aD86IHN0cmluZztcbiAgICB0aXRsZT86IHN0cmluZztcbiAgICBsb2FkQ29tcG9uZW50PzogKCkgPT5cbiAgICAgICAgfCBPYnNlcnZhYmxlPERlZmF1bHRFeHBvcnQ8VHlwZTx1bmtub3duPj4gfCBUeXBlPHVua25vd24+PlxuICAgICAgICB8IFByb21pc2U8RGVmYXVsdEV4cG9ydDxUeXBlPHVua25vd24+PiB8IFR5cGU8dW5rbm93bj4+XG4gICAgICAgIHwgVHlwZTx1bmtub3duPjtcbiAgICBsb2FkQ2hpbGRyZW4/OiBMb2FkQ2hpbGRyZW47XG4gICAgcHJvdmlkZXJzPzogQXJyYXk8RW52aXJvbm1lbnRQcm92aWRlcnMgfCBQcm92aWRlcj47XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlQcm92aWRlUm91dGVQYWdlVGFiKHtcbiAgICBwYXRoLFxuICAgIHRpdGxlLFxuICAgIGxvYWRDb21wb25lbnQsXG4gICAgbG9hZENoaWxkcmVuLFxuICAgIHByb3ZpZGVycyxcbn06IE9wdGlvbnMgPSB7fSk6IFJvdXRlIHtcbiAgICByZXR1cm4ge1xuICAgICAgICBwYXRoOiBwYXRoPy5yZXBsYWNlKC9eXFwvLywgJycpLCAvLyBFcnJvcjogTkcwNDAxNDogSW52YWxpZCBjb25maWd1cmF0aW9uIG9mIHJvdXRlOiBwYXRoIGNhbm5vdCBzdGFydCB3aXRoIGEgc2xhc2hcbiAgICAgICAgbG9hZENvbXBvbmVudCxcbiAgICAgICAgbG9hZENoaWxkcmVuLFxuICAgICAgICBwcm92aWRlcnMsXG4gICAgICAgIGRhdGE6IHt0aXRsZX0sXG4gICAgICAgIC4uLighbG9hZENoaWxkcmVuICYmIHBhdGggIT09ICcnXG4gICAgICAgICAgICA/IHtjaGlsZHJlbjogW3twYXRoOiAnOnRhYicsIGxvYWRDb21wb25lbnR9XX1cbiAgICAgICAgICAgIDoge30pLFxuICAgIH07XG59XG4iXX0=
@@ -1,4 +1,4 @@
1
1
  export async function tuiRawLoad(content) {
2
- return content instanceof Promise ? (await content).default : content;
2
+ return Promise.resolve(content).then((x) => typeof x === 'object' && 'default' in x ? x.default : x);
3
3
  }
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmF3LWxvYWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvdXRpbHMvcmF3LWxvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLEtBQUssVUFBVSxVQUFVLENBQUMsT0FBNEI7SUFDekQsT0FBTyxPQUFPLFlBQVksT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sT0FBTyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUM7QUFDMUUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dHlwZSBUdWlSYXdMb2FkZXJDb250ZW50fSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tZG9jL3R5cGVzJztcblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHR1aVJhd0xvYWQoY29udGVudDogVHVpUmF3TG9hZGVyQ29udGVudCk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgcmV0dXJuIGNvbnRlbnQgaW5zdGFuY2VvZiBQcm9taXNlID8gKGF3YWl0IGNvbnRlbnQpLmRlZmF1bHQgOiBjb250ZW50O1xufVxuIl19
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmF3LWxvYWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvdXRpbHMvcmF3LWxvYWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLEtBQUssVUFBVSxVQUFVLENBQUMsT0FBNEI7SUFDekQsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQ3ZDLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxTQUFTLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQzFELENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHt0eXBlIFR1aVJhd0xvYWRlckNvbnRlbnR9IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvdHlwZXMnO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gdHVpUmF3TG9hZChjb250ZW50OiBUdWlSYXdMb2FkZXJDb250ZW50KTogUHJvbWlzZTxzdHJpbmc+IHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKGNvbnRlbnQpLnRoZW4oKHgpID0+XG4gICAgICAgIHR5cGVvZiB4ID09PSAnb2JqZWN0JyAmJiAnZGVmYXVsdCcgaW4geCA/IHguZGVmYXVsdCA6IHgsXG4gICAgKTtcbn1cbiJdfQ==
@@ -78,6 +78,7 @@ import { TuiRoot } from '@taiga-ui/core/components/root';
78
78
  import { TuiReplacePipe } from '@taiga-ui/cdk/pipes/replace';
79
79
  import { TuiAutoColorPipe } from '@taiga-ui/core/pipes/auto-color';
80
80
  import { TuiChip } from '@taiga-ui/kit/components/chip';
81
+ import { tuiCreateOptions } from '@taiga-ui/cdk/utils/di';
81
82
 
82
83
  class TuiDocAPI {
83
84
  constructor() {
@@ -1327,6 +1328,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1327
1328
  ], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.Default, template: "<tui-root [attr.tuiTheme]=\"theme()\">\n <div class=\"tui-doc-page\">\n <tui-doc-navigation class=\"tui-doc-navigation\">\n <ng-content select=\"tuiDocNavigation\" />\n </tui-doc-navigation>\n <div class=\"tui-doc-content\">\n <router-outlet class=\"tui-doc-outlet\" />\n </div>\n </div>\n <header tuiDocHeader>\n <ng-content select=\"tuiDocHeader\" />\n\n <button\n *ngIf=\"dir && icons.ltr\"\n appearance=\"outline\"\n aria-label=\"Switch directionality of the element's text\"\n size=\"s\"\n tuiButton\n type=\"button\"\n class=\"tui-doc-switch-direction\"\n [iconEnd]=\"icons.ltr.preview\"\n (click)=\"changeTextDirection()\"\n >\n <tui-icon [icon]=\"icons.ltr.direction\" />\n </button>\n\n <button\n appearance=\"secondary\"\n aria-label=\"Switch between dark and light mode\"\n size=\"s\"\n tuiIconButton\n type=\"button\"\n class=\"tui-doc-dark-mode-switch\"\n [iconStart]=\"icon()\"\n [style.border-radius.%]=\"100\"\n (click)=\"darkMode.set(!darkMode())\"\n ></button>\n </header>\n <ng-container ngProjectAs=\"tuiOverContent\">\n <ng-content select=\"tuiOverContent\" />\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverDialogs\">\n <ng-content select=\"tuiOverDialogs\" />\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverAlerts\">\n <ng-content select=\"tuiOverAlerts\" />\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverDropdowns\">\n <ng-content select=\"tuiOverDropdowns\" />\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverHints\">\n <ng-content select=\"tuiOverHints\" />\n </ng-container>\n</tui-root>\n", styles: ["@keyframes tuiShaking{0%,to{transform:translateZ(0)}10%,30%,50%,70%,90%{transform:translate3d(-.3125rem,0,0)}20%,40%,60%,80%{transform:translate3d(.3125rem,0,0)}}html,body{scroll-padding-top:4rem;background:var(--tui-background-base)}tui-root>tui-scroll-controls>.t-bar_vertical{top:4rem!important}tui-doc-main{display:block}code:not(pre code):not(.hljs):not([class*=language-]){transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:inline-flex;background:var(--tui-background-neutral-1);color:var(--tui-text-secondary);vertical-align:middle;align-items:center;border-radius:.25rem;font-weight:500;outline:1px solid var(--tui-border-hover);font-size:.75rem;padding:0 .3125rem;margin:.125rem .1875rem;text-wrap:wrap}a code:not(pre code):not(.hljs):not([class*=language-]){color:var(--tui-text-action)}button:focus code,a:focus code{background:var(--tui-background-base)}.tui-doc-page{isolation:isolate;padding-block-start:4rem}tui-doc-navigation.tui-doc-navigation{position:fixed;top:4rem;bottom:0;inline-size:16.25rem;border-inline-end:1px solid var(--tui-border-normal)}@media screen and (max-width: 47.9625em){tui-doc-navigation.tui-doc-navigation{display:none}}.tui-doc-content{margin-inline-start:16.25rem}@media screen and (max-width: 47.9625em){.tui-doc-content{margin-inline-start:0}}.tui-doc-outlet+*{display:block}.tui-doc-switch-direction,.tui-doc-dark-mode-switch{margin-inline-start:1rem}tui-doc-code .hljs-tag{background:none}tui-doc-code .hljs{display:block;overflow-x:auto;padding:.5em;color:var(--tui-text-primary);background-color:var(--tui-background-neutral-1)}tui-doc-code .hljs.hljs-line-numbers{background:transparent}tui-doc-code .hljs-subst,tui-doc-code .hljs-title{font-weight:400;color:var(--tui-text-primary)}tui-doc-code .hljs-property{color:#bd65a4}tui-doc-code .hljs-comment,tui-doc-code .hljs-quote{color:var(--tui-text-secondary);font-style:italic}tui-doc-code .hljs-meta{color:#e38162}tui-doc-code .hljs-section,tui-doc-code .hljs-name,tui-doc-code .hljs-literal,tui-doc-code .hljs-keyword,tui-doc-code .hljs-selector-tag,tui-doc-code .hljs-type,tui-doc-code .hljs-selector-id,tui-doc-code .hljs-selector-class{font-weight:700;color:var(--tui-text-action)}tui-doc-code .hljs-attr{color:var(--tui-text-action)}tui-doc-code .hljs-attribute,tui-doc-code .hljs-number,tui-doc-code .hljs-regexp,tui-doc-code .hljs-link,tui-doc-code .hljs-built_in{font-weight:700;color:#b8474e}tui-doc-code .hljs-number,tui-doc-code .hljs-regexp,tui-doc-code .hljs-link{font-weight:400}tui-doc-code .hljs-string{color:var(--tui-status-positive);font-weight:700}tui-doc-code .hljs-symbol,tui-doc-code .hljs-bullet,tui-doc-code .hljs-formula{color:var(--tui-text-primary);background:var(--tui-background-base-alt);font-style:italic}tui-doc-code .hljs-doctag{text-decoration:underline}tui-doc-code .hljs-variable,tui-doc-code .hljs-template-variable{color:var(--tui-text-action-hover)}tui-doc-code .hljs-addition{background:var(--tui-status-positive-pale)}tui-doc-code .hljs-deletion{background:var(--tui-status-negative-pale)}tui-doc-code .hljs-emphasis{font-style:italic}tui-doc-code .hljs-strong{font-weight:700}tui-doc-code .hljs .hljs-line-numbers{padding:0}tui-doc-code .hljs-ln-numbers{vertical-align:top;opacity:.3;text-align:end;padding-inline-end:1em!important}[tuiTheme=dark] tui-doc-code .hljs-variable,tui-doc-code[tuiTheme=dark] .hljs-variable,[tuiTheme=dark] tui-doc-code .hljs-template-variable,tui-doc-code[tuiTheme=dark] .hljs-template-variable{color:var(--tui-status-warning)}\n"] }]
1328
1329
  }] });
1329
1330
 
1331
+ const [TUI_DOC_PAGE_OPTIONS, tuiDocPageOptionsProvider] = tuiCreateOptions({
1332
+ header: '',
1333
+ package: '',
1334
+ type: '',
1335
+ tags: [],
1336
+ path: '',
1337
+ deprecated: false,
1338
+ });
1330
1339
  const TUI_DOC_TABS = new InjectionToken(ngDevMode ? 'TUI_DOC_TABS' : '', {
1331
1340
  factory: () => () => ({}),
1332
1341
  });
@@ -1369,17 +1378,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1369
1378
 
1370
1379
  class TuiDocPage {
1371
1380
  constructor() {
1381
+ this.options = inject(TUI_DOC_PAGE_OPTIONS);
1372
1382
  this.tabs = inject(TUI_DOC_TABS)(inject(ActivatedRoute).snapshot);
1373
1383
  this.supportLanguage = inject(TUI_DOC_SUPPORT_LANGUAGE);
1374
1384
  this.defaultTabs = inject(TUI_DOC_DEFAULT_TABS);
1375
1385
  this.from = / /g;
1376
1386
  this.to = '_';
1377
- this.header = '';
1378
- this.package = '';
1379
- this.type = '';
1380
- this.tags = [];
1381
- this.path = '';
1382
- this.deprecated = false;
1387
+ this.header = this.options.header;
1388
+ this.package = this.options.package;
1389
+ this.type = this.options.type;
1390
+ this.tags = this.options.tags;
1391
+ this.path = this.options.path;
1392
+ this.deprecated = this.options.deprecated;
1383
1393
  this.tabConnectors = EMPTY_QUERY;
1384
1394
  this.activeItemIndex = 0;
1385
1395
  this.seeAlso = inject(PAGE_SEE_ALSO);
@@ -1462,5 +1472,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1462
1472
  * Generated bundle index. Do not edit.
1463
1473
  */
1464
1474
 
1465
- export { NAVIGATION_ITEMS, NAVIGATION_LABELS, NAVIGATION_PROVIDERS, NAVIGATION_TITLE, PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_EXAMPLE_DEFAULT_OPTIONS, TUI_DOC_EXAMPLE_OPTIONS, TUI_DOC_TABS, TUI_THEMES, TUI_THEME_KEY, TuiDocAPI, TuiDocAPIItem, TuiDocAPINumberItem, TuiDocCode, TuiDocCopy, TuiDocDemo, TuiDocDocumentation, TuiDocDocumentationPropertyConnector, TuiDocExample, TuiDocExampleGetTabsPipe, TuiDocHeader, TuiDocLanguageSwitcher, TuiDocMain, TuiDocNavigation, TuiDocPage, TuiDocPageTabConnector, TuiDocScrollIntoViewLink, TuiDocSeeAlso, TuiDocSourceCode, TuiDocTab, TuiDocThemeSwitcher, TuiDocTypeReferencePipe, TuiGetColorPipe, TuiGetOpacityPipe, TuiInspectPipe, TuiIsOptionalPipe, TuiIsPrimitivePolymorpheusContentPipe, TuiShowCleanerPipe, TuiStripOptionalPipe, tuiDocExampleOptionsProvider, tuiDocThemeProvider };
1475
+ export { NAVIGATION_ITEMS, NAVIGATION_LABELS, NAVIGATION_PROVIDERS, NAVIGATION_TITLE, PAGE_PROVIDERS, PAGE_SEE_ALSO, TUI_DOC_EXAMPLE_DEFAULT_OPTIONS, TUI_DOC_EXAMPLE_OPTIONS, TUI_DOC_PAGE_OPTIONS, TUI_DOC_TABS, TUI_THEMES, TUI_THEME_KEY, TuiDocAPI, TuiDocAPIItem, TuiDocAPINumberItem, TuiDocCode, TuiDocCopy, TuiDocDemo, TuiDocDocumentation, TuiDocDocumentationPropertyConnector, TuiDocExample, TuiDocExampleGetTabsPipe, TuiDocHeader, TuiDocLanguageSwitcher, TuiDocMain, TuiDocNavigation, TuiDocPage, TuiDocPageTabConnector, TuiDocScrollIntoViewLink, TuiDocSeeAlso, TuiDocSourceCode, TuiDocTab, TuiDocThemeSwitcher, TuiDocTypeReferencePipe, TuiGetColorPipe, TuiGetOpacityPipe, TuiInspectPipe, TuiIsOptionalPipe, TuiIsPrimitivePolymorpheusContentPipe, TuiShowCleanerPipe, TuiStripOptionalPipe, tuiDocExampleOptionsProvider, tuiDocPageOptionsProvider, tuiDocThemeProvider };
1466
1476
  //# sourceMappingURL=taiga-ui-addon-doc-components.mjs.map