@taiga-ui/addon-doc 3.14.0-dev.main-6fca3d4 → 3.14.0-dev.main-49a682e

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.
@@ -8,8 +8,8 @@ import * as i1 from "@angular/common";
8
8
  import * as i2 from "ngx-highlightjs";
9
9
  export class TuiDocCodeComponent {
10
10
  constructor() {
11
- this.rawLoader$$ = new BehaviorSubject(``);
12
- this.filename = ``;
11
+ this.rawLoader$$ = new BehaviorSubject('');
12
+ this.filename = '';
13
13
  this.processor$ = this.rawLoader$$.pipe(switchMap(tuiRawLoad), map(tuiTryParseMarkdownCodeBlock));
14
14
  }
15
15
  set code(code) {
@@ -24,9 +24,9 @@ TuiDocCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", ve
24
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocCodeComponent, decorators: [{
25
25
  type: Component,
26
26
  args: [{
27
- selector: `tui-doc-code`,
28
- templateUrl: `./code.template.html`,
29
- styleUrls: [`./code.style.less`],
27
+ selector: 'tui-doc-code',
28
+ templateUrl: './code.template.html',
29
+ styleUrls: ['./code.style.less'],
30
30
  }]
31
31
  }], propDecorators: { filename: [{
32
32
  type: Input
@@ -34,6 +34,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
34
34
  type: Input
35
35
  }], hasFilename: [{
36
36
  type: HostBinding,
37
- args: [`class._has-filename`]
37
+ args: ['class._has-filename']
38
38
  }] } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvY29kZS9jb2RlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9jb2RlL2NvZGUudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUNyQyxPQUFPLEVBQUMsR0FBRyxFQUFFLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRzlDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNoRCxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQzs7OztBQU9oRSxNQUFNLE9BQU8sbUJBQW1CO0lBTGhDO1FBTXFCLGdCQUFXLEdBQUcsSUFBSSxlQUFlLENBQW1CLEVBQUUsQ0FBQyxDQUFDO1FBR3pFLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFFTCxlQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQ3ZDLFNBQVMsQ0FBQyxVQUFVLENBQUMsRUFDckIsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQ3BDLENBQUM7S0FXTDtJQVRHLElBQ0ksSUFBSSxDQUFDLElBQXNCO1FBQzNCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUNJLFdBQVc7UUFDWCxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQzNCLENBQUM7O2lIQW5CUSxtQkFBbUI7cUdBQW5CLG1CQUFtQix5S0NiaEMsc09BVUE7NEZER2EsbUJBQW1CO2tCQUwvQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsc0JBQXNCO29CQUNuQyxTQUFTLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztpQkFDbkM7OEJBS0csUUFBUTtzQkFEUCxLQUFLO2dCQVNGLElBQUk7c0JBRFAsS0FBSztnQkFNRixXQUFXO3NCQURkLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcCwgc3dpdGNoTWFwfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7UmF3TG9hZGVyQ29udGVudH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9wYWdlJztcbmltcG9ydCB7dHVpUmF3TG9hZH0gZnJvbSAnLi4vLi4vdXRpbHMvcmF3LWxvYWQnO1xuaW1wb3J0IHt0dWlUcnlQYXJzZU1hcmtkb3duQ29kZUJsb2NrfSBmcm9tICcuL3BhcnNlLWNvZGUtYmxvY2snO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogYHR1aS1kb2MtY29kZWAsXG4gICAgdGVtcGxhdGVVcmw6IGAuL2NvZGUudGVtcGxhdGUuaHRtbGAsXG4gICAgc3R5bGVVcmxzOiBbYC4vY29kZS5zdHlsZS5sZXNzYF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY0NvZGVDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgcmF3TG9hZGVyJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFJhd0xvYWRlckNvbnRlbnQ+KGBgKTtcblxuICAgIEBJbnB1dCgpXG4gICAgZmlsZW5hbWUgPSBgYDtcblxuICAgIHJlYWRvbmx5IHByb2Nlc3NvciQgPSB0aGlzLnJhd0xvYWRlciQkLnBpcGUoXG4gICAgICAgIHN3aXRjaE1hcCh0dWlSYXdMb2FkKSxcbiAgICAgICAgbWFwKHR1aVRyeVBhcnNlTWFya2Rvd25Db2RlQmxvY2spLFxuICAgICk7XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBjb2RlKGNvZGU6IFJhd0xvYWRlckNvbnRlbnQpIHtcbiAgICAgICAgdGhpcy5yYXdMb2FkZXIkJC5uZXh0KGNvZGUpO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZyhgY2xhc3MuX2hhcy1maWxlbmFtZWApXG4gICAgZ2V0IGhhc0ZpbGVuYW1lKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISF0aGlzLmZpbGVuYW1lO1xuICAgIH1cbn1cbiIsIjxwXG4gICAgKm5nSWY9XCJmaWxlbmFtZVwiXG4gICAgY2xhc3M9XCJ0LWhlYWRlclwiXG4+XG4gICAge3sgZmlsZW5hbWUgfX1cbjwvcD5cbjxwcmVcbiAgICAqbmdGb3I9XCJsZXQgY29udGVudCBvZiBwcm9jZXNzb3IkIHwgYXN5bmNcIlxuICAgIGNsYXNzPVwidC1jb2RlXCJcbj48Y29kZSBbbGluZU51bWJlcnNdPVwidHJ1ZVwiIFtoaWdobGlnaHRdPVwiY29udGVudFwiPjwvY29kZT48L3ByZT5cbiJdfQ==
39
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29kZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvY29kZS9jb2RlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9jb2RlL2NvZGUudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUNyQyxPQUFPLEVBQUMsR0FBRyxFQUFFLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBRzlDLE9BQU8sRUFBQyxVQUFVLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUNoRCxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSxvQkFBb0IsQ0FBQzs7OztBQU9oRSxNQUFNLE9BQU8sbUJBQW1CO0lBTGhDO1FBTXFCLGdCQUFXLEdBQUcsSUFBSSxlQUFlLENBQW1CLEVBQUUsQ0FBQyxDQUFDO1FBR3pFLGFBQVEsR0FBRyxFQUFFLENBQUM7UUFFTCxlQUFVLEdBQUcsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQ3ZDLFNBQVMsQ0FBQyxVQUFVLENBQUMsRUFDckIsR0FBRyxDQUFDLDRCQUE0QixDQUFDLENBQ3BDLENBQUM7S0FXTDtJQVRHLElBQ0ksSUFBSSxDQUFDLElBQXNCO1FBQzNCLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxJQUNJLFdBQVc7UUFDWCxPQUFPLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQzNCLENBQUM7O2lIQW5CUSxtQkFBbUI7cUdBQW5CLG1CQUFtQix5S0NiaEMsc09BVUE7NEZER2EsbUJBQW1CO2tCQUwvQixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsc0JBQXNCO29CQUNuQyxTQUFTLEVBQUUsQ0FBQyxtQkFBbUIsQ0FBQztpQkFDbkM7OEJBS0csUUFBUTtzQkFEUCxLQUFLO2dCQVNGLElBQUk7c0JBRFAsS0FBSztnQkFNRixXQUFXO3NCQURkLFdBQVc7dUJBQUMscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0JlaGF2aW9yU3ViamVjdH0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcCwgc3dpdGNoTWFwfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7UmF3TG9hZGVyQ29udGVudH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9wYWdlJztcbmltcG9ydCB7dHVpUmF3TG9hZH0gZnJvbSAnLi4vLi4vdXRpbHMvcmF3LWxvYWQnO1xuaW1wb3J0IHt0dWlUcnlQYXJzZU1hcmtkb3duQ29kZUJsb2NrfSBmcm9tICcuL3BhcnNlLWNvZGUtYmxvY2snO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1kb2MtY29kZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvZGUudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vY29kZS5zdHlsZS5sZXNzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY0NvZGVDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgcmF3TG9hZGVyJCQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PFJhd0xvYWRlckNvbnRlbnQ+KCcnKTtcblxuICAgIEBJbnB1dCgpXG4gICAgZmlsZW5hbWUgPSAnJztcblxuICAgIHJlYWRvbmx5IHByb2Nlc3NvciQgPSB0aGlzLnJhd0xvYWRlciQkLnBpcGUoXG4gICAgICAgIHN3aXRjaE1hcCh0dWlSYXdMb2FkKSxcbiAgICAgICAgbWFwKHR1aVRyeVBhcnNlTWFya2Rvd25Db2RlQmxvY2spLFxuICAgICk7XG5cbiAgICBASW5wdXQoKVxuICAgIHNldCBjb2RlKGNvZGU6IFJhd0xvYWRlckNvbnRlbnQpIHtcbiAgICAgICAgdGhpcy5yYXdMb2FkZXIkJC5uZXh0KGNvZGUpO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZygnY2xhc3MuX2hhcy1maWxlbmFtZScpXG4gICAgZ2V0IGhhc0ZpbGVuYW1lKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gISF0aGlzLmZpbGVuYW1lO1xuICAgIH1cbn1cbiIsIjxwXG4gICAgKm5nSWY9XCJmaWxlbmFtZVwiXG4gICAgY2xhc3M9XCJ0LWhlYWRlclwiXG4+XG4gICAge3sgZmlsZW5hbWUgfX1cbjwvcD5cbjxwcmVcbiAgICAqbmdGb3I9XCJsZXQgY29udGVudCBvZiBwcm9jZXNzb3IkIHwgYXN5bmNcIlxuICAgIGNsYXNzPVwidC1jb2RlXCJcbj48Y29kZSBbbGluZU51bWJlcnNdPVwidHJ1ZVwiIFtoaWdobGlnaHRdPVwiY29udGVudFwiPjwvY29kZT48L3ByZT5cbiJdfQ==
@@ -29,9 +29,9 @@ __decorate([
29
29
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocCopyComponent, decorators: [{
30
30
  type: Component,
31
31
  args: [{
32
- selector: `tui-doc-copy`,
33
- templateUrl: `./copy.template.html`,
34
- styleUrls: [`./copy.style.less`],
32
+ selector: 'tui-doc-copy',
33
+ templateUrl: './copy.template.html',
34
+ styleUrls: ['./copy.style.less'],
35
35
  changeDetection: ChangeDetectionStrategy.OnPush,
36
36
  providers: [TuiDestroyService],
37
37
  }]
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
39
39
  type: Inject,
40
40
  args: [TUI_COPY_TEXTS]
41
41
  }] }]; }, propDecorators: { copied$: [] } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvY29weS9jb3B5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9jb3B5L2NvcHkudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFDLGlCQUFpQixFQUFFLE9BQU8sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sRUFBYSxPQUFPLEVBQUUsS0FBSyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDOzs7OztBQUU3RCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUM7QUFTNUIsTUFBTSxPQUFPLG1CQUFtQjtJQUc1QixZQUE2QyxNQUFvQztRQUFwQyxXQUFNLEdBQU4sTUFBTSxDQUE4QjtRQUZoRSxVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUU2QyxDQUFDO0lBR3JGLElBQUksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQ2xCLFdBQVcsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUN6RSxDQUFDO0lBQ04sQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7O2lIQWRRLG1CQUFtQixrQkFHUixjQUFjO3FHQUh6QixtQkFBbUIsdUNBRmpCLENBQUMsaUJBQWlCLENBQUMsMEJDYmxDLDJmQXVCQTtBREZJO0lBREMsT0FBTztrREFLUDs0RkFWUSxtQkFBbUI7a0JBUC9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFdBQVcsRUFBRSxzQkFBc0I7b0JBQ25DLFNBQVMsRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNoQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsU0FBUyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQ2pDOzswQkFJZ0IsTUFBTTsyQkFBQyxjQUFjOzRDQUc5QixPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlEZXN0cm95U2VydmljZSwgdHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1RVSV9DT1BZX1RFWFRTfSBmcm9tICdAdGFpZ2EtdWkva2l0JztcbmltcG9ydCB7T2JzZXJ2YWJsZSwgU3ViamVjdCwgdGltZXJ9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHttYXBUbywgc3RhcnRXaXRoLCBzd2l0Y2hNYXBUb30gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5jb25zdCBDT1BJRURfVElNRU9VVCA9IDE1MDA7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiBgdHVpLWRvYy1jb3B5YCxcbiAgICB0ZW1wbGF0ZVVybDogYC4vY29weS50ZW1wbGF0ZS5odG1sYCxcbiAgICBzdHlsZVVybHM6IFtgLi9jb3B5LnN0eWxlLmxlc3NgXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBwcm92aWRlcnM6IFtUdWlEZXN0cm95U2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY0NvcHlDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgY29weSQgPSBuZXcgU3ViamVjdCgpO1xuXG4gICAgY29uc3RydWN0b3IoQEluamVjdChUVUlfQ09QWV9URVhUUykgcmVhZG9ubHkgdGV4dHMkOiBPYnNlcnZhYmxlPFtzdHJpbmcsIHN0cmluZ10+KSB7fVxuXG4gICAgQHR1aVB1cmVcbiAgICBnZXQgY29waWVkJCgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29weSQucGlwZShcbiAgICAgICAgICAgIHN3aXRjaE1hcFRvKHRpbWVyKENPUElFRF9USU1FT1VUKS5waXBlKG1hcFRvKGZhbHNlKSwgc3RhcnRXaXRoKHRydWUpKSksXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgb25DbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb3B5JC5uZXh0KCk7XG4gICAgfVxufVxuIiwiPGJ1dHRvblxuICAgICpuZ0lmPVwidGV4dHMkIHwgYXN5bmMgYXMgdGV4dHNcIlxuICAgIHR1aUJ1dHRvblxuICAgIHR5cGU9XCJidXR0b25cIlxuICAgIGFwcGVhcmFuY2U9XCJcIlxuICAgIHNpemU9XCJzXCJcbiAgICBjbGFzcz1cInQtY29weVwiXG4gICAgW3RpdGxlXT1cInRleHRzWzBdXCJcbiAgICAoY2xpY2spPVwib25DbGljaygpXCJcbj5cbiAgICA8c3BhblxuICAgICAgICBjbGFzcz1cInQtY29udGVudFwiXG4gICAgICAgIFtjbGFzcy50LWNvbnRlbnRfbW92ZWRdPVwiY29waWVkJCB8IGFzeW5jXCJcbiAgICA+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgICBjbGFzcz1cInQtaW5pdGlhbFwiXG4gICAgICAgICAgICBbYXR0ci5kYXRhLXRleHRdPVwidGV4dHNbMF1cIlxuICAgICAgICA+XG4gICAgICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICAge3sgdGV4dHNbMV0gfX1cbiAgICA8L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29weS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1kb2Mvc3JjL2NvbXBvbmVudHMvY29weS9jb3B5LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWRvYy9zcmMvY29tcG9uZW50cy9jb3B5L2NvcHkudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekUsT0FBTyxFQUFDLGlCQUFpQixFQUFFLE9BQU8sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzdDLE9BQU8sRUFBYSxPQUFPLEVBQUUsS0FBSyxFQUFDLE1BQU0sTUFBTSxDQUFDO0FBQ2hELE9BQU8sRUFBQyxLQUFLLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBQyxNQUFNLGdCQUFnQixDQUFDOzs7OztBQUU3RCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUM7QUFTNUIsTUFBTSxPQUFPLG1CQUFtQjtJQUc1QixZQUE2QyxNQUFvQztRQUFwQyxXQUFNLEdBQU4sTUFBTSxDQUE4QjtRQUZoRSxVQUFLLEdBQUcsSUFBSSxPQUFPLEVBQUUsQ0FBQztJQUU2QyxDQUFDO0lBR3JGLElBQUksT0FBTztRQUNQLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQ2xCLFdBQVcsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUN6RSxDQUFDO0lBQ04sQ0FBQztJQUVELE9BQU87UUFDSCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ3RCLENBQUM7O2lIQWRRLG1CQUFtQixrQkFHUixjQUFjO3FHQUh6QixtQkFBbUIsdUNBRmpCLENBQUMsaUJBQWlCLENBQUMsMEJDYmxDLDJmQXVCQTtBREZJO0lBREMsT0FBTztrREFLUDs0RkFWUSxtQkFBbUI7a0JBUC9CLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGNBQWM7b0JBQ3hCLFdBQVcsRUFBRSxzQkFBc0I7b0JBQ25DLFNBQVMsRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNoQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsU0FBUyxFQUFFLENBQUMsaUJBQWlCLENBQUM7aUJBQ2pDOzswQkFJZ0IsTUFBTTsyQkFBQyxjQUFjOzRDQUc5QixPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlEZXN0cm95U2VydmljZSwgdHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1RVSV9DT1BZX1RFWFRTfSBmcm9tICdAdGFpZ2EtdWkva2l0JztcbmltcG9ydCB7T2JzZXJ2YWJsZSwgU3ViamVjdCwgdGltZXJ9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHttYXBUbywgc3RhcnRXaXRoLCBzd2l0Y2hNYXBUb30gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5jb25zdCBDT1BJRURfVElNRU9VVCA9IDE1MDA7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndHVpLWRvYy1jb3B5JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vY29weS50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9jb3B5LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBwcm92aWRlcnM6IFtUdWlEZXN0cm95U2VydmljZV0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aURvY0NvcHlDb21wb25lbnQge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgY29weSQgPSBuZXcgU3ViamVjdCgpO1xuXG4gICAgY29uc3RydWN0b3IoQEluamVjdChUVUlfQ09QWV9URVhUUykgcmVhZG9ubHkgdGV4dHMkOiBPYnNlcnZhYmxlPFtzdHJpbmcsIHN0cmluZ10+KSB7fVxuXG4gICAgQHR1aVB1cmVcbiAgICBnZXQgY29waWVkJCgpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29weSQucGlwZShcbiAgICAgICAgICAgIHN3aXRjaE1hcFRvKHRpbWVyKENPUElFRF9USU1FT1VUKS5waXBlKG1hcFRvKGZhbHNlKSwgc3RhcnRXaXRoKHRydWUpKSksXG4gICAgICAgICk7XG4gICAgfVxuXG4gICAgb25DbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5jb3B5JC5uZXh0KCk7XG4gICAgfVxufVxuIiwiPGJ1dHRvblxuICAgICpuZ0lmPVwidGV4dHMkIHwgYXN5bmMgYXMgdGV4dHNcIlxuICAgIHR1aUJ1dHRvblxuICAgIHR5cGU9XCJidXR0b25cIlxuICAgIGFwcGVhcmFuY2U9XCJcIlxuICAgIHNpemU9XCJzXCJcbiAgICBjbGFzcz1cInQtY29weVwiXG4gICAgW3RpdGxlXT1cInRleHRzWzBdXCJcbiAgICAoY2xpY2spPVwib25DbGljaygpXCJcbj5cbiAgICA8c3BhblxuICAgICAgICBjbGFzcz1cInQtY29udGVudFwiXG4gICAgICAgIFtjbGFzcy50LWNvbnRlbnRfbW92ZWRdPVwiY29waWVkJCB8IGFzeW5jXCJcbiAgICA+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgICBjbGFzcz1cInQtaW5pdGlhbFwiXG4gICAgICAgICAgICBbYXR0ci5kYXRhLXRleHRdPVwidGV4dHNbMF1cIlxuICAgICAgICA+XG4gICAgICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICAgIDwvc3Bhbj5cbiAgICAgICAge3sgdGV4dHNbMV0gfX1cbiAgICA8L3NwYW4+XG48L2J1dHRvbj5cbiJdfQ==
@@ -24,14 +24,14 @@ export class TuiDocDemoComponent {
24
24
  this.texts = texts;
25
25
  this.control = null;
26
26
  this.template = null;
27
- this.updateOnVariants = [`change`, `blur`, `submit`];
27
+ this.updateOnVariants = ['change', 'blur', 'submit'];
28
28
  this.updateOn = this.updateOnVariants[0];
29
29
  this.expanded = false;
30
30
  this.opaque = true;
31
31
  this.mode = this.getUrlTree().queryParams.tuiMode || null;
32
32
  this.sandboxWidth = parseInt(this.getUrlTree().queryParams.sandboxWidth, 10);
33
33
  this.change$ = new Subject();
34
- this.items = [`onLight`, `onDark`];
34
+ this.items = ['onLight', 'onDark'];
35
35
  }
36
36
  onResize() {
37
37
  this.updateWidth();
@@ -65,7 +65,7 @@ export class TuiDocDemoComponent {
65
65
  const clamped = Math.round(tuiClamp(safe, MIN_WIDTH, total)) - this.delta;
66
66
  const validated = safe < total ? clamped : NaN;
67
67
  this.resizer.nativeElement.textContent = String(clamped);
68
- this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : ``;
68
+ this.resizeable.nativeElement.style.width = validated ? tuiPx(safe) : '';
69
69
  this.sandboxWidth = validated;
70
70
  }
71
71
  get delta() {
@@ -108,9 +108,9 @@ __decorate([
108
108
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDemoComponent, decorators: [{
109
109
  type: Component,
110
110
  args: [{
111
- selector: `tui-doc-demo`,
112
- templateUrl: `./demo.template.html`,
113
- styleUrls: [`./demo.style.less`],
111
+ selector: 'tui-doc-demo',
112
+ templateUrl: './demo.template.html',
113
+ styleUrls: ['./demo.style.less'],
114
114
  changeDetection: ChangeDetectionStrategy.OnPush,
115
115
  providers: [
116
116
  TuiDestroyService,
@@ -140,10 +140,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
140
140
  args: [TuiResizeableDirective, { static: true }]
141
141
  }], content: [{
142
142
  type: ViewChild,
143
- args: [`content`, { static: true }]
143
+ args: ['content', { static: true }]
144
144
  }], resizer: [{
145
145
  type: ViewChild,
146
- args: [`resizer`, { static: true }]
146
+ args: ['resizer', { static: true }]
147
147
  }], control: [{
148
148
  type: Input
149
149
  }], template: [{
@@ -151,9 +151,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
151
151
  args: [TemplateRef]
152
152
  }], onResize: [{
153
153
  type: HostListener,
154
- args: [`window:resize`]
154
+ args: ['window:resize']
155
155
  }], onMouseUp: [{
156
156
  type: HostListener,
157
- args: [`document:mouseup.silent`]
157
+ args: ['document:mouseup.silent']
158
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"]}
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":";AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,UAAU,EACV,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,WAAW,EACX,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAC,aAAa,EAAU,MAAM,iBAAiB,CAAC;AACvD,OAAO,EACH,aAAa,EACb,QAAQ,EACR,iBAAiB,EACjB,OAAO,EACP,KAAK,EACL,sBAAsB,GACzB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAgB,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AAC/D,OAAO,EAAC,OAAO,EAAC,MAAM,MAAM,CAAC;AAE7B,OAAO,EAAC,kBAAkB,EAAC,MAAM,mBAAmB,CAAC;;;;;;;;AAErD,MAAM,SAAS,GAAG,GAAG,CAAC;AAetB,MAAM,OAAO,mBAAmB;IA2B5B,YACoC,QAAiB,EACZ,UAAmC,EACrC,WAAqB,EAChB,aAA4B,EAC/B,KAA+B;QAJpC,aAAQ,GAAR,QAAQ,CAAS;QACZ,eAAU,GAAV,UAAU,CAAyB;QACrC,gBAAW,GAAX,WAAW,CAAU;QAChB,kBAAa,GAAb,aAAa,CAAe;QAC/B,UAAK,GAAL,KAAK,CAA0B;QArBxE,YAAO,GAA2B,IAAI,CAAC;QAG9B,aAAQ,GAAgD,IAAI,CAAC;QAG7D,qBAAgB,GAAG,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAU,CAAC;QAClE,aAAQ,GAAiC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QAClE,aAAQ,GAAG,KAAK,CAAC;QACjB,WAAM,GAAG,IAAI,CAAC;QACd,SAAI,GAAyB,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,OAAO,IAAI,IAAI,CAAC;QAC3E,iBAAY,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;QAE/D,YAAO,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC9B,UAAK,GAA6B,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAQ9D,CAAC;IAGJ,QAAQ;QACJ,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAGD,SAAS;QACL,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IACjD,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;IACrD,CAAC;IAED,YAAY,CAAC,IAA0B;QACnC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACxC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACxB,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;IAED,WAAW,CAAC,QAAgB,GAAG;QAC3B,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACpD,OAAO;SACV;QAED,MAAM,IAAI,GAAG,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;QAChE,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC;QACxD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;QAC1E,MAAM,SAAS,GAAG,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC;QAE/C,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC,CAAC;QACzD,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACzE,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC;IAClC,CAAC;IAED,IAAY,KAAK;QACb,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,OAAO;YAClC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW;gBACrC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,WAAW;YAC5C,CAAC,CAAC,CAAC,CAAC;IACZ,CAAC;IAGO,SAAS,CAAC,OAA6B,EAAE,YAAoB;QACjE,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAClC,MAAM,EAAC,WAAW,EAAC,GAAG,OAAO,CAAC;QAC9B,MAAM,SAAS,GAAG,OAAO,CAAC,CAAC,CAAC,EAAC,OAAO,EAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC3C,MAAM,WAAW,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAC,YAAY,EAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAEtE,OAAO,WAAW,CAAC,YAAY,CAAC;QAChC,OAAO,WAAW,CAAC,OAAO,CAAC;QAE3B,OAAO,CAAC,WAAW,iDACZ,WAAW,GACX,SAAS,GACT,WAAW,CACjB,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC;IACnD,CAAC;IAEO,UAAU;QACd,MAAM,EAAC,OAAO,EAAE,QAAQ,EAAC,GAAG,IAAI,CAAC;QAEjC,IAAI,OAAO,EAAE;YACT,IAAI,CAAC,QAAQ,GAAG,IAAI,SAAS,CAAC,EAAC,SAAS,EAAE,OAAO,EAAC,EAAE,EAAC,QAAQ,EAAC,CAAC,CAAC;SACnE;IACL,CAAC;IAEO,UAAU;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IAC7D,CAAC;;iHArHQ,mBAAmB,kBA4BhB,aAAa,aACb,UAAU,aACV,QAAQ,aACR,aAAa,aACb,kBAAkB;qGAhCrB,mBAAmB,yKARjB;QACP,iBAAiB;QACjB;YACI,OAAO,EAAE,gBAAgB;YACzB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,mBAAmB,CAAC;SACrD;KACJ,gEAea,WAAW,4FAZd,sBAAsB,oQC7CrC,ovLA8KA;ADzCI;IADC,OAAO;oDAiBP;4FAzGQ,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;;0BA6BQ,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,UAAU;;0BACjB,MAAM;2BAAC,QAAQ;;0BACf,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,kBAAkB;4CA9Bb,UAAU;sBAD1B,SAAS;uBAAC,sBAAsB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAIhC,OAAO;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAInB,OAAO;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBAIpC,OAAO;sBADN,KAAK;gBAIG,QAAQ;sBADhB,YAAY;uBAAC,WAAW;gBAuBzB,QAAQ;sBADP,YAAY;uBAAC,eAAe;gBAO7B,SAAS;sBADR,YAAY;uBAAC,yBAAyB;gBAgD/B,SAAS","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"]}
@@ -6,7 +6,7 @@ import { tuiCoerceValue } from '../../utils/coerce-value';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/common";
8
8
  import * as i2 from "@angular/router";
9
- const SERIALIZED_SUFFIX = `$`;
9
+ const SERIALIZED_SUFFIX = '$';
10
10
  // @bad TODO: refactor output and value sync
11
11
  export class TuiDocDocumentationPropertyConnectorDirective {
12
12
  constructor(template, locationRef, activatedRoute, urlSerializer) {
@@ -14,9 +14,9 @@ export class TuiDocDocumentationPropertyConnectorDirective {
14
14
  this.locationRef = locationRef;
15
15
  this.activatedRoute = activatedRoute;
16
16
  this.urlSerializer = urlSerializer;
17
- this.documentationPropertyName = ``;
17
+ this.documentationPropertyName = '';
18
18
  this.documentationPropertyMode = null;
19
- this.documentationPropertyType = ``;
19
+ this.documentationPropertyType = '';
20
20
  this.documentationPropertyDeprecated = false;
21
21
  this.documentationPropertyValues = null;
22
22
  this.documentationPropertyValueChange = new EventEmitter();
@@ -28,11 +28,11 @@ export class TuiDocDocumentationPropertyConnectorDirective {
28
28
  }
29
29
  get attrName() {
30
30
  switch (this.documentationPropertyMode) {
31
- case `input`:
31
+ case 'input':
32
32
  return `[${this.documentationPropertyName}]`;
33
- case `output`:
33
+ case 'output':
34
34
  return `(${this.documentationPropertyName})`;
35
- case `input-output`:
35
+ case 'input-output':
36
36
  return `[(${this.documentationPropertyName})]`;
37
37
  default:
38
38
  return this.documentationPropertyName;
@@ -42,7 +42,7 @@ export class TuiDocDocumentationPropertyConnectorDirective {
42
42
  return !!this.documentationPropertyValues;
43
43
  }
44
44
  get shouldShowValues() {
45
- return this.documentationPropertyMode !== `output`;
45
+ return this.documentationPropertyMode !== 'output';
46
46
  }
47
47
  ngOnChanges() {
48
48
  this.changed$.next();
@@ -74,7 +74,7 @@ export class TuiDocDocumentationPropertyConnectorDirective {
74
74
  const computedValue = isValueAvailableByKey && this.documentationPropertyValues
75
75
  ? this.documentationPropertyValues.indexOf(value)
76
76
  : value;
77
- const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : ``;
77
+ const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';
78
78
  const propName = this.documentationPropertyName + suffix;
79
79
  tree.queryParams = Object.assign(Object.assign({}, tree.queryParams), { [propName]: computedValue });
80
80
  this.locationRef.go(String(tree));
@@ -85,8 +85,8 @@ TuiDocDocumentationPropertyConnectorDirective.ɵdir = i0.ɵɵngDeclareDirective(
85
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDocumentationPropertyConnectorDirective, decorators: [{
86
86
  type: Directive,
87
87
  args: [{
88
- selector: `ng-template[documentationPropertyName]`,
89
- exportAs: `documentationProperty`,
88
+ selector: 'ng-template[documentationPropertyName]',
89
+ exportAs: 'documentationProperty',
90
90
  }]
91
91
  }], ctorParameters: function () { return [{ type: i0.TemplateRef, decorators: [{
92
92
  type: Inject,
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
115
115
  }], documentationPropertyValueChange: [{
116
116
  type: Output
117
117
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation-property-connector.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation-property-connector.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    Directive,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport {ActivatedRoute, Params, UrlSerializer} from '@angular/router';\nimport {BehaviorSubject, Subject} from 'rxjs';\n\nimport {tuiCoerceValue} from '../../utils/coerce-value';\n\nconst SERIALIZED_SUFFIX = `$`;\n\nexport type DocumentationPropertyType = 'input-output' | 'input' | 'output' | null;\n\n// @bad TODO: refactor output and value sync\n@Directive({\n    selector: `ng-template[documentationPropertyName]`,\n    exportAs: `documentationProperty`,\n})\nexport class TuiDocDocumentationPropertyConnectorDirective<T>\n    implements OnInit, OnChanges\n{\n    @Input()\n    documentationPropertyName = ``;\n\n    @Input()\n    documentationPropertyMode: DocumentationPropertyType = null;\n\n    @Input()\n    documentationPropertyType = ``;\n\n    @Input()\n    documentationPropertyValue!: T;\n\n    @Input()\n    documentationPropertyDeprecated = false;\n\n    @Input()\n    documentationPropertyValues: readonly T[] | null = null;\n\n    @Output()\n    readonly documentationPropertyValueChange = new EventEmitter<T>();\n\n    readonly changed$ = new Subject<void>();\n\n    readonly emits$ = new BehaviorSubject(1);\n\n    constructor(\n        @Inject(TemplateRef) readonly template: TemplateRef<Record<string, unknown>>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(ActivatedRoute) private readonly activatedRoute: ActivatedRoute,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n    ) {}\n\n    ngOnInit(): void {\n        this.parseParams(this.activatedRoute.snapshot.queryParams);\n    }\n\n    get attrName(): string {\n        switch (this.documentationPropertyMode) {\n            case `input`:\n                return `[${this.documentationPropertyName}]`;\n            case `output`:\n                return `(${this.documentationPropertyName})`;\n            case `input-output`:\n                return `[(${this.documentationPropertyName})]`;\n            default:\n                return this.documentationPropertyName;\n        }\n    }\n\n    get hasItems(): boolean {\n        return !!this.documentationPropertyValues;\n    }\n\n    get shouldShowValues(): boolean {\n        return this.documentationPropertyMode !== `output`;\n    }\n\n    ngOnChanges(): void {\n        this.changed$.next();\n    }\n\n    onValueChange(value: T): void {\n        this.documentationPropertyValue = value;\n        this.documentationPropertyValueChange.emit(value);\n        this.setQueryParam(value);\n    }\n\n    emitEvent(event: unknown): void {\n        // For more convenient debugging\n        console.info(this.attrName, event);\n\n        this.emits$.next(this.emits$.value + 1);\n    }\n\n    private parseParams(params: Params): void {\n        const propertyValue: string | undefined = params[this.documentationPropertyName];\n        const propertyValueWithSuffix: number | string | undefined =\n            params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`];\n\n        if (!propertyValue && !propertyValueWithSuffix) {\n            return;\n        }\n\n        const value =\n            !!propertyValueWithSuffix && this.documentationPropertyValues\n                ? this.documentationPropertyValues[propertyValueWithSuffix as number]\n                : tuiCoerceValue(propertyValue);\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.documentationPropertyValues\n                ? this.documentationPropertyValues.indexOf(value as T)\n                : value;\n\n        const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : ``;\n        const propName = this.documentationPropertyName + suffix;\n\n        tree.queryParams = {\n            ...tree.queryParams,\n            [propName]: computedValue,\n        };\n\n        this.locationRef.go(String(tree));\n    }\n}\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation-property-connector.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation-property-connector.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EACH,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,MAAM,EACN,WAAW,GACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,cAAc,EAAU,aAAa,EAAC,MAAM,iBAAiB,CAAC;AACtE,OAAO,EAAC,eAAe,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AAE9C,OAAO,EAAC,cAAc,EAAC,MAAM,0BAA0B,CAAC;;;;AAExD,MAAM,iBAAiB,GAAG,GAAG,CAAC;AAI9B,4CAA4C;AAK5C,MAAM,OAAO,6CAA6C;IA4BtD,YACkC,QAA8C,EACzC,WAAqB,EACf,cAA8B,EAC/B,aAA4B;QAHtC,aAAQ,GAAR,QAAQ,CAAsC;QACzC,gBAAW,GAAX,WAAW,CAAU;QACf,mBAAc,GAAd,cAAc,CAAgB;QAC/B,kBAAa,GAAb,aAAa,CAAe;QA5BxE,8BAAyB,GAAG,EAAE,CAAC;QAG/B,8BAAyB,GAA8B,IAAI,CAAC;QAG5D,8BAAyB,GAAG,EAAE,CAAC;QAM/B,oCAA+B,GAAG,KAAK,CAAC;QAGxC,gCAA2B,GAAwB,IAAI,CAAC;QAG/C,qCAAgC,GAAG,IAAI,YAAY,EAAK,CAAC;QAEzD,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAE/B,WAAM,GAAG,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC;IAOtC,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;IAC/D,CAAC;IAED,IAAI,QAAQ;QACR,QAAQ,IAAI,CAAC,yBAAyB,EAAE;YACpC,KAAK,OAAO;gBACR,OAAO,IAAI,IAAI,CAAC,yBAAyB,GAAG,CAAC;YACjD,KAAK,QAAQ;gBACT,OAAO,IAAI,IAAI,CAAC,yBAAyB,GAAG,CAAC;YACjD,KAAK,cAAc;gBACf,OAAO,KAAK,IAAI,CAAC,yBAAyB,IAAI,CAAC;YACnD;gBACI,OAAO,IAAI,CAAC,yBAAyB,CAAC;SAC7C;IACL,CAAC;IAED,IAAI,QAAQ;QACR,OAAO,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC;IAC9C,CAAC;IAED,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,yBAAyB,KAAK,QAAQ,CAAC;IACvD,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,aAAa,CAAC,KAAQ;QAClB,IAAI,CAAC,0BAA0B,GAAG,KAAK,CAAC;QACxC,IAAI,CAAC,gCAAgC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;IAED,SAAS,CAAC,KAAc;QACpB,gCAAgC;QAChC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAEnC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;IAC5C,CAAC;IAEO,WAAW,CAAC,MAAc;QAC9B,MAAM,aAAa,GAAuB,MAAM,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;QACjF,MAAM,uBAAuB,GACzB,MAAM,CAAC,GAAG,IAAI,CAAC,yBAAyB,GAAG,iBAAiB,EAAE,CAAC,CAAC;QAEpE,IAAI,CAAC,aAAa,IAAI,CAAC,uBAAuB,EAAE;YAC5C,OAAO;SACV;QAED,MAAM,KAAK,GACP,CAAC,CAAC,uBAAuB,IAAI,IAAI,CAAC,2BAA2B;YACzD,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,uBAAiC,CAAC;YACrE,CAAC,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;QAExC,IAAI,CAAC,aAAa,CAAC,KAAU,CAAC,CAAC;IACnC,CAAC;IAEO,aAAa,CAAC,KAA2C;QAC7D,MAAM,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;QAE/D,MAAM,qBAAqB,GAAG,KAAK,YAAY,MAAM,CAAC;QACtD,MAAM,aAAa,GACf,qBAAqB,IAAI,IAAI,CAAC,2BAA2B;YACrD,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,OAAO,CAAC,KAAU,CAAC;YACtD,CAAC,CAAC,KAAK,CAAC;QAEhB,MAAM,MAAM,GAAG,qBAAqB,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,MAAM,QAAQ,GAAG,IAAI,CAAC,yBAAyB,GAAG,MAAM,CAAC;QAEzD,IAAI,CAAC,WAAW,mCACT,IAAI,CAAC,WAAW,KACnB,CAAC,QAAQ,CAAC,EAAE,aAAa,GAC5B,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC;IACtC,CAAC;;2IAhHQ,6CAA6C,kBA6B1C,WAAW,aACX,QAAQ,aACR,cAAc,aACd,aAAa;+HAhChB,6CAA6C;4FAA7C,6CAA6C;kBAJzD,SAAS;mBAAC;oBACP,QAAQ,EAAE,wCAAwC;oBAClD,QAAQ,EAAE,uBAAuB;iBACpC;;0BA8BQ,MAAM;2BAAC,WAAW;;0BAClB,MAAM;2BAAC,QAAQ;;0BACf,MAAM;2BAAC,cAAc;;0BACrB,MAAM;2BAAC,aAAa;4CA5BzB,yBAAyB;sBADxB,KAAK;gBAIN,yBAAyB;sBADxB,KAAK;gBAIN,yBAAyB;sBADxB,KAAK;gBAIN,0BAA0B;sBADzB,KAAK;gBAIN,+BAA+B;sBAD9B,KAAK;gBAIN,2BAA2B;sBAD1B,KAAK;gBAIG,gCAAgC;sBADxC,MAAM","sourcesContent":["import {Location} from '@angular/common';\nimport {\n    Directive,\n    EventEmitter,\n    Inject,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    TemplateRef,\n} from '@angular/core';\nimport {ActivatedRoute, Params, UrlSerializer} from '@angular/router';\nimport {BehaviorSubject, Subject} from 'rxjs';\n\nimport {tuiCoerceValue} from '../../utils/coerce-value';\n\nconst SERIALIZED_SUFFIX = '$';\n\nexport type DocumentationPropertyType = 'input-output' | 'input' | 'output' | null;\n\n// @bad TODO: refactor output and value sync\n@Directive({\n    selector: 'ng-template[documentationPropertyName]',\n    exportAs: 'documentationProperty',\n})\nexport class TuiDocDocumentationPropertyConnectorDirective<T>\n    implements OnInit, OnChanges\n{\n    @Input()\n    documentationPropertyName = '';\n\n    @Input()\n    documentationPropertyMode: DocumentationPropertyType = null;\n\n    @Input()\n    documentationPropertyType = '';\n\n    @Input()\n    documentationPropertyValue!: T;\n\n    @Input()\n    documentationPropertyDeprecated = false;\n\n    @Input()\n    documentationPropertyValues: readonly T[] | null = null;\n\n    @Output()\n    readonly documentationPropertyValueChange = new EventEmitter<T>();\n\n    readonly changed$ = new Subject<void>();\n\n    readonly emits$ = new BehaviorSubject(1);\n\n    constructor(\n        @Inject(TemplateRef) readonly template: TemplateRef<Record<string, unknown>>,\n        @Inject(Location) private readonly locationRef: Location,\n        @Inject(ActivatedRoute) private readonly activatedRoute: ActivatedRoute,\n        @Inject(UrlSerializer) private readonly urlSerializer: UrlSerializer,\n    ) {}\n\n    ngOnInit(): void {\n        this.parseParams(this.activatedRoute.snapshot.queryParams);\n    }\n\n    get attrName(): string {\n        switch (this.documentationPropertyMode) {\n            case 'input':\n                return `[${this.documentationPropertyName}]`;\n            case 'output':\n                return `(${this.documentationPropertyName})`;\n            case 'input-output':\n                return `[(${this.documentationPropertyName})]`;\n            default:\n                return this.documentationPropertyName;\n        }\n    }\n\n    get hasItems(): boolean {\n        return !!this.documentationPropertyValues;\n    }\n\n    get shouldShowValues(): boolean {\n        return this.documentationPropertyMode !== 'output';\n    }\n\n    ngOnChanges(): void {\n        this.changed$.next();\n    }\n\n    onValueChange(value: T): void {\n        this.documentationPropertyValue = value;\n        this.documentationPropertyValueChange.emit(value);\n        this.setQueryParam(value);\n    }\n\n    emitEvent(event: unknown): void {\n        // For more convenient debugging\n        console.info(this.attrName, event);\n\n        this.emits$.next(this.emits$.value + 1);\n    }\n\n    private parseParams(params: Params): void {\n        const propertyValue: string | undefined = params[this.documentationPropertyName];\n        const propertyValueWithSuffix: number | string | undefined =\n            params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`];\n\n        if (!propertyValue && !propertyValueWithSuffix) {\n            return;\n        }\n\n        const value =\n            !!propertyValueWithSuffix && this.documentationPropertyValues\n                ? this.documentationPropertyValues[propertyValueWithSuffix as number]\n                : tuiCoerceValue(propertyValue);\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.documentationPropertyValues\n                ? this.documentationPropertyValues.indexOf(value as T)\n                : value;\n\n        const suffix = isValueAvailableByKey ? SERIALIZED_SUFFIX : '';\n        const propName = this.documentationPropertyName + suffix;\n\n        tree.queryParams = {\n            ...tree.queryParams,\n            [propName]: computedValue,\n        };\n\n        this.locationRef.go(String(tree));\n    }\n}\n"]}
@@ -33,7 +33,7 @@ export class TuiDocDocumentationComponent {
33
33
  this.destroy$ = destroy$;
34
34
  this.getColor = getColor;
35
35
  this.getOpacity = getOpacity;
36
- this.heading = ``;
36
+ this.heading = '';
37
37
  this.showValues = true;
38
38
  this.isAPI = false;
39
39
  this.propertiesConnectors = EMPTY_QUERY;
@@ -49,17 +49,17 @@ export class TuiDocDocumentationComponent {
49
49
  return this.isAPI ? this.texts[0] : this.texts[1];
50
50
  }
51
51
  onColorChange(connector, color) {
52
- const opacity = this.getOpacity.transform(connector.documentationPropertyValue || ``);
52
+ const opacity = this.getOpacity.transform(connector.documentationPropertyValue || '');
53
53
  if (opacity === 100) {
54
54
  connector.onValueChange(color);
55
55
  return;
56
56
  }
57
- const rgb = tuiHexToRgb(color).join(`, `);
57
+ const rgb = tuiHexToRgb(color).join(', ');
58
58
  const result = `rgba(${rgb}, ${opacity / 100})`;
59
59
  connector.onValueChange(result);
60
60
  }
61
61
  onOpacityChange(connector, opacity) {
62
- const hex = this.getColor.transform(connector.documentationPropertyValue || ``);
62
+ const hex = this.getColor.transform(connector.documentationPropertyValue || '');
63
63
  const rgb = tuiHexToRgb(hex);
64
64
  const result = `rgba(${rgb}, ${opacity / 100})`;
65
65
  connector.onValueChange(result);
@@ -67,20 +67,20 @@ export class TuiDocDocumentationComponent {
67
67
  }
68
68
  TuiDocDocumentationComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDocumentationComponent, deps: [{ token: ChangeDetectorRef }, { token: TUI_DOC_DOCUMENTATION_TEXTS }, { token: TUI_DOC_EXCLUDED_PROPERTIES }, { token: TuiDestroyService, self: true }, { token: TuiGetColorPipe }, { token: TuiGetOpacityPipe }], target: i0.ɵɵFactoryTarget.Component });
69
69
  TuiDocDocumentationComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiDocDocumentationComponent, selector: "tui-doc-documentation", inputs: { heading: "heading", showValues: "showValues", isAPI: "isAPI" }, providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService], queries: [{ propertyName: "propertiesConnectors", predicate: TuiDocDocumentationPropertyConnectorDirective }], ngImport: i0, template: "<h1\n *ngIf=\"heading\"\n class=\"t-heading\"\n>\n {{ heading }}\n</h1>\n<ng-content></ng-content>\n<table class=\"t-table\">\n <tr class=\"t-row t-row_header\">\n <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n <th class=\"t-th\">{{ type }}</th>\n <th\n *ngIf=\"showValues && !isAPI\"\n class=\"t-th t-cell t-th_value\"\n >\n {{ texts[3] }}\n </th>\n </tr>\n <tr\n *ngFor=\"let propertyConnector of $any(propertiesConnectors) | tuiFilter : matcher : excludedProperties\"\n class=\"t-row\"\n [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n >\n <td class=\"t-cell\">\n <div\n automation-id=\"tui-documentation__property-name\"\n class=\"t-property\"\n >\n {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n <tui-badge\n *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n size=\"s\"\n value=\"Optional\"\n ></tui-badge>\n </div>\n <span\n *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n class=\"t-deprecated-label\"\n >\n deprecated\n </span>\n <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n </td>\n <td class=\"t-cell\">\n <span class=\"type\">\n {{ propertyConnector.documentationPropertyType }}\n <tui-tooltip\n *ngIf=\"propertyConnector.documentationPropertyType | tuiShowContentTooltip\"\n [describeId]=\"propertyConnector.attrName\"\n [content]=\"content\"\n >\n <ng-template #content>\n {{ texts[4] }}\n <a\n tuiLink\n tuiMode=\"onDark\"\n target=\"_blank\"\n href=\"https://github.com/tinkoff/ng-polymorpheus\"\n >\n <code>ng-polymorpheus</code>\n </a>\n </ng-template>\n </tui-tooltip>\n </span>\n </td>\n <td\n *ngIf=\"showValues\"\n class=\"t-cell t-cell_value\"\n >\n <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n <tui-select\n *ngIf=\"propertyConnector.hasItems; else noItems\"\n tuiTextfieldSize=\"m\"\n tuiDropdownLimitWidth=\"min\"\n [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n [tuiTextfieldLabelOutside]=\"true\"\n [nativeId]=\"propertyConnector.attrName\"\n [valueContent]=\"selectContent\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n >\n <code class=\"t-exception\">null</code>\n <tui-data-list-wrapper\n *tuiDataList\n [items]=\"propertyConnector.documentationPropertyValues\"\n [itemContent]=\"selectContent\"\n ></tui-data-list-wrapper>\n </tui-select>\n <ng-template\n #selectContent\n let-data\n >\n <code>{{ data | tuiInspectAny }}</code>\n </ng-template>\n\n <ng-template #noItems>\n <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n <tui-toggle\n *ngSwitchCase=\"'boolean'\"\n size=\"l\"\n [nativeId]=\"propertyConnector.attrName\"\n [showIcons]=\"true\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n ></tui-toggle>\n\n <tui-primitive-textfield\n *ngSwitchCase=\"'string'\"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [tuiTextfieldLabelOutside]=\"true\"\n [tuiTextfieldCleaner]=\"true\"\n [value]=\"propertyConnector.documentationPropertyValue || ''\"\n (valueChange)=\"propertyConnector.onValueChange($event)\"\n ></tui-primitive-textfield>\n\n <div\n *ngSwitchCase=\"'color'\"\n tuiGroup\n >\n <tui-primitive-textfield\n tuiTextfieldSize=\"m\"\n [attr.id]=\"propertyConnector.attrName\"\n [tuiTextfieldLabelOutside]=\"true\"\n [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n (valueChange)=\"onColorChange(propertyConnector, $event)\"\n >\n <input\n tuiTextfield\n type=\"text\"\n />\n </tui-primitive-textfield>\n <tui-input-count\n tuiTextfieldSize=\"m\"\n [max]=\"100\"\n [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n >\n Opacity\n </tui-input-count>\n </div>\n\n <tui-input-count\n *ngSwitchCase=\"'number'\"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [tuiTextfieldLabelOutside]=\"true\"\n [ngModel]=\"propertyConnector.documentationPropertyValue\"\n (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n ></tui-input-count>\n\n <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n <tui-primitive-textfield\n *ngIf=\"\n propertyConnector.documentationPropertyValue | tuiIsPrimitivePolymorpheusContentPipe\n \"\n tuiTextfieldSize=\"m\"\n [nativeId]=\"propertyConnector.attrName\"\n [tuiTextfieldLabelOutside]=\"true\"\n [tuiTextfieldCleaner]=\"true\"\n [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n (valueChange)=\"propertyConnector.onValueChange($event)\"\n >\n Default content\n </tui-primitive-textfield>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-template #elseEmitter>\n <tui-notification\n class=\"t-output\"\n [@emitEvent]=\"propertyConnector.emits$ | async\"\n >\n Emit!\n </tui-notification>\n </ng-template>\n </td>\n </tr>\n</table>\n", styles: [":host{display:block;min-width:100%}.t-table{width:100%;table-layout:fixed}.t-row:not(:last-child){border-bottom:1px solid var(--tui-base-03)}:host-context(tui-root._mobile) .t-row{display:flex;flex-wrap:wrap}:host-context(tui-root._mobile) .t-row_header{display:none}.t-cell{padding:1rem 1rem .875rem}.t-cell:first-child{padding-left:0}.t-cell:last-child{padding-right:0}.t-cell_prop{width:40%}.t-cell_value{text-align:right}:host-context(tui-root._mobile) .t-cell{width:100%;height:auto;padding:.5rem 0;text-align:left}.t-th{padding:.5rem 1rem;color:var(--tui-text-02);font-weight:normal;text-align:left}.t-th_value{max-width:20rem;text-align:right}:host-context(tui-root._mobile) .t-th_value{width:9.375rem}.t-property{font:var(--tui-font-text-m);margin-bottom:.25rem;font-family:monospace;color:#8f75d1}:host-context(tui-root._mobile) .t-property{padding:.5rem 0}.t-type{font-family:monospace}.t-deprecated{background-color:var(--tui-error-bg);box-shadow:-1rem 0 var(--tui-error-bg),1rem 0 var(--tui-error-bg)}.t-deprecated-label{margin-right:.125rem;color:var(--tui-error-fill)}.t-exception{display:block;width:-webkit-max-content;width:-moz-max-content;width:max-content}.t-output{text-align:left;opacity:0}.t-heading{font:var(--tui-font-heading-4)}\n"], components: [{ type: i1.TuiBadgeComponent, selector: "tui-badge", inputs: ["value", "size", "status", "hoverable"] }, { type: i2.TuiTooltipComponent, selector: "tui-tooltip", inputs: ["content", "direction", "appearance", "showDelay", "hideDelay", "describeId"] }, { type: i2.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { type: i1.TuiSelectComponent, selector: "tui-select", inputs: ["stringify", "identityMatcher", "valueContent"] }, { type: i1.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }, { type: i1.TuiToggleComponent, selector: "tui-toggle", inputs: ["singleColor", "showIcons", "showLoader", "size"] }, { type: i2.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }, { type: i2.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }, { type: i1.TuiInputCountComponent, selector: "tui-input-count", inputs: ["step", "min", "max", "hideButtons", "prefix", "postfix"] }, { type: i2.TuiNotificationComponent, selector: "tui-notification", inputs: ["hasIcon", "status"], outputs: ["close"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i2.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { type: i1.TuiSelectDirective, selector: "tui-select" }, { type: i2.TuiTextfieldSizeDirective, selector: "[tuiTextfieldSize]", inputs: ["tuiTextfieldSize"] }, { type: i2.TuiDropdownOptionsDirective, selector: "[tuiDropdownAlign], [tuiDropdownDirection], [tuiDropdownLimitWidth], [tuiDropdownMinHeight], [tuiDropdownMaxHeight], [tuiDropdownOffset]", inputs: ["tuiDropdownAlign", "tuiDropdownDirection", "tuiDropdownLimitWidth", "tuiDropdownMinHeight", "tuiDropdownMaxHeight", "tuiDropdownOffset"] }, { type: i2.TuiTextfieldCleanerDirective, selector: "[tuiTextfieldCleaner]", inputs: ["tuiTextfieldCleaner"] }, { type: i2.TuiTextfieldLabelOutsideDirective, selector: "[tuiTextfieldLabelOutside]", inputs: ["tuiTextfieldLabelOutside"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { type: i2.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i2.TuiGroupDirective, selector: "[tuiGroup]:not(ng-container)", inputs: ["orientation", "adaptive", "collapsed", "rounded", "size"] }, { type: i5.TuiInputOpacityDirective, selector: "[tuiInputOpacity]", inputs: ["tuiInputOpacity"] }, { type: i1.TuiInputCountDirective, selector: "tui-input-count" }], pipes: { "tuiFilter": i6.TuiFilterPipe, "tuiStripOptionalPipe": i7.TuiStripOptionalPipe, "tuiIsOptionalPipe": i8.TuiIsOptionalPipe, "tuiShowContentTooltip": i9.TuiShowContentTooltip, "tuiShowCleanerPipe": i10.TuiShowCleanerPipe, "tuiInspectAny": i11.TuiInspectPipe, "tuiGetOpacity": i12.TuiGetOpacityPipe, "tuiGetColorPipe": i13.TuiGetColorPipe, "tuiIsPrimitivePolymorpheusContentPipe": i14.TuiIsPrimitivePolymorpheusContentPipe, "async": i3.AsyncPipe }, animations: [
70
- trigger(`emitEvent`, [
71
- transition(`:increment`, [style({ opacity: 1 }), animate(`500ms ease-in`)]),
70
+ trigger('emitEvent', [
71
+ transition(':increment', [style({ opacity: 1 }), animate('500ms ease-in')]),
72
72
  ]),
73
73
  ], changeDetection: i0.ChangeDetectionStrategy.OnPush });
74
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiDocDocumentationComponent, decorators: [{
75
75
  type: Component,
76
76
  args: [{
77
- selector: `tui-doc-documentation`,
78
- templateUrl: `./documentation.template.html`,
79
- styleUrls: [`./documentation.style.less`],
77
+ selector: 'tui-doc-documentation',
78
+ templateUrl: './documentation.template.html',
79
+ styleUrls: ['./documentation.style.less'],
80
80
  changeDetection: ChangeDetectionStrategy.OnPush,
81
81
  animations: [
82
- trigger(`emitEvent`, [
83
- transition(`:increment`, [style({ opacity: 1 }), animate(`500ms ease-in`)]),
82
+ trigger('emitEvent', [
83
+ transition(':increment', [style({ opacity: 1 }), animate('500ms ease-in')]),
84
84
  ]),
85
85
  ],
86
86
  providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
115
115
  type: ContentChildren,
116
116
  args: [TuiDocDocumentationPropertyConnectorDirective]
117
117
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation.component.ts","../../../../../projects/addon-doc/src/components/documentation/documentation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {animate, style, transition, trigger} from '@angular/animations';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n    Self,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiDestroyService,\n    tuiHexToRgb,\n    tuiItemsQueryListObservable,\n    TuiMatcher,\n    tuiWatch,\n} from '@taiga-ui/cdk';\nimport {merge} from 'rxjs';\nimport {switchMap, takeUntil} from 'rxjs/operators';\n\nimport {TUI_DOC_EXCLUDED_PROPERTIES} from '../../tokens/excluded-properties';\nimport {TUI_DOC_DOCUMENTATION_TEXTS} from '../../tokens/i18n';\nimport {TuiDocDocumentationPropertyConnectorDirective} from './documentation-property-connector.directive';\nimport {TuiGetOpacityPipe} from './pipes/opacity.pipe';\nimport {TuiGetColorPipe} from './pipes/сolor.pipe';\n\n// @bad TODO subscribe propertiesConnectors changes\n// @bad TODO refactor to make more flexible\n@Component({\n    selector: `tui-doc-documentation`,\n    templateUrl: `./documentation.template.html`,\n    styleUrls: [`./documentation.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger(`emitEvent`, [\n            transition(`:increment`, [style({opacity: 1}), animate(`500ms ease-in`)]),\n        ]),\n    ],\n    providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],\n})\nexport class TuiDocDocumentationComponent implements AfterContentInit {\n    @Input()\n    heading = ``;\n\n    @Input()\n    showValues = true;\n\n    @Input()\n    isAPI = false;\n\n    @ContentChildren(TuiDocDocumentationPropertyConnectorDirective)\n    propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>> =\n        EMPTY_QUERY;\n\n    activeItemIndex = 0;\n\n    constructor(\n        @Inject(ChangeDetectorRef) private readonly changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_DOC_DOCUMENTATION_TEXTS)\n        readonly texts: [string, string, string, string, string],\n        @Inject(TUI_DOC_EXCLUDED_PROPERTIES)\n        readonly excludedProperties: Set<string>,\n        @Self()\n        @Inject(TuiDestroyService)\n        private readonly destroy$: TuiDestroyService,\n        @Inject(TuiGetColorPipe)\n        private readonly getColor: TuiGetColorPipe,\n        @Inject(TuiGetOpacityPipe)\n        private readonly getOpacity: TuiGetOpacityPipe,\n    ) {}\n\n    ngAfterContentInit(): void {\n        tuiItemsQueryListObservable(this.propertiesConnectors)\n            .pipe(\n                switchMap(items => merge(...items.map(({changed$}) => changed$))),\n                tuiWatch(this.changeDetectorRef),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    get type(): string {\n        return this.isAPI ? this.texts[0] : this.texts[1];\n    }\n\n    matcher: TuiMatcher<TuiDocDocumentationPropertyConnectorDirective<any>> = (\n        item: TuiDocDocumentationPropertyConnectorDirective<any>,\n        exclusions: Set<string>,\n    ) => !exclusions.has(item.documentationPropertyName);\n\n    onColorChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        color: string,\n    ): void {\n        const opacity = this.getOpacity.transform(\n            connector.documentationPropertyValue || ``,\n        );\n\n        if (opacity === 100) {\n            connector.onValueChange(color);\n\n            return;\n        }\n\n        const rgb = tuiHexToRgb(color).join(`, `);\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n\n    onOpacityChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        opacity: number,\n    ): void {\n        const hex = this.getColor.transform(connector.documentationPropertyValue || ``);\n        const rgb = tuiHexToRgb(hex);\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n}\n","<h1\n    *ngIf=\"heading\"\n    class=\"t-heading\"\n>\n    {{ heading }}\n</h1>\n<ng-content></ng-content>\n<table class=\"t-table\">\n    <tr class=\"t-row t-row_header\">\n        <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n        <th class=\"t-th\">{{ type }}</th>\n        <th\n            *ngIf=\"showValues && !isAPI\"\n            class=\"t-th t-cell t-th_value\"\n        >\n            {{ texts[3] }}\n        </th>\n    </tr>\n    <tr\n        *ngFor=\"let propertyConnector of $any(propertiesConnectors) | tuiFilter : matcher : excludedProperties\"\n        class=\"t-row\"\n        [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n    >\n        <td class=\"t-cell\">\n            <div\n                automation-id=\"tui-documentation__property-name\"\n                class=\"t-property\"\n            >\n                {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n                <tui-badge\n                    *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n                    size=\"s\"\n                    value=\"Optional\"\n                ></tui-badge>\n            </div>\n            <span\n                *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n                class=\"t-deprecated-label\"\n            >\n                deprecated\n            </span>\n            <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n        </td>\n        <td class=\"t-cell\">\n            <span class=\"type\">\n                {{ propertyConnector.documentationPropertyType }}\n                <tui-tooltip\n                    *ngIf=\"propertyConnector.documentationPropertyType | tuiShowContentTooltip\"\n                    [describeId]=\"propertyConnector.attrName\"\n                    [content]=\"content\"\n                >\n                    <ng-template #content>\n                        {{ texts[4] }}\n                        <a\n                            tuiLink\n                            tuiMode=\"onDark\"\n                            target=\"_blank\"\n                            href=\"https://github.com/tinkoff/ng-polymorpheus\"\n                        >\n                            <code>ng-polymorpheus</code>\n                        </a>\n                    </ng-template>\n                </tui-tooltip>\n            </span>\n        </td>\n        <td\n            *ngIf=\"showValues\"\n            class=\"t-cell t-cell_value\"\n        >\n            <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n                <tui-select\n                    *ngIf=\"propertyConnector.hasItems; else noItems\"\n                    tuiTextfieldSize=\"m\"\n                    tuiDropdownLimitWidth=\"min\"\n                    [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n                    [tuiTextfieldLabelOutside]=\"true\"\n                    [nativeId]=\"propertyConnector.attrName\"\n                    [valueContent]=\"selectContent\"\n                    [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                    (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                >\n                    <code class=\"t-exception\">null</code>\n                    <tui-data-list-wrapper\n                        *tuiDataList\n                        [items]=\"propertyConnector.documentationPropertyValues\"\n                        [itemContent]=\"selectContent\"\n                    ></tui-data-list-wrapper>\n                </tui-select>\n                <ng-template\n                    #selectContent\n                    let-data\n                >\n                    <code>{{ data | tuiInspectAny }}</code>\n                </ng-template>\n\n                <ng-template #noItems>\n                    <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n                        <tui-toggle\n                            *ngSwitchCase=\"'boolean'\"\n                            size=\"l\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [showIcons]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-toggle>\n\n                        <tui-primitive-textfield\n                            *ngSwitchCase=\"'string'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [tuiTextfieldCleaner]=\"true\"\n                            [value]=\"propertyConnector.documentationPropertyValue || ''\"\n                            (valueChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-primitive-textfield>\n\n                        <div\n                            *ngSwitchCase=\"'color'\"\n                            tuiGroup\n                        >\n                            <tui-primitive-textfield\n                                tuiTextfieldSize=\"m\"\n                                [attr.id]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n                                (valueChange)=\"onColorChange(propertyConnector, $event)\"\n                            >\n                                <input\n                                    tuiTextfield\n                                    type=\"text\"\n                                />\n                            </tui-primitive-textfield>\n                            <tui-input-count\n                                tuiTextfieldSize=\"m\"\n                                [max]=\"100\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n                            >\n                                Opacity\n                            </tui-input-count>\n                        </div>\n\n                        <tui-input-count\n                            *ngSwitchCase=\"'number'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-input-count>\n\n                        <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n                            <tui-primitive-textfield\n                                *ngIf=\"\n                                    propertyConnector.documentationPropertyValue | tuiIsPrimitivePolymorpheusContentPipe\n                                \"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiTextfieldCleaner]=\"true\"\n                                [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n                                (valueChange)=\"propertyConnector.onValueChange($event)\"\n                            >\n                                Default content\n                            </tui-primitive-textfield>\n                        </ng-container>\n                    </ng-container>\n                </ng-template>\n            </ng-container>\n\n            <ng-template #elseEmitter>\n                <tui-notification\n                    class=\"t-output\"\n                    [@emitEvent]=\"propertyConnector.emits$ | async\"\n                >\n                    Emit!\n                </tui-notification>\n            </ng-template>\n        </td>\n    </tr>\n</table>\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation.component.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/src/components/documentation/documentation.component.ts","../../../../../projects/addon-doc/src/components/documentation/documentation.template.html"],"names":[],"mappings":"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","sourcesContent":["import {animate, style, transition, trigger} from '@angular/animations';\nimport {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    Inject,\n    Input,\n    QueryList,\n    Self,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiDestroyService,\n    tuiHexToRgb,\n    tuiItemsQueryListObservable,\n    TuiMatcher,\n    tuiWatch,\n} from '@taiga-ui/cdk';\nimport {merge} from 'rxjs';\nimport {switchMap, takeUntil} from 'rxjs/operators';\n\nimport {TUI_DOC_EXCLUDED_PROPERTIES} from '../../tokens/excluded-properties';\nimport {TUI_DOC_DOCUMENTATION_TEXTS} from '../../tokens/i18n';\nimport {TuiDocDocumentationPropertyConnectorDirective} from './documentation-property-connector.directive';\nimport {TuiGetOpacityPipe} from './pipes/opacity.pipe';\nimport {TuiGetColorPipe} from './pipes/сolor.pipe';\n\n// @bad TODO subscribe propertiesConnectors changes\n// @bad TODO refactor to make more flexible\n@Component({\n    selector: 'tui-doc-documentation',\n    templateUrl: './documentation.template.html',\n    styleUrls: ['./documentation.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [\n        trigger('emitEvent', [\n            transition(':increment', [style({opacity: 1}), animate('500ms ease-in')]),\n        ]),\n    ],\n    providers: [TuiGetColorPipe, TuiGetOpacityPipe, TuiDestroyService],\n})\nexport class TuiDocDocumentationComponent implements AfterContentInit {\n    @Input()\n    heading = '';\n\n    @Input()\n    showValues = true;\n\n    @Input()\n    isAPI = false;\n\n    @ContentChildren(TuiDocDocumentationPropertyConnectorDirective)\n    propertiesConnectors: QueryList<TuiDocDocumentationPropertyConnectorDirective<any>> =\n        EMPTY_QUERY;\n\n    activeItemIndex = 0;\n\n    constructor(\n        @Inject(ChangeDetectorRef) private readonly changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_DOC_DOCUMENTATION_TEXTS)\n        readonly texts: [string, string, string, string, string],\n        @Inject(TUI_DOC_EXCLUDED_PROPERTIES)\n        readonly excludedProperties: Set<string>,\n        @Self()\n        @Inject(TuiDestroyService)\n        private readonly destroy$: TuiDestroyService,\n        @Inject(TuiGetColorPipe)\n        private readonly getColor: TuiGetColorPipe,\n        @Inject(TuiGetOpacityPipe)\n        private readonly getOpacity: TuiGetOpacityPipe,\n    ) {}\n\n    ngAfterContentInit(): void {\n        tuiItemsQueryListObservable(this.propertiesConnectors)\n            .pipe(\n                switchMap(items => merge(...items.map(({changed$}) => changed$))),\n                tuiWatch(this.changeDetectorRef),\n                takeUntil(this.destroy$),\n            )\n            .subscribe();\n    }\n\n    get type(): string {\n        return this.isAPI ? this.texts[0] : this.texts[1];\n    }\n\n    matcher: TuiMatcher<TuiDocDocumentationPropertyConnectorDirective<any>> = (\n        item: TuiDocDocumentationPropertyConnectorDirective<any>,\n        exclusions: Set<string>,\n    ) => !exclusions.has(item.documentationPropertyName);\n\n    onColorChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        color: string,\n    ): void {\n        const opacity = this.getOpacity.transform(\n            connector.documentationPropertyValue || '',\n        );\n\n        if (opacity === 100) {\n            connector.onValueChange(color);\n\n            return;\n        }\n\n        const rgb = tuiHexToRgb(color).join(', ');\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n\n    onOpacityChange(\n        connector: TuiDocDocumentationPropertyConnectorDirective<string>,\n        opacity: number,\n    ): void {\n        const hex = this.getColor.transform(connector.documentationPropertyValue || '');\n        const rgb = tuiHexToRgb(hex);\n        const result = `rgba(${rgb}, ${opacity / 100})`;\n\n        connector.onValueChange(result);\n    }\n}\n","<h1\n    *ngIf=\"heading\"\n    class=\"t-heading\"\n>\n    {{ heading }}\n</h1>\n<ng-content></ng-content>\n<table class=\"t-table\">\n    <tr class=\"t-row t-row_header\">\n        <th class=\"t-th t-cell t-cell_prop\">{{ texts[2] }}</th>\n        <th class=\"t-th\">{{ type }}</th>\n        <th\n            *ngIf=\"showValues && !isAPI\"\n            class=\"t-th t-cell t-th_value\"\n        >\n            {{ texts[3] }}\n        </th>\n    </tr>\n    <tr\n        *ngFor=\"let propertyConnector of $any(propertiesConnectors) | tuiFilter : matcher : excludedProperties\"\n        class=\"t-row\"\n        [class.t-deprecated]=\"propertyConnector.documentationPropertyDeprecated\"\n    >\n        <td class=\"t-cell\">\n            <div\n                automation-id=\"tui-documentation__property-name\"\n                class=\"t-property\"\n            >\n                {{ propertyConnector.attrName | tuiStripOptionalPipe }}\n                <tui-badge\n                    *ngIf=\"propertyConnector.attrName | tuiIsOptionalPipe\"\n                    size=\"s\"\n                    value=\"Optional\"\n                ></tui-badge>\n            </div>\n            <span\n                *ngIf=\"propertyConnector.documentationPropertyDeprecated\"\n                class=\"t-deprecated-label\"\n            >\n                deprecated\n            </span>\n            <ng-container [ngTemplateOutlet]=\"propertyConnector.template\"></ng-container>\n        </td>\n        <td class=\"t-cell\">\n            <span class=\"type\">\n                {{ propertyConnector.documentationPropertyType }}\n                <tui-tooltip\n                    *ngIf=\"propertyConnector.documentationPropertyType | tuiShowContentTooltip\"\n                    [describeId]=\"propertyConnector.attrName\"\n                    [content]=\"content\"\n                >\n                    <ng-template #content>\n                        {{ texts[4] }}\n                        <a\n                            tuiLink\n                            tuiMode=\"onDark\"\n                            target=\"_blank\"\n                            href=\"https://github.com/tinkoff/ng-polymorpheus\"\n                        >\n                            <code>ng-polymorpheus</code>\n                        </a>\n                    </ng-template>\n                </tui-tooltip>\n            </span>\n        </td>\n        <td\n            *ngIf=\"showValues\"\n            class=\"t-cell t-cell_value\"\n        >\n            <ng-container *ngIf=\"propertyConnector.shouldShowValues; else elseEmitter\">\n                <tui-select\n                    *ngIf=\"propertyConnector.hasItems; else noItems\"\n                    tuiTextfieldSize=\"m\"\n                    tuiDropdownLimitWidth=\"min\"\n                    [tuiTextfieldCleaner]=\"propertyConnector.documentationPropertyType | tuiShowCleanerPipe\"\n                    [tuiTextfieldLabelOutside]=\"true\"\n                    [nativeId]=\"propertyConnector.attrName\"\n                    [valueContent]=\"selectContent\"\n                    [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                    (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                >\n                    <code class=\"t-exception\">null</code>\n                    <tui-data-list-wrapper\n                        *tuiDataList\n                        [items]=\"propertyConnector.documentationPropertyValues\"\n                        [itemContent]=\"selectContent\"\n                    ></tui-data-list-wrapper>\n                </tui-select>\n                <ng-template\n                    #selectContent\n                    let-data\n                >\n                    <code>{{ data | tuiInspectAny }}</code>\n                </ng-template>\n\n                <ng-template #noItems>\n                    <ng-container [ngSwitch]=\"propertyConnector.documentationPropertyType\">\n                        <tui-toggle\n                            *ngSwitchCase=\"'boolean'\"\n                            size=\"l\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [showIcons]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-toggle>\n\n                        <tui-primitive-textfield\n                            *ngSwitchCase=\"'string'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [tuiTextfieldCleaner]=\"true\"\n                            [value]=\"propertyConnector.documentationPropertyValue || ''\"\n                            (valueChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-primitive-textfield>\n\n                        <div\n                            *ngSwitchCase=\"'color'\"\n                            tuiGroup\n                        >\n                            <tui-primitive-textfield\n                                tuiTextfieldSize=\"m\"\n                                [attr.id]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiInputOpacity]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                [value]=\"propertyConnector.documentationPropertyValue | tuiGetColorPipe\"\n                                (valueChange)=\"onColorChange(propertyConnector, $event)\"\n                            >\n                                <input\n                                    tuiTextfield\n                                    type=\"text\"\n                                />\n                            </tui-primitive-textfield>\n                            <tui-input-count\n                                tuiTextfieldSize=\"m\"\n                                [max]=\"100\"\n                                [ngModel]=\"propertyConnector.documentationPropertyValue | tuiGetOpacity\"\n                                (ngModelChange)=\"onOpacityChange(propertyConnector, $event)\"\n                            >\n                                Opacity\n                            </tui-input-count>\n                        </div>\n\n                        <tui-input-count\n                            *ngSwitchCase=\"'number'\"\n                            tuiTextfieldSize=\"m\"\n                            [nativeId]=\"propertyConnector.attrName\"\n                            [tuiTextfieldLabelOutside]=\"true\"\n                            [ngModel]=\"propertyConnector.documentationPropertyValue\"\n                            (ngModelChange)=\"propertyConnector.onValueChange($event)\"\n                        ></tui-input-count>\n\n                        <ng-container *ngSwitchCase=\"'PolymorpheusContent'\">\n                            <tui-primitive-textfield\n                                *ngIf=\"\n                                    propertyConnector.documentationPropertyValue | tuiIsPrimitivePolymorpheusContentPipe\n                                \"\n                                tuiTextfieldSize=\"m\"\n                                [nativeId]=\"propertyConnector.attrName\"\n                                [tuiTextfieldLabelOutside]=\"true\"\n                                [tuiTextfieldCleaner]=\"true\"\n                                [value]=\"propertyConnector.documentationPropertyValue.toString()\"\n                                (valueChange)=\"propertyConnector.onValueChange($event)\"\n                            >\n                                Default content\n                            </tui-primitive-textfield>\n                        </ng-container>\n                    </ng-container>\n                </ng-template>\n            </ng-container>\n\n            <ng-template #elseEmitter>\n                <tui-notification\n                    class=\"t-output\"\n                    [@emitEvent]=\"propertyConnector.emits$ | async\"\n                >\n                    Emit!\n                </tui-notification>\n            </ng-template>\n        </td>\n    </tr>\n</table>\n"]}