@taiga-ui/addon-doc 3.18.0-dev.main-a12f1fc → 3.19.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.umd.js +67 -24
- package/bundles/taiga-ui-addon-doc.umd.js.map +1 -1
- package/components/example/example-options.d.ts +8 -0
- package/components/example/example.component.d.ts +4 -2
- package/components/language-switcher/language-switcher.component.d.ts +7 -4
- package/components/language-switcher/language-switcher.module.d.ts +3 -3
- package/esm2015/components/example/example-options.js +16 -0
- package/esm2015/components/example/example.component.js +9 -7
- package/esm2015/components/language-switcher/language-switcher.component.js +20 -12
- package/esm2015/components/language-switcher/language-switcher.module.js +21 -5
- package/esm2015/public-api.js +2 -1
- package/fesm2015/taiga-ui-addon-doc.js +66 -26
- package/fesm2015/taiga-ui-addon-doc.js.map +1 -1
- package/package.json +10 -10
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { InjectionToken, ValueProvider } from '@angular/core';
|
|
2
|
+
import { TuiBooleanHandler } from '@taiga-ui/cdk';
|
|
3
|
+
export interface TuiDocExampleOptions {
|
|
4
|
+
codeEditorVisibilityHandler: TuiBooleanHandler<Record<string, string>>;
|
|
5
|
+
}
|
|
6
|
+
export declare const TUI_DOC_EXAMPLE_DEFAULT_OPTIONS: TuiDocExampleOptions;
|
|
7
|
+
export declare const TUI_DOC_EXAMPLE_OPTIONS: InjectionToken<TuiDocExampleOptions>;
|
|
8
|
+
export declare function tuiDocExampleOptionsProvider(options: Partial<TuiDocExampleOptions>): ValueProvider;
|
|
@@ -7,6 +7,7 @@ import { PolymorpheusContent } from '@tinkoff/ng-polymorpheus';
|
|
|
7
7
|
import { Observable, Subject } from 'rxjs';
|
|
8
8
|
import { TuiCodeEditor } from '../../interfaces/code-editor';
|
|
9
9
|
import { TuiDocExample } from '../../interfaces/page';
|
|
10
|
+
import { TuiDocExampleOptions } from './example-options';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
export declare class TuiDocExampleComponent {
|
|
12
13
|
private readonly clipboard;
|
|
@@ -21,6 +22,7 @@ export declare class TuiDocExampleComponent {
|
|
|
21
22
|
private readonly router;
|
|
22
23
|
private readonly route;
|
|
23
24
|
private readonly ngLocation;
|
|
25
|
+
private readonly options;
|
|
24
26
|
private readonly rawLoader$$;
|
|
25
27
|
id: string | null;
|
|
26
28
|
heading: PolymorpheusContent;
|
|
@@ -33,11 +35,11 @@ export declare class TuiDocExampleComponent {
|
|
|
33
35
|
readonly copy$: Observable<string>;
|
|
34
36
|
readonly processor$: Observable<Record<string, string>>;
|
|
35
37
|
readonly loading$: Subject<boolean>;
|
|
36
|
-
constructor(clipboard: Clipboard, alertService: 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);
|
|
38
|
+
constructor(clipboard: Clipboard, alertService: 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);
|
|
37
39
|
readonly visible: (files: Record<string, string>) => boolean;
|
|
38
40
|
copyExampleLink(): void;
|
|
39
41
|
edit(files: Record<string, string>): void;
|
|
40
42
|
private setFragmentWithoutRedirect;
|
|
41
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocExampleComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null, null, null]>;
|
|
43
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocExampleComponent, [null, null, null, null, null, { optional: true; }, null, null, null, null, null, null, null]>;
|
|
42
44
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocExampleComponent, "tui-doc-example", never, { "id": "id"; "heading": "heading"; "description": "description"; "content": "content"; "componentName": "componentName"; }, {}, never, ["*"]>;
|
|
43
45
|
}
|
|
@@ -1,15 +1,18 @@
|
|
|
1
1
|
import { FormControl } from '@angular/forms';
|
|
2
|
-
import {
|
|
2
|
+
import { TuiFlagPipe } from '@taiga-ui/core';
|
|
3
3
|
import { TuiCountryIsoCode, TuiLanguageName, TuiLanguageSwitcher } from '@taiga-ui/i18n';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TuiLanguageSwitcherComponent {
|
|
6
6
|
readonly switcher: TuiLanguageSwitcher;
|
|
7
|
-
private readonly
|
|
8
|
-
private readonly path;
|
|
7
|
+
private readonly flagPipe;
|
|
9
8
|
readonly language: FormControl;
|
|
10
9
|
readonly flags: Map<TuiLanguageName, TuiCountryIsoCode>;
|
|
11
10
|
readonly names: TuiLanguageName[];
|
|
12
|
-
constructor(switcher: TuiLanguageSwitcher,
|
|
11
|
+
constructor(switcher: TuiLanguageSwitcher, flagPipe: TuiFlagPipe);
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated use `<img [src]="countryIsoCode | tuiFlagPipe" />`
|
|
14
|
+
* TODO drop in v4.0
|
|
15
|
+
*/
|
|
13
16
|
getFlagPath(code?: TuiCountryIsoCode): string | null;
|
|
14
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiLanguageSwitcherComponent, never>;
|
|
15
18
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiLanguageSwitcherComponent, "tui-language-switcher", never, {}, {}, never, ["*"]>;
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./language-switcher.component";
|
|
3
3
|
import * as i2 from "@angular/common";
|
|
4
|
-
import * as i3 from "@taiga-ui/
|
|
5
|
-
import * as i4 from "@taiga-ui/
|
|
4
|
+
import * as i3 from "@taiga-ui/core";
|
|
5
|
+
import * as i4 from "@taiga-ui/kit";
|
|
6
6
|
import * as i5 from "@angular/forms";
|
|
7
7
|
export declare class TuiLanguageSwitcherModule {
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiLanguageSwitcherModule, never>;
|
|
9
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiLanguageSwitcherModule, [typeof i1.TuiLanguageSwitcherComponent], [typeof i2.CommonModule, typeof i3.
|
|
9
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TuiLanguageSwitcherModule, [typeof i1.TuiLanguageSwitcherComponent], [typeof i2.CommonModule, typeof i3.TuiFlagPipeModule, typeof i4.TuiSelectModule, typeof i3.TuiDataListModule, typeof i5.ReactiveFormsModule], [typeof i1.TuiLanguageSwitcherComponent]>;
|
|
10
10
|
static ɵinj: i0.ɵɵInjectorDeclaration<TuiLanguageSwitcherModule>;
|
|
11
11
|
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
import { TUI_EXAMPLE_PRIMARY_FILE_NAME } from '../../interfaces/page';
|
|
3
|
+
export const TUI_DOC_EXAMPLE_DEFAULT_OPTIONS = {
|
|
4
|
+
codeEditorVisibilityHandler: files => Boolean(files[TUI_EXAMPLE_PRIMARY_FILE_NAME.TS] &&
|
|
5
|
+
files[TUI_EXAMPLE_PRIMARY_FILE_NAME.HTML]),
|
|
6
|
+
};
|
|
7
|
+
export const TUI_DOC_EXAMPLE_OPTIONS = new InjectionToken(`[TUI_DOC_EXAMPLE_OPTIONS]: Default parameters for DocExample component`, {
|
|
8
|
+
factory: () => TUI_DOC_EXAMPLE_DEFAULT_OPTIONS,
|
|
9
|
+
});
|
|
10
|
+
export function tuiDocExampleOptionsProvider(options) {
|
|
11
|
+
return {
|
|
12
|
+
provide: TUI_DOC_EXAMPLE_OPTIONS,
|
|
13
|
+
useValue: Object.assign(Object.assign({}, TUI_DOC_EXAMPLE_DEFAULT_OPTIONS), options),
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhhbXBsZS1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL3NyYy9jb21wb25lbnRzL2V4YW1wbGUvZXhhbXBsZS1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQWdCLE1BQU0sZUFBZSxDQUFDO0FBRzVELE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLHVCQUF1QixDQUFDO0FBTXBFLE1BQU0sQ0FBQyxNQUFNLCtCQUErQixHQUF5QjtJQUNqRSwyQkFBMkIsRUFBRSxLQUFLLENBQUMsRUFBRSxDQUNqQyxPQUFPLENBQ0gsS0FBSyxDQUFDLDZCQUE2QixDQUFDLEVBQUUsQ0FBQztRQUNuQyxLQUFLLENBQUMsNkJBQTZCLENBQUMsSUFBSSxDQUFDLENBQ2hEO0NBQ1IsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLElBQUksY0FBYyxDQUNyRCx3RUFBd0UsRUFDeEU7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsK0JBQStCO0NBQ2pELENBQ0osQ0FBQztBQUVGLE1BQU0sVUFBVSw0QkFBNEIsQ0FDeEMsT0FBc0M7SUFFdEMsT0FBTztRQUNILE9BQU8sRUFBRSx1QkFBdUI7UUFDaEMsUUFBUSxrQ0FBTSwrQkFBK0IsR0FBSyxPQUFPLENBQUM7S0FDN0QsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VuLCBWYWx1ZVByb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VHVpQm9vbGVhbkhhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuXG5pbXBvcnQge1RVSV9FWEFNUExFX1BSSU1BUllfRklMRV9OQU1FfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL3BhZ2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFR1aURvY0V4YW1wbGVPcHRpb25zIHtcbiAgICBjb2RlRWRpdG9yVmlzaWJpbGl0eUhhbmRsZXI6IFR1aUJvb2xlYW5IYW5kbGVyPFJlY29yZDxzdHJpbmcsIHN0cmluZz4+O1xufVxuXG5leHBvcnQgY29uc3QgVFVJX0RPQ19FWEFNUExFX0RFRkFVTFRfT1BUSU9OUzogVHVpRG9jRXhhbXBsZU9wdGlvbnMgPSB7XG4gICAgY29kZUVkaXRvclZpc2liaWxpdHlIYW5kbGVyOiBmaWxlcyA9PlxuICAgICAgICBCb29sZWFuKFxuICAgICAgICAgICAgZmlsZXNbVFVJX0VYQU1QTEVfUFJJTUFSWV9GSUxFX05BTUUuVFNdICYmXG4gICAgICAgICAgICAgICAgZmlsZXNbVFVJX0VYQU1QTEVfUFJJTUFSWV9GSUxFX05BTUUuSFRNTF0sXG4gICAgICAgICksXG59O1xuXG5leHBvcnQgY29uc3QgVFVJX0RPQ19FWEFNUExFX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHVpRG9jRXhhbXBsZU9wdGlvbnM+KFxuICAgIGBbVFVJX0RPQ19FWEFNUExFX09QVElPTlNdOiBEZWZhdWx0IHBhcmFtZXRlcnMgZm9yIERvY0V4YW1wbGUgY29tcG9uZW50YCxcbiAgICB7XG4gICAgICAgIGZhY3Rvcnk6ICgpID0+IFRVSV9ET0NfRVhBTVBMRV9ERUZBVUxUX09QVElPTlMsXG4gICAgfSxcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlEb2NFeGFtcGxlT3B0aW9uc1Byb3ZpZGVyKFxuICAgIG9wdGlvbnM6IFBhcnRpYWw8VHVpRG9jRXhhbXBsZU9wdGlvbnM+LFxuKTogVmFsdWVQcm92aWRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgcHJvdmlkZTogVFVJX0RPQ19FWEFNUExFX09QVElPTlMsXG4gICAgICAgIHVzZVZhbHVlOiB7Li4uVFVJX0RPQ19FWEFNUExFX0RFRkFVTFRfT1BUSU9OUywgLi4ub3B0aW9uc30sXG4gICAgfTtcbn1cbiJdfQ==
|
|
@@ -8,12 +8,12 @@ import { TuiAlertService } from '@taiga-ui/core';
|
|
|
8
8
|
import { TUI_COPY_TEXTS } from '@taiga-ui/kit';
|
|
9
9
|
import { BehaviorSubject, Subject } from 'rxjs';
|
|
10
10
|
import { map, switchMap } from 'rxjs/operators';
|
|
11
|
-
import { TUI_EXAMPLE_PRIMARY_FILE_NAME } from '../../interfaces/page';
|
|
12
11
|
import { TUI_DOC_CODE_ACTIONS } from '../../tokens/code-actions';
|
|
13
12
|
import { TUI_DOC_CODE_EDITOR } from '../../tokens/code-editor';
|
|
14
13
|
import { TUI_DOC_EXAMPLE_CONTENT_PROCESSOR } from '../../tokens/example-content-processor';
|
|
15
14
|
import { TUI_DOC_EXAMPLE_TEXTS } from '../../tokens/i18n';
|
|
16
15
|
import { tuiRawLoadRecord } from '../../utils/raw-load-record';
|
|
16
|
+
import { TUI_DOC_EXAMPLE_OPTIONS } from './example-options';
|
|
17
17
|
import * as i0 from "@angular/core";
|
|
18
18
|
import * as i1 from "@taiga-ui/core";
|
|
19
19
|
import * as i2 from "@taiga-ui/kit";
|
|
@@ -28,7 +28,7 @@ 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, alertService, location, copyTexts$, texts, codeEditor, processContent, isCypress, codeActions, router, route, ngLocation) {
|
|
31
|
+
constructor(clipboard, alertService, location, copyTexts$, texts, codeEditor, processContent, isCypress, codeActions, router, route, ngLocation, options) {
|
|
32
32
|
this.clipboard = clipboard;
|
|
33
33
|
this.alertService = alertService;
|
|
34
34
|
this.location = location;
|
|
@@ -41,6 +41,7 @@ export class TuiDocExampleComponent {
|
|
|
41
41
|
this.router = router;
|
|
42
42
|
this.route = route;
|
|
43
43
|
this.ngLocation = ngLocation;
|
|
44
|
+
this.options = options;
|
|
44
45
|
this.rawLoader$$ = new BehaviorSubject({});
|
|
45
46
|
this.id = null;
|
|
46
47
|
this.heading = '';
|
|
@@ -52,9 +53,7 @@ export class TuiDocExampleComponent {
|
|
|
52
53
|
this.copy$ = this.copyTexts$.pipe(map(([copy]) => copy));
|
|
53
54
|
this.processor$ = this.rawLoader$$.pipe(switchMap(tuiRawLoadRecord), map(value => this.processContent(value)));
|
|
54
55
|
this.loading$ = new Subject();
|
|
55
|
-
this.visible = (files) => Boolean(this.codeEditor &&
|
|
56
|
-
files[TUI_EXAMPLE_PRIMARY_FILE_NAME.TS] &&
|
|
57
|
-
files[TUI_EXAMPLE_PRIMARY_FILE_NAME.HTML]);
|
|
56
|
+
this.visible = (files) => Boolean(this.codeEditor && this.options.codeEditorVisibilityHandler(files));
|
|
58
57
|
}
|
|
59
58
|
set content(content) {
|
|
60
59
|
this.rawLoader$$.next(content);
|
|
@@ -86,7 +85,7 @@ export class TuiDocExampleComponent {
|
|
|
86
85
|
this.ngLocation.go(url);
|
|
87
86
|
}
|
|
88
87
|
}
|
|
89
|
-
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_CYPRESS }, { token: TUI_DOC_CODE_ACTIONS }, { token: Router }, { token: ActivatedRoute }, { token: NgLocation }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
+
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_CYPRESS }, { token: TUI_DOC_CODE_ACTIONS }, { token: Router }, { token: ActivatedRoute }, { token: NgLocation }, { token: TUI_DOC_EXAMPLE_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
90
89
|
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", componentName: "componentName" }, ngImport: i0, template: "<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 <button\n *ngIf=\"files | tuiMapper : visible\"\n tuiButton\n appearance=\"flat\"\n size=\"s\"\n type=\"button\"\n [showLoader]=\"!!(loading$ | async)\"\n (click)=\"edit(files)\"\n >\n Edit on {{ codeEditor!.name }}\n </button>\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", styles: [":host{position:relative;display:block;padding-top:3.5rem;clear:right}: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-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 rgba(0,0,0,.1)}:host-context(tui-root._mobile) .t-example{margin-top:.75rem}.t-tabs-wrapper{display:flex;padding: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 1rem}.t-tabs{flex-grow:1}.t-demo{padding:2rem;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:2.667rem 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}.t-code-actions{position:absolute;top:4.375rem;right:1rem;display:flex;justify-content:flex-end;align-items:center}.t-code-actions>*{margin-left:.5rem}.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: i3.TuiDocCopyComponent, selector: "tui-doc-copy" }, { type: i4.TuiDocCodeComponent, selector: "tui-doc-code", inputs: ["filename", "code"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.TuiItemDirective, selector: "[tuiItem]" }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i8.CdkCopyToClipboard, selector: "[cdkCopyToClipboard]", inputs: ["cdkCopyToClipboard", "cdkCopyToClipboardAttempts"], outputs: ["cdkCopyToClipboardCopied"] }], pipes: { "tuiDocExampleCapitalize": i9.TuiDocExampleCapitalizePipe, "async": i5.AsyncPipe, "tuiDocExampleGetTabs": i10.TuiDocExampleGetTabsPipe, "tuiMapper": i7.TuiMapperPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
91
90
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDocExampleComponent, decorators: [{
|
|
92
91
|
type: Component,
|
|
@@ -134,6 +133,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
134
133
|
}] }, { type: i5.Location, decorators: [{
|
|
135
134
|
type: Inject,
|
|
136
135
|
args: [NgLocation]
|
|
136
|
+
}] }, { type: undefined, decorators: [{
|
|
137
|
+
type: Inject,
|
|
138
|
+
args: [TUI_DOC_EXAMPLE_OPTIONS]
|
|
137
139
|
}] }]; }, propDecorators: { id: [{
|
|
138
140
|
type: Input
|
|
139
141
|
}], heading: [{
|
|
@@ -145,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
145
147
|
}], componentName: [{
|
|
146
148
|
type: Input
|
|
147
149
|
}] } });
|
|
148
|
-
//# 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 {TUI_EXAMPLE_PRIMARY_FILE_NAME, 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';\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    ) {}\n\n    readonly visible = (files: Record<string, string>): boolean =>\n        Boolean(\n            this.codeEditor &&\n                files[TUI_EXAMPLE_PRIMARY_FILE_NAME.TS] &&\n                files[TUI_EXAMPLE_PRIMARY_FILE_NAME.HTML],\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.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            <button\n                *ngIf=\"files | tuiMapper : visible\"\n                tuiButton\n                appearance=\"flat\"\n                size=\"s\"\n                type=\"button\"\n                [showLoader]=\"!!(loading$ | async)\"\n                (click)=\"edit(files)\"\n            >\n                Edit on {{ codeEditor!.name }}\n            </button>\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":"AAAA,OAAO,EAAC,SAAS,EAAC,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAC,QAAQ,IAAI,UAAU,EAAC,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAC,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAC,cAAc,EAAE,MAAM,EAAC,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAC,QAAQ,EAAC,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAC,cAAc,EAAqC,MAAM,eAAe,CAAC;AACjF,OAAO,EAAC,eAAe,EAAkB,MAAM,gBAAgB,CAAC;AAChE,OAAO,EAAC,cAAc,EAAC,MAAM,eAAe,CAAC;AAE7C,OAAO,EAAC,eAAe,EAAc,OAAO,EAAC,MAAM,MAAM,CAAC;AAC1D,OAAO,EAAC,GAAG,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAI9C,OAAO,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAC,mBAAmB,EAAC,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAC,iCAAiC,EAAC,MAAM,wCAAwC,CAAC;AACzF,OAAO,EAAC,qBAAqB,EAAC,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAC,gBAAgB,EAAC,MAAM,6BAA6B,CAAC;AAC7D,OAAO,EAAC,uBAAuB,EAAuB,MAAM,mBAAmB,CAAC;;;;;;;;;;;;;;AAQhF,MAAM,OAAO,sBAAsB;IAmC/B,YACwC,SAAoB,EAEvC,YAA6B,EACX,QAAkB,EACZ,UAAwC,EACzC,KAA+B,EAG9D,UAAgC,EAExB,cAGhB,EACgC,SAAkB,EAE1C,WAAuE,EAC/C,MAAc,EACN,KAAqB,EACzB,UAAsB,EACT,OAA6B;QApB3C,cAAS,GAAT,SAAS,CAAW;QAEvC,iBAAY,GAAZ,YAAY,CAAiB;QACX,aAAQ,GAAR,QAAQ,CAAU;QACZ,eAAU,GAAV,UAAU,CAA8B;QACzC,UAAK,GAAL,KAAK,CAA0B;QAG9D,eAAU,GAAV,UAAU,CAAsB;QAExB,mBAAc,GAAd,cAAc,CAG9B;QACgC,cAAS,GAAT,SAAS,CAAS;QAE1C,gBAAW,GAAX,WAAW,CAA4D;QAC/C,WAAM,GAAN,MAAM,CAAQ;QACN,UAAK,GAAL,KAAK,CAAgB;QACzB,eAAU,GAAV,UAAU,CAAY;QACT,YAAO,GAAP,OAAO,CAAsB;QAvDlE,gBAAW,GAAG,IAAI,eAAe,CAAgB,EAAE,CAAC,CAAC;QAGtE,OAAE,GAAkB,IAAI,CAAC;QAGzB,YAAO,GAAwB,EAAE,CAAC;QAGlC,gBAAW,GAAwB,EAAE,CAAC;QAQtC,kBAAa,GAAW,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAE/C,oBAAe,GAAG,CAAC,CAAC;QAEpB,eAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAEvD,oBAAe,GAAG,IAAI,CAAC,eAAe,CAAC;QAE9B,UAAK,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;QAEpD,eAAU,GAAuC,IAAI,CAAC,WAAW,CAAC,IAAI,CAC3E,SAAS,CAAC,gBAAgB,CAAC,EAC3B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAC3C,CAAC;QAEO,aAAQ,GAAG,IAAI,OAAO,EAAW,CAAC;QA0BlC,YAAO,GAAG,CAAC,KAA6B,EAAW,EAAE,CAC1D,OAAO,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC,CAAC;IAH7E,CAAC;IA7CJ,IACI,OAAO,CAAC,OAAsB;QAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,CAAC;IA+CD,eAAe;QACX,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QACrD,MAAM,UAAU,GACZ,YAAY,GAAG,CAAC,CAAC;YACb,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,YAAY,CAAC,CAAC;YACxD,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;QAC7B,MAAM,GAAG,GAAG,GAAG,UAAU,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;QAEvC,IAAI,CAAC,0BAA0B,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACzB,IAAI,CAAC,YAAY;aACZ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;YACjB,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;YACpB,MAAM,yBAAyB;SAClC,CAAC;aACD,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,IAAI,CAAC,KAA6B;;QAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,MAAA,IAAI,CAAC,UAAU,0CACT,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,EAAE,IAAI,EAAE,EAAE,KAAK,EAG9C,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EACpC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAChD,CAAC;IAEO,0BAA0B,CAAC,EAAiB;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM;aAClB,aAAa,CAAC,EAAE,EAAE,EAAC,UAAU,EAAE,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,EAAC,CAAC;aAC/D,QAAQ,EAAE,CAAC;QAEhB,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;;oHAhGQ,sBAAsB,kBAoCnB,SAAS,aACT,eAAe,aAEf,QAAQ,aACR,cAAc,aACd,qBAAqB,aAErB,mBAAmB,6BAEnB,iCAAiC,aAKjC,cAAc,aACd,oBAAoB,aAEpB,MAAM,aACN,cAAc,aACd,UAAU,aACV,uBAAuB;wGAxD1B,sBAAsB,iLC3BnC,skGAyGA;4FD9Ea,sBAAsB;kBANlC,SAAS;mBAAC;oBACP,QAAQ,EAAE,iBAAiB;oBAC3B,WAAW,EAAE,yBAAyB;oBACtC,SAAS,EAAE,CAAC,sBAAsB,CAAC;oBACnC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;;0BAqCQ,MAAM;2BAAC,SAAS;;0BAChB,MAAM;2BAAC,eAAe;8BAEsB,QAAQ;0BAApD,MAAM;2BAAC,QAAQ;;0BACf,MAAM;2BAAC,cAAc;;0BACrB,MAAM;2BAAC,qBAAqB;;0BAC5B,QAAQ;;0BACR,MAAM;2BAAC,mBAAmB;;0BAE1B,MAAM;2BAAC,iCAAiC;;0BAKxC,MAAM;2BAAC,cAAc;8BAEA,KAAK;0BAD1B,MAAM;2BAAC,oBAAoB;;0BAE3B,MAAM;2BAAC,MAAM;;0BACb,MAAM;2BAAC,cAAc;;0BACrB,MAAM;2BAAC,UAAU;;0BACjB,MAAM;2BAAC,uBAAuB;4CApDnC,EAAE;sBADD,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIF,OAAO;sBADV,KAAK;gBAMN,aAAa;sBADZ,KAAK","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            <button\n                *ngIf=\"files | tuiMapper : visible\"\n                tuiButton\n                appearance=\"flat\"\n                size=\"s\"\n                type=\"button\"\n                [showLoader]=\"!!(loading$ | async)\"\n                (click)=\"edit(files)\"\n            >\n                Edit on {{ codeEditor!.name }}\n            </button>\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,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
-
import {
|
|
3
|
+
import { tuiCapitalizeFirstLetter, TuiFlagPipe } from '@taiga-ui/core';
|
|
4
4
|
import { TuiCountryIsoCode, TuiLanguageSwitcher } from '@taiga-ui/i18n';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@taiga-ui/kit";
|
|
@@ -9,12 +9,9 @@ import * as i3 from "@angular/forms";
|
|
|
9
9
|
import * as i4 from "@angular/common";
|
|
10
10
|
import * as i5 from "@taiga-ui/i18n";
|
|
11
11
|
export class TuiLanguageSwitcherComponent {
|
|
12
|
-
constructor(switcher,
|
|
12
|
+
constructor(switcher, flagPipe) {
|
|
13
13
|
this.switcher = switcher;
|
|
14
|
-
this.
|
|
15
|
-
this.path = this.options
|
|
16
|
-
.path('tuiIcon')
|
|
17
|
-
.replace('tuiIcon.svg#tuiIcon', '');
|
|
14
|
+
this.flagPipe = flagPipe;
|
|
18
15
|
this.language = new FormControl(tuiCapitalizeFirstLetter(this.switcher.language));
|
|
19
16
|
this.flags = new Map([
|
|
20
17
|
['chinese', TuiCountryIsoCode.CN],
|
|
@@ -33,25 +30,36 @@ export class TuiLanguageSwitcherComponent {
|
|
|
33
30
|
]);
|
|
34
31
|
this.names = Array.from(this.flags.keys());
|
|
35
32
|
}
|
|
33
|
+
/**
|
|
34
|
+
* @deprecated use `<img [src]="countryIsoCode | tuiFlagPipe" />`
|
|
35
|
+
* TODO drop in v4.0
|
|
36
|
+
*/
|
|
36
37
|
getFlagPath(code) {
|
|
37
|
-
return
|
|
38
|
+
return this.flagPipe.transform(code);
|
|
38
39
|
}
|
|
39
40
|
}
|
|
40
|
-
TuiLanguageSwitcherComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherComponent, deps: [{ token: TuiLanguageSwitcher }, { token:
|
|
41
|
-
TuiLanguageSwitcherComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiLanguageSwitcherComponent, selector: "tui-language-switcher",
|
|
41
|
+
TuiLanguageSwitcherComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherComponent, deps: [{ token: TuiLanguageSwitcher }, { token: TuiFlagPipe }], target: i0.ɵɵFactoryTarget.Component });
|
|
42
|
+
TuiLanguageSwitcherComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiLanguageSwitcherComponent, selector: "tui-language-switcher", providers: [
|
|
43
|
+
// TODO: for backward compatibility only. Drop in v4.0
|
|
44
|
+
TuiFlagPipe,
|
|
45
|
+
], ngImport: i0, template: "<tui-select [formControl]=\"language\">\n <ng-content></ng-content>\n <tui-data-list *tuiDataList>\n <button\n *ngFor=\"let name of names\"\n tuiOption\n [value]=\"name | titlecase\"\n (click)=\"switcher.setLanguage(name)\"\n >\n <img\n alt=\"\"\n class=\"t-flag\"\n [src]=\"flags.get(name) | tuiFlag\"\n />\n {{ name | titlecase }}\n </button>\n </tui-data-list>\n</tui-select>\n", styles: [".t-flag{width:1.75rem;height:1.25rem;margin-right:.5rem}\n"], components: [{ type: i1.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i2.TuiDataListComponent, selector: "tui-data-list", inputs: ["role", "emptyContent", "size"] }, { type: i2.TuiOptionComponent, selector: "button[tuiOption], a[tuiOption]", inputs: ["size", "role", "disabled", "value"] }], directives: [{ type: i1.TuiSelectDirective, selector: "tui-select" }, { type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i3.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i2.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "titlecase": i4.TitleCasePipe, "tuiFlag": i2.TuiFlagPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
42
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherComponent, decorators: [{
|
|
43
47
|
type: Component,
|
|
44
48
|
args: [{
|
|
45
49
|
selector: 'tui-language-switcher',
|
|
46
50
|
templateUrl: './language-switcher.component.html',
|
|
47
51
|
styleUrls: ['./language-switcher.component.less'],
|
|
52
|
+
providers: [
|
|
53
|
+
// TODO: for backward compatibility only. Drop in v4.0
|
|
54
|
+
TuiFlagPipe,
|
|
55
|
+
],
|
|
48
56
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
49
57
|
}]
|
|
50
58
|
}], ctorParameters: function () { return [{ type: i5.TuiLanguageSwitcher, decorators: [{
|
|
51
59
|
type: Inject,
|
|
52
60
|
args: [TuiLanguageSwitcher]
|
|
53
|
-
}] }, { type:
|
|
61
|
+
}] }, { type: i2.TuiFlagPipe, decorators: [{
|
|
54
62
|
type: Inject,
|
|
55
|
-
args: [
|
|
63
|
+
args: [TuiFlagPipe]
|
|
56
64
|
}] }]; } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2Utc3dpdGNoZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL3NyYy9jb21wb25lbnRzL2xhbmd1YWdlLXN3aXRjaGVyL2xhbmd1YWdlLXN3aXRjaGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9sYW5ndWFnZS1zd2l0Y2hlci9sYW5ndWFnZS1zd2l0Y2hlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0MsT0FBTyxFQUFDLHdCQUF3QixFQUFFLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQ3JFLE9BQU8sRUFBQyxpQkFBaUIsRUFBbUIsbUJBQW1CLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7OztBQVl2RixNQUFNLE9BQU8sNEJBQTRCO0lBcUJyQyxZQUMwQyxRQUE2QixFQUM3QixRQUFxQjtRQURyQixhQUFRLEdBQVIsUUFBUSxDQUFxQjtRQUM3QixhQUFRLEdBQVIsUUFBUSxDQUFhO1FBdEJ0RCxhQUFRLEdBQUcsSUFBSSxXQUFXLENBQUMsd0JBQXdCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDO1FBRTdFLFVBQUssR0FBNEMsSUFBSSxHQUFHLENBQUM7WUFDOUQsQ0FBQyxTQUFTLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1lBQ2pDLENBQUMsT0FBTyxFQUFFLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztZQUMvQixDQUFDLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDakMsQ0FBQyxRQUFRLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1lBQ2hDLENBQUMsUUFBUSxFQUFFLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztZQUNoQyxDQUFDLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDakMsQ0FBQyxRQUFRLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1lBQ2hDLENBQUMsWUFBWSxFQUFFLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztZQUNwQyxDQUFDLFNBQVMsRUFBRSxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDakMsQ0FBQyxTQUFTLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1lBQ2pDLENBQUMsU0FBUyxFQUFFLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztZQUNqQyxDQUFDLFdBQVcsRUFBRSxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDbkMsQ0FBQyxZQUFZLEVBQUUsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1NBQ3ZDLENBQUMsQ0FBQztRQUVNLFVBQUssR0FBc0IsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUM7SUFLL0QsQ0FBQztJQUVKOzs7T0FHRztJQUNILFdBQVcsQ0FBQyxJQUF3QjtRQUNoQyxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3pDLENBQUM7OzBIQWhDUSw0QkFBNEIsa0JBc0J6QixtQkFBbUIsYUFDbkIsV0FBVzs4R0F2QmQsNEJBQTRCLGdEQU4xQjtRQUNQLHNEQUFzRDtRQUN0RCxXQUFXO0tBQ2QsMEJDWkwsc2hCQWtCQTs0RkRIYSw0QkFBNEI7a0JBVnhDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjtvQkFDakMsV0FBVyxFQUFFLG9DQUFvQztvQkFDakQsU0FBUyxFQUFFLENBQUMsb0NBQW9DLENBQUM7b0JBQ2pELFNBQVMsRUFBRTt3QkFDUCxzREFBc0Q7d0JBQ3RELFdBQVc7cUJBQ2Q7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzswQkF1QlEsTUFBTTsyQkFBQyxtQkFBbUI7OzBCQUMxQixNQUFNOzJCQUFDLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1Db250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge3R1aUNhcGl0YWxpemVGaXJzdExldHRlciwgVHVpRmxhZ1BpcGV9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7VHVpQ291bnRyeUlzb0NvZGUsIFR1aUxhbmd1YWdlTmFtZSwgVHVpTGFuZ3VhZ2VTd2l0Y2hlcn0gZnJvbSAnQHRhaWdhLXVpL2kxOG4nO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1sYW5ndWFnZS1zd2l0Y2hlcicsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2xhbmd1YWdlLXN3aXRjaGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9sYW5ndWFnZS1zd2l0Y2hlci5jb21wb25lbnQubGVzcyddLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICAvLyBUT0RPOiBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eSBvbmx5LiBEcm9wIGluIHY0LjBcbiAgICAgICAgVHVpRmxhZ1BpcGUsXG4gICAgXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpTGFuZ3VhZ2VTd2l0Y2hlckNvbXBvbmVudCB7XG4gICAgcmVhZG9ubHkgbGFuZ3VhZ2UgPSBuZXcgRm9ybUNvbnRyb2wodHVpQ2FwaXRhbGl6ZUZpcnN0TGV0dGVyKHRoaXMuc3dpdGNoZXIubGFuZ3VhZ2UpKTtcblxuICAgIHJlYWRvbmx5IGZsYWdzOiBNYXA8VHVpTGFuZ3VhZ2VOYW1lLCBUdWlDb3VudHJ5SXNvQ29kZT4gPSBuZXcgTWFwKFtcbiAgICAgICAgWydjaGluZXNlJywgVHVpQ291bnRyeUlzb0NvZGUuQ05dLFxuICAgICAgICBbJ2R1dGNoJywgVHVpQ291bnRyeUlzb0NvZGUuTkxdLFxuICAgICAgICBbJ2VuZ2xpc2gnLCBUdWlDb3VudHJ5SXNvQ29kZS5HQl0sXG4gICAgICAgIFsnZnJlbmNoJywgVHVpQ291bnRyeUlzb0NvZGUuRlJdLFxuICAgICAgICBbJ2dlcm1hbicsIFR1aUNvdW50cnlJc29Db2RlLkRFXSxcbiAgICAgICAgWydpdGFsaWFuJywgVHVpQ291bnRyeUlzb0NvZGUuSVRdLFxuICAgICAgICBbJ3BvbGlzaCcsIFR1aUNvdW50cnlJc29Db2RlLlBMXSxcbiAgICAgICAgWydwb3J0dWd1ZXNlJywgVHVpQ291bnRyeUlzb0NvZGUuUFRdLFxuICAgICAgICBbJ3J1c3NpYW4nLCBUdWlDb3VudHJ5SXNvQ29kZS5SVV0sXG4gICAgICAgIFsnc3BhbmlzaCcsIFR1aUNvdW50cnlJc29Db2RlLkVTXSxcbiAgICAgICAgWyd0dXJraXNoJywgVHVpQ291bnRyeUlzb0NvZGUuVFJdLFxuICAgICAgICBbJ3VrcmFpbmlhbicsIFR1aUNvdW50cnlJc29Db2RlLlVBXSxcbiAgICAgICAgWyd2aWV0bmFtZXNlJywgVHVpQ291bnRyeUlzb0NvZGUuVk5dLFxuICAgIF0pO1xuXG4gICAgcmVhZG9ubHkgbmFtZXM6IFR1aUxhbmd1YWdlTmFtZVtdID0gQXJyYXkuZnJvbSh0aGlzLmZsYWdzLmtleXMoKSk7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChUdWlMYW5ndWFnZVN3aXRjaGVyKSByZWFkb25seSBzd2l0Y2hlcjogVHVpTGFuZ3VhZ2VTd2l0Y2hlcixcbiAgICAgICAgQEluamVjdChUdWlGbGFnUGlwZSkgcHJpdmF0ZSByZWFkb25seSBmbGFnUGlwZTogVHVpRmxhZ1BpcGUsXG4gICAgKSB7fVxuXG4gICAgLyoqXG4gICAgICogQGRlcHJlY2F0ZWQgdXNlIGA8aW1nIFtzcmNdPVwiY291bnRyeUlzb0NvZGUgfCB0dWlGbGFnUGlwZVwiIC8+YFxuICAgICAqIFRPRE8gZHJvcCBpbiB2NC4wXG4gICAgICovXG4gICAgZ2V0RmxhZ1BhdGgoY29kZT86IFR1aUNvdW50cnlJc29Db2RlKTogc3RyaW5nIHwgbnVsbCB7XG4gICAgICAgIHJldHVybiB0aGlzLmZsYWdQaXBlLnRyYW5zZm9ybShjb2RlKTtcbiAgICB9XG59XG4iLCI8dHVpLXNlbGVjdCBbZm9ybUNvbnRyb2xdPVwibGFuZ3VhZ2VcIj5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPHR1aS1kYXRhLWxpc3QgKnR1aURhdGFMaXN0PlxuICAgICAgICA8YnV0dG9uXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgbmFtZSBvZiBuYW1lc1wiXG4gICAgICAgICAgICB0dWlPcHRpb25cbiAgICAgICAgICAgIFt2YWx1ZV09XCJuYW1lIHwgdGl0bGVjYXNlXCJcbiAgICAgICAgICAgIChjbGljayk9XCJzd2l0Y2hlci5zZXRMYW5ndWFnZShuYW1lKVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIDxpbWdcbiAgICAgICAgICAgICAgICBhbHQ9XCJcIlxuICAgICAgICAgICAgICAgIGNsYXNzPVwidC1mbGFnXCJcbiAgICAgICAgICAgICAgICBbc3JjXT1cImZsYWdzLmdldChuYW1lKSB8IHR1aUZsYWdcIlxuICAgICAgICAgICAgLz5cbiAgICAgICAgICAgIHt7IG5hbWUgfCB0aXRsZWNhc2UgfX1cbiAgICAgICAgPC9idXR0b24+XG4gICAgPC90dWktZGF0YS1saXN0PlxuPC90dWktc2VsZWN0PlxuIl19
|
|
@@ -1,21 +1,37 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
2
|
import { NgModule } from '@angular/core';
|
|
3
3
|
import { ReactiveFormsModule } from '@angular/forms';
|
|
4
|
-
import { TuiDataListModule } from '@taiga-ui/core';
|
|
4
|
+
import { TuiDataListModule, TuiFlagPipeModule } from '@taiga-ui/core';
|
|
5
5
|
import { TuiSelectModule } from '@taiga-ui/kit';
|
|
6
6
|
import { TuiLanguageSwitcherComponent } from './language-switcher.component';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export class TuiLanguageSwitcherModule {
|
|
9
9
|
}
|
|
10
10
|
TuiLanguageSwitcherModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
-
TuiLanguageSwitcherModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherModule, declarations: [TuiLanguageSwitcherComponent], imports: [CommonModule,
|
|
12
|
-
|
|
11
|
+
TuiLanguageSwitcherModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherModule, declarations: [TuiLanguageSwitcherComponent], imports: [CommonModule,
|
|
12
|
+
TuiFlagPipeModule,
|
|
13
|
+
TuiSelectModule,
|
|
14
|
+
TuiDataListModule,
|
|
15
|
+
ReactiveFormsModule], exports: [TuiLanguageSwitcherComponent] });
|
|
16
|
+
TuiLanguageSwitcherModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherModule, imports: [[
|
|
17
|
+
CommonModule,
|
|
18
|
+
TuiFlagPipeModule,
|
|
19
|
+
TuiSelectModule,
|
|
20
|
+
TuiDataListModule,
|
|
21
|
+
ReactiveFormsModule,
|
|
22
|
+
]] });
|
|
13
23
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiLanguageSwitcherModule, decorators: [{
|
|
14
24
|
type: NgModule,
|
|
15
25
|
args: [{
|
|
16
26
|
exports: [TuiLanguageSwitcherComponent],
|
|
17
27
|
declarations: [TuiLanguageSwitcherComponent],
|
|
18
|
-
imports: [
|
|
28
|
+
imports: [
|
|
29
|
+
CommonModule,
|
|
30
|
+
TuiFlagPipeModule,
|
|
31
|
+
TuiSelectModule,
|
|
32
|
+
TuiDataListModule,
|
|
33
|
+
ReactiveFormsModule,
|
|
34
|
+
],
|
|
19
35
|
}]
|
|
20
36
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFuZ3VhZ2Utc3dpdGNoZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL3NyYy9jb21wb25lbnRzL2xhbmd1YWdlLXN3aXRjaGVyL2xhbmd1YWdlLXN3aXRjaGVyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNuRCxPQUFPLEVBQUMsaUJBQWlCLEVBQUUsaUJBQWlCLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUNwRSxPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTlDLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLCtCQUErQixDQUFDOztBQWEzRSxNQUFNLE9BQU8seUJBQXlCOzt1SEFBekIseUJBQXlCO3dIQUF6Qix5QkFBeUIsaUJBVG5CLDRCQUE0QixhQUV2QyxZQUFZO1FBQ1osaUJBQWlCO1FBQ2pCLGVBQWU7UUFDZixpQkFBaUI7UUFDakIsbUJBQW1CLGFBUGIsNEJBQTRCO3dIQVU3Qix5QkFBeUIsWUFSekI7WUFDTCxZQUFZO1lBQ1osaUJBQWlCO1lBQ2pCLGVBQWU7WUFDZixpQkFBaUI7WUFDakIsbUJBQW1CO1NBQ3RCOzRGQUVRLHlCQUF5QjtrQkFYckMsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztvQkFDdkMsWUFBWSxFQUFFLENBQUMsNEJBQTRCLENBQUM7b0JBQzVDLE9BQU8sRUFBRTt3QkFDTCxZQUFZO3dCQUNaLGlCQUFpQjt3QkFDakIsZUFBZTt3QkFDZixpQkFBaUI7d0JBQ2pCLG1CQUFtQjtxQkFDdEI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbW1vbk1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7TmdNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtSZWFjdGl2ZUZvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1R1aURhdGFMaXN0TW9kdWxlLCBUdWlGbGFnUGlwZU1vZHVsZX0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuaW1wb3J0IHtUdWlTZWxlY3RNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9raXQnO1xuXG5pbXBvcnQge1R1aUxhbmd1YWdlU3dpdGNoZXJDb21wb25lbnR9IGZyb20gJy4vbGFuZ3VhZ2Utc3dpdGNoZXIuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBleHBvcnRzOiBbVHVpTGFuZ3VhZ2VTd2l0Y2hlckNvbXBvbmVudF0sXG4gICAgZGVjbGFyYXRpb25zOiBbVHVpTGFuZ3VhZ2VTd2l0Y2hlckNvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIFR1aUZsYWdQaXBlTW9kdWxlLFxuICAgICAgICBUdWlTZWxlY3RNb2R1bGUsXG4gICAgICAgIFR1aURhdGFMaXN0TW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aUxhbmd1YWdlU3dpdGNoZXJNb2R1bGUge31cbiJdfQ==
|
package/esm2015/public-api.js
CHANGED
|
@@ -17,6 +17,7 @@ export * from './components/example/example.component';
|
|
|
17
17
|
export * from './components/example/example.module';
|
|
18
18
|
export * from './components/example/example-capitalize.pipe';
|
|
19
19
|
export * from './components/example/example-get-tabs.pipe';
|
|
20
|
+
export * from './components/example/example-options';
|
|
20
21
|
export * from './components/language-switcher/language-switcher.component';
|
|
21
22
|
export * from './components/language-switcher/language-switcher.module';
|
|
22
23
|
export * from './components/main/main.component';
|
|
@@ -57,4 +58,4 @@ export * from './utils/coerce-value';
|
|
|
57
58
|
export * from './utils/generate-routes';
|
|
58
59
|
export * from './utils/raw-load';
|
|
59
60
|
export * from './utils/raw-load-record';
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGdCQUFnQjtBQUNoQixjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYyxpREFBaUQsQ0FBQztBQUNoRSxjQUFjLHVFQUF1RSxDQUFDO0FBQ3RGLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyx5REFBeUQsQ0FBQztBQUN4RSxjQUFjLGtDQUFrQyxDQUFDO0FBQ2pELGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHNDQUFzQyxDQUFDO0FBRXJELGdCQUFnQjtBQUNoQixjQUFjLDBEQUEwRCxDQUFDO0FBQ3pFLGNBQWMsdURBQXVELENBQUM7QUFFdEUsZ0JBQWdCO0FBQ2hCLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHVDQUF1QyxDQUFDO0FBRXRELGVBQWU7QUFDZixjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFlBQVk7QUFDWixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZ0JBQWdCLENBQUM7QUFFL0IsV0FBVztBQUNYLGNBQWMsZUFBZSxDQUFDO0FBRTlCLFdBQVc7QUFDWCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMseUJBQXlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBAdGFpZ2EtdWkvYWRkb24tZG9jXG4gKi9cblxuLyogQ29tcG9uZW50cyAqL1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2NvZGUvY29kZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2NvZGUvY29kZS5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2NvZGUvcGFyc2UtY29kZS1ibG9jayc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvY29weS9jb3B5LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvY29weS9jb3B5Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZGVtby9kZW1vLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZGVtby9kZW1vLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZG9jdW1lbnRhdGlvbi9kb2N1bWVudGF0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZG9jdW1lbnRhdGlvbi9kb2N1bWVudGF0aW9uLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZG9jdW1lbnRhdGlvbi9kb2N1bWVudGF0aW9uLXByb3BlcnR5LWNvbm5lY3Rvci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2RvY3VtZW50YXRpb24vcGlwZXMvaW5zcGVjdC5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9leGFtcGxlL2V4YW1wbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9leGFtcGxlL2V4YW1wbGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9leGFtcGxlL2V4YW1wbGUtY2FwaXRhbGl6ZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9leGFtcGxlL2V4YW1wbGUtZ2V0LXRhYnMucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvZXhhbXBsZS9leGFtcGxlLW9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21wb25lbnRzL2xhbmd1YWdlLXN3aXRjaGVyL2xhbmd1YWdlLXN3aXRjaGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NvbXBvbmVudHMvbGFuZ3VhZ2Utc3dpdGNoZXIvbGFuZ3VhZ2Utc3dpdGNoZXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9tYWluL21haW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9tYWluL21haW4ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9wYWdlL3BhZ2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9wYWdlL3BhZ2UubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50cy9wYWdlL3BhZ2UtdGFiLmRpcmVjdGl2ZSc7XG5cbi8qIERpcmVjdGl2ZXMgKi9cbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9zY3JvbGwtaW50by12aWV3L3Njcm9sbC1pbnRvLXZpZXcuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9zY3JvbGwtaW50by12aWV3L3Njcm9sbC1pbnRvLXZpZXcubW9kdWxlJztcblxuLyogSW50ZXJmYWNlcyAqL1xuZXhwb3J0ICogZnJvbSAnLi9pbnRlcmZhY2VzL2NvZGUtZWRpdG9yJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcy9wYWdlJztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcy9zb3VyY2UtY29kZS1wYXRoLW9wdGlvbnMnO1xuXG4vKiBMYW5ndWFnZXMgKi9cbmV4cG9ydCAqIGZyb20gJy4vbGFuZ3VhZ2VzL3J1c3NpYW4nO1xuXG4vKiBUb2tlbnMgKi9cbmV4cG9ydCAqIGZyb20gJy4vdG9rZW5zL2NvZGUtYWN0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9jb2RlLWVkaXRvcic7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9kZWZhdWx0LXRhYnMnO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbnMvZXhhbXBsZS1jb250ZW50LXByb2Nlc3Nvcic7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9leGNsdWRlZC1wcm9wZXJ0aWVzJztcbmV4cG9ydCAqIGZyb20gJy4vdG9rZW5zL2kxOG4nO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbnMvbG9nbyc7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9wYWdlLWxvYWRlZCc7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9wYWdlcyc7XG5leHBvcnQgKiBmcm9tICcuL3Rva2Vucy9zY3JvbGwtYmVoYXZpb3InO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbnMvc2VlLWFsc28nO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbnMvc291cmNlLWNvZGUnO1xuZXhwb3J0ICogZnJvbSAnLi90b2tlbnMvdGl0bGUnO1xuXG4vKiBUeXBlcyAqL1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy9wYWdlcyc7XG5cbi8qIFV0aWxzICovXG5leHBvcnQgKiBmcm9tICcuL2FkZG9uLWRvYy5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9jb2VyY2UtdmFsdWUnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9nZW5lcmF0ZS1yb3V0ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9yYXctbG9hZCc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL3Jhdy1sb2FkLXJlY29yZCc7XG4iXX0=
|