@taiga-ui/addon-doc 3.13.0 → 3.14.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.
@@ -1,53 +1,42 @@
1
1
  import { Location } from '@angular/common';
2
- import { AfterViewInit, OnInit, Renderer2, TemplateRef } from '@angular/core';
3
- import { AbstractControl, FormControl, FormGroup } from '@angular/forms';
2
+ import { ElementRef, OnInit, TemplateRef } from '@angular/core';
3
+ import { AbstractControl, FormGroup } from '@angular/forms';
4
4
  import { UrlSerializer } from '@angular/router';
5
- import { TuiDestroyService } from '@taiga-ui/cdk';
6
5
  import { TuiBrightness } from '@taiga-ui/core';
7
6
  import { Subject } from 'rxjs';
8
7
  import * as i0 from "@angular/core";
9
- export declare class TuiDocDemoComponent implements OnInit, AfterViewInit {
8
+ export declare class TuiDocDemoComponent implements OnInit {
10
9
  readonly isMobile: boolean;
11
- private readonly destroy$;
12
- private readonly renderer;
10
+ private readonly elementRef;
13
11
  private readonly locationRef;
14
12
  private readonly urlSerializer;
15
13
  readonly texts: [string, string, string];
14
+ private readonly resizeable?;
16
15
  private readonly content?;
17
- private readonly wrapper?;
18
- private readonly resizerText?;
19
- private readonly isBrowser;
20
- private initialX;
21
- private wrapperWidth;
16
+ private readonly resizer?;
22
17
  control: AbstractControl | null;
23
18
  readonly template: TemplateRef<Record<string, unknown>> | null;
24
19
  testForm?: FormGroup;
25
- updateOnVariants: string[];
20
+ readonly updateOnVariants: readonly ["change", "blur", "submit"];
26
21
  updateOn: 'blur' | 'change' | 'submit';
27
22
  expanded: boolean;
28
23
  opaque: boolean;
29
- modeControl: FormControl;
30
24
  mode: TuiBrightness | null;
25
+ sandboxWidth: number;
31
26
  readonly change$: Subject<void>;
32
27
  readonly items: readonly TuiBrightness[];
33
- constructor(isMobile: boolean, destroy$: TuiDestroyService, renderer: Renderer2, platformId: Record<string, unknown>, locationRef: Location, urlSerializer: UrlSerializer, texts: [string, string, string]);
28
+ constructor(isMobile: boolean, elementRef: ElementRef<HTMLElement>, locationRef: Location, urlSerializer: UrlSerializer, texts: [string, string, string]);
34
29
  onResize(): void;
30
+ onMouseUp(): void;
35
31
  ngOnInit(): void;
36
- ngAfterViewInit(): void;
37
- setResizerTextContent(): void;
38
- onDragStart(event: MouseEvent): void;
39
- onDragContinues(event: MouseEvent): void;
40
- onDragEnd(): void;
32
+ onModeChange(mode: TuiBrightness | null): void;
41
33
  toggleDetails(): void;
42
34
  updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void;
43
- private createForm;
44
- private resizeContent;
45
- private setWidthWrapper;
35
+ updateWidth(width?: number): void;
36
+ private get delta();
46
37
  private updateUrl;
38
+ private createForm;
47
39
  private getUrlTree;
48
- private getPaddingOfWrapper;
49
- private getResizeButtonWidth;
50
- private updateSandboxWidth;
51
- static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocDemoComponent, [null, { self: true; }, null, null, null, null, null]>;
40
+ static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocDemoComponent, never>;
52
41
  static ɵcmp: i0.ɵɵComponentDeclaration<TuiDocDemoComponent, "tui-doc-demo", never, { "control": "control"; }, {}, ["template"], ["*"]>;
53
42
  }
@@ -4,10 +4,10 @@ import * as i2 from "@angular/common";
4
4
  import * as i3 from "@angular/forms";
5
5
  import * as i4 from "@angular/router";
6
6
  import * as i5 from "@taiga-ui/core";
7
- import * as i6 from "@taiga-ui/cdk";
8
- import * as i7 from "@taiga-ui/kit";
7
+ import * as i6 from "@taiga-ui/kit";
8
+ import * as i7 from "@taiga-ui/cdk";
9
9
  export declare class TuiDocDemoModule {
10
10
  static ɵfac: i0.ɵɵFactoryDeclaration<TuiDocDemoModule, never>;
11
- static ɵmod: i0.ɵɵNgModuleDeclaration<TuiDocDemoModule, [typeof i1.TuiDocDemoComponent], [typeof i2.CommonModule, typeof i3.ReactiveFormsModule, typeof i3.FormsModule, typeof i4.RouterModule, typeof i5.TuiLinkModule, typeof i6.TuiDragModule, typeof i5.TuiButtonModule, typeof i7.TuiSelectModule, typeof i5.TuiExpandModule, typeof i5.TuiGroupModule, typeof i5.TuiTooltipModule, typeof i5.TuiModeModule, typeof i7.TuiRadioBlockModule, typeof i7.TuiCheckboxLabeledModule, typeof i5.TuiSvgModule, typeof i7.TuiDataListWrapperModule, typeof i5.TuiDataListModule, typeof i5.TuiTextfieldControllerModule, typeof i5.TuiHintModule], [typeof i1.TuiDocDemoComponent]>;
11
+ static ɵmod: i0.ɵɵNgModuleDeclaration<TuiDocDemoModule, [typeof i1.TuiDocDemoComponent], [typeof i2.CommonModule, typeof i3.ReactiveFormsModule, typeof i3.FormsModule, typeof i4.RouterModule, typeof i5.TuiLinkModule, typeof i5.TuiButtonModule, typeof i6.TuiSelectModule, typeof i5.TuiExpandModule, typeof i5.TuiGroupModule, typeof i5.TuiTooltipModule, typeof i5.TuiModeModule, typeof i6.TuiRadioBlockModule, typeof i6.TuiCheckboxLabeledModule, typeof i5.TuiSvgModule, typeof i6.TuiDataListWrapperModule, typeof i5.TuiDataListModule, typeof i5.TuiTextfieldControllerModule, typeof i5.TuiHintModule, typeof i7.TuiResizerModule], [typeof i1.TuiDocDemoComponent]>;
12
12
  static ɵinj: i0.ɵɵInjectorDeclaration<TuiDocDemoModule>;
13
13
  }
@@ -20,7 +20,7 @@ export class TuiDocCodeComponent {
20
20
  }
21
21
  }
22
22
  TuiDocCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocCodeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
