@taiga-ui/addon-doc 3.58.0 → 3.59.0-canary.10da730
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/components/code/code.component.d.ts +1 -1
- package/components/copy/copy.component.d.ts +1 -1
- package/components/demo/demo.component.d.ts +3 -3
- package/components/doc-tab/doc-tab.component.d.ts +1 -1
- package/components/documentation/documentation-property-connector.directive.d.ts +3 -3
- package/components/documentation/documentation.component.d.ts +1 -1
- package/components/documentation/pipes/cleaner.pipe.d.ts +1 -1
- package/components/documentation/pipes/color.pipe.d.ts +1 -1
- package/components/documentation/pipes/inspect.pipe.d.ts +1 -1
- package/components/documentation/pipes/opacity.pipe.d.ts +1 -1
- package/components/documentation/pipes/optional.pipe.d.ts +1 -1
- package/components/documentation/pipes/primitive-polymorpheus-content.pipe.d.ts +1 -1
- package/components/documentation/pipes/strip-optional.pipe.d.ts +1 -1
- package/components/documentation/pipes/type-reference.pipe.d.ts +1 -1
- package/components/example/example-get-tabs.pipe.d.ts +1 -1
- package/components/example/example.component.d.ts +1 -1
- package/components/internal/header/header.component.d.ts +1 -1
- package/components/internal/input-opacity/input-opacity.directive.d.ts +1 -1
- package/components/internal/see-also/see-also.component.d.ts +1 -1
- package/components/internal/source-code/source-code.component.d.ts +1 -1
- package/components/language-switcher/language-switcher.component.d.ts +3 -3
- package/components/main/main.component.d.ts +1 -1
- package/components/navigation/navigation.component.d.ts +3 -3
- package/components/page/page-tab.directive.d.ts +1 -1
- package/components/page/page.component.d.ts +1 -1
- package/directives/scroll-into-view/scroll-into-view.directive.d.ts +1 -1
- package/directives/text-code/text-code.directive.d.ts +1 -1
- package/{esm2015/addon-doc.module.js → esm2020/addon-doc.module.mjs} +4 -4
- package/esm2020/components/code/code.component.mjs +42 -0
- package/{esm2015/components/code/code.module.js → esm2020/components/code/code.module.mjs} +9 -11
- package/esm2020/components/copy/copy.component.mjs +35 -0
- package/{esm2015/components/copy/copy.module.js → esm2020/components/copy/copy.module.mjs} +5 -5
- package/esm2020/components/demo/demo.component.mjs +179 -0
- package/{esm2015/components/demo/demo.module.js → esm2020/components/demo/demo.module.mjs} +23 -25
- package/esm2020/components/doc-tab/doc-tab.component.mjs +17 -0
- package/{esm2015/components/doc-tab/doc-tab.module.js → esm2020/components/doc-tab/doc-tab.module.mjs} +5 -5
- package/{esm2015/components/documentation/documentation-property-connector.directive.js → esm2020/components/documentation/documentation-property-connector.directive.mjs} +8 -5
- package/esm2020/components/documentation/documentation.component.mjs +109 -0
- package/{esm2015/components/documentation/documentation.module.js → esm2020/components/documentation/documentation.module.mjs} +22 -24
- package/{esm2015/components/documentation/pipes/cleaner.pipe.js → esm2020/components/documentation/pipes/cleaner.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/color.pipe.js → esm2020/components/documentation/pipes/color.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/inspect.pipe.js → esm2020/components/documentation/pipes/inspect.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/opacity.pipe.js → esm2020/components/documentation/pipes/opacity.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/optional.pipe.js → esm2020/components/documentation/pipes/optional.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/primitive-polymorpheus-content.pipe.js → esm2020/components/documentation/pipes/primitive-polymorpheus-content.pipe.mjs} +3 -3
- package/{esm2015/components/documentation/pipes/strip-optional.pipe.js → esm2020/components/documentation/pipes/strip-optional.pipe.mjs} +3 -3
- package/esm2020/components/documentation/pipes/type-reference.pipe.mjs +31 -0
- package/{esm2015/components/example/example-get-tabs.pipe.js → esm2020/components/example/example-get-tabs.pipe.mjs} +3 -3
- package/esm2020/components/example/example.component.mjs +150 -0
- package/{esm2015/components/example/example.module.js → esm2020/components/example/example.module.mjs} +13 -15
- package/esm2020/components/internal/header/header.component.mjs +54 -0
- package/{esm2015/components/internal/header/header.module.js → esm2020/components/internal/header/header.module.mjs} +10 -12
- package/{esm2015/components/internal/input-opacity/input-opacity.directive.js → esm2020/components/internal/input-opacity/input-opacity.directive.mjs} +8 -8
- package/{esm2015/components/internal/input-opacity/input-opacity.module.js → esm2020/components/internal/input-opacity/input-opacity.module.mjs} +4 -4
- package/esm2020/components/internal/see-also/see-also.component.mjs +31 -0
- package/{esm2015/components/internal/see-also/see-also.module.js → esm2020/components/internal/see-also/see-also.module.mjs} +5 -5
- package/{esm2015/components/internal/source-code/source-code.component.js → esm2020/components/internal/source-code/source-code.component.mjs} +7 -11
- package/{esm2015/components/internal/source-code/source-code.module.js → esm2020/components/internal/source-code/source-code.module.mjs} +5 -5
- package/esm2020/components/language-switcher/language-switcher.component.mjs +61 -0
- package/{esm2015/components/language-switcher/language-switcher.module.js → esm2020/components/language-switcher/language-switcher.module.mjs} +9 -11
- package/esm2020/components/main/main.component.mjs +59 -0
- package/{esm2015/components/main/main.module.js → esm2020/components/main/main.module.mjs} +14 -16
- package/esm2020/components/navigation/navigation.component.mjs +213 -0
- package/{esm2015/components/navigation/navigation.module.js → esm2020/components/navigation/navigation.module.mjs} +24 -26
- package/esm2020/components/navigation/navigation.providers.mjs +48 -0
- package/{esm2015/components/page/page-tab.directive.js → esm2020/components/page/page-tab.directive.mjs} +3 -3
- package/esm2020/components/page/page.component.mjs +56 -0
- package/{esm2015/components/page/page.module.js → esm2020/components/page/page.module.mjs} +11 -13
- package/esm2020/directives/scroll-into-view/scroll-into-view.directive.mjs +44 -0
- package/{esm2015/directives/scroll-into-view/scroll-into-view.module.js → esm2020/directives/scroll-into-view/scroll-into-view.module.mjs} +4 -4
- package/{esm2015/directives/text-code/text-code.directive.js → esm2020/directives/text-code/text-code.directive.mjs} +3 -3
- package/{esm2015/directives/text-code/text-code.module.js → esm2020/directives/text-code/text-code.module.mjs} +4 -4
- package/{esm2015/services/theme-night.service.js → esm2020/services/theme-night.service.mjs} +4 -4
- package/{esm2015/services/theme.service.js → esm2020/services/theme.service.mjs} +4 -4
- package/esm2020/tokens/page-loaded.mjs +7 -0
- package/esm2020/tokens/pages.mjs +9 -0
- package/esm2020/utils/coerce-boolean.mjs +4 -0
- package/{esm2015/utils/coerce-value.js → esm2020/utils/coerce-value.mjs} +2 -2
- package/esm2020/utils/raw-load-record.mjs +11 -0
- package/esm2020/utils/raw-load.mjs +4 -0
- package/esm2020/utils/sort-pages.mjs +26 -0
- package/esm2020/utils/to-flat-map-pages.mjs +22 -0
- package/esm2020/utils/type-reference-parser.mjs +24 -0
- package/fesm2015/taiga-ui-addon-doc-components.mjs +1909 -0
- package/fesm2015/taiga-ui-addon-doc-components.mjs.map +1 -0
- package/fesm2015/taiga-ui-addon-doc-directives.mjs +99 -0
- package/fesm2015/taiga-ui-addon-doc-directives.mjs.map +1 -0
- package/fesm2015/{taiga-ui-addon-doc-interfaces.js → taiga-ui-addon-doc-interfaces.mjs} +1 -1
- package/fesm2015/taiga-ui-addon-doc-interfaces.mjs.map +1 -0
- package/fesm2015/{taiga-ui-addon-doc-languages.js → taiga-ui-addon-doc-languages.mjs} +1 -1
- package/fesm2015/taiga-ui-addon-doc-languages.mjs.map +1 -0
- package/fesm2015/taiga-ui-addon-doc-services.mjs +97 -0
- package/fesm2015/taiga-ui-addon-doc-services.mjs.map +1 -0
- package/fesm2015/{taiga-ui-addon-doc-tokens.js → taiga-ui-addon-doc-tokens.mjs} +2 -3
- package/fesm2015/taiga-ui-addon-doc-tokens.mjs.map +1 -0
- package/fesm2015/taiga-ui-addon-doc-types.mjs +4 -0
- package/fesm2015/taiga-ui-addon-doc-types.mjs.map +1 -0
- package/fesm2015/{taiga-ui-addon-doc-utils.js → taiga-ui-addon-doc-utils.mjs} +7 -6
- package/fesm2015/taiga-ui-addon-doc-utils.mjs.map +1 -0
- package/fesm2015/{taiga-ui-addon-doc.js → taiga-ui-addon-doc.mjs} +5 -5
- package/fesm2015/taiga-ui-addon-doc.mjs.map +1 -0
- package/{fesm2015/taiga-ui-addon-doc-components.js → fesm2020/taiga-ui-addon-doc-components.mjs} +351 -441
- package/fesm2020/taiga-ui-addon-doc-components.mjs.map +1 -0
- package/{fesm2015/taiga-ui-addon-doc-directives.js → fesm2020/taiga-ui-addon-doc-directives.mjs} +19 -20
- package/fesm2020/taiga-ui-addon-doc-directives.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc-interfaces.mjs +12 -0
- package/fesm2020/taiga-ui-addon-doc-interfaces.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc-languages.mjs +46 -0
- package/fesm2020/taiga-ui-addon-doc-languages.mjs.map +1 -0
- package/{fesm2015/taiga-ui-addon-doc-services.js → fesm2020/taiga-ui-addon-doc-services.mjs} +7 -7
- package/fesm2020/taiga-ui-addon-doc-services.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc-tokens.mjs +148 -0
- package/fesm2020/taiga-ui-addon-doc-tokens.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc-types.mjs +4 -0
- package/fesm2020/taiga-ui-addon-doc-types.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc-utils.mjs +275 -0
- package/fesm2020/taiga-ui-addon-doc-utils.mjs.map +1 -0
- package/fesm2020/taiga-ui-addon-doc.mjs +49 -0
- package/fesm2020/taiga-ui-addon-doc.mjs.map +1 -0
- package/interfaces/page.d.ts +3 -3
- package/package.json +115 -38
- package/tokens/pages.d.ts +4 -2
- package/types/pages.d.ts +1 -1
- package/utils/type-reference-parser.d.ts +1 -1
- package/bundles/taiga-ui-addon-doc-components.umd.js +0 -2549
- package/bundles/taiga-ui-addon-doc-components.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-directives.umd.js +0 -140
- package/bundles/taiga-ui-addon-doc-directives.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-interfaces.umd.js +0 -22
- package/bundles/taiga-ui-addon-doc-interfaces.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-languages.umd.js +0 -54
- package/bundles/taiga-ui-addon-doc-languages.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-services.umd.js +0 -457
- package/bundles/taiga-ui-addon-doc-services.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-tokens.umd.js +0 -179
- package/bundles/taiga-ui-addon-doc-tokens.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-types.umd.js +0 -11
- package/bundles/taiga-ui-addon-doc-types.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc-utils.umd.js +0 -671
- package/bundles/taiga-ui-addon-doc-utils.umd.js.map +0 -1
- package/bundles/taiga-ui-addon-doc.umd.js +0 -117
- package/bundles/taiga-ui-addon-doc.umd.js.map +0 -1
- package/components/package.json +0 -10
- package/components/taiga-ui-addon-doc-components.d.ts +0 -5
- package/directives/package.json +0 -10
- package/directives/taiga-ui-addon-doc-directives.d.ts +0 -5
- package/esm2015/components/code/code.component.js +0 -48
- package/esm2015/components/copy/copy.component.js +0 -42
- package/esm2015/components/demo/demo.component.js +0 -183
- package/esm2015/components/doc-tab/doc-tab.component.js +0 -22
- package/esm2015/components/documentation/documentation.component.js +0 -117
- package/esm2015/components/documentation/pipes/type-reference.pipe.js +0 -34
- package/esm2015/components/example/example.component.js +0 -152
- package/esm2015/components/internal/header/header.component.js +0 -60
- package/esm2015/components/internal/see-also/see-also.component.js +0 -37
- package/esm2015/components/language-switcher/language-switcher.component.js +0 -67
- package/esm2015/components/main/main.component.js +0 -68
- package/esm2015/components/navigation/navigation.component.js +0 -221
- package/esm2015/components/navigation/navigation.providers.js +0 -48
- package/esm2015/components/page/page.component.js +0 -62
- package/esm2015/directives/scroll-into-view/scroll-into-view.directive.js +0 -45
- package/esm2015/tokens/page-loaded.js +0 -8
- package/esm2015/tokens/pages.js +0 -9
- package/esm2015/utils/coerce-boolean.js +0 -4
- package/esm2015/utils/raw-load-record.js +0 -14
- package/esm2015/utils/raw-load.js +0 -7
- package/esm2015/utils/sort-pages.js +0 -23
- package/esm2015/utils/to-flat-map-pages.js +0 -23
- package/esm2015/utils/type-reference-parser.js +0 -24
- package/fesm2015/taiga-ui-addon-doc-components.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-directives.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-interfaces.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-languages.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-services.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-tokens.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-types.js +0 -4
- package/fesm2015/taiga-ui-addon-doc-types.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc-utils.js.map +0 -1
- package/fesm2015/taiga-ui-addon-doc.js.map +0 -1
- package/interfaces/package.json +0 -10
- package/interfaces/taiga-ui-addon-doc-interfaces.d.ts +0 -5
- package/languages/package.json +0 -10
- package/languages/taiga-ui-addon-doc-languages.d.ts +0 -5
- package/services/package.json +0 -10
- package/services/taiga-ui-addon-doc-services.d.ts +0 -5
- package/taiga-ui-addon-doc.d.ts +0 -5
- package/tokens/package.json +0 -10
- package/tokens/taiga-ui-addon-doc-tokens.d.ts +0 -5
- package/types/package.json +0 -10
- package/types/taiga-ui-addon-doc-types.d.ts +0 -5
- package/utils/package.json +0 -10
- package/utils/taiga-ui-addon-doc-utils.d.ts +0 -5
- /package/{esm2015/components/example/example.options.js → esm2020/components/example/example.options.mjs} +0 -0
- /package/{esm2015/components/index.js → esm2020/components/index.mjs} +0 -0
- /package/{esm2015/components/page/page.providers.js → esm2020/components/page/page.providers.mjs} +0 -0
- /package/{esm2015/components/taiga-ui-addon-doc-components.js → esm2020/components/taiga-ui-addon-doc-components.mjs} +0 -0
- /package/{esm2015/directives/index.js → esm2020/directives/index.mjs} +0 -0
- /package/{esm2015/directives/taiga-ui-addon-doc-directives.js → esm2020/directives/taiga-ui-addon-doc-directives.mjs} +0 -0
- /package/{esm2015/index.js → esm2020/index.mjs} +0 -0
- /package/{esm2015/interfaces/code-editor.js → esm2020/interfaces/code-editor.mjs} +0 -0
- /package/{esm2015/interfaces/demo-params.js → esm2020/interfaces/demo-params.mjs} +0 -0
- /package/{esm2015/interfaces/index.js → esm2020/interfaces/index.mjs} +0 -0
- /package/{esm2015/interfaces/page.js → esm2020/interfaces/page.mjs} +0 -0
- /package/{esm2015/interfaces/source-code-path-options.js → esm2020/interfaces/source-code-path-options.mjs} +0 -0
- /package/{esm2015/interfaces/taiga-ui-addon-doc-interfaces.js → esm2020/interfaces/taiga-ui-addon-doc-interfaces.mjs} +0 -0
- /package/{esm2015/languages/index.js → esm2020/languages/index.mjs} +0 -0
- /package/{esm2015/languages/russian.js → esm2020/languages/russian.mjs} +0 -0
- /package/{esm2015/languages/taiga-ui-addon-doc-languages.js → esm2020/languages/taiga-ui-addon-doc-languages.mjs} +0 -0
- /package/{esm2015/services/index.js → esm2020/services/index.mjs} +0 -0
- /package/{esm2015/services/taiga-ui-addon-doc-services.js → esm2020/services/taiga-ui-addon-doc-services.mjs} +0 -0
- /package/{esm2015/services/theme-night.options.js → esm2020/services/theme-night.options.mjs} +0 -0
- /package/{esm2015/services/theme.options.js → esm2020/services/theme.options.mjs} +0 -0
- /package/{esm2015/taiga-ui-addon-doc.js → esm2020/taiga-ui-addon-doc.mjs} +0 -0
- /package/{esm2015/tokens/code-actions.js → esm2020/tokens/code-actions.mjs} +0 -0
- /package/{esm2015/tokens/code-editor.js → esm2020/tokens/code-editor.mjs} +0 -0
- /package/{esm2015/tokens/default-tabs.js → esm2020/tokens/default-tabs.mjs} +0 -0
- /package/{esm2015/tokens/doc-icons.js → esm2020/tokens/doc-icons.mjs} +0 -0
- /package/{esm2015/tokens/example-content-processor.js → esm2020/tokens/example-content-processor.mjs} +0 -0
- /package/{esm2015/tokens/excluded-properties.js → esm2020/tokens/excluded-properties.mjs} +0 -0
- /package/{esm2015/tokens/i18n.js → esm2020/tokens/i18n.mjs} +0 -0
- /package/{esm2015/tokens/index.js → esm2020/tokens/index.mjs} +0 -0
- /package/{esm2015/tokens/logo.js → esm2020/tokens/logo.mjs} +0 -0
- /package/{esm2015/tokens/scroll-behavior.js → esm2020/tokens/scroll-behavior.mjs} +0 -0
- /package/{esm2015/tokens/see-also.js → esm2020/tokens/see-also.mjs} +0 -0
- /package/{esm2015/tokens/source-code.js → esm2020/tokens/source-code.mjs} +0 -0
- /package/{esm2015/tokens/taiga-ui-addon-doc-tokens.js → esm2020/tokens/taiga-ui-addon-doc-tokens.mjs} +0 -0
- /package/{esm2015/tokens/title.js → esm2020/tokens/title.mjs} +0 -0
- /package/{esm2015/tokens/type-reference-handler.js → esm2020/tokens/type-reference-handler.mjs} +0 -0
- /package/{esm2015/tokens/url-state-handler.js → esm2020/tokens/url-state-handler.mjs} +0 -0
- /package/{esm2015/types/index.js → esm2020/types/index.mjs} +0 -0
- /package/{esm2015/types/pages.js → esm2020/types/pages.mjs} +0 -0
- /package/{esm2015/types/taiga-ui-addon-doc-types.js → esm2020/types/taiga-ui-addon-doc-types.mjs} +0 -0
- /package/{esm2015/utils/generate-routes.js → esm2020/utils/generate-routes.mjs} +0 -0
- /package/{esm2015/utils/index.js → esm2020/utils/index.mjs} +0 -0
- /package/{esm2015/utils/inspect.js → esm2020/utils/inspect.mjs} +0 -0
- /package/{esm2015/utils/is-page-group.js → esm2020/utils/is-page-group.mjs} +0 -0
- /package/{esm2015/utils/parse-code-block.js → esm2020/utils/parse-code-block.mjs} +0 -0
- /package/{esm2015/utils/taiga-ui-addon-doc-utils.js → esm2020/utils/taiga-ui-addon-doc-utils.mjs} +0 -0
- /package/{esm2015/utils/transliterate-keyboard-layout.js → esm2020/utils/transliterate-keyboard-layout.mjs} +0 -0
|
@@ -0,0 +1,213 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, Inject, Optional, Self, } from '@angular/core';
|
|
4
|
+
import { UntypedFormControl } from '@angular/forms';
|
|
5
|
+
import { Title } from '@angular/platform-browser';
|
|
6
|
+
import { ActivatedRoute, Router, Scroll } from '@angular/router';
|
|
7
|
+
import { TUI_DOC_ICONS, TUI_DOC_PAGE_LOADED, TUI_DOC_SEARCH_TEXT, } from '@taiga-ui/addon-doc/tokens';
|
|
8
|
+
import { tuiTransliterateKeyboardLayout } from '@taiga-ui/addon-doc/utils';
|
|
9
|
+
import { TuiSidebarDirective } from '@taiga-ui/addon-mobile';
|
|
10
|
+
import { tuiControlValue, TuiDestroyService, tuiPure, tuiUniqBy } from '@taiga-ui/cdk';
|
|
11
|
+
import { TUI_COMMON_ICONS, TuiModeDirective, } from '@taiga-ui/core';
|
|
12
|
+
import { combineLatest, filter, map, startWith, switchMap, take, takeUntil, } from 'rxjs';
|
|
13
|
+
import { NAVIGATION_ITEMS, NAVIGATION_LABELS, NAVIGATION_PROVIDERS, NAVIGATION_TITLE, } from './navigation.providers';
|
|
14
|
+
import * as i0 from "@angular/core";
|
|
15
|
+
import * as i1 from "@angular/common";
|
|
16
|
+
import * as i2 from "@angular/forms";
|
|
17
|
+
import * as i3 from "@angular/router";
|
|
18
|
+
import * as i4 from "@tinkoff/ng-polymorpheus";
|
|
19
|
+
import * as i5 from "@taiga-ui/addon-doc/directives";
|
|
20
|
+
import * as i6 from "@taiga-ui/kit";
|
|
21
|
+
import * as i7 from "@taiga-ui/core";
|
|
22
|
+
import * as i8 from "@taiga-ui/cdk";
|
|
23
|
+
import * as i9 from "@angular/platform-browser";
|
|
24
|
+
import * as i10 from "rxjs";
|
|
25
|
+
export class TuiDocNavigationComponent {
|
|
26
|
+
constructor(cdr, titleService, title$, mode, sidebar, labels, items, searchText, router, activatedRoute, destroy$, readyToScroll$, docIcons, icons, doc) {
|
|
27
|
+
this.title$ = title$;
|
|
28
|
+
this.mode = mode;
|
|
29
|
+
this.sidebar = sidebar;
|
|
30
|
+
this.labels = labels;
|
|
31
|
+
this.items = items;
|
|
32
|
+
this.searchText = searchText;
|
|
33
|
+
this.router = router;
|
|
34
|
+
this.activatedRoute = activatedRoute;
|
|
35
|
+
this.destroy$ = destroy$;
|
|
36
|
+
this.readyToScroll$ = readyToScroll$;
|
|
37
|
+
this.docIcons = docIcons;
|
|
38
|
+
this.icons = icons;
|
|
39
|
+
this.doc = doc;
|
|
40
|
+
this.menuOpen = false;
|
|
41
|
+
this.openPagesArr = [];
|
|
42
|
+
this.openPagesGroupsArr = [];
|
|
43
|
+
this.active = '';
|
|
44
|
+
this.search = new UntypedFormControl('');
|
|
45
|
+
this.filtered$ = tuiControlValue(this.search).pipe(filter(search => search.trim().length > 2), map(search => this.filterItems(this.flattenSubPages(this.items), search)));
|
|
46
|
+
this.mode$ = this.mode.change$.pipe(startWith(null), map(() => this.mode.mode || 'onLight'));
|
|
47
|
+
title$.subscribe(title => {
|
|
48
|
+
cdr.markForCheck();
|
|
49
|
+
titleService.setTitle(title);
|
|
50
|
+
this.openActivePageGroup();
|
|
51
|
+
});
|
|
52
|
+
combineLatest([
|
|
53
|
+
this.router.events.pipe(filter((event) => event instanceof Scroll)),
|
|
54
|
+
this.title$.pipe(switchMap(() => this.readyToScroll$.pipe(filter(Boolean)))),
|
|
55
|
+
])
|
|
56
|
+
.pipe(take(1), map(([event]) => event.anchor || ''), filter(Boolean), takeUntil(this.destroy$))
|
|
57
|
+
.subscribe(anchor => this.navigateToAnchorLink(anchor));
|
|
58
|
+
}
|
|
59
|
+
get canOpen() {
|
|
60
|
+
return (this.search.value?.length ?? 0) > 2;
|
|
61
|
+
}
|
|
62
|
+
get itemsWithoutSections() {
|
|
63
|
+
return this.items[this.items.length - 1];
|
|
64
|
+
}
|
|
65
|
+
$pages(pages) {
|
|
66
|
+
return pages;
|
|
67
|
+
}
|
|
68
|
+
isActive(route) {
|
|
69
|
+
return route === this.active;
|
|
70
|
+
}
|
|
71
|
+
onGroupClick(index) {
|
|
72
|
+
this.openPagesGroupsArr[index] = !this.openPagesGroupsArr[index];
|
|
73
|
+
}
|
|
74
|
+
closeMenu() {
|
|
75
|
+
this.menuOpen = false;
|
|
76
|
+
}
|
|
77
|
+
onClick(input) {
|
|
78
|
+
input.open = false;
|
|
79
|
+
this.menuOpen = false;
|
|
80
|
+
this.search.setValue('');
|
|
81
|
+
this.openActivePageGroup();
|
|
82
|
+
}
|
|
83
|
+
filterItems(items, search) {
|
|
84
|
+
return items.map(section => tuiUniqBy(section.filter(({ title, keywords = '' }) => {
|
|
85
|
+
search = search.toLowerCase().trim();
|
|
86
|
+
keywords = keywords.toLowerCase();
|
|
87
|
+
title = title.toLowerCase();
|
|
88
|
+
return (title.includes(search) ||
|
|
89
|
+
keywords.includes(search) ||
|
|
90
|
+
title.includes(tuiTransliterateKeyboardLayout(search)) ||
|
|
91
|
+
keywords.includes(tuiTransliterateKeyboardLayout(search)) ||
|
|
92
|
+
search.replace(/-/gi, '').includes(title) ||
|
|
93
|
+
title.includes(search.replace(/\s|tui/g, '')) ||
|
|
94
|
+
keywords.includes(search.replace(/\s|tui/g, '')) ||
|
|
95
|
+
search.split(/\s/).find(word => title.includes(word)));
|
|
96
|
+
}), 'title'));
|
|
97
|
+
}
|
|
98
|
+
flattenSubPages(items) {
|
|
99
|
+
return items.reduce((array, item) => [
|
|
100
|
+
...array,
|
|
101
|
+
item.reduce((pages, page) => 'subPages' in page
|
|
102
|
+
? [...pages, ...page.subPages]
|
|
103
|
+
: [...pages, page], []),
|
|
104
|
+
], []);
|
|
105
|
+
}
|
|
106
|
+
isActiveRoute(route) {
|
|
107
|
+
return this.router.isActive(route, {
|
|
108
|
+
paths: 'subset',
|
|
109
|
+
queryParams: 'subset',
|
|
110
|
+
fragment: 'ignored',
|
|
111
|
+
matrixParams: 'ignored',
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
openActivePageGroup() {
|
|
115
|
+
this.items.forEach((pages, pagesIndex) => {
|
|
116
|
+
pages.forEach((page, pageIndex) => {
|
|
117
|
+
if ('route' in page && this.isActiveRoute(page.route)) {
|
|
118
|
+
this.openPagesArr[pagesIndex] = true;
|
|
119
|
+
this.active = page.route;
|
|
120
|
+
}
|
|
121
|
+
if ('subPages' in page) {
|
|
122
|
+
page.subPages.forEach(subPage => {
|
|
123
|
+
if (this.isActiveRoute(subPage.route)) {
|
|
124
|
+
this.openPagesArr[pagesIndex] = true;
|
|
125
|
+
this.openPagesGroupsArr[pagesIndex * 100 + pageIndex] = true;
|
|
126
|
+
this.active = subPage.route;
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
navigateToAnchorLink(fragment) {
|
|
134
|
+
const nodes = fragment ? this.doc.querySelectorAll(`#${fragment}`) : [];
|
|
135
|
+
const element = nodes.length && nodes[nodes.length - 1];
|
|
136
|
+
if (!element) {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
// emulate :target event
|
|
140
|
+
const target = this.doc.createElement('a');
|
|
141
|
+
target.href = `${this.doc.location.pathname}#${fragment}`;
|
|
142
|
+
target.style.display = 'none';
|
|
143
|
+
target.style.position = 'absolute';
|
|
144
|
+
this.doc.body.appendChild(target);
|
|
145
|
+
target.click();
|
|
146
|
+
target.remove();
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
TuiDocNavigationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationComponent, deps: [{ token: ChangeDetectorRef }, { token: Title }, { token: NAVIGATION_TITLE }, { token: TuiModeDirective }, { token: TuiSidebarDirective, optional: true }, { token: NAVIGATION_LABELS }, { token: NAVIGATION_ITEMS }, { token: TUI_DOC_SEARCH_TEXT }, { token: Router }, { token: ActivatedRoute }, { token: TuiDestroyService, self: true }, { token: TUI_DOC_PAGE_LOADED }, { token: TUI_DOC_ICONS }, { token: TUI_COMMON_ICONS }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component });
|
|
150
|
+
TuiDocNavigationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TuiDocNavigationComponent, selector: "tui-doc-navigation", host: { properties: { "class._open": "this.menuOpen" } }, providers: NAVIGATION_PROVIDERS, ngImport: i0, template: "<tui-input\n #input\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [formControl]=\"search\"\n [tuiAutoFocus]=\"!!sidebar\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiTextfieldIconLeft]=\"docIcons.search\"\n [tuiTextfieldLabelOutside]=\"true\"\n>\n {{ searchText }}\n <ng-container *ngIf=\"canOpen\">\n <tui-data-list *tuiDataList>\n <tui-opt-group\n *ngFor=\"let group of filtered$ | async; let index = index\"\n [label]=\"labels[index] || ''\"\n >\n <a\n *ngFor=\"let item of group\"\n tuiOption\n [fragment]=\"item.fragment\"\n [routerLink]=\"item.route\"\n (click)=\"onClick(input)\"\n >\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n </tui-opt-group>\n </tui-data-list>\n </ng-container>\n</tui-input>\n\n<nav class=\"t-navigation\">\n <tui-scrollbar\n class=\"t-scrollbar\"\n [tuiMode]=\"mode$ | async\"\n >\n <tui-accordion\n [closeOthers]=\"false\"\n [rounded]=\"false\"\n >\n <tui-accordion-item\n *ngFor=\"let label of labels; index as index\"\n size=\"s\"\n [borders]=\"null\"\n [(open)]=\"!!openPagesArr[index]\"\n >\n <span class=\"t-label\">\n <strong>{{ label }}</strong>\n </span>\n <ng-template tuiAccordionItemContent>\n <div class=\"t-section\">\n <ng-container\n *ngFor=\"let item of items[index]; index as subIndex\"\n [ngTemplateOutlet]=\"pages\"\n [ngTemplateOutletContext]=\"{item: item, index: index * 100 + subIndex}\"\n ></ng-container>\n </div>\n </ng-template>\n </tui-accordion-item>\n </tui-accordion>\n <div class=\"t-items-container\">\n <ng-container\n *ngFor=\"let item of itemsWithoutSections; let index = index\"\n [ngTemplateOutlet]=\"pages\"\n [ngTemplateOutletContext]=\"{item: item, index: items.length - 1 + index}\"\n ></ng-container>\n </div>\n\n <ng-template\n #pages\n let-index=\"index\"\n let-item=\"item\"\n >\n <a\n *ngIf=\"!item.subPages; else subPagesTemplate\"\n routerLinkActive=\"t-sublink_active\"\n tuiLink\n class=\"t-sublink\"\n [routerLink]=\"item.route\"\n [tuiScrollIntoViewLink]=\"isActive(item.route)\"\n (click)=\"closeMenu()\"\n >\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n\n <ng-template #subPagesTemplate>\n <div\n routerLinkActive\n class=\"t-subsection\"\n [routerLinkActiveOptions]=\"{exact: false}\"\n >\n <button\n *ngIf=\"item.subPages\"\n tuiLink\n type=\"button\"\n class=\"t-sublink t-sublink_subsection\"\n (click)=\"onGroupClick(index)\"\n >\n <tui-svg\n class=\"t-chevron\"\n [class.t-chevron_active]=\"!!openPagesGroupsArr[index]\"\n [src]=\"icons.more\"\n ></tui-svg>\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </button>\n <tui-expand\n class=\"t-expand\"\n [expanded]=\"!!openPagesGroupsArr[index]\"\n >\n <div class=\"t-section t-section_bordered\">\n <a\n *ngFor=\"let subPage of $pages(item.subPages)\"\n routerLinkActive=\"t-sublink_active\"\n tuiLink\n class=\"t-sublink t-sublink_small\"\n [fragment]=\"subPage.fragment\"\n [routerLink]=\"subPage.route\"\n [tuiScrollIntoViewLink]=\"isActive(subPage.route)\"\n (click)=\"closeMenu()\"\n >\n {{ subPage.title }}\n <tui-svg\n *polymorpheusOutlet=\"subPage.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n </div>\n </tui-expand>\n </div>\n </ng-template>\n </ng-template>\n </tui-scrollbar>\n</nav>\n\n<ng-content></ng-content>\n", styles: [":host{z-index:1;display:flex;flex-direction:column;text-align:center;background:var(--tui-base-01)}.t-input{margin:1.25rem}.t-navigation{display:flex;max-height:100%;min-height:0;flex:1 1 0;text-align:left}.t-scrollbar{scroll-behavior:smooth;width:100%}:host-context(tui-root._reduced-motion) .t-scrollbar{scroll-behavior:auto}.t-items-container{display:flex;flex-direction:column;padding:0 1rem}.t-label{margin-left:.5rem}.t-expand{margin-left:.25rem}.t-section{display:flex;flex-direction:column;align-items:flex-start;margin:-1rem 0 -.5rem}.t-section_bordered{margin:.5rem 0;border-left:1px solid var(--tui-base-03)}.t-subsection{margin-left:.5rem}.t-sublink{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;font:var(--tui-font-text-m);margin-left:.5rem;padding-top:1rem}.t-sublink_small{margin-left:1rem;line-height:1.5rem;padding-top:.5rem}.t-sublink_subsection{margin-left:0;line-height:1.6rem}.t-sublink.t-sublink.t-sublink_active{color:var(--tui-text-01)}.t-icon{margin-left:.5rem}.t-chevron{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;width:1rem;height:1rem;margin:-.25rem .25rem 0 -.1875rem}.t-chevron_active{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "directive", type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: i5.TuiScrollIntoViewLinkDirective, selector: "[tuiScrollIntoViewLink]", inputs: ["tuiScrollIntoViewLink"] }, { kind: "component", type: i6.TuiInputComponent, selector: "tui-input" }, { kind: "directive", type: i6.TuiInputDirective, selector: "tui-input" }, { kind: "directive", type: i7.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { kind: "directive", type: i7.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { kind: "directive", type: i7.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { kind: "directive", type: i7.TuiTextfieldIconLeftDirective, selector: "[tuiTextfieldIconLeft]", inputs: ["tuiTextfieldIconLeft"] }, { kind: "directive", type: i7.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "component", type: i7.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { kind: "component", type: i7.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }, { kind: "component", type: i6.TuiAccordionComponent, selector: "tui-accordion", inputs: ["closeOthers", "rounded"] }, { kind: "component", type: i6.TuiAccordionItemComponent, selector: "tui-accordion-item", inputs: ["noPadding", "showArrow", "borders", "size", "disabled", "disableHover", "open", "async"], outputs: ["openChange"] }, { kind: "directive", type: i6.TuiAccordionItemContentDirective, selector: "ng-template[tuiAccordionItemContent]" }, { kind: "component", type: i7.TuiScrollbarComponent, selector: "tui-scrollbar", inputs: ["hidden"] }, { kind: "component", type: i7.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { kind: "component", type: i7.TuiDataListComponent, selector: "tui-data-list", inputs: ["role", "emptyContent", "size"] }, { kind: "component", type: i7.TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: ["size", "role", "disabled", "value"] }, { kind: "directive", type: i7.TuiOptGroupDirective, selector: "tui-opt-group", inputs: ["label"] }, { kind: "directive", type: i7.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { kind: "directive", type: i8.TuiAutoFocusDirective, selector: "[tuiAutoFocus]", inputs: ["tuiAutoFocus"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
151
|
+
__decorate([
|
|
152
|
+
tuiPure
|
|
153
|
+
], TuiDocNavigationComponent.prototype, "filterItems", null);
|
|
154
|
+
__decorate([
|
|
155
|
+
tuiPure
|
|
156
|
+
], TuiDocNavigationComponent.prototype, "flattenSubPages", null);
|
|
157
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationComponent, decorators: [{
|
|
158
|
+
type: Component,
|
|
159
|
+
args: [{ selector: 'tui-doc-navigation', changeDetection: ChangeDetectionStrategy.OnPush, providers: NAVIGATION_PROVIDERS, template: "<tui-input\n #input\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [formControl]=\"search\"\n [tuiAutoFocus]=\"!!sidebar\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiTextfieldIconLeft]=\"docIcons.search\"\n [tuiTextfieldLabelOutside]=\"true\"\n>\n {{ searchText }}\n <ng-container *ngIf=\"canOpen\">\n <tui-data-list *tuiDataList>\n <tui-opt-group\n *ngFor=\"let group of filtered$ | async; let index = index\"\n [label]=\"labels[index] || ''\"\n >\n <a\n *ngFor=\"let item of group\"\n tuiOption\n [fragment]=\"item.fragment\"\n [routerLink]=\"item.route\"\n (click)=\"onClick(input)\"\n >\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n </tui-opt-group>\n </tui-data-list>\n </ng-container>\n</tui-input>\n\n<nav class=\"t-navigation\">\n <tui-scrollbar\n class=\"t-scrollbar\"\n [tuiMode]=\"mode$ | async\"\n >\n <tui-accordion\n [closeOthers]=\"false\"\n [rounded]=\"false\"\n >\n <tui-accordion-item\n *ngFor=\"let label of labels; index as index\"\n size=\"s\"\n [borders]=\"null\"\n [(open)]=\"!!openPagesArr[index]\"\n >\n <span class=\"t-label\">\n <strong>{{ label }}</strong>\n </span>\n <ng-template tuiAccordionItemContent>\n <div class=\"t-section\">\n <ng-container\n *ngFor=\"let item of items[index]; index as subIndex\"\n [ngTemplateOutlet]=\"pages\"\n [ngTemplateOutletContext]=\"{item: item, index: index * 100 + subIndex}\"\n ></ng-container>\n </div>\n </ng-template>\n </tui-accordion-item>\n </tui-accordion>\n <div class=\"t-items-container\">\n <ng-container\n *ngFor=\"let item of itemsWithoutSections; let index = index\"\n [ngTemplateOutlet]=\"pages\"\n [ngTemplateOutletContext]=\"{item: item, index: items.length - 1 + index}\"\n ></ng-container>\n </div>\n\n <ng-template\n #pages\n let-index=\"index\"\n let-item=\"item\"\n >\n <a\n *ngIf=\"!item.subPages; else subPagesTemplate\"\n routerLinkActive=\"t-sublink_active\"\n tuiLink\n class=\"t-sublink\"\n [routerLink]=\"item.route\"\n [tuiScrollIntoViewLink]=\"isActive(item.route)\"\n (click)=\"closeMenu()\"\n >\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n\n <ng-template #subPagesTemplate>\n <div\n routerLinkActive\n class=\"t-subsection\"\n [routerLinkActiveOptions]=\"{exact: false}\"\n >\n <button\n *ngIf=\"item.subPages\"\n tuiLink\n type=\"button\"\n class=\"t-sublink t-sublink_subsection\"\n (click)=\"onGroupClick(index)\"\n >\n <tui-svg\n class=\"t-chevron\"\n [class.t-chevron_active]=\"!!openPagesGroupsArr[index]\"\n [src]=\"icons.more\"\n ></tui-svg>\n {{ item.title }}\n <tui-svg\n *polymorpheusOutlet=\"item.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </button>\n <tui-expand\n class=\"t-expand\"\n [expanded]=\"!!openPagesGroupsArr[index]\"\n >\n <div class=\"t-section t-section_bordered\">\n <a\n *ngFor=\"let subPage of $pages(item.subPages)\"\n routerLinkActive=\"t-sublink_active\"\n tuiLink\n class=\"t-sublink t-sublink_small\"\n [fragment]=\"subPage.fragment\"\n [routerLink]=\"subPage.route\"\n [tuiScrollIntoViewLink]=\"isActive(subPage.route)\"\n (click)=\"closeMenu()\"\n >\n {{ subPage.title }}\n <tui-svg\n *polymorpheusOutlet=\"subPage.icon as icon\"\n class=\"t-icon\"\n [src]=\"icon\"\n ></tui-svg>\n </a>\n </div>\n </tui-expand>\n </div>\n </ng-template>\n </ng-template>\n </tui-scrollbar>\n</nav>\n\n<ng-content></ng-content>\n", styles: [":host{z-index:1;display:flex;flex-direction:column;text-align:center;background:var(--tui-base-01)}.t-input{margin:1.25rem}.t-navigation{display:flex;max-height:100%;min-height:0;flex:1 1 0;text-align:left}.t-scrollbar{scroll-behavior:smooth;width:100%}:host-context(tui-root._reduced-motion) .t-scrollbar{scroll-behavior:auto}.t-items-container{display:flex;flex-direction:column;padding:0 1rem}.t-label{margin-left:.5rem}.t-expand{margin-left:.25rem}.t-section{display:flex;flex-direction:column;align-items:flex-start;margin:-1rem 0 -.5rem}.t-section_bordered{margin:.5rem 0;border-left:1px solid var(--tui-base-03)}.t-subsection{margin-left:.5rem}.t-sublink{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;text-decoration:none;font:var(--tui-font-text-m);margin-left:.5rem;padding-top:1rem}.t-sublink_small{margin-left:1rem;line-height:1.5rem;padding-top:.5rem}.t-sublink_subsection{margin-left:0;line-height:1.6rem}.t-sublink.t-sublink.t-sublink_active{color:var(--tui-text-01)}.t-icon{margin-left:.5rem}.t-chevron{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;width:1rem;height:1rem;margin:-.25rem .25rem 0 -.1875rem}.t-chevron_active{transform:rotate(90deg)}\n"] }]
|
|
160
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef, decorators: [{
|
|
161
|
+
type: Inject,
|
|
162
|
+
args: [ChangeDetectorRef]
|
|
163
|
+
}] }, { type: i9.Title, decorators: [{
|
|
164
|
+
type: Inject,
|
|
165
|
+
args: [Title]
|
|
166
|
+
}] }, { type: i10.Observable, decorators: [{
|
|
167
|
+
type: Inject,
|
|
168
|
+
args: [NAVIGATION_TITLE]
|
|
169
|
+
}] }, { type: i7.TuiModeDirective, decorators: [{
|
|
170
|
+
type: Inject,
|
|
171
|
+
args: [TuiModeDirective]
|
|
172
|
+
}] }, { type: undefined, decorators: [{
|
|
173
|
+
type: Optional
|
|
174
|
+
}, {
|
|
175
|
+
type: Inject,
|
|
176
|
+
args: [TuiSidebarDirective]
|
|
177
|
+
}] }, { type: undefined, decorators: [{
|
|
178
|
+
type: Inject,
|
|
179
|
+
args: [NAVIGATION_LABELS]
|
|
180
|
+
}] }, { type: undefined, decorators: [{
|
|
181
|
+
type: Inject,
|
|
182
|
+
args: [NAVIGATION_ITEMS]
|
|
183
|
+
}] }, { type: undefined, decorators: [{
|
|
184
|
+
type: Inject,
|
|
185
|
+
args: [TUI_DOC_SEARCH_TEXT]
|
|
186
|
+
}] }, { type: i3.Router, decorators: [{
|
|
187
|
+
type: Inject,
|
|
188
|
+
args: [Router]
|
|
189
|
+
}] }, { type: i3.ActivatedRoute, decorators: [{
|
|
190
|
+
type: Inject,
|
|
191
|
+
args: [ActivatedRoute]
|
|
192
|
+
}] }, { type: i10.Observable, decorators: [{
|
|
193
|
+
type: Self
|
|
194
|
+
}, {
|
|
195
|
+
type: Inject,
|
|
196
|
+
args: [TuiDestroyService]
|
|
197
|
+
}] }, { type: i10.Observable, decorators: [{
|
|
198
|
+
type: Inject,
|
|
199
|
+
args: [TUI_DOC_PAGE_LOADED]
|
|
200
|
+
}] }, { type: undefined, decorators: [{
|
|
201
|
+
type: Inject,
|
|
202
|
+
args: [TUI_DOC_ICONS]
|
|
203
|
+
}] }, { type: undefined, decorators: [{
|
|
204
|
+
type: Inject,
|
|
205
|
+
args: [TUI_COMMON_ICONS]
|
|
206
|
+
}] }, { type: Document, decorators: [{
|
|
207
|
+
type: Inject,
|
|
208
|
+
args: [DOCUMENT]
|
|
209
|
+
}] }]; }, propDecorators: { menuOpen: [{
|
|
210
|
+
type: HostBinding,
|
|
211
|
+
args: ['class._open']
|
|
212
|
+
}], filterItems: [], flattenSubPages: [] } });
|
|
213
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"navigation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/navigation/navigation.component.ts","../../../../../projects/addon-doc/components/navigation/navigation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Inject,\n    Optional,\n    Self,\n} from '@angular/core';\nimport {UntypedFormControl} from '@angular/forms';\nimport {Title} from '@angular/platform-browser';\nimport {ActivatedRoute, Router, Scroll} from '@angular/router';\nimport {TuiDocPage} from '@taiga-ui/addon-doc/interfaces';\nimport {\n    TUI_DOC_ICONS,\n    TUI_DOC_PAGE_LOADED,\n    TUI_DOC_SEARCH_TEXT,\n    TuiDocIcons,\n} from '@taiga-ui/addon-doc/tokens';\nimport {TuiDocPages} from '@taiga-ui/addon-doc/types';\nimport {tuiTransliterateKeyboardLayout} from '@taiga-ui/addon-doc/utils';\nimport {TuiSidebarDirective} from '@taiga-ui/addon-mobile';\nimport {tuiControlValue, TuiDestroyService, tuiPure, tuiUniqBy} from '@taiga-ui/cdk';\nimport {\n    TUI_COMMON_ICONS,\n    TuiBrightness,\n    TuiCommonIcons,\n    TuiModeDirective,\n} from '@taiga-ui/core';\nimport {TuiInputComponent} from '@taiga-ui/kit';\nimport {\n    combineLatest,\n    filter,\n    map,\n    Observable,\n    startWith,\n    switchMap,\n    take,\n    takeUntil,\n} from 'rxjs';\n\nimport {\n    NAVIGATION_ITEMS,\n    NAVIGATION_LABELS,\n    NAVIGATION_PROVIDERS,\n    NAVIGATION_TITLE,\n} from './navigation.providers';\n\n@Component({\n    selector: 'tui-doc-navigation',\n    templateUrl: './navigation.template.html',\n    styleUrls: ['./navigation.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: NAVIGATION_PROVIDERS,\n})\nexport class TuiDocNavigationComponent {\n    @HostBinding('class._open')\n    menuOpen = false;\n\n    openPagesArr: boolean[] = [];\n    openPagesGroupsArr: boolean[] = [];\n    active = '';\n\n    readonly search = new UntypedFormControl('');\n\n    readonly filtered$ = tuiControlValue<string>(this.search).pipe(\n        filter(search => search.trim().length > 2),\n        map(search => this.filterItems(this.flattenSubPages(this.items), search)),\n    );\n\n    readonly mode$: Observable<TuiBrightness> = this.mode.change$.pipe(\n        startWith(null),\n        map(() => this.mode.mode || 'onLight'),\n    );\n\n    constructor(\n        @Inject(ChangeDetectorRef) cdr: ChangeDetectorRef,\n        @Inject(Title) titleService: Title,\n        @Inject(NAVIGATION_TITLE) private readonly title$: Observable<string>,\n        @Inject(TuiModeDirective)\n        private readonly mode: TuiModeDirective,\n        @Optional()\n        @Inject(TuiSidebarDirective)\n        readonly sidebar: unknown,\n        @Inject(NAVIGATION_LABELS) readonly labels: string[],\n        @Inject(NAVIGATION_ITEMS)\n        readonly items: readonly TuiDocPages[],\n        @Inject(TUI_DOC_SEARCH_TEXT) readonly searchText: string,\n        @Inject(Router) private readonly router: Router,\n        @Inject(ActivatedRoute) readonly activatedRoute: ActivatedRoute,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: Observable<void>,\n        @Inject(TUI_DOC_PAGE_LOADED)\n        private readonly readyToScroll$: Observable<boolean>,\n        @Inject(TUI_DOC_ICONS) readonly docIcons: TuiDocIcons,\n        @Inject(TUI_COMMON_ICONS) readonly icons: TuiCommonIcons,\n        @Inject(DOCUMENT) private readonly doc: Document,\n    ) {\n        title$.subscribe(title => {\n            cdr.markForCheck();\n            titleService.setTitle(title);\n            this.openActivePageGroup();\n        });\n\n        combineLatest([\n            this.router.events.pipe(\n                filter((event): event is Scroll => event instanceof Scroll),\n            ),\n            this.title$.pipe(switchMap(() => this.readyToScroll$.pipe(filter(Boolean)))),\n        ])\n            .pipe(\n                take(1),\n                map(([event]) => event.anchor || ''),\n                filter<string>(Boolean),\n                takeUntil(this.destroy$),\n            )\n            .subscribe(anchor => this.navigateToAnchorLink(anchor));\n    }\n\n    get canOpen(): boolean {\n        return (this.search.value?.length ?? 0) > 2;\n    }\n\n    get itemsWithoutSections(): TuiDocPages {\n        return this.items[this.items.length - 1];\n    }\n\n    $pages(pages: any): readonly TuiDocPage[] {\n        return pages as TuiDocPage[];\n    }\n\n    isActive(route: string): boolean {\n        return route === this.active;\n    }\n\n    onGroupClick(index: number): void {\n        this.openPagesGroupsArr[index] = !this.openPagesGroupsArr[index];\n    }\n\n    closeMenu(): void {\n        this.menuOpen = false;\n    }\n\n    onClick(input: TuiInputComponent): void {\n        input.open = false;\n        this.menuOpen = false;\n        this.search.setValue('');\n        this.openActivePageGroup();\n    }\n\n    @tuiPure\n    private filterItems(\n        items: ReadonlyArray<readonly TuiDocPage[]>,\n        search: string,\n    ): ReadonlyArray<readonly TuiDocPage[]> {\n        return items.map(section =>\n            tuiUniqBy(\n                section.filter(({title, keywords = ''}) => {\n                    search = search.toLowerCase().trim();\n                    keywords = keywords.toLowerCase();\n                    title = title.toLowerCase();\n\n                    return (\n                        title.includes(search) ||\n                        keywords.includes(search) ||\n                        title.includes(tuiTransliterateKeyboardLayout(search)) ||\n                        keywords.includes(tuiTransliterateKeyboardLayout(search)) ||\n                        search.replace(/-/gi, '').includes(title) ||\n                        title.includes(search.replace(/\\s|tui/g, '')) ||\n                        keywords.includes(search.replace(/\\s|tui/g, '')) ||\n                        search.split(/\\s/).find(word => title.includes(word))\n                    );\n                }),\n                'title',\n            ),\n        );\n    }\n\n    @tuiPure\n    private flattenSubPages(\n        items: readonly TuiDocPages[],\n    ): ReadonlyArray<readonly TuiDocPage[]> {\n        return items.reduce<ReadonlyArray<readonly TuiDocPage[]>>(\n            (array, item) => [\n                ...array,\n                item.reduce<readonly TuiDocPage[]>(\n                    (pages, page) =>\n                        'subPages' in page\n                            ? [...pages, ...page.subPages]\n                            : [...pages, page],\n                    [],\n                ),\n            ],\n            [],\n        );\n    }\n\n    private isActiveRoute(route: string): boolean {\n        return this.router.isActive(route, {\n            paths: 'subset',\n            queryParams: 'subset',\n            fragment: 'ignored',\n            matrixParams: 'ignored',\n        });\n    }\n\n    private openActivePageGroup(): void {\n        this.items.forEach((pages, pagesIndex) => {\n            pages.forEach((page, pageIndex) => {\n                if ('route' in page && this.isActiveRoute(page.route)) {\n                    this.openPagesArr[pagesIndex] = true;\n                    this.active = page.route;\n                }\n\n                if ('subPages' in page) {\n                    page.subPages.forEach(subPage => {\n                        if (this.isActiveRoute(subPage.route)) {\n                            this.openPagesArr[pagesIndex] = true;\n                            this.openPagesGroupsArr[pagesIndex * 100 + pageIndex] = true;\n                            this.active = subPage.route;\n                        }\n                    });\n                }\n            });\n        });\n    }\n\n    private navigateToAnchorLink(fragment: string): void {\n        const nodes = fragment ? this.doc.querySelectorAll(`#${fragment}`) : [];\n        const element = nodes.length && nodes[nodes.length - 1];\n\n        if (!element) {\n            return;\n        }\n\n        // emulate :target event\n        const target = this.doc.createElement('a');\n\n        target.href = `${this.doc.location.pathname}#${fragment}`;\n        target.style.display = 'none';\n        target.style.position = 'absolute';\n        this.doc.body.appendChild(target);\n        target.click();\n        target.remove();\n    }\n}\n","<tui-input\n    #input\n    tuiTextfieldSize=\"m\"\n    class=\"t-input\"\n    [formControl]=\"search\"\n    [tuiAutoFocus]=\"!!sidebar\"\n    [tuiTextfieldCleaner]=\"true\"\n    [tuiTextfieldIconLeft]=\"docIcons.search\"\n    [tuiTextfieldLabelOutside]=\"true\"\n>\n    {{ searchText }}\n    <ng-container *ngIf=\"canOpen\">\n        <tui-data-list *tuiDataList>\n            <tui-opt-group\n                *ngFor=\"let group of filtered$ | async; let index = index\"\n                [label]=\"labels[index] || ''\"\n            >\n                <a\n                    *ngFor=\"let item of group\"\n                    tuiOption\n                    [fragment]=\"item.fragment\"\n                    [routerLink]=\"item.route\"\n                    (click)=\"onClick(input)\"\n                >\n                    {{ item.title }}\n                    <tui-svg\n                        *polymorpheusOutlet=\"item.icon as icon\"\n                        class=\"t-icon\"\n                        [src]=\"icon\"\n                    ></tui-svg>\n                </a>\n            </tui-opt-group>\n        </tui-data-list>\n    </ng-container>\n</tui-input>\n\n<nav class=\"t-navigation\">\n    <tui-scrollbar\n        class=\"t-scrollbar\"\n        [tuiMode]=\"mode$ | async\"\n    >\n        <tui-accordion\n            [closeOthers]=\"false\"\n            [rounded]=\"false\"\n        >\n            <tui-accordion-item\n                *ngFor=\"let label of labels; index as index\"\n                size=\"s\"\n                [borders]=\"null\"\n                [(open)]=\"!!openPagesArr[index]\"\n            >\n                <span class=\"t-label\">\n                    <strong>{{ label }}</strong>\n                </span>\n                <ng-template tuiAccordionItemContent>\n                    <div class=\"t-section\">\n                        <ng-container\n                            *ngFor=\"let item of items[index]; index as subIndex\"\n                            [ngTemplateOutlet]=\"pages\"\n                            [ngTemplateOutletContext]=\"{item: item, index: index * 100 + subIndex}\"\n                        ></ng-container>\n                    </div>\n                </ng-template>\n            </tui-accordion-item>\n        </tui-accordion>\n        <div class=\"t-items-container\">\n            <ng-container\n                *ngFor=\"let item of itemsWithoutSections; let index = index\"\n                [ngTemplateOutlet]=\"pages\"\n                [ngTemplateOutletContext]=\"{item: item, index: items.length - 1 + index}\"\n            ></ng-container>\n        </div>\n\n        <ng-template\n            #pages\n            let-index=\"index\"\n            let-item=\"item\"\n        >\n            <a\n                *ngIf=\"!item.subPages; else subPagesTemplate\"\n                routerLinkActive=\"t-sublink_active\"\n                tuiLink\n                class=\"t-sublink\"\n                [routerLink]=\"item.route\"\n                [tuiScrollIntoViewLink]=\"isActive(item.route)\"\n                (click)=\"closeMenu()\"\n            >\n                {{ item.title }}\n                <tui-svg\n                    *polymorpheusOutlet=\"item.icon as icon\"\n                    class=\"t-icon\"\n                    [src]=\"icon\"\n                ></tui-svg>\n            </a>\n\n            <ng-template #subPagesTemplate>\n                <div\n                    routerLinkActive\n                    class=\"t-subsection\"\n                    [routerLinkActiveOptions]=\"{exact: false}\"\n                >\n                    <button\n                        *ngIf=\"item.subPages\"\n                        tuiLink\n                        type=\"button\"\n                        class=\"t-sublink t-sublink_subsection\"\n                        (click)=\"onGroupClick(index)\"\n                    >\n                        <tui-svg\n                            class=\"t-chevron\"\n                            [class.t-chevron_active]=\"!!openPagesGroupsArr[index]\"\n                            [src]=\"icons.more\"\n                        ></tui-svg>\n                        {{ item.title }}\n                        <tui-svg\n                            *polymorpheusOutlet=\"item.icon as icon\"\n                            class=\"t-icon\"\n                            [src]=\"icon\"\n                        ></tui-svg>\n                    </button>\n                    <tui-expand\n                        class=\"t-expand\"\n                        [expanded]=\"!!openPagesGroupsArr[index]\"\n                    >\n                        <div class=\"t-section t-section_bordered\">\n                            <a\n                                *ngFor=\"let subPage of $pages(item.subPages)\"\n                                routerLinkActive=\"t-sublink_active\"\n                                tuiLink\n                                class=\"t-sublink t-sublink_small\"\n                                [fragment]=\"subPage.fragment\"\n                                [routerLink]=\"subPage.route\"\n                                [tuiScrollIntoViewLink]=\"isActive(subPage.route)\"\n                                (click)=\"closeMenu()\"\n                            >\n                                {{ subPage.title }}\n                                <tui-svg\n                                    *polymorpheusOutlet=\"subPage.icon as icon\"\n                                    class=\"t-icon\"\n                                    [src]=\"icon\"\n                                ></tui-svg>\n                            </a>\n                        </div>\n                    </tui-expand>\n                </div>\n            </ng-template>\n        </ng-template>\n    </tui-scrollbar>\n</nav>\n\n<ng-content></ng-content>\n"]}
|
|
@@ -11,8 +11,8 @@ import { TuiDocNavigationComponent } from './navigation.component';
|
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
export class TuiDocNavigationModule {
|
|
13
13
|
}
|
|
14
|
-
TuiDocNavigationModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
15
|
-
TuiDocNavigationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "
|
|
14
|
+
TuiDocNavigationModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
+
TuiDocNavigationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationModule, declarations: [TuiDocNavigationComponent], imports: [CommonModule,
|
|
16
16
|
ReactiveFormsModule,
|
|
17
17
|
RouterModule,
|
|
18
18
|
PolymorpheusModule,
|
|
@@ -32,29 +32,27 @@ TuiDocNavigationModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0",
|
|
|
32
32
|
TuiSvgModule,
|
|
33
33
|
TuiDataListModule,
|
|
34
34
|
TuiAutoFocusModule], exports: [TuiDocNavigationComponent] });
|
|
35
|
-
TuiDocNavigationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
]] });
|
|
57
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocNavigationModule, decorators: [{
|
|
35
|
+
TuiDocNavigationModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationModule, imports: [CommonModule,
|
|
36
|
+
ReactiveFormsModule,
|
|
37
|
+
RouterModule,
|
|
38
|
+
PolymorpheusModule,
|
|
39
|
+
TuiScrollIntoViewLinkModule,
|
|
40
|
+
TuiButtonModule,
|
|
41
|
+
TuiInputModule,
|
|
42
|
+
TuiTextfieldControllerModule,
|
|
43
|
+
TuiActiveZoneModule,
|
|
44
|
+
TuiLetModule,
|
|
45
|
+
TuiModeModule,
|
|
46
|
+
TuiLinkModule,
|
|
47
|
+
TuiExpandModule,
|
|
48
|
+
TuiHostedDropdownModule,
|
|
49
|
+
TuiDropdownModule,
|
|
50
|
+
TuiAccordionModule,
|
|
51
|
+
TuiScrollbarModule,
|
|
52
|
+
TuiSvgModule,
|
|
53
|
+
TuiDataListModule,
|
|
54
|
+
TuiAutoFocusModule] });
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocNavigationModule, decorators: [{
|
|
58
56
|
type: NgModule,
|
|
59
57
|
args: [{
|
|
60
58
|
imports: [
|
|
@@ -83,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
83
81
|
exports: [TuiDocNavigationComponent],
|
|
84
82
|
}]
|
|
85
83
|
}] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ25ELE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM3QyxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUMzRSxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsa0JBQWtCLEVBQUUsWUFBWSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFDSCxlQUFlLEVBQ2YsaUJBQWlCLEVBQ2pCLGlCQUFpQixFQUNqQixlQUFlLEVBQ2YsdUJBQXVCLEVBQ3ZCLGFBQWEsRUFDYixhQUFhLEVBQ2Isa0JBQWtCLEVBQ2xCLFlBQVksRUFDWiw0QkFBNEIsR0FDL0IsTUFBTSxnQkFBZ0IsQ0FBQztBQUN4QixPQUFPLEVBQUMsa0JBQWtCLEVBQUUsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDBCQUEwQixDQUFDO0FBRTVELE9BQU8sRUFBQyx5QkFBeUIsRUFBQyxNQUFNLHdCQUF3QixDQUFDOztBQTRCakUsTUFBTSxPQUFPLHNCQUFzQjs7b0hBQXRCLHNCQUFzQjtxSEFBdEIsc0JBQXNCLGlCQUhoQix5QkFBeUIsYUFyQnBDLFlBQVk7UUFDWixtQkFBbUI7UUFDbkIsWUFBWTtRQUNaLGtCQUFrQjtRQUNsQiwyQkFBMkI7UUFDM0IsZUFBZTtRQUNmLGNBQWM7UUFDZCw0QkFBNEI7UUFDNUIsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWixhQUFhO1FBQ2IsYUFBYTtRQUNiLGVBQWU7UUFDZix1QkFBdUI7UUFDdkIsaUJBQWlCO1FBQ2pCLGtCQUFrQjtRQUNsQixrQkFBa0I7UUFDbEIsWUFBWTtRQUNaLGlCQUFpQjtRQUNqQixrQkFBa0IsYUFHWix5QkFBeUI7cUhBRTFCLHNCQUFzQixZQXhCM0IsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixZQUFZO1FBQ1osa0JBQWtCO1FBQ2xCLDJCQUEyQjtRQUMzQixlQUFlO1FBQ2YsY0FBYztRQUNkLDRCQUE0QjtRQUM1QixtQkFBbUI7UUFDbkIsWUFBWTtRQUNaLGFBQWE7UUFDYixhQUFhO1FBQ2IsZUFBZTtRQUNmLHVCQUF1QjtRQUN2QixpQkFBaUI7UUFDakIsa0JBQWtCO1FBQ2xCLGtCQUFrQjtRQUNsQixZQUFZO1FBQ1osaUJBQWlCO1FBQ2pCLGtCQUFrQjs0RkFLYixzQkFBc0I7a0JBMUJsQyxRQUFRO21CQUFDO29CQUNOLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLG1CQUFtQjt3QkFDbkIsWUFBWTt3QkFDWixrQkFBa0I7d0JBQ2xCLDJCQUEyQjt3QkFDM0IsZUFBZTt3QkFDZixjQUFjO3dCQUNkLDRCQUE0Qjt3QkFDNUIsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixlQUFlO3dCQUNmLHVCQUF1Qjt3QkFDdkIsaUJBQWlCO3dCQUNqQixrQkFBa0I7d0JBQ2xCLGtCQUFrQjt3QkFDbEIsWUFBWTt3QkFDWixpQkFBaUI7d0JBQ2pCLGtCQUFrQjtxQkFDckI7b0JBQ0QsWUFBWSxFQUFFLENBQUMseUJBQXlCLENBQUM7b0JBQ3pDLE9BQU8sRUFBRSxDQUFDLHlCQUF5QixDQUFDO2lCQUN2QyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7Um91dGVyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtUdWlTY3JvbGxJbnRvVmlld0xpbmtNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvZGlyZWN0aXZlcyc7XG5pbXBvcnQge1R1aUFjdGl2ZVpvbmVNb2R1bGUsIFR1aUF1dG9Gb2N1c01vZHVsZSwgVHVpTGV0TW9kdWxlfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7XG4gICAgVHVpQnV0dG9uTW9kdWxlLFxuICAgIFR1aURhdGFMaXN0TW9kdWxlLFxuICAgIFR1aURyb3Bkb3duTW9kdWxlLFxuICAgIFR1aUV4cGFuZE1vZHVsZSxcbiAgICBUdWlIb3N0ZWREcm9wZG93bk1vZHVsZSxcbiAgICBUdWlMaW5rTW9kdWxlLFxuICAgIFR1aU1vZGVNb2R1bGUsXG4gICAgVHVpU2Nyb2xsYmFyTW9kdWxlLFxuICAgIFR1aVN2Z01vZHVsZSxcbiAgICBUdWlUZXh0ZmllbGRDb250cm9sbGVyTW9kdWxlLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQge1R1aUFjY29yZGlvbk1vZHVsZSwgVHVpSW5wdXRNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9raXQnO1xuaW1wb3J0IHtQb2x5bW9ycGhldXNNb2R1bGV9IGZyb20gJ0B0aW5rb2ZmL25nLXBvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpRG9jTmF2aWdhdGlvbkNvbXBvbmVudH0gZnJvbSAnLi9uYXZpZ2F0aW9uLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgICAgIFJvdXRlck1vZHVsZSxcbiAgICAgICAgUG9seW1vcnBoZXVzTW9kdWxlLFxuICAgICAgICBUdWlTY3JvbGxJbnRvVmlld0xpbmtNb2R1bGUsXG4gICAgICAgIFR1aUJ1dHRvbk1vZHVsZSxcbiAgICAgICAgVHVpSW5wdXRNb2R1bGUsXG4gICAgICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG4gICAgICAgIFR1aUFjdGl2ZVpvbmVNb2R1bGUsXG4gICAgICAgIFR1aUxldE1vZHVsZSxcbiAgICAgICAgVHVpTW9kZU1vZHVsZSxcbiAgICAgICAgVHVpTGlua01vZHVsZSxcbiAgICAgICAgVHVpRXhwYW5kTW9kdWxlLFxuICAgICAgICBUdWlIb3N0ZWREcm9wZG93bk1vZHVsZSxcbiAgICAgICAgVHVpRHJvcGRvd25Nb2R1bGUsXG4gICAgICAgIFR1aUFjY29yZGlvbk1vZHVsZSxcbiAgICAgICAgVHVpU2Nyb2xsYmFyTW9kdWxlLFxuICAgICAgICBUdWlTdmdNb2R1bGUsXG4gICAgICAgIFR1aURhdGFMaXN0TW9kdWxlLFxuICAgICAgICBUdWlBdXRvRm9jdXNNb2R1bGUsXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUdWlEb2NOYXZpZ2F0aW9uQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbVHVpRG9jTmF2aWdhdGlvbkNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY05hdmlnYXRpb25Nb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
|
|
3
|
+
import { TUI_DOC_PAGES, TUI_DOC_TITLE } from '@taiga-ui/addon-doc/tokens';
|
|
4
|
+
import { TuiDestroyService, tuiIsPresent } from '@taiga-ui/cdk';
|
|
5
|
+
import { filter, map, mergeMap, takeUntil } from 'rxjs';
|
|
6
|
+
function labelsProviderFactory(pages) {
|
|
7
|
+
return pages
|
|
8
|
+
.map(({ section }) => section)
|
|
9
|
+
.filter(tuiIsPresent)
|
|
10
|
+
.filter((item, index, array) => array.indexOf(item) === index);
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Page title
|
|
14
|
+
*/
|
|
15
|
+
export const NAVIGATION_TITLE = new InjectionToken(`[NAVIGATION_TITLE]`);
|
|
16
|
+
/**
|
|
17
|
+
* Navigation sections labels for search
|
|
18
|
+
*/
|
|
19
|
+
export const NAVIGATION_LABELS = new InjectionToken(`[NAVIGATION_LABELS]`);
|
|
20
|
+
/**
|
|
21
|
+
* Navigation pages
|
|
22
|
+
*/
|
|
23
|
+
export const NAVIGATION_ITEMS = new InjectionToken(`[NAVIGATION_ITEMS]`);
|
|
24
|
+
export const NAVIGATION_PROVIDERS = [
|
|
25
|
+
TuiDestroyService,
|
|
26
|
+
{
|
|
27
|
+
provide: NAVIGATION_TITLE,
|
|
28
|
+
deps: [Router, ActivatedRoute, TUI_DOC_TITLE, TuiDestroyService],
|
|
29
|
+
useFactory: (router, activatedRoute, titlePrefix, destroy$) => router.events.pipe(filter(event => event instanceof NavigationEnd), map(() => activatedRoute.firstChild), filter(tuiIsPresent), mergeMap(({ data }) => data), map(({ title }) => `${titlePrefix}${title}`), takeUntil(destroy$)),
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
provide: NAVIGATION_LABELS,
|
|
33
|
+
deps: [TUI_DOC_PAGES],
|
|
34
|
+
useFactory: labelsProviderFactory,
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
provide: NAVIGATION_ITEMS,
|
|
38
|
+
deps: [TUI_DOC_PAGES],
|
|
39
|
+
useFactory: (pages) => {
|
|
40
|
+
const labels = labelsProviderFactory(pages);
|
|
41
|
+
return [
|
|
42
|
+
...labels.map(label => pages.filter(({ section }) => section === label)),
|
|
43
|
+
pages.filter(page => !page.section),
|
|
44
|
+
];
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi5wcm92aWRlcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24ucHJvdmlkZXJzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQVcsTUFBTSxlQUFlLENBQUM7QUFDdkQsT0FBTyxFQUFDLGNBQWMsRUFBRSxhQUFhLEVBQUUsTUFBTSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDdEUsT0FBTyxFQUFDLGFBQWEsRUFBRSxhQUFhLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUV4RSxPQUFPLEVBQUMsaUJBQWlCLEVBQUUsWUFBWSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBQyxNQUFNLEVBQUUsR0FBRyxFQUFFLFFBQVEsRUFBYyxTQUFTLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFFbEUsU0FBUyxxQkFBcUIsQ0FBQyxLQUFrQjtJQUM3QyxPQUFPLEtBQUs7U0FDUCxHQUFHLENBQUMsQ0FBQyxFQUFDLE9BQU8sRUFBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUM7U0FDM0IsTUFBTSxDQUFDLFlBQVksQ0FBQztTQUNwQixNQUFNLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQztBQUN2RSxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLGNBQWMsQ0FDOUMsb0JBQW9CLENBQ3ZCLENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLElBQUksY0FBYyxDQUMvQyxxQkFBcUIsQ0FDeEIsQ0FBQztBQUVGOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQ3pCLElBQUksY0FBYyxDQUF5QixvQkFBb0IsQ0FBQyxDQUFDO0FBRXJFLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFlO0lBQzVDLGlCQUFpQjtJQUNqQjtRQUNJLE9BQU8sRUFBRSxnQkFBZ0I7UUFDekIsSUFBSSxFQUFFLENBQUMsTUFBTSxFQUFFLGNBQWMsRUFBRSxhQUFhLEVBQUUsaUJBQWlCLENBQUM7UUFDaEUsVUFBVSxFQUFFLENBQ1IsTUFBYyxFQUNkLGNBQThCLEVBQzlCLFdBQW1CLEVBQ25CLFFBQTBCLEVBQ1IsRUFBRSxDQUNwQixNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FDZCxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxLQUFLLFlBQVksYUFBYSxDQUFDLEVBQy9DLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLEVBQ3BDLE1BQU0sQ0FBQyxZQUFZLENBQUMsRUFDcEIsUUFBUSxDQUFDLENBQUMsRUFBQyxJQUFJLEVBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLEVBQzFCLEdBQUcsQ0FBQyxDQUFDLEVBQUMsS0FBSyxFQUFDLEVBQUUsRUFBRSxDQUFDLEdBQUcsV0FBVyxHQUFHLEtBQUssRUFBRSxDQUFDLEVBQzFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FDdEI7S0FDUjtJQUNEO1FBQ0ksT0FBTyxFQUFFLGlCQUFpQjtRQUMxQixJQUFJLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDckIsVUFBVSxFQUFFLHFCQUFxQjtLQUNwQztJQUNEO1FBQ0ksT0FBTyxFQUFFLGdCQUFnQjtRQUN6QixJQUFJLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDckIsVUFBVSxFQUFFLENBQUMsS0FBa0IsRUFBMEIsRUFBRTtZQUN2RCxNQUFNLE1BQU0sR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUU1QyxPQUFPO2dCQUNILEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFDLE9BQU8sRUFBQyxFQUFFLEVBQUUsQ0FBQyxPQUFPLEtBQUssS0FBSyxDQUFDLENBQUM7Z0JBQ3RFLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7YUFDdEMsQ0FBQztRQUNOLENBQUM7S0FDSjtDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VuLCBQcm92aWRlcn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0FjdGl2YXRlZFJvdXRlLCBOYXZpZ2F0aW9uRW5kLCBSb3V0ZXJ9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQge1RVSV9ET0NfUEFHRVMsIFRVSV9ET0NfVElUTEV9IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvdG9rZW5zJztcbmltcG9ydCB7VHVpRG9jUGFnZXN9IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvdHlwZXMnO1xuaW1wb3J0IHtUdWlEZXN0cm95U2VydmljZSwgdHVpSXNQcmVzZW50fSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7ZmlsdGVyLCBtYXAsIG1lcmdlTWFwLCBPYnNlcnZhYmxlLCB0YWtlVW50aWx9IGZyb20gJ3J4anMnO1xuXG5mdW5jdGlvbiBsYWJlbHNQcm92aWRlckZhY3RvcnkocGFnZXM6IFR1aURvY1BhZ2VzKTogcmVhZG9ubHkgc3RyaW5nW10ge1xuICAgIHJldHVybiBwYWdlc1xuICAgICAgICAubWFwKCh7c2VjdGlvbn0pID0+IHNlY3Rpb24pXG4gICAgICAgIC5maWx0ZXIodHVpSXNQcmVzZW50KVxuICAgICAgICAuZmlsdGVyKChpdGVtLCBpbmRleCwgYXJyYXkpID0+IGFycmF5LmluZGV4T2YoaXRlbSkgPT09IGluZGV4KTtcbn1cblxuLyoqXG4gKiBQYWdlIHRpdGxlXG4gKi9cbmV4cG9ydCBjb25zdCBOQVZJR0FUSU9OX1RJVExFID0gbmV3IEluamVjdGlvblRva2VuPE9ic2VydmFibGU8c3RyaW5nPj4oXG4gICAgYFtOQVZJR0FUSU9OX1RJVExFXWAsXG4pO1xuXG4vKipcbiAqIE5hdmlnYXRpb24gc2VjdGlvbnMgbGFiZWxzIGZvciBzZWFyY2hcbiAqL1xuZXhwb3J0IGNvbnN0IE5BVklHQVRJT05fTEFCRUxTID0gbmV3IEluamVjdGlvblRva2VuPHJlYWRvbmx5IHN0cmluZ1tdPihcbiAgICBgW05BVklHQVRJT05fTEFCRUxTXWAsXG4pO1xuXG4vKipcbiAqIE5hdmlnYXRpb24gcGFnZXNcbiAqL1xuZXhwb3J0IGNvbnN0IE5BVklHQVRJT05fSVRFTVM6IEluamVjdGlvblRva2VuPHJlYWRvbmx5IFR1aURvY1BhZ2VzW10+ID1cbiAgICBuZXcgSW5qZWN0aW9uVG9rZW48cmVhZG9ubHkgVHVpRG9jUGFnZXNbXT4oYFtOQVZJR0FUSU9OX0lURU1TXWApO1xuXG5leHBvcnQgY29uc3QgTkFWSUdBVElPTl9QUk9WSURFUlM6IFByb3ZpZGVyW10gPSBbXG4gICAgVHVpRGVzdHJveVNlcnZpY2UsXG4gICAge1xuICAgICAgICBwcm92aWRlOiBOQVZJR0FUSU9OX1RJVExFLFxuICAgICAgICBkZXBzOiBbUm91dGVyLCBBY3RpdmF0ZWRSb3V0ZSwgVFVJX0RPQ19USVRMRSwgVHVpRGVzdHJveVNlcnZpY2VdLFxuICAgICAgICB1c2VGYWN0b3J5OiAoXG4gICAgICAgICAgICByb3V0ZXI6IFJvdXRlcixcbiAgICAgICAgICAgIGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSxcbiAgICAgICAgICAgIHRpdGxlUHJlZml4OiBzdHJpbmcsXG4gICAgICAgICAgICBkZXN0cm95JDogT2JzZXJ2YWJsZTx2b2lkPixcbiAgICAgICAgKTogT2JzZXJ2YWJsZTxzdHJpbmc+ID0+XG4gICAgICAgICAgICByb3V0ZXIuZXZlbnRzLnBpcGUoXG4gICAgICAgICAgICAgICAgZmlsdGVyKGV2ZW50ID0+IGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvbkVuZCksXG4gICAgICAgICAgICAgICAgbWFwKCgpID0+IGFjdGl2YXRlZFJvdXRlLmZpcnN0Q2hpbGQpLFxuICAgICAgICAgICAgICAgIGZpbHRlcih0dWlJc1ByZXNlbnQpLFxuICAgICAgICAgICAgICAgIG1lcmdlTWFwKCh7ZGF0YX0pID0+IGRhdGEpLFxuICAgICAgICAgICAgICAgIG1hcCgoe3RpdGxlfSkgPT4gYCR7dGl0bGVQcmVmaXh9JHt0aXRsZX1gKSxcbiAgICAgICAgICAgICAgICB0YWtlVW50aWwoZGVzdHJveSQpLFxuICAgICAgICAgICAgKSxcbiAgICB9LFxuICAgIHtcbiAgICAgICAgcHJvdmlkZTogTkFWSUdBVElPTl9MQUJFTFMsXG4gICAgICAgIGRlcHM6IFtUVUlfRE9DX1BBR0VTXSxcbiAgICAgICAgdXNlRmFjdG9yeTogbGFiZWxzUHJvdmlkZXJGYWN0b3J5LFxuICAgIH0sXG4gICAge1xuICAgICAgICBwcm92aWRlOiBOQVZJR0FUSU9OX0lURU1TLFxuICAgICAgICBkZXBzOiBbVFVJX0RPQ19QQUdFU10sXG4gICAgICAgIHVzZUZhY3Rvcnk6IChwYWdlczogVHVpRG9jUGFnZXMpOiByZWFkb25seSBUdWlEb2NQYWdlc1tdID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGxhYmVscyA9IGxhYmVsc1Byb3ZpZGVyRmFjdG9yeShwYWdlcyk7XG5cbiAgICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICAgICAgLi4ubGFiZWxzLm1hcChsYWJlbCA9PiBwYWdlcy5maWx0ZXIoKHtzZWN0aW9ufSkgPT4gc2VjdGlvbiA9PT0gbGFiZWwpKSxcbiAgICAgICAgICAgICAgICBwYWdlcy5maWx0ZXIocGFnZSA9PiAhcGFnZS5zZWN0aW9uKSxcbiAgICAgICAgICAgIF07XG4gICAgICAgIH0sXG4gICAgfSxcbl07XG4iXX0=
|
|
@@ -5,9 +5,9 @@ export class TuiDocPageTabConnectorDirective {
|
|
|
5
5
|
this.template = template;
|
|
6
6
|
}
|
|
7
7
|
}
|
|
8
|
-
TuiDocPageTabConnectorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
9
|
-
TuiDocPageTabConnectorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
8
|
+
TuiDocPageTabConnectorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocPageTabConnectorDirective, deps: [{ token: TemplateRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
9
|
+
TuiDocPageTabConnectorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.10", type: TuiDocPageTabConnectorDirective, selector: "[pageTab]", inputs: { pageTab: "pageTab" }, ngImport: i0 });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocPageTabConnectorDirective, decorators: [{
|
|
11
11
|
type: Directive,
|
|
12
12
|
args: [{
|
|
13
13
|
selector: '[pageTab]',
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, Inject, Input, } from '@angular/core';
|
|
2
|
+
import { TUI_DOC_DEFAULT_TABS } from '@taiga-ui/addon-doc/tokens';
|
|
3
|
+
import { EMPTY_QUERY } from '@taiga-ui/cdk';
|
|
4
|
+
import { PAGE_PROVIDERS, PAGE_SEE_ALSO } from './page.providers';
|
|
5
|
+
import { TuiDocPageTabConnectorDirective } from './page-tab.directive';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/common";
|
|
8
|
+
import * as i2 from "@angular/router";
|
|
9
|
+
import * as i3 from "../internal/see-also/see-also.component";
|
|
10
|
+
import * as i4 from "@taiga-ui/kit";
|
|
11
|
+
import * as i5 from "@taiga-ui/cdk";
|
|
12
|
+
import * as i6 from "../internal/source-code/source-code.component";
|
|
13
|
+
export class TuiDocPageComponent {
|
|
14
|
+
constructor(defaultTabs, seeAlso) {
|
|
15
|
+
this.defaultTabs = defaultTabs;
|
|
16
|
+
this.seeAlso = seeAlso;
|
|
17
|
+
this.header = '';
|
|
18
|
+
this.package = '';
|
|
19
|
+
this.type = '';
|
|
20
|
+
this.path = '';
|
|
21
|
+
this.deprecated = false;
|
|
22
|
+
this.tabConnectors = EMPTY_QUERY;
|
|
23
|
+
this.activeItemIndex = 0;
|
|
24
|
+
this.from = / /g;
|
|
25
|
+
this.to = '_';
|
|
26
|
+
}
|
|
27
|
+
get showSeeAlso() {
|
|
28
|
+
return !!this.seeAlso.length && this.activeItemIndex === 0;
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
TuiDocPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocPageComponent, deps: [{ token: TUI_DOC_DEFAULT_TABS }, { token: PAGE_SEE_ALSO }], target: i0.ɵɵFactoryTarget.Component });
|
|
32
|
+
TuiDocPageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: TuiDocPageComponent, selector: "tui-doc-page", inputs: { header: "header", package: "package", type: "type", path: "path", deprecated: "deprecated" }, providers: PAGE_PROVIDERS, queries: [{ propertyName: "tabConnectors", predicate: TuiDocPageTabConnectorDirective }], ngImport: i0, template: "<header class=\"t-header\">\n <h1 class=\"t-title\">\n {{ header }}\n <tui-tag\n *ngIf=\"!!deprecated || deprecated === ''\"\n status=\"custom\"\n value=\"deprecated\"\n class=\"t-tag t-tag_deprecated\"\n ></tui-tag>\n <tui-tag\n *ngIf=\"package\"\n status=\"custom\"\n class=\"t-tag t-tag_package\"\n [autoColor]=\"true\"\n [value]=\"package\"\n ></tui-tag>\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 </tui-tabs-with-more>\n <tui-doc-source-code\n class=\"t-source-code\"\n [header]=\"header\"\n [package]=\"package\"\n [path]=\"path\"\n [type]=\"type\"\n ></tui-doc-source-code>\n</header>\n<div class=\"t-content\">\n <ng-content></ng-content>\n <tui-doc-see-also\n *ngIf=\"showSeeAlso\"\n class=\"t-see-also\"\n [seeAlso]=\"seeAlso\"\n ></tui-doc-see-also>\n <ng-container *ngFor=\"let tab of tabConnectors; index as index\">\n <ng-container\n *ngIf=\"index === activeItemIndex\"\n [ngTemplateOutlet]=\"tab.template\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:flex;flex-direction:column;min-height:0;flex-basis:0;flex-grow:1}.t-header{display:flex;font:var(--tui-font-heading-3);flex-wrap:wrap;min-height:7.25rem;color:var(--tui-text-01);box-shadow:inset 0 -1px 0 0 var(--tui-base-03);padding:3.75rem 0 0;box-sizing:border-box;flex-shrink:0;margin:0 min(10vw,8.75rem)}:host-context(tui-root._mobile) .t-header{font:var(--tui-font-heading-4);min-height:4.5rem;padding:1.25rem 1.25rem 0;margin:0}.t-title{min-width:100%;font-size:inherit;margin:0}.t-tag{vertical-align:middle;text-transform:uppercase;margin-right:.5rem}.t-tag_deprecated{background-color:var(--tui-error-fill);color:#fff}.t-tag.t-tag_package{color:#000}.t-tabs{flex:1;margin:1.125rem .3125rem 0 0}:host-context(tui-root._mobile) .t-tabs{margin-top:.25rem}.t-content{padding:2rem 0;margin:0 min(10vw,8.75rem)}:host-context(tui-root._mobile) .t-content{padding:2rem 1.25rem;margin:0}.t-see-also{min-width:18.75rem;width:30%;float:right;margin-left:1.5rem}:host-context(tui-root._mobile) .t-see-also{float:none;width:100%;margin:0 0 1.5rem}.t-source-code{align-self:flex-end;line-height:2.75rem;margin-left:auto}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i2.RouterLinkActive, selector: "[routerLinkActive]", inputs: ["routerLinkActiveOptions", "ariaCurrentWhenActive", "routerLinkActive"], outputs: ["isActiveChange"], exportAs: ["routerLinkActive"] }, { kind: "component", type: i3.TuiDocSeeAlsoComponent, selector: "tui-doc-see-also", inputs: ["seeAlso"] }, { kind: "component", type: i4.TuiTabsWithMoreComponent, selector: "tui-tabs-with-more, nav[tuiTabsWithMore]", inputs: ["moreContent", "dropdownContent", "underline", "activeItemIndex", "itemsLimit"], outputs: ["activeItemIndexChange"] }, { kind: "component", type: i4.TuiTabComponent, selector: "a[tuiTab]:not([routerLink]), a[tuiTab][routerLink][routerLinkActive], button[tuiTab]" }, { kind: "directive", type: i5.TuiItemDirective, selector: "[tuiItem]" }, { kind: "component", type: i4.TuiTagComponent, selector: "tui-tag, a[tuiTag], button[tuiTag]", inputs: ["value", "editable", "separator", "maxLength", "size", "showLoader", "status", "hoverable", "removable", "disabled", "autoColor", "leftContent"], outputs: ["edited"] }, { kind: "component", type: i6.TuiDocSourceCodeComponent, selector: "tui-doc-source-code", inputs: ["header", "package", "type", "path"] }, { kind: "pipe", type: i5.TuiReplacePipe, name: "tuiReplace" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
33
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: TuiDocPageComponent, decorators: [{
|
|
34
|
+
type: Component,
|
|
35
|
+
args: [{ selector: 'tui-doc-page', changeDetection: ChangeDetectionStrategy.OnPush, providers: PAGE_PROVIDERS, template: "<header class=\"t-header\">\n <h1 class=\"t-title\">\n {{ header }}\n <tui-tag\n *ngIf=\"!!deprecated || deprecated === ''\"\n status=\"custom\"\n value=\"deprecated\"\n class=\"t-tag t-tag_deprecated\"\n ></tui-tag>\n <tui-tag\n *ngIf=\"package\"\n status=\"custom\"\n class=\"t-tag t-tag_package\"\n [autoColor]=\"true\"\n [value]=\"package\"\n ></tui-tag>\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 </tui-tabs-with-more>\n <tui-doc-source-code\n class=\"t-source-code\"\n [header]=\"header\"\n [package]=\"package\"\n [path]=\"path\"\n [type]=\"type\"\n ></tui-doc-source-code>\n</header>\n<div class=\"t-content\">\n <ng-content></ng-content>\n <tui-doc-see-also\n *ngIf=\"showSeeAlso\"\n class=\"t-see-also\"\n [seeAlso]=\"seeAlso\"\n ></tui-doc-see-also>\n <ng-container *ngFor=\"let tab of tabConnectors; index as index\">\n <ng-container\n *ngIf=\"index === activeItemIndex\"\n [ngTemplateOutlet]=\"tab.template\"\n ></ng-container>\n </ng-container>\n</div>\n", styles: [":host{display:flex;flex-direction:column;min-height:0;flex-basis:0;flex-grow:1}.t-header{display:flex;font:var(--tui-font-heading-3);flex-wrap:wrap;min-height:7.25rem;color:var(--tui-text-01);box-shadow:inset 0 -1px 0 0 var(--tui-base-03);padding:3.75rem 0 0;box-sizing:border-box;flex-shrink:0;margin:0 min(10vw,8.75rem)}:host-context(tui-root._mobile) .t-header{font:var(--tui-font-heading-4);min-height:4.5rem;padding:1.25rem 1.25rem 0;margin:0}.t-title{min-width:100%;font-size:inherit;margin:0}.t-tag{vertical-align:middle;text-transform:uppercase;margin-right:.5rem}.t-tag_deprecated{background-color:var(--tui-error-fill);color:#fff}.t-tag.t-tag_package{color:#000}.t-tabs{flex:1;margin:1.125rem .3125rem 0 0}:host-context(tui-root._mobile) .t-tabs{margin-top:.25rem}.t-content{padding:2rem 0;margin:0 min(10vw,8.75rem)}:host-context(tui-root._mobile) .t-content{padding:2rem 1.25rem;margin:0}.t-see-also{min-width:18.75rem;width:30%;float:right;margin-left:1.5rem}:host-context(tui-root._mobile) .t-see-also{float:none;width:100%;margin:0 0 1.5rem}.t-source-code{align-self:flex-end;line-height:2.75rem;margin-left:auto}\n"] }]
|
|
36
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
37
|
+
type: Inject,
|
|
38
|
+
args: [TUI_DOC_DEFAULT_TABS]
|
|
39
|
+
}] }, { type: undefined, decorators: [{
|
|
40
|
+
type: Inject,
|
|
41
|
+
args: [PAGE_SEE_ALSO]
|
|
42
|
+
}] }]; }, propDecorators: { header: [{
|
|
43
|
+
type: Input
|
|
44
|
+
}], package: [{
|
|
45
|
+
type: Input
|
|
46
|
+
}], type: [{
|
|
47
|
+
type: Input
|
|
48
|
+
}], path: [{
|
|
49
|
+
type: Input
|
|
50
|
+
}], deprecated: [{
|
|
51
|
+
type: Input
|
|
52
|
+
}], tabConnectors: [{
|
|
53
|
+
type: ContentChildren,
|
|
54
|
+
args: [TuiDocPageTabConnectorDirective]
|
|
55
|
+
}] } });
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9wYWdlL3BhZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL2NvbXBvbmVudHMvcGFnZS9wYWdlLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsZUFBZSxFQUNmLE1BQU0sRUFDTixLQUFLLEdBRVIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDaEUsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUxQyxPQUFPLEVBQUMsY0FBYyxFQUFFLGFBQWEsRUFBQyxNQUFNLGtCQUFrQixDQUFDO0FBQy9ELE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHNCQUFzQixDQUFDOzs7Ozs7OztBQVNyRSxNQUFNLE9BQU8sbUJBQW1CO0lBd0I1QixZQUMyQyxXQUE4QixFQUNyQyxPQUEwQjtRQURuQixnQkFBVyxHQUFYLFdBQVcsQ0FBbUI7UUFDckMsWUFBTyxHQUFQLE9BQU8sQ0FBbUI7UUF4QjlELFdBQU0sR0FBRyxFQUFFLENBQUM7UUFHWixZQUFPLEdBQUcsRUFBRSxDQUFDO1FBR2IsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUdWLFNBQUksR0FBRyxFQUFFLENBQUM7UUFHVixlQUFVLEdBQWlCLEtBQUssQ0FBQztRQUd4QixrQkFBYSxHQUErQyxXQUFXLENBQUM7UUFFakYsb0JBQWUsR0FBRyxDQUFDLENBQUM7UUFFWCxTQUFJLEdBQUcsSUFBSSxDQUFDO1FBQ1osT0FBRSxHQUFHLEdBQUcsQ0FBQztJQUtmLENBQUM7SUFFSixJQUFJLFdBQVc7UUFDWCxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsZUFBZSxLQUFLLENBQUMsQ0FBQztJQUMvRCxDQUFDOztpSEEvQlEsbUJBQW1CLGtCQXlCaEIsb0JBQW9CLGFBQ3BCLGFBQWE7cUdBMUJoQixtQkFBbUIsK0lBRmpCLGNBQWMsd0RBa0JSLCtCQUErQiw2QkNyQ3BELDAzREEwREE7NEZEckNhLG1CQUFtQjtrQkFQL0IsU0FBUzsrQkFDSSxjQUFjLG1CQUdQLHVCQUF1QixDQUFDLE1BQU0sYUFDcEMsY0FBYzs7MEJBMkJwQixNQUFNOzJCQUFDLG9CQUFvQjs7MEJBQzNCLE1BQU07MkJBQUMsYUFBYTs0Q0F4QnpCLE1BQU07c0JBREwsS0FBSztnQkFJTixPQUFPO3NCQUROLEtBQUs7Z0JBSU4sSUFBSTtzQkFESCxLQUFLO2dCQUlOLElBQUk7c0JBREgsS0FBSztnQkFJTixVQUFVO3NCQURULEtBQUs7Z0JBSUcsYUFBYTtzQkFEckIsZUFBZTt1QkFBQywrQkFBK0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBDb250ZW50Q2hpbGRyZW4sXG4gICAgSW5qZWN0LFxuICAgIElucHV0LFxuICAgIFF1ZXJ5TGlzdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1RVSV9ET0NfREVGQVVMVF9UQUJTfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tZG9jL3Rva2Vucyc7XG5pbXBvcnQge0VNUFRZX1FVRVJZfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcblxuaW1wb3J0IHtQQUdFX1BST1ZJREVSUywgUEFHRV9TRUVfQUxTT30gZnJvbSAnLi9wYWdlLnByb3ZpZGVycyc7XG5pbXBvcnQge1R1aURvY1BhZ2VUYWJDb25uZWN0b3JEaXJlY3RpdmV9IGZyb20gJy4vcGFnZS10YWIuZGlyZWN0aXZlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0dWktZG9jLXBhZ2UnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9wYWdlLnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3BhZ2Uuc3R5bGUubGVzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIHByb3ZpZGVyczogUEFHRV9QUk9WSURFUlMsXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY1BhZ2VDb21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgaGVhZGVyID0gJyc7XG5cbiAgICBASW5wdXQoKVxuICAgIHBhY2thZ2UgPSAnJztcblxuICAgIEBJbnB1dCgpXG4gICAgdHlwZSA9ICcnO1xuXG4gICAgQElucHV0KClcbiAgICBwYXRoID0gJyc7XG5cbiAgICBASW5wdXQoKVxuICAgIGRlcHJlY2F0ZWQ6IGJvb2xlYW4gfCAnJyA9IGZhbHNlO1xuXG4gICAgQENvbnRlbnRDaGlsZHJlbihUdWlEb2NQYWdlVGFiQ29ubmVjdG9yRGlyZWN0aXZlKVxuICAgIHJlYWRvbmx5IHRhYkNvbm5lY3RvcnM6IFF1ZXJ5TGlzdDxUdWlEb2NQYWdlVGFiQ29ubmVjdG9yRGlyZWN0aXZlPiA9IEVNUFRZX1FVRVJZO1xuXG4gICAgYWN0aXZlSXRlbUluZGV4ID0gMDtcblxuICAgIHJlYWRvbmx5IGZyb20gPSAvIC9nO1xuICAgIHJlYWRvbmx5IHRvID0gJ18nO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoVFVJX0RPQ19ERUZBVUxUX1RBQlMpIHJlYWRvbmx5IGRlZmF1bHRUYWJzOiByZWFkb25seSBzdHJpbmdbXSxcbiAgICAgICAgQEluamVjdChQQUdFX1NFRV9BTFNPKSByZWFkb25seSBzZWVBbHNvOiByZWFkb25seSBzdHJpbmdbXSxcbiAgICApIHt9XG5cbiAgICBnZXQgc2hvd1NlZUFsc28oKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuc2VlQWxzby5sZW5ndGggJiYgdGhpcy5hY3RpdmVJdGVtSW5kZXggPT09IDA7XG4gICAgfVxufVxuIiwiPGhlYWRlciBjbGFzcz1cInQtaGVhZGVyXCI+XG4gICAgPGgxIGNsYXNzPVwidC10aXRsZVwiPlxuICAgICAgICB7eyBoZWFkZXIgfX1cbiAgICAgICAgPHR1aS10YWdcbiAgICAgICAgICAgICpuZ0lmPVwiISFkZXByZWNhdGVkIHx8IGRlcHJlY2F0ZWQgPT09ICcnXCJcbiAgICAgICAgICAgIHN0YXR1cz1cImN1c3RvbVwiXG4gICAgICAgICAgICB2YWx1ZT1cImRlcHJlY2F0ZWRcIlxuICAgICAgICAgICAgY2xhc3M9XCJ0LXRhZyB0LXRhZ19kZXByZWNhdGVkXCJcbiAgICAgICAgPjwvdHVpLXRhZz5cbiAgICAgICAgPHR1aS10YWdcbiAgICAgICAgICAgICpuZ0lmPVwicGFja2FnZVwiXG4gICAgICAgICAgICBzdGF0dXM9XCJjdXN0b21cIlxuICAgICAgICAgICAgY2xhc3M9XCJ0LXRhZyB0LXRhZ19wYWNrYWdlXCJcbiAgICAgICAgICAgIFthdXRvQ29sb3JdPVwidHJ1ZVwiXG4gICAgICAgICAgICBbdmFsdWVdPVwicGFja2FnZVwiXG4gICAgICAgID48L3R1aS10YWc+XG4gICAgPC9oMT5cbiAgICA8dHVpLXRhYnMtd2l0aC1tb3JlXG4gICAgICAgICpuZ0lmPVwidGFiQ29ubmVjdG9ycy5sZW5ndGhcIlxuICAgICAgICBjbGFzcz1cInQtdGFic1wiXG4gICAgICAgIFsoYWN0aXZlSXRlbUluZGV4KV09XCJhY3RpdmVJdGVtSW5kZXhcIlxuICAgID5cbiAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgdGFiIG9mIHRhYkNvbm5lY3RvcnM7IGZpcnN0IGFzIGZpcnN0OyBpbmRleCBhcyBpbmRleFwiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cInRhYi5wYWdlVGFiIHx8IGRlZmF1bHRUYWJzW2luZGV4XSBhcyB0YWJOYW1lXCI+XG4gICAgICAgICAgICAgICAgPGFcbiAgICAgICAgICAgICAgICAgICAgKnR1aUl0ZW1cbiAgICAgICAgICAgICAgICAgICAgcm91dGVyTGlua0FjdGl2ZVxuICAgICAgICAgICAgICAgICAgICB0dWlUYWJcbiAgICAgICAgICAgICAgICAgICAgW3JvdXRlckxpbmtdPVwiZmlyc3QgPyAnLi8nIDogKHRhYk5hbWUgfCB0dWlSZXBsYWNlOiBmcm9tIDogdG8pXCJcbiAgICAgICAgICAgICAgICAgICAgW3JvdXRlckxpbmtBY3RpdmVPcHRpb25zXT1cIntleGFjdDogZmlyc3R9XCJcbiAgICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAgICAgIHt7IHRhYk5hbWUgfX1cbiAgICAgICAgICAgICAgICA8L2E+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgPC90dWktdGFicy13aXRoLW1vcmU+XG4gICAgPHR1aS1kb2Mtc291cmNlLWNvZGVcbiAgICAgICAgY2xhc3M9XCJ0LXNvdXJjZS1jb2RlXCJcbiAgICAgICAgW2hlYWRlcl09XCJoZWFkZXJcIlxuICAgICAgICBbcGFja2FnZV09XCJwYWNrYWdlXCJcbiAgICAgICAgW3BhdGhdPVwicGF0aFwiXG4gICAgICAgIFt0eXBlXT1cInR5cGVcIlxuICAgID48L3R1aS1kb2Mtc291cmNlLWNvZGU+XG48L2hlYWRlcj5cbjxkaXYgY2xhc3M9XCJ0LWNvbnRlbnRcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPHR1aS1kb2Mtc2VlLWFsc29cbiAgICAgICAgKm5nSWY9XCJzaG93U2VlQWxzb1wiXG4gICAgICAgIGNsYXNzPVwidC1zZWUtYWxzb1wiXG4gICAgICAgIFtzZWVBbHNvXT1cInNlZUFsc29cIlxuICAgID48L3R1aS1kb2Mtc2VlLWFsc28+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgdGFiIG9mIHRhYkNvbm5lY3RvcnM7IGluZGV4IGFzIGluZGV4XCI+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAgICpuZ0lmPVwiaW5kZXggPT09IGFjdGl2ZUl0ZW1JbmRleFwiXG4gICAgICAgICAgICBbbmdUZW1wbGF0ZU91dGxldF09XCJ0YWIudGVtcGxhdGVcIlxuICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgPC9uZy1jb250YWluZXI+XG48L2Rpdj5cbiJdfQ==
|