@taiga-ui/addon-doc 4.8.1 → 4.10.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/components/api/api-item.component.d.ts +11 -1
- package/components/code/index.d.ts +2 -2
- package/components/copy/index.d.ts +2 -3
- package/components/demo/index.d.ts +11 -5
- package/components/documentation/documentation-property-connector.directive.d.ts +2 -2
- package/components/example/example.component.d.ts +4 -6
- package/components/internal/header/index.d.ts +1 -1
- package/components/language-switcher/index.d.ts +1 -0
- package/components/navigation/navigation.component.d.ts +1 -1
- package/components/navigation/navigation.providers.d.ts +3 -4
- package/components/page/page.component.d.ts +2 -0
- package/components/page/page.providers.d.ts +5 -2
- package/esm2022/components/api/api-item.component.mjs +52 -5
- package/esm2022/components/code/index.mjs +6 -6
- package/esm2022/components/copy/index.mjs +10 -15
- package/esm2022/components/demo/index.mjs +27 -11
- package/esm2022/components/documentation/documentation-property-connector.directive.mjs +5 -5
- package/esm2022/components/documentation/documentation.component.mjs +4 -5
- package/esm2022/components/documentation/pipes/inspect.pipe.mjs +3 -3
- package/esm2022/components/example/example.component.mjs +15 -13
- package/esm2022/components/internal/header/index.mjs +5 -6
- package/esm2022/components/language-switcher/index.mjs +14 -8
- package/esm2022/components/navigation/navigation.component.mjs +6 -7
- package/esm2022/components/navigation/navigation.providers.mjs +5 -6
- package/esm2022/components/page/page.component.mjs +16 -10
- package/esm2022/components/page/page.providers.mjs +5 -3
- package/esm2022/tokens/code-editor.mjs +3 -3
- package/esm2022/tokens/doc-icons.mjs +2 -1
- package/esm2022/tokens/example-content-processor.mjs +1 -1
- package/esm2022/tokens/index.mjs +2 -1
- package/esm2022/tokens/support-language.mjs +3 -0
- package/fesm2022/taiga-ui-addon-doc-components.mjs +135 -75
- package/fesm2022/taiga-ui-addon-doc-components.mjs.map +1 -1
- package/fesm2022/taiga-ui-addon-doc-tokens.mjs +6 -3
- package/fesm2022/taiga-ui-addon-doc-tokens.mjs.map +1 -1
- package/package.json +8 -7
- package/tokens/code-editor.d.ts +1 -2
- package/tokens/doc-icons.d.ts +1 -0
- package/tokens/example-content-processor.d.ts +1 -1
- package/tokens/index.d.ts +1 -0
- package/tokens/support-language.d.ts +1 -0
|
@@ -1,11 +1,21 @@
|
|
|
1
|
+
import type { OnInit } from '@angular/core';
|
|
1
2
|
import { EventEmitter } from '@angular/core';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
export declare class TuiDocAPIItem<T> {
|
|
4
|
+
export declare class TuiDocAPIItem<T> implements OnInit {
|
|
5
|
+
private readonly locationRef;
|
|
6
|
+
private readonly activatedRoute;
|
|
7
|
+
private readonly urlSerializer;
|
|
8
|
+
private readonly urlStateHandler;
|
|
4
9
|
name: string;
|
|
5
10
|
type: string;
|
|
6
11
|
value?: T;
|
|
7
12
|
items: readonly T[];
|
|
8
13
|
readonly valueChange: EventEmitter<T>;
|
|
14
|
+
ngOnInit(): void;
|
|
15
|
+
onValueChange(value: T): void;
|
|
16
|
+
private clearBrackets;
|
|
17
|
+
private parseParams;
|
|
18
|
+
private setQueryParam;
|
|
9
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocAPIItem<any>, never>;
|
|
10
20
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocAPIItem<any>, "tr[tuiDocAPIItem]", never, { "name": { "alias": "name"; "required": false; }; "type": { "alias": "type"; "required": false; }; "value": { "alias": "value"; "required": false; }; "items": { "alias": "items"; "required": false; }; }, { "valueChange": "valueChange"; }, never, ["*"], true, never>;
|
|
11
21
|
}
|
|
@@ -6,10 +6,10 @@ export declare class TuiDocCode {
|
|
|
6
6
|
private readonly icons;
|
|
7
7
|
private readonly rawLoader$$;
|
|
8
8
|
protected readonly isServer: boolean;
|
|
9
|
-
protected readonly markdownCodeProcessor: TuiHandler<string, string[]>;
|
|
9
|
+
protected readonly markdownCodeProcessor: TuiHandler<string, readonly string[]>;
|
|
10
10
|
protected readonly copy$: Subject<void>;
|
|
11
11
|
protected readonly icon: import("@angular/core").Signal<string>;
|
|
12
|
-
protected readonly processor
|
|
12
|
+
protected readonly processor: import("@angular/core").Signal<never[] | readonly string[]>;
|
|
13
13
|
filename: string;
|
|
14
14
|
set code(code: TuiRawLoaderContent);
|
|
15
15
|
get hasFilename(): boolean;
|
|
@@ -1,9 +1,8 @@
|
|
|
1
|
-
import type { Observable } from 'rxjs';
|
|
2
1
|
import * as i0 from "@angular/core";
|
|
3
2
|
export declare class TuiDocCopy {
|
|
4
3
|
private readonly copy$;
|
|
5
|
-
protected readonly texts
|
|
6
|
-
protected
|
|
4
|
+
protected readonly texts: import("@angular/core").Signal<readonly [copy: string, copied: string] | readonly ["", ""]>;
|
|
5
|
+
protected readonly copied: import("@angular/core").Signal<boolean>;
|
|
7
6
|
protected onClick(): void;
|
|
8
7
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocCopy, never>;
|
|
9
8
|
static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocCopy, "tui-doc-copy", never, {}, {}, never, ["*"], true, never>;
|
|
@@ -1,18 +1,24 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { AfterViewInit } from '@angular/core';
|
|
2
2
|
import { TemplateRef } from '@angular/core';
|
|
3
3
|
import type { AbstractControl } from '@angular/forms';
|
|
4
4
|
import { FormGroup } from '@angular/forms';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
|
-
export declare class TuiDocDemo implements
|
|
6
|
+
export declare class TuiDocDemo implements AfterViewInit {
|
|
7
7
|
private readonly resizable?;
|
|
8
8
|
private readonly content?;
|
|
9
9
|
private readonly resizer?;
|
|
10
10
|
private readonly el;
|
|
11
|
+
private readonly destroyRef;
|
|
12
|
+
private readonly ngZone;
|
|
11
13
|
private readonly locationRef;
|
|
12
14
|
private readonly urlSerializer;
|
|
13
15
|
private readonly urlStateHandler;
|
|
16
|
+
private readonly darkMode;
|
|
14
17
|
protected readonly template: TemplateRef<Record<string, unknown>> | null;
|
|
15
|
-
protected
|
|
18
|
+
protected readonly rendered: import("@angular/core").WritableSignal<boolean>;
|
|
19
|
+
protected theme: import("@angular/core").Signal<"dark" | "light">;
|
|
20
|
+
protected dark: import("@angular/core").WritableSignal<boolean>;
|
|
21
|
+
protected readonly $: import("rxjs").Subscription;
|
|
16
22
|
protected testForm?: FormGroup;
|
|
17
23
|
protected readonly updateOnVariants: readonly ["change", "blur", "submit"];
|
|
18
24
|
protected updateOn: 'blur' | 'change' | 'submit';
|
|
@@ -22,10 +28,10 @@ export declare class TuiDocDemo implements OnInit {
|
|
|
22
28
|
protected readonly texts: [string, string, string];
|
|
23
29
|
control: AbstractControl | null;
|
|
24
30
|
sticky: boolean;
|
|
25
|
-
|
|
31
|
+
ngAfterViewInit(): void;
|
|
26
32
|
protected onResize(): void;
|
|
27
33
|
protected onMouseUp(): void;
|
|
28
|
-
protected onModeChange(
|
|
34
|
+
protected onModeChange(darkMode: boolean): void;
|
|
29
35
|
protected toggleDetails(): void;
|
|
30
36
|
protected changeOpaque(opaque: boolean): void;
|
|
31
37
|
protected updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { OnChanges, OnInit } from '@angular/core';
|
|
2
2
|
import { EventEmitter, TemplateRef } from '@angular/core';
|
|
3
|
-
import {
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export type TuiDocumentationPropertyType = 'input-output' | 'input' | 'output' | null;
|
|
6
6
|
export declare class TuiDocDocumentationPropertyConnector<T> implements OnInit, OnChanges {
|
|
@@ -17,7 +17,7 @@ export declare class TuiDocDocumentationPropertyConnector<T> implements OnInit,
|
|
|
17
17
|
documentationPropertyValues: readonly T[] | null;
|
|
18
18
|
readonly documentationPropertyValueChange: EventEmitter<T>;
|
|
19
19
|
readonly changed$: Subject<void>;
|
|
20
|
-
readonly emits
|
|
20
|
+
readonly emits: import("@angular/core").WritableSignal<number>;
|
|
21
21
|
readonly template: TemplateRef<any>;
|
|
22
22
|
get attrName(): string;
|
|
23
23
|
get shouldShowValues(): boolean;
|
|
@@ -2,8 +2,6 @@ import type { TuiRawLoaderContent } from '@taiga-ui/addon-doc/types';
|
|
|
2
2
|
import type { TuiContext } from '@taiga-ui/cdk/types';
|
|
3
3
|
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
4
4
|
import { PolymorpheusComponent } from '@taiga-ui/polymorpheus';
|
|
5
|
-
import type { Observable } from 'rxjs';
|
|
6
|
-
import { Subject } from 'rxjs';
|
|
7
5
|
import * as i0 from "@angular/core";
|
|
8
6
|
export declare class TuiDocExample {
|
|
9
7
|
private readonly clipboard;
|
|
@@ -21,10 +19,10 @@ export declare class TuiDocExample {
|
|
|
21
19
|
protected readonly defaultTabIndex = 0;
|
|
22
20
|
protected readonly defaultTab: string;
|
|
23
21
|
protected activeItemIndex: number;
|
|
24
|
-
protected readonly copy
|
|
25
|
-
protected readonly loading
|
|
26
|
-
protected readonly processor
|
|
27
|
-
protected readonly lazyComponent
|
|
22
|
+
protected readonly copy: import("@angular/core").Signal<string>;
|
|
23
|
+
protected readonly loading: import("@angular/core").WritableSignal<boolean>;
|
|
24
|
+
protected readonly processor: import("@angular/core").Signal<Record<string, string>>;
|
|
25
|
+
protected readonly lazyComponent: import("@angular/core").Signal<PolymorpheusComponent<unknown> | undefined>;
|
|
28
26
|
id: string | null;
|
|
29
27
|
heading: PolymorpheusContent;
|
|
30
28
|
description: PolymorpheusContent;
|
|
@@ -5,7 +5,7 @@ export declare class TuiDocHeader {
|
|
|
5
5
|
protected readonly icons: import("@taiga-ui/addon-doc/tokens").TuiDocIcons;
|
|
6
6
|
protected readonly logo: import("@taiga-ui/polymorpheus").PolymorpheusContent;
|
|
7
7
|
protected readonly menu: string;
|
|
8
|
-
protected readonly open
|
|
8
|
+
protected readonly open: import("@angular/core").Signal<boolean>;
|
|
9
9
|
protected onClick(): void;
|
|
10
10
|
protected onActiveZone(active: boolean): void;
|
|
11
11
|
static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocHeader, never>;
|
|
@@ -3,6 +3,7 @@ import type { TuiCountryIsoCode, TuiLanguageName } from '@taiga-ui/i18n/types';
|
|
|
3
3
|
import { TuiLanguageSwitcherService } from '@taiga-ui/i18n/utils';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class TuiDocLanguageSwitcher {
|
|
6
|
+
protected readonly icons: import("@taiga-ui/addon-doc/tokens").TuiDocIcons;
|
|
6
7
|
protected readonly switcher: TuiLanguageSwitcherService;
|
|
7
8
|
protected readonly language: FormControl<string | null>;
|
|
8
9
|
protected open: boolean;
|
|
@@ -19,7 +19,7 @@ export declare class TuiDocNavigation {
|
|
|
19
19
|
protected openPagesGroupsArr: boolean[];
|
|
20
20
|
protected active: string;
|
|
21
21
|
protected readonly search: FormControl<string | null>;
|
|
22
|
-
protected readonly filtered
|
|
22
|
+
protected readonly filtered: import("@angular/core").Signal<never[] | readonly (readonly TuiDocRoutePage[])[]>;
|
|
23
23
|
constructor();
|
|
24
24
|
protected get canOpen(): boolean;
|
|
25
25
|
protected get itemsWithoutSections(): TuiDocRoutePages;
|
|
@@ -1,17 +1,16 @@
|
|
|
1
1
|
import type { Provider } from '@angular/core';
|
|
2
|
-
import { InjectionToken } from '@angular/core';
|
|
3
2
|
import type { TuiDocRoutePages } from '@taiga-ui/addon-doc/types';
|
|
4
3
|
import type { Observable } from 'rxjs';
|
|
5
4
|
/**
|
|
6
5
|
* Page title
|
|
7
6
|
*/
|
|
8
|
-
export declare const NAVIGATION_TITLE: InjectionToken<Observable<string>>;
|
|
7
|
+
export declare const NAVIGATION_TITLE: import("@angular/core").InjectionToken<Observable<string>>;
|
|
9
8
|
/**
|
|
10
9
|
* Navigation sections labels for search
|
|
11
10
|
*/
|
|
12
|
-
export declare const NAVIGATION_LABELS: InjectionToken<readonly string[]>;
|
|
11
|
+
export declare const NAVIGATION_LABELS: import("@angular/core").InjectionToken<readonly string[]>;
|
|
13
12
|
/**
|
|
14
13
|
* Navigation pages
|
|
15
14
|
*/
|
|
16
|
-
export declare const NAVIGATION_ITEMS: InjectionToken<readonly TuiDocRoutePages[]>;
|
|
15
|
+
export declare const NAVIGATION_ITEMS: import("@angular/core").InjectionToken<readonly TuiDocRoutePages[]>;
|
|
17
16
|
export declare const NAVIGATION_PROVIDERS: Provider[];
|
|
@@ -2,6 +2,8 @@ import type { QueryList } from '@angular/core';
|
|
|
2
2
|
import { TuiDocPageTabConnector } from './page-tab.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TuiDocPage {
|
|
5
|
+
protected readonly tabs: Record<string, import("@taiga-ui/polymorpheus").PolymorpheusContent>;
|
|
6
|
+
protected readonly supportLanguage: Set<string>;
|
|
5
7
|
protected readonly defaultTabs: readonly string[];
|
|
6
8
|
protected readonly from: RegExp;
|
|
7
9
|
protected readonly to = "_";
|
|
@@ -1,7 +1,10 @@
|
|
|
1
1
|
import type { Provider } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import type { ActivatedRouteSnapshot } from '@angular/router';
|
|
3
|
+
import type { TuiHandler } from '@taiga-ui/cdk/types';
|
|
4
|
+
import type { PolymorpheusContent } from '@taiga-ui/polymorpheus';
|
|
5
|
+
export declare const TUI_DOC_TABS: import("@angular/core").InjectionToken<TuiHandler<ActivatedRouteSnapshot, Record<string, PolymorpheusContent>>>;
|
|
3
6
|
/**
|
|
4
7
|
* Array if related page titles
|
|
5
8
|
*/
|
|
6
|
-
export declare const PAGE_SEE_ALSO: InjectionToken<readonly string[]>;
|
|
9
|
+
export declare const PAGE_SEE_ALSO: import("@angular/core").InjectionToken<readonly string[]>;
|
|
7
10
|
export declare const PAGE_PROVIDERS: Provider[];
|
|
@@ -1,6 +1,10 @@
|
|
|
1
|
-
import { NgForOf, NgIf, NgSwitch, NgSwitchCase } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
1
|
+
import { Location, NgForOf, NgIf, NgSwitch, NgSwitchCase } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { ActivatedRoute, UrlSerializer } from '@angular/router';
|
|
5
|
+
import { TUI_DOC_URL_STATE_HANDLER } from '@taiga-ui/addon-doc/tokens';
|
|
6
|
+
import { tuiCoerceValue } from '@taiga-ui/addon-doc/utils';
|
|
7
|
+
import { tuiIsNumber } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
4
8
|
import { TuiIcon } from '@taiga-ui/core/components/icon';
|
|
5
9
|
import { TuiTextfield } from '@taiga-ui/core/components/textfield';
|
|
6
10
|
import { TuiDataListWrapper } from '@taiga-ui/kit/components/data-list-wrapper';
|
|
@@ -16,15 +20,58 @@ import * as i2 from "@taiga-ui/kit/components/data-list-wrapper";
|
|
|
16
20
|
import * as i3 from "@taiga-ui/legacy/components/input-number";
|
|
17
21
|
import * as i4 from "@taiga-ui/core/components/textfield";
|
|
18
22
|
import * as i5 from "@taiga-ui/legacy/directives/textfield-controller";
|
|
23
|
+
const SERIALIZED_SUFFIX = '$';
|
|
19
24
|
class TuiDocAPIItem {
|
|
20
25
|
constructor() {
|
|
26
|
+
this.locationRef = inject(Location);
|
|
27
|
+
this.activatedRoute = inject(ActivatedRoute);
|
|
28
|
+
this.urlSerializer = inject(UrlSerializer);
|
|
29
|
+
this.urlStateHandler = inject(TUI_DOC_URL_STATE_HANDLER);
|
|
21
30
|
this.name = '';
|
|
22
31
|
this.type = '';
|
|
23
32
|
this.items = [];
|
|
24
33
|
this.valueChange = new EventEmitter();
|
|
25
34
|
}
|
|
35
|
+
ngOnInit() {
|
|
36
|
+
this.parseParams(this.activatedRoute.snapshot.queryParams);
|
|
37
|
+
}
|
|
38
|
+
onValueChange(value) {
|
|
39
|
+
this.value = value;
|
|
40
|
+
this.valueChange.emit(value);
|
|
41
|
+
this.setQueryParam(value);
|
|
42
|
+
}
|
|
43
|
+
clearBrackets(value) {
|
|
44
|
+
return value.replaceAll(/[()[\]]/g, '');
|
|
45
|
+
}
|
|
46
|
+
parseParams(params) {
|
|
47
|
+
const name = this.clearBrackets(this.name);
|
|
48
|
+
const propertyValue = params[name];
|
|
49
|
+
const propertyValueWithSuffix = params[`${name}${SERIALIZED_SUFFIX}`];
|
|
50
|
+
if (!propertyValue && !propertyValueWithSuffix) {
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
let value = !!propertyValueWithSuffix && this.items
|
|
54
|
+
? this.items[propertyValueWithSuffix]
|
|
55
|
+
: tuiCoerceValue(propertyValue);
|
|
56
|
+
if (this.type === 'string' && tuiIsNumber(value)) {
|
|
57
|
+
value = value.toString();
|
|
58
|
+
}
|
|
59
|
+
this.onValueChange(value);
|
|
60
|
+
}
|
|
61
|
+
setQueryParam(value) {
|
|
62
|
+
const tree = this.urlSerializer.parse(this.locationRef.path());
|
|
63
|
+
const isValueAvailableByKey = value instanceof Object;
|
|
64
|
+
const computedValue = isValueAvailableByKey && this.items ? this.items.indexOf(value) : value;
|
|
65
|
+
const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';
|
|
66
|
+
const propName = this.clearBrackets(this.name) + suffix;
|
|
67
|
+
tree.queryParams = {
|
|
68
|
+
...tree.queryParams,
|
|
69
|
+
[propName]: computedValue,
|
|
70
|
+
};
|
|
71
|
+
this.locationRef.go(this.urlStateHandler(tree));
|
|
72
|
+
}
|
|
26
73
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocAPIItem, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
27
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocAPIItem, isStandalone: true, selector: "tr[tuiDocAPIItem]", inputs: { name: "name", type: "type", value: "value", items: "items" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<td class=\"t-td\">\n <code\n class=\"t-name\"\n [class.t-name_banana]=\"name.startsWith('[(')\"\n [class.t-name_input]=\"name.startsWith('[')\"\n [class.t-name_output]=\"name.startsWith('(')\"\n >\n {{ name }}\n </code>\n <ng-content />\n</td>\n<td class=\"t-td\">\n <code class=\"t-type\">\n <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n <a\n *ngIf=\"item.reference; else default\"\n target=\"_blank\"\n class=\"t-reference\"\n [attr.href]=\"item.reference\"\n >\n {{ item.type }}\n <tui-icon\n icon=\"@tui.external-link\"\n [style.font-size.rem]=\"1\"\n />\n </a>\n <ng-template #default>\n {{ item.type }}\n </ng-template>\n <span *ngIf=\"!last\"> | </span>\n </ng-container>\n </code>\n</td>\n<td class=\"t-td\">\n <tui-textfield\n *ngIf=\"items.length; else noItems\"\n tuiChevron\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [content]=\"content\"\n [tuiTextfieldCleaner]=\"type.includes('null')\"\n >\n <select\n placeholder=\"null\"\n tuiTextfield\n [ngModel]=\"value ?? null\"\n (ngModelChange)=\"
|
|
74
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocAPIItem, isStandalone: true, selector: "tr[tuiDocAPIItem]", inputs: { name: "name", type: "type", value: "value", items: "items" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<td class=\"t-td\">\n <code\n class=\"t-name\"\n [class.t-name_banana]=\"name.startsWith('[(')\"\n [class.t-name_input]=\"name.startsWith('[')\"\n [class.t-name_output]=\"name.startsWith('(')\"\n >\n {{ name }}\n </code>\n <ng-content />\n</td>\n<td class=\"t-td\">\n <code class=\"t-type\">\n <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n <a\n *ngIf=\"item.reference; else default\"\n target=\"_blank\"\n class=\"t-reference\"\n [attr.href]=\"item.reference\"\n >\n {{ item.type }}\n <tui-icon\n icon=\"@tui.external-link\"\n [style.font-size.rem]=\"1\"\n />\n </a>\n <ng-template #default>\n {{ item.type }}\n </ng-template>\n <span *ngIf=\"!last\"> | </span>\n </ng-container>\n </code>\n</td>\n<td class=\"t-td\">\n <tui-textfield\n *ngIf=\"items.length; else noItems\"\n tuiChevron\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [content]=\"content\"\n [tuiTextfieldCleaner]=\"type.includes('null')\"\n >\n <select\n placeholder=\"null\"\n tuiTextfield\n [ngModel]=\"value ?? null\"\n (ngModelChange)=\"onValueChange($event)\"\n ></select>\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n [itemContent]=\"content\"\n [items]=\"items\"\n />\n </tui-textfield>\n <ng-template\n #content\n let-data\n >\n <code [style.margin]=\"0\">{{ data | tuiInspectAny }}</code>\n </ng-template>\n <ng-template #noItems>\n <ng-container [ngSwitch]=\"type\">\n <input\n *ngSwitchCase=\"'boolean'\"\n tuiSwitch\n type=\"checkbox\"\n [id]=\"name\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onValueChange($event)\"\n />\n\n <tui-textfield\n *ngSwitchCase=\"'string'\"\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n >\n <input\n tuiTextfield\n [id]=\"name\"\n [ngModel]=\"value || ''\"\n (ngModelChange)=\"onValueChange($event)\"\n />\n </tui-textfield>\n\n <tui-input-number\n *ngSwitchCase=\"'number'\"\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [nativeId]=\"name\"\n [ngModel]=\"value\"\n [step]=\"1\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onValueChange($event || 0)\"\n />\n </ng-container>\n </ng-template>\n</td>\n", styles: [":host{box-shadow:inset 0 -1px var(--tui-border-normal)}.t-td{padding:1.5rem 2rem 1.5rem 0;vertical-align:top}.t-td:last-child{padding-inline-end:0;text-align:end}.t-name{display:flex!important;min-block-size:1.5rem;inline-size:-webkit-fit-content;inline-size:-moz-fit-content;inline-size:fit-content;margin:0 0 .5rem!important;-webkit-text-fill-color:var(--tui-background-accent-2-pressed)}.t-name_input{-webkit-text-fill-color:var(--tui-text-negative)}.t-name_banana{-webkit-text-fill-color:var(--tui-text-action)}.t-name_output{-webkit-text-fill-color:var(--tui-status-info)}.t-type{flex-wrap:wrap;align-items:center;justify-content:flex-start;min-block-size:1.5rem;margin:0!important}.t-reference{display:inline-flex;color:var(--tui-text-action);text-decoration:none;align-items:center;justify-content:center;gap:3px}.t-input{min-inline-size:10rem;margin-block-start:-.625rem}@media screen and (max-width: 47.9625em){:host{gap:1rem;padding:1rem 0}.t-td{padding:0}.t-td:last-child{text-align:start}.t-input{margin:0}}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: TuiChevron, selector: "[tuiChevron]", inputs: ["tuiChevron"] }, { kind: "component", type: i2.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items", "disabledItemHandler", "emptyContent", "size", "itemContent"], outputs: ["itemClick"] }, { kind: "pipe", type: TuiDocTypeReferencePipe, name: "tuiDocTypeReference" }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "ngmodule", type: TuiInputNumberModule }, { kind: "component", type: i3.TuiInputNumberComponent, selector: "tui-input-number", inputs: ["min", "max", "step"] }, { kind: "directive", type: i3.TuiInputNumberDirective, selector: "tui-input-number" }, { kind: "pipe", type: TuiInspectPipe, name: "tuiInspectAny" }, { kind: "component", type: TuiSwitch, selector: "input[type=\"checkbox\"][tuiSwitch]", inputs: ["size", "showIcons"] }, { kind: "component", type: i4.TuiSelect, selector: "select[tuiTextfield]", inputs: ["placeholder"] }, { kind: "component", type: i4.TuiTextfieldComponent, selector: "tui-textfield", inputs: ["stringify", "content", "filler"] }, { kind: "directive", type: i4.TuiTextfieldDirective, selector: "input[tuiTextfield]" }, { kind: "directive", type: i4.TuiTextfieldOptionsDirective, selector: "[tuiTextfieldAppearance],[tuiTextfieldSize],[tuiTextfieldCleaner]", inputs: ["tuiTextfieldAppearance", "tuiTextfieldSize", "tuiTextfieldCleaner"] }, { kind: "directive", type: i4.TuiTextfieldDropdownDirective, selector: "ng-template[tuiTextfieldDropdown]" }, { kind: "ngmodule", type: TuiTextfieldControllerModule }, { kind: "directive", type: i5.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { kind: "directive", type: i5.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { kind: "directive", type: i5.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
28
75
|
}
|
|
29
76
|
export { TuiDocAPIItem };
|
|
30
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocAPIItem, decorators: [{
|
|
@@ -44,7 +91,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
44
91
|
TuiSwitch,
|
|
45
92
|
TuiTextfield,
|
|
46
93
|
TuiTextfieldControllerModule,
|
|
47
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<td class=\"t-td\">\n <code\n class=\"t-name\"\n [class.t-name_banana]=\"name.startsWith('[(')\"\n [class.t-name_input]=\"name.startsWith('[')\"\n [class.t-name_output]=\"name.startsWith('(')\"\n >\n {{ name }}\n </code>\n <ng-content />\n</td>\n<td class=\"t-td\">\n <code class=\"t-type\">\n <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n <a\n *ngIf=\"item.reference; else default\"\n target=\"_blank\"\n class=\"t-reference\"\n [attr.href]=\"item.reference\"\n >\n {{ item.type }}\n <tui-icon\n icon=\"@tui.external-link\"\n [style.font-size.rem]=\"1\"\n />\n </a>\n <ng-template #default>\n {{ item.type }}\n </ng-template>\n <span *ngIf=\"!last\"> | </span>\n </ng-container>\n </code>\n</td>\n<td class=\"t-td\">\n <tui-textfield\n *ngIf=\"items.length; else noItems\"\n tuiChevron\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [content]=\"content\"\n [tuiTextfieldCleaner]=\"type.includes('null')\"\n >\n <select\n placeholder=\"null\"\n tuiTextfield\n [ngModel]=\"value ?? null\"\n (ngModelChange)=\"
|
|
94
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<td class=\"t-td\">\n <code\n class=\"t-name\"\n [class.t-name_banana]=\"name.startsWith('[(')\"\n [class.t-name_input]=\"name.startsWith('[')\"\n [class.t-name_output]=\"name.startsWith('(')\"\n >\n {{ name }}\n </code>\n <ng-content />\n</td>\n<td class=\"t-td\">\n <code class=\"t-type\">\n <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n <a\n *ngIf=\"item.reference; else default\"\n target=\"_blank\"\n class=\"t-reference\"\n [attr.href]=\"item.reference\"\n >\n {{ item.type }}\n <tui-icon\n icon=\"@tui.external-link\"\n [style.font-size.rem]=\"1\"\n />\n </a>\n <ng-template #default>\n {{ item.type }}\n </ng-template>\n <span *ngIf=\"!last\"> | </span>\n </ng-container>\n </code>\n</td>\n<td class=\"t-td\">\n <tui-textfield\n *ngIf=\"items.length; else noItems\"\n tuiChevron\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [content]=\"content\"\n [tuiTextfieldCleaner]=\"type.includes('null')\"\n >\n <select\n placeholder=\"null\"\n tuiTextfield\n [ngModel]=\"value ?? null\"\n (ngModelChange)=\"onValueChange($event)\"\n ></select>\n <tui-data-list-wrapper\n *tuiTextfieldDropdown\n [itemContent]=\"content\"\n [items]=\"items\"\n />\n </tui-textfield>\n <ng-template\n #content\n let-data\n >\n <code [style.margin]=\"0\">{{ data | tuiInspectAny }}</code>\n </ng-template>\n <ng-template #noItems>\n <ng-container [ngSwitch]=\"type\">\n <input\n *ngSwitchCase=\"'boolean'\"\n tuiSwitch\n type=\"checkbox\"\n [id]=\"name\"\n [ngModel]=\"value\"\n (ngModelChange)=\"onValueChange($event)\"\n />\n\n <tui-textfield\n *ngSwitchCase=\"'string'\"\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n >\n <input\n tuiTextfield\n [id]=\"name\"\n [ngModel]=\"value || ''\"\n (ngModelChange)=\"onValueChange($event)\"\n />\n </tui-textfield>\n\n <tui-input-number\n *ngSwitchCase=\"'number'\"\n tuiTextfieldSize=\"m\"\n class=\"t-input\"\n [nativeId]=\"name\"\n [ngModel]=\"value\"\n [step]=\"1\"\n [tuiTextfieldLabelOutside]=\"true\"\n (ngModelChange)=\"onValueChange($event || 0)\"\n />\n </ng-container>\n </ng-template>\n</td>\n", styles: [":host{box-shadow:inset 0 -1px var(--tui-border-normal)}.t-td{padding:1.5rem 2rem 1.5rem 0;vertical-align:top}.t-td:last-child{padding-inline-end:0;text-align:end}.t-name{display:flex!important;min-block-size:1.5rem;inline-size:-webkit-fit-content;inline-size:-moz-fit-content;inline-size:fit-content;margin:0 0 .5rem!important;-webkit-text-fill-color:var(--tui-background-accent-2-pressed)}.t-name_input{-webkit-text-fill-color:var(--tui-text-negative)}.t-name_banana{-webkit-text-fill-color:var(--tui-text-action)}.t-name_output{-webkit-text-fill-color:var(--tui-status-info)}.t-type{flex-wrap:wrap;align-items:center;justify-content:flex-start;min-block-size:1.5rem;margin:0!important}.t-reference{display:inline-flex;color:var(--tui-text-action);text-decoration:none;align-items:center;justify-content:center;gap:3px}.t-input{min-inline-size:10rem;margin-block-start:-.625rem}@media screen and (max-width: 47.9625em){:host{gap:1rem;padding:1rem 0}.t-td{padding:0}.t-td:last-child{text-align:start}.t-input{margin:0}}\n"] }]
|
|
48
95
|
}], propDecorators: { name: [{
|
|
49
96
|
type: Input
|
|
50
97
|
}], type: [{
|
|
@@ -56,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
56
103
|
}], valueChange: [{
|
|
57
104
|
type: Output
|
|
58
105
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-item.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/api/api-item.component.ts","../../../../../projects/addon-doc/components/api/api-item.template.html"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,YAAY,EAAC,MAAM,iBAAiB,CAAC;AACtE,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EACL,MAAM,GACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,WAAW,EAAC,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAC,OAAO,EAAC,MAAM,gCAAgC,CAAC;AACvD,OAAO,EAAC,YAAY,EAAC,MAAM,qCAAqC,CAAC;AACjE,OAAO,EAAC,kBAAkB,EAAC,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAC,SAAS,EAAC,MAAM,iCAAiC,CAAC;AAC1D,OAAO,EAAC,UAAU,EAAC,MAAM,kCAAkC,CAAC;AAC5D,OAAO,EAAC,oBAAoB,EAAC,MAAM,0CAA0C,CAAC;AAC9E,OAAO,EAAC,4BAA4B,EAAC,MAAM,kDAAkD,CAAC;AAE9F,OAAO,EAAC,cAAc,EAAC,MAAM,qCAAqC,CAAC;AACnE,OAAO,EAAC,uBAAuB,EAAC,MAAM,4CAA4C,CAAC;;;;;;;AAEnF,MAuBa,aAAa;IAvB1B;QAyBW,SAAI,GAAG,EAAE,CAAC;QAGV,SAAI,GAAG,EAAE,CAAC;QAMV,UAAK,GAAiB,EAAE,CAAC;QAGhB,gBAAW,GAAG,IAAI,YAAY,EAAK,CAAC;KACvD;+GAfY,aAAa;mGAAb,aAAa,8LC3C1B,m9FAiGA,sjCDzEQ,WAAW,8+BACX,OAAO,mHACP,IAAI,6FACJ,QAAQ,6EACR,YAAY,qFACZ,UAAU,mSAEV,uBAAuB,4DACvB,OAAO,oFACP,oBAAoB,wOACpB,cAAc,sDACd,SAAS,ovBAET,4BAA4B;;SAMvB,aAAa;4FAAb,aAAa;kBAvBzB,SAAS;iCACM,IAAI,YACN,mBAAmB,WACpB;wBACL,WAAW;wBACX,OAAO;wBACP,IAAI;wBACJ,QAAQ;wBACR,YAAY;wBACZ,UAAU;wBACV,kBAAkB;wBAClB,uBAAuB;wBACvB,OAAO;wBACP,oBAAoB;wBACpB,cAAc;wBACd,SAAS;wBACT,YAAY;wBACZ,4BAA4B;qBAC/B,mBAGgB,uBAAuB,CAAC,MAAM;8BAIxC,IAAI;sBADV,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIU,WAAW;sBAD1B,MAAM","sourcesContent":["import {NgForOf, NgIf, NgSwitch, NgSwitchCase} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TuiTextfield} from '@taiga-ui/core/components/textfield';\nimport {TuiDataListWrapper} from '@taiga-ui/kit/components/data-list-wrapper';\nimport {TuiSwitch} from '@taiga-ui/kit/components/switch';\nimport {TuiChevron} from '@taiga-ui/kit/directives/chevron';\nimport {TuiInputNumberModule} from '@taiga-ui/legacy/components/input-number';\nimport {TuiTextfieldControllerModule} from '@taiga-ui/legacy/directives/textfield-controller';\n\nimport {TuiInspectPipe} from '../documentation/pipes/inspect.pipe';\nimport {TuiDocTypeReferencePipe} from '../documentation/pipes/type-reference.pipe';\n\n@Component({\n    standalone: true,\n    selector: 'tr[tuiDocAPIItem]',\n    imports: [\n        FormsModule,\n        NgForOf,\n        NgIf,\n        NgSwitch,\n        NgSwitchCase,\n        TuiChevron,\n        TuiDataListWrapper,\n        TuiDocTypeReferencePipe,\n        TuiIcon,\n        TuiInputNumberModule,\n        TuiInspectPipe,\n        TuiSwitch,\n        TuiTextfield,\n        TuiTextfieldControllerModule,\n    ],\n    templateUrl: './api-item.template.html',\n    styleUrls: ['./api-item.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiDocAPIItem<T> {\n    @Input()\n    public name = '';\n\n    @Input()\n    public type = '';\n\n    @Input()\n    public value?: T;\n\n    @Input()\n    public items: readonly T[] = [];\n\n    @Output()\n    public readonly valueChange = new EventEmitter<T>();\n}\n","<td class=\"t-td\">\n    <code\n        class=\"t-name\"\n        [class.t-name_banana]=\"name.startsWith('[(')\"\n        [class.t-name_input]=\"name.startsWith('[')\"\n        [class.t-name_output]=\"name.startsWith('(')\"\n    >\n        {{ name }}\n    </code>\n    <ng-content />\n</td>\n<td class=\"t-td\">\n    <code class=\"t-type\">\n        <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n            <a\n                *ngIf=\"item.reference; else default\"\n                target=\"_blank\"\n                class=\"t-reference\"\n                [attr.href]=\"item.reference\"\n            >\n                {{ item.type }}\n                <tui-icon\n                    icon=\"@tui.external-link\"\n                    [style.font-size.rem]=\"1\"\n                />\n            </a>\n            <ng-template #default>\n                {{ item.type }}\n            </ng-template>\n            <span *ngIf=\"!last\">&nbsp;|&nbsp;</span>\n        </ng-container>\n    </code>\n</td>\n<td class=\"t-td\">\n    <tui-textfield\n        *ngIf=\"items.length; else noItems\"\n        tuiChevron\n        tuiTextfieldSize=\"m\"\n        class=\"t-input\"\n        [content]=\"content\"\n        [tuiTextfieldCleaner]=\"type.includes('null')\"\n    >\n        <select\n            placeholder=\"null\"\n            tuiTextfield\n            [ngModel]=\"value ?? null\"\n            (ngModelChange)=\"valueChange.emit($event)\"\n        ></select>\n        <tui-data-list-wrapper\n            *tuiTextfieldDropdown\n            [itemContent]=\"content\"\n            [items]=\"items\"\n        />\n    </tui-textfield>\n    <ng-template\n        #content\n        let-data\n    >\n        <code [style.margin]=\"0\">{{ data | tuiInspectAny }}</code>\n    </ng-template>\n    <ng-template #noItems>\n        <ng-container [ngSwitch]=\"type\">\n            <input\n                *ngSwitchCase=\"'boolean'\"\n                tuiSwitch\n                type=\"checkbox\"\n                [id]=\"name\"\n                [ngModel]=\"value\"\n                (ngModelChange)=\"valueChange.emit($event)\"\n            />\n\n            <tui-textfield\n                *ngSwitchCase=\"'string'\"\n                tuiTextfieldSize=\"m\"\n                class=\"t-input\"\n            >\n                <input\n                    tuiTextfield\n                    [id]=\"name\"\n                    [ngModel]=\"value || ''\"\n                    (ngModelChange)=\"valueChange.emit($event)\"\n                />\n            </tui-textfield>\n\n            <tui-input-number\n                *ngSwitchCase=\"'number'\"\n                tuiTextfieldSize=\"m\"\n                class=\"t-input\"\n                [nativeId]=\"name\"\n                [ngModel]=\"value\"\n                [step]=\"1\"\n                [tuiTextfieldLabelOutside]=\"true\"\n                (ngModelChange)=\"valueChange.emit($event || 0)\"\n            />\n        </ng-container>\n    </ng-template>\n</td>\n"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api-item.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/api/api-item.component.ts","../../../../../projects/addon-doc/components/api/api-item.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Location, NgForOf, NgIf, NgSwitch, NgSwitchCase} from '@angular/common';\nimport type {OnInit} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport type {Params} from '@angular/router';\nimport {ActivatedRoute, UrlSerializer} from '@angular/router';\nimport {TUI_DOC_URL_STATE_HANDLER} from '@taiga-ui/addon-doc/tokens';\nimport {tuiCoerceValue} from '@taiga-ui/addon-doc/utils';\nimport {tuiIsNumber} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiIcon} from '@taiga-ui/core/components/icon';\nimport {TuiTextfield} from '@taiga-ui/core/components/textfield';\nimport {TuiDataListWrapper} from '@taiga-ui/kit/components/data-list-wrapper';\nimport {TuiSwitch} from '@taiga-ui/kit/components/switch';\nimport {TuiChevron} from '@taiga-ui/kit/directives/chevron';\nimport {TuiInputNumberModule} from '@taiga-ui/legacy/components/input-number';\nimport {TuiTextfieldControllerModule} from '@taiga-ui/legacy/directives/textfield-controller';\n\nimport {TuiInspectPipe} from '../documentation/pipes/inspect.pipe';\nimport {TuiDocTypeReferencePipe} from '../documentation/pipes/type-reference.pipe';\n\nconst SERIALIZED_SUFFIX = '$';\n\n@Component({\n    standalone: true,\n    selector: 'tr[tuiDocAPIItem]',\n    imports: [\n        FormsModule,\n        NgForOf,\n        NgIf,\n        NgSwitch,\n        NgSwitchCase,\n        TuiChevron,\n        TuiDataListWrapper,\n        TuiDocTypeReferencePipe,\n        TuiIcon,\n        TuiInputNumberModule,\n        TuiInspectPipe,\n        TuiSwitch,\n        TuiTextfield,\n        TuiTextfieldControllerModule,\n    ],\n    templateUrl: './api-item.template.html',\n    styleUrls: ['./api-item.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiDocAPIItem<T> implements OnInit {\n    private readonly locationRef = inject(Location);\n    private readonly activatedRoute = inject(ActivatedRoute);\n    private readonly urlSerializer = inject(UrlSerializer);\n    private readonly urlStateHandler = inject(TUI_DOC_URL_STATE_HANDLER);\n\n    @Input()\n    public name = '';\n\n    @Input()\n    public type = '';\n\n    @Input()\n    public value?: T;\n\n    @Input()\n    public items: readonly T[] = [];\n\n    @Output()\n    public readonly valueChange = new EventEmitter<T>();\n\n    public ngOnInit(): void {\n        this.parseParams(this.activatedRoute.snapshot.queryParams);\n    }\n\n    public onValueChange(value: T): void {\n        this.value = value;\n        this.valueChange.emit(value);\n        this.setQueryParam(value);\n    }\n\n    private clearBrackets(value: string): string {\n        return value.replaceAll(/[()[\\]]/g, '');\n    }\n\n    private parseParams(params: Params): void {\n        const name = this.clearBrackets(this.name);\n        const propertyValue: string | undefined = params[name];\n        const propertyValueWithSuffix: number | string | undefined =\n            params[`${name}${SERIALIZED_SUFFIX}`];\n\n        if (!propertyValue && !propertyValueWithSuffix) {\n            return;\n        }\n\n        let value =\n            !!propertyValueWithSuffix && this.items\n                ? this.items[propertyValueWithSuffix as number]\n                : tuiCoerceValue(propertyValue);\n\n        if (this.type === 'string' && tuiIsNumber(value)) {\n            value = value.toString();\n        }\n\n        this.onValueChange(value as T);\n    }\n\n    private setQueryParam(value: T | boolean | number | string | null): void {\n        const tree = this.urlSerializer.parse(this.locationRef.path());\n\n        const isValueAvailableByKey = value instanceof Object;\n        const computedValue =\n            isValueAvailableByKey && this.items ? this.items.indexOf(value as T) : value;\n\n        const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';\n        const propName = this.clearBrackets(this.name) + suffix;\n\n        tree.queryParams = {\n            ...tree.queryParams,\n            [propName]: computedValue,\n        };\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n}\n","<td class=\"t-td\">\n    <code\n        class=\"t-name\"\n        [class.t-name_banana]=\"name.startsWith('[(')\"\n        [class.t-name_input]=\"name.startsWith('[')\"\n        [class.t-name_output]=\"name.startsWith('(')\"\n    >\n        {{ name }}\n    </code>\n    <ng-content />\n</td>\n<td class=\"t-td\">\n    <code class=\"t-type\">\n        <ng-container *ngFor=\"let item of type | tuiDocTypeReference; let last = last\">\n            <a\n                *ngIf=\"item.reference; else default\"\n                target=\"_blank\"\n                class=\"t-reference\"\n                [attr.href]=\"item.reference\"\n            >\n                {{ item.type }}\n                <tui-icon\n                    icon=\"@tui.external-link\"\n                    [style.font-size.rem]=\"1\"\n                />\n            </a>\n            <ng-template #default>\n                {{ item.type }}\n            </ng-template>\n            <span *ngIf=\"!last\">&nbsp;|&nbsp;</span>\n        </ng-container>\n    </code>\n</td>\n<td class=\"t-td\">\n    <tui-textfield\n        *ngIf=\"items.length; else noItems\"\n        tuiChevron\n        tuiTextfieldSize=\"m\"\n        class=\"t-input\"\n        [content]=\"content\"\n        [tuiTextfieldCleaner]=\"type.includes('null')\"\n    >\n        <select\n            placeholder=\"null\"\n            tuiTextfield\n            [ngModel]=\"value ?? null\"\n            (ngModelChange)=\"onValueChange($event)\"\n        ></select>\n        <tui-data-list-wrapper\n            *tuiTextfieldDropdown\n            [itemContent]=\"content\"\n            [items]=\"items\"\n        />\n    </tui-textfield>\n    <ng-template\n        #content\n        let-data\n    >\n        <code [style.margin]=\"0\">{{ data | tuiInspectAny }}</code>\n    </ng-template>\n    <ng-template #noItems>\n        <ng-container [ngSwitch]=\"type\">\n            <input\n                *ngSwitchCase=\"'boolean'\"\n                tuiSwitch\n                type=\"checkbox\"\n                [id]=\"name\"\n                [ngModel]=\"value\"\n                (ngModelChange)=\"onValueChange($event)\"\n            />\n\n            <tui-textfield\n                *ngSwitchCase=\"'string'\"\n                tuiTextfieldSize=\"m\"\n                class=\"t-input\"\n            >\n                <input\n                    tuiTextfield\n                    [id]=\"name\"\n                    [ngModel]=\"value || ''\"\n                    (ngModelChange)=\"onValueChange($event)\"\n                />\n            </tui-textfield>\n\n            <tui-input-number\n                *ngSwitchCase=\"'number'\"\n                tuiTextfieldSize=\"m\"\n                class=\"t-input\"\n                [nativeId]=\"name\"\n                [ngModel]=\"value\"\n                [step]=\"1\"\n                [tuiTextfieldLabelOutside]=\"true\"\n                (ngModelChange)=\"onValueChange($event || 0)\"\n            />\n        </ng-container>\n    </ng-template>\n</td>\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ClipboardModule } from '@angular/cdk/clipboard';
|
|
2
|
-
import {
|
|
2
|
+
import { isPlatformServer, NgForOf, NgIf } from '@angular/common';
|
|
3
3
|
import { ChangeDetectionStrategy, Component, inject, Input, PLATFORM_ID, } from '@angular/core';
|
|
4
4
|
import { toSignal } from '@angular/core/rxjs-interop';
|
|
5
5
|
import { TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR, TUI_DOC_ICONS, } from '@taiga-ui/addon-doc/tokens';
|
|
@@ -17,7 +17,7 @@ class TuiDocCode {
|
|
|
17
17
|
this.markdownCodeProcessor = inject(TUI_DOC_EXAMPLE_MARKDOWN_CODE_PROCESSOR);
|
|
18
18
|
this.copy$ = new Subject();
|
|
19
19
|
this.icon = toSignal(this.copy$.pipe(switchMap(() => timer(2000).pipe(map(() => this.icons.copy), startWith(this.icons.check)))), { initialValue: this.icons.copy });
|
|
20
|
-
this.processor
|
|
20
|
+
this.processor = toSignal(this.rawLoader$$.pipe(switchMap(tuiRawLoad), map((value) => this.markdownCodeProcessor(value))), { initialValue: [] });
|
|
21
21
|
this.filename = '';
|
|
22
22
|
}
|
|
23
23
|
set code(code) {
|
|
@@ -27,18 +27,18 @@ class TuiDocCode {
|
|
|
27
27
|
return !!this.filename;
|
|
28
28
|
}
|
|
29
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocCode, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocCode, isStandalone: true, selector: "tui-doc-code", inputs: { filename: "filename", code: "code" }, host: { properties: { "style.visibility": "isServer ? \"hidden\" : \"visible\"", "class._has-filename": "hasFilename" } }, ngImport: i0, template: "<p\n *ngIf=\"filename\"\n class=\"t-header\"\n>\n {{ filename }}\n</p>\n<pre\n *ngFor=\"let content of processor
|
|
30
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocCode, isStandalone: true, selector: "tui-doc-code", inputs: { filename: "filename", code: "code" }, host: { properties: { "style.visibility": "isServer ? \"hidden\" : \"visible\"", "class._has-filename": "hasFilename" } }, ngImport: i0, template: "<p\n *ngIf=\"filename\"\n class=\"t-header\"\n>\n {{ filename }}\n</p>\n<pre\n *ngFor=\"let content of processor()\"\n class=\"t-code\"\n>\n <code [lineNumbers]=\"true\" [highlight]=\"content\"></code>\n <div class=\"t-code-actions\">\n <button type=\"button\"\n tuiIconButton\n appearance=\"icon\"\n size=\"xs\"\n class=\"t-copy-button\"\n [iconStart]=\"icon()\"\n [cdkCopyToClipboard]=\"content\"\n (click)=\"copy$.next()\"\n >\n </button>\n <ng-content />\n </div>\n</pre>\n", styles: [":host{display:block}.t-header{font:var(--tui-font-text-s);font-weight:700}.t-header+.t-code{border-radius:.25rem}.t-code{position:relative;margin:0;white-space:normal;outline:1px solid var(--tui-border-normal)}.t-code ::ng-deep .hljs-ln{inline-size:100%}.t-code ::ng-deep .hljs-ln .hljs-ln-numbers{inline-size:1rem}.t-code ::ng-deep .hljs-ln td{white-space:pre}.t-code ::ng-deep .hljs-ln td:not(.hljs-ln-numbers):hover{outline:1px solid var(--tui-border-normal);border-radius:.25rem}.t-code+.t-code{margin-top:1rem}.t-code-actions{position:absolute;top:.75rem;right:.75rem;display:flex;justify-content:center;align-items:center;flex-direction:row-reverse}@media screen and (max-width: 47.9625em){.t-code-actions{padding:.3125rem;border-radius:.25rem;border:1px solid var(--tui-border-normal)}}.t-copy-button::ng-deep+*:not(:empty){margin-right:.375rem}.hljs:not(:empty){font:var(--tui-font-text-m);font-size:.875rem;padding:1.5rem 2rem;font-family:monospace;word-wrap:break-word;white-space:pre-wrap}@media all and (-webkit-min-device-pixel-ratio: 0) and (-webkit-min-device-pixel-ratio: 0),all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.hljs:not(:empty)::-webkit-scrollbar,.hljs:not(:empty)::-webkit-scrollbar-thumb{inline-size:1rem;block-size:1rem;border-radius:6.25rem;background-clip:padding-box;border:.375rem solid transparent}.hljs:not(:empty)::-webkit-scrollbar{background-color:transparent}.hljs:not(:empty)::-webkit-scrollbar-thumb{background-color:var(--tui-background-neutral-1-hover)}.hljs:not(:empty)::-webkit-scrollbar-thumb:hover{background-color:var(--tui-background-neutral-1-pressed)}.hljs:not(:empty)::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-tertiary)}}@media screen and (max-width: 47.9625em){.hljs:not(:empty){padding:1rem}}.t-code-actions,.hljs:not(:empty){background:var(--tui-background-base)}@supports (background: color-mix(in srgb,var(--tui-background-base),#222 2%)){.t-code-actions,.hljs:not(:empty){background:color-mix(in srgb,var(--tui-background-base),#222 2%)}}\n"], dependencies: [{ kind: "ngmodule", type: ClipboardModule }, { kind: "directive", type: i1.CdkCopyToClipboard, selector: "[cdkCopyToClipboard]", inputs: ["cdkCopyToClipboard", "cdkCopyToClipboardAttempts"], outputs: ["cdkCopyToClipboardCopied"] }, { kind: "directive", type: Highlight, selector: "[highlight]", inputs: ["highlight", "languages", "lineNumbers"], outputs: ["highlighted"] }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
31
31
|
}
|
|
32
32
|
export { TuiDocCode };
|
|
33
33
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocCode, decorators: [{
|
|
34
34
|
type: Component,
|
|
35
|
-
args: [{ standalone: true, selector: 'tui-doc-code', imports: [
|
|
35
|
+
args: [{ standalone: true, selector: 'tui-doc-code', imports: [ClipboardModule, Highlight, NgForOf, NgIf, TuiButton], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
36
36
|
'[style.visibility]': 'isServer ? "hidden" : "visible"',
|
|
37
37
|
'[class._has-filename]': 'hasFilename',
|
|
38
|
-
}, template: "<p\n *ngIf=\"filename\"\n class=\"t-header\"\n>\n {{ filename }}\n</p>\n<pre\n *ngFor=\"let content of processor
|
|
38
|
+
}, template: "<p\n *ngIf=\"filename\"\n class=\"t-header\"\n>\n {{ filename }}\n</p>\n<pre\n *ngFor=\"let content of processor()\"\n class=\"t-code\"\n>\n <code [lineNumbers]=\"true\" [highlight]=\"content\"></code>\n <div class=\"t-code-actions\">\n <button type=\"button\"\n tuiIconButton\n appearance=\"icon\"\n size=\"xs\"\n class=\"t-copy-button\"\n [iconStart]=\"icon()\"\n [cdkCopyToClipboard]=\"content\"\n (click)=\"copy$.next()\"\n >\n </button>\n <ng-content />\n </div>\n</pre>\n", styles: [":host{display:block}.t-header{font:var(--tui-font-text-s);font-weight:700}.t-header+.t-code{border-radius:.25rem}.t-code{position:relative;margin:0;white-space:normal;outline:1px solid var(--tui-border-normal)}.t-code ::ng-deep .hljs-ln{inline-size:100%}.t-code ::ng-deep .hljs-ln .hljs-ln-numbers{inline-size:1rem}.t-code ::ng-deep .hljs-ln td{white-space:pre}.t-code ::ng-deep .hljs-ln td:not(.hljs-ln-numbers):hover{outline:1px solid var(--tui-border-normal);border-radius:.25rem}.t-code+.t-code{margin-top:1rem}.t-code-actions{position:absolute;top:.75rem;right:.75rem;display:flex;justify-content:center;align-items:center;flex-direction:row-reverse}@media screen and (max-width: 47.9625em){.t-code-actions{padding:.3125rem;border-radius:.25rem;border:1px solid var(--tui-border-normal)}}.t-copy-button::ng-deep+*:not(:empty){margin-right:.375rem}.hljs:not(:empty){font:var(--tui-font-text-m);font-size:.875rem;padding:1.5rem 2rem;font-family:monospace;word-wrap:break-word;white-space:pre-wrap}@media all and (-webkit-min-device-pixel-ratio: 0) and (-webkit-min-device-pixel-ratio: 0),all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.hljs:not(:empty)::-webkit-scrollbar,.hljs:not(:empty)::-webkit-scrollbar-thumb{inline-size:1rem;block-size:1rem;border-radius:6.25rem;background-clip:padding-box;border:.375rem solid transparent}.hljs:not(:empty)::-webkit-scrollbar{background-color:transparent}.hljs:not(:empty)::-webkit-scrollbar-thumb{background-color:var(--tui-background-neutral-1-hover)}.hljs:not(:empty)::-webkit-scrollbar-thumb:hover{background-color:var(--tui-background-neutral-1-pressed)}.hljs:not(:empty)::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-tertiary)}}@media screen and (max-width: 47.9625em){.hljs:not(:empty){padding:1rem}}.t-code-actions,.hljs:not(:empty){background:var(--tui-background-base)}@supports (background: color-mix(in srgb,var(--tui-background-base),#222 2%)){.t-code-actions,.hljs:not(:empty){background:color-mix(in srgb,var(--tui-background-base),#222 2%)}}\n"] }]
|
|
39
39
|
}], propDecorators: { filename: [{
|
|
40
40
|
type: Input
|
|
41
41
|
}], code: [{
|
|
42
42
|
type: Input
|
|
43
43
|
}] } });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9jb2RlL2luZGV4LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL2NvbXBvbmVudHMvY29kZS9pbmRleC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSx3QkFBd0IsQ0FBQztBQUN2RCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ2hFLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixLQUFLLEVBQ0wsV0FBVyxHQUNkLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNwRCxPQUFPLEVBQ0gsdUNBQXVDLEVBQ3ZDLGFBQWEsR0FDaEIsTUFBTSw0QkFBNEIsQ0FBQztBQUVwQyxPQUFPLEVBQUMsVUFBVSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFFckQsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzNELE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUMxQyxPQUFPLEVBQUMsZUFBZSxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxNQUFNLENBQUM7OztBQUVoRixNQVlhLFVBQVU7SUFadkI7UUFhcUIsVUFBSyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM5QixnQkFBVyxHQUFHLElBQUksZUFBZSxDQUFzQixFQUFFLENBQUMsQ0FBQztRQUV6RCxhQUFRLEdBQUcsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUM7UUFFakQsMEJBQXFCLEdBQ3BDLE1BQU0sQ0FBQyx1Q0FBdUMsQ0FBQyxDQUFDO1FBRWpDLFVBQUssR0FBRyxJQUFJLE9BQU8sRUFBUSxDQUFDO1FBRTVCLFNBQUksR0FBRyxRQUFRLENBQzlCLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUNYLFNBQVMsQ0FBQyxHQUFHLEVBQUUsQ0FDWCxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxDQUNaLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxFQUMxQixTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FDOUIsQ0FDSixDQUNKLEVBQ0QsRUFBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUMsQ0FDbEMsQ0FBQztRQUVpQixjQUFTLEdBQUcsUUFBUSxDQUNuQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FDakIsU0FBUyxDQUFDLFVBQVUsQ0FBQyxFQUNyQixHQUFHLENBQUMsQ0FBQyxLQUFhLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUM1RCxFQUNELEVBQUMsWUFBWSxFQUFFLEVBQUUsRUFBQyxDQUNyQixDQUFDO1FBR0ssYUFBUSxHQUFHLEVBQUUsQ0FBQztLQVV4QjtJQVJHLElBQ1csSUFBSSxDQUFDLElBQXlCO1FBQ3JDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUFXLFdBQVc7UUFDbEIsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztJQUMzQixDQUFDOytHQXpDUSxVQUFVO21HQUFWLFVBQVUsbVBDakN2QixnbUJBeUJBLDJqRUREYyxlQUFlLDBOQUFFLFNBQVMscUlBQUUsT0FBTyxtSEFBRSxJQUFJLDZGQUFFLFNBQVM7O1NBU3JELFVBQVU7NEZBQVYsVUFBVTtrQkFadEIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sY0FBYyxXQUNmLENBQUMsZUFBZSxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFNBQVMsQ0FBQyxtQkFHOUMsdUJBQXVCLENBQUMsTUFBTSxRQUN6Qzt3QkFDRixvQkFBb0IsRUFBRSxpQ0FBaUM7d0JBQ3ZELHVCQUF1QixFQUFFLGFBQWE7cUJBQ3pDOzhCQWtDTSxRQUFRO3NCQURkLEtBQUs7Z0JBSUssSUFBSTtzQkFEZCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDbGlwYm9hcmRNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9jbGlwYm9hcmQnO1xuaW1wb3J0IHtpc1BsYXRmb3JtU2VydmVyLCBOZ0Zvck9mLCBOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgaW5qZWN0LFxuICAgIElucHV0LFxuICAgIFBMQVRGT1JNX0lELFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dG9TaWduYWx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7XG4gICAgVFVJX0RPQ19FWEFNUExFX01BUktET1dOX0NPREVfUFJPQ0VTU09SLFxuICAgIFRVSV9ET0NfSUNPTlMsXG59IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1kb2MvdG9rZW5zJztcbmltcG9ydCB0eXBlIHtUdWlSYXdMb2FkZXJDb250ZW50fSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tZG9jL3R5cGVzJztcbmltcG9ydCB7dHVpUmF3TG9hZH0gZnJvbSAnQHRhaWdhLXVpL2FkZG9uLWRvYy91dGlscyc7XG5pbXBvcnQgdHlwZSB7VHVpSGFuZGxlcn0gZnJvbSAnQHRhaWdhLXVpL2Nkay90eXBlcyc7XG5pbXBvcnQge1R1aUJ1dHRvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHtIaWdobGlnaHR9IGZyb20gJ25neC1oaWdobGlnaHRqcyc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdCwgbWFwLCBzdGFydFdpdGgsIFN1YmplY3QsIHN3aXRjaE1hcCwgdGltZXJ9IGZyb20gJ3J4anMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAndHVpLWRvYy1jb2RlJyxcbiAgICBpbXBvcnRzOiBbQ2xpcGJvYXJkTW9kdWxlLCBIaWdobGlnaHQsIE5nRm9yT2YsIE5nSWYsIFR1aUJ1dHRvbl0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2luZGV4Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2luZGV4Lmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBob3N0OiB7XG4gICAgICAgICdbc3R5bGUudmlzaWJpbGl0eV0nOiAnaXNTZXJ2ZXIgPyBcImhpZGRlblwiIDogXCJ2aXNpYmxlXCInLFxuICAgICAgICAnW2NsYXNzLl9oYXMtZmlsZW5hbWVdJzogJ2hhc0ZpbGVuYW1lJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlEb2NDb2RlIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGljb25zID0gaW5qZWN0KFRVSV9ET0NfSUNPTlMpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgcmF3TG9hZGVyJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFR1aVJhd0xvYWRlckNvbnRlbnQ+KCcnKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBpc1NlcnZlciA9IGlzUGxhdGZvcm1TZXJ2ZXIoaW5qZWN0KFBMQVRGT1JNX0lEKSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgbWFya2Rvd25Db2RlUHJvY2Vzc29yOiBUdWlIYW5kbGVyPHN0cmluZywgcmVhZG9ubHkgc3RyaW5nW10+ID1cbiAgICAgICAgaW5qZWN0KFRVSV9ET0NfRVhBTVBMRV9NQVJLRE9XTl9DT0RFX1BST0NFU1NPUik7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29weSQgPSBuZXcgU3ViamVjdDx2b2lkPigpO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGljb24gPSB0b1NpZ25hbChcbiAgICAgICAgdGhpcy5jb3B5JC5waXBlKFxuICAgICAgICAgICAgc3dpdGNoTWFwKCgpID0+XG4gICAgICAgICAgICAgICAgdGltZXIoMjAwMCkucGlwZShcbiAgICAgICAgICAgICAgICAgICAgbWFwKCgpID0+IHRoaXMuaWNvbnMuY29weSksXG4gICAgICAgICAgICAgICAgICAgIHN0YXJ0V2l0aCh0aGlzLmljb25zLmNoZWNrKSxcbiAgICAgICAgICAgICAgICApLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgKSxcbiAgICAgICAge2luaXRpYWxWYWx1ZTogdGhpcy5pY29ucy5jb3B5fSxcbiAgICApO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHByb2Nlc3NvciA9IHRvU2lnbmFsKFxuICAgICAgICB0aGlzLnJhd0xvYWRlciQkLnBpcGUoXG4gICAgICAgICAgICBzd2l0Y2hNYXAodHVpUmF3TG9hZCksXG4gICAgICAgICAgICBtYXAoKHZhbHVlOiBzdHJpbmcpID0+IHRoaXMubWFya2Rvd25Db2RlUHJvY2Vzc29yKHZhbHVlKSksXG4gICAgICAgICksXG4gICAgICAgIHtpbml0aWFsVmFsdWU6IFtdfSxcbiAgICApO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgZmlsZW5hbWUgPSAnJztcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNldCBjb2RlKGNvZGU6IFR1aVJhd0xvYWRlckNvbnRlbnQpIHtcbiAgICAgICAgdGhpcy5yYXdMb2FkZXIkJC5uZXh0KGNvZGUpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXQgaGFzRmlsZW5hbWUoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiAhIXRoaXMuZmlsZW5hbWU7XG4gICAgfVxufVxuIiwiPHBcbiAgICAqbmdJZj1cImZpbGVuYW1lXCJcbiAgICBjbGFzcz1cInQtaGVhZGVyXCJcbj5cbiAgICB7eyBmaWxlbmFtZSB9fVxuPC9wPlxuPHByZVxuICAgICpuZ0Zvcj1cImxldCBjb250ZW50IG9mIHByb2Nlc3NvcigpXCJcbiAgICBjbGFzcz1cInQtY29kZVwiXG4+XG4gICAgPGNvZGUgW2xpbmVOdW1iZXJzXT1cInRydWVcIiBbaGlnaGxpZ2h0XT1cImNvbnRlbnRcIj48L2NvZGU+XG4gICAgPGRpdiBjbGFzcz1cInQtY29kZS1hY3Rpb25zXCI+XG4gICAgICAgIDxidXR0b24gdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICB0dWlJY29uQnV0dG9uXG4gICAgICAgICAgICBhcHBlYXJhbmNlPVwiaWNvblwiXG4gICAgICAgICAgICBzaXplPVwieHNcIlxuICAgICAgICAgICAgY2xhc3M9XCJ0LWNvcHktYnV0dG9uXCJcbiAgICAgICAgICAgIFtpY29uU3RhcnRdPVwiaWNvbigpXCJcbiAgICAgICAgICAgIFtjZGtDb3B5VG9DbGlwYm9hcmRdPVwiY29udGVudFwiXG4gICAgICAgICAgICAoY2xpY2spPVwiY29weSQubmV4dCgpXCJcbiAgICAgICAgPlxuICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICA8L2Rpdj5cbjwvcHJlPlxuIl19
|
|
@@ -1,9 +1,7 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { AsyncPipe, NgIf } from '@angular/common';
|
|
1
|
+
import { NgIf } from '@angular/common';
|
|
3
2
|
import { ChangeDetectionStrategy, Component, inject } from '@angular/core';
|
|
3
|
+
import { toSignal } from '@angular/core/rxjs-interop';
|
|
4
4
|
import { TUI_FALSE_HANDLER } from '@taiga-ui/cdk/constants';
|
|
5
|
-
import { TuiLet } from '@taiga-ui/cdk/directives/let';
|
|
6
|
-
import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
|
|
7
5
|
import { TuiButton } from '@taiga-ui/core/components/button';
|
|
8
6
|
import { TUI_COPY_TEXTS } from '@taiga-ui/kit/tokens';
|
|
9
7
|
import { map, startWith, Subject, switchMap, timer } from 'rxjs';
|
|
@@ -12,23 +10,20 @@ const COPIED_TIMEOUT = 1500;
|
|
|
12
10
|
class TuiDocCopy {
|
|
13
11
|
constructor() {
|
|
14
12
|
this.copy$ = new Subject();
|
|
15
|
-
this.texts
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
this.texts = toSignal(inject(TUI_COPY_TEXTS), {
|
|
14
|
+
initialValue: ['', ''],
|
|
15
|
+
});
|
|
16
|
+
this.copied = toSignal(this.copy$.pipe(switchMap(() => timer(COPIED_TIMEOUT).pipe(map(TUI_FALSE_HANDLER), startWith(true)))), { initialValue: false });
|
|
19
17
|
}
|
|
20
18
|
onClick() {
|
|
21
19
|
this.copy$.next();
|
|
22
20
|
}
|
|
23
21
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocCopy, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
24
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocCopy, isStandalone: true, selector: "tui-doc-copy", ngImport: i0, template: "<button\n
|
|
22
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocCopy, isStandalone: true, selector: "tui-doc-copy", ngImport: i0, template: "<button\n appearance=\"\"\n size=\"s\"\n tuiButton\n type=\"button\"\n class=\"t-copy\"\n (click)=\"onClick()\"\n>\n <span class=\"t-content\">\n <span\n class=\"t-initial\"\n [attr.data-text]=\"copied() ? '' : texts()[0]\"\n >\n <ng-container *ngIf=\"!copied()\">\n <ng-content />\n </ng-container>\n </span>\n {{ copied() ? texts()[1] : '' }}\n </span>\n</button>\n", styles: [":host{position:relative;display:inline-block;vertical-align:middle;border-radius:var(--tui-radius-m)}.t-copy{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;inline-size:100%;block-size:100%;color:var(--tui-text-primary);background:var(--tui-background-base);overflow:hidden}.t-copy:hover{background:var(--tui-background-base-alt)}.t-initial{white-space:nowrap}.t-initial:empty:before{content:attr(data-text)}.t-content{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;flex-direction:column;text-align:center;line-height:2rem}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
25
23
|
}
|
|
26
|
-
__decorate([
|
|
27
|
-
tuiPure
|
|
28
|
-
], TuiDocCopy.prototype, "copied$", null);
|
|
29
24
|
export { TuiDocCopy };
|
|
30
25
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocCopy, decorators: [{
|
|
31
26
|
type: Component,
|
|
32
|
-
args: [{ standalone: true, selector: 'tui-doc-copy', imports: [
|
|
33
|
-
}]
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
27
|
+
args: [{ standalone: true, selector: 'tui-doc-copy', imports: [NgIf, TuiButton], changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n appearance=\"\"\n size=\"s\"\n tuiButton\n type=\"button\"\n class=\"t-copy\"\n (click)=\"onClick()\"\n>\n <span class=\"t-content\">\n <span\n class=\"t-initial\"\n [attr.data-text]=\"copied() ? '' : texts()[0]\"\n >\n <ng-container *ngIf=\"!copied()\">\n <ng-content />\n </ng-container>\n </span>\n {{ copied() ? texts()[1] : '' }}\n </span>\n</button>\n", styles: [":host{position:relative;display:inline-block;vertical-align:middle;border-radius:var(--tui-radius-m)}.t-copy{transition-property:background;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;inline-size:100%;block-size:100%;color:var(--tui-text-primary);background:var(--tui-background-base);overflow:hidden}.t-copy:hover{background:var(--tui-background-base-alt)}.t-initial{white-space:nowrap}.t-initial:empty:before{content:attr(data-text)}.t-content{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;display:flex;flex-direction:column;text-align:center;line-height:2rem}\n"] }]
|
|
28
|
+
}] });
|
|
29
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2MvY29tcG9uZW50cy9jb3B5L2luZGV4LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tZG9jL2NvbXBvbmVudHMvY29weS9pbmRleC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxJQUFJLEVBQUMsTUFBTSxpQkFBaUIsQ0FBQztBQUNyQyxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDcEQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0seUJBQXlCLENBQUM7QUFDMUQsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzNELE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNwRCxPQUFPLEVBQUMsR0FBRyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLE1BQU0sQ0FBQzs7QUFFL0QsTUFBTSxjQUFjLEdBQUcsSUFBSSxDQUFDO0FBRTVCLE1BUWEsVUFBVTtJQVJ2QjtRQVNxQixVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUUxQixVQUFLLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsRUFBRTtZQUN4RCxZQUFZLEVBQUUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFVO1NBQ2xDLENBQUMsQ0FBQztRQUVnQixXQUFNLEdBQUcsUUFBUSxDQUNoQyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FDWCxTQUFTLENBQUMsR0FBRyxFQUFFLENBQ1gsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsaUJBQWlCLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FDdEUsQ0FDSixFQUNELEVBQUMsWUFBWSxFQUFFLEtBQUssRUFBQyxDQUN4QixDQUFDO0tBS0w7SUFIYSxPQUFPO1FBQ2IsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN0QixDQUFDOytHQWxCUSxVQUFVO21HQUFWLFVBQVUsd0VDbEJ2QixnZUFvQkEsMHRCRFBjLElBQUksNkZBQUUsU0FBUzs7U0FLaEIsVUFBVTs0RkFBVixVQUFVO2tCQVJ0QixTQUFTO2lDQUNNLElBQUksWUFDTixjQUFjLFdBQ2YsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFDLG1CQUdULHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nSWZ9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3RvU2lnbmFsfSBmcm9tICdAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcCc7XG5pbXBvcnQge1RVSV9GQUxTRV9IQU5ETEVSfSBmcm9tICdAdGFpZ2EtdWkvY2RrL2NvbnN0YW50cyc7XG5pbXBvcnQge1R1aUJ1dHRvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHtUVUlfQ09QWV9URVhUU30gZnJvbSAnQHRhaWdhLXVpL2tpdC90b2tlbnMnO1xuaW1wb3J0IHttYXAsIHN0YXJ0V2l0aCwgU3ViamVjdCwgc3dpdGNoTWFwLCB0aW1lcn0gZnJvbSAncnhqcyc7XG5cbmNvbnN0IENPUElFRF9USU1FT1VUID0gMTUwMDtcblxuQENvbXBvbmVudCh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ3R1aS1kb2MtY29weScsXG4gICAgaW1wb3J0czogW05nSWYsIFR1aUJ1dHRvbl0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2luZGV4Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2luZGV4Lmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRG9jQ29weSB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBjb3B5JCA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgdGV4dHMgPSB0b1NpZ25hbChpbmplY3QoVFVJX0NPUFlfVEVYVFMpLCB7XG4gICAgICAgIGluaXRpYWxWYWx1ZTogWycnLCAnJ10gYXMgY29uc3QsXG4gICAgfSk7XG5cbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29waWVkID0gdG9TaWduYWwoXG4gICAgICAgIHRoaXMuY29weSQucGlwZShcbiAgICAgICAgICAgIHN3aXRjaE1hcCgoKSA9PlxuICAgICAgICAgICAgICAgIHRpbWVyKENPUElFRF9USU1FT1VUKS5waXBlKG1hcChUVUlfRkFMU0VfSEFORExFUiksIHN0YXJ0V2l0aCh0cnVlKSksXG4gICAgICAgICAgICApLFxuICAgICAgICApLFxuICAgICAgICB7aW5pdGlhbFZhbHVlOiBmYWxzZX0sXG4gICAgKTtcblxuICAgIHByb3RlY3RlZCBvbkNsaWNrKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNvcHkkLm5leHQoKTtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgYXBwZWFyYW5jZT1cIlwiXG4gICAgc2l6ZT1cInNcIlxuICAgIHR1aUJ1dHRvblxuICAgIHR5cGU9XCJidXR0b25cIlxuICAgIGNsYXNzPVwidC1jb3B5XCJcbiAgICAoY2xpY2spPVwib25DbGljaygpXCJcbj5cbiAgICA8c3BhbiBjbGFzcz1cInQtY29udGVudFwiPlxuICAgICAgICA8c3BhblxuICAgICAgICAgICAgY2xhc3M9XCJ0LWluaXRpYWxcIlxuICAgICAgICAgICAgW2F0dHIuZGF0YS10ZXh0XT1cImNvcGllZCgpID8gJycgOiB0ZXh0cygpWzBdXCJcbiAgICAgICAgPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cIiFjb3BpZWQoKVwiPlxuICAgICAgICAgICAgICAgIDxuZy1jb250ZW50IC8+XG4gICAgICAgICAgICA8L25nLWNvbnRhaW5lcj5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgICB7eyBjb3BpZWQoKSA/IHRleHRzKClbMV0gOiAnJyB9fVxuICAgIDwvc3Bhbj5cbjwvYnV0dG9uPlxuIl19
|