@taiga-ui/addon-doc 3.23.1-dev.main-d8b7500 → 3.23.1-dev.main-3d032b2
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/bundles/taiga-ui-addon-doc.umd.js +42 -34
- package/bundles/taiga-ui-addon-doc.umd.js.map +1 -1
- package/components/demo/demo.component.d.ts +2 -2
- package/components/documentation/documentation.component.d.ts +2 -2
- package/components/example/example.component.d.ts +2 -2
- package/components/main/main.component.d.ts +4 -3
- package/components/navigation/navigation.component.d.ts +2 -2
- package/esm2015/components/demo/demo.component.js +5 -5
- package/esm2015/components/documentation/documentation.component.js +4 -4
- package/esm2015/components/example/example.component.js +4 -4
- package/esm2015/components/main/main.component.js +9 -7
- package/esm2015/components/navigation/navigation.component.js +5 -5
- package/esm2015/internal/input-opacity/input-opacity.directive.js +4 -4
- package/esm2015/services/theme-night.options.js +4 -1
- package/esm2015/services/theme-night.service.js +10 -6
- package/esm2015/utils/to-flat-map-pages.js +4 -4
- package/fesm2015/taiga-ui-addon-doc.js +39 -32
- package/fesm2015/taiga-ui-addon-doc.js.map +1 -1
- package/internal/input-opacity/input-opacity.directive.d.ts +2 -2
- package/package.json +1 -1
- package/services/theme-night.options.d.ts +1 -0
- package/services/theme-night.service.d.ts +3 -2
|
@@ -8,7 +8,7 @@ import { Subject } from 'rxjs';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
export declare class TuiDocDemoComponent implements OnInit {
|
|
10
10
|
readonly isMobile: boolean;
|
|
11
|
-
private readonly
|
|
11
|
+
private readonly el;
|
|
12
12
|
private readonly locationRef;
|
|
13
13
|
private readonly urlSerializer;
|
|
14
14
|
readonly texts: [string, string, string];
|
|
@@ -27,7 +27,7 @@ export declare class TuiDocDemoComponent implements OnInit {
|
|
|
27
27
|
sandboxWidth: number;
|
|
28
28
|
readonly change$: Subject<void>;
|
|
29
29
|
readonly items: readonly TuiBrightness[];
|
|
30
|
-
constructor(isMobile: boolean,
|
|
30
|
+
constructor(isMobile: boolean, el: ElementRef<HTMLElement>, locationRef: Location, urlSerializer: UrlSerializer, texts: [string, string, string], urlStateHandler: TuiStringHandler<UrlTree>);
|
|
31
31
|
onResize(): void;
|
|
32
32
|
onMouseUp(): void;
|
|
33
33
|
ngOnInit(): void;
|
|
@@ -5,7 +5,7 @@ import { TuiGetOpacityPipe } from './pipes/opacity.pipe';
|
|
|
5
5
|
import { TuiGetColorPipe } from './pipes/сolor.pipe';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare class TuiDocDocumentationComponent implements AfterContentInit {
|
|
8
|
-
private readonly
|
|
8
|
+
private readonly cdr;
|
|
9
9
|
readonly texts: [string, string, string, string, string];
|
|
10
10
|
readonly excludedProperties: Set<string>;
|
|
11
11
|
private readonly destroy$;
|
|
@@ -16,7 +16,7 @@ export declare class TuiDocDocumentationComponent implements AfterContentInit {
|
|
|
16
16
|
isAPI: boolean;
|
|
17
17
|
propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>>;
|
|
18
18
|
activeItemIndex: number;
|
|
19
|
-
constructor(
|
|
19
|
+
constructor(cdr: ChangeDetectorRef, texts: [string, string, string, string, string], excludedProperties: Set<string>, destroy$: TuiDestroyService, getColor: TuiGetColorPipe, getOpacity: TuiGetOpacityPipe);
|
|
20
20
|
ngAfterContentInit(): void;
|
|
21
21
|
get type(): string;
|
|
22
22
|
matcher: TuiMatcher<TuiDocDocumentationPropertyConnectorDirective<any>>;
|
|
@@ -11,7 +11,7 @@ import { TuiDocExampleOptions } from './example-options';
|
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
export declare class TuiDocExampleComponent {
|
|
13
13
|
private readonly clipboard;
|
|
14
|
-
private readonly
|
|
14
|
+
private readonly alerts;
|
|
15
15
|
private readonly location;
|
|
16
16
|
private readonly copyTexts$;
|
|
17
17
|
readonly texts: [string, string, string];
|
|
@@ -35,7 +35,7 @@ export declare class TuiDocExampleComponent {
|
|
|
35
35
|
readonly copy$: Observable<string>;
|
|
36
36
|
readonly processor$: Observable<Record<string, string>>;
|
|
37
37
|
readonly loading$: Subject<boolean>;
|
|
38
|
-
constructor(clipboard: Clipboard,
|
|
38
|
+
constructor(clipboard: Clipboard, alerts: TuiAlertService, location: Location, copyTexts$: Observable<[string, string]>, texts: [string, string, string], codeEditor: TuiCodeEditor | null, processContent: TuiHandler<Record<string, string>, Record<string, string>>, isCypress: boolean, codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>, router: Router, route: ActivatedRoute, ngLocation: NgLocation, options: TuiDocExampleOptions);
|
|
39
39
|
readonly visible: (files: Record<string, string>) => boolean;
|
|
40
40
|
copyExampleLink(): void;
|
|
41
41
|
edit(files: Record<string, string>): void;
|
|
@@ -3,10 +3,11 @@ import { TuiThemeService } from '../../services/theme.service';
|
|
|
3
3
|
import { TuiThemeNightService } from '../../services/theme-night.service';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TuiDocMainComponent {
|
|
6
|
-
readonly
|
|
7
|
-
readonly
|
|
6
|
+
readonly theme: TuiThemeService;
|
|
7
|
+
readonly night: TuiThemeNightService;
|
|
8
8
|
readonly change$: TuiThemeNightService;
|
|
9
|
-
|
|
9
|
+
readonly night$: import("rxjs").Observable<boolean>;
|
|
10
|
+
constructor(theme: TuiThemeService, night: TuiThemeNightService);
|
|
10
11
|
get mode(): TuiBrightness | null;
|
|
11
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocMainComponent, never>;
|
|
12
13
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocMainComponent, "tui-doc-main", never, {}, {}, never, ["tuiDocNavigation", "tuiDocHeader", "tuiOverContent", "tuiOverDialogs", "tuiOverAlerts", "tuiOverPortals", "tuiOverHints"]>;
|
|
@@ -9,7 +9,7 @@ import { TuiDocPage } from '../../interfaces/page';
|
|
|
9
9
|
import { TuiDocPages } from '../../types/pages';
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
export declare class TuiDocNavigationComponent {
|
|
12
|
-
private readonly
|
|
12
|
+
private readonly doc;
|
|
13
13
|
private readonly mode;
|
|
14
14
|
readonly sidebar: unknown;
|
|
15
15
|
readonly labels: string[];
|
|
@@ -27,7 +27,7 @@ export declare class TuiDocNavigationComponent {
|
|
|
27
27
|
readonly search: FormControl;
|
|
28
28
|
readonly filtered$: Observable<readonly (readonly TuiDocPage[])[]>;
|
|
29
29
|
readonly mode$: Observable<TuiBrightness>;
|
|
30
|
-
constructor(
|
|
30
|
+
constructor(cdr: ChangeDetectorRef, titleService: Title, title$: Observable<string>, doc: Document, mode: TuiModeDirective, sidebar: unknown, labels: string[], items: readonly TuiDocPages[], searchText: string, router: Router, activatedRoute: ActivatedRoute, destroy$: Observable<void>, readyToScroll$: Observable<boolean>, scrollBehavior: ScrollBehavior);
|
|
31
31
|
get canOpen(): boolean;
|
|
32
32
|
get itemsWithoutSections(): TuiDocPages;
|
|
33
33
|
isActive(route: string): boolean;
|
|
@@ -17,9 +17,9 @@ import * as i5 from "@angular/forms";
|
|
|
17
17
|
import * as i6 from "@taiga-ui/cdk";
|
|
18
18
|
const MIN_WIDTH = 160;
|
|
19
19
|
export class TuiDocDemoComponent {
|
|
20
|
-
constructor(isMobile,
|
|
20
|
+
constructor(isMobile, el, locationRef, urlSerializer, texts, urlStateHandler) {
|
|
21
21
|
this.isMobile = isMobile;
|
|
22
|
-
this.
|
|
22
|
+
this.el = el;
|
|
23
23
|
this.locationRef = locationRef;
|
|
24
24
|
this.urlSerializer = urlSerializer;
|
|
25
25
|
this.texts = texts;
|
|
@@ -63,10 +63,10 @@ export class TuiDocDemoComponent {
|
|
|
63
63
|
return;
|
|
64
64
|
}
|
|
65
65
|
const safe = width || this.resizeable.nativeElement.clientWidth;
|
|
66
|
-
const total = this.
|
|
66
|
+
const total = this.el.nativeElement.clientWidth;
|
|
67
67
|
const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;
|
|
68
68
|
const validated = safe < total ? clamped : NaN;
|
|
69
|
-
this.resizer.nativeElement.textContent = String(clamped);
|
|
69
|
+
this.resizer.nativeElement.textContent = String(clamped || '-');
|
|
70
70
|
this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';
|
|
71
71
|
this.sandboxWidth = validated;
|
|
72
72
|
}
|
|
@@ -161,4 +161,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
161
161
|
type: HostListener,
|
|
162
162
|
args: ['document:mouseup.silent']
|
|
163
163
|
}], updateUrl: [] } });
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/demo/demo.component.ts","../../../../../projects/addon-doc/src/components/demo/demo.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormGroup} from '@angular/forms';\nimport {UrlSerializer, UrlTree} from '@angular/router';\nimport {\n    TUI_IS_MOBILE,\n    tuiClamp,\n    TuiDestroyService,\n    tuiPure,\n    tuiPx,\n    TuiResizeableDirective,\n    TuiStringHandler,\n} from '@taiga-ui/cdk';\nimport {TuiBrightness, TuiModeDirective} from '@taiga-ui/core';\nimport {Subject} from 'rxjs';\n\nimport {TUI_DOC_DEMO_TEXTS} from '../../tokens/i18n';\nimport {TUI_DOC_URL_STATE_HANDLER} from '../../tokens/url-state-handler';\n\nconst MIN_WIDTH = 160;\n\n@Component({\n    selector: 'tui-doc-demo',\n    templateUrl: './demo.template.html',\n    styleUrls: ['./demo.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        {\n            provide: TuiModeDirective,\n            useExisting: forwardRef(() => TuiDocDemoComponent),\n        },\n    ],\n})\nexport class TuiDocDemoComponent implements OnInit {\n    @ViewChild(TuiResizeableDirective, {static: true})\n    private readonly resizeable?: ElementRef<HTMLElement>;\n\n    @ViewChild('content', {static: true})\n    private readonly content?: ElementRef<HTMLElement>;\n\n    @ViewChild('resizer', {static: true})\n    private readonly resizer?: ElementRef<HTMLElement>;\n\n    @Input()\n    control: AbstractControl | null = null;\n\n    @ContentChild(TemplateRef)\n    readonly template: TemplateRef<Record<string, unknown>> | null = null;\n\n    testForm?: FormGroup;\n    readonly updateOnVariants = ['change', 'blur', 'submit'] as const;\n    updateOn: 'blur' | 'change' | 'submit' = this.updateOnVariants[0];\n    expanded = false;\n    opaque = true;\n    mode: TuiBrightness | null = this.getUrlTree().queryParams.tuiMode || null;\n    sandboxWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10);\n\n    readonly change$ = new Subject<void>();\n    readonly items: readonly TuiBrightness[] = ['onLight', 'onDark'];\n\n    constructor(\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_DEMO_TEXTS) readonly texts: [string, string, string],\n        @Inject(TUI_DOC_URL_STATE_HANDLER)\n        private readonly urlStateHandler: TuiStringHandler<UrlTree>,\n    ) {}\n\n    @HostListener('window:resize')\n    onResize(): void {\n        this.updateWidth();\n        this.onMouseUp();\n    }\n\n    @HostListener('document:mouseup.silent')\n    onMouseUp(): void {\n        this.updateUrl(this.mode, this.sandboxWidth);\n    }\n\n    ngOnInit(): void {\n        this.createForm();\n        this.updateWidth(this.sandboxWidth + this.delta);\n    }\n\n    onModeChange(mode: TuiBrightness | null): void {\n        this.updateUrl(mode, this.sandboxWidth);\n        this.mode = mode;\n        this.change$.next();\n    }\n\n    toggleDetails(): void {\n        this.expanded = !this.expanded;\n    }\n\n    updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void {\n        this.updateOn = updateOn;\n        this.createForm();\n    }\n\n    updateWidth(width: number = NaN): void {\n        if (!this.resizer || !this.resizeable || !this.content) {\n            return;\n        }\n\n        const safe = width || this.resizeable.nativeElement.clientWidth;\n        const total = this.elementRef.nativeElement.clientWidth;\n        const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;\n        const validated = safe < total ? clamped : NaN;\n\n        this.resizer.nativeElement.textContent = String(clamped);\n        this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';\n        this.sandboxWidth = validated;\n    }\n\n    private get delta(): number {\n        return this.resizeable && this.content\n            ? this.resizeable.nativeElement.clientWidth -\n                  this.content.nativeElement.clientWidth\n            : 0;\n    }\n\n    @tuiPure\n    private updateUrl(tuiMode: TuiBrightness | null, sandboxWidth: number): void {\n        const tree = this.getUrlTree();\n        const {queryParams} = tree;\n        const modeParam = tuiMode ? {tuiMode} : {};\n        const resizeParam = !Number.isNaN(sandboxWidth) ? {sandboxWidth} : {};\n\n        delete queryParams.sandboxWidth;\n        delete queryParams.tuiMode;\n\n        tree.queryParams = {\n            ...queryParams,\n            ...modeParam,\n            ...resizeParam,\n        };\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n\n    private createForm(): void {\n        const {control, updateOn} = this;\n\n        if (control) {\n            this.testForm = new FormGroup({testValue: control}, {updateOn});\n        }\n    }\n\n    private getUrlTree(): UrlTree {\n        return this.urlSerializer.parse(this.locationRef.path());\n    }\n}\n","<div\n    class=\"t-bg-toggle\"\n    [tuiMode]=\"null\"\n>\n    <ng-template #tooltip>\n        {{ texts[0] }}\n        <a\n            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\n        >\n            <code>tuiMode</code>\n        </a>\n    </ng-template>\n    <ng-container *ngIf=\"isMobile; else desktop\">\n        <tui-select\n            tuiTextfieldSize=\"s\"\n            class=\"t-mode\"\n            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [ngModel]=\"mode\"\n            (ngModelChange)=\"onModeChange($event)\"\n        >\n            tuiMode\n            <tui-data-list-wrapper\n                *tuiDataList\n                [items]=\"items\"\n            ></tui-data-list-wrapper>\n        </tui-select>\n    </ng-container>\n    <ng-template #desktop>\n        tuiMode:\n        <tui-tooltip\n            describeId=\"form\"\n            [content]=\"tooltip\"\n        ></tui-tooltip>\n        <div\n            tuiGroup\n            class=\"t-group\"\n            [collapsed]=\"true\"\n        >\n            <tui-radio-block\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onDark\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onLight\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onLight\n            </tui-radio-block>\n        </div>\n    </ng-template>\n    <tui-checkbox-labeled\n        size=\"m\"\n        class=\"t-checkbox\"\n        [(ngModel)]=\"opaque\"\n    >\n        {{ texts[1] }}\n    </tui-checkbox-labeled>\n</div>\n<div\n    tuiResizeable\n    class=\"t-wrapper\"\n    [class.t-wrapper_dark]=\"mode === 'onDark'\"\n    [class.t-wrapper_gray]=\"mode === 'onLight'\"\n    [class.t-wrapper_transparent]=\"!opaque\"\n>\n    <div\n        id=\"demo-content\"\n        class=\"t-content\"\n    >\n        <div #content>\n            <form\n                *ngIf=\"testForm\"\n                class=\"t-form\"\n                [formGroup]=\"testForm\"\n            >\n                <div class=\"t-input-wrapper\">\n                    <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n                </div>\n                <button\n                    tuiButton\n                    type=\"button\"\n                    size=\"s\"\n                    automation-id=\"tui-demo-button__toggle-details\"\n                    class=\"t-button\"\n                    [iconRight]=\"icon\"\n                    (click)=\"toggleDetails()\"\n                >\n                    {{ texts[2] }}\n                </button>\n                <ng-template #icon>\n                    <tui-svg\n                        src=\"tuiIconChevronDown\"\n                        class=\"t-icon\"\n                        [class.t-icon_rotated]=\"expanded\"\n                    ></tui-svg>\n                </ng-template>\n                <tui-expand\n                    class=\"t-expand\"\n                    [expanded]=\"expanded\"\n                >\n                    <ng-template tuiExpandContent>\n                        <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n                        <div\n                            tuiGroup\n                            class=\"t-form-controls\"\n                        >\n                            <tui-select\n                                tuiTextfieldSize=\"s\"\n                                automation-id=\"tui-demo-select__expand-update-on\"\n                                class=\"t-select\"\n                                [ngModel]=\"updateOn\"\n                                [ngModelOptions]=\"{standalone: true}\"\n                                (ngModelChange)=\"updateOnChange($event)\"\n                            >\n                                updateOn\n                                <tui-data-list-wrapper\n                                    *tuiDataList\n                                    [items]=\"updateOnVariants\"\n                                ></tui-data-list-wrapper>\n                            </tui-select>\n                            <button\n                                tuiButton\n                                type=\"reset\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__reset-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                tuiButton\n                                type=\"submit\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__submit-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Submit\n                            </button>\n                        </div>\n                    </ng-template>\n                </tui-expand>\n            </form>\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        #resizer\n        class=\"t-resizer\"\n        [tuiResizer]=\"[1, 0]\"\n        (tuiSizeChange)=\"updateWidth($event[0])\"\n    ></div>\n</div>\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/demo/demo.component.ts","../../../../../projects/addon-doc/src/components/demo/demo.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormGroup} from '@angular/forms';\nimport {UrlSerializer, UrlTree} from '@angular/router';\nimport {\n    TUI_IS_MOBILE,\n    tuiClamp,\n    TuiDestroyService,\n    tuiPure,\n    tuiPx,\n    TuiResizeableDirective,\n    TuiStringHandler,\n} from '@taiga-ui/cdk';\nimport {TuiBrightness, TuiModeDirective} from '@taiga-ui/core';\nimport {Subject} from 'rxjs';\n\nimport {TUI_DOC_DEMO_TEXTS} from '../../tokens/i18n';\nimport {TUI_DOC_URL_STATE_HANDLER} from '../../tokens/url-state-handler';\n\nconst MIN_WIDTH = 160;\n\n@Component({\n    selector: 'tui-doc-demo',\n    templateUrl: './demo.template.html',\n    styleUrls: ['./demo.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        {\n            provide: TuiModeDirective,\n            useExisting: forwardRef(() => TuiDocDemoComponent),\n        },\n    ],\n})\nexport class TuiDocDemoComponent implements OnInit {\n    @ViewChild(TuiResizeableDirective, {static: true})\n    private readonly resizeable?: ElementRef<HTMLElement>;\n\n    @ViewChild('content', {static: true})\n    private readonly content?: ElementRef<HTMLElement>;\n\n    @ViewChild('resizer', {static: true})\n    private readonly resizer?: ElementRef<HTMLElement>;\n\n    @Input()\n    control: AbstractControl | null = null;\n\n    @ContentChild(TemplateRef)\n    readonly template: TemplateRef<Record<string, unknown>> | null = null;\n\n    testForm?: FormGroup;\n    readonly updateOnVariants = ['change', 'blur', 'submit'] as const;\n    updateOn: 'blur' | 'change' | 'submit' = this.updateOnVariants[0];\n    expanded = false;\n    opaque = true;\n    mode: TuiBrightness | null = this.getUrlTree().queryParams.tuiMode || null;\n    sandboxWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10);\n\n    readonly change$ = new Subject<void>();\n    readonly items: readonly TuiBrightness[] = ['onLight', 'onDark'];\n\n    constructor(\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_DEMO_TEXTS) readonly texts: [string, string, string],\n        @Inject(TUI_DOC_URL_STATE_HANDLER)\n        private readonly urlStateHandler: TuiStringHandler<UrlTree>,\n    ) {}\n\n    @HostListener('window:resize')\n    onResize(): void {\n        this.updateWidth();\n        this.onMouseUp();\n    }\n\n    @HostListener('document:mouseup.silent')\n    onMouseUp(): void {\n        this.updateUrl(this.mode, this.sandboxWidth);\n    }\n\n    ngOnInit(): void {\n        this.createForm();\n        this.updateWidth(this.sandboxWidth + this.delta);\n    }\n\n    onModeChange(mode: TuiBrightness | null): void {\n        this.updateUrl(mode, this.sandboxWidth);\n        this.mode = mode;\n        this.change$.next();\n    }\n\n    toggleDetails(): void {\n        this.expanded = !this.expanded;\n    }\n\n    updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void {\n        this.updateOn = updateOn;\n        this.createForm();\n    }\n\n    updateWidth(width: number = NaN): void {\n        if (!this.resizer || !this.resizeable || !this.content) {\n            return;\n        }\n\n        const safe = width || this.resizeable.nativeElement.clientWidth;\n        const total = this.el.nativeElement.clientWidth;\n        const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;\n        const validated = safe < total ? clamped : NaN;\n\n        this.resizer.nativeElement.textContent = String(clamped || '-');\n        this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';\n        this.sandboxWidth = validated;\n    }\n\n    private get delta(): number {\n        return this.resizeable && this.content\n            ? this.resizeable.nativeElement.clientWidth -\n                  this.content.nativeElement.clientWidth\n            : 0;\n    }\n\n    @tuiPure\n    private updateUrl(tuiMode: TuiBrightness | null, sandboxWidth: number): void {\n        const tree = this.getUrlTree();\n        const {queryParams} = tree;\n        const modeParam = tuiMode ? {tuiMode} : {};\n        const resizeParam = !Number.isNaN(sandboxWidth) ? {sandboxWidth} : {};\n\n        delete queryParams.sandboxWidth;\n        delete queryParams.tuiMode;\n\n        tree.queryParams = {\n            ...queryParams,\n            ...modeParam,\n            ...resizeParam,\n        };\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n\n    private createForm(): void {\n        const {control, updateOn} = this;\n\n        if (control) {\n            this.testForm = new FormGroup({testValue: control}, {updateOn});\n        }\n    }\n\n    private getUrlTree(): UrlTree {\n        return this.urlSerializer.parse(this.locationRef.path());\n    }\n}\n","<div\n    class=\"t-bg-toggle\"\n    [tuiMode]=\"null\"\n>\n    <ng-template #tooltip>\n        {{ texts[0] }}\n        <a\n            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\n        >\n            <code>tuiMode</code>\n        </a>\n    </ng-template>\n    <ng-container *ngIf=\"isMobile; else desktop\">\n        <tui-select\n            tuiTextfieldSize=\"s\"\n            class=\"t-mode\"\n            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [ngModel]=\"mode\"\n            (ngModelChange)=\"onModeChange($event)\"\n        >\n            tuiMode\n            <tui-data-list-wrapper\n                *tuiDataList\n                [items]=\"items\"\n            ></tui-data-list-wrapper>\n        </tui-select>\n    </ng-container>\n    <ng-template #desktop>\n        tuiMode:\n        <tui-tooltip\n            describeId=\"form\"\n            [content]=\"tooltip\"\n        ></tui-tooltip>\n        <div\n            tuiGroup\n            class=\"t-group\"\n            [collapsed]=\"true\"\n        >\n            <tui-radio-block\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onDark\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onLight\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onLight\n            </tui-radio-block>\n        </div>\n    </ng-template>\n    <tui-checkbox-labeled\n        size=\"m\"\n        class=\"t-checkbox\"\n        [(ngModel)]=\"opaque\"\n    >\n        {{ texts[1] }}\n    </tui-checkbox-labeled>\n</div>\n<div\n    tuiResizeable\n    class=\"t-wrapper\"\n    [class.t-wrapper_dark]=\"mode === 'onDark'\"\n    [class.t-wrapper_gray]=\"mode === 'onLight'\"\n    [class.t-wrapper_transparent]=\"!opaque\"\n>\n    <div\n        id=\"demo-content\"\n        class=\"t-content\"\n    >\n        <div #content>\n            <form\n                *ngIf=\"testForm\"\n                class=\"t-form\"\n                [formGroup]=\"testForm\"\n            >\n                <div class=\"t-input-wrapper\">\n                    <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n                </div>\n                <button\n                    tuiButton\n                    type=\"button\"\n                    size=\"s\"\n                    automation-id=\"tui-demo-button__toggle-details\"\n                    class=\"t-button\"\n                    [iconRight]=\"icon\"\n                    (click)=\"toggleDetails()\"\n                >\n                    {{ texts[2] }}\n                </button>\n                <ng-template #icon>\n                    <tui-svg\n                        src=\"tuiIconChevronDown\"\n                        class=\"t-icon\"\n                        [class.t-icon_rotated]=\"expanded\"\n                    ></tui-svg>\n                </ng-template>\n                <tui-expand\n                    class=\"t-expand\"\n                    [expanded]=\"expanded\"\n                >\n                    <ng-template tuiExpandContent>\n                        <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n                        <div\n                            tuiGroup\n                            class=\"t-form-controls\"\n                        >\n                            <tui-select\n                                tuiTextfieldSize=\"s\"\n                                automation-id=\"tui-demo-select__expand-update-on\"\n                                class=\"t-select\"\n                                [ngModel]=\"updateOn\"\n                                [ngModelOptions]=\"{standalone: true}\"\n                                (ngModelChange)=\"updateOnChange($event)\"\n                            >\n                                updateOn\n                                <tui-data-list-wrapper\n                                    *tuiDataList\n                                    [items]=\"updateOnVariants\"\n                                ></tui-data-list-wrapper>\n                            </tui-select>\n                            <button\n                                tuiButton\n                                type=\"reset\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__reset-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                tuiButton\n                                type=\"submit\"\n                                size=\"s\"\n                                automation-id=\"tui-demo-button__submit-state\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Submit\n                            </button>\n                        </div>\n                    </ng-template>\n                </tui-expand>\n            </form>\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        #resizer\n        class=\"t-resizer\"\n        [tuiResizer]=\"[1, 0]\"\n        (tuiSizeChange)=\"updateWidth($event[0])\"\n    ></div>\n</div>\n"]}
|
|
@@ -26,8 +26,8 @@ import * as i14 from "./pipes/primitive-polymorpheus-content.pipe";
|
|
|
26
26
|
// @bad TODO subscribe propertiesConnectors changes
|
|
27
27
|
// @bad TODO refactor to make more flexible
|
|
28
28
|
export class TuiDocDocumentationComponent {
|
|
29
|
-
constructor(
|
|
30
|
-
this.
|
|
29
|
+
constructor(cdr, texts, excludedProperties, destroy$, getColor, getOpacity) {
|
|
30
|
+
this.cdr = cdr;
|
|
31
31
|
this.texts = texts;
|
|
32
32
|
this.excludedProperties = excludedProperties;
|
|
33
33
|
this.destroy$ = destroy$;
|
|
@@ -42,7 +42,7 @@ export class TuiDocDocumentationComponent {
|
|
|
42
42
|
}
|
|
43
43
|
ngAfterContentInit() {
|
|
44
44
|
tuiQueryListChanges(this.propertiesConnectors)
|
|
45
|
-
.pipe(switchMap(items => merge(...items.map(({ changed$ }) => changed$))), tuiWatch(this.
|
|
45
|
+
.pipe(switchMap(items => merge(...items.map(({ changed$ }) => changed$))), tuiWatch(this.cdr), takeUntil(this.destroy$))
|
|
46
46
|
.subscribe();
|
|
47
47
|
}
|
|
48
48
|
get type() {
|
|
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
115
115
|
type: ContentChildren,
|
|
116
116
|
args: [TuiDocDocumentationPropertyConnectorDirective]
|
|
117
117
|
}] } });
|
|
118
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation.component.ts","../../../../../projects/addon-doc/src/components/documentation/documentation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {animate, style, transition, trigger} from '@angular/animations';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n    Self,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiDestroyService,\n    tuiHexToRgb,\n    TuiMatcher,\n    tuiQueryListChanges,\n    tuiWatch,\n} from '@taiga-ui/cdk';\nimport {merge} from 'rxjs';\nimport {switchMap, takeUntil} from 'rxjs/operators';\n\nimport {TUI_DOC_EXCLUDED_PROPERTIES} from '../../tokens/excluded-properties';\nimport {TUI_DOC_DOCUMENTATION_TEXTS} from '../../tokens/i18n';\nimport {TuiDocDocumentationPropertyConnectorDirective} from './documentation-property-connector.directive';\nimport {TuiGetOpacityPipe} from './pipes/opacity.pipe';\nimport {TuiGetColorPipe} from './pipes/сolor.pipe';\n\n// @bad TODO subscribe propertiesConnectors changes\n// @bad TODO refactor to make more flexible\n@Component({\n    selector: 'tui-doc-documentation',\n    templateUrl: './documentation.template.html',\n    styleUrls: ['./documentation.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('emitEvent', [\n            transition(':increment', [style({opacity: 1}), animate('500ms ease-in')]),\n        ]),\n    ],\n    providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],\n})\nexport class TuiDocDocumentationComponent implements AfterContentInit {\n    @Input()\n    heading = '';\n\n    @Input()\n    showValues = true;\n\n    @Input()\n    isAPI = false;\n\n    @ContentChildren(TuiDocDocumentationPropertyConnectorDirective)\n    propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>> =\n        EMPTY_QUERY;\n\n    activeItemIndex = 0;\n\n    constructor(\n        @Inject(ChangeDetectorRef) private readonly changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_DOC_DOCUMENTATION_TEXTS)\n        readonly texts: [string, string, string, string, string],\n        @Inject(TUI_DOC_EXCLUDED_PROPERTIES)\n        readonly excludedProperties: Set<string>,\n        @Self()\n        @Inject(TuiDestroyService)\n        private readonly destroy$: TuiDestroyService,\n        @Inject(TuiGetColorPipe)\n        private readonly getColor: TuiGetColorPipe,\n        @Inject(TuiGetOpacityPipe)\n        private readonly getOpacity: TuiGetOpacityPipe,\n    ) {}\n\n    ngAfterContentInit(): void {\n        tuiQueryListChanges(this.propertiesConnectors)\n            .pipe(\n                switchMap(items => merge(...items.map(({changed$}) => changed$))),\n                tuiWatch(this.changeDetectorRef),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    get type(): string {\n        return this.isAPI ? this.texts[0] : this.texts[1];\n    }\n\n    matcher: TuiMatcher<TuiDocDocumentationPropertyConnectorDirective<any>> = (\n        item: TuiDocDocumentationPropertyConnectorDirective<any>,\n        exclusions: Set<string>,\n    ) => !exclusions.has(item.documentationPropertyName);\n\n    onColorChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        color: string,\n    ): void {\n        const opacity = this.getOpacity.transform(\n            connector.documentationPropertyValue || '',\n        );\n\n        if (opacity === 100) {\n            connector.onValueChange(color);\n\n            return;\n        }\n\n        const rgb = tuiHexToRgb(color).join(', ');\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n\n    onOpacityChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        opacity: number,\n    ): void {\n        const hex = this.getColor.transform(connector.documentationPropertyValue || '');\n        const rgb = tuiHexToRgb(hex);\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n}\n","<h1\n    *ngIf=\"heading\"\n    class=\"t-heading\"\n>\n    {{ heading }}\n</h1>\n<ng-content></ng-content>\n<table class=\"t-table\">\n    <tr class=\"t-row t-row_header\">\n        <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n        <th class=\"t-th\">{{ type }}</th>\n        <th\n            *ngIf=\"showValues && !isAPI\"\n            class=\"t-th t-cell t-th_value\"\n        >\n            {{ texts[3] }}\n        </th>\n    </tr>\n    <tr\n        *ngFor=\"let propertyConnector of $any(propertiesConnectors) | tuiFilter : matcher : excludedProperties\"\n        class=\"t-row\"\n        [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n    >\n        <td class=\"t-cell\">\n            <div\n                automation-id=\"tui-documentation__property-name\"\n                class=\"t-property\"\n            >\n                {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n                <tui-badge\n                    *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n                    size=\"s\"\n                    value=\"Optional\"\n                ></tui-badge>\n            </div>\n            <span\n                *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n                class=\"t-deprecated-label\"\n            >\n                deprecated\n            </span>\n            <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n        </td>\n        <td class=\"t-cell\">\n            <span class=\"type\">\n                {{ propertyConnector.documentationPropertyType }}\n                <tui-tooltip\n                    *ngIf=\"propertyConnector.documentationPropertyType | tuiShowContentTooltip\"\n                    [describeId]=\"propertyConnector.attrName\"\n                    [content]=\"content\"\n                >\n                    <ng-template #content>\n                        {{ texts[4] }}\n                        <a\n                            tuiLink\n                            tuiMode=\"onDark\"\n                            target=\"_blank\"\n                            rel=\"noreferrer\"\n                            href=\"https://github.com/tinkoff/ng-polymorpheus\"\n                        >\n                            <code>ng-polymorpheus</code>\n                        </a>\n                    </ng-template>\n                </tui-tooltip>\n            </span>\n        </td>\n        <td\n            *ngIf=\"showValues\"\n            class=\"t-cell t-cell_value\"\n        >\n            <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n                <tui-select\n                    *ngIf=\"propertyConnector.hasItems; else noItems\"\n                    tuiTextfieldSize=\"m\"\n                    tuiDropdownLimitWidth=\"min\"\n                    [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n                    [tuiTextfieldLabelOutside]=\"true\"\n                    [nativeId]=\"propertyConnector.attrName\"\n                    [valueContent]=\"selectContent\"\n                    [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                    (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                >\n                    <code class=\"t-exception\">null</code>\n                    <tui-data-list-wrapper\n                        *tuiDataList\n                        [items]=\"propertyConnector.documentationPropertyValues\"\n                        [itemContent]=\"selectContent\"\n                    ></tui-data-list-wrapper>\n                </tui-select>\n                <ng-template\n                    #selectContent\n                    let-data\n                >\n                    <code>{{ data | tuiInspectAny }}</code>\n                </ng-template>\n\n                <ng-template #noItems>\n                    <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n                        <tui-toggle\n                            *ngSwitchCase=\"'boolean'\"\n                            size=\"l\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [showIcons]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-toggle>\n\n                        <tui-primitive-textfield\n                            *ngSwitchCase=\"'string'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [tuiTextfieldCleaner]=\"true\"\n                            [value]=\"propertyConnector.documentationPropertyValue || ''\"\n                            (valueChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-primitive-textfield>\n\n                        <div\n                            *ngSwitchCase=\"'color'\"\n                            tuiGroup\n                        >\n                            <tui-primitive-textfield\n                                tuiTextfieldSize=\"m\"\n                                [attr.id]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n                                (valueChange)=\"onColorChange(propertyConnector, $event)\"\n                            >\n                                <input\n                                    tuiTextfield\n                                    type=\"text\"\n                                />\n                            </tui-primitive-textfield>\n                            <tui-input-count\n                                tuiTextfieldSize=\"m\"\n                                [max]=\"100\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n                            >\n                                Opacity\n                            </tui-input-count>\n                        </div>\n\n                        <tui-input-count\n                            *ngSwitchCase=\"'number'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-input-count>\n\n                        <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n                            <tui-primitive-textfield\n                                *ngIf=\"\n                                    propertyConnector.documentationPropertyValue | tuiIsPrimitivePolymorpheusContentPipe\n                                \"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiTextfieldCleaner]=\"true\"\n                                [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n                                (valueChange)=\"propertyConnector.onValueChange($event)\"\n                            >\n                                Default content\n                            </tui-primitive-textfield>\n                        </ng-container>\n                    </ng-container>\n                </ng-template>\n            </ng-container>\n\n            <ng-template #elseEmitter>\n                <tui-notification\n                    class=\"t-output\"\n                    [@emitEvent]=\"propertyConnector.emits$ | async\"\n                >\n                    Emit!\n                </tui-notification>\n            </ng-template>\n        </td>\n    </tr>\n</table>\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation.component.ts","../../../../../projects/addon-doc/src/components/documentation/documentation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {animate, style, transition, trigger} from '@angular/animations';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n    Self,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiDestroyService,\n    tuiHexToRgb,\n    TuiMatcher,\n    tuiQueryListChanges,\n    tuiWatch,\n} from '@taiga-ui/cdk';\nimport {merge} from 'rxjs';\nimport {switchMap, takeUntil} from 'rxjs/operators';\n\nimport {TUI_DOC_EXCLUDED_PROPERTIES} from '../../tokens/excluded-properties';\nimport {TUI_DOC_DOCUMENTATION_TEXTS} from '../../tokens/i18n';\nimport {TuiDocDocumentationPropertyConnectorDirective} from './documentation-property-connector.directive';\nimport {TuiGetOpacityPipe} from './pipes/opacity.pipe';\nimport {TuiGetColorPipe} from './pipes/сolor.pipe';\n\n// @bad TODO subscribe propertiesConnectors changes\n// @bad TODO refactor to make more flexible\n@Component({\n    selector: 'tui-doc-documentation',\n    templateUrl: './documentation.template.html',\n    styleUrls: ['./documentation.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('emitEvent', [\n            transition(':increment', [style({opacity: 1}), animate('500ms ease-in')]),\n        ]),\n    ],\n    providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],\n})\nexport class TuiDocDocumentationComponent implements AfterContentInit {\n    @Input()\n    heading = '';\n\n    @Input()\n    showValues = true;\n\n    @Input()\n    isAPI = false;\n\n    @ContentChildren(TuiDocDocumentationPropertyConnectorDirective)\n    propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>> =\n        EMPTY_QUERY;\n\n    activeItemIndex = 0;\n\n    constructor(\n        @Inject(ChangeDetectorRef) private readonly cdr: ChangeDetectorRef,\n        @Inject(TUI_DOC_DOCUMENTATION_TEXTS)\n        readonly texts: [string, string, string, string, string],\n        @Inject(TUI_DOC_EXCLUDED_PROPERTIES)\n        readonly excludedProperties: Set<string>,\n        @Self()\n        @Inject(TuiDestroyService)\n        private readonly destroy$: TuiDestroyService,\n        @Inject(TuiGetColorPipe)\n        private readonly getColor: TuiGetColorPipe,\n        @Inject(TuiGetOpacityPipe)\n        private readonly getOpacity: TuiGetOpacityPipe,\n    ) {}\n\n    ngAfterContentInit(): void {\n        tuiQueryListChanges(this.propertiesConnectors)\n            .pipe(\n                switchMap(items => merge(...items.map(({changed$}) => changed$))),\n                tuiWatch(this.cdr),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    get type(): string {\n        return this.isAPI ? this.texts[0] : this.texts[1];\n    }\n\n    matcher: TuiMatcher<TuiDocDocumentationPropertyConnectorDirective<any>> = (\n        item: TuiDocDocumentationPropertyConnectorDirective<any>,\n        exclusions: Set<string>,\n    ) => !exclusions.has(item.documentationPropertyName);\n\n    onColorChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        color: string,\n    ): void {\n        const opacity = this.getOpacity.transform(\n            connector.documentationPropertyValue || '',\n        );\n\n        if (opacity === 100) {\n            connector.onValueChange(color);\n\n            return;\n        }\n\n        const rgb = tuiHexToRgb(color).join(', ');\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n\n    onOpacityChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        opacity: number,\n    ): void {\n        const hex = this.getColor.transform(connector.documentationPropertyValue || '');\n        const rgb = tuiHexToRgb(hex);\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n}\n","<h1\n    *ngIf=\"heading\"\n    class=\"t-heading\"\n>\n    {{ heading }}\n</h1>\n<ng-content></ng-content>\n<table class=\"t-table\">\n    <tr class=\"t-row t-row_header\">\n        <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n        <th class=\"t-th\">{{ type }}</th>\n        <th\n            *ngIf=\"showValues && !isAPI\"\n            class=\"t-th t-cell t-th_value\"\n        >\n            {{ texts[3] }}\n        </th>\n    </tr>\n    <tr\n        *ngFor=\"let propertyConnector of $any(propertiesConnectors) | tuiFilter : matcher : excludedProperties\"\n        class=\"t-row\"\n        [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n    >\n        <td class=\"t-cell\">\n            <div\n                automation-id=\"tui-documentation__property-name\"\n                class=\"t-property\"\n            >\n                {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n                <tui-badge\n                    *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n                    size=\"s\"\n                    value=\"Optional\"\n                ></tui-badge>\n            </div>\n            <span\n                *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n                class=\"t-deprecated-label\"\n            >\n                deprecated\n            </span>\n            <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n        </td>\n        <td class=\"t-cell\">\n            <span class=\"type\">\n                {{ propertyConnector.documentationPropertyType }}\n                <tui-tooltip\n                    *ngIf=\"propertyConnector.documentationPropertyType | tuiShowContentTooltip\"\n                    [describeId]=\"propertyConnector.attrName\"\n                    [content]=\"content\"\n                >\n                    <ng-template #content>\n                        {{ texts[4] }}\n                        <a\n                            tuiLink\n                            tuiMode=\"onDark\"\n                            target=\"_blank\"\n                            rel=\"noreferrer\"\n                            href=\"https://github.com/tinkoff/ng-polymorpheus\"\n                        >\n                            <code>ng-polymorpheus</code>\n                        </a>\n                    </ng-template>\n                </tui-tooltip>\n            </span>\n        </td>\n        <td\n            *ngIf=\"showValues\"\n            class=\"t-cell t-cell_value\"\n        >\n            <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n                <tui-select\n                    *ngIf=\"propertyConnector.hasItems; else noItems\"\n                    tuiTextfieldSize=\"m\"\n                    tuiDropdownLimitWidth=\"min\"\n                    [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n                    [tuiTextfieldLabelOutside]=\"true\"\n                    [nativeId]=\"propertyConnector.attrName\"\n                    [valueContent]=\"selectContent\"\n                    [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                    (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                >\n                    <code class=\"t-exception\">null</code>\n                    <tui-data-list-wrapper\n                        *tuiDataList\n                        [items]=\"propertyConnector.documentationPropertyValues\"\n                        [itemContent]=\"selectContent\"\n                    ></tui-data-list-wrapper>\n                </tui-select>\n                <ng-template\n                    #selectContent\n                    let-data\n                >\n                    <code>{{ data | tuiInspectAny }}</code>\n                </ng-template>\n\n                <ng-template #noItems>\n                    <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n                        <tui-toggle\n                            *ngSwitchCase=\"'boolean'\"\n                            size=\"l\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [showIcons]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-toggle>\n\n                        <tui-primitive-textfield\n                            *ngSwitchCase=\"'string'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [tuiTextfieldCleaner]=\"true\"\n                            [value]=\"propertyConnector.documentationPropertyValue || ''\"\n                            (valueChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-primitive-textfield>\n\n                        <div\n                            *ngSwitchCase=\"'color'\"\n                            tuiGroup\n                        >\n                            <tui-primitive-textfield\n                                tuiTextfieldSize=\"m\"\n                                [attr.id]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n                                (valueChange)=\"onColorChange(propertyConnector, $event)\"\n                            >\n                                <input\n                                    tuiTextfield\n                                    type=\"text\"\n                                />\n                            </tui-primitive-textfield>\n                            <tui-input-count\n                                tuiTextfieldSize=\"m\"\n                                [max]=\"100\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n                            >\n                                Opacity\n                            </tui-input-count>\n                        </div>\n\n                        <tui-input-count\n                            *ngSwitchCase=\"'number'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-input-count>\n\n                        <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n                            <tui-primitive-textfield\n                                *ngIf=\"\n                                    propertyConnector.documentationPropertyValue | tuiIsPrimitivePolymorpheusContentPipe\n                                \"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiTextfieldCleaner]=\"true\"\n                                [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n                                (valueChange)=\"propertyConnector.onValueChange($event)\"\n                            >\n                                Default content\n                            </tui-primitive-textfield>\n                        </ng-container>\n                    </ng-container>\n                </ng-template>\n            </ng-container>\n\n            <ng-template #elseEmitter>\n                <tui-notification\n                    class=\"t-output\"\n                    [@emitEvent]=\"propertyConnector.emits$ | async\"\n                >\n                    Emit!\n                </tui-notification>\n            </ng-template>\n        </td>\n    </tr>\n</table>\n"]}
|
|
@@ -28,9 +28,9 @@ import * as i10 from "./example-get-tabs.pipe";
|
|
|
28
28
|
import * as i11 from "rxjs";
|
|
29
29
|
import * as i12 from "@angular/router";
|
|
30
30
|
export class TuiDocExampleComponent {
|
|
31
|
-
constructor(clipboard,
|
|
31
|
+
constructor(clipboard, alerts, location, copyTexts$, texts, codeEditor, processContent, isCypress, codeActions, router, route, ngLocation, options) {
|
|
32
32
|
this.clipboard = clipboard;
|
|
33
|
-
this.
|
|
33
|
+
this.alerts = alerts;
|
|
34
34
|
this.location = location;
|
|
35
35
|
this.copyTexts$ = copyTexts$;
|
|
36
36
|
this.texts = texts;
|
|
@@ -66,7 +66,7 @@ export class TuiDocExampleComponent {
|
|
|
66
66
|
const url = `${currentUrl}#${this.id}`;
|
|
67
67
|
this.setFragmentWithoutRedirect(this.id);
|
|
68
68
|
this.clipboard.copy(url);
|
|
69
|
-
this.
|
|
69
|
+
this.alerts
|
|
70
70
|
.open(this.texts[1], {
|
|
71
71
|
label: this.texts[2],
|
|
72
72
|
status: "success" /* Success */,
|
|
@@ -147,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
147
147
|
}], componentName: [{
|
|
148
148
|
type: Input
|
|
149
149
|
}] } });
|
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"example.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/example/example.component.ts","../../../../../projects/addon-doc/src/components/example/example.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Clipboard} from '@angular/cdk/clipboard';\nimport {Location as NgLocation} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, Inject, Input, Optional} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {LOCATION} from '@ng-web-apis/common';\nimport {TUI_IS_CYPRESS, TuiContextWithImplicit, TuiHandler} from '@taiga-ui/cdk';\nimport {TuiAlertService, TuiNotification} from '@taiga-ui/core';\nimport {TUI_COPY_TEXTS} from '@taiga-ui/kit';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {map, switchMap} from 'rxjs/operators';\n\nimport {TuiCodeEditor} from '../../interfaces/code-editor';\nimport {TuiDocExample} from '../../interfaces/page';\nimport {TUI_DOC_CODE_ACTIONS} from '../../tokens/code-actions';\nimport {TUI_DOC_CODE_EDITOR} from '../../tokens/code-editor';\nimport {TUI_DOC_EXAMPLE_CONTENT_PROCESSOR} from '../../tokens/example-content-processor';\nimport {TUI_DOC_EXAMPLE_TEXTS} from '../../tokens/i18n';\nimport {tuiRawLoadRecord} from '../../utils/raw-load-record';\nimport {TUI_DOC_EXAMPLE_OPTIONS, TuiDocExampleOptions} from './example-options';\n\n@Component({\n    selector: 'tui-doc-example',\n    templateUrl: './example.template.html',\n    styleUrls: ['./example.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiDocExampleComponent {\n    private readonly rawLoader$$ = new BehaviorSubject<TuiDocExample>({});\n\n    @Input()\n    id: string | null = null;\n\n    @Input()\n    heading: PolymorpheusContent = '';\n\n    @Input()\n    description: PolymorpheusContent = '';\n\n    @Input()\n    set content(content: TuiDocExample) {\n        this.rawLoader$$.next(content);\n    }\n\n    @Input()\n    componentName: string = this.location.pathname.slice(1);\n\n    readonly defaultTabIndex = 0;\n\n    readonly defaultTab = this.texts[this.defaultTabIndex];\n\n    activeItemIndex = this.defaultTabIndex;\n\n    readonly copy$ = this.copyTexts$.pipe(map(([copy]) => copy));\n\n    readonly processor$: Observable<Record<string, string>> = this.rawLoader$$.pipe(\n        switchMap(tuiRawLoadRecord),\n        map(value => this.processContent(value)),\n    );\n\n    readonly loading$ = new Subject<boolean>();\n\n    constructor(\n        @Inject(Clipboard) private readonly clipboard: Clipboard,\n        @Inject(TuiAlertService)\n        private readonly alertService: TuiAlertService,\n        @Inject(LOCATION) private readonly location: Location,\n        @Inject(TUI_COPY_TEXTS) private readonly copyTexts$: Observable<[string, string]>,\n        @Inject(TUI_DOC_EXAMPLE_TEXTS) readonly texts: [string, string, string],\n        @Optional()\n        @Inject(TUI_DOC_CODE_EDITOR)\n        readonly codeEditor: TuiCodeEditor | null,\n        @Inject(TUI_DOC_EXAMPLE_CONTENT_PROCESSOR)\n        private readonly processContent: TuiHandler<\n            Record<string, string>,\n            Record<string, string>\n        >,\n        @Inject(TUI_IS_CYPRESS) readonly isCypress: boolean,\n        @Inject(TUI_DOC_CODE_ACTIONS)\n        readonly codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>,\n        @Inject(Router) private readonly router: Router,\n        @Inject(ActivatedRoute) private readonly route: ActivatedRoute,\n        @Inject(NgLocation) private readonly ngLocation: NgLocation,\n        @Inject(TUI_DOC_EXAMPLE_OPTIONS) private readonly options: TuiDocExampleOptions,\n    ) {}\n\n    readonly visible = (files: Record<string, string>): boolean =>\n        Boolean(this.codeEditor && this.options.codeEditorVisibilityHandler(files));\n\n    copyExampleLink(): void {\n        const hashPosition = this.location.href.indexOf('#');\n        const currentUrl =\n            hashPosition > -1\n                ? this.location.href.slice(0, Math.max(0, hashPosition))\n                : this.location.href;\n        const url = `${currentUrl}#${this.id}`;\n\n        this.setFragmentWithoutRedirect(this.id);\n        this.clipboard.copy(url);\n        this.alertService\n            .open(this.texts[1], {\n                label: this.texts[2],\n                status: TuiNotification.Success,\n            })\n            .subscribe();\n    }\n\n    edit(files: Record<string, string>): void {\n        this.loading$.next(true);\n        this.codeEditor\n            ?.edit(this.componentName, this.id || '', files)\n            // TODO: replace lines below with `finally` when we bump Firefox to 58+\n            // TODO: Add `es2018.promise` to `tsconfig.json` => `compilerOptions.lib`.\n            .then(() => this.loading$.next(false))\n            .catch(() => this.loading$.next(false));\n    }\n\n    private setFragmentWithoutRedirect(id: string | null): void {\n        const url = this.router\n            .createUrlTree([], {relativeTo: this.route, fragment: id || ''})\n            .toString();\n\n        this.ngLocation.go(url);\n    }\n}\n","<h3\n    *ngIf=\"heading\"\n    class=\"t-title\"\n>\n    <span\n        *polymorpheusOutlet=\"heading | tuiDocExampleCapitalize as text\"\n        [textContent]=\"text\"\n    ></span>\n    <button\n        *ngIf=\"id\"\n        tuiIconButton\n        type=\"button\"\n        size=\"xs\"\n        icon=\"tuiIconLinkLarge\"\n        appearance=\"icon\"\n        class=\"t-link-icon\"\n        [title]=\"copy$ | async\"\n        (click)=\"copyExampleLink()\"\n    ></button>\n</h3>\n<h4\n    *ngIf=\"description\"\n    class=\"t-description\"\n>\n    <ng-container *polymorpheusOutlet=\"description | tuiDocExampleCapitalize as text\">\n        {{ text }}\n    </ng-container>\n</h4>\n\n<div\n    *ngIf=\"processor$ | async as files\"\n    class=\"t-example\"\n>\n    <ng-container *ngIf=\"files | tuiDocExampleGetTabs : defaultTab as tabs\">\n        <div class=\"t-tabs-wrapper\">\n            <tui-tabs-with-more\n                class=\"t-tabs\"\n                [(activeItemIndex)]=\"activeItemIndex\"\n            >\n                <ng-container *ngFor=\"let tab of tabs\">\n                    <button\n                        *tuiItem\n                        tuiTab\n                    >\n                        {{ tab }}\n                    </button>\n                </ng-container>\n            </tui-tabs-with-more>\n\n            <tui-loader\n                *ngIf=\"files | tuiMapper : visible\"\n                size=\"xs\"\n                [overlay]=\"true\"\n                [showLoader]=\"!!(loading$ | async)\"\n                (click)=\"edit(files)\"\n            >\n                <ng-container *ngIf=\"codeEditor?.content as content; else defaultEditContent\">\n                    <ng-container *polymorpheusOutlet=\"content as editContent\">\n                        {{ editContent }}\n                    </ng-container>\n                </ng-container>\n\n                <ng-template #defaultEditContent>\n                    <button\n                        tuiButton\n                        appearance=\"flat\"\n                        size=\"s\"\n                        type=\"button\"\n                    >\n                        Edit on {{ codeEditor!.name }}\n                    </button>\n                </ng-template>\n            </tui-loader>\n        </div>\n\n        <div\n            *ngFor=\"let tab of tabs; let index = index\"\n            class=\"t-content\"\n            [class.t-content_animated]=\"!isCypress\"\n            [class.t-content_visible]=\"activeItemIndex === index\"\n        >\n            <ng-container\n                *ngIf=\"index === defaultTabIndex; else anotherTab\"\n                [ngTemplateOutlet]=\"preview\"\n            ></ng-container>\n            <ng-template #anotherTab>\n                <ng-container\n                    [ngTemplateOutlet]=\"codeSection\"\n                    [ngTemplateOutletContext]=\"{$implicit: files[tabs[activeItemIndex]] || ''}\"\n                ></ng-container>\n            </ng-template>\n        </div>\n    </ng-container>\n</div>\n\n<ng-template #preview>\n    <div\n        automation-id=\"tui-doc-example\"\n        class=\"t-demo\"\n    >\n        <ng-content></ng-content>\n    </div>\n</ng-template>\n\n<ng-template\n    #codeSection\n    let-code\n>\n    <section class=\"t-code-actions\">\n        <ng-container *ngFor=\"let action of codeActions\">\n            <ng-container *polymorpheusOutlet=\"action as text; context: {$implicit: code}\">\n                {{ text }}\n            </ng-container>\n        </ng-container>\n        <tui-doc-copy [cdkCopyToClipboard]=\"code\"></tui-doc-copy>\n    </section>\n    <tui-doc-code [code]=\"code\"></tui-doc-code>\n</ng-template>\n"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"example.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/example/example.component.ts","../../../../../projects/addon-doc/src/components/example/example.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Clipboard} from '@angular/cdk/clipboard';\nimport {Location as NgLocation} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, Inject, Input, Optional} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {LOCATION} from '@ng-web-apis/common';\nimport {TUI_IS_CYPRESS, TuiContextWithImplicit, TuiHandler} from '@taiga-ui/cdk';\nimport {TuiAlertService, TuiNotification} from '@taiga-ui/core';\nimport {TUI_COPY_TEXTS} from '@taiga-ui/kit';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, Observable, Subject} from 'rxjs';\nimport {map, switchMap} from 'rxjs/operators';\n\nimport {TuiCodeEditor} from '../../interfaces/code-editor';\nimport {TuiDocExample} from '../../interfaces/page';\nimport {TUI_DOC_CODE_ACTIONS} from '../../tokens/code-actions';\nimport {TUI_DOC_CODE_EDITOR} from '../../tokens/code-editor';\nimport {TUI_DOC_EXAMPLE_CONTENT_PROCESSOR} from '../../tokens/example-content-processor';\nimport {TUI_DOC_EXAMPLE_TEXTS} from '../../tokens/i18n';\nimport {tuiRawLoadRecord} from '../../utils/raw-load-record';\nimport {TUI_DOC_EXAMPLE_OPTIONS, TuiDocExampleOptions} from './example-options';\n\n@Component({\n    selector: 'tui-doc-example',\n    templateUrl: './example.template.html',\n    styleUrls: ['./example.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiDocExampleComponent {\n    private readonly rawLoader$$ = new BehaviorSubject<TuiDocExample>({});\n\n    @Input()\n    id: string | null = null;\n\n    @Input()\n    heading: PolymorpheusContent = '';\n\n    @Input()\n    description: PolymorpheusContent = '';\n\n    @Input()\n    set content(content: TuiDocExample) {\n        this.rawLoader$$.next(content);\n    }\n\n    @Input()\n    componentName: string = this.location.pathname.slice(1);\n\n    readonly defaultTabIndex = 0;\n\n    readonly defaultTab = this.texts[this.defaultTabIndex];\n\n    activeItemIndex = this.defaultTabIndex;\n\n    readonly copy$ = this.copyTexts$.pipe(map(([copy]) => copy));\n\n    readonly processor$: Observable<Record<string, string>> = this.rawLoader$$.pipe(\n        switchMap(tuiRawLoadRecord),\n        map(value => this.processContent(value)),\n    );\n\n    readonly loading$ = new Subject<boolean>();\n\n    constructor(\n        @Inject(Clipboard) private readonly clipboard: Clipboard,\n        @Inject(TuiAlertService)\n        private readonly alerts: TuiAlertService,\n        @Inject(LOCATION) private readonly location: Location,\n        @Inject(TUI_COPY_TEXTS) private readonly copyTexts$: Observable<[string, string]>,\n        @Inject(TUI_DOC_EXAMPLE_TEXTS) readonly texts: [string, string, string],\n        @Optional()\n        @Inject(TUI_DOC_CODE_EDITOR)\n        readonly codeEditor: TuiCodeEditor | null,\n        @Inject(TUI_DOC_EXAMPLE_CONTENT_PROCESSOR)\n        private readonly processContent: TuiHandler<\n            Record<string, string>,\n            Record<string, string>\n        >,\n        @Inject(TUI_IS_CYPRESS) readonly isCypress: boolean,\n        @Inject(TUI_DOC_CODE_ACTIONS)\n        readonly codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>,\n        @Inject(Router) private readonly router: Router,\n        @Inject(ActivatedRoute) private readonly route: ActivatedRoute,\n        @Inject(NgLocation) private readonly ngLocation: NgLocation,\n        @Inject(TUI_DOC_EXAMPLE_OPTIONS) private readonly options: TuiDocExampleOptions,\n    ) {}\n\n    readonly visible = (files: Record<string, string>): boolean =>\n        Boolean(this.codeEditor && this.options.codeEditorVisibilityHandler(files));\n\n    copyExampleLink(): void {\n        const hashPosition = this.location.href.indexOf('#');\n        const currentUrl =\n            hashPosition > -1\n                ? this.location.href.slice(0, Math.max(0, hashPosition))\n                : this.location.href;\n        const url = `${currentUrl}#${this.id}`;\n\n        this.setFragmentWithoutRedirect(this.id);\n        this.clipboard.copy(url);\n        this.alerts\n            .open(this.texts[1], {\n                label: this.texts[2],\n                status: TuiNotification.Success,\n            })\n            .subscribe();\n    }\n\n    edit(files: Record<string, string>): void {\n        this.loading$.next(true);\n        this.codeEditor\n            ?.edit(this.componentName, this.id || '', files)\n            // TODO: replace lines below with `finally` when we bump Firefox to 58+\n            // TODO: Add `es2018.promise` to `tsconfig.json` => `compilerOptions.lib`.\n            .then(() => this.loading$.next(false))\n            .catch(() => this.loading$.next(false));\n    }\n\n    private setFragmentWithoutRedirect(id: string | null): void {\n        const url = this.router\n            .createUrlTree([], {relativeTo: this.route, fragment: id || ''})\n            .toString();\n\n        this.ngLocation.go(url);\n    }\n}\n","<h3\n    *ngIf=\"heading\"\n    class=\"t-title\"\n>\n    <span\n        *polymorpheusOutlet=\"heading | tuiDocExampleCapitalize as text\"\n        [textContent]=\"text\"\n    ></span>\n    <button\n        *ngIf=\"id\"\n        tuiIconButton\n        type=\"button\"\n        size=\"xs\"\n        icon=\"tuiIconLinkLarge\"\n        appearance=\"icon\"\n        class=\"t-link-icon\"\n        [title]=\"copy$ | async\"\n        (click)=\"copyExampleLink()\"\n    ></button>\n</h3>\n<h4\n    *ngIf=\"description\"\n    class=\"t-description\"\n>\n    <ng-container *polymorpheusOutlet=\"description | tuiDocExampleCapitalize as text\">\n        {{ text }}\n    </ng-container>\n</h4>\n\n<div\n    *ngIf=\"processor$ | async as files\"\n    class=\"t-example\"\n>\n    <ng-container *ngIf=\"files | tuiDocExampleGetTabs : defaultTab as tabs\">\n        <div class=\"t-tabs-wrapper\">\n            <tui-tabs-with-more\n                class=\"t-tabs\"\n                [(activeItemIndex)]=\"activeItemIndex\"\n            >\n                <ng-container *ngFor=\"let tab of tabs\">\n                    <button\n                        *tuiItem\n                        tuiTab\n                    >\n                        {{ tab }}\n                    </button>\n                </ng-container>\n            </tui-tabs-with-more>\n\n            <tui-loader\n                *ngIf=\"files | tuiMapper : visible\"\n                size=\"xs\"\n                [overlay]=\"true\"\n                [showLoader]=\"!!(loading$ | async)\"\n                (click)=\"edit(files)\"\n            >\n                <ng-container *ngIf=\"codeEditor?.content as content; else defaultEditContent\">\n                    <ng-container *polymorpheusOutlet=\"content as editContent\">\n                        {{ editContent }}\n                    </ng-container>\n                </ng-container>\n\n                <ng-template #defaultEditContent>\n                    <button\n                        tuiButton\n                        appearance=\"flat\"\n                        size=\"s\"\n                        type=\"button\"\n                    >\n                        Edit on {{ codeEditor!.name }}\n                    </button>\n                </ng-template>\n            </tui-loader>\n        </div>\n\n        <div\n            *ngFor=\"let tab of tabs; let index = index\"\n            class=\"t-content\"\n            [class.t-content_animated]=\"!isCypress\"\n            [class.t-content_visible]=\"activeItemIndex === index\"\n        >\n            <ng-container\n                *ngIf=\"index === defaultTabIndex; else anotherTab\"\n                [ngTemplateOutlet]=\"preview\"\n            ></ng-container>\n            <ng-template #anotherTab>\n                <ng-container\n                    [ngTemplateOutlet]=\"codeSection\"\n                    [ngTemplateOutletContext]=\"{$implicit: files[tabs[activeItemIndex]] || ''}\"\n                ></ng-container>\n            </ng-template>\n        </div>\n    </ng-container>\n</div>\n\n<ng-template #preview>\n    <div\n        automation-id=\"tui-doc-example\"\n        class=\"t-demo\"\n    >\n        <ng-content></ng-content>\n    </div>\n</ng-template>\n\n<ng-template\n    #codeSection\n    let-code\n>\n    <section class=\"t-code-actions\">\n        <ng-container *ngFor=\"let action of codeActions\">\n            <ng-container *polymorpheusOutlet=\"action as text; context: {$implicit: code}\">\n                {{ text }}\n            </ng-container>\n        </ng-container>\n        <tui-doc-copy [cdkCopyToClipboard]=\"code\"></tui-doc-copy>\n    </section>\n    <tui-doc-code [code]=\"code\"></tui-doc-code>\n</ng-template>\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, forwardRef, HostBinding, Inject, ViewEncapsulation, } from '@angular/core';
|
|
2
2
|
import { TuiSwipeService } from '@taiga-ui/cdk';
|
|
3
3
|
import { TuiModeDirective } from '@taiga-ui/core';
|
|
4
|
+
import { distinctUntilChanged, map, share, startWith } from 'rxjs/operators';
|
|
4
5
|
import { TuiThemeService } from '../../services/theme.service';
|
|
5
6
|
import { TuiThemeNightService } from '../../services/theme-night.service';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
@@ -12,13 +13,14 @@ import * as i5 from "@angular/router";
|
|
|
12
13
|
import * as i6 from "../../services/theme.service";
|
|
13
14
|
import * as i7 from "../../services/theme-night.service";
|
|
14
15
|
export class TuiDocMainComponent {
|
|
15
|
-
constructor(
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
18
|
-
this.change$ = this.
|
|
16
|
+
constructor(theme, night) {
|
|
17
|
+
this.theme = theme;
|
|
18
|
+
this.night = night;
|
|
19
|
+
this.change$ = this.night;
|
|
20
|
+
this.night$ = this.change$.pipe(startWith(null), map(() => this.night.value), distinctUntilChanged(), share());
|
|
19
21
|
}
|
|
20
22
|
get mode() {
|
|
21
|
-
return this.
|
|
23
|
+
return this.night.value ? 'onDark' : null;
|
|
22
24
|
}
|
|
23
25
|
}
|
|
24
26
|
TuiDocMainComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocMainComponent, deps: [{ token: TuiThemeService }, { token: TuiThemeNightService }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -28,7 +30,7 @@ TuiDocMainComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", ve
|
|
|
28
30
|
useExisting: forwardRef(() => TuiDocMainComponent),
|
|
29
31
|
},
|
|
30
32
|
TuiSwipeService,
|
|
31
|
-
], ngImport: i0, template: "<tui-theme-night *ngIf=\"
|
|
33
|
+
], ngImport: i0, template: "<tui-theme-night *ngIf=\"theme.isDefaultTheme && night.useDefaultNightTheme && (night$ | async)\"></tui-theme-night>\n<tui-root>\n <div class=\"tui-doc-page\">\n <tui-doc-navigation class=\"tui-doc-navigation\">\n <ng-content select=\"tuiDocNavigation\"></ng-content>\n </tui-doc-navigation>\n <div class=\"tui-doc-content\">\n <router-outlet class=\"tui-doc-outlet\"></router-outlet>\n </div>\n </div>\n <header tuiDocHeader>\n <ng-content select=\"tuiDocHeader\"></ng-content>\n <button\n tuiIconButton\n tuiMode=\"onLight\"\n appearance=\"secondary\"\n size=\"s\"\n shape=\"rounded\"\n type=\"button\"\n class=\"tui-doc-night-mode-switch\"\n [icon]=\"night.value ? 'tuiIconSunLarge' : 'tuiIconMoonLarge'\"\n (click)=\"night.toggle()\"\n ></button>\n </header>\n <ng-container ngProjectAs=\"tuiOverContent\">\n <ng-content select=\"tuiOverContent\"></ng-content>\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverDialogs\">\n <ng-content select=\"tuiOverDialogs\"></ng-content>\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverAlerts\">\n <ng-content select=\"tuiOverAlerts\"></ng-content>\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverPortals\">\n <ng-content select=\"tuiOverPortals\"></ng-content>\n </ng-container>\n <ng-container ngProjectAs=\"tuiOverHints\">\n <ng-content select=\"tuiOverHints\"></ng-content>\n </ng-container>\n</tui-root>\n", styles: ["html{scroll-padding-top:4rem;height:auto}tui-root>tui-scroll-controls>.t-bar_vertical{top:4rem!important}@keyframes tuiShaking{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-.3125rem)}20%,40%,60%,80%{transform:translate(.3125rem)}}body{background:var(--tui-base-01);height:auto}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;background:var(--tui-base-02);color:var(--tui-text-02);vertical-align:middle;box-shadow:inset 0 -2px var(--tui-secondary);padding:.375rem .5rem;font-size:.875rem;border-radius:.5rem}button:focus code,a:focus code{background:var(--tui-base-01)}.tui-doc-page{position:relative;z-index:0;padding-top:4rem}tui-doc-navigation.tui-doc-navigation{position:fixed;top:4rem;bottom:0;width:16.25rem;border-right:1px solid var(--tui-base-03)}@media screen and (max-width: 47.9625em){tui-doc-navigation.tui-doc-navigation{display:none}}.tui-doc-content{margin-left:16.25rem}@media screen and (max-width: 47.9625em){.tui-doc-content{margin-left:0}}.tui-doc-outlet+*{display:block}.tui-doc-animated-example{animation:1s .3s tuiShaking}.tui-doc-night-mode-switch{margin-left:1rem}.tui-doc-night-mode-switch tui-svg{color:var(--tui-text-02)}tui-doc-code .hljs-tag{background:none}tui-doc-code .hljs{display:block;overflow-x:auto;padding:.5em;color:var(--tui-text-01);background-color:var(--tui-clear)}tui-doc-code .hljs.hljs-line-numbers{background:transparent}tui-doc-code .hljs-subst,tui-doc-code .hljs-title{font-weight:normal;color:var(--tui-text-01)}tui-doc-code .hljs-comment,tui-doc-code .hljs-quote{color:var(--tui-text-03);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:bold;color:var(--tui-link)}tui-doc-code .hljs-attribute,tui-doc-code .hljs-number,tui-doc-code .hljs-regexp,tui-doc-code .hljs-link{font-weight:bold;color:var(--tui-support-06)}tui-doc-code .hljs-number,tui-doc-code .hljs-regexp,tui-doc-code .hljs-link{font-weight:normal}tui-doc-code .hljs-string{color:var(--tui-positive);font-weight:bold}tui-doc-code .hljs-symbol,tui-doc-code .hljs-bullet,tui-doc-code .hljs-formula{color:var(--tui-text-01);background:var(--tui-base-02);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-link-hover)}tui-doc-code [data-mode=onDark] .hljs-variable,tui-doc-code [data-mode=onDark] .hljs-template-variable{color:var(--tui-warning-fill)}tui-doc-code .hljs-addition{background:var(--tui-success-bg)}tui-doc-code .hljs-deletion{background:var(--tui-error-bg)}tui-doc-code .hljs-emphasis{font-style:italic}tui-doc-code .hljs-strong{font-weight:bold}tui-doc-code .hljs .hljs-line-numbers{padding:0}tui-doc-code .hljs-ln-numbers{vertical-align:top;opacity:.3;text-align:right;padding-right:1em!important}\n"], components: [{ type: i1.TuiThemeNightComponent, selector: "tui-theme-night" }, { type: i1.TuiRootComponent, selector: "tui-root" }, { type: i2.TuiDocNavigationComponent, selector: "tui-doc-navigation" }, { type: i3.TuiDocHeaderComponent, selector: "header[tuiDocHeader]" }, { type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.RouterOutlet, selector: "router-outlet", outputs: ["activate", "deactivate"], exportAs: ["outlet"] }, { type: i1.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }], pipes: { "async": i4.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
|
32
34
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocMainComponent, decorators: [{
|
|
33
35
|
type: Component,
|
|
34
36
|
args: [{
|
|
@@ -57,4 +59,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
57
59
|
type: HostBinding,
|
|
58
60
|
args: ['attr.data-mode']
|
|
59
61
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFpbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvbWFpbi9tYWluLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9tYWluL21haW4udGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLE1BQU0sRUFDTixpQkFBaUIsR0FDcEIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM5QyxPQUFPLEVBQWdCLGdCQUFnQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDL0QsT0FBTyxFQUFDLG9CQUFvQixFQUFFLEdBQUcsRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFM0UsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQzdELE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLG9DQUFvQyxDQUFDOzs7Ozs7Ozs7QUFrQnhFLE1BQU0sT0FBTyxtQkFBbUI7SUFVNUIsWUFDc0MsS0FBc0IsRUFDakIsS0FBMkI7UUFEaEMsVUFBSyxHQUFMLEtBQUssQ0FBaUI7UUFDakIsVUFBSyxHQUFMLEtBQUssQ0FBc0I7UUFYN0QsWUFBTyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUM7UUFFckIsV0FBTSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUMvQixTQUFTLENBQUMsSUFBSSxDQUFDLEVBQ2YsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLEVBQzNCLG9CQUFvQixFQUFFLEVBQ3RCLEtBQUssRUFBRSxDQUNWLENBQUM7SUFLQyxDQUFDO0lBRUosSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDOUMsQ0FBQzs7aUhBbEJRLG1CQUFtQixrQkFXaEIsZUFBZSxhQUNmLG9CQUFvQjtxR0FadkIsbUJBQW1CLGdHQVJqQjtRQUNQO1lBQ0ksT0FBTyxFQUFFLGdCQUFnQjtZQUN6QixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLG1CQUFtQixDQUFDO1NBQ3JEO1FBQ0QsZUFBZTtLQUNsQiwwQkM3Qkwsb2xEQXdDQTs0RkRUYSxtQkFBbUI7a0JBaEIvQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsc0JBQXNCO29CQUNuQyxTQUFTLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDaEMsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLDhFQUE4RTtvQkFDOUUscUZBQXFGO29CQUNyRixlQUFlLEVBQUUsdUJBQXVCLENBQUMsT0FBTztvQkFDaEQsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxnQkFBZ0I7NEJBQ3pCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLG9CQUFvQixDQUFDO3lCQUNyRDt3QkFDRCxlQUFlO3FCQUNsQjtpQkFDSjs7MEJBWVEsTUFBTTsyQkFBQyxlQUFlOzswQkFDdEIsTUFBTTsyQkFBQyxvQkFBb0I7NENBSTVCLElBQUk7c0JBRFAsV0FBVzt1QkFBQyxnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBmb3J3YXJkUmVmLFxuICAgIEhvc3RCaW5kaW5nLFxuICAgIEluamVjdCxcbiAgICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aVN3aXBlU2VydmljZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aUJyaWdodG5lc3MsIFR1aU1vZGVEaXJlY3RpdmV9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7ZGlzdGluY3RVbnRpbENoYW5nZWQsIG1hcCwgc2hhcmUsIHN0YXJ0V2l0aH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5pbXBvcnQge1R1aVRoZW1lU2VydmljZX0gZnJvbSAnLi4vLi4vc2VydmljZXMvdGhlbWUuc2VydmljZSc7XG5pbXBvcnQge1R1aVRoZW1lTmlnaHRTZXJ2aWNlfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy90aGVtZS1uaWdodC5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0dWktZG9jLW1haW4nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9tYWluLnRlbXBsYXRlLmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL21haW4uc3R5bGUubGVzcyddLFxuICAgIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXG4gICAgLy8gQG5vdGU6IFRoaXMgb25lIHdhcyBkZWZhdWx0IG9uIHB1cnBvc2Ugc28gd2UgY2FuIHRlc3QgZGVtbyBpbiBkZWZhdWx0IG1vZGUuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9wcmVmZXItb24tcHVzaC1jb21wb25lbnQtY2hhbmdlLWRldGVjdGlvblxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuRGVmYXVsdCxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogVHVpTW9kZURpcmVjdGl2ZSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IFR1aURvY01haW5Db21wb25lbnQpLFxuICAgICAgICB9LFxuICAgICAgICBUdWlTd2lwZVNlcnZpY2UsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRG9jTWFpbkNvbXBvbmVudCB7XG4gICAgcmVhZG9ubHkgY2hhbmdlJCA9IHRoaXMubmlnaHQ7XG5cbiAgICByZWFkb25seSBuaWdodCQgPSB0aGlzLmNoYW5nZSQucGlwZShcbiAgICAgICAgc3RhcnRXaXRoKG51bGwpLFxuICAgICAgICBtYXAoKCkgPT4gdGhpcy5uaWdodC52YWx1ZSksXG4gICAgICAgIGRpc3RpbmN0VW50aWxDaGFuZ2VkKCksXG4gICAgICAgIHNoYXJlKCksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KFR1aVRoZW1lU2VydmljZSkgcmVhZG9ubHkgdGhlbWU6IFR1aVRoZW1lU2VydmljZSxcbiAgICAgICAgQEluamVjdChUdWlUaGVtZU5pZ2h0U2VydmljZSkgcmVhZG9ubHkgbmlnaHQ6IFR1aVRoZW1lTmlnaHRTZXJ2aWNlLFxuICAgICkge31cblxuICAgIEBIb3N0QmluZGluZygnYXR0ci5kYXRhLW1vZGUnKVxuICAgIGdldCBtb2RlKCk6IFR1aUJyaWdodG5lc3MgfCBudWxsIHtcbiAgICAgICAgcmV0dXJuIHRoaXMubmlnaHQudmFsdWUgPyAnb25EYXJrJyA6IG51bGw7XG4gICAgfVxufVxuIiwiPHR1aS10aGVtZS1uaWdodCAqbmdJZj1cInRoZW1lLmlzRGVmYXVsdFRoZW1lICYmIG5pZ2h0LnVzZURlZmF1bHROaWdodFRoZW1lICYmIChuaWdodCQgfCBhc3luYylcIj48L3R1aS10aGVtZS1uaWdodD5cbjx0dWktcm9vdD5cbiAgICA8ZGl2IGNsYXNzPVwidHVpLWRvYy1wYWdlXCI+XG4gICAgICAgIDx0dWktZG9jLW5hdmlnYXRpb24gY2xhc3M9XCJ0dWktZG9jLW5hdmlnYXRpb25cIj5cbiAgICAgICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cInR1aURvY05hdmlnYXRpb25cIj48L25nLWNvbnRlbnQ+XG4gICAgICAgIDwvdHVpLWRvYy1uYXZpZ2F0aW9uPlxuICAgICAgICA8ZGl2IGNsYXNzPVwidHVpLWRvYy1jb250ZW50XCI+XG4gICAgICAgICAgICA8cm91dGVyLW91dGxldCBjbGFzcz1cInR1aS1kb2Mtb3V0bGV0XCI+PC9yb3V0ZXItb3V0bGV0PlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgICA8aGVhZGVyIHR1aURvY0hlYWRlcj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpRG9jSGVhZGVyXCI+PC9uZy1jb250ZW50PlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICB0dWlJY29uQnV0dG9uXG4gICAgICAgICAgICB0dWlNb2RlPVwib25MaWdodFwiXG4gICAgICAgICAgICBhcHBlYXJhbmNlPVwic2Vjb25kYXJ5XCJcbiAgICAgICAgICAgIHNpemU9XCJzXCJcbiAgICAgICAgICAgIHNoYXBlPVwicm91bmRlZFwiXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIGNsYXNzPVwidHVpLWRvYy1uaWdodC1tb2RlLXN3aXRjaFwiXG4gICAgICAgICAgICBbaWNvbl09XCJuaWdodC52YWx1ZSA/ICd0dWlJY29uU3VuTGFyZ2UnIDogJ3R1aUljb25Nb29uTGFyZ2UnXCJcbiAgICAgICAgICAgIChjbGljayk9XCJuaWdodC50b2dnbGUoKVwiXG4gICAgICAgID48L2J1dHRvbj5cbiAgICA8L2hlYWRlcj5cbiAgICA8bmctY29udGFpbmVyIG5nUHJvamVjdEFzPVwidHVpT3ZlckNvbnRlbnRcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpT3ZlckNvbnRlbnRcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9uZy1jb250YWluZXI+XG4gICAgPG5nLWNvbnRhaW5lciBuZ1Byb2plY3RBcz1cInR1aU92ZXJEaWFsb2dzXCI+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cInR1aU92ZXJEaWFsb2dzXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgbmdQcm9qZWN0QXM9XCJ0dWlPdmVyQWxlcnRzXCI+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cInR1aU92ZXJBbGVydHNcIj48L25nLWNvbnRlbnQ+XG4gICAgPC9uZy1jb250YWluZXI+XG4gICAgPG5nLWNvbnRhaW5lciBuZ1Byb2plY3RBcz1cInR1aU92ZXJQb3J0YWxzXCI+XG4gICAgICAgIDxuZy1jb250ZW50IHNlbGVjdD1cInR1aU92ZXJQb3J0YWxzXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbmctY29udGFpbmVyPlxuICAgIDxuZy1jb250YWluZXIgbmdQcm9qZWN0QXM9XCJ0dWlPdmVySGludHNcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpT3ZlckhpbnRzXCI+PC9uZy1jb250ZW50PlxuICAgIDwvbmctY29udGFpbmVyPlxuPC90dWktcm9vdD5cbiJdfQ==
|