@taiga-ui/addon-doc 3.61.0 → 3.63.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-addon-doc-components.umd.js +11 -34
- package/bundles/taiga-ui-addon-doc-components.umd.js.map +1 -1
- package/components/example/example.component.d.ts +3 -9
- package/components/example/example.module.d.ts +2 -1
- package/esm2015/components/example/example.component.js +14 -43
- package/esm2015/components/example/example.module.js +6 -2
- package/fesm2015/taiga-ui-addon-doc-components.js +10 -34
- package/fesm2015/taiga-ui-addon-doc-components.js.map +1 -1
- package/package.json +5 -5
|
@@ -1,6 +1,4 @@
|
|
|
1
1
|
import { Clipboard } from '@angular/cdk/clipboard';
|
|
2
|
-
import { Location as NgLocation } from '@angular/common';
|
|
3
|
-
import { ActivatedRoute, Router } from '@angular/router';
|
|
4
2
|
import { TuiCodeEditor, TuiDocExample } from '@taiga-ui/addon-doc/interfaces';
|
|
5
3
|
import { TuiContextWithImplicit, TuiHandler } from '@taiga-ui/cdk';
|
|
6
4
|
import { TuiAlertService } from '@taiga-ui/core';
|
|
@@ -18,9 +16,6 @@ export declare class TuiDocExampleComponent {
|
|
|
18
16
|
private readonly processContent;
|
|
19
17
|
readonly isE2E: boolean;
|
|
20
18
|
readonly codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>;
|
|
21
|
-
private readonly router;
|
|
22
|
-
private readonly route;
|
|
23
|
-
private readonly ngLocation;
|
|
24
19
|
readonly options: TuiDocExampleOptions;
|
|
25
20
|
private readonly rawLoader$$;
|
|
26
21
|
id: string | null;
|
|
@@ -35,12 +30,11 @@ export declare class TuiDocExampleComponent {
|
|
|
35
30
|
readonly copy$: Observable<string>;
|
|
36
31
|
readonly processor$: Observable<Record<string, string>>;
|
|
37
32
|
readonly loading$: Subject<boolean>;
|
|
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>>, isE2E: boolean, codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>,
|
|
33
|
+
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>>, isE2E: boolean, codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>, options: TuiDocExampleOptions);
|
|
39
34
|
readonly visible: (files: Record<string, string>) => boolean;
|
|
40
35
|
getTabTitle(fileName: string): PolymorpheusContent;
|
|
41
|
-
copyExampleLink(): void;
|
|
36
|
+
copyExampleLink({ href }: HTMLAnchorElement): void;
|
|
42
37
|
edit(files: Record<string, string>): void;
|
|
43
|
-
|
|
44
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocExampleComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null, null, null, null]>;
|
|
38
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocExampleComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null]>;
|
|
45
39
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocExampleComponent, "tui-doc-example", never, { "id": "id"; "heading": "heading"; "description": "description"; "content": "content"; "fullsize": "fullsize"; "componentName": "componentName"; }, {}, never, ["*"]>;
|
|
46
40
|
}
|
|
@@ -9,8 +9,9 @@ import * as i7 from "../copy/copy.module";
|
|
|
9
9
|
import * as i8 from "../code/code.module";
|
|
10
10
|
import * as i9 from "@tinkoff/ng-polymorpheus";
|
|
11
11
|
import * as i10 from "@taiga-ui/cdk";
|
|
12
|
+
import * as i11 from "@angular/router";
|
|
12
13
|
export declare class TuiDocExampleModule {
|
|
13
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocExampleModule, never>;
|
|
14
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiDocExampleModule, [typeof i1.TuiDocExampleComponent, typeof i2.TuiDocExampleGetTabsPipe], [typeof i3.CommonModule, typeof i4.ClipboardModule, typeof i5.TuiTabsModule, typeof i6.TuiButtonModule, typeof i7.TuiDocCopyModule, typeof i8.TuiDocCodeModule, typeof i9.PolymorpheusModule, typeof i10.TuiMapperPipeModule, typeof i6.TuiLoaderModule], [typeof i1.TuiDocExampleComponent, typeof i2.TuiDocExampleGetTabsPipe]>;
|
|
15
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiDocExampleModule, [typeof i1.TuiDocExampleComponent, typeof i2.TuiDocExampleGetTabsPipe], [typeof i3.CommonModule, typeof i4.ClipboardModule, typeof i5.TuiTabsModule, typeof i6.TuiButtonModule, typeof i7.TuiDocCopyModule, typeof i8.TuiDocCodeModule, typeof i9.PolymorpheusModule, typeof i10.TuiMapperPipeModule, typeof i6.TuiLoaderModule, typeof i11.RouterModule], [typeof i1.TuiDocExampleComponent, typeof i2.TuiDocExampleGetTabsPipe]>;
|
|
15
16
|
static ɵinj: i0.ɵɵInjectorDeclaration<TuiDocExampleModule>;
|
|
16
17
|
}
|
|
@@ -1,7 +1,5 @@
|
|
|
1
1
|
import { Clipboard } from '@angular/cdk/clipboard';
|
|
2
|
-
import { Location as NgLocation } from '@angular/common';
|
|
3
2
|
import { ChangeDetectionStrategy, Component, HostBinding, Inject, Input, Optional, } from '@angular/core';
|
|
4
|
-
import { ActivatedRoute, Router } from '@angular/router';
|
|
5
3
|
import { LOCATION } from '@ng-web-apis/common';
|
|
6
4
|
import { TUI_DOC_CODE_ACTIONS, TUI_DOC_CODE_EDITOR, TUI_DOC_EXAMPLE_CONTENT_PROCESSOR, TUI_DOC_EXAMPLE_TEXTS, } from '@taiga-ui/addon-doc/tokens';
|
|
7
5
|
import { tuiRawLoadRecord } from '@taiga-ui/addon-doc/utils';
|
|
@@ -17,13 +15,13 @@ import * as i2 from "@taiga-ui/kit";
|
|
|
17
15
|
import * as i3 from "../code/code.component";
|
|
18
16
|
import * as i4 from "@angular/common";
|
|
19
17
|
import * as i5 from "@tinkoff/ng-polymorpheus";
|
|
20
|
-
import * as i6 from "@
|
|
21
|
-
import * as i7 from "
|
|
22
|
-
import * as i8 from "
|
|
23
|
-
import * as i9 from "
|
|
24
|
-
import * as i10 from "
|
|
18
|
+
import * as i6 from "@angular/router";
|
|
19
|
+
import * as i7 from "@taiga-ui/cdk";
|
|
20
|
+
import * as i8 from "./example-get-tabs.pipe";
|
|
21
|
+
import * as i9 from "@angular/cdk/clipboard";
|
|
22
|
+
import * as i10 from "rxjs";
|
|
25
23
|
export class TuiDocExampleComponent {
|
|
26
|
-
constructor(clipboard, alerts, location, copyTexts$, texts, codeEditor, processContent, isE2E, codeActions,
|
|
24
|
+
constructor(clipboard, alerts, location, copyTexts$, texts, codeEditor, processContent, isE2E, codeActions, options) {
|
|
27
25
|
this.clipboard = clipboard;
|
|
28
26
|
this.alerts = alerts;
|
|
29
27
|
this.location = location;
|
|
@@ -33,9 +31,6 @@ export class TuiDocExampleComponent {
|
|
|
33
31
|
this.processContent = processContent;
|
|
34
32
|
this.isE2E = isE2E;
|
|
35
33
|
this.codeActions = codeActions;
|
|
36
|
-
this.router = router;
|
|
37
|
-
this.route = route;
|
|
38
|
-
this.ngLocation = ngLocation;
|
|
39
34
|
this.options = options;
|
|
40
35
|
this.rawLoader$$ = new BehaviorSubject({});
|
|
41
36
|
this.id = null;
|
|
@@ -55,19 +50,10 @@ export class TuiDocExampleComponent {
|
|
|
55
50
|
getTabTitle(fileName) {
|
|
56
51
|
return this.options.tabTitles.get(fileName) || fileName;
|
|
57
52
|
}
|
|
58
|
-
copyExampleLink() {
|
|
59
|
-
|
|
60
|
-
const currentUrl = hashPosition > -1
|
|
61
|
-
? this.location.href.slice(0, Math.max(0, hashPosition))
|
|
62
|
-
: this.location.href;
|
|
63
|
-
const url = `${currentUrl}#${this.id}`;
|
|
64
|
-
this.setFragmentWithoutRedirect(this.id);
|
|
65
|
-
this.clipboard.copy(url);
|
|
53
|
+
copyExampleLink({ href }) {
|
|
54
|
+
this.clipboard.copy(href);
|
|
66
55
|
this.alerts
|
|
67
|
-
.open(this.texts[1], {
|
|
68
|
-
label: this.texts[2],
|
|
69
|
-
status: 'success',
|
|
70
|
-
})
|
|
56
|
+
.open(this.texts[1], { label: this.texts[2], status: 'success' })
|
|
71
57
|
.subscribe();
|
|
72
58
|
}
|
|
73
59
|
edit(files) {
|
|
@@ -75,15 +61,9 @@ export class TuiDocExampleComponent {
|
|
|
75
61
|
this.loading$.next(true);
|
|
76
62
|
(_a = this.codeEditor) === null || _a === void 0 ? void 0 : _a.edit(this.componentName, this.id || '', files).then(() => this.loading$.next(false)).catch(() => this.loading$.next(false));
|
|
77
63
|
}
|
|
78
|
-
setFragmentWithoutRedirect(id) {
|
|
79
|
-
const url = this.router
|
|
80
|
-
.createUrlTree([], { relativeTo: this.route, fragment: id || '' })
|
|
81
|
-
.toString();
|
|
82
|
-
this.ngLocation.go(url);
|
|
83
|
-
}
|
|
84
64
|
}
|
|
85
|
-
TuiDocExampleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, deps: [{ token: Clipboard }, { token: TuiAlertService }, { token: LOCATION }, { token: TUI_COPY_TEXTS }, { token: TUI_DOC_EXAMPLE_TEXTS }, { token: TUI_DOC_CODE_EDITOR, optional: true }, { token: TUI_DOC_EXAMPLE_CONTENT_PROCESSOR }, { token: TUI_IS_E2E }, { token: TUI_DOC_CODE_ACTIONS }, { token:
|
|
86
|
-
TuiDocExampleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocExampleComponent, selector: "tui-doc-example", inputs: { id: "id", heading: "heading", description: "description", content: "content", fullsize: "fullsize", componentName: "componentName" }, host: { properties: { "class._fullsize": "this.fullsize" } }, ngImport: i0, template: "<h3\n *ngIf=\"heading\"\n class=\"t-title\"\n>\n <span\n *polymorpheusOutlet=\"heading as text\"\n [textContent]=\"text\"\n ></span>\n <
|
|
65
|
+
TuiDocExampleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, deps: [{ token: Clipboard }, { token: TuiAlertService }, { token: LOCATION }, { token: TUI_COPY_TEXTS }, { token: TUI_DOC_EXAMPLE_TEXTS }, { token: TUI_DOC_CODE_EDITOR, optional: true }, { token: TUI_DOC_EXAMPLE_CONTENT_PROCESSOR }, { token: TUI_IS_E2E }, { token: TUI_DOC_CODE_ACTIONS }, { token: TUI_DOC_EXAMPLE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
66
|
+
TuiDocExampleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocExampleComponent, selector: "tui-doc-example", inputs: { id: "id", heading: "heading", description: "description", content: "content", fullsize: "fullsize", componentName: "componentName" }, host: { properties: { "class._fullsize": "this.fullsize" } }, ngImport: i0, template: "<h3\n *ngIf=\"heading\"\n class=\"t-title\"\n>\n <span\n *polymorpheusOutlet=\"heading as text\"\n [textContent]=\"text\"\n ></span>\n <a\n *ngIf=\"id\"\n appearance=\"icon\"\n routerLink=\".\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-link-icon\"\n [fragment]=\"id\"\n [icon]=\"options.linkIcon\"\n [title]=\"copy$ | async\"\n (click)=\"copyExampleLink($any($event.currentTarget))\"\n ></a>\n</h3>\n<h4\n *ngIf=\"description\"\n class=\"t-description\"\n>\n <ng-container *polymorpheusOutlet=\"description 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\n *ngIf=\"tabs.length > 1\"\n class=\"t-tabs-wrapper\"\n >\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 <ng-container *polymorpheusOutlet=\"getTabTitle(tab) as text\">\n {{ text }}\n </ng-container>\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 appearance=\"flat\"\n size=\"s\"\n tuiButton\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]=\"!isE2E\"\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 <tui-doc-code [code]=\"code\">\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-code>\n</ng-template>\n", styles: [":host{position:relative;display:block;padding-top:3.5rem;clear:right}:host:target{animation:1s .3s tuiShaking}:host :host-context(tui-root._mobile){padding-top:2rem}.t-title{font:var(--tui-font-heading-5);margin:0 0 .5rem}:host-context(tui-root._mobile) .t-title{font:var(--tui-font-heading-6)}.t-description{font:var(--tui-font-text-m);font-weight:normal;margin:0}.t-title:first-letter,.t-description:first-letter{text-transform:capitalize}.t-example{position:relative;margin-top:1.5rem;border:1px solid var(--tui-base-03);border-radius:var(--tui-radius-m);box-shadow:0 .125rem .1875rem #0000001a;overflow:hidden}:host-context(tui-root._mobile) .t-example{margin-top:.75rem}.t-tabs-wrapper{display:flex;padding:0 .875rem 0 2rem;box-shadow:inset 0 -1px var(--tui-base-03);justify-content:space-between;align-items:center}:host-context(tui-root._mobile) .t-tabs-wrapper{padding:0 .875rem 0 1rem}.t-tabs{flex-grow:1}.t-demo{padding:2rem;max-width:100%;box-sizing:border-box;overflow-x:auto}@media all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.t-demo::-webkit-scrollbar,.t-demo::-webkit-scrollbar-thumb{width:1rem;height:1rem;border-radius:6.25rem;background-clip:padding-box;border:.375rem solid transparent}.t-demo::-webkit-scrollbar{background-color:transparent}.t-demo::-webkit-scrollbar-thumb{background-color:var(--tui-clear-hover)}.t-demo::-webkit-scrollbar-thumb:hover{background-color:var(--tui-clear-active)}.t-demo::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-03)}}:host-context(tui-root._mobile) .t-demo{padding:1rem}:host:not(._fullsize) .t-demo{width:-webkit-min-content;width:min-content;min-width:20rem}.t-link-icon{margin-left:.3rem;vertical-align:baseline}.t-content{will-change:opacity;height:0;visibility:hidden;opacity:0}.t-content_animated{transition:opacity .3s ease-in-out}.t-content_visible{height:auto;visibility:visible;opacity:1}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i2.TuiTabsWithMoreComponent, selector: "tui-tabs-with-more, nav[tuiTabsWithMore]", inputs: ["moreContent", "dropdownContent", "underline", "activeItemIndex", "itemsLimit"], outputs: ["activeItemIndexChange"] }, { type: i2.TuiTabComponent, selector: "a[tuiTab]:not([routerLink]), a[tuiTab][routerLink][routerLinkActive], button[tuiTab]" }, { type: i1.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { type: i3.TuiDocCodeComponent, selector: "tui-doc-code", inputs: ["filename", "code"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i6.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.TuiItemDirective, selector: "[tuiItem]" }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i4.AsyncPipe, "tuiDocExampleGetTabs": i8.TuiDocExampleGetTabsPipe, "tuiMapper": i7.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
87
67
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, decorators: [{
|
|
88
68
|
type: Component,
|
|
89
69
|
args: [{
|
|
@@ -92,7 +72,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
92
72
|
styleUrls: ['./example.style.less'],
|
|
93
73
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
94
74
|
}]
|
|
95
|
-
}], ctorParameters: function () { return [{ type:
|
|
75
|
+
}], ctorParameters: function () { return [{ type: i9.Clipboard, decorators: [{
|
|
96
76
|
type: Inject,
|
|
97
77
|
args: [Clipboard]
|
|
98
78
|
}] }, { type: i1.TuiAlertService, decorators: [{
|
|
@@ -101,7 +81,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
101
81
|
}] }, { type: Location, decorators: [{
|
|
102
82
|
type: Inject,
|
|
103
83
|
args: [LOCATION]
|
|
104
|
-
}] }, { type:
|
|
84
|
+
}] }, { type: i10.Observable, decorators: [{
|
|
105
85
|
type: Inject,
|
|
106
86
|
args: [TUI_COPY_TEXTS]
|
|
107
87
|
}] }, { type: undefined, decorators: [{
|
|
@@ -121,15 +101,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
121
101
|
}] }, { type: Array, decorators: [{
|
|
122
102
|
type: Inject,
|
|
123
103
|
args: [TUI_DOC_CODE_ACTIONS]
|
|
124
|
-
}] }, { type: i10.Router, decorators: [{
|
|
125
|
-
type: Inject,
|
|
126
|
-
args: [Router]
|
|
127
|
-
}] }, { type: i10.ActivatedRoute, decorators: [{
|
|
128
|
-
type: Inject,
|
|
129
|
-
args: [ActivatedRoute]
|
|
130
|
-
}] }, { type: i4.Location, decorators: [{
|
|
131
|
-
type: Inject,
|
|
132
|
-
args: [NgLocation]
|
|
133
104
|
}] }, { type: undefined, decorators: [{
|
|
134
105
|
type: Inject,
|
|
135
106
|
args: [TUI_DOC_EXAMPLE_OPTIONS]
|
|
@@ -149,4 +120,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
149
120
|
}], componentName: [{
|
|
150
121
|
type: Input
|
|
151
122
|
}] } });
|
|
152
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"example.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/example/example.component.ts","../../../../../projects/addon-doc/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 {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {ActivatedRoute, Router} from '@angular/router';\nimport {LOCATION} from '@ng-web-apis/common';\nimport {TuiCodeEditor, TuiDocExample} from '@taiga-ui/addon-doc/interfaces';\nimport {\n    TUI_DOC_CODE_ACTIONS,\n    TUI_DOC_CODE_EDITOR,\n    TUI_DOC_EXAMPLE_CONTENT_PROCESSOR,\n    TUI_DOC_EXAMPLE_TEXTS,\n} from '@taiga-ui/addon-doc/tokens';\nimport {tuiRawLoadRecord} from '@taiga-ui/addon-doc/utils';\nimport {TUI_IS_E2E, TuiContextWithImplicit, TuiHandler} from '@taiga-ui/cdk';\nimport {TuiAlertService} 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 {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    @HostBinding('class._fullsize')\n    fullsize = this.options.fullsize;\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_E2E) readonly isE2E: 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) readonly options: TuiDocExampleOptions,\n    ) {}\n\n    readonly visible = (files: Record<string, string>): boolean =>\n        Boolean(this.codeEditor && this.options.codeEditorVisibilityHandler(files));\n\n    getTabTitle(fileName: string): PolymorpheusContent {\n        return this.options.tabTitles.get(fileName) || fileName;\n    }\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: '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 as text\"\n        [textContent]=\"text\"\n    ></span>\n    <button\n        *ngIf=\"id\"\n        appearance=\"icon\"\n        size=\"xs\"\n        tuiIconButton\n        type=\"button\"\n        class=\"t-link-icon\"\n        [icon]=\"options.linkIcon\"\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 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\n            *ngIf=\"tabs.length > 1\"\n            class=\"t-tabs-wrapper\"\n        >\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                        <ng-container *polymorpheusOutlet=\"getTabTitle(tab) as text\">\n                            {{ text }}\n                        </ng-container>\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                        appearance=\"flat\"\n                        size=\"s\"\n                        tuiButton\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]=\"!isE2E\"\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    <tui-doc-code [code]=\"code\">\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-code>\n</ng-template>\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"example.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/example/example.component.ts","../../../../../projects/addon-doc/components/example/example.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Clipboard} from '@angular/cdk/clipboard';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Inject,\n    Input,\n    Optional,\n} from '@angular/core';\nimport {LOCATION} from '@ng-web-apis/common';\nimport {TuiCodeEditor, TuiDocExample} from '@taiga-ui/addon-doc/interfaces';\nimport {\n    TUI_DOC_CODE_ACTIONS,\n    TUI_DOC_CODE_EDITOR,\n    TUI_DOC_EXAMPLE_CONTENT_PROCESSOR,\n    TUI_DOC_EXAMPLE_TEXTS,\n} from '@taiga-ui/addon-doc/tokens';\nimport {tuiRawLoadRecord} from '@taiga-ui/addon-doc/utils';\nimport {TUI_IS_E2E, TuiContextWithImplicit, TuiHandler} from '@taiga-ui/cdk';\nimport {TuiAlertService} 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 {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    @HostBinding('class._fullsize')\n    fullsize = this.options.fullsize;\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_E2E) readonly isE2E: boolean,\n        @Inject(TUI_DOC_CODE_ACTIONS)\n        readonly codeActions: Array<PolymorpheusContent<TuiContextWithImplicit<string>>>,\n        @Inject(TUI_DOC_EXAMPLE_OPTIONS) readonly options: TuiDocExampleOptions,\n    ) {}\n\n    readonly visible = (files: Record<string, string>): boolean =>\n        Boolean(this.codeEditor && this.options.codeEditorVisibilityHandler(files));\n\n    getTabTitle(fileName: string): PolymorpheusContent {\n        return this.options.tabTitles.get(fileName) || fileName;\n    }\n\n    copyExampleLink({href}: HTMLAnchorElement): void {\n        this.clipboard.copy(href);\n        this.alerts\n            .open(this.texts[1], {label: this.texts[2], status: 'success'})\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","<h3\n    *ngIf=\"heading\"\n    class=\"t-title\"\n>\n    <span\n        *polymorpheusOutlet=\"heading as text\"\n        [textContent]=\"text\"\n    ></span>\n    <a\n        *ngIf=\"id\"\n        appearance=\"icon\"\n        routerLink=\".\"\n        size=\"xs\"\n        tuiIconButton\n        type=\"button\"\n        class=\"t-link-icon\"\n        [fragment]=\"id\"\n        [icon]=\"options.linkIcon\"\n        [title]=\"copy$ | async\"\n        (click)=\"copyExampleLink($any($event.currentTarget))\"\n    ></a>\n</h3>\n<h4\n    *ngIf=\"description\"\n    class=\"t-description\"\n>\n    <ng-container *polymorpheusOutlet=\"description 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\n            *ngIf=\"tabs.length > 1\"\n            class=\"t-tabs-wrapper\"\n        >\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                        <ng-container *polymorpheusOutlet=\"getTabTitle(tab) as text\">\n                            {{ text }}\n                        </ng-container>\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                        appearance=\"flat\"\n                        size=\"s\"\n                        tuiButton\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]=\"!isE2E\"\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    <tui-doc-code [code]=\"code\">\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-code>\n</ng-template>\n"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { ClipboardModule } from '@angular/cdk/clipboard';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { NgModule } from '@angular/core';
|
|
4
|
+
import { RouterModule } from '@angular/router';
|
|
4
5
|
import { TuiMapperPipeModule } from '@taiga-ui/cdk';
|
|
5
6
|
import { TuiButtonModule, TuiLoaderModule } from '@taiga-ui/core';
|
|
6
7
|
import { TuiTabsModule } from '@taiga-ui/kit';
|
|
@@ -21,7 +22,8 @@ TuiDocExampleModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", ver
|
|
|
21
22
|
TuiDocCodeModule,
|
|
22
23
|
PolymorpheusModule,
|
|
23
24
|
TuiMapperPipeModule,
|
|
24
|
-
TuiLoaderModule
|
|
25
|
+
TuiLoaderModule,
|
|
26
|
+
RouterModule], exports: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe] });
|
|
25
27
|
TuiDocExampleModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleModule, imports: [[
|
|
26
28
|
CommonModule,
|
|
27
29
|
ClipboardModule,
|
|
@@ -32,6 +34,7 @@ TuiDocExampleModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver
|
|
|
32
34
|
PolymorpheusModule,
|
|
33
35
|
TuiMapperPipeModule,
|
|
34
36
|
TuiLoaderModule,
|
|
37
|
+
RouterModule,
|
|
35
38
|
]] });
|
|
36
39
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleModule, decorators: [{
|
|
37
40
|
type: NgModule,
|
|
@@ -46,9 +49,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
46
49
|
PolymorpheusModule,
|
|
47
50
|
TuiMapperPipeModule,
|
|
48
51
|
TuiLoaderModule,
|
|
52
|
+
RouterModule,
|
|
49
53
|
],
|
|
50
54
|
declarations: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe],
|
|
51
55
|
exports: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe],
|
|
52
56
|
}]
|
|
53
57
|
}] });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9leGFtcGxlL2V4YW1wbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBQyxlQUFlLEVBQUUsZUFBZSxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEUsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1QyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUU1RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUNyRCxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxxQkFBcUIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQzs7QUFrQmpFLE1BQU0sT0FBTyxtQkFBbUI7O2lIQUFuQixtQkFBbUI7a0hBQW5CLG1CQUFtQixpQkFIYixzQkFBc0IsRUFBRSx3QkFBd0IsYUFYM0QsWUFBWTtRQUNaLGVBQWU7UUFDZixhQUFhO1FBQ2IsZUFBZTtRQUNmLGdCQUFnQjtRQUNoQixnQkFBZ0I7UUFDaEIsa0JBQWtCO1FBQ2xCLG1CQUFtQjtRQUNuQixlQUFlO1FBQ2YsWUFBWSxhQUdOLHNCQUFzQixFQUFFLHdCQUF3QjtrSEFFakQsbUJBQW1CLFlBZm5CO1lBQ0wsWUFBWTtZQUNaLGVBQWU7WUFDZixhQUFhO1lBQ2IsZUFBZTtZQUNmLGdCQUFnQjtZQUNoQixnQkFBZ0I7WUFDaEIsa0JBQWtCO1lBQ2xCLG1CQUFtQjtZQUNuQixlQUFlO1lBQ2YsWUFBWTtTQUNmOzRGQUlRLG1CQUFtQjtrQkFoQi9CLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osZUFBZTt3QkFDZixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZ0JBQWdCO3dCQUNoQixnQkFBZ0I7d0JBQ2hCLGtCQUFrQjt3QkFDbEIsbUJBQW1CO3dCQUNuQixlQUFlO3dCQUNmLFlBQVk7cUJBQ2Y7b0JBQ0QsWUFBWSxFQUFFLENBQUMsc0JBQXNCLEVBQUUsd0JBQXdCLENBQUM7b0JBQ2hFLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixFQUFFLHdCQUF3QixDQUFDO2lCQUM5RCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2xpcGJvYXJkTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jZGsvY2xpcGJvYXJkJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1JvdXRlck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7VHVpTWFwcGVyUGlwZU1vZHVsZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aUJ1dHRvbk1vZHVsZSwgVHVpTG9hZGVyTW9kdWxlfSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQge1R1aVRhYnNNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9raXQnO1xuaW1wb3J0IHtQb2x5bW9ycGhldXNNb2R1bGV9IGZyb20gJ0B0aW5rb2ZmL25nLXBvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpRG9jQ29kZU1vZHVsZX0gZnJvbSAnLi4vY29kZS9jb2RlLm1vZHVsZSc7XG5pbXBvcnQge1R1aURvY0NvcHlNb2R1bGV9IGZyb20gJy4uL2NvcHkvY29weS5tb2R1bGUnO1xuaW1wb3J0IHtUdWlEb2NFeGFtcGxlQ29tcG9uZW50fSBmcm9tICcuL2V4YW1wbGUuY29tcG9uZW50JztcbmltcG9ydCB7VHVpRG9jRXhhbXBsZUdldFRhYnNQaXBlfSBmcm9tICcuL2V4YW1wbGUtZ2V0LXRhYnMucGlwZSc7XG5cbkBOZ01vZHVsZSh7XG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIENsaXBib2FyZE1vZHVsZSxcbiAgICAgICAgVHVpVGFic01vZHVsZSxcbiAgICAgICAgVHVpQnV0dG9uTW9kdWxlLFxuICAgICAgICBUdWlEb2NDb3B5TW9kdWxlLFxuICAgICAgICBUdWlEb2NDb2RlTW9kdWxlLFxuICAgICAgICBQb2x5bW9ycGhldXNNb2R1bGUsXG4gICAgICAgIFR1aU1hcHBlclBpcGVNb2R1bGUsXG4gICAgICAgIFR1aUxvYWRlck1vZHVsZSxcbiAgICAgICAgUm91dGVyTW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbVHVpRG9jRXhhbXBsZUNvbXBvbmVudCwgVHVpRG9jRXhhbXBsZUdldFRhYnNQaXBlXSxcbiAgICBleHBvcnRzOiBbVHVpRG9jRXhhbXBsZUNvbXBvbmVudCwgVHVpRG9jRXhhbXBsZUdldFRhYnNQaXBlXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRG9jRXhhbXBsZU1vZHVsZSB7fVxuIl19
|
|
@@ -969,7 +969,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
969
969
|
}] });
|
|
970
970
|
|
|
971
971
|
class TuiDocExampleComponent {
|
|
972
|
-
constructor(clipboard, alerts, location, copyTexts$, texts, codeEditor, processContent, isE2E, codeActions,
|
|
972
|
+
constructor(clipboard, alerts, location, copyTexts$, texts, codeEditor, processContent, isE2E, codeActions, options) {
|
|
973
973
|
this.clipboard = clipboard;
|
|
974
974
|
this.alerts = alerts;
|
|
975
975
|
this.location = location;
|
|
@@ -979,9 +979,6 @@ class TuiDocExampleComponent {
|
|
|
979
979
|
this.processContent = processContent;
|
|
980
980
|
this.isE2E = isE2E;
|
|
981
981
|
this.codeActions = codeActions;
|
|
982
|
-
this.router = router;
|
|
983
|
-
this.route = route;
|
|
984
|
-
this.ngLocation = ngLocation;
|
|
985
982
|
this.options = options;
|
|
986
983
|
this.rawLoader$$ = new BehaviorSubject({});
|
|
987
984
|
this.id = null;
|
|
@@ -1001,19 +998,10 @@ class TuiDocExampleComponent {
|
|
|
1001
998
|
getTabTitle(fileName) {
|
|
1002
999
|
return this.options.tabTitles.get(fileName) || fileName;
|
|
1003
1000
|
}
|
|
1004
|
-
copyExampleLink() {
|
|
1005
|
-
|
|
1006
|
-
const currentUrl = hashPosition > -1
|
|
1007
|
-
? this.location.href.slice(0, Math.max(0, hashPosition))
|
|
1008
|
-
: this.location.href;
|
|
1009
|
-
const url = `${currentUrl}#${this.id}`;
|
|
1010
|
-
this.setFragmentWithoutRedirect(this.id);
|
|
1011
|
-
this.clipboard.copy(url);
|
|
1001
|
+
copyExampleLink({ href }) {
|
|
1002
|
+
this.clipboard.copy(href);
|
|
1012
1003
|
this.alerts
|
|
1013
|
-
.open(this.texts[1], {
|
|
1014
|
-
label: this.texts[2],
|
|
1015
|
-
status: 'success',
|
|
1016
|
-
})
|
|
1004
|
+
.open(this.texts[1], { label: this.texts[2], status: 'success' })
|
|
1017
1005
|
.subscribe();
|
|
1018
1006
|
}
|
|
1019
1007
|
edit(files) {
|
|
@@ -1021,15 +1009,9 @@ class TuiDocExampleComponent {
|
|
|
1021
1009
|
this.loading$.next(true);
|
|
1022
1010
|
(_a = this.codeEditor) === null || _a === void 0 ? void 0 : _a.edit(this.componentName, this.id || '', files).then(() => this.loading$.next(false)).catch(() => this.loading$.next(false));
|
|
1023
1011
|
}
|
|
1024
|
-
setFragmentWithoutRedirect(id) {
|
|
1025
|
-
const url = this.router
|
|
1026
|
-
.createUrlTree([], { relativeTo: this.route, fragment: id || '' })
|
|
1027
|
-
.toString();
|
|
1028
|
-
this.ngLocation.go(url);
|
|
1029
|
-
}
|
|
1030
1012
|
}
|
|
1031
|
-
TuiDocExampleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, deps: [{ token: Clipboard }, { token: TuiAlertService }, { token: LOCATION }, { token: TUI_COPY_TEXTS }, { token: TUI_DOC_EXAMPLE_TEXTS }, { token: TUI_DOC_CODE_EDITOR, optional: true }, { token: TUI_DOC_EXAMPLE_CONTENT_PROCESSOR }, { token: TUI_IS_E2E }, { token: TUI_DOC_CODE_ACTIONS }, { token:
|
|
1032
|
-
TuiDocExampleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocExampleComponent, selector: "tui-doc-example", inputs: { id: "id", heading: "heading", description: "description", content: "content", fullsize: "fullsize", componentName: "componentName" }, host: { properties: { "class._fullsize": "this.fullsize" } }, ngImport: i0, template: "<h3\n *ngIf=\"heading\"\n class=\"t-title\"\n>\n <span\n *polymorpheusOutlet=\"heading as text\"\n [textContent]=\"text\"\n ></span>\n <
|
|
1013
|
+
TuiDocExampleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, deps: [{ token: Clipboard }, { token: TuiAlertService }, { token: LOCATION }, { token: TUI_COPY_TEXTS }, { token: TUI_DOC_EXAMPLE_TEXTS }, { token: TUI_DOC_CODE_EDITOR, optional: true }, { token: TUI_DOC_EXAMPLE_CONTENT_PROCESSOR }, { token: TUI_IS_E2E }, { token: TUI_DOC_CODE_ACTIONS }, { token: TUI_DOC_EXAMPLE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
1014
|
+
TuiDocExampleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDocExampleComponent, selector: "tui-doc-example", inputs: { id: "id", heading: "heading", description: "description", content: "content", fullsize: "fullsize", componentName: "componentName" }, host: { properties: { "class._fullsize": "this.fullsize" } }, ngImport: i0, template: "<h3\n *ngIf=\"heading\"\n class=\"t-title\"\n>\n <span\n *polymorpheusOutlet=\"heading as text\"\n [textContent]=\"text\"\n ></span>\n <a\n *ngIf=\"id\"\n appearance=\"icon\"\n routerLink=\".\"\n size=\"xs\"\n tuiIconButton\n type=\"button\"\n class=\"t-link-icon\"\n [fragment]=\"id\"\n [icon]=\"options.linkIcon\"\n [title]=\"copy$ | async\"\n (click)=\"copyExampleLink($any($event.currentTarget))\"\n ></a>\n</h3>\n<h4\n *ngIf=\"description\"\n class=\"t-description\"\n>\n <ng-container *polymorpheusOutlet=\"description 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\n *ngIf=\"tabs.length > 1\"\n class=\"t-tabs-wrapper\"\n >\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 <ng-container *polymorpheusOutlet=\"getTabTitle(tab) as text\">\n {{ text }}\n </ng-container>\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 appearance=\"flat\"\n size=\"s\"\n tuiButton\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]=\"!isE2E\"\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 <tui-doc-code [code]=\"code\">\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-code>\n</ng-template>\n", styles: [":host{position:relative;display:block;padding-top:3.5rem;clear:right}:host:target{animation:1s .3s tuiShaking}:host :host-context(tui-root._mobile){padding-top:2rem}.t-title{font:var(--tui-font-heading-5);margin:0 0 .5rem}:host-context(tui-root._mobile) .t-title{font:var(--tui-font-heading-6)}.t-description{font:var(--tui-font-text-m);font-weight:normal;margin:0}.t-title:first-letter,.t-description:first-letter{text-transform:capitalize}.t-example{position:relative;margin-top:1.5rem;border:1px solid var(--tui-base-03);border-radius:var(--tui-radius-m);box-shadow:0 .125rem .1875rem #0000001a;overflow:hidden}:host-context(tui-root._mobile) .t-example{margin-top:.75rem}.t-tabs-wrapper{display:flex;padding:0 .875rem 0 2rem;box-shadow:inset 0 -1px var(--tui-base-03);justify-content:space-between;align-items:center}:host-context(tui-root._mobile) .t-tabs-wrapper{padding:0 .875rem 0 1rem}.t-tabs{flex-grow:1}.t-demo{padding:2rem;max-width:100%;box-sizing:border-box;overflow-x:auto}@media all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.t-demo::-webkit-scrollbar,.t-demo::-webkit-scrollbar-thumb{width:1rem;height:1rem;border-radius:6.25rem;background-clip:padding-box;border:.375rem solid transparent}.t-demo::-webkit-scrollbar{background-color:transparent}.t-demo::-webkit-scrollbar-thumb{background-color:var(--tui-clear-hover)}.t-demo::-webkit-scrollbar-thumb:hover{background-color:var(--tui-clear-active)}.t-demo::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-03)}}:host-context(tui-root._mobile) .t-demo{padding:1rem}:host:not(._fullsize) .t-demo{width:-webkit-min-content;width:min-content;min-width:20rem}.t-link-icon{margin-left:.3rem;vertical-align:baseline}.t-content{will-change:opacity;height:0;visibility:hidden;opacity:0}.t-content_animated{transition:opacity .3s ease-in-out}.t-content_visible{height:auto;visibility:visible;opacity:1}\n"], components: [{ type: i2.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i1.TuiTabsWithMoreComponent, selector: "tui-tabs-with-more, nav[tuiTabsWithMore]", inputs: ["moreContent", "dropdownContent", "underline", "activeItemIndex", "itemsLimit"], outputs: ["activeItemIndexChange"] }, { type: i1.TuiTabComponent, selector: "a[tuiTab]:not([routerLink]), a[tuiTab][routerLink][routerLinkActive], button[tuiTab]" }, { type: i2.TuiLoaderComponent, selector: "tui-loader", inputs: ["size", "inheritColor", "overlay", "textContent", "showLoader"] }, { type: TuiDocCodeComponent, selector: "tui-doc-code", inputs: ["filename", "code"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i5$1.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i6.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6$1.TuiItemDirective, selector: "[tuiItem]" }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i4.AsyncPipe, "tuiDocExampleGetTabs": TuiDocExampleGetTabsPipe, "tuiMapper": i6$1.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
1033
1015
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, decorators: [{
|
|
1034
1016
|
type: Component,
|
|
1035
1017
|
args: [{
|
|
@@ -1067,15 +1049,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
1067
1049
|
}] }, { type: Array, decorators: [{
|
|
1068
1050
|
type: Inject,
|
|
1069
1051
|
args: [TUI_DOC_CODE_ACTIONS]
|
|
1070
|
-
}] }, { type: i6.Router, decorators: [{
|
|
1071
|
-
type: Inject,
|
|
1072
|
-
args: [Router]
|
|
1073
|
-
}] }, { type: i6.ActivatedRoute, decorators: [{
|
|
1074
|
-
type: Inject,
|
|
1075
|
-
args: [ActivatedRoute]
|
|
1076
|
-
}] }, { type: i4.Location, decorators: [{
|
|
1077
|
-
type: Inject,
|
|
1078
|
-
args: [Location$1]
|
|
1079
1052
|
}] }, { type: undefined, decorators: [{
|
|
1080
1053
|
type: Inject,
|
|
1081
1054
|
args: [TUI_DOC_EXAMPLE_OPTIONS]
|
|
@@ -1107,7 +1080,8 @@ TuiDocExampleModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", ver
|
|
|
1107
1080
|
TuiDocCodeModule,
|
|
1108
1081
|
PolymorpheusModule,
|
|
1109
1082
|
TuiMapperPipeModule,
|
|
1110
|
-
TuiLoaderModule
|
|
1083
|
+
TuiLoaderModule,
|
|
1084
|
+
RouterModule], exports: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe] });
|
|
1111
1085
|
TuiDocExampleModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleModule, imports: [[
|
|
1112
1086
|
CommonModule,
|
|
1113
1087
|
ClipboardModule,
|
|
@@ -1118,6 +1092,7 @@ TuiDocExampleModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ver
|
|
|
1118
1092
|
PolymorpheusModule,
|
|
1119
1093
|
TuiMapperPipeModule,
|
|
1120
1094
|
TuiLoaderModule,
|
|
1095
|
+
RouterModule,
|
|
1121
1096
|
]] });
|
|
1122
1097
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleModule, decorators: [{
|
|
1123
1098
|
type: NgModule,
|
|
@@ -1132,6 +1107,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
1132
1107
|
PolymorpheusModule,
|
|
1133
1108
|
TuiMapperPipeModule,
|
|
1134
1109
|
TuiLoaderModule,
|
|
1110
|
+
RouterModule,
|
|
1135
1111
|
],
|
|
1136
1112
|
declarations: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe],
|
|
1137
1113
|
exports: [TuiDocExampleComponent, TuiDocExampleGetTabsPipe],
|