23
- TuiDocCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDocCodeComponent, selector: "tui-doc-code", inputs: { filename: "filename", code: "code" }, host: { properties: { "class._has-filename": "this.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$ | async\"\n class=\"t-code\"\n><code [lineNumbers]=\"true\" [highlight]=\"content\"></code></pre>\n", styles: [":host{display:block}.t-header{font:var(--tui-font-text-s);font-weight:bold}.t-code{margin:0}.t-code+.t-code{margin-top:1rem}.hljs:not(:empty){font:var(--tui-font-text-m);padding:1.5rem 2rem;font-family:monospace;background:var(--tui-clear-disabled);word-wrap:break-word;white-space:pre-wrap}@media all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.hljs:not(:empty)::-webkit-scrollbar,.hljs:not(:empty)::-webkit-scrollbar-thumb{width:1rem;height:1rem;border-radius:6.25rem;background-clip:padding-box;border:2.667rem solid transparent}.hljs:not(:empty)::-webkit-scrollbar{background-color:transparent}.hljs:not(:empty)::-webkit-scrollbar-thumb{background-color:var(--tui-clear-hover)}.hljs:not(:empty)::-webkit-scrollbar-thumb:hover{background-color:var(--tui-clear-active)}.hljs:not(:empty)::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-03)}}:host._has-filename .hljs:not(:empty){border-radius:.75rem}:host-context(tui-root._mobile) .hljs:not(:empty){padding:1rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.Highlight, selector: "[highlight]", inputs: ["highlight", "languages", "lineNumbers"], outputs: ["highlighted"] }], pipes: { "async": i1.AsyncPipe } });
23
+ TuiDocCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDocCodeComponent, selector: "tui-doc-code", inputs: { filename: "filename", code: "code" }, host: { properties: { "class._has-filename": "this.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$ | async\"\n class=\"t-code\"\n><code [lineNumbers]=\"true\" [highlight]=\"content\"></code></pre>\n", styles: [":host{display:block}.t-header{font:var(--tui-font-text-s);font-weight:bold}.t-code{margin:0}.t-code+.t-code{margin-top:1rem}.hljs:not(:empty){font:var(--tui-font-text-m);padding:1.5rem 2rem;font-family:monospace;background:var(--tui-clear);word-wrap:break-word;white-space:pre-wrap}@media all and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm){.hljs:not(:empty)::-webkit-scrollbar,.hljs:not(:empty)::-webkit-scrollbar-thumb{width:1rem;height:1rem;border-radius:6.25rem;background-clip:padding-box;border:2.667rem solid transparent}.hljs:not(:empty)::-webkit-scrollbar{background-color:transparent}.hljs:not(:empty)::-webkit-scrollbar-thumb{background-color:var(--tui-clear-hover)}.hljs:not(:empty)::-webkit-scrollbar-thumb:hover{background-color:var(--tui-clear-active)}.hljs:not(:empty)::-webkit-scrollbar-thumb:active{background-color:var(--tui-text-03)}}:host._has-filename .hljs:not(:empty){border-radius:.75rem}:host-context(tui-root._mobile) .hljs:not(:empty){padding:1rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.Highlight, selector: "[highlight]", inputs: ["highlight", "languages", "lineNumbers"], outputs: ["highlighted"] }], pipes: { "async": i1.AsyncPipe } });
24
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocCodeComponent, decorators: [{
25
25
  type: Component,
26
26
  args: [{
@@ -1,12 +1,11 @@
1
1
  import { __decorate } from "tslib";
2
- import { isPlatformBrowser, Location } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, ContentChild, forwardRef, HostListener, Inject, Input, PLATFORM_ID, Renderer2, Self, TemplateRef, ViewChild, } from '@angular/core';
4
- import { FormControl, FormGroup } from '@angular/forms';
2
+ import { Location } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, forwardRef, HostListener, Inject, Input, TemplateRef, ViewChild, } from '@angular/core';
4
+ import { FormGroup } from '@angular/forms';
5
5
  import { UrlSerializer } from '@angular/router';
6
- import { TUI_IS_MOBILE, tuiDebounce, TuiDestroyService, tuiPx } from '@taiga-ui/cdk';
6
+ import { TUI_IS_MOBILE, tuiClamp, TuiDestroyService, tuiPure, tuiPx, TuiResizeableDirective, } from '@taiga-ui/cdk';
7
7
  import { TuiModeDirective } from '@taiga-ui/core';
8
8
  import { Subject } from 'rxjs';
9
- import { startWith, takeUntil } from 'rxjs/operators';
10
9
  import { TUI_DOC_DEMO_TEXTS } from '../../tokens/i18n';
11
10
  import * as i0 from "@angular/core";
12
11
  import * as i1 from "@taiga-ui/core";
@@ -15,75 +14,40 @@ import * as i3 from "@angular/router";
15
14
  import * as i4 from "@angular/common";
16
15
  import * as i5 from "@angular/forms";
17
16
  import * as i6 from "@taiga-ui/cdk";
18
- const MIN_COMPONENT_WIDTH = 104;
17
+ const MIN_WIDTH = 160;
19
18
  export class TuiDocDemoComponent {
20
- constructor(isMobile, destroy$, renderer, platformId, locationRef, urlSerializer, texts) {
19
+ constructor(isMobile, elementRef, locationRef, urlSerializer, texts) {
21
20
  this.isMobile = isMobile;
22
- this.destroy$ = destroy$;
23
- this.renderer = renderer;
21
+ this.elementRef = elementRef;
24
22
  this.locationRef = locationRef;
25
23
  this.urlSerializer = urlSerializer;
26
24
  this.texts = texts;
27
- this.initialX = 0;
28
- this.wrapperWidth = 0;
29
25
  this.control = null;
30
26
  this.template = null;
31
27
  this.updateOnVariants = [`change`, `blur`, `submit`];
32
- this.updateOn = `change`;
28
+ this.updateOn = this.updateOnVariants[0];
33
29
  this.expanded = false;
34
30
  this.opaque = true;
35
- this.modeControl = new FormControl();
36
- this.mode = null;
31
+ this.mode = this.getUrlTree().queryParams.tuiMode || null;
32
+ this.sandboxWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10);
37
33
  this.change$ = new Subject();
38
34
  this.items = [`onLight`, `onDark`];
39
- this.isBrowser = isPlatformBrowser(platformId);
40
- const parsedMode = locationRef.path().match(/tuiMode=(onDark|onLight)/);
41
- if (parsedMode !== null && parsedMode.length > 0) {
42
- this.modeControl.setValue(parsedMode[1]);
43
- }
44
35
  }
45
36
  onResize() {
46
- this.setResizerTextContent();
37
+ this.updateWidth();
38
+ this.onMouseUp();
39
+ }
40
+ onMouseUp() {
41
+ this.updateUrl(this.mode, this.sandboxWidth);
47
42
  }
48
43
  ngOnInit() {
49
44
  this.createForm();
45
+ this.updateWidth(this.sandboxWidth + this.delta);
50
46
  }
51
- ngAfterViewInit() {
52
- this.modeControl.valueChanges
53
- .pipe(startWith(this.modeControl.value), takeUntil(this.destroy$))
54
- .subscribe(mode => {
55
- this.updateUrl(mode);
56
- const wrapperWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10) +
57
- this.getPaddingOfWrapper() +
58
- this.getResizeButtonWidth();
59
- if (!Number.isNaN(wrapperWidth)) {
60
- this.wrapperWidth = wrapperWidth;
61
- this.setWidthWrapper(tuiPx(wrapperWidth));
62
- }
63
- this.setResizerTextContent();
64
- this.mode = mode;
65
- this.change$.next();
66
- });
67
- }
68
- setResizerTextContent() {
69
- if (!this.content || !this.resizerText) {
70
- return;
71
- }
72
- this.resizerText.nativeElement.textContent = (this.content.nativeElement.offsetWidth - this.getPaddingOfWrapper()).toString();
73
- }
74
- onDragStart(event) {
75
- event.preventDefault();
76
- this.initialX = event.clientX;
77
- this.wrapperWidth = this.wrapper ? this.wrapper.nativeElement.offsetWidth : 0;
78
- }
79
- onDragContinues(event) {
80
- const deltaX = this.initialX - event.clientX;
81
- this.resizeContent(deltaX);
82
- this.setResizerTextContent();
83
- }
84
- onDragEnd() {
85
- this.wrapperWidth = this.wrapper ? this.wrapper.nativeElement.offsetWidth : 0;
86
- this.updateSandboxWidth();
47
+ onModeChange(mode) {
48
+ this.updateUrl(mode, this.sandboxWidth);
49
+ this.mode = mode;
50
+ this.change$.next();
87
51
  }
88
52
  toggleDetails() {
89
53
  this.expanded = !this.expanded;
@@ -92,63 +56,55 @@ export class TuiDocDemoComponent {
92
56
  this.updateOn = updateOn;
93
57
  this.createForm();
94
58
  }
95
- createForm() {
96
- const { control, updateOn } = this;
97
- if (!control) {
59
+ updateWidth(width = NaN) {
60
+ if (!this.resizer || !this.resizeable || !this.content) {
98
61
  return;
99
62
  }
100
- this.testForm = new FormGroup({ testValue: control }, { updateOn });
101
- }
102
- resizeContent(delta) {
103
- this.setWidthWrapper(tuiPx(Math.max(this.wrapperWidth - delta, MIN_COMPONENT_WIDTH)));
63
+ const safe = width || this.resizeable.nativeElement.clientWidth;
64
+ const total = this.elementRef.nativeElement.clientWidth;
65
+ const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;
66
+ const validated = safe < total ? clamped : NaN;
67
+ this.resizer.nativeElement.textContent = String(clamped);
68
+ this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : ``;
69
+ this.sandboxWidth = validated;
70
+ }
71
+ get delta() {
72
+ return this.resizeable && this.content
73
+ ? this.resizeable.nativeElement.clientWidth -
74
+ this.content.nativeElement.clientWidth
75
+ : 0;
76
+ }
77
+ updateUrl(tuiMode, sandboxWidth) {
78
+ const urlTree = this.getUrlTree();
79
+ const { queryParams } = urlTree;
80
+ const modeParam = tuiMode ? { tuiMode } : {};
81
+ const resizeParam = !Number.isNaN(sandboxWidth) ? { sandboxWidth } : {};
82
+ delete queryParams.sandboxWidth;
83
+ delete queryParams.tuiMode;
84
+ urlTree.queryParams = Object.assign(Object.assign(Object.assign({}, queryParams), modeParam), resizeParam);
85
+ this.locationRef.replaceState(String(urlTree));
104
86
  }
105
- setWidthWrapper(width) {
106
- if (!this.wrapper) {
107
- return;
87
+ createForm() {
88
+ const { control, updateOn } = this;
89
+ if (control) {
90
+ this.testForm = new FormGroup({ testValue: control }, { updateOn });
108
91
  }
109
- this.renderer.setStyle(this.wrapper.nativeElement, `width`, width);
110
- }
111
- updateUrl(mode) {
112
- const urlTree = this.getUrlTree();
113
- const modeParam = (mode !== null && mode !== void 0 ? mode : urlTree.queryParams.tuiMode) ? { tuiMode: mode } : {};
114
- const sandboxWidth = parseInt(urlTree.queryParams.sandboxWidth, 10);
115
- const resizeParam = !Number.isNaN(sandboxWidth) && MIN_COMPONENT_WIDTH > sandboxWidth
116
- ? { sandboxWidth }
117
- : {};
118
- urlTree.queryParams = Object.assign(Object.assign(Object.assign({}, urlTree.queryParams), modeParam), resizeParam);
119
- this.locationRef.go(String(urlTree));
120
92
  }
121
93
  getUrlTree() {
122
94
  return this.urlSerializer.parse(this.locationRef.path());
123
95
  }
124
- getPaddingOfWrapper() {
125
- const paddingLeft = this.isBrowser && this.content
126
- ? getComputedStyle(this.content.nativeElement).paddingLeft
127
- : `0`;
128
- return parseInt(paddingLeft || `0`, 10) * 2;
129
- }
130
- getResizeButtonWidth() {
131
- var _a, _b, _c;
132
- return (_c = (_b = (_a = this.resizerText) === null || _a === void 0 ? void 0 : _a.nativeElement.parentElement) === null || _b === void 0 ? void 0 : _b.offsetWidth) !== null && _c !== void 0 ? _c : 0;
133
- }
134
- updateSandboxWidth() {
135
- var _a, _b;
136
- const urlTree = this.getUrlTree();
137
- urlTree.queryParams.sandboxWidth = parseInt((_b = (_a = this.resizerText) === null || _a === void 0 ? void 0 : _a.nativeElement.textContent) !== null && _b !== void 0 ? _b : `0`, 10);
138
- this.locationRef.go(String(urlTree));
139
- }
140
96
  }
141
- TuiDocDemoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoComponent, deps: [{ token: TUI_IS_MOBILE }, { token: TuiDestroyService, self: true }, { token: Renderer2 }, { token: PLATFORM_ID }, { token: Location }, { token: UrlSerializer }, { token: TUI_DOC_DEMO_TEXTS }], target: i0.ɵɵFactoryTarget.Component });
142
- TuiDocDemoComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDocDemoComponent, selector: "tui-doc-demo", inputs: { control: "control" }, host: { listeners: { "window:resize": "onResize()" } }, providers: [
97
+ TuiDocDemoComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoComponent, deps: [{ token: TUI_IS_MOBILE }, { token: ElementRef }, { token: Location }, { token: UrlSerializer }, { token: TUI_DOC_DEMO_TEXTS }], target: i0.ɵɵFactoryTarget.Component });
98
+ TuiDocDemoComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDocDemoComponent, selector: "tui-doc-demo", inputs: { control: "control" }, host: { listeners: { "window:resize": "onResize()", "document:mouseup.silent": "onMouseUp()" } }, providers: [
143
99
  TuiDestroyService,
144
100
  {
145
101
  provide: TuiModeDirective,
146
102
  useExisting: forwardRef(() => TuiDocDemoComponent),
147
103
  },
148
- ], queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "content", first: true, predicate: ["content"], descendants: true }, { propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true }, { propertyName: "resizerText", first: true, predicate: ["resizerText"], descendants: true }], ngImport: i0, template: "<div\n class=\"t-bg-toggle\"\n [tuiMode]=\"null\"\n>\n <ng-template #tooltip>\n {{ texts[0] }}\n <a\n tuiLink\n tuiMode=\"onDark\"\n routerLink=\"/directives/mode\"\n >\n <code>tuiMode</code>\n </a>\n </ng-template>\n <ng-container *ngIf=\"isMobile; else desktop\">\n <tui-select\n tuiTextfieldSize=\"s\"\n class=\"t-mode\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiHintContent]=\"tooltip\"\n [formControl]=\"modeControl\"\n >\n tuiMode\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"items\"\n ></tui-data-list-wrapper>\n </tui-select>\n </ng-container>\n <ng-template #desktop>\n tuiMode:\n <tui-tooltip\n describeId=\"form\"\n [content]=\"tooltip\"\n ></tui-tooltip>\n <div\n tuiGroup\n class=\"t-group\"\n [collapsed]=\"true\"\n >\n <tui-radio-block\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [item]=\"null\"\n [hideRadio]=\"true\"\n [formControl]=\"modeControl\"\n >\n null\n </tui-radio-block>\n <tui-radio-block\n item=\"onDark\"\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [formControl]=\"modeControl\"\n >\n onDark\n </tui-radio-block>\n <tui-radio-block\n item=\"onLight\"\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [formControl]=\"modeControl\"\n >\n onLight\n </tui-radio-block>\n </div>\n </ng-template>\n <tui-checkbox-labeled\n size=\"m\"\n class=\"t-checkbox\"\n [(ngModel)]=\"opaque\"\n >\n {{ texts[1] }}\n </tui-checkbox-labeled>\n</div>\n<div\n #wrapper\n class=\"t-wrapper\"\n [class.t-wrapper_dark]=\"modeControl.value === 'onDark'\"\n [class.t-wrapper_gray]=\"modeControl.value === 'onLight'\"\n [class.t-wrapper_transparent]=\"!opaque\"\n>\n <div\n #content\n id=\"demoContent\"\n class=\"t-content\"\n >\n <form\n *ngIf=\"testForm\"\n class=\"t-form\"\n [formGroup]=\"testForm\"\n >\n <div class=\"t-input-wrapper\">\n <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n </div>\n <button\n tuiButton\n type=\"button\"\n size=\"s\"\n class=\"t-button\"\n [iconRight]=\"icon\"\n (click)=\"toggleDetails()\"\n >\n {{ texts[2] }}\n </button>\n <ng-template #icon>\n <tui-svg\n src=\"tuiIconChevronDown\"\n class=\"t-icon\"\n [class.t-icon_rotated]=\"expanded\"\n ></tui-svg>\n </ng-template>\n <tui-expand\n class=\"t-expand\"\n [expanded]=\"expanded\"\n >\n <ng-template tuiExpandContent>\n <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n <div\n tuiGroup\n class=\"t-form-controls\"\n >\n <tui-select\n tuiTextfieldSize=\"s\"\n class=\"t-select\"\n [ngModel]=\"updateOn\"\n [ngModelOptions]=\"{standalone: true}\"\n (ngModelChange)=\"updateOnChange($event)\"\n >\n updateOn\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"updateOnVariants\"\n ></tui-data-list-wrapper>\n </tui-select>\n <button\n tuiButton\n type=\"reset\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n >\n Reset\n </button>\n <button\n tuiButton\n type=\"submit\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n >\n Submit\n </button>\n </div>\n </ng-template>\n </tui-expand>\n </form>\n <ng-content></ng-content>\n </div>\n <button\n tabindex=\"-1\"\n class=\"t-resizer\"\n (tuiDragStart)=\"onDragStart($event)\"\n (tuiDragContinues)=\"onDragContinues($event)\"\n (tuiDragEnd)=\"onDragEnd()\"\n >\n <span\n #resizerText\n class=\"t-resizer-text\"\n ></span>\n </button>\n</div>\n", styles: [":host{position:relative;display:block;min-width:100%;margin:1.5rem 0}.t-bg-toggle{position:absolute;bottom:calc(100% + .75rem);display:flex;align-items:center;justify-content:flex-end;pointer-events:none;width:100%}.t-bg-toggle>*{pointer-events:auto}.t-wrapper{box-shadow:0 1.5rem 1rem rgba(0,0,0,.03),0 .75rem .75rem rgba(0,0,0,.04),0 .25rem .375rem rgba(0,0,0,.05);display:flex;border:1px solid var(--tui-base-03);border-radius:var(--tui-radius-m);max-width:100%;min-height:6rem;width:100%;background-color:var(--tui-base-01);overflow:hidden}.t-wrapper.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-02) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-02) 75%);background-size:1.25rem 1.25rem;background-position:0 0,0 .625rem,.625rem -.625rem,-.625rem 0}.t-wrapper.t-wrapper_dark{background-color:#454e58;color:var(--tui-base-01)}.t-wrapper.t-wrapper_gray{background-color:#e5e7ea}.t-wrapper.t-wrapper_dark.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-focus) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-focus) 75%)}.t-wrapper.t-wrapper_gray.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-05) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-05) 75%)}:host-context(tui-root._mobile) .t-wrapper{min-height:auto}.t-content{flex:1 1 0;min-width:0;padding:1.5rem;box-sizing:border-box;overflow:hidden}:host-context(tui-root._mobile) .t-content{padding:1rem}.t-form{display:flex;flex-wrap:wrap;align-items:flex-start}.t-input-wrapper{width:100%;margin-bottom:.5rem}.t-expand{width:100%}.t-icon{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}.t-icon_rotated{transform:rotate(180deg)}.t-value{flex:1;background:var(--tui-clear-inverse);padding:.75rem;border-radius:.25rem}.t-mode{width:12.5rem}.t-select{max-width:15rem}.t-resizer{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:0;background:none;font-size:inherit;line-height:inherit;box-shadow:0 1.5rem 1rem rgba(0,0,0,.03),0 .75rem .75rem rgba(0,0,0,.04),0 .25rem .375rem rgba(0,0,0,.05);position:relative;width:3.5rem;min-height:inherit;flex-shrink:0;border-left:1px solid var(--tui-base-03);cursor:col-resize;outline:none;background:var(--tui-base-01);color:var(--tui-text-01)}.t-resizer:before,.t-resizer:after{content:\"\";position:absolute;top:.75rem;left:50%;bottom:.75rem;width:1px;background:var(--tui-base-05)}.t-resizer:before{transform:translate(.125rem)}.t-resizer:after{transform:translate(-.1875rem)}:host-context(tui-root._mobile) .t-resizer{display:none}.t-resizer-text{font:var(--tui-font-text-s);position:relative;z-index:1;padding:.75rem;background:var(--tui-base-01)}.wrapper_light .t-resizer-text{background:#3e464e}.t-group,.t-checkbox{margin-left:.75rem}.t-button,.t-form-controls{margin-top:.75rem}@supports ((position: -webkit-sticky) or (position: sticky)){@media screen and (min-height: 37.5rem){:host{position:-webkit-sticky;position:sticky;top:4.625rem;z-index:2}}}\n"], components: [{ type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { type: i2.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i2.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }, { type: i1.TuiTooltipComponent, selector: "tui-tooltip", inputs: ["content", "direction", "appearance", "showDelay", "hideDelay", "describeId"] }, { type: i2.TuiRadioBlockComponent, selector: "tui-radio-block", inputs: ["item", "identityMatcher", "contentAlign", "size", "hideRadio", "pseudoDisabled"] }, { type: i2.TuiCheckboxLabeledComponent, selector: "tui-checkbox-labeled", inputs: ["size"] }, { type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], directives: [{ type: i1.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiSelectDirective, selector: "tui-select" }, { type: i1.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.FormControlDirective, selector: "[formControl]", inputs: ["disabled", "formControl", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i1.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i1.TuiGroupDirective, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "adaptive", "collapsed", "rounded", "size"] }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.TuiExpandContentDirective, selector: "[tuiExpandContent]" }, { type: i6.TuiDragDirective, selector: "[tuiDragStart], [tuiDragContinues], [tuiDragEnd]", outputs: ["tuiDragStart", "tuiDragContinues", "tuiDragEnd"] }], pipes: { "json": i4.JsonPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
104
+ ], queries: [{ propertyName: "template", first: true, predicate: TemplateRef, descendants: true }], viewQueries: [{ propertyName: "resizeable", first: true, predicate: TuiResizeableDirective, descendants: true, static: true }, { propertyName: "content", first: true, predicate: ["content"], descendants: true, static: true }, { propertyName: "resizer", first: true, predicate: ["resizer"], descendants: true, static: true }], ngImport: i0, template: "<div\n class=\"t-bg-toggle\"\n [tuiMode]=\"null\"\n>\n <ng-template #tooltip>\n {{ texts[0] }}\n <a\n tuiLink\n tuiMode=\"onDark\"\n routerLink=\"/directives/mode\"\n >\n <code>tuiMode</code>\n </a>\n </ng-template>\n <ng-container *ngIf=\"isMobile; else desktop\">\n <tui-select\n tuiTextfieldSize=\"s\"\n class=\"t-mode\"\n [tuiTextfieldCleaner]=\"true\"\n [tuiHintContent]=\"tooltip\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n tuiMode\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"items\"\n ></tui-data-list-wrapper>\n </tui-select>\n </ng-container>\n <ng-template #desktop>\n tuiMode:\n <tui-tooltip\n describeId=\"form\"\n [content]=\"tooltip\"\n ></tui-tooltip>\n <div\n tuiGroup\n class=\"t-group\"\n [collapsed]=\"true\"\n >\n <tui-radio-block\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [item]=\"null\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n null\n </tui-radio-block>\n <tui-radio-block\n item=\"onDark\"\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n onDark\n </tui-radio-block>\n <tui-radio-block\n item=\"onLight\"\n size=\"s\"\n nativeId=\"form\"\n class=\"tui-group__auto-width-item\"\n [hideRadio]=\"true\"\n [ngModel]=\"mode\"\n (ngModelChange)=\"onModeChange($event)\"\n >\n onLight\n </tui-radio-block>\n </div>\n </ng-template>\n <tui-checkbox-labeled\n size=\"m\"\n class=\"t-checkbox\"\n [(ngModel)]=\"opaque\"\n >\n {{ texts[1] }}\n </tui-checkbox-labeled>\n</div>\n<div\n tuiResizeable\n class=\"t-wrapper\"\n [class.t-wrapper_dark]=\"mode === 'onDark'\"\n [class.t-wrapper_gray]=\"mode === 'onLight'\"\n [class.t-wrapper_transparent]=\"!opaque\"\n>\n <div\n id=\"demo-content\"\n class=\"t-content\"\n >\n <div #content>\n <form\n *ngIf=\"testForm\"\n class=\"t-form\"\n [formGroup]=\"testForm\"\n >\n <div class=\"t-input-wrapper\">\n <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n </div>\n <button\n tuiButton\n type=\"button\"\n size=\"s\"\n class=\"t-button\"\n [iconRight]=\"icon\"\n (click)=\"toggleDetails()\"\n >\n {{ texts[2] }}\n </button>\n <ng-template #icon>\n <tui-svg\n src=\"tuiIconChevronDown\"\n class=\"t-icon\"\n [class.t-icon_rotated]=\"expanded\"\n ></tui-svg>\n </ng-template>\n <tui-expand\n class=\"t-expand\"\n [expanded]=\"expanded\"\n >\n <ng-template tuiExpandContent>\n <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n <div\n tuiGroup\n class=\"t-form-controls\"\n >\n <tui-select\n tuiTextfieldSize=\"s\"\n class=\"t-select\"\n [ngModel]=\"updateOn\"\n [ngModelOptions]=\"{standalone: true}\"\n (ngModelChange)=\"updateOnChange($event)\"\n >\n updateOn\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"updateOnVariants\"\n ></tui-data-list-wrapper>\n </tui-select>\n <button\n tuiButton\n type=\"reset\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n >\n Reset\n </button>\n <button\n tuiButton\n type=\"submit\"\n size=\"s\"\n class=\"tui-group__auto-width-item\"\n >\n Submit\n </button>\n </div>\n </ng-template>\n </tui-expand>\n </form>\n <ng-content></ng-content>\n </div>\n </div>\n <div\n #resizer\n class=\"t-resizer\"\n [tuiResizer]=\"[1, 0]\"\n (tuiSizeChange)=\"updateWidth($event[0])\"\n ></div>\n</div>\n", styles: [":host{position:relative;display:block;min-width:100%;margin:1.5rem 0}.t-bg-toggle{position:absolute;bottom:calc(100% + .75rem);display:flex;align-items:center;justify-content:flex-end;pointer-events:none;width:100%}.t-bg-toggle>*{pointer-events:auto}.t-wrapper{box-shadow:0 1.5rem 1rem rgba(0,0,0,.03),0 .75rem .75rem rgba(0,0,0,.04),0 .25rem .375rem rgba(0,0,0,.05);display:flex;border:1px solid var(--tui-base-03);border-radius:var(--tui-radius-m);max-width:100%;min-height:6rem;width:100%;min-width:10rem;background-color:var(--tui-base-01);overflow:hidden}.t-wrapper.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-02) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-02) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-02) 75%);background-size:1.25rem 1.25rem;background-position:0 0,0 .625rem,.625rem -.625rem,-.625rem 0}.t-wrapper.t-wrapper_dark{background-color:#454e58;color:var(--tui-base-01)}.t-wrapper.t-wrapper_gray{background-color:#e5e7ea}.t-wrapper.t-wrapper_dark.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-focus) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-focus) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-focus) 75%)}.t-wrapper.t-wrapper_gray.t-wrapper_transparent{background-image:linear-gradient(45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(-45deg,var(--tui-base-05) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--tui-base-05) 75%),linear-gradient(-45deg,transparent 75%,var(--tui-base-05) 75%)}:host-context(tui-root._mobile) .t-wrapper{min-height:auto}.t-content{flex:1 1 0;min-width:0;padding:1.5rem;box-sizing:border-box;overflow:hidden}:host-context(tui-root._mobile) .t-content{padding:1rem}.t-form{display:flex;flex-wrap:wrap;align-items:flex-start}.t-input-wrapper{width:100%;margin-bottom:.5rem}.t-expand{width:100%}.t-icon{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}.t-icon_rotated{transform:rotate(180deg)}.t-value{flex:1;background:var(--tui-clear-inverse);padding:.75rem;border-radius:.25rem}.t-mode{width:12.5rem}.t-select{max-width:15rem}.t-resizer{box-shadow:0 1.5rem 1rem rgba(0,0,0,.03),0 .75rem .75rem rgba(0,0,0,.04),0 .25rem .375rem rgba(0,0,0,.05);position:relative;width:3.5rem;min-height:inherit;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-left:1px solid var(--tui-base-03);outline:none;background:var(--tui-base-01);color:var(--tui-text-01)}.t-resizer:before,.t-resizer:after{content:\"\";position:absolute;top:.75rem;left:50%;bottom:calc(50% + 1rem);width:1px;background:var(--tui-base-04);box-shadow:-.25rem 0 var(--tui-base-04);transform:translate(0)}.t-resizer:after{bottom:.75rem;top:calc(50% + 1rem)}:host-context(tui-root._mobile) .t-resizer{display:none}.t-resizer-text{font:var(--tui-font-text-s);position:relative;z-index:1;padding:.75rem;background:var(--tui-base-01)}.wrapper_light .t-resizer-text{background:#3e464e}.t-group,.t-checkbox{margin-left:.75rem}.t-button,.t-form-controls{margin-top:.75rem}@supports ((position: -webkit-sticky) or (position: sticky)){@media screen and (min-height: 37.5rem){:host{position:-webkit-sticky;position:sticky;top:4.625rem;z-index:2}}}\n"], components: [{ type: i1.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { type: i2.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i2.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }, { type: i1.TuiTooltipComponent, selector: "tui-tooltip", inputs: ["content", "direction", "appearance", "showDelay", "hideDelay", "describeId"] }, { type: i2.TuiRadioBlockComponent, selector: "tui-radio-block", inputs: ["item", "identityMatcher", "contentAlign", "size", "hideRadio", "pseudoDisabled"] }, { type: i2.TuiCheckboxLabeledComponent, selector: "tui-checkbox-labeled", inputs: ["size"] }, { type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { type: i1.TuiSvgComponent, selector: "tui-svg", inputs: ["src"] }, { type: i1.TuiExpandComponent, selector: "tui-expand", inputs: ["async", "expanded"] }], directives: [{ type: i1.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { type: i3.RouterLinkWithHref, selector: "a[routerLink],area[routerLink]", inputs: ["routerLink", "target", "queryParams", "fragment", "queryParamsHandling", "preserveFragment", "skipLocationChange", "replaceUrl", "state", "relativeTo"] }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiSelectDirective, selector: "tui-select" }, { type: i1.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i1.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i1.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i1.TuiGroupDirective, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "adaptive", "collapsed", "rounded", "size"] }, { type: i6.TuiResizeableDirective, selector: "[tuiResizeable]" }, { type: i5.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i5.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i5.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i1.TuiExpandContentDirective, selector: "[tuiExpandContent]" }, { type: i6.TuiResizerDirective, selector: "[tuiResizer]", inputs: ["tuiResizer"], outputs: ["tuiSizeChange"] }], pipes: { "json": i4.JsonPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
149
105
  __decorate([
150
- tuiDebounce(200)
151
- ], TuiDocDemoComponent.prototype, "onResize", null);
106
+ tuiPure
107
+ ], TuiDocDemoComponent.prototype, "updateUrl", null);
152
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoComponent, decorators: [{
153
109
  type: Component,
154
110
  args: [{
@@ -167,17 +123,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
167
123
  }], ctorParameters: function () { return [{ type: undefined, decorators: [{
168
124
  type: Inject,
169
125
  args: [TUI_IS_MOBILE]
170
- }] }, { type: i6.TuiDestroyService, decorators: [{
171
- type: Self
172
- }, {
173
- type: Inject,
174
- args: [TuiDestroyService]
175
- }] }, { type: i0.Renderer2, decorators: [{
126
+ }] }, { type: i0.ElementRef, decorators: [{
176
127
  type: Inject,
177
- args: [Renderer2]
178
- }] }, { type: undefined, decorators: [{
179
- type: Inject,
180
- args: [PLATFORM_ID]
128
+ args: [ElementRef]
181
129
  }] }, { type: i4.Location, decorators: [{
182
130
  type: Inject,
183
131
  args: [Location]
@@ -187,15 +135,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
187
135
  }] }, { type: undefined, decorators: [{
188
136
  type: Inject,
189
137
  args: [TUI_DOC_DEMO_TEXTS]
190
- }] }]; }, propDecorators: { content: [{
138
+ }] }]; }, propDecorators: { resizeable: [{
191
139
  type: ViewChild,
192
- args: [`content`]
193
- }], wrapper: [{
140
+ args: [TuiResizeableDirective, { static: true }]
141
+ }], content: [{
194
142
  type: ViewChild,
195
- args: [`wrapper`]
196
- }], resizerText: [{
143
+ args: [`content`, { static: true }]
144
+ }], resizer: [{
197
145
  type: ViewChild,
198
- args: [`resizerText`]
146
+ args: [`resizer`, { static: true }]
199
147
  }], control: [{
200
148
  type: Input
201
149
  }], template: [{
@@ -204,5 +152,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
204
152
  }], onResize: [{
205
153
  type: HostListener,
206
154
  args: [`window:resize`]
207
- }] } });
208
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/demo/demo.component.ts","../../../../../projects/addon-doc/src/components/demo/demo.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,iBAAiB,EAAE,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AAC5D,OAAO,EAEH,uBAAuB,EACvB,SAAS,EACT,YAAY,EAEZ,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,EACT,IAAI,EACJ,WAAW,EACX,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,WAAW,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AACvE,OAAO,EAAC,aAAa,EAAU,MAAM,iBAAiB,CAAC;AACvD,OAAO,EAAC,aAAa,EAAE,WAAW,EAAE,iBAAiB,EAAE,KAAK,EAAC,MAAM,eAAe,CAAC;AACnF,OAAO,EAAgB,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAC,SAAS,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEpD,OAAO,EAAC,kBAAkB,EAAC,MAAM,mBAAmB,CAAC;;;;;;;;AAErD,MAAM,mBAAmB,GAAG,GAAG,CAAC;AAehC,MAAM,OAAO,mBAAmB;IA8B5B,YACoC,QAAiB,EACG,QAA2B,EAC3C,QAAmB,EAClC,UAAmC,EACrB,WAAqB,EAChB,aAA4B,EAC/B,KAA+B;QANpC,aAAQ,GAAR,QAAQ,CAAS;QACG,aAAQ,GAAR,QAAQ,CAAmB;QAC3C,aAAQ,GAAR,QAAQ,CAAW;QAEpB,gBAAW,GAAX,WAAW,CAAU;QAChB,kBAAa,GAAb,aAAa,CAAe;QAC/B,UAAK,GAAL,KAAK,CAA0B;QA1BhE,aAAQ,GAAG,CAAC,CAAC;QACb,iBAAY,GAAG,CAAC,CAAC;QAGzB,YAAO,GAA2B,IAAI,CAAC;QAG9B,aAAQ,GAAgD,IAAI,CAAC;QAGtE,qBAAgB,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC;QAChD,aAAQ,GAAiC,QAAQ,CAAC;QAClD,aAAQ,GAAG,KAAK,CAAC;QACjB,WAAM,GAAG,IAAI,CAAC;QACd,gBAAW,GAAG,IAAI,WAAW,EAAE,CAAC;QAChC,SAAI,GAAyB,IAAI,CAAC;QACzB,YAAO,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC9B,UAAK,GAA6B,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;QAW7D,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAE/C,MAAM,UAAU,GAAG,WAAW,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAExE,IAAI,UAAU,KAAK,IAAI,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9C,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;SAC5C;IACL,CAAC;IAID,QAAQ;QACJ,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,eAAe;QACX,IAAI,CAAC,WAAW,CAAC,YAAY;aACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aACjE,SAAS,CAAC,IAAI,CAAC,EAAE;YACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YAErB,MAAM,YAAY,GACd,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,CAAC;gBACxD,IAAI,CAAC,mBAAmB,EAAE;gBAC1B,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAEhC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,EAAE;gBAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;gBACjC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC;aAC7C;YAED,IAAI,CAAC,qBAAqB,EAAE,CAAC;YAE7B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;QACxB,CAAC,CAAC,CAAC;IACX,CAAC;IAED,qBAAqB;QACjB,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACpC,OAAO;SACV;QAED,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,WAAW,GAAG,CACzC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC,mBAAmB,EAAE,CACtE,CAAC,QAAQ,EAAE,CAAC;IACjB,CAAC;IAED,WAAW,CAAC,KAAiB;QACzB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;IAClF,CAAC;IAED,eAAe,CAAC,KAAiB;QAC7B,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,OAAO,CAAC;QAE7C,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC3B,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAED,SAAS;QACL,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,aAAa;QACT,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;IACnC,CAAC;IAED,cAAc,CAAC,QAAsC;QACjD,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAEO,UAAU;QACd,MAAM,EAAC,OAAO,EAAE,QAAQ,EAAC,GAAG,IAAI,CAAC;QAEjC,IAAI,CAAC,OAAO,EAAE;YACV,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,GAAG,IAAI,SAAS,CAAC,EAAC,SAAS,EAAE,OAAO,EAAC,EAAE,EAAC,QAAQ,EAAC,CAAC,CAAC;IACpE,CAAC;IAEO,aAAa,CAAC,KAAa;QAC/B,IAAI,CAAC,eAAe,CAChB,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAClE,CAAC;IACN,CAAC;IAEO,eAAe,CAAC,KAAsB;QAC1C,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACf,OAAO;SACV;QAED,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IACvE,CAAC;IAEO,SAAS,CAAC,IAAY;QAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,MAAM,SAAS,GAAG,CAAA,IAAI,aAAJ,IAAI,cAAJ,IAAI,GAAI,OAAO,CAAC,WAAW,CAAC,OAAO,EAAC,CAAC,CAAC,EAAC,OAAO,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC7E,MAAM,YAAY,GAAG,QAAQ,CAAC,OAAO,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;QACpE,MAAM,WAAW,GACb,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,mBAAmB,GAAG,YAAY;YAC7D,CAAC,CAAC,EAAC,YAAY,EAAC;YAChB,CAAC,CAAC,EAAE,CAAC;QAEb,OAAO,CAAC,WAAW,iDACZ,OAAO,CAAC,WAAW,GACnB,SAAS,GACT,WAAW,CACjB,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IACzC,CAAC;IAEO,UAAU;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7D,CAAC;IAEO,mBAAmB;QACvB,MAAM,WAAW,GACb,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO;YAC1B,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,WAAW;YAC1D,CAAC,CAAC,GAAG,CAAC;QAEd,OAAO,QAAQ,CAAC,WAAW,IAAI,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC;IAChD,CAAC;IAEO,oBAAoB;;QACxB,OAAO,MAAA,MAAA,MAAA,IAAI,CAAC,WAAW,0CAAE,aAAa,CAAC,aAAa,0CAAE,WAAW,mCAAI,CAAC,CAAC;IAC3E,CAAC;IAEO,kBAAkB;;QACtB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAElC,OAAO,CAAC,WAAW,CAAC,YAAY,GAAG,QAAQ,CACvC,MAAA,MAAA,IAAI,CAAC,WAAW,0CAAE,aAAa,CAAC,WAAW,mCAAI,GAAG,EAClD,EAAE,CACL,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IACzC,CAAC;;iHA1LQ,mBAAmB,kBA+BhB,aAAa,aACL,iBAAiB,yBACzB,SAAS,aACT,WAAW,aACX,QAAQ,aACR,aAAa,aACb,kBAAkB;qGArCrB,mBAAmB,+HARjB;QACP,iBAAiB;QACjB;YACI,OAAO,EAAE,gBAAgB;YACzB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;SACrD;KACJ,gEAmBa,WAAW,sUC3D7B,m9KA+KA;ADnFI;IAFC,WAAW,CAAC,GAAG,CAAC;mDAIhB;4FApDQ,mBAAmB;kBAb/B,SAAS;mBAAC;oBACP,QAAQ,EAAE,cAAc;oBACxB,WAAW,EAAE,sBAAsB;oBACnC,SAAS,EAAE,CAAC,mBAAmB,CAAC;oBAChC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACP,iBAAiB;wBACjB;4BACI,OAAO,EAAE,gBAAgB;4BACzB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,oBAAoB,CAAC;yBACrD;qBACJ;iBACJ;;0BAgCQ,MAAM;2BAAC,aAAa;;0BACpB,IAAI;;0BAAI,MAAM;2BAAC,iBAAiB;;0BAChC,MAAM;2BAAC,SAAS;;0BAChB,MAAM;2BAAC,WAAW;;0BAClB,MAAM;2BAAC,QAAQ;;0BACf,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,kBAAkB;4CAnCb,OAAO;sBADvB,SAAS;uBAAC,SAAS;gBAIH,OAAO;sBADvB,SAAS;uBAAC,SAAS;gBAIH,WAAW;sBAD3B,SAAS;uBAAC,aAAa;gBAQxB,OAAO;sBADN,KAAK;gBAIG,QAAQ;sBADhB,YAAY;uBAAC,WAAW;gBAiCzB,QAAQ;sBADP,YAAY;uBAAC,eAAe","sourcesContent":["import {isPlatformBrowser, Location} from '@angular/common';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    OnInit,\n    PLATFORM_ID,\n    Renderer2,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormControl, FormGroup} from '@angular/forms';\nimport {UrlSerializer, UrlTree} from '@angular/router';\nimport {TUI_IS_MOBILE, tuiDebounce, TuiDestroyService, tuiPx} from '@taiga-ui/cdk';\nimport {TuiBrightness, TuiModeDirective} from '@taiga-ui/core';\nimport {Subject} from 'rxjs';\nimport {startWith, takeUntil} from 'rxjs/operators';\n\nimport {TUI_DOC_DEMO_TEXTS} from '../../tokens/i18n';\n\nconst MIN_COMPONENT_WIDTH = 104;\n\n@Component({\n    selector: `tui-doc-demo`,\n    templateUrl: `./demo.template.html`,\n    styleUrls: [`./demo.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        {\n            provide: TuiModeDirective,\n            useExisting: forwardRef(() => TuiDocDemoComponent),\n        },\n    ],\n})\nexport class TuiDocDemoComponent implements OnInit, AfterViewInit {\n    @ViewChild(`content`)\n    private readonly content?: ElementRef<HTMLElement>;\n\n    @ViewChild(`wrapper`)\n    private readonly wrapper?: ElementRef<HTMLElement>;\n\n    @ViewChild(`resizerText`)\n    private readonly resizerText?: ElementRef<HTMLElement>;\n\n    private readonly isBrowser: boolean;\n    private initialX = 0;\n    private wrapperWidth = 0;\n\n    @Input()\n    control: AbstractControl | null = null;\n\n    @ContentChild(TemplateRef)\n    readonly template: TemplateRef<Record<string, unknown>> | null = null;\n\n    testForm?: FormGroup;\n    updateOnVariants = [`change`, `blur`, `submit`];\n    updateOn: 'blur' | 'change' | 'submit' = `change`;\n    expanded = false;\n    opaque = true;\n    modeControl = new FormControl();\n    mode: TuiBrightness | null = null;\n    readonly change$ = new Subject<void>();\n    readonly items: readonly TuiBrightness[] = [`onLight`, `onDark`];\n\n    constructor(\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(Renderer2) private readonly renderer: Renderer2,\n        @Inject(PLATFORM_ID) platformId: Record<string, unknown>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_DEMO_TEXTS) readonly texts: [string, string, string],\n    ) {\n        this.isBrowser = isPlatformBrowser(platformId);\n\n        const parsedMode = locationRef.path().match(/tuiMode=(onDark|onLight)/);\n\n        if (parsedMode !== null && parsedMode.length > 0) {\n            this.modeControl.setValue(parsedMode[1]);\n        }\n    }\n\n    @tuiDebounce(200)\n    @HostListener(`window:resize`)\n    onResize(): void {\n        this.setResizerTextContent();\n    }\n\n    ngOnInit(): void {\n        this.createForm();\n    }\n\n    ngAfterViewInit(): void {\n        this.modeControl.valueChanges\n            .pipe(startWith(this.modeControl.value), takeUntil(this.destroy$))\n            .subscribe(mode => {\n                this.updateUrl(mode);\n\n                const wrapperWidth =\n                    parseInt(this.getUrlTree().queryParams.sandboxWidth, 10) +\n                    this.getPaddingOfWrapper() +\n                    this.getResizeButtonWidth();\n\n                if (!Number.isNaN(wrapperWidth)) {\n                    this.wrapperWidth = wrapperWidth;\n                    this.setWidthWrapper(tuiPx(wrapperWidth));\n                }\n\n                this.setResizerTextContent();\n\n                this.mode = mode;\n                this.change$.next();\n            });\n    }\n\n    setResizerTextContent(): void {\n        if (!this.content || !this.resizerText) {\n            return;\n        }\n\n        this.resizerText.nativeElement.textContent = (\n            this.content.nativeElement.offsetWidth - this.getPaddingOfWrapper()\n        ).toString();\n    }\n\n    onDragStart(event: MouseEvent): void {\n        event.preventDefault();\n        this.initialX = event.clientX;\n        this.wrapperWidth = this.wrapper ? this.wrapper.nativeElement.offsetWidth : 0;\n    }\n\n    onDragContinues(event: MouseEvent): void {\n        const deltaX = this.initialX - event.clientX;\n\n        this.resizeContent(deltaX);\n        this.setResizerTextContent();\n    }\n\n    onDragEnd(): void {\n        this.wrapperWidth = this.wrapper ? this.wrapper.nativeElement.offsetWidth : 0;\n        this.updateSandboxWidth();\n    }\n\n    toggleDetails(): void {\n        this.expanded = !this.expanded;\n    }\n\n    updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void {\n        this.updateOn = updateOn;\n        this.createForm();\n    }\n\n    private createForm(): void {\n        const {control, updateOn} = this;\n\n        if (!control) {\n            return;\n        }\n\n        this.testForm = new FormGroup({testValue: control}, {updateOn});\n    }\n\n    private resizeContent(delta: number): void {\n        this.setWidthWrapper(\n            tuiPx(Math.max(this.wrapperWidth - delta, MIN_COMPONENT_WIDTH)),\n        );\n    }\n\n    private setWidthWrapper(width: number | string): void {\n        if (!this.wrapper) {\n            return;\n        }\n\n        this.renderer.setStyle(this.wrapper.nativeElement, `width`, width);\n    }\n\n    private updateUrl(mode: string): void {\n        const urlTree = this.getUrlTree();\n        const modeParam = mode ?? urlTree.queryParams.tuiMode ? {tuiMode: mode} : {};\n        const sandboxWidth = parseInt(urlTree.queryParams.sandboxWidth, 10);\n        const resizeParam =\n            !Number.isNaN(sandboxWidth) && MIN_COMPONENT_WIDTH > sandboxWidth\n                ? {sandboxWidth}\n                : {};\n\n        urlTree.queryParams = {\n            ...urlTree.queryParams,\n            ...modeParam,\n            ...resizeParam,\n        };\n\n        this.locationRef.go(String(urlTree));\n    }\n\n    private getUrlTree(): UrlTree {\n        return this.urlSerializer.parse(this.locationRef.path());\n    }\n\n    private getPaddingOfWrapper(): number {\n        const paddingLeft =\n            this.isBrowser && this.content\n                ? getComputedStyle(this.content.nativeElement).paddingLeft\n                : `0`;\n\n        return parseInt(paddingLeft || `0`, 10) * 2;\n    }\n\n    private getResizeButtonWidth(): number {\n        return this.resizerText?.nativeElement.parentElement?.offsetWidth ?? 0;\n    }\n\n    private updateSandboxWidth(): void {\n        const urlTree = this.getUrlTree();\n\n        urlTree.queryParams.sandboxWidth = parseInt(\n            this.resizerText?.nativeElement.textContent ?? `0`,\n            10,\n        );\n\n        this.locationRef.go(String(urlTree));\n    }\n}\n","<div\n    class=\"t-bg-toggle\"\n    [tuiMode]=\"null\"\n>\n    <ng-template #tooltip>\n        {{ texts[0] }}\n        <a\n            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\n        >\n            <code>tuiMode</code>\n        </a>\n    </ng-template>\n    <ng-container *ngIf=\"isMobile; else desktop\">\n        <tui-select\n            tuiTextfieldSize=\"s\"\n            class=\"t-mode\"\n            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [formControl]=\"modeControl\"\n        >\n            tuiMode\n            <tui-data-list-wrapper\n                *tuiDataList\n                [items]=\"items\"\n            ></tui-data-list-wrapper>\n        </tui-select>\n    </ng-container>\n    <ng-template #desktop>\n        tuiMode:\n        <tui-tooltip\n            describeId=\"form\"\n            [content]=\"tooltip\"\n        ></tui-tooltip>\n        <div\n            tuiGroup\n            class=\"t-group\"\n            [collapsed]=\"true\"\n        >\n            <tui-radio-block\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [formControl]=\"modeControl\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [formControl]=\"modeControl\"\n            >\n                onDark\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onLight\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [formControl]=\"modeControl\"\n            >\n                onLight\n            </tui-radio-block>\n        </div>\n    </ng-template>\n    <tui-checkbox-labeled\n        size=\"m\"\n        class=\"t-checkbox\"\n        [(ngModel)]=\"opaque\"\n    >\n        {{ texts[1] }}\n    </tui-checkbox-labeled>\n</div>\n<div\n    #wrapper\n    class=\"t-wrapper\"\n    [class.t-wrapper_dark]=\"modeControl.value === 'onDark'\"\n    [class.t-wrapper_gray]=\"modeControl.value === 'onLight'\"\n    [class.t-wrapper_transparent]=\"!opaque\"\n>\n    <div\n        #content\n        id=\"demoContent\"\n        class=\"t-content\"\n    >\n        <form\n            *ngIf=\"testForm\"\n            class=\"t-form\"\n            [formGroup]=\"testForm\"\n        >\n            <div class=\"t-input-wrapper\">\n                <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n            </div>\n            <button\n                tuiButton\n                type=\"button\"\n                size=\"s\"\n                class=\"t-button\"\n                [iconRight]=\"icon\"\n                (click)=\"toggleDetails()\"\n            >\n                {{ texts[2] }}\n            </button>\n            <ng-template #icon>\n                <tui-svg\n                    src=\"tuiIconChevronDown\"\n                    class=\"t-icon\"\n                    [class.t-icon_rotated]=\"expanded\"\n                ></tui-svg>\n            </ng-template>\n            <tui-expand\n                class=\"t-expand\"\n                [expanded]=\"expanded\"\n            >\n                <ng-template tuiExpandContent>\n                    <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n                    <div\n                        tuiGroup\n                        class=\"t-form-controls\"\n                    >\n                        <tui-select\n                            tuiTextfieldSize=\"s\"\n                            class=\"t-select\"\n                            [ngModel]=\"updateOn\"\n                            [ngModelOptions]=\"{standalone: true}\"\n                            (ngModelChange)=\"updateOnChange($event)\"\n                        >\n                            updateOn\n                            <tui-data-list-wrapper\n                                *tuiDataList\n                                [items]=\"updateOnVariants\"\n                            ></tui-data-list-wrapper>\n                        </tui-select>\n                        <button\n                            tuiButton\n                            type=\"reset\"\n                            size=\"s\"\n                            class=\"tui-group__auto-width-item\"\n                        >\n                            Reset\n                        </button>\n                        <button\n                            tuiButton\n                            type=\"submit\"\n                            size=\"s\"\n                            class=\"tui-group__auto-width-item\"\n                        >\n                            Submit\n                        </button>\n                    </div>\n                </ng-template>\n            </tui-expand>\n        </form>\n        <ng-content></ng-content>\n    </div>\n    <button\n        tabindex=\"-1\"\n        class=\"t-resizer\"\n        (tuiDragStart)=\"onDragStart($event)\"\n        (tuiDragContinues)=\"onDragContinues($event)\"\n        (tuiDragEnd)=\"onDragEnd()\"\n    >\n        <span\n            #resizerText\n            class=\"t-resizer-text\"\n        ></span>\n    </button>\n</div>\n"]}
155
+ }], onMouseUp: [{
156
+ type: HostListener,
157
+ args: [`document:mouseup.silent`]
158
+ }], updateUrl: [] } });
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"demo.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/demo/demo.component.ts","../../../../../projects/addon-doc/src/components/demo/demo.template.html"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    forwardRef,\n    HostListener,\n    Inject,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {AbstractControl, FormGroup} from '@angular/forms';\nimport {UrlSerializer, UrlTree} from '@angular/router';\nimport {\n    TUI_IS_MOBILE,\n    tuiClamp,\n    TuiDestroyService,\n    tuiPure,\n    tuiPx,\n    TuiResizeableDirective,\n} from '@taiga-ui/cdk';\nimport {TuiBrightness, TuiModeDirective} from '@taiga-ui/core';\nimport {Subject} from 'rxjs';\n\nimport {TUI_DOC_DEMO_TEXTS} from '../../tokens/i18n';\n\nconst MIN_WIDTH = 160;\n\n@Component({\n    selector: `tui-doc-demo`,\n    templateUrl: `./demo.template.html`,\n    styleUrls: [`./demo.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiDestroyService,\n        {\n            provide: TuiModeDirective,\n            useExisting: forwardRef(() => TuiDocDemoComponent),\n        },\n    ],\n})\nexport class TuiDocDemoComponent implements OnInit {\n    @ViewChild(TuiResizeableDirective, {static: true})\n    private readonly resizeable?: ElementRef<HTMLElement>;\n\n    @ViewChild(`content`, {static: true})\n    private readonly content?: ElementRef<HTMLElement>;\n\n    @ViewChild(`resizer`, {static: true})\n    private readonly resizer?: ElementRef<HTMLElement>;\n\n    @Input()\n    control: AbstractControl | null = null;\n\n    @ContentChild(TemplateRef)\n    readonly template: TemplateRef<Record<string, unknown>> | null = null;\n\n    testForm?: FormGroup;\n    readonly updateOnVariants = [`change`, `blur`, `submit`] as const;\n    updateOn: 'blur' | 'change' | 'submit' = this.updateOnVariants[0];\n    expanded = false;\n    opaque = true;\n    mode: TuiBrightness | null = this.getUrlTree().queryParams.tuiMode || null;\n    sandboxWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10);\n\n    readonly change$ = new Subject<void>();\n    readonly items: readonly TuiBrightness[] = [`onLight`, `onDark`];\n\n    constructor(\n        @Inject(TUI_IS_MOBILE) readonly isMobile: boolean,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n        @Inject(TUI_DOC_DEMO_TEXTS) readonly texts: [string, string, string],\n    ) {}\n\n    @HostListener(`window:resize`)\n    onResize(): void {\n        this.updateWidth();\n        this.onMouseUp();\n    }\n\n    @HostListener(`document:mouseup.silent`)\n    onMouseUp(): void {\n        this.updateUrl(this.mode, this.sandboxWidth);\n    }\n\n    ngOnInit(): void {\n        this.createForm();\n        this.updateWidth(this.sandboxWidth + this.delta);\n    }\n\n    onModeChange(mode: TuiBrightness | null): void {\n        this.updateUrl(mode, this.sandboxWidth);\n        this.mode = mode;\n        this.change$.next();\n    }\n\n    toggleDetails(): void {\n        this.expanded = !this.expanded;\n    }\n\n    updateOnChange(updateOn: 'blur' | 'change' | 'submit'): void {\n        this.updateOn = updateOn;\n        this.createForm();\n    }\n\n    updateWidth(width: number = NaN): void {\n        if (!this.resizer || !this.resizeable || !this.content) {\n            return;\n        }\n\n        const safe = width || this.resizeable.nativeElement.clientWidth;\n        const total = this.elementRef.nativeElement.clientWidth;\n        const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;\n        const validated = safe < total ? clamped : NaN;\n\n        this.resizer.nativeElement.textContent = String(clamped);\n        this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : ``;\n        this.sandboxWidth = validated;\n    }\n\n    private get delta(): number {\n        return this.resizeable && this.content\n            ? this.resizeable.nativeElement.clientWidth -\n                  this.content.nativeElement.clientWidth\n            : 0;\n    }\n\n    @tuiPure\n    private updateUrl(tuiMode: TuiBrightness | null, sandboxWidth: number): void {\n        const urlTree = this.getUrlTree();\n        const {queryParams} = urlTree;\n        const modeParam = tuiMode ? {tuiMode} : {};\n        const resizeParam = !Number.isNaN(sandboxWidth) ? {sandboxWidth} : {};\n\n        delete queryParams.sandboxWidth;\n        delete queryParams.tuiMode;\n\n        urlTree.queryParams = {\n            ...queryParams,\n            ...modeParam,\n            ...resizeParam,\n        };\n\n        this.locationRef.replaceState(String(urlTree));\n    }\n\n    private createForm(): void {\n        const {control, updateOn} = this;\n\n        if (control) {\n            this.testForm = new FormGroup({testValue: control}, {updateOn});\n        }\n    }\n\n    private getUrlTree(): UrlTree {\n        return this.urlSerializer.parse(this.locationRef.path());\n    }\n}\n","<div\n    class=\"t-bg-toggle\"\n    [tuiMode]=\"null\"\n>\n    <ng-template #tooltip>\n        {{ texts[0] }}\n        <a\n            tuiLink\n            tuiMode=\"onDark\"\n            routerLink=\"/directives/mode\"\n        >\n            <code>tuiMode</code>\n        </a>\n    </ng-template>\n    <ng-container *ngIf=\"isMobile; else desktop\">\n        <tui-select\n            tuiTextfieldSize=\"s\"\n            class=\"t-mode\"\n            [tuiTextfieldCleaner]=\"true\"\n            [tuiHintContent]=\"tooltip\"\n            [ngModel]=\"mode\"\n            (ngModelChange)=\"onModeChange($event)\"\n        >\n            tuiMode\n            <tui-data-list-wrapper\n                *tuiDataList\n                [items]=\"items\"\n            ></tui-data-list-wrapper>\n        </tui-select>\n    </ng-container>\n    <ng-template #desktop>\n        tuiMode:\n        <tui-tooltip\n            describeId=\"form\"\n            [content]=\"tooltip\"\n        ></tui-tooltip>\n        <div\n            tuiGroup\n            class=\"t-group\"\n            [collapsed]=\"true\"\n        >\n            <tui-radio-block\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [item]=\"null\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                null\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onDark\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onDark\n            </tui-radio-block>\n            <tui-radio-block\n                item=\"onLight\"\n                size=\"s\"\n                nativeId=\"form\"\n                class=\"tui-group__auto-width-item\"\n                [hideRadio]=\"true\"\n                [ngModel]=\"mode\"\n                (ngModelChange)=\"onModeChange($event)\"\n            >\n                onLight\n            </tui-radio-block>\n        </div>\n    </ng-template>\n    <tui-checkbox-labeled\n        size=\"m\"\n        class=\"t-checkbox\"\n        [(ngModel)]=\"opaque\"\n    >\n        {{ texts[1] }}\n    </tui-checkbox-labeled>\n</div>\n<div\n    tuiResizeable\n    class=\"t-wrapper\"\n    [class.t-wrapper_dark]=\"mode === 'onDark'\"\n    [class.t-wrapper_gray]=\"mode === 'onLight'\"\n    [class.t-wrapper_transparent]=\"!opaque\"\n>\n    <div\n        id=\"demo-content\"\n        class=\"t-content\"\n    >\n        <div #content>\n            <form\n                *ngIf=\"testForm\"\n                class=\"t-form\"\n                [formGroup]=\"testForm\"\n            >\n                <div class=\"t-input-wrapper\">\n                    <ng-container [ngTemplateOutlet]=\"template\"></ng-container>\n                </div>\n                <button\n                    tuiButton\n                    type=\"button\"\n                    size=\"s\"\n                    class=\"t-button\"\n                    [iconRight]=\"icon\"\n                    (click)=\"toggleDetails()\"\n                >\n                    {{ texts[2] }}\n                </button>\n                <ng-template #icon>\n                    <tui-svg\n                        src=\"tuiIconChevronDown\"\n                        class=\"t-icon\"\n                        [class.t-icon_rotated]=\"expanded\"\n                    ></tui-svg>\n                </ng-template>\n                <tui-expand\n                    class=\"t-expand\"\n                    [expanded]=\"expanded\"\n                >\n                    <ng-template tuiExpandContent>\n                        <pre class=\"t-value\">Form data: {{ testForm.value | json }}</pre>\n                        <div\n                            tuiGroup\n                            class=\"t-form-controls\"\n                        >\n                            <tui-select\n                                tuiTextfieldSize=\"s\"\n                                class=\"t-select\"\n                                [ngModel]=\"updateOn\"\n                                [ngModelOptions]=\"{standalone: true}\"\n                                (ngModelChange)=\"updateOnChange($event)\"\n                            >\n                                updateOn\n                                <tui-data-list-wrapper\n                                    *tuiDataList\n                                    [items]=\"updateOnVariants\"\n                                ></tui-data-list-wrapper>\n                            </tui-select>\n                            <button\n                                tuiButton\n                                type=\"reset\"\n                                size=\"s\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Reset\n                            </button>\n                            <button\n                                tuiButton\n                                type=\"submit\"\n                                size=\"s\"\n                                class=\"tui-group__auto-width-item\"\n                            >\n                                Submit\n                            </button>\n                        </div>\n                    </ng-template>\n                </tui-expand>\n            </form>\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        #resizer\n        class=\"t-resizer\"\n        [tuiResizer]=\"[1, 0]\"\n        (tuiSizeChange)=\"updateWidth($event[0])\"\n    ></div>\n</div>\n"]}
@@ -2,7 +2,7 @@ import { CommonModule } from '@angular/common';
2
2
  import { NgModule } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { RouterModule } from '@angular/router';
5
- import { TuiDragModule } from '@taiga-ui/cdk';
5
+ import { TuiResizerModule } from '@taiga-ui/cdk';
6
6
  import { TuiButtonModule, TuiDataListModule, TuiExpandModule, TuiGroupModule, TuiHintModule, TuiLinkModule, TuiModeModule, TuiSvgModule, TuiTextfieldControllerModule, TuiTooltipModule, } from '@taiga-ui/core';
7
7
  import { TuiCheckboxLabeledModule, TuiDataListWrapperModule, TuiRadioBlockModule, TuiSelectModule, } from '@taiga-ui/kit';
8
8
  import { TuiDocDemoComponent } from './demo.component';
@@ -15,7 +15,6 @@ TuiDocDemoModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
15
15
  FormsModule,
16
16
  RouterModule,
17
17
  TuiLinkModule,
18
- TuiDragModule,
19
18
  TuiButtonModule,
20
19
  TuiSelectModule,
21
20
  TuiExpandModule,
@@ -28,14 +27,14 @@ TuiDocDemoModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versio
28
27
  TuiDataListWrapperModule,
29
28
  TuiDataListModule,
30
29
  TuiTextfieldControllerModule,
31
- TuiHintModule], exports: [TuiDocDemoComponent] });
30
+ TuiHintModule,
31
+ TuiResizerModule], exports: [TuiDocDemoComponent] });
32
32
  TuiDocDemoModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoModule, imports: [[
33
33
  CommonModule,
34
34
  ReactiveFormsModule,
35
35
  FormsModule,
36
36
  RouterModule,
37
37
  TuiLinkModule,
38
- TuiDragModule,
39
38
  TuiButtonModule,
40
39
  TuiSelectModule,
41
40
  TuiExpandModule,
@@ -49,6 +48,7 @@ TuiDocDemoModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", versio
49
48
  TuiDataListModule,
50
49
  TuiTextfieldControllerModule,
51
50
  TuiHintModule,
51
+ TuiResizerModule,
52
52
  ]] });
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoModule, decorators: [{
54
54
  type: NgModule,
@@ -59,7 +59,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
59
59
  FormsModule,
60
60
  RouterModule,
61
61
  TuiLinkModule,
62
- TuiDragModule,
63
62
  TuiButtonModule,
64
63
  TuiSelectModule,
65
64
  TuiExpandModule,
@@ -73,9 +72,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
73
72
  TuiDataListModule,
74
73
  TuiTextfieldControllerModule,
75
74
  TuiHintModule,
75
+ TuiResizerModule,
76
76
  ],
77
77
  declarations: [TuiDocDemoComponent],
78
78
  exports: [TuiDocDemoComponent],
79
79
  }]
80
80
  }] });
81
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVtby5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvZGVtby9kZW1vLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsV0FBVyxFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxhQUFhLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUMsT0FBTyxFQUNILGVBQWUsRUFDZixpQkFBaUIsRUFDakIsZUFBZSxFQUNmLGNBQWMsRUFDZCxhQUFhLEVBQ2IsYUFBYSxFQUNiLGFBQWEsRUFDYixZQUFZLEVBQ1osNEJBQTRCLEVBQzVCLGdCQUFnQixHQUNuQixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFDSCx3QkFBd0IsRUFDeEIsd0JBQXdCLEVBQ3hCLG1CQUFtQixFQUNuQixlQUFlLEdBQ2xCLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLGtCQUFrQixDQUFDOztBQTJCckQsTUFBTSxPQUFPLGdCQUFnQjs7OEdBQWhCLGdCQUFnQjsrR0FBaEIsZ0JBQWdCLGlCQUhWLG1CQUFtQixhQXBCOUIsWUFBWTtRQUNaLG1CQUFtQjtRQUNuQixXQUFXO1FBQ1gsWUFBWTtRQUNaLGFBQWE7UUFDYixhQUFhO1FBQ2IsZUFBZTtRQUNmLGVBQWU7UUFDZixlQUFlO1FBQ2YsY0FBYztRQUNkLGdCQUFnQjtRQUNoQixhQUFhO1FBQ2IsbUJBQW1CO1FBQ25CLHdCQUF3QjtRQUN4QixZQUFZO1FBQ1osd0JBQXdCO1FBQ3hCLGlCQUFpQjtRQUNqQiw0QkFBNEI7UUFDNUIsYUFBYSxhQUdQLG1CQUFtQjsrR0FFcEIsZ0JBQWdCLFlBeEJoQjtZQUNMLFlBQVk7WUFDWixtQkFBbUI7WUFDbkIsV0FBVztZQUNYLFlBQVk7WUFDWixhQUFhO1lBQ2IsYUFBYTtZQUNiLGVBQWU7WUFDZixlQUFlO1lBQ2YsZUFBZTtZQUNmLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQix3QkFBd0I7WUFDeEIsWUFBWTtZQUNaLHdCQUF3QjtZQUN4QixpQkFBaUI7WUFDakIsNEJBQTRCO1lBQzVCLGFBQWE7U0FDaEI7NEZBSVEsZ0JBQWdCO2tCQXpCNUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixhQUFhO3dCQUNiLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGVBQWU7d0JBQ2YsY0FBYzt3QkFDZCxnQkFBZ0I7d0JBQ2hCLGFBQWE7d0JBQ2IsbUJBQW1CO3dCQUNuQix3QkFBd0I7d0JBQ3hCLFlBQVk7d0JBQ1osd0JBQXdCO3dCQUN4QixpQkFBaUI7d0JBQ2pCLDRCQUE0Qjt3QkFDNUIsYUFBYTtxQkFDaEI7b0JBQ0QsWUFBWSxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLG1CQUFtQixDQUFDO2lCQUNqQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Zvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1JvdXRlck1vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7VHVpRHJhZ01vZHVsZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1xuICAgIFR1aUJ1dHRvbk1vZHVsZSxcbiAgICBUdWlEYXRhTGlzdE1vZHVsZSxcbiAgICBUdWlFeHBhbmRNb2R1bGUsXG4gICAgVHVpR3JvdXBNb2R1bGUsXG4gICAgVHVpSGludE1vZHVsZSxcbiAgICBUdWlMaW5rTW9kdWxlLFxuICAgIFR1aU1vZGVNb2R1bGUsXG4gICAgVHVpU3ZnTW9kdWxlLFxuICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG4gICAgVHVpVG9vbHRpcE1vZHVsZSxcbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuaW1wb3J0IHtcbiAgICBUdWlDaGVja2JveExhYmVsZWRNb2R1bGUsXG4gICAgVHVpRGF0YUxpc3RXcmFwcGVyTW9kdWxlLFxuICAgIFR1aVJhZGlvQmxvY2tNb2R1bGUsXG4gICAgVHVpU2VsZWN0TW9kdWxlLFxufSBmcm9tICdAdGFpZ2EtdWkva2l0JztcblxuaW1wb3J0IHtUdWlEb2NEZW1vQ29tcG9uZW50fSBmcm9tICcuL2RlbW8uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIENvbW1vbk1vZHVsZSxcbiAgICAgICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICAgICAgRm9ybXNNb2R1bGUsXG4gICAgICAgIFJvdXRlck1vZHVsZSxcbiAgICAgICAgVHVpTGlua01vZHVsZSxcbiAgICAgICAgVHVpRHJhZ01vZHVsZSxcbiAgICAgICAgVHVpQnV0dG9uTW9kdWxlLFxuICAgICAgICBUdWlTZWxlY3RNb2R1bGUsXG4gICAgICAgIFR1aUV4cGFuZE1vZHVsZSxcbiAgICAgICAgVHVpR3JvdXBNb2R1bGUsXG4gICAgICAgIFR1aVRvb2x0aXBNb2R1bGUsXG4gICAgICAgIFR1aU1vZGVNb2R1bGUsXG4gICAgICAgIFR1aVJhZGlvQmxvY2tNb2R1bGUsXG4gICAgICAgIFR1aUNoZWNrYm94TGFiZWxlZE1vZHVsZSxcbiAgICAgICAgVHVpU3ZnTW9kdWxlLFxuICAgICAgICBUdWlEYXRhTGlzdFdyYXBwZXJNb2R1bGUsXG4gICAgICAgIFR1aURhdGFMaXN0TW9kdWxlLFxuICAgICAgICBUdWlUZXh0ZmllbGRDb250cm9sbGVyTW9kdWxlLFxuICAgICAgICBUdWlIaW50TW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbVHVpRG9jRGVtb0NvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW1R1aURvY0RlbW9Db21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlEb2NEZW1vTW9kdWxlIHt9XG4iXX0=
81
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVtby5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvZGVtby9kZW1vLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsV0FBVyxFQUFFLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEUsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMvQyxPQUFPLEVBQ0gsZUFBZSxFQUNmLGlCQUFpQixFQUNqQixlQUFlLEVBQ2YsY0FBYyxFQUNkLGFBQWEsRUFDYixhQUFhLEVBQ2IsYUFBYSxFQUNiLFlBQVksRUFDWiw0QkFBNEIsRUFDNUIsZ0JBQWdCLEdBQ25CLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEIsT0FBTyxFQUNILHdCQUF3QixFQUN4Qix3QkFBd0IsRUFDeEIsbUJBQW1CLEVBQ25CLGVBQWUsR0FDbEIsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7O0FBMkJyRCxNQUFNLE9BQU8sZ0JBQWdCOzs4R0FBaEIsZ0JBQWdCOytHQUFoQixnQkFBZ0IsaUJBSFYsbUJBQW1CLGFBcEI5QixZQUFZO1FBQ1osbUJBQW1CO1FBQ25CLFdBQVc7UUFDWCxZQUFZO1FBQ1osYUFBYTtRQUNiLGVBQWU7UUFDZixlQUFlO1FBQ2YsZUFBZTtRQUNmLGNBQWM7UUFDZCxnQkFBZ0I7UUFDaEIsYUFBYTtRQUNiLG1CQUFtQjtRQUNuQix3QkFBd0I7UUFDeEIsWUFBWTtRQUNaLHdCQUF3QjtRQUN4QixpQkFBaUI7UUFDakIsNEJBQTRCO1FBQzVCLGFBQWE7UUFDYixnQkFBZ0IsYUFHVixtQkFBbUI7K0dBRXBCLGdCQUFnQixZQXhCaEI7WUFDTCxZQUFZO1lBQ1osbUJBQW1CO1lBQ25CLFdBQVc7WUFDWCxZQUFZO1lBQ1osYUFBYTtZQUNiLGVBQWU7WUFDZixlQUFlO1lBQ2YsZUFBZTtZQUNmLGNBQWM7WUFDZCxnQkFBZ0I7WUFDaEIsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQix3QkFBd0I7WUFDeEIsWUFBWTtZQUNaLHdCQUF3QjtZQUN4QixpQkFBaUI7WUFDakIsNEJBQTRCO1lBQzVCLGFBQWE7WUFDYixnQkFBZ0I7U0FDbkI7NEZBSVEsZ0JBQWdCO2tCQXpCNUIsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixtQkFBbUI7d0JBQ25CLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixhQUFhO3dCQUNiLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZixlQUFlO3dCQUNmLGNBQWM7d0JBQ2QsZ0JBQWdCO3dCQUNoQixhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsd0JBQXdCO3dCQUN4QixZQUFZO3dCQUNaLHdCQUF3Qjt3QkFDeEIsaUJBQWlCO3dCQUNqQiw0QkFBNEI7d0JBQzVCLGFBQWE7d0JBQ2IsZ0JBQWdCO3FCQUNuQjtvQkFDRCxZQUFZLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztvQkFDbkMsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7aUJBQ2pDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21tb25Nb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Rm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7Um91dGVyTW9kdWxlfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHtUdWlSZXNpemVyTW9kdWxlfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7XG4gICAgVHVpQnV0dG9uTW9kdWxlLFxuICAgIFR1aURhdGFMaXN0TW9kdWxlLFxuICAgIFR1aUV4cGFuZE1vZHVsZSxcbiAgICBUdWlHcm91cE1vZHVsZSxcbiAgICBUdWlIaW50TW9kdWxlLFxuICAgIFR1aUxpbmtNb2R1bGUsXG4gICAgVHVpTW9kZU1vZHVsZSxcbiAgICBUdWlTdmdNb2R1bGUsXG4gICAgVHVpVGV4dGZpZWxkQ29udHJvbGxlck1vZHVsZSxcbiAgICBUdWlUb29sdGlwTW9kdWxlLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQge1xuICAgIFR1aUNoZWNrYm94TGFiZWxlZE1vZHVsZSxcbiAgICBUdWlEYXRhTGlzdFdyYXBwZXJNb2R1bGUsXG4gICAgVHVpUmFkaW9CbG9ja01vZHVsZSxcbiAgICBUdWlTZWxlY3RNb2R1bGUsXG59IGZyb20gJ0B0YWlnYS11aS9raXQnO1xuXG5pbXBvcnQge1R1aURvY0RlbW9Db21wb25lbnR9IGZyb20gJy4vZGVtby5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgICAgICBGb3Jtc01vZHVsZSxcbiAgICAgICAgUm91dGVyTW9kdWxlLFxuICAgICAgICBUdWlMaW5rTW9kdWxlLFxuICAgICAgICBUdWlCdXR0b25Nb2R1bGUsXG4gICAgICAgIFR1aVNlbGVjdE1vZHVsZSxcbiAgICAgICAgVHVpRXhwYW5kTW9kdWxlLFxuICAgICAgICBUdWlHcm91cE1vZHVsZSxcbiAgICAgICAgVHVpVG9vbHRpcE1vZHVsZSxcbiAgICAgICAgVHVpTW9kZU1vZHVsZSxcbiAgICAgICAgVHVpUmFkaW9CbG9ja01vZHVsZSxcbiAgICAgICAgVHVpQ2hlY2tib3hMYWJlbGVkTW9kdWxlLFxuICAgICAgICBUdWlTdmdNb2R1bGUsXG4gICAgICAgIFR1aURhdGFMaXN0V3JhcHBlck1vZHVsZSxcbiAgICAgICAgVHVpRGF0YUxpc3RNb2R1bGUsXG4gICAgICAgIFR1aVRleHRmaWVsZENvbnRyb2xsZXJNb2R1bGUsXG4gICAgICAgIFR1aUhpbnRNb2R1bGUsXG4gICAgICAgIFR1aVJlc2l6ZXJNb2R1bGUsXG4gICAgXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUdWlEb2NEZW1vQ29tcG9uZW50XSxcbiAgICBleHBvcnRzOiBbVHVpRG9jRGVtb0NvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY0RlbW9Nb2R1bGUge31cbiJdfQ